:root{
  /* Brand — navy + bauxite (oxyde de fer, accent E du wordmark ALIM[E]X) */
  --navy:#0b2d52; --navy7:#143a66; --navy-soft:#1E3A5F; --navy-deep:#072037; --navy-tint:#E8EFF7; --navy-press:#0A2444;
  --bauxite:#C8552B; --bauxite-soft:#FDF2EC; --bauxite-deep:#7A2E12; --bauxite-tint:#FBEDE6;
  /* Surfaces */
  --bg:#F7F8FA; --canvas:#EEF1F5; --card:#FFFFFF; --chrome:#F4F6FA;
  /* Lignes */
  --line:#E5E7EB; --line-soft:#F3F4F6;
  /* Texte */
  --ink:#0E1A2B; --slate:#2C3E54; --muted:#5A6B80; --faint:#8A99AD;
  /* Status — LANGAGE (Monday) : -solid = bloc d'état plein ; -s/-bd = méta douce */
  --ok:#059669; --ok-s:#D9F2E6; --ok-bd:#A7E0C6; --ok-solid:#16A34A;
  --warn:#B45309; --warn-s:#FCEBCB; --warn-bd:#F5D08A; --warn-solid:#EA8C0C;
  --danger:#DC2626; --danger-s:#FBDADA; --danger-bd:#F4A8A8; --danger-solid:#DC2626;
  --info:#0E7490; --info-s:#D4F1F7; --info-bd:#A5E0EC; --info-solid:#0E7FA3;
  --violet:#6D28D9; --violet-s:#ECE6FB; --violet-bd:#CFBEF4;
  --off-solid:#E2E8F0; --off-bd:#CBD5E1;
  /* Legacy aliases (compat code existant) */
  --amber:#D97706; --rust:#B45309;
  /* Typographie */
  --sans:'Inter',-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --mono:'JetBrains Mono','SF Mono',Consolas,monospace;
  /* Radius — shape lock (une seule échelle) */
  /* Arrondis resserrés : look outil industriel/logistique, pas app grand public */
  --radius:9px; --r-sm:7px; --r-lg:10px; --r-pill:999px;
  /* Shadows — soft diffuse */
  --shadow-xs:0 1px 2px rgba(11,45,82,.05);
  --shadow:0 1px 3px rgba(11,45,82,.05),0 8px 24px -8px rgba(11,45,82,.10);
  --shadow-md:0 4px 10px rgba(11,45,82,.10),0 2px 4px rgba(11,45,82,.06);
  --shadow-lg:0 4px 12px rgba(11,45,82,.07),0 24px 48px -12px rgba(11,45,82,.16);
  --shadow-float:0 2px 4px -2px rgba(11,45,82,.06),0 14px 34px -14px rgba(11,45,82,.22);
  /* Motion */
  --ease:cubic-bezier(0.32,0.72,0,1); --dur:220ms;
}
*{box-sizing:border-box}html,body{margin:0;height:100%}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;display:flex;flex-direction:column;height:100vh;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.num,table.data td.num,table.data th.num,.gauge .val,.tabnum{font-variant-numeric:tabular-nums}
.svg-i{width:18px;height:18px;stroke-width:2;flex-shrink:0;display:inline-block;vertical-align:middle}
.svg-i.sm{width:14px;height:14px}
.svg-i.lg{width:20px;height:20px}
.svg-i.xl{width:24px;height:24px}
/* Selection + scrollbar */
::selection{background:var(--navy-tint);color:var(--navy)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#D1D5DB;border-radius:5px;border:2px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:#9CA3AF;background-clip:content-box;border:2px solid transparent}
/* Smooth scroll + focus a11y */
html{scroll-behavior:smooth}
:focus-visible{outline:none}
/* Lucide icons inside .ic containers must scale to .ic size */
.ic .svg-i{width:18px;height:18px}
nav.side button.home .ic .svg-i{width:24px;height:24px}
.kpi-icon .svg-i{width:18px;height:18px}
.tb-btn .svg-i{width:14px;height:14px}
.cfic .svg-i{width:22px;height:22px}
/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}
.topbar{position:relative;background:linear-gradient(90deg,var(--navy) 0%,var(--navy-soft) 100%);color:#fff;display:flex;align-items:center;gap:14px;padding:0 22px;height:58px;flex-shrink:0;box-shadow:0 1px 0 rgba(11,45,82,.5),0 2px 14px -6px rgba(11,45,82,.55);z-index:60}
.topbar::after{content:"";position:absolute;left:0;bottom:0;right:0;height:4px;background:linear-gradient(90deg,var(--bauxite) 0%,rgba(200,85,43,.85) 18%,rgba(200,85,43,0) 72%);z-index:1}
.topbar::before{content:"";position:absolute;left:0;bottom:0;width:300px;height:100%;background:radial-gradient(ellipse 300px 64px at 0% 100%,rgba(200,85,43,.20),transparent 70%);pointer-events:none;z-index:0}
.topbar>*{position:relative;z-index:2}
.brand{font-weight:800;letter-spacing:-.02em;font-size:22px;color:#fff;display:flex;align-items:center;text-shadow:0 1px 2px rgba(0,0,0,.22)}
.brand b{color:#E8703F;font-weight:800}
.brandmark{color:var(--navy);font-weight:700}
.brandmark b{color:var(--bauxite);font-weight:700}
.brand .sub{font-size:10px;text-transform:uppercase;letter-spacing:1.6px;color:rgba(255,255,255,.6);font-weight:500;margin-left:10px}
.topbar .tb-btn{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.16);color:rgba(255,255,255,.88)}
.topbar .tb-btn:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.32);color:#fff}
.topbar .tb-btn:focus-visible{border-color:#fff;box-shadow:0 0 0 3px rgba(255,255,255,.2)}
.topbar .spacer{flex:1}
.topbar label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-right:4px;font-weight:500}
.topbar select{background:var(--card);border:1px solid var(--line);color:var(--slate);padding:7px 11px;border-radius:var(--r-sm);font-size:13px;font-family:inherit;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.topbar select:hover{border-color:var(--faint)}
.topbar select:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px var(--navy-tint)}
.topbar select option{color:var(--ink)}
.tb-btn{font-family:inherit;font-size:13px;font-weight:500;border:1px solid var(--line);background:var(--card);color:var(--slate);padding:7px 13px;border-radius:var(--r-sm);cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease),transform 80ms var(--ease)}
.tb-btn.icon-only{padding:7px;width:34px;height:34px;justify-content:center}
.tb-btn:hover{background:var(--canvas);border-color:var(--faint)}
.tb-btn:active{transform:scale(.98)}
.tb-btn:focus-visible{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px var(--navy-tint)}
.userchip{display:flex;align-items:center;gap:9px;background:var(--canvas);padding:4px 13px 4px 4px;border-radius:999px;font-size:13px;font-weight:500;color:var(--slate);border:1px solid var(--line)}
.userchip .av{width:28px;height:28px;border-radius:50%;background:var(--navy);color:#fff;font-weight:600;display:flex;align-items:center;justify-content:center;font-size:12px;letter-spacing:0}
.userchip .meta{display:flex;flex-direction:column;line-height:1.2}
.userchip .meta>div:first-child{font-size:13px;color:var(--ink);font-weight:600}
.userchip .role{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-weight:500}
main{flex:1;overflow:auto;padding:22px 26px;min-width:0}
.view{display:none}.view.active{display:block;animation:fade .18s ease}
@keyframes fade{from{opacity:0;transform:translateY(3px)}to{opacity:1;transform:none}}
.head{display:flex;align-items:center;gap:13px;margin-bottom:6px}
.head-tt{min-width:0}
.head-kicker{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.9px;margin-bottom:1px}
h1.page{font-size:22px;margin:0;color:var(--ink);font-weight:600;letter-spacing:-0.02em}
.page-sub{color:var(--muted);margin:6px 0 22px;font-size:13.5px;line-height:1.5}
.gauges{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:20px}
.gauge{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px;box-shadow:var(--shadow-xs);position:relative;overflow:hidden;transition:border-color var(--dur) var(--ease)}
.gauge:hover{border-color:var(--faint)}
.gauge::before{display:none}
.gauge .label{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);font-weight:500}
.gauge .val{font-family:var(--sans);font-size:22px;font-weight:600;color:var(--ink);margin-top:6px;letter-spacing:-0.01em;font-variant-numeric:tabular-nums}
.gauge .val small{font-size:12px;color:var(--muted);font-weight:500;margin-left:3px}
/* KPI grid — north-star metrics (Tabler-inspired) */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(258px,1fr));gap:16px;margin-bottom:24px}
.ca-card.no-hd>.bd{padding-top:18px}
/* Panneau finance encastré : ombre interne sur la grande carte (harmonise le bloc des 4 éléments) */
/* Section finance : flottante + fond glossy harmonieux (plus de biseau interne) */
/* Carte finance légèrement translucide : la trame du fond transparaît (effet verre discret) */
.card.ca-card{box-shadow:0 2px 5px -3px rgba(11,45,82,.05),0 8px 18px -12px rgba(11,45,82,.14);background:linear-gradient(155deg,rgba(252,253,255,.78),rgba(236,241,248,.64));backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}
/* Finances au-dessus des KPI + respiration autour des KPI */
.dash-bento .zone-a .ca-card{order:-1}
.dash-bento .zone-a .kpi-grid{margin:12px 0 12px}
/* Le dashboard n'a pas de pageHead → dégager la 1re rangée sous la pilule de période flottante */
/* Fond « salle de contrôle » porté par #main (classe dash-bg posée par openTab) : couverture totale de la
   zone visible — plus de coupure blanche en bas ; gradient resserré, ne s'éclaircit plus vers le bas droit */
/* Fond assombri + points renforcés : le contenu (cartes claires) passe au premier plan */
main#main.dash-bg{background:radial-gradient(rgba(11,45,82,.11) 1px,transparent 1.4px) 0 0/22px 22px,linear-gradient(170deg,#D5E0EC 0%,#DEE6F0 55%,#E1E8F2 100%)}
#v-tableau_bord.view.active{padding:16px 28px 24px;margin:-24px -28px -24px}
/* Vues avec barre période flottante : dégager le contenu sous la pilule */
#v-fiche_camion.view.active,#v-entretien.view.active,#v-situation.view.active,#v-bilan.view.active,#v-rapport.view.active{padding-top:46px}
/* En-tête du dashboard — ancrage "app" (titre + période) */
.dash-head{display:flex;align-items:center;gap:13px;margin-bottom:22px;max-width:calc(100% - 200px)}
.dash-head .dash-ic{width:42px;height:42px;border-radius:10px;background:var(--navy-tint);color:var(--navy);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.dash-head .dash-ic .svg-i{width:22px;height:22px;stroke-width:1.5px}
.dash-title{font-size:22px;font-weight:600;color:var(--ink);margin:0;letter-spacing:-0.01em;line-height:1.1}
.dash-sub{font-size:12.5px;color:var(--muted);margin-top:2px}
/* ===== Dashboard bento (zones) ===== */
.dash-bento{display:grid;grid-template-columns:repeat(12,1fr);gap:18px;align-items:start}
.dash-bento .zone{min-width:0;display:flex;flex-direction:column;gap:20px}
.dash-bento .zone>.card{margin-bottom:0}
.dash-bento .kpi-grid{margin-bottom:0}
.zone-a{grid-column:span 12}
.zone-d{grid-column:span 4}
/* Synthèse financière : CA navy + coûts à côté */
/* Bento du haut en 4 unités : CA (2) · Coût total maintenance hero (1) · 2 coûts empilés (1) */
.fin-row{display:grid;grid-template-columns:2fr 1fr 1fr;gap:14px;align-items:stretch}
.fin-row>*{min-width:0}
.fin-row .ca-main{max-width:none}
.ca-main.fin-hero-maint{background:linear-gradient(140deg,#8A6730,#BD9856)}
.ca-main.fin-hero-maint::after{background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%)}
.ca-main.fin-hero-maint .ca-v span{color:#F6E6C2}
@media(max-width:1000px){.fin-row{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.fin-row{grid-template-columns:1fr}}
.fin-side{display:flex;flex-direction:column;gap:6px;justify-content:center;min-width:0}
.fin-stat{position:relative;overflow:hidden;display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:9px 14px;box-shadow:var(--shadow-xs);transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.fin-stat::before{content:"";position:absolute;left:0;top:10px;bottom:10px;width:3px;border-radius:0 3px 3px 0;background:var(--navy)}
.fin-stat.fs-bauxite::before{background:var(--bauxite)}
.fin-stat.fs-info::before{background:var(--info)}
.fin-stat.fs-gold{background:rgba(244,234,210,.5)}
.fin-stat.fs-gold::before{background:#A87A3A}
.fin-stat:hover{border-color:var(--faint);box-shadow:var(--shadow)}
.fs-ic{width:32px;height:32px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.fs-ic.bauxite{background:var(--bauxite-soft);color:var(--bauxite)}
.fs-ic.navy{background:var(--navy-tint);color:var(--navy)}
.fs-ic.info{background:var(--info-s);color:var(--info)}
.fs-ic.gold{background:#F4EAD2;color:#8A6730}
.fs-ic .svg-i{width:17px;height:17px}
.fs-k{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:500}
.fs-v{font-size:17px;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums;margin-top:2px}
.fs-v small{font-size:12px;color:var(--muted);font-weight:500}
.zone-c{grid-column:span 12}
@media(max-width:1100px){.zone-a,.zone-d,.zone-c{grid-column:span 12}}
/* ===== Cartes visuelles (Chauffeurs / Camions) ===== */
.ent-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(284px,1fr));gap:14px}
.ent-card{border:1px solid var(--line);border-radius:var(--r-lg);padding:15px 16px;background:var(--card);transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease),transform 80ms var(--ease);display:flex;flex-direction:column;gap:12px}
.ent-card:hover{border-color:var(--faint);box-shadow:var(--shadow)}
.ec-top{display:flex;align-items:center;gap:12px;min-width:0}
.ec-ic,.ec-av{width:46px;height:46px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700;font-size:17px}
.ec-av{border-radius:50%}
.ec-ic.info,.ec-av.info{background:var(--info-s);color:var(--info)}
.ec-ic.navy,.ec-av.navy{background:var(--navy-tint);color:var(--navy)}
.ec-ic .svg-i{width:22px;height:22px}
.ec-tt{min-width:0}
.ec-title{font-size:15px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ec-sub{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ec-meta{display:flex;flex-direction:column;gap:7px;border-top:1px solid var(--line-soft);padding-top:11px}
/* Stats camion sans libellé : icône = sens, valeur directe (clean, compact) */
.ec-row{display:flex;justify-content:space-between;gap:10px;font-size:12.5px;align-items:baseline}
.ec-k{color:var(--muted);flex-shrink:0}
.ec-v{color:var(--ink);font-weight:500;text-align:right;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ec-act{display:flex;gap:8px;margin-top:2px}
.ec-act .btn{flex:1;justify-content:center}
.att-link{display:inline-flex;align-items:center;gap:5px;color:var(--info);font-size:12.5px;font-weight:500;text-decoration:none}
.att-link:hover{text-decoration:underline}
/* Trombone : petit effet au survol */
.att-link .svg-i{transition:transform .16s var(--ease),color .16s var(--ease)}
.att-link:hover .svg-i{transform:scale(1.28) rotate(-10deg);color:var(--navy)}
.att-file{font-size:12.5px;color:var(--slate)}
/* Bouton de téléversement stylé (remplace le natif "choisir un fichier") */
.filebtn{position:relative;display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border:1.5px dashed var(--info);background:var(--info-s);border-radius:var(--r-sm);cursor:pointer;color:var(--info);font-size:13px;font-weight:600;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease);max-width:100%}
.filebtn:hover{background:#E0F7FB;border-color:#0E7490}
.filebtn input[type=file]{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer}
.filebtn .fb-ic{display:inline-flex;align-items:center}
.filebtn .fb-ic .svg-i{width:18px;height:18px}
.filebtn .fb-name{color:var(--slate);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}
.filebtn.has{border-style:solid;border-color:var(--ok);background:var(--ok-s);color:var(--ok)}
/* Panneau Alertes flotte */
.alert-card{height:100%}
.al-ic{width:26px;height:26px;border-radius:8px;background:var(--warn-s);color:var(--warn);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.al-ic .svg-i{width:15px;height:15px}
.al-count{min-width:24px;height:24px;padding:0 7px;border-radius:999px;font-size:12px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}
.al-count.on{background:var(--danger-s);color:var(--danger)}
.al-count.ok{background:var(--ok-s);color:var(--ok)}
.al-list{display:flex;flex-direction:column;max-height:360px;overflow-y:auto}
.al-row{display:flex;align-items:center;gap:11px;width:100%;border:0;border-top:1px solid var(--line-soft);background:transparent;padding:11px 18px;cursor:pointer;font-family:inherit;text-align:left;transition:background var(--dur) var(--ease)}
.al-row:first-child{border-top:0}
.al-row:hover{background:var(--canvas)}
.al-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.al-row.danger .al-dot{background:var(--danger)}
.al-row.warn .al-dot{background:var(--warn)}
.al-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.al-cam{font-size:13px;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:6px}
.al-cam .svg-i{width:13px;height:13px;color:var(--muted)}
.al-detail{font-size:11.5px;color:var(--muted)}
.al-row.danger .al-detail{color:var(--danger);font-weight:500}
.al-chev{color:var(--faint);flex-shrink:0}
.al-ok{display:flex;align-items:center;gap:10px;padding:26px 18px;color:var(--ok);font-size:13px;font-weight:500}
.al-ok .svg-i{width:20px;height:20px}
/* Alerte flotte repliable (repliée par défaut) */
/* Liseré = état réel : rouge si ≥1 retard, jaune si à surveiller, NEUTRE si rien ; ombre discrète */
.flotte-alert.sev-danger{box-shadow:inset 3px 0 0 var(--danger),var(--shadow-xs)}
.flotte-alert.sev-warn{box-shadow:inset 3px 0 0 var(--warn),var(--shadow-xs)}
.flotte-alert.sev-ok{box-shadow:inset 3px 0 0 var(--line),var(--shadow-xs)}
.flotte-alert.sev-ok .al-ic{background:var(--canvas);color:var(--slate)}
.flotte-alert.sev-ok .al-count{background:var(--canvas);color:var(--slate)}
.flotte-alert .al-hd:hover{background:var(--canvas)}
/* Bandeau d'alerte plus bas */
.card .hd.al-hd{padding:8px 16px}
.flotte-alert .al-bd{display:none}
.flotte-alert.open .al-bd{display:block;animation:accIn .2s var(--ease)}
.flotte-alert .al-hd{cursor:pointer;gap:11px;user-select:none}
.al-summary{font-size:12px;color:var(--muted);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.al-chev2{color:var(--muted);transition:transform var(--dur) var(--ease);margin-left:2px}
.flotte-alert.open .al-chev2{transform:rotate(180deg)}
.al-ic.danger{background:var(--danger-s);color:var(--danger)}
.al-ic.ok{background:var(--ok-s);color:var(--ok)}
.al-ic.warn{background:var(--warn-s);color:var(--warn)}
/* Cartes Base Camions — variante sombre bauxite (identité camion, données très lisibles) */
.ec-ic.bauxite,.ec-av.bauxite{background:var(--bauxite-soft);color:var(--bauxite)}
/* Retour à la robe bauxite (essai charbon écarté) */
.ent-card.cam-dark{background:linear-gradient(135deg,#6E2A14,#A8492A);border-color:transparent;color:#fff;position:relative;overflow:hidden;box-shadow:0 12px 26px -12px rgba(110,42,20,.45)}
.ent-card.cam-dark::after{content:"";position:absolute;right:-30px;top:-30px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%);pointer-events:none}
.ent-card.cam-dark>*{position:relative}
.ent-card.cam-dark .ec-ic{background:rgba(255,222,205,.2);color:#fff}
.ent-card.cam-dark .ec-title{color:#fff}
.ent-card.cam-dark .ec-sub{color:rgba(255,255,255,.82)}
.ent-card.cam-dark .ec-meta{border-top-color:rgba(255,255,255,.18)}
.ent-card.cam-dark .ec-k{color:rgba(255,255,255,.62)}
.ent-card.cam-dark .ec-v{color:#fff}
.ent-card.cam-dark .ec-k{color:rgba(255,255,255,.72)}
.ent-card.cam-dark .ec-v{color:#fff;font-weight:600}
.ent-card.cam-dark .ec-act .btn{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.24);color:#fff}
.ent-card.cam-dark .ec-act .btn:hover{background:rgba(255,255,255,.26);border-color:rgba(255,255,255,.36)}
.ent-card.cam-dark .ec-act .btn.danger-o{color:#FFDFD5}
.ent-card.cam-dark:hover{box-shadow:var(--shadow-lg);border-color:transparent}
.al-row.danger{box-shadow:inset 3px 0 0 var(--danger)}
@keyframes alPulse{0%,100%{box-shadow:inset 3px 0 0 var(--danger)}50%{box-shadow:inset 3px 0 0 rgba(220,38,38,.35)}}
@media(prefers-reduced-motion:no-preference){.al-row.danger{animation:alPulse 2.2s ease-in-out infinite}}
/* Pas de bordure : les cartes teintées portent leur relief par l'ombre seule (le liseré clair jurait sur le fond sombre) */
/* Effet verre : fond teinté translucide + flou d'arrière-plan (la trame du dashboard transparaît) */
.kpi-card{background:var(--card);border:1px solid transparent;border-radius:var(--r-lg);padding:12px 16px;box-shadow:0 9px 22px -8px rgba(11,45,82,.18),0 3px 6px -3px rgba(11,45,82,.09);backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease);position:relative;overflow:visible}
.kpi-head{padding-right:56px}
.kpi-card:hover{z-index:10}
.kpi-card:hover{box-shadow:0 22px 40px -12px rgba(11,45,82,.30);transform:translateY(-4px)}
.kpi-head{display:flex;align-items:center;gap:10px;margin-bottom:15px}
.kpi-icon{width:30px;height:30px;border-radius:8px;background:var(--navy-tint);color:var(--navy);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 3px 7px -1px rgba(11,45,82,.19)}
/* Pastille pleine dans le coin haut-droit (couvre le coin arrondi, sans débordement) — couleur = accent métrique */
/* Pastilles de coin masquées TEMPORAIREMENT (aperçu demandé) — repasser display:block pour les rétablir */
.kpi-card::before{display:none;content:"";position:absolute;top:-1px;right:-1px;width:16px;height:16px;border-radius:0 var(--r-lg) 0 9px;background:var(--navy);opacity:.6}
.kpi-card.k-bauxite::before{background:var(--bauxite)}
.kpi-card.k-amber::before{background:#A65D1E}
.kpi-card.k-info::before{background:var(--info)}
.kpi-card.k-teal::before{background:#0F766E}
.kpi-card.k-bauxite .kpi-icon{background:var(--bauxite-soft);color:var(--bauxite)}
/* Cadrans d'icônes = exactement la couleur de leur carte (relief porté par l'ombre seule) */
.kpi-card.k-navy .kpi-icon{background:#D3E0EF;color:var(--navy)}
.kpi-card.k-amber .kpi-icon{background:#EDDCC5;color:#A65D1E}
.kpi-card.k-info .kpi-icon{background:#CCE4EB;color:var(--info)}
.kpi-card.k-teal .kpi-icon{background:#CBE2DB;color:#0F766E}
/* Fond de carte = teinte de l'encadré d'icône (pas la couleur de l'icône) ; l'icône passe en badge blanc */
/* Teintes verre : translucides, plus claires que l'aplat précédent — accentuation légère, pas d'assombrissement */
/* Teintes verre un cran plus soutenues (mieux ressenties) — restent translucides, la trame transparaît */
.kpi-card.k-navy{background:linear-gradient(150deg,rgba(210,224,242,.88),rgba(184,206,233,.74))}
.kpi-card.k-info{background:linear-gradient(150deg,rgba(203,230,238,.88),rgba(176,214,225,.74))}
.kpi-card.k-amber{background:linear-gradient(150deg,rgba(240,227,205,.9),rgba(226,206,178,.76))}
.kpi-card.k-teal{background:linear-gradient(150deg,rgba(205,230,221,.88),rgba(180,214,203,.74))}
/* En-têtes de section teintés par identité (doux, color-codés ; le tableau reste le focus) */
#v-pointage .card>.hd,#v-carburant .card>.hd,#v-entretien_hist .card>.hd,#v-pieces .card>.hd,#v-referentiels .card>.hd,#v-entretien .card>.hd,#v-situation .card>.hd,#v-bilan .card>.hd,#v-rapport .card>.hd,#v-utilisateurs .card>.hd,#v-corbeille .card>.hd{border-radius:var(--r-lg) var(--r-lg) 0 0;border-bottom:0}
#v-pointage .card>.hd{background:var(--ok-s);box-shadow:inset 3px 0 0 var(--ok)}
#v-carburant .card>.hd{background:var(--warn-s);box-shadow:inset 3px 0 0 var(--warn)}
#v-entretien_hist .card>.hd{background:var(--violet-s);box-shadow:inset 3px 0 0 var(--violet)}
#v-pieces .card>.hd{background:var(--canvas);box-shadow:inset 3px 0 0 var(--slate)}
#v-referentiels .card>.hd{background:var(--info-s);box-shadow:inset 3px 0 0 var(--info)}
#v-entretien .card>.hd{background:var(--canvas);box-shadow:inset 3px 0 0 var(--slate)}
#v-situation .card>.hd{background:var(--canvas);box-shadow:inset 3px 0 0 var(--slate)}
#v-bilan .card>.hd{background:var(--canvas);box-shadow:inset 3px 0 0 var(--slate)}
#v-rapport .card>.hd{background:var(--canvas);box-shadow:inset 3px 0 0 var(--slate)}
#v-utilisateurs .card>.hd{background:var(--canvas);box-shadow:inset 3px 0 0 var(--slate)}
#v-corbeille .card>.hd{background:var(--canvas);box-shadow:inset 3px 0 0 var(--slate)}
.kpi-label{font-size:12.5px;color:var(--muted);font-weight:500;letter-spacing:.1px}
.kpi-val{font-family:var(--sans);font-size:28px;font-weight:700;color:var(--ink);letter-spacing:-0.02em;line-height:1.1;font-variant-numeric:tabular-nums}
.kpi-val small{font-size:13px;color:var(--muted);font-weight:500;margin-left:4px;letter-spacing:0}
.kpi-foot{display:flex;align-items:center;margin-top:8px;min-height:0;gap:10px}
/* Delta ancré en haut à droite de sa carte KPI */
.kpi-delta{position:absolute;top:11px;right:11px;z-index:2;display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;padding:2px 7px;border-radius:6px;letter-spacing:.1px;white-space:nowrap;box-shadow:0 1px 3px rgba(11,45,82,.14)}
.kpi-delta.up{background:var(--ok-s);color:var(--ok)}
.kpi-delta.down{background:var(--danger-s);color:var(--danger)}
/* Vert clair UNIQUEMENT pour « Stable » ; « — » (pas de comparaison) reste neutre */
.kpi-delta.stable{background:var(--ok-s);color:var(--ok)}
.kpi-delta.neutral{background:var(--canvas);color:var(--muted)}
.kpi-spark{width:74px;height:26px;flex-shrink:0}
/* Production déroulable + couplage sparklines */
.prod-hd{cursor:pointer;user-select:none;transition:background var(--dur) var(--ease),box-shadow var(--dur) var(--ease),padding var(--dur) var(--ease);border-radius:var(--r-lg);background:linear-gradient(135deg,#3F5470,#5A7391);padding:10px 20px}
/* Bandeau compact permanent (plié comme déplié) : une seule ligne, titre ellipsé, chevron fixe */
/* Les 3 barres dépliables partagent EXACTEMENT le même gabarit (padding, icône, titre) */
/* Effet flottant sur les 3 barres repliées (Flux Production / Par camion / Par chauffeur), cohérent avec les cartes ; l'état déplié garde sa propre ombre */
.prod-card .hd.prod-hd,.perf-sec .hd.perf-hd{flex-wrap:nowrap;padding:8px 16px;border-bottom:0;box-shadow:0 8px 20px -10px rgba(20,30,45,.4),0 2px 5px -3px rgba(20,30,45,.24);transition:box-shadow var(--dur) var(--ease),transform 90ms var(--ease),background var(--dur) var(--ease)}
.prod-card:not(.open) .prod-hd:hover,.perf-sec:not(.open) .perf-hd:hover{box-shadow:0 12px 26px -10px rgba(20,30,45,.46),0 3px 7px -3px rgba(20,30,45,.28);transform:translateY(-1px)}
.prod-card .hd.prod-hd h2,.perf-sec .hd.perf-hd h2{font-size:13.5px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.prod-card .hd.prod-hd .rowico,.perf-sec .hd.perf-hd .rowico{width:28px;height:28px}
.prod-card .hd.prod-hd .rowico .svg-i,.perf-sec .hd.perf-hd .rowico .svg-i{width:16px;height:16px}
.prod-card.open .prod-hd{border-radius:var(--r-lg) var(--r-lg) 0 0;background:linear-gradient(135deg,rgba(70,92,116,.95),rgba(99,127,154,.92));box-shadow:0 10px 24px -14px rgba(20,30,45,.5);position:relative;z-index:2}
.prod-card .hd.prod-hd h2,.prod-card .hd.prod-hd .prod-chev{color:#fff}
.prod-hd .rowico.prod-ico{background:rgba(255,255,255,.2);color:#fff}
.prod-sub{font-size:12px;color:var(--muted);margin-left:10px;font-weight:500}
.prod-chev{color:var(--muted);transition:transform var(--dur) var(--ease);flex-shrink:0}
.prod-card.open .prod-chev{transform:rotate(180deg)}
.prod-card .prod-bd{display:none}
/* Corps du panneau production en gris console : le bandeau slate + la chart respirent, cohérent avec le fond monitoring */
.prod-card.open .bd.prod-bd{padding:12px 16px 12px;background:var(--chrome);border-radius:0 0 var(--r-lg) var(--r-lg)}
.prod-card.open .prod-bd{display:block;animation:accIn .2s var(--ease)}
/* Focus au déroulage : la section vient sous la pilule de période flottante */
.prod-card,.perf-sec,.flotte-alert{scroll-margin-top:64px}
/* Repliées : la barre colorée est la seule surface visible — plus de trait blanc (fond/bord de carte) dessous */
.prod-card:not(.open),.perf-sec:not(.open){background:transparent;border-color:transparent}
.prod-controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:14px}
#prodMetToggle{display:inline-flex;align-items:center;gap:6px}
#prodMetToggle.on{background:var(--navy-tint);border-color:var(--navy);color:var(--navy)}
#prodMetToggle .met-chev{transition:transform var(--dur) var(--ease)}
#prodMetToggle.on .met-chev{transform:rotate(180deg)}
.prod-metrics{margin-bottom:8px}
#v-tableau_bord.prod-open .kpi-spark{display:none}
/* Chips de sélection de métrique (chart Production) */
.prod-metrics{display:flex;gap:6px;flex-wrap:wrap}
.prod-metrics .chip{font-family:inherit;font-size:11.5px;font-weight:600;border:1px solid var(--line);background:#fff;color:var(--muted);padding:5px 11px;border-radius:999px;cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease);display:inline-flex;align-items:center;gap:6px}
.prod-metrics .chip::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--chip,#94a3b8);opacity:.45;transition:opacity var(--dur) var(--ease)}
.prod-metrics .chip:hover{border-color:var(--faint);color:var(--slate)}
.prod-metrics .chip.on{color:#fff;background:var(--chip,#0b2d52);border-color:var(--chip,#0b2d52)}
.prod-metrics .chip.on::before{opacity:1;background:#fff}
/* Carte Chiffre d'affaires — hero navy + accent bauxite */
/* Carte CA compacte (réduite) */
.ca-card .hd{gap:10px}
.ca-ic{width:30px;height:30px;border-radius:8px;background:var(--navy-tint);color:var(--navy);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.ca-ic .svg-i{width:17px;height:17px}
.ca-line{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.ca-num{font-size:28px;font-weight:700;color:var(--navy);letter-spacing:-0.02em;font-variant-numeric:tabular-nums;line-height:1.1}
.ca-num small{font-size:14px;color:var(--bauxite);font-weight:600;margin-left:2px}
.ca-sub2{font-size:13px;color:var(--muted);font-weight:500}
.ca-hero{display:flex;gap:18px;flex-wrap:wrap;align-items:stretch}
.ca-main{flex:1;min-width:240px;background:linear-gradient(140deg,#0A2645,#143A66 55%,#1A4877);border-radius:var(--r-lg);padding:22px 24px;color:#fff;position:relative;overflow:hidden}
.ca-main::after{content:"";position:absolute;right:-36px;bottom:-36px;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.06),transparent 70%);pointer-events:none}
.ca-k{font-size:11px;text-transform:uppercase;letter-spacing:.8px;opacity:.82;font-weight:500;position:relative}
.ca-v{font-size:34px;font-weight:700;margin-top:8px;letter-spacing:-0.02em;font-variant-numeric:tabular-nums;color:#fff;position:relative;display:flex;align-items:baseline;gap:7px}
.ca-v span{font-size:15px;font-weight:600;color:var(--bauxite)}
.ca-foot{margin-top:8px;font-size:12px;opacity:.78;position:relative}
/* CA réduite : même DA navy, format rectangulaire compact */
.ca-compact{flex:none;min-width:0;max-width:400px;padding:12px 20px}
.ca-compact .ca-k{font-size:10px;margin-bottom:1px}
.ca-compact .ca-v{font-size:25px;margin-top:5px}
.ca-compact .ca-v span{font-size:13px}
.ca-compact .ca-foot{margin-top:5px;font-size:11.5px}
.ca-compact::after{width:96px;height:96px;right:-26px;bottom:-26px}
/* ===== Sections performance dépliables (dashboard) ===== */
.perf-sec .perf-bd{display:none}
.perf-sec.open .perf-bd{display:block;animation:accIn .2s var(--ease)}
.perf-hd{cursor:pointer;user-select:none}
.perf-hd .perf-chev{color:var(--muted);transition:transform var(--dur) var(--ease);margin-left:2px}
.perf-sec.open .perf-hd .perf-chev{transform:rotate(180deg)}
.perf-hint{font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.perf-sec.open .perf-hint{display:none}
/* Identité couleur des dropdowns : bauxite (camion) / navy (chauffeur) ; atténué à l'ouverture */
.perf-hd{transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}
.perf-sec[data-perf] .perf-hd{border-radius:var(--r-lg)}
.perf-sec[data-perf].open .perf-hd{border-radius:var(--r-lg) var(--r-lg) 0 0}
/* Barres repliées : teintes pleines (plus d'atténuation) pour la profondeur */
.perf-sec[data-perf="cam"] .perf-hd{background:linear-gradient(135deg,rgba(110,42,20,1),rgba(168,73,42,.98))}
.perf-sec[data-perf="ch"] .perf-hd{background:linear-gradient(135deg,rgba(11,45,82,1),rgba(20,58,102,.98))}
.perf-sec[data-perf] .perf-hd h2,.perf-sec[data-perf] .perf-hd .perf-hint,.perf-sec[data-perf] .perf-hd .perf-chev{color:#fff}
.perf-sec[data-perf] .perf-hd .rowico{background:rgba(255,255,255,.2);color:#fff}
.perf-sec[data-perf] .perf-hd .cnt{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.3);color:#fff}
/* Ouverture : même DA que Production — la couleur reste, en-tête flottant (ombre) */
.perf-sec[data-perf="cam"].open .perf-hd{background:linear-gradient(135deg,#6E2A14,#A8492A)}
.perf-sec[data-perf="ch"].open .perf-hd{background:linear-gradient(135deg,var(--navy),var(--navy-soft))}
.perf-sec[data-perf].open .perf-hd{box-shadow:0 10px 24px -14px rgba(20,30,45,.6);position:relative;z-index:2}
.perf-search{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:var(--r-sm);padding:8px 12px;margin-bottom:14px;color:var(--muted);background:#fff;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.perf-search:focus-within{border-color:var(--navy);box-shadow:0 0 0 3px var(--navy-tint)}
.perf-search input{border:0;outline:none;flex:1;font-family:inherit;font-size:13px;background:transparent;color:var(--ink)}
/* Liste défilante DANS le panneau : plus besoin de scroller toute la page pour parcourir la flotte */
.perf-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px;max-height:52vh;overflow-y:auto;padding:3px 6px 6px 3px;margin:0 -3px}
.perf-cards::-webkit-scrollbar{width:9px}
.perf-cards::-webkit-scrollbar-thumb{background:var(--line);border-radius:999px;border:2px solid var(--card)}
.perf-cards::-webkit-scrollbar-thumb:hover{background:var(--faint)}
.perf-card{border-radius:var(--r-lg);padding:16px 18px;color:#fff;position:relative;overflow:hidden;display:flex;flex-direction:column;gap:14px;box-shadow:0 8px 18px -10px rgba(20,30,45,.38);transition:transform 90ms var(--ease),box-shadow var(--dur) var(--ease)}
.perf-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.perf-card.ch{background:linear-gradient(135deg,var(--navy),var(--navy-soft))}
.perf-card.cam{background:linear-gradient(135deg,#6E2A14,#A8492A)}
.perf-card::after{content:"";position:absolute;right:-34px;top:-34px;width:128px;height:128px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%);pointer-events:none}
.pf-top{display:flex;align-items:center;gap:12px;position:relative}
.pf-ic{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.15);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.perf-card.cam .pf-ic{background:rgba(255,222,205,.2)}
.perf-card.ch .pf-ic{background:rgba(173,201,233,.22)}
.pf-ic .svg-i{width:21px;height:21px;color:#fff}
.pf-tt{min-width:0;flex:1}
.pf-name{font-size:15px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}
.pf-sub{font-size:11.5px;opacity:.82;font-variant-numeric:tabular-nums;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pf-hero{text-align:right;flex-shrink:0}
.pf-hero span{font-size:20px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.pf-hero small{display:block;font-size:10px;opacity:.7;text-transform:uppercase;letter-spacing:.35px}
.pf-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(58px,1fr));gap:10px;border-top:1px solid rgba(255,255,255,.16);padding-top:12px;position:relative}
.pf-stat{min-width:0}
.pf-k{font-size:10px;text-transform:uppercase;letter-spacing:.4px;opacity:.72;white-space:nowrap}
.pf-v{font-size:15px;font-weight:600;font-variant-numeric:tabular-nums;margin-top:2px;white-space:nowrap}
.pf-v small{font-size:10px;opacity:.72;font-weight:500}
/* ===== Section Équipe (onglets cliquables + cartes membres navy uniformes) ===== */
.team-pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.team-pill{display:inline-flex;align-items:center;gap:8px;font-family:inherit;font-size:13.5px;font-weight:600;border:1px solid var(--line);background:#fff;color:var(--slate);padding:7px 13px 7px 9px;border-radius:var(--r-pill);cursor:pointer;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease),color var(--dur) var(--ease)}
.team-pill:hover{border-color:var(--navy7);color:var(--navy)}
.team-pill.on{background:var(--navy);border-color:var(--navy);color:#fff}
.team-pill .tp-ic{width:24px;height:24px;border-radius:50%;background:var(--navy-tint);color:var(--navy);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.team-pill.on .tp-ic{background:rgba(255,255,255,.18);color:#fff}
.team-pill .tp-count{font-size:11.5px;font-weight:700;background:var(--canvas);color:var(--muted);border-radius:var(--r-pill);padding:1px 8px;font-variant-numeric:tabular-nums}
.team-pill.on .tp-count{background:rgba(255,255,255,.2);color:#fff}
/* 3 cartes par ligne (retombe à 2 puis 1 sur écrans étroits) */
.member-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:1080px){.member-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.member-grid{grid-template-columns:1fr}}
.member-card{background:linear-gradient(135deg,var(--navy),var(--navy-soft));color:#fff;border-radius:var(--r-lg);padding:15px 16px;position:relative;overflow:hidden;display:flex;flex-direction:column;gap:12px;box-shadow:0 11px 24px -11px rgba(11,45,82,.4);transition:transform 90ms var(--ease),box-shadow var(--dur) var(--ease)}
.member-card::after{content:"";position:absolute;right:-30px;top:-30px;width:110px;height:110px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%);pointer-events:none}
.member-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
/* Chef : pas de cadre autour de la carte — l'encoche orange (badge) porte seule l'identité, avec un léger flottement */
.member-card>*{position:relative}
.mc-top{display:flex;align-items:center;gap:12px;min-width:0}
.mc-av{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:17px;flex-shrink:0}
.mc-id{min-width:0;flex:1}
/* Nom complet toujours lisible : retour à la ligne plutôt qu'ellipse */
.mc-name{font-size:15px;font-weight:700;white-space:normal;overflow-wrap:anywhere;line-height:1.25}
.mc-sub{font-size:12px;opacity:.82;font-variant-numeric:tabular-nums}
.mc-badge{display:inline-flex;align-items:center;gap:5px;background:var(--bauxite);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:4px 9px;border-radius:var(--r-pill);flex-shrink:0;white-space:nowrap;box-shadow:0 4px 10px -3px rgba(0,0,0,.45)}
.mc-badge .svg-i{width:12px;height:12px}
.mc-meta{display:flex;flex-direction:column;gap:6px;border-top:1px solid rgba(255,255,255,.16);padding-top:11px}
.mc-row{display:flex;justify-content:space-between;gap:10px;font-size:12.5px;align-items:baseline}
.mc-row span{opacity:.72}
.mc-row b{font-weight:600;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mc-act{display:flex;gap:8px}
.mc-act .btn.mc-btn{flex:1;justify-content:center;background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.24);color:#fff}
.mc-act .btn.mc-btn:hover{background:rgba(255,255,255,.26);border-color:rgba(255,255,255,.38)}
.mc-act .btn.mc-btn-d{color:#FFD7CC}
.mc-act .btn.mc-btn-d:hover{background:rgba(220,38,38,.45);color:#fff}
/* ===== Fiche Camion dynamisée ===== */
.cam-picker{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.cp-lab{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700;display:inline-flex;align-items:center;gap:6px;flex-shrink:0}
.cp-pills{display:flex;gap:8px;flex-wrap:wrap}
.cp-pill{font-family:inherit;font-size:13px;font-weight:600;border:1px solid var(--line);background:#fff;color:var(--slate);padding:8px 16px;border-radius:999px;cursor:pointer;font-variant-numeric:tabular-nums;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease),color var(--dur) var(--ease)}
/* Focus clavier visible sur les contrôles pilules/listes (WCAG AA) */
.team-pill:focus-visible,.cp-pill:focus-visible,.al-row:focus-visible{outline:none;box-shadow:0 0 0 3px var(--navy-tint);border-color:var(--navy)}
.cp-pill:hover{border-color:var(--bauxite);color:var(--bauxite)}
.cp-pill.on{background:var(--navy);border-color:var(--navy);color:#fff}
.fiche-hero{display:flex;align-items:center;gap:16px;background:linear-gradient(135deg,#8A4A30,#C07A58);color:#fff;border-radius:var(--r-lg);padding:18px 22px;margin-bottom:16px;position:relative;overflow:hidden;flex-wrap:wrap}
.fiche-hero::after{content:"";position:absolute;right:-40px;top:-40px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%);pointer-events:none}
.fh-ic{width:54px;height:54px;border-radius:10px;background:rgba(255,222,205,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative}
.fh-ic .svg-i{width:28px;height:28px}
.fh-main{position:relative;min-width:0}
.fh-name{font-size:22px;font-weight:700;letter-spacing:-.01em}
.fh-sub{font-size:12.5px;opacity:.85;margin-top:2px}
.fh-tags{display:flex;gap:10px;margin-left:auto;flex-wrap:wrap;position:relative}
.fh-tag{background:rgba(255,255,255,.12);border-radius:10px;padding:8px 14px;display:flex;flex-direction:column;gap:2px;min-width:92px}
.fh-tag span{font-size:10px;text-transform:uppercase;letter-spacing:.35px;opacity:.75}
.fh-tag b{font-size:14px;font-weight:600;font-variant-numeric:tabular-nums}
.fiche-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(168px,1fr));gap:12px;margin-bottom:16px}
.fiche-stat{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:14px 16px;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.fiche-stat:hover{border-color:var(--faint);box-shadow:var(--shadow)}
.fst-ic{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fst-ic .svg-i{width:20px;height:20px}
.fst-ic.navy{background:var(--navy-tint);color:var(--navy)}
.fst-ic.info{background:var(--info-s);color:var(--info)}
.fst-ic.violet{background:var(--violet-s);color:var(--violet)}
.fst-ic.bauxite{background:var(--bauxite-soft);color:var(--bauxite)}
.fst-ic.amber{background:var(--warn-s);color:var(--warn)}
.fst-ic.ok{background:var(--ok-s);color:var(--ok)}
.fst-tt{min-width:0}
.fst-k{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-weight:500}
.fst-v{font-size:19px;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums;margin-top:1px;white-space:nowrap}
.fst-v small{font-size:11px;color:var(--muted);font-weight:500}
.fiche-maint{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.maint-card{border:1px solid var(--line);border-radius:var(--r-lg);padding:14px 16px;border-left:4px solid var(--line)}
.maint-card.ok{border-left-color:var(--ok)}
.maint-card.warn{border-left-color:var(--warn)}
.maint-card.danger{border-left-color:var(--danger)}
.mc-top{display:flex;align-items:center;gap:10px;margin-bottom:11px}
.mc-ic{width:32px;height:32px;border-radius:9px;background:var(--canvas);color:var(--slate);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mc-ic .svg-i{width:17px;height:17px}
.mc-tt{font-weight:600;font-size:14px;flex:1}
.mc-body{display:flex;gap:18px;flex-wrap:wrap}
.mc-stat{display:flex;flex-direction:column;gap:2px}
.mc-stat span{font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted)}
.mc-stat b{font-size:14px;color:var(--ink);font-variant-numeric:tabular-nums}
/* ===== Diffusion par rôle (destinataires) ===== */
.rec-list{display:flex;flex-direction:column;gap:10px}
.rec-card{border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;transition:border-color var(--dur) var(--ease)}
.rec-card.custom{border-color:#cfe0f5}
.rec-hd{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--canvas)}
.rec-mail{font-size:13px;font-weight:500;color:var(--ink);display:inline-flex;align-items:center;gap:7px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rec-mail .svg-i{color:var(--muted);flex-shrink:0}
.rec-hd .rec-role{padding:6px 10px;border:1px solid var(--line);border-radius:var(--r-sm);font-family:inherit;font-size:12.5px;background:#fff;color:var(--slate);cursor:pointer;flex-shrink:0}
.rec-hd .rec-role:hover{border-color:var(--faint)}
.rec-hd .rec-rm{flex-shrink:0;padding:5px 11px;font-size:15px;line-height:1}
.rec-content{display:none;padding:12px;border-top:1px solid var(--line-soft);background:#fff}
.rec-card.custom .rec-content{display:block}
.rec-clab{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-weight:600;margin-bottom:9px}
.checks.small{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:7px}
.checks.small label{font-size:12px;padding:7px 10px}
.ca-sub{display:flex;flex-direction:column;gap:10px;justify-content:center;min-width:190px}
.ca-stat{background:var(--canvas);border:1px solid var(--line);border-radius:var(--r-sm);padding:10px 14px;transition:border-color var(--dur) var(--ease)}
.ca-stat:hover{border-color:var(--faint)}
.cs-k{font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-weight:500}
.cs-v{font-size:18px;font-weight:600;color:var(--ink);margin-top:2px;font-variant-numeric:tabular-nums}
.cs-v small{font-size:12px;color:var(--muted);font-weight:500}
/* Effet flottant harmonisé sur toutes les cartes de section (même langage que les cartes dashboard) */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-float);margin-bottom:22px;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
/* Accordéon (Paramètres : une section repliable par bloc) */
.acc{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-float);margin-bottom:12px;overflow:hidden;transition:border-color var(--dur) var(--ease)}
.acc:hover{border-color:#DCE0E6}
.acc-hd{display:flex;align-items:center;gap:13px;width:100%;border:0;background:transparent;padding:14px 18px;cursor:pointer;font-family:inherit;text-align:left;color:var(--ink)}
.acc-ic{width:34px;height:34px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;background:var(--navy-tint);color:var(--navy);flex-shrink:0;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}
.acc-ic .svg-i{width:17px;height:17px}
.acc-title{font-size:14px;font-weight:600;flex:1;letter-spacing:-0.005em}
.acc-chev{width:18px;height:18px;color:var(--muted);flex-shrink:0;transition:transform var(--dur) var(--ease)}
.acc.open .acc-chev{transform:rotate(180deg)}
.acc.open .acc-ic{background:var(--navy);color:#fff}
.acc-bd{display:none;padding:16px 18px 18px;border-top:1px solid var(--line-soft)}
.acc.open .acc-bd{display:block;animation:accIn .2s var(--ease)}
@keyframes accIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.card:hover{border-color:#DCE0E6}
.card .hd{display:flex;align-items:center;gap:12px;padding:15px 20px;border-bottom:1px solid var(--line-soft);flex-wrap:wrap}
.card .hd h2{font-size:15px;margin:0;color:var(--ink);font-weight:600;letter-spacing:-0.005em}
.card .hd .spacer{flex:1}
.card .bd{padding:18px 20px}.card .bd.flush{padding:0}
.tablewrap{overflow-x:auto}
table.data{width:100%;border-collapse:collapse;font-size:13px}
table.data th,table.data td{padding:10px 14px;text-align:left;white-space:nowrap}
table.data thead th{background:var(--navy);color:rgba(255,255,255,.92);font-size:11px;font-weight:600;letter-spacing:.4px;border-bottom:1px solid var(--navy);text-transform:uppercase;padding-top:11px;padding-bottom:11px;position:sticky;top:0;z-index:5}
table.data thead th:first-child{border-top-left-radius:0}
table.data thead th:last-child{border-top-right-radius:0}
/* À l'impression / PDF, les fonds sombres sont supprimés par le navigateur : en-têtes lisibles en navy-sur-blanc */
@media print{table.data thead th{background:#fff!important;color:var(--navy)!important;border-bottom:1.5px solid var(--navy)!important;border-radius:0!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}}
table.data tbody tr{border-bottom:1px solid var(--line-soft);transition:background var(--dur) var(--ease)}
table.data tbody tr:nth-child(even){background:#F4F5F7}
table.data tbody tr:hover{background:var(--navy-tint)}
table.data tbody tr:last-child{border-bottom:0}
/* Zébrures neutres globales (façon Excel) sur toutes les listes ; le survol navy garde la priorité partout */
table.data td.num,table.data th.num{text-align:right;font-variant-numeric:tabular-nums}
table.data tfoot td{font-weight:600;color:var(--ink);background:var(--canvas);border-top:1px solid var(--line)}
table.data tfoot td.num{font-variant-numeric:tabular-nums}
/* Total épinglé en haut de la liste — visible sans scroller */
.totbar{display:flex;flex-wrap:wrap;gap:9px;padding:9px 16px;background:var(--navy-tint);box-shadow:inset 3px 0 0 var(--navy),0 6px 14px -8px rgba(11,45,82,.20);align-items:center;margin-bottom:0}
/* Totbar : prend la couleur d'identité de la section (flotte au-dessus de la liste) */
#v-pointage .totbar{background:var(--ok-s);box-shadow:inset 3px 0 0 var(--ok),0 6px 14px -8px rgba(11,45,82,.18)}
#v-carburant .totbar{background:var(--warn-s);box-shadow:inset 3px 0 0 var(--warn),0 6px 14px -8px rgba(11,45,82,.18)}
#v-pieces .totbar{background:var(--canvas);box-shadow:inset 3px 0 0 var(--slate),0 6px 14px -8px rgba(11,45,82,.18)}
#v-entretien_hist .totbar{background:var(--violet-s);box-shadow:inset 3px 0 0 var(--violet),0 6px 14px -8px rgba(11,45,82,.18)}
.totbar .tb-lab{font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--navy);font-weight:700;display:inline-flex;align-items:center;gap:6px}
.totbar .tb-lab .svg-i{width:14px;height:14px}
.totbar .tot-chip{display:inline-flex;align-items:baseline;gap:6px;background:#fff;border:1px solid #DCE5F0;border-radius:999px;padding:5px 13px;font-size:12px;color:var(--muted)}
.totbar .tot-chip b{font-size:14px;color:var(--navy);font-weight:700;font-variant-numeric:tabular-nums}
.totbar .tot-chip i{font-style:normal;font-size:10.5px;color:var(--faint)}
.rowact{display:flex;gap:6px}
.empty{padding:32px 24px;text-align:center;color:var(--faint);font-size:13px}
/* Recherche + compteur sur les listes (anti-longue-liste) */
.card .hd .cnt{font-size:11.5px;color:var(--muted);font-weight:600;font-variant-numeric:tabular-nums;background:var(--canvas);border:1px solid var(--line);padding:3px 9px;border-radius:999px}
/* Unité en suffixe dans les cellules numériques */
table.data td .cu{font-style:normal;font-size:10.5px;color:var(--muted);margin-left:2px}
.card .hd .flt{font-family:inherit;font-size:13px;border:1px solid var(--line);border-radius:var(--r-sm);padding:7px 12px;background:#fff;color:var(--ink);width:220px;max-width:42vw;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.card .hd .flt:hover{border-color:var(--faint)}
.card .hd .flt:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px var(--navy-tint)}
.card .hd .flt::placeholder{color:var(--faint)}
/* Hauteur par défaut ×1.2 (62→74vh) : évite le micro-scroll pour atteindre les dernières lignes (Bilan, etc.) */
.bd.flush .tablewrap{max-height:74vh;overflow:auto}
/* Colonne icône d'identité par base (pastille teintée, façon Linear/Notion) */
table.data th.ico-col{width:46px;padding-left:16px;padding-right:0}
table.data td.ico-col{width:46px;padding:8px 0 8px 16px}
.rowico{width:30px;height:30px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center}
.rowico .svg-i{width:16px;height:16px}
.rowico.navy{background:var(--navy-tint);color:var(--navy)}
.rowico.info{background:var(--info-s);color:var(--info)}
.rowico.bauxite{background:var(--bauxite-soft);color:var(--bauxite)}
.rowico.ok{background:var(--ok-s);color:var(--ok)}
.rowico.amber{background:var(--warn-s);color:var(--warn)}
.rowico.violet{background:var(--violet-s);color:var(--violet)}
.rowico.slate{background:var(--canvas);color:var(--slate)}
.badge{font-size:12px;padding:4px 11px;border-radius:var(--r-pill);font-weight:600;white-space:nowrap;letter-spacing:.1px;display:inline-flex;align-items:center;gap:5px;border:1px solid transparent}
.badge.ok{background:var(--ok-s);color:var(--ok);border-color:var(--ok-bd)}
.badge.warn{background:var(--warn-s);color:var(--warn);border-color:var(--warn-bd)}
.badge.danger{background:var(--danger-s);color:var(--danger);border-color:var(--danger-bd)}
.badge.info{background:var(--info-s);color:var(--info);border-color:var(--info-bd)}
.badge.off{background:var(--canvas);color:var(--muted);border-color:var(--off-bd)}
/* En-têtes de section colorées flottantes — même DA que "Par camion/chauffeur" déroulés (Camions=bauxite, Équipe=navy) */
.card .hd.hd-themed{position:relative;z-index:2;border-bottom:0;border-radius:var(--r-lg) var(--r-lg) 0 0;box-shadow:0 10px 24px -14px rgba(20,30,45,.55)}
.hd-themed.hd-cam{background:linear-gradient(135deg,rgba(110,42,20,.96),rgba(168,73,42,.93))}
.hd-themed.hd-team{background:linear-gradient(135deg,rgba(11,45,82,.96),rgba(20,58,102,.93))}
.card .hd.hd-themed h2{color:#fff}
.card .hd.hd-themed .cnt{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.3);color:#fff}
.card .hd.hd-themed .flt{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.32);color:#fff}
.card .hd.hd-themed .flt::placeholder{color:rgba(255,255,255,.72)}
.card .hd.hd-themed .flt:focus{border-color:#fff;box-shadow:0 0 0 3px rgba(255,255,255,.18)}
.hd-themed .btn.sm{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.3);color:#fff}
.hd-themed .btn.sm:hover{background:rgba(255,255,255,.26);border-color:rgba(255,255,255,.4)}
.hd-themed .btn.primary{background:#fff;color:var(--ink);border-color:transparent}
.hd-themed .badge.off{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.32);color:#fff}
/* Pill de statut PLEINE — langage Monday (bloc d'état, lisible à distance) */
.badge.solid{border-radius:10px;border:0;font-weight:700}
.badge.solid.ok{background:var(--ok-solid);color:#fff}
.badge.solid.warn{background:var(--warn-solid);color:#3D2A00}
.badge.solid.danger{background:var(--danger-solid);color:#fff}
.badge.solid.info{background:var(--info-solid);color:#fff}
.badge.solid.off{background:var(--off-solid);color:#475569}
button.btn,a.btn,select.btn{font-family:inherit;font-size:13px;font-weight:500;border:1px solid var(--line);background:var(--card);color:var(--slate);padding:8px 14px;border-radius:var(--r-sm);cursor:pointer;display:inline-flex;align-items:center;gap:7px;text-decoration:none;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease),transform 80ms var(--ease)}
button.btn:hover,select.btn:hover{background:var(--canvas);border-color:var(--faint)}
/* Select stylé comme un bouton : caret custom, coins arrondis identiques à .btn */
select.btn{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235A6B80' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;background-size:13px}
button.btn:active{transform:scale(.98)}
button.btn:focus-visible{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px var(--navy-tint)}
button.btn.primary{background:var(--navy);border-color:var(--navy);color:#fff;font-weight:600}
button.btn.primary:hover{background:var(--navy-soft);border-color:var(--navy-soft)}
button.btn.amber{background:var(--warn);border-color:var(--warn);color:#fff;font-weight:600}
button.btn.amber:hover{filter:brightness(.95)}
button.btn.green{background:var(--ok);border-color:var(--ok);color:#fff;font-weight:600}
button.btn.green:hover{filter:brightness(.95)}
button.btn.sm{padding:6px 10px;font-size:12px}
button.btn.sm.icon-o{padding:6px 8px}
/* Icône export Excel : teinte verte (affordance tableur) uniquement sur boutons neutres */
.btn .xls-ic{color:var(--ok)}
select.btn.sm{padding:6px 28px 6px 10px;font-size:12px}
button.btn.danger-o{color:var(--danger);border-color:#FECACA}
button.btn.danger-o:hover{background:var(--danger-s);border-color:#FCA5A5}
.formgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:13px 14px}
/* Modale de saisie uniquement : grille 6 colonnes, les hints `w` d'ENT contrôlent la largeur (défaut = 1/3 de rangée) */
#mForm.formgrid{grid-template-columns:repeat(6,1fr)}
#mForm .field{grid-column:span 2;min-width:0}
#mForm .field.w1{grid-column:span 1}#mForm .field.w3{grid-column:span 3}#mForm .field.w6{grid-column:1/-1}
@media(max-width:640px){#mForm .field,#mForm .field.w1,#mForm .field.w3{grid-column:span 3}}
/* En-tête de section : groupement logique du workflow — texte affirmé + respiration au-dessus de chaque groupe */
.fsec{grid-column:1/-1;display:flex;align-items:center;gap:10px;margin:20px 0 3px;font-size:12.5px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--navy)}
.fsec:first-child{margin-top:2px}
.fsec::after{content:"";flex:1;height:1px;background:var(--line)}
/* Numérique : chiffres tabulaires alignés à droite (comparaison début/fin d'un coup d'œil) */
.field.num input{text-align:right;font-variant-numeric:tabular-nums}
/* Champ calculé : ne ressemble jamais à un champ éditable (fond creux, bordure tiretée, valeur navy) */
.field.fauto input[readonly]{background:var(--canvas);border-style:dashed;color:var(--navy);font-weight:600;cursor:default}
.field.fauto.calc-neg input[readonly]{color:var(--danger);border-color:var(--danger-bd)}
/* Alerte de cohérence compteurs (fin < début) */
.calcwarn{grid-column:1/-1;display:none;align-items:center;gap:8px;background:var(--danger-s);border:1px solid var(--danger-bd);border-radius:var(--r-sm);padding:9px 13px;font-size:12.5px;font-weight:500;color:var(--danger)}
.calcwarn.on{display:flex}
/* Erreur inline sous le champ fautif (en plus du toast) */
.field.err input,.field.err select,.field.err textarea,.field.err .combo-in,.field.err .filebtn{border-color:var(--danger)!important;box-shadow:0 0 0 3px var(--danger-s)}
.field-err{margin-top:5px;font-size:12px;color:var(--danger);font-weight:500}
.field label{display:block;font-size:12px;color:var(--slate);margin-bottom:6px;font-weight:500}
.field input,.field select,.field textarea{width:100%;padding:10px 13px;border:1px solid var(--line);border-radius:var(--r-sm);font-family:inherit;font-size:13.5px;background:var(--card);color:var(--ink);transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.field input:hover,.field select:hover,.field textarea:hover{border-color:var(--faint)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px var(--navy-tint)}
.field.num input{font-variant-numeric:tabular-nums}
.field input[readonly]{background:var(--canvas);color:var(--slate);font-weight:500}
/* Select natif (énums) : caret custom, plus de flèche système moche */
.field select{appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:34px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 11px center}
/* Calendrier / date : indicateur plus discret + lisible */
.field input[type=date],.field input[type=month],.field input[type=week]{cursor:pointer}
.field input[type=date]::-webkit-calendar-picker-indicator,.field input[type=month]::-webkit-calendar-picker-indicator,.field input[type=week]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.5;transition:opacity var(--dur) var(--ease)}
.field input:hover::-webkit-calendar-picker-indicator{opacity:1}
/* Astérisque requis + tag auto */
.field label .req-star{color:var(--bauxite);font-weight:700;margin-left:1px}
.field label .auto-tag{font-size:10px;text-transform:uppercase;letter-spacing:.3px;color:var(--muted);background:var(--canvas);border:1px solid var(--line);border-radius:999px;padding:1px 6px;margin-left:5px;font-weight:600}
/* Case à cocher en ligne (ex. « Chef d'équipe ») */
.field label.ckline{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--ink);font-weight:500;padding:9px 0 0;cursor:pointer;margin:0}
.field label.ckline input[type=checkbox]{width:16px;height:16px;accent-color:var(--navy);cursor:pointer}
/* ===== Combobox recherchable ===== */
.combo{position:relative}
.combo-in{width:100%;padding:10px 34px 10px 13px;border:1px solid var(--line);border-radius:var(--r-sm);font-family:inherit;font-size:13.5px;background:var(--card);color:var(--ink);transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.combo-in:hover{border-color:var(--faint)}
.combo-in:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px var(--navy-tint)}
.combo.req .combo-in{border-left:3px solid var(--navy)}
.combo-caret{position:absolute;right:9px;top:50%;transform:translateY(-50%);color:var(--muted);cursor:pointer;display:inline-flex;transition:transform var(--dur) var(--ease)}
.combo.open .combo-caret{transform:translateY(-50%) rotate(180deg);color:var(--navy)}
.combo-list{display:none;position:absolute;top:calc(100% + 5px);left:0;right:0;background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:var(--shadow-lg);max-height:248px;overflow:auto;z-index:30;padding:5px}
.combo.drop-up .combo-list{top:auto;bottom:calc(100% + 5px)}
.combo.open .combo-list{display:block;animation:accIn .14s var(--ease)}
.combo-opt{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 11px;border-radius:9px;font-size:13.5px;color:var(--ink);cursor:pointer}
.combo-opt:hover{background:var(--navy-tint)}
.combo-hint{font-size:11.5px;color:var(--muted);font-family:var(--mono);white-space:nowrap;flex-shrink:0}
.combo-add{color:var(--navy);font-weight:600;border-top:1px solid var(--line-soft);margin-top:3px;justify-content:flex-start;gap:5px}
.combo-empty{padding:12px;text-align:center;color:var(--faint);font-size:12.5px}
.calcbar{grid-column:1/-1;background:var(--navy-tint);border:1px solid #DCE5F0;border-radius:var(--r-sm);padding:11px 16px;display:flex;gap:24px;flex-wrap:wrap;font-size:13px;color:var(--slate)}
.calcbar b{font-variant-numeric:tabular-nums;color:var(--navy);font-weight:600}
.overlay{position:fixed;inset:0;background:rgba(15,23,42,.45);backdrop-filter:blur(2px);display:none;align-items:flex-start;justify-content:center;padding:50px 16px;z-index:100;overflow:auto}
.overlay.open{display:flex}
/* Modale : hauteur bornée + corps scrollable → le pied (Enregistrer) reste toujours visible */
.modal{background:var(--card);border-radius:var(--r-lg);width:100%;max-width:820px;box-shadow:var(--shadow-lg);border:1px solid var(--line);display:flex;flex-direction:column;max-height:calc(100vh - 76px)}
.modal.sm{max-width:480px}
.modal .mh{display:flex;align-items:center;padding:16px 22px;border-bottom:1px solid var(--line-soft)}
.modal .mh h3{margin:0;font-size:16px;color:var(--ink);font-weight:600;letter-spacing:-0.01em}
.modal .mh .x{margin-left:auto;border:0;background:none;font-size:22px;cursor:pointer;color:var(--muted);line-height:1;padding:4px 8px;border-radius:6px;transition:background var(--dur) var(--ease)}
.modal .mh .x:hover{background:var(--canvas);color:var(--ink)}
.modal .mb{padding:20px 22px;overflow-y:auto;flex:1;min-height:0}
.modal .mf{display:flex;justify-content:flex-end;gap:10px;padding:14px 22px;border-top:1px solid var(--line-soft)}
.notice{background:var(--navy-tint);border:1px solid #DCE5F0;color:var(--navy-soft);padding:11px 16px;border-radius:var(--r-sm);font-size:13px;margin-bottom:16px;line-height:1.5}
.notice.warn{background:var(--warn-s);border-color:#FDE68A;color:#78350F}
.subgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.kv{background:var(--canvas);border:1px solid var(--line);border-radius:var(--r-sm);padding:12px 14px;transition:border-color var(--dur) var(--ease)}
.kv:hover{border-color:var(--faint)}
.kv .k{font-size:10.5px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);font-weight:500}
.kv .v{font-weight:600;margin-top:4px;color:var(--ink);font-size:14px;font-variant-numeric:tabular-nums}
.checks{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:9px}
.checks label{display:flex;align-items:center;gap:9px;font-size:13px;padding:9px 12px;border:1px solid var(--line);border-radius:var(--r-sm);cursor:pointer;color:var(--slate);transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.checks label:hover{background:var(--canvas);border-color:var(--faint)}
.checks input{width:auto;accent-color:var(--navy)}
#toast{position:fixed;bottom:24px;right:24px;z-index:300;display:flex;flex-direction:column;gap:10px}
.toast{background:var(--ink);color:#fff;padding:12px 16px;border-radius:var(--r-sm);box-shadow:var(--shadow-lg);font-size:13px;max-width:340px;border-left:3px solid var(--navy);font-weight:500;animation:toastIn .3s var(--ease)}
.toast.ok{border-left-color:var(--ok)}
.toast.err{border-left-color:var(--danger)}
@keyframes toastIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.legend{font-size:12.5px;color:var(--muted);margin:0 0 16px;display:flex;gap:18px;flex-wrap:wrap}
.legend b{color:var(--ink);font-weight:600}
.legend span{display:inline-flex;align-items:center;gap:6px}
iframe.report{width:100%;height:680px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--card);box-shadow:var(--shadow-xs)}
/* Login */
#login{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:500;padding:20px}
#login::before{content:"";position:absolute;inset:0;background:
  radial-gradient(ellipse 50% 40% at 20% 30%, rgba(11,45,82,0.08), transparent 60%),
  radial-gradient(ellipse 40% 35% at 80% 70%, rgba(8,145,178,0.06), transparent 60%);
  pointer-events:none}
#login .box{background:var(--card);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px;padding:36px 32px;border:1px solid var(--line);position:relative;z-index:1}
#login .lg{font-weight:700;font-size:26px;color:var(--navy);text-align:center;letter-spacing:-0.02em}
#login .lg b{color:var(--bauxite);font-weight:700}
#login .sub{text-align:center;color:var(--faint);font-size:11px;margin:6px 0 28px;text-transform:uppercase;letter-spacing:1.6px;font-weight:500}
#login .field{margin-bottom:14px}
#login button{width:100%;margin-top:8px;justify-content:center;padding:12px}
#login .btn.is-busy{opacity:.78;cursor:progress;pointer-events:none}
/* Champ mot de passe avec œil (le wrapper porte la bordure, l'input la perd) */
.pwdfield{display:flex;align-items:stretch;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--card);transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.pwdfield:hover{border-color:var(--faint)}
.pwdfield:focus-within{border-color:var(--navy);box-shadow:0 0 0 3px var(--navy-tint)}
.pwdfield>input{flex:1;min-width:0;width:auto;border:0!important;background:transparent;outline:none!important;box-shadow:none!important;padding:9px 12px;font-family:inherit;font-size:13.5px;color:var(--ink)}
.pwdfield>input:hover,.pwdfield>input:focus{border:0!important;box-shadow:none!important}
#login .pwd-eye{width:42px;flex:0 0 auto;margin-top:0;padding:0;display:flex;align-items:center;justify-content:center;border:0;background:transparent;color:var(--muted);cursor:pointer;border-radius:0 var(--r-sm) var(--r-sm) 0;transition:color var(--dur) var(--ease),background var(--dur) var(--ease)}
#login .pwd-eye:hover{color:var(--slate);background:var(--canvas)}
#login .pwd-eye:focus-visible{outline:none;color:var(--navy);background:var(--navy-tint)}
.pwd-eye .svg-i{width:18px;height:18px}
#login .err{color:var(--danger);font-size:13px;text-align:center;min-height:18px;margin-top:10px}
#login .hint{font-size:11.5px;color:var(--muted);text-align:center;margin-top:18px;line-height:1.5}
/* Tooltip générique réutilisable (KPI deltas, etc.) */
.tip{position:relative;cursor:help}
.kpi-label.tip{border-bottom:1px dotted var(--faint);padding-bottom:1px}
.tip::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;font-size:11.5px;font-weight:500;padding:7px 11px;border-radius:6px;white-space:normal;max-width:220px;width:max-content;text-align:center;line-height:1.4;opacity:0;pointer-events:none;transition:opacity .15s var(--ease),transform .15s var(--ease);z-index:60;box-shadow:var(--shadow);letter-spacing:.1px}
.tip::before{content:'';position:absolute;bottom:calc(100% + 2px);left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--ink);opacity:0;transition:opacity .15s var(--ease);z-index:60}
.tip:hover::after,.tip:focus-visible::after{opacity:1;transform:translateX(-50%) translateY(-2px)}
.tip:hover::before,.tip:focus-visible::before{opacity:1}
/* Impression : ne garder QUE la vue active, sans chrome (nav, topbar, barre de période) et sans scroll interne */
@media print{
.topbar,nav.side,.navrail,.ctxbar,.tabbar.primary,.subbar,.tb-btn,.rowact,#toast,#login,.demo-badge{display:none!important}
/* Les conteneurs flex à hauteur d'écran clippaient l'impression à une page : tout repasse en flux */
.appshell{display:block!important;height:auto!important}
.layout{display:block!important}
.content{display:block!important}
main#main{overflow:visible!important;height:auto!important;padding:0}
.view{display:none!important}.view.active{display:block!important}
.bd.flush .tablewrap{max-height:none!important;overflow:visible!important}
.card{box-shadow:none!important;break-inside:avoid}
body{background:#fff}
}
@media(max-width:860px){main{padding:14px}.userchip .meta{display:none}}

/* ===== Refonte navigation : onglets + sous-onglets ===== */
.tabbar.primary{display:flex;gap:2px;background:var(--navy);padding:0 10px;flex-shrink:0;overflow-x:auto}
.tabbar.primary button{color:#cdd9ea;background:transparent;border:0;padding:15px 18px;font-weight:600;font-size:14px;border-bottom:3px solid transparent;cursor:pointer;font-family:inherit;white-space:nowrap;display:flex;align-items:center;gap:8px}
.tabbar.primary button:hover{color:#fff;background:rgba(255,255,255,.06)}
.tabbar.primary button.active{color:#fff;border-bottom-color:var(--amber)}
.tabbar.primary button .pic{opacity:.85}
.subbar{display:flex;align-items:center;gap:14px;background:#fff;border-bottom:1px solid var(--line);padding:0 16px;flex-shrink:0;flex-wrap:wrap;min-height:48px}
.tabbar.secondary{display:flex;gap:4px;overflow-x:auto;padding:8px 0;flex:1}
.tabbar.secondary button{font-family:inherit;font-size:13px;border:1px solid transparent;background:transparent;color:var(--slate);padding:7px 13px;border-radius:8px;cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:7px}
.tabbar.secondary button:hover{background:#f1f5f9}
.tabbar.secondary button.active{background:#eef3fb;color:var(--navy);font-weight:600;border-color:#cfe0f5}
.tabbar.secondary button .stag{font-size:10px;padding:1px 5px;border-radius:999px;font-weight:700}
.period{display:flex;align-items:center;gap:10px;padding:9px 0;flex-wrap:wrap;width:100%}
.period .per-ic{width:34px;height:34px;border-radius:9px;background:#fff;border:1px solid var(--line);color:var(--navy);display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--shadow-xs);flex-shrink:0}
.period .per-ic .svg-i{width:17px;height:17px}
.period label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;font-weight:600}
.period select,.period input{padding:8px 11px;border:1px solid var(--line);border-radius:var(--r-sm);font-family:inherit;font-size:13px;background:#fff;color:var(--ink);transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);box-shadow:var(--shadow-xs)}
.period select{cursor:pointer;font-weight:500}
.period select:hover,.period input:hover{border-color:var(--navy7)}
.period select:focus,.period input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px var(--navy-tint)}
.period input[type=date],.period input[type=month],.period input[type=week]{cursor:pointer;width:160px;max-width:160px}
.period input::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.5;transition:opacity var(--dur) var(--ease)}
.period input:hover::-webkit-calendar-picker-indicator{opacity:1}
.period .per-spacer{flex:1;min-width:8px}
.period .perlabel{font-size:12px;font-weight:600;color:#fff;background:var(--navy);border:1px solid var(--navy);padding:6px 12px;border-radius:999px;font-variant-numeric:tabular-nums;box-shadow:var(--shadow-xs);letter-spacing:.1px;text-transform:capitalize;white-space:nowrap}
.appshell{display:none;flex-direction:column;height:100vh;width:100%}
main#main{flex:1;overflow:auto;padding:22px 26px;min-width:0}
@media(max-width:760px){.tabbar.primary button{padding:13px 12px;font-size:13px}main#main{padding:14px}.userchip .meta{display:none}}
/* ===== Sidebar — rail icônes, ouverture au survol ou épinglée (façon Supabase) ===== */
.tabbar.primary{display:none!important}
.layout{display:flex;flex:1;min-height:0;position:relative}
.navrail{width:58px;flex-shrink:0;position:relative;z-index:50;transition:width var(--dur) var(--ease)}
/* Chrome (nav) en gris froid léger : recule derrière le contenu — le blanc pur reste réservé aux cartes de données */
nav.side{position:absolute;top:0;left:0;bottom:0;width:58px;background:var(--chrome);border-right:1px solid var(--line);padding:0 7px 8px;overflow:hidden;display:flex;flex-direction:column;transition:width var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.navrail:hover nav.side,.navrail:focus-within nav.side{width:212px;overflow-y:auto;box-shadow:var(--shadow-lg)}
/* Mode épinglé : la nav occupe sa place et pousse le contenu */
.layout.nav-pinned .navrail{width:206px}
.layout.nav-pinned nav.side{width:206px;box-shadow:none;overflow-y:auto}
.layout.nav-pinned nav.side .txt{opacity:1}
/* Boutons : icône fixe à gauche, label qui apparaît, fond inset arrondi */
nav.side button{position:relative;display:flex;align-items:center;gap:11px;width:100%;border:0;background:transparent;text-align:left;padding:7px 9px;border-radius:8px;font-size:13px;color:var(--slate);cursor:pointer;font-family:inherit;font-weight:500;white-space:nowrap;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}
nav.side button .ic{width:28px;height:26px;display:inline-flex;align-items:center;justify-content:center;color:var(--navy);opacity:1;flex-shrink:0;transition:color var(--dur) var(--ease)}
nav.side button .ic .svg-i{width:24px;height:24px;stroke-width:1.5px}
/* Palette de rail restreinte (cohérente, pas multicolore) : slate par défaut, navy = Accueil, bauxite = Rapports */
nav.side button[data-acc="navy"] .ic,nav.side button[data-acc="bauxite"] .ic{color:var(--navy)}
nav.side button .txt{opacity:0;transition:opacity .12s var(--ease)}
.navrail:hover nav.side button .txt,.navrail:focus-within nav.side button .txt{opacity:1}
nav.side button:hover{background:var(--navy-tint);color:var(--navy)}
nav.side button:hover .ic{color:var(--navy)}
/* Item ACTIF = bloc plein navy (langage de statut Monday) */
nav.side button.active{background:linear-gradient(135deg,#0B2D52,#17436F);color:#fff;font-weight:600;box-shadow:0 2px 6px -1px rgba(11,45,82,.32);padding-top:9px;padding-bottom:9px}
nav.side button.active .ic{color:#fff}
nav.side button.active:hover{background:linear-gradient(135deg,#0B2D52,#17436F);color:#fff}
/* Sections (hors Tableau de bord) : bloc navy plus bas + fin liseré bauxite au bord gauche (rappel DA) */
nav.side button.active:not(.home){padding-top:6px;padding-bottom:6px;box-shadow:inset 3px 0 0 var(--bauxite),0 2px 6px -1px rgba(11,45,82,.32)}
/* Exception marque : Rapports actif garde l'identité bauxite via liseré */
nav.side button.active[data-acc="bauxite"]{box-shadow:inset 3px 0 0 var(--bauxite),0 2px 6px -1px rgba(11,45,82,.32)}
nav.side button:focus-visible{outline:none;box-shadow:inset 0 0 0 2px var(--navy-tint)}
/* Groupe → fine ligne séparatrice insérée, ne touche pas les bords */
nav.side .grp{height:1px;background:var(--line);margin:9px 9px;padding:0;flex-shrink:0;border:0}
/* Pied : bouton d'épinglage */
nav.side .nav-foot{margin-top:auto;padding-top:8px;border-top:1px solid var(--line-soft);margin-top:auto}
nav.side .nav-profile{display:flex;align-items:center;gap:12px;padding:9px 10px;border-radius:9px;margin:6px 0 2px}
nav.side .np-av{width:30px;height:30px;border-radius:50%;background:var(--navy);color:#fff;font-weight:600;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;margin-left:-1px}
nav.side .np-meta{min-width:0;opacity:0;transition:opacity .12s var(--ease)}
.navrail:hover nav.side .np-meta,.navrail:focus-within nav.side .np-meta,.layout.nav-pinned nav.side .np-meta{opacity:1}
nav.side .np-name{font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:170px}
nav.side .np-role{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}
nav.side .nav-pin{position:relative;display:flex;align-items:center;gap:12px;width:100%;border:0;background:transparent;text-align:left;padding:9px 10px;border-radius:9px;font-size:13px;color:var(--muted);cursor:pointer;font-family:inherit;font-weight:500;white-space:nowrap;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}
nav.side .nav-pin .ic{width:28px;height:20px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.7}
nav.side .nav-pin .ic .svg-i{width:18px;height:18px}
nav.side .nav-pin .txt{opacity:0;transition:opacity .12s var(--ease)}
.navrail:hover nav.side .nav-pin .txt,.navrail:focus-within nav.side .nav-pin .txt,.layout.nav-pinned nav.side .nav-pin .txt{opacity:1}
nav.side .nav-pin:hover{background:var(--canvas);color:var(--ink)}
nav.side .nav-pin.on{color:var(--navy)}
nav.side .nav-pin.on .ic{opacity:1;color:var(--navy)}
/* Repli immédiat après désépinglage : neutralise l'expansion hover/focus jusqu'à la sortie du curseur */
.navrail.hover-off nav.side{width:58px!important;overflow:hidden!important;box-shadow:none!important}
.navrail.hover-off nav.side .txt,.navrail.hover-off nav.side .np-meta{opacity:0!important}
.content{flex:1;display:flex;flex-direction:column;min-width:0;position:relative}
/* Barre de période flottante (carte en haut à droite du contenu) */
.ctxbar{position:absolute;top:14px;right:26px;z-index:30;background:transparent;border:0;padding:0;min-height:0;pointer-events:none}
.ctxbar .period{pointer-events:auto;width:auto;padding:5px 9px 5px 7px;background:var(--chrome);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);gap:7px;max-width:min(90vw,540px);flex-wrap:nowrap;transition:padding .2s var(--ease),box-shadow .2s var(--ease)}
/* Plage personnalisée : tout tient sur une ligne — dates compactes, Du/au insécables, pilule récap masquée */
.ctxbar .period #perInputs{white-space:nowrap;display:inline-flex;align-items:center;gap:6px}
.ctxbar .period.per-custom{max-width:min(96vw,700px)}
.ctxbar .period.per-custom input[type=date]{width:128px;max-width:128px}
.ctxbar:not(.compact) .period.per-custom .perlabel{display:none}
.ctxbar .period select,.ctxbar .period input{padding:6px 9px;font-size:12.5px}
.ctxbar .period>label{font-size:10px}
.ctxbar .period input[type=date],.ctxbar .period input[type=month],.ctxbar .period input[type=week]{width:140px;max-width:140px}
.ctxbar .period .per-ic{width:30px;height:30px}
/* Au scroll, la pilule se réduit à l'icône + le libellé de période pour ne pas gêner */
.ctxbar.compact .period{padding:5px 8px 5px 6px;gap:6px;box-shadow:var(--shadow-xs);transition:padding var(--dur) var(--ease)}
.ctxbar.compact .period .per-ic{width:28px;height:28px}
.ctxbar.compact .period .perlabel{padding:5px 11px;font-size:11.5px}
.ctxbar.compact .period>label,.ctxbar.compact .period #perType,.ctxbar.compact .period #perInputs,.ctxbar.compact .period .per-spacer{display:none}
.ctxbar.compact .period:hover,.ctxbar.compact .period:focus-within{padding:6px 10px 6px 8px;box-shadow:var(--shadow)}
.ctxbar.compact .period:hover>label,.ctxbar.compact .period:hover #perType,.ctxbar.compact .period:hover #perInputs,.ctxbar.compact .period:hover .per-spacer,.ctxbar.compact .period:focus-within>label,.ctxbar.compact .period:focus-within #perType,.ctxbar.compact .period:focus-within #perInputs,.ctxbar.compact .period:focus-within .per-spacer{display:revert}
@media print{.ctxbar{position:static}}
main#main{flex:1;overflow:auto;padding:24px 28px;min-width:0;background:var(--bg)}
@media print{nav.side,.ctxbar{display:none!important}}
@media(max-width:820px){main#main{padding:16px}}
/* ===== Confirmation + corbeille ===== */
button.btn.danger-solid,.btn.danger-solid{background:var(--danger);border-color:var(--danger);color:#fff}
button.btn.danger-solid:hover{filter:brightness(.95)}
#confirmOverlay{position:fixed;inset:0;background:rgba(11,45,82,.5);display:none;align-items:center;justify-content:center;padding:20px;z-index:150}
#confirmOverlay.open{display:flex}
#confirmOverlay .modal{max-width:460px;width:100%}
#confirmOverlay .cfhead{display:flex;align-items:center;gap:12px;padding:18px 20px 6px}
#confirmOverlay .cfic{width:40px;height:40px;border-radius:50%;background:#fbe6e3;color:var(--danger);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
#confirmOverlay h3{margin:0;font-size:16px;color:var(--navy)}
#confirmOverlay .cfmsg{padding:6px 20px 4px;color:var(--slate);font-size:14px;line-height:1.5}
#confirmOverlay .mf{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px}
/* ===== Avertissement d'inactivite ===== */
#idleOverlay{position:fixed;inset:0;background:rgba(11,45,82,.55);display:none;align-items:center;justify-content:center;padding:20px;z-index:220}
#idleOverlay.open{display:flex}
#idleOverlay .modal{max-width:440px;width:100%}
#idleOverlay .cfhead{display:flex;align-items:center;gap:12px;padding:18px 20px 6px}
#idleOverlay .cfic{width:40px;height:40px;border-radius:50%;background:#fdf3e0;color:var(--warn);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
#idleOverlay h3{margin:0;font-size:16px;color:var(--navy)}
#idleOverlay .cfmsg{padding:6px 20px 4px;color:var(--slate);font-size:14px;line-height:1.5}
#idleOverlay .cfmsg b{color:var(--navy)}
#idleOverlay .mf{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px}
/* ===== Tableau de bord prioritaire (en tete du menu) — bouton normalisé ===== */
nav.side button.home{margin:0}
/* Onglet Tableau de bord désélectionné : look distinctif (pastille navy douce, ≠ autres onglets) */
nav.side button.home:not(.active){background:transparent;color:var(--navy);font-weight:600}
nav.side button.home:not(.active) .ic{color:var(--navy)}
/* Tête de nav FIGÉE : onglet + trait restent en haut au scroll ; fond plein = masque, rien ne défile dessous */
nav.side .nav-head{position:sticky;top:0;z-index:3;background:var(--chrome);margin:0 -7px;padding:14px 7px 0;box-shadow:0 6px 14px -10px rgba(11,45,82,.09)}
nav.side .nav-head .grp.nav-head-line{margin:9px 9px 7px}
