@font-face{font-family:BintoMediaApp;src:url('/assets/fonts/BintoMedia-Regular.otf') format('opentype'),url('/assets/fonts/BintoMedia-Regular.ttf') format('truetype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:BintoMediaApp;src:url('/assets/fonts/BintoMedia-Bold.otf') format('opentype'),url('/assets/fonts/BintoMedia-Bold.ttf') format('truetype'),url('/assets/fonts/BintoMedia-Regular.otf') format('opentype'),url('/assets/fonts/BintoMedia-Regular.ttf') format('truetype');font-weight:700 900;font-style:normal;font-display:swap}
:root{--yellow:#ffd800;--black:#070707;--ink:#171717;--muted:#697386;--line:#eceff3;--bg:#f5f6f8;--card:#fff;--danger:#b42318}*{box-sizing:border-box}body{margin:0;background:var(--bg);font-family:BintoMediaApp,Arial,Helvetica,sans-serif;color:var(--ink)}a{color:inherit;text-decoration:none}.topbar{background:#050505;color:#fff;min-height:98px;padding:10px 26px;border-bottom:5px solid var(--yellow);display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:nowrap}.brand{display:flex;align-items:center;gap:14px;min-width:360px;white-space:nowrap;flex:0 0 auto}.brand img{height:78px;width:245px;object-fit:contain;object-position:left center;display:block;filter:none}.brand span{font-size:13px;letter-spacing:.42em;text-transform:uppercase;color:var(--yellow);font-weight:800;display:block}.topbar nav{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex:1 1 auto;flex-wrap:wrap;margin:0}.topbar nav a{display:inline-flex;align-items:center;justify-content:center;margin:0;padding:8px 11px;border-radius:999px;font-size:13px;color:#fff;vertical-align:middle;line-height:1.2}.topbar nav a.on,.topbar nav a:hover{background:var(--yellow);color:#000}.profile-link{display:inline-flex;align-items:center}.top-avatar{width:26px;height:26px;border-radius:50%;object-fit:cover;border:2px solid var(--yellow);margin-right:7px;background:#fff;flex:0 0 auto}.profile-link span{display:inline-block;line-height:1.2}.wrap{max-width:1240px;margin:28px auto;padding:0 18px}.hero{background:linear-gradient(135deg,#050505 0%,#242424 65%,#ffd800 65%,#ffd800 100%);color:#fff;border-radius:24px;padding:26px;margin-bottom:22px;box-shadow:0 16px 40px rgba(0,0,0,.12)}.hero h1{margin:0 0 6px;font-size:30px}.hero p{margin:0;color:#ececec}.card{background:var(--card);border:1px solid #eef0f4;border-radius:20px;padding:20px;margin-bottom:20px;box-shadow:0 10px 28px rgba(15,23,42,.06)}.card h2{margin:0 0 14px}.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field{margin-bottom:12px}label{display:block;font-weight:700;margin-bottom:6px;font-size:13px}input,select,textarea{width:100%;border:1px solid #d7dce5;border-radius:12px;padding:11px 12px;background:#fff;font-size:14px;font-family:BintoMediaApp,Arial,Helvetica,sans-serif}textarea{min-height:94px}.btn{display:inline-block;border:0;border-radius:999px;padding:10px 15px;font-weight:800;cursor:pointer;background:#111;color:#fff;margin:2px;font-family:BintoMediaApp,Arial,Helvetica,sans-serif}.btn.primary{background:var(--yellow);color:#000}.btn.alt{background:#111;color:#fff}.btn.light{background:#eef1f5;color:#151515}.btn.danger{background:#fee4e2;color:#912018}.actions{white-space:nowrap}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}.stat{background:#fff;border-radius:18px;padding:18px;border-left:6px solid var(--yellow);box-shadow:0 8px 22px rgba(15,23,42,.06)}.stat b{font-size:24px;display:block;margin-top:5px}table{width:100%;border-collapse:collapse}th,td{padding:11px 9px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}th{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#667085;background:#fbfcfe}.pill{display:inline-block;padding:5px 9px;border-radius:999px;background:#fff7bd;color:#111;font-weight:700;font-size:12px}.alert{padding:12px;border-radius:14px;margin-bottom:15px}.ok{background:#ecfdf3;border:1px solid #abefc6;color:#067647}.err{background:#fff1f0;border:1px solid #fecdca;color:#b42318}.login{min-height:100vh;background:#050505;display:table;width:100%}.login-inner{display:table-cell;vertical-align:middle}.login-card{width:430px;max-width:92%;margin:auto;background:#fff;border-radius:24px;padding:30px;box-shadow:0 20px 80px rgba(0,0,0,.35);border-top:8px solid var(--yellow)}.login-logo-wrap{background:#fff;border:1px solid #eef0f4;border-radius:18px;padding:14px 16px;margin:0 auto 18px;text-align:center}.login-card img.login-logo{max-width:320px;width:100%;height:auto;display:block;margin:0 auto;object-fit:contain}.totals{max-width:430px;margin-left:auto}.remove{background:#fff1f0;color:#b42318;border:0;border-radius:10px;padding:8px 10px;cursor:pointer}.foot{text-align:center;color:#777;font-size:12px;padding:22px}.small{font-size:12px;color:#697386}.right{text-align:right}.currency{font-weight:800;color:#111}@media(max-width:980px){.grid,.grid2,.stats{display:block}.topbar{display:block;padding:10px 18px}.brand{display:block;min-width:0}.brand img{width:220px;max-width:100%;height:auto}.brand span{display:block;margin-top:8px}.topbar nav{display:block;margin-top:12px}.topbar nav a{margin:3px}.profile-link{display:inline-flex}.items{font-size:12px}.hero h1{font-size:24px}}
code{background:#111;color:var(--yellow);border-radius:7px;padding:2px 6px;font-size:12px}.badge{display:inline-block;background:#111;color:var(--yellow);border-radius:999px;padding:8px 12px;font-size:12px;font-weight:700}

/* v23 — hiérarchie typographique renforcée avec les polices uploadées */
h1,h2,h3,.hero h1,.card h2{font-weight:900;letter-spacing:-.02em}
.stat b,.brand span,.btn,th,label,.pill{font-weight:800}
.card h2{font-size:20px}.hero h1{font-size:32px}

/* v24 — utilisation plus nette de la police grasse dans l’administration */
.topbar nav a,.hero h1,.card h2,.stat b,.btn,th,label,.pill,.badge,.currency{font-weight:900}
input,select,textarea,td,p,.small{font-weight:400}
.topbar nav a.on{font-weight:900}

/* v25 — police grasse réellement séparée et visible dans toute l’administration */
@font-face{font-family:BintoMediaAppBold;src:url('/assets/fonts/BintoMedia-Bold.otf') format('opentype'),url('/assets/fonts/BintoMedia-Bold.ttf') format('truetype'),url('/assets/fonts/BintoMedia-Regular.otf') format('opentype'),url('/assets/fonts/BintoMedia-Regular.ttf') format('truetype');font-weight:700;font-style:normal;font-display:swap}
h1,h2,h3,h4,.hero h1,.card h2,.login-card h1,.login-card h2,.topbar nav a,.brand span,.btn,button,th,label,.pill,.badge,.currency,.stat b,.actions a{font-family:BintoMediaAppBold,BintoMediaApp,Arial,Helvetica,sans-serif!important;font-weight:900!important}
.hero h1{font-size:34px;line-height:1.05}.card h2{font-size:21px;line-height:1.2}.login-card h1{font-size:30px;margin:8px 0 8px}.topbar nav a{letter-spacing:.01em}.btn{letter-spacing:.01em}.card h2:after{content:"";display:block;width:46px;height:4px;background:var(--yellow);border-radius:99px;margin-top:8px}.login-card h1:after{content:"";display:block;width:48px;height:4px;background:var(--yellow);border-radius:99px;margin-top:10px}.hero p,.card p,td,input,select,textarea{font-family:BintoMediaApp,Arial,Helvetica,sans-serif!important}.login-logo-wrap{box-shadow:0 12px 30px rgba(15,23,42,.08)}
.checkline{display:block;margin:10px 0;font-family:BintoMediaApp,Arial,Helvetica,sans-serif!important;font-weight:600!important}.meta-preview{max-width:360px;border-radius:16px;border:1px solid #e7eaf0;box-shadow:0 8px 22px rgba(15,23,42,.06);display:block;margin:10px 0;background:#fff}

/* v26 — forçage visuel de la police grasse uploadée */
:root{font-synthesis-weight:none;}
body{font-family:BintoMediaApp,Arial,Helvetica,sans-serif!important;}
.hero h1,.wrap h1,main h1,section.hero h1,.card h2,main h2,main h3,.page-title,.topbar nav a,.brand span,.stat b,.btn,button,th,label,.pill,.badge,.currency,.actions a,strong,b{
  font-family:BintoMediaAppBold,BintoMediaApp,Arial,Helvetica,sans-serif!important;
  font-weight:900!important;
  font-synthesis-weight:none!important;
}
.hero h1,.wrap h1,section.hero h1{letter-spacing:-.015em;text-rendering:geometricPrecision;}
.hero p,.card p,td,input,select,textarea,li,.small{font-family:BintoMediaApp,Arial,Helvetica,sans-serif!important;font-weight:400!important;}


/* v27 — alignement équipe et meilleure visibilité des photos de profil */
.topbar nav{display:block;line-height:34px}.profile-link{padding:6px 10px!important}.top-avatar{width:34px!important;height:34px!important;border-radius:50%;object-fit:cover;border:3px solid var(--yellow);vertical-align:middle;margin-right:8px;box-shadow:0 0 0 2px rgba(255,255,255,.18)}
.team-table{table-layout:fixed}.team-table th,.team-table td{vertical-align:middle!important}.team-table th:nth-child(1){width:24%}.team-table th:nth-child(2){width:22%}.team-table th:nth-child(3){width:13%}.team-table th:nth-child(4){width:13%}.team-table th:nth-child(5){width:28%}.team-profile{display:table;width:100%;min-height:54px}.team-avatar-wrap{display:table-cell;width:58px;vertical-align:middle}.team-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;display:block;border:3px solid var(--yellow);background:#111;box-shadow:0 4px 12px rgba(0,0,0,.14)}.team-avatar-placeholder{width:48px;height:48px;border-radius:50%;display:block;background:#111;color:var(--yellow);text-align:center;line-height:48px;font-family:BintoMediaAppBold,BintoMediaApp,Arial,sans-serif;font-weight:900;border:3px solid var(--yellow)}.team-name{display:table-cell;vertical-align:middle;font-family:BintoMediaAppBold,BintoMediaApp,Arial,sans-serif!important;font-weight:900!important}.team-actions{white-space:nowrap}.team-actions .btn{margin-right:6px}.team-card{padding-bottom:16px}
@media(max-width:980px){.team-table{table-layout:auto}.team-table,.team-table thead,.team-table tbody,.team-table th,.team-table td,.team-table tr{display:block}.team-table thead{display:none}.team-table tr{border-bottom:1px solid var(--line);padding:12px 0}.team-table td{border-bottom:0;padding:8px 0}.team-actions{white-space:normal}.top-avatar{width:32px!important;height:32px!important}}

/* v31 : menu principal */
.brand-kicker, .brand-kicker strong, .topbar .brand-subtitle, .app-brand .brand-subtitle { font-family: var(--font-bold, var(--font-main)) !important; font-weight: 900 !important; }

/* v32 : menu principal */
.brand span.brand-title{font-family:BintoMediaAppBold,BintoMediaApp,Arial,Helvetica,sans-serif!important;font-weight:950!important;color:var(--yellow)!important;text-shadow:0 0 .01px currentColor;}

/* v41 - settings spacing improvements */
.card h2{margin:26px 0 16px;font-size:20px;line-height:1.25}
.card h2:first-child{margin-top:0}
.grid,.grid2{gap:18px 18px}
.field{margin-bottom:18px}
.checkline{margin:16px 0 18px}
.small{display:block;margin-top:8px;line-height:1.5}
.card form > p.small{margin:6px 0 18px}
.meta-preview{margin:14px 0 14px}
.badge{display:inline-block;margin:8px 0 14px}
input[type="file"]{padding:10px 12px;min-height:44px}
button.btn.primary,button.btn.alt{margin-top:8px}
.card form > .grid + .grid,
.card form > .grid2 + .grid,
.card form > .grid + .field,
.card form > .field + h2,
.card form > .grid2 + h2,
.card form > .grid + h2,
.card form > .checkline + .grid{margin-top:6px}

.money-lines{display:block;margin-top:5px}.money-line{display:block;font-size:24px;line-height:1.1;font-family:BintoMediaAppBold,BintoMediaApp,Arial,Helvetica,sans-serif;font-weight:900}.money-line+.money-line{margin-top:4px;font-size:18px}
.inline-form{display:inline-block;margin:0}.inline-form .btn{vertical-align:middle}


/* Animation logo login : version claire vers version sombre */
.login-logo-switch{
  position:relative;
  overflow:hidden;
  min-height:118px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#ffffff;
  transition:background .45s ease, box-shadow .45s ease, transform .45s ease;
}
.login-logo-switch::before{
  content:"";
  position:absolute;
  inset:-40%;
  background:radial-gradient(circle at 50% 50%, rgba(255,216,0,.22), transparent 42%);
  opacity:0;
  transform:scale(.78);
  transition:opacity .45s ease, transform .55s ease;
  pointer-events:none;
}
.login-logo-switch .login-logo{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%) scale(1);
  max-width:320px;
  width:82%;
  height:auto;
  margin:0;
  transition:opacity .45s ease, transform .55s cubic-bezier(.2,.8,.2,1), filter .45s ease;
}
.login-logo-switch .login-logo-light{
  opacity:1;
  filter:none;
}
.login-logo-switch .login-logo-dark{
  opacity:0;
  transform:translate(-50%,-50%) scale(.94);
  filter:blur(2px);
}
.login-logo-switch:hover,
.login-logo-switch:focus-within{
  background:#050505;
  box-shadow:0 16px 38px rgba(0,0,0,.18);
  transform:translateY(-2px);
}
.login-logo-switch:hover::before,
.login-logo-switch:focus-within::before{
  opacity:1;
  transform:scale(1);
}
.login-logo-switch:hover .login-logo-light,
.login-logo-switch:focus-within .login-logo-light{
  opacity:0;
  transform:translate(-50%,-50%) scale(1.06);
  filter:blur(2px);
}
.login-logo-switch:hover .login-logo-dark,
.login-logo-switch:focus-within .login-logo-dark{
  opacity:1;
  transform:translate(-50%,-50%) scale(1);
  filter:none;
}

.login-title{
  text-align:left;
  margin-top:18px;
  margin-bottom:8px;
}
.login-card > .small{
  text-align:left;
}


/* Ajustement v66 : logo login non coupé */
.login-logo-wrap.login-logo-switch{
  min-height:150px;
  padding:24px 22px;
}
.login-logo-switch .login-logo{
  max-width:360px;
  width:88%;
  max-height:112px;
  object-fit:contain;
}
.login-card{
  overflow:visible;
}


/* Espace de travail */
.workspace-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px}
.work-file-card{background:#fff;border:1px solid #e8ebf0;border-radius:18px;padding:16px;box-shadow:0 8px 22px rgba(15,23,42,.06)}
.work-file-card strong{display:block;margin-bottom:6px}
.thread{display:grid;gap:12px;margin-bottom:16px}
.thread-msg{border-radius:18px;padding:14px 16px;border:1px solid #e8ebf0;background:#fff}
.thread-msg strong{display:inline-block;margin-right:8px}
.thread-msg span{font-size:12px;color:#667085}
.thread-msg.admin{border-left:6px solid var(--yellow)}
.thread-msg.client{border-left:6px solid #111;background:#fbfcfe}
.client-topbar{border-bottom-color:#ffd800}
.client-hero{background:linear-gradient(135deg,#050505 0%,#202020 62%,#ffd800 62%,#ffd800 100%)}
.profile-preview{max-width:120px;max-height:120px;border-radius:50%;border:4px solid var(--yellow);object-fit:cover}

.client-topbar .profile-link span{font-weight:900}

.work-preview-thumb{display:block;margin:10px 0;border-radius:14px;overflow:hidden;border:1px solid #e8ebf0;background:#f6f7f9;min-height:120px}
.work-preview-thumb img{display:block;width:100%;height:180px;object-fit:cover}
.work-preview-pdf{display:block;margin:10px 0;padding:18px;border-radius:14px;background:#111;color:#ffd800;font-weight:900;text-align:center}
.notif-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#ff3434;color:#fff;font-size:11px;margin-left:4px}
.notif-list{display:grid;gap:10px}
.notif-item{display:block;border:1px solid #e8ebf0;border-left:6px solid #ddd;border-radius:16px;padding:14px;background:#fff}
.notif-item.unread{border-left-color:#ffd800;background:#fffdf0}
.notif-item span{display:block;color:#667085;font-size:12px;margin-top:4px}


/* Menu admin simplifié avec groupes */
.topbar nav.main-nav{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex:1 1 auto;flex-wrap:wrap;margin:0}
.nav-group{position:relative;display:inline-flex;align-items:center}
.nav-group-btn{border:0;border-radius:999px;background:transparent;color:#fff;padding:8px 11px;font-family:BintoMediaAppBold,BintoMediaApp,Arial,Helvetica,sans-serif;font-weight:900;cursor:pointer;font-size:13px;line-height:1.2}
.nav-group-btn.on,.nav-group:hover .nav-group-btn{background:var(--yellow);color:#000}
.nav-dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:210px;background:#080808;border:1px solid rgba(255,216,0,.35);border-radius:16px;padding:8px;box-shadow:0 18px 40px rgba(0,0,0,.25);display:none;z-index:50}
.nav-group:hover .nav-dropdown,.nav-group:focus-within .nav-dropdown{display:block}
.topbar .nav-dropdown a{display:block;margin:0 0 4px 0;padding:10px 12px;border-radius:12px;color:#fff;white-space:nowrap}
.topbar .nav-dropdown a:hover,.topbar .nav-dropdown a.on{background:var(--yellow);color:#000}
@media(max-width:980px){.topbar nav.main-nav{display:block}.nav-group{display:block}.nav-dropdown{position:static;display:block;margin:4px 0 8px 8px;box-shadow:none}.nav-group-btn{margin:3px}}
.message-template-box{border:1px solid #e8ebf0;background:#fbfcfe;border-radius:16px;padding:14px;margin-bottom:14px}
.message-template-box select{max-width:460px}


/* Chat direct admin/client */
.bcg-chat-widget{position:fixed;right:22px;bottom:22px;z-index:9999;font-family:BintoMediaApp,Arial,Helvetica,sans-serif}
.bcg-chat-toggle{border:0;border-radius:999px;background:#050505;color:#fff;border-bottom:4px solid #ffd800;padding:13px 18px;font-weight:900;box-shadow:0 14px 34px rgba(0,0,0,.25);cursor:pointer}
.bcg-chat-dot{display:inline-block;width:9px;height:9px;border-radius:50%;background:#22c55e;margin-right:8px;box-shadow:0 0 0 4px rgba(34,197,94,.16)}
.bcg-chat-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:999px;background:#ef4444;color:#fff;font-size:11px;margin-left:8px;padding:0 6px}
.bcg-chat-panel{position:absolute;right:0;bottom:58px;width:370px;max-width:calc(100vw - 32px);height:520px;max-height:calc(100vh - 110px);background:#fff;border-radius:22px;box-shadow:0 24px 70px rgba(0,0,0,.28);border:1px solid #e8ebf0;display:none;overflow:hidden}
.bcg-chat-panel.on{display:flex;flex-direction:column}
.bcg-chat-head{background:#050505;color:#fff;border-bottom:5px solid #ffd800;padding:14px 16px;display:flex;align-items:center;justify-content:space-between}
.bcg-chat-head button{border:0;background:transparent;color:#fff;font-size:24px;cursor:pointer;line-height:1}
.bcg-chat-clients{display:flex;gap:6px;overflow-x:auto;padding:8px;background:#f6f7f9;border-bottom:1px solid #e8ebf0}
.bcg-chat-clients button{border:0;border-radius:999px;padding:8px 10px;background:#fff;white-space:nowrap;cursor:pointer;font-weight:800}
.bcg-chat-clients button.on{background:#ffd800;color:#000}
.bcg-chat-clients b{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:999px;background:#ef4444;color:#fff;font-size:10px;margin-left:4px}
.online-dot{display:inline-block;width:8px;height:8px;background:#22c55e;border-radius:50%;margin-right:5px}
.bcg-chat-messages{flex:1;overflow-y:auto;padding:14px;background:#f3f4f6}
.bcg-chat-msg{max-width:82%;margin:0 0 10px 0;padding:10px 12px;border-radius:16px;background:#fff;border:1px solid #e8ebf0}
.bcg-chat-msg.admin{margin-left:auto;background:#050505;color:#fff;border-color:#050505}
.bcg-chat-msg.client{margin-right:auto;background:#fff}
.bcg-chat-msg strong{font-size:12px;display:block;margin-bottom:4px}
.bcg-chat-msg p{margin:0;line-height:1.35;font-size:14px}
.bcg-chat-msg span{display:block;font-size:10px;opacity:.65;margin-top:4px}
.bcg-chat-form{display:flex;gap:8px;padding:10px;border-top:1px solid #e8ebf0;background:#fff}
.bcg-chat-form input{flex:1;border:1px solid #d0d5dd;border-radius:999px;padding:10px 12px}
.bcg-chat-form button{border:0;background:#ffd800;border-radius:999px;font-weight:900;padding:10px 12px;cursor:pointer}
@media(max-width:640px){.bcg-chat-widget{right:12px;bottom:12px}.bcg-chat-panel{width:calc(100vw - 24px);height:70vh}}


/* Notifications visuelles et sonores du chat */
.bcg-chat-widget.has-new-message .bcg-chat-toggle{
  background:#ffd800;
  color:#050505;
  box-shadow:0 0 0 0 rgba(255,216,0,.85), 0 18px 42px rgba(255,216,0,.35);
  animation:bcgChatGlow 1.15s ease-in-out infinite;
}
.bcg-chat-widget.has-new-message .bcg-chat-dot{
  background:#ef4444;
  box-shadow:0 0 0 5px rgba(239,68,68,.22);
}
.bcg-chat-toggle.pulse{
  animation:bcgChatPulse .55s ease-in-out 4;
}
.bcg-chat-count{
  animation:bcgChatBadge .8s ease-in-out infinite alternate;
}
.bcg-chat-clients button.has-unread{
  background:#fff1a6;
  color:#111;
  box-shadow:inset 0 0 0 2px #ffd800;
}
.bcg-chat-msg.incoming{
  animation:bcgIncomingMsg .55s ease;
}
@keyframes bcgChatGlow{
  0%{box-shadow:0 0 0 0 rgba(255,216,0,.85),0 18px 42px rgba(255,216,0,.35)}
  70%{box-shadow:0 0 0 14px rgba(255,216,0,0),0 18px 42px rgba(255,216,0,.35)}
  100%{box-shadow:0 0 0 0 rgba(255,216,0,0),0 18px 42px rgba(255,216,0,.35)}
}
@keyframes bcgChatPulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.08)}
}
@keyframes bcgChatBadge{
  from{transform:scale(1)}
  to{transform:scale(1.18)}
}
@keyframes bcgIncomingMsg{
  from{transform:translateY(8px);opacity:.25}
  to{transform:translateY(0);opacity:1}
}


/* v76 : compteur non lu persistant et alerte renforcée */
.bcg-chat-widget.has-new-message .bcg-chat-toggle{
  position:relative;
  outline:3px solid rgba(255,216,0,.35);
}
.bcg-chat-widget.has-new-message .bcg-chat-toggle::after{
  content:"";
  position:absolute;
  inset:-7px;
  border-radius:999px;
  border:2px solid rgba(255,216,0,.9);
  animation:bcgChatRing 1.2s ease-out infinite;
  pointer-events:none;
}
.bcg-chat-widget.has-new-message .bcg-chat-count{
  display:inline-flex !important;
  background:#ef4444;
  color:#fff;
  font-size:12px;
  min-width:24px;
  height:24px;
  box-shadow:0 0 0 4px rgba(239,68,68,.18);
}
@keyframes bcgChatRing{
  0%{transform:scale(.96);opacity:.9}
  100%{transform:scale(1.18);opacity:0}
}


/* v77 : dates lisibles et invitation chat */
.bcg-chat-msg span{
  font-variant-numeric:tabular-nums;
  letter-spacing:.01em;
}
.bcg-chat-msg.invitation{
  border-color:#ffd800;
  box-shadow:0 0 0 2px rgba(255,216,0,.25);
}
.bcg-chat-widget.has-chat-invitation .bcg-chat-toggle{
  background:#ef4444;
  color:#fff;
  border-bottom-color:#ffd800;
  animation:bcgChatInvite 0.75s ease-in-out infinite;
}
.bcg-chat-widget.has-chat-invitation .bcg-chat-toggle::before{
  content:"Invitation";
  position:absolute;
  right:10px;
  bottom:calc(100% + 8px);
  background:#ef4444;
  color:#fff;
  border-radius:999px;
  padding:6px 10px;
  font-size:11px;
  font-weight:900;
  box-shadow:0 10px 28px rgba(239,68,68,.28);
}
.bcg-chat-invite{
  border:0;
  background:#ffd800;
  color:#111;
  font-weight:900;
  padding:9px 12px;
  cursor:pointer;
  border-bottom:1px solid #e8ebf0;
}
@keyframes bcgChatInvite{
  0%,100%{transform:translateY(0) scale(1)}
  50%{transform:translateY(-3px) scale(1.04)}
}

.login-help{
  margin-top:14px;
  padding:10px 12px;
  border-left:4px solid #ffd800;
  background:#fffbea;
  border-radius:12px;
}

.client-access-request{
  margin-top:18px;
  border:1px solid #e8ebf0;
  border-radius:16px;
  background:#fbfcfe;
  padding:12px 14px;
}
.client-access-request summary{
  cursor:pointer;
  font-family:BintoMediaAppBold,BintoMediaApp,Arial,Helvetica,sans-serif;
  font-weight:900;
}
.client-access-form{
  margin-top:14px;
}


/* v81 : avatars dans le chat */
.bcg-chat-msg{
  display:block;
}
.bcg-chat-msg-row{
  display:flex;
  align-items:flex-start;
  gap:9px;
}
.bcg-chat-msg.admin .bcg-chat-msg-row{
  flex-direction:row-reverse;
}
.bcg-chat-msg-body{
  min-width:0;
  flex:1;
}
.bcg-chat-avatar{
  width:32px;
  height:32px;
  border-radius:50%;
  object-fit:cover;
  flex:0 0 32px;
  border:2px solid #ffd800;
  background:#fff;
}
.bcg-chat-msg.admin .bcg-chat-avatar{
  border-color:#ffd800;
}
.bcg-chat-avatar-fallback{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  font-size:13px;
  color:#111;
}
.bcg-chat-msg.admin .bcg-chat-avatar-fallback{
  background:#ffd800;
}
.bcg-chat-msg.client .bcg-chat-avatar-fallback{
  background:#111;
  color:#ffd800;
}

.file-meta{display:block;margin-top:4px;color:#111;font-weight:900}
.replace-file-box{margin:10px 0;border:1px dashed #d0d5dd;border-radius:14px;padding:10px;background:#fbfcfe}
.replace-file-box summary{cursor:pointer;font-weight:900}


/* v83 : aperçu workspace dans la même page */
.workspace-preview-opened{overflow:hidden}
.workspace-preview-modal[hidden]{display:none}
.workspace-preview-modal{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;padding:24px}
.workspace-preview-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.68);backdrop-filter:blur(3px)}
.workspace-preview-dialog{position:relative;width:min(1180px,96vw);height:min(840px,90vh);background:#fff;border-radius:22px;box-shadow:0 24px 80px rgba(0,0,0,.38);overflow:hidden;border:4px solid #ffd800}
.workspace-preview-dialog iframe{width:100%;height:100%;border:0;background:#fff}
.workspace-preview-close{position:absolute;right:12px;top:10px;z-index:5;width:40px;height:40px;border:0;border-radius:50%;background:#050505;color:#fff;font-size:26px;line-height:1;cursor:pointer}
.work-preview-thumb{display:flex;align-items:center;justify-content:center;margin:10px 0;border-radius:14px;overflow:hidden;border:1px solid #e8ebf0;min-height:180px;background:#f5f5f5;background-image:linear-gradient(45deg,#e7e7e7 25%,transparent 25%),linear-gradient(-45deg,#e7e7e7 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#e7e7e7 75%),linear-gradient(-45deg,transparent 75%,#e7e7e7 75%);background-size:22px 22px;background-position:0 0,0 11px,11px -11px,-11px 0}
.work-preview-thumb img{display:block;width:100%;height:180px;object-fit:contain}

/* v86 : recadrage photo de profil */
.profile-cropper .crop-stage{margin-top:12px;display:inline-block;background:#fff;border:1px solid #e8ebf0;border-radius:18px;padding:14px}
.profile-cropper canvas{display:block;border-radius:16px;cursor:grab;background:#f5f5f5}
.profile-cropper canvas:active{cursor:grabbing}
.crop-controls{display:flex;align-items:center;gap:10px;margin-top:10px}
.crop-controls input{width:180px}
.mini-stats .stat b{font-size:24px}
.bcg-chat-clients em{font-style:normal;font-size:10px;opacity:.65;margin-left:4px}

.bcg-chat-loading,.bcg-chat-empty{padding:18px;text-align:center;color:#667085;font-size:13px}

.profile-cropper .crop-stage[hidden]{display:none !important}
.profile-cropper .crop-stage{margin-top:12px}


/* Binto Media Group edition */
:root{--bmg-red:#ef3129;--bmg-dark:#151515;--bmg-soft:#fff4f3;--bmg-border:#ead7d5;--bmg-blue:#0f6e8d;}
.topbar{background:#fff;border-bottom:1px solid rgba(239,49,41,.18);box-shadow:0 8px 30px rgba(20,20,20,.06)}
.brand img{max-height:48px;width:auto}.brand-title{color:var(--bmg-red);font-weight:900;text-transform:uppercase;letter-spacing:.08em;font-size:12px}.main-nav a.on,.nav-group-btn.on{background:var(--bmg-red);color:#fff}.btn.primary,.btn.alt{background:var(--bmg-red);border-color:var(--bmg-red);color:#fff}.btn.alt{background:#151515;border-color:#151515}.hero{background:linear-gradient(135deg,#ef3129 0%,#ff544c 48%,#fff 48.3%,#fff 100%);color:#151515;border:0;position:relative;overflow:hidden}.hero h1{color:#151515}.hero p{max-width:920px;color:#2d2d2d}.card h2{color:#ef3129}.stat b{color:#ef3129}.pill{background:#fff1ef;color:#b71f19;border:1px solid #ffd1cc}.bmg-media-strip{display:flex;align-items:center;gap:18px;overflow:hidden;padding:14px 0}.bmg-media-strip img{max-height:54px;width:auto;object-fit:contain}.bmg-alert-blue{border-left:4px solid var(--bmg-blue);background:#eef8fb;padding:14px 16px;border-radius:14px}.bmg-payroll-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.bmg-doc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}.bmg-template-card{border:1px solid var(--bmg-border);border-radius:18px;padding:18px;background:#fff}.bmg-table-tight td,.bmg-table-tight th{padding:8px 10px}.bmg-danger{color:#b71f19}.bmg-ok{color:#137333}.bmg-muted{color:#666;font-size:.92em}.login-panel .brand-login img{max-height:115px}.login-panel h1::after{content:'Binto Media Group';display:block;color:#ef3129;font-size:14px;text-transform:uppercase;letter-spacing:.12em;margin-top:8px}

/* v2 BMG — interface recentrée sur la rédaction, les journalistes et la paie */
:root{--bmg-red:#ef3129;--bmg-red-dark:#c51622;--bmg-yellow:#ffe11a;--bmg-ink:#17171d;--bmg-blue:#0d6b8b;--yellow:var(--bmg-yellow);--black:#161618;--bg:#f7f4f2;--card:#fff;--line:#eee2df;--muted:#776b67}
body{background:radial-gradient(circle at 8% 0%,rgba(239,49,41,.12),transparent 32%),linear-gradient(180deg,#fff7f3 0,#f7f4f2 340px,#f7f4f2 100%);color:var(--bmg-ink)}
.topbar{background:linear-gradient(135deg,#ef3129 0%,#d71f2d 56%,#991828 100%);border-bottom:6px solid var(--bmg-yellow);box-shadow:0 18px 36px rgba(97,24,20,.18)}
.brand{min-width:310px}.brand img{height:82px;width:210px;object-fit:contain}.brand span.brand-title{color:#fff!important;letter-spacing:.22em;font-size:11px}.topbar nav a,.nav-group-btn{color:#fff}.topbar nav a.on,.topbar nav a:hover,.nav-group-btn.on,.nav-group:hover .nav-group-btn{background:#fff;color:var(--bmg-red)!important}.nav-dropdown{background:#fff;border:1px solid rgba(239,49,41,.18)}.topbar .nav-dropdown a{color:#301b19}.topbar .nav-dropdown a:hover,.topbar .nav-dropdown a.on{background:var(--bmg-red);color:#fff!important}.wrap{max-width:1360px}.hero.bmg-hero,.hero{background:linear-gradient(135deg,#ef3129 0%,#d7192e 50%,#b90d27 72%,#ffe11a 72%,#ffe11a 100%);border-radius:30px;padding:34px 38px;min-height:170px;display:flex;align-items:center;box-shadow:0 24px 55px rgba(154,27,28,.22)}.hero h1{font-size:38px;max-width:820px}.hero p{max-width:760px;color:#fff7f0;font-size:16px;line-height:1.55}.eyebrow{display:inline-block;text-transform:uppercase;letter-spacing:.18em;font-size:11px;font-weight:900;color:#ffe11a;margin-bottom:10px}.card{border:1px solid rgba(239,49,41,.12);border-radius:26px;box-shadow:0 18px 42px rgba(99,28,24,.07)}.card h2:after{background:var(--bmg-red)}.stat{border-left:0;border-top:6px solid var(--bmg-red);border-radius:24px;background:linear-gradient(180deg,#fff 0%,#fffaf8 100%)}.stat b{color:var(--bmg-red);font-size:30px}.pill{background:#fff0ec;color:var(--bmg-red);border:1px solid rgba(239,49,41,.18)}.btn.primary{background:var(--bmg-red);color:#fff}.btn.alt{background:var(--bmg-ink);color:#fff}.btn.light{background:#fff0ec;color:var(--bmg-red)}th{background:#fff4f0;color:#8f221d}tr:hover td{background:#fffdfb}.bmg-command-center{background:linear-gradient(135deg,#fff 0%,#fff7f2 100%)}.command-grid{display:grid;grid-template-columns:1.4fr .8fr;gap:22px;align-items:stretch}.payroll-tile{background:var(--bmg-ink);color:#fff;border-radius:24px;padding:22px;display:flex;flex-direction:column;justify-content:center}.payroll-tile span{text-transform:uppercase;font-size:11px;letter-spacing:.12em;color:#ffe11a;font-weight:900}.payroll-tile b{font-size:34px;margin:8px 0}.payroll-tile small{color:#d8d8d8}.compact-billing{border-top:5px solid #1f2937}.workspace-focus{border-top:6px solid var(--bmg-red)}.journalist-thread-list{display:grid;gap:12px}.journalist-thread{border:1px solid rgba(239,49,41,.15);border-left:7px solid var(--bmg-red);background:#fff;border-radius:20px;padding:15px 16px}.journalist-thread.high{border-left-color:#f59e0b}.journalist-thread.urgent{border-left-color:#dc2626;background:#fff7f5}.journalist-thread div{display:flex;justify-content:space-between;gap:12px;align-items:start}.journalist-thread strong{font-size:15px}.journalist-thread span,.journalist-thread footer span{font-size:12px;color:#7b6f6a}.journalist-thread p{margin:10px 0;color:#3f3a38;line-height:1.45}.journalist-thread footer{display:flex;justify-content:space-between;align-items:center;border-top:1px solid #f0e1dd;padding-top:10px}.login{background:linear-gradient(135deg,#ef3129,#b90d27)}.login-card{border-top:8px solid var(--bmg-yellow)}.login-logo-switch:hover,.login-logo-switch:focus-within{background:#ef3129}.bcg-chat-head{background:var(--bmg-red);border-bottom-color:var(--bmg-yellow)}.bcg-chat-toggle{background:var(--bmg-red);border-bottom-color:var(--bmg-yellow)}.bcg-chat-form button{background:var(--bmg-red);color:#fff}.bcg-chat-msg.admin{background:var(--bmg-red);border-color:var(--bmg-red)}
@media(max-width:980px){.command-grid{grid-template-columns:1fr}.hero h1{font-size:28px}.brand{min-width:0}.brand img{width:180px}.journalist-thread div,.journalist-thread footer{display:block}.stats{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.stats{display:block}.hero{padding:24px}.grid,.grid2{display:block}}

/* v110 — redesign Binto Media Group : app rouge, newsroom et workspace journalistes */
:root{--bmg-red:#ee2f2a;--bmg-red-dark:#d91d1a;--bmg-red-soft:#fff1f0;--bmg-black:#101010;--bmg-text:#202124;--bmg-muted:#6f7177;--bmg-line:#e8e8ec;--bmg-panel:#f7f7f8;--bmg-card:#ffffff;--bmg-radius:22px;--bmg-shadow:0 18px 45px rgba(25,25,25,.10)}
body.bmg-red-shell{background:var(--bmg-red);color:var(--bmg-text);min-height:100vh;overflow-x:hidden}.app-shell{display:grid;grid-template-columns:286px minmax(0,1fr);min-height:calc(100vh - 46px);padding:28px 28px 0 0}.sidebar-bmg{color:#fff;padding:26px 22px 22px;display:flex;flex-direction:column;gap:22px;position:sticky;top:0;height:calc(100vh - 28px)}.brand-bmg{display:block;text-align:center;margin:4px auto 8px;color:#fff}.brand-bmg img{width:178px;max-width:100%;height:auto;display:block;margin:0 auto 8px;object-fit:contain;filter:brightness(0) invert(1)}.brand-bmg span{display:inline-block;background:#fff;color:#111;padding:3px 18px 4px;transform:skewY(-4deg);font-size:12px;text-transform:uppercase;letter-spacing:.02em}.side-nav{display:grid;gap:7px}.side-nav a{display:flex;align-items:center;gap:14px;color:#fff;padding:13px 16px;border-radius:10px;font-family:BintoMediaAppBold,BintoMediaApp,Arial,sans-serif!important;font-weight:900!important;transition:.18s ease}.side-nav a:hover,.side-nav a.on{background:#fff;color:var(--bmg-red);box-shadow:0 12px 28px rgba(0,0,0,.11)}.side-nav svg,.logout-bmg svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;flex:0 0 24px}.side-nav em{margin-left:auto;min-width:22px;height:22px;border-radius:999px;background:var(--bmg-red);color:#fff;font-style:normal;text-align:center;line-height:22px;font-size:11px}.side-profile{margin-top:auto;border:1px solid rgba(255,255,255,.35);border-radius:14px;padding:12px;display:flex;align-items:center;gap:12px}.side-profile img,.side-profile>span{width:46px;height:46px;border-radius:50%;object-fit:cover;background:#fff;color:var(--bmg-red);display:flex;align-items:center;justify-content:center;font-family:BintoMediaAppBold,BintoMediaApp,Arial,sans-serif!important;font-size:22px}.side-profile strong{display:block;color:#fff}.side-profile small{display:block;color:rgba(255,255,255,.78);font-size:12px;margin-top:3px}.logout-bmg{display:flex;align-items:center;gap:12px;color:#fff;padding:14px 4px 4px;font-family:BintoMediaAppBold,BintoMediaApp,Arial,sans-serif!important;font-weight:900!important}.app-main{background:var(--bmg-panel);border-radius:18px 18px 0 0;min-height:calc(100vh - 28px);box-shadow:var(--bmg-shadow);overflow:hidden}.app-topline{display:grid;grid-template-columns:minmax(250px,1fr) minmax(260px,460px) auto;gap:22px;align-items:center;padding:22px 30px 18px;border-bottom:1px solid var(--bmg-line);background:rgba(255,255,255,.88);backdrop-filter:blur(10px)}.app-topline h1{margin:0;color:#111;font-size:26px;line-height:1.05}.app-topline p{margin:5px 0 0;color:var(--bmg-muted);font-size:13px}.app-search{height:48px;background:#fff;border:1px solid #dddfe4;border-radius:12px;display:flex;align-items:center;gap:10px;padding:0 14px;box-shadow:0 7px 20px rgba(0,0,0,.03)}.app-search svg{width:21px;height:21px;fill:none;stroke:#777;stroke-width:2}.app-search input{border:0!important;padding:0!important;background:transparent!important;box-shadow:none!important}.top-actions{display:flex;align-items:center;gap:10px;white-space:nowrap}.top-actions a,.top-actions span{display:inline-flex;align-items:center;min-height:42px;border:1px solid #e2e3e7;background:#fff;border-radius:12px;padding:0 14px;font-family:BintoMediaAppBold,BintoMediaApp,Arial,sans-serif!important}.content-panel{padding:22px 30px 28px}.wrap{max-width:none;margin:0;padding:0}.hero{background:#fff!important;color:var(--bmg-text)!important;border-radius:18px!important;border:1px solid var(--bmg-line)!important;box-shadow:0 10px 26px rgba(0,0,0,.06)!important}.hero h1{color:var(--bmg-red)!important}.hero p{color:var(--bmg-muted)!important}.card{border:1px solid var(--bmg-line)!important;border-radius:18px!important;box-shadow:0 10px 26px rgba(0,0,0,.055)!important;background:#fff!important}.card h2{color:#191919!important;text-transform:none}.card h2:after{background:var(--bmg-red)!important}.btn{border-radius:12px!important;padding:11px 16px!important;box-shadow:none!important}.btn.primary{background:var(--bmg-red)!important;color:#fff!important}.btn.alt{background:#111!important;color:#fff!important}.btn.light{background:#fff!important;color:var(--bmg-red)!important;border:1px solid #f1b9b6!important}.btn.wide{display:block;text-align:center;width:100%}.pill{background:#f2f4f7;color:#555}.pill.danger{background:#fee4e2!important;color:#b42318!important}.alert{border-radius:14px}.foot.app-legal{display:flex;align-items:center;justify-content:flex-end;gap:18px;flex-wrap:wrap;background:#f7f7f8;color:#333;margin-left:286px;padding:12px 30px;border-top:1px solid var(--bmg-line);font-size:12px}.foot.app-legal strong{color:#111}.bmg-welcome{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:18px}.bmg-welcome .eyebrow{color:var(--bmg-red);font-family:BintoMediaAppBold,BintoMediaApp,Arial,sans-serif!important;text-transform:uppercase;letter-spacing:.08em;font-size:12px}.bmg-welcome h2{font-size:29px;margin:3px 0 3px;color:#111}.bmg-welcome p{margin:0;color:var(--bmg-muted)}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:18px}.kpi-card{background:#fff;border:1px solid var(--bmg-line);border-radius:18px;padding:18px 18px 16px;box-shadow:0 8px 22px rgba(0,0,0,.045);position:relative;min-height:132px}.kpi-card i{width:54px;height:54px;border-radius:13px;background:linear-gradient(135deg,var(--bmg-red),#d30f0c);color:#fff;display:flex;align-items:center;justify-content:center;font-style:normal;font-size:24px;margin-bottom:12px}.kpi-card span{display:block;color:#222;font-family:BintoMediaAppBold,BintoMediaApp,Arial,sans-serif!important}.kpi-card b{display:block;font-size:31px;line-height:1;margin:5px 0 7px;color:#111}.kpi-card small{color:var(--bmg-muted)}.dashboard-layout{display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:18px}.card-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px}.card-head h2{margin:0!important}.card-head a{color:var(--bmg-red);font-family:BintoMediaAppBold,BintoMediaApp,Arial,sans-serif!important;font-size:13px}.newsroom-card{min-height:350px}.newsroom-grid{display:grid;grid-template-columns:290px minmax(0,1fr) 160px;gap:16px}.conversation-list{display:grid;gap:8px}.conversation-item{display:grid;grid-template-columns:42px 1fr auto;gap:2px 10px;align-items:center;padding:11px;border-radius:12px;border:1px solid transparent}.conversation-item.active,.conversation-item:hover{background:var(--bmg-red-soft);border-color:#ffe0de}.conversation-item .avatar-dot{grid-row:1/3;width:42px;height:42px;border-radius:50%;background:#111;color:#fff;display:flex;align-items:center;justify-content:center;font-family:BintoMediaAppBold,BintoMediaApp,Arial,sans-serif!important}.conversation-item strong{font-size:14px}.conversation-item small{color:var(--bmg-muted)}.conversation-item em{grid-column:3;grid-row:1;font-style:normal;color:#777;font-size:12px}.thread-panel{border:1px solid var(--bmg-line);border-radius:14px;padding:14px;background:#fff}.thread-head{display:flex;justify-content:space-between;border-bottom:1px solid var(--bmg-line);padding-bottom:10px;margin-bottom:14px}.thread-head strong,.thread-head small{display:block}.thread-head small{color:var(--bmg-muted);margin-top:3px}.thread-head span{align-self:start;background:#fff2e8;color:#cf4a00;border-radius:999px;padding:5px 9px;font-size:12px}.chat-bubble{max-width:88%;border-radius:14px;padding:12px 14px;margin:0 0 10px;line-height:1.35}.chat-bubble.journalist{background:#fff;border:1px solid var(--bmg-line)}.chat-bubble.editor{background:#f2f3f5;margin-left:auto}.composer{display:flex;gap:8px;border-top:1px solid var(--bmg-line);padding-top:10px}.composer input{border-radius:12px!important}.composer button{width:44px;border:0;border-radius:12px;background:var(--bmg-red);color:#fff;font-weight:900}.action-stack{border:1px solid var(--bmg-line);border-radius:14px;padding:14px;display:grid;align-content:start;gap:9px}.action-stack h3{margin:0 0 4px}.side-column{display:grid;gap:18px;align-content:start}.pay-profile{display:flex;align-items:center;gap:12px;margin:7px 0 14px}.pay-profile span{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bmg-red);color:#fff;font-family:BintoMediaAppBold,BintoMediaApp,Arial,sans-serif!important;font-size:23px}.pay-profile strong,.pay-profile small{display:block}.pay-profile small{color:var(--bmg-muted);margin-top:3px}.payroll-preview dl{display:grid;grid-template-columns:1fr auto;gap:10px 14px;border-top:1px solid var(--bmg-line);border-bottom:1px solid var(--bmg-line);padding:14px 0;margin:0 0 14px}.payroll-preview dt{color:#555}.payroll-preview dd{margin:0;font-family:BintoMediaAppBold,BintoMediaApp,Arial,sans-serif!important}.payroll-preview dd:last-child{color:var(--bmg-red)}.doc-row{display:grid;grid-template-columns:30px 1fr auto;gap:10px;align-items:center;padding:10px 0;border-bottom:1px solid var(--bmg-line)}.doc-row:last-child{border-bottom:0}.doc-row span{width:30px;height:30px;border-radius:8px;background:#f6f7f9;display:flex;align-items:center;justify-content:center}.doc-row em{font-style:normal;background:#f4f5f6;border-radius:999px;padding:5px 8px;font-size:11px}.media-portfolio>div{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.media-tile,.media-mini{display:inline-flex;align-items:center;justify-content:center;text-align:center;white-space:pre-line;border-radius:8px;min-height:58px;color:#fff;font-family:BintoMediaAppBold,BintoMediaApp,Arial,sans-serif!important;font-weight:900!important;line-height:.95;padding:6px}.media-mini{min-height:0;padding:5px 9px;border-radius:999px;white-space:normal}.info241{background:#0b5e8e;color:#ffe21a}.sport241{background:#7225cb;color:#ffe21a}.footgabon{background:#e10021;color:#ffe21a}.rue241{background:#111;color:#ffe21a}.star241{background:#9b158f;color:#ffe21a}.gabonsoir{background:#111;color:#fff}.gabontime{background:#056aa6;color:#fff}.productions-card{margin-top:18px}.bmg-table th{font-size:12px}.bmg-table td{vertical-align:middle}.type-pill{display:inline-flex;align-items:center;border-radius:999px;padding:7px 10px;font-size:12px;font-family:BintoMediaAppBold,BintoMediaApp,Arial,sans-serif!important}.type-pill.article{background:#eaf2ff;color:#175cd3}.type-pill.breve{background:#f4e8ff;color:#7a2ebf}.type-pill.interview{background:#e9f8ef;color:#027a48}.type-pill.podcast{background:#ffecf8;color:#b4238a}.type-pill.video{background:#fff2cc;color:#a15c00}.company-strip{display:flex;gap:18px;flex-wrap:wrap;margin:18px 0 0;padding:14px 18px;border:1px solid var(--bmg-line);border-radius:16px;background:#fff;color:#444;font-size:13px}.company-strip span{display:inline-flex;align-items:center;gap:6px}.company-strip span:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--bmg-red)}.stats{gap:16px}.stat{border-left-color:var(--bmg-red)!important}.grid,.grid2{gap:16px}input:focus,select:focus,textarea:focus{outline:2px solid rgba(238,47,42,.18);border-color:var(--bmg-red)}.login{background:var(--bmg-red)!important}.login-card{border-top:0!important;border-radius:24px!important;box-shadow:0 24px 80px rgba(0,0,0,.20)!important}.login-card .btn.primary{width:100%;margin-top:6px}.login-logo-wrap{border-radius:18px!important;border-color:#f0d1cf!important}.login-title{color:var(--bmg-red)}.client-access-request{margin-top:15px}.client-access-request summary{cursor:pointer;color:var(--bmg-red);font-family:BintoMediaAppBold,BintoMediaApp,Arial,sans-serif!important}.bcg-chat-toggle{background:var(--bmg-red)!important;border-bottom-color:#111!important}.bcg-chat-head{background:var(--bmg-red)!important;border-bottom-color:#111!important}.bcg-chat-form button{background:var(--bmg-red)!important;color:#fff!important}.bcg-chat-msg.admin{background:var(--bmg-red)!important;border-color:var(--bmg-red)!important}.bcg-chat-widget.has-new-message .bcg-chat-toggle{background:#111!important;color:#fff!important;animation:none!important}
@media(max-width:1220px){.app-shell{grid-template-columns:240px}.dashboard-layout{grid-template-columns:1fr}.newsroom-grid{grid-template-columns:1fr}.media-portfolio>div{grid-template-columns:repeat(7,1fr)}.foot.app-legal{margin-left:240px}.sidebar-bmg{padding-left:14px;padding-right:14px}.brand-bmg img{width:150px}}
@media(max-width:880px){.app-shell{display:block;padding:0}.sidebar-bmg{position:relative;height:auto;padding:18px}.side-nav{grid-template-columns:repeat(2,minmax(0,1fr))}.app-main{border-radius:18px 18px 0 0;margin:0 12px}.app-topline{grid-template-columns:1fr}.content-panel{padding:18px}.kpi-grid{grid-template-columns:1fr 1fr}.foot.app-legal{margin-left:0;justify-content:center}.bmg-welcome{display:block}.media-portfolio>div{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.side-nav{grid-template-columns:1fr}.kpi-grid{grid-template-columns:1fr}.app-main{margin:0}.content-panel{padding:14px}.bmg-table{font-size:12px}.bmg-table th:nth-child(4),.bmg-table td:nth-child(4),.bmg-table th:nth-child(6),.bmg-table td:nth-child(6){display:none}}

/* v4.1 — app Binto Media Group : police interface fixe + logo admin corrigé */
:root{
  --bmg-ui-font: "Montserrat", "Trebuchet MS", Arial, Helvetica, sans-serif;
  --bmg-ui-font-bold: "Montserrat", "Arial Black", Arial, Helvetica, sans-serif;
}
body,
body.bmg-red-shell,
body.bmg-red-shell input,
body.bmg-red-shell select,
body.bmg-red-shell textarea,
body.bmg-red-shell button,
body.bmg-red-shell table,
body.bmg-red-shell p,
body.bmg-red-shell td,
body.bmg-red-shell li,
body.bmg-red-shell .small,
.login,
.login input,
.login select,
.login textarea,
.login button{
  font-family:var(--bmg-ui-font)!important;
}
body.bmg-red-shell h1,
body.bmg-red-shell h2,
body.bmg-red-shell h3,
body.bmg-red-shell h4,
body.bmg-red-shell strong,
body.bmg-red-shell b,
body.bmg-red-shell label,
body.bmg-red-shell th,
body.bmg-red-shell .btn,
body.bmg-red-shell .side-nav a,
body.bmg-red-shell .logout-bmg,
body.bmg-red-shell .top-actions a,
body.bmg-red-shell .top-actions span,
body.bmg-red-shell .kpi-card span,
body.bmg-red-shell .kpi-card b,
body.bmg-red-shell .media-tile,
body.bmg-red-shell .media-mini,
.login h1,
.login h2,
.login strong,
.login b,
.login .btn,
.login label{
  font-family:var(--bmg-ui-font-bold)!important;
  font-weight:900!important;
}
.brand-bmg{
  width:100%;
  padding:0 2px;
  margin:0 auto 16px!important;
}
.brand-bmg img{
  width:190px!important;
  max-width:92%!important;
  height:auto!important;
  display:block!important;
  margin:0 auto!important;
  object-fit:contain!important;
  filter:none!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
}
.brand-bmg span{
  margin-top:6px;
  transform:skewY(-3deg)!important;
}
.sidebar-bmg{
  gap:18px!important;
}
.side-nav{
  gap:5px!important;
}
.side-nav a{
  padding:11px 14px!important;
}
.top-actions .update-shortcut{
  background:var(--bmg-red)!important;
  color:#fff!important;
  border-color:var(--bmg-red)!important;
  text-transform:uppercase;
  letter-spacing:.02em;
}
.login-logo-wrap,
.login-logo-switch{
  background:#fff!important;
}
.login-logo-wrap .login-logo{
  filter:none!important;
}
/* Les polices déposées par l’admin restent réservées aux PDF via src/pdf_render.php. */


/* v5 — logo unique et identification utilisateur */
.brand-bmg span{display:none!important}
.brand-bmg img{margin-bottom:0!important}
.app-topline p strong{color:#111;font-weight:900}
.top-actions .user-chip{max-width:190px;overflow:hidden;text-overflow:ellipsis}
.bmg-code-copy{display:flex;align-items:center;gap:10px;background:#f7f7f7;border:1px solid #e5e5e5;border-radius:14px;padding:14px 16px;overflow:auto}.bmg-code-copy code{font-weight:700;color:#e62b2b;white-space:nowrap}.update-shortcut{display:inline-flex;align-items:center;justify-content:center;height:38px;padding:0 14px;border-radius:12px;background:#fff0f0;color:#e62b2b;font-weight:800;text-decoration:none;border:1px solid #ffd2d2}.user-chip{font-weight:700;color:#111;background:#fff;border:1px solid #eee;border-radius:12px;padding:8px 12px}
