/* ============================================================
   GenAI in Financial Services — deck design system
   ============================================================ */

/* ---------- Themes ---------- */
:root,
[data-theme="navy"] {
  --bg:#080c17;        --bg-2:#0f1525;      --bg-3:#18213a;
  --ink:#eef2fb;       --ink-2:#97a4c2;     --ink-3:#5a6889;
  --line:rgba(255,255,255,.10);
  --line-2:rgba(255,255,255,.18);
  --accent:#5b8cff;    --accent-2:#36d8e0;
  --accent-soft:rgba(91,140,255,.14);
  --on-accent:#06122b;
  --code-bg:#0a1020;
  --shadow:0 30px 80px -30px rgba(0,0,0,.7);
  --glow:0 0 0 1px var(--accent-soft), 0 18px 50px -20px rgba(91,140,255,.45);
}
[data-theme="paper"]{
  --bg:#f1ece1;        --bg-2:#faf6ee;      --bg-3:#e7e0d0;
  --ink:#1b1a16;       --ink-2:#6c6555;     --ink-3:#9a917c;
  --line:rgba(27,26,22,.14);
  --line-2:rgba(27,26,22,.26);
  --accent:#c2603a;    --accent-2:#2f6f6a;
  --accent-soft:rgba(194,96,58,.13);
  --on-accent:#fbf7ef;
  --code-bg:#ece5d6;
  --shadow:0 26px 60px -34px rgba(60,40,20,.45);
  --glow:0 0 0 1px var(--accent-soft), 0 16px 40px -22px rgba(194,96,58,.4);
}
[data-theme="mint"]{
  --bg:#0a100e;        --bg-2:#111a16;      --bg-3:#18241f;
  --ink:#e9f3ee;       --ink-2:#90a79c;     --ink-3:#586d63;
  --line:rgba(255,255,255,.09);
  --line-2:rgba(255,255,255,.17);
  --accent:#54e3a0;    --accent-2:#46c4cf;
  --accent-soft:rgba(84,227,160,.13);
  --on-accent:#05130c;
  --code-bg:#0a1411;
  --shadow:0 30px 80px -30px rgba(0,0,0,.7);
  --glow:0 0 0 1px var(--accent-soft), 0 18px 50px -20px rgba(84,227,160,.4);
}
[data-theme="red"]{
  --bg:#ffffff;        --bg-2:#f6f6f8;      --bg-3:#ededf1;
  --ink:#141416;       --ink-2:#666670;     --ink-3:#9c9ca6;
  --line:rgba(0,0,0,.11);
  --line-2:rgba(0,0,0,.2);
  --accent:#e2231a;    --accent-2:#1a1a1a;
  --accent-soft:rgba(226,35,26,.10);
  --on-accent:#ffffff;
  --code-bg:#f1f1f4;
  --shadow:0 26px 60px -34px rgba(0,0,0,.25);
  --glow:0 0 0 1px var(--accent-soft), 0 16px 40px -22px rgba(226,35,26,.32);
}

:root{
  --font-head:'Space Grotesk', system-ui, sans-serif;
  --font-body:'Manrope', system-ui, sans-serif;
  --font-mono:'JetBrains Mono', ui-monospace, monospace;
}

/* ---------- Base ---------- */
deck-stage:not(:defined){ visibility:hidden; }
*{ box-sizing:border-box; }
html,body{ margin:0; background:#000; }

deck-stage > section{
  background:
    radial-gradient(1200px 700px at 82% -8%, var(--accent-soft), transparent 60%),
    var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  padding:88px 116px 104px;
  display:flex; flex-direction:column;
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
}
deck-stage > section.flush{ padding:0; }

/* ---------- Footer chrome ---------- */
.chrome{
  position:absolute; left:116px; right:116px; bottom:46px;
  display:flex; align-items:center; justify-content:space-between;
  font-family:var(--font-mono); font-size:15px; letter-spacing:.02em;
  color:var(--ink-3);
}
.chrome .bfh{ display:flex; align-items:center; gap:14px; }
.chrome .bfh b{ color:var(--ink-2); font-weight:600; }
.chrome .tick{ width:26px; height:2px; background:var(--accent); display:inline-block; }
.chrome .pg{ color:var(--ink-2); }
.chrome .pg span{ color:var(--accent); }

/* ---------- Type helpers ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--font-mono); font-size:18px; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase; color:var(--accent);
}
.eyebrow::before{ content:""; width:30px; height:2px; background:var(--accent); }
h1.title{ font-family:var(--font-head); font-weight:600; line-height:1.02;
  letter-spacing:-.02em; margin:0; font-size:104px; }
h2.head{ font-family:var(--font-head); font-weight:600; line-height:1.04;
  letter-spacing:-.018em; margin:0; font-size:66px; }
h3.sub{ font-family:var(--font-head); font-weight:600; font-size:36px;
  letter-spacing:-.01em; margin:0; }
.lede{ font-size:30px; line-height:1.5; color:var(--ink-2); max-width:24ch; font-weight:400; }
.kicker{ font-family:var(--font-mono); font-size:17px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--ink-3); }
.accent{ color:var(--accent); }
.mono{ font-family:var(--font-mono); }
.muted{ color:var(--ink-2); }

/* slide header block used on concept slides */
.s-head{ display:flex; flex-direction:column; gap:18px; margin-bottom:44px; }
.s-head h2{ max-width:20ch; }

/* ---------- Cover ---------- */
.cover{ justify-content:center; }
.cover .topline{ position:absolute; top:80px; left:116px; right:116px;
  display:flex; justify-content:space-between; align-items:flex-start; }
.cover .logo{ font-family:var(--font-head); font-weight:600; font-size:22px; letter-spacing:.01em; }
.cover .logo small{ display:block; font-family:var(--font-mono); font-weight:400;
  font-size:15px; letter-spacing:.04em; color:var(--ink-3); margin-top:6px; }
.cover .badge{ font-family:var(--font-mono); font-size:15px; color:var(--ink-2);
  border:1px solid var(--line); border-radius:100px; padding:9px 18px; }
.cover h1{ font-size:120px; max-width:17ch; }
.cover .series{ margin-top:34px; display:flex; gap:14px; align-items:center;
  font-family:var(--font-mono); font-size:20px; color:var(--ink-2); }
.cover .series .dot{ width:9px; height:9px; border-radius:50%; background:var(--accent); }
.cover .author{ position:absolute; bottom:120px; left:116px; display:flex;
  align-items:center; gap:18px; }
.cover .author .ph{ width:60px; height:60px; border-radius:50%;
  background:var(--bg-3); border:1px solid var(--line);
  display:grid; place-items:center; font-family:var(--font-mono);
  font-size:11px; color:var(--ink-3); }
.cover .author b{ font-family:var(--font-head); font-weight:600; font-size:24px; }
.cover .author span{ display:block; color:var(--ink-2); font-size:18px; }

/* ---------- Section divider ---------- */
.section-divider{ justify-content:center; }
.section-divider .num{ font-family:var(--font-mono); font-size:24px;
  letter-spacing:.2em; color:var(--accent); margin-bottom:30px; }
.section-divider h2{ font-family:var(--font-head); font-weight:600;
  font-size:130px; line-height:.98; letter-spacing:-.025em; max-width:18ch; }
.section-divider .arrow{ color:var(--accent); }
.section-divider .toc{ position:absolute; right:116px; bottom:120px;
  display:flex; flex-direction:column; gap:10px; align-items:flex-end;
  font-family:var(--font-mono); font-size:16px; color:var(--ink-3); text-align:right; }
.section-divider .toc .on{ color:var(--ink); }
.section-divider .toc .on::after{ content:""; display:inline-block; margin-left:12px;
  width:24px; height:2px; background:var(--accent); vertical-align:middle; }

/* ---------- Prompt / question slide ---------- */
.prompt-slide{ justify-content:center; }
.prompt-slide .kicker{ margin-bottom:26px; }
.prompt-slide .q{ font-family:var(--font-head); font-weight:600; font-size:96px;
  line-height:1.05; letter-spacing:-.02em; max-width:20ch; }
.prompt-slide .q .accent{ position:relative; }
.prompt-slide .hint{ margin-top:42px; font-family:var(--font-mono);
  font-size:19px; color:var(--ink-2); display:flex; align-items:center; gap:14px; }
.prompt-slide .hint .pill{ border:1px solid var(--line-2); border-radius:100px;
  padding:8px 16px; color:var(--ink); }

/* ---------- Cards / grids ---------- */
.triad{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; flex:1; align-content:center; }
.card{ background:var(--bg-2); border:1px solid var(--line); border-radius:22px;
  padding:38px 34px; display:flex; flex-direction:column; gap:18px;
  box-shadow:var(--shadow); }
.card .n{ font-family:var(--font-mono); font-size:16px; color:var(--accent);
  letter-spacing:.1em; }
.card h4{ font-family:var(--font-head); font-weight:600; font-size:30px; margin:0;
  letter-spacing:-.01em; }
.card p{ font-size:21px; line-height:1.5; color:var(--ink-2); margin:0; }
.card.lift{ border-color:var(--line-2); }

.two{ display:grid; grid-template-columns:1fr 1fr; gap:48px; flex:1; align-items:center; }
.two.wide{ grid-template-columns:0.9fr 1.1fr; }

/* bullets */
.blist{ display:flex; flex-direction:column; gap:20px; margin:0; padding:0; list-style:none; }
.blist li{ position:relative; padding-left:30px; font-size:25px; line-height:1.45; color:var(--ink); }
.blist li::before{ content:""; position:absolute; left:0; top:11px; width:11px; height:11px;
  border-radius:3px; background:var(--accent); transform:rotate(45deg); }
.blist li b{ font-weight:700; }

/* ---------- Code block ---------- */
.code{ background:var(--code-bg); border:1px solid var(--line); border-radius:18px;
  font-family:var(--font-mono); font-size:21px; line-height:1.6; color:var(--ink);
  padding:30px 34px; white-space:pre; overflow:hidden; box-shadow:var(--shadow); }
.code .k{ color:var(--accent); }
.code .s{ color:var(--accent-2); }
.code .c{ color:var(--ink-3); }
.code .winbar{ display:flex; gap:8px; margin-bottom:18px; }
.code .winbar i{ width:13px; height:13px; border-radius:50%; background:var(--ink-3); opacity:.5; }

/* chat bubbles */
.chat{ display:flex; flex-direction:column; gap:16px; }
.bub{ max-width:78%; padding:18px 24px; border-radius:20px; font-size:24px; line-height:1.4; }
.bub.u{ align-self:flex-start; background:var(--bg-3); border-bottom-left-radius:6px; }
.bub.a{ align-self:flex-end; background:var(--accent); color:var(--on-accent);
  border-bottom-right-radius:6px; }
.bub .who{ display:block; font-family:var(--font-mono); font-size:13px; opacity:.7;
  margin-bottom:5px; letter-spacing:.05em; }

/* image placeholder */
.ph-img{ position:relative; border-radius:20px; overflow:hidden; border:1px solid var(--line);
  background:
    repeating-linear-gradient(135deg, var(--bg-2) 0 14px, var(--bg-3) 14px 28px);
  display:grid; place-items:center; }
.ph-img span{ font-family:var(--font-mono); font-size:16px; color:var(--ink-2);
  background:var(--bg); padding:8px 16px; border-radius:100px; border:1px solid var(--line);
  letter-spacing:.04em; }

/* exercise badge */
.exbadge{ display:inline-flex; align-items:center; gap:12px; align-self:flex-start;
  font-family:var(--font-mono); font-size:16px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--on-accent); background:var(--accent); border-radius:100px; padding:10px 20px;
  font-weight:600; }
.exbadge::before{ content:"●"; font-size:11px; }

/* break slide */
.break-slide{ align-items:center; justify-content:center; text-align:center; }
.break-slide .lab{ font-family:var(--font-mono); letter-spacing:.3em; text-transform:uppercase;
  color:var(--accent); font-size:22px; margin-bottom:26px; }
.break-slide .time{ font-family:var(--font-head); font-weight:600; font-size:180px;
  line-height:1; letter-spacing:-.03em; white-space:nowrap; }
.break-slide .time small{ font-size:54px; color:var(--ink-2); font-weight:500; }

/* stat slide */
.stat-slide{ justify-content:center; }
.stat-slide .big{ font-family:var(--font-head); font-weight:600; font-size:300px;
  line-height:.9; letter-spacing:-.04em; background:linear-gradient(180deg,var(--ink),var(--accent));
  -webkit-background-clip:text; background-clip:text; color:transparent; }
.stat-slide .cap{ font-size:38px; max-width:22ch; line-height:1.3; margin-top:10px; }
.stat-slide .src{ position:absolute; bottom:120px; font-family:var(--font-mono);
  font-size:16px; color:var(--ink-3); }

/* quote slide */
.quote-slide{ justify-content:center; }
.quote-slide blockquote{ margin:0; font-family:var(--font-head); font-weight:500;
  font-size:84px; line-height:1.12; letter-spacing:-.02em; max-width:24ch; }
.quote-slide blockquote .mk{ color:var(--accent); }
.quote-slide cite{ display:block; margin-top:44px; font-style:normal;
  font-family:var(--font-mono); font-size:24px; color:var(--ink-2); }

/* ---------- generic entrance animations ----------
   Gated on body.anim-on: a timer reveals content (removes the gate's effect
   by keeping base styles) if the page never paints, so export / PDF / any
   non-painting context shows content instead of a frozen hidden frame. */
@media (prefers-reduced-motion:no-preference){
  body.anim-on [data-deck-active] .anim{ animation:rise .65s cubic-bezier(.2,.7,.2,1) both; }
  body.anim-on [data-deck-active] .anim.d1{ animation-delay:.08s; }
  body.anim-on [data-deck-active] .anim.d2{ animation-delay:.16s; }
  body.anim-on [data-deck-active] .anim.d3{ animation-delay:.24s; }
  body.anim-on [data-deck-active] .anim.d4{ animation-delay:.32s; }
  body.anim-on [data-deck-active] .anim.d5{ animation-delay:.40s; }
  body.anim-on [data-deck-active] .anim.d6{ animation-delay:.48s; }
  body.anim-on [data-deck-active] .fade{ animation:fade .8s ease both; }
}
@media print{
  .anim, .fade{ animation:none !important; opacity:1 !important; transform:none !important; }
}
@keyframes rise{ from{ opacity:0; transform:translateY(26px); } to{ opacity:1; transform:none; } }
@keyframes fade{ from{ opacity:0; } to{ opacity:1; } }

.no-motion .anim,
.no-motion .fade{ animation:none !important; opacity:1 !important; transform:none !important; }

/* ---------- Agenda ---------- */
.agenda{ flex:1; display:flex; align-items:center; }
.ag-list{ list-style:none; margin:0; padding:0; display:grid;
  grid-template-columns:1fr 1fr; gap:18px 64px; width:100%; }
.ag-list li{ display:flex; align-items:baseline; gap:22px; padding:18px 4px;
  border-bottom:1px solid var(--line); }
.ag-n{ font-family:var(--font-mono); font-size:22px; color:var(--accent); min-width:42px; }
.ag-t{ font-family:var(--font-head); font-weight:500; font-size:30px; letter-spacing:-.01em; }

/* ---------- arrow in headings ---------- */
.section-divider h2 .arrow, .s-head h2 .arrow, h2 .arrow{
  display:inline-block; vertical-align:baseline; white-space:nowrap; }
.section-divider h2{ text-wrap:balance; }

/* ---------- chat frame ---------- */
.chat-frame{ background:var(--bg-2); border:1px solid var(--line); border-radius:24px;
  padding:34px 32px; box-shadow:var(--shadow); }
.chat-frame .chat-bar{ display:flex; align-items:center; gap:9px; margin-bottom:22px; }
.chat-frame .chat-bar i{ width:11px; height:11px; border-radius:50%; background:var(--ink-3); opacity:.45; }
.chat-frame .chat-bar span{ margin-left:8px; font-family:var(--font-mono); font-size:14px;
  letter-spacing:.06em; color:var(--ink-3); }

/* ---------- iceberg slide ---------- */
.ice-wrap{ display:grid; grid-template-columns:0.92fr 1.08fr; gap:64px; flex:1; align-items:center; }
.ice-visual{ display:grid; place-items:center; }
.ice-svg{ width:100%; max-width:440px; height:auto; }
.ice-water{ fill:var(--accent-soft); }
.ice-line{ stroke:var(--accent); stroke-width:2; stroke-dasharray:7 8; opacity:.65; }
.ice-tip{ fill:var(--ink); }
.ice-body{ fill:var(--accent); opacity:.92; }
.ice-cards{ display:flex; flex-direction:column; gap:22px; }
.ice-card{ border:1px solid var(--line); border-radius:20px; padding:26px 30px; background:var(--bg-2); }
.ice-card .ice-tag{ font-family:var(--font-mono); font-size:15px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-3); margin-bottom:12px; }
.ice-card h4{ font-family:var(--font-head); font-weight:600; font-size:32px; margin:0 0 10px; letter-spacing:-.01em; }
.ice-card p{ font-size:22px; line-height:1.45; color:var(--ink-2); margin:0; }
.ice-card .pct{ color:var(--ink-3); }
.ice-card.deep{ border-color:var(--accent); background:var(--accent-soft); box-shadow:var(--glow); }
.ice-card.deep .ice-tag{ color:var(--accent); }
.ice-card.deep .pct{ color:var(--accent); font-weight:700; }

/* ---------- trainer slide ---------- */
.trainer{ display:grid; grid-template-columns:0.78fr 1.22fr; gap:72px; flex:1; align-items:center; }
.trainer-photo{ width:100%; height:540px; }
.trainer-info h3{ font-family:var(--font-head); font-weight:600; font-size:72px;
  letter-spacing:-.02em; margin:0; }
.trainer-role{ font-family:var(--font-mono); font-size:22px; color:var(--accent); margin-top:8px; }
.trainer-bio{ font-size:30px; line-height:1.5; color:var(--ink-2); max-width:26ch; margin:34px 0 0; }
.trainer-tags{ display:flex; flex-wrap:wrap; gap:12px; margin-top:36px; }
.trainer-tags span{ font-family:var(--font-mono); font-size:17px; color:var(--ink);
  border:1px solid var(--line-2); border-radius:100px; padding:10px 20px; }

/* ---------- needle in a haystack ---------- */
.nh-wrap{ display:flex; flex-direction:column; gap:30px; }
.nh-strip{ display:grid; grid-template-columns:repeat(40, 1fr); gap:5px; }
.nh-cell{ height:46px; border-radius:5px; background:var(--bg-3); border:1px solid var(--line); transition:.2s; }
.nh-cell.needle{ background:var(--accent); border-color:var(--accent); box-shadow:var(--glow); }
.nh-chart{ width:100%; max-width:640px; height:auto; }
.nh-curve{ fill:none; stroke:var(--accent); stroke-width:3; }
.nh-area{ fill:var(--accent-soft); }
.nh-axis{ stroke:var(--line-2); stroke-width:1.5; }
.nh-dot{ fill:var(--accent); }
.nh-grid{ stroke:var(--line); stroke-width:1; }
.nh-tick{ font-family:var(--font-mono); font-size:14px; fill:var(--ink-3); }

/* ---------- news / browser frame ---------- */
.newsframe{ border:1px solid var(--line-2); border-radius:18px; overflow:hidden;
  background:#fff; box-shadow:var(--shadow); }
.newsframe .bar{ display:flex; align-items:center; gap:8px; padding:14px 18px;
  background:var(--bg-2); border-bottom:1px solid var(--line); }
.newsframe .bar i{ width:12px; height:12px; border-radius:50%; background:var(--ink-3); opacity:.4; }
.newsframe .bar span{ margin-left:10px; font-family:var(--font-mono); font-size:14px; color:var(--ink-3); }
.newsframe img{ display:block; width:100%; height:auto; }

/* ---------- two-day timed agenda ---------- */
.agenda2{ display:grid; grid-template-columns:1fr 1fr; gap:30px 56px; flex:1; align-content:center; }
.day-col{ display:flex; flex-direction:column; gap:14px; }
.day-col .day-h{ display:flex; align-items:baseline; gap:14px; padding-bottom:14px;
  border-bottom:2px solid var(--accent); margin-bottom:6px; }
.day-col .day-h b{ font-family:var(--font-head); font-weight:700; font-size:34px; letter-spacing:-.01em; }
.day-col .day-h span{ font-family:var(--font-mono); font-size:16px; color:var(--ink-2); }
.trow{ display:grid; grid-template-columns:96px 1fr; gap:18px; align-items:baseline; }
.trow .tt{ font-family:var(--font-mono); font-size:17px; color:var(--accent); }
.trow .td{ font-size:21px; line-height:1.35; color:var(--ink); }
.trow .td small{ display:block; font-family:var(--font-mono); font-size:14px; color:var(--ink-3); margin-top:2px; }
.trow.brk .td{ color:var(--ink-3); }
.trow.brk .tt{ color:var(--ink-3); }

/* ---------- day divider ---------- */
.day-divider{ justify-content:center; }
.day-divider .dlabel{ font-family:var(--font-mono); font-size:24px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--accent); margin-bottom:26px; }
.day-divider h2{ font-family:var(--font-head); font-weight:600; font-size:120px; line-height:.98;
  letter-spacing:-.025em; max-width:18ch; margin:0; }
.day-divider .dsub{ margin-top:34px; font-size:30px; color:var(--ink-2); max-width:34ch; line-height:1.4; }
.day-divider .dmeta{ position:absolute; right:116px; bottom:120px; text-align:right;
  font-family:var(--font-mono); font-size:18px; color:var(--ink-3); display:flex; flex-direction:column; gap:10px; align-items:flex-end; }
.day-divider .dmeta div{ white-space:nowrap; }
.day-divider .dmeta b{ color:var(--accent); font-weight:600; }

/* ---------- agent vs workflow compare ---------- */
.cmp{ display:grid; grid-template-columns:1fr 1fr; gap:30px; flex:1; align-content:center; }
.cmp .col{ border:1px solid var(--line); border-radius:22px; padding:36px 34px; background:var(--bg-2);
  display:flex; flex-direction:column; gap:16px; box-shadow:var(--shadow); }
.cmp .col.agent{ border-color:color-mix(in srgb, var(--accent-2) 45%, transparent); }
.cmp .col.flow{ border-color:var(--accent); background:var(--accent-soft); }
.cmp .col .tag{ font-family:var(--font-mono); font-size:16px; letter-spacing:.14em; text-transform:uppercase; }
.cmp .col.agent .tag{ color:var(--accent-2); }
.cmp .col.flow .tag{ color:var(--accent); }
.cmp .col h4{ font-family:var(--font-head); font-weight:600; font-size:34px; margin:0; letter-spacing:-.01em; }
.cmp .col p{ font-size:21px; line-height:1.45; color:var(--ink-2); margin:0; }
.cmp .col .big-line{ font-family:var(--font-head); font-weight:600; font-size:26px; color:var(--ink); }

/* ---------- metric numbers ---------- */
.metrics{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; flex:1; align-content:center; }
.metric{ border:1px solid var(--line); border-radius:22px; padding:38px 34px; background:var(--bg-2);
  box-shadow:var(--shadow); }
.metric .mlab{ font-family:var(--font-mono); font-size:16px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--accent); margin-bottom:16px; }
.metric .mnum{ font-family:var(--font-head); font-weight:700; font-size:84px; line-height:1;
  letter-spacing:-.03em; }
.metric .msub{ font-size:20px; color:var(--ink-2); margin-top:12px; line-height:1.4; }

/* score chips */
.scorewrap{ display:flex; gap:26px; flex-wrap:wrap; align-items:stretch; }
.scorecard{ flex:1; min-width:300px; border:1px solid var(--line); border-radius:20px;
  padding:30px 32px; background:var(--bg-2); box-shadow:var(--shadow); }
.scorecard.win{ border-color:var(--accent); background:var(--accent-soft); }
.scorecard .stitle{ font-family:var(--font-mono); font-size:17px; color:var(--ink-2); letter-spacing:.04em; }
.scorecard .snum{ font-family:var(--font-head); font-weight:700; font-size:96px; line-height:1; margin:10px 0;
  letter-spacing:-.03em; }
.scorecard.win .snum{ color:var(--accent); }
.scorecard .stag{ font-family:var(--font-mono); font-size:16px; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink-3); }
.scorecard.win .stag{ color:var(--accent); }

/* ---------- file table (case study) ---------- */
.ftable{ width:100%; border-collapse:collapse; font-size:21px; }
.ftable th{ font-family:var(--font-mono); font-size:15px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--ink-3); text-align:left; padding:14px 18px; border-bottom:1px solid var(--line-2); font-weight:500; }
.ftable td{ padding:16px 18px; border-bottom:1px solid var(--line); color:var(--ink); vertical-align:top; }
.ftable td .mono{ color:var(--ink-2); }
.ftable .cat{ display:inline-block; font-family:var(--font-mono); font-size:15px; padding:5px 12px;
  border-radius:100px; border:1px solid var(--line-2); color:var(--accent); }

/* step metric inline */
.fieldrow{ display:grid; grid-template-columns:auto 1fr; gap:18px 22px; align-items:start; }
.fieldrow .fnum{ font-family:var(--font-mono); font-size:16px; color:var(--accent); padding-top:4px; }
.fieldrow .fmethod{ font-family:var(--font-head); font-weight:600; font-size:24px; }
.fieldrow .fdesc{ grid-column:2; font-size:20px; color:var(--ink-2); line-height:1.4; margin-top:-8px; }

/* ---------- Tweaks host root (invisible) ---------- */
#tweak-root{ position:fixed; inset:0; pointer-events:none; z-index:9999; }
#tweak-root > *{ pointer-events:auto; }
