/* SPHR Exam — design system for exam.sphr.world.
   Ported from the sample-review artifact: cool "assessment" palette anchored to SPHR blue,
   system-ui for prose + monospace for the technical tokens the exam is full of, card-based
   layout with meta chips, mono letter badges, and a green "correct" state used ONLY on results.
   No webfonts (CSP-safe). Bump ?v= when editing. */

:root{
  --paper:#f5f6f9; --surface:#ffffff; --ink:#181a20; --muted:#5a6170;
  --faint:#8a91a0; --line:#e3e6ec; --line-soft:#eef0f4;
  --accent:#1e50c7; --accent-ink:#173f9e; --accent-tint:rgba(30,80,199,.08); --accent-line:rgba(30,80,199,.22);
  --good:#127a58; --good-tint:rgba(18,122,88,.09); --good-line:rgba(18,122,88,.32);
  --bad:#b3261e; --bad-tint:rgba(179,38,30,.08); --bad-line:rgba(179,38,30,.3);
  --warn:#a2670a;
  --radius:14px; --radius-sm:10px;
  --sans:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,"Cascadia Code","SF Mono",Menlo,Consolas,monospace;
  --shadow:0 1px 2px rgba(20,26,45,.04),0 1px 3px rgba(20,26,45,.03);
  --max:900px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
.wrap{max-width:var(--max);margin:0 auto;padding:0 22px}
a{color:var(--accent)}
h1,h2,h3{letter-spacing:-.02em;text-wrap:balance}
code{font-family:var(--mono);font-size:.88em;background:var(--line-soft);
  padding:1px 5px;border-radius:5px;color:#2a2f3a;word-break:break-word}

/* ── header / footer ─────────────────────────────────────────────── */
.site-header{border-bottom:1px solid var(--line);background:#fff}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:9px;text-decoration:none;color:var(--ink);font-weight:700}
.brand-name{letter-spacing:-.01em}
.nav-links a{margin-left:18px;text-decoration:none;color:var(--muted);font-size:14px}
.nav-links a:hover{color:var(--ink)}
.site-footer{border-top:1px solid var(--line);color:var(--faint);
  font-family:var(--mono);font-size:12px;letter-spacing:.02em;padding:22px 0 40px;margin-top:40px}

/* ── generic layout helpers ──────────────────────────────────────── */
.exam-main{padding:34px 0 60px}
.exam-shell{max-width:560px;margin:0 auto}
.exam-shell-md{max-width:720px}
.eyebrow,.exam-kicker{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent);font-weight:600}
.exam-title{font-size:clamp(24px,3.6vw,32px);line-height:1.14;font-weight:750;margin:.5rem 0 .4rem}
.exam-lead{color:var(--muted);margin:0 0 22px}

.exam-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 30px 34px;box-shadow:var(--shadow)}

/* stepper */
.exam-steps{display:flex;gap:8px;list-style:none;padding:0;margin:0 0 18px;
  font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase}
.exam-steps li{color:var(--faint);display:flex;align-items:center;gap:8px}
.exam-steps li::after{content:"";width:16px;height:1px;background:var(--line);margin-left:8px}
.exam-steps li:last-child::after{display:none}
.exam-steps li.active{color:var(--accent);font-weight:600}
.exam-steps li.done{color:var(--ink)}

/* ── forms ───────────────────────────────────────────────────────── */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field label{font-size:13px;font-weight:600;color:var(--ink)}
.field-hint{font-size:12.5px;color:var(--faint)}
.exam-panel input:not([type="checkbox"]){width:100%;padding:12px 13px;font-size:15px;
  border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;color:var(--ink);font-family:var(--sans)}
.exam-panel input:focus-visible{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
.code-input{font-family:var(--mono);font-size:26px !important;letter-spacing:.4em;text-align:center;text-transform:uppercase}
.consent{display:flex;gap:10px;align-items:flex-start;margin:6px 0 18px;font-size:13.5px;color:var(--muted);cursor:pointer}
.consent input{margin-top:3px;flex:none;width:16px;height:16px;accent-color:var(--accent)}

/* Turnstile — centered */
.cf-turnstile{display:flex;justify-content:center;margin:4px 0 16px}

.form-msg{font-size:13.5px;margin:12px 0 0;color:var(--bad)}
.form-msg.ok{color:var(--accent)}

/* ── buttons ─────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;
  font-family:var(--sans);font-size:15px;font-weight:600;line-height:1;border-radius:var(--radius-sm);
  padding:13px 18px;border:1px solid transparent;transition:background .15s,border-color .15s,opacity .15s;
  text-decoration:none}
.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.btn-block{width:100%}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-ink)}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:var(--line-soft)}
.btn-link{background:none;border:none;color:var(--accent);padding:8px;font-weight:600}
.btn-submit{background:var(--good);color:#fff}
.btn-submit:hover{filter:brightness(.95)}
.btn[disabled]{opacity:.5;cursor:not-allowed}
.btn.is-busy{position:relative;color:transparent !important;pointer-events:none}
.btn.is-busy::after{content:"";position:absolute;width:16px;height:16px;border-radius:50%;
  border:2px solid rgba(255,255,255,.45);border-top-color:#fff;animation:btnspin .6s linear infinite}
.btn-ghost.is-busy::after,.btn-link.is-busy::after{border-color:rgba(30,80,199,.35);border-top-color:var(--accent)}
@keyframes btnspin{to{transform:rotate(360deg)}}

/* ── instructions facts ──────────────────────────────────────────── */
.exam-facts{display:flex;gap:12px;margin:8px 0 20px}
.exam-fact{flex:1;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:14px;text-align:center}
.exam-fact-num{display:block;font-size:24px;font-weight:750;letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.exam-fact-label{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}
.exam-checklist{margin:0 0 18px;padding-left:20px;color:var(--muted);font-size:14.5px}
.exam-checklist li{margin:5px 0}
.exam-callout{background:var(--accent-tint);border:1px solid var(--accent-line);border-radius:var(--radius-sm);
  padding:13px 16px;font-size:13.5px;color:#2a3346;margin-bottom:18px}

/* ── test runner ─────────────────────────────────────────────────── */
.exam-run{max-width:760px;margin:0 auto}
.exam-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.exam-topbar-meta{display:flex;align-items:center;gap:10px}
.exam-count{font-family:var(--mono);font-size:13px;font-weight:600}
.exam-answered-chip{font-size:12px;color:var(--muted);background:var(--surface);
  border:1px solid var(--line);border-radius:999px;padding:3px 10px}
.exam-timer{font-family:var(--mono);font-size:20px;font-weight:700;font-variant-numeric:tabular-nums;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:6px 12px}
.exam-timer.low{color:var(--bad);border-color:var(--bad-line);background:var(--bad-tint)}
.exam-progressbar{height:5px;background:var(--line-soft);border-radius:999px;overflow:hidden;margin-bottom:18px}
.exam-progressbar span{display:block;height:100%;width:0;background:var(--accent);transition:width .25s}

.exam-qcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 26px;box-shadow:var(--shadow)}
.exam-scenario{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--accent);margin-bottom:10px}
.exam-prompt{font-size:16.5px;line-height:1.6;margin-bottom:18px}
.exam-options{display:flex;flex-direction:column;gap:9px}

/* option rows (candidate view — no correct highlight) */
.opt{display:flex;gap:12px;align-items:flex-start;padding:13px 15px;border:1px solid var(--line);
  border-radius:var(--radius-sm);cursor:pointer;background:#fff;transition:border-color .12s,background .12s;font-size:15px;line-height:1.5}
.opt:hover{border-color:var(--accent-line);background:var(--accent-tint)}
.opt .badge{font-family:var(--mono);font-weight:700;font-size:12.5px;width:24px;height:24px;flex:none;
  border-radius:6px;display:grid;place-items:center;border:1px solid var(--line);color:var(--muted);margin-top:1px}
.opt.selected{border-color:var(--accent);background:var(--accent-tint)}
.opt.selected .badge{background:var(--accent);border-color:var(--accent);color:#fff}
.opt input{position:absolute;opacity:0;pointer-events:none}
/* the radio is visually hidden, so surface keyboard focus on the label */
.opt:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-tint)}

.exam-footer{display:flex;justify-content:space-between;gap:12px;margin-top:18px}
.exam-submit-row{display:flex;justify-content:space-between;gap:12px;margin-top:12px;
  padding-top:16px;border-top:1px solid var(--line)}
@media(max-width:520px){.exam-footer,.exam-submit-row{flex-direction:column}}

/* paused */
.exam-paused{text-align:center;padding:30px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);margin-top:16px}
.exam-paused-badge{display:inline-block;font-family:var(--mono);font-size:12px;color:var(--warn);
  background:rgba(162,103,10,.09);border:1px solid rgba(162,103,10,.3);border-radius:999px;padding:4px 12px;margin-bottom:10px}
.exam-paused-time{font-family:var(--mono);font-size:30px;font-weight:700;font-variant-numeric:tabular-nums;margin-top:12px}
.exam-paused-label{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:16px}

/* ── results ─────────────────────────────────────────────────────── */
.result-head{text-align:center;padding:22px 0 26px;border-bottom:1px solid var(--line);margin-bottom:22px}
.result-badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;padding:5px 14px;border-radius:999px;margin-bottom:14px}
.result-badge.pass{color:var(--good);background:var(--good-tint);border:1px solid var(--good-line)}
.result-badge.fail{color:var(--bad);background:var(--bad-tint);border:1px solid var(--bad-line)}
.result-score{font-size:56px;font-weight:800;line-height:1;letter-spacing:-.03em;font-variant-numeric:tabular-nums}
.result-score-sub{color:var(--faint);font-family:var(--mono);font-size:12px;letter-spacing:.06em;margin-top:6px}
.result-section-title,.result-review-title{font-size:16px;font-weight:700;margin:26px 0 12px}
.result-scenarios{display:flex;flex-direction:column;gap:8px}
.result-scen{display:flex;align-items:center;gap:12px}
.result-scen-name{flex:none;width:210px;font-size:13px;color:var(--muted)}
.result-scen-bar{flex:1;height:8px;background:var(--line-soft);border-radius:999px;overflow:hidden}
.result-scen-bar span{display:block;height:100%;background:var(--accent)}
.result-scen-num{font-family:var(--mono);font-size:12px;font-variant-numeric:tabular-nums;flex:none;width:56px;text-align:right}
@media(max-width:560px){.result-scen-name{width:130px}}

/* review cards reuse question card + reveal correct/incorrect */
.result-review{display:flex;flex-direction:column;gap:14px}
.rev{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px}
.rev .opt{cursor:default}
.rev .opt.is-correct{background:var(--good-tint);border-color:var(--good-line)}
.rev .opt.is-correct .badge{background:var(--good);border-color:var(--good);color:#fff}
.rev .opt.is-wrong{background:var(--bad-tint);border-color:var(--bad-line)}
.rev .opt.is-wrong .badge{background:var(--bad);border-color:var(--bad);color:#fff}
.rev .mark{margin-left:auto;flex:none;font-weight:700}
.rev .mark.ok{color:var(--good)}
.rev .mark.no{color:var(--bad)}
.why{margin-top:14px;padding-top:12px;border-top:1px dashed var(--line)}
.why .wl{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);display:block;margin-bottom:5px}
.why p{margin:0;font-size:14px;color:var(--muted);line-height:1.62}

/* ── admin dashboard ─────────────────────────────────────────────── */
.dash-wrap{max-width:1180px;margin:0 auto;padding:0 22px}
.dash-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:26px 0 20px}
.dash-title{font-size:26px;font-weight:750;margin:0}
.dash-sub{color:var(--muted);font-size:13.5px;margin:4px 0 0}
.dash-actions{display:flex;gap:8px}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:24px}
.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 18px}
.stat-num{display:block;font-size:26px;font-weight:750;letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.stat-label{font-family:var(--mono);font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--faint)}
.dash-section{margin-bottom:26px}
.dash-section-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.dash-section-head h2{font-size:16px;margin:0}
.admin-badge{font-family:var(--mono);font-size:11px;color:var(--muted);background:var(--line-soft);border-radius:999px;padding:2px 9px}
.dash-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.dash-scroll{overflow-x:auto}
.admin-table{width:100%;border-collapse:collapse;font-size:13px}
.admin-table-fixed{table-layout:fixed}
.admin-table th{text-align:left;font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;
  color:var(--faint);padding:11px 14px;border-bottom:1px solid var(--line);background:var(--paper)}
.admin-table td{padding:11px 14px;border-bottom:1px solid var(--line-soft);vertical-align:top}
.admin-table tr:last-child td{border-bottom:none}
.cell-email{word-break:break-all}
.cell-nowrap{white-space:nowrap}
.pill{display:inline-block;font-family:var(--mono);font-size:11px;padding:2px 9px;border-radius:999px;border:1px solid var(--line);color:var(--muted)}
.pill-pass{color:var(--good);background:var(--good-tint);border-color:var(--good-line)}
.pill-fail{color:var(--bad);background:var(--bad-tint);border-color:var(--bad-line)}
.pill-in_progress{color:var(--accent);background:var(--accent-tint);border-color:var(--accent-line)}
.pill-paused{color:var(--warn);background:rgba(162,103,10,.09);border-color:rgba(162,103,10,.3)}
.pill-submitted{color:var(--muted)}
.pill-expired{color:var(--bad)}

/* shared question meta chips (used in review + could be elsewhere) */
.meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px}
.qnum{font-family:var(--mono);font-weight:700;font-size:13px;background:var(--line-soft);border-radius:7px;padding:3px 8px}
.chip{font-size:11.5px;padding:3px 9px;border-radius:999px;border:1px solid var(--line);color:var(--muted);
  display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.chip .dot{width:7px;height:7px;border-radius:50%;flex:none}

@media(prefers-reduced-motion:reduce){*{animation-duration:.001ms !important;transition-duration:.001ms !important}}
