/* ============================================================
   YABOX — DESIGN SYSTEM PRO  (yabox-ui-pro.css)
   Discipline visuelle : riche en modules, simple a l'oeil.
   100% tokens. Aucun HTML, menu, route ou metier touche.
   A charger EN DERNIER.
   ============================================================ */

/* ============ 0. FONDATIONS ============ */
body{
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-family:'Plus Jakarta Sans','Inter',system-ui,sans-serif;
}

/* Echelle d'espacement coherente */
:root{
  --gap:14px;
  --pad-card:18px;
  --radius-card:16px;
}

/* Transitions globales douces */
.nav-item,.sd-item,.sd-group-btn,.obtn,.yabox-btn,.btn,button,
.cbox,.card,.kpi,.kpi-card,.intel-card,.yabox-card,.panel,
.badge,.pill,.chip,.theme-option,input,select,textarea,a{
  transition:background-color .18s ease,border-color .18s ease,color .18s ease,
             box-shadow .22s ease,transform .16s ease !important;
}

/* ============ 1. TITRES — UN SEUL SYSTEME ============ */
/* Hierarchie claire : H1 page > H2 section > H3 sous-section. */
.topbar-title,
.intel-page h1, .panel h1{
  font-weight:800 !important;
  font-size:22px !important;
  letter-spacing:-.3px !important;
  color:var(--text) !important;
}
.intel-page h2, .panel > h2, .module-title, .section-title{
  font-weight:800 !important;
  font-size:19px !important;
  letter-spacing:-.2px !important;
  color:var(--text) !important;
  margin-bottom:4px !important;
}
.intel-page h3, .panel-head, .panel > h3, .intel-section-title{
  font-weight:700 !important;
  font-size:15px !important;
  color:var(--text) !important;
}
/* Accent discret sous les titres de section (repere visuel) */
.intel-page h2::after, .panel > h2::after, .module-title::after{
  content:""; display:block; width:30px; height:3px;
  background:var(--accent); border-radius:2px; margin-top:7px;
}
/* NEUTRALISER tout titre decoratif geant (violet Mon Espace, etc.) */
.intel-card-value[style*="color"],
.profile-value, .agent-profile-card .big,
[style*="font-size:34px"], [style*="font-size:42px"]{
  color:var(--text) !important;
}

/* ============ 2. CARTES — UN SEUL MODELE ============ */
.cbox,.card,.kpi,.kpi-card,.intel-card,
.intel-page .yabox-card,.panel{
  background:var(--bg-elev,#fff) !important;
  border:1px solid var(--border) !important;
  border-radius:var(--radius-card) !important;
  box-shadow:var(--shadow-sm,0 1px 3px rgba(15,23,42,.06)) !important;
}
.cbox,.card,.intel-card,.intel-page .yabox-card{ padding:var(--pad-card) !important; }
.panel{ padding:18px 20px !important; }

/* Hover : leger relief, jamais agressif */
.cbox:hover,.card:hover,.kpi:hover,.kpi-card:hover,
.intel-card:hover,.intel-page .yabox-card:hover{
  box-shadow:var(--shadow-md,0 6px 18px rgba(15,23,42,.10)) !important;
  border-color:var(--border2,var(--border)) !important;
  transform:translateY(-1px);
}

/* ============ 3. METRIQUES — HIERARCHIE "5 SECONDES" ============ */
/* Label = quoi (discret) | Valeur = combien (dominant) */
.intel-card-label,.kpi-label,.metric-label{
  color:var(--text2) !important;
  font-size:11px !important;
  font-weight:700 !important;
  text-transform:uppercase !important;
  letter-spacing:.6px !important;
  line-height:1.3 !important;
}
.intel-card-value,.kpi-value,.metric-value{
  color:var(--text) !important;
  font-size:30px !important;
  font-weight:800 !important;
  line-height:1.05 !important;
  margin-top:6px !important;
}
/* Liseré d'accent en haut, apparait au survol */
.intel-card{ position:relative; overflow:hidden; }
.intel-card::before{
  content:"";position:absolute;left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg,var(--accent),var(--accent-h,var(--accent)));
  opacity:0;transition:opacity .2s ease;
}
.intel-card:hover::before{ opacity:1; }

/* ============ 4. COULEUR SEMANTIQUE (sens, pas deco) ============ */
/* Vert = livre/positif | Rouge = retour/echec | Orange = alerte | Bleu = info */
.intel-card.is-good .intel-card-value,
.metric-value.good, .value-success{ color:var(--green,#16A34A) !important; }
.intel-card.is-bad .intel-card-value,
.metric-value.bad, .value-danger{ color:var(--red,#EF4444) !important; }
.intel-card.is-warn .intel-card-value,
.metric-value.warn{ color:var(--orange,#F59E0B) !important; }

/* Badges de statut normalises (un seul style) */
.badge,.pill,.tag,.status-chip,[class*="badge-"]{
  border-radius:var(--r-full,9999px) !important;
  font-size:11px !important;
  font-weight:700 !important;
  letter-spacing:.3px !important;
  padding:4px 11px !important;
  display:inline-flex !important;
  align-items:center; gap:5px;
  border:1px solid transparent;
}
.badge.green,.badge.success,[class*="connected"],.status-active{
  background:var(--green-bg,#F0FDF4) !important;color:var(--green-txt,#15803D) !important;
  border-color:var(--green-border,#BBF7D0) !important;
}
.badge.red,.badge.danger,[class*="disconnected"]{
  background:var(--red-bg,#FEF2F2) !important;color:var(--red-txt,#DC2626) !important;
  border-color:var(--red-border,#FCA5A5) !important;
}
.badge.orange,.badge.warn{
  background:var(--orange-bg,#FFFBEB) !important;color:var(--orange-txt,#B45309) !important;
  border-color:var(--orange-border,#FCD34D) !important;
}
.badge.blue,.badge.info{
  background:var(--blue-bg,#EFF6FF) !important;color:var(--blue-txt,#1D4ED8) !important;
}

/* ============ 5. DENSITE — GRILLES AEREES ============ */
.intel-page [style*="grid-template-columns"]{ gap:var(--gap) !important; }
/* Cartes metriques : largeur mini confortable, pas tassees */
.intel-page [style*="minmax(160px"],
.intel-page [style*="minmax(170px"]{
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr)) !important;
}
/* Espacement vertical entre sections */
.panel,.cbox{ margin-bottom:16px !important; }

/* ============ 6. ETATS VIDES — GUIDER, PAS CASSER ============ */
.panel .muted, .intel-page .muted, .no-data, .empty-hint, .state-sub{
  color:var(--text3) !important;
  font-size:13px !important;
}
.panel:has(> .muted:only-child){
  border-style:dashed !important;
  background:var(--bg-2,var(--bg-elev)) !important;
}

/* ============ 7. BOUTONS — FEEDBACK CLAIR ============ */
.obtn,.yabox-btn,.btn{
  border-radius:var(--r-md,10px) !important;
  font-weight:600 !important;
  letter-spacing:.1px;
}
.obtn:active,.yabox-btn:active,.btn:active,button:active{ transform:translateY(1px) scale(.99); }
.obtn.primary,.yabox-btn-primary,.btn.primary,.topbar-btn-primary,.edux-primary{
  background:linear-gradient(180deg,var(--accent),var(--accent-h,var(--accent))) !important;
  color:var(--on-accent,#fff) !important;
  border:none !important;
  box-shadow:0 2px 8px var(--accent-soft,rgba(232,64,12,.25)) !important;
}
.obtn.primary:hover,.yabox-btn-primary:hover,.btn.primary:hover,.topbar-btn-primary:hover{
  filter:brightness(1.05);
  box-shadow:0 4px 14px var(--accent-soft,rgba(232,64,12,.35)) !important;
}

/* ============ 8. SIDEBAR — LISIBLE, ITEM ACTIF NET ============ */
.nav-item{ border-radius:10px !important; font-weight:600 !important; }
.nav-item:hover,.sd-item:hover{ background:var(--bg-hover,rgba(255,255,255,.06)) !important; }
.nav-item.active,.sd-item.active{ position:relative; background:var(--bg-active,var(--accent-soft)) !important; }
.nav-item.active::after,.sd-item.active::after{
  content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:60%;border-radius:0 3px 3px 0;background:var(--accent);
}
.nav-section-title{ letter-spacing:1px !important; font-size:10px !important; opacity:.7; }

/* ============ 9. TOPBAR — SOBRE ============ */
.topbar{
  border-bottom:1px solid var(--border) !important;
  background:var(--bg-elev,#fff) !important;
}

/* ============ 10. TABLEAUX — LECTURE CONFORTABLE ============ */
table{ border-collapse:separate; border-spacing:0; }
table thead th,.intel-page table thead th,.panel table thead th{
  text-transform:uppercase !important;
  font-size:11px !important;
  letter-spacing:.5px !important;
  font-weight:700 !important;
  color:var(--text2) !important;
  background:var(--bg-2,var(--bg-elev)) !important;
  border-bottom:1px solid var(--border) !important;
}
table tbody tr{ transition:background-color .14s ease; }
table tbody tr:hover{ background:var(--bg-hover,rgba(15,23,42,.03)) !important; }
table tbody td{ border-bottom:1px solid var(--border) !important; }

/* ============ 11. FORMULAIRES ============ */
input,select,textarea{
  border:1px solid var(--border) !important;
  border-radius:var(--r-md,10px) !important;
  background:var(--bg-elev,#fff) !important;
  color:var(--text,#0F172A) !important;
}
input:focus,select:focus,textarea:focus{ border-color:var(--accent) !important; outline:none; }

/* ============ 12. ACCESSIBILITE — FOCUS VISIBLE ============ */
button:focus-visible,a:focus-visible,input:focus-visible,
select:focus-visible,textarea:focus-visible,.nav-item:focus-visible,
.obtn:focus-visible,.theme-option:focus-visible{
  outline:none !important;
  box-shadow:var(--shadow-focus,0 0 0 3px rgba(33,85,224,.25)) !important;
}

/* ============ 13. SCROLLBARS DISCRETES ============ */
*{ scrollbar-width:thin; scrollbar-color:var(--border2,#C8D3E0) transparent; }
*::-webkit-scrollbar{ width:10px;height:10px; }
*::-webkit-scrollbar-thumb{
  background:var(--border2,#C8D3E0);border-radius:8px;
  border:2px solid transparent;background-clip:content-box;
}
*::-webkit-scrollbar-thumb:hover{ background:var(--text3,#94A3B8);background-clip:content-box; }

/* ============ 14. APPARITION DOUCE ============ */
.cbox,.card,.kpi,.intel-card,.panel{ animation:yb-fade .26s ease both; }
@keyframes yb-fade{ from{opacity:0;transform:translateY(5px)} to{opacity:1;transform:translateY(0)} }

/* ============ 15. SELECTION + GARANTIES ============ */
::selection{ background:var(--accent-soft,rgba(232,64,12,.2)); color:var(--text); }
/* Garantie fond visible meme si une couche l'a retire */
.intel-page .yabox-card,.intel-page .intel-card,.intel-page .panel,.intel-page [class*="card"]{
  background-color:var(--bg-elev,#fff) !important;
}

/* ============ 16. THEME OPTION (menu Personnaliser) ============ */
.theme-option{ border:1px solid var(--border) !important;border-radius:var(--r-lg,12px) !important;overflow:hidden; }
.theme-option:hover{ border-color:var(--accent) !important;box-shadow:var(--shadow-sm) !important; }
.theme-option.is-active{ border-color:var(--accent) !important;box-shadow:0 0 0 2px var(--accent-soft) !important; }

/* ============ 17. REDUCED MOTION ============ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms !important;transition-duration:.001ms !important; }
}

/* ============ 18. MOBILE — DENSITE ADAPTEE ============ */
@media(max-width:768px){
  .intel-card-value,.kpi-value{ font-size:24px !important; }
  .intel-page [style*="grid-template-columns"]{ grid-template-columns:repeat(auto-fit,minmax(140px,1fr)) !important; }
  .topbar-title,.intel-page h1{ font-size:18px !important; }
  .cbox,.card,.intel-card{ padding:14px !important; }
}


/* ============ 19. HAUTE SPECIFICITE (#cnt) — GAGNE TOUJOURS ============ */
/* Les regles existantes utilisent #cnt (ID) -> on egale la specificite */
#cnt .intel-card,
#cnt .intel-page .intel-card,
#cnt .intel-page .yabox-card{
  background:var(--bg-elev,#fff) !important;
  border:1px solid var(--border) !important;
  border-radius:var(--radius-card,16px) !important;
  box-shadow:var(--shadow-sm,0 1px 3px rgba(15,23,42,.06)) !important;
  padding:18px !important;
  position:relative; overflow:hidden;
}
#cnt .intel-card:hover,
#cnt .intel-page .intel-card:hover,
#cnt .intel-page .yabox-card:hover{
  box-shadow:var(--shadow-md,0 6px 18px rgba(15,23,42,.10)) !important;
  border-color:var(--border2,var(--border)) !important;
  transform:translateY(-1px);
}
#cnt .intel-card-label{
  color:var(--text2) !important;font-size:11px !important;font-weight:700 !important;
  text-transform:uppercase !important;letter-spacing:.6px !important;
}
#cnt .intel-card-value{
  color:var(--text) !important;font-size:30px !important;font-weight:800 !important;
  line-height:1.05 !important;margin-top:6px !important;
}
#cnt .intel-page h2,#cnt .panel > h2,#cnt .module-title{
  font-weight:800 !important;font-size:19px !important;color:var(--text) !important;
}
#cnt .intel-page h2::after,#cnt .panel > h2::after{
  content:"";display:block;width:30px;height:3px;background:var(--accent);
  border-radius:2px;margin-top:7px;
}
#cnt .panel{
  background:var(--bg-elev,#fff) !important;border:1px solid var(--border) !important;
  border-radius:var(--radius-card,16px) !important;padding:18px 20px !important;
  box-shadow:var(--shadow-sm) !important;margin-bottom:16px !important;
}
#cnt .badge,#cnt .pill{
  border-radius:9999px !important;font-size:11px !important;font-weight:700 !important;
  padding:4px 11px !important;
}

/* ============================================================
   20. WHATSAPP HUB — VRAI ENVIRONNEMENT MESSAGERIE
   ------------------------------------------------------------
   Transforme les classes wa-* existantes en look WhatsApp
   authentique : fond texture, bulles vert/blanc avec queue,
   heures + coches discretes. Aucun JS ni metier touche.
   ============================================================ */

/* --- Fond de conversation type WhatsApp (creme texture) --- */
#cnt .wa-messages{
  background-color:#ECE5DD !important;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(0,0,0,.012) 1px, transparent 1px),
    radial-gradient(circle at 70% 60%, rgba(0,0,0,.012) 1px, transparent 1px);
  background-size:42px 42px;
  padding:18px 16px !important;
  gap:4px !important;
}
/* Mode sombre (theme Nuit) : fond sombre WhatsApp */
body[data-theme="nuit"] #cnt .wa-messages{
  background-color:#0B141A !important;
  background-image:none !important;
}

/* --- Bulle commune --- */
#cnt .wa-msg{
  position:relative !important;
  max-width:72% !important;
  border:none !important;
  border-radius:8px !important;
  padding:7px 11px 8px 11px !important;
  margin-bottom:4px !important;
  box-shadow:0 1px .5px rgba(11,20,26,.13) !important;
  font-size:14px !important;
  line-height:1.4 !important;
  animation:wa-pop .18s ease both;
}
@keyframes wa-pop{ from{opacity:0;transform:translateY(3px) scale(.98)} to{opacity:1;transform:none} }

/* --- Message ENTRANT (client) : bulle blanche a gauche --- */
#cnt .wa-msg.in{
  align-self:flex-start !important;
  background:#FFFFFF !important;
  color:#111B21 !important;
  border-top-left-radius:2px !important;
}
#cnt .wa-msg.in::before{
  content:""; position:absolute; top:0; left:-7px;
  width:0;height:0;border-style:solid;
  border-width:0 8px 8px 0; border-color:transparent #FFFFFF transparent transparent;
}
body[data-theme="nuit"] #cnt .wa-msg.in{ background:#202C33 !important; color:#E9EDEF !important; }
body[data-theme="nuit"] #cnt .wa-msg.in::before{ border-color:transparent #202C33 transparent transparent; }

/* --- Message SORTANT (agent) : bulle verte a droite --- */
#cnt .wa-msg.out{
  align-self:flex-end !important;
  background:#D9FDD3 !important;
  color:#111B21 !important;
  border-top-right-radius:2px !important;
}
#cnt .wa-msg.out::before{
  content:""; position:absolute; top:0; right:-7px;
  width:0;height:0;border-style:solid;
  border-width:0 0 8px 8px; border-color:transparent transparent transparent #D9FDD3;
}
body[data-theme="nuit"] #cnt .wa-msg.out{ background:#005C4B !important; color:#E9EDEF !important; }
body[data-theme="nuit"] #cnt .wa-msg.out::before{ border-color:transparent transparent transparent #005C4B; }

/* --- Heure + statut sous le message (style WhatsApp) --- */
#cnt .wa-msg small{
  display:block !important;
  text-align:right !important;
  margin-top:3px !important;
  font-size:11px !important;
  color:#667781 !important;
}
body[data-theme="nuit"] #cnt .wa-msg small{ color:#8696A0 !important; }

/* Etat "failed" : teinte rouge discrete (les messages manual failed) */
#cnt .wa-msg[class*="fail"], #cnt .wa-msg small:has-text("failed"){
  /* fallback : si le JS ajoute 'failed' on le marque */
}
#cnt .wa-msg small{ position:relative; }

/* --- Message systeme : pilule centrale --- */
#cnt .wa-msg.system{
  align-self:center !important;
  background:#FFF3C4 !important;
  color:#54656F !important;
  font-size:12px !important;
  border-radius:8px !important;
  box-shadow:0 1px .5px rgba(11,20,26,.13) !important;
  max-width:85% !important;
  text-align:center;
}
#cnt .wa-msg.system::before{ display:none !important; }
body[data-theme="nuit"] #cnt .wa-msg.system{ background:#182229 !important; color:#8696A0 !important; }

/* --- En-tete de la fenetre de chat : barre WhatsApp verte --- */
#cnt .wa-chat .wa-panel-head,
#cnt .wa-chat > .wa-panel-head:first-child{
  background:#008069 !important;
  color:#fff !important;
  border-bottom:none !important;
}
#cnt .wa-chat .wa-panel-head h3,
#cnt .wa-chat .wa-panel-head span{ color:#fff !important; }
body[data-theme="nuit"] #cnt .wa-chat .wa-panel-head{ background:#202C33 !important; }

/* --- Liste de conversations : item actif net --- */
#cnt .wa-conv-card{
  border-radius:10px !important;
  transition:background .14s ease, border-color .14s ease;
}
#cnt .wa-conv-card:hover{ background:var(--bg-hover) !important; }
#cnt .wa-conv-card.active{
  border-color:#008069 !important;
  box-shadow:0 0 0 2px rgba(0,128,105,.15) !important;
}

/* --- Composer (zone d'ecriture) facon WhatsApp --- */
#cnt .wa-composer{ background:var(--bg-2,#F0F2F5) !important; }
#cnt .wa-composer textarea{
  border-radius:18px !important;
  background:var(--bg-elev,#fff) !important;
}

/* --- Boutons d'action rapide (Confirmer, Refus...) plus clairs --- */
#cnt .wa-quick button, #cnt .wa-chat-tools button{
  border-radius:18px !important;
  font-weight:600 !important;
  font-size:13px !important;
}

/* --- Panneau lateral client : lisible --- */
#cnt .wa-side-card{ border-radius:14px !important; }
#cnt .wa-info b{ font-weight:600 !important; }

/* --- Mobile : pleine largeur --- */
@media(max-width:980px){
  #cnt .wa-msg{ max-width:85% !important; }
  #cnt .wa-messages{ max-height:60vh !important; }
}

/* ============================================================
   21. VISION GLOBALE — dashboard dense lisible
   ============================================================ */
#cnt .vg-page{max-width:1280px;margin:0 auto;}
#cnt .vg-loading,#cnt .vg-empty{padding:30px;text-align:center;color:var(--text2);
  border:1px dashed var(--border);border-radius:14px;background:var(--bg-2,var(--bg-elev));}
#cnt .vg-empty small{color:var(--text3);}
#cnt .vg-nc{color:var(--text3);font-size:.7em;font-style:italic;font-weight:600;
  background:var(--bg-2,#f1f5f9);padding:2px 8px;border-radius:6px;}

/* notif WhatsApp */
#cnt .vg-wa{display:flex;align-items:center;gap:13px;background:linear-gradient(120deg,#E7FBEF,#F0FDF4);
  border:1px solid #BBF7D0;border-radius:13px;padding:12px 15px;margin-bottom:16px;}
#cnt .vg-wa-ic{width:40px;height:40px;border-radius:11px;background:#25D366;display:flex;align-items:center;
  justify-content:center;font-size:21px;box-shadow:0 3px 8px rgba(37,211,102,.35);flex-shrink:0;}
#cnt .vg-wa-tx{flex:1;}#cnt .vg-wa-tx b{font-size:13.5px;color:#128C7E;}
#cnt .vg-wa-tx p{font-size:12px;color:#3a5a4a;margin:2px 0 0;}
#cnt .vg-wa-btn{background:#25D366;color:#fff;border:none;border-radius:9px;padding:9px 15px;
  font-size:12.5px;font-weight:700;cursor:pointer;white-space:nowrap;}
body[data-theme="nuit"] #cnt .vg-wa{background:#11261c;border-color:#1f5c45;}

/* section titles */
#cnt .vg-st{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;
  color:var(--text2);margin:18px 0 10px;display:flex;align-items:center;gap:8px;}
#cnt .vg-st::after{content:"";flex:1;height:1px;background:var(--border);}

/* KPI grids */
#cnt .vg-kpis{display:grid;grid-template-columns:repeat(6,1fr);gap:11px;}
#cnt .vg-kpi{background:var(--bg-elev,#fff);border:1px solid var(--border);border-radius:13px;
  padding:13px;box-shadow:var(--shadow-sm);transition:.18s;}
#cnt .vg-kpi:hover{box-shadow:var(--shadow-md);transform:translateY(-1px);}
#cnt .vg-kpi-l{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text2);line-height:1.3;}
#cnt .vg-kpi-v{font-size:23px;font-weight:800;margin-top:4px;line-height:1;color:var(--text);}
#cnt .vg-kpi-d{font-size:10.5px;margin-top:5px;font-weight:600;color:var(--text2);}
#cnt .vg-kpi-v.green{color:var(--green,#16A34A);}
#cnt .vg-kpi-v.red{color:var(--red,#EF4444);}
#cnt .vg-kpi-v.orange{color:var(--orange,#F59E0B);}
#cnt .vg-kpi-v.blue{color:var(--blue,#2155E0);}

/* layout rows */
#cnt .vg-row2{display:grid;grid-template-columns:1fr 1fr;gap:13px;}
#cnt .vg-row3{display:grid;grid-template-columns:repeat(3,1fr);gap:13px;}
#cnt .vg-row2b{display:grid;grid-template-columns:1.4fr 1fr;gap:13px;}
#cnt .vg-card{background:var(--bg-elev,#fff);border:1px solid var(--border);border-radius:15px;
  padding:16px;box-shadow:var(--shadow-sm);}
#cnt .vg-card h3{font-size:13.5px;font-weight:700;margin-bottom:12px;}

/* team mini kpi */
#cnt .vg-tkpi{display:grid;grid-template-columns:repeat(2,1fr);gap:9px;margin-bottom:12px;}
#cnt .vg-tk{background:var(--bg-2,#f6f7f9);border-radius:10px;padding:11px;}
#cnt .vg-tk-l{font-size:9.5px;text-transform:uppercase;letter-spacing:.3px;color:var(--text2);font-weight:700;}
#cnt .vg-tk-v{font-size:19px;font-weight:800;margin-top:3px;color:var(--text);}
#cnt .vg-tk-v.g{color:var(--green);}#cnt .vg-tk-v.b{color:var(--blue);}#cnt .vg-tk-v.o{color:var(--orange);}

/* agents */
#cnt .vg-agent{display:flex;align-items:center;gap:9px;padding:7px 0;border-bottom:1px solid var(--border);}
#cnt .vg-agent:last-child{border-bottom:none;}
#cnt .vg-rank{width:20px;height:20px;border-radius:50%;background:var(--bg-2,#f1f5f9);display:flex;
  align-items:center;justify-content:center;font-size:10px;font-weight:800;color:var(--text2);}
#cnt .vg-rank.gold{background:var(--gold,#C89B3C);color:#fff;}
#cnt .vg-an{flex:1;font-size:12px;font-weight:600;}
#cnt .vg-am{font-size:11.5px;color:var(--text2);font-weight:600;}#cnt .vg-am b{color:var(--green);}

/* brand */
#cnt .vg-brand{display:grid;grid-template-columns:1fr auto;gap:2px 11px;padding:9px 0;
  border-bottom:1px solid var(--border);align-items:center;}
#cnt .vg-brand:last-child{border-bottom:none;}
#cnt .vg-brand-n{font-size:12.5px;font-weight:700;grid-column:1;}
#cnt .vg-brand-s{font-size:10.5px;color:var(--text2);grid-column:1;grid-row:2;}
#cnt .vg-brand-bar{grid-column:1;grid-row:3;height:6px;background:var(--bg-2,#f1f5f9);border-radius:5px;overflow:hidden;margin-top:3px;}
#cnt .vg-brand-bar i{display:block;height:100%;border-radius:5px;}
#cnt .vg-brand-p{grid-column:2;grid-row:1/4;font-weight:800;font-size:15px;align-self:center;}

/* funnel */
#cnt .vg-fn{display:flex;align-items:center;gap:9px;margin-bottom:7px;}
#cnt .vg-fn-l{flex:0 0 84px;font-size:11.5px;font-weight:600;color:var(--text2);}
#cnt .vg-fn-t{flex:1;height:26px;background:var(--bg-2,#f1f5f9);border-radius:7px;overflow:hidden;}
#cnt .vg-fn-f{height:100%;border-radius:7px;display:flex;align-items:center;padding-left:10px;color:#fff;font-weight:700;font-size:11.5px;}

/* bars (villes) */
#cnt .vg-bars{display:flex;align-items:flex-end;gap:8px;height:130px;padding-top:6px;}
#cnt .vg-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;height:100%;justify-content:flex-end;}
#cnt .vg-bar{width:100%;max-width:34px;border-radius:6px 6px 0 0;}
#cnt .vg-bar-v{font-size:10.5px;font-weight:700;}
#cnt .vg-bar-l{font-size:9.5px;color:var(--text2);font-weight:600;}

/* alerts */
#cnt .vg-alert{display:flex;gap:9px;padding:9px 11px;border-radius:9px;margin-bottom:7px;align-items:flex-start;font-size:11.5px;line-height:1.4;}
#cnt .vg-alert:last-child{margin-bottom:0;}
#cnt .vg-alert.red{background:var(--red-bg,#FEF2F2);}
#cnt .vg-alert.orange{background:var(--orange-bg,#FFFBEB);}
#cnt .vg-alert.green{background:var(--green-bg,#F0FDF4);}

/* gauge */
#cnt .vg-gauge-wrap{display:flex;align-items:center;gap:14px;}
#cnt .vg-gauge{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
#cnt .vg-gauge-in{width:58px;height:58px;border-radius:50%;background:var(--bg-elev,#fff);display:flex;flex-direction:column;align-items:center;justify-content:center;}
#cnt .vg-gauge-in b{font-size:17px;font-weight:800;}
#cnt .vg-gauge-in small{font-size:8.5px;color:var(--text2);}
#cnt .vg-gauge-tx{font-size:11.5px;color:var(--text2);line-height:1.5;}

/* note config */
#cnt .vg-nc-note{margin-top:16px;background:var(--bg-2,#FFF8F4);border:1px dashed var(--accent);
  border-radius:11px;padding:12px 15px;font-size:11.5px;color:var(--text2);line-height:1.5;}

@media(max-width:1150px){
  #cnt .vg-kpis{grid-template-columns:repeat(3,1fr);}
  #cnt .vg-row2,#cnt .vg-row3,#cnt .vg-row2b{grid-template-columns:1fr;}
}

/* ============================================================
   22. MENU DROPDOWN — groupes repliables
   ============================================================ */
/* accès rapide (Vision Globale hors dropdown) */
.nav-quick-access{padding:0 0 6px;margin-bottom:6px;border-bottom:1px solid rgba(255,255,255,.08);}
.nav-quick-access .nav-item{background:rgba(232,64,12,.14);}
.nav-quick-access .nav-item:hover{background:rgba(232,64,12,.24);}
.nav-quick-access .nav-item.active{background:var(--accent,#E8400C);}

/* en-tête de groupe cliquable */
.nav-dropdown{margin-bottom:2px;}
.nav-dropdown-head{display:flex;align-items:center;width:100%;gap:10px;padding:10px 12px;
  background:transparent;border:none;cursor:pointer;border-radius:9px;text-align:left;
  font-family:inherit;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;
  color:#a8a8b3;transition:.15s;}
.nav-dropdown-head:hover{background:rgba(255,255,255,.05);color:#fff;}
.nav-dropdown.open .nav-dropdown-head{color:#fff;}
.nav-dd-label{flex:1;}
.nav-dd-count{font-size:10px;background:rgba(255,255,255,.12);border-radius:10px;padding:1px 7px;
  font-weight:700;min-width:20px;text-align:center;}
.nav-dd-arrow{font-size:9px;opacity:.6;transition:transform .25s ease;margin-left:4px;}
.nav-dropdown.open .nav-dd-arrow{transform:rotate(90deg);}

/* conteneur repliable */
.nav-dropdown-items{max-height:0;overflow:hidden;transition:max-height .28s ease;}
.nav-dropdown.open .nav-dropdown-items{max-height:800px;}
.nav-dropdown-items .nav-item{padding-left:18px;font-size:13px;font-weight:500;margin:1px 0;}

/* thème clair : adapter les couleurs */
body:not(.yabox-os-kit) .nav-dropdown-head,
body[data-theme] .nav-dropdown-head{color:inherit;}

/* ============================================================
   23. WORKSPACE CONFIRMATION — Style A (moderne & coloré)
   Cible .cai-style-a, n'affecte que l'interface de confirmation.
   ============================================================ */
/* header coloré dégradé */
.cai-style-a .cai-style-a-hdr{
  background:linear-gradient(135deg,#E8400C,#FF7A45)!important;
  color:#fff!important;padding:18px 20px!important;border-radius:16px 16px 0 0!important;border:none!important;}
.cai-style-a .cai-sa-name{font-weight:800;font-size:22px;color:#fff;display:block;}
.cai-style-a .cai-sa-phone{font-family:'DM Mono',monospace;font-size:15px;color:#fff;margin-top:4px;letter-spacing:.5px;}
.cai-style-a .cai-style-a-hdr .cai-tag{font-weight:700;}
.cai-style-a .cai-sa-status{background:rgba(255,255,255,.22)!important;color:#fff!important;}

/* barre Business Intelligence */
.cai-style-a .cai-sa-bi{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:14px 0 16px;}
.cai-style-a .cai-sa-bi .bi{background:var(--purple-bg,#F5F3FF);border-radius:11px;padding:10px 8px;text-align:center;}
.cai-style-a .cai-sa-bi .biv{font-size:18px;font-weight:800;color:var(--purple,#7C3AED);line-height:1;}
.cai-style-a .cai-sa-bi .bik{font-size:9px;color:#6B7280;text-transform:uppercase;letter-spacing:.4px;font-weight:700;margin-top:3px;}

/* sections : cartes plus douces */
.cai-style-a .cai-section{border:1px solid #EEF0F3!important;border-radius:14px!important;
  margin-bottom:10px!important;box-shadow:0 1px 3px rgba(15,23,42,.04);}
.cai-style-a .sec-lbl{font-size:12px!important;font-weight:800!important;text-transform:uppercase;
  letter-spacing:.5px;color:#16161A!important;padding:12px 14px!important;}
.cai-style-a .sec-body{padding:0 14px 14px!important;}

/* actions : boutons plus gros, mieux espacés */
.cai-style-a .cai-acts{grid-template-columns:1fr 1fr!important;gap:9px!important;padding:14px!important;}
.cai-style-a .cai-acts button{padding:13px!important;font-size:14px!important;font-weight:800!important;
  border-radius:11px!important;transition:.15s;}
.cai-style-a .cai-acts button:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.12);}
/* le bouton Confirmer en pleine largeur et bien vert */
.cai-style-a .cai-acts button[data-conf-action="confirm"]{grid-column:1/3!important;
  background:var(--green,#16A34A)!important;color:#fff!important;font-size:16px!important;padding:16px!important;}

/* champ prix / total du panier : mise en valeur */
.cai-style-a .sec-body input[type="number"],
.cai-style-a .sec-body input.yabox-input{border-radius:9px;}

/* transporteur : select plus lisible */
.cai-style-a #carrier-sel-,.cai-style-a [id^="carrier-sel-"]{border-radius:9px!important;padding:10px!important;font-weight:600;}

/* boutons timeline / notes : plus visibles */
.cai-style-a [data-action="ca-show-timeline"],
.cai-style-a [data-action="ca-quick-note"]{border-radius:10px!important;font-weight:700!important;
  background:#F6F7F9!important;border:1px solid #E6E8EC!important;padding:11px!important;}
.cai-style-a [data-action="ca-show-timeline"]:hover,
.cai-style-a [data-action="ca-quick-note"]:hover{background:#EEF0F3!important;}

/* dark mode adaptation */
body[data-theme="nuit"] .cai-style-a .cai-section{background:var(--bg-2,#1a1a22)!important;border-color:#2a2a35!important;}
body[data-theme="nuit"] .cai-style-a .sec-lbl{color:#e8e8ef!important;}

/* ============================================================
   24. MENU PROFIL — carte user cliquable + déroulant
   ============================================================ */
.sd-user[data-action="toggle-profile-menu"]{transition:.15s;position:relative;}
.sd-user[data-action="toggle-profile-menu"]:hover{background:var(--bg-3,rgba(255,255,255,.08))!important;}
.sd-profile-menu{margin-top:8px;background:var(--bg-2,#1f1813);border:1px solid var(--b-1,rgba(255,255,255,.12));
  border-radius:13px;padding:6px;box-shadow:0 12px 30px rgba(0,0,0,.35);animation:sdpm-in .15s ease;}
@keyframes sdpm-in{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:translateY(0);}}
.sd-pm-head{padding:9px 11px;border-bottom:1px solid var(--b-1,rgba(255,255,255,.08));margin-bottom:4px;}
.sd-pm-name{font-size:13px;font-weight:800;color:var(--t-1,#fff);}
.sd-pm-mail{font-size:10px;color:var(--t-4,#8b8b96);font-family:var(--font-mono,monospace);margin-top:1px;}
.sd-pm-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:8px 2px 2px;}
.sd-pm-stat{background:var(--bg-3,rgba(255,255,255,.06));border-radius:9px;padding:6px;text-align:center;}
.sd-pm-stat .v{font-size:14px;font-weight:800;color:var(--t-1,#fff);}
.sd-pm-stat .k{font-size:8px;color:var(--t-4,#8b8b96);text-transform:uppercase;letter-spacing:.3px;margin-top:1px;}
.sd-pm-item{display:flex;align-items:center;gap:11px;width:100%;padding:10px 11px;background:transparent;
  border:none;color:var(--t-3,#d4d4dc);font-size:13px;font-weight:600;border-radius:9px;cursor:pointer;
  font-family:inherit;text-align:left;transition:.12s;}
.sd-pm-item:hover{background:var(--bg-3,rgba(255,255,255,.08));color:var(--t-1,#fff);}
.sd-pm-ic{width:20px;text-align:center;font-size:14px;}
.sd-pm-sep{height:1px;background:var(--b-1,rgba(255,255,255,.08));margin:4px 6px;}
.sd-pm-item.logout{color:#FF7A6B;}
.sd-pm-item.logout:hover{background:rgba(239,68,68,.15);}

/* ============================================================
   25. BLITZ MODE — Style A (carte rapide)
   ============================================================ */
.bcard-style-a{border-radius:18px!important;border:1px solid #EEF0F3!important;padding:18px!important;}
.bcard-style-a .bcard-sa-hdr{background:linear-gradient(135deg,#E8400C,#FF7A45);margin:-18px -18px 14px!important;
  padding:18px!important;border-radius:18px 18px 0 0;color:#fff;}
.bcard-style-a .bcard-sa-hdr .cai-tag{background:rgba(255,255,255,.22)!important;color:#fff!important;}
.bcard-style-a .bcard-sa-name{color:#fff!important;}
.bcard-style-a .bcard-sa-hdr .flbl,.bcard-style-a .bcard-sa-hdr label{color:rgba(255,255,255,.85)!important;}
.bcard-style-a .bcard-sa-hdr input,.bcard-style-a .bcard-sa-hdr select{background:rgba(255,255,255,.15)!important;
  border-color:rgba(255,255,255,.25)!important;color:#fff!important;}
.bcard-style-a .bcard-sa-hdr input::placeholder{color:rgba(255,255,255,.6)!important;}
/* montant CRBT bien visible dans le header */
.bcard-style-a .bcard-sa-hdr [style*="color:var(--green)"]{color:#fff!important;}
/* boutons Blitz plus gros */
.bcard-style-a ~ div [data-bact] , .bcard-style-a + div [data-bact]{border-radius:11px!important;font-weight:800!important;}

/* ============================================================
   26. CORRECTIFS MOBILE — Style A confirmation + Blitz + profil
   ============================================================ */
@media(max-width:768px){
  /* --- Workspace confirmation : champs lisibles dans le header orange --- */
  .cai-style-a .cai-style-a-hdr{padding:14px!important;}
  .cai-style-a .cai-style-a-hdr .flbl,
  .cai-style-a .cai-style-a-hdr label{color:rgba(255,255,255,.9)!important;font-size:10px!important;}
  .cai-style-a .cai-style-a-hdr input.yabox-input{
    background:rgba(255,255,255,.16)!important;border:1px solid rgba(255,255,255,.3)!important;
    color:#fff!important;width:100%!important;box-sizing:border-box;border-radius:9px!important;}
  .cai-style-a .cai-style-a-hdr input.yabox-input::placeholder{color:rgba(255,255,255,.6)!important;}
  /* le bouton ✓ de sauvegarde : ne plus flotter, l'intégrer à droite du label */
  .cai-style-a .cai-style-a-hdr .flbl .yabox-btn,
  .cai-style-a .flbl .yabox-btn{background:rgba(255,255,255,.25)!important;color:#fff!important;
    border-radius:6px!important;flex-shrink:0;}
  /* éviter le chevauchement : chaque champ sur sa ligne, marge nette */
  .cai-style-a .cai-style-a-hdr > div{margin-bottom:6px;}

  /* Blitz : header sur mobile */
  .bcard-style-a{padding:14px!important;}
  .bcard-style-a .bcard-sa-hdr{margin:-14px -14px 12px!important;padding:14px!important;}
  .bcard-style-a .bcard-sa-hdr input.yabox-input{background:rgba(255,255,255,.16)!important;
    border-color:rgba(255,255,255,.3)!important;color:#fff!important;width:100%!important;box-sizing:border-box;}
  .bcard-style-a .bcard-sa-hdr .flbl{color:rgba(255,255,255,.9)!important;}

  /* --- Menu profil : overlay propre par-dessus (pas pousser le contenu) --- */
  .sd-profile-menu{position:fixed!important;left:12px!important;right:12px!important;
    top:auto!important;bottom:70px!important;z-index:9999!important;max-height:60vh;overflow-y:auto;}

  /* --- Champ éditable générique : empêcher le chevournement des boutons --- */
  .cai-style-a .flbl{display:flex!important;justify-content:space-between!important;align-items:center!important;gap:6px;}
  .cai-style-a .sec-body input.yabox-input{width:100%!important;box-sizing:border-box;}

  /* --- Bouton dispatch qui apparaît vide/bleu : forcer le texte visible --- */
  .obtn-primary[data-action="ca-dispatch-confirmation"]{
    white-space:normal!important;line-height:1.2!important;min-height:40px;color:#fff!important;}
}

/* Très petit écran (≤420px) : actions confirmation en 1 colonne */
@media(max-width:420px){
  .cai-style-a .cai-acts{grid-template-columns:1fr!important;}
  .cai-style-a .cai-acts button[data-conf-action="confirm"]{grid-column:1!important;}
}

/* ============================================================
   27. CONFIRMATION Style A — Timeline inline + Notes rapides
   ============================================================ */
.cai-style-a .cai-sa-timeline{background:#FFF8F4;border:1px solid #FFE0CC;border-radius:11px;padding:12px 14px;}
body[data-theme="nuit"] .cai-style-a .cai-sa-timeline{background:rgba(232,64,12,.08);border-color:rgba(232,64,12,.25);}
.cai-style-a .cai-sa-tl-row{display:flex;gap:11px;padding:5px 0;position:relative;}
.cai-style-a .cai-sa-tl-row:not(:last-child)::before{content:"";position:absolute;left:5px;top:17px;bottom:-5px;width:2px;background:#FFD4B8;}
.cai-style-a .cai-sa-tl-dot{width:12px;height:12px;border-radius:50%;background:var(--accent,#E8400C);flex-shrink:0;margin-top:3px;z-index:1;}
.cai-style-a .cai-sa-tl-dot.ok{background:var(--green,#16A34A);}
.cai-style-a .cai-sa-tl-dot.warn{background:var(--orange,#F59E0B);}
.cai-style-a .cai-sa-tl-c{flex:1;}
.cai-style-a .cai-sa-tl-t{font-size:12.5px;font-weight:700;color:var(--text,#16161A);}
.cai-style-a .cai-sa-tl-d{font-size:11px;color:var(--text2,#9CA3AF);}
.cai-style-a .cai-sa-notes-quick{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap;}
.cai-style-a .cai-sa-notes-quick button{background:#F6F7F9;border:none;border-radius:8px;padding:6px 11px;
  font-size:11.5px;font-weight:600;cursor:pointer;color:#444;width:auto;}
.cai-style-a .cai-sa-notes-quick button:hover{background:#EBEDF0;}
body[data-theme="nuit"] .cai-style-a .cai-sa-notes-quick button{background:var(--bg-3,#2a2a35);color:#d4d4dc;}

/* ============================================================
   28. VISION GLOBALE — en-tête + filtre période (maquette)
   ============================================================ */
.vg-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:18px;flex-wrap:wrap;gap:12px;}
.vg-h1{font-size:24px;font-weight:800;color:var(--text,#16161A);margin:0;}
.vg-sub{font-size:12px;color:var(--text2,#6B7280);margin-top:2px;}
.vg-seg{display:inline-flex;background:var(--bg-2,#F1F3F5);border-radius:11px;padding:3px;gap:2px;}
.vg-seg button{border:none;background:transparent;padding:7px 16px;font-size:13px;font-weight:700;
  border-radius:9px;cursor:pointer;color:var(--text2,#6B7280);font-family:inherit;transition:.12s;}
.vg-seg button:hover{color:var(--text,#16161A);}
.vg-seg button.on{background:var(--accent,#E8400C);color:#fff;box-shadow:0 2px 6px rgba(232,64,12,.3);}
@media(max-width:768px){
  .vg-head{flex-direction:column;align-items:stretch;}
  .vg-seg{width:100%;justify-content:space-between;}
  .vg-seg button{flex:1;padding:9px 4px;}
}

/* ============================================================
   29. VISION GLOBALE — WhatsApp + Agents disponibles
   ============================================================ */
.vg-wa-card .vg-wa-big{font-size:42px;font-weight:800;color:var(--wa,#25D366);line-height:1;margin:8px 0 4px;}
.vg-wa-card .vg-wa-lbl{font-size:13px;color:var(--text2,#6B7280);margin-bottom:12px;}
.vg-wa-card .vg-wa-btn{background:var(--wa,#25D366);color:#fff;border:none;border-radius:10px;
  padding:10px 16px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;}
.vg-wa-card .vg-wa-btn:hover{filter:brightness(.95);}
.vg-agents-card .vg-ag-count{background:var(--accent,#E8400C);color:#fff;border-radius:999px;
  padding:2px 10px;font-size:13px;font-weight:700;margin-left:6px;}
.vg-ag-list{display:flex;flex-direction:column;gap:6px;margin-top:10px;max-height:240px;overflow-y:auto;}
.vg-ag-row{display:flex;align-items:center;gap:9px;padding:8px 10px;background:var(--bg-2,#F6F7F9);border-radius:9px;}
.vg-ag-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
.vg-ag-dot.on{background:#16A34A;}.vg-ag-dot.pause{background:#F59E0B;}.vg-ag-dot.off{background:#9CA3AF;}
.vg-ag-name{font-size:13px;font-weight:700;color:var(--text,#16161A);flex:1;}
.vg-ag-role{font-size:11px;color:var(--text2,#9CA3AF);}
.vg-ag-st{font-size:11px;font-weight:700;}
.vg-ag-st.on{color:#16A34A;}.vg-ag-st.pause{color:#F59E0B;}.vg-ag-st.off{color:#9CA3AF;}

/* ============================================================
   30. VISION GLOBALE — Trésorerie COD (barre cash)
   ============================================================ */
.vg-treso-card .vg-cs{font-size:12px;color:var(--text2,#6B7280);margin-bottom:14px;}
.vg-treso-bar{display:flex;height:42px;border-radius:11px;overflow:hidden;margin-bottom:14px;background:var(--bg-2,#F1F3F5);}
.vg-treso-seg{display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;
  white-space:nowrap;overflow:hidden;transition:width .4s ease;}
.vg-treso-seg.enc{background:#16A34A;}
.vg-treso-seg.tr{background:#F59E0B;}
.vg-treso-seg.ri{background:#EF4444;}
.vg-treso-legend{display:flex;flex-wrap:wrap;gap:14px;font-size:12px;color:var(--text2,#6B7280);}
.vg-treso-legend span{display:flex;align-items:center;gap:6px;}
.vg-lg-dot{width:10px;height:10px;border-radius:50%;display:inline-block;}
.vg-lg-dot.enc{background:#16A34A;}.vg-lg-dot.tr{background:#F59E0B;}.vg-lg-dot.ri{background:#EF4444;}

/* ============================================================
   31. EXECUTIVE ACTION CENTER (V3458) — décisions
   ============================================================ */
.eac-page{padding:4px 2px;}
.eac-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:18px;flex-wrap:wrap;gap:12px;}
.eac-h1{font-size:23px;font-weight:800;color:var(--text,#16161A);margin:0;}
.eac-sub{font-size:12px;color:var(--text2,#6B7280);margin-top:3px;}
.eac-recompute{background:var(--accent,#E8400C);color:#fff;border:none;border-radius:10px;padding:10px 16px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;}
.eac-recompute:hover{filter:brightness(.95);}
.eac-loading,.eac-empty{padding:30px;text-align:center;color:var(--text2,#9CA3AF);font-size:14px;}
.eac-warn{background:#FFFBEB;border:1px solid #FDE68A;color:#92400E;border-radius:10px;padding:11px 14px;font-size:12.5px;margin-bottom:16px;}
.eac-sec{margin-bottom:22px;}
.eac-sec-h{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--text,#16161A);margin-bottom:11px;display:flex;align-items:center;gap:7px;}
.eac-n{background:var(--soft,#F1F3F5);color:var(--text2,#6B7280);border-radius:999px;padding:1px 9px;font-size:12px;}
.eac-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:12px;}
.eac-card{background:#fff;border:1px solid var(--line,#EEF0F3);border-radius:13px;padding:14px 15px;box-shadow:0 2px 8px rgba(15,23,42,.04);}
.eac-top{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap;}
.eac-badge{color:#fff;border-radius:7px;padding:3px 9px;font-size:11px;font-weight:800;}
.eac-mod{font-size:11px;color:var(--text2,#9CA3AF);font-weight:600;}
.eac-st{font-size:10px;font-weight:700;border-radius:6px;padding:2px 8px;text-transform:uppercase;margin-left:auto;}
.eac-st-accepted{background:#EFF6FF;color:#2155E0;}.eac-st-done{background:#F0FDF4;color:#16A34A;}
.eac-st-rejected,.eac-st-ignored{background:#FEF2F2;color:#EF4444;}.eac-st-in_review{background:#FFFBEB;color:#F59E0B;}
.eac-title{font-size:15px;font-weight:800;color:var(--text,#16161A);margin-bottom:8px;text-transform:capitalize;}
.eac-target{color:var(--accent,#E8400C);font-weight:700;}
.eac-reason,.eac-impact{font-size:12.5px;color:#444;margin-bottom:5px;line-height:1.45;}
.eac-conf{font-size:11px;color:var(--text2,#9CA3AF);margin:8px 0 11px;font-style:italic;}
.eac-acts{display:flex;gap:7px;}
.eac-b{flex:1;border:none;border-radius:9px;padding:9px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;}
.eac-b.ok{background:#F0FDF4;color:#16A34A;}.eac-b.acc{background:#EFF6FF;color:#2155E0;}.eac-b.rej{background:#FEF2F2;color:#EF4444;}
.eac-b:hover{filter:brightness(.96);}
@media(max-width:760px){.eac-grid{grid-template-columns:1fr;}}

/* ============================================================
   32. CONFIRMATION Workspace — Layout 2 colonnes (design validé)
   ============================================================ */
/* V3477 — Panneau détail : UN SEUL BLOC vertical (le 2-colonnes cassait
   dans le panneau étroit, le breakpoint viewport ne reflète pas la largeur
   réelle du panneau). Client → Panier → Livraison → Actions empilés. */
.cai-2col-wrap{display:flex;flex-direction:column;gap:10px;align-items:stretch;}
.cai-2col-wrap .cai-col{display:flex;flex-direction:column;gap:10px;min-width:0;width:100%;}
.cai-2col-wrap .cai-col-right{background:transparent;border-radius:0;padding:0;}
body[data-theme="nuit"] .cai-2col-wrap .cai-col-right{background:transparent;}

/* ============================================================
   33. V3477 — CONFIRMATION redesign validé (blocs 1·2·3 + Blitz)
   Design tokens : violet #534AB7, orange accent #E8400C
   ============================================================ */

/* ── BLOC 3 : workspace 1 colonne ── */
.cai-1col-wrap{display:flex;flex-direction:column;gap:10px;align-items:stretch;}
.cai-1col-wrap .cai-section{width:100%;}

/* Boutons rapides header (appel / WhatsApp) */
.cai-sa-quick{display:flex;gap:7px;}
.cai-sa-q{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;
  font-size:16px;text-decoration:none;background:rgba(255,255,255,.18);color:#fff;transition:.13s;}
.cai-sa-q:hover{transform:translateY(-1px);background:rgba(255,255,255,.3);}
.cai-sa-q.call{background:#fff;}
.cai-sa-q.wa{background:#25D366;}

/* Bande FLASH 3 secondes (dans le header orange) */
.cai-sa-flash{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.25);border-radius:11px;padding:8px 12px;margin-top:9px;}
.cai-sa-flash .fp{flex:1;min-width:0;}
.cai-sa-flash .ft{font-size:12.5px;font-weight:800;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cai-sa-flash .fm{font-size:10.5px;color:rgba(255,255,255,.9);margin-top:1px;}
.cai-sa-flash .fc{text-align:right;flex-shrink:0;}
.cai-sa-flash .fv{font-size:20px;font-weight:800;color:#fff;line-height:1;font-family:'DM Mono',monospace;}
.cai-sa-flash .fk{font-size:8.5px;font-weight:700;color:rgba(255,255,255,.85);letter-spacing:.5px;margin-top:2px;}

/* Sections repliables (BI / etc.) */
.cai-fold{border:1px solid #EEF0F3;border-radius:13px;margin:10px 0;background:#fff;overflow:hidden;}
.cai-fold summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;
  padding:11px 14px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:#6B7280;background:#FCFCFD;}
.cai-fold summary::-webkit-details-marker{display:none;}
.cai-fold .cai-fold-body{padding:11px 13px;border-top:1px solid #EEF0F3;}
.cai-fold .cai-fold-arr{transition:.15s;}
.cai-fold[open] .cai-fold-arr{transform:rotate(180deg);}
.cai-fold .cai-fold-body .cai-section{border:none!important;box-shadow:none!important;margin:0!important;}
body[data-theme="nuit"] .cai-fold{background:var(--bg-2,#1a1a22);border-color:#2a2a35;}
body[data-theme="nuit"] .cai-fold summary{background:rgba(255,255,255,.03);color:#c9c9d4;}

/* V3498 - Confirmation principal: les blocs critiques du panneau droit restent ouverts et lisibles. */
#cai-detail .sec-body,
#cai-detail .cai-fold-body{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  height:auto!important;
  max-height:none!important;
  overflow:visible!important;
}
#cai-detail .ca-visible-summary{
  display:grid!important;
  gap:6px;
  margin:0 0 10px;
  padding:10px;
  border:1px solid #E2E8F0;
  border-radius:10px;
  background:#F8FAFC;
  color:#0F172A!important;
}
#cai-detail .ca-visible-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  font-size:12px;
  line-height:1.35;
}
#cai-detail .ca-fixed-panel{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:12px!important;
  padding:0!important;
  color:#0F172A!important;
}
#cai-detail .ca-fixed-card{
  display:block!important;
  padding:14px!important;
  border:1px solid #E2E8F0!important;
  border-radius:12px!important;
  background:#FFFFFF!important;
  box-shadow:0 1px 2px rgba(15,23,42,.04)!important;
}
#cai-detail .ca-fixed-title{
  margin:0 0 10px!important;
  color:#0F172A!important;
  font-size:12px!important;
  line-height:1.25!important;
  font-weight:900!important;
  letter-spacing:.04em!important;
  text-transform:uppercase!important;
}
#cai-detail .ca-fixed-content{display:grid!important;gap:7px!important;}
#cai-detail .ca-fixed-row{display:flex!important;justify-content:space-between!important;align-items:flex-start!important;gap:12px!important;min-height:20px!important;}
#cai-detail .ca-fixed-k{flex:0 0 auto!important;color:#64748B!important;font-size:11px!important;font-weight:800!important;}
#cai-detail .ca-fixed-v{min-width:0!important;color:#0F172A!important;font-size:12px!important;font-weight:750!important;text-align:right!important;white-space:normal!important;}
#cai-detail .ca-fixed-v.strong{font-weight:950!important;}
#cai-detail .ca-fixed-actions{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:8px!important;}
#cai-detail .ca-fixed-action{min-height:38px!important;padding:8px 10px!important;border:1px solid var(--ca-action-color,#743e8f)!important;border-radius:9px!important;background:var(--ca-action-color,#743e8f)!important;color:#fff!important;font-size:12px!important;font-weight:900!important;cursor:pointer!important;}
#cai-detail .ca-fixed-action.ghost{background:#fff!important;color:var(--ca-action-color,#64748B)!important;}
#cai-detail .ca-fixed-action:disabled{background:#F1F5F9!important;border-color:#CBD5E1!important;color:#64748B!important;cursor:not-allowed!important;}
#cai-detail .ca-fixed-warning,
#cai-detail .ca-fixed-notice{grid-column:1/-1!important;padding:9px 10px!important;border-radius:9px!important;font-size:12px!important;font-weight:850!important;}
#cai-detail .ca-fixed-warning{background:#FFF7ED!important;border:1px solid #FDBA74!important;color:#9A3412!important;}
#cai-detail .ca-fixed-notice{background:#EFF6FF!important;border:1px solid #BFDBFE!important;color:#1D4ED8!important;}
#cai-detail .ca-visible-k{
  flex:0 0 auto;
  color:#64748B!important;
  font-weight:800;
  text-transform:uppercase;
  font-size:10px;
}
#cai-detail .ca-visible-v{
  min-width:0;
  color:#1E293B!important;
  font-weight:700;
  text-align:right;
  white-space:normal;
  overflow:visible;
}
#cai-detail .ca-visible-v.strong,
#cai-detail .ca-visible-note{
  color:#0F172A!important;
  font-weight:900;
}

/* Bouton Créer la livraison — orange dégradé pleine largeur */
.ca-ship-btn{width:100%!important;padding:12px!important;border:none!important;border-radius:11px!important;
  font-size:13.5px!important;font-weight:800!important;cursor:pointer;color:#fff!important;
  background:linear-gradient(135deg,#E8400C,#FF7A45)!important;
  box-shadow:0 4px 14px rgba(232,64,12,.25);transition:.15s;}
.ca-ship-btn:hover:not([disabled]){transform:translateY(-2px);box-shadow:0 8px 20px rgba(232,64,12,.35);}

/* ── BLOC 1 : files (sidebar confirmation) ── */
#cai-sb-inner .cai-sb-sec{font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;
  color:#9CA3AF;margin:14px 8px 6px;}
#cai-sb-inner .cai-sb-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border:none;
  background:transparent;border-radius:10px;cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:600;
  color:var(--text,#16161A);transition:.12s;text-align:left;position:relative;margin-bottom:2px;}
#cai-sb-inner .cai-sb-item:hover{background:var(--bg2,#F6F7F9);}
#cai-sb-inner .cai-sb-item.active{background:#EEEDFE;color:#3C3489;font-weight:800;}
#cai-sb-inner .cai-sb-item.active::before{content:"";position:absolute;left:-6px;top:7px;bottom:7px;width:3px;
  border-radius:3px;background:#534AB7;}
#cai-sb-inner .cai-sb-cnt{margin-left:auto;font-size:11px;font-weight:800;color:var(--text2,#6B7280);
  font-family:'DM Mono',monospace;}
#cai-sb-inner .cai-sb-item.active .cai-sb-cnt{color:#3C3489;}
body[data-theme="nuit"] #cai-sb-inner .cai-sb-item.active{background:rgba(83,74,183,.22);color:#cdc8ff;}

/* ── BLOC 2 : barre KPI ── */
#cai-kbar .kpi{border-radius:12px;border:none;border-top:3px solid #9CA3AF;background:var(--bg,#fff);
  box-shadow:0 4px 14px rgba(15,23,42,.05);}
#cai-kbar .kpi.blue{border-top-color:#534AB7;}
#cai-kbar .kpi.green{border-top-color:#16A34A;}
#cai-kbar .kpi.gray{border-top-color:#6B7280;}
#cai-kbar .kpi.red{border-top-color:#EF4444;}
#cai-kbar .kpiv{font-family:'DM Mono',monospace;}

/* ── BLOC 2 : barre filtres ── */
#cai-list .filters-row{background:var(--bg,#fff);border-radius:13px;padding:9px 11px;
  box-shadow:0 4px 14px rgba(15,23,42,.05);}
#cai-list .filters-row .ninp{border:1.5px solid #E6E8EC;border-radius:9px;padding:7px 8px;font-weight:600;}
#cai-list .ca-fdate{border-color:#D7D3F7!important;background:#EEEDFE!important;color:#3C3489!important;font-weight:700!important;}
#cai-list .ca-fdate-pick{font-family:'DM Mono',monospace;}
body[data-theme="nuit"] #cai-list .ca-fdate{background:rgba(83,74,183,.18)!important;color:#cdc8ff!important;border-color:#534AB766!important;}

/* ── BLOC 2 : cartes commandes ── */
#cai-list .cai-card{background:var(--bg,#fff);border:1px solid #EEF0F3;border-left-width:4px;border-radius:13px;
  padding:11px 13px;margin-bottom:8px;cursor:pointer;transition:.13s;}
#cai-list .cai-card:hover{box-shadow:0 8px 22px rgba(15,23,42,.09);transform:translateY(-1px);}
#cai-list .cai-card.selected{box-shadow:0 0 0 2px #EEEDFE,0 8px 22px rgba(83,74,183,.13);border-color:#534AB7;}
#cai-list .cai-card .cai-tag{border-radius:999px;font-weight:700;}
.cai-card-age{margin-left:auto;font-size:10px;font-weight:700;color:#9CA3AF;}
.cai-card-age.warn{color:#F59E0B;}
body[data-theme="nuit"] #cai-list .cai-card{border-color:#2a2a35;}

/* ── BLITZ : barre navigation ── */
.blitz-bar{background:linear-gradient(135deg,#534AB7,#7B6FE0);border-radius:14px;padding:11px 13px;
  margin-bottom:10px;box-shadow:0 8px 24px rgba(83,74,183,.3);}
.blitz-bar .bb-r1{display:flex;align-items:center;gap:9px;}
.blitz-bar .bb-t{color:#fff;font-size:13px;font-weight:800;flex:1;}
.blitz-bar .bb-quit{border:none;background:rgba(255,255,255,.18);color:#fff;border-radius:9px;width:30px;height:30px;
  font-size:13px;cursor:pointer;flex-shrink:0;font-family:inherit;}
.blitz-bar .bb-prog{height:5px;background:rgba(255,255,255,.22);border-radius:99px;margin:9px 0;overflow:hidden;}
.blitz-bar .bb-prog i{display:block;height:100%;background:#fff;border-radius:99px;transition:width .3s;}
.blitz-bar .bb-r2{display:flex;align-items:center;gap:6px;}
.blitz-bar .bb-st{font-size:10.5px;font-weight:700;color:#fff;background:rgba(255,255,255,.16);padding:4px 9px;border-radius:7px;}
.blitz-bar .bb-r2 button{border:none;border-radius:9px;padding:8px 13px;font-size:12px;font-weight:800;cursor:pointer;
  font-family:inherit;transition:.13s;}
.blitz-bar .bb-r2 button:hover{transform:translateY(-1px);}
.blitz-bar .bb-prev{background:rgba(255,255,255,.2);color:#fff;}
.blitz-bar .bb-skip{background:rgba(255,255,255,.1);color:rgba(255,255,255,.85);font-size:11px;}
.blitz-bar .bb-next{background:#fff;color:#534AB7;}
.blitz-hint{background:var(--bg,#fff);border:1px dashed #D7D3F7;border-radius:12px;padding:14px;
  font-size:12px;color:var(--text2,#6B7280);text-align:center;line-height:1.6;}
@media(max-width:760px){.blitz-hint{display:none;}}
