/* ---- Self-hosted fonts (no CDN; CSP font-src 'self') ---- */
  @font-face{font-family:'Fraunces';font-style:normal;font-weight:500 600;font-display:swap;src:url('/fonts/fraunces-v38-latin-var.woff2') format('woff2');}
  @font-face{font-family:'Inter';font-style:normal;font-weight:400 600;font-display:swap;src:url('/fonts/inter-v20-latin-var.woff2') format('woff2');}
  @font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:500;font-display:swap;src:url('/fonts/jetbrains-mono-v24-latin-500.woff2') format('woff2');}

  /* ============================================================
     TOKENS — LIGHT is the default (unprefixed :root); dark is opt-in.
     Mirrors the app palette so the marketing site and the app match.
     ============================================================ */
  :root, [data-theme="light"]{
    --bg:#F4F1EA; --surface:#FFFFFF; --card:#FFFFFF; --card-2:#FBF8F1;
    --line:#E7E0D1; --line-2:#DBD2BF;
    --text:#1F2937; --dim:#5B5345; --muted:#857B66;
    --accent:#C2410C; --accent-bri:#D97706; --accent-deep:#9A3412; --on-accent:#FFFFFF;
    --gold:#D9A441; --gold-deep:#B8862B; --ok:#2A7A52;
    --serif:'Fraunces',Georgia,serif;
    --sans:'Inter',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
    --mono:'JetBrains Mono','SF Mono',Menlo,monospace;
    --shadow:0 20px 50px -28px rgba(31,41,55,0.22);
  }
  [data-theme="dark"]{
    --bg:#14110C; --surface:#1C1813; --card:#251F18; --card-2:#2C2316;
    --line:#3A3225; --line-2:#473826;
    --text:#EDE7D9; --dim:#C9C0AE; --muted:#A89F8C;
    --accent:#F0911F; --accent-bri:#D97706; --accent-deep:#B45309; --on-accent:#2A1B05;
    --gold:#FCD34D; --gold-deep:#E9B838; --ok:#7bbe97;
    --shadow:0 24px 60px -30px rgba(0,0,0,0.7);
  }

  *,*::before,*::after{box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{margin:0;background:var(--bg);color:var(--text);font-family:var(--sans);
    font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;
    transition:background .2s ease,color .2s ease}
  a{color:var(--accent);text-decoration:none}
  a:hover{text-decoration:underline;text-underline-offset:3px}
  .mono{font-family:var(--mono)}
  .wrap{max-width:1120px;margin:0 auto;padding:0 24px}

  h1,h2,h3{font-family:var(--serif);font-weight:600;letter-spacing:-0.02em;line-height:1.1;margin:0 0 18px}
  h1{font-size:clamp(38px,5.2vw,56px);line-height:1.05}
  h2.sec{font-size:clamp(28px,3.4vw,38px);margin:10px 0 24px}
  p.lead{color:var(--dim);font-size:clamp(16px,1.3vw,18px);max-width:600px;line-height:1.6}
  .eyebrow,.kick{display:inline-block;font-family:var(--mono);font-size:12px;font-weight:600;
    letter-spacing:0.18em;text-transform:uppercase;color:var(--accent-bri);margin-bottom:14px}

  /* ---- Top bar ---- */
  .topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:14px;
    padding:14px 24px;max-width:1120px;margin:0 auto;
    background:color-mix(in srgb,var(--bg) 88%,transparent);
    -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}
  .brand{display:flex;align-items:center;gap:10px;color:var(--text)}
  .logo-mark{height:26px;width:auto}
  .wm{font-family:var(--serif);font-weight:600;font-size:20px;letter-spacing:-0.3px}
  .pill{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:1px;
    color:var(--on-accent);background:linear-gradient(180deg,var(--gold),var(--gold-deep));
    padding:3px 7px;border-radius:6px}
  .topnav{display:flex;gap:4px;margin-left:14px}
  .navlink{color:var(--dim);font-size:14px;font-weight:500;padding:7px 11px;border-radius:8px}
  .navlink:hover{color:var(--text);background:var(--card);text-decoration:none}
  .topactions{margin-left:auto;display:flex;align-items:center;gap:10px}
  .tbtn{display:inline-flex;align-items:center;justify-content:center;gap:6px;
    font-family:var(--sans);font-size:13.5px;font-weight:600;color:var(--text);
    background:var(--card);border:1px solid var(--line-2);border-radius:9px;
    padding:9px 13px;cursor:pointer}
  .tbtn:hover{border-color:var(--accent)}
  .tbtn.icon{padding:9px;width:40px}
  .btn{display:inline-block;text-align:center;font-weight:700;font-size:14.5px;
    border-radius:10px;padding:11px 18px;border:1px solid transparent;cursor:pointer;
    font-family:var(--sans)}
  .btn.primary{background:linear-gradient(180deg,var(--accent-bri),var(--accent));
    color:var(--on-accent);border-color:var(--accent-deep)}
  .btn.primary:hover{filter:brightness(1.05);text-decoration:none}
  .btn.ghost{background:transparent;color:var(--text);border-color:var(--line-2)}
  .btn.ghost:hover{border-color:var(--accent);text-decoration:none}
  @media(max-width:780px){.topnav{display:none}.tbtn .txt{display:none}}

  /* ---- Hero (text + media) ---- */
  .hero{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:start;padding:60px 0 50px}
  @media(max-width:900px){.hero{grid-template-columns:1fr;gap:34px;padding:40px 0 28px}}
  .hero h1{margin:8px 0 16px}
  .hero p.lead{margin:0 0 26px}
  .hero .cta-row{display:flex;gap:12px;flex-wrap:wrap}
  .deposit-note{margin-top:18px;font-family:var(--mono);font-size:12.5px;color:var(--muted);letter-spacing:.04em}

  /* hero media (video) */
  .hero-media{margin:0}
  .hero-frame{position:relative;border-radius:16px;overflow:hidden;box-shadow:var(--shadow);
    border:1px solid var(--line)}
  .hero-video{display:block;width:100%;aspect-ratio:16/9;object-fit:cover}
  .hero-play{display:flex;align-items:center;justify-content:center;position:absolute;top:50%;left:50%;
    transform:translate(-50%,-50%);background:color-mix(in srgb,var(--bg) 78%,transparent);color:var(--text);
    border:2px solid var(--text);border-radius:50%;width:64px;height:64px;font-size:21px;padding-left:3px;
    cursor:pointer;line-height:1;transition:transform .15s ease,background .15s ease,color .15s ease,border-color .15s ease}
  .hero-play:hover,.hero-play:focus-visible{transform:translate(-50%,-50%) scale(1.08);
    background:var(--accent);color:var(--on-accent);border-color:var(--accent);outline:none}
  .hero-cap{margin:10px 2px 0;font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.03em}
  /* Reduced motion: hero.js also pauses the autoplay preview; drop the button animation too. */
  @media (prefers-reduced-motion: reduce){.hero-play{transition:none}
    .hero-play:hover,.hero-play:focus-visible{transform:translate(-50%,-50%)}}

  /* ---- Sections ---- */
  section.band{border-top:1px solid var(--line);padding:56px 0}
  .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}
  @media(max-width:820px){.cards{grid-template-columns:1fr}}
  .card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px}
  .card .num{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--accent-bri)}
  .card h3{font-size:18px;margin:10px 0 8px}
  .card p{color:var(--dim);font-size:14.5px;margin:0;line-height:1.6}

  /* timeline */
  .timeline{max-width:760px;margin:8px 0 0;position:relative;padding-left:30px}
  .timeline::before{content:"";position:absolute;left:8px;top:8px;bottom:8px;width:2px;background:var(--accent);opacity:.8}
  .tstep{position:relative;margin-bottom:26px;padding-left:8px}
  .tstep::before{content:"";position:absolute;left:-30px;top:5px;width:15px;height:15px;border-radius:50%;
    background:var(--accent);border:4px solid var(--bg)}
  .tstep .when{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--accent-bri);letter-spacing:.12em;text-transform:uppercase}
  .tstep h4{margin:5px 0 5px;font-family:var(--serif);font-weight:600;font-size:19px;color:var(--text)}
  .tstep p{margin:0;color:var(--dim);font-size:15px;line-height:1.55}

  /* trust */
  .callout{background:var(--card);border-left:3px solid var(--gold);padding:24px 28px;border-radius:8px;
    max-width:820px;margin:8px 0 0;font-size:16px;color:var(--text);line-height:1.7}
  .callout strong{color:var(--text)}
  .trust{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;text-align:center;margin-top:40px}
  @media(max-width:760px){.trust{grid-template-columns:repeat(2,1fr)}}
  .stat .num{font-family:var(--serif);font-size:24px;font-weight:600;color:var(--accent);line-height:1.2}
  .stat .label{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--muted);letter-spacing:.08em;margin-top:8px;text-transform:uppercase}

  /* pricing */
  .pricing{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:840px;margin:8px 0 0}
  @media(max-width:720px){.pricing{grid-template-columns:1fr}}
  .tier{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:30px 28px;position:relative}
  .tier.featured{border:2px solid var(--accent)}
  .tier .tag{position:absolute;top:-12px;left:28px;background:var(--accent);color:var(--on-accent);
    padding:4px 11px;border-radius:5px;font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase}
  .tier h3{font-size:21px;margin:0 0 4px}
  .tier .sub{color:var(--muted);font-size:14px;margin:0 0 14px}
  .tier .price{font-family:var(--serif);font-size:46px;font-weight:600;margin:2px 0;color:var(--text);line-height:1}
  .tier .price small{font-family:var(--sans);font-size:16px;font-weight:400;color:var(--muted)}
  .tier ul{list-style:none;padding:0;margin:22px 0}
  .tier li{padding:8px 0 8px 24px;position:relative;font-size:14.5px;color:var(--dim);line-height:1.55}
  .tier li::before{content:"✓";position:absolute;left:0;color:var(--ok);font-weight:800}
  .tier .btn{display:block;width:100%}

  /* cta band */
  .ctaband{text-align:center;background:var(--card-2);border:1px solid var(--line);border-radius:20px;padding:46px 24px;margin:56px 0}
  .ctaband h2{font-family:var(--serif);font-weight:600;font-size:clamp(26px,3vw,34px);margin:0 0 10px;letter-spacing:-.3px}
  .ctaband p{color:var(--dim);margin:0 auto 22px;max-width:560px}

  footer{border-top:1px solid var(--line);padding:30px 0;color:var(--muted);font-size:13px}
  footer .row{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
  footer a{color:var(--muted);margin-right:14px}
  footer a:hover{color:var(--text)}
  footer .brand{color:var(--text);font-family:var(--serif);font-weight:600;font-size:17px}


/* utilities (were inline style="" attributes) */
.u-mx-auto { margin-left: auto; margin-right: auto; }
.u-ml-auto { margin-left: auto; }
.u-cta-lg { font-size: 17px; padding: 15px 30px; }
.u-note { color: var(--muted); font-size: 13px; margin-top: 24px; font-family: var(--mono); letter-spacing: .04em; }
.u-gold { color: var(--gold); }
.u-brand-inline { display: inline-flex; align-items: center; gap: 9px; }
.u-h22 { height: 22px; }
