/* ═══════════════════════════════════════════════════════════════════════
   Company OS Fable — design system v3 « Encre & Laiton » (finition studio)
   Sombre premium · motion design unifié · cérémonies de porte.
   Typo : Fraunces (display) + Outfit (UI), auto-hébergées (offline).
   ═══════════════════════════════════════════════════════════════════════ */

@font-face{font-family:"Fraunces";src:url("fonts/fraunces-600.woff2") format("woff2");font-weight:600;font-display:swap}
@font-face{font-family:"Fraunces";src:url("fonts/fraunces-800.woff2") format("woff2");font-weight:800;font-display:swap}
@font-face{font-family:"Outfit";src:url("fonts/outfit-400.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"Outfit";src:url("fonts/outfit-500.woff2") format("woff2");font-weight:500;font-display:swap}
@font-face{font-family:"Outfit";src:url("fonts/outfit-700.woff2") format("woff2");font-weight:700;font-display:swap}

:root{
  --bg:#0f141c; --bg-soft:#131a24; --card:#161e2a; --card-2:#1b2432; --card-3:#212c3d;
  --line:rgba(148,163,184,.14); --line-strong:rgba(148,163,184,.28);
  --ink:#e9eef6; --ink-2:#c3cddb; --muted:#94a3b8;
  --brass:#e0b95f; --brass-2:#f0d08a; --brass-3:#b8933d; --brass-ink:#10151d;
  --brass-dim:rgba(224,185,95,.16); --brass-glow:rgba(224,185,95,.32);
  --ok:#3ddc84; --ok-dim:rgba(61,220,132,.14);
  --warn:#ffb454; --warn-dim:rgba(255,180,84,.14);
  --bad:#ff6b7a; --bad-dim:rgba(255,107,122,.14);
  --info:#6db3f2; --info-dim:rgba(109,179,242,.13);
  --c-n0:#a78bfa; --c-n1:#3fd6d2; --c-n2:#4ade80; --c-n3:#ff6b7a;
  --c-n4:#ff9f43; --c-n5:#ffd166; --c-n6:#c9a2ff;
  --r:16px; --r-sm:10px; --r-lg:22px;
  --shadow:0 10px 34px rgba(0,0,0,.38);
  --ease:cubic-bezier(.2,.8,.3,1); --spring:cubic-bezier(.34,1.4,.5,1);
  --t:180ms var(--ease);
  --font-ui:"Outfit",system-ui,-apple-system,"Segoe UI",sans-serif;
  --font-display:"Fraunces",Georgia,serif;
  color-scheme:dark;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scrollbar-color:var(--card-3) var(--bg)}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-thumb{background:var(--card-3);border-radius:99px;border:3px solid var(--bg)}
::-webkit-scrollbar-track{background:transparent}
body{
  margin:0;font:16px/1.6 var(--font-ui);color:var(--ink);
  background:
    radial-gradient(1100px 520px at 85% -10%, rgba(224,185,95,.08), transparent 60%),
    radial-gradient(900px 620px at -10% 110%, rgba(109,179,242,.05), transparent 55%),
    var(--bg);
  min-height:100dvh;padding-bottom:2.5rem;
}
::selection{background:var(--brass-dim);color:var(--brass-2)}
a{color:var(--info);text-decoration:none}
a:hover{text-decoration:underline}
:focus-visible{outline:2px solid var(--brass);outline-offset:2px;border-radius:6px}

h1{font-family:var(--font-display);font-weight:800;font-size:1.75rem;line-height:1.22;margin:.5rem 0 1rem;letter-spacing:-.012em;text-wrap:balance}
h2{font-family:var(--font-display);font-weight:600;font-size:1.22rem;margin:1.2rem 0 .55rem}
.muted{color:var(--muted)} .small{font-size:.85rem}
.kicker{font-size:.72rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:var(--brass);margin-bottom:.3rem}

/* ── barre supérieure ─────────────────────────────────────────────── */
#topbar{
  position:sticky;top:0;z-index:20;display:flex;gap:1rem;align-items:center;flex-wrap:wrap;
  padding:.55rem 1rem;background:rgba(15,20,28,.82);backdrop-filter:blur(16px) saturate(1.3);
  border-bottom:1px solid var(--line);
}
#topbar .brand{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--font-display);font-weight:800;font-size:1.1rem;color:var(--ink)}
#topbar .brand b{color:var(--brass)}
#topbar .brand:hover{text-decoration:none}
.logo-seal{width:30px;height:30px;flex:none;filter:drop-shadow(0 2px 6px rgba(224,185,95,.35))}
#topbar nav{display:flex;gap:.2rem;flex-wrap:wrap;margin-left:auto}
#topbar nav a{
  display:inline-flex;align-items:center;gap:.42rem;color:var(--ink-2);
  padding:.5rem .8rem;border-radius:99px;font-size:.9rem;font-weight:500;
  min-height:44px;transition:background var(--t),color var(--t),transform var(--t);
}
#topbar nav a svg{width:17px;height:17px;stroke:currentColor;flex:none}
#topbar nav a:hover{background:var(--card-2);color:var(--ink);text-decoration:none}
#topbar nav a:active{transform:scale(.95)}
#topbar nav a.on{background:var(--brass-dim);color:var(--brass-2)}

#app{max-width:960px;margin:0 auto;padding:1.2rem 1rem}
#foot{max-width:960px;margin:2rem auto 0;padding:0 1rem;color:var(--muted);font-size:.78rem;letter-spacing:.02em}

/* ── transitions de vue (chaque changement d'écran) ───────────────── */
@media (prefers-reduced-motion: no-preference){
  #app.view-in > *{animation:viewIn .32s var(--ease) both}
  #app.view-in > :nth-child(2){animation-delay:35ms}
  #app.view-in > :nth-child(3){animation-delay:70ms}
  #app.view-in > :nth-child(4){animation-delay:105ms}
  #app.view-in > :nth-child(5){animation-delay:140ms}
}
@keyframes viewIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ── cartes ───────────────────────────────────────────────────────── */
.card{
  background:linear-gradient(180deg, rgba(255,255,255,.025), transparent 42%), var(--card);
  border:1px solid var(--line);border-radius:var(--r);
  padding:1.15rem 1.3rem;margin:.8rem 0;
}
.grid{display:grid;gap:.8rem}
@media(min-width:720px){.grid.c2{grid-template-columns:1fr 1fr}.grid.c3{grid-template-columns:1fr 1fr 1fr}}

/* ── boutons ──────────────────────────────────────────────────────── */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  border:1px solid var(--line-strong);background:var(--card-2);color:var(--ink);
  padding:.6rem 1.1rem;border-radius:12px;font:500 .95rem var(--font-ui);
  cursor:pointer;min-height:44px;text-decoration:none;overflow:hidden;
  transition:transform 140ms var(--spring),background var(--t),border-color var(--t),box-shadow var(--t),filter var(--t);
  touch-action:manipulation;
}
.btn:hover{border-color:var(--brass);text-decoration:none;background:var(--card-3);transform:translateY(-1px)}
.btn:active{transform:scale(.96)}
.btn.primary{
  background:linear-gradient(180deg,var(--brass-2),var(--brass) 55%,var(--brass-3));
  border-color:transparent;color:var(--brass-ink);font-weight:700;letter-spacing:.01em;
  box-shadow:0 4px 20px var(--brass-glow), inset 0 1px 0 rgba(255,255,255,.35);
}
.btn.primary:hover{filter:brightness(1.07);transform:translateY(-1px)}
.btn.big{padding:.85rem 1.6rem;font-size:1.05rem;border-radius:14px}
.btn.danger{background:var(--bad-dim);border-color:rgba(255,107,122,.4);color:var(--bad)}
.btn.ghost{background:transparent;border-color:transparent;color:var(--ink-2)}
.btn.ghost:hover{border-color:var(--line-strong)}
.btn[disabled]{opacity:.4;cursor:not-allowed;transform:none}
.btnrow{display:flex;gap:.55rem;flex-wrap:wrap;margin:.7rem 0;align-items:center}

/* ── pastilles ────────────────────────────────────────────────────── */
.chip{
  display:inline-flex;align-items:center;gap:.3rem;padding:.18rem .6rem;border-radius:99px;
  font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  border:1px solid transparent;vertical-align:middle;white-space:nowrap;
}
.chip.afaire{background:var(--card-2);color:var(--muted);border-color:var(--line)}
.chip.encours{background:var(--warn-dim);color:var(--warn)}
.chip.fait{background:var(--ok-dim);color:var(--ok)}
.chip.sautee{background:transparent;color:var(--muted);border-color:var(--line);text-decoration:line-through}
.chip.verrou{background:var(--card-2);color:var(--muted);border-color:var(--line)}
.chip.prep{background:var(--warn-dim);color:var(--warn)}
.chip.preaudit{background:var(--info-dim);color:var(--info)}
.chip.validee{background:var(--ok-dim);color:var(--ok);border-color:rgba(61,220,132,.35)}
.chip.bloquant{background:var(--bad-dim);color:var(--bad)}

/* ── formulaires ──────────────────────────────────────────────────── */
input[type=text],input[type=number],input[type=date],select,textarea{
  width:100%;padding:.62rem .78rem;border:1px solid var(--line-strong);border-radius:var(--r-sm);
  font:inherit;background:var(--bg-soft);color:var(--ink);min-height:44px;
  transition:border-color var(--t),box-shadow var(--t);
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px var(--brass-dim)}
textarea{min-height:9rem;resize:vertical;line-height:1.55}
textarea.big{min-height:16rem}
label{font-weight:600;font-size:.86rem;display:block;margin:.7rem 0 .3rem;color:var(--ink-2)}
input[type=file]{color:var(--muted)}
input[type=file]::file-selector-button{
  border:1px solid var(--line-strong);background:var(--card-2);color:var(--ink);
  padding:.5rem .9rem;border-radius:10px;margin-right:.8rem;cursor:pointer;font:500 .9rem var(--font-ui);
}
input[type=radio],input[type=checkbox]{accent-color:var(--brass);width:1.05rem;height:1.05rem}
fieldset{border:1px solid var(--line);border-radius:var(--r-sm);margin:.8rem 0;padding:.6rem 1rem}
legend{font-weight:700;font-size:.9rem;padding:0 .4rem;color:var(--ink-2)}

/* ═══ ASSISTANT D'ONBOARDING (4 actes) ════════════════════════════── */
.wizard{max-width:640px;margin:1.5rem auto}
.wizard .acte{min-height:1rem}
.wz-dots{display:flex;gap:.5rem;justify-content:center;margin:1.4rem 0}
.wz-dots i{width:8px;height:8px;border-radius:99px;background:var(--card-3);transition:all .3s var(--ease)}
.wz-dots i.on{width:26px;background:var(--brass)}
.wz-hero{text-align:center;padding:1.5rem 0 .5rem}
.wz-hero .logo-seal{width:64px;height:64px;margin-bottom:1rem}
.wz-hero h1{font-size:2.1rem;margin:.4rem 0}
.wz-hero p{color:var(--ink-2);max-width:44ch;margin:.5rem auto}
.choice-grid{display:grid;gap:.7rem;margin:.8rem 0}
@media(min-width:560px){.choice-grid{grid-template-columns:1fr 1fr}}
.choice{
  display:flex;gap:.85rem;align-items:flex-start;text-align:left;cursor:pointer;
  background:var(--card);border:1.5px solid var(--line);border-radius:var(--r);
  padding:1rem 1.05rem;transition:transform 140ms var(--spring),border-color var(--t),background var(--t),box-shadow var(--t);
}
.choice:hover{transform:translateY(-2px);border-color:var(--line-strong)}
.choice .ico{font-size:1.5rem;line-height:1;flex:none;margin-top:.1rem}
.choice b{display:block;font-size:.98rem}
.choice span{display:block;font-size:.82rem;color:var(--muted);margin-top:.15rem}
.choice.sel{border-color:var(--brass);background:linear-gradient(135deg, var(--brass-dim), transparent 60%), var(--card);box-shadow:0 0 0 1px var(--brass-glow)}
.choice.sel .ico{transform:scale(1.12)}

/* ═══ LE PLATEAU ══════════════════════════════════════════════════── */
.board{max-width:760px;margin:0 auto;position:relative}
.lvl{
  position:relative;display:flex;gap:1.1rem;align-items:center;cursor:pointer;
  transition:transform 160ms var(--spring),border-color var(--t),box-shadow var(--t);
}
.lvl:hover{transform:translateY(-2px) scale(1.005);border-color:var(--line-strong);box-shadow:var(--shadow), 0 0 24px -12px var(--lvl-c, var(--brass))}
.lvl:active{transform:scale(.99)}
.lvl:not(:last-of-type)::after{
  content:"";position:absolute;left:calc(1.3rem + 27px);top:calc(50% + 34px);
  width:2px;height:calc(100% - 40px);border-left:2px dashed var(--line-strong);
}
.lvl.done::after{border-left:2px solid rgba(61,220,132,.4)}
.lvl .medal{flex:none;position:relative;width:56px;height:56px}
.lvl .medal svg{width:56px;height:56px;transform:rotate(-90deg)}
.lvl .medal circle.prog{transition:stroke-dashoffset .9s var(--ease)}
.lvl .medal .num{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:800;font-size:1.15rem;
}
.lvl .body{flex:1;min-width:0}
.lvl h3{margin:0 0 .15rem;font-family:var(--font-display);font-weight:600;font-size:1.08rem}
.lvl .q{font-size:.86rem;color:var(--muted);margin:0 0 .3rem}
.lvl .meta{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;font-size:.8rem;color:var(--muted)}
.lvl.current{border-color:rgba(224,185,95,.55);box-shadow:0 0 0 1px var(--brass-glow), 0 10px 34px rgba(224,185,95,.09)}
.lvl.current .tag-current{
  position:absolute;top:-9px;right:14px;background:linear-gradient(180deg,var(--brass-2),var(--brass));
  color:var(--brass-ink);font-size:.68rem;font-weight:800;letter-spacing:.09em;text-transform:uppercase;
  padding:.14rem .6rem;border-radius:99px;box-shadow:0 3px 12px var(--brass-glow);
}
.lvl.done{opacity:.78}
.lvl.locked .body{opacity:.6}
.seal{
  flex:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:1rem;border:1.5px solid var(--line-strong);background:var(--bg-soft);color:var(--muted);
}
.seal.ok{background:var(--ok-dim);border-color:rgba(61,220,132,.5);color:var(--ok)}
.seal.prep{background:var(--warn-dim);border-color:rgba(255,180,84,.5);color:var(--warn)}

/* héro « prochaine action » */
.next-action{
  border:1px solid rgba(224,185,95,.4);
  background:linear-gradient(135deg, rgba(224,185,95,.13), rgba(224,185,95,.03) 55%), var(--card);
}
.next-action .action-line{font-family:var(--font-display);font-weight:600;font-size:1.18rem;line-height:1.4}
.victory{
  text-align:center;border-color:rgba(61,220,132,.4);
  background:linear-gradient(180deg, rgba(61,220,132,.1), transparent 60%), var(--card);
}

/* barre de progression */
.bar{height:6px;background:var(--bg-soft);border-radius:99px;overflow:hidden;margin:.45rem 0 .3rem}
.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--brass),var(--brass-2));border-radius:99px;transition:width .5s var(--ease)}

/* ═══ NIVEAU : timeline d'étapes ══════════════════════════════════── */
.steps{position:relative;margin:.4rem 0}
.step{
  position:relative;display:flex;gap:.95rem;align-items:flex-start;
  padding:.75rem 0 .75rem 0;
}
.step:not(:last-child)::after{
  content:"";position:absolute;left:17px;top:44px;bottom:-6px;width:2px;
  background:var(--line);
}
.step.fait:not(:last-child)::after{background:rgba(61,220,132,.35)}
.step .dot{
  flex:none;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.82rem;border:1.5px solid var(--line-strong);
  background:var(--bg-soft);color:var(--muted);z-index:1;
  font-variant-numeric:tabular-nums;
}
.step.fait .dot{background:var(--ok-dim);border-color:rgba(61,220,132,.5);color:var(--ok)}
.step.encours .dot{background:var(--warn-dim);border-color:rgba(255,180,84,.5);color:var(--warn)}
.step.sautee .dot{opacity:.45}
.step .stbody{flex:1;min-width:0;padding-top:.25rem}
.step .stbody a{color:var(--ink);font-weight:500}
.step .stbody a:hover{color:var(--brass-2);text-decoration:none}
.step.sautee .stbody{opacity:.55}
.step .stmeta{font-size:.8rem;color:var(--muted);margin-top:.1rem}

/* ═══ PORTE : cérémonie ═══════════════════════════════════════════── */
.manifest-item{
  display:flex;gap:.8rem;align-items:flex-start;border:1px solid var(--line);
  border-radius:var(--r-sm);padding:.75rem .9rem;margin:.5rem 0;background:var(--bg-soft);
  transition:border-color var(--t);
}
.manifest-item.ok{border-color:rgba(61,220,132,.4);background:linear-gradient(90deg,var(--ok-dim),transparent 45%),var(--bg-soft)}
.manifest-item .mi-ico{flex:none;font-weight:800;width:26px;text-align:center;padding-top:.05rem}
.manifest-item .mi-body{flex:1;min-width:0}
.manifest-item .mi-fmt{font-size:.8rem;color:var(--muted);margin-top:.1rem}
.manifest-item .mi-count{flex:none;font-size:.78rem;color:var(--muted);font-variant-numeric:tabular-nums}

/* contrôle segmenté 0/1/2 */
.seg{display:inline-flex;border:1px solid var(--line-strong);border-radius:10px;overflow:hidden}
.seg button{
  border:none;background:transparent;color:var(--muted);font:600 .95rem var(--font-ui);
  min-width:52px;min-height:44px;cursor:pointer;transition:background var(--t),color var(--t);
  border-left:1px solid var(--line);font-variant-numeric:tabular-nums;
}
.seg button:first-child{border-left:none}
.seg button:hover{background:var(--card-2);color:var(--ink)}
.seg button.sel{background:var(--brass);color:var(--brass-ink)}
.seg button.sel.v0{background:var(--bad);color:#fff}
.crit{border-top:1px dashed var(--line);padding:.7rem 0;display:flex;gap:1rem;align-items:center;justify-content:space-between;flex-wrap:wrap}
.crit .ct{flex:1;min-width:220px}
.gatehead{display:flex;justify-content:space-between;align-items:center;gap:.6rem;flex-wrap:wrap}
.filerow{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;border-top:1px dashed var(--line);padding:.55rem 0;font-size:.92rem}
.filerow:first-of-type{border-top:none}
.filerow select{width:auto;max-width:15rem;min-height:38px;padding:.35rem .5rem}
.item-ok{color:var(--ok);font-weight:700}
.item-ko{color:var(--muted);font-weight:700}
.item-warn{color:var(--warn);font-weight:700}

/* cérémonie de scellement */
.ceremony{
  position:fixed;inset:0;z-index:100;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:rgba(10,14,20,.9);backdrop-filter:blur(8px);
  animation:cerFade .3s var(--ease) both;
}
@keyframes cerFade{from{opacity:0}to{opacity:1}}
.ceremony .cseal{
  width:150px;height:150px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 35% 30%, var(--brass-2), var(--brass) 55%, var(--brass-3));
  color:var(--brass-ink);font-size:3.4rem;font-weight:800;
  box-shadow:0 0 0 8px rgba(224,185,95,.15), 0 0 90px 10px var(--brass-glow);
}
@media (prefers-reduced-motion: no-preference){
  .ceremony .cseal{animation:stamp .55s var(--spring) both}
}
@keyframes stamp{
  0%{transform:scale(2.4) rotate(-14deg);opacity:0}
  60%{transform:scale(.94) rotate(2deg);opacity:1}
  100%{transform:scale(1) rotate(0)}
}
.ceremony h2{font-family:var(--font-display);font-weight:800;font-size:1.7rem;color:var(--brass-2);margin:1.3rem 0 .2rem;letter-spacing:.02em}
.ceremony p{color:var(--ink-2)}
.ceremony .spark{
  position:absolute;width:7px;height:7px;border-radius:2px;background:var(--brass);
  animation:spark 1s var(--ease) both;pointer-events:none;
}
@keyframes spark{
  0%{transform:translate(0,0) scale(1) rotate(0);opacity:1}
  100%{transform:translate(var(--dx), var(--dy)) scale(.2) rotate(220deg);opacity:0}
}

/* ── rendu markdown ───────────────────────────────────────────────── */
.md{line-height:1.65}
.md h1{font-size:1.4rem}.md h2{font-size:1.15rem}.md h3{font-size:1rem;font-family:var(--font-ui);font-weight:700;color:var(--ink-2)}
.md p{margin:.6rem 0}
.md table{border-collapse:collapse;width:100%;margin:.8rem 0;font-size:.88rem;display:block;overflow-x:auto;border-radius:var(--r-sm)}
.md th,.md td{border:1px solid var(--line);padding:.5rem .65rem;text-align:left;vertical-align:top}
.md th{background:var(--card-2);color:var(--ink-2);font-weight:600;white-space:nowrap}
.md tr:nth-child(even) td{background:rgba(255,255,255,.015)}
.md blockquote{margin:.8rem 0;padding:.6rem 1rem;border-left:3px solid var(--line-strong);background:var(--bg-soft);border-radius:0 var(--r-sm) var(--r-sm) 0;color:var(--ink-2)}
.md .callout{border-radius:var(--r-sm);padding:.7rem 1rem;margin:.8rem 0;border:1px solid var(--line);border-left-width:4px;background:var(--bg-soft)}
.md .callout .co-title{font-weight:700;margin-bottom:.3rem}
.md .co-question{border-left-color:var(--info);background:var(--info-dim)}
.md .co-warning,.md .co-danger{border-left-color:var(--bad);background:var(--bad-dim)}
.md .co-tip,.md .co-note,.md .co-check{border-left-color:var(--ok);background:var(--ok-dim)}
.md code{background:var(--card-2);border:1px solid var(--line);border-radius:6px;padding:.08rem .35rem;font-size:.85em;color:var(--brass-2)}
.md pre{background:#0a0e14;border:1px solid var(--line);padding:.9rem;border-radius:var(--r-sm);overflow-x:auto;font-size:.85rem;color:var(--ink-2)}
.md pre code{background:none;border:none;color:inherit;padding:0}
.md img{max-width:100%;border-radius:var(--r-sm)}
.md hr{border:none;border-top:1px solid var(--line);margin:1.2rem 0}
.md li{margin:.2rem 0}
.md a{color:var(--info)}

/* ── bannières & toasts ───────────────────────────────────────────── */
.banner{padding:.7rem 1rem;border-radius:var(--r-sm);margin:.7rem 0;font-size:.92rem;border:1px solid transparent}
.banner.ok{background:var(--ok-dim);color:var(--ok);border-color:rgba(61,220,132,.3)}
.banner.warn{background:var(--warn-dim);color:var(--warn);border-color:rgba(255,180,84,.3)}
.banner.bad{background:var(--bad-dim);color:var(--bad);border-color:rgba(255,107,122,.3)}
.banner.info{background:var(--info-dim);color:var(--info);border-color:rgba(109,179,242,.3)}

#toast{
  position:fixed;bottom:1.3rem;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--card-3);border:1px solid var(--line-strong);color:var(--ink);
  padding:.6rem 1.1rem;border-radius:99px;font-size:.9rem;font-weight:500;
  box-shadow:var(--shadow);z-index:90;opacity:0;pointer-events:none;
  transition:opacity .25s var(--ease),transform .25s var(--ease);
}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast .tk{color:var(--ok);font-weight:800;margin-right:.35rem}

/* ── KPI ──────────────────────────────────────────────────────────── */
.kpi{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.7rem}
.kpi .card{margin:0;text-align:center;padding:1rem .6rem}
.kpi .v{font-family:var(--font-display);font-size:1.7rem;font-weight:800;color:var(--brass-2);font-variant-numeric:tabular-nums}
.kpi .l{font-size:.75rem;color:var(--muted);letter-spacing:.05em;text-transform:uppercase;margin-top:.15rem}

/* ── chat Coach ───────────────────────────────────────────────────── */
.msg{max-width:92%;margin:.6rem 0;padding:.85rem 1.05rem;border-radius:var(--r);border:1px solid var(--line)}
.msg.user{margin-left:auto;background:var(--card-2);border-top-right-radius:4px}
.msg.coach{margin-right:auto;background:var(--card);border-left:3px solid var(--brass);border-top-left-radius:4px}
@media (prefers-reduced-motion: no-preference){
  .msg.reveal{animation:viewIn .35s var(--ease) both}
}
.msg .who{font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem}
.msg.coach .who{color:var(--brass)}
.typing{display:inline-flex;gap:.25rem;align-items:center;padding:.4rem 0}
.typing i{width:6px;height:6px;border-radius:50%;background:var(--brass);animation:blink 1.2s infinite}
.typing i:nth-child(2){animation-delay:.2s}.typing i:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,80%,100%{opacity:.25}40%{opacity:1}}

/* ── divers ───────────────────────────────────────────────────────── */
.saved-pulse{display:inline-flex;align-items:center;gap:.3rem;color:var(--ok);font-size:.85rem}
.saved-pulse::before{content:"";width:7px;height:7px;border-radius:99px;background:var(--ok);animation:pulse 1s var(--ease)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(61,220,132,.5)}100%{box-shadow:0 0 0 9px transparent}}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
}
@media(max-width:640px){
  h1{font-size:1.42rem}
  #topbar{padding:.45rem .6rem}
  #topbar nav a span{display:none}
  #topbar nav a{padding:.55rem .6rem}
  .lvl{gap:.8rem}
  .lvl:not(:last-of-type)::after{left:calc(1.3rem + 23px)}
  .lvl .medal,.lvl .medal svg{width:48px;height:48px}
  .card{padding:1rem}
  .wz-hero h1{font-size:1.65rem}
  .crit{flex-direction:column;align-items:flex-start;gap:.5rem}
}
