/* sejour.css — design system du cubion auberge.
   Clean & rassurant (un vrai produit SaaS), 2 densités persona, mobile-first, ZÉRO GPU.
   persona-simple  = gérant : grand, aéré, guidé, gros boutons.
   persona-efficace = épouse : dense, pro, raccourcis, multi-colonnes. */
:root{
  --bg:#eef2f7; --surf:#ffffff; --surf2:#f6f8fc; --ink:#16202e; --dim:#5d6b7e; --faint:#8a98ab;
  --line:#e2e8f1; --line2:#d3dce8;
  --acc:#2f6df0; --acc-ink:#fff; --acc-soft:#e8f0ff;
  --warm:#c2701c; --ok:#0e9f6e; --okx:#e7f7f0; --warn:#b9821b; --warnx:#fbf3e2; --danger:#e23d52; --dangerx:#fdecee;
  --r:12px; --r2:16px; --pad:16px; --fs:15px; --tap:42px; --shadow:0 1px 3px rgba(16,32,60,.07),0 6px 20px rgba(16,32,60,.05);
  --maxcols:repeat(auto-fill,minmax(230px,1fr));
}
body.persona-simple{ --fs:16.5px; --pad:20px; --tap:52px; --r:16px; --r2:20px; --maxcols:repeat(auto-fill,minmax(280px,1fr)); }
body.persona-efficace{ --fs:13.5px; --pad:11px; --tap:34px; --r:9px; --r2:12px; --maxcols:repeat(auto-fill,minmax(190px,1fr)); }

*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:var(--bg);color:var(--ink);font:var(--fs)/1.45 -apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;-webkit-font-smoothing:antialiased}
a{color:var(--acc);text-decoration:none}
h1,h2,h3{margin:0;font-weight:700;letter-spacing:-.01em}
.muted{color:var(--dim)} .faint{color:var(--faint)} .mono{font-family:ui-monospace,"SF Mono",Menlo,monospace}
.tnum{font-variant-numeric:tabular-nums}

/* ---- contrôles ---- */
button,.btn{font:inherit;cursor:pointer;border:1px solid var(--line2);background:var(--surf);color:var(--ink);border-radius:var(--r);padding:0 14px;min-height:var(--tap);display:inline-flex;align-items:center;gap:7px;font-weight:600;transition:.12s}
button:hover,.btn:hover{border-color:var(--acc);color:var(--acc)}
.btn-primary{background:var(--acc);color:var(--acc-ink);border-color:var(--acc)}
.btn-primary:hover{filter:brightness(1.06);color:#fff}
.btn-ghost{background:transparent;border-color:transparent}
.btn-danger{color:var(--danger);border-color:var(--line2)} .btn-danger:hover{border-color:var(--danger);background:var(--dangerx)}
.btn-sm{min-height:30px;padding:0 10px;font-size:.82em;border-radius:9px}
input,select,textarea{font:inherit;width:100%;background:var(--surf);border:1px solid var(--line2);border-radius:var(--r);padding:9px 12px;min-height:var(--tap);color:var(--ink);outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--acc);box-shadow:0 0 0 3px var(--acc-soft)}
label.fld{display:block;margin:0 0 10px} label.fld>span{display:block;font-size:.8em;font-weight:600;color:var(--dim);margin-bottom:5px}
.chip{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:.78em;font-weight:600;background:var(--surf2);border:1px solid var(--line)}
.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:.74em;font-weight:700;color:#fff}

/* ---- cards & grid ---- */
.card{background:var(--surf);border:1px solid var(--line);border-radius:var(--r2);box-shadow:var(--shadow)}
.card.pad{padding:var(--pad)}
.grid{display:grid;gap:var(--pad)}
.cards{display:grid;gap:var(--pad);grid-template-columns:var(--maxcols)}
.stat{display:grid;gap:3px}
.stat .k{font-size:.78em;color:var(--dim);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.stat .v{font-size:1.9em;font-weight:800;letter-spacing:-.02em}
.row{display:flex;align-items:center;gap:10px} .wrap{flex-wrap:wrap} .sp{flex:1} .between{justify-content:space-between}

/* ---- tables (denses en efficace) ---- */
table.t{width:100%;border-collapse:collapse;font-size:.95em}
table.t th{text-align:left;font-size:.74em;text-transform:uppercase;letter-spacing:.04em;color:var(--dim);font-weight:700;padding:9px 12px;border-bottom:1px solid var(--line2);position:sticky;top:0;background:var(--surf)}
table.t td{padding:11px 12px;border-bottom:1px solid var(--line)}
body.persona-efficace table.t td{padding:6px 10px}
table.t tr:hover td{background:var(--surf2)}
table.t tr{cursor:default}

/* ---- App shell ---- */
.app{display:grid;height:100vh;grid-template-rows:auto 1fr;overflow:hidden}
.appbar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--surf);border-bottom:1px solid var(--line2);z-index:5}
.appbar .brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.05em}
.appbar .brand .logo{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,var(--acc),var(--warm));display:grid;place-items:center;color:#fff;font-size:1.05em}
.live{width:9px;height:9px;border-radius:50%;background:var(--faint);transition:.3s} .live.on{background:var(--ok);box-shadow:0 0 0 3px var(--okx)}
.seg{display:flex;background:var(--surf2);border:1px solid var(--line2);border-radius:999px;padding:3px}
.seg button{min-height:30px;border:none;background:transparent;border-radius:999px;padding:0 13px;font-size:.84em;color:var(--dim)}
.seg button.on{background:var(--surf);color:var(--acc);box-shadow:var(--shadow);font-weight:700}

.body{display:grid;grid-template-columns:auto 1fr;min-height:0}
.nav{width:230px;background:var(--surf);border-right:1px solid var(--line);padding:10px;overflow:auto;display:flex;flex-direction:column;gap:3px}
body.persona-efficace .nav{width:200px}
.nav a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--r);color:var(--ink);font-weight:600;cursor:pointer}
.nav a .i{width:24px;text-align:center;font-size:1.1em}
.nav a:hover{background:var(--surf2)}
.nav a.on{background:var(--acc-soft);color:var(--acc)}
.nav .navsec{font-size:.7em;text-transform:uppercase;letter-spacing:.05em;color:var(--faint);font-weight:700;padding:12px 12px 5px}
.nav .add{margin-top:auto;color:var(--dim);border:1px dashed var(--line2);justify-content:center}
.main{overflow:auto;padding:var(--pad);min-height:0}
.view{max-width:1180px;margin:0 auto;display:flex;flex-direction:column;gap:var(--pad)}
.view h1{font-size:1.5em;margin-bottom:2px} .view .sub{color:var(--dim);font-size:.92em}

/* bottom tab bar (mobile) */
.tabbar{display:none}
@media(max-width:820px){
  .body{grid-template-columns:1fr}
  .nav{display:none}
  .main{padding:12px 12px 78px}
  .tabbar{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--surf);border-top:1px solid var(--line2);padding:6px 4px env(safe-area-inset-bottom);z-index:8;overflow-x:auto}
  .tabbar a{flex:1 0 19%;display:flex;flex-direction:column;align-items:center;gap:2px;padding:7px 2px;color:var(--dim);font-size:.62em;font-weight:600;cursor:pointer;min-width:60px}
  .tabbar a .i{font-size:1.35em} .tabbar a.on{color:var(--acc)}
  .appbar{padding:10px 12px}
  .stat .v{font-size:1.6em}
}

/* drawer / modal */
.scrim{position:fixed;inset:0;background:rgba:(16,32,60,.45);background:rgba(16,32,60,.4);backdrop-filter:saturate(1.2) blur(2px);z-index:20;display:flex;align-items:flex-end;justify-content:center}
@media(min-width:821px){.scrim{align-items:center}}
.sheet{background:var(--surf);width:100%;max-width:560px;max-height:92vh;overflow:auto;border-radius:var(--r2) var(--r2) 0 0;box-shadow:0 -8px 40px rgba(16,32,60,.2)}
@media(min-width:821px){.sheet{border-radius:var(--r2)}}
.sheet .sh-top{display:flex;align-items:center;gap:10px;padding:16px var(--pad);border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--surf);z-index:1}
.sheet .sh-top h2{font-size:1.15em} .sheet .sh-body{padding:var(--pad)} .sheet .sh-foot{padding:14px var(--pad);border-top:1px solid var(--line);display:flex;gap:10px;position:sticky;bottom:0;background:var(--surf)}

.empty{text-align:center;color:var(--dim);padding:48px 16px} .empty .ico{font-size:2.4em;opacity:.6;margin-bottom:8px}
.toast{position:fixed;bottom:84px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;padding:11px 18px;border-radius:999px;font-weight:600;font-size:.9em;z-index:50;box-shadow:0 8px 30px rgba(0,0,0,.3);opacity:0;transition:.25s}
.toast.on{opacity:1;bottom:96px}
@media(min-width:821px){.toast{bottom:24px}.toast.on{bottom:32px}}
.spin{width:22px;height:22px;border:2.5px solid var(--line2);border-top-color:var(--acc);border-radius:50%;animation:sp 1s linear infinite;margin:30px auto}
@keyframes sp{to{transform:rotate(360deg)}}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;vertical-align:middle}
