/* === Marque Ambre & Musc — fontes self-host === */
@font-face{
  font-family:'Archivo';
  src:url('/fonts/Archivo.ttf') format('truetype-variations');
  font-weight:100 900;
  font-stretch:62.5% 125%;     /* axe wdth : 125% = Expanded */
  font-display:swap;
}
@font-face{
  font-family:'Cabinet Grotesk';
  src:url('/fonts/CabinetGrotesk-800.ttf') format('truetype');
  font-weight:800;
  font-display:swap;
}

/* Institut OS · design system NOIR & BLANC (tablette, touch-first) */
:root{
  /* NB: les variables --beige* sont conservées comme noms historiques.
     DA 2026 = NOIR & BLANC : --beige=crème fond, --beige-2=blanc surface, --beige-3=crème hover. Aucune teinte beige. */
  --beige:#FAF8F5;        /* fond app = crème chaud (grands aplats clairs) */
  --beige-2:#FFFFFF;      /* cartes / surfaces = blanc pur */
  --beige-3:#F2EFEA;      /* hover slot / état pressé = crème un cran plus foncé */
  --noir:#0E0E0E;         /* texte fort, boutons pleins, fonds hero */
  --noir-soft:#2A2724;    /* corps de texte (noir chaud très léger) */
  --greige:#8E8A85;       /* légendes, mentions, dots par défaut */
  --line:#E7E3DE;         /* filets 1px (greige clair) */
  --ui:'Inter',system-ui,-apple-system,sans-serif;     /* interface, texte courant, CTA */
  --mark:'Archivo',system-ui,sans-serif;               /* wordmark — toujours rendu Expanded (voir .wm) */
  --amp:'Cabinet Grotesk','Archivo',sans-serif;        /* le « & » signature, jamais ailleurs */
  --serif:'Cormorant Garamond',Georgia,serif;
  --tap:56px; --tap-lg:68px;
  --pad:20px; --gap:14px;
  --topbar:0px; --tabbar:72px;                 /* pas de bandeau haut rendu (option A) */
  --safe-top:env(safe-area-inset-top,0px); --safe-bottom:env(safe-area-inset-bottom,0px);
  --safe-left:env(safe-area-inset-left,0px); --safe-right:env(safe-area-inset-right,0px);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%;min-height:100dvh}
body{
  background:var(--beige);color:var(--noir-soft);
  font-family:var(--ui);font-weight:300;font-size:16px;
  -webkit-font-smoothing:antialiased;
  padding-top:0;padding-bottom:calc(var(--tabbar) + var(--safe-bottom));
  padding-left:var(--safe-left);padding-right:var(--safe-right);
  overflow:hidden;
}
button{font-family:inherit}
a{color:inherit;text-decoration:none}

/* ---- Wordmark (réutilisé par le #gate) — Archivo Expanded, minuscules, « & » Cabinet Grotesk ---- */
.wm{
  font-family:var(--mark);font-weight:800;
  font-stretch:125%;
  font-variation-settings:'wght' 800,'wdth' 125;   /* force l'Expanded sur le .ttf variable */
  letter-spacing:-.02em;text-transform:lowercase;line-height:1;white-space:nowrap;
}
.wm .amp{
  font-family:var(--amp);font-weight:800;
  font-stretch:normal;font-variation-settings:normal;   /* le « & » garde sa chasse Cabinet Grotesk */
}

/* ---- Offline banner ---- */
#offline-banner{
  position:fixed;top:var(--safe-top);left:0;right:0;z-index:40;
  background:var(--noir);color:#fff;text-align:center;
  font-size:13px;letter-spacing:.04em;padding:8px calc(12px + var(--safe-right)) 8px calc(12px + var(--safe-left));
}

/* ---- Tabbar (zone pouce) ---- */
.tabbar{
  position:fixed;bottom:0;left:0;right:0;z-index:30;
  height:calc(var(--tabbar) + var(--safe-bottom));
  background:var(--noir);display:flex;
  padding-bottom:var(--safe-bottom);
  padding-left:var(--safe-left);padding-right:var(--safe-right);
}
.tabbar a{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  color:#9a958c;font-size:11px;letter-spacing:.14em;text-transform:uppercase;
}
.tabbar a .ico{font-size:20px;line-height:1}
.tabbar a[aria-current="true"]{color:#fff}
.tabbar a[hidden]{display:none}  /* l'attribut hidden doit cacher l'onglet (sinon .tabbar a{display:flex} l'emporte) : Réglages réservé manager, Verrouiller masqué hors session */

/* ---- Layout vues ---- */
#view{height:calc(100vh - var(--tabbar) - var(--safe-bottom));height:calc(100dvh - var(--tabbar) - var(--safe-bottom));overflow:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.view-head{
  display:flex;align-items:center;justify-content:space-between;gap:var(--gap);
  padding:14px var(--pad);padding-top:calc(14px + var(--safe-top));border-bottom:1px solid var(--line);background:var(--beige);
  position:sticky;top:0;z-index:10;
}
.view-head h1{font-family:var(--serif);font-style:italic;font-weight:500;font-size:24px;margin:0;color:var(--noir)}
.muted{color:var(--greige)}

/* ---- Boutons ---- */
.btn{
  min-height:var(--tap-lg);background:var(--noir);color:#fff;border:0;
  font:500 13px/1 var(--ui);letter-spacing:.16em;text-transform:uppercase;
  padding:0 26px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;
}
.btn:disabled{opacity:.35}
.btn--ghost{background:transparent;color:var(--noir);border:1px solid var(--noir)}
.btn--block{width:100%}
.btn--lg{min-height:var(--tap-lg);font-size:14px}
.iconbtn{min-width:var(--tap);min-height:var(--tap);background:transparent;border:1px solid var(--noir);color:var(--noir);font-size:22px;cursor:pointer}

/* ---- Chips catégorie ---- */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{
  min-height:var(--tap);padding:0 18px;border:1px solid var(--noir);background:transparent;color:var(--noir);
  font-size:12px;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;white-space:nowrap;
}
.chip[aria-selected="true"]{background:var(--noir);color:#fff}

/* ---- Cartes ---- */
.card{background:var(--beige-2);border:1px solid var(--line);padding:16px}
.grid{display:grid;gap:12px}

/* ---- Agenda ---- */
.agenda{display:grid;grid-template-columns:64px repeat(var(--ncols,3),minmax(120px,1fr));gap:1px;background:var(--line);min-height:100%}
/* Agenda : barre d'outils HORS scroll, SEULE la grille défile (X+Y) dans #agenda-body.
   -> entêtes collés en haut du bon conteneur (plus sous la toolbar), colonne d'heures collée à gauche, toolbar fixe en scroll-X. */
#view:has(#agenda-body){display:flex;flex-direction:column;overflow:hidden}
#view:has(#agenda-body) .view-head{position:static}
#agenda-body{flex:1;min-height:0;overflow:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.agenda .colhead{position:sticky;top:0;background:var(--noir);color:#fff;text-align:center;
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;padding:10px 4px;z-index:6}
.agenda .colhead:first-child{position:sticky;left:0;z-index:8}  /* coin haut-gauche : collant sur les 2 axes, au-dessus de tout */
.agenda .timecol,.agenda .rescol{background:var(--beige)}
.agenda .rescol{position:relative}
.tick{height:var(--rowh,90px);border-top:1px solid var(--line);font-size:11px;color:var(--greige);padding:2px 6px;text-align:right}
.appt{
  position:absolute;left:4px;right:4px;background:var(--beige-2); /* blanc */
  border:1px solid var(--noir);border-left:4px solid var(--noir);
  padding:6px 8px;overflow:hidden;cursor:pointer;z-index:2;
}
.appt .who{font-weight:500;font-size:14px;color:var(--noir);line-height:1.15}
.appt .what{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--noir-soft);line-height:1.1}
.appt .leg{font-size:11px;color:var(--greige);letter-spacing:.04em}
/* FAIT : inversion totale = clos */
.appt[data-status="done"]{background:var(--noir);color:#fff;border-color:var(--noir);border-left-color:#fff}
.appt[data-status="done"] .who,.appt[data-status="done"] .what{color:#fff}
.appt[data-status="done"] .leg{color:#c9c3b8}      /* greige clair sur noir, lisible */
/* NO-SHOW : hachures greige + bord pointillé + étiquette */
.appt[data-status="noshow"]{
  border-left:4px dashed var(--noir);
  background:repeating-linear-gradient(45deg,#fff,#fff 7px,#EDEAE6 7px,#EDEAE6 9px);
}
.appt[data-status="noshow"] .who::after{
  content:"no-show";margin-left:6px;font-family:var(--ui);font-size:9px;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;color:var(--noir);
  border:1px solid var(--noir);padding:0 4px;vertical-align:middle;
}
/* ANNULÉ : barré + estompé */
.appt[data-status="cancelled"],.appt[data-status="canceled"]{opacity:.55;background:var(--beige-3)}
.appt[data-status="cancelled"] .who,.appt[data-status="canceled"] .who{text-decoration:line-through}
/* SÉANCE DE CURE : rail double-filet noir (zéro couleur) */
.appt.cure{box-shadow:inset 6px 0 0 #fff, inset 8px 0 0 var(--noir)}
.appt[data-status="done"].cure{box-shadow:inset 6px 0 0 var(--noir), inset 8px 0 0 #fff}
.nowline{position:absolute;left:0;right:0;height:2px;background:var(--noir);z-index:4;pointer-events:none}
.agenda .timecol{position:sticky;left:0;z-index:7}  /* colonne d'heures collée à gauche en scroll-X (sert aussi de containing block pour la now-label) */
.nowlabel{position:absolute;right:2px;transform:translateY(-50%);background:var(--noir);color:#fff;font-size:10px;font-weight:600;padding:1px 5px;z-index:6;pointer-events:none;white-space:nowrap}
.gap{position:absolute;left:3px;right:3px;border:1px dashed var(--greige);background:transparent;color:var(--greige);display:flex;align-items:center;justify-content:center;font-size:12px;letter-spacing:.03em;cursor:pointer;overflow:hidden}
.gap:active{background:var(--beige-3)}
.gap--matin{border-color:var(--noir);color:var(--noir);border-style:solid}
/* Pastille praticienne = monogramme N&B (remplace .pdot coloré et .swatch coloré) */
.pdot{
  display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;border-radius:50%;border:1px solid var(--noir);
  background:#fff;color:var(--noir);
  font:600 10px/1 var(--ui);letter-spacing:0;vertical-align:middle;margin-right:5px;
  text-transform:uppercase;
}
/* variante "colhead" un peu plus grande */
.colhead .pdot{width:20px;height:20px;font-size:11px}
/* dans l'agenda inversé (entête noir), la pastille s'inverse */
.agenda .colhead .pdot{background:#fff;color:var(--noir);border-color:#fff}

/* Paliers d'affichage des RDV selon la hauteur (T6) */
.appt--mini{padding:2px 6px;display:flex;align-items:center}
.appt--mini .who{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:12px;line-height:1.1}
.appt--md{padding:4px 8px}
.appt--md .who{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px}
.appt--md .leg{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:11px}
.zoomctl{display:flex;gap:4px}
.zoomctl .iconbtn{min-width:44px;min-height:44px;font-size:20px}
.appt--pause{background:repeating-linear-gradient(45deg,var(--beige-3),var(--beige-3) 6px,#E3DFD9 6px,#E3DFD9 8px);border-left-color:var(--greige)}
.appt--acuity{border-left:4px solid var(--noir);background:repeating-linear-gradient(45deg,#fff,#fff 7px,#EDEAE6 7px,#EDEAE6 9px)}
.appt--pause .who{color:var(--noir-soft);font-weight:400}
.curerow{cursor:pointer}

/* T7 — bascule d'axe Cabines / Praticiennes */
.axisctl{display:flex;border:1px solid var(--noir);background:var(--beige-2)}
.axisctl .seg{padding:8px 14px;font-size:13px;background:transparent;border:0;cursor:pointer;color:var(--noir);min-height:44px;letter-spacing:.02em}
.axisctl .seg[aria-selected="true"]{background:var(--noir);color:#fff}
/* Hors-présence (planning) + pauses (par praticienne) */
.offhours{position:absolute;left:0;right:0;z-index:1;pointer-events:none;background:repeating-linear-gradient(45deg,rgba(0,0,0,.045),rgba(0,0,0,.045) 7px,rgba(0,0,0,.09) 7px,rgba(0,0,0,.09) 8px)}
.offhours--full{display:flex;align-items:flex-start;justify-content:center;padding-top:8px}
.offhours--full span{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--greige)}
.brk{position:absolute;left:3px;right:3px;z-index:3;display:flex;align-items:center;padding:2px 8px;cursor:pointer;overflow:hidden;border:1px solid var(--greige);border-left:3px solid var(--greige);background:repeating-linear-gradient(45deg,var(--beige-3),var(--beige-3) 6px,#E3DFD9 6px,#E3DFD9 8px)}
.brk span{font-size:12px;color:var(--noir-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.breaks-banner{display:flex;flex-wrap:wrap;gap:8px;padding:8px 12px;background:var(--beige-2);border-bottom:1px solid var(--line);max-height:88px;overflow:auto}
.breaks-banner span{font-size:12px;color:var(--noir-soft);background:var(--beige-3);padding:3px 8px;border:1px solid var(--line)}
/* Éditeur de planning (Réglages) */
.sched-card{margin-bottom:12px}
.sched-row{display:flex;align-items:center;gap:8px;padding:4px 0}
.sched-day{display:flex;align-items:center;gap:6px;min-width:64px;font-size:14px;color:var(--noir)}
.sched-row input[type=time]{padding:6px 8px}
.sched-row input[type=time]:disabled{opacity:.4}
/* Équipe & codes (T5) */
.staff-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between;margin-bottom:8px}
.staff-act{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.staff-act .st-code{width:170px}
.tabbar a[data-lock]{color:#9a958c}
/* Case "décompter de la cure" (T10) */
.cure-check{display:flex;gap:10px;align-items:center;padding:12px;border:1px solid var(--noir);background:var(--beige-2);color:var(--noir);font-size:14px;margin:4px 0 14px}
.cure-check input{width:20px;height:20px}
/* Sélecteur d'horaire (drawer pause) — gros, centré, tactile */
.timerange{display:flex;align-items:center;gap:12px}
.timepick{flex:1;min-height:60px;font-size:22px;text-align:center;letter-spacing:.06em;border:1px solid var(--noir)}
.timepick:focus{box-shadow:inset 0 -3px 0 var(--noir)}
.timearrow{color:var(--greige);font-family:var(--serif);font-style:italic;font-size:20px}

/* Vue mois (mini-calendrier) */
.mo-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.mo-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.mo-wd{margin-bottom:6px}
.mo-wd div{text-align:center;font-size:11px;color:var(--greige);letter-spacing:.08em}
.mo-day{position:relative;aspect-ratio:1;min-height:42px;background:var(--beige-2);border:1px solid var(--line);color:var(--noir);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.mo-day.on{background:var(--noir);color:#fff}
.mo-day.today{border-color:var(--noir);border-width:2px}
.mo-dot{position:absolute;bottom:5px;left:50%;transform:translateX(-50%);width:6px;height:6px;border-radius:50%;background:var(--noir)}
.mo-day.on .mo-dot{background:#fff}

/* ---- Réglages ---- */
.prac-row{display:flex;align-items:center;gap:14px}
/* Réglages : la pastille monogramme remplace le carré de couleur */
.prac-row .swatch{
  width:30px;height:30px;border-radius:50%;border:1px solid var(--noir);
  background:#fff;color:var(--noir);display:flex;align-items:center;justify-content:center;
  font:600 13px/1 var(--ui);text-transform:uppercase;flex:0 0 auto;
}
.prac-row .prac-name{flex:1;font-size:16px;color:var(--noir)}
.closed{padding:40px;text-align:center;color:var(--greige);font-family:var(--serif);font-style:italic;font-size:22px}

/* ---- Stepper visite ---- */
.stepper{display:flex;gap:8px;align-items:center}
.stepper .step{display:flex;align-items:center;gap:8px;color:var(--greige);font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.stepper .dot{width:26px;height:26px;border:1px solid var(--greige);border-radius:50%;display:grid;place-items:center;font-size:13px}
.stepper .step[aria-current="true"]{color:var(--noir)}
.stepper .step[aria-current="true"] .dot{background:var(--noir);color:#fff;border-color:var(--noir)}

/* Flux "Nouvelle visite" : la zone d'étape remplit la hauteur restante -> le bouton bas (Planifier/Valider) ne passe plus sous la tabbar */
.visite-flow{display:flex;flex-direction:column;height:100%}
.visite-flow>#step-body{flex:1;min-height:0;overflow:auto}
.split{display:grid;grid-template-columns:200px 1fr 320px;grid-template-rows:minmax(0,1fr);gap:1px;background:var(--line);height:100%}
.split>div{background:var(--beige);overflow:auto;min-height:0;padding:16px}
/* Colonne catégories (étape panier) : noms longs sur 2 lignes au lieu d'être coupés */
#cats .chip{white-space:normal;height:auto;min-height:56px;padding:10px 14px;line-height:1.25;text-align:center}
.svc{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.svc button{text-align:left;background:var(--beige-2);border:1px solid var(--line);padding:12px;cursor:pointer;min-height:84px}
.svc button:active{background:var(--beige-3)}
.svc .nm{font-size:14px;color:var(--noir);line-height:1.2}
.svc .mt{font-size:12px;color:var(--greige);margin-top:6px}
.svc .cure-badge{display:inline-block;margin-top:6px;font-size:10px;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--noir);color:var(--noir);padding:2px 6px}

/* Étape 3 — ligne praticienne/parallèle */
.planline{display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line);padding:10px 0}
.planline .pl-svc{flex:1;color:var(--noir);font-size:15px}
.planline .pl-par{min-height:44px;padding:0 12px;font-size:12px}
.planline .pl-prac{min-height:48px;min-width:150px;flex:0 0 auto}

.cart{display:flex;flex-direction:column;height:100%}
.cart h2{font-family:var(--serif);font-style:italic;font-weight:500;font-size:20px;margin:0 0 4px;color:var(--noir)}
.cart .client-pin{border:1px solid var(--noir);padding:10px 12px;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center}
.cart .items{flex:1;overflow:auto}
.cartline{display:flex;justify-content:space-between;align-items:center;gap:8px;border-bottom:1px solid var(--line);padding:12px 0}
.cartline .x{min-width:44px;min-height:44px;border:1px solid var(--line);background:transparent;cursor:pointer;font-size:18px;color:var(--noir)}
.cart .tot{border-top:2px solid var(--noir);padding-top:12px;margin-top:8px;display:flex;justify-content:space-between;font-size:15px}
.cart .tot b{font-size:18px}
.cart [data-next]{margin-bottom:calc(8px + env(safe-area-inset-bottom, 0px))}

/* ---- Recherche client / inputs ---- */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.field label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--greige)}
input,select{
  min-height:var(--tap);font-family:var(--ui);font-size:16px;font-weight:300;
  background:var(--beige-2);border:1px solid var(--line);padding:0 14px;color:var(--noir);
}
input:focus,select:focus{outline:none;border-color:var(--noir)}
.results{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.results button{text-align:left;background:var(--beige-2);border:1px solid var(--line);padding:14px;cursor:pointer;min-height:var(--tap)}
.results .nm{font-size:16px;color:var(--noir)}
.results .meta{font-size:12px;color:var(--greige);margin-top:3px}

/* ---- Cures ---- */
.tabs{display:flex;gap:0;border-bottom:1px solid var(--line)}
.tabs button{flex:0 0 auto;min-height:var(--tap);padding:0 22px;background:transparent;border:0;border-bottom:2px solid transparent;
  font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--greige);cursor:pointer}
.tabs button[aria-selected="true"]{color:var(--noir);border-bottom-color:var(--noir)}
.tabs .badge{display:inline-block;margin-left:8px;background:var(--noir);color:#fff;font-size:11px;padding:1px 7px;border-radius:10px}
.curerow{background:var(--beige-2);border:1px solid var(--line);padding:16px;margin:12px var(--pad)}
.curerow .top{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.curerow .who{font-size:17px;color:var(--noir)}
.curerow .lab{font-family:var(--serif);font-style:italic;font-size:16px;color:var(--noir-soft)}
.pellets{display:flex;gap:6px;align-items:center;margin:10px 0;font-size:15px;color:var(--noir)}
.pellet{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--noir)}
.pellet.on{background:var(--noir)}
.curerow .meta{font-size:13px;color:var(--greige)}
.curerow .meta.warn{color:var(--noir);font-weight:500}     /* précédé de ⚠ dans le JS */
.curerow .actions{display:flex;gap:10px;margin-top:12px}

/* ---- Modal / drawer ---- */
#modal-root:empty{display:none}
.overlay{position:fixed;inset:0;background:rgba(20,16,12,.45);z-index:50;display:flex;justify-content:flex-end}
.drawer{width:min(440px,92vw);background:var(--beige);height:100%;overflow:auto;padding:var(--pad);padding-bottom:calc(var(--pad) + var(--safe-bottom) + 8px);box-shadow:-8px 0 30px rgba(0,0,0,.2);-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.drawer h2{font-family:var(--serif);font-style:italic;font-weight:500;font-size:22px;margin:0 0 12px;color:var(--noir)}
.drawer .row{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}

/* ---- Toast ---- */
.toast{position:fixed;left:50%;bottom:calc(var(--tabbar) + var(--safe-bottom) + 16px);transform:translateX(-50%);z-index:60;
  background:var(--noir);color:#fff;padding:14px 22px;font-size:14px;letter-spacing:.04em;max-width:90vw}
.toast.err{background:var(--noir);box-shadow:inset 0 0 0 2px #fff}

/* ---- Gate : pavé PIN brandé Ambre & Musc ---- */
#gate{position:fixed;inset:0;z-index:80;background:var(--beige);display:flex;align-items:center;justify-content:center;
  padding:calc(20px + var(--safe-top)) calc(16px + var(--safe-right)) calc(20px + var(--safe-bottom)) calc(16px + var(--safe-left))}
#gate[hidden]{display:none}
.gate-pad{display:flex;flex-direction:column;align-items:center;gap:14px;width:min(330px,90vw);text-align:center}
.gate-wm{font-size:22px;color:var(--noir)}     /* .wm fournit déjà famille/poids/lowercase */
.gate-sub{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--greige);margin-bottom:2px}
.gate-dots{display:flex;gap:18px;margin:6px 0 2px}
.gate-dots span{width:13px;height:13px;border-radius:50%;border:1.5px solid var(--noir);transition:background .12s}
.gate-dots span.on{background:var(--noir)}
.gate-dots.shake{animation:gate-shake .4s}
#gate-err{color:var(--noir);font-weight:500;font-size:13px;min-height:18px;letter-spacing:.02em}
.gate-keys{display:grid;grid-template-columns:repeat(3,1fr);gap:16px 20px;margin-top:4px}
.gkey{width:72px;height:72px;border-radius:50%;border:1px solid var(--line);background:var(--beige-2);color:var(--noir);
  font:300 28px/1 var(--ui);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,transform .08s}
.gkey:active{background:var(--noir);color:#fff;transform:scale(.95)}
.gkey--ghost{background:transparent;border-color:transparent;font-size:22px;color:var(--greige)}
.gkey--ghost:active{background:transparent;color:var(--noir);transform:none}
.gkey-spacer{width:72px;height:72px;visibility:hidden}
@keyframes gate-shake{10%,90%{transform:translateX(-2px)}20%,80%{transform:translateX(4px)}30%,50%,70%{transform:translateX(-7px)}40%,60%{transform:translateX(7px)}}

.empty{padding:48px var(--pad);text-align:center;color:var(--greige)}
.spin{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}

/* ============================================================
   RESPONSIVE — Institut OS (audit 8 surfaces × 7 viewports)
   Breakpoints : <=480 tel · <=767/860 phablet+stack · 768-1024 tablette · >=1025 desktop · paysage court
   ============================================================ */

/* .step-label : classe utilisée par les drawers (#pay-box/#edit-box), absente jusque-là */
.step-label{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--greige);margin:18px 0 10px}

/* Bandeau stats / lignes de fiche cliente (externalisés depuis clients.js) */
.client-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:16px}
.fiche-row{display:flex;justify-content:space-between;gap:12px;align-items:center}
.fiche-row>span:first-child{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fiche-row>:last-child{flex:0 0 auto;white-space:nowrap}

/* ---- Stacking structurel (phablet + tablette portrait) ---- */
@media (max-width:860px){
  /* Panier (.split) : 3 colonnes -> empilées, panier collant en bas (CRITICAL encaissement) */
  .split{grid-template-columns:1fr;grid-template-rows:auto;height:auto;overflow:visible}
  .split>div{overflow:visible;min-height:auto}
  .cart{height:auto}
  .cart .items{flex:none;overflow:visible}
  #cart.cart{position:sticky;bottom:0;z-index:5;border-top:2px solid var(--noir);background:var(--beige)}
  /* Colonne catégories : carrousel horizontal collant en haut du scroll */
  #cats{position:sticky;top:0;z-index:6;background:var(--beige);padding-top:8px}
  #cats .chips{flex-direction:row !important;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}
  #cats .chip{flex:0 0 auto;white-space:nowrap;min-height:48px}
}
@media (max-height:480px){ .split{grid-template-columns:1fr;height:auto} }

@media (max-width:1024px){
  .view-head{flex-wrap:wrap;row-gap:10px}
  .view-head>div{flex-wrap:wrap}
  .view-head h1{min-width:0}
}

/* ---- Téléphone (<=600) ---- */
@media (max-width:600px){
  /* Drawers : bottom-sheet pleine largeur, safe-area latérale */
  .overlay{justify-content:stretch}
  .overlay .drawer{width:100%!important;max-width:none!important}   /* bat les width:min(...) inline (drawer "trou évitable") */
  .drawer{padding-left:calc(var(--pad) + var(--safe-left));padding-right:calc(var(--pad) + var(--safe-right))}
  .drawer .row.pay-disc-row{display:flex;flex-wrap:nowrap;gap:6px;align-items:center}  /* la rangée remise reste en flex (pas happée par la grille 2 col) */
  .pay-disc-row #pay-disc{flex:1;min-width:0}
  /* Rangée d'actions du drawer (✓/✎/Annuler) en grille 2 colonnes propre */
  .drawer .row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .drawer .row .btn--block{grid-column:1/-1}
  .btn{padding:0 14px;letter-spacing:.08em}
  .btn--block{white-space:normal;line-height:1.2;min-height:var(--tap-lg)}
  /* Encaissement #pay-box : remise + moyens compacts */
  #pay-box .chip{padding:0 12px;min-width:48px}
  #pay-method{display:grid;grid-template-columns:repeat(3,1fr)}
  #pay-method .chip{padding:0 8px;justify-content:center}
  /* Stepper visite : pastilles seules (libellés masqués) */
  .stepper .step{font-size:0}
  .stepper .dot{font-size:13px}
  /* Étape 3 — praticienne/parallèle empilée */
  .planline{flex-wrap:wrap}
  .planline .pl-svc{flex:1 1 100%;min-width:0}
  .planline .pl-prac{flex:1 1 auto;min-width:0;width:100%}
  .planline .pl-par{order:3}
  /* Fiche cliente : titre tronqué + bouton compact */
  .view-head h1{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .client-stats .contact{grid-column:1/-1}
  /* Vue mois : cellules tactiles */
  .mo-grid{gap:2px}
  .mo-day{min-height:44px;font-size:14px;min-width:0}
}

/* ---- Petit téléphone (<=480) ---- */
@media (max-width:480px){
  /* Tabbar : 6 onglets tiennent à 360px (libellés compacts, icône conservée) */
  .tabbar a{min-width:0;font-size:9px;letter-spacing:.02em;padding:0 2px;white-space:nowrap;text-align:center}
  .tabbar a .ico{font-size:18px}
  /* Grilles inline "1fr 1fr" (prénom/nom, date/heure, sellCure, staff…) -> 1 colonne */
  .grid[style*="1fr 1fr"]{grid-template-columns:1fr !important}
  /* Cures : onglets scrollables + actions empilées + pellets qui wrap */
  .tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .tabs button{flex:1 1 0;padding:0 10px;letter-spacing:.06em;font-size:12px;white-space:nowrap}
  .curerow .actions{flex-direction:column}
  .curerow .actions .btn{width:100%}
  .pellets{flex-wrap:wrap}
  .pellet{width:15px;height:15px}
  /* Réglages : planning + équipe empilés */
  .sched-row{flex-wrap:wrap;gap:6px}
  .sched-day{flex:0 0 100%;min-width:0}
  .sched-row input[type=time]{flex:1;min-width:0;padding:6px}
  .staff-act{flex-direction:column;align-items:stretch}
  .staff-act .st-code{width:100%}
  .staff-act .btn{width:100%}
  /* Agenda : barre d'outils compacte */
  .view-head h1{font-size:18px}
  .view-head .btn{padding:0 12px;min-height:48px;font-size:11px;letter-spacing:.06em}
  .iconbtn{min-width:48px;min-height:48px}
  .axisctl .seg{padding:8px 10px;font-size:12px}
}
.curerow .top>*{min-width:0}
.curerow .lab{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1 1 auto;text-align:right}
@media (max-width:560px){ .curerow .top{flex-direction:column;align-items:flex-start;gap:2px} .curerow .lab{text-align:left} }

/* ---- Agenda : scroll horizontal sur mobile (colonnes >=120px, jamais compressées) ---- */
@media (max-width:640px){
  /* grille/scroll-X/sticky désormais gérés en base (minmax 120 + #agenda-body) : ici cosmétique mobile */
  .agenda .colhead{font-size:11px;letter-spacing:.06em;padding:8px 2px;white-space:normal;line-height:1.1;min-height:40px;display:flex;align-items:center;justify-content:center}
  .gap,.brk{min-height:44px}
  .appt .leg{letter-spacing:0;font-size:10px}
  .nowlabel{right:1px;font-size:9px;padding:1px 3px}
  .breaks-banner{flex-wrap:nowrap;gap:6px;padding:6px 10px}
  .breaks-banner span{flex:0 0 auto}
  .offhours--full span{white-space:normal;text-align:center;padding:0 4px;line-height:1.2;font-size:10px;letter-spacing:.04em}
}

/* ---- Téléphone paysage (hauteur critique) ---- */
@media (orientation:landscape) and (max-height:480px){
  :root{--tabbar:54px;--tap:48px;--tap-lg:56px}
  .tabbar a{font-size:10px}
  .tabbar a .ico{font-size:17px}
  .view-head{padding-top:calc(8px + var(--safe-top));padding-bottom:8px}
  .view-head h1{font-size:18px}
  .timepick{min-height:48px;font-size:18px}
  .field{margin-bottom:8px}
  .gate-pad{gap:8px}
  .gate-wm{font-size:16px}
  .gate-sub{font-size:15px}
  .gate-dots{gap:14px;margin:2px 0}
  .gate-keys{gap:8px 14px}
  .gate-keys .gkey,.gate-keys .gkey-spacer{width:52px;height:52px;font-size:22px}
}

/* ---- Gate : centré par défaut ; top-aligné + scrollable seulement si hauteur faible (clavier ouvert / paysage) ---- */
@media (max-height:600px){
  #gate{align-items:flex-start;overflow:auto}
  .gate-keys .gkey,.gate-keys .gkey-spacer{width:60px;height:60px;font-size:24px}
  .gate-keys{gap:10px 16px}
}

/* ---- Desktop : densité cures ---- */
@media (min-width:1025px){
  .curerow{max-width:920px;margin-left:auto;margin-right:auto}
}

/* ---- Admin (pilotage) : en-tête + cockpit de réactivation ---- */
.admin-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:18px 18px 12px;border-bottom:1px solid var(--line)}
.admin-wm{font-size:22px}
.admin-tag{font-family:var(--serif);font-style:italic;color:var(--greige);font-size:15px}
.reac-top{padding:18px 18px 4px;max-width:680px;margin:0 auto}
.reac-top h1{font-family:var(--ui);font-weight:600;font-size:22px;margin:0 0 6px;color:var(--noir)}
.reac-intro{color:var(--greige);font-size:14px;line-height:1.5;margin:0}
.reac-list{display:flex;flex-direction:column;gap:14px;padding:14px 14px 96px;max-width:680px;margin:0 auto}
.reac-card{background:var(--beige-2);border:1px solid var(--line);padding:16px;transition:opacity .22s}
.reac-card.reac-done{opacity:.5}
.reac-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.reac-name{font-weight:600;font-size:17px;color:var(--noir)}
.reac-tier{font-size:11px;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--noir);padding:2px 8px;color:var(--noir);white-space:nowrap}
.reac-tier--vip{background:var(--noir);color:#fff}
.reac-meta{color:var(--greige);font-size:13px;margin:6px 0 10px;line-height:1.45}
.reac-warn{color:var(--noir);font-size:12px;background:var(--beige-3);padding:6px 9px;margin:0 0 8px}
.reac-msg{width:100%;box-sizing:border-box;border:1px solid var(--line);background:var(--beige);font-family:var(--ui);font-size:14px;line-height:1.5;color:var(--noir);padding:10px;resize:vertical}
.reac-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.reac-actions .btn{padding:10px 16px;font-size:14px}
.reac-wa{min-width:120px}
.reac-skip{margin-left:auto;color:var(--greige);border-color:var(--line)}
