/* TopStock - styles SPA prod. Derive du mockup, charte Top Sales.
   Bleu marine #002956 + Raleway + rouge signal #E30613. */

:root {
  --bg:#FFFFFF; --surface-1:#F7F7F8; --surface-2:#EFEFF1; --surface-3:#E4E4E7;
  --text:#1A1A1A; --text-muted:#52525B; --text-faint:#71717A;
  --line:rgba(26,26,26,0.10); --line-strong:rgba(26,26,26,0.22);
  --primary:#002956; --primary-700:#001b3a;
  --accent:#E30613; --accent-700:var(--accent-700); --ok:#1E7A47; --warn:#B45309; --warn-strong:#92400E;
  /* Alias : des composants utilisent ces noms. On les mappe aux variables réelles
     pour réparer ~31 usages (bordures invisibles, textes, CTA Aide illisible). */
  --border:var(--line); --muted:var(--text-muted); --primary-dark:var(--primary-700);
  --font:'Raleway',system-ui,-apple-system,sans-serif;
  /* Police dédiée aux chiffres (KPIs, stocks, montants, tableaux) : Inter, plus
     lisible et plus dense en colonne que Raleway. N'impose pas de graisse, pour
     conserver la hiérarchie (KPI 800, cellules 400). Repli sur Raleway. */
  --font-num:'Inter','Raleway',system-ui,sans-serif;
  /* Alias historiques : des blocs (bandeau PWA, guide install, sync, support, net)
     référencaient --font-b (texte) et un mono 'JetBrains Mono' jamais chargé. On les
     mappe sur les deux seules polices du système pour une typo 100% uniforme :
     --font-b = Raleway (texte), --font-m = Inter (codes/SKU/URL, déjà chargée). */
  --font-b:var(--font);
  --font-m:var(--font-num);
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:20px; --s-6:24px; --s-8:32px; --s-10:40px;
  --r-sm:6px; --r-md:8px; --r-lg:14px; --r-xl:20px; --r-pill:999px;
  --shadow-sm:0 1px 2px rgba(0,41,86,0.06), 0 1px 3px rgba(0,41,86,0.05);
  --shadow-md:0 6px 24px rgba(0,41,86,0.10);
  --shadow-lg:0 18px 50px rgba(0,41,86,0.16);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font);font-weight:400;font-size:15px;line-height:1.55;color:var(--text);background:var(--surface-1);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
img,svg{display:block}
ul{list-style:none}
input,select,textarea{font:inherit}

.caps{text-transform:uppercase;letter-spacing:0.1em;font-weight:700;font-size:11px}
.muted{color:var(--text-muted)}
.faint{color:var(--text-faint)}
.num{font-family:var(--font-num);font-variant-numeric:tabular-nums;letter-spacing:0}
.strong{font-weight:700}
.right{text-align:right}
.hidden{display:none !important}

/* ── Login ─────────────────────────────────────────────────────────────── */
.login-page{min-height:100vh;display:grid;place-items:center;background:var(--primary);padding:24px}
.login-card{background:#fff;border-radius:var(--r-lg);padding:36px 32px;width:100%;max-width:380px;box-shadow:var(--shadow-lg)}
.login-card .logo{display:block;margin:0 auto 24px;max-width:140px}
.login-card h1{font-size:22px;font-weight:800;text-align:center;letter-spacing:-0.02em;margin-bottom:6px}
.login-card .sub{text-align:center;color:var(--text-muted);font-size:13px;margin-bottom:24px}
.login-card label{display:block;font-size:12px;font-weight:700;letter-spacing:0.04em;color:var(--text-muted);margin-bottom:6px;margin-top:14px}
.login-card input{width:100%;padding:11px 14px;border:1px solid var(--line-strong);border-radius:var(--r-md);background:var(--surface-1);outline:none;font-size:14px}
.login-card input:focus{border-color:var(--primary);background:#fff}
.login-card button{width:100%;margin-top:22px;padding:13px;border-radius:var(--r-md);background:var(--primary);color:#fff;border:none;font-weight:700;font-size:14px}
.login-card button:hover{background:var(--primary-700)}
.login-card .err{margin-top:14px;padding:10px 12px;background:rgba(227,6,19,0.08);border:1px solid rgba(227,6,19,0.3);border-radius:var(--r-sm);color:var(--accent);font-size:13px;text-align:center}
.login-card .foot{margin-top:22px;text-align:center;font-size:11px;color:var(--text-faint)}

/* ── Buttons ───────────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:14px;padding:11px 20px;border-radius:var(--r-md);border:1px solid transparent;background:var(--surface-2);color:var(--text);transition:transform .18s cubic-bezier(.4,0,.2,1),background .18s,box-shadow .18s}
.btn:hover{background:var(--surface-3)}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--primary-700)}
.btn-ghost{background:transparent;border-color:var(--line-strong);color:var(--text)}
.btn-ghost:hover{background:var(--surface-2)}
.btn-block{width:100%}
.btn-lg{padding:14px 22px;font-size:15px}
.btn-xl{padding:20px 24px;font-size:18px;font-weight:700}
.btn-sm{padding:6px 12px;font-size:12px}
/* Focus clavier visible (accessibilité) sur tous les éléments interactifs. Sur la
   sidebar marine et les boutons pleins, anneau clair (sinon marine sur marine invisible). */
:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
.sidebar :focus-visible,.btn-primary:focus-visible,.btn-xl:focus-visible{outline-color:#fff}

/* ── Chrome appli ──────────────────────────────────────────────────────── */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{background:var(--primary);color:#fff;display:flex;flex-direction:column;padding:var(--s-5) var(--s-4);position:sticky;top:0;height:100vh;overflow:hidden}
.sidebar .logo-wrap{flex:none;padding:14px 0;margin-bottom:var(--s-6);text-align:center}
.sidebar .logo-wrap img{width:140px;display:inline-block}
/* La liste de menu prend l'espace disponible et scrolle si la fenetre est trop
   courte : le logo (haut) et le bloc utilisateur (bas) restent toujours visibles. */
.nav{display:flex;flex-direction:column;gap:2px;flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden}
.nav::-webkit-scrollbar{width:6px}
.nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.18);border-radius:3px}
.nav{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.18) transparent}
.nav a{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:var(--r-md);color:rgba(255,255,255,0.78);font-weight:500;font-size:14px;transition:background .16s,color .16s}
.nav a:hover{background:rgba(255,255,255,0.08);color:#fff}
.nav a.active{background:#fff;color:var(--primary);font-weight:700}
.nav a.active svg{stroke:var(--primary)}
.nav a svg{width:19px;height:19px;flex:none;stroke:currentColor}
.nav .group-label{font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.45);font-weight:700;padding:0 13px;margin:var(--s-5) 0 var(--s-2)}
.sidebar .me{flex:none;margin-top:var(--s-4);padding-top:var(--s-5);border-top:1px solid rgba(255,255,255,0.12);display:flex;align-items:center;gap:11px}
.sidebar .me .avatar{width:36px;height:36px;border-radius:var(--r-pill);background:#fff;color:var(--primary);display:grid;place-items:center;font-weight:800;font-size:14px;flex:none}
.sidebar .me .info{line-height:1.25;min-width:0;flex:1}
.sidebar .me .info .n{font-weight:700;font-size:13px}
.sidebar .me .info .r{font-size:11px;color:rgba(255,255,255,0.6)}
.sidebar .me .logout{color:rgba(255,255,255,0.5);font-size:12px;cursor:pointer;padding:6px 8px;border-radius:var(--r-sm);background:none;border:none}
.sidebar .me .logout:hover{background:rgba(255,255,255,0.08);color:#fff}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;gap:var(--s-4);padding:var(--s-5) var(--s-8);background:var(--bg);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5;flex-wrap:wrap;row-gap:10px}
.topbar h1{font-size:22px;font-weight:800;letter-spacing:-0.02em}
.topbar .sub{font-size:13px;color:var(--text-muted);margin-top:1px}
.topbar .spacer{flex:1}
.search{display:flex;align-items:center;gap:9px;background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r-md);padding:9px 14px;min-width:240px}
.search input{border:none;background:none;outline:none;font:inherit;flex:1;color:var(--text)}
.content{padding:var(--s-8);display:flex;flex-direction:column;gap:var(--s-6)}

/* ── Cartes / KPI ──────────────────────────────────────────────────────── */
.card{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s-6);box-shadow:var(--shadow-sm)}
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-4)}
.kpi{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s-5);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.kpi .k-label{font-size:12px;font-weight:600;color:var(--text-muted)}
.kpi .k-value{font-size:34px;font-weight:800;letter-spacing:-0.03em;margin-top:6px}
/* Montant en euros : ne jamais couper le symbole € sur une nouvelle ligne ; on
   réduit la taille plutôt que de passer à la ligne (le « € » tombait sous le montant). */
.kpi .k-value.k-eur{white-space:nowrap;font-size:clamp(22px,2.4vw,34px)}
.kpi .k-value small{font-size:16px;font-weight:600;color:var(--text-faint)}
.kpi .k-sub{font-size:12px;font-weight:600;margin-top:4px;color:var(--text-muted)}
.kpi.alert{border-color:rgba(227,6,19,0.35)}
.kpi.alert .k-value{color:var(--accent)}

.section-head{display:flex;align-items:center;gap:var(--s-3);margin-bottom:var(--s-4)}
.section-head h2{font-size:17px;font-weight:700}
.section-head .count{font-size:12px;color:var(--text-faint)}
.section-head .spacer{flex:1}

.two-col{display:grid;grid-template-columns:1.6fr 1fr;gap:var(--s-6);align-items:start}

/* ── Tableaux ──────────────────────────────────────────────────────────── */
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th{text-align:left;font-size:11px;letter-spacing:0.06em;text-transform:uppercase;color:var(--text-faint);font-weight:700;padding:10px 14px;border-bottom:1px solid var(--line);background:var(--surface-1)}
.table td{padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
.table tr:last-child td{border-bottom:none}
.table tbody tr:hover{background:var(--surface-1)}

/* Cellule produit (historique d'un collaborateur) : nom au-dessus, référence dessous.
   Plus lisible qu'un nom + SKU sur la même ligne, surtout en mode cartes (terminal). */
.histo-prod{display:flex;flex-direction:column;gap:2px;min-width:0}
.histo-prod .hp-nom{font-weight:700;line-height:1.3}
.histo-prod .hp-sku{font-size:11px;font-weight:600;letter-spacing:.02em;color:var(--text-faint)}

.tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:var(--r-pill);text-transform:uppercase;letter-spacing:0.04em}
.tag.sortie{background:rgba(0,41,86,0.08);color:var(--primary)}
.tag.retour{background:rgba(30,122,71,0.12);color:var(--ok)}
.tag.casse{background:rgba(227,6,19,0.10);color:var(--accent)}
.tag.recep,.tag.reception{background:var(--surface-2);color:var(--text-muted)}
.tag.transfert{background:rgba(0,41,86,0.06);color:var(--text-muted)}
.tag.inventaire{background:rgba(180,83,9,0.10);color:var(--warn)}

.brand-pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:3px 10px;border-radius:var(--r-pill);background:var(--surface-2);color:var(--text-muted);border:1px solid var(--line);white-space:nowrap}
.brand-pill .dot{width:7px;height:7px;border-radius:var(--r-pill);flex:none;background:var(--text-faint)}

/* ── Scan (mobile-first) ───────────────────────────────────────────────── */
.scan-wrap{max-width:520px;margin:0 auto;width:100%}
.scan-camera{background:#000;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:1/1;position:relative;margin-bottom:var(--s-4)}
.scan-camera #qr{width:100%;height:100%}
.scan-camera .hint{position:absolute;left:0;right:0;bottom:0;padding:14px;background:rgba(0,0,0,0.62);color:#fff;font-size:13px;text-align:center;display:flex;flex-wrap:wrap;gap:6px 14px;align-items:center;justify-content:center}
.scan-result{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;margin-bottom:var(--s-4)}
.scan-result .nom{font-size:20px;font-weight:800;letter-spacing:-0.01em}
.scan-result .sku{font-size:12px;color:var(--text-faint);font-family:var(--font-num);font-variant-numeric:tabular-nums;margin-top:4px}
.scan-result .row{display:flex;justify-content:space-between;margin-top:14px;padding-top:14px;border-top:1px solid var(--line);font-size:14px}
.qty-control{display:flex;align-items:center;background:var(--surface-1);border-radius:var(--r-lg);padding:8px;margin:16px 0;gap:10px}
.qty-control button{width:48px;height:48px;border-radius:var(--r-pill);border:1px solid var(--line);background:#fff;font-size:24px;font-weight:700}
.qty-control input{flex:1;text-align:center;font-size:34px;font-weight:800;border:none;background:transparent;outline:none;color:var(--text);font-family:var(--font-num);font-variant-numeric:tabular-nums}
/* Comptoir : invite de scan + saisie manuelle (laser intégré ou douchette d'abord). */
.scan-prompt{display:flex;align-items:center;gap:12px;background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r-lg);padding:14px 16px;margin-bottom:12px;color:var(--text-muted);font-size:14px;line-height:1.4}
.scan-prompt svg{color:var(--primary);flex:none}
.scan-manual{display:flex;gap:8px;margin-bottom:14px}
.scan-manual input{flex:1;min-width:0;padding:14px 16px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--bg);outline:none;font-size:16px}
.scan-manual .btn{padding:14px 20px}
.scan-camera{max-height:52vh}
/* Terminal durci 5" (EA502) et petits écrans : cibles tactiles agrandies (gants),
   tout le flux comptoir tient sans scroll inutile. */
@media (max-width:480px){
  .scan-wrap{max-width:none}
  #benefSel{padding:13px 14px !important;font-size:15px}
  .scan-manual input{font-size:17px;padding:15px 16px}
  .qty-control button{width:58px;height:58px;font-size:28px}
  .qty-control input{font-size:32px}
  .scan-result .nom{font-size:18px}
  .btn-xl{padding:18px 24px;font-size:18px}
}

/* ── Toast ─────────────────────────────────────────────────────────────── */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--text);color:#fff;padding:12px 20px;border-radius:var(--r-pill);box-shadow:var(--shadow-md);font-weight:600;font-size:14px;z-index:100;opacity:0;transition:opacity .2s, transform .2s}
.toast.show{opacity:1;transform:translateX(-50%) translateY(-4px)}
.toast.ok{background:var(--ok)}
.toast.err{background:var(--accent)}

/* ── Filtres chips ─────────────────────────────────────────────────────── */
.chips{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.chip{padding:6px 12px;border-radius:var(--r-pill);background:var(--bg);border:1px solid var(--line);font-size:12px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .15s}
.chip:hover{border-color:var(--line-strong);color:var(--text)}
.chip.on{background:var(--primary);color:#fff;border-color:var(--primary)}

/* ── Loader skeleton ───────────────────────────────────────────────────── */
.skeleton{background:linear-gradient(90deg, var(--surface-2) 25%, var(--surface-3) 50%, var(--surface-2) 75%);background-size:200% 100%;animation:sk 1.4s infinite;border-radius:var(--r-sm)}
@keyframes sk{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── Empty state ───────────────────────────────────────────────────────── */
.empty{padding:48px;text-align:center;color:var(--text-muted);background:var(--bg);border:1px dashed var(--line-strong);border-radius:var(--r-lg)}
.empty .ico{font-size:36px;margin-bottom:8px;opacity:0.4}

/* ── Footer credit ─────────────────────────────────────────────────────── */
.credit{text-align:center;font-size:12px;color:var(--text-faint);padding:var(--s-6);border-top:1px solid var(--line)}

/* ── Modaux ─────────────────────────────────────────────────────────────── */
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.55);z-index:200;display:flex;align-items:flex-start;justify-content:center;padding:48px 16px;overflow:auto;opacity:0;animation:bd-in .15s forwards}
@keyframes bd-in{to{opacity:1}}
.modal-card{background:var(--bg);border-radius:var(--r-lg);padding:24px 26px;width:100%;max-width:480px;box-shadow:var(--shadow-lg);transform:scale(.96);animation:m-in .18s cubic-bezier(.2,.7,.3,1.2) forwards}
@keyframes m-in{to{transform:scale(1)}}
.modal-card.large{max-width:720px}
.modal-card h3{font-size:18px;font-weight:800;letter-spacing:-0.01em;margin-bottom:6px}
.modal-card .sub{color:var(--text-muted);font-size:13px;margin-bottom:18px}
.modal-card label{display:block;font-size:12px;font-weight:700;letter-spacing:0.04em;color:var(--text-muted);margin-bottom:6px;margin-top:14px;text-transform:uppercase}
.modal-card input[type=text],.modal-card input[type=email],.modal-card input[type=password],.modal-card input[type=number],.modal-card select,.modal-card textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--bg);outline:none;font:inherit;font-size:14px}
.modal-card input:focus,.modal-card select:focus,.modal-card textarea:focus{border-color:var(--primary)}
.modal-card .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:22px}
.modal-card .actions .btn{padding:9px 18px;font-size:14px}

/* ── Recherche globale ──────────────────────────────────────────────────── */
.search.global{position:relative}
.search-results{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-md);max-height:380px;overflow:auto;z-index:50}
.search-results .item{padding:10px 14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line);cursor:pointer}
.search-results .item:last-child{border-bottom:none}
.search-results .item:hover,.search-results .item.kbd{background:var(--surface-1)}
.search-results .kind{font-size:10px;font-weight:700;color:var(--text-faint);letter-spacing:0.08em;text-transform:uppercase;flex:none;min-width:60px}
.search-results .empty{padding:20px;text-align:center;color:var(--text-faint);font-size:13px}

/* ── Mobile hamburger + drawer ─────────────────────────────────────────── */
.hamburger{display:none;width:36px;height:36px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--bg);align-items:center;justify-content:center;flex:none}
.hamburger svg{width:20px;height:20px}

/* ── Badge sidebar (compteurs) ─────────────────────────────────────────── */
.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 6px;border-radius:var(--r-pill);background:var(--accent);color:#fff;font-size:10px;font-weight:800;margin-left:auto;font-family:var(--font-num);font-variant-numeric:tabular-nums}
/* Menu déroulant "voir comme" (console de maintenance). */
.va-menu{position:absolute;right:0;top:calc(100% + 6px);min-width:210px;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-md);padding:6px;z-index:60;display:flex;flex-direction:column;gap:2px}
.va-menu[hidden]{display:none}  /* sinon display:flex écrase l'attribut hidden et le menu reste ouvert */
/* Sélecteur de couleur (marques) : carré chromatique natif + champ hex côte à côte. */
.color-field{display:flex;align-items:center;gap:10px}
.color-field input[type=color]{flex:none;width:46px;height:40px;padding:3px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--bg);cursor:pointer}
.color-field input[type=color]::-webkit-color-swatch{border:none;border-radius:4px}
.color-field input[type=color]::-webkit-color-swatch-wrapper{padding:0}
.color-field input[type=text]{flex:1;min-width:0;text-transform:uppercase;font-family:var(--font-num)}
/* Bouton « + » d'ajout inline à côté d'un select (marque, catégorie). */
.select-add{display:flex;align-items:center;gap:8px}
.select-add select{flex:1;min-width:0}
.select-add-btn{flex:none;width:42px;height:40px;border:1px solid var(--line);background:var(--surface-1);color:var(--primary);border-radius:var(--r-md);font-size:22px;font-weight:700;line-height:1;cursor:pointer;transition:background .15s,color .15s}
.select-add-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
/* Formulaire produit : sélecteur de mode (Standard scanner / Manuel) + zone de scan. */
.np-modebar{display:flex;gap:6px;background:var(--surface-1);padding:5px;border-radius:11px;border:1px solid var(--line);margin-bottom:14px}
.np-mode{flex:1;padding:11px 12px;font:inherit;font-weight:700;font-size:14px;background:transparent;border:none;border-radius:8px;cursor:pointer;color:var(--text-muted);transition:background .16s,color .16s,box-shadow .16s}
.np-mode.on{background:var(--primary);color:#fff;box-shadow:0 2px 8px rgba(0,41,86,0.18)}
.np-scanwrap{background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r-md);padding:14px;margin-bottom:16px}
.np-scanwrap input{width:100%;padding:13px 14px;font-size:17px;font-weight:700;text-align:center;letter-spacing:0.04em;border:2px dashed var(--line-strong);border-radius:var(--r-md);background:var(--bg);outline:none;font-family:var(--font-num)}
.np-scanwrap input:focus{border-color:var(--primary)}
.np-scanstatus{font-size:12.5px;margin-top:8px;line-height:1.4}
.np-scanstatus.ok{color:var(--ok)}
.np-scanstatus.warn{color:var(--warn)}
/* Sélecteur de collaborateur cherchable (vue Scan) + verrou tant qu'aucun choix. */
.benef-list{margin-top:10px;max-height:240px;overflow-y:auto;border:1px solid var(--line);border-radius:var(--r-md)}
.benef-opt{display:block;width:100%;text-align:left;padding:11px 13px;border:0;border-bottom:1px solid var(--line);background:var(--bg);cursor:pointer;font-family:var(--font);font-size:14px}
.benef-opt:last-child{border-bottom:0}
.benef-opt:hover,.benef-opt:focus{background:var(--surface-1)}
.benef-chosen{display:flex;align-items:center;gap:10px}
.benef-chosen[hidden]{display:none}
.scan-prompt{transition:color .15s}
.scan-locked .scan-prompt{color:var(--accent)}
.scan-locked .scan-manual,.scan-locked #camBtn{opacity:.55}
.va-menu button{display:block;width:100%;text-align:left;padding:9px 12px;border:0;background:transparent;border-radius:var(--r-sm);font-family:var(--font);font-size:14px;font-weight:600;color:var(--text);cursor:pointer}
.va-menu button:hover{background:var(--surface-1)}
/* Bannière "voir comme" (compte maintenance qui simule une vue magasinier/patron). */
.viewas-banner{display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--accent);color:#fff;font-family:var(--font);font-weight:700;font-size:11px;letter-spacing:.03em;text-transform:uppercase;padding:9px 12px}
.viewas-banner button{background:rgba(255,255,255,0.22);color:#fff;border:0;border-radius:var(--r-sm);padding:5px 10px;font-family:var(--font);font-weight:700;font-size:11px;letter-spacing:.03em;text-transform:uppercase;cursor:pointer}
.viewas-banner button:hover{background:rgba(255,255,255,0.34)}
.nav a.active .nav-badge{background:var(--accent);color:#fff}

/* ── Stats / graphs SVG ────────────────────────────────────────────────── */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-4);margin-bottom:var(--s-6)}
.stat-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--shadow-sm)}
.stat-card .l{font-size:11px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:var(--text-faint)}
.stat-card .v{font-size:28px;font-weight:800;letter-spacing:-0.02em;margin-top:4px}
.stat-card .s{font-size:12px;color:var(--text-muted);margin-top:2px}
.spark{width:100%;height:34px;margin-top:8px}
.spark path{fill:none;stroke:var(--primary);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.spark .area{fill:rgba(0,41,86,0.08);stroke:none}

.bar-chart{display:flex;align-items:flex-end;gap:6px;height:160px;padding:12px 14px;background:var(--surface-1);border-radius:var(--r-md);border:1px solid var(--line)}
.bar-chart .bar{flex:1;background:var(--primary);border-radius:3px 3px 0 0;min-height:2px;position:relative;transition:opacity .12s}
.bar-chart .bar:hover{opacity:0.78}
.bar-chart .bar.warn{background:var(--warn)}
.bar-chart .bar.crit{background:var(--accent)}
.bar-chart-axis{display:flex;justify-content:space-between;font-size:10px;color:var(--text-faint);padding:6px 14px 0}

/* ── Print stylesheet (refacturation imprimable) ───────────────────────── */
@media print {
  body{background:#fff !important}
  .sidebar,.topbar,.credit,.toast,.demo-banner,.search.global,.hamburger,.btn,.actions,.chips,.section-head .spacer + *{display:none !important}
  .app{display:block !important;grid-template-columns:none !important}
  .main{display:block !important}
  .content{padding:0 !important;display:block !important}
  .card{box-shadow:none !important;border:1px solid #ddd !important;break-inside:avoid;page-break-inside:avoid}
  .modal-card,.backdrop{display:none !important}
  a{color:#000 !important;text-decoration:none !important}
  .table{font-size:11px}
  .table th{background:#f0f0f0 !important;color:#000 !important}
  .tag{border:1px solid #ccc;color:#000 !important;background:transparent !important}
}

/* ── Responsive ────────────────────────────────────────────────────────── */
@media (max-width: 900px){
  .app{grid-template-columns:1fr}
  .sidebar{display:flex;position:fixed;top:0;left:0;width:268px;z-index:100;transform:translateX(-100%);transition:transform .2s cubic-bezier(.2,.7,.3,1)}
  .sidebar.open{transform:translateX(0);box-shadow:8px 0 30px rgba(0,0,0,0.25)}
  .hamburger{display:inline-flex}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .stat-row{grid-template-columns:repeat(2,1fr)}
  .two-col{grid-template-columns:1fr}
  .content{padding:var(--s-4)}
  .topbar{padding:var(--s-4);gap:var(--s-3)}
  .topbar .search{min-width:0;flex:1 1 100%;order:5}
  .topbar .search input{font-size:14px}
  .modal-card{padding:18px 20px}
  /* Tables larges (Catalogue, Mouvements, Comptes) : scroll horizontal au doigt
     plutôt que colonnes écrasées ou contenu coupé par overflow:hidden. */
  .card{overflow-x:auto}
  .table{min-width:560px}
  /* Tiroir mobile : voile derrière le menu + blocage du défilement de fond. */
  body.nav-open{overflow:hidden}
  body.nav-open::before{content:"";position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:99;animation:bd-in .15s forwards}
}
@media (max-width: 600px){
  .kpi-grid{grid-template-columns:1fr 1fr}
  .stat-row{grid-template-columns:1fr 1fr}
  /* Cartes KPI plus compactes sur mobile : on récupère de la largeur pour les
     montants. Compteurs (chiffres courts) à 28px, montants (ex. "29 163,90 €")
     en taille fluide pour tenir sur une ligne sans déborder, même un montant
     long, à partir des plus petits écrans. */
  .kpi{padding:14px}
  .kpi .k-value{font-size:28px}
  .kpi .k-value.k-eur{font-size:clamp(17px,5.2vw,28px);white-space:nowrap}
  .stat-card{padding:16px}
  .stat-card .v.k-eur{font-size:clamp(17px,5vw,26px);white-space:nowrap}
}

/* ── Tables en cartes empilées sur petit écran (terminal EA502 ~360px, mobiles) ──
   S'applique à TOUTES les .table : sur écran <=600px chaque ligne devient une carte
   lisible (en-tête masqué, chaque cellule en "libellé : valeur"). Les libellés sont
   repris de l'en-tête automatiquement (voir labelTableCards dans app.js, qui pose les
   data-label). On ne scrolle plus jamais horizontalement sur le terminal. */
@media (max-width:600px){
  /* Annule le min-width 560px hérité du bloc 900px. */
  .card .table, .table{min-width:0}
  .cat-card{overflow:hidden}
  .table thead{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
  .table, .table tbody, .table tr, .table td{display:block;width:100%}
  .table tr{
    width:auto;                /* width:auto + marge : remplit sans déborder (sinon 100%+marge dépasse) */
    border:1px solid var(--line);border-radius:var(--r-md);
    margin:10px;padding:12px 14px;background:var(--bg);
  }
  .table tbody tr:hover{background:var(--bg)}
  .table td{
    border:none;padding:6px 0;display:flex;align-items:flex-start;gap:14px;
    justify-content:space-between;text-align:right;min-height:0;font-size:14px;
    overflow-wrap:anywhere;word-break:break-word;   /* emails/SKU longs sans espace ne débordent pas */
  }
  .table td > *{min-width:0}
  /* Cellule produit de l'historique collaborateur : prend la largeur, nom à gauche. */
  .table td .histo-prod{flex:1;text-align:left;align-items:flex-start}
  .table td::before{
    content:attr(data-label);text-align:left;flex:0 0 auto;max-width:45%;
    font-size:11px;letter-spacing:.06em;text-transform:uppercase;
    color:var(--text-faint);font-weight:700;padding-top:1px;
  }
  /* Cellule sans libellé connu : pas de pseudo vide qui occupe de la place. */
  .table td:not([data-label])::before{content:none}
  /* 1re cellule désignée comme titre de carte (ex. nom produit), pleine largeur. */
  .table td.tcard-title{
    display:block;text-align:left;font-size:16px;font-weight:700;line-height:1.3;
    padding:0 0 8px;margin-bottom:6px;border-bottom:1px solid var(--line);
  }
  .table td.tcard-title::before{content:none}
  /* Cellule actions = boutons à droite, séparés, cibles tactiles confortables. */
  .table td.tcard-actions{justify-content:flex-end;gap:10px;padding-top:10px;margin-top:6px;border-top:1px solid var(--line);flex-wrap:wrap}
  .table td.tcard-actions::before{content:none}
  .table td.tcard-actions .btn{padding:9px 16px !important;font-size:13px !important;margin:0 !important}
  /* Cellule vide / squelette (colspan) : pas de libellé ni de flex. */
  .table td[colspan]{display:block;text-align:left}
  .table td[colspan]::before{content:none}
  /* Cellule masquée en mode carte (ex. « voir → » : la carte entière est déjà cliquable). */
  .table td.tcard-hide{display:none}
}

/* ── Aide / Centre d'aide ──────────────────────────────────────────────── */
.aide-hero { padding: 24px; }
.aide-hero-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 24px; align-items: center; }
.aide-hero-video { aspect-ratio: 16/9; border-radius: var(--r-md); overflow: hidden; background: var(--surface-2); }
.aide-video { width: 100%; height: 100%; border: 0; display: block; }
.aide-video-placeholder { display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; height: 100%; padding: 18px; }
.aide-video-icon { width: 56px; height: 56px; border-radius: 50%; background: rgba(0,41,86,0.08); display: grid; place-items: center; font-size: 22px; color: var(--primary); }
@media (max-width: 900px) { .aide-hero-grid { grid-template-columns: 1fr; } }

.aide-list { display: grid; gap: 8px; }
.aide-section { background: var(--surface-1); border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden; transition: border-color .15s, box-shadow .15s; }
.aide-section[open] { border-color: var(--primary); box-shadow: 0 2px 12px rgba(0,41,86,0.06); }
.aide-summary { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 12px; padding: 14px 18px; cursor: pointer; list-style: none; font-weight: 600; }
.aide-summary::-webkit-details-marker { display: none; }
.aide-summary:hover { background: var(--surface-2); }
.aide-summary-ico { width: 28px; height: 28px; border-radius: 7px; background: rgba(0,41,86,0.08); color: var(--primary); display: grid; place-items: center; }
.aide-summary-ico svg { width: 16px; height: 16px; }
.aide-summary-txt { font-size: 15px; line-height: 1.3; }
.aide-summary-arrow { font-size: 22px; color: var(--muted); font-weight: 400; transition: transform .15s; line-height: 1; }
.aide-section[open] .aide-summary-arrow { transform: rotate(90deg); }
.aide-content { padding: 0 18px 18px 58px; font-size: 14.5px; line-height: 1.55; }
.aide-why { background: var(--surface-2); border-left: 3px solid var(--primary); padding: 10px 14px; border-radius: 0 var(--r-sm) var(--r-sm) 0; margin-bottom: 14px; font-size: 13.5px; color: var(--text); font-style: italic; }
.aide-steps { padding-left: 22px; margin: 0; }
.aide-steps li { padding: 4px 0; color: var(--text); }
.aide-steps li::marker { color: var(--primary); font-weight: 700; }


/* ── Démos animées dans l'Aide ─────────────────────────────────────────── */
.aide-has-demo { display: inline-block; font-size: 10.5px; font-weight: 700; color: var(--primary); padding: 2px 8px; background: rgba(0,41,86,0.10); border-radius: 99px; margin-left: 8px; vertical-align: middle; letter-spacing: 0.5px; }
.aide-demo { margin: 18px 0; padding: 18px; background: #F4F6FA; border: 1px solid var(--border); border-radius: var(--r-md); }
.aide-demo-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
.aide-demo-badge { font-size: 11px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--primary); padding: 4px 10px; background: var(--surface-1); border: 1px solid var(--border); border-radius: 99px; }
.aide-demo-duree { font-size: 12px; color: var(--muted); font-style: italic; }
.aide-demo-stage { display: flex; align-items: center; justify-content: center; margin-bottom: 14px; padding: 18px; background: var(--surface-1); border-radius: var(--r-md); position: relative; min-height: 320px; }
.aide-demo-narration { background: var(--surface-1); border-left: 3px solid var(--primary); border-radius: 0 var(--r-sm) var(--r-sm) 0; padding: 12px 16px; min-height: 52px; position: relative; }
.aide-demo-narration .narr-step { position: absolute; left: 16px; right: 16px; top: 12px; opacity: 0; font-size: 14px; line-height: 1.55; }
.aide-demo-narration .narr-step b { color: var(--primary); margin-right: 6px; }

/* ── Phone frame ───────────────────────────────────────────────────────── */
.aide-phone-frame { width: 280px; height: 540px; background: #1A1A1A; border-radius: 32px; padding: 12px; position: relative; box-shadow: 0 8px 24px rgba(0,0,0,0.15); }
.aide-phone-frame::before { content: ""; position: absolute; top: 8px; left: 50%; transform: translateX(-50%); width: 100px; height: 22px; background: #1A1A1A; border-radius: 0 0 16px 16px; z-index: 2; }
.aide-phone-frame .dm-stage-frame { position: absolute; inset: 12px; border-radius: 22px; overflow: hidden; opacity: 0; }
.aide-phone-frame .dm-screen { width: 100%; height: 100%; background: #fff; display: flex; flex-direction: column; padding-top: 28px; }

/* ── Desktop frame ─────────────────────────────────────────────────────── */
.aide-desktop-frame { width: 100%; max-width: 560px; min-height: 360px; background: var(--surface-1); border-radius: var(--r-md); overflow: hidden; box-shadow: 0 8px 24px rgba(0,0,0,0.10); border: 1px solid var(--border); position: relative; }
.aide-desktop-bar { display: flex; align-items: center; gap: 6px; padding: 10px 14px; background: var(--surface-2); border-bottom: 1px solid var(--border); font-size: 11.5px; color: var(--muted); }
.aide-desktop-bar span { width: 10px; height: 10px; border-radius: 50%; background: #DDD; }
.aide-desktop-bar span:nth-child(1) { background: #FF5F57; }
.aide-desktop-bar span:nth-child(2) { background: #FEBC2E; }
.aide-desktop-bar span:nth-child(3) { background: #28C840; }
.aide-desktop-bar b { margin-left: auto; font-size: 11px; font-weight: 600; color: var(--text); }
.aide-desktop-frame .dm-stage-frame { position: absolute; left: 0; right: 0; top: 36px; bottom: 0; opacity: 0; padding: 16px; overflow: hidden; }

/* ── Écran mobile détail ───────────────────────────────────────────────── */
.dm-topbar { background: var(--primary); color: #fff; padding: 12px 16px; display: flex; align-items: center; justify-content: space-between; font-size: 13px; }
.dm-topbar b { font-size: 13.5px; }
.dm-topbar span { font-size: 10.5px; opacity: 0.85; letter-spacing: 0.5px; }
.dm-camera { flex: 1; background: #0A1430; position: relative; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; padding: 18px; }
.dm-viseur { width: 200px; height: 130px; border: 2.5px solid var(--accent); border-radius: 8px; position: relative; box-shadow: 0 0 40px rgba(227,6,19,0.3); }
.dm-viseur::before { content: ""; position: absolute; left: 10%; right: 10%; top: 0; height: 2px; background: var(--accent); animation: dm-scanline 1.5s ease-in-out infinite; }
.dm-flash { animation: dm-flash 0.6s ease-out; box-shadow: 0 0 80px rgba(227,6,19,0.8); }
@keyframes dm-scanline { 0%, 100% { top: 8%; } 50% { top: 80%; } }
@keyframes dm-flash { 0% { box-shadow: 0 0 0 rgba(227,6,19,1); } 100% { box-shadow: 0 0 80px rgba(227,6,19,0); } }
.dm-instructions { color: #fff; font-size: 13px; font-weight: 600; }
.dm-success { color: #4FE07A; }
.dm-barcode { display: flex; gap: 3px; height: 28px; }
.dm-barcode span { width: 4px; background: #fff; }
.dm-barcode span:nth-child(2) { width: 2px; }
.dm-barcode span:nth-child(4) { width: 6px; }
.dm-barcode span:nth-child(5) { width: 2px; }
.dm-barcode span:nth-child(7) { width: 3px; }
.dm-bottom-cta { padding: 14px; text-align: center; font-size: 13px; font-weight: 600; color: var(--muted); border-top: 1px solid var(--border); cursor: pointer; }
.dm-cta-pri { background: var(--primary); color: #fff; border: 0; }
.dm-cta-ghost { background: var(--surface-1); }
.dm-product { padding: 18px; text-align: center; flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; }
.dm-product-img { width: 64px; height: 64px; background: var(--surface-2); border-radius: 12px; display: grid; place-items: center; font-size: 32px; }
.dm-product-name { font-weight: 700; font-size: 16px; color: var(--text); }
.dm-product-meta { font-size: 12px; color: var(--muted); }
.dm-product-stock { margin-top: 8px; font-size: 14px; }
.dm-product-stock b { color: var(--primary); font-size: 24px; }
.dm-qty { padding: 14px 18px; display: flex; align-items: center; justify-content: space-between; border-top: 1px solid var(--border); }
.dm-qty-lbl { font-size: 13px; color: var(--muted); }
.dm-qty-input { display: flex; align-items: center; gap: 14px; background: var(--surface-2); padding: 6px 14px; border-radius: 99px; font-weight: 700; }
.dm-qty-input span { width: 24px; height: 24px; background: var(--primary); color: #fff; border-radius: 50%; display: grid; place-items: center; font-weight: 700; }
.dm-qty-input b { font-size: 18px; min-width: 24px; text-align: center; }
.dm-success-card { padding: 24px 18px; text-align: center; flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; background: linear-gradient(180deg, #F0FBF4, #fff); }
.dm-success-card-wide { background: linear-gradient(180deg, rgba(79,224,122,0.10), transparent); }
.dm-check { width: 56px; height: 56px; background: #00D68A; color: #fff; border-radius: 50%; display: grid; place-items: center; font-size: 30px; font-weight: 700; box-shadow: 0 4px 16px rgba(0,214,138,0.3); }
.dm-success-title { font-weight: 700; font-size: 16px; color: var(--text); }
.dm-success-meta { font-size: 12.5px; color: var(--muted); }
.dm-list { flex: 1; overflow: hidden; padding: 6px; }
.dm-row { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; border-bottom: 1px solid var(--border); font-size: 12.5px; }
.dm-row b { font-weight: 600; color: var(--text); display: block; }
.dm-row small { color: var(--muted); font-size: 10.5px; }
.dm-row-qty { font-weight: 700; color: var(--primary); font-size: 15px; }
.dm-row-active { background: var(--surface-2); border-left: 3px solid var(--primary); }
.dm-row-retour b { color: #00D68A; }
.dm-row-qty-ret { color: #00D68A; }
.dm-search-box { margin: 14px; padding: 10px 14px; background: var(--surface-2); border-radius: 8px; font-size: 13px; color: var(--muted); }
.dm-inv-row { display: flex; justify-content: space-between; padding: 12px 18px; font-size: 13px; border-bottom: 1px solid var(--border); }
.dm-inv-row b { font-size: 18px; color: var(--text); }
.dm-inv-input { background: var(--surface-2); }
.dm-inv-ecart { background: rgba(227,6,19,0.05); }
.dm-bad { color: var(--accent); }
.dm-motif { padding: 12px 18px; font-size: 12.5px; color: var(--muted); }
.dm-pill { display: inline-block; padding: 3px 10px; background: rgba(227,6,19,0.10); color: var(--accent); border-radius: 99px; font-size: 11px; font-weight: 600; }

/* ── Écran desktop détail ──────────────────────────────────────────────── */
.dm-d-topbar { display: flex; justify-content: space-between; align-items: center; padding-bottom: 12px; border-bottom: 1px solid var(--border); margin-bottom: 14px; }
.dm-d-topbar b { font-size: 15px; color: var(--text); }
.dm-d-topbar span { font-size: 12px; color: var(--muted); }
.dm-d-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 12px; }
.dm-d-field { display: flex; flex-direction: column; gap: 4px; }
.dm-d-field label { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--muted); }
.dm-d-select, .dm-d-input { padding: 8px 12px; background: var(--surface-2); border: 1px solid var(--border); border-radius: 6px; font-size: 13px; color: var(--text); }
.dm-d-select-active { background: rgba(0,41,86,0.06); border-color: var(--primary); color: var(--primary); font-weight: 600; }
.dm-d-toggle { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--text); margin-bottom: 14px; padding: 10px 12px; background: var(--surface-2); border-radius: 6px; }
.dm-d-cta { display: inline-block; padding: 10px 22px; background: var(--primary); color: #fff; border-radius: 6px; font-weight: 700; font-size: 14px; cursor: pointer; }
.dm-d-loading { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; padding: 40px 0; }
.dm-spinner { width: 32px; height: 32px; border: 3px solid var(--border); border-top-color: var(--primary); border-radius: 50%; animation: dm-spin 0.8s linear infinite; }
@keyframes dm-spin { to { transform: rotate(360deg); } }
.dm-d-small { font-size: 12px; color: var(--muted); }
.dm-d-result { display: flex; flex-direction: column; gap: 8px; margin-bottom: 14px; }
.dm-d-file { display: flex; align-items: center; gap: 12px; padding: 12px; background: var(--surface-2); border-radius: 6px; }
.dm-d-ext { font-size: 10.5px; font-weight: 800; padding: 4px 8px; background: var(--ok); color: #fff; border-radius: 4px; letter-spacing: 0.5px; }
.dm-d-ext-pdf { background: var(--accent); }
.dm-d-file b { font-size: 13.5px; color: var(--text); display: block; }
.dm-d-file small { font-size: 11.5px; color: var(--muted); }
.dm-d-file > div { flex: 1; }
.dm-d-dl { font-size: 18px; color: var(--primary); font-weight: 700; }
.dm-d-actions { display: flex; gap: 8px; }
.dm-d-btn { padding: 9px 18px; border-radius: 6px; font-weight: 600; font-size: 13px; cursor: pointer; }
.dm-d-btn-ghost { background: var(--surface-2); color: var(--text); }
.dm-d-btn-pri { background: var(--primary); color: #fff; }
.dm-d-list { display: flex; flex-direction: column; gap: 4px; }
.dm-d-prod { display: flex; align-items: center; gap: 12px; padding: 10px 12px; background: var(--surface-2); border-radius: 6px; font-size: 12.5px; }
.dm-d-img { font-size: 18px; }
.dm-d-prod b { font-weight: 600; color: var(--text); display: block; }
.dm-d-prod small { color: var(--muted); font-size: 11px; }
.dm-d-prod > div { flex: 1; }
.dm-d-stock { font-weight: 700; color: var(--primary); }
.dm-d-stock-low { color: var(--accent); }
.dm-d-form { display: flex; flex-direction: column; gap: 10px; margin-bottom: 14px; }
.dm-d-upload-zone { padding: 22px; border: 2px dashed var(--border); border-radius: 8px; text-align: center; font-size: 13px; color: var(--text); margin-bottom: 14px; }
.dm-d-upload-zone small { display: block; color: var(--muted); margin-top: 4px; font-size: 11.5px; }
.dm-d-import-result { display: flex; flex-direction: column; gap: 6px; padding: 12px; background: var(--surface-2); border-radius: 6px; font-size: 13px; margin-bottom: 14px; }

@media (max-width: 720px) {
  .aide-phone-frame { transform: scale(0.85); }
  .aide-demo-stage { padding: 12px; min-height: 280px; }
}

/* ── Bandeaux PWA (install + update) ───────────────────────────────────── */
.ts-pwa-banner { position: fixed; left: 16px; right: 16px; bottom: 16px; max-width: 480px; margin: 0 auto; background: var(--primary, #002956); color: #fff; padding: 12px 16px; border-radius: 12px; display: grid; grid-template-columns: auto 1fr auto auto; gap: 12px; align-items: center; box-shadow: 0 12px 32px rgba(0,0,0,0.20); z-index: 9999; animation: ts-pwa-slide 0.3s ease-out; }
@keyframes ts-pwa-slide { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.ts-pwa-banner[hidden] { display: none !important; }
.ts-pwa-banner-icon { width: 36px; height: 36px; background: rgba(255,255,255,0.15); border-radius: 50%; display: grid; place-items: center; font-size: 18px; flex-shrink: 0; }
.ts-pwa-banner-text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.ts-pwa-banner-text b { font: 700 13px/1.2 var(--font-b, sans-serif); }
.ts-pwa-banner-text small { font: 400 11.5px/1.3 var(--font-b, sans-serif); opacity: 0.75; }
.ts-pwa-banner-btn { background: var(--accent, #E30613); color: #fff; border: 0; padding: 8px 14px; border-radius: 6px; font: 700 12px/1 var(--font-b, sans-serif); letter-spacing: 0.04em; cursor: pointer; text-transform: uppercase; flex-shrink: 0; }
.ts-pwa-banner-btn:hover { background: var(--accent-700); }
.ts-pwa-banner-close { background: transparent; color: rgba(255,255,255,0.55); border: 0; font-size: 20px; line-height: 1; cursor: pointer; padding: 4px 8px; flex-shrink: 0; }
.ts-pwa-banner-close:hover { color: #fff; }
.ts-pwa-banner-update { background: var(--accent, #E30613); }
.ts-pwa-banner-update .ts-pwa-banner-btn { background: #fff; color: var(--accent, #E30613); }
.ts-pwa-banner-update .ts-pwa-banner-btn:hover { background: #F4F4F4; }
@media (display-mode: standalone) { #ts-install-banner { display: none !important; } }

/* ── Guide install manuel (modal) ──────────────────────────────────────── */
.ts-guide-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.55); z-index: 10000; animation: ts-guide-fade 0.2s ease-out; }
.ts-guide { position: fixed; left: 50%; top: 50%; transform: translate(-50%, -50%); background: #fff; color: #1A1A1A; padding: 32px 28px 24px; border-radius: 16px; max-width: 420px; width: calc(100vw - 32px); z-index: 10001; box-shadow: 0 24px 64px rgba(0,0,0,0.25); animation: ts-guide-pop 0.25s ease-out; }
@keyframes ts-guide-fade { from { opacity: 0; } to { opacity: 1; } }
@keyframes ts-guide-pop { from { opacity: 0; transform: translate(-50%, -45%) scale(0.95); } to { opacity: 1; transform: translate(-50%, -50%) scale(1); } }
.ts-guide-close { position: absolute; top: 12px; right: 14px; background: transparent; border: 0; font-size: 28px; line-height: 1; color: #999; cursor: pointer; padding: 4px 10px; }
.ts-guide-close:hover { color: #1A1A1A; }
.ts-guide-icon { width: 56px; height: 56px; background: #002956; color: #fff; border-radius: 14px; display: grid; place-items: center; font-size: 28px; margin: 0 auto 16px; }
.ts-guide h2 { font: 700 22px/1.2 var(--font); text-align: center; margin-bottom: 18px; color: #002956; }
.ts-guide-steps { padding: 0; margin: 0 0 18px; list-style: none; counter-reset: step; }
.ts-guide-steps li { counter-increment: step; padding: 12px 14px 12px 50px; position: relative; background: #F7F7F8; border-radius: 8px; margin-bottom: 8px; font: 400 14px/1.5 var(--font); color: #1A1A1A; }
.ts-guide-steps li::before { content: counter(step); position: absolute; left: 14px; top: 12px; width: 26px; height: 26px; background: #E30613; color: #fff; border-radius: 50%; display: grid; place-items: center; font: 700 12px/1 var(--font); }
.ts-guide-foot { text-align: center; font: 400 12.5px/1.5 var(--font); color: #5A5C60; padding-top: 14px; border-top: 1px solid rgba(0,0,0,0.08); margin: 0; }

/* ── Indicateur réseau (TS_NET) ────────────────────────────────────────── */
.ts-net { display: inline-flex; align-items: center; gap: 7px; padding: 5px 11px; border-radius: 99px; font: 600 11px/1 var(--font); cursor: pointer; user-select: none; transition: background 0.15s, color 0.15s; border: 1px solid transparent; }
.ts-net-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.ts-net-online { background: rgba(27,122,74,0.10); color: var(--ok); border-color: rgba(27,122,74,0.25); }
.ts-net-online .ts-net-dot { background: var(--ok); }
.ts-net-syncing { background: rgba(217,119,6,0.12); color: #B45309; border-color: rgba(217,119,6,0.30); }
.ts-net-syncing .ts-net-dot { background: #D97706; animation: ts-net-pulse 1.2s ease-in-out infinite; }
.ts-net-offline { background: rgba(227,6,19,0.10); color: var(--accent-700); border-color: rgba(227,6,19,0.30); }
.ts-net-offline .ts-net-dot { background: #E30613; }
.ts-net-conflicts { background: rgba(245,158,11,0.14); color: #92400E; border-color: rgba(245,158,11,0.35); }
.ts-net-conflicts .ts-net-dot { background: #F59E0B; }
@keyframes ts-net-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }

/* ── viewSync : tableau des entrées outbox ─────────────────────────────── */
.sync-list { display: flex; flex-direction: column; gap: 8px; }
.sync-row { padding: 12px 14px; background: var(--surface-1, #F7F7F8); border: 1px solid var(--border, rgba(0,0,0,0.08)); border-radius: 8px; display: grid; grid-template-columns: auto 1fr auto auto; gap: 12px; align-items: center; }
.sync-row .sync-icon { width: 32px; height: 32px; border-radius: 8px; display: grid; place-items: center; font-weight: 700; font-size: 14px; }
.sync-row.pending  .sync-icon { background: rgba(217,119,6,0.18); color: #B45309; }
.sync-row.syncing  .sync-icon { background: rgba(0,41,86,0.12); color: #002956; }
.sync-row.error    .sync-icon { background: rgba(227,6,19,0.14); color: var(--accent-700); }
.sync-row.conflict .sync-icon { background: rgba(245,158,11,0.18); color: #92400E; }
.sync-row.synced   .sync-icon { background: rgba(27,122,74,0.14); color: var(--ok); }
.sync-row .sync-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.sync-row .sync-title { font: 600 13.5px/1.2 var(--font); color: var(--text, #1A1A1A); }
.sync-row .sync-meta { font: 400 11.5px/1.3 var(--font); color: var(--muted, #5A5C60); }
.sync-row .sync-err { font: 500 11.5px/1.3 var(--font); color: var(--accent-700); font-style: italic; }
.sync-row .sync-status { font: 700 10px/1 var(--font); padding: 4px 8px; border-radius: 99px; text-transform: uppercase; letter-spacing: 0.5px; }
.sync-row .sync-actions { display: flex; gap: 4px; }
.sync-row .sync-actions button { padding: 6px 10px; font: 600 11px/1 var(--font); border: 1px solid var(--border, rgba(0,0,0,0.10)); background: #fff; border-radius: 6px; cursor: pointer; color: var(--text, #1A1A1A); }
.sync-row .sync-actions button:hover { background: var(--surface-2, #ECEEF1); }
.sync-row .sync-actions button.danger { color: var(--accent-700); }

/* Bloc URL + bouton Copier dans le guide install (Firefox desktop, etc.) */
.ts-guide-url-box { margin: 14px 0 4px; }
.ts-guide-url-lbl { font: 700 10px/1 var(--font); letter-spacing: 0.5px; text-transform: uppercase; color: #5A5C60; display: block; margin-bottom: 6px; }
.ts-guide-url-row { display: flex; gap: 8px; align-items: stretch; }
.ts-guide-url-row code { flex: 1; padding: 10px 12px; background: #F7F7F8; border: 1px solid rgba(0,0,0,0.08); border-radius: 8px; font: 500 12.5px/1.2 var(--font-m); color: #1A1A1A; word-break: break-all; }
.ts-guide-copy { padding: 0 16px; background: #002956; color: #fff; border: 0; border-radius: 8px; font: 700 12px/1 var(--font); letter-spacing: 0.04em; cursor: pointer; flex-shrink: 0; transition: background 0.15s; }
.ts-guide-copy:hover { background: #001A37; }
.ts-guide-copy.copied { background: var(--ok); }

/* ── LOT 5 · Canal support : FAB + modale ────────────────────────────────── */
#ts-support-fab {
  position: fixed; right: 18px; bottom: 18px; z-index: 9000;
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--primary, #002956); color: #fff; border: 0;
  box-shadow: 0 8px 22px rgba(0,41,86,0.25);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: transform .12s, background .15s;
}
#ts-support-fab:hover { background: var(--primary-700, #001b3a); transform: scale(1.06); }
#ts-support-fab:focus-visible { outline: 3px solid #E30613; outline-offset: 2px; }
@media (max-width: 600px) {
  #ts-support-fab { right: 14px; bottom: 14px; width: 48px; height: 48px; }
  /* Réserve de l'espace en bas pour que la bulle support ne recouvre pas la
     dernière carte / le bouton « Sortir » sur le scanner. */
  .content { padding-bottom: 84px; }
}

.ts-support-modal {
  position: fixed; inset: 0; z-index: 9500;
  background: rgba(0, 12, 28, 0.55);
  display: flex; align-items: center; justify-content: center; padding: 16px;
  animation: tsFadeIn .14s ease-out;
}
@keyframes tsFadeIn { from { opacity: 0; } to { opacity: 1; } }

.ts-support-card {
  background: #fff; color: var(--text, #1A1A1A);
  border-radius: 16px; box-shadow: var(--shadow-lg, 0 18px 50px rgba(0,41,86,0.16));
  width: 100%; max-width: 560px; max-height: 92vh; overflow-y: auto;
  padding: 24px 24px 20px; position: relative;
  font-family: var(--font, 'Raleway', sans-serif);
}
.ts-support-close {
  position: absolute; top: 10px; right: 12px;
  background: transparent; border: 0; font-size: 26px; line-height: 1;
  color: var(--text-muted, #52525B); cursor: pointer; padding: 4px 10px;
  border-radius: 6px;
}
.ts-support-close:hover { background: var(--surface-2, #EFEFF1); color: var(--text, #1A1A1A); }

.ts-support-card h2 { font-size: 19px; font-weight: 800; margin-bottom: 6px; }
.ts-support-sub { font-size: 13px; color: var(--text-muted, #52525B); margin-bottom: 18px; line-height: 1.5; }

.ts-support-label { display: block; font: 700 12px/1 var(--font, 'Raleway'); text-transform: uppercase; letter-spacing: .04em; color: var(--text-muted, #52525B); margin-bottom: 6px; }
.ts-support-form textarea {
  width: 100%; padding: 12px 14px; border: 1px solid var(--line, rgba(26,26,26,0.10));
  border-radius: 10px; font: 400 14px/1.5 var(--font, 'Raleway'); color: var(--text, #1A1A1A);
  background: #fff; resize: vertical; min-height: 130px; outline: none;
}
.ts-support-form textarea:focus { border-color: var(--primary, #002956); box-shadow: 0 0 0 3px rgba(0,41,86,0.10); }

.ts-support-prio { display: flex; gap: 18px; margin: 14px 0 6px; font-size: 13.5px; }
.ts-support-prio label { display: inline-flex; gap: 6px; align-items: center; cursor: pointer; }

.ts-support-ctx { margin: 12px 0 14px; }
.ts-support-ctx summary { cursor: pointer; font-size: 12.5px; color: var(--primary, #002956); font-weight: 700; padding: 4px 0; }
.ts-support-ctx pre {
  background: var(--surface-1, #F7F7F8); border: 1px solid var(--line, rgba(26,26,26,0.10));
  border-radius: 8px; padding: 10px 12px; margin-top: 8px;
  font: 500 11.5px/1.5 var(--font-m);
  max-height: 180px; overflow: auto; white-space: pre-wrap; word-break: break-word;
  color: var(--text-muted, #52525B);
}

.ts-support-actions { display: flex; gap: 10px; margin-top: 16px; flex-wrap: wrap; }
.ts-support-send {
  flex: 1; min-width: 180px; padding: 13px 18px; background: var(--primary, #002956); color: #fff; border: 0;
  border-radius: 10px; font: 700 13px/1 var(--font, 'Raleway'); letter-spacing: .03em;
  cursor: pointer; transition: background .15s;
}
.ts-support-send:hover:not(:disabled) { background: var(--primary-700, #001b3a); }
.ts-support-send:disabled { opacity: .6; cursor: not-allowed; }
.ts-support-wa {
  padding: 13px 16px; background: #25D366; color: #fff; border-radius: 10px;
  text-decoration: none; font: 700 13px/1 var(--font, 'Raleway'); letter-spacing: .03em;
  display: inline-flex; align-items: center; gap: 6px;
}
.ts-support-wa:hover { background: #1FB855; }

.ts-support-foot { font-size: 11.5px; color: var(--text-faint, #A1A1AA); margin-top: 14px; }
.ts-support-status { margin-top: 10px; font-size: 13px; font-weight: 600; min-height: 18px; }
.ts-support-status.sending { color: var(--text-muted, #52525B); }
.ts-support-status.ok { color: var(--ok, #1E7A47); }
.ts-support-status.err { color: var(--accent, #E30613); }

/* == LOT 6 - Aide contextuelle par vue ===================================== */
.ts-aide-btn {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--surface-1, #F7F7F8); color: var(--text-muted, #52525B);
  border: 1px solid var(--line, rgba(26,26,26,0.10));
  padding: 7px 13px 7px 10px; border-radius: 8px;
  font: 700 12px/1 var(--font, 'Raleway'); letter-spacing: .04em; text-transform: uppercase;
  cursor: pointer; transition: background .14s, color .14s, border-color .14s;
}
.ts-aide-btn:hover { background: #fff; color: var(--primary, #002956); border-color: var(--primary, #002956); }
.ts-aide-btn:focus-visible { outline: 3px solid var(--primary, #002956); outline-offset: 2px; }
.ts-aide-btn svg { flex-shrink: 0; }
@media (max-width: 700px) {
  .ts-aide-btn span { display: none; }
  .ts-aide-btn { padding: 8px; }
}

.ts-aide-modal {
  position: fixed; inset: 0; z-index: 9700;
  background: rgba(0, 12, 28, 0.55);
  display: flex; align-items: center; justify-content: center; padding: 16px;
  animation: tsAideFade .14s ease-out;
}
@keyframes tsAideFade { from { opacity: 0; } to { opacity: 1; } }

.ts-aide-card {
  background: #fff; color: var(--text, #1A1A1A);
  border-radius: 16px; box-shadow: 0 22px 60px rgba(0,41,86,0.22);
  width: 100%; max-width: 920px; max-height: 92vh; overflow-y: auto;
  padding: 26px 28px 24px; position: relative;
  font-family: var(--font, 'Raleway', sans-serif);
}
.ts-aide-close {
  position: absolute; top: 12px; right: 14px;
  background: transparent; border: 0; cursor: pointer; padding: 6px;
  color: var(--text-muted, #52525B); border-radius: 6px; line-height: 0;
}
.ts-aide-close:hover { background: var(--surface-2, #EFEFF1); color: var(--text); }

.ts-aide-head { margin-bottom: 22px; padding-right: 28px; }
.ts-aide-head h2 { font-size: 22px; font-weight: 800; letter-spacing: -0.02em; margin-bottom: 6px; }
.ts-aide-sub { font-size: 13.5px; color: var(--text-muted, #52525B); line-height: 1.55; }

.ts-aide-body { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; align-items: start; }
@media (max-width: 760px) { .ts-aide-body { grid-template-columns: 1fr; gap: 22px; } }

.ts-aide-points-lbl {
  font: 700 11px/1 var(--font, 'Raleway'); letter-spacing: .08em; text-transform: uppercase;
  color: var(--text-muted, #52525B); margin-bottom: 12px;
}
.ts-aide-points ol {
  margin: 0; padding-left: 0; list-style: none; counter-reset: aidep;
}
.ts-aide-points ol li {
  counter-increment: aidep; position: relative; padding: 0 0 12px 32px;
  font-size: 13.5px; line-height: 1.55; color: var(--text, #1A1A1A);
}
.ts-aide-points ol li::before {
  content: counter(aidep); position: absolute; left: 0; top: 0;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--primary, #002956); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font: 800 11px/1 var(--font, 'Raleway');
}
.ts-aide-tuto-link {
  display: inline-block; margin-top: 6px;
  color: var(--primary, #002956); font-weight: 700; font-size: 12.5px;
  text-decoration: underline; text-underline-offset: 3px;
}
.ts-aide-tuto-link:hover { color: var(--primary-700, #001b3a); }

/* Zone démo : conteneur qui adapte le style phone vs desktop */
.ts-aide-demo {
  background: var(--surface-1, #F7F7F8); border-radius: 14px; padding: 18px;
  display: flex; flex-direction: column; align-items: center;
}
.ts-aide-stage {
  display: flex; justify-content: center; width: 100%;
  margin-bottom: 14px;
}
.ts-aide-stage.phone { max-width: 260px; margin-left: auto; margin-right: auto; }
.ts-aide-stage.desktop { width: 100%; }
.ts-aide-stage .dm-screen {
  animation: tsAideStageIn .35s ease-out;
}
@keyframes tsAideStageIn {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

.ts-aide-narr {
  font-size: 13px; color: var(--text, #1A1A1A); line-height: 1.5;
  text-align: center; max-width: 380px; margin: 0 auto;
  min-height: 36px;
}
.ts-aide-dots {
  display: flex; gap: 8px; margin-top: 14px; justify-content: center;
}
.ts-aide-dot {
  width: 26px; height: 4px; border-radius: 99px;
  background: rgba(26,26,26,0.15); cursor: pointer; transition: background .15s;
}
.ts-aide-dot:hover { background: rgba(26,26,26,0.32); }
.ts-aide-dot.active { background: var(--primary, #002956); }

/* Compléments démos pour les vues ajoutées (KPIs dashboard, etc.) */
.dm-kpis { display: grid; grid-template-columns: repeat(3,1fr); gap: 6px; padding: 10px 12px; }
.dm-kpi { background: rgba(0,41,86,0.05); border-radius: 8px; padding: 8px 10px; text-align: center; }
.dm-kpi span { display: block; font-size: 9px; color: var(--text-muted, #52525B); text-transform: uppercase; letter-spacing: 0.05em; font-weight: 700; }
.dm-kpi b { display: block; font-size: 16px; margin-top: 2px; }
.dm-kpi-alert { background: rgba(227,6,19,0.10); }
.dm-kpi-alert b { color: var(--accent, #E30613); }

.dm-list-compact .dm-row { padding: 7px 10px; }
.dm-row-badge { background: var(--surface-2, #EFEFF1); border-radius: 6px; padding: 2px 8px; font: 700 11px/1.2 var(--font, 'Raleway'); }
.dm-row-bad { background: rgba(227,6,19,0.10); color: var(--accent, #E30613); }
.dm-row-good { background: rgba(30,122,71,0.10); color: var(--ok, #1E7A47); }

.dm-d-filters { display: flex; gap: 6px; padding: 8px 12px; }
.dm-d-search { background: var(--surface-1, #F7F7F8); padding: 6px 10px; margin: 0 12px 8px; border-radius: 6px; font-size: 11px; color: var(--text-muted, #52525B); }
.dm-d-recap { display: flex; justify-content: space-between; align-items: center; padding: 10px 14px; background: rgba(0,41,86,0.05); border-radius: 8px; margin: 8px 12px; }
.dm-d-recap b { font-size: 18px; }
.dm-d-row-alert { background: rgba(227,6,19,0.05); }
.dm-d-input { background: var(--surface-1, #F7F7F8); padding: 6px 9px; border-radius: 6px; font-size: 11px; color: var(--text); }

.dm-reglages-bloc { background: var(--surface-1, #F7F7F8); padding: 10px 12px; margin: 6px 12px; border-radius: 8px; }
.dm-reglages-bloc b { font-size: 12px; }
.dm-reglages-bloc small { display: block; font-size: 10px; color: var(--text-muted, #52525B); margin-top: 2px; }

.dm-pill-pri { background: var(--primary, #002956); color: #fff; }

/* ── Splash d'ouverture : le logo code-barres se révèle pendant qu'un laser
   rouge le scanne, comme une douchette qui lit l'inventaire. Sobre, rapide,
   désactivé si l'utilisateur préfère moins d'animations. ───────────────── */
#ts-splash{position:fixed;inset:0;z-index:9999;background:var(--primary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;opacity:1;transition:opacity .45s ease}
#ts-splash.hide{opacity:0;pointer-events:none}
#ts-splash .ts-splash-logo{position:relative;width:min(62vw,260px);line-height:0}
#ts-splash .ts-splash-logo img{width:100%;display:block;clip-path:inset(0 100% 0 0);animation:ts-reveal 1s cubic-bezier(.62,.04,.2,1) .2s forwards}
#ts-splash .ts-scan{position:absolute;top:-8%;bottom:-8%;left:0;width:3px;border-radius:2px;background:var(--accent);box-shadow:0 0 0 transparent;opacity:0;animation:ts-scan 1.05s cubic-bezier(.62,.04,.2,1) .2s forwards}
#ts-splash .ts-splash-name{font-family:var(--font);font-weight:800;font-size:20px;letter-spacing:.26em;text-transform:uppercase;color:#fff;opacity:0;transform:translateY(8px);animation:ts-name .55s ease 1.05s forwards}
@keyframes ts-reveal{from{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}
@keyframes ts-scan{0%{opacity:0;left:0}10%{opacity:1}88%{opacity:1;left:100%}94%{opacity:1;left:100%}100%{opacity:0;left:100%}}
@keyframes ts-name{to{opacity:1;transform:translateY(0)}}
@media (prefers-reduced-motion: reduce){
  #ts-splash .ts-splash-logo img{clip-path:none;animation:none}
  #ts-splash .ts-scan{display:none}
  #ts-splash .ts-splash-name{animation:ts-name .3s ease forwards}
}

/* ── Mini tableur de référence dans les fenêtres d'import CSV ─────────────── */
.xls{border:1px solid var(--line-strong);border-radius:var(--r-sm);overflow:hidden;background:#fff;margin:4px 0 10px}
.xls-bar{display:flex;align-items:center;gap:10px;padding:6px 12px;background:var(--surface-2);border-bottom:1px solid var(--line);font-size:11px;color:var(--text-muted)}
.xls-file{display:flex;align-items:center;gap:6px;font-weight:700;color:var(--text)}
.xls-file svg{width:13px;height:13px}
.xls-hint{margin-left:auto;font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint)}
.xls-scroll{overflow-x:auto}
.xls table{border-collapse:collapse;font-family:var(--font-num);font-size:11px;white-space:nowrap}
.xls td{border:1px solid #E4E4E7;padding:4px 9px;color:var(--text);font-variant-numeric:tabular-nums}
.xls .xls-colh td{background:var(--surface-1);color:var(--text-faint);text-align:center;font-size:10px;font-weight:600;padding:2px 9px}
.xls .xls-gut{background:var(--surface-1);color:var(--text-faint);text-align:center;font-size:10px;width:22px;padding:2px 0}
.xls .xls-corner{background:var(--surface-2);width:22px}
.xls .xls-hrow td{background:#E9F0F7;color:var(--primary);font-weight:700;font-family:var(--font)}
.xls .xls-hl{box-shadow:inset 0 0 0 2px var(--accent);font-weight:700}
.xls-empty{color:var(--text-faint);font-style:italic}
.xls-cap{font-size:12px;color:var(--text-muted);margin:0 0 14px;line-height:1.5}
.xls-cap b{color:var(--text)}

/* ── Historique : navigation semaine + grille 7 jours ────────────────────── */
.hist-nav{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg);border-bottom:1px solid var(--line)}
.hist-nav-btn{width:40px;height:40px;flex:none;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface-1);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--primary);-webkit-tap-highlight-color:transparent}
.hist-nav-btn:active{background:var(--surface-2)}
.hist-nav-label{flex:1;text-align:center;font-size:13px;font-weight:700;color:var(--primary);white-space:nowrap}
.hist-week{display:grid;grid-template-columns:repeat(7,1fr);background:var(--bg);border-bottom:1px solid var(--line);padding:6px 4px}
.hist-day{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 2px 5px;border:2px solid transparent;border-radius:8px;background:none;cursor:pointer;font-family:var(--font);-webkit-tap-highlight-color:transparent;transition:background .12s,border-color .12s;width:100%}
.hist-day-name{font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint);line-height:1}
.hist-day-num{font-size:16px;font-weight:700;font-family:var(--font-num);line-height:1.2;color:var(--text-muted)}
.hist-day-badge{font-size:9px;font-weight:800;background:var(--accent);color:#fff;border-radius:99px;min-width:15px;height:15px;padding:0 3px;text-align:center;line-height:15px;display:block}
.hist-day-dot{width:15px;height:15px;display:block}
.hist-day.has-data .hist-day-name,.hist-day.has-data .hist-day-num{color:var(--primary)}
.hist-day.today{border-color:var(--accent)}
.hist-day.today .hist-day-num{color:var(--accent)}
.hist-day.selected{background:var(--primary);border-color:var(--primary)}
.hist-day.selected .hist-day-name,.hist-day.selected .hist-day-num{color:#fff}
.hist-day.today.selected{border-color:var(--accent)}
.hist-day.selected .hist-day-badge{background:rgba(255,255,255,.28);color:#fff}
#hist-list{padding:0 14px 80px}
