/* =============================================================================
   ILFIRIN — "DATUM" brand system
   A clinical-precision instrument. Blue-grey near-black, signal-blue accent,
   cool-green for pass/ok. IBM-Plex-Mono tabular labels + a faint lab-notebook
   hairline grid. Every accent is rationed; nothing glows that doesn't carry a
   reading. System fonts only — no external fonts, no JS dependency.

   Ported verbatim from concept-datum.html (palette, type, signature gesture)
   and expanded to dress an entire multi-page site.

   SECTION MAP
     1.  Tokens (:root)
     2.  Reset + base + the lab-notebook grid
     3.  Layout: .wrap, links, helpers
     4.  Header / nav (+ CSS-only mobile collapse)
     5.  Footer (multi-column)
     6.  Preview tag
     7.  Type scale: h1/h2/h3, eyebrows, .reading telemetry strip, .fence
     8.  Buttons / CTAs
     9.  Chips + badges + evidence-tier chips (the signature gesture)
     10. Heroes: homepage .hero + interior .page-hero
     11. Section bands + section heads
     12. Prose / article styles (content pages)
     13. Data tables (framework targets, scorecards)
     14. Callout / note / aside boxes
     15. Flow component (inputs -> ilfirin -> outputs)
     16. Card grid (feature + dashboard + domain cards)
     17. Forms
     18. Utilities + reduced-motion
   ============================================================================= */

/* ----------------------------------------------------------------------------
   1. TOKENS
   ---------------------------------------------------------------------------- */
:root{
  /* core palette — ported exactly from concept-datum.html */
  --bg:#0c0f14;
  --surface:#11151c;
  --surface-2:#161b24;
  --line:#1e2631;
  --text:#e7edf4;
  --muted:#8a97a8;
  --blue:#4aa3ff;          /* the one signal accent */
  --green:#46DA94;         /* pass / ok / positive only */

  /* expansion tokens (kept in-family; used sparingly, honesty-first) */
  --blue-hi:#62b1ff;       /* button hover */
  --ink-on-blue:#06121f;   /* text on a filled blue surface */
  --text-2:#cdd6e0;        /* slightly dimmed body text */
  --text-3:#b6c0cd;        /* captions, fine print emphasis */
  --line-soft:rgba(30,38,49,.7);
  --amber:#d8a657;         /* Tier 3-4 / "watch" — unproven, flagged */
  --red:#e5786d;           /* over-target / flag — used only in scorecards */

  /* subtle, desaturated five-domain tints — differentiate without a haze.
     Use ONLY on domain bars/indices, never as fills. */
  --d-move:#4aa3ff;
  --d-recov:#46c6da;
  --d-fuel:#46DA94;
  --d-bio:#7ea8e8;
  --d-env:#6fb6a6;

  /* type */
  --sans:"Helvetica Neue",Helvetica,Arial,system-ui,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,"SF Mono",Menlo,Consolas,monospace;

  /* rhythm */
  --radius:7px;
  --radius-lg:12px;
  --radius-xl:14px;
  --maxw:1120px;
  --gut:clamp(20px,5vw,40px);
  --band-y:clamp(40px,6vw,72px);
}

/* ----------------------------------------------------------------------------
   2. RESET + BASE + the lab-notebook grid (signature backdrop)
   ---------------------------------------------------------------------------- */
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  background-color:var(--bg);
  /* fine minor grid + fainter major grid — the lab notebook */
  background-image:
    linear-gradient(rgba(74,163,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(74,163,255,.045) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px);
  background-size:140px 140px,140px 140px,28px 28px,28px 28px;
  background-position:-1px -1px,-1px -1px,-1px -1px,-1px -1px;
  background-attachment:fixed;
  color:var(--text);
  font-family:var(--sans);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%}
::selection{background:rgba(74,163,255,.28);color:#fff}

/* ----------------------------------------------------------------------------
   3. LAYOUT: .wrap, links, helpers
   ---------------------------------------------------------------------------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}
.wrap-narrow{max-width:760px;margin:0 auto;padding:0 var(--gut)}
a{color:inherit;text-decoration:none}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--blue);color:var(--ink-on-blue);
  font-family:var(--mono);font-size:.8rem;padding:10px 16px;border-radius:0 0 var(--radius) 0;z-index:50}
.skip-link:focus{left:0}
:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:3px}

/* ----------------------------------------------------------------------------
   4. HEADER / NAV  (CSS-only mobile collapse, no JS)
   ---------------------------------------------------------------------------- */
.site-header,header.site-header{
  position:sticky;top:0;z-index:30;
  border-bottom:1px solid var(--line);
  background:rgba(12,15,20,.72);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px;flex-wrap:wrap}
.brand{font-family:var(--mono);font-weight:600;letter-spacing:.04em;font-size:.95rem;
  display:inline-flex;align-items:center;gap:9px;color:var(--text)}
.brand .mk{color:var(--blue);font-size:1.05rem;line-height:1}
.brand b{color:var(--text);font-weight:600}

.nav .links{display:flex;gap:22px;align-items:center;
  font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.nav .links a{transition:color .15s}
.nav .links a:hover{color:var(--text)}
.nav .links a.nav-cta{color:var(--blue);border:1px solid var(--line);
  padding:8px 14px;border-radius:var(--radius);transition:border-color .15s,color .15s}
.nav .links a.nav-cta:hover{border-color:var(--blue);color:var(--blue-hi)}

/* mobile toggle: hidden checkbox + label, no script */
.nav-toggle-cb{position:absolute;opacity:0;pointer-events:none}
.nav-toggle{display:none;cursor:pointer;color:var(--text);
  border:1px solid var(--line);border-radius:var(--radius);padding:7px 9px;line-height:0}
.nav-toggle:hover{border-color:var(--blue)}

@media(max-width:620px){
  .nav{height:auto;padding-top:12px;padding-bottom:12px}
  .nav-toggle{display:inline-flex}
  .nav .links{display:none;flex-basis:100%;flex-direction:column;align-items:flex-start;
    gap:4px;padding:8px 0 4px}
  .nav .links a{padding:9px 2px;width:100%}
  .nav .links a.nav-cta{width:auto}
  .nav-toggle-cb:checked ~ .links{display:flex}
}

/* ----------------------------------------------------------------------------
   5. FOOTER (multi-column)
   ---------------------------------------------------------------------------- */
.site-footer{border-top:1px solid var(--line);
  background:linear-gradient(180deg,#0b0e13,#0c0f14);
  padding:clamp(40px,6vw,64px) 0 44px;margin-top:clamp(40px,7vw,90px)}
.footer-top{display:grid;gap:36px 40px;grid-template-columns:1.4fr 1fr 1fr}
@media(max-width:760px){.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-top{grid-template-columns:1fr}}
.footer-brand .brand{font-size:1rem;margin-bottom:14px}
.footer-brand .ftag{font-family:var(--mono);font-size:.72rem;line-height:1.7;color:var(--muted);
  display:flex;flex-direction:column;gap:2px;max-width:34ch}
.footer-brand .ftag .blue{color:var(--blue)}
.footer-col h4{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);font-weight:600;margin-bottom:14px}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:9px}
.footer-col a{font-size:.86rem;color:var(--text-2);transition:color .15s}
.footer-col a:hover{color:var(--blue)}
.footer-col .na-aside{font-family:var(--mono);font-size:.7rem;color:var(--muted);margin-top:16px;line-height:1.6}
.footer-col .na-aside em{color:var(--text-3);font-style:italic}

.footer-bottom{border-top:1px solid var(--line);margin-top:34px;padding-top:22px;
  display:flex;flex-direction:column;gap:6px;font-family:var(--mono);font-size:.71rem;color:var(--muted);line-height:1.7}
.footer-bottom .evidence-line{color:var(--text-3)}
.footer-bottom .blue{color:var(--blue)}

/* ----------------------------------------------------------------------------
   6. PREVIEW TAG (fixed corner badge)
   ---------------------------------------------------------------------------- */
.preview-tag{position:fixed;top:10px;right:10px;
  font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-on-blue);background:var(--blue);padding:4px 9px;border-radius:5px;z-index:60}

/* ----------------------------------------------------------------------------
   7. TYPE SCALE + eyebrows + .reading + .fence
   ---------------------------------------------------------------------------- */
h1{font-weight:700;letter-spacing:-.025em;line-height:1.02;
  font-size:clamp(2.3rem,5.6vw,4.65rem);max-width:18ch}
h2{font-weight:700;letter-spacing:-.02em;line-height:1.08;
  font-size:clamp(1.6rem,3.6vw,2.4rem);max-width:26ch}
h3{font-weight:600;letter-spacing:-.01em;line-height:1.18;font-size:1.2rem}

/* the underlined signal phrase inside a heading */
.accent,h1 .blue,h2 .blue{color:var(--blue);position:relative;white-space:nowrap}
.accent::after,h1 .blue::after,h2 .blue::after{
  content:"";position:absolute;left:0;right:0;bottom:-.06em;height:2px;background:var(--blue);opacity:.55}
@media(max-width:620px){.accent,h1 .blue,h2 .blue{white-space:normal}}

/* eyebrow — mono micro-label with a glowing square */
.eyebrow{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--blue);display:inline-flex;align-items:center;gap:9px}
.eyebrow::before{content:"";width:7px;height:7px;background:var(--blue);box-shadow:0 0 0 3px rgba(74,163,255,.18)}
.eyebrow.muted-eyebrow{color:var(--muted)}
.eyebrow.muted-eyebrow::before{background:var(--muted);box-shadow:0 0 0 3px rgba(138,151,168,.14)}

/* .reading — the telemetry strip: rec.001 · src: … · model: … · fee: ok */
.reading{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);display:flex;flex-wrap:wrap;gap:6px 16px}
.reading .v{color:var(--blue)}
.reading .ok{color:var(--green)}

/* .fence — an inline bracketed caveat: [ no sensor, no blood draw ] */
.fence{font-family:var(--mono);font-size:.74em;color:var(--muted);white-space:nowrap;letter-spacing:.01em}
.fence::before{content:"[ "}
.fence::after{content:" ]"}
@media(max-width:620px){.fence{white-space:normal}}

/* .lead — large intro paragraph */
.lead{font-size:clamp(1.04rem,1.5vw,1.28rem);color:var(--text-2);max-width:62ch}
.lead b{color:var(--text);font-weight:600}

/* .fine — mono fine print block (disclaimers, honesty rails) */
.fine{font-family:var(--mono);font-size:.71rem;line-height:1.7;color:var(--muted);max-width:78ch}
.fine b{color:var(--text-3);font-weight:600}

/* ----------------------------------------------------------------------------
   8. BUTTONS / CTAs
   ---------------------------------------------------------------------------- */
.ctas{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.btn{font-family:var(--mono);font-size:.8rem;letter-spacing:.03em;text-transform:uppercase;font-weight:600;
  padding:13px 22px;border-radius:var(--radius);border:1px solid transparent;cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;
  transition:transform .12s,background .15s,border-color .15s,color .15s}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--blue);color:var(--ink-on-blue)}
.btn-primary:hover{background:var(--blue-hi)}
.btn-ghost,.btn-secondary{border-color:var(--line);color:var(--text);background:transparent}
.btn-ghost:hover,.btn-secondary:hover{border-color:var(--blue)}
.btn .arrow{font-weight:600}

/* ----------------------------------------------------------------------------
   9. CHIPS + BADGES + EVIDENCE-TIER CHIPS (signature gesture)
   ---------------------------------------------------------------------------- */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{font-family:var(--mono);font-size:.72rem;letter-spacing:.02em;color:var(--text-2);
  border:1px solid var(--line);border-radius:6px;padding:7px 13px;background:var(--surface);
  display:inline-flex;align-items:center;gap:9px}
.chip .d{width:6px;height:6px;background:var(--blue);flex:0 0 auto}
.chip.ok .d{background:var(--green)}
.chip.opt .d{background:var(--muted)}

/* device chips reuse .chip; .chip.opt marks not-yet-supported */

/* generic badge (inline pill) */
.badge{font-family:var(--mono);font-size:.62rem;letter-spacing:.06em;text-transform:uppercase;
  font-weight:600;padding:3px 8px;border-radius:4px;border:1px solid var(--line);color:var(--muted)}
.badge.blue{color:var(--blue);border-color:rgba(74,163,255,.4);background:rgba(74,163,255,.08)}
.badge.green{color:var(--green);border-color:rgba(70,218,148,.4);background:rgba(70,218,148,.08)}

/* evidence-tier chips — the brand's load-bearing gesture */
.etiers{display:flex;flex-wrap:wrap;gap:8px}
.etag{font-family:var(--mono);font-size:.66rem;letter-spacing:.02em;color:var(--text-3);
  border:1px solid var(--line);background:var(--surface);border-radius:5px;padding:5px 9px;
  display:inline-flex;align-items:center;gap:8px}
.etag .k{color:var(--muted)}
.etag .t{font-weight:600;padding:1px 6px;border-radius:3px;font-size:.62rem;letter-spacing:.04em;text-transform:uppercase}
.etag .t.t1{color:var(--green);border:1px solid rgba(70,218,148,.4);background:rgba(70,218,148,.08)}
.etag .t.t2{color:var(--blue);border:1px solid rgba(74,163,255,.4);background:rgba(74,163,255,.08)}
.etag .t.t3,.etag .t.t4{color:var(--amber);border:1px solid rgba(216,166,87,.4);background:rgba(216,166,87,.08)}
.etag .t.pr{color:var(--text-3);border:1px solid var(--line)}

/* standalone tier chip (used in tables, cards, prose) */
.tier-chip{font-family:var(--mono);font-size:.62rem;letter-spacing:.04em;text-transform:uppercase;
  font-weight:600;padding:2px 7px;border-radius:3px;border:1px solid var(--line);color:var(--muted)}
.tier-chip.t1{color:var(--green);border-color:rgba(70,218,148,.4);background:rgba(70,218,148,.08)}
.tier-chip.t2{color:var(--blue);border-color:rgba(74,163,255,.4);background:rgba(74,163,255,.08)}
.tier-chip.t3,.tier-chip.t4{color:var(--amber);border-color:rgba(216,166,87,.4);background:rgba(216,166,87,.08)}

/* ----------------------------------------------------------------------------
   10. HEROES — homepage .hero + interior .page-hero
   ---------------------------------------------------------------------------- */
.hero{padding:clamp(46px,8vw,96px) 0 clamp(34px,6vw,60px);position:relative}
.hero h1{margin-top:20px}
.hero .lead{margin-top:28px}
.hero .etiers{margin-top:26px}
.hero .ctas{margin-top:32px}
.hero .chips{margin-top:28px}
.hero .fine{margin-top:26px}
.hero .reading{margin-bottom:18px}
.hero .eyebrow + h1{margin-top:18px}

/* optional two-column hero (copy + flow/figure) */
.hero-grid{display:grid;gap:clamp(30px,5vw,60px);grid-template-columns:1fr}
@media(min-width:900px){.hero-grid{grid-template-columns:1.05fr .95fr;align-items:center}}

/* interior page hero — smaller, for content pages */
.page-hero{padding:clamp(40px,6vw,72px) 0 clamp(24px,4vw,40px);border-bottom:1px solid var(--line)}
.page-hero h1{font-size:clamp(2rem,4.4vw,3.3rem);margin-top:16px;max-width:20ch}
.page-hero .lead{margin-top:22px}
.page-hero .reading{margin-bottom:16px}
.page-hero .ctas{margin-top:26px}

/* ----------------------------------------------------------------------------
   11. SECTION BANDS + section heads
   ---------------------------------------------------------------------------- */
.band{border-top:1px solid var(--line);padding:var(--band-y) 0}
.band.shade{background:linear-gradient(180deg,#0d1118,#0c0f14)}
.band.flush{border-top:0}
section{padding:var(--band-y) 0}
section.band{padding:var(--band-y) 0}

.section-head{max-width:62ch;margin-bottom:34px}
.section-head h2{margin-top:12px}
.section-head .lead,.section-head .muted{margin-top:16px}

/* band index label: "01  How it works" */
.band-idx{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);display:inline-flex;align-items:center;gap:10px}
.band-idx .n{color:var(--blue)}

.muted{color:var(--muted)}
.text-green{color:var(--green)}
.text-blue{color:var(--blue)}

/* ----------------------------------------------------------------------------
   12. PROSE / ARTICLE  (content pages: framework, privacy, how-it-works)
   ---------------------------------------------------------------------------- */
.prose{max-width:72ch}
.prose > * + *{margin-top:1.05em}
.prose h2{margin-top:1.7em;font-size:clamp(1.45rem,3vw,2rem)}
.prose h3{margin-top:1.5em;font-size:1.18rem}
.prose h2:first-child,.prose h3:first-child{margin-top:0}
.prose p{color:var(--text-2);max-width:72ch}
.prose .lead{color:var(--text);font-size:clamp(1.06rem,1.5vw,1.28rem)}
.prose b,.prose strong{color:var(--text);font-weight:600}
.prose em,.prose cite{color:var(--text-3);font-style:italic}
.prose a{color:var(--blue);text-decoration:none;border-bottom:1px solid rgba(74,163,255,.35);
  transition:border-color .15s}
.prose a:hover{border-bottom-color:var(--blue)}
.prose ul,.prose ol{padding-left:1.3em;color:var(--text-2)}
.prose li{margin-top:.5em}
.prose li::marker{color:var(--blue)}
.prose ul.ticks{list-style:none;padding-left:0}
.prose ul.ticks li{position:relative;padding-left:1.7em}
.prose ul.ticks li::before{content:"›";position:absolute;left:0;top:0;
  font-family:var(--mono);color:var(--blue);font-weight:600}

.prose blockquote{border-left:2px solid var(--blue);padding:6px 0 6px 20px;margin:1.4em 0;
  color:var(--text);font-size:1.08rem}
.prose blockquote cite{display:block;margin-top:8px;font-family:var(--mono);font-size:.72rem;
  letter-spacing:.04em;color:var(--muted);font-style:normal}

.prose code,code.inline{font-family:var(--mono);font-size:.86em;color:var(--text);
  background:var(--surface-2);border:1px solid var(--line);border-radius:4px;padding:1px 6px}
.prose pre{font-family:var(--mono);font-size:.82rem;line-height:1.6;color:var(--text-2);
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:18px 20px;overflow-x:auto}
.prose pre code{background:none;border:0;padding:0;color:inherit}

hr,.prose hr{border:0;border-top:1px solid var(--line);margin:2.2em 0}
.hr-dotted{border:0;border-top:1px dashed var(--line);margin:2.2em 0}

cite{font-family:var(--mono);font-size:.78em;color:var(--muted);font-style:normal;letter-spacing:.01em}

/* ----------------------------------------------------------------------------
   13. DATA TABLES (framework targets, scorecards)
   ---------------------------------------------------------------------------- */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface)}
table.data{width:100%;border-collapse:collapse;font-size:.9rem;min-width:520px}
table.data caption{font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted);text-align:left;padding:14px 18px 0}
table.data thead th{font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);font-weight:600;text-align:left;padding:14px 18px;border-bottom:1px solid var(--line);white-space:nowrap}
table.data tbody td{padding:13px 18px;border-bottom:1px solid var(--line-soft);color:var(--text-2);vertical-align:top}
table.data tbody tr:last-child td{border-bottom:0}
table.data tbody tr:hover{background:var(--surface-2)}
table.data td .num,table.data td.num{font-family:var(--mono);color:var(--text);font-variant-numeric:tabular-nums}
table.data td b{color:var(--text);font-weight:600}

/* status cells for scorecards */
.stat-pass{color:var(--green);font-family:var(--mono);font-size:.78rem;font-weight:600}
.stat-watch{color:var(--amber);font-family:var(--mono);font-size:.78rem;font-weight:600}
.stat-flag{color:var(--red);font-family:var(--mono);font-size:.78rem;font-weight:600}
.stat-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:7px;vertical-align:middle}
.stat-dot.pass{background:var(--green)}
.stat-dot.watch{background:var(--amber)}
.stat-dot.flag{background:var(--red)}

/* ----------------------------------------------------------------------------
   14. CALLOUT / NOTE / ASIDE boxes
   ---------------------------------------------------------------------------- */
.callout{border:1px solid var(--line);border-left:2px solid var(--blue);background:var(--surface);
  border-radius:var(--radius-lg);padding:18px 20px;margin:1.5em 0}
.callout .clabel{font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--blue);margin-bottom:8px;display:flex;align-items:center;gap:8px}
.callout p{color:var(--text-2)}
.callout.ok{border-left-color:var(--green)}
.callout.ok .clabel{color:var(--green)}
.callout.warn{border-left-color:var(--amber)}
.callout.warn .clabel{color:var(--amber)}

/* honesty rail — the recurring fenced caveat box; mono, sober */
.rail{border:1px dashed var(--line);background:rgba(17,21,28,.6);border-radius:var(--radius-lg);
  padding:16px 18px;margin:1.4em 0;font-family:var(--mono);font-size:.74rem;line-height:1.7;color:var(--muted)}
.rail b{color:var(--text-3);font-weight:600}
.rail .blue{color:var(--blue)}

/* aside — pull-to-the-side note, lighter weight than .callout */
.aside{border:1px solid var(--line);background:var(--surface-2);border-radius:var(--radius-lg);
  padding:16px 18px;font-size:.88rem;color:var(--text-2)}
.aside .alabel{font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);margin-bottom:6px}

/* ----------------------------------------------------------------------------
   15. FLOW COMPONENT — inputs -> ilfirin -> outputs
   ---------------------------------------------------------------------------- */
.flow{display:grid;gap:14px;grid-template-columns:1fr;align-items:stretch}
@media(min-width:840px){.flow{grid-template-columns:1fr 64px 1.06fr 64px 1fr;align-items:stretch}}

.fcol{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:20px;position:relative}
.fcol .lbl{font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted);margin-bottom:14px;display:flex;justify-content:space-between}
.fcol .lbl .ix{color:var(--blue)}
.fcol.out .lbl,.fcol.out .lbl .ix{color:var(--green)}

.frow{display:flex;align-items:baseline;gap:11px;font-size:.95rem;color:var(--text-2);
  padding:6px 0;border-top:1px solid var(--line-soft)}
.frow:first-of-type{border-top:0}
.frow .d{width:6px;height:6px;flex:0 0 auto;position:relative;top:6px;background:var(--blue)}
.fcol.out .frow .d{background:var(--green)}
.frow .u{font-family:var(--mono);font-size:.66rem;color:var(--muted);margin-left:auto;
  letter-spacing:.02em;white-space:nowrap;align-self:center}

.arrow{display:flex;align-items:center;justify-content:center;color:var(--blue);
  font-family:var(--mono);font-size:1.1rem;font-weight:600}
@media(max-width:839px){.arrow{transform:rotate(90deg);height:24px}}

.core{background:#0a0d12;border:1px solid var(--blue);border-radius:var(--radius-xl);padding:26px 22px;
  text-align:center;display:flex;flex-direction:column;justify-content:center;
  box-shadow:inset 0 0 0 1px rgba(74,163,255,.06)}
.core .name{font-family:var(--mono);font-weight:600;letter-spacing:.01em;font-size:1.7rem;
  display:inline-flex;align-items:center;gap:8px;justify-content:center}
.core .name .mk{color:var(--blue)}
.core .sub{font-family:var(--mono);font-size:.66rem;letter-spacing:.05em;color:#9fb0c2;margin-top:10px}
.core .note{font-size:.86rem;color:var(--text-3);margin-top:13px;line-height:1.5}
.core .meta{font-family:var(--mono);font-size:.6rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted);margin-top:14px;border-top:1px solid var(--line);padding-top:12px;
  display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.core .meta .ok{color:var(--green)}

/* ----------------------------------------------------------------------------
   16. CARD GRID — feature cards, dashboard cards, five-domain cards
   ---------------------------------------------------------------------------- */
.card-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.card-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.card-grid.cols-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:760px){.card-grid.cols-2,.card-grid.cols-3{grid-template-columns:1fr}}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:22px;transition:border-color .15s,transform .12s}
.card:hover{border-color:rgba(74,163,255,.45)}
.card .num{font-family:var(--mono);font-size:.78rem;letter-spacing:.08em;color:var(--blue);display:block;margin-bottom:12px}
.card h3{margin-bottom:8px}
.card p{color:var(--text-2);font-size:.92rem}
.card .card-foot{margin-top:16px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}

/* domain card — five-domain dashboard / framework tiles */
.domain-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:20px;border-top:2px solid var(--accent,var(--blue));--accent:var(--blue)}
.domain-card.d-move{--accent:var(--d-move)}
.domain-card.d-recov{--accent:var(--d-recov)}
.domain-card.d-fuel{--accent:var(--d-fuel)}
.domain-card.d-bio{--accent:var(--d-bio)}
.domain-card.d-env{--accent:var(--d-env)}
.domain-card .dhead{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:10px}
.domain-card .dindex{font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.domain-card .dsub{font-family:var(--mono);font-size:.66rem;color:var(--muted);letter-spacing:.02em}
.domain-card .dbody{color:var(--text-2);font-size:.9rem;margin-top:6px}
.domain-card .dmeta{margin-top:14px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.domain-card .dmetric{font-family:var(--mono);font-size:.68rem;color:var(--muted)}

/* metric tile — a single reading (dashboard) */
.metric{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}
.metric .mlabel{font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.metric .mvalue{font-family:var(--mono);font-size:1.7rem;color:var(--text);margin-top:8px;font-variant-numeric:tabular-nums}
.metric .munit{font-size:.8rem;color:var(--muted);margin-left:4px}
.metric .mnote{font-size:.78rem;color:var(--muted);margin-top:6px}

/* ----------------------------------------------------------------------------
   17. FORMS
   ---------------------------------------------------------------------------- */
.form{display:flex;flex-direction:column;gap:18px;max-width:560px}
.field{display:flex;flex-direction:column;gap:7px}
.field label,.label{font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3)}
.field .hint{font-size:.78rem;color:var(--muted)}

input[type=text],input[type=email],input[type=url],input[type=tel],input[type=number],
textarea,select{
  font-family:var(--sans);font-size:.95rem;color:var(--text);
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:12px 14px;width:100%;transition:border-color .15s,background .15s}
input::placeholder,textarea::placeholder{color:var(--muted)}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--blue);background:var(--surface-2)}
textarea{min-height:120px;resize:vertical;line-height:1.5}
select{appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);
  background-position:calc(100% - 18px) 52%,calc(100% - 13px) 52%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;
  padding-right:38px}

/* radio + checkbox groups */
.choice{display:flex;align-items:flex-start;gap:10px;border:1px solid var(--line);background:var(--surface);
  border-radius:var(--radius);padding:12px 14px;cursor:pointer;transition:border-color .15s,background .15s}
.choice:hover{border-color:rgba(74,163,255,.45)}
.choice input{accent-color:var(--blue);margin-top:3px;flex:0 0 auto}
.choice .ctitle{font-size:.92rem;color:var(--text)}
.choice .cdesc{font-size:.8rem;color:var(--muted);margin-top:2px}
.choice-row{display:flex;flex-direction:column;gap:10px}

fieldset{border:0;padding:0;margin:0}
fieldset legend{font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-3);margin-bottom:10px}

.form .form-foot{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-top:6px}
.form-msg{font-family:var(--mono);font-size:.74rem;color:var(--muted)}
.form-msg.ok{color:var(--green)}
.form-msg.err{color:var(--red)}

/* ----------------------------------------------------------------------------
   18. UTILITIES + reduced motion
   ---------------------------------------------------------------------------- */
.mt-0{margin-top:0}.mt-1{margin-top:12px}.mt-2{margin-top:20px}.mt-3{margin-top:28px}.mt-4{margin-top:40px}
.center{text-align:center}
.stack{display:flex;flex-direction:column;gap:16px}
.row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.divide-top{border-top:1px solid var(--line)}
.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}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .btn:hover{transform:none}
}
