/* ============================================================
   realbacktesting — "Audited Command Deck"
   Slate Terminal · calm-blue accent rationed to action ·
   Geist / Geist Mono · proof, not pitch.
   ============================================================ */

:root{
  /* base — near-black slate, layered elevations */
  --bg:        #0A0B0D;
  --bg-1:      #0D0F12;
  --bg-2:      #111419;
  --bg-3:      #161A20;
  --line:      rgba(255,255,255,.07);
  --line-2:    rgba(255,255,255,.11);
  --line-strong: rgba(255,255,255,.16);

  /* ink */
  --ink:       #E7E9EC;
  --ink-2:     #A4ABB4;
  --ink-3:     #8A929B;   /* WCAG-AA: ≥4.99:1 on every surface up to --bg-3 (was #6C747E, failed) */
  --ink-4:     #5C636D;   /* decorative only (separators, strike, dim glyphs) — never body text */

  /* the one accent — calm blue, rationed */
  --accent:    #5B8DEF;
  --accent-hi: #7BA6F5;
  --accent-dk: #3E6CD0;
  --accent-wash: rgba(91,141,239,.10);
  --accent-line: rgba(91,141,239,.32);

  /* desaturated, semantic — reserved for signed numbers (with ▲▼) and verified pass/proven
     state (always with a text label). NEVER purely decorative; red is signed-negatives only. */
  --pos:       #51B07E;
  --neg:       #D17268;

  --r:   14px;     /* card radius */
  --r-sm: 9px;
  --maxw: 1200px;
  --pad:  clamp(20px, 5vw, 64px);

  --mono: "Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --sans: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:
    radial-gradient(1100px 620px at 78% -8%, rgba(91,141,239,.07), transparent 60%),
    radial-gradient(900px 700px at -6% 8%, rgba(91,141,239,.045), transparent 55%),
    var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* film grain for atmosphere */
.grain{
  position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

/* numbers everywhere are mono + tabular */
.mono, .num, dd, .metric b, .price, code, .code{
  font-family:var(--mono);
  font-variant-numeric:tabular-nums;
  font-feature-settings:"tnum" 1, "ss01" 1;
}

a{ color:inherit; text-decoration:none; }
h1,h2,h3{ margin:0; font-weight:600; letter-spacing:-.02em; line-height:1.04; }
section{ position:relative; z-index:2; }
html{ scroll-padding-top:78px; }   /* anchor jumps clear the sticky nav */
/* sub-page "back to home" crumb */
.subnav-back{ max-width:var(--maxw); margin:0 auto; padding:clamp(14px,2vw,20px) var(--pad) 0; }
.subnav-back a{ font-family:var(--mono); font-size:.78rem; letter-spacing:.02em; color:var(--ink-3); text-decoration:none; transition:color .18s ease; }
.subnav-back a:hover{ color:var(--accent-hi); }
/* a11y: visually-hidden (SEO h1 + labels) + keyboard skip link */
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.skip-link{ position:absolute; left:10px; top:-48px; z-index:200; background:linear-gradient(180deg,var(--accent-hi),var(--accent)); color:#06122b; font-weight:600; padding:.6em 1em; border-radius:8px; text-decoration:none; transition:top .16s ease; }
.skip-link:focus{ top:10px; }

/* ── shared bits ─────────────────────────────────────────── */
.btn{
  --bd:var(--line-2);
  display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--sans); font-size:.92rem; font-weight:500; letter-spacing:-.01em;
  padding:.72em 1.15em; border-radius:var(--r-sm);
  border:1px solid var(--bd); color:var(--ink);
  background:var(--bg-2);
  cursor:pointer; transition:transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
}
.btn:hover{ transform:translateY(-1px); border-color:var(--line-strong); }
.btn-accent{
  background:linear-gradient(180deg, var(--accent-hi), var(--accent));
  border-color:var(--accent-dk); color:#06122b; font-weight:600;
  box-shadow:0 1px 0 rgba(255,255,255,.18) inset, 0 8px 26px -10px rgba(91,141,239,.65);
}
.btn-accent:hover{ box-shadow:0 1px 0 rgba(255,255,255,.22) inset, 0 12px 34px -10px rgba(91,141,239,.8); }
.btn-ghost{ background:transparent; color:var(--ink-2); }
.btn-ghost:hover{ color:var(--ink); }
.btn .arr{ transition:transform .18s ease; }
.btn-ghost:hover .arr{ transform:translateX(3px); }

.panel{
  background:linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border:1px solid var(--line); border-radius:var(--r);
  box-shadow:0 1px 0 rgba(255,255,255,.03) inset, 0 24px 60px -40px rgba(0,0,0,.9);
}
.pending{ color:var(--accent-hi); font-weight:500; }
.muted{ color:var(--ink-3); font-weight:400; }
.sec-kicker{
  font-family:var(--mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--accent-hi); display:inline-flex; align-items:center; gap:.6em;
}
.sec-kicker::before{ content:""; width:18px; height:1px; background:var(--accent-line); display:inline-block; }
.sec-head{ max-width:760px; margin:0 0 clamp(28px,4vw,52px); }
.sec-head h2{ font-size:clamp(1.7rem, 3.4vw, 2.65rem); margin:.5em 0 .35em; }
.sec-lede{ color:var(--ink-2); font-size:1.04rem; max-width:62ch; }
.fineprint{ color:var(--ink-3); font-size:.82rem; margin-top:26px; max-width:80ch; }
.fineprint code, code{ color:var(--ink-2); background:var(--bg-3); padding:.08em .4em; border-radius:5px; font-size:.86em; }

/* ───────────── cTRADER band — intermediary + free 24/7 cloud (the hook) ───────────── */
.ctband{ max-width:var(--maxw); margin:0 auto; padding:clamp(8px,2vw,18px) var(--pad) clamp(28px,4vw,44px); }
.ctband-inner{
  position:relative; overflow:hidden;
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(24px,3.2vw,46px);
  padding:clamp(26px,3.4vw,46px);
  border-color:var(--accent-line);
}
.ctband-glow{
  position:absolute; inset:auto -10% -55% auto; width:60%; height:120%;
  background:radial-gradient(closest-side, rgba(91,141,239,.16), transparent 70%);
  pointer-events:none; z-index:0;
}
.ctband-copy, .cloud-feat{ position:relative; z-index:1; min-width:0; }

/* "Runs on cTrader" lockup */
.ct-lockup{ display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--mono); font-size:.74rem; letter-spacing:.13em; text-transform:uppercase;
  color:var(--ink-3); padding:.42em .7em .42em .5em; border:1px solid var(--line-2); border-radius:999px;
  background:var(--bg-2); }
.ct-lockup .ct-word b{ color:var(--ink); font-weight:600; }
.ct-mark{ display:block; width:1.55em; height:auto; }
.ctband h2{ font-size:clamp(1.7rem,3.3vw,2.55rem); letter-spacing:-.025em; margin:.66em 0 .42em; line-height:1.08; }
.ctband .sec-lede{ max-width:54ch; }
.ctband-trust{ list-style:none; margin:1.4em 0 0; padding:0; display:grid; gap:10px; }
.ctband-trust li{ display:flex; align-items:flex-start; gap:.7em;
  background:var(--bg-1); border:1px solid var(--line); border-radius:var(--r-sm); padding:.78em .9em;
  color:var(--ink-2); font-size:.92rem; line-height:1.5; }
.ctband-trust li > span:last-child{ flex:1 1 auto; min-width:0; }   /* text wraps as one block, not per-word flex items */
.ctband-trust b{ color:var(--ink); font-weight:600; }
.ctt-i{ flex:none; width:20px; height:20px; color:var(--accent-hi); margin-top:1px; }
.ctt-i svg{ width:100%; height:100%; display:block; }
.ctband-cta{ margin-top:1.6em; display:flex; flex-direction:column; gap:.7em; align-items:flex-start; }
.btn-lg{ font-size:1rem; padding:.85em 1.35em; }
.ct-mark-btn{ width:1.1em; }
.ctband-cta-note{ color:var(--ink-3); font-size:.8rem; max-width:46ch; }

/* free-cloud feature card */
.cloud-feat{
  background:linear-gradient(180deg, rgba(91,141,239,.07), rgba(91,141,239,.02));
  border:1px solid var(--accent-line); border-radius:var(--r);
  padding:clamp(20px,2.4vw,30px);
  box-shadow:0 1px 0 rgba(255,255,255,.04) inset;
}
.cloud-badge{ display:inline-flex; align-items:center; gap:.55em;
  font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--accent-hi); border:1px solid var(--accent-line); border-radius:999px;
  padding:.4em .8em; background:var(--accent-wash); }
.cloud-dot{ width:7px; height:7px; border-radius:50%; background:var(--accent);
  box-shadow:0 0 0 0 rgba(91,141,239,.55); animation:cloudPulse 2.4s ease-out infinite; }
@keyframes cloudPulse{ 0%{ box-shadow:0 0 0 0 rgba(91,141,239,.5);} 70%{ box-shadow:0 0 0 7px rgba(91,141,239,0);} 100%{ box-shadow:0 0 0 0 rgba(91,141,239,0);} }
.cloud-feat-head h3{ font-size:clamp(1.25rem,2vw,1.55rem); letter-spacing:-.02em; margin:.7em 0 .35em; }
.cloud-feat-head p{ color:var(--ink-2); font-size:.96rem; line-height:1.55; max-width:46ch; }
.cloud-steps{ list-style:none; margin:1.3em 0 0; padding:0; display:grid; gap:12px; counter-reset:cs; }
.cloud-steps li{ display:flex; align-items:flex-start; gap:.8em;
  background:var(--bg-1); border:1px solid var(--line); border-radius:var(--r-sm); padding:.85em .95em;
  color:var(--ink-2); font-size:.92rem; line-height:1.5; }
.cloud-steps b{ color:var(--ink); font-weight:600; }
.cs-n{ flex:none; width:26px; height:26px; border-radius:50%; display:grid; place-items:center;
  font-family:var(--mono); font-size:.84rem; font-weight:600; color:var(--accent-hi);
  background:var(--accent-wash); border:1px solid var(--accent-line); }
.cs-done{ background:linear-gradient(180deg, rgba(81,176,126,.10), rgba(81,176,126,.03)); border-color:rgba(81,176,126,.34); }
.cs-done .cs-n{ color:#8fd6af; background:rgba(81,176,126,.14); border-color:rgba(81,176,126,.40); }
.cloud-foot{ margin:1.15em 0 0; color:var(--ink-3); font-size:.86rem; line-height:1.55; }
.cloud-foot b{ color:var(--ink-2); }
@media (max-width:900px){
  .ctband-inner{ grid-template-columns:1fr; }
  .ctband-glow{ inset:auto -30% -70% auto; width:90%; }
}

/* brand — lockup: RB. tile + real (bold) backtesting (dim) . (accent) */
.brand{ display:inline-flex; align-items:center; gap:.55em; }
.brand-rb{ display:inline-flex; align-items:flex-end; justify-content:center; gap:2px; width:30px; height:30px;
  border-radius:8px; background:#0E1014; border:1px solid var(--line-2); flex-shrink:0; transition:border-color .2s ease; }
.brand-rb b{ font-family:var(--mono); font-weight:700; font-size:13.5px; line-height:1; color:var(--ink); letter-spacing:-.04em; margin-bottom:5.5px; }
.brand-rb i{ width:4px; height:4px; border-radius:1px; background:var(--accent); margin-bottom:5.5px; }
.brand:hover .brand-rb{ border-color:var(--accent-line); }
.brand-name{ font-family:var(--sans); font-weight:500; letter-spacing:-.03em; font-size:1.08rem; color:var(--ink-2); transition:color .2s ease; }
.brand-name b{ font-weight:700; color:var(--ink); }
.brand-name .dot{ display:inline-block; width:.3em; height:.3em; border-radius:.075em; background:var(--accent); margin-left:.16em; vertical-align:baseline; }
.brand:hover .brand-name{ color:var(--ink); }
.foot .brand-rb{ width:34px; height:34px; border-radius:9px; }
.foot .brand-rb b{ font-size:15px; margin-bottom:6px; }
.foot .brand-rb i{ width:4.5px; height:4.5px; border-radius:1.1px; margin-bottom:7px; }
.foot .brand-name{ font-size:1.1rem; }

/* ── NAV ─────────────────────────────────────────────────── */
.nav{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; gap:24px;
  padding:14px var(--pad);
  background:rgba(10,11,13,.6); backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid transparent; transition:border-color .3s ease, background .3s ease;
}
.nav.scrolled{ border-color:var(--line); background:rgba(10,11,13,.82); }
.nav-links{ display:flex; gap:26px; margin-left:auto; }
.nav-links a{ color:var(--ink-3); font-size:.9rem; transition:color .16s ease; }
.nav-links a:hover{ color:var(--ink); }
.nav-cta{ padding:.55em .95em; font-size:.86rem; }
.nav-burger{ display:none; } .nav-menu-cta{ display:none; }
/* ── mobile: hamburger → elegant slide-down section menu ── */
@media (max-width:860px){
  .nav-burger{ display:inline-flex; flex-direction:column; justify-content:center; gap:5px; width:42px; height:38px;
    margin-left:auto; background:transparent; border:1px solid var(--line-2); border-radius:9px; cursor:pointer; padding:0 9px; }
  .nav-burger span{ display:block; height:2px; width:100%; background:var(--ink-2); border-radius:2px;
    transition:transform .25s ease, opacity .2s ease; }
  .nav.menu-open .nav-burger{ border-color:var(--accent-line); }
  .nav.menu-open .nav-burger span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .nav.menu-open .nav-burger span:nth-child(2){ opacity:0; }
  .nav.menu-open .nav-burger span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
  .nav-links{ display:flex; flex-direction:column; gap:0; position:absolute; top:100%; left:0; right:0; margin:0;
    background:rgba(13,15,18,.98); backdrop-filter:blur(16px) saturate(140%); border-bottom:1px solid var(--line);
    padding:0 var(--pad); max-height:0; overflow:hidden; opacity:0; pointer-events:none;
    transition:max-height .32s cubic-bezier(.4,0,.2,1), opacity .22s ease, padding .32s ease; }
  .nav.menu-open .nav-links{ max-height:82vh; opacity:1; padding:4px var(--pad) 18px; pointer-events:auto; }
  .nav-links a{ padding:15px 2px; font-size:1.02rem; color:var(--ink-2); border-bottom:1px solid var(--line); }
  .nav-links a:active{ color:var(--ink); }
  .nav-cta{ display:none; }
  .nav-links a.nav-menu-cta{ display:inline-flex; justify-content:center; align-items:center; margin-top:14px;
    padding:.85em; font-size:.96rem; border-bottom:0; color:#06122b; }
}

/* ── HERO ────────────────────────────────────────────────── */
.hero{
  max-width:var(--maxw); margin:0 auto;
  padding:clamp(40px,6vw,84px) var(--pad) clamp(40px,6vw,72px);
  display:flex; flex-direction:column; gap:clamp(20px,2.6vw,30px);
}
.hero-grid{ display:grid; grid-template-columns:1.02fr 1.18fr; gap:clamp(32px,5vw,64px); align-items:center; }
/* horizontal claim bar below the hero (funding stats + the buy conditions) */
.hero-bar{ display:flex; justify-content:space-between; align-items:center; gap:18px 30px; flex-wrap:wrap; padding:18px clamp(18px,3vw,28px); }
.hero-bar .hero-stats{ margin:0; padding:0; border-top:none; gap:18px 30px; }
.hero-conds{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.hcond{ display:inline-flex; align-items:center; gap:7px; font-family:var(--mono); font-size:.76rem; color:var(--ink-2); white-space:nowrap; }
.hcond i{ color:var(--pos); font-style:normal; font-weight:700; }
.hcond-buy{ padding:.5em 1.25em; white-space:nowrap; }
#ledger.hsys-row{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
@media(max-width:760px){ #ledger.hsys-row{ grid-template-columns:1fr; } .hero-bar{ flex-direction:column; align-items:stretch; } }
.eyebrow{ display:inline-flex; align-items:center; gap:.6em; font-family:var(--mono);
  font-size:.78rem; color:var(--ink-2); letter-spacing:.02em; margin-bottom:22px; }
.eyebrow .dot{ width:7px; height:7px; border-radius:50%; background:var(--accent);
  box-shadow:0 0 0 4px var(--accent-wash); animation:pulse 3.2s ease-in-out infinite; }
@keyframes pulse{ 50%{ box-shadow:0 0 0 7px rgba(91,141,239,0); } }
.hero h1{ font-size:clamp(2.7rem, 6.4vw, 4.7rem); font-weight:600; letter-spacing:-.035em; }
.lede{ color:var(--ink-2); font-size:1.12rem; max-width:46ch; margin:1.3em 0 1.9em; }
.lede em{ color:var(--ink); font-style:normal; border-bottom:1px solid var(--accent-line); }
.hero-actions{ display:flex; gap:12px; flex-wrap:wrap; }
.hero-stats{ display:flex; flex-wrap:wrap; gap:26px 30px; margin:40px 0 0; padding-top:26px; border-top:1px solid var(--line); }
.hero-stats div{ display:flex; flex-direction:column; gap:3px; }
.hero-stats dt{ font-size:.74rem; color:var(--ink-3); letter-spacing:.04em; }
.hero-stats dd{ margin:0; font-size:1.5rem; font-weight:500; color:var(--ink); }
.hero-stats .u{ font-size:.78rem; color:var(--ink-3); }
.hero-stats .hs-sub{ font-family:var(--mono); font-size:.64rem; color:var(--ink-4); letter-spacing:.02em; }

.hero-panel{ display:flex; flex-direction:column; gap:14px; }
.chart-card{ padding:18px 18px 14px; }
.chart-head{ display:flex; justify-content:space-between; align-items:flex-start; gap:14px; margin-bottom:8px; }
.chart-title{ font-size:.92rem; font-weight:500; }
.chart-sub{ font-family:var(--mono); font-size:.78rem; color:var(--ink-3); margin-top:3px; word-break:break-word; }
.hero-copy, .hero-panel{ min-width:0; }
.chart-head > div:first-child{ min-width:0; }
.seg{ display:inline-flex; background:var(--bg-3); border:1px solid var(--line); border-radius:8px; padding:3px; gap:2px; }
.seg button{ font-family:var(--mono); font-size:.72rem; color:var(--ink-3); background:transparent;
  border:0; padding:.34em .6em; border-radius:6px; cursor:pointer; transition:.16s; letter-spacing:.01em; }
.seg button:hover{ color:var(--ink-2); }
.seg button[aria-pressed="true"]{ background:var(--accent-wash); color:var(--accent-hi); box-shadow:0 0 0 1px var(--accent-line) inset; }
/* account-size selector */
.chart-controls{ display:flex; align-items:center; gap:10px; margin:10px 0 6px; flex-wrap:wrap; }
.chart-controls-l{ font-family:var(--mono); font-size:.68rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); }
.seg-sm{ padding:2px; }
.seg-sm button{ font-size:.7rem; padding:.3em .58em; }
.chart-controls-r{ margin-left:auto; }
body[data-engine="ctrader"] .lg-oos-item{ display:none; }
.eng-inline{ display:inline-flex; flex-wrap:wrap; align-items:center; gap:9px; margin-top:14px; font-family:var(--mono);
  font-size:.68rem; color:var(--ink-3); text-transform:uppercase; letter-spacing:.06em; }
.eng-inline-sep{ color:var(--line); font-weight:700; }
@media(max-width:560px){ .eng-inline-sep{ display:none; } }
.engine-switch-lg{ margin-top:16px; }
/* engines explainer */
.engines{ padding:clamp(40px,7vw,90px) var(--pad); max-width:var(--maxw); margin:0 auto; }
.eng-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:10px; }
@media(max-width:760px){ .eng-grid{ grid-template-columns:1fr; } }
.eng-card{ background:linear-gradient(180deg,var(--bg-2),var(--bg-1)); border:1px solid var(--line);
  border-radius:var(--r); padding:22px 22px 18px; }
.eng-card.eng-ctrader{ border-color:var(--accent-line); }
.eng-top{ display:flex; align-items:center; gap:10px; margin-bottom:4px; flex-wrap:wrap; }
.eng-top h3{ margin:0; font-size:1.18rem; font-weight:600; letter-spacing:-.02em; }
.eng-tag{ font-family:var(--mono); font-size:.6rem; letter-spacing:.08em; text-transform:uppercase;
  color:#06122b; background:linear-gradient(180deg,var(--accent-hi),var(--accent)); padding:.32em .6em; border-radius:6px; font-weight:600; }
.eng-tag.alt{ color:var(--ink-2); background:var(--bg-3); border:1px solid var(--line-2); }
.eng-what{ color:var(--ink-2); font-size:.92rem; margin:.3em 0 14px; }
.eng-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:9px; }
.eng-list li{ position:relative; padding-left:24px; font-size:.86rem; color:var(--ink-2); line-height:1.5; }
.eng-list li::before{ position:absolute; left:0; top:0; font-family:var(--mono); font-weight:700; }
.eng-list li.ok::before{ content:"✓"; color:var(--pos); }
.eng-list li.lim::before{ content:"!"; color:var(--neg); }
.eng-list li b{ color:var(--ink); }
.eng-foot{ margin-top:16px; padding-top:14px; border-top:1px solid var(--line); font-size:.86rem; color:var(--ink-3); }
.eng-foot b{ color:var(--ink); }
.metrics-basis b.rce{ color:var(--accent-hi); }
/* "why it's execution" proof callout */
.eng-proof{ margin-top:18px; padding:16px 18px; border:1px solid var(--accent-line); background:var(--accent-wash); border-radius:var(--r-sm); }
.eng-proof-k{ font-family:var(--mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--accent-hi); display:block; margin-bottom:6px; }
.eng-proof p{ margin:0; color:var(--ink-2); font-size:.9rem; line-height:1.6; }
.eng-proof b{ color:var(--ink); }
/* engine comparison table */
.ec-wrap{ margin-top:20px; overflow-x:auto; }
.ec-table{ width:100%; border-collapse:collapse; font-size:.86rem; min-width:580px; }
.ec-table th{ font-family:var(--mono); font-size:.63rem; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink-3); font-weight:500; text-align:left; padding:9px 12px; border-bottom:1px solid var(--line-2); }
.ec-table th.num, .ec-table td.num{ text-align:right; font-variant-numeric:tabular-nums; }
.ec-table td{ padding:8px 12px; }
.ec-table .num{ font-family:var(--mono); }
.ec-name{ font-weight:600; color:var(--ink); }
.ec-eng{ font-family:var(--mono); font-size:.78rem; color:var(--ink-2); }
.ec-r td{ border-top:1px solid var(--line); }
.ec-r .ec-eng{ color:var(--accent-hi); }
.ec-c td, .ec-c .num{ color:var(--ink-3); }
.soon{ color:var(--accent-hi); font-family:var(--mono); font-size:.76rem; }
.ec-note{ margin:12px 2px 0; color:var(--ink-3); font-size:.8rem; line-height:1.55; max-width:80ch; }
.chart-wrap{ position:relative; }
#equity{ width:100%; height:auto; display:block; cursor:crosshair; touch-action:none; }
/* hover tooltip */
.chart-tip{ position:absolute; pointer-events:none; opacity:0; transition:opacity .12s ease; z-index:5;
  background:var(--bg-3); border:1px solid var(--line-2); border-radius:9px; padding:8px 11px; min-width:106px;
  box-shadow:0 10px 28px -12px rgba(0,0,0,.85); }
.tip-money{ font-family:var(--mono); font-variant-numeric:tabular-nums; font-weight:600; font-size:1.02rem; color:var(--ink); line-height:1.1; }
.tip-row{ display:flex; justify-content:space-between; align-items:baseline; gap:12px; margin-top:3px; font-size:.72rem; color:var(--ink-3); }
.tip-row b{ font-family:var(--mono); font-weight:500; }
.tip-row b.pos{ color:var(--pos); } .tip-row b.neg{ color:var(--neg); }
.tip-oos{ font-family:var(--mono); font-size:.64rem; color:var(--accent-hi); margin-top:4px; letter-spacing:.02em; }
.chart-legend{ display:flex; gap:18px; margin-top:6px; font-size:.74rem; color:var(--ink-3); flex-wrap:wrap; }
.chart-legend .lg{ display:inline-flex; align-items:center; gap:7px; }
.lg-line{ width:16px; height:2px; background:var(--accent); display:inline-block; border-radius:2px; }
.lg-oos{ width:16px; height:9px; background:repeating-linear-gradient(135deg, var(--accent-wash) 0 3px, transparent 3px 6px);
  border:1px solid var(--accent-line); display:inline-block; border-radius:2px; }
.chart-foot{ font-size:.76rem; color:var(--ink-3); margin-top:12px; padding-top:11px; border-top:1px dashed var(--line-2); }

/* Proven/Pending ledger */
.ledger{ padding:16px 18px; }
.ledger-head{ font-family:var(--mono); font-size:.78rem; letter-spacing:.06em; color:var(--ink-2);
  text-transform:uppercase; margin-bottom:10px; }
.ledger-head .vs{ color:var(--ink-3); }
.ledger ul, #ledger{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; }
#ledger li{ display:flex; align-items:center; gap:12px; padding:11px 0; border-top:1px solid var(--line); }
#ledger li:first-child{ border-top:0; }
.lev-name{ font-size:.9rem; flex:1; }
.lev-name small{ display:block; color:var(--ink-3); font-size:.76rem; font-family:var(--mono); }
.chip{ font-family:var(--mono); font-size:.7rem; letter-spacing:.04em; padding:.28em .6em; border-radius:6px;
  border:1px solid; white-space:nowrap; }
.chip.proven{ color:var(--pos); border-color:rgba(81,176,126,.35); background:rgba(81,176,126,.08); }
.chip.pending{ color:var(--accent-hi); border-color:var(--accent-line); background:var(--accent-wash); }
.lev-val{ font-family:var(--mono); font-size:.92rem; min-width:64px; text-align:right; }

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

/* ── CONTRAST ────────────────────────────────────────────── */
.contrast{ max-width:var(--maxw); margin:0 auto; padding:clamp(48px,7vw,96px) var(--pad); }
.contrast-title{ font-size:clamp(1.6rem,3.2vw,2.4rem); }
.contrast-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); border:1px solid var(--line);
  border-radius:var(--r); overflow:hidden; }
.ccol{ display:flex; flex-direction:column; gap:1px; background:var(--line); }
.cell{ padding:18px 20px; background:var(--bg-1); display:flex; align-items:flex-start; gap:12px; font-size:.97rem; flex:1; }
.cell.bad{ background:linear-gradient(180deg, #0c0d0f, var(--bg)); color:var(--ink-3); }
.cell.good{ background:var(--bg-2); color:var(--ink); }
.cell .mk{ font-family:var(--mono); font-size:.95rem; line-height:1.3; margin-top:1px; }
.cell.bad .mk{ color:var(--ink-3); }   /* neutral — red reserved for signed negatives */
.cell.good .mk{ color:var(--pos); }
.cell.bad s{ text-decoration:none; }
.chead{ font-family:var(--mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; padding:12px 20px; }
.chead.bad{ color:var(--ink-3); background:#0b0c0e; }
.chead.good{ color:var(--accent-hi); background:var(--bg-2); }
@media (max-width:680px){ .contrast-grid{ grid-template-columns:1fr; } .cell{ font-size:.9rem; } }

/* ── PRODUCTS / BENTO ────────────────────────────────────── */
.products{ max-width:var(--maxw); margin:0 auto; padding:clamp(40px,6vw,80px) var(--pad); }

/* tier comparison — badges side by side */
.compare{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:44px; align-items:stretch; }
.cmp{ position:relative; background:linear-gradient(180deg, var(--bg-2), var(--bg-1)); border:1px solid var(--line);
  border-radius:var(--r); padding:24px 20px 20px; display:flex; flex-direction:column; gap:15px;
  transition:transform .2s ease, border-color .2s ease; }
.cmp:hover{ transform:translateY(-4px); border-color:var(--line-strong); }
.cmp.feat{ border-color:var(--accent-line); background:linear-gradient(180deg, rgba(91,141,239,.08), var(--bg-1));
  box-shadow:0 22px 54px -28px rgba(91,141,239,.6); }
.cmp-ribbon{ position:absolute; top:0; right:18px; transform:translateY(-50%); font-family:var(--mono);
  font-size:.64rem; letter-spacing:.07em; text-transform:uppercase; color:#06122b; font-weight:600;
  background:linear-gradient(180deg, var(--accent-hi), var(--accent)); padding:.34em .72em; border-radius:6px;
  box-shadow:0 6px 18px -6px rgba(91,141,239,.7); }
.cmp-tier{ font-family:var(--mono); font-size:.68rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.cmp-name{ font-size:1.55rem; margin-top:3px; }
.cmp-ceil{ display:flex; flex-direction:column; gap:2px; padding:13px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.cmp-ceil-v{ font-family:var(--mono); font-size:2.1rem; font-weight:600; color:var(--accent-hi); line-height:1; font-variant-numeric:tabular-nums; }
.cmp-ceil-v small{ font-size:1rem; color:var(--ink-3); }
.cmp-ceil-l{ font-size:.69rem; color:var(--ink-3); letter-spacing:.02em; }
.cmp-price{ font-family:var(--mono); font-size:1.85rem; font-weight:600; color:var(--ink); display:flex; flex-direction:column; line-height:1.1; }
.cmp-price-l{ font-family:var(--sans); font-size:.7rem; font-weight:400; color:var(--ink-3); margin-top:2px; }
.cmp-stats{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; }
.cmp-stats li{ display:flex; justify-content:space-between; align-items:baseline; padding:7px 0; border-top:1px solid var(--line); font-size:.8rem; color:var(--ink-3); }
.cmp-stats li:first-child{ border-top:0; }
.cmp-stats b{ font-family:var(--mono); font-weight:500; color:var(--ink); font-size:.92rem; }
.cmp-badge{ font-family:var(--mono); font-size:.67rem; padding:.42em .6em; border-radius:7px; border:1px solid; text-align:center; }
.cmp-badge.prop{ color:var(--pos); border-color:rgba(81,176,126,.3); background:rgba(81,176,126,.07); }
.cmp-badge.warn{ color:var(--ink-2); border-color:var(--line-2); background:var(--bg-3); }
.cmp-cta{ justify-content:center; margin-top:auto; }
.cmp-trial{ text-align:center; font-family:var(--mono); font-size:.7rem; color:var(--ink-3); margin-top:9px; }
/* 4-up only when columns stay comfortable (≥1040px); 2-up below; 1-up on phones */
/* 3 products: go straight from 3-col to 1-col (a 2-col step would leave one card stranded) */
@media (max-width:880px){ .compare{ grid-template-columns:1fr; max-width:460px; margin-inline:auto; } .cmp:hover,.cmp.feat{ transform:none; } }

.detail-divider{ display:flex; align-items:center; gap:18px; margin:6px 0 28px; }
.detail-divider::before, .detail-divider::after{ content:""; height:1px; background:var(--line); flex:1; }
.detail-divider span{ font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); white-space:nowrap; }

.bento{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.card{ padding:24px; display:flex; flex-direction:column; gap:20px; position:relative; overflow:hidden;
  transition:transform .2s ease, border-color .2s ease; }
.card::after{ content:""; position:absolute; inset:0; border-radius:var(--r);
  box-shadow:0 0 0 1px transparent inset; transition:box-shadow .2s ease; pointer-events:none; }
.card:hover{ transform:translateY(-3px); }
.card:hover::after{ box-shadow:0 0 0 1px var(--accent-line) inset; }
.card.feat{ grid-column:span 2; }
.card-top{ display:flex; justify-content:space-between; align-items:flex-start; gap:14px; }
.card-id .fam{ font-family:var(--mono); font-size:.72rem; color:var(--ink-3); letter-spacing:.04em; }
.card-id h3{ font-size:1.5rem; margin-top:2px; }
.card-id .tag{ color:var(--ink-2); font-size:.92rem; margin-top:5px; max-width:34ch; min-height:2.7em; }
.ceil{ text-align:right; flex-shrink:0; }
.ceil .lab{ font-size:.68rem; color:var(--ink-3); letter-spacing:.05em; text-transform:uppercase; }
.ceil .val{ font-family:var(--mono); font-size:1.55rem; font-weight:600; color:var(--ink); line-height:1; margin-top:3px; }
.ceil .val .pct{ font-size:.9rem; color:var(--ink-3); }
.badge{ display:inline-flex; align-items:center; gap:.4em; font-family:var(--mono); font-size:.68rem;
  padding:.26em .55em; border-radius:6px; margin-top:8px; border:1px solid; letter-spacing:.02em; }
.badge.prop{ color:var(--pos); border-color:rgba(81,176,126,.3); background:rgba(81,176,126,.07); }
.badge.warn{ color:var(--ink-2); border-color:var(--line-2); background:var(--bg-3); }

.metrics{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line);
  border:1px solid var(--line); border-radius:10px; overflow:hidden; }
.metric{ background:var(--bg-1); padding:17px 18px; display:flex; flex-direction:column; gap:6px; min-height:74px; justify-content:center; }
.metric .k{ font-size:.68rem; color:var(--ink-3); letter-spacing:.03em; overflow-wrap:anywhere; }
.metric b{ font-weight:500; font-size:1.08rem; color:var(--ink); }
.metric .sub{ font-size:.66rem; color:var(--ink-3); font-family:var(--mono); }
.signed.pos{ color:var(--pos); } .signed.neg{ color:var(--neg); }
/* the 9th metric would orphan in a 4-col grid (3 empty cells) — span it full-width as a clean summary bar */
.metrics .metric:last-child{ grid-column:1 / -1; flex-direction:row; align-items:baseline; justify-content:space-between; gap:14px; }
.metrics .metric:last-child .k{ order:0; } .metrics .metric:last-child b{ order:1; }
.mp-pct{ color:var(--ink-3); font-weight:400; font-size:.82em; }   /* % positive months, muted, beside the +/- count */

.assets{ display:flex; flex-wrap:wrap; gap:6px; }
.assets span{ font-family:var(--mono); font-size:.7rem; color:var(--ink-2); background:var(--bg-3);
  border:1px solid var(--line); padding:.24em .5em; border-radius:6px; }
.card-foot{ margin-top:auto; display:flex; justify-content:space-between; align-items:center; gap:14px;
  padding-top:16px; border-top:1px solid var(--line); }
.price{ display:flex; align-items:baseline; gap:9px; }
.price .now{ font-size:1.5rem; font-weight:600; color:var(--ink); }
.price .was{ font-size:.95rem; color:var(--ink-4); text-decoration:line-through; }
.price .off{ font-family:var(--mono); font-size:.66rem; color:var(--accent-hi); border:1px solid var(--accent-line);
  background:var(--accent-wash); padding:.18em .42em; border-radius:5px; }
.price-cap{ font-size:.7rem; color:var(--ink-3); margin-top:3px; }
@media (max-width:760px){ .bento{ grid-template-columns:1fr; } .card.feat{ grid-column:span 1; }
  .metrics{ grid-template-columns:repeat(2,1fr); } }

/* ── FUNDING ─────────────────────────────────────────────── */
.funding{ max-width:var(--maxw); margin:0 auto; padding:clamp(40px,6vw,84px) var(--pad); }
.fund-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.fund{ padding:20px; display:flex; flex-direction:column; gap:16px; }
.fund h3{ margin:0; font-size:1.1rem; font-weight:600; display:flex; align-items:center; justify-content:space-between; }
.fund h3 .pr{ font-family:var(--mono); font-size:.74rem; color:var(--ink-3); }
.fund-big{ display:flex; flex-direction:column; gap:2px; }
.fund-big .v{ font-family:var(--mono); font-size:2.1rem; font-weight:600; color:var(--accent-hi); line-height:1; }
.fund-big .v small{ font-size:.95rem; color:var(--ink-3); font-weight:400; }
.fund-big .k{ font-size:.74rem; color:var(--ink-3); }
.range{ height:5px; border-radius:3px; background:var(--bg-3); position:relative; overflow:hidden; border:1px solid var(--line); }
.range i{ position:absolute; top:0; bottom:0; background:var(--accent-line); border-left:1px solid var(--accent); border-right:1px solid var(--accent); }
.range-cap{ display:flex; justify-content:space-between; font-family:var(--mono); font-size:.68rem; color:var(--ink-3); }
.fund-pay{ padding-top:14px; border-top:1px solid var(--line); display:flex; flex-direction:column; gap:7px; }
.payrow{ display:flex; justify-content:space-between; align-items:baseline; font-size:.82rem; color:var(--ink-2); }
.payrow b{ font-family:var(--mono); font-weight:500; color:var(--ink); font-size:.96rem; }
.payrow.big{ padding-top:8px; margin-top:2px; border-top:1px dashed var(--line); }
.payrow.big > span{ color:var(--ink); font-weight:500; }
.payrow.big b{ font-size:1.08rem; }
.assumptions{ margin-top:26px; border:1px solid var(--line); border-radius:var(--r); background:var(--bg-1); }
.assumptions summary{ cursor:pointer; padding:14px 18px; font-size:.88rem; color:var(--ink-2); list-style:none; }
.assumptions summary::-webkit-details-marker{ display:none; }
.assumptions summary::before{ content:"＋ "; color:var(--accent-hi); font-family:var(--mono); }
.assumptions[open] summary::before{ content:"－ "; }
.assumptions div{ padding:0 18px 18px; color:var(--ink-3); font-size:.84rem; line-height:1.6; }
.assumptions li{ margin:.3em 0; }
/* 3 products: 3-col straight to 1-col centred (a 2-col step strands one card) */
@media (max-width:820px){ .fund-grid{ grid-template-columns:1fr; max-width:460px; margin-inline:auto; } }

/* funding card — funded-rate hero (consistency is the headline, not ROI) */
.fund-rate{ display:flex; flex-direction:column; gap:3px; padding:13px 15px; border-radius:11px;
  background:var(--bg-3); border:1px solid var(--line); }
.fund-rate.perfect{ border-color:var(--accent-line); background:linear-gradient(180deg,var(--accent-wash),var(--bg-3)); }
.fund-rate .fr-v{ font-family:var(--mono); font-size:1.95rem; font-weight:600; color:var(--accent-hi); line-height:1; }
.fund-rate .fr-v span{ font-family:var(--sans); font-size:.78rem; font-weight:500; color:var(--ink-2); margin-left:3px; }
.fund-rate .fr-k{ font-family:var(--mono); font-size:.67rem; color:var(--ink-3); letter-spacing:.01em; }
.fund-time{ display:flex; flex-direction:column; gap:8px; }
.fund-time .ft-v{ font-family:var(--mono); font-size:1.45rem; font-weight:600; color:var(--ink); line-height:1; }
.fund-time .ft-v small{ font-size:.78rem; color:var(--ink-3); font-weight:400; }
.fund-time .ft-k{ font-size:.71rem; color:var(--ink-3); margin:-3px 0 2px; }

/* funding methodology — always visible, scannable rows (replaces the hidden <details>) */
.methodology{ margin-top:26px; border:1px solid var(--line); border-radius:var(--r); background:var(--bg-1); padding:20px 22px; }
.meth-head{ font-family:var(--mono); font-size:.76rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-2); margin-bottom:14px; }
.meth-grid{ display:grid; gap:11px; }
.meth-item{ display:grid; grid-template-columns:70px 1fr; gap:14px; align-items:start; }
.meth-item .mi-l{ font-family:var(--mono); font-size:.69rem; letter-spacing:.04em; text-transform:uppercase; color:var(--accent-hi); padding-top:2px; }
.meth-item.warn .mi-l{ color:var(--ink-3); }
.meth-item p{ margin:0; color:var(--ink-3); font-size:.84rem; line-height:1.55; }
.meth-item p b{ color:var(--ink-2); }
@media(max-width:560px){ .meth-item{ grid-template-columns:1fr; gap:2px; } }

/* product card — funded strip (the consistency star, with an info affordance) */
.card-fund{ display:flex; align-items:center; gap:13px; padding:11px 14px; border-radius:10px;
  background:var(--bg-3); border:1px solid var(--line); margin-top:2px; }
.card-fund.perfect{ border-color:var(--accent-line); background:linear-gradient(180deg,var(--accent-wash),var(--bg-3)); }
.card-fund .cf-v{ font-family:var(--mono); font-size:1.5rem; font-weight:600; color:var(--accent-hi); line-height:1; flex:none; }
.card-fund .cf-x{ display:flex; flex-direction:column; gap:1px; min-width:0; }
.card-fund .cf-k{ font-size:.82rem; font-weight:600; color:var(--ink); }
.card-fund .cf-s{ font-family:var(--mono); font-size:.67rem; color:var(--ink-3); display:flex; align-items:center; gap:6px; flex-wrap:wrap; }

/* reusable info "i" tooltip — accessible (hover + keyboard focus) */
.info{ display:inline-flex; align-items:center; justify-content:center; width:14px; height:14px; flex:none;
  border-radius:50%; border:1px solid var(--line-2); background:var(--bg-2); color:var(--ink-3);
  font-family:var(--mono); font-size:9px; font-weight:700; line-height:1; cursor:help; padding:0; position:relative; }
.info:hover, .info:focus-visible{ color:var(--accent-hi); border-color:var(--accent-line); outline:none; }
/* anchored to the icon's RIGHT and opening LEFT — the "i" sits at the right edge of its card, so a
   centred tooltip would overflow and the card's overflow:hidden would clip it (see funded strip). */
.info::after{ content:attr(data-tip); position:absolute; bottom:calc(100% + 9px); right:-3px; left:auto;
  width:min(250px,74vw); background:var(--bg-3); border:1px solid var(--line-2); border-radius:9px; padding:9px 11px;
  font-family:var(--sans); font-weight:400; font-size:.74rem; line-height:1.5; color:var(--ink-2); text-align:left;
  letter-spacing:0; text-transform:none; opacity:0; visibility:hidden; transition:opacity .14s ease;
  box-shadow:0 12px 30px -12px rgba(0,0,0,.85); z-index:30; }
.info::before{ content:""; position:absolute; bottom:calc(100% + 5px); right:3px; left:auto; transform:rotate(45deg);
  width:8px; height:8px; background:var(--bg-3); border-right:1px solid var(--line-2); border-bottom:1px solid var(--line-2);
  opacity:0; visibility:hidden; transition:opacity .14s ease; z-index:31; }
.info:hover::after, .info:focus-visible::after, .info:hover::before, .info:focus-visible::before{ opacity:1; visibility:visible; }

/* ── DEDICATED PRODUCT PAGE (guardian/balanced/edge.html) ── */
.prod{ max-width:var(--maxw); margin:0 auto; padding:clamp(20px,3vw,34px) var(--pad) clamp(48px,7vw,90px); }
/* the ficha sections live inside #prod (app.js fills it); the flex gap MUST be here, not on .prod */
#prod{ display:flex; flex-direction:column; gap:clamp(22px,2.6vw,32px); }
.pf-head{ display:flex; justify-content:space-between; gap:28px; flex-wrap:wrap; align-items:flex-start; }
.pf-tier{ font-family:var(--mono); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase; color:var(--accent-hi); }
.pf-name{ margin:8px 0 6px; font-size:clamp(1.8rem,4vw,2.6rem); font-weight:600; letter-spacing:-.02em; }
.pf-name .swing{ font-size:.46em; font-weight:500; color:var(--ink-3); }
.pf-tag{ margin:0; color:var(--ink-2); font-size:1.02rem; max-width:54ch; line-height:1.5; }
.pf-bestfor{ margin-top:13px; font-size:.9rem; color:var(--ink-2); max-width:54ch; }
.pf-bestfor span{ font-family:var(--mono); font-size:.68rem; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-3); margin-right:8px; }
.pf-buy{ display:flex; flex-direction:column; gap:12px; align-items:stretch; min-width:230px; }
.pf-buy-row{ display:flex; gap:12px; }
.pf-ceil, .pf-price{ flex:1; background:var(--bg-2); border:1px solid var(--line); border-radius:11px; padding:11px 15px; }
.pf-ceil span, .pf-price small{ display:block; font-family:var(--mono); font-size:.62rem; text-transform:uppercase; letter-spacing:.04em; color:var(--ink-3); }
.pf-ceil b, .pf-price b{ display:block; font-family:var(--mono); font-size:1.45rem; font-weight:600; color:var(--ink); line-height:1.15; }
.pf-ceil b{ color:var(--accent-hi); }
.pf-fund-strip{ margin:0; }
.pf-section{ display:flex; flex-direction:column; gap:16px; }
.pf-controls{ display:flex; align-items:center; gap:9px; flex-wrap:wrap; }
.pf-cl{ font-family:var(--mono); font-size:.7rem; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-3); }
.pf-cl-r{ margin-left:6px; }
.pf-grid{ display:grid; grid-template-columns:minmax(250px,350px) 1fr; gap:18px; align-items:start; }
.pf-grid .metrics{ grid-template-columns:1fr 1fr; }
.pf-chart{ padding:16px; }
.pf-trade{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.pf-pros, .pf-cons{ background:var(--bg-1); border:1px solid var(--line); border-radius:var(--r); padding:18px 20px; }
.pf-pros{ border-color:var(--accent-line); }
.pf-pros h3, .pf-cons h3{ margin:0 0 11px; font-size:.92rem; font-weight:600; }
.pf-pros h3{ color:var(--accent-hi); } .pf-cons h3{ color:var(--ink-2); }
.pf-pros ul, .pf-cons ul{ margin:0; padding:0; list-style:none; display:flex; flex-direction:column; gap:9px; }
.pf-pros li, .pf-cons li{ position:relative; padding-left:20px; font-size:.86rem; color:var(--ink-2); line-height:1.5; }
.pf-pros li::before{ content:"+"; position:absolute; left:0; color:var(--accent-hi); font-family:var(--mono); font-weight:700; }
.pf-cons li::before{ content:"–"; position:absolute; left:0; color:var(--ink-3); font-family:var(--mono); font-weight:700; }
.pf-funding, .pf-markets{ background:var(--bg-1); border:1px solid var(--line); border-radius:var(--r); padding:22px; }
.pf-funding h3, .pf-markets h3{ margin:0 0 14px; font-size:1rem; font-weight:600; }
.pf-fund-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:16px; }
.pf-fblock{ background:var(--bg-2); border:1px solid var(--line); border-radius:10px; padding:13px 15px; }
.pf-fv{ font-family:var(--mono); font-size:1.3rem; font-weight:600; color:var(--ink); line-height:1; }
.pf-fv small{ font-size:.64rem; color:var(--ink-3); font-weight:400; }
.pf-fk{ margin-top:5px; font-size:.69rem; color:var(--ink-3); line-height:1.35; }
.pf-paytable{ display:flex; flex-direction:column; gap:7px; padding-top:12px; border-top:1px solid var(--line); }
.pf-payrow{ display:flex; justify-content:space-between; align-items:baseline; font-size:.84rem; color:var(--ink-2); }
.pf-payrow b{ font-family:var(--mono); font-weight:500; color:var(--ink); }
.pf-note{ margin:14px 0 0; font-size:.78rem; color:var(--ink-3); line-height:1.55; }
.pf-note a{ color:var(--accent-hi); text-decoration:none; border-bottom:1px solid var(--accent-line); }
.pf-cta{ display:flex; justify-content:space-between; align-items:center; gap:18px; flex-wrap:wrap;
  background:linear-gradient(180deg,var(--bg-2),var(--bg-1)); border:1px solid var(--accent-line); border-radius:var(--r); padding:20px 24px; }
.pf-cta .pf-price{ background:none; border:none; padding:0; }
.pf-cta .pf-price b{ font-size:1.6rem; }
.pf-cta-btns{ display:flex; gap:10px; flex-wrap:wrap; }
@media(max-width:820px){ .pf-grid, .pf-trade{ grid-template-columns:1fr; } .pf-fund-grid{ grid-template-columns:1fr 1fr; }
  .pf-head{ flex-direction:column; gap:18px; } .pf-buy{ width:100%; min-width:0; } .pf-cta{ flex-direction:column; align-items:stretch; } .pf-cta-btns{ width:100%; } .pf-cta-btns .btn{ flex:1; } }
@media(max-width:520px){ .pf-fund-grid, .pf-grid .metrics{ grid-template-columns:1fr; } .pf-buy-row{ flex-direction:column; } }

/* links into the dedicated product pages (from bento / funding / comparison cards) */
.card-more, .fund-more, .cmp-more{ display:inline-flex; align-items:center; gap:6px; font-family:var(--mono);
  font-size:.74rem; color:var(--accent-hi); text-decoration:none; border-bottom:1px solid var(--accent-line); width:fit-content; }
.card-more:hover, .fund-more:hover, .cmp-more:hover{ border-bottom-color:var(--accent-hi); }
.card-more{ margin:2px 0; } .fund-more{ margin-top:2px; }
.cmp-more{ margin:9px auto 0; justify-content:center; }

/* hero side panel — compact per-product funding cards (price · Details · Buy → cTrader) */
#ledger.hsys-list{ gap:10px; }
.hsys-card{ background:var(--bg-2); border:1px solid var(--line); border-radius:11px; padding:13px 15px; display:flex; flex-direction:column; gap:8px; transition:border-color .2s ease; }
.hsys-card:hover{ border-color:var(--accent-line); }
.hsys-top{ display:flex; justify-content:space-between; align-items:baseline; }
.hsys-name{ font-weight:600; font-size:1rem; }
.hsys-ceil{ font-family:var(--mono); font-size:.7rem; color:var(--ink-3); }
.hsys-mets{ font-size:.8rem; color:var(--ink-3); }
.hsys-mets b{ font-family:var(--mono); color:var(--ink); font-weight:500; }
.hsys-foot{ display:flex; align-items:center; gap:12px; }
.hsys-price{ font-family:var(--mono); font-size:1.05rem; font-weight:600; color:var(--ink); }
.hsys-det{ font-family:var(--mono); font-size:.74rem; color:var(--accent-hi); text-decoration:none; border-bottom:1px solid var(--accent-line); }
.hsys-det:hover{ border-bottom-color:var(--accent-hi); }
.hsys-buy{ margin-left:auto; padding:.4em 1.05em; font-size:.8rem; }

/* ── WHY realbacktesting (positive value props, replaces the cliché contrast) ── */
.why{ max-width:var(--maxw); margin:0 auto; padding:clamp(40px,6vw,84px) var(--pad); }
.why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:10px; }
@media(max-width:860px){ .why-grid{ grid-template-columns:1fr; } }
.why-card{ background:linear-gradient(180deg,var(--bg-2),var(--bg-1)); border:1px solid var(--line);
  border-radius:var(--r); padding:24px 22px; transition:border-color .2s ease, transform .2s ease; }
.why-card:hover{ border-color:var(--accent-line); transform:translateY(-2px); }
.why-n{ font-family:var(--mono); font-size:.74rem; color:var(--accent-hi); letter-spacing:.14em; }
.why-card h3{ margin:11px 0 9px; font-size:1.12rem; font-weight:600; letter-spacing:-.02em; }
.why-card p{ margin:0; color:var(--ink-2); font-size:.92rem; line-height:1.6; }
.why-card p b{ color:var(--ink); }
.why-card p a{ color:var(--accent-hi); text-decoration:none; border-bottom:1px solid var(--accent-line); }
.why-card p a:hover{ border-bottom-color:var(--accent-hi); }

/* ── EXPLAINER — short "what you're getting" (2×2, reuses .why-card) ── */
.explain{ max-width:var(--maxw); margin:0 auto; padding:clamp(40px,6vw,80px) var(--pad); }
.explain-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin-top:6px; }
@media (max-width:680px){ .explain-grid{ grid-template-columns:1fr; } }
.explain-foot{ margin-top:22px; color:var(--ink-3); font-size:.9rem; }
.explain-foot a{ color:var(--accent-hi); text-decoration:none; border-bottom:1px solid var(--accent-line); }
.explain-foot a:hover{ border-bottom-color:var(--accent-hi); }

/* ── EXPLORE — teaser grid linking to the 7 deep pages ── */
.explore{ max-width:var(--maxw); margin:0 auto; padding:clamp(40px,6vw,84px) var(--pad); }
.explore-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(min(100%, 280px), 1fr));
  gap:14px; margin-top:clamp(22px,3vw,34px); }
.xcard{ position:relative; display:flex; flex-direction:column; gap:.5em;
  padding:clamp(20px,2.2vw,26px); padding-right:2.4em;
  background:linear-gradient(180deg,var(--bg-2),var(--bg-1)); border:1px solid var(--line);
  border-radius:var(--r); color:inherit; text-decoration:none;
  transition:transform .2s ease, border-color .2s ease, background .2s ease; }
.xcard::after{ content:"→"; position:absolute; top:clamp(18px,2vw,24px); right:18px;
  font-family:var(--mono); color:var(--ink-4); transition:transform .2s ease, color .2s ease; }
.xcard:hover{ transform:translateY(-3px); border-color:var(--accent-line);
  background:linear-gradient(180deg,var(--bg-3),var(--bg-1)); }
.xcard:hover::after{ color:var(--accent-hi); transform:translate(3px,-3px); }
.xcard:focus-visible{ outline:2px solid var(--accent); outline-offset:2px; }
.xcard-n{ font-family:var(--mono); font-size:.74rem; letter-spacing:.14em; color:var(--accent-hi); }
.xcard h3{ font-size:1.1rem; font-weight:600; letter-spacing:-.015em; }
.xcard p{ margin:0; color:var(--ink-2); font-size:.92rem; line-height:1.55; }

/* ── PROOF / LEVELS ──────────────────────────────────────── */
.proof{ max-width:var(--maxw); margin:0 auto; padding:clamp(40px,6vw,84px) var(--pad); }
.levels{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.level{ padding:22px; display:flex; flex-direction:column; gap:13px; }
.level-top{ display:flex; justify-content:space-between; align-items:center; }
.level-n{ font-family:var(--mono); font-size:.74rem; color:var(--ink-3); }
.level h3{ font-size:1.16rem; }
.level .val{ font-family:var(--mono); font-size:2rem; font-weight:600; line-height:1; }
.level.proven .val{ color:var(--ink); }
.level.pending .val{ color:var(--accent-hi); }
.level p{ color:var(--ink-3); font-size:.86rem; margin:0; flex:1; }
.level .ev{ font-family:var(--mono); font-size:.72rem; color:var(--ink-3); padding-top:11px; border-top:1px dashed var(--line-2); }
.level.pending{ border-color:var(--accent-line); background:linear-gradient(180deg, rgba(91,141,239,.05), var(--bg-1)); }
/* official cTrader reports (per-product, Pending until published) */
.reports{ margin-top:16px; padding:24px; }
.reports-head{ display:flex; justify-content:space-between; align-items:flex-start; gap:24px; margin-bottom:18px; }
.reports-head h3{ font-size:1.2rem; margin-bottom:8px; }
.reports-head p{ color:var(--ink-3); font-size:.88rem; max-width:62ch; margin:0; }
.reports-count{ flex-shrink:0; text-align:right; display:flex; flex-direction:column; align-items:flex-end; }
.rc-n{ font-family:var(--mono); font-size:1.9rem; font-weight:600; color:var(--ink); line-height:1; }
.rc-d{ color:var(--ink-3); font-size:1rem; }
.rc-l{ font-size:.68rem; color:var(--ink-3); letter-spacing:.05em; text-transform:uppercase; margin-top:4px; }
.report-rows{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:10px; overflow:hidden; }
/* symmetric 3-column rows: id · two aligned stat lines · stacked actions — all rows equal height */
.report-row{ display:grid; grid-template-columns:minmax(140px,180px) 1fr auto; align-items:center; gap:20px;
  padding:16px 20px; background:var(--bg-1); min-height:90px; }
.report-row.ready{ background:linear-gradient(180deg, rgba(91,141,239,.05), var(--bg-1)); }
.rr-id h4{ margin:0; font-size:1rem; font-weight:600; letter-spacing:-.01em; }
.rr-band{ display:block; color:var(--ink-3); font-size:.72rem; font-family:var(--mono); margin-top:4px; }
.rr-stats{ display:flex; flex-direction:column; gap:6px; min-width:0; }
.rr-line{ font-family:var(--mono); font-size:.79rem; color:var(--ink-2); line-height:1.5; white-space:nowrap;
  overflow:hidden; text-overflow:ellipsis; }
.rr-line.dim{ color:var(--ink-3); font-size:.74rem; }
.rr-line b.pos{ color:var(--pos); } .rr-tag{ color:var(--ink-3); } .rr-pd{ color:var(--accent-hi); font-weight:600; }
.rr-vs{ color:var(--ink-4); margin:0 .55em; }
.rr-actions{ display:flex; flex-direction:column; align-items:flex-end; gap:8px; white-space:nowrap; }
.rr-orig{ font-family:var(--mono); font-size:.72rem; color:var(--ink-3); }
.rr-orig:hover{ color:var(--accent-hi); }
.metrics-basis{ font-family:var(--mono); font-size:.7rem; color:var(--ink-3); padding:9px 2px 0;
  letter-spacing:.01em; line-height:1.45; }
.metrics-basis b{ color:var(--ink-2); font-weight:600; }
.metrics-basis b.vfd{ color:var(--pos); }
.pd{ font-family:var(--mono); font-size:.6em; color:var(--accent-hi); font-weight:500; letter-spacing:.02em;
  background:var(--accent-wash); padding:.12em .42em; border-radius:5px; vertical-align:1px; }
.btn-sm{ padding:.5em .85em; font-size:.82rem; }
@media (max-width:720px){ .reports-head{ flex-direction:column; } .reports-count{ text-align:left; align-items:baseline; flex-direction:row; gap:8px; }
  .report-row{ grid-template-columns:1fr; gap:11px; min-height:0; padding:16px; }
  /* stats wrap fully (no clip); actions stack so the "untouched original" link can't force horizontal overflow */
  .rr-line{ white-space:normal; overflow:visible; text-overflow:clip; word-break:break-word; }
  .rr-actions{ flex-direction:column; align-items:flex-start; gap:9px; }
  .rr-orig{ white-space:normal; }
  .rr-vs{ margin:0 .35em; } }

.repro{ display:grid; grid-template-columns:1fr 1.25fr; gap:24px; align-items:center; margin-top:16px; padding:24px; }
.repro h3{ font-size:1.2rem; margin-bottom:8px; }
.repro p{ color:var(--ink-2); font-size:.92rem; max-width:42ch; }
.code{ background:#070809; border:1px solid var(--line-2); border-radius:10px; padding:18px 20px; margin:0;
  font-size:.84rem; line-height:1.75; overflow-x:auto; color:var(--ink-2); }
.code .c-dim{ color:var(--ink-3); } .code .c-ok{ color:var(--pos); font-weight:600; }
@media (max-width:880px){ .levels{ grid-template-columns:1fr; } .repro{ grid-template-columns:1fr; } }

/* ── METHOD ──────────────────────────────────────────────── */
.method{ max-width:var(--maxw); margin:0 auto; padding:clamp(40px,6vw,84px) var(--pad); }
/* real per-symbol spread table */
.spread-card{ padding:22px 24px; margin:6px 0 14px; }
.spread-head{ display:flex; align-items:baseline; justify-content:space-between; gap:14px; margin-bottom:14px; flex-wrap:wrap; }
.spread-head h3{ font-size:1.12rem; margin:0; font-weight:600; }
.spread-head span{ font-family:var(--mono); font-size:.72rem; color:var(--ink-3); }
.spread-cols{ display:grid; grid-template-columns:1fr 1fr; gap:14px 32px; }
@media(max-width:620px){ .spread-cols{ grid-template-columns:1fr; } }
.spread-table{ width:100%; border-collapse:collapse; font-size:.9rem; }
.spread-table th{ font-family:var(--mono); font-size:.64rem; text-transform:uppercase; letter-spacing:.06em;
  color:var(--ink-3); font-weight:500; text-align:left; padding:7px 4px; border-bottom:1px solid var(--line-2); }
.spread-table th.num, .spread-table td.num{ text-align:right; font-family:var(--mono); color:var(--ink); }
.spread-table td{ padding:8px 4px; border-bottom:1px solid var(--line); color:var(--ink-2); }
.spread-table tr:last-child td{ border-bottom:none; }
.sc-cls{ font-family:var(--mono); font-size:.68rem; color:var(--ink-4); margin-left:6px; }
.spread-foot{ margin:16px 0 0; padding-top:14px; border-top:1px dashed var(--line-2); color:var(--ink-3);
  font-size:.86rem; line-height:1.55; }
.spread-foot b{ color:var(--ink); }
.method-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line);
  border:1px solid var(--line); border-radius:var(--r); overflow:hidden; }
.mitem{ background:var(--bg-1); padding:20px; display:flex; flex-direction:column; gap:6px; }
.mitem .k{ font-family:var(--mono); font-size:.72rem; color:var(--accent-hi); letter-spacing:.04em; text-transform:uppercase; }
.mitem .v{ font-size:1.02rem; color:var(--ink); }
.mitem.wide{ grid-column:span 3; }
.mitem .d{ color:var(--ink-3); font-size:.86rem; }
@media (max-width:760px){ .method-grid{ grid-template-columns:1fr; } .mitem.wide{ grid-column:span 1; } }

/* ── CUSTOM ──────────────────────────────────────────────── */
.custom{ max-width:var(--maxw); margin:0 auto; padding:clamp(40px,6vw,84px) var(--pad); }
.custom-inner{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,56px); padding:clamp(28px,4vw,48px); align-items:center; }
.custom-copy h2{ font-size:clamp(1.6rem,3vw,2.3rem); margin:.5em 0 .5em; }
.steps{ list-style:none; counter-reset:s; margin:0; padding:0; display:flex; flex-direction:column; gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; }
.steps li{ counter-increment:s; background:var(--bg-1); padding:16px 18px; display:flex; align-items:center; gap:14px; font-size:.96rem; }
.steps li::before{ content:counter(s,decimal-leading-zero); font-family:var(--mono); font-size:.8rem;
  color:var(--accent-hi); border:1px solid var(--accent-line); background:var(--accent-wash);
  width:30px; height:30px; border-radius:7px; display:grid; place-items:center; flex-shrink:0; }
@media (max-width:780px){ .custom-inner{ grid-template-columns:1fr; } }

/* ── FAQ ─────────────────────────────────────────────────── */
.faq{ max-width:880px; margin:0 auto; padding:clamp(40px,6vw,84px) var(--pad); }
.faq-list{ display:flex; flex-direction:column; gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; }
.faq-item{ background:var(--bg-1); }
.faq-item summary{ cursor:pointer; padding:18px 22px; font-size:1.02rem; font-weight:500; color:var(--ink);
  list-style:none; display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:"+"; font-family:var(--mono); color:var(--accent-hi); font-size:1.3rem; line-height:1; flex-shrink:0; transition:transform .2s ease; }
.faq-item[open] summary::after{ transform:rotate(45deg); }
.faq-item summary:hover{ color:var(--accent-hi); }
.faq-item p{ margin:0; padding:0 22px 20px; color:var(--ink-2); font-size:.94rem; line-height:1.65; max-width:74ch; }
.faq-item p em{ color:var(--ink); font-style:normal; }

/* ── END CTA ─────────────────────────────────────────────── */
.endcta{ max-width:var(--maxw); margin:0 auto; padding:clamp(48px,7vw,110px) var(--pad); text-align:center; }
.endcta-inner{ max-width:640px; margin:0 auto; }
.endcta h2{ font-size:clamp(1.8rem,4vw,3rem); }
.endcta p{ color:var(--ink-2); font-size:1.06rem; margin:1em auto 2em; max-width:52ch; }
.lead{ display:flex; gap:10px; max-width:460px; margin:0 auto; }
.lead input{ flex:1; background:var(--bg-2); border:1px solid var(--line-2); border-radius:var(--r-sm);
  padding:.8em 1em; color:var(--ink); font-family:var(--mono); font-size:.92rem; }
.lead input:focus{ outline:none; border-color:var(--accent-line); box-shadow:0 0 0 3px var(--accent-wash); }
.lead-note{ font-size:.8rem; color:var(--ink-3); margin-top:14px; }
@media (max-width:520px){ .lead{ flex-direction:column; } }

/* ── FOOTER ──────────────────────────────────────────────── */
.foot{ max-width:var(--maxw); margin:0 auto; padding:40px var(--pad) 60px; border-top:1px solid var(--line);
  position:relative; z-index:2; }
.foot-top{ display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap; margin-bottom:24px; }
.foot-tag{ color:var(--ink-3); font-size:.88rem; margin:0; }
.foot-legal p{ color:var(--ink-3); font-size:.78rem; line-height:1.6; max-width:92ch; margin:.6em 0; }
.foot-legal strong{ color:var(--ink-3); }
.foot-meta{ font-family:var(--mono); }

/* ── reveal on scroll ────────────────────────────────────── */
/* reveal = CSS-only auto-completing entrance. Content is NEVER gated on JS — a failed app.js/fetch
   can no longer black out the page (the pre-rendered content always animates to opacity:1). */
.reveal{ animation: rb-reveal .7s cubic-bezier(.2,.7,.2,1) both; }
@keyframes rb-reveal{ from{ opacity:0; transform:translateY(16px); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion: reduce){ .reveal{ animation:none; } .eyebrow .dot{ animation:none; } }

/* ── focus visibility (consistent, contrast-safe) ────────── */
:where(a, button, summary, [role="tab"]):focus-visible{ outline:2px solid var(--accent-hi); outline-offset:2px; border-radius:7px; }
.seg button:focus-visible{ outline:none; box-shadow:0 0 0 2px var(--accent-hi) inset; }

/* ── responsive hardening (holds on every screen) ────────── */
/* chart head: let the product switch wrap / scroll on narrow widths */
@media (max-width:560px){
  .chart-head{ flex-wrap:wrap; }
  .seg{ width:100%; overflow-x:auto; -webkit-overflow-scrolling:touch; justify-content:flex-start; }
  .seg button{ flex:1 0 auto; }
}
/* small phones: tighten rhythm, prevent any overflow */
@media (max-width:400px){
  :root{ --pad:18px; }
  .hero h1{ font-size:2.45rem; }
  .lede{ font-size:1rem; }
  .hero-stats{ gap:18px 22px; }
  .hero-stats dd{ font-size:1.3rem; }
  .hero-actions{ width:100%; }
  .hero-actions .btn{ flex:1 1 auto; justify-content:center; }
  .card-foot{ flex-direction:column; align-items:flex-start; }
  .card-foot .btn{ width:100%; justify-content:center; }
  .ceil .val{ font-size:1.3rem; }
}
/* very small phones: avoid 2-col metric crush */
@media (max-width:340px){
  .metrics{ grid-template-columns:1fr; }
  .fund-big .v{ font-size:1.8rem; }
}
/* tablet portrait: keep the 2-up bento from feeling tight */
@media (min-width:761px) and (max-width:880px){
  .bento{ gap:13px; } .card{ padding:18px; }
  .metric{ padding:9px 10px; } .metric b{ font-size:.98rem; }
}
/* large screens: cap line lengths, keep the deck centered (no stretch) */
@media (min-width:1500px){
  :root{ --maxw:1280px; }
}
/* anchor offset so the sticky nav never covers section headings */
section[id]{ scroll-margin-top:78px; }
/* touch targets + no accidental horizontal scroll */
.btn, .nav-links a{ min-height:40px; }
.seg button{ min-height:34px; }
/* mobile: shrink the cTrader 'reproduce' code block so it needs no horizontal scroll */
@media (max-width:520px){ .code{ font-size:.72rem; padding:14px 14px; } }
img, canvas, pre, table{ max-width:100%; }

/* ── account safety / anti-copy ─────────────────────────── */
/* the new sections need the same centered max-width + padding as the rest (this was the missing rule) */
.safety, .strategies, .setup, .transp{ max-width:var(--maxw); margin:0 auto; padding:clamp(40px,6vw,84px) var(--pad); }
.safety-layers{ list-style:none; padding:0; margin:30px 0 0; display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media(max-width:760px){ .safety-layers{ grid-template-columns:1fr; } }
.safety-layers li{ display:flex; gap:16px; border:1px solid var(--line); border-radius:14px; background:linear-gradient(180deg,#0F1216,#0C0E11); padding:20px; }
.ly-n{ font-size:1.05rem; color:var(--accent-hi); font-weight:600; flex-shrink:0; line-height:1.2; }
.ly-name{ font-weight:600; color:var(--ink); font-size:1.02rem; }
.ly-name small{ display:block; font-family:var(--mono); font-size:.68rem; color:var(--ink-3); letter-spacing:.04em; text-transform:uppercase; margin-top:4px; font-weight:400; }
.ly-body p{ color:var(--ink-2); font-size:.91rem; line-height:1.55; margin:9px 0 0; }
.safety-foot{ display:grid; grid-template-columns:1.4fr 1fr; gap:14px; margin-top:16px; }
@media(max-width:760px){ .safety-foot{ grid-template-columns:1fr; } }
.safety-immut{ border-left:3px solid var(--accent); background:rgba(91,141,239,.06); border-radius:10px; padding:16px 18px; color:var(--ink-2); font-size:.92rem; line-height:1.6; }
.safety-immut b{ color:var(--ink); }
.safety-stance{ border:1px dashed var(--line-2); border-radius:10px; padding:16px 18px; color:var(--ink-3); font-size:.85rem; line-height:1.6; }
.results-note{ margin-top:16px; padding:clamp(26px,3.4vw,40px); }
.results-note .sec-kicker{ color:var(--accent-hi); }
.results-note h3{ font-size:1.32rem; letter-spacing:-.02em; margin:.25em 0 .5em; }
.results-note > p{ color:var(--ink-2); }
.rn-points{ margin:14px 0; padding:0; list-style:none; display:flex; flex-direction:column; gap:9px; }
.rn-points li{ position:relative; padding-left:22px; color:var(--ink-2); font-size:.94rem; line-height:1.5; }
.rn-points li::before{ content:"↳"; position:absolute; left:0; color:var(--accent-hi); }
.rn-close{ color:var(--ink-3); font-size:.9rem; border-top:1px dashed var(--line-2); padding-top:14px; margin-top:8px; line-height:1.6; }

/* ── strategies ─────────────────────────────────────────── */
.strat-blocks{ display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:16px; margin-top:30px; }
.sb{ border:1px solid var(--line); border-radius:14px; background:linear-gradient(180deg,#0F1216,#0C0E11); padding:22px 24px; }
.sb h4{ margin:0 0 8px; font-size:1.02rem; color:var(--ink); font-weight:600; }
.sb p{ margin:0; color:var(--ink-2); font-size:.92rem; line-height:1.62; }
.strat-families{ display:grid; grid-template-columns:repeat(auto-fit,minmax(178px,1fr)); gap:12px; margin-top:28px; }
.strat-families .fam{ border:1px solid var(--line); border-radius:12px; background:#0E1014; padding:18px; }
.fam-name{ font-weight:600; color:var(--ink); }
.fam-detail{ font-family:var(--mono); font-size:.76rem; color:var(--ink-3); margin-top:6px; line-height:1.4; }
.strat-foot{ margin-top:24px; color:var(--ink-3); font-size:.92rem; line-height:1.6; max-width:70ch; }
.strat-foot b{ color:var(--ink-2); }
/* product-name "FTMO Swing" suffix (matches the logo's Guardian + FTMO-Swing-badge treatment) */
.swing{ font-size:.52em; font-weight:500; color:var(--ink-3); letter-spacing:.02em; vertical-align:middle; white-space:nowrap; }
/* tier "Best for:" persona + price↔payout value anchor (conversion) */
.bestfor, .cmp-bestfor{ font-size:.82rem; color:var(--ink-2); line-height:1.45; margin-top:10px; }
.bestfor{ min-height:2.9em; }   /* normalize 1- vs 2-line "Best for" so the two top cards stay symmetric */
.bestfor span, .cmp-bestfor span{ font-family:var(--mono); font-size:.6rem; letter-spacing:.09em; text-transform:uppercase; color:var(--accent-hi); margin-right:8px; display:inline-block; }
/* brand highlight — bold + page-blue, for emphasising key words anywhere in the copy */
b.hl, strong.hl, .hl{ color:var(--accent-hi); font-weight:600; }
.card-value, .cmp-value{ font-size:.76rem; color:var(--ink-3); line-height:1.45; margin-top:10px; }
/* ── value stack / risk-reversal ────────────────────────── */
.vstack{ max-width:var(--maxw); margin:0 auto; padding:clamp(16px,3vw,32px) var(--pad) clamp(40px,6vw,80px); }
.vstack-inner{ padding:clamp(30px,4vw,52px); }
.vstack-head{ max-width:66ch; }
.vstack-head .sec-kicker{ color:var(--accent-hi); }
.vstack-head h2{ font-size:clamp(1.5rem,3vw,2.2rem); margin-top:10px; }
.vstack-head .sec-lede{ margin-top:14px; }
.vstack-items{ list-style:none; margin:32px 0 0; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:18px 36px; }
.vstack-items li{ display:flex; gap:13px; align-items:flex-start; }
.vs-check{ color:var(--pos); font-family:var(--mono); font-size:.95rem; margin-top:2px; flex-shrink:0; }
.vstack-items b{ display:block; color:var(--ink); font-size:1rem; }
.vstack-items span{ display:block; color:var(--ink-2); font-size:.9rem; line-height:1.5; margin-top:3px; }
@media (max-width:760px){ .vstack-items{ grid-template-columns:1fr; gap:16px; } }
/* setup run-topology schematic */
.setup-topo{ margin:32px 0 6px; }
.setup-topo svg{ width:100%; height:auto; display:block; max-width:920px; }
.setup-topo figcaption{ margin-top:16px; color:var(--ink-3); font-size:.88rem; line-height:1.6; max-width:82ch; }
/* ── parity heatmap (per-strategy, engine-to-engine) ────── */
.parity-hm{ padding:clamp(26px,3.4vw,44px); margin-top:16px; }
.hm-head{ max-width:76ch; }
.hm-head .sec-kicker{ color:var(--accent-hi); }
.hm-head h3{ font-size:clamp(1.3rem,2.4vw,1.8rem); margin-top:8px; }
.hm-head p{ color:var(--ink-2); margin-top:12px; font-size:.95rem; line-height:1.6; }
.hm-wrap{ overflow-x:auto; margin-top:24px; }
.hm{ width:100%; border-collapse:separate; border-spacing:3px; }
.hm th{ font-family:var(--mono); font-size:.64rem; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-3); font-weight:500; padding:4px 8px; text-align:center; white-space:nowrap; }
.hm th[scope=row]{ text-align:left; color:var(--ink); font-family:var(--sans); font-size:.84rem; font-weight:500; padding-right:14px; }
.hm thead th:first-child{ text-align:left; }
.hm-cell, .hm-ov{ font-family:var(--mono); text-align:center; padding:9px 8px; border-radius:6px; font-size:.76rem; }
.hm-cell.ok, .hm-ov.ok{ background:rgba(81,176,126,.13); color:var(--pos); }
.hm-cell.near, .hm-ov.near{ background:rgba(123,166,245,.14); color:var(--accent-hi); }
.hm-cell.warn, .hm-ov.warn{ background:rgba(209,114,104,.14); color:var(--neg); }
.hm-ov{ font-weight:600; }
.hm-foot{ margin-top:22px; padding-top:18px; border-top:1px solid var(--line); color:var(--ink-3); font-size:.86rem; line-height:1.6; }
@media(max-width:680px){ .hm th[scope=row]{ font-size:.78rem; } .hm-cell, .hm-ov{ font-size:.7rem; padding:7px 5px; } }
/* official-policy link inside the FTMO FAQ answers */
.faq-item .faq-link{ display:inline-block; margin:-6px 22px 18px; font-family:var(--mono); font-size:.82rem; color:var(--accent-hi); text-decoration:none; border-bottom:1px solid transparent; }
.faq-item .faq-link:hover{ border-bottom-color:var(--accent-hi); }
/* ── transparency / before you buy ──────────────────────── */
.transp-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:30px; }
.transp-col{ border:1px solid var(--line); border-radius:14px; background:#0E1014; padding:24px 26px; }
.transp-col h3{ margin:0 0 14px; font-size:1.05rem; }
.transp-col.get h3{ color:var(--pos); }
.transp-col.dont h3{ color:var(--ink-2); }
.transp-col ul{ margin:0; padding:0; list-style:none; display:flex; flex-direction:column; gap:11px; }
.transp-col li{ position:relative; padding-left:24px; color:var(--ink-2); font-size:.92rem; line-height:1.55; }
.transp-col.get li::before{ content:"✓"; position:absolute; left:0; color:var(--pos); font-family:var(--mono); }
.transp-col.dont li::before{ content:"✕"; position:absolute; left:0; color:var(--neg); font-family:var(--mono); }
.transp-risk{ margin-top:26px; color:var(--ink-2); font-size:.95rem; line-height:1.65; max-width:82ch; border-left:2px solid var(--accent); padding-left:16px; }
.transp-risk b{ color:var(--ink); }
.transp-curr{ margin-top:14px; color:var(--ink-3); font-family:var(--mono); font-size:.82rem; }
@media(max-width:760px){ .transp-grid{ grid-template-columns:1fr; } }

/* ── faq subheading ─────────────────────────────────────── */
.faq-sub{ font-family:var(--mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--accent-hi); margin:34px 0 14px; }

/* ── run it right / setup ───────────────────────────────── */
.setup-steps{ list-style:none; padding:0; margin:30px 0 0; display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media(max-width:760px){ .setup-steps{ grid-template-columns:1fr; } }
.setup-steps li{ display:flex; gap:16px; border:1px solid var(--line); border-radius:14px; background:linear-gradient(180deg,#0F1216,#0C0E11); padding:20px; }
.st-n{ font-size:1.1rem; font-weight:600; color:var(--accent-hi); flex-shrink:0; width:1.3em; line-height:1.2; }
.st-t{ font-weight:600; color:var(--ink); font-size:1rem; }
.st-body p{ color:var(--ink-2); font-size:.9rem; line-height:1.55; margin:8px 0 0; }
.setup-foot{ display:grid; grid-template-columns:1fr 1.5fr; gap:14px; margin-top:18px; }
@media(max-width:760px){ .setup-foot{ grid-template-columns:1fr; } }
.setup-rules{ border:1px solid var(--accent-line); background:rgba(91,141,239,.06); border-radius:14px; padding:20px 22px; }
.rules-h, .cya-h{ font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; margin-bottom:13px; }
.rules-h{ color:var(--accent-hi); }
.setup-rules ul{ margin:0; padding:0; list-style:none; display:flex; flex-direction:column; gap:11px; }
.setup-rules li{ position:relative; padding-left:24px; color:var(--ink); font-size:.95rem; line-height:1.4; }
.setup-rules li::before{ content:"✓"; position:absolute; left:0; color:var(--accent-hi); font-weight:700; }
.setup-cya{ border:1px dashed var(--line-2); border-radius:14px; padding:20px 22px; }
.setup-cya .cya-h{ color:var(--ink-3); }
.setup-cya p{ color:var(--ink-3); font-size:.85rem; line-height:1.65; margin:0; }
