:root {
  --paper: #f7f3ec; --paper-alt: #ffffff; --paper-sunk: #f0eae0;
  --ink: #161312; --ink-soft: #5b554d; --ink-faint: #8c867c;
  --accent: #c8642a; --accent-soft: rgba(200, 100, 42, 0.1);
  --red-deep: #661d18;
  --ex: #c8642a; --he: #0f9a86; --tr: #4257d6;
  --neg: #b53a2b; --pos: #0f9a86;
  --line: rgba(22, 19, 18, 0.12); --line-soft: rgba(22, 19, 18, 0.06);
  --grid: rgba(22, 19, 18, 0.08);
  --sans: 'Sora', system-ui, sans-serif; --mono: 'IBM Plex Mono', ui-monospace, monospace;
}
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; text-size-adjust: 100%; overflow-x: clip; }
body { margin: 0; background: var(--paper); color: var(--ink); font-family: var(--sans); line-height: 1.6; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
::selection { background: var(--accent-soft); color: var(--ink); }
.wrap { max-width: 1120px; margin: 0 auto; padding: 0 clamp(18px, 5vw, 40px); }
.mono { font-family: var(--mono); font-size: 10px; font-weight: 500; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-faint); }
.mono.accent { color: var(--accent); }
a { color: inherit; }

/* header + nav */
header { position: sticky; top: 0; z-index: 20; background: rgba(247, 243, 236, 0.82); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); }
.head { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 13px 0; flex-wrap: wrap; }
.brand { display: flex; align-items: center; gap: 11px; text-decoration: none; }
.brand .wm { font-weight: 600; letter-spacing: 0.32em; padding-left: 0.32em; font-size: 15px; color: var(--ink); }
.brand .wm b { color: var(--red-deep); font-weight: 600; }
.nav { display: flex; gap: clamp(12px, 3vw, 26px); flex-wrap: wrap; }
.nav a { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-soft); text-decoration: none; padding: 4px 0; border-bottom: 2px solid transparent; transition: color 0.15s, border-color 0.15s; }
.nav a:hover { color: var(--accent); }
.nav a.active { color: var(--ink); border-bottom-color: var(--accent); }
/* highlight the Deal item so it reads as the destination */
.nav a[href="/deal.html"] { color: var(--accent); border: 1px solid rgba(200, 100, 42, 0.55); border-radius: 999px; padding: 5px 13px; font-weight: 600; }
.nav a[href="/deal.html"]:hover { background: var(--accent); color: #fff; border-color: var(--accent); }
.nav a[href="/deal.html"].active { background: var(--accent); color: #fff; border-color: var(--accent); }

/* hero */
.hero { padding: clamp(46px, 9vw, 92px) 0 clamp(24px, 4vw, 40px); }
.hero .eyebrow { display: inline-flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.hero .eyebrow::before { content: ''; width: 22px; height: 1px; background: var(--accent); }
.hero h1 { font-size: clamp(30px, 6vw, 60px); line-height: 1.04; letter-spacing: -0.03em; font-weight: 800; margin: 0; max-width: 20ch; }
.hero h1 .a { color: var(--accent); }
.hero .sub { margin: 22px 0 0; font-size: clamp(15px, 1.7vw, 19px); color: var(--ink-soft); max-width: 62ch; }
.cta-row { margin-top: 30px; display: flex; flex-wrap: wrap; gap: 12px; }
.btn { display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; text-decoration: none; padding: 13px 20px; border-radius: 11px; cursor: pointer; transition: all 0.15s; }
.btn.primary { background: var(--accent); color: #fff; border: none; box-shadow: 0 12px 26px -12px rgba(200, 100, 42, 0.6); }
.btn.primary:hover { transform: translateY(-2px); box-shadow: 0 16px 32px -12px rgba(200, 100, 42, 0.7); }
.btn.ghost { background: transparent; color: var(--ink); border: 1px solid var(--line); }
.btn.ghost:hover { border-color: var(--accent); color: var(--accent); }
.prewarn { margin-top: 22px; display: inline-flex; align-items: center; gap: 9px; font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.06em; color: var(--ink-soft); background: var(--paper-sunk); border: 1px solid var(--line); border-radius: 999px; padding: 7px 13px; }
.prewarn i { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); display: inline-block; }

/* sections */
section.s { padding: clamp(40px, 7vw, 76px) 0; border-top: 1px solid var(--line); }
.kicker { display: flex; align-items: baseline; gap: 13px; margin-bottom: 8px; }
.kicker .idx { font-family: var(--mono); font-size: 12px; font-weight: 600; color: var(--accent); letter-spacing: 0.12em; }
h2.t { font-size: clamp(22px, 3vw, 34px); line-height: 1.1; letter-spacing: -0.02em; font-weight: 700; margin: 0 0 6px; }
.lead { color: var(--ink-soft); font-size: clamp(14px, 1.5vw, 16px); max-width: 66ch; margin: 0 0 clamp(24px, 4vw, 36px); }
.group-label { margin: 30px 0 14px; display: flex; align-items: center; gap: 10px; }
.group-label::after { content: ''; flex: 1; height: 1px; background: var(--line); }

/* stat tiles */
.stats { display: grid; gap: 12px; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); }
.stat { background: var(--paper-alt); border: 1px solid var(--line); border-radius: 14px; padding: 16px 18px; box-shadow: 0 18px 40px -30px rgba(22, 19, 18, 0.5); }
.stat.accent { border-color: rgba(200, 100, 42, 0.4); }
.stat .v { font-size: clamp(24px, 3.2vw, 34px); font-weight: 700; letter-spacing: -0.02em; line-height: 1; }
.stat .v .u { font-size: 0.5em; color: var(--ink-faint); font-weight: 600; margin-left: 2px; }
.stat .k { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-faint); margin-top: 9px; }

/* cards + charts */
.card { background: var(--paper-alt); border: 1px solid var(--line); border-radius: 16px; padding: clamp(18px, 2.4vw, 26px); box-shadow: 0 22px 50px -34px rgba(22, 19, 18, 0.45); }
.card.sunk { background: var(--paper-sunk); box-shadow: none; }
.card.accent { border-color: rgba(200, 100, 42, 0.45); box-shadow: 0 0 0 1px rgba(200, 100, 42, 0.12), 0 22px 50px -34px rgba(22, 19, 18, 0.45); }
.grid2 { display: grid; gap: 16px; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); }
.chart-h { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 16px; }
.chart-h .name { font-size: 15px; font-weight: 700; }
.legend { display: flex; flex-wrap: wrap; gap: 12px; }
.legend span { display: inline-flex; align-items: center; gap: 6px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.04em; color: var(--ink-soft); }
.legend i { width: 10px; height: 10px; border-radius: 3px; display: inline-block; }
.cap { font-size: 11.5px; color: var(--ink-faint); margin-top: 12px; line-height: 1.5; }

/* revenue-model lines (how each product earns) */
.revlines { display: grid; gap: 0; margin-top: 10px; border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
.revline { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 10px 14px; border-bottom: 1px solid var(--line-soft); background: var(--paper-alt); }
.revline:last-child { border-bottom: none; }
.revline.total { background: var(--paper-sunk); }
.revline .rl-k { font-size: 12.5px; color: var(--ink-soft); }
.revline.total .rl-k { color: var(--ink); font-weight: 600; }
.revline .rl-v { font-family: var(--mono); font-size: 11.5px; font-weight: 600; color: var(--ink); white-space: nowrap; text-align: right; }
.revline.total .rl-v { color: var(--accent); }

/* leadership: split bars + bullet lists */
.splitbar { display: flex; height: 28px; border-radius: 8px; overflow: hidden; border: 1px solid var(--line); }
.splitbar > div { height: 100%; }
.splitbar > div + div { border-left: 2px solid var(--paper-alt); }
.splitlabels { display: flex; justify-content: space-between; gap: 12px; font-family: var(--mono); font-size: 11px; margin-top: 8px; color: var(--ink-soft); }
.blist { list-style: none; margin: 12px 0 0; padding: 0; }
.blist li { position: relative; padding-left: 18px; margin-bottom: 9px; font-size: 13px; line-height: 1.5; color: var(--ink-soft); }
.blist li::before { content: ''; position: absolute; left: 0; top: 8px; width: 6px; height: 6px; background: var(--accent); border-radius: 1px; }
.blist li b { color: var(--ink); font-weight: 600; }

/* flow (home model) */
.flow { display: flex; align-items: stretch; justify-content: center; gap: 12px; flex-wrap: wrap; }
.flow .card { flex: 1 1 220px; }
.flow .arrow { display: flex; align-items: center; color: var(--accent); font-size: 24px; }
.node-name { font-size: 16px; font-weight: 700; letter-spacing: -0.01em; margin: 6px 0 0; }
.node-desc { font-size: 12.5px; line-height: 1.5; color: var(--ink-soft); margin: 6px 0 0; }
.strip { display: inline-block; margin-top: 10px; font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); border: 1px solid var(--accent-soft); border-radius: 999px; padding: 3px 9px; }

/* column bar chart */
.cols { display: grid; grid-auto-flow: column; grid-auto-columns: 1fr; gap: clamp(8px, 2vw, 20px); align-items: end; padding-top: 12px; }
.col-c { display: flex; flex-direction: column; align-items: center; height: 100%; justify-content: flex-end; }
.col-total { font-family: var(--mono); font-size: 11px; font-weight: 600; color: var(--ink); margin-bottom: 7px; text-align: center; line-height: 1.2; }
.col-total .cs { display: block; font-weight: 400; color: var(--ink-faint); font-size: 9px; margin-top: 1px; }
.bar-stack { width: 100%; max-width: 62px; display: flex; flex-direction: column-reverse; }
.seg { width: 100%; }
.bar-stack .seg:first-child { border-radius: 0 0 4px 4px; }
.bar-stack .seg:last-child { border-radius: 4px 4px 0 0; }
.seg + .seg { margin-bottom: 2px; }
.col-x { font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; color: var(--ink-faint); margin-top: 10px; }

/* horizontal bars */
.hbars { display: flex; flex-direction: column; gap: 12px; }
.hbar { display: grid; grid-template-columns: 92px 1fr auto; align-items: center; gap: 12px; }
.hbar .lab { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.06em; color: var(--ink-soft); }
.hbar .track { height: 22px; background: var(--paper-sunk); border-radius: 6px; overflow: hidden; }
.hbar .fill { height: 100%; border-radius: 6px; }
.hbar .val { font-family: var(--mono); font-size: 12px; font-weight: 600; }

/* spark */
.spark { display: grid; grid-auto-flow: column; grid-auto-columns: 1fr; gap: 6px; align-items: end; height: 84px; }
.spark .sb { width: 100%; border-radius: 3px 3px 0 0; min-height: 3px; }
.spark-x { display: grid; grid-auto-flow: column; grid-auto-columns: 1fr; gap: 6px; margin-top: 6px; }
.spark-x span { font-family: var(--mono); font-size: 9px; color: var(--ink-faint); text-align: center; }

/* tables */
.tbl-wrap { overflow-x: auto; margin-top: 16px; }
table.d { width: 100%; border-collapse: collapse; font-size: 12.5px; min-width: 380px; }
table.d th, table.d td { text-align: right; padding: 8px 10px; border-bottom: 1px solid var(--line-soft); font-variant-numeric: tabular-nums; }
table.d th:first-child, table.d td:first-child { text-align: left; }
table.d thead th { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-faint); font-weight: 500; }
table.d tbody tr:last-child td { border-bottom: none; font-weight: 700; }
table.d .pos { color: var(--pos); }
table.d .neg { color: var(--neg); }

/* svg chart */
.svgchart { width: 100%; height: auto; display: block; }
.svgchart .axis { stroke: var(--line); stroke-width: 1; }
.svgchart .grid { stroke: var(--grid); stroke-width: 1; }
.svgchart .ylab, .svgchart .xlab { font-family: var(--mono); font-size: 10px; fill: var(--ink-faint); }
.svgchart .dlab { font-family: var(--mono); font-size: 11px; font-weight: 600; fill: var(--ink); }
.svgchart .zero { stroke: var(--ink-faint); stroke-width: 1; stroke-dasharray: 3 3; }

/* tooltip */
#tip { position: fixed; z-index: 200; pointer-events: none; background: #1d1311; color: #f9f3ea; font-family: var(--mono); font-size: 11px; letter-spacing: 0.02em; padding: 7px 10px; border-radius: 8px; box-shadow: 0 10px 30px -10px rgba(0, 0, 0, 0.6); opacity: 0; transform: translate(-50%, -140%); transition: opacity 0.1s; white-space: nowrap; }
.hint { cursor: default; }

/* big free-catch banner */
.freecatch { position: relative; overflow: hidden; background: radial-gradient(120% 140% at 82% -10%, #2c2220 0%, #1d1311 45%, #141110 100%); color: #f9f3ea; border-radius: 22px; padding: clamp(28px, 5vw, 52px); }
.freecatch .mono { color: var(--accent); }
.freecatch h3 { margin: 14px 0 0; font-size: clamp(22px, 3.4vw, 38px); line-height: 1.12; letter-spacing: -0.02em; font-weight: 800; max-width: 20ch; }
.freecatch h3 .a { color: var(--accent); }
.freecatch p { margin: 16px 0 0; font-size: clamp(14px, 1.6vw, 17px); line-height: 1.55; color: #c9c1b6; max-width: 60ch; }
.freecatch .row { margin-top: 24px; display: flex; flex-wrap: wrap; gap: 10px; }
.freecatch .pill { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.06em; color: #f9f3ea; background: rgba(249, 243, 234, 0.06); border: 1px solid rgba(249, 243, 234, 0.16); border-radius: 999px; padding: 8px 14px; }
.freecatch .pill b { color: var(--accent); }

/* callout */
.callout { background: radial-gradient(120% 140% at 82% -10%, #2c2220 0%, #1d1311 45%, #141110 100%); color: #f9f3ea; border-radius: 20px; padding: clamp(26px, 4vw, 44px); }
.callout .mono { color: var(--accent); }
.callout p { margin: 12px 0 0; font-size: clamp(16px, 2vw, 22px); line-height: 1.4; font-weight: 600; letter-spacing: -0.01em; max-width: 52ch; }

footer { border-top: 1px solid var(--line); padding: 38px 0 56px; color: var(--ink-faint); }
footer .fnav { display: flex; flex-wrap: wrap; gap: 18px; margin-bottom: 14px; }
footer .fnav a { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-soft); text-decoration: none; }
footer .fnav a:hover { color: var(--accent); }
footer .disc { font-size: 11.5px; max-width: 78ch; margin-top: 12px; line-height: 1.55; }

/* mobile burger menu */
.burger { display: none; width: 40px; height: 40px; align-items: center; justify-content: center; padding: 0; background: transparent; border: 1px solid var(--line); border-radius: 10px; color: var(--ink); cursor: pointer; }
.burger:hover { border-color: var(--accent); color: var(--accent); }

@media (max-width: 760px) {
  .head { padding: 11px 0; }
  .burger { display: inline-flex; }
  .nav { display: none; position: absolute; top: 100%; left: 0; right: 0; flex-direction: column; gap: 0; align-items: stretch; background: var(--paper); border-bottom: 1px solid var(--line); box-shadow: 0 24px 40px -22px rgba(22, 19, 18, 0.35); padding: 6px clamp(18px, 5vw, 40px) 16px; }
  header.open .nav { display: flex; }
  .nav a { width: 100%; padding: 13px 2px; border-bottom: 1px solid var(--line-soft); font-size: 12px; }
  .nav a:last-child { border-bottom: none; }
  .nav a[href="/deal.html"] { text-align: center; border: 1px solid rgba(200, 100, 42, 0.55); border-radius: 10px; padding: 12px 0; margin-top: 10px; }
  .nav a[href="/deal.html"].active { background: var(--accent); color: #fff; }

  /* centre the content column on mobile */
  .hero { text-align: center; }
  .hero .eyebrow { justify-content: center; }
  .hero h1, .hero .sub { margin-left: auto; margin-right: auto; }
  .hero .cta-row { justify-content: center; }
  .wrap > .kicker { justify-content: center; }
  .wrap > h2.t { text-align: center; }
  .wrap > .lead { text-align: center; margin-left: auto; margin-right: auto; }
  .freecatch, .callout { text-align: center; }
  .freecatch h3, .freecatch p, .callout p { margin-left: auto; margin-right: auto; }
  .freecatch .row { justify-content: center; }
}

@media (max-width: 640px) {
  section.s { padding: 40px 0; }
  .hero { padding: 40px 0 22px; }
  .hero .sub { font-size: 15px; }
  .cta-row { gap: 10px; }
  .btn { padding: 12px 16px; font-size: 11.5px; }
  .card { padding: 18px 15px; }
  .stat { padding: 14px 15px; }
  .chart-h { margin-bottom: 12px; }
  .cols { gap: 5px; padding-top: 8px; }
  .col-total { font-size: 9.5px; margin-bottom: 5px; }
  .col-total .cs { font-size: 8px; }
  .col-x { font-size: 9px; margin-top: 7px; }
  .bar-stack { max-width: 44px; }
  .hbar { grid-template-columns: 60px 1fr auto; gap: 8px; }
  .hbar .lab { font-size: 9.5px; }
  .flow .arrow { transform: rotate(90deg); }
  .svgchart .ylab, .svgchart .xlab { font-size: 13px; }
  .svgchart .dlab { font-size: 14px; }
  table.d { min-width: 300px; font-size: 12px; }
  table.d th, table.d td { padding: 7px 8px; }
  .freecatch, .callout { padding: 24px 20px; }
}

/* ===== access gate ===== */
@keyframes drift { from { background-position: 0 0, 0 0; } to { background-position: 64px 64px, 64px 64px; } }
@keyframes glow { 0%,100% { opacity:.5; transform:translate(-50%,-50%) scale(1); } 50% { opacity:.8; transform:translate(-50%,-50%) scale(1.12); } }
@keyframes gblink { 0%,100% { opacity:1; } 50% { opacity:.25; } }
@keyframes grise { from { opacity:0; transform:translateY(14px); } to { opacity:1; transform:translateY(0); } }
@keyframes gshake { 10%,90%{transform:translateX(-2px);} 20%,80%{transform:translateX(4px);} 30%,50%,70%{transform:translateX(-7px);} 40%,60%{transform:translateX(7px);} }
#gate { position:fixed; inset:0; z-index:1000; overflow:hidden; background:radial-gradient(125% 120% at 82% -8%,#fff 0%,#f7f3ec 46%,#f0eae0 100%); }
#gate.hidden { display:none; }
#gate .amb { position:absolute; inset:0; background-image:linear-gradient(rgba(22,19,18,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(22,19,18,.05) 1px,transparent 1px); background-size:64px 64px; -webkit-mask-image:radial-gradient(circle at 50% 40%,#000 0%,transparent 75%); mask-image:radial-gradient(circle at 50% 40%,#000 0%,transparent 75%); animation:drift 28s linear infinite; }
#gate canvas { position:absolute; inset:0; width:100%; height:100%; }
#gate .orb { position:absolute; border-radius:50%; filter:blur(26px); }
#gate .orb.a { top:8%; left:80%; width:520px; height:520px; background:radial-gradient(circle,rgba(200,100,42,.12),transparent 65%); animation:glow 9s ease-in-out infinite; }
#gate .orb.b { top:72%; left:10%; width:440px; height:440px; background:radial-gradient(circle,rgba(200,100,42,.08),transparent 65%); animation:glow 12s ease-in-out infinite; }
#gate .center { position:relative; z-index:10; height:100%; display:flex; align-items:center; justify-content:center; padding:clamp(16px,5vw,24px); }
#gate .cardwrap { width:100%; max-width:382px; display:flex; flex-direction:column; align-items:center; gap:clamp(18px,5vw,24px); animation:grise .6s ease both; }
#gate .lockup { display:flex; flex-direction:column; align-items:center; gap:12px; }
#gate .lockup .wm { font-size:20px; font-weight:600; letter-spacing:.42em; padding-left:.42em; color:var(--ink); }
#gate .lockup .wm b { color:var(--accent); font-weight:600; }
#gate .lockup .ss { font-family:var(--mono); font-size:10px; letter-spacing:.24em; padding-left:.24em; color:var(--ink-faint); text-transform:uppercase; }
#gate .panel { width:100%; border:1px solid var(--line); background:rgba(255,255,255,.62); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border-radius:16px; padding:clamp(22px,6vw,28px) clamp(18px,5vw,26px) clamp(24px,6vw,30px); display:flex; flex-direction:column; align-items:center; gap:20px; box-shadow:0 30px 70px -34px rgba(22,19,18,.3); }
#gate .sar { display:flex; align-items:center; gap:8px; font-family:var(--mono); font-size:10.5px; letter-spacing:.22em; color:var(--accent); }
#gate .sar i { width:6px; height:6px; border-radius:50%; background:var(--accent); animation:gblink 1.6s infinite; display:inline-block; }
#gate .prompt { text-align:center; }
#gate .prompt .h { font-size:16px; font-weight:600; color:var(--ink); }
#gate .prompt .p { font-size:12px; color:var(--ink-faint); margin-top:5px; font-family:var(--mono); }
#gate .dots { display:flex; gap:14px; }
#gate .dots.err { animation:gshake .5s cubic-bezier(.36,.07,.19,.97); }
#gate .dot { width:14px; height:14px; border-radius:50%; border:1.5px solid rgba(22,19,18,.22); }
#gate .dot.on { background:var(--accent); border-color:var(--accent); box-shadow:0 0 10px rgba(200,100,42,.55); }
#gate .errmsg { font-family:var(--mono); font-size:11px; letter-spacing:.12em; color:var(--accent); min-height:14px; }
#gate .keys { display:grid; grid-template-columns:repeat(3,1fr); gap:11px; width:100%; }
#gate .key { aspect-ratio:1.45; border:1px solid var(--line); background:rgba(22,19,18,.025); color:var(--ink); font-family:var(--mono); font-size:22px; font-weight:500; border-radius:11px; cursor:pointer; transition:all .14s; }
#gate .key:hover { background:rgba(200,100,42,.14); border-color:rgba(200,100,42,.55); color:var(--accent); }
#gate .key:active { transform:scale(.95); }
#gate .key.ghost { background:transparent; color:var(--ink-faint); border-color:var(--line-soft); font-size:12px; letter-spacing:.1em; }
#gate .foot { font-family:var(--mono); font-size:9.5px; letter-spacing:.18em; color:rgba(22,19,18,.4); text-align:center; }
#gate .dc { width:100%; display:none; flex-direction:column; gap:20px; animation:grise .4s ease both; }
#gate .dc .dch { display:flex; align-items:center; gap:12px; font-family:var(--mono); font-size:13px; letter-spacing:.2em; color:var(--accent); }
#gate .dc .lines { font-family:var(--mono); font-size:12px; line-height:2.1; color:var(--ink-soft); }
#gate .dc .lines .c { color:var(--accent); }
#gate .dc .bar { width:100%; height:3px; background:rgba(22,19,18,.08); border-radius:3px; overflow:hidden; }
#gate .dc .fill { height:100%; width:0; background:var(--accent); box-shadow:0 0 12px rgba(200,100,42,.6); transition:width .12s linear; }
#gate .dc .pf { font-family:var(--mono); font-size:10px; letter-spacing:.16em; color:var(--ink-faint); display:flex; justify-content:space-between; }
@media (prefers-reduced-motion: reduce) { #gate *, #gate .amb { animation:none !important; } }
