/* ============================================================
   Humanomy — Shared design system (golden source vocabulary)
   SINGLE SOURCE OF TRUTH for all prototype screens.
   Edit here → every screen updates on refresh. No build step.
   Derived from: wip/ux-extract/golden-source-ux.html + design-system.md
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;900&display=swap');

:root{
  /* Brand — NUANCIER (source of truth) */
  --blue:#0928FF; --lime:#CCFC60; --lavender:#CACBFF; --sky:#5DA3FF; --violet:#A032F9;
  /* Neutral */
  --n0:#FFFFFF; --n50:#F8F8F8; --n100:#F3F4F6; --n200:#E5E7EB; --n300:#D1D5DB;
  --n500:#6B7280; --n900:#1A1A2E; --n950:#0A0A0A;
  /* Semantic */
  --success:#10B981; --warning:#F59E0B; --error:#EF4444; --magenta:#E040FB;
  /* Shape */
  --r-sm:8px; --r-md:12px; --r-lg:16px; --r-xl:20px; --r-pill:9999px;
  --sh-card:0 2px 8px rgba(0,0,0,.08); --sh-raised:0 4px 16px rgba(0,0,0,.10);
}

*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',system-ui,sans-serif;background:var(--n50);color:var(--n900);
  line-height:1.5;-webkit-font-smoothing:antialiased}
.app{max-width:1180px;margin:0 auto;padding:24px}

/* ---------- Logo ---------- */
.logo{display:flex;flex-direction:column}
.logo .pn{font-weight:900;font-size:18px;letter-spacing:.04em;line-height:1.1}
.logo .by{font-weight:400;font-size:11px;color:var(--n500)}
.logo .by b{color:var(--blue)}
.on-blue .logo .pn{color:#fff}
.on-blue .logo .by{color:rgba(255,255,255,.7)}

/* ---------- Typography ---------- */
.t-display{font-size:clamp(56px,9vw,120px);font-weight:900;letter-spacing:-.02em;line-height:1}
h1,.t-h1{font-size:44px;font-weight:900;letter-spacing:-.02em;line-height:1.05}
h2,.t-h2{font-size:32px;font-weight:700}
h3,.t-h3{font-size:24px;font-weight:700}
h4,.t-h4{font-size:18px;font-weight:600}
.t-body{font-size:16px;font-weight:400}
.t-cap{font-size:12px;font-weight:400;color:var(--n500)}
.amt{font-weight:900;font-variant-numeric:tabular-nums}
.eyebrow{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--n500)}
.muted{color:var(--n500)}

/* ---------- Buttons (pill) ---------- */
.btn{font-family:inherit;font-weight:600;font-size:15px;border-radius:var(--r-pill);
  padding:13px 26px;border:none;cursor:pointer;display:inline-flex;align-items:center;
  justify-content:center;gap:8px;transition:filter .12s,transform .06s}
.btn:hover{filter:brightness(.92)}
.btn:active{transform:scale(.98)}
.btn:focus-visible{outline:2px solid var(--blue);outline-offset:2px}
.btn-primary{background:var(--blue);color:#fff}
.btn-action{background:var(--lime);color:var(--blue)}        /* signature pair */
.btn-secondary{background:transparent;color:var(--blue);border:1.5px solid var(--blue)}
.btn-dark{background:var(--n900);color:#fff}
.btn-social{background:#fff;color:var(--n900);border:1.5px solid var(--n200);font-weight:500}
.btn[disabled],.btn-disabled{opacity:.4;cursor:not-allowed;pointer-events:none}
.btn-block{width:100%}
.g-icon{width:18px;height:18px;border-radius:50%;
  background:conic-gradient(#EA4335 0 25%,#FBBC05 0 50%,#34A853 0 75%,#4285F4 0 100%);display:inline-block}
.btnrow{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* ---------- Forms ---------- */
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;margin-bottom:6px;font-weight:500}
.field label .req{color:var(--error)}
.inputwrap{position:relative}
.input{width:100%;background:var(--n100);border:none;border-radius:var(--r-md);
  padding:14px;font-family:inherit;font-size:14px;color:var(--n900)}
.input::placeholder{color:var(--n500)}
.input:focus{outline:2px solid var(--blue);outline-offset:2px}
.input.error{outline:2px solid var(--error)}
.input-caption{font-size:12px;color:var(--error);margin-top:4px}
.inline-field{border:none;border-bottom:1.5px solid var(--n300);background:transparent;
  padding:8px 0;font-family:inherit;font-size:14px;width:100%;max-width:240px}
.eye{position:absolute;right:14px;top:50%;transform:translateY(-50%);
  color:var(--n500);font-size:15px;cursor:pointer;user-select:none}
/* on blue panels */
.on-blue .field label{color:#fff}
.on-blue .field label .req{color:var(--lime)}
.on-blue .input{background:#fff}
.on-blue .input:focus{outline-color:#fff}

/* controls */
.ctrl-row{display:flex;align-items:center;gap:10px;font-size:14px}
.radio{width:22px;height:22px;border-radius:50%;border:2px solid var(--n300);flex:0 0 auto;cursor:pointer}
.radio.on{border-color:var(--success);background:var(--success);position:relative}
.radio.on::after{content:"✓";color:#fff;font-size:13px;position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center}
.on-blue .radio{border-color:rgba(255,255,255,.6)}
.on-blue .radio.on{border-color:var(--lime);background:var(--lime)}
.on-blue .radio.on::after{color:var(--blue)}
.checkbox{width:24px;height:24px;border-radius:50%;border:2px solid var(--n300);flex:0 0 auto;cursor:pointer}
.checkbox.on{border-color:var(--success);background:var(--success);position:relative}
.checkbox.on::after{content:"✓";color:#fff;font-size:14px;position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center}
.switch{width:46px;height:26px;border-radius:var(--r-pill);background:var(--n900);
  position:relative;flex:0 0 auto;cursor:pointer;transition:background .15s}
.switch::after{content:"";width:20px;height:20px;border-radius:50%;background:#fff;
  position:absolute;top:3px;right:3px;transition:all .15s}
.switch.off{background:var(--n300)}
.switch.off::after{left:3px;right:auto}

/* ---------- Cards ---------- */
.card{border-radius:var(--r-lg);padding:18px}
.card-neutral{background:#fff;box-shadow:var(--sh-card)}
.card-soft-sky{background:#DBEAFE}
.card-soft-lav{background:var(--lavender)}
.card-highlight{background:var(--lime);color:var(--blue)}
.card-selected{background:var(--n100);border:2px solid var(--n900)}
.hero{position:relative;border-radius:var(--r-lg);overflow:hidden;color:#fff;
  padding:32px;background:linear-gradient(135deg,#1A1A2E,#0928FF)}
.hero::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.25)}
.hero>*{position:relative}

/* service cards (2x2 colour grid) */
.svc{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.svc .s{border-radius:var(--r-xl);padding:18px;min-height:120px;display:flex;
  flex-direction:column;justify-content:space-between}
.s.lime{background:var(--lime);color:var(--blue)}
.s.lav{background:var(--lavender);color:var(--n900)}
.s.sky{background:var(--sky);color:var(--n900)}
.s.blue{background:var(--blue);color:#fff}
.s .st{font-weight:700;font-size:15px}
.s .scta{font-size:12px;font-weight:600;margin-top:10px;text-decoration:underline}

/* ---------- KPI ---------- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.kpi{border-radius:var(--r-lg);padding:18px;background:#fff;box-shadow:var(--sh-card)}
.kpi.highlight{background:var(--lime);color:var(--blue);box-shadow:none}
.kpi .clbl{font-size:11px;color:var(--n500);font-weight:500}
.kpi.highlight .clbl{color:var(--blue);opacity:.75}
.kpi .camt{font-size:28px;font-weight:900;margin-top:4px;font-variant-numeric:tabular-nums}
.kpi .up{font-size:12px;color:var(--success);font-weight:600;margin-top:4px}
.kpi.highlight .up{color:var(--blue)}

/* ---------- Badges / chips ---------- */
.pillrow{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.badge{border-radius:var(--r-pill);padding:5px 12px;font-size:12px;font-weight:600;display:inline-block}
.badge.lime{background:var(--lime);color:var(--blue)}
.badge.blue{background:var(--blue);color:#fff}
.badge.success{background:var(--success);color:#fff}
.badge.warn{background:var(--warning);color:#fff}
.badge.err{background:var(--error);color:#fff}
.chip{border-radius:var(--r-pill);padding:6px 14px;font-size:13px;border:1.5px solid var(--n300);
  background:#fff;cursor:pointer;user-select:none}
.chip.on{border-color:var(--blue);color:var(--blue);font-weight:600}

/* ---------- Navigation ---------- */
.navbar{display:flex;align-items:center;justify-content:space-between;background:#fff;
  padding:10px 16px;border-radius:var(--r-lg);box-shadow:var(--sh-card);margin-bottom:20px}
.navpill{display:flex;gap:4px;border:1.5px solid var(--n200);border-radius:var(--r-pill);padding:4px}
.navpill a{font-size:13px;padding:8px 16px;border-radius:var(--r-pill);color:var(--n500);
  text-decoration:none;white-space:nowrap}
.navpill a.on{color:var(--blue);font-weight:600}
.navpill a.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}
.nav-id{display:flex;align-items:center;gap:8px}
.nav-id .who{text-align:right;font-size:11px}
.nav-id .who b{font-size:12px}
.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--sky),var(--violet))}

/* sidebar greyed roadmap section */
.side-section{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  color:var(--n500);margin:18px 0 8px}
.side-link{display:block;padding:9px 12px;border-radius:var(--r-md);font-size:14px;
  color:var(--n900);text-decoration:none}
.side-link.on{background:var(--n100);font-weight:600;color:var(--blue)}
.side-link.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}
.side-link.disabled::after{content:" · bientôt";font-size:11px;color:var(--n500)}

/* left icon rail */
.rail{display:flex;flex-direction:column;gap:14px;align-items:center;padding:16px 8px}
.rail .ico{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;background:var(--n100);color:var(--n500);font-size:18px;cursor:pointer}
.rail .ico.on{background:var(--blue);color:#fff}

/* accordion */
.acc{background:#fff;border-radius:var(--r-lg);box-shadow:var(--sh-card);overflow:hidden}
.acc .it{display:flex;align-items:center;gap:14px;padding:16px 18px;border-bottom:1px solid var(--n200);cursor:pointer}
.acc .it:last-child{border-bottom:none}
.acc .num{font-size:15px;color:var(--n500);font-weight:700;font-family:ui-monospace,monospace}
.acc .ttl{font-weight:600;font-size:15px;flex:1}
.acc .chev{color:var(--n500)}

/* ---------- Data display ---------- */
.divider-label{display:flex;align-items:center;gap:14px;margin:18px 0;font-size:12px;
  color:var(--n500);font-weight:500}
.divider-label::before,.divider-label::after{content:"";flex:1;height:1px;background:var(--n200)}
.on-blue .divider-label{color:rgba(255,255,255,.8)}
.on-blue .divider-label::before,.on-blue .divider-label::after{background:rgba(255,255,255,.3)}
.benefit{display:flex;align-items:flex-start;gap:10px;margin:8px 0;font-size:14px}
.benefit .ck{width:22px;height:22px;border-radius:50%;background:var(--success);color:#fff;
  flex:0 0 auto;display:flex;align-items:center;justify-content:center;font-size:13px}
.summary-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;
  border-bottom:1px solid var(--n200);font-size:14px}
.summary-row:last-child{border-bottom:none}
.summary-row .lbl{color:var(--n500)}
.summary-row .val{font-weight:700;font-variant-numeric:tabular-nums}
.link{color:var(--blue);text-decoration:underline;cursor:pointer}
.on-blue .link{color:var(--lime)}

/* chart box (charts rendered inline SVG per screen) */
.chartbox{background:var(--n100);border-radius:var(--r-lg);padding:18px;box-shadow:var(--sh-card)}
.charttitle{font-size:13px;font-weight:600;margin-bottom:10px}
.marker{background:var(--n900);color:#fff;font-size:11px;padding:4px 10px;border-radius:var(--r-pill);display:inline-block}
.legend{display:flex;gap:14px;margin-top:12px;font-size:12px;flex-wrap:wrap}
.legend span{display:flex;align-items:center;gap:6px}
.dot{width:10px;height:10px;border-radius:50%;display:inline-block}

/* advisor */
.advisor{display:flex;align-items:center;gap:14px;background:#fff;border-radius:var(--r-lg);
  padding:16px;box-shadow:var(--sh-card)}
.advisor .photo{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--sky),var(--lavender));flex:0 0 auto}

/* ---------- Layout helpers ---------- */
.stack{display:flex;flex-direction:column}
.row{display:flex;gap:16px;align-items:center}
.between{justify-content:space-between}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
.gap-sm{gap:8px}.gap-lg{gap:24px}
.mt{margin-top:16px}.mt-lg{margin-top:24px}.mb{margin-bottom:16px}
.sticky-bottom{position:sticky;bottom:0;background:var(--n50);padding:16px 0;margin-top:auto}

/* ---------- Stepper (funnel) ---------- */
.stepper{display:flex;gap:6px;margin-bottom:20px}
.stepper .seg{flex:1;height:5px;border-radius:var(--r-pill);background:var(--n200)}
.stepper .seg.done{background:var(--blue)}

/* ---------- Demo annotation banner (review aid; remove for real build) ---------- */
.annot{background:var(--n900);color:#fff;font-size:11px;padding:6px 16px;text-align:center;
  font-weight:500;letter-spacing:.03em;position:sticky;top:0;z-index:99}
.annot b{color:var(--lime)}
.annot a{color:#fff}

/* ---------- Responsive ---------- */
@media(max-width:768px){
  .kpis{grid-template-columns:1fr 1fr}
  .grid-2{grid-template-columns:1fr}
  .svc{grid-template-columns:1fr}
  .navpill{display:none}
}
