/* =====================================================================
   DSP RÉSEAU v3 — Maquette PWA (design system)
   Registre : industriel-utilitaire raffiné, lisible plein soleil.
   Couleur = sens (statuts grêle). Le reste reste neutre et contrasté.
   ===================================================================== */

:root{
  /* --- Couleurs de statut (NORMATIVES) --- */
  --dsp:#5aa53a;  --dsp-d:#47832d;  --dsp-soft:#eaf4e3;
  --dap:#e8932b;  --dap-d:#c2741a;  --dap-soft:#fcefdc;
  --trad:#d6443c; --trad-d:#b3322b; --trad-soft:#fbe3e1;
  --ras:#9a968d;  --ras-soft:#efede8;
  --blue:#2f6db0; --blue-d:#235488; --blue-soft:#e4eef8;

  /* --- Neutres (clair pro, fort contraste) --- */
  --paper:#f4f5f2;          /* fond app */
  --paper-2:#eceee8;
  --surface:#ffffff;        /* cartes */
  --surface-2:#fafbf8;
  --ink:#16190f;            /* texte principal, quasi noir chaud */
  --ink-2:#3e4237;
  --muted:#74786b;
  --faint:#9a9e90;
  --line:#dfe1d8;
  --line-2:#c9ccc0;

  /* --- Élévation --- */
  --sh-1:0 1px 2px rgba(20,25,15,.06), 0 1px 1px rgba(20,25,15,.04);
  --sh-2:0 2px 8px rgba(20,25,15,.08), 0 1px 2px rgba(20,25,15,.05);
  --sh-3:0 10px 30px rgba(20,25,15,.16), 0 2px 8px rgba(20,25,15,.10);
  --sh-up:0 -8px 30px rgba(20,25,15,.14);

  /* --- Rayons & rythme --- */
  --r-s:10px; --r-m:14px; --r-l:20px; --r-xl:28px;
  --tap:56px;               /* cible tactile primaire */

  /* --- Typo --- */
  --f-disp:"Archivo","Archivo Expanded",system-ui,sans-serif;
  --f-body:"IBM Plex Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --f-mono:"IBM Plex Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--f-body);
  color:var(--ink);
  background:
    radial-gradient(1200px 800px at 85% -10%, #e8efe2 0%, transparent 55%),
    radial-gradient(900px 700px at -10% 110%, #e6ecf4 0%, transparent 50%),
    var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overscroll-behavior:none;
}
button{font-family:inherit}
img{display:block}

/* =====================================================================
   CADRE TABLETTE — colonne portrait centrée sur desktop,
   plein écran sur tablette / téléphone.
   ===================================================================== */
.stage{
  min-height:100dvh;
  display:flex; align-items:center; justify-content:center;
  padding:clamp(0px,3vh,28px);
}
/* Préréglages de format (pilotés par le panneau démo sur desktop) :
   défaut = TABLETTE portrait (priorité du brief) ; .pf-phone = téléphone. */
body{--dev-w:760px; --dev-h:1010px}
body.pf-phone{--dev-w:430px; --dev-h:920px}

.device{
  position:relative;
  width:100%;
  max-width:var(--dev-w);
  height:min(var(--dev-h), 100dvh);
  background:var(--paper);
  border-radius:34px;
  box-shadow:var(--sh-3), 0 0 0 1px var(--line) inset;
  overflow:hidden;
  display:flex; flex-direction:column;
  isolation:isolate;
}
/* vrais téléphones : plein écran */
@media (max-width:560px){
  .stage{padding:0}
  .device{max-width:none;width:100vw;height:100dvh;border-radius:0;box-shadow:none}
}
/* vraies tablettes (portrait) : colonne large quasi plein écran, sans châssis */
@media (min-width:561px) and (max-width:1100px){
  .stage{padding:0}
  .device{max-width:760px;width:100%;height:100dvh;border-radius:0;box-shadow:none}
}
/* desktop : aperçu encadré "matériel" (taille selon le préréglage tel/tablette) */
@media (min-width:1101px){
  .device{box-shadow:var(--sh-3), 0 0 0 10px #11140d, 0 0 0 11px #2a2e22}
}

/* zone applicative (chaque écran s'y rend) */
#app{flex:1;display:flex;flex-direction:column;min-height:0;position:relative}
.screen{flex:1;display:flex;flex-direction:column;min-height:0;animation:screen-in .26s cubic-bezier(.2,.7,.2,1)}
@keyframes screen-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* =====================================================================
   BARRE DE STATUT (factice, ambiance)
   ===================================================================== */
.statusbar{
  height:30px;flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;
  padding:0 18px;font:600 12px/1 var(--f-body);color:var(--ink-2);
  letter-spacing:.02em;background:transparent;
}
.statusbar .right{display:flex;gap:7px;align-items:center}
.statusbar .batt{width:22px;height:11px;border:1.5px solid var(--ink-2);border-radius:3px;position:relative}
.statusbar .batt::after{content:"";position:absolute;right:-3px;top:3px;width:2px;height:5px;background:var(--ink-2);border-radius:0 2px 2px 0}
.statusbar .batt::before{content:"";position:absolute;inset:1.5px;right:5px;background:var(--dsp);border-radius:1px}

/* =====================================================================
   APP BAR
   ===================================================================== */
.appbar{
  flex:0 0 auto;display:flex;align-items:center;gap:10px;
  padding:8px 12px 10px;background:transparent;
}
.appbar .title{flex:1;min-width:0}
.appbar .title h1{margin:0;font:800 19px/1.15 var(--f-disp);letter-spacing:-.01em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.appbar .title .sub{font:500 12.5px/1.2 var(--f-body);color:var(--muted);margin-top:2px}
.iconbtn{
  width:44px;height:44px;flex:0 0 auto;display:grid;place-items:center;
  background:var(--surface);border:1px solid var(--line);border-radius:13px;
  font-size:19px;color:var(--ink);cursor:pointer;box-shadow:var(--sh-1);
  transition:transform .12s, background .12s, border-color .12s;
}
.iconbtn:active{transform:scale(.94)}
.iconbtn.ghost{background:transparent;box-shadow:none;border-color:transparent}
.iconbtn.accent{border-color:var(--blue);color:var(--blue)}

/* =====================================================================
   CORPS SCROLLABLE
   ===================================================================== */
.body{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding:4px 16px 20px;display:flex;flex-direction:column;gap:14px}
.body.center{align-items:center;justify-content:center;text-align:center}
.body::-webkit-scrollbar{width:8px}
.body::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px}

/* =====================================================================
   TYPO UTILITAIRES
   ===================================================================== */
.h2{font:800 16px/1.1 var(--f-disp);letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2);margin:2px 0}
.lbl{font:700 12px/1 var(--f-body);letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.tiny{font-size:12px} .small{font-size:13.5px}
.muted{color:var(--muted)} .faint{color:var(--faint)}
.mono{font-family:var(--f-mono);letter-spacing:-.02em}
.req{color:var(--trad);font-weight:700}
.grow{flex:1;min-width:0}
.row{display:flex;align-items:center;gap:10px}
.between{display:flex;align-items:center;justify-content:space-between;gap:10px}
.wrap{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.divider{height:1px;background:var(--line);margin:4px 0}
.center-t{text-align:center}

/* =====================================================================
   CARTES
   ===================================================================== */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-l);box-shadow:var(--sh-1)}
.card.pad{padding:14px}
.card.soft{background:var(--surface-2)}

/* =====================================================================
   BOUTONS
   ===================================================================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  min-height:var(--tap);padding:0 20px;width:100%;
  font:700 16px/1 var(--f-body);letter-spacing:.01em;
  border-radius:var(--r-m);border:1.5px solid transparent;cursor:pointer;
  background:var(--surface);color:var(--ink);box-shadow:var(--sh-1);
  transition:transform .12s, box-shadow .12s, background .12s, filter .12s;
}
.btn:active{transform:translateY(1px) scale(.995)}
.btn.primary{background:var(--blue);border-color:var(--blue);color:#fff;box-shadow:0 6px 16px rgba(47,109,176,.32)}
.btn.primary:active{filter:brightness(.96)}
.btn.dsp{background:var(--dsp);border-color:var(--dsp);color:#fff;box-shadow:0 6px 16px rgba(90,165,58,.32)}
.btn.dark{background:var(--ink);border-color:var(--ink);color:#fff}
.btn.ghost{background:var(--surface);border-color:var(--line-2);color:var(--ink-2)}
.btn.danger{background:var(--surface);border-color:var(--trad);color:var(--trad)}
.btn.outline-dsp{background:var(--surface);border-color:var(--dsp);color:var(--dsp-d)}
.btn.lg{min-height:66px;font-size:18px;border-radius:var(--r-l)}
.btn.sm{min-height:42px;width:auto;padding:0 14px;font-size:14px;border-radius:11px}
.btn.block{width:100%}
.row-btns{display:flex;gap:10px}
.row-btns>*{flex:1}

/* =====================================================================
   CHIPS / PILLS
   ===================================================================== */
.chip{
  display:inline-flex;align-items:center;gap:7px;
  min-height:38px;padding:0 14px;border-radius:999px;
  font:600 14px/1 var(--f-body);cursor:pointer;
  background:var(--surface);color:var(--ink-2);border:1.5px solid var(--line);
  transition:transform .12s, background .12s, border-color .12s, color .12s;
  user-select:none;
}
.chip:active{transform:scale(.96)}
.chip.on{background:var(--blue);border-color:var(--blue);color:#fff}
.chip.on.dsp{background:var(--dsp);border-color:var(--dsp)}
.chip.on.dap{background:var(--dap);border-color:var(--dap)}
.chip.on.trad{background:var(--trad);border-color:var(--trad)}
.chip.on.ras{background:var(--ras);border-color:var(--ras)}
.chip .dot{width:11px;height:11px;border-radius:50%}

/* badges statut (lecture seule, plus petits) */
.badge{display:inline-flex;align-items:center;gap:6px;height:26px;padding:0 11px;border-radius:999px;
  font:700 12px/1 var(--f-body);letter-spacing:.02em;white-space:nowrap}
.badge.dsp{background:var(--dsp-soft);color:var(--dsp-d)}
.badge.dap{background:var(--dap-soft);color:var(--dap-d)}
.badge.trad{background:var(--trad-soft);color:var(--trad-d)}
.badge.ras{background:var(--ras-soft);color:var(--ink-2)}
.badge.blue{background:var(--blue-soft);color:var(--blue-d)}

.dot{width:11px;height:11px;border-radius:50%;display:inline-block;flex:0 0 auto}
.dot.dsp{background:var(--dsp)} .dot.dap{background:var(--dap)}
.dot.trad{background:var(--trad)} .dot.ras{background:var(--ras)} .dot.blue{background:var(--blue)}

/* pills de navigation (sections devis) */
.pills{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}
.pills::-webkit-scrollbar{display:none}
.pill{
  display:inline-flex;align-items:center;gap:8px;flex:0 0 auto;
  height:42px;padding:0 16px;border-radius:999px;cursor:pointer;
  background:var(--surface);border:1.5px solid var(--line);color:var(--muted);
  font:700 13.5px/1 var(--f-body);transition:all .15s;white-space:nowrap;
}
.pill .n{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;
  background:var(--paper-2);color:var(--muted);font:800 12px/1 var(--f-disp)}
.pill.on{background:var(--ink);border-color:var(--ink);color:#fff}
.pill.on .n{background:#fff;color:var(--ink)}
.pill.done{border-color:var(--dsp);color:var(--dsp-d)}
.pill.done .n{background:var(--dsp);color:#fff}

/* segment (toggle 2 états) */
.seg{display:flex;background:var(--paper-2);border-radius:12px;padding:4px;gap:4px}
.seg>button{flex:1;border:none;background:transparent;border-radius:9px;min-height:40px;
  font:700 14px/1 var(--f-body);color:var(--muted);cursor:pointer}
.seg>button.on{background:var(--surface);color:var(--ink);box-shadow:var(--sh-1)}

/* =====================================================================
   CHAMPS
   ===================================================================== */
.field{display:flex;flex-direction:column;gap:6px}
.field .flabel{font:700 12px/1 var(--f-body);letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.input{
  display:flex;align-items:center;gap:10px;min-height:var(--tap);
  padding:0 15px;background:var(--surface);border:1.5px solid var(--line);
  border-radius:var(--r-m);font-size:16px;color:var(--ink);width:100%;
  transition:border-color .15s, box-shadow .15s;cursor:text;
}
.input.tap{cursor:pointer}
.input:focus,.input.focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}
.input input{flex:1;border:none;outline:none;background:transparent;font:inherit;color:inherit;min-width:0}
.input .ph{color:var(--faint)}
.input .chev{color:var(--faint);font-size:18px}
.input.search{background:var(--surface)}
.input .clear{margin-left:auto;color:var(--faint);font-size:16px;cursor:pointer;
  width:26px;height:26px;display:grid;place-items:center;border-radius:50%}
.input .clear:active{background:var(--paper-2)}

/* =====================================================================
   STAT COUNTERS (dashboard)
   ===================================================================== */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.stat{
  position:relative;overflow:hidden;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r-l);padding:14px 12px 12px;
  box-shadow:var(--sh-1);
}
.stat::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;border-radius:5px 0 0 5px}
.stat.b::before{background:var(--blue)} .stat.g::before{background:var(--dsp)} .stat.o::before{background:var(--dap)}
.stat .num{font:800 34px/1 var(--f-disp);letter-spacing:-.02em}
.stat.b .num{color:var(--blue-d)} .stat.g .num{color:var(--dsp-d)} .stat.o .num{color:var(--dap-d)}
.stat .cap{font:600 12px/1.1 var(--f-body);color:var(--muted);margin-top:5px}

/* =====================================================================
   LISTES (devis, ref…)
   ===================================================================== */
.list{display:flex;flex-direction:column;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r-l);box-shadow:var(--sh-1);overflow:hidden}
.li{display:flex;align-items:center;gap:12px;padding:14px 14px;cursor:pointer;
  border-top:1px solid var(--line);transition:background .12s}
.li:first-child{border-top:none}
.li:active{background:var(--paper-2)}
.li .name{font:700 15.5px/1.2 var(--f-body)}
.li .meta{font-size:12.5px;color:var(--muted);margin-top:2px}
.li .chev{color:var(--faint);font-size:20px;flex:0 0 auto}
.li .chev.go{color:var(--dsp-d)}

/* =====================================================================
   HELLO / DASHBOARD HEADER
   ===================================================================== */
.hello{display:flex;align-items:center;gap:12px;padding:8px 16px 6px}
.avatar{width:48px;height:48px;border-radius:15px;display:grid;place-items:center;
  background:linear-gradient(145deg,var(--blue),var(--blue-d));color:#fff;
  font:800 20px/1 var(--f-disp);box-shadow:var(--sh-2)}
.hello h1{margin:0;font:800 21px/1.05 var(--f-disp);letter-spacing:-.01em}
.hello .org{font-size:13px;color:var(--muted);margin-top:2px}
.syncchip{display:inline-flex;align-items:center;gap:7px;height:30px;padding:0 11px;border-radius:999px;
  font:700 12px/1 var(--f-body);background:var(--dsp-soft);color:var(--dsp-d);cursor:pointer}
.syncchip.warn{background:var(--dap-soft);color:var(--dap-d)}
.syncchip .pulse{width:8px;height:8px;border-radius:50%;background:var(--dsp);position:relative}
.syncchip.warn .pulse{background:var(--dap)}
.syncchip .pulse::after{content:"";position:absolute;inset:-4px;border-radius:50%;
  border:2px solid currentColor;opacity:.4;animation:pulse 1.8s ease-out infinite}
@keyframes pulse{0%{transform:scale(.6);opacity:.5}100%{transform:scale(1.8);opacity:0}}

/* =====================================================================
   CARTE DES DÉGÂTS
   ===================================================================== */
.mapfull{flex:1;min-height:0;position:relative;display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(120% 90% at 50% 0%, #f0f2ec 0%, #e7eae2 60%, #dde0d6 100%);
  overflow:hidden;padding:8px}
.mapfull .grid{position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:34px 34px;-webkit-mask-image:radial-gradient(100% 80% at 50% 40%,#000 30%,transparent 75%)}
.carwrap{position:relative;height:100%;max-height:100%;display:flex;align-items:center;filter:drop-shadow(0 12px 24px rgba(20,25,15,.22))}
.carwrap .car{height:100%;max-height:100%;width:auto;object-fit:contain}
.legend{position:absolute;top:10px;left:0;right:0;display:flex;gap:7px;justify-content:center;flex-wrap:wrap;z-index:3}
.legend .badge{height:30px;background:rgba(255,255,255,.92);backdrop-filter:blur(4px);box-shadow:var(--sh-1)}

/* pastilles de zone */
.zone{
  position:absolute;transform:translate(-50%,-50%);
  min-width:46px;height:46px;padding:0 6px;border-radius:999px;
  display:grid;place-items:center;cursor:pointer;
  font:800 15px/1 var(--f-disp);color:#fff;
  border:3px solid #fff;box-shadow:0 4px 10px rgba(20,25,15,.30);
  transition:transform .14s, box-shadow .14s;z-index:2;
}
.zone:active{transform:translate(-50%,-50%) scale(.9)}
.zone.dsp{background:var(--dsp)} .zone.dap{background:var(--dap)}
.zone.trad{background:var(--trad)} .zone.ras{background:var(--ras)}
.zone.empty{background:rgba(255,255,255,.85);color:var(--blue);border-color:var(--blue);
  border-style:dashed;font-weight:800;box-shadow:0 2px 8px rgba(20,25,15,.18)}
.zone.sel{box-shadow:0 0 0 4px var(--blue-soft),0 0 0 7px var(--blue),0 6px 16px rgba(20,25,15,.35);transform:translate(-50%,-50%) scale(1.12)}
.zone.lg{min-width:54px;height:54px;font-size:17px}

.fab{position:absolute;right:16px;bottom:16px;width:60px;height:60px;border-radius:20px;z-index:4;
  display:grid;place-items:center;font-size:26px;background:var(--ink);color:#fff;
  border:none;cursor:pointer;box-shadow:var(--sh-3)}
.fab:active{transform:scale(.92)}

/* =====================================================================
   BARRE DE TOTAL FIXE
   ===================================================================== */
.totalbar{
  flex:0 0 auto;display:flex;align-items:center;gap:12px;
  padding:12px 16px calc(12px + env(safe-area-inset-bottom));
  background:var(--ink);color:#fff;box-shadow:var(--sh-up);z-index:5;
}
.totalbar.onmap{background:rgba(18,20,12,.92);backdrop-filter:blur(8px)}
.totalbar .cap{font:600 11.5px/1 var(--f-body);opacity:.72;letter-spacing:.04em;text-transform:uppercase}
.totalbar .amt{font:800 24px/1.05 var(--f-disp);letter-spacing:-.01em;margin-top:3px}
.totalbar .amt small{font-size:14px;opacity:.7;font-weight:700;margin-left:3px}
.totalbar .go{flex:0 0 auto;display:inline-flex;align-items:center;gap:8px;min-height:50px;padding:0 20px;
  border-radius:14px;background:#fff;color:var(--ink);font:800 15px/1 var(--f-body);border:none;cursor:pointer}
.totalbar .go.dsp{background:var(--dsp);color:#fff}
.totalbar .go:active{transform:scale(.97)}
.totalbar .miniphoto{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 11px;border-radius:999px;
  border:1.5px solid rgba(255,255,255,.4);font:700 12px/1 var(--f-body);background:transparent;color:#fff}

/* =====================================================================
   STEPPERS (bottom-sheet)
   ===================================================================== */
.stepline{display:flex;align-items:center;gap:12px;padding:8px 0}
.stepline .tag{flex:1;font:600 15px/1 var(--f-body)}
.stepper{display:flex;align-items:center;gap:0;background:var(--paper-2);border-radius:14px;padding:4px}
.stepper .pm{width:48px;height:48px;border-radius:11px;border:none;background:var(--surface);
  font:700 24px/1 var(--f-disp);color:var(--ink);cursor:pointer;box-shadow:var(--sh-1);display:grid;place-items:center}
.stepper .pm:active{transform:scale(.9)}
.stepper .pm:disabled{opacity:.4;cursor:default}
.stepper .val{min-width:50px;text-align:center;font:800 20px/1 var(--f-disp);font-variant-numeric:tabular-nums}

/* =====================================================================
   TOGGLE
   ===================================================================== */
.toggle{width:52px;height:32px;border-radius:999px;background:var(--line-2);position:relative;
  cursor:pointer;flex:0 0 auto;transition:background .18s;border:none;padding:0}
.toggle::after{content:"";position:absolute;top:3px;left:3px;width:26px;height:26px;border-radius:50%;
  background:#fff;box-shadow:var(--sh-1);transition:transform .18s}
.toggle.on{background:var(--dsp)}
.toggle.on::after{transform:translateX(20px)}

/* =====================================================================
   PHOTOS
   ===================================================================== */
.thumbs{display:flex;flex-wrap:wrap;gap:9px}
.thumb{width:72px;height:72px;border-radius:14px;position:relative;overflow:hidden;flex:0 0 auto;
  background:linear-gradient(135deg,#cfd3c8,#b9bdb1);display:grid;place-items:center;color:#fff;font-size:24px;
  box-shadow:var(--sh-1)}
.thumb.add{background:var(--surface);border:1.5px dashed var(--line-2);color:var(--blue);font-size:28px;cursor:pointer}
.thumb .del{position:absolute;top:3px;right:3px;width:22px;height:22px;border-radius:50%;
  background:rgba(20,25,15,.7);color:#fff;display:grid;place-items:center;font-size:12px;cursor:pointer}

/* =====================================================================
   RECAP
   ===================================================================== */
.recap{display:flex;flex-direction:column}
.recap .rline{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:9px 0;
  border-top:1px dashed var(--line);font-size:15.5px}
.recap .rline:first-child{border-top:none}
.recap .rline .v{font-family:var(--f-mono);font-weight:600;font-variant-numeric:tabular-nums}
.recap .rline.big{border-top:2px solid var(--line-2);margin-top:4px;padding-top:12px}
.recap .rline.big .l{font:800 16px/1 var(--f-disp);text-transform:uppercase;letter-spacing:.03em}
.recap .rline.big .v{font:800 22px/1 var(--f-disp);color:var(--ink)}
.recap .rline .l .tag{font-size:11px;color:var(--muted);margin-left:6px}

/* =====================================================================
   SIGNATURES
   ===================================================================== */
.sigrow{display:flex;gap:10px}
.sigcol{flex:1;display:flex;flex-direction:column;gap:5px}
.sigcol .cap{font:700 11px/1 var(--f-body);text-transform:uppercase;letter-spacing:.05em;color:var(--muted);text-align:center}
.sigbox{height:80px;border-radius:14px;background:var(--surface);border:1.5px solid var(--line);
  display:grid;place-items:center;cursor:pointer;position:relative;overflow:hidden}
.sigbox.empty{border-style:dashed;color:var(--faint);font-size:13px}
.sigbox.signed{border-color:var(--dsp);background:var(--dsp-soft)}
.sigbox canvas{position:absolute;inset:0;width:100%;height:100%}
.sigbox .done{position:absolute;top:5px;right:7px;color:var(--dsp-d);font-size:13px;font-weight:700}

/* =====================================================================
   BOTTOM SHEET + MODALE + SCRIM
   ===================================================================== */
.scrim{position:absolute;inset:0;z-index:50;display:flex;align-items:flex-end;justify-content:center;
  background:rgba(18,20,12,.42);backdrop-filter:blur(2px);animation:fade .2s}
.scrim.center{align-items:center;padding:22px}
@keyframes fade{from{opacity:0}to{opacity:1}}
.sheet{
  width:100%;max-height:88%;background:var(--surface);border-radius:var(--r-xl) var(--r-xl) 0 0;
  box-shadow:var(--sh-3);display:flex;flex-direction:column;overflow:hidden;
  animation:sheet-up .3s cubic-bezier(.2,.8,.2,1);
}
@keyframes sheet-up{from{transform:translateY(100%)}to{transform:none}}
.sheet .grip{width:44px;height:5px;border-radius:5px;background:var(--line-2);margin:10px auto 4px}
.sheet .shead{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:4px 18px 8px}
.sheet .shead h3{margin:0;font:800 18px/1.1 var(--f-disp)}
.sheet .scontent{overflow-y:auto;padding:4px 18px 18px;display:flex;flex-direction:column;gap:12px}
.sheet .sfoot{padding:12px 18px calc(14px + env(safe-area-inset-bottom));border-top:1px solid var(--line);background:var(--surface-2)}

/* gros boutons méthode */
.methods{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mbtn{min-height:58px;border-radius:14px;border:2px solid var(--line);background:var(--surface);
  font:800 15px/1 var(--f-body);color:var(--ink-2);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;
  transition:all .14s}
.mbtn:active{transform:scale(.97)}
.mbtn .d{width:13px;height:13px;border-radius:50%}
.mbtn.dsp .d{background:var(--dsp)} .mbtn.dap .d{background:var(--dap)}
.mbtn.trad .d{background:var(--trad)} .mbtn.ras .d{background:var(--ras)}
.mbtn.on.dsp{background:var(--dsp);border-color:var(--dsp);color:#fff} .mbtn.on.dsp .d{background:#fff}
.mbtn.on.dap{background:var(--dap);border-color:var(--dap);color:#fff} .mbtn.on.dap .d{background:#fff}
.mbtn.on.trad{background:var(--trad);border-color:var(--trad);color:#fff} .mbtn.on.trad .d{background:#fff}
.mbtn.on.ras{background:var(--ras);border-color:var(--ras);color:#fff} .mbtn.on.ras .d{background:#fff}

/* dialog (alertes) */
.dialog{width:100%;max-width:380px;background:var(--surface);border-radius:var(--r-l);padding:22px;
  box-shadow:var(--sh-3);display:flex;flex-direction:column;gap:14px;animation:pop .24s cubic-bezier(.2,.8,.2,1)}
@keyframes pop{from{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:none}}
.dialog .dh{font:800 19px/1.15 var(--f-disp);display:flex;align-items:center;gap:9px}
.dialog .dtxt{font-size:15px;color:var(--ink-2);line-height:1.45}
.dialog.warn{border-top:5px solid var(--dap)}
.dialog.danger{border-top:5px solid var(--trad)}
.dialog.ok{border-top:5px solid var(--dsp);text-align:center;align-items:center}

/* =====================================================================
   MODALE AUTOCOMPLÉTION (plein écran interne)
   ===================================================================== */
.fullmodal{position:absolute;inset:0;z-index:60;background:var(--paper);display:flex;flex-direction:column;
  animation:screen-in .22s}

/* =====================================================================
   TOAST
   ===================================================================== */
.toast{position:absolute;left:50%;bottom:90px;transform:translateX(-50%);z-index:80;
  background:var(--ink);color:#fff;padding:13px 18px;border-radius:14px;box-shadow:var(--sh-3);
  font:600 14px/1.2 var(--f-body);display:flex;align-items:center;gap:9px;max-width:88%;
  animation:toast-in .3s cubic-bezier(.2,.8,.2,1)}
.toast .ic{color:var(--dsp)}
@keyframes toast-in{from{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translateX(-50%)}}

/* =====================================================================
   SPLASH / LOGIN / UPDATE
   ===================================================================== */
.brand{display:inline-flex;flex-direction:column;align-items:center;gap:6px}
.brand .logo{width:108px;height:108px;border-radius:30px;display:grid;place-items:center;
  background:linear-gradient(150deg,var(--blue),var(--blue-d));box-shadow:var(--sh-3);position:relative;overflow:hidden}
.brand .logo::after{content:"";position:absolute;inset:0;background:
  radial-gradient(60% 50% at 30% 20%,rgba(255,255,255,.35),transparent 60%)}
.brand .logo b{font:800 40px/1 var(--f-disp);color:#fff;letter-spacing:.02em;z-index:1}
.brand .name{font:800 26px/1 var(--f-disp);letter-spacing:.01em}
.brand .name span{color:var(--blue-d)}
.brand .tag{font:600 13px/1 var(--f-body);color:var(--muted);letter-spacing:.18em;text-transform:uppercase}

.spinner{width:38px;height:38px;border-radius:50%;border:4px solid var(--line);border-top-color:var(--blue);
  animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.foot-ver{flex:0 0 auto;text-align:center;padding:10px;font:600 12px/1 var(--f-mono);color:var(--faint);letter-spacing:.04em}

.progress{height:24px;border-radius:999px;background:var(--paper-2);padding:4px;overflow:hidden}
.progress .bar{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--blue),var(--blue-d));
  transition:width .3s ease;display:flex;align-items:center;justify-content:flex-end}

/* offline banner */
.banner{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--r-m);font-size:14px}
.banner.ok{background:var(--dsp-soft);color:var(--dsp-d)}
.banner.warn{background:var(--dap-soft);color:var(--dap-d)}

/* queue list rows */
.qrow{display:flex;align-items:center;gap:10px;padding:11px 0;border-top:1px dashed var(--line)}
.qrow:first-child{border-top:none}

/* helpers */
.hide{display:none!important}
.stack{display:flex;flex-direction:column;gap:10px}
.pad16{padding:16px}
.mt0{margin-top:0}
.flex1{flex:1}

/* nav inferieure compacte (optionnelle) */
.tabbar{flex:0 0 auto;display:flex;background:var(--surface);border-top:1px solid var(--line);
  padding:6px 8px calc(6px + env(safe-area-inset-bottom))}
.tabbar button{flex:1;border:none;background:transparent;display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:6px 0;color:var(--muted);font:600 11px/1 var(--f-body);cursor:pointer}
.tabbar button .i{font-size:20px}
.tabbar button.on{color:var(--blue-d)}
