/* ============================================================
   Z-TEAM — "THE OPERATING REPORT"
   Design system per PRD A2. Paper ground, navy ink accent,
   green as live-indicator only. Zero radius. No shadow except
   1px hairline on exhibit frames.
   ============================================================ */

:root{
  --paper:        #F7F5F0;
  --paper-2:      #F1EEE7;   /* faint alternate band */
  --ink:          #16181A;
  --ink-dim:      #5C5F63;
  --masthead:     #142F54;
  --accent-ink:   #1A4684;
  --live:         #3E9B4F;
  --hairline:     #D9D5CC;
  --hairline-2:   #E7E3DA;
  --panel:        #101214;
  --panel-line:   #23262B;
  --console-ok:   #7CCC44;
  --console-wait: #C99A3C;
  --console-dim:  #6B7178;
  --console-text: #C7CDD2;

  --measure: 64ch;
  --col: 1080px;
  --gutter: clamp(20px, 6vw, 96px);

  --font-display: "Bitter", Georgia, serif;
  --font-body:    "Outfit", system-ui, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, monospace;

  --section-pad: clamp(96px, 13vw, 168px);
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--font-body);
  font-weight:400;
  font-size:18px;
  line-height:1.62;
  font-variant-numeric: tabular-nums;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

::selection{ background:var(--accent-ink); color:var(--paper); }

a{ color:var(--accent-ink); text-decoration:none; }

/* ---- layout primitives ---- */
.wrap{ width:100%; max-width:var(--col); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:var(--section-pad); border-top:1px solid var(--hairline); }
.section--plain{ border-top:none; }

/* ---- type ---- */
.eyebrow{
  font-family:var(--font-mono);
  font-size:12px;
  font-weight:500;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--accent-ink);
  margin:0 0 28px;
  display:flex;
  align-items:center;
  gap:12px;
}
.eyebrow::before{
  content:"";
  width:26px; height:1px; background:var(--accent-ink);
  display:inline-block; flex:none;
}

h1,h2,h3{ font-family:var(--font-display); font-weight:700; color:var(--ink); margin:0; }
h1{ font-size:clamp(40px, 6vw, 68px); line-height:1.02; letter-spacing:-0.015em; }
.h2{ font-size:clamp(30px, 4.2vw, 46px); line-height:1.08; letter-spacing:-0.01em; text-wrap:balance; }
.lede{ font-size:clamp(19px,2.1vw,22px); line-height:1.55; color:var(--ink); font-weight:300; max-width:var(--measure); margin:28px 0 0; }
.body{ max-width:var(--measure); color:var(--ink); }
.dim{ color:var(--ink-dim); }

.kicker{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(30px,4.6vw,52px);
  line-height:1.08;
  letter-spacing:-0.01em;
  color:var(--ink);
  text-wrap:balance;
}
.kicker .em{ color:var(--accent-ink); }

/* mono utility label */
.label{
  font-family:var(--font-mono);
  font-size:11.5px;
  font-weight:500;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-dim);
}

/* ---- buttons ---- */
.btn{
  font-family:var(--font-mono);
  font-size:13px;
  font-weight:500;
  letter-spacing:0.04em;
  padding:15px 24px;
  border:1px solid var(--ink);
  background:var(--ink);
  color:var(--paper);
  cursor:pointer;
  display:inline-flex; align-items:center; gap:10px;
  transition:background .18s ease, color .18s ease, border-color .18s ease;
  text-transform:none;
}
.btn:hover{ background:var(--accent-ink); border-color:var(--accent-ink); }
.btn--ghost{ background:transparent; color:var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.btn--sm{ padding:11px 18px; font-size:12px; }
.btn[disabled]{ opacity:.4; cursor:not-allowed; }
.btn .arr{ transition:transform .18s ease; }
.btn:hover .arr{ transform:translateX(3px); }

/* ============================================================
   MASTHEAD (navy band) + NAV
   ============================================================ */
.masthead{
  position:sticky; top:0; z-index:60;
  background:var(--masthead);
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,0.10);
}
.masthead .wrap{ display:flex; align-items:center; gap:24px; height:62px; padding-block:0; }
.masthead__logo{ display:flex; align-items:center; gap:14px; }
.masthead__logo img{ height:26px; width:auto; display:block; }
.masthead__div{ width:1px; height:22px; background:rgba(255,255,255,0.22); }
.masthead__word{
  font-family:var(--font-mono); font-size:13px; font-weight:500;
  letter-spacing:0.22em; color:#fff;
}
.masthead nav{ margin-left:auto; display:flex; align-items:center; gap:26px; }
.masthead nav a{
  font-family:var(--font-mono); font-size:12px; letter-spacing:0.08em;
  color:rgba(255,255,255,0.72); transition:color .15s;
}
.masthead nav a:hover{ color:#fff; }
.lang{ font-family:var(--font-mono); font-size:11.5px; letter-spacing:0.06em; color:rgba(255,255,255,0.5); display:flex; gap:7px; }
.lang b{ color:#fff; font-weight:500; }
.masthead .btn{ padding:9px 16px; font-size:12px; background:#fff; color:var(--masthead); border-color:#fff; white-space:nowrap; }
.masthead nav{ margin-left:auto; display:flex; align-items:center; gap:20px; }
.masthead nav a.navlink{ white-space:nowrap; }
@media (max-width:1180px){ .masthead nav{ gap:14px; } }
.masthead .btn:hover{ background:var(--live); border-color:var(--live); color:#fff; }
.masthead nav .navlink--mobile{ display:none; }
@media (max-width:820px){
  .masthead__word{ display:none; }
  .masthead nav{ gap:16px; }
  .masthead nav a.navlink{ display:none; }
  .lang{ display:none; }
}

/* ============================================================
   01 HERO
   ============================================================ */
.hero{ position:relative; overflow:hidden; }
.hero .wrap{ padding-block:clamp(64px,9vw,110px) clamp(56px,8vw,96px); position:relative; z-index:2; }
.hero__grid{ display:grid; grid-template-columns: 1.15fr 0.85fr; gap:clamp(32px,5vw,72px); align-items:center; }
.hero__copy{ max-width:620px; }
.hero h1{ margin-top:22px; }
.hero h1 .soft{ color:var(--ink-dim); }
.hero__sub{ font-size:clamp(18px,1.9vw,21px); font-weight:300; line-height:1.55; color:var(--ink); max-width:54ch; margin:26px 0 0; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:38px; }

/* engraved Z exhibit */
.hero__z{ position:relative; justify-self:center; }
.hero__z-frame{
  position:relative;
  border:1px solid var(--hairline);
  background:#fff;
  padding:22px;
}
.hero__z-frame::after{
  content:""; position:absolute; inset:7px; border:1px solid var(--hairline-2); pointer-events:none;
}
.hero__z img{ display:block; width:min(360px, 42vw); height:auto; mix-blend-mode:multiply; }
.hero__z-cap{
  font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.12em; text-transform:uppercase;
  color:var(--ink-dim); margin-top:14px; text-align:left; display:flex; justify-content:space-between; gap:12px;
}

/* proof strip */
.proof{
  margin-top:clamp(48px,7vw,76px);
  border-top:1px solid var(--hairline);
  border-bottom:1px solid var(--hairline);
  padding:18px 0;
}
.proof__line{
  font-family:var(--font-mono); font-size:12.5px; letter-spacing:0.08em;
  color:var(--ink-dim); min-height:1.2em; white-space:normal;
}
.proof__line .tok{ color:var(--ink); }
.proof__line .sep{ color:var(--hairline); padding:0 4px; }
.proof__cursor{ display:inline-block; width:8px; height:1.05em; background:var(--accent-ink); transform:translateY(2px); margin-left:2px; animation:blink 1s steps(1) infinite; }
@keyframes blink{ 50%{ opacity:0; } }

/* faint ledger baseline behind hero */
.hero__rule{
  position:absolute; left:0; right:0; bottom:0; height:46%;
  background-image:repeating-linear-gradient(to bottom, transparent 0 31px, var(--hairline-2) 31px 32px);
  opacity:.5; z-index:0; pointer-events:none;
  -webkit-mask-image:linear-gradient(to bottom, transparent, #000 60%);
          mask-image:linear-gradient(to bottom, transparent, #000 60%);
}

/* HERO TREATMENT VARIATIONS (data-hero) */
/* default = letterhead (grid above) */

/* illuminated: Z as oversized drop initial, text wraps beside */
[data-hero="illuminated"] .hero__grid{ display:block; }
[data-hero="illuminated"] .hero__copy{ max-width:none; }
[data-hero="illuminated"] .hero__z{
  float:left; margin:6px clamp(28px,4vw,56px) 0 0; shape-outside:content-box;
}
[data-hero="illuminated"] .hero__z-frame{ border:none; padding:0; background:transparent; }
[data-hero="illuminated"] .hero__z-frame::after{ display:none; }
[data-hero="illuminated"] .hero__z img{ width:min(300px,40vw); }
[data-hero="illuminated"] .hero__z-cap{ display:none; }
[data-hero="illuminated"] .hero h1{ font-size:clamp(38px,5.4vw,62px); }
[data-hero="illuminated"] .hero__cta{ clear:both; }

/* fullbleed: Z huge, bleeding right edge, text left */
[data-hero="fullbleed"] .hero{ }
[data-hero="fullbleed"] .hero__grid{ grid-template-columns: 1fr; }
[data-hero="fullbleed"] .hero__copy{ max-width:640px; position:relative; z-index:2; }
[data-hero="fullbleed"] .hero__z{
  position:absolute; top:50%; right:calc(-1 * clamp(40px,6vw,120px)); transform:translateY(-50%);
  z-index:1; justify-self:auto;
}
[data-hero="fullbleed"] .hero__z-frame{ border:none; padding:0; background:transparent; }
[data-hero="fullbleed"] .hero__z-frame::after{ display:none; }
[data-hero="fullbleed"] .hero__z img{ width:min(560px,52vw); opacity:.16; }
[data-hero="fullbleed"] .hero__z-cap{ display:none; }
@media (max-width:900px){
  [data-hero="fullbleed"] .hero__z{ position:absolute; opacity:1; }
  [data-hero="fullbleed"] .hero__z img{ width:64vw; opacity:.10; }
}

@media (max-width:900px){
  .hero__grid{ grid-template-columns:1fr; gap:36px; }
  .hero__z{ order:-1; justify-self:start; }
  .hero__z img{ width:min(220px,46vw); }
  [data-hero="illuminated"] .hero__z{ float:left; }
}

/* ============================================================
   GENERIC SECTION HEADER
   ============================================================ */
.shead{ max-width:760px; margin-bottom:clamp(48px,6vw,72px); }
.shead .h2{ margin-top:0; }
.shead .lede{ margin-top:24px; }

/* ============================================================
   02 REPLAY
   ============================================================ */
.replay__top{ display:flex; justify-content:space-between; align-items:flex-end; gap:24px; flex-wrap:wrap; margin-bottom:36px; }
.replay__progress{ font-family:var(--font-mono); font-size:13px; letter-spacing:0.1em; color:var(--ink-dim); }
.replay__progress b{ color:var(--ink); font-weight:600; }

.replay__stage{
  display:grid; grid-template-columns: 280px 1fr; gap:0;
  border:1px solid var(--hairline); background:#fff;
}
.replay__steps{ border-right:1px solid var(--hairline); background:var(--paper-2); }
.replay__step{
  display:flex; gap:14px; padding:18px 20px; cursor:pointer; border-bottom:1px solid var(--hairline-2);
  text-align:left; width:100%; background:transparent; border-left:3px solid transparent; font-family:inherit;
  transition:background .15s;
}
.replay__step:last-child{ border-bottom:none; }
.replay__step:hover{ background:var(--paper); }
.replay__step[aria-current="true"]{ background:var(--paper); border-left-color:var(--accent-ink); }
.replay__step-n{ font-family:var(--font-mono); font-size:12px; color:var(--ink-dim); flex:none; padding-top:2px; min-width:20px; }
.replay__step[aria-current="true"] .replay__step-n{ color:var(--accent-ink); font-weight:600; }
.replay__step-t{ font-size:14.5px; line-height:1.42; color:var(--ink); }
.replay__step[aria-current="true"] .replay__step-t{ font-weight:500; }

.replay__view{ padding:clamp(20px,3vw,34px); display:flex; flex-direction:column; min-height:480px; background:var(--paper); }
.replay__exhibit{ flex:1; display:flex; align-items:center; justify-content:center; }
.replay__cap{
  font-family:var(--font-mono); font-size:11px; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--ink-dim); margin-top:20px; padding-top:14px; border-top:1px solid var(--hairline);
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
}
.replay__nav{ display:flex; gap:10px; margin-top:24px; }
.replay__closing{ font-family:var(--font-display); font-weight:600; font-size:clamp(22px,2.6vw,30px); margin-top:40px; color:var(--ink); }

/* email / screenshot mock exhibits */
.mock{
  width:100%; max-width:560px; background:#fff; border:1px solid var(--hairline);
  font-family:var(--font-body); color:var(--ink); margin-inline:auto;
}
.mock--mail{}
.mock__bar{ display:flex; align-items:center; gap:8px; padding:9px 14px; border-bottom:1px solid var(--hairline); background:var(--paper-2); }
.mock__dot{ width:9px; height:9px; border-radius:50%; background:var(--hairline); }
.mock__chip{ margin-left:auto; font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.08em; color:var(--ink-dim); }
.mock__head{ padding:14px 18px; border-bottom:1px solid var(--hairline-2); font-size:13.5px; line-height:1.7; }
.mock__head .k{ display:inline-block; width:54px; color:var(--ink-dim); font-family:var(--font-mono); font-size:11px; letter-spacing:0.04em; text-transform:uppercase; }
.mock__subj{ font-family:var(--font-display); font-weight:600; font-size:15px; margin-top:2px; }
.mock__body{ padding:18px; font-size:14px; line-height:1.62; color:var(--ink); }
.mock__body p{ margin:0 0 12px; }
.mock__body p:last-child{ margin-bottom:0; }
.mock__sig{ font-family:var(--font-mono); font-size:11.5px; color:var(--ink-dim); line-height:1.7; margin-top:14px; }
.redact{ background:var(--ink); color:transparent; padding:0 2px; border-radius:0; user-select:none; box-decoration-break:clone; -webkit-box-decoration-break:clone; }
.redact--nav{ background:var(--accent-ink); }

/* status card mock */
.mock--card{ max-width:460px; }
.card__row{ display:flex; justify-content:space-between; gap:16px; padding:12px 18px; border-bottom:1px solid var(--hairline-2); font-size:13px; }
.card__row:last-child{ border-bottom:none; }
.card__row .ck{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink-dim); }
.card__row .cv{ font-weight:500; }
.ok-tick{ color:var(--live); font-family:var(--font-mono); }

/* approval stamp */
.stamp{
  display:inline-flex; flex-direction:column; align-items:center; gap:2px;
  border:1.5px solid var(--accent-ink); color:var(--accent-ink);
  font-family:var(--font-mono); text-transform:uppercase; letter-spacing:0.1em;
  padding:8px 16px; transform:rotate(-1.6deg); line-height:1.3;
}
.stamp b{ font-size:13px; font-weight:600; letter-spacing:0.14em; }
.stamp span{ font-size:10px; opacity:.85; }
.stamp--inline{ transform:rotate(-1.4deg) translateY(-2px); }

@media (max-width:760px){
  .replay__stage{ grid-template-columns:1fr; }
  .replay__steps{ display:flex; overflow-x:auto; border-right:none; border-bottom:1px solid var(--hairline); }
  .replay__step{ flex:none; width:200px; border-bottom:none; border-right:1px solid var(--hairline-2); border-left:none; border-top:3px solid transparent; }
  .replay__step[aria-current="true"]{ border-left-color:transparent; border-top-color:var(--accent-ink); }
  .replay__view{ min-height:auto; }
}

/* ============================================================
   03 WHAT IT IS — cards
   ============================================================ */
.cards{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--hairline); border:1px solid var(--hairline); }
.card{ background:var(--paper); padding:clamp(26px,3vw,38px); }
.card__n{ font-family:var(--font-mono); font-size:12px; letter-spacing:0.1em; color:var(--accent-ink); margin-bottom:18px; }
.card h3{ font-size:21px; line-height:1.2; margin-bottom:12px; }
.card p{ font-size:15.5px; line-height:1.6; color:var(--ink-dim); margin:0; max-width:42ch; }
@media (max-width:720px){ .cards{ grid-template-columns:1fr; } }

.bigkicker{ margin-top:clamp(56px,7vw,84px); padding-top:clamp(40px,5vw,56px); border-top:1px solid var(--hairline); }

/* ============================================================
   04 COMMAND — numbered items
   ============================================================ */
.items{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,56px) clamp(40px,6vw,80px); }
.item{ border-top:2px solid var(--ink); padding-top:20px; }
.item__n{ font-family:var(--font-mono); font-size:12px; letter-spacing:0.1em; color:var(--ink-dim); margin-bottom:14px; }
.item h3{ font-size:20px; line-height:1.22; margin-bottom:10px; }
.item p{ font-size:15.5px; line-height:1.6; color:var(--ink-dim); margin:0; max-width:46ch; }
@media (max-width:720px){ .items{ grid-template-columns:1fr; } }

.command__stamp{ margin-top:clamp(48px,6vw,72px); display:flex; align-items:center; gap:28px; flex-wrap:wrap; }

/* ============================================================
   05 FUNCTIONS
   ============================================================ */
.fn-group{ margin-bottom:clamp(48px,6vw,72px); }
.fn-tag{
  font-family:var(--font-mono); font-size:11.5px; letter-spacing:0.16em; text-transform:uppercase;
  display:inline-flex; align-items:center; gap:9px; margin-bottom:26px;
}
.fn-tag .dot{ width:8px; height:8px; border-radius:50%; flex:none; }
.fn-tag--live{ color:var(--live); }
.fn-tag--live .dot{ background:var(--live); box-shadow:0 0 0 3px rgba(62,155,79,0.16); }
.fn-tag--deploy{ color:var(--console-wait); }
.fn-tag--deploy .dot{ background:var(--console-wait); }
.fn-tag--bp{ color:var(--ink-dim); }
.fn-tag--bp .dot{ width:8px; height:8px; border-radius:0; border:1px solid var(--ink-dim); background:transparent; }

.fn-live{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--hairline); border:1px solid var(--hairline); }
.fn-live .card{ background:var(--paper); }
.fn-live .card h3{ font-size:18.5px; }
@media (max-width:820px){ .fn-live{ grid-template-columns:1fr; } }

.fn-deploy{ border-top:1px solid var(--hairline); border-bottom:1px solid var(--hairline); padding:24px 0; display:flex; gap:24px; align-items:baseline; flex-wrap:wrap; }
.fn-deploy h3{ font-size:18px; flex:none; min-width:220px; }
.fn-deploy p{ font-size:15.5px; color:var(--ink-dim); margin:0; max-width:52ch; }

/* blueprints as ledger entries */
.bp-intro{ max-width:var(--measure); color:var(--ink-dim); font-size:16px; margin:18px 0 36px; }
.ledger{ border-top:2px solid var(--ink); }
.bp{ border-bottom:1px solid var(--hairline); padding:26px 0; display:grid; grid-template-columns: 200px 1fr; gap:8px clamp(24px,4vw,48px); }
.bp__fn{ font-family:var(--font-display); font-weight:700; font-size:19px; line-height:1.2; grid-row:span 4; }
.bp__rows{ display:grid; gap:0; }
.bp__row{ display:grid; grid-template-columns:120px 1fr; gap:18px; padding:7px 0; border-bottom:1px dotted var(--hairline); align-items:baseline; }
.bp__row:last-child{ border-bottom:none; }
.bp__rk{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-dim); }
.bp__rv{ font-size:14.5px; line-height:1.5; color:var(--ink); }
.bp__line{ font-size:14.5px; color:var(--ink-dim); font-style:italic; }
@media (max-width:680px){
  .bp{ grid-template-columns:1fr; }
  .bp__fn{ grid-row:auto; margin-bottom:8px; }
  .bp__row{ grid-template-columns:96px 1fr; gap:12px; }
}
.bp-cta{ margin-top:36px; font-size:16px; color:var(--ink); max-width:var(--measure); }
.bp-cta a{ border-bottom:1px solid var(--accent-ink); }
.fn-rule{ margin-top:clamp(44px,5vw,64px); padding-top:32px; border-top:1px solid var(--hairline); font-size:17px; line-height:1.6; max-width:var(--measure); color:var(--ink); }
.fn-rule b{ font-weight:500; color:var(--ink); }

/* ============================================================
   06 ENGAGEMENT MODEL
   ============================================================ */
.layers{ display:grid; gap:0; border-top:2px solid var(--ink); }
.layer{ display:grid; grid-template-columns: 260px 1fr; gap:clamp(20px,4vw,56px); padding:32px 0; border-bottom:1px solid var(--hairline); }
.layer__label{ font-family:var(--font-mono); font-size:13px; letter-spacing:0.1em; font-weight:500; color:var(--accent-ink); }
.layer__label .when{ display:block; color:var(--ink-dim); font-size:11px; letter-spacing:0.12em; margin-top:6px; text-transform:uppercase; }
.layer p{ margin:0; font-size:16px; line-height:1.6; color:var(--ink); max-width:54ch; }
@media (max-width:680px){ .layer{ grid-template-columns:1fr; gap:10px; } }
.stance{ margin-top:clamp(40px,5vw,60px); font-family:var(--font-display); font-weight:600; font-size:clamp(20px,2.4vw,26px); line-height:1.4; max-width:30ch; color:var(--ink); }

/* ============================================================
   07 LIVE DESK + CONSOLE
   ============================================================ */
.desk__grid{ display:grid; grid-template-columns: 1fr 1.05fr; gap:clamp(32px,4vw,56px); align-items:start; }
.desk__copy .lede{ margin-top:22px; }
.desk__copy p{ font-size:16px; line-height:1.62; color:var(--ink-dim); max-width:50ch; }
.desk__stress{ border-left:2px solid var(--accent-ink); padding:16px 0 16px 22px; margin:30px 0; font-size:15.5px; line-height:1.6; color:var(--ink); }
.desk__stress b{ font-weight:500; }
.desk__outcome{ font-size:16px; color:var(--ink-dim); max-width:52ch; }
.desk__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:30px; align-items:center; }
.bypass{ font-family:var(--font-mono); font-size:12.5px; letter-spacing:0.03em; color:var(--accent-ink); border-bottom:1px solid var(--hairline); padding-bottom:2px; }
.bypass:hover{ border-color:var(--accent-ink); }
.privacy-line{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.04em; line-height:1.6; color:var(--ink-dim); margin-top:28px; max-width:56ch; }

@media (max-width:880px){ .desk__grid{ grid-template-columns:1fr; } }

/* CONSOLE — the single dark element */
.console{
  background:var(--panel); color:var(--console-text); border:1px solid var(--panel-line);
  border-radius:2px; font-family:var(--font-mono); position:sticky; top:84px;
  box-shadow:0 1px 0 var(--hairline);
}
.console__head{
  display:flex; align-items:center; gap:10px; padding:13px 16px; border-bottom:1px solid var(--panel-line);
  font-size:11.5px; letter-spacing:0.1em; color:var(--console-dim);
}
.console__head .id{ color:var(--console-text); }
.console__live{ margin-left:auto; display:flex; align-items:center; gap:7px; }
.console__live .d{ width:7px; height:7px; border-radius:50%; background:var(--console-dim); }
.console.is-connected .console__live .d{ background:var(--accent-ink); box-shadow:0 0 0 3px rgba(26,70,132,0.28); }
.console.is-connected .console__live{ color:var(--console-ok); }

.console__log{ padding:14px 16px; height:340px; overflow-y:auto; font-size:12.5px; line-height:1.85; }
.console__log::-webkit-scrollbar{ width:8px; }
.console__log::-webkit-scrollbar-thumb{ background:var(--panel-line); }
.logline{ display:flex; gap:12px; padding:2px 0; opacity:0; transform:translateY(4px); animation:logIn .28s ease forwards; }
@keyframes logIn{ to{ opacity:1; transform:none; } }
.logline .ts{ color:var(--console-dim); flex:none; }
.logline .msg{ color:var(--console-text); }
.logline .msg .ok{ color:var(--console-ok); }
.logline .msg .wait{ color:var(--console-wait); }
.logline .msg .accent{ color:#6ea8ff; }
.logline .msg .actor{ color:#fff; }
.logline.is-gate .msg{ color:var(--console-wait); }
.console__foot{ padding:10px 16px; border-top:1px solid var(--panel-line); font-size:10.5px; letter-spacing:0.06em; color:var(--console-dim); display:flex; justify-content:space-between; gap:12px; }
.console__waiting{ color:var(--console-dim); font-style:normal; }

/* ============================================================
   GATE (modal)
   ============================================================ */
.gate-overlay{
  position:fixed; inset:0; background:rgba(16,18,20,0.62); z-index:100;
  display:none; align-items:center; justify-content:center; padding:24px;
  backdrop-filter:saturate(0.9) blur(1px);
}
.gate-overlay.is-open{ display:flex; }
.gate{
  background:var(--paper); border:1px solid var(--ink); width:min(480px,100%);
  max-height:92vh; overflow:auto;
}
.gate__bar{ background:var(--masthead); color:#fff; padding:13px 22px; display:flex; align-items:center; justify-content:space-between; }
.gate__bar .t{ font-family:var(--font-mono); font-size:12px; letter-spacing:0.16em; }
.gate__close{ background:none; border:none; color:rgba(255,255,255,0.7); font-size:20px; cursor:pointer; line-height:1; padding:0; }
.gate__close:hover{ color:#fff; }
.gate__body{ padding:26px 28px 30px; }
.gate__note{ font-size:13.5px; line-height:1.55; color:var(--ink-dim); margin:0 0 22px; }
.field{ margin-bottom:16px; }
.field label{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-dim); display:block; margin-bottom:7px; }
.field input{
  width:100%; padding:12px 14px; border:1px solid var(--hairline); background:#fff; color:var(--ink);
  font-family:var(--font-body); font-size:15px; border-radius:0;
}
.field input:focus{ outline:none; border-color:var(--accent-ink); box-shadow:inset 0 0 0 1px var(--accent-ink); }
.field.err input{ border-color:#B23A3A; }
.field__err{ font-family:var(--font-mono); font-size:11px; color:#B23A3A; margin-top:6px; display:none; }
.field.err .field__err{ display:block; }
.gate__submit{ width:100%; justify-content:center; margin-top:8px; }
.gate__reject{
  display:none; margin-top:18px; border:1px solid #B23A3A; background:#FBF3F2; padding:16px;
  font-size:13.5px; line-height:1.55; color:var(--ink);
}
.gate__reject.show{ display:block; }
.gate__reject .addr{ font-family:var(--font-mono); color:var(--accent-ink); }

/* gate success / desk panel */
.deskpanel{ display:none; }
.deskpanel.show{ display:block; }
.gate__form.hide{ display:none; }
.gate__success-head{ font-family:var(--font-mono); font-size:12px; letter-spacing:0.06em; color:var(--live); margin-bottom:18px; line-height:1.6; }
.deskrow{ display:flex; align-items:center; justify-content:space-between; gap:14px; padding:13px 0; border-bottom:1px solid var(--hairline); }
.deskrow:first-of-type{ border-top:1px solid var(--hairline); }
.deskrow .dk{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-dim); }
.deskrow .dv{ font-family:var(--font-mono); font-size:14px; color:var(--ink); display:flex; align-items:center; gap:10px; }
.copybtn{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.08em; text-transform:uppercase; border:1px solid var(--hairline); background:#fff; color:var(--ink-dim); padding:4px 8px; cursor:pointer; }
.copybtn:hover{ border-color:var(--accent-ink); color:var(--accent-ink); }
.copybtn.copied{ color:var(--live); border-color:var(--live); }
.deskpanel__draft{ margin-top:22px; }
.deskpanel__note{ font-family:var(--font-mono); font-size:10.5px; line-height:1.6; color:var(--ink-dim); margin-top:16px; }

/* ============================================================
   08 FAQ
   ============================================================ */
.faq{ border-top:2px solid var(--ink); }
.faq__item{ border-bottom:1px solid var(--hairline); }
.faq__q{
  width:100%; text-align:left; background:none; border:none; cursor:pointer;
  padding:26px 48px 26px 0; position:relative; font-family:var(--font-display); font-weight:600;
  font-size:clamp(18px,2vw,22px); line-height:1.32; color:var(--ink);
}
.faq__q::after{
  content:"+"; position:absolute; right:6px; top:26px; font-family:var(--font-mono); font-weight:400;
  font-size:22px; color:var(--accent-ink); transition:transform .2s;
}
.faq__item.open .faq__q::after{ content:"\2013"; }
.faq__a{ max-height:0; overflow:hidden; transition:max-height .32s ease; }
.faq__a-inner{ padding:0 60px 28px 0; font-size:16px; line-height:1.64; color:var(--ink-dim); max-width:68ch; }
.faq__a-inner b{ color:var(--ink); font-weight:500; }

/* ============================================================
   09 FINAL CTA
   ============================================================ */
.final{ text-align:left; }
.final .h2{ font-size:clamp(34px,5vw,58px); max-width:18ch; }
.final__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:40px; }

/* ============================================================
   10 FOOTER
   ============================================================ */
.foot{ background:var(--masthead); color:rgba(255,255,255,0.82); }
.foot .wrap{ padding-block:56px; }
.foot__top{ display:flex; justify-content:space-between; align-items:flex-start; gap:32px; flex-wrap:wrap; padding-bottom:36px; border-bottom:1px solid rgba(255,255,255,0.14); }
.foot__logo img{ height:30px; }
.foot__word{ font-family:var(--font-mono); font-size:12px; letter-spacing:0.22em; color:#fff; margin-top:14px; }
.foot__links{ display:flex; gap:28px; flex-wrap:wrap; }
.foot__links a{ font-family:var(--font-mono); font-size:12px; letter-spacing:0.06em; color:rgba(255,255,255,0.7); }
.foot__links a:hover{ color:#fff; }
.foot__legal{ font-size:12.5px; line-height:1.7; color:rgba(255,255,255,0.6); margin-top:28px; max-width:74ch; font-family:var(--font-mono); letter-spacing:0.02em; }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{ opacity:0; transform:translateY(8px); }
.reveal.in{ opacity:1; transform:none; transition:opacity .6s ease, transform .6s ease; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; }
  .logline{ animation:none; opacity:1; transform:none; }
  .proof__cursor{ animation:none; }
}

/* ============================================================
   COMPLIFY ADDITIONS
   ============================================================ */

/* ---- masthead: Complify lockup + language switcher ---- */
.masthead__logo img{ height:24px; }
.masthead__oem{ display:flex; align-items:center; gap:9px; }
.masthead__oem img{ height:18px; width:auto; opacity:.92; }
.masthead__oem span{
  font-family:var(--font-mono); font-size:10px; letter-spacing:0.12em; text-transform:uppercase;
  color:rgba(255,255,255,0.55); line-height:1.25;
}
.lang{ gap:0; }
.lang button{
  background:none; border:none; font-family:var(--font-mono); font-size:11.5px; letter-spacing:0.06em;
  color:rgba(255,255,255,0.5); cursor:pointer; padding:5px 7px; transition:color .15s;
}
.lang button.on{ color:#fff; }
.lang button:hover{ color:#fff; }
.lang .sep{ color:rgba(255,255,255,0.22); padding:0; pointer-events:none; }
@media (max-width:980px){
  .masthead__oem span{ display:none; }
}

/* i18n swap softener */
[data-i18n]{ transition:opacity .12s ease; }
.lang-swapping [data-i18n]{ opacity:.35; }

/* ---- generic accent pull-quote block reused as .creed ---- */
.creed{ margin-top:clamp(48px,6vw,72px); padding-top:clamp(36px,4vw,52px); border-top:1px solid var(--hairline); }

/* ============================================================
   CLOSED LOOP
   ============================================================ */
.loop{
  display:grid; grid-template-columns:repeat(5,1fr); gap:1px;
  background:var(--hairline); border:1px solid var(--hairline);
}
.loop__stage{ background:var(--paper); padding:clamp(20px,2.3vw,28px) clamp(16px,1.7vw,22px); display:flex; flex-direction:column; gap:12px; position:relative; }
.loop__l{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.14em; color:var(--accent-ink); }
.loop__name{ font-family:var(--font-display); font-weight:700; font-size:17px; line-height:1.15; }
.loop__d{ font-size:13.5px; line-height:1.5; color:var(--ink-dim); margin:0; }
.loop__arrow{ position:absolute; top:50%; right:-1px; transform:translate(50%,-50%); z-index:2;
  width:18px; height:18px; background:var(--paper); border:1px solid var(--hairline); color:var(--ink-dim);
  display:flex; align-items:center; justify-content:center; font-family:var(--font-mono); font-size:11px; }
.loop__stage:last-child .loop__arrow{ display:none; }
.loop__close{ margin-top:24px; display:flex; align-items:center; gap:14px; font-family:var(--font-mono);
  font-size:12px; letter-spacing:0.08em; color:var(--ink-dim); text-transform:uppercase; }
.loop__close .ln{ flex:1; height:1px; background:var(--hairline); }
.loop__close .lp{ color:var(--accent-ink); }
@media (max-width:900px){ .loop{ grid-template-columns:1fr 1fr; } .loop__arrow{ display:none; } }
@media (max-width:520px){ .loop{ grid-template-columns:1fr; } }

/* ============================================================
   ORG / WORKFORCE DIRECTORY
   ============================================================ */
.org{ border-top:2px solid var(--ink); }
.role{
  display:grid; grid-template-columns: minmax(240px,1fr) 1.4fr auto; gap:18px clamp(20px,3vw,40px);
  align-items:baseline; padding:20px 0; border-bottom:1px solid var(--hairline);
}
.role__id{ display:flex; align-items:baseline; gap:12px; }
.role__rule{ flex:none; width:14px; height:1px; background:var(--hairline); align-self:center; }
.role--l1{ padding-left:0; }
.role--l2{ padding-left:clamp(16px,3vw,40px); }
.role--l3{ padding-left:clamp(32px,6vw,80px); }
.role__title{ font-family:var(--font-display); font-weight:700; font-size:17.5px; line-height:1.2; }
.role__aiw{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.12em; color:var(--accent-ink);
  border:1px solid var(--hairline); padding:2px 6px; margin-left:8px; vertical-align:2px; white-space:nowrap; }
.role__mandate{ font-size:14.5px; line-height:1.55; color:var(--ink-dim); margin:0; }
.role__mandate b{ color:var(--ink); font-weight:500; }
.role__tag{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-dim); white-space:nowrap; }
.org__note{ margin-top:30px; font-size:15px; line-height:1.6; color:var(--ink-dim); max-width:var(--measure); }
.org__note b{ color:var(--ink); font-weight:500; }
@media (max-width:760px){ .role{ grid-template-columns:1fr; gap:8px; } .role__tag{ order:3; } }

/* ============================================================
   FRAMEWORKS
   ============================================================ */
.fw-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--hairline); border:1px solid var(--hairline); }
.fw{ background:var(--paper); padding:clamp(22px,2.6vw,30px); display:flex; flex-direction:column; gap:12px; }
.fw__name{ font-family:var(--font-display); font-weight:700; font-size:19px; line-height:1.15; }
.fw__scope{ font-size:13.5px; line-height:1.5; color:var(--ink-dim); margin:0; flex:1; }
.fw__foot{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding-top:12px; border-top:1px solid var(--hairline-2); }
.fw__ind{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.06em; color:var(--ink-dim); text-transform:uppercase; }
.tag{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.12em; text-transform:uppercase; display:inline-flex; align-items:center; gap:7px; }
.tag .dot{ width:8px; height:8px; border-radius:50%; flex:none; }
.tag--loaded{ color:var(--live); }
.tag--loaded .dot{ background:var(--live); box-shadow:0 0 0 3px rgba(62,155,79,0.16); }
.tag--seed{ color:var(--console-wait); }
.tag--seed .dot{ background:var(--console-wait); }
.tag--req{ color:var(--ink-dim); }
.tag--req .dot{ border-radius:0; border:1px solid var(--ink-dim); background:transparent; }
@media (max-width:820px){ .fw-grid{ grid-template-columns:1fr; } }

/* ============================================================
   DECISION COCKPIT
   ============================================================ */
.cockpit__grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(32px,4vw,56px); align-items:start; }
.cockpit__copy .lede{ margin-top:22px; }
.cockpit__copy p{ font-size:16px; line-height:1.62; color:var(--ink-dim); max-width:50ch; }
@media (max-width:880px){ .cockpit__grid{ grid-template-columns:1fr; } }
.nba{ border:1px solid var(--hairline); background:#fff; }
.nba__head{ display:flex; align-items:center; justify-content:space-between; gap:10px; padding:12px 16px;
  border-bottom:1px solid var(--hairline); background:var(--paper-2); font-family:var(--font-mono);
  font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-dim); }
.nba__head .ct{ color:var(--accent-ink); }
.nba__card{ padding:clamp(20px,2.4vw,28px); }
.nba__route{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-dim); margin:0 0 12px; }
.nba__what{ font-family:var(--font-display); font-weight:700; font-size:clamp(19px,2.2vw,23px); line-height:1.25; margin:0 0 16px; }
.nba__rows{ border-top:1px solid var(--hairline-2); }
.nba__row{ display:grid; grid-template-columns:130px 1fr; gap:16px; padding:11px 0; border-bottom:1px solid var(--hairline-2); align-items:baseline; }
.nba__rk{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-dim); }
.nba__rv{ font-size:14.5px; line-height:1.5; color:var(--ink); }
.nba__rv .conf{ color:var(--live); font-family:var(--font-mono); font-size:13px; }
.nba__rv .sla{ color:#B23A3A; font-family:var(--font-mono); font-size:13px; }
.nba__act{ display:flex; gap:10px; margin-top:20px; flex-wrap:wrap; }
.nba__empty{ padding:28px 16px; text-align:center; font-family:var(--font-mono); font-size:12px; letter-spacing:0.08em;
  color:var(--ink-dim); border-top:1px solid var(--hairline); display:flex; align-items:center; justify-content:center; gap:10px; }
.nba__empty .ok{ color:var(--live); }

/* ============================================================
   ASSESSMENT INSTRUMENT
   ============================================================ */
.assess{ position:relative; border:1px solid var(--ink); background:#fff; }
.assess::after{ content:""; position:absolute; inset:6px; border:1px solid var(--hairline); pointer-events:none; }
.assess__bar{ display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap;
  padding:14px clamp(20px,2.6vw,30px); border-bottom:1px solid var(--hairline); background:var(--paper-2); position:relative; z-index:2; }
.assess__bar .t{ font-family:var(--font-mono); font-size:12px; letter-spacing:0.14em; text-transform:uppercase; color:var(--ink); }
.assess__bar .code{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.08em; color:var(--ink-dim); }
.assess__body{ padding:clamp(24px,3vw,40px); position:relative; z-index:2; }
.assess__intro{ font-size:15.5px; line-height:1.6; color:var(--ink-dim); max-width:64ch; margin:0 0 30px; }

.qgrid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(20px,2.6vw,30px) clamp(24px,3vw,44px); }
@media (max-width:680px){ .qgrid{ grid-template-columns:1fr; } }
.q{ display:flex; flex-direction:column; gap:9px; }
.q__label{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-dim); display:flex; align-items:baseline; gap:9px; }
.q__label .qn{ color:var(--accent-ink); }
.q__select{ position:relative; }
.q__select select{
  width:100%; appearance:none; -webkit-appearance:none; border:1px solid var(--hairline); background:#fff;
  font-family:var(--font-body); font-size:15px; color:var(--ink); padding:12px 38px 12px 14px; border-radius:0; cursor:pointer;
}
.q__select select:focus{ outline:none; border-color:var(--accent-ink); box-shadow:inset 0 0 0 1px var(--accent-ink); }
.q__select::after{ content:"▾"; position:absolute; right:14px; top:50%; transform:translateY(-50%); pointer-events:none; color:var(--ink-dim); font-size:12px; }
.assess__run{ margin-top:clamp(28px,3.4vw,40px); display:flex; align-items:center; gap:18px; flex-wrap:wrap; padding-top:24px; border-top:1px solid var(--hairline); }
.assess__disclaim{ font-family:var(--font-mono); font-size:10.5px; line-height:1.6; letter-spacing:0.03em; color:var(--ink-dim); max-width:52ch; }

/* ---- results dossier ---- */
.report{ display:none; }
.report.show{ display:block; animation:logIn .4s ease; }
.report__masthead{ background:var(--masthead); color:#fff; padding:clamp(18px,2.2vw,24px) clamp(20px,2.6vw,30px);
  display:flex; align-items:flex-end; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.report__masthead .rt{ font-family:var(--font-display); font-weight:700; font-size:clamp(20px,2.4vw,26px); line-height:1.1; }
.report__masthead .rc{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.1em; color:rgba(255,255,255,0.7); text-transform:uppercase; }
.report__metrics{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--hairline); border-bottom:1px solid var(--hairline); }
@media (max-width:680px){ .report__metrics{ grid-template-columns:1fr; } }
.metric{ background:#fff; padding:clamp(22px,2.8vw,32px); }
.metric__k{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-dim); margin:0 0 14px; }
.metric__score{ display:flex; align-items:baseline; gap:10px; }
.metric__num{ font-family:var(--font-display); font-weight:700; font-size:clamp(46px,7vw,68px); line-height:0.95; letter-spacing:-0.02em; }
.metric__den{ font-family:var(--font-mono); font-size:14px; color:var(--ink-dim); }
.metric__band{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.1em; text-transform:uppercase; margin:10px 0 0; }
.metric__band.lo{ color:#B23A3A; } .metric__band.mid{ color:var(--console-wait); } .metric__band.hi{ color:var(--live); }
.gauge{ height:6px; background:var(--hairline-2); margin-top:16px; position:relative; overflow:hidden; }
.gauge__fill{ position:absolute; inset:0 auto 0 0; background:var(--accent-ink); width:0; transition:width 1s cubic-bezier(.2,.7,.2,1); }
.gauge__fill.lo{ background:#B23A3A; } .gauge__fill.mid{ background:var(--console-wait); } .gauge__fill.hi{ background:var(--live); }
.metric__note{ font-size:13px; line-height:1.55; color:var(--ink-dim); margin:14px 0 0; }
.metric__note b{ color:var(--ink); font-weight:500; }

.report__sections{ padding:clamp(24px,3vw,36px); display:grid; gap:clamp(26px,3vw,38px); }
.rsec__h{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--accent-ink); margin:0 0 16px; display:flex; align-items:center; gap:12px; }
.rsec__h::before{ content:""; width:22px; height:1px; background:var(--accent-ink); }
.surface{ display:flex; flex-wrap:wrap; gap:10px; }
.surface__chip{ font-family:var(--font-mono); font-size:12px; letter-spacing:0.04em; color:var(--ink); border:1px solid var(--hairline); padding:8px 13px; background:var(--paper); display:inline-flex; align-items:center; gap:9px; }
.surface__chip .d{ width:7px; height:7px; background:var(--accent-ink); flex:none; }
.surface__note{ margin-top:14px; font-size:13.5px; line-height:1.55; color:var(--ink-dim); max-width:64ch; }
.uplift{ border-top:2px solid var(--ink); }
.uplift__row{ display:grid; grid-template-columns:minmax(160px,1fr) auto 1fr; gap:14px clamp(16px,2.4vw,30px); align-items:center; padding:16px 0; border-bottom:1px solid var(--hairline); }
.uplift__k{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-dim); }
.uplift__from{ font-size:15px; color:var(--ink-dim); }
.uplift__arrow{ font-family:var(--font-mono); color:var(--accent-ink); }
.uplift__to{ font-family:var(--font-display); font-weight:600; font-size:clamp(17px,2vw,21px); color:var(--ink); }
.uplift__to .pos{ color:var(--live); }
.report__foot{ display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap;
  padding:clamp(22px,2.8vw,32px); border-top:1px solid var(--hairline); background:var(--paper-2); }
.report__cta{ display:flex; gap:12px; flex-wrap:wrap; align-items:center; }
.report__stamp .stamp{ border-color:var(--accent-ink); color:var(--accent-ink); }

/* assessment scoped reveal: never hide via .reveal inside report */
.report .reveal{ opacity:1; transform:none; }

/* ============================================================
   MODERN UI POLISH  (subtle — applied to platform-UI depictions
   + a few restrained global touches. Dossier identity intact.)
   ============================================================ */
:root{
  --ui-radius:    16px;
  --ui-radius-sm: 11px;
  --ui-shadow:    0 18px 44px -22px rgba(20,47,84,0.34), 0 3px 10px -4px rgba(20,47,84,0.14);
  --ui-shadow-sm: 0 8px 22px -14px rgba(20,47,84,0.26);
  --ui-hi:        linear-gradient(180deg, rgba(255,255,255,0.85), rgba(255,255,255,0));
  --ui-glow:      #5B6BF0; /* a quiet nod to the app accent */
}

/* ---- frosted sticky masthead (the one bit of real glass) ---- */
@supports (backdrop-filter:blur(10px)) or (-webkit-backdrop-filter:blur(10px)){
  .masthead{
    background:rgba(20,47,84,0.80);
    -webkit-backdrop-filter:blur(16px) saturate(150%);
    backdrop-filter:blur(16px) saturate(150%);
    border-bottom-color:rgba(255,255,255,0.12);
  }
  .masthead::after{
    content:""; position:absolute; left:0; right:0; bottom:-1px; height:1px;
    background:linear-gradient(90deg, transparent, rgba(110,168,255,0.55), rgba(62,155,79,0.4), transparent);
  }
  .masthead{ position:sticky; }
}

/* ---- buttons: a small modern nudge (soft radius, lift, glow) ---- */
.btn{ border-radius:10px; box-shadow:0 6px 16px -10px rgba(16,18,20,0.5); transition:background .18s ease, color .18s ease, border-color .18s ease, transform .18s ease, box-shadow .18s ease; }
.btn:hover{ transform:translateY(-1px); box-shadow:0 12px 24px -12px rgba(26,70,132,0.6); }
.btn:active{ transform:translateY(0); }
.masthead .btn{ border-radius:10px; }
.btn--sm{ border-radius:8px; }

/* ============================================================
   PLATFORM-UI DEPICTIONS — modern glass treatment
   ============================================================ */

/* ---- replay window-chrome mocks ---- */
.mock{
  border-radius:var(--ui-radius-sm);
  border-color:rgba(20,47,84,0.10);
  box-shadow:var(--ui-shadow);
  overflow:hidden;
  position:relative;
}
.mock::before{ content:""; position:absolute; inset:0 0 auto 0; height:1px; background:var(--ui-hi); z-index:3; pointer-events:none; }
.mock__bar{ background:linear-gradient(180deg, rgba(255,255,255,0.75), var(--paper-2)); border-bottom-color:rgba(20,47,84,0.08); }
/* traffic-light dots — a familiar modern UI cue */
.mock__bar .mock__dot{ box-shadow:inset 0 0 0 1px rgba(0,0,0,0.06); }
.mock__bar .mock__dot:nth-child(1){ background:#FF5F57; }
.mock__bar .mock__dot:nth-child(2){ background:#FEBC2E; }
.mock__bar .mock__dot:nth-child(3){ background:#28C840; }

/* ---- replay stage frame ---- */
.replay__stage{
  border-radius:var(--ui-radius);
  border-color:rgba(20,47,84,0.12);
  box-shadow:var(--ui-shadow);
  overflow:hidden;
}
.replay__steps{ background:linear-gradient(180deg, rgba(255,255,255,0.45), var(--paper-2)); }
.replay__step{ transition:background .15s ease, border-color .15s ease; }
.replay__step[aria-current="true"]{ background:#fff; box-shadow:inset 0 0 0 9999px rgba(91,107,240,0.04); }

/* ---- decision cockpit (next-best-action) card ---- */
.nba{
  border-radius:var(--ui-radius);
  border-color:rgba(20,47,84,0.10);
  box-shadow:var(--ui-shadow);
  overflow:hidden;
  position:relative;
  transition:transform .3s cubic-bezier(.22,.61,.36,1), box-shadow .3s ease;
}
.nba::before{ content:""; position:absolute; inset:0 0 auto 0; height:1px; background:var(--ui-hi); z-index:3; pointer-events:none; }
.nba:hover{ transform:translateY(-2px); box-shadow:0 26px 56px -26px rgba(20,47,84,0.40), 0 4px 12px -5px rgba(20,47,84,0.16); }
.nba__head{ background:linear-gradient(180deg, rgba(255,255,255,0.6), var(--paper-2)); border-bottom-color:rgba(20,47,84,0.08); }
.nba__act .btn{ border-radius:9px; }

/* ---- live console: modern dark-glass terminal ---- */
.console{
  border-radius:var(--ui-radius);
  border-color:rgba(255,255,255,0.09);
  background:linear-gradient(180deg, #15181d, #0d0f13);
  box-shadow:0 24px 56px -26px rgba(8,10,14,0.8), inset 0 1px 0 rgba(255,255,255,0.06);
  overflow:hidden;
  position:relative;
}
.console::before{ content:""; position:absolute; inset:0 0 auto 0; height:1px; z-index:3; pointer-events:none;
  background:linear-gradient(90deg, transparent, rgba(124,204,68,0.5), transparent); }
.console__head{ border-bottom-color:rgba(255,255,255,0.07); }
.console.is-connected .console__live .d{
  background:var(--console-ok);
  box-shadow:0 0 0 3px rgba(124,204,68,0.20), 0 0 10px rgba(124,204,68,0.8);
}
.console__foot{ border-top-color:rgba(255,255,255,0.07); }
.console__log::-webkit-scrollbar-thumb{ background:rgba(255,255,255,0.14); border-radius:99px; }

/* ---- framework cards: very light lift on hover (subtle) ---- */
.fw{ transition:background .18s ease; }
.fw:hover{ background:#fff; }

@media (prefers-reduced-motion: reduce){
  .btn:hover,.nba:hover{ transform:none; }
}
