/* ── Design Tokens & Component Styles ────────────────────────────────────────
   Single stylesheet for the whole app.
   Design: clinical-warm palette, teal accent, serif display font.
   See CLAUDE_CODE_HANDOFF.md for token reference.
─────────────────────────────────────────────────────────────────────────── */

/* ============================================================
   DESIGN TOKENS
   Palette: clinical but warm — deep ink, clean paper, a
   considered teal as the single accent, amber for caution.
   ============================================================ */
:root{
  --ink:#1a2332;
  --ink-soft:#3d4a5c;
  --ink-faint:#6b7888;
  --paper:#fbfaf7;
  --paper-raised:#ffffff;
  --line:#e4e0d8;
  --line-strong:#cdc8bd;
  --accent:#1f7a8c;
  --accent-deep:#155e6d;
  --accent-wash:#e8f2f4;
  --amber:#c77d2e;
  --amber-wash:#fbf0e1;
  --rose:#b23a48;
  --rose-wash:#f7e8ea;
  --green:#3a7d44;
  --green-wash:#e7f1e8;
  --shadow:0 1px 2px rgba(26,35,50,.04),0 4px 16px rgba(26,35,50,.06);
  --shadow-lg:0 2px 8px rgba(26,35,50,.06),0 12px 40px rgba(26,35,50,.10);
  --radius:14px;
  --radius-sm:9px;
  --font-display:"Iowan Old Style","Palatino Linotype",Palatino,"Book Antiqua",Georgia,serif;
  --font-body:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --font-mono:"SF Mono",ui-monospace,"Cascadia Mono","Roboto Mono",Menlo,Consolas,monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
}

/* ============================================================
   APP SHELL
   ============================================================ */
.app{min-height:100vh;display:flex;flex-direction:column}

.topbar{
  background:var(--paper-raised);
  border-bottom:1px solid var(--line);
  padding:0 clamp(16px,4vw,40px);
  height:64px;
  display:flex;align-items:center;gap:16px;
  position:sticky;top:0;z-index:50;
}
.brand{display:flex;align-items:center;gap:12px;cursor:pointer;user-select:none}
.brand-mark{
  width:34px;height:34px;border-radius:9px;
  background:linear-gradient(135deg,var(--accent),var(--accent-deep));
  display:grid;place-items:center;flex-shrink:0;
  box-shadow:0 2px 8px rgba(31,122,140,.25);
}
.brand-mark svg{width:20px;height:20px}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-text b{font-family:var(--font-display);font-size:17px;font-weight:600;letter-spacing:-.01em}
.brand-text span{font-size:11px;color:var(--ink-faint);letter-spacing:.04em;text-transform:uppercase}
.topbar-spacer{flex:1}
.topbar-meta{font-size:13px;color:var(--ink-faint);display:none}
@media(min-width:720px){.topbar-meta{display:block}}

.main{flex:1;width:100%;max-width:1320px;margin:0 auto;padding:clamp(14px,2.4vw,26px) clamp(16px,4vw,40px) 40px}

/* ============================================================
   VIEW TRANSITIONS
   ============================================================ */
.view{display:none;animation:fade .35s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ============================================================
   TYPOGRAPHY HELPERS
   ============================================================ */
.eyebrow{
  font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent);margin-bottom:6px;
}
h1.page-title{font-family:var(--font-display);font-size:clamp(24px,4vw,32px);font-weight:600;letter-spacing:-.02em;line-height:1.12;margin-bottom:8px}
.lede{font-size:clamp(15px,2vw,17px);color:var(--ink-soft);max-width:60ch;margin-bottom:8px}

/* ============================================================
   HOME — TEST GRID
   ============================================================ */
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin:36px 0 18px;flex-wrap:wrap}
.section-head h2{font-family:var(--font-display);font-size:22px;font-weight:600;letter-spacing:-.01em}
.section-head .count{font-size:13px;color:var(--ink-faint)}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:16px}

.card{
  background:var(--paper-raised);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:17px 18px;
  cursor:pointer;
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  text-align:left;width:100%;font:inherit;color:inherit;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--line-strong)}
.card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.card[disabled]{cursor:not-allowed;opacity:.6}
.card[disabled]:hover{transform:none;box-shadow:none;border-color:var(--line)}

.card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.card-tag{
  font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  padding:4px 9px;border-radius:6px;
}
.tag-autism{background:var(--accent-wash);color:var(--accent-deep)}
.tag-adhd{background:var(--amber-wash);color:var(--amber)}
.tag-sensory{background:var(--green-wash);color:var(--green)}
.tag-social{background:#ece8f5;color:#5b4b8a}
.tag-behaviour{background:#e6eef5;color:#3a5a7a}
.tag-mood{background:#f3e3ec;color:#8a4a6b}

.card-soon{font-size:11px;font-weight:600;color:var(--ink-faint);background:var(--line);padding:4px 9px;border-radius:6px;letter-spacing:.03em}

.card h3{font-family:var(--font-display);font-size:19px;font-weight:600;letter-spacing:-.01em;margin-bottom:4px;line-height:1.2}
.card .card-full{font-size:13px;color:var(--ink-faint);margin-bottom:12px}
.card .card-desc{font-size:14px;color:var(--ink-soft);line-height:1.5;flex:1}
.card-foot{display:flex;align-items:center;gap:14px;margin-top:12px;padding-top:11px;border-top:1px solid var(--line);font-size:12.5px;color:var(--ink-faint)}
.card-foot span{display:flex;align-items:center;gap:5px}
.card-foot svg{width:14px;height:14px;opacity:.7}
.card-age{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;padding:5px 10px;border-radius:7px;margin-top:10px;width:fit-content}
.card-age svg{width:13px;height:13px;flex-shrink:0}
.card-age-ok{background:var(--accent-wash);color:var(--accent-deep)}
.card-age-warn{background:var(--amber-wash);color:var(--amber)}
.card-age-plain{background:var(--line);color:var(--ink-soft)}

/* family tile (e.g. AQ → child/adolescent/adult) */
.card-versions{font-size:11px;font-weight:600;letter-spacing:.03em;color:var(--accent-deep);background:var(--accent-wash);padding:4px 9px;border-radius:6px}
.card-cta{display:flex;align-items:center;gap:6px;margin-top:10px;font-size:13px;font-weight:600;color:var(--accent)}
.card-cta svg{width:15px;height:15px;transition:transform .18s ease}
.card-family:hover .card-cta svg{transform:translateX(3px)}

/* ============================================================
   MODAL / CHOOSER
   ============================================================ */
#modalRoot{position:fixed;inset:0;z-index:200;display:none}
#modalRoot.show{display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(26,35,50,.45);animation:fade .18s ease}
.modal{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(460px,92vw);
  background:var(--paper-raised);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);padding:clamp(22px,3vw,30px);max-height:86vh;overflow:auto;
  animation:modalIn .22s cubic-bezier(.4,0,.2,1)}
@keyframes modalIn{from{opacity:0;transform:translate(-50%,-46%)}to{opacity:1;transform:translate(-50%,-50%)}}
.modal-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:24px;line-height:1;
  color:var(--ink-faint);cursor:pointer;padding:2px 8px;border-radius:6px;transition:all .14s ease}
.modal-close:hover{color:var(--ink);background:var(--line)}
.modal-eyebrow{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);margin-bottom:5px}
.modal-title{font-family:var(--font-display);font-size:23px;font-weight:600;letter-spacing:-.01em;line-height:1.15}
.modal-sub{font-size:14px;color:var(--ink-soft);margin:5px 0 18px}
.chooser-list{display:flex;flex-direction:column;gap:10px}
.chooser-row{display:flex;align-items:center;justify-content:space-between;gap:14px;text-align:left;width:100%;font:inherit;
  padding:14px 16px;border:1.5px solid var(--line-strong);border-radius:var(--radius-sm);background:var(--paper);
  color:inherit;cursor:pointer;transition:border-color .14s ease,background .14s ease}
.chooser-row:hover{border-color:var(--accent);background:var(--accent-wash)}
.chooser-row:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.chooser-name{display:block;font-family:var(--font-display);font-size:17px;font-weight:600;color:var(--ink)}
.chooser-sub{display:block;font-size:13px;color:var(--ink-faint);margin-top:2px}
.chooser-row svg{width:18px;height:18px;color:var(--ink-faint);flex-shrink:0;transition:transform .14s ease}
.chooser-row:hover svg{transform:translateX(3px);color:var(--accent)}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  font:inherit;font-weight:600;font-size:15px;
  padding:12px 22px;border-radius:var(--radius-sm);
  border:1px solid transparent;cursor:pointer;
  transition:transform .12s ease,box-shadow .12s ease,background .15s ease;
  display:inline-flex;align-items:center;gap:9px;justify-content:center;
  text-decoration:none;line-height:1;
}
.btn:active{transform:translateY(1px)}
.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(31,122,140,.22)}
.btn-primary:hover{background:var(--accent-deep);box-shadow:0 4px 14px rgba(31,122,140,.3)}
.btn-ghost{background:transparent;color:var(--ink-soft);border-color:var(--line-strong)}
.btn-ghost:hover{background:var(--paper-raised);border-color:var(--ink-faint);color:var(--ink)}
.btn-lg{padding:12px 28px;font-size:16px}
.btn[disabled]{opacity:.45;cursor:not-allowed;pointer-events:none}

/* ============================================================
   INTAKE FORM
   ============================================================ */
.intake-wrap{max-width:1040px;margin:0 auto}
.intake-layout{display:grid;grid-template-columns:minmax(250px,330px) minmax(0,1fr);gap:clamp(28px,4vw,52px);align-items:start}
.intake-intro .page-title{margin-bottom:10px}
.intake-intro .lede{margin-bottom:18px}
.intake-intro .intake-note{margin-bottom:0}
@media(max-width:820px){.intake-layout{grid-template-columns:1fr;gap:18px}}
.intake-card{background:var(--paper-raised);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(18px,3vw,26px);box-shadow:var(--shadow)}
.field{margin-bottom:11px}
.field:last-child{margin-bottom:0}
.field label{display:block;font-size:13.5px;font-weight:600;color:var(--ink-soft);margin-bottom:7px;letter-spacing:.01em}
.field .opt{font-weight:400;color:var(--ink-faint);font-size:12.5px}
.field input,.field select{
  width:100%;font:inherit;font-size:15px;
  padding:9px 13px;border:1px solid var(--line-strong);border-radius:var(--radius-sm);
  background:var(--paper);color:var(--ink);transition:border-color .15s ease,box-shadow .15s ease;
}
.field input:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-wash)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:520px){.field-row{grid-template-columns:1fr}}
.intake-note{font-size:13px;color:var(--ink-faint);background:var(--accent-wash);border-radius:var(--radius-sm);padding:10px 14px;margin-bottom:16px;display:flex;gap:10px;align-items:flex-start}
.intake-note svg{width:17px;height:17px;flex-shrink:0;margin-top:1px;color:var(--accent-deep)}
.age-warning{background:var(--amber-wash);border:1px solid #efd9bb;border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:20px;display:flex;gap:11px;align-items:flex-start;font-size:13.5px;color:var(--ink-soft);line-height:1.5}
.age-warning svg{width:18px;height:18px;flex-shrink:0;margin-top:1px;color:var(--amber)}
.age-warning b{color:var(--amber);display:block;margin-bottom:3px}
.intake-actions{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap}

/* ============================================================
   QUESTION RUNNER
   ============================================================ */
.runner{max-width:860px;margin:0 auto}
.runner-rmet{max-width:1120px}
.runner-head{margin-bottom:16px}
.runner-head .test-name{font-family:var(--font-display);font-size:19px;font-weight:600;letter-spacing:-.01em;margin-bottom:10px}
.progress-track{height:6px;background:var(--line);border-radius:99px;overflow:hidden;margin-bottom:8px}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-deep));border-radius:99px;transition:width .4s cubic-bezier(.4,0,.2,1);width:0%}
.progress-label{display:flex;justify-content:space-between;font-size:12.5px;color:var(--ink-faint)}

.q-stage{position:relative;min-height:200px}
.q-card{
  background:var(--paper-raised);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(24px,3vw,40px) clamp(24px,4vw,52px);box-shadow:var(--shadow);text-align:center;
}
.q-number{font-family:var(--font-mono);font-size:13px;color:var(--accent);font-weight:600;letter-spacing:.02em;margin-bottom:14px}
.q-stem{font-size:15px;line-height:1.45;color:var(--ink-soft);max-width:46ch;margin:0 auto 14px;font-weight:600}
.q-text{font-family:var(--font-display);font-size:clamp(21px,2.4vw,29px);font-weight:500;line-height:1.3;letter-spacing:-.01em;margin:0 auto 26px;max-width:34ch;color:var(--ink)}

/* horizontal response row — one column per option (Likert) or per point (scale) */
.opt-row{display:grid;grid-template-columns:repeat(var(--n),minmax(0,1fr));gap:10px}
.opt-btn{
  font:inherit;font-size:15.5px;text-align:left;
  padding:15px 18px;border:1.5px solid var(--line-strong);border-radius:var(--radius-sm);
  background:var(--paper);color:var(--ink-soft);cursor:pointer;
  transition:border-color .14s ease,background .14s ease,color .14s ease,transform .1s ease;
  display:flex;align-items:center;gap:13px;width:100%;
}
.opt-btn:hover{border-color:var(--accent);background:var(--accent-wash);color:var(--ink)}
.opt-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.opt-btn.selected{border-color:var(--accent);background:var(--accent-wash);color:var(--ink);font-weight:600}
.opt-btn .opt-key{
  width:26px;height:26px;border-radius:7px;border:1.5px solid var(--line-strong);
  display:grid;place-items:center;font-size:12.5px;font-weight:700;font-family:var(--font-mono);
  flex-shrink:0;transition:all .14s ease;color:var(--ink-faint);
}
.opt-btn:hover .opt-key,.opt-btn.selected .opt-key{border-color:var(--accent);background:var(--accent);color:#fff}
/* Likert option: stacked & centered (key chip over label) */
.opt-btn.likert-btn{flex-direction:column;justify-content:flex-start;align-items:center;text-align:center;gap:11px;padding:18px 12px;min-height:112px}
.opt-btn.likert-btn .opt-label{font-size:15px;font-weight:500;line-height:1.25;color:inherit}
/* 1–N scale point */
.opt-btn.scale-btn{justify-content:center;padding:14px 0;min-height:58px}
.opt-btn.scale-btn .opt-num{font-family:var(--font-display);font-size:23px;font-weight:600;line-height:1;color:inherit}
.scale-anchors{display:flex;justify-content:space-between;font-size:12.5px;color:var(--ink-faint);margin:0 2px 7px}

.q-anim-next{animation:slideNext .32s cubic-bezier(.4,0,.2,1)}
.q-anim-prev{animation:slidePrev .32s cubic-bezier(.4,0,.2,1)}
@keyframes slideNext{from{opacity:0;transform:translateX(24px)}to{opacity:1;transform:none}}
@keyframes slidePrev{from{opacity:0;transform:translateX(-24px)}to{opacity:1;transform:none}}

.runner-nav{display:flex;justify-content:space-between;align-items:center;margin-top:16px;gap:12px}
.nav-dots{display:flex;gap:5px;flex-wrap:wrap;justify-content:center;max-width:50%}
.nav-dot{width:7px;height:7px;border-radius:99px;background:var(--line-strong);transition:all .2s ease;cursor:pointer;border:none;padding:0}
.nav-dot.done{background:var(--accent)}
.nav-dot.current{background:var(--accent);transform:scale(1.5)}
.nav-dot.flagged{background:var(--amber)}
.nav-dot.locked{opacity:.3;cursor:not-allowed}

.unanswered-hint{font-size:13px;color:var(--amber);margin-top:14px;text-align:center;display:none}
.unanswered-hint.show{display:block}

/* ============================================================
   RMET RUNNER (image-based test)
   ============================================================ */
.rmet-practice-tag{display:inline-block;font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:.02em;
  color:var(--amber);background:var(--amber-wash);border:1px solid #ecd3ab;border-radius:99px;padding:3px 11px;margin-top:8px}
.rmet-stage{background:var(--paper-raised);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(18px,2.2vw,26px);box-shadow:var(--shadow)}
.rmet-instruct{font-size:14px;line-height:1.45;color:var(--ink-soft);margin-bottom:14px}
/* two-column: large eye photo on the left, prompt + word options on the right */
.rmet-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(300px,0.82fr);gap:24px;align-items:center}
.rmet-answer{display:flex;flex-direction:column;gap:11px;min-width:0}
.rmet-photo-wrap{display:flex;align-items:center;justify-content:center;background:#000;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--line-strong)}
.rmet-photo{display:block;width:100%;height:auto;max-height:min(58vh,470px)}
.rmet-prompt{font-family:var(--font-display);font-size:clamp(16px,1.5vw,20px);font-weight:500;line-height:1.3;
  text-align:left;color:var(--ink);margin:0 0 4px}
.rmet-options{display:flex;flex-direction:column;gap:10px}
.rmet-opt{font:inherit;font-size:16px;text-align:left;padding:13px 16px;border:1.5px solid var(--line-strong);
  border-radius:var(--radius-sm);background:var(--paper);color:var(--ink-soft);cursor:pointer;
  transition:border-color .14s ease,background .14s ease,color .14s ease;display:flex;align-items:center;gap:12px;width:100%}
.rmet-opt:hover{border-color:var(--accent);background:var(--accent-wash);color:var(--ink)}
.rmet-opt:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.rmet-opt.selected{border-color:var(--accent);background:var(--accent-wash);color:var(--ink);font-weight:600}
.rmet-opt .opt-key{width:26px;height:26px;border-radius:7px;border:1.5px solid var(--line-strong);
  display:grid;place-items:center;font-size:12.5px;font-weight:700;font-family:var(--font-mono);
  flex-shrink:0;transition:all .14s ease;color:var(--ink-faint)}
.rmet-opt:hover .opt-key,.rmet-opt.selected .opt-key{border-color:var(--accent);background:var(--accent);color:#fff}
.rmet-opt.correct{border-color:var(--green);background:var(--green-wash);color:var(--ink)}
.rmet-opt.correct .opt-key{border-color:var(--green);background:var(--green);color:#fff}
.rmet-opt.incorrect{border-color:var(--rose);background:var(--rose-wash);color:var(--ink)}
.rmet-opt.incorrect .opt-key{border-color:var(--rose);background:var(--rose);color:#fff}
.rmet-feedback{display:none;margin-top:16px;padding:13px 16px;border:1px solid var(--line);border-radius:var(--radius-sm);
  background:var(--paper);font-size:14px;line-height:1.5;color:var(--ink-soft)}
.rmet-feedback.show{display:block}
/* stack the two columns only if the window gets narrow */
@media(max-width:820px){.rmet-grid{grid-template-columns:1fr;gap:14px}}
@media(max-height:760px){.rmet-photo{max-height:46vh}}

/* RMET results: chance marker + timing */
.rmet-chance{position:absolute;top:6px;bottom:6px;width:2px;background:repeating-linear-gradient(var(--ink-faint),var(--ink-faint) 3px,transparent 3px,transparent 6px);z-index:4}
.rmet-chance-key{display:inline-block;width:14px;height:0;border-top:2px dashed var(--ink-faint);vertical-align:middle}
.rmet-time-grid{display:flex;flex-wrap:wrap;gap:12px}
.rmet-time-cell{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 18px;text-align:center;min-width:120px}
.rmet-time-cell .rt-val{display:block;font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--ink)}
.rmet-time-cell .rt-lbl{display:block;font-size:12px;color:var(--ink-faint);margin-top:3px}

/* ============================================================
   RESULTS DASHBOARD
   ============================================================ */
.results{max-width:1000px;margin:0 auto}
.result-banner{
  background:linear-gradient(135deg,var(--accent-deep),var(--accent));
  border-radius:var(--radius);padding:clamp(22px,4vw,32px);color:#fff;margin-bottom:24px;
  position:relative;overflow:hidden;box-shadow:var(--shadow-lg);
}
.result-banner::after{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.06)}
.result-banner .rb-test{font-size:13px;letter-spacing:.05em;text-transform:uppercase;opacity:.85;margin-bottom:6px;font-weight:600}
.result-banner .rb-client{font-family:var(--font-display);font-size:clamp(22px,4vw,30px);font-weight:600;letter-spacing:-.01em;position:relative}
.result-banner .rb-meta{display:flex;gap:20px;margin-top:14px;flex-wrap:wrap;position:relative}
.result-banner .rb-meta div{font-size:13.5px}
.result-banner .rb-meta b{display:block;font-size:11px;opacity:.8;text-transform:uppercase;letter-spacing:.04em;font-weight:600;margin-bottom:2px}

.score-hero{display:grid;grid-template-columns:auto 1fr;gap:clamp(20px,4vw,36px);align-items:center;background:var(--paper-raised);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,4vw,32px);margin-bottom:24px;box-shadow:var(--shadow)}
@media(max-width:560px){.score-hero{grid-template-columns:1fr;text-align:center}}
.score-ring{position:relative;width:140px;height:140px;flex-shrink:0;margin:0 auto}
.score-ring svg{transform:rotate(-90deg)}
.score-ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.score-ring-center .val{font-family:var(--font-display);font-size:38px;font-weight:700;line-height:1;color:var(--ink)}
.score-ring-center .max{font-size:13px;color:var(--ink-faint);margin-top:2px}
.score-summary .ss-label{font-size:13px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.04em;font-weight:600;margin-bottom:8px}
.score-summary h2{font-family:var(--font-display);font-size:clamp(22px,4vw,28px);font-weight:600;letter-spacing:-.01em;margin-bottom:10px;line-height:1.2}
.score-summary p{font-size:15px;color:var(--ink-soft);line-height:1.55;max-width:48ch}
.band-pill{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;padding:6px 13px;border-radius:99px;margin-top:12px}
.band-typical{background:var(--green-wash);color:var(--green)}
.band-elevated{background:var(--amber-wash);color:var(--amber)}
.band-high{background:var(--rose-wash);color:var(--rose)}
.band-neutral{background:var(--accent-wash);color:var(--accent-deep)}

.panel{background:var(--paper-raised);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(20px,4vw,28px);margin-bottom:24px;box-shadow:var(--shadow)}
.panel-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:6px;flex-wrap:wrap}
.panel-head h3{font-family:var(--font-display);font-size:19px;font-weight:600;letter-spacing:-.01em}
.panel-sub{font-size:13.5px;color:var(--ink-faint);margin-bottom:22px;max-width:62ch}

/* percentile / comparison bars */
.cmp-row{margin-bottom:20px}
.cmp-row:last-child{margin-bottom:0}
.cmp-label{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px;gap:12px}
.cmp-label .name{font-size:14.5px;font-weight:600;color:var(--ink)}
.cmp-label .sub{font-size:12.5px;color:var(--ink-faint)}
.cmp-label .score{font-family:var(--font-mono);font-size:13.5px;font-weight:600;color:var(--accent-deep)}
.cmp-bar-track{position:relative;height:34px;background:var(--paper);border:1px solid var(--line);border-radius:8px;overflow:hidden}
.cmp-bar-fill{position:absolute;left:0;top:0;bottom:0;border-radius:7px 0 0 7px;transition:width .7s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;padding-left:11px}
.cmp-bar-fill .pct{font-size:12.5px;font-weight:700;color:#fff;white-space:nowrap;text-shadow:0 1px 2px rgba(0,0,0,.15)}
.fill-typical{background:linear-gradient(90deg,var(--green),#4a9456)}
.fill-elevated{background:linear-gradient(90deg,var(--amber),#d98f3f)}
.fill-high{background:linear-gradient(90deg,var(--rose),#c54e5b)}
.fill-accent{background:linear-gradient(90deg,var(--accent),var(--accent-deep))}

/* unified profile table (SDQ + others): scale · score · normative track (mean±1SD + ● marker) · %ile · band */
.profile-table{--cols:minmax(120px,1.15fr) 50px minmax(120px,2.5fr) 50px 116px;display:flex;flex-direction:column}
.profile-table .ph{display:grid;grid-template-columns:var(--cols);gap:16px;align-items:end;font-size:10.5px;text-transform:uppercase;letter-spacing:.03em;color:var(--ink-faint);padding-bottom:7px;border-bottom:1px solid var(--line)}
.profile-table .ph span.r{text-align:right}
.profile-table .ph span.c{text-align:center}
.sdq-u-row{display:grid;grid-template-columns:var(--cols);gap:16px;align-items:center;padding:9px 0;border-top:1px solid var(--line)}
.sdq-u-row:first-of-type{border-top:none}
.sdq-u-lead{padding:4px 0 10px}
.sdq-u-lead .sdq-name{font-size:16px;font-weight:700}
.sdq-u-lead .sdq-score{font-size:19px;font-weight:700}
.sdq-u-sub .sdq-name{padding-left:12px}
.sdq-name{font-size:14.5px;color:var(--ink);font-weight:600;display:flex;flex-direction:column;line-height:1.2}
.sdq-note{font-weight:400;font-size:11.5px;color:var(--ink-faint)}
.sdq-score{font-size:14.5px;font-weight:600;color:var(--ink);white-space:nowrap;text-align:right;font-variant-numeric:tabular-nums}
.sdq-max{color:var(--ink-faint);font-weight:500}
.sdq-track{position:relative;height:24px}
.sdq-track .norm-marker-dot{width:14px;height:14px;border-width:2px}
.sdq-track .norm-group-mean{height:22px}
.sdq-track .norm-group-band{height:14px;border-radius:4px;opacity:.4}
.sdq-pct{font-size:13.5px;font-weight:600;color:var(--ink-soft);white-space:nowrap;text-align:right;font-variant-numeric:tabular-nums}
.sdq-pct-empty{color:var(--ink-faint)}
.sdq-u-row .band-pill{margin-top:0;justify-self:stretch;justify-content:center;white-space:nowrap}
/* cut-off ticks on a track (HSC sensitivity boundaries, Vanderbilt thresholds, etc.) */
.hsc-cut{position:absolute;top:50%;width:2px;height:18px;transform:translate(-50%,-50%);background:var(--ink-faint);z-index:3}
/* Vanderbilt: count-vs-cutoff bar inside a track */
.vand-bar{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);height:8px;background:var(--line);border-radius:99px;overflow:hidden}
.vand-bar-fill{position:absolute;left:0;top:0;height:100%;border-radius:99px}
@media(max-width:680px){.sdq-track,.sdq-pct,.profile-table .ph .col-opt{display:none}}

/* normative comparison band chart */
.norm-chart{margin-top:6px}
.norm-item{margin-bottom:24px}
.norm-item:last-child{margin-bottom:4px}
.norm-item-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px;gap:12px}
.norm-item-head .nm{font-size:14.5px;font-weight:600}
.norm-item-head .nv{font-family:var(--font-mono);font-size:13px;color:var(--ink-soft)}
.norm-scale{position:relative;height:48px;margin:0 6px}
.norm-axis{position:absolute;left:0;right:0;top:50%;height:2px;background:var(--line-strong);transform:translateY(-50%)}
.norm-group-band{position:absolute;top:50%;height:22px;transform:translateY(-50%);border-radius:5px;opacity:.32}
.norm-group-mean{position:absolute;top:50%;width:2px;height:30px;transform:translate(-50%,-50%)}
.norm-marker{position:absolute;top:50%;transform:translate(-50%,-50%);z-index:5}
.norm-marker-dot{width:18px;height:18px;border-radius:50%;background:var(--ink);border:3px solid var(--paper-raised);box-shadow:0 2px 6px rgba(0,0,0,.2)}
.norm-marker-label{position:absolute;top:-26px;left:50%;transform:translateX(-50%);font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--ink);white-space:nowrap;background:var(--paper-raised);padding:1px 6px;border-radius:4px;border:1px solid var(--line)}
.norm-legend{display:flex;gap:18px;flex-wrap:wrap;margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.norm-legend-item{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--ink-soft)}
.norm-legend-swatch{width:14px;height:14px;border-radius:4px}
.norm-legend-dot{width:14px;height:14px;border-radius:50%;background:var(--ink)}
/* subscale profile rows with dual percentiles */
.sub-norm-row{margin-bottom:26px}
.sub-norm-row:last-child{margin-bottom:6px}
.sub-norm-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px;gap:12px}
.sub-norm-name{font-size:14.5px;font-weight:600;color:var(--ink)}
.sub-norm-score{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--accent-deep)}
.sub-norm-scale{position:relative;height:44px;margin:0 6px 10px}
.sub-norm-pctiles{display:flex;gap:10px;flex-wrap:wrap;margin:0 6px}
.pctile-chip{font-size:12.5px;padding:5px 11px;border-radius:7px;display:inline-flex;align-items:center;gap:6px;line-height:1}
.pctile-chip b{font-weight:600;font-size:11px;letter-spacing:.02em;opacity:.85}
.pctile-control{background:var(--green-wash);color:var(--green)}
.pctile-autism{background:var(--rose-wash);color:var(--rose)}

/* ── Online mode: sign-in / profile card ── */
.auth-card{max-width:420px;margin:48px auto;padding:0 20px}
.auth-brand{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:14px}
.auth-card h1{font-size:25px;color:var(--ink);margin-bottom:8px}
.auth-sub{font-size:14.5px;color:var(--ink-soft);line-height:1.55;margin-bottom:22px}
.auth-card .field{margin-bottom:16px}
.auth-card .btn{width:100%;justify-content:center}
.auth-note{font-size:13px;color:var(--ink-soft);line-height:1.5;margin-top:14px;min-height:1em}
.auth-note b{color:var(--ink)}
.auth-alt{font-size:13.5px;margin-top:16px}
.auth-alt a{color:var(--accent-deep);text-decoration:none;font-weight:600}
.auth-alt a:hover{text-decoration:underline}
.ph-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.ph-preview-note{font-size:13px;color:var(--accent-deep);background:var(--accent-wash);border-radius:var(--radius-sm);padding:9px 14px;margin:6px 0 0}
.auth-msg{font-size:14.5px;color:var(--ink-soft);line-height:1.55;margin-top:18px}

/* ── Online mode: patient home ── */
.patient-home{max-width:760px;margin:0 auto}
.ph-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:6px}
.pt-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:24px}
.pt-tile{display:flex;flex-direction:column;gap:4px;text-align:left;padding:18px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--paper);cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}
.pt-tile:hover{border-color:var(--accent-deep);box-shadow:0 2px 10px rgba(0,0,0,.05)}
.pt-name{font-size:16px;font-weight:700;color:var(--ink)}
.pt-full{font-size:13px;color:var(--ink-soft);line-height:1.35}
.pt-meta{font-size:12px;color:var(--ink-faint);margin-top:4px}
.pt-badge{font-size:12px;font-weight:700;margin-top:8px;padding:4px 10px;border-radius:99px;align-self:flex-start}
.pt-badge-done{color:var(--green);background:var(--green-wash)}
.pt-badge-progress{color:var(--amber);background:var(--amber-wash)}
.pt-badge-todo{color:var(--accent-deep);background:var(--accent-wash,rgba(0,0,0,.05))}
.pt-note{font-size:12.5px;color:var(--ink-soft);font-style:italic;margin-top:6px;line-height:1.4}
.pt-tile.pt-done{cursor:default;opacity:.8}
.pt-tile.pt-done:hover{border-color:var(--line);box-shadow:none}
.ph-section{font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);margin:28px 0 0}
.ph-section-done{color:var(--ink-faint)}
.ph-empty{margin-top:22px;padding:22px;border:1px dashed var(--line);border-radius:var(--radius-sm);color:var(--ink-soft);font-size:14.5px;line-height:1.6;background:var(--paper)}

/* clinician console: tabs */
.cc-tabs{display:flex;gap:6px;margin:18px 0 4px;border-bottom:1px solid var(--line)}
.cc-tab{appearance:none;border:none;background:none;cursor:pointer;font-size:14px;font-weight:600;color:var(--ink-soft);padding:9px 14px;border-bottom:2px solid transparent;margin-bottom:-1px}
.cc-tab:hover{color:var(--ink)}
.cc-tab.active{color:var(--accent-deep);border-bottom-color:var(--accent-deep)}

/* clinician console: assign panel + patient cards */
.asg-panel{margin-top:18px;padding:20px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--paper)}
.asg-panel .field{margin-bottom:14px}
.asg-tests{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px 14px;margin-top:6px}
.asg-test{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--ink);cursor:pointer}
.asg-test input{width:16px;height:16px;flex-shrink:0}
.pcard{margin-top:10px;padding:14px 16px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--paper)}
.pcard-link{display:block;width:100%;text-align:left;cursor:pointer;font:inherit;transition:border-color .15s ease,box-shadow .15s ease}
.pcard-link:hover{border-color:var(--accent-deep);box-shadow:0 2px 10px rgba(0,0,0,.05)}
.pcard-head{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}

/* per-patient detail */
.pd-email{font-size:13px;color:var(--ink-faint);margin-top:4px}
.pd-rows{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.pd-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px 14px;padding:12px 16px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--paper)}
.pd-row-main{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.pd-test{font-size:14.5px;font-weight:700;color:var(--ink)}
.pd-status{font-size:12.5px;font-weight:600;padding:3px 9px;border-radius:99px}
.pd-done{color:var(--green);background:var(--green-wash)}
.pd-todo{color:var(--ink-soft);background:rgba(0,0,0,.05)}
.pd-note{grid-column:1/-1;font-size:12.5px;color:var(--ink-soft);font-style:italic}
.pd-empty{color:var(--ink-soft);font-size:14px;margin-top:8px}
.btn-sm{padding:5px 12px;font-size:13px}
.pd-actions{display:flex;gap:6px;align-items:center}
.pd-archive{color:var(--ink-faint)}
.pd-row-archived{opacity:.7}
.pd-add{margin-top:12px}
.pd-add>summary{cursor:pointer;font-size:13.5px;font-weight:600;color:var(--accent-deep);padding:8px 0;list-style:none}
.pd-add>summary::-webkit-details-marker{display:none}
.pd-add .asg-panel{margin-top:6px}
.asg-admin-btn{appearance:none;border:1px solid var(--line-strong);background:var(--paper);color:var(--ink);border-radius:var(--radius-sm);padding:8px 12px;font:inherit;font-size:13.5px;cursor:pointer;transition:border-color .12s ease,background .12s ease}
.asg-admin-btn:hover{border-color:var(--accent);background:var(--accent-wash)}

/* score trends */
.pd-trend-note{font-size:12.5px;color:var(--ink-faint);margin:4px 0 10px;line-height:1.5}
.trend{padding:12px 16px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--paper);margin-top:8px}
.trend-head{display:flex;align-items:center;gap:12px}
.trend-head .pd-test{flex:1}
.sparkline{flex-shrink:0}
.trend-delta{font-size:12.5px;font-weight:700;color:var(--ink-soft);white-space:nowrap}
.trend-seq{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:8px}
.tr-pt{display:inline-flex;flex-direction:column;line-height:1.2}
.tr-d{font-size:11px;color:var(--ink-faint)}
.tr-v{font-size:14px;font-weight:700;color:var(--ink)}
.tr-sep{color:var(--ink-faint)}

/* one-page score summary */
.sum-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-top:14px}
.sum-card{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--paper);padding:14px 16px}
.sum-card.sum-flag{border-color:#eccdd0;background:var(--rose-wash)}
.sum-top{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.sum-name{font-size:14.5px;font-weight:700;color:var(--ink)}
.sum-date{font-size:12px;color:var(--ink-faint);white-space:nowrap}
.sum-score{font-size:22px;font-weight:700;color:var(--ink);margin-top:8px;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.sum-band{font-size:13px;font-weight:600;color:var(--accent-deep);background:var(--accent-wash);padding:2px 9px;border-radius:99px}
.sum-chips{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}
.sum-chip{font-size:11.5px;color:var(--ink-soft);background:rgba(0,0,0,.05);padding:2px 8px;border-radius:99px}
.sum-actions{display:flex;gap:6px;margin-top:12px}
.sum-resp{font-size:12px;color:var(--ink-faint);margin-top:2px}
.sum-break{margin-top:10px;border-top:1px solid var(--line);padding-top:8px;display:flex;flex-direction:column;gap:4px}
.sum-row{display:flex;justify-content:space-between;gap:12px;font-size:13px}
.sum-rk{color:var(--ink-soft)}
.sum-rv{color:var(--ink);font-weight:600;text-align:right;white-space:nowrap}
.sum-flags{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}
.sum-flagchip{font-size:11.5px;font-weight:600;color:var(--rose);background:var(--rose-wash);padding:2px 9px;border-radius:99px}
.sum-missing{display:block;font-size:11.5px;color:var(--amber);margin-top:8px}
.sum-meta{display:flex;flex-wrap:wrap;gap:6px 22px;margin:10px 0 4px;font-size:13px;color:var(--ink-soft)}
.sum-meta b{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-faint);font-weight:700}
.sum-foot{margin-top:18px;font-size:11.5px;color:var(--ink-faint);font-style:italic}

/* technical report: overview table + stacked full reports */
.ov-table{width:100%;border-collapse:collapse;margin-top:10px;font-size:13.5px}
.ov-table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-faint);font-weight:700;padding:6px 10px;border-bottom:1px solid var(--line)}
.ov-table td{padding:8px 10px;border-bottom:1px solid var(--line);color:var(--ink);vertical-align:top}
.ov-table .ov-score{font-weight:700;font-variant-numeric:tabular-nums}
.ov-table tr.ov-flag td{background:var(--rose-wash)}
.rep-sec{margin-top:22px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--paper-raised)}
.rep-head{display:flex;align-items:center;gap:12px;padding:12px 18px;background:var(--paper);border-bottom:1px solid var(--line)}
.rep-title{font-size:17px;color:var(--ink);margin:0;flex-shrink:0}
.rep-date{font-size:12.5px;color:var(--ink-faint)}
.rep-tools{margin-left:auto}
.rep-body{padding:18px;overflow-x:auto}
.ov-wrap{overflow-x:auto}
.sum-page{overflow-x:hidden}
.rep-body .results{max-width:none;margin:0}
.rep-body .back-link,.rep-body .result-banner,.rep-body .results-actions{display:none!important}
.rep-ref{padding:16px 18px;color:var(--ink-soft)}
@media print{
  .topbar,.no-print{display:none!important}
  .ov-table{break-inside:avoid}
  .rep-sec{break-inside:avoid;page-break-inside:avoid}
}

/* RMET item-by-item breakdown */
.rmet-grid{display:flex;flex-direction:column;gap:3px;margin-top:6px}
.rmet-r{display:grid;grid-template-columns:34px 1fr 1fr 30px;align-items:center;gap:10px;padding:7px 10px;border-radius:6px;font-size:13.5px}
.rmet-r.rmet-h{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-faint);font-weight:700;padding-bottom:2px}
.rmet-r.ok{background:var(--green-wash)}
.rmet-r.no{background:var(--rose-wash)}
.rmet-r .ri-n{color:var(--ink-faint);font-variant-numeric:tabular-nums;text-align:center}
.rmet-r .ri-target{font-weight:600;color:var(--ink)}
.rmet-r.no .ri-resp{color:var(--rose);font-weight:600}
.rmet-r.ok .ri-resp{color:var(--ink-soft)}
.rmet-r .ri-mark{text-align:center;font-weight:700}
.rmet-r.ok .ri-mark{color:var(--green)}
.rmet-r.no .ri-mark{color:var(--rose)}
@media print{ .rmet-grid{columns:2;gap:0} .rmet-r{break-inside:avoid} }

/* item-by-item response editor */
.ei-stem{font-size:14px;font-weight:600;color:var(--ink-soft);margin:6px 0 12px}
.ei-rows{display:flex;flex-direction:column;gap:2px}
.ei-group{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--accent-deep);margin:16px 0 6px}
.ei-row{display:grid;grid-template-columns:1fr 220px;align-items:center;gap:14px;padding:10px 12px;border-bottom:1px solid var(--line)}
.ei-q{display:flex;gap:10px;align-items:baseline}
.ei-n{font-size:12px;font-weight:700;color:var(--ink-faint);min-width:22px}
.ei-text{font-size:14px;color:var(--ink);line-height:1.4}
.ei-select{width:100%;font:inherit;font-size:14px;padding:7px 10px;border:1px solid var(--line-strong);border-radius:6px;background:var(--paper);color:var(--ink)}
.ei-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-wash)}
@media(max-width:600px){.ei-row{grid-template-columns:1fr;gap:6px}}

/* raw-score editor */
.ed-rows{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.ed-row{display:grid;grid-template-columns:1fr 160px;align-items:center;gap:12px;padding:8px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--paper)}
.ed-key{font-size:13.5px;color:var(--ink);font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.ed-row input,.ed-row select{width:100%;font:inherit;font-size:14px;padding:6px 10px;border:1px solid var(--line-strong);border-radius:6px;background:var(--paper);color:var(--ink)}
.ed-ro{font-size:12.5px;color:var(--ink-faint);text-align:right}
@media(max-width:600px){.ed-row{grid-template-columns:1fr;gap:5px}.ed-ro{text-align:left}}

/* submissions search */
.cc-search{width:100%;font:inherit;font-size:14px;padding:9px 13px;border:1px solid var(--line-strong);border-radius:var(--radius-sm);background:var(--paper);color:var(--ink);margin:14px 0 4px}
.cc-search:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-wash)}
.pcard-name{font-size:15px;font-weight:700;color:var(--ink)}
.pcard-email{font-size:12.5px;color:var(--ink-faint)}
.pcard-off{opacity:.6}
.pcard-inactive{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--ink-soft);background:var(--line);padding:2px 8px;border-radius:99px}
.pcard-count{margin-left:auto;font-size:12.5px;font-weight:600;color:var(--ink-soft);white-space:nowrap}
.asg-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.asg-chip{font-size:12px;font-weight:600;padding:3px 9px;border-radius:99px;white-space:nowrap}
.asg-chip-done{color:var(--green);background:var(--green-wash)}
.asg-chip-todo{color:var(--ink-soft);background:rgba(0,0,0,.05)}
.asg-chip-link{border:none;cursor:pointer;font:inherit;font-weight:600;font-size:12px}
.asg-chip-link:hover{text-decoration:underline}

/* clinician console inbox */
.cc-rows{display:flex;flex-direction:column;gap:8px;margin-top:20px}
.cc-row{display:flex;align-items:center;gap:14px;width:100%;text-align:left;padding:13px 16px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--paper);cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}
.cc-row:hover{border-color:var(--accent-deep);box-shadow:0 2px 10px rgba(0,0,0,.05)}
.cc-row.cc-urgent{border-color:#eccdd0;background:var(--rose-wash)}
.cc-who{font-size:14.5px;font-weight:700;color:var(--ink);min-width:90px}
.cc-test{font-size:13.5px;color:var(--ink-soft);flex:1}
.cc-when{font-size:12.5px;color:var(--ink-faint);white-space:nowrap}
.cc-flag{font-size:11.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#fff;background:var(--rose);padding:3px 9px;border-radius:99px;white-space:nowrap}
@media(max-width:600px){
  .cc-row{flex-wrap:wrap;gap:4px 10px}
  .cc-test{flex-basis:100%}
}

/* ── Referral / intake form ── */
.referral{max-width:640px;margin:0 auto}
.referral-card{background:var(--paper-raised);border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin-top:18px}
.referral-title{font-size:20px;color:var(--ink);margin-bottom:6px}
.referral-intro{font-size:14px;color:var(--ink-soft);line-height:1.55;margin-bottom:18px}
.referral-fields .field{margin-bottom:18px}
.referral-fields textarea{width:100%;font:inherit;font-size:15px;padding:9px 13px;border:1px solid var(--line-strong);border-radius:var(--radius-sm);background:var(--paper);color:var(--ink);resize:vertical;line-height:1.5}
.referral-fields textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-wash)}
.ref-opts{display:flex;flex-direction:column;gap:8px}
.ref-opt{display:flex;align-items:center;gap:11px;padding:11px 14px;border:1px solid var(--line-strong);border-radius:var(--radius-sm);cursor:pointer;font-size:14.5px;color:var(--ink);transition:border-color .12s ease,background .12s ease}
.ref-opt:hover{border-color:var(--accent)}
.ref-opt.selected{border-color:var(--accent);background:var(--accent-wash)}
.ref-opt input{width:17px;height:17px;flex-shrink:0;margin:0}
.referral-error{color:var(--rose);font-size:13.5px;font-weight:600;min-height:1.2em;margin-top:4px}
.referral-nav{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:22px}
.referral-nav .btn-primary{margin-left:auto}

/* clinician read-only referral view */
.ref-group{margin-top:22px}
.ref-group-title{font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--line)}
.ref-dl{display:grid;grid-template-columns:1fr;gap:12px}
.ref-dl dt{font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:2px}
.ref-dl dd{font-size:15px;color:var(--ink);line-height:1.5;white-space:pre-wrap;margin:0}

/* spinner + warn icon for the submit flow */
.spinner{width:38px;height:38px;margin:0 auto 22px;border-radius:50%;border:3px solid var(--line);border-top-color:var(--accent-deep);animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.submitted-icon-warn{background:var(--amber-wash);color:var(--amber)}

/* ── Patient submitted / confirmation screen (online mode) ── */
.submitted-card{max-width:560px;margin:40px auto;text-align:center;padding:0 20px}
.submitted-icon{width:64px;height:64px;margin:0 auto 22px;border-radius:50%;display:grid;place-items:center;background:var(--green-wash);color:var(--green)}
.submitted-icon svg{width:32px;height:32px}
.submitted-card h1{font-size:24px;color:var(--ink);margin-bottom:12px;line-height:1.25}
.submitted-sub{font-size:15px;color:var(--ink-soft);line-height:1.55;margin-bottom:28px}
.submitted-card .btn{margin-top:8px}
.resume-actions{display:flex;flex-direction:column;align-items:center;gap:10px}
.crisis-card{text-align:left;background:var(--rose-wash);border:1px solid #eccdd0;border-radius:var(--radius-sm);padding:18px 20px;margin-bottom:28px}
.crisis-head{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:700;color:var(--rose);margin-bottom:8px}
.crisis-head svg{width:20px;height:20px;flex-shrink:0}
.crisis-intro{font-size:14px;color:var(--ink-soft);line-height:1.55;margin-bottom:14px}
.crisis-lines{list-style:none;display:flex;flex-direction:column;gap:8px}
.crisis-lines li{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:9px 12px;background:#fff;border:1px solid #eccdd0;border-radius:8px}
.cl-name{font-size:13.5px;color:var(--ink)}
.cl-val{font-size:15px;font-weight:700;color:var(--rose);text-decoration:none;font-variant-numeric:tabular-nums;white-space:nowrap}

/* PHQ-9 / GAD-7 severity band reference chips */
.sev-chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px}
.sev-chip{font-size:12px;padding:5px 10px;border-radius:7px;background:var(--paper);border:1px solid var(--line);color:var(--ink-faint);white-space:nowrap}
.sev-chip-on{font-weight:600;border-color:transparent}
.sev-chip-on.band-typical{background:var(--green-wash);color:var(--green)}
.sev-chip-on.band-elevated{background:var(--amber-wash);color:var(--amber)}
.sev-chip-on.band-high{background:var(--rose-wash);color:var(--rose)}

/* ASRS Part A — response label + shaded mark cells */
.asrs-resp{justify-self:end;text-align:right;font-size:12.5px;color:var(--ink-faint);white-space:nowrap}
.asrs-resp-on{color:var(--accent-deep);font-weight:600}
.asrs-mark{justify-self:center;text-align:center;font-size:14px;color:var(--line)}
.asrs-mark.on{color:var(--accent)}

/* RMET age- & sex-adjusted percentile (Kynast 2021) */
.rmet-agenorm{display:flex;gap:16px;align-items:stretch;margin-top:14px;padding:14px 16px;background:var(--accent-wash);border:1px solid #cfe4e8;border-radius:var(--radius-sm)}
.ran-figure{flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:96px;padding-right:16px;border-right:1px solid #cfe4e8}
.ran-pct{font-family:var(--font-mono);font-size:30px;font-weight:600;color:var(--accent-deep);line-height:1}
.ran-pct small{font-size:13px;font-weight:600;vertical-align:super}
.ran-cap{font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-faint);margin-top:5px}
.ran-body{flex:1}
.ran-head{font-size:13px;font-weight:600;color:var(--accent-deep);margin-bottom:4px}
.rmet-agenorm .ran-body p{font-size:13px;color:var(--ink-soft);line-height:1.5;margin:0}
.ran-src{font-size:11.5px;color:var(--ink-faint);font-style:italic;margin-top:6px!important}
.ran-missing{font-size:12.5px;color:var(--ink-faint);font-style:italic;margin-top:12px;line-height:1.5}

/* subscale radar */
.radar-wrap{display:flex;justify-content:center;padding:8px 0}
.radar-wrap svg{max-width:100%;height:auto}

/* interpretation / caveats */
.caveat{background:var(--amber-wash);border:1px solid #efd9bb;border-radius:var(--radius-sm);padding:16px 18px;display:flex;gap:12px;align-items:flex-start;margin-bottom:16px}
.caveat svg{width:19px;height:19px;flex-shrink:0;margin-top:1px;color:var(--amber)}
.caveat .cv-body{font-size:13.5px;color:var(--ink-soft);line-height:1.5}
.caveat .cv-body b{color:var(--amber);font-weight:600}

.interp-list{list-style:none}
.interp-list li{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);font-size:14.5px;color:var(--ink-soft);line-height:1.5}
.interp-list li:last-child{border-bottom:none}
.interp-list li .ic{flex-shrink:0;width:22px;height:22px;border-radius:6px;display:grid;place-items:center;margin-top:1px}
.interp-list li .ic svg{width:14px;height:14px}
.ic-info{background:var(--accent-wash);color:var(--accent-deep)}
.ic-flag{background:var(--amber-wash);color:var(--amber)}

.results-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}

.src-note{font-size:12px;color:var(--ink-faint);margin-top:16px;line-height:1.5;font-style:italic}

/* ============================================================
   MISC
   ============================================================ */
.disclaimer-bar{background:var(--rose-wash);border:1px solid #eccdd0;border-radius:var(--radius-sm);padding:14px 18px;margin-bottom:28px;display:flex;gap:11px;align-items:flex-start}
.disclaimer-bar svg{width:18px;height:18px;flex-shrink:0;margin-top:1px;color:var(--rose)}
.disclaimer-bar p{font-size:13px;color:var(--ink-soft);line-height:1.5}
.disclaimer-bar b{color:var(--rose);font-weight:600}

.back-link{display:inline-flex;align-items:center;gap:7px;font-size:14px;color:var(--ink-faint);background:none;border:none;cursor:pointer;font:inherit;margin-bottom:12px;padding:4px 0;transition:color .15s ease}
.back-link:hover{color:var(--accent)}
.back-link svg{width:16px;height:16px}

.empty-soon{text-align:center;padding:60px 20px;color:var(--ink-faint)}
.empty-soon svg{width:48px;height:48px;opacity:.4;margin-bottom:16px}

/* ============================================================
   NORMS REFERENCE (clinician QA page)
   ============================================================ */
.norms-link-row{margin-top:34px;padding-top:22px;border-top:1px solid var(--line)}
.norms-link{display:inline-flex;align-items:center;gap:13px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);padding:13px 18px;cursor:pointer;font:inherit;text-align:left;transition:border-color .15s ease,background .15s ease}
.norms-link:hover{border-color:var(--accent-deep);background:var(--accent-wash)}
.norms-link svg{width:20px;height:20px;color:var(--accent-deep);flex-shrink:0}
.norms-link-text{display:flex;flex-direction:column;gap:2px}
.norms-link-text b{font-size:14px;color:var(--ink);font-weight:600}
.norms-link-text small{font-size:12px;color:var(--ink-faint)}

.norms-section{margin:0 0 34px}
.norms-section>h2{font-size:18px;color:var(--ink);margin-bottom:2px;padding-bottom:8px;border-bottom:2px solid var(--accent-wash)}
#view-norms h4{font-size:13px;font-weight:600;color:var(--accent-deep);margin:16px 0 5px;letter-spacing:.01em}
.norms-src{font-size:11.5px;color:var(--ink-faint);font-style:italic;margin:3px 0 4px;line-height:1.45}
.norms-note{font-size:12px;color:var(--ink-soft);margin:6px 0 2px;line-height:1.5}
.norms-note b{color:var(--accent-deep);font-weight:600}

.norms-tbl{border-collapse:collapse;width:100%;font-size:12.5px;margin:5px 0 6px;font-variant-numeric:tabular-nums}
.norms-tbl th,.norms-tbl td{border:1px solid var(--line);padding:5px 9px;text-align:right;white-space:nowrap}
.norms-tbl th.rh,.norms-tbl td.rh{text-align:left}
.norms-tbl thead th{background:var(--accent-wash);color:var(--accent-deep);font-weight:600;position:sticky;top:0}
.norms-tbl td{color:var(--ink-soft)}
.norms-tbl td.rh{color:var(--ink);font-weight:500}
.norms-tbl tbody tr:nth-child(even) td{background:var(--paper)}

.norms-details{margin:5px 0 10px;border:1px solid var(--line);border-radius:8px;background:var(--paper);overflow:hidden}
.norms-details>summary{cursor:pointer;font-size:12.5px;font-weight:600;color:var(--accent-deep);padding:9px 14px;list-style:none;text-transform:capitalize}
.norms-details>summary::-webkit-details-marker{display:none}
.norms-details>summary::before{content:'▸ ';color:var(--ink-faint)}
.norms-details[open]>summary::before{content:'▾ '}
.norms-details[open]>summary{border-bottom:1px solid var(--line)}
.norms-details .norms-tbl{margin:0}
.norms-details .norms-tbl th,.norms-details .norms-tbl td{border-left:none;border-right:none}

/* ============================================================
   MOBILE (phones) — patients complete assessments remotely
   ============================================================ */
@media(max-width:600px){
  /* Likert options stack into a tappable list; the numeric scale stays a tight row */
  .opt-row:has(.likert-btn){grid-template-columns:1fr;gap:8px}
  .opt-btn.likert-btn{flex-direction:row;justify-content:flex-start;text-align:left;min-height:0;padding:14px 16px;gap:14px}
  .opt-btn.likert-btn .opt-label{font-size:15.5px}
  .opt-row:has(.scale-btn){gap:6px}
  .opt-btn.scale-btn{min-height:50px;padding:12px 0}
  .opt-btn.scale-btn .opt-num{font-size:20px}

  /* question card + text tighten on small screens */
  .q-card{padding:22px 18px}
  .q-text{font-size:20px;margin-bottom:20px;max-width:none}

  /* runner nav: Back / Next on one row, progress dots wrap full-width beneath */
  .runner-nav{flex-wrap:wrap}
  .nav-dots{order:3;max-width:none;width:100%;margin-top:6px}

  /* results profile tables reflow: scale name over its score · %ile · band */
  .profile-table .ph{display:none}
  .sdq-u-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px 12px}
  .sdq-u-row .sdq-name{flex:1 1 100%}
  .sdq-track{display:none}

  /* full-width actions + patient home header stacks */
  .results-actions .btn{width:100%;justify-content:center}
  .ph-top{flex-direction:column;gap:10px;align-items:flex-start}
}

/* print */
@media print{
  .topbar,.results-actions,.back-link,.disclaimer-bar{display:none!important}
  body{background:#fff}
  .main{padding:0;max-width:100%}
  .panel,.score-hero,.result-banner{box-shadow:none;break-inside:avoid}
  .result-banner{background:var(--accent-deep)!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .cmp-bar-fill,.fill-typical,.fill-elevated,.fill-high,.fill-accent,.band-pill,.card-tag,.norm-group-band,.norm-marker-dot,.rmet-chance,.rmet-time-cell,.pctile-chip{-webkit-print-color-adjust:exact;print-color-adjust:exact}
}