/* ============================================================================
   Crucible — "Idea Assay" instrument UI  ·  v3
   Metallurgical palette · Space Grotesk / IBM Plex Sans / IBM Plex Mono
   Signature: the readiness assay gauge (the one place heat appears)
   Fully dual-theme: :root = light · prefers-color-scheme dark · [data-theme] wins
   ========================================================================== */

@font-face{font-family:"Space Grotesk";src:url("/static/fonts/space-grotesk-500.woff2") format("woff2");font-weight:500;font-display:swap}
@font-face{font-family:"Space Grotesk";src:url("/static/fonts/space-grotesk-600.woff2") format("woff2");font-weight:600;font-display:swap}
@font-face{font-family:"Space Grotesk";src:url("/static/fonts/space-grotesk-700.woff2") format("woff2");font-weight:700;font-display:swap}
@font-face{font-family:"Plex Sans";src:url("/static/fonts/plex-sans-400.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"Plex Sans";src:url("/static/fonts/plex-sans-500.woff2") format("woff2");font-weight:500;font-display:swap}
@font-face{font-family:"Plex Sans";src:url("/static/fonts/plex-sans-600.woff2") format("woff2");font-weight:600;font-display:swap}
@font-face{font-family:"Plex Mono";src:url("/static/fonts/plex-mono-400.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"Plex Mono";src:url("/static/fonts/plex-mono-500.woff2") format("woff2");font-weight:500;font-display:swap}
@font-face{font-family:"Plex Mono";src:url("/static/fonts/plex-mono-600.woff2") format("woff2");font-weight:600;font-display:swap}

/* ============================================================================
   THEME TOKENS
   1) :root              → light (default)
   2) @media dark + :root:not([data-theme="light"]) → system-adaptive dark
   3) :root[data-theme="dark|light"] → explicit choice always wins
   ========================================================================== */
:root{
  color-scheme:light;
  /* canvas + surfaces */
  --paper:#EBECEF; --paper-2:#E2E4E8;
  --surface:#FAFBFC; --surface-2:#F4F5F7; --elevated:#FFFFFF;
  /* ink */
  --ink:#15181D; --ink-2:#454C56; --ink-3:#7C848E;
  /* hairlines */
  --line:#D6D9DF; --line-2:#E5E7EC;
  /* masthead / instrument graphite (dark in BOTH themes) */
  --graphite:#171B21; --graphite-2:#212732; --graphite-line:#333B47;
  --graphite-ink:#EEF0F3; --graphite-ink-2:#8B94A0;
  /* heat + metals */
  --ember:#C2611C; --ember-2:#E5872E; --gold:#B38A2E;
  --ember-bg:#F7ECE1; --ember-line:#ECD9C4;
  /* verdicts — text/accent (-) · solid fill (-solid) · card tint (-bg) · rail line (-line) */
  --holds:#2E7A57;  --holds-solid:#2E7A57;  --holds-bg:#E6F1EB;  --holds-line:#BEDCCB;
  --weak:#94700F;   --weak-solid:#94700F;   --weak-bg:#F4EDD8;   --weak-line:#E2D29C;
  --breaks:#AC3829; --breaks-solid:#AC3829; --breaks-bg:#F4E5E1; --breaks-line:#E4BCB2;
  --review:#6B7480; --review-solid:#6B7480; --review-bg:#EAECEF; --review-line:#D6D9DF;
  --on-accent:#FFFFFF;
  /* type */
  --f-display:"Space Grotesk",system-ui,sans-serif;
  --f-body:"Plex Sans",system-ui,-apple-system,sans-serif;
  --f-mono:"Plex Mono",ui-monospace,"SFMono-Regular",monospace;
  /* depth */
  --shadow:0 1px 2px rgba(16,22,30,.05), 0 8px 24px rgba(16,22,30,.06);
  --shadow-lift:0 2px 4px rgba(16,22,30,.05), 0 12px 30px rgba(16,22,30,.08);
  --ring:rgba(194,97,28,.30);
  /* faint warm paper grain (gradient only) */
  --canvas:
    radial-gradient(1100px 520px at 78% -12%, rgba(194,97,28,.05), transparent 62%),
    radial-gradient(900px 600px at -10% 8%, rgba(179,138,46,.045), transparent 60%),
    var(--paper);
}

/* ----- system-adaptive dark (only when not explicitly light) ----- */
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]){
    color-scheme:dark;
    --paper:#0E1116; --paper-2:#11151B;
    --surface:#161A21; --surface-2:#1C212B; --elevated:#222834;
    --ink:#E7EAEF; --ink-2:#AEB6C2; --ink-3:#828B98;
    --line:#272D38; --line-2:#202632;
    --graphite:#0B0E13; --graphite-2:#1A1F28; --graphite-line:#2C333E;
    --graphite-ink:#EEF0F3; --graphite-ink-2:#8B94A0;
    --ember:#E5872E; --ember-2:#F2A04D; --gold:#D6AC4E;
    --ember-bg:#241A12; --ember-line:#46331F;
    --holds:#62C495;  --holds-solid:#2F8A60;  --holds-bg:#13241B;  --holds-line:#27543A;
    --weak:#D8B65C;   --weak-solid:#8A6A10;   --weak-bg:#241F11;   --weak-line:#4C4120;
    --breaks:#E78C7C; --breaks-solid:#A8392A; --breaks-bg:#291612; --breaks-line:#572F27;
    --review:#9AA5B2; --review-solid:#5A636E; --review-bg:#191E26; --review-line:#2C333E;
    --shadow:0 1px 2px rgba(0,0,0,.45), 0 12px 32px rgba(0,0,0,.5);
    --shadow-lift:0 2px 6px rgba(0,0,0,.5), 0 16px 40px rgba(0,0,0,.6);
    --canvas:
      radial-gradient(1100px 520px at 78% -12%, rgba(229,135,46,.07), transparent 62%),
      radial-gradient(900px 600px at -10% 8%, rgba(214,172,78,.05), transparent 60%),
      var(--paper);
  }
}

/* ----- explicit dark (wins over system) ----- */
:root[data-theme="dark"]{
  color-scheme:dark;
  --paper:#0E1116; --paper-2:#11151B;
  --surface:#161A21; --surface-2:#1C212B; --elevated:#222834;
  --ink:#E7EAEF; --ink-2:#AEB6C2; --ink-3:#828B98;
  --line:#272D38; --line-2:#202632;
  --graphite:#0B0E13; --graphite-2:#1A1F28; --graphite-line:#2C333E;
  --graphite-ink:#EEF0F3; --graphite-ink-2:#8B94A0;
  --ember:#E5872E; --ember-2:#F2A04D; --gold:#D6AC4E;
  --ember-bg:#241A12; --ember-line:#46331F;
  --holds:#62C495;  --holds-solid:#2F8A60;  --holds-bg:#13241B;  --holds-line:#27543A;
  --weak:#D8B65C;   --weak-solid:#8A6A10;   --weak-bg:#241F11;   --weak-line:#4C4120;
  --breaks:#E78C7C; --breaks-solid:#A8392A; --breaks-bg:#291612; --breaks-line:#572F27;
  --review:#9AA5B2; --review-solid:#5A636E; --review-bg:#191E26; --review-line:#2C333E;
  --shadow:0 1px 2px rgba(0,0,0,.45), 0 12px 32px rgba(0,0,0,.5);
  --shadow-lift:0 2px 6px rgba(0,0,0,.5), 0 16px 40px rgba(0,0,0,.6);
  --canvas:
    radial-gradient(1100px 520px at 78% -12%, rgba(229,135,46,.07), transparent 62%),
    radial-gradient(900px 600px at -10% 8%, rgba(214,172,78,.05), transparent 60%),
    var(--paper);
}

/* ----- explicit light (wins over system; restates light tokens) ----- */
:root[data-theme="light"]{
  color-scheme:light;
  --paper:#EBECEF; --paper-2:#E2E4E8;
  --surface:#FAFBFC; --surface-2:#F4F5F7; --elevated:#FFFFFF;
  --ink:#15181D; --ink-2:#454C56; --ink-3:#7C848E;
  --line:#D6D9DF; --line-2:#E5E7EC;
  --graphite:#171B21; --graphite-2:#212732; --graphite-line:#333B47;
  --graphite-ink:#EEF0F3; --graphite-ink-2:#8B94A0;
  --ember:#C2611C; --ember-2:#E5872E; --gold:#B38A2E;
  --ember-bg:#F7ECE1; --ember-line:#ECD9C4;
  --holds:#2E7A57;  --holds-solid:#2E7A57;  --holds-bg:#E6F1EB;  --holds-line:#BEDCCB;
  --weak:#94700F;   --weak-solid:#94700F;   --weak-bg:#F4EDD8;   --weak-line:#E2D29C;
  --breaks:#AC3829; --breaks-solid:#AC3829; --breaks-bg:#F4E5E1; --breaks-line:#E4BCB2;
  --review:#6B7480; --review-solid:#6B7480; --review-bg:#EAECEF; --review-line:#D6D9DF;
  --shadow:0 1px 2px rgba(16,22,30,.05), 0 8px 24px rgba(16,22,30,.06);
  --shadow-lift:0 2px 4px rgba(16,22,30,.05), 0 12px 30px rgba(16,22,30,.08);
  --canvas:
    radial-gradient(1100px 520px at 78% -12%, rgba(194,97,28,.05), transparent 62%),
    radial-gradient(900px 600px at -10% 8%, rgba(179,138,46,.045), transparent 60%),
    var(--paper);
}

/* ============================================================================
   BASE
   ========================================================================== */
*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:var(--f-body); background:var(--canvas); background-attachment:fixed;
  color:var(--ink); line-height:1.6; -webkit-font-smoothing:antialiased; font-size:15px;
  transition:background-color .25s ease, color .25s ease;
}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0;font-family:var(--f-display);letter-spacing:-.01em}
::selection{background:var(--ember);color:var(--on-accent)}

/* mono label utility — the "instrument readout" voice */
.lbl{font-family:var(--f-mono);font-size:11px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-3)}

/* ============================================================================
   ICONS  (svg = .ico, em-scaled so it tracks text)
   ========================================================================== */
.ico{width:1.15em;height:1.15em;flex:none;vertical-align:-.18em;stroke-width:2;display:inline-block}
.ico-sm{width:14px;height:14px}
.ico-lg{width:22px;height:22px}
.ico-xl{width:30px;height:30px}

/* per-lens icon chip — used in the assay rail + lens-index cells */
.ico-lens{
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;border-radius:9px;flex:none;
  background:var(--surface-2);border:1px solid var(--line-2);color:var(--ink-2);
}
.ico-lens .ico{width:17px;height:17px;vertical-align:0}

/* ============================================================================
   MASTHEAD  (graphite in both themes)
   ========================================================================== */
.masthead{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  height:60px;padding:0 24px;background:var(--graphite);color:var(--graphite-ink);
  position:sticky;top:0;z-index:30;border-bottom:1px solid rgba(0,0,0,.6);
}
.wordmark{display:flex;align-items:center;gap:11px}
.wordmark svg{width:20px;height:20px;display:block}
.wordmark-name{font-family:var(--f-display);font-weight:700;font-size:18px;letter-spacing:.02em}
.wordmark-sub{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--graphite-ink-2);padding-left:11px;border-left:1px solid var(--graphite-line)}
.masthead-right{display:flex;align-items:center;gap:14px}
.masthead-method{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--graphite-ink-2)}
@media(max-width:680px){.masthead-method,.wordmark-sub{display:none}}

/* theme toggle — icon button living in the masthead (JS swaps the icon) */
.theme-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:9px;cursor:pointer;
  background:rgba(255,255,255,.05);border:1px solid var(--graphite-line);
  color:#C9CFD7;transition:background .14s,color .14s,border-color .14s;
}
.theme-toggle:hover{background:var(--graphite-2);color:#fff;border-color:#48515E}
.theme-toggle .ico{width:17px;height:17px}

/* ============================================================================
   SHELL
   ========================================================================== */
.shell{display:grid;grid-template-columns:276px minmax(0,1fr);min-height:calc(100vh - 60px)}
.archive{
  background:var(--surface-2);border-right:1px solid var(--line);
  padding:22px 16px;position:sticky;top:60px;align-self:start;height:calc(100vh - 60px);overflow-y:auto;
}
.archive-head{margin-bottom:14px}
.main{padding:40px clamp(20px,4vw,64px);max-width:1000px;width:100%}

/* ============================================================================
   ARCHIVE / specimen log
   ========================================================================== */
.log{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.log-item{display:block;padding:11px 12px;border-radius:8px;border:1px solid transparent;transition:.12s}
.log-item:hover{background:var(--elevated);border-color:var(--line)}
.log-idea{display:block;font-size:13px;color:var(--ink-2);line-height:1.45}
.log-meta{display:flex;gap:7px;margin-top:7px;font-family:var(--f-mono);font-size:11px}
.log-meta b{font-weight:600}
.log-h{color:var(--holds)} .log-w{color:var(--weak)} .log-b{color:var(--breaks)}
.log-empty{font-size:13px;color:var(--ink-3);line-height:1.5}

/* ============================================================================
   INTAKE (home)
   ========================================================================== */
.intake{max-width:760px}
.eyebrow{display:inline-flex;align-items:center;gap:9px;margin-bottom:20px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--ember);box-shadow:0 0 0 3px var(--ring)}
.intake-title{font-size:clamp(30px,4.4vw,46px);font-weight:700;line-height:1.04;letter-spacing:-.025em}
.intake-title em{font-style:normal;color:var(--ember)}
.intake-lede{font-size:16.5px;color:var(--ink-2);margin:20px 0 28px;max-width:60ch}
.tray{background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}
.tray-head{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;border-bottom:1px solid var(--line-2);background:var(--surface-2)}
.tray textarea{
  width:100%;border:0;padding:18px 18px 8px;font-family:var(--f-body);font-size:15.5px;
  line-height:1.6;resize:vertical;background:transparent;color:var(--ink);min-height:150px;
}
.tray textarea:focus{outline:none}
.tray-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 16px;border-top:1px solid var(--line-2);flex-wrap:wrap}
.tray-hint{font-size:12.5px;color:var(--ink-3)}

/* the 10-lens index — annotated, icon-bearing cells (not bare pills) */
.lens-index{margin-top:40px;border-top:1px solid var(--line);padding-top:22px}
.lens-index-head{display:flex;align-items:baseline;gap:10px;margin-bottom:16px}
.lens-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(225px,1fr));gap:1px;background:var(--line-2);border:1px solid var(--line-2);border-radius:10px;overflow:hidden}
.lens-cell{background:var(--surface);padding:13px 15px 13px 56px;position:relative;transition:background .12s}
.lens-cell:hover{background:var(--elevated)}
.lens-cell .ico-lens{position:absolute;left:14px;top:12px;color:var(--ember);background:var(--ember-bg);border-color:var(--ember-line)}
.lens-cell .code{font-family:var(--f-mono);font-size:12.5px;font-weight:600;color:var(--ember);letter-spacing:.02em}
.lens-cell .nm{font-family:var(--f-display);font-weight:600;font-size:13.5px;margin-left:7px}
.lens-cell .ex{display:block;margin-top:5px;font-size:11.5px;color:var(--ink-3);line-height:1.45}

/* ============================================================================
   BUTTONS
   ========================================================================== */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--f-body);font-weight:600;font-size:14px;
  border-radius:9px;padding:11px 17px;border:1px solid transparent;cursor:pointer;transition:.14s;white-space:nowrap;line-height:1}
.btn-primary{background:var(--ember);color:var(--on-accent);box-shadow:0 1px 2px rgba(150,70,15,.3)}
.btn-primary:hover{background:#A85214}
.btn-primary:disabled{opacity:.55;cursor:progress}
.btn-dark{background:var(--graphite);color:var(--graphite-ink);border-color:var(--graphite-line)}
.btn-dark:hover{background:var(--graphite-2)}
.btn-line{background:transparent;border-color:var(--line);color:var(--ink-2)}
.btn-line:hover{background:var(--surface);border-color:var(--ink-3)}
.masthead .btn-line{border-color:var(--graphite-line);color:#C9CFD7}
.masthead .btn-line:hover{background:var(--graphite-2);color:#fff}
.btn-sm{padding:7px 13px;font-size:12.5px;border-radius:7px}
.btn-danger:hover{background:var(--breaks-bg);color:var(--breaks);border-color:var(--breaks-line)}

/* ============================================================================
   SPECIMEN HEADER (idea page)
   ========================================================================== */
.report-bar{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.report-bar h1{font-size:13px}
.report-actions{display:flex;gap:8px;align-items:center}
.report-actions form{margin:0}
.specimen{background:var(--graphite);color:#E9ECF0;border-radius:14px;padding:22px 24px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.specimen::before{content:"";position:absolute;inset:0 0 auto 0;height:2px;background:linear-gradient(90deg,transparent,var(--ember) 40%,var(--ember-2) 60%,transparent)}
.specimen-tag{display:flex;align-items:center;gap:10px;margin-bottom:13px}
.specimen-tag .lbl{color:#8C95A1}
.specimen-tag .id{font-family:var(--f-mono);font-size:11px;color:#6E7783;margin-left:auto}
.specimen-text{font-family:var(--f-display);font-weight:500;font-size:18px;line-height:1.5;color:#F2F4F7;letter-spacing:-.01em}

/* ============================================================================
   READINESS ASSAY GAUGE (SIGNATURE)
   ========================================================================== */
.assay-gauge{background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:22px 24px;margin-top:14px;position:relative;overflow:hidden}
.assay-gauge::before{content:"";position:absolute;inset:0 0 auto 0;height:2px;background:linear-gradient(90deg,transparent,var(--ember-2) 50%,transparent)}
.gauge-top{display:flex;align-items:baseline;justify-content:space-between;gap:14px;margin-bottom:16px;flex-wrap:wrap}
.gauge-reading{display:flex;align-items:baseline;gap:12px}
.gauge-reading .grade{font-family:var(--f-display);font-weight:700;font-size:26px;letter-spacing:-.02em}
.grade.g-strong{color:var(--holds)} .grade.g-promising{color:var(--weak)} .grade.g-early{color:var(--breaks)}
.gauge-reading .grade-sub{font-size:13px;color:var(--ink-3)}
.tally{display:flex;gap:14px;font-family:var(--f-mono);font-size:12px;font-weight:600}
.tally span{display:inline-flex;align-items:center;gap:6px}
.tally i{width:9px;height:9px;border-radius:2px;font-style:normal;display:inline-block}
.tally .t-h i{background:var(--holds-solid)} .tally .t-h{color:var(--holds)}
.tally .t-w i{background:var(--weak-solid)} .tally .t-w{color:var(--weak)}
.tally .t-b i{background:var(--breaks-solid)} .tally .t-b{color:var(--breaks)}
/* the thermal scale */
.scale{position:relative;margin:6px 0 4px}
.scale-track{height:8px;border-radius:6px;background:linear-gradient(90deg,#b8493a 0%,#c98a2a 50%,#2e7a57 100%);opacity:.92;box-shadow:inset 0 0 0 1px rgba(0,0,0,.06)}
.scale-ticks{display:flex;justify-content:space-between;margin-top:9px;font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3)}
.scale-ticks b{font-weight:600}
.needle{position:absolute;top:-5px;width:2px;height:18px;background:var(--ink);transform:translateX(-1px)}
.needle::after{content:"";position:absolute;top:-5px;left:-4px;width:10px;height:10px;background:var(--ink);transform:rotate(45deg)}
.gauge-summary{margin:18px 0 0;font-size:15px;color:var(--ink);line-height:1.6;padding-top:16px;border-top:1px solid var(--line-2)}
.gauge-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:16px}
.gauge-grid .vp p{margin:7px 0 0;font-size:13px;font-style:italic;color:var(--ink-2);line-height:1.55}
.gauge-grid ol{margin:8px 0 0;padding-left:18px}
.gauge-grid li{font-size:13px;color:var(--ink-2);margin-bottom:7px;line-height:1.45}
@media(max-width:720px){.gauge-grid{grid-template-columns:1fr}}

/* ============================================================================
   VERDICT LEGEND (always visible, zero ambiguity)
   ========================================================================== */
.legend{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:26px 0 14px;
  background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:11px 14px}
.legend .lbl{margin-right:4px}
.legend-key{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-2)}
.legend-key .tick{width:16px;height:16px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--on-accent)}
.tick.k-h{background:var(--holds-solid)} .tick.k-w{background:var(--weak-solid)} .tick.k-b{background:var(--breaks-solid)}
.legend-key b{font-family:var(--f-mono);font-weight:600;font-size:11.5px;letter-spacing:.04em}
.legend-key span{color:var(--ink-3)}
.legend-sep{width:1px;height:18px;background:var(--line)}

/* ============================================================================
   PROGRESS (deep run streaming) — graphite instrument readout in both themes
   ========================================================================== */
.progress{display:grid;grid-template-columns:auto 1fr;gap:4px 14px;align-items:center;
  background:var(--graphite);color:#E9ECF0;border-radius:12px;padding:16px 20px;margin-bottom:18px}
.progress .spinner{grid-row:span 2}
.progress strong{font-family:var(--f-display);font-weight:600;font-size:14.5px}
.progress span{font-size:12.5px;color:#9AA3AE}
.progress .ptrack{grid-column:1/-1;height:5px;border-radius:5px;background:#2A313C;overflow:hidden;margin-top:9px}
.progress .pfill{height:100%;background:linear-gradient(90deg,var(--ember),var(--ember-2));transition:width .5s}

/* call-to-action banners */
.cta{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  border:1px solid var(--line);border-radius:12px;padding:16px 20px;margin-bottom:18px;background:var(--surface)}
.cta-next{border-color:var(--ember-line);background:linear-gradient(105deg,var(--ember-bg),var(--surface))}
.cta strong{font-family:var(--f-display);font-weight:600;font-size:15px;display:block}
.cta span{font-size:13px;color:var(--ink-2)}

/* ============================================================================
   ASSAY CARDS — verdict color carried into the surface + an icon-bearing rail
   ========================================================================== */
.assays{display:flex;flex-direction:column;gap:14px}
.assay{display:grid;grid-template-columns:84px 1fr;background:var(--surface);border:1px solid var(--line);
  border-radius:13px;overflow:hidden;box-shadow:var(--shadow);transition:box-shadow .15s,transform .15s,border-color .15s}
.assay:hover{box-shadow:var(--shadow-lift);transform:translateY(-1px)}
/* left rail: lens icon chip + assay code + verdict tick */
.assay-rail{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:10px;
  padding:18px 10px;border-right:1px solid var(--line-2);background:var(--surface-2);text-align:center}
.assay-rail .ico-lens{width:36px;height:36px;border-radius:10px}
.assay-code{font-family:var(--f-mono);font-weight:600;font-size:15px;letter-spacing:.01em;color:var(--ink);line-height:1.1}
.assay-tick{width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--on-accent)}
.assay-tick .ico{width:15px;height:15px}
.assay-rail .vlabel{font-family:var(--f-mono);font-size:9.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}

/* verdict theming — tinted surface, colored rail, colored tick, colored lens chip */
.assay.v-pass{border-color:var(--holds-line);background:linear-gradient(180deg,var(--holds-bg),var(--surface) 110px)}
.v-pass{border-left:3px solid var(--holds-solid)}
.v-pass .assay-rail{background:var(--holds-bg);border-right-color:var(--holds-line)}
.v-pass .assay-tick{background:var(--holds-solid)}
.v-pass .vlabel,.v-pass .assay-code{color:var(--holds)}
.v-pass .ico-lens{color:var(--holds);background:var(--holds-bg);border-color:var(--holds-line)}

.assay.v-weak{border-color:var(--weak-line);background:linear-gradient(180deg,var(--weak-bg),var(--surface) 110px)}
.v-weak{border-left:3px solid var(--weak-solid)}
.v-weak .assay-rail{background:var(--weak-bg);border-right-color:var(--weak-line)}
.v-weak .assay-tick{background:var(--weak-solid)}
.v-weak .vlabel,.v-weak .assay-code{color:var(--weak)}
.v-weak .ico-lens{color:var(--weak);background:var(--weak-bg);border-color:var(--weak-line)}

.assay.v-fail{border-color:var(--breaks-line);background:linear-gradient(180deg,var(--breaks-bg),var(--surface) 110px)}
.v-fail{border-left:3px solid var(--breaks-solid)}
.v-fail .assay-rail{background:var(--breaks-bg);border-right-color:var(--breaks-line)}
.v-fail .assay-tick{background:var(--breaks-solid)}
.v-fail .vlabel,.v-fail .assay-code{color:var(--breaks)}
.v-fail .ico-lens{color:var(--breaks);background:var(--breaks-bg);border-color:var(--breaks-line)}

.assay.v-needs_review{border-color:var(--review-line);background:linear-gradient(180deg,var(--review-bg),var(--surface) 110px)}
.v-needs_review{border-left:3px solid var(--review-solid)}
.v-needs_review .assay-rail{background:var(--review-bg);border-right-color:var(--review-line)}
.v-needs_review .assay-tick{background:var(--review-solid)}
.v-needs_review .vlabel,.v-needs_review .assay-code{color:var(--review)}
.v-needs_review .ico-lens{color:var(--review);background:var(--review-bg);border-color:var(--review-line)}

/* body */
.assay-body{padding:18px 20px;min-width:0}
.assay-name{display:flex;align-items:baseline;gap:9px;flex-wrap:wrap}
.assay-name h3{font-size:16px;font-weight:600}
.assay-name .measures{font-size:12.5px;color:var(--ink-3)}
.assay-expand{font-family:var(--f-mono);font-size:11px;color:var(--ink-3);margin-top:4px;letter-spacing:.01em}
.assay-q{font-size:12.5px;color:var(--ink-3);font-style:italic;margin:6px 0 0}
.assay-finding{font-family:var(--f-display);font-weight:600;font-size:15.5px;line-height:1.4;margin:13px 0 0;color:var(--ink)}
.assay-reason{font-size:14px;color:var(--ink-2);margin:9px 0 0;line-height:1.6}
.assay-fix{display:flex;gap:10px;margin:13px 0 0;font-size:14px;background:var(--surface-2);border:1px solid var(--line-2);border-radius:9px;padding:11px 13px}
.assay-fix .fixlbl{font-family:var(--f-mono);font-size:10.5px;font-weight:600;letter-spacing:.06em;color:var(--ember);text-transform:uppercase;flex:none;padding-top:2px}
.assay-evidence{margin:11px 0 0;font-size:12.5px;color:var(--ink-3);line-height:1.5}
.assay-evidence .lbl{margin-right:7px}
.assay-foot{margin-top:14px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.deepened-tag{font-family:var(--f-mono);font-size:9.5px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--ember);background:var(--ember-bg);border:1px solid var(--ember-line);padding:2px 7px;border-radius:5px}
@media(max-width:560px){.assay{grid-template-columns:1fr}.assay-rail{flex-direction:row;justify-content:flex-start;border-right:0;border-bottom:1px solid var(--line-2)}}

/* ============================================================================
   EXPAND / COLLAPSE (clamp)  — accessible show-more on overflow
   ========================================================================== */
.clamp{
  display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;
  -webkit-line-clamp:var(--clamp-lines,4);line-clamp:var(--clamp-lines,4);
  -webkit-mask-image:linear-gradient(180deg,#000 68%,transparent 100%);
  mask-image:linear-gradient(180deg,#000 68%,transparent 100%);
}
.clamp--open{
  display:block;-webkit-line-clamp:unset;line-clamp:unset;overflow:visible;
  -webkit-mask-image:none;mask-image:none;
}
.clamp-toggle{
  display:inline-flex;align-items:center;gap:6px;margin-top:9px;
  background:none;border:0;cursor:pointer;padding:2px 0;
  font-family:var(--f-mono);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ember);
}
.clamp-toggle:hover{color:var(--ember-2)}
.clamp-toggle .ico{width:14px;height:14px;transition:transform .18s ease}
.clamp-toggle[aria-expanded="true"] .ico{transform:rotate(180deg)}

/* auto-grow textareas hide their own scrollbar (JS sizes them) */
textarea[data-autogrow]{overflow:hidden}

/* ============================================================================
   DEEPEN / SHARPEN form
   ========================================================================== */
.sharpen{margin-top:14px;padding:16px;background:var(--surface-2);border:1px solid var(--line);border-radius:11px}
.sharpen-intro{margin:0 0 13px;font-size:13px;color:var(--ink-2)}
.sharpen-q{display:block;margin-bottom:12px}
.sharpen-q span{display:block;font-size:13px;font-weight:600;margin-bottom:5px}
.sharpen-q textarea{width:100%;border:1px solid var(--line);border-radius:8px;padding:9px 11px;font-family:var(--f-body);font-size:13.5px;resize:vertical;background:var(--elevated);color:var(--ink)}
.sharpen-q textarea:focus{outline:none;border-color:var(--ember);box-shadow:0 0 0 3px var(--ring)}
.sharpen-foot{display:flex;align-items:center;justify-content:flex-end;gap:12px}
.sharpen-slot:empty{display:none}
textarea:focus{outline:none}
.tray:focus-within{border-color:var(--ember);box-shadow:0 0 0 3px var(--ring)}

/* ============================================================================
   STRUCTURED v2 — "Reforged" change-memo  (premium dark on ANY theme)
   ========================================================================== */
.v2{
  --v2-ink:#EEF0F4; --v2-ink-2:#C2C8D2; --v2-ink-3:#8E97A4;
  --v2-line:rgba(255,255,255,.12); --v2-chip:rgba(255,255,255,.08); --v2-panel:rgba(255,255,255,.04);
  background:linear-gradient(165deg,#191d24,#23202c 70%,#2a2230);color:var(--v2-ink);
  border:1px solid #34303f;border-radius:16px;padding:26px;margin-bottom:22px;box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.v2::before{content:"";position:absolute;inset:0 0 auto 0;height:2px;background:linear-gradient(90deg,var(--ember),var(--ember-2),var(--gold))}
.v2-head{display:flex;flex-direction:column;gap:11px;margin-bottom:6px}
.v2-tag{display:inline-flex;align-items:center;gap:8px;align-self:flex-start;font-family:var(--f-mono);font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:#191d24;background:linear-gradient(90deg,var(--ember-2),var(--gold));padding:5px 11px;border-radius:6px}
.v2-headline{font-family:var(--f-display);font-weight:700;font-size:21px;line-height:1.32;letter-spacing:-.01em;color:#fff;margin:0}
.v2-summary{font-size:14.5px;line-height:1.6;color:var(--v2-ink-2);margin:0}

/* before → after shift */
.v2-shift{display:grid;grid-template-columns:1fr 1fr;gap:14px;position:relative;margin-top:18px}
.v2-shift::after{content:"\2192";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font-family:var(--f-mono);font-size:16px;font-weight:600;color:var(--ember-2);
  background:#23202c;border:1px solid var(--v2-line);border-radius:50%;width:26px;height:26px;display:flex;align-items:center;justify-content:center;z-index:1}
.v2-from,.v2-to{background:var(--v2-panel);border:1px solid var(--v2-line);border-radius:10px;padding:12px 14px;font-size:13.5px;line-height:1.5;color:var(--v2-ink-2)}
.v2-from::before,.v2-to::before{display:block;font-family:var(--f-mono);font-size:9.5px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;margin-bottom:6px;color:var(--v2-ink-3)}
.v2-from::before{content:"From"}
.v2-to{border-color:rgba(229,135,46,.32);color:var(--v2-ink)}
.v2-to::before{content:"To";color:var(--ember-2)}

/* change log */
.v2-changes{margin-top:20px;padding-top:6px}
.v2-changes-head{font-family:var(--f-mono);font-size:10.5px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--v2-ink-3);margin-bottom:4px}
.v2-change{display:grid;grid-template-columns:auto minmax(0,1fr);column-gap:13px;row-gap:6px;padding:14px 0;border-top:1px solid var(--v2-line)}
.v2-lens{grid-row:1/span 3;align-self:start;font-family:var(--f-mono);font-size:10.5px;font-weight:600;letter-spacing:.03em;
  color:#F0C98B;background:var(--v2-chip);border:1px solid var(--v2-line);padding:4px 9px;border-radius:6px;height:fit-content}
.v2-change-title{grid-column:2;font-family:var(--f-display);font-weight:600;font-size:14.5px;color:#fff;line-height:1.3}
.v2-delta{grid-column:2;display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:13px;line-height:1.5}
.d-from{color:var(--v2-ink-3);text-decoration:line-through;text-decoration-color:rgba(231,140,124,.5)}
.d-to{color:#7FD3A6;display:inline-flex;align-items:center;gap:8px}
.d-to::before{content:"\2192";color:var(--ember-2);font-family:var(--f-mono);text-decoration:none}
.v2-why{grid-column:2;font-size:12.5px;color:var(--v2-ink-3);font-style:italic;line-height:1.5}

/* full rewritten idea (clamped) */
.v2-rewrite{margin-top:20px;padding:16px 18px;background:var(--v2-panel);border:1px solid var(--v2-line);border-radius:11px}
.v2-rewrite-head{font-family:var(--f-mono);font-size:10.5px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--v2-ink-3);margin-bottom:9px}
.v2-rewrite-body{font-size:14.5px;line-height:1.7;color:var(--v2-ink-2);white-space:pre-line}
.v2-rewrite .clamp-toggle{color:var(--ember-2)}
.v2-rewrite .clamp-toggle:hover{color:var(--gold)}

/* next steps */
.v2-next{margin-top:20px;padding-top:16px;border-top:1px solid var(--v2-line)}
.v2-next-head{font-family:var(--f-mono);font-size:10.5px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--v2-ink-3);margin-bottom:11px}
.v2-next ol{list-style:none;counter-reset:step;margin:0;padding:0;display:grid;gap:10px}
.v2-next li{counter-increment:step;display:grid;grid-template-columns:auto 1fr;gap:11px;align-items:start;font-size:14px;line-height:1.5;color:var(--v2-ink-2)}
.v2-next li::before{content:counter(step);font-family:var(--f-mono);font-size:11px;font-weight:600;color:var(--ember-2);
  background:var(--v2-chip);border:1px solid var(--v2-line);border-radius:6px;width:22px;height:22px;display:flex;align-items:center;justify-content:center}
@media(max-width:560px){.v2-shift{grid-template-columns:1fr}.v2-shift::after{display:none}}

/* ---- legacy reforged classes (kept for back-compat; same dark identity) ---- */
.reforged{background:linear-gradient(165deg,#191d24,#23202c 70%,#2a2230);color:#EEF0F4;
  border:1px solid #34303f;border-radius:14px;padding:26px;margin-bottom:22px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.reforged::before{content:"";position:absolute;inset:0 0 auto 0;height:2px;background:linear-gradient(90deg,var(--ember),var(--ember-2),var(--gold))}
.reforged-tag{display:inline-flex;align-items:center;gap:8px;font-family:var(--f-mono);font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:#191d24;background:linear-gradient(90deg,var(--ember-2),var(--gold));padding:5px 11px;border-radius:6px}
.reforged-headline{font-family:var(--f-display);font-weight:700;font-size:19px;line-height:1.35;letter-spacing:-.01em;margin:15px 0 0;color:#fff}
.reforged-text{font-size:15px;line-height:1.7;color:#D6DAE2;margin:12px 0 0;white-space:pre-line}
.reforged-changes{margin-top:20px;padding-top:16px;border-top:1px solid #ffffff1c}
.reforged-changes ul{list-style:none;padding:0;margin:11px 0 0;display:grid;gap:9px}
.reforged-changes li{font-size:13.5px;color:#D6DAE2;line-height:1.5;display:flex;gap:10px}
.reforged-changes .fw{font-family:var(--f-mono);font-size:10.5px;font-weight:600;color:#F0C98B;background:#ffffff14;border:1px solid #ffffff1f;padding:3px 8px;border-radius:6px;flex:none;height:fit-content;letter-spacing:.03em}

/* ============================================================================
   REFINEMENT RECORD — timeline of sharpenings under a card
   ========================================================================== */
.refined-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--f-mono);font-size:9.5px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;
  color:var(--ember);background:var(--ember-bg);border:1px solid var(--ember-line);padding:3px 8px;border-radius:5px}
.refined-badge .ico{width:12px;height:12px;color:var(--ember)}

.refine-log{margin-top:14px;padding-top:14px;border-top:1px dashed var(--line);display:flex;flex-direction:column;gap:13px}
.refine-log-head{font-family:var(--f-mono);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3)}
.refine-item{display:grid;grid-template-columns:auto 1fr;column-gap:11px;row-gap:7px;align-items:start;
  background:var(--surface-2);border:1px solid var(--line-2);border-radius:10px;padding:12px 14px}
.refine-item > .ico{grid-row:1/span 3;color:var(--ember);width:16px;height:16px;margin-top:2px}
.rf-note{font-size:13.5px;font-weight:600;color:var(--ink);line-height:1.4}
.rf-shift{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}
.rf-from,.rf-to{display:inline-flex;align-items:center;gap:5px;font-family:var(--f-mono);font-size:11px;font-weight:600;
  padding:2px 8px;border-radius:5px;border:1px solid var(--line)}
.rf-from{color:var(--ink-3);background:var(--surface)}
.rf-to{color:var(--ink);background:var(--elevated)}
.rf-shift .ico{width:13px;height:13px;color:var(--ink-3)}
/* verdict tint on the chips when a v- modifier is present */
.rf-from.v-pass,.rf-to.v-pass{color:var(--holds);border-color:var(--holds-line);background:var(--holds-bg)}
.rf-from.v-weak,.rf-to.v-weak{color:var(--weak);border-color:var(--weak-line);background:var(--weak-bg)}
.rf-from.v-fail,.rf-to.v-fail{color:var(--breaks);border-color:var(--breaks-line);background:var(--breaks-bg)}
.rf-from.v-needs_review,.rf-to.v-needs_review{color:var(--review);border-color:var(--review-line);background:var(--review-bg)}
.rf-detail{grid-column:2;font-size:12.5px;color:var(--ink-2);line-height:1.55;border-left:2px solid var(--line);padding-left:11px;font-style:italic}
.rf-detail b{font-style:normal;font-family:var(--f-mono);font-size:10.5px;font-weight:600;letter-spacing:.04em;color:var(--ink-3);text-transform:uppercase;display:block;margin-bottom:2px}

/* ============================================================================
   SPINNER / INDICATORS / ERRORS
   ========================================================================== */
.htmx-indicator{display:none;align-items:center;gap:8px;color:var(--ink-3);font-size:13px}
.htmx-request .htmx-indicator,.htmx-indicator.htmx-request{display:inline-flex}
.spinner{width:15px;height:15px;border:2px solid color-mix(in srgb,var(--ink-3) 35%,transparent);border-top-color:var(--ember);border-radius:50%;display:inline-block;animation:spin .7s linear infinite}
.progress .spinner{border-color:#ffffff2a;border-top-color:var(--ember-2);width:18px;height:18px}
@keyframes spin{to{transform:rotate(360deg)}}
.errbox{background:var(--breaks-bg);color:var(--breaks);border:1px solid var(--breaks-line);padding:13px 15px;border-radius:10px}

/* ============================================================================
   CRITERIA BREAKDOWN — the per-lens sub-criteria scorecard inside each card
   ========================================================================== */
.breakdown{margin:14px 0 0;border:1px solid var(--line-2);border-radius:10px;background:var(--surface)}
.breakdown-head{display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:8px 13px;background:var(--surface-2);border-bottom:1px solid var(--line-2);border-radius:9px 9px 0 0}
.breakdown-head .lbl{display:inline-flex;align-items:center;gap:6px}
.sub-tally{display:inline-flex;gap:10px;font-family:var(--f-mono);font-size:11.5px;font-weight:600}
.sub-tally .st{display:inline-flex;align-items:center;gap:3px}
.sub-tally .st .ico{width:13px;height:13px}
.sub-tally .st-h{color:var(--holds)} .sub-tally .st-w{color:var(--weak)} .sub-tally .st-b{color:var(--breaks)}
.subcrits{list-style:none;margin:0;padding:0}
.subcrit{display:grid;grid-template-columns:18px minmax(92px,max-content) 1fr;align-items:baseline;gap:11px;
  padding:9px 13px;border-bottom:1px solid var(--line-2);border-left:3px solid transparent}
.subcrit:last-child{border-bottom:0;border-radius:0 0 9px 9px}
.subcrit .sc-tick{align-self:start;display:inline-flex}
.subcrit .sc-tick .ico{width:15px;height:15px}
.sc-name{font-family:var(--f-mono);font-size:11.5px;font-weight:600;letter-spacing:.02em;color:var(--ink)}
.sc-finding{font-size:13px;color:var(--ink-2);line-height:1.5}
.sc-pass{border-left-color:var(--holds)} .sc-pass .sc-tick{color:var(--holds)}
.sc-weak{border-left-color:var(--weak)} .sc-weak .sc-tick{color:var(--weak)}
.sc-fail{border-left-color:var(--breaks)} .sc-fail .sc-tick{color:var(--breaks)}
.sc-needs_review{border-left-color:var(--review)} .sc-needs_review .sc-tick{color:var(--review)}
@media(max-width:560px){.subcrit{grid-template-columns:18px 1fr;gap:4px 11px}.sc-finding{grid-column:2}}

/* ============================================================================
   TOOLTIPS — accessible hover/focus/tap descriptors (the "what does this mean?")
   The chip uses the graphite palette so it reads identically in light & dark.
   ========================================================================== */
/* inline-block gives a single atomic box, so the absolutely-positioned tip has a
   reliable origin (a plain inline hint that wraps across lines does not). */
.hint{position:relative;outline:none;display:inline-block;vertical-align:baseline}
.hint[tabindex]{cursor:help}
.hint:focus-visible{outline:2px solid var(--ring);outline-offset:2px;border-radius:4px}
/* dotted underline cue on inline text terms */
.sc-name.hint,.nm.hint{border-bottom:1px dotted var(--ink-3);text-decoration:none}
.hint-info{display:inline-flex;vertical-align:-2px;margin-left:5px;color:var(--ink-3)}
.hint-info:hover,.hint-info:focus-visible{color:var(--ember)}
.hint-info .ico{width:14px;height:14px}
.hint .tip{
  position:absolute;bottom:calc(100% + 9px);left:0;z-index:50;
  width:max-content;max-width:250px;display:flex;flex-direction:column;gap:4px;
  padding:9px 11px;border-radius:9px;
  background:var(--graphite-2);color:var(--graphite-ink);border:1px solid var(--graphite-line);
  box-shadow:var(--shadow-lift);
  font-family:var(--f-body);font-size:12.5px;font-weight:400;line-height:1.46;
  letter-spacing:0;text-transform:none;white-space:normal;text-align:left;
  opacity:0;transform:translateY(3px);pointer-events:none;
  transition:opacity .12s ease,transform .12s ease;
}
.hint .tip b{font-family:var(--f-mono);font-size:10.5px;font-weight:600;letter-spacing:.04em;
  color:var(--graphite-ink);text-transform:none}
.hint .tip::after{content:"";position:absolute;top:100%;left:var(--arrow-x,15px);border:6px solid transparent;border-top-color:var(--graphite-2)}
.hint:hover .tip,.hint:focus-visible .tip,.hint.is-open .tip{opacity:1;transform:translateY(0)}
/* flip below when there isn't room above (set by JS — masthead or a clipping ancestor) */
.hint.tip-below .tip{bottom:auto;top:calc(100% + 9px);transform:translateY(-3px)}
.hint.tip-below:hover .tip,.hint.tip-below:focus-visible .tip,.hint.tip-below.is-open .tip{transform:translateY(0)}
.hint.tip-below .tip::after{top:auto;bottom:100%;left:var(--arrow-x,15px);border-top-color:transparent;border-bottom-color:var(--graphite-2)}
@media(prefers-reduced-motion:reduce){.hint .tip{transition:none}}

/* masthead Method link (replaces the static tagline) */
.masthead-method-link{display:inline-flex;align-items:center;gap:6px;
  font-family:var(--f-mono);font-size:11.5px;font-weight:500;letter-spacing:.03em;
  color:var(--graphite-ink-2);text-decoration:none;padding:5px 4px;transition:color .15s ease}
.masthead-method-link:hover{color:var(--graphite-ink)}
.masthead-method-link .ico{width:15px;height:15px}

/* ============================================================================
   METHOD PAGE — the public reference for the lenses, sub-criteria & scales
   ========================================================================== */
.method{max-width:760px}
.method-intro{margin-bottom:8px}
.method-block{margin:30px 0;padding-top:26px;border-top:1px solid var(--line)}
.method-h{font-family:var(--f-display);font-size:20px;font-weight:600;color:var(--ink);margin:0 0 4px}
.method-sub{color:var(--ink-3);font-size:13.5px;margin:0 0 16px}
.vscale,.rbands{display:grid;gap:10px}
.vscale-row{display:grid;grid-template-columns:24px 1fr;gap:13px;align-items:start;
  padding:13px 15px;border:1px solid var(--line-2);border-left:3px solid var(--line);border-radius:10px;background:var(--surface)}
.vscale-row .vscale-tick{display:inline-flex}.vscale-row .vscale-tick .ico{width:20px;height:20px}
.vscale-row.v-pass{border-left-color:var(--holds)}.vscale-row.v-pass .vscale-tick{color:var(--holds)}
.vscale-row.v-weak{border-left-color:var(--weak)}.vscale-row.v-weak .vscale-tick{color:var(--weak)}
.vscale-row.v-fail{border-left-color:var(--breaks)}.vscale-row.v-fail .vscale-tick{color:var(--breaks)}
.vscale-row.v-needs_review{border-left-color:var(--review)}.vscale-row.v-needs_review .vscale-tick{color:var(--review)}
.vscale-label{font-family:var(--f-display);font-weight:600;font-size:14.5px;color:var(--ink);display:flex;gap:9px;align-items:baseline}
.vscale-label em{font-style:normal;font-family:var(--f-mono);font-size:10.5px;font-weight:500;color:var(--ink-3);text-transform:uppercase;letter-spacing:.05em}
.vscale-full{display:block;color:var(--ink-2);font-size:13px;margin-top:3px;line-height:1.45}
.rband{display:grid;grid-template-columns:max-content 1fr;gap:15px;align-items:center;
  padding:12px 15px;border:1px solid var(--line-2);border-radius:10px;background:var(--surface)}
.rband-text{color:var(--ink-2);font-size:13px;line-height:1.45}
.method-lenses{display:grid;gap:14px}
.method-lens{display:grid;grid-template-columns:78px 1fr;gap:18px;padding:18px 20px;
  border:1px solid var(--line);border-radius:13px;background:var(--surface);box-shadow:var(--shadow)}
.ml-rail{display:flex;flex-direction:column;align-items:center;gap:8px;padding-top:3px;color:var(--ink-2);
  border-right:1px solid var(--line-2)}
.ml-rail .ico-lens{width:26px;height:26px}
.ml-code{font-family:var(--f-mono);font-size:10.5px;font-weight:600;letter-spacing:.07em;color:var(--ink-3)}
.ml-title{font-family:var(--f-display);font-size:17px;font-weight:600;margin:0 0 4px;color:var(--ink)}
.ml-blurb{color:var(--ink-2);font-size:14px;margin:0 0 9px;line-height:1.5}
.ml-q{font-size:12.5px;color:var(--ink-3);margin:0 0 13px;line-height:1.45}
.ml-q .lbl{margin-right:5px}
.ml-subs{list-style:none;margin:0;padding:0;border-top:1px solid var(--line-2)}
.ml-sub{display:grid;grid-template-columns:minmax(118px,168px) 1fr;gap:16px;padding:9px 0;border-bottom:1px solid var(--line-2)}
.ml-sub:last-child{border-bottom:0}
.ml-sub-name{font-family:var(--f-mono);font-size:12px;font-weight:600;color:var(--ink)}
.ml-sub-desc{color:var(--ink-2);font-size:13px;line-height:1.46}
.method-foot{margin-top:30px;display:flex;justify-content:center}
@media(max-width:620px){
  .method-lens{grid-template-columns:1fr}
  .ml-rail{flex-direction:row;justify-content:flex-start;gap:10px;border-right:0;border-bottom:1px solid var(--line-2);padding-bottom:10px}
  .ml-sub{grid-template-columns:1fr;gap:2px}
}

/* ============================================================================
   ACCOUNTS — masthead identity, auth forms, account page, pricing
   ========================================================================== */
.masthead-acct{display:inline-flex;align-items:center;gap:6px;color:var(--graphite-ink);text-decoration:none;
  font-size:13px;font-weight:500;padding:5px 8px;border-radius:8px;transition:background .15s}
.masthead-acct:hover{background:var(--graphite-2)}
.masthead-acct .ico{width:16px;height:16px}
.tier-chip{display:inline-flex;align-items:center;gap:4px;font-family:var(--f-mono);font-size:10.5px;font-weight:600;
  letter-spacing:.04em;text-transform:uppercase;padding:3px 8px;border-radius:999px}
.tier-chip.tier-pro{color:var(--ember-2);background:rgba(229,135,46,.13);border:1px solid var(--ember-line)}
.tier-chip .ico{width:12px;height:12px}
.credit-chip{display:inline-flex;align-items:center;gap:5px;font-family:var(--f-mono);font-size:12px;font-weight:600;
  color:var(--ember-2);background:rgba(229,135,46,.10);border:1px solid var(--ember-line);
  padding:3px 9px;border-radius:999px;text-decoration:none;line-height:1}
.credit-chip:hover{background:rgba(229,135,46,.18)}
.credit-chip .ico{width:13px;height:13px}

/* auth forms */
.authbox{max-width:420px}
.authform{display:flex;flex-direction:column;gap:14px;margin:22px 0 16px}
.field{display:flex;flex-direction:column;gap:6px}
.field .lbl{margin:0}
.field input{font-family:var(--f-body);font-size:15px;color:var(--ink);background:var(--surface);
  border:1px solid var(--line);border-radius:10px;padding:11px 13px;transition:border-color .15s,box-shadow .15s}
.field input:focus{outline:none;border-color:var(--ember-2);box-shadow:0 0 0 3px var(--ring)}
.authform .btn{margin-top:4px;justify-content:center}
.auth-alt{color:var(--ink-3);font-size:13.5px}
.auth-alt a{color:var(--ember);text-decoration:none;font-weight:500}
/* Google sign-in: neutral white button + "or" divider */
.btn-google{width:100%;justify-content:center;gap:10px;background:var(--surface);color:var(--ink);
  border:1px solid var(--line);font-weight:500;box-shadow:0 1px 2px rgba(20,20,20,.04)}
.btn-google:hover{background:var(--surface-2,#f6f4ef);border-color:var(--ember-2)}
.btn-google .g-logo{flex:0 0 auto}
.auth-or{display:flex;align-items:center;gap:12px;margin:16px 0 2px;color:var(--ink-3);font-size:12.5px}
.auth-or::before,.auth-or::after{content:"";flex:1;height:1px;background:var(--line)}
.form-error{display:flex;align-items:center;gap:8px;background:var(--breaks-bg);border:1px solid var(--breaks-line);
  color:var(--breaks);border-radius:10px;padding:10px 13px;font-size:13.5px;margin-bottom:14px}
.form-ok{display:flex;align-items:center;gap:8px;background:var(--holds-bg);border:1px solid var(--holds-line);
  color:var(--holds);border-radius:10px;padding:10px 13px;font-size:13.5px;margin-bottom:14px}
.form-error .ico,.form-ok .ico{flex:none}

/* account page */
.account{max-width:680px}
.acct-finalizing{display:flex;align-items:center;gap:10px;margin:18px 0 0;padding:12px 15px;
  background:var(--ember-bg);border:1px solid var(--ember-line);border-radius:11px;
  color:var(--ink-2);font-size:.92rem;line-height:1.45}
.acct-finalizing.is-slow{background:var(--surface-2);border-color:var(--line)}
.acct-spin{flex:none;width:15px;height:15px;border-radius:50%;
  border:2px solid var(--ember-line);border-top-color:var(--ember);animation:spin .7s linear infinite}
@media(prefers-reduced-motion:reduce){.acct-spin{animation:none}}
.acct-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:22px 0}
.acct-card{background:var(--surface);border:1px solid var(--line);border-radius:13px;box-shadow:var(--shadow);
  padding:18px 20px;display:flex;flex-direction:column;gap:12px}
.acct-card .lbl{margin:0}
.plan-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.tier-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--f-display);font-weight:600;font-size:15px;
  padding:5px 12px;border-radius:999px}
.tier-badge.tier-free{color:var(--ink-2);background:var(--surface-2);border:1px solid var(--line-2)}
.tier-badge.tier-pro{color:var(--ember-2);background:rgba(229,135,46,.12);border:1px solid var(--ember-line)}
.usage{display:flex;flex-direction:column;gap:8px}
.usage-nums{font-family:var(--f-display);font-size:15px;color:var(--ink)}
.usage-nums b{font-size:22px}
.usage-nums span{color:var(--ink-3)}
.usage-track{height:8px;background:var(--surface-2);border:1px solid var(--line-2);border-radius:999px;overflow:hidden}
.usage-fill{height:100%;background:linear-gradient(90deg,var(--ember),var(--ember-2));border-radius:999px}
.usage-fill.is-full{background:linear-gradient(90deg,var(--breaks),var(--breaks-solid))}
.usage-sub{font-size:12.5px;color:var(--ink-3)}
.usage-sub a{color:var(--ember);text-decoration:none;font-weight:500}
/* account — credit wallet */
.credits-box{display:flex;flex-direction:column;gap:9px;align-items:flex-start}
.credits-nums{font-family:var(--f-display);font-size:15px;color:var(--ink)}
.credits-nums b{font-size:26px;color:var(--ember-2)}
.credits-nums span{color:var(--ink-3);margin-left:4px}
.credit-ledger{margin:0 0 22px}
.credit-ledger .bill-table{width:100%;border-collapse:collapse;font-size:13px}
.credit-ledger th{text-align:left;font-family:var(--f-mono);font-size:10.5px;text-transform:uppercase;
  letter-spacing:.04em;color:var(--ink-3);padding:4px 8px;border-bottom:1px solid var(--line-2)}
.credit-ledger td{padding:6px 8px;border-bottom:1px solid var(--line-2);color:var(--ink-2)}
.credit-ledger .ta-r{text-align:right}
.credit-ledger .led-plus{color:var(--depth,#2e7d5b);font-weight:600}
.credit-ledger .led-minus{color:var(--ink-3);font-weight:600}
.acct-logout{margin-top:6px}
.cta-quota{border-color:var(--ember-line);background:var(--ember-bg)}

/* account — Pro billing detail (status / invoices / cancel) */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0}
.billing-detail{margin:14px 0 0;display:flex;flex-direction:column;gap:12px}
.billing-card{gap:14px}
.billing-banner{display:flex;align-items:center;gap:9px;padding:11px 14px;border-radius:11px;
  font-size:.9rem;line-height:1.45;border:1px solid var(--line)}
.billing-banner .ico{flex:none;width:16px;height:16px}
.billing-banner.is-ok{background:var(--holds-bg);border-color:var(--holds-line);color:var(--holds)}
.billing-banner.is-err{background:var(--breaks-bg);border-color:var(--breaks-line);color:var(--breaks-solid)}
.bill-feats{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.bill-feats li{display:flex;align-items:flex-start;gap:9px;font-size:14px;color:var(--ink-2);line-height:1.4}
.bill-feats .ico{flex:none;width:16px;height:16px;color:var(--holds);margin-top:1px}
.bill-status{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.bill-amount{font-family:var(--f-display);font-weight:600;font-size:15px;color:var(--ink)}
.status-badge{display:inline-flex;align-items:center;font-family:var(--f-mono);font-size:11px;font-weight:600;
  letter-spacing:.04em;text-transform:uppercase;padding:4px 10px;border-radius:999px;border:1px solid var(--line-2)}
.status-badge.is-active{color:var(--holds);background:var(--holds-bg);border-color:var(--holds-line)}
.status-badge.is-ending{color:var(--ember-2);background:var(--ember-bg);border-color:var(--ember-line)}
.status-badge.is-inactive{color:var(--ink-3);background:var(--surface-2)}
.bill-note{margin:0;font-size:13px;color:var(--ink-3);line-height:1.5}
.bill-history{display:flex;flex-direction:column;gap:8px}
.bill-table{width:100%;border-collapse:collapse;font-size:13px}
.bill-table th{text-align:left;font-family:var(--f-mono);font-size:11px;font-weight:600;letter-spacing:.03em;
  text-transform:uppercase;color:var(--ink-3);padding:0 10px 7px 0;border-bottom:1px solid var(--line-2)}
.bill-table td{padding:8px 10px 8px 0;border-bottom:1px solid var(--line-2);color:var(--ink-2);vertical-align:middle}
.bill-table tr:last-child td{border-bottom:0}
.inv-status{text-transform:capitalize}
.inv-link{color:var(--ember);text-decoration:none;font-weight:500}
.inv-link:hover{text-decoration:underline}
.bill-cancel{align-self:flex-start;font-size:13px;color:var(--ink-3);text-decoration:underline;text-underline-offset:2px}
.bill-cancel:hover{color:var(--breaks-solid)}
.cancel-confirm{max-width:560px}
.cancel-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:4px}

/* pricing */
.pricing{max-width:760px}
.plans{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:24px 0 14px}
.plan{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);
  padding:22px 22px 24px;display:flex;flex-direction:column;gap:16px}
.plan-pro{border-color:var(--ember-line);box-shadow:var(--shadow-lift)}
.plan-current{outline:2px solid var(--ember-2);outline-offset:-2px}
.plan-badge{position:absolute;top:-11px;right:18px;display:inline-flex;align-items:center;gap:5px;
  font-family:var(--f-mono);font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;
  color:var(--on-accent);background:linear-gradient(90deg,var(--ember),var(--ember-2));padding:4px 11px;border-radius:999px}
.plan-badge .ico{width:13px;height:13px}
.plan-head{display:flex;align-items:baseline;justify-content:space-between}
.plan-name{font-family:var(--f-display);font-weight:600;font-size:18px;color:var(--ink)}
.plan-price{font-family:var(--f-display);font-weight:700;font-size:30px;color:var(--ink)}
.plan-price small{font-size:14px;font-weight:500;color:var(--ink-3)}
.plan-feats{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.plan-feats li{display:flex;align-items:flex-start;gap:9px;font-size:14px;color:var(--ink-2);line-height:1.4}
.plan-feats .ico{flex:none;width:16px;height:16px;color:var(--holds);margin-top:1px}
.plan .btn{justify-content:center}
.plan-cta-note{display:inline-flex;align-items:center;gap:6px;color:var(--ink-3);font-size:13px;font-weight:500}
.plan-cta-note .ico{color:var(--holds)}
.pricing-foot{color:var(--ink-3);font-size:12.5px;text-align:center;margin-top:6px}
.region-note{display:inline-flex;align-items:center;gap:7px;margin:0 0 4px;padding:7px 12px;
  font-size:13px;color:var(--ember-2);background:var(--ember-bg);border:1px solid var(--ember-line);border-radius:999px}
.region-note .ico{width:15px;height:15px;flex:none}
.plan-was{margin-left:8px;font-size:15px;font-weight:500;color:var(--ink-3);text-decoration:line-through;vertical-align:middle}
/* pricing — credit wallet */
.pricing-sub{font-family:var(--f-display);font-size:16px;font-weight:600;color:var(--ink-2);
  margin:26px 0 12px;letter-spacing:.01em}
.pricing-balance{display:inline-flex;align-items:center;gap:7px;margin:2px 0 0;padding:6px 12px;font-size:13px;
  color:var(--ember-2);background:var(--ember-bg);border:1px solid var(--ember-line);border-radius:999px}
.pricing-balance .ico{width:15px;height:15px}
.packs{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:0 0 8px}
.pack{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);
  padding:20px 18px;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}
.pack-pop{border-color:var(--ember-line);box-shadow:0 0 0 1px var(--ember-line),var(--shadow)}
.pack-badge{position:absolute;top:-11px;display:inline-flex;align-items:center;gap:4px;font-family:var(--f-mono);
  font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#fff;background:var(--ember-2);
  padding:3px 10px;border-radius:999px}
.pack-badge .ico{width:11px;height:11px}
.pack-name{font-family:var(--f-mono);font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3)}
.pack-credits{font-family:var(--f-display);color:var(--ink-3);font-size:13px}
.pack-credits b{font-size:34px;color:var(--ember-2);margin-right:4px}
.pack-price{font-family:var(--f-display);font-size:22px;font-weight:600;color:var(--ink)}
.pack-each{font-size:11.5px;color:var(--ink-3);margin-bottom:8px}
.pack form,.pack .btn{width:100%}
@media(max-width:620px){.acct-grid,.plans,.packs{grid-template-columns:1fr}}

/* ============================================================================
   LEGAL pages + global footer
   ========================================================================== */
.legal{max-width:760px}
.legal-meta{color:var(--ink-3);font-size:13px;margin:-4px 0 22px}
.legal h2{font-family:var(--f-display);font-size:18px;font-weight:600;color:var(--ink);
  margin:26px 0 8px;padding-top:4px}
.legal p,.legal li{color:var(--ink-2);font-size:14.5px;line-height:1.62}
.legal p{margin:0 0 12px}
.legal ul{margin:0 0 14px;padding-left:20px;display:flex;flex-direction:column;gap:6px}
.legal a:not(.btn){color:var(--ember);text-decoration:none}
.legal a:not(.btn):hover{text-decoration:underline}
.legal-callout{background:var(--surface-2);border:1px solid var(--line-2);border-left:3px solid var(--ember-2);
  border-radius:8px;padding:12px 15px;margin:8px 0 14px}

.site-foot{margin-top:48px;padding:18px 0 10px;border-top:1px solid var(--line-2);
  display:flex;align-items:center;justify-content:space-between;gap:10px 20px;flex-wrap:wrap}
.site-foot-brand{font-family:var(--f-mono);font-weight:500;color:var(--ink-3);font-size:12px;letter-spacing:.02em}
.site-foot-links{display:flex;flex-wrap:wrap;align-items:center}
.site-foot-links a{color:var(--ink-3);text-decoration:none;font-size:13px;transition:color .15s}
.site-foot-links a:hover{color:var(--ember)}
.site-foot-links a:not(:last-child)::after{content:"·";margin:0 12px;color:var(--ink-3);opacity:.45}

/* ============================================================================
   PENDING PLACEHOLDER — each lens slot shows its identity + an animated skeleton
   while its result streams in (cards render & update independently)
   ========================================================================== */
.assay--pending{border-style:dashed}
.assay--pending .assay-rail{background:var(--surface-2)}
.assay--pending .ico-lens{animation:lens-pulse 1.6s ease-in-out infinite}
.assay--pending .vlabel{color:var(--ink-3)}
.pending-dot{width:8px;height:8px;border-radius:50%;background:var(--ember);animation:pending-pulse 1.5s ease-out infinite}
.pending-label{display:inline-flex;align-items:center;gap:7px;font-family:var(--f-mono);font-size:11px;
  letter-spacing:.05em;text-transform:uppercase;color:var(--ember);margin:15px 0 13px}
.pending-label .ico{animation:lens-pulse 1.6s ease-in-out infinite}
.skel{position:relative;overflow:hidden;background:var(--surface-2);border-radius:6px}
.skel::after{content:"";position:absolute;inset:0;transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--ink-3) 16%,transparent),transparent);
  animation:shimmer 1.45s infinite}
.skel-line{height:11px;margin-bottom:10px}
.skel-line.w100{width:100%}.skel-line.w90{width:90%}.skel-line.w70{width:70%}
.skel-fix{height:44px;border-radius:9px;margin-top:8px}
@keyframes shimmer{100%{transform:translateX(100%)}}
@keyframes pending-pulse{0%{box-shadow:0 0 0 0 var(--ember-line)}70%{box-shadow:0 0 0 7px transparent}100%{box-shadow:0 0 0 0 transparent}}
@keyframes lens-pulse{0%,100%{opacity:.5}50%{opacity:1}}

/* ============================================================================
   ACCESSIBILITY / MOTION / RESPONSIVE
   ========================================================================== */
@media(prefers-reduced-motion:reduce){*{animation-duration:.001ms!important;transition-duration:.001ms!important}}
@media(max-width:820px){.shell{grid-template-columns:1fr}.archive{display:none}}
:focus-visible{outline:2px solid var(--ember);outline-offset:2px;border-radius:4px}

/* ===== copy buttons ===== */
/* Unobtrusive copy-to-clipboard controls. The .copy-default / .copy-done spans
   are swapped by copy.js toggling .is-copied on the button (~1.5s). */
.copy-host{position:relative}
.copy-btn{display:inline-flex;align-items:center;gap:5px;flex:none;
  font-family:var(--f-mono);font-size:10.5px;font-weight:600;letter-spacing:.04em;
  color:var(--ink-3);background:var(--surface);border:1px solid var(--line);
  border-radius:7px;padding:3px 7px;cursor:pointer;line-height:1;
  transition:opacity .15s,color .15s,border-color .15s,background .15s}
.copy-btn:hover{color:var(--ember);border-color:var(--ink-3)}
.copy-btn .ico{width:14px;height:14px}
.copy-btn .copy-done{display:none;align-items:center;gap:5px;color:var(--ember)}
.copy-btn.is-copied{color:var(--ember);border-color:var(--ember-line)}
.copy-btn.is-copied .copy-default{display:none}
.copy-btn.is-copied .copy-done{display:inline-flex}

/* floating copy buttons pinned to the top-right of their host section; kept out
   of the way until the section is hovered/focused (always reachable by keyboard
   via focus-within / focus-visible, and forced visible while showing "Copied!") */
.copy-host > .copy-btn{position:absolute;top:0;right:0;opacity:0}
.copy-host:hover > .copy-btn,
.copy-host:focus-within > .copy-btn,
.copy-host > .copy-btn:focus-visible,
.copy-host > .copy-btn.is-copied{opacity:1}
.v2-rewrite.copy-host > .copy-btn{top:14px;right:16px}
.assay-fix.copy-host > .copy-btn{position:static;align-self:flex-start;margin-left:auto}

/* the inline "Copy as Markdown" button mirrors the export link's .btn styling;
   only its label swaps, so no absolute positioning here */
.copy-md{cursor:pointer}
.copy-md .copy-default{display:inline-flex;align-items:center;gap:8px}
.copy-md .copy-done{display:none;align-items:center;gap:8px}
.copy-md.is-copied{color:var(--ember);border-color:var(--ember-line)}
.copy-md.is-copied .copy-default{display:none}
.copy-md.is-copied .copy-done{display:inline-flex}

/* ===== document upload ===== */
/* Drop a PDF/DOCX/TXT/MD onto the specimen field (or use the button) and upload.js
   pre-fills the idea textarea with the extracted text. CSP-safe: all behaviour lives
   in upload.js; only presentational state classes are toggled here. */
.tray{position:relative}
/* keep the submit button and the upload controls on one row, wrapping gracefully */
.tray-foot-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;min-width:0}
.tray-foot-actions .btn-line .ico{color:var(--ink-3)}
.tray-foot-actions .tray-hint{flex:1 1 12ch;min-width:0}

/* drag-over: highlight the tray and reveal the centred drop overlay */
.tray.is-dragover{border-color:var(--ember);box-shadow:0 0 0 3px var(--ring)}
.upload-drop-hint{position:absolute;inset:42px 10px 56px;z-index:3;display:none;
  align-items:center;justify-content:center;gap:8px;pointer-events:none;
  font-family:var(--f-mono);font-size:12px;font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;color:var(--ember);
  background:var(--ember-bg);border:1.5px dashed var(--ember-line);border-radius:10px}
.upload-drop-hint.is-visible{display:flex}
.upload-drop-hint .ico{width:16px;height:16px}

/* inline status line next to the upload button — spinner while busy, ember-on-error */
.upload-status{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;
  color:var(--ink-3);max-width:48ch;overflow:hidden;text-overflow:ellipsis}
.upload-status.is-busy{color:var(--ink-2)}
.upload-status.is-busy::before{content:"";width:13px;height:13px;flex:none;
  border:2px solid var(--line);border-top-color:var(--ember);border-radius:50%;
  animation:upload-spin .7s linear infinite}
.upload-status.is-error{color:var(--ember)}
@keyframes upload-spin{to{transform:rotate(360deg)}}
@media(prefers-reduced-motion:reduce){.upload-status.is-busy::before{animation:none}}

/* ===== spotlight search ===== */
/* Sidebar trigger + centred command palette over the user's specimens. CSP-safe:
   all behaviour lives in search.js; only presentational state classes toggle here. */
.spotlight-trigger{display:flex;align-items:center;gap:8px;width:100%;
  margin-bottom:18px;padding:9px 11px;cursor:pointer;text-align:left;
  background:var(--elevated);border:1px solid var(--line);border-radius:9px;
  color:var(--ink-3);font:inherit;font-size:13px;line-height:1;
  transition:border-color .12s,color .12s,box-shadow .12s}
.spotlight-trigger:hover{border-color:var(--ink-3);color:var(--ink-2)}
.spotlight-trigger:focus-visible{outline:none;border-color:var(--ember);box-shadow:0 0 0 3px var(--ring)}
.spotlight-trigger .ico{flex:none;color:var(--ink-3)}
.spotlight-trigger-label{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.spotlight-kbd{flex:none;font-family:var(--f-mono);font-size:10.5px;font-weight:600;
  letter-spacing:.04em;color:var(--ink-3);background:var(--surface-2);
  border:1px solid var(--line);border-radius:5px;padding:2px 5px;line-height:1}

/* overlay: fixed, centred, above everything; hidden via the [hidden] attribute */
.spotlight{position:fixed;inset:0;z-index:120;display:flex;align-items:flex-start;
  justify-content:center;padding:14vh 18px 18px}
.spotlight[hidden]{display:none}
.spotlight-backdrop{position:absolute;inset:0;background:rgba(8,11,16,.52);
  opacity:0;transition:opacity .16s ease}
.spotlight.is-open .spotlight-backdrop{opacity:1}
.spotlight-panel{position:relative;z-index:1;width:100%;max-width:560px;
  background:var(--elevated);border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow-lift);overflow:hidden;
  opacity:0;transform:translateY(-8px) scale(.985);transition:opacity .16s ease,transform .16s ease}
.spotlight.is-open .spotlight-panel{opacity:1;transform:none}
.spotlight-input-row{display:flex;align-items:center;gap:10px;padding:14px 16px;
  border-bottom:1px solid var(--line)}
.spotlight-input-row .ico{flex:none;color:var(--ink-3)}
.spotlight-input{flex:1 1 auto;min-width:0;border:none;background:transparent;
  color:var(--ink);font:inherit;font-size:15px;line-height:1.4;outline:none}
.spotlight-input::placeholder{color:var(--ink-3)}
.spotlight-results{max-height:46vh;overflow-y:auto;padding:6px}
.spotlight-result{display:flex;align-items:center;gap:12px;padding:10px 12px;
  border-radius:9px;border:1px solid transparent;cursor:pointer;text-decoration:none}
.spotlight-result.is-active{background:var(--surface-2);border-color:var(--line)}
.spotlight-result-idea{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;
  white-space:nowrap;font-size:13.5px;color:var(--ink-2);line-height:1.45}
.spotlight-result.is-active .spotlight-result-idea{color:var(--ink)}
.spotlight-result-meta{flex:none;display:flex;gap:7px;font-family:var(--f-mono);font-size:11px}
.spotlight-result-meta b{font-weight:600}
.spotlight-empty{padding:16px 14px;font-size:13px;color:var(--ink-3);line-height:1.5}
@media(prefers-reduced-motion:reduce){
  .spotlight-backdrop,.spotlight-panel{transition:none}
  .spotlight-panel{transform:none}
}

/* ---- email-verification nag (site-wide banner) ----
   Dismiss is a CSP-safe checkbox hack: no JS, collapses for the page, returns
   on the next load (dismissible yet persistent). */
.verify-nag-x:checked + .verify-nag{display:none}
.verify-nag{display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  margin:0 0 18px;padding:11px 14px;border-radius:10px;
  background:color-mix(in srgb, var(--ember, #E5872E) 12%, var(--surface, #fff));
  border:1px solid color-mix(in srgb, var(--ember, #E5872E) 38%, transparent);
  color:var(--ink-2);font-size:13.5px;line-height:1.45}
.verify-nag .ico{flex:none;color:var(--ember, #E5872E)}
.verify-nag-msg{flex:1 1 240px;min-width:0}
.verify-nag-form{flex:none;margin:0}
.verify-nag-close{flex:none;display:inline-flex;align-items:center;cursor:pointer;
  color:var(--ink-3);border-radius:6px}
.verify-nag-close:hover{color:var(--ink)}
