/* Ambre & Musc — Institut OS · design system beige + noir (tablette, touch-first) */
:root{
  --beige:#EFE7DA;        /* fond app */
  --beige-2:#F6F1E8;      /* cartes / surfaces */
  --beige-3:#E6DCCB;      /* hover slot, grille */
  --noir:#0E0E0E;         /* texte fort, boutons pleins */
  --noir-soft:#2A2724;    /* corps de texte */
  --greige:#8E8A85;       /* légendes, mentions */
  --line:#D8CEBE;         /* filets 1px */
  --alert:#9A4B42;        /* terracotta : à relancer / no-show */
  --ok:#5E6B57;           /* olive : validé / done */
  --sans:'Jost',system-ui,-apple-system,sans-serif;
  --serif:'Cormorant Garamond',Georgia,serif;
  --tap:56px; --tap-lg:68px;
  --pad:20px; --gap:14px;
  --topbar:60px; --tabbar:72px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  background:var(--beige);color:var(--noir-soft);
  font-family:var(--sans);font-weight:300;font-size:16px;
  -webkit-font-smoothing:antialiased;
  padding-top:var(--topbar);padding-bottom:var(--tabbar);
  overflow:hidden;
}
button{font-family:inherit}
a{color:inherit;text-decoration:none}

/* ---- Topbar (bandeau noir signature) ---- */
.topbar{
  position:fixed;top:0;left:0;right:0;height:var(--topbar);z-index:30;
  background:var(--noir);color:#fff;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--pad);padding-top:env(safe-area-inset-top);
}
.wm{font-family:var(--sans);font-weight:300;letter-spacing:.28em;text-transform:uppercase;font-size:16px}
.topbar-sub{font-family:var(--serif);font-style:italic;font-size:18px;color:#e9e2d6}

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

/* ---- Tabbar (zone pouce) ---- */
.tabbar{
  position:fixed;bottom:0;left:0;right:0;height:var(--tabbar);z-index:30;
  background:var(--noir);display:flex;
  padding-bottom:env(safe-area-inset-bottom);
}
.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}

/* ---- Layout vues ---- */
#view{height:calc(100vh - var(--topbar) - var(--tabbar));overflow:auto;-webkit-overflow-scrolling:touch}
.view-head{
  display:flex;align-items:center;justify-content:space-between;gap:var(--gap);
  padding:14px var(--pad);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(--sans);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 1fr 1fr 1fr;gap:1px;background:var(--line);min-height:100%}
.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:5}
.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);border:1px solid var(--noir);
  padding:6px 8px;overflow:hidden;cursor:pointer;border-left:4px solid var(--noir);
}
.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}
.appt[data-status="done"]{background:var(--noir);color:#fff;border-left-color:#fff}
.appt[data-status="done"] .who,.appt[data-status="done"] .what{color:#fff}
.appt[data-status="done"] .leg{color:#c9c3b8}
.appt[data-status="noshow"]{border-left-color:var(--alert);background:repeating-linear-gradient(45deg,var(--beige-2),var(--beige-2) 7px,#efe1de 7px,#efe1de 9px)}
.appt.cure{box-shadow:inset 4px 0 0 var(--ok)}
.nowline{position:absolute;left:0;right:0;height:2px;background:var(--alert);z-index:4}
.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)}

.split{display:grid;grid-template-columns:200px 1fr 320px;gap:1px;background:var(--line);height:100%}
.split>div{background:var(--beige);overflow:auto;padding:16px}
.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(--ok);color:var(--ok);padding:2px 6px}

.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:40px;min-height:40px;border:1px solid var(--line);background:transparent;cursor:pointer;font-size:18px;color:var(--alert)}
.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}

/* ---- 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(--sans);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(--alert);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(--alert)}
.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);box-shadow:-8px 0 30px rgba(0,0,0,.2)}
.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) + 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(--alert)}

.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)}}
