/* ============================================================
   Budge, marketing site. Calm as the flex, as a living typeset masterpiece.
   Premium themes recolor the entire world (including the canvas dawn) through
   one --glow token. Every motion is slow and quiet. Reduced motion turns it all
   off into a clean, still book.
   ============================================================ */

/* ----------  self hosted fonts  ---------- */
@font-face { font-family:"Fraunces"; src:url("/assets/fonts/fraunces.woff2") format("woff2"); font-weight:100 900; font-style:normal; font-display:swap; }
@font-face { font-family:"Fraunces"; src:url("/assets/fonts/fraunces-italic.woff2") format("woff2"); font-weight:100 900; font-style:italic; font-display:swap; }
@font-face { font-family:"Hanken Grotesk"; src:url("/assets/fonts/hanken.woff2") format("woff2"); font-weight:100 900; font-style:normal; font-display:swap; }

/* ----------  base tokens  ---------- */
:root {
  --serif:"Fraunces", Georgia, "Times New Roman", serif;
  --sans:"Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --wrap:1180px; --pad:clamp(1.25rem, 5vw, 3rem); --r:18px;
  --ease:cubic-bezier(0.22,0.7,0.2,1);
  --spring:cubic-bezier(0.16,1,0.3,1);
  --reveal-dur:1.15s;
  --line:rgba(232,226,210,0.09);
  --line-strong:rgba(232,226,210,0.16);
}

/* ----------  premium themes (the app's worlds). --glow is the accent as an
   rgb triplet, so every soft light, shadow and the canvas dawn follow.  ---------- */
:root, [data-theme="sun"] {
  --accent:#ff9a1f; --accent-2:#e08a12; --glow:255,154,31;
  --bg:#0b0a08; --bg-2:#14110f; --bg-3:#1b1613;
  --ink:#e8e2d2; --ink-2:#c4bdb0; --muted:#8a857c;
}
[data-theme="aurora"] {
  --accent:#6bce85; --accent-2:#4dae68; --glow:107,206,133;
  --bg:#07100b; --bg-2:#0d1813; --bg-3:#121f18;
  --ink:#e3ece0; --ink-2:#bdc9bd; --muted:#7d897f;
}
[data-theme="bloom"] {
  --accent:#f56867; --accent-2:#d94d4c; --glow:245,104,103;
  --bg:#100808; --bg-2:#180d0d; --bg-3:#201313;
  --ink:#ecdfe0; --ink-2:#c8bcbd; --muted:#888082;
}
[data-theme="tide"] {
  --accent:#39b6e8; --accent-2:#2792cf; --glow:57,182,232;
  --bg:#070d11; --bg-2:#0c1419; --bg-3:#111a20;
  --ink:#dfe9ed; --ink-2:#bcc6c9; --muted:#7c8589;
}
[data-theme="dusk"] {
  --accent:#be8ef7; --accent-2:#9d6fe8; --glow:190,142,247;
  --bg:#0c0810; --bg-2:#130d19; --bg-3:#191320;
  --ink:#e8e0ed; --ink-2:#c6bcc9; --muted:#857c89;
}
[data-theme="paper"] {
  --accent:#c8750e; --accent-2:#a85f0c; --glow:200,117,14;
  --bg:#f7f3ea; --bg-2:#efe9da; --bg-3:#e7dfcc;
  --ink:#2a2622; --ink-2:#564f47; --muted:#726b64;
  --line:rgba(42,38,34,0.10); --line-strong:rgba(42,38,34,0.18);
}

/* ----------  reset / base  ---------- */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  background:var(--bg); color:var(--ink); font-family:var(--sans);
  font-size:clamp(1rem,0.55vw + 0.9rem,1.18rem); line-height:1.6; font-weight:380;
  letter-spacing:0.005em; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden; position:relative;
  transition:background-color 0.7s var(--ease), color 0.7s var(--ease);
}
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
::selection { background:var(--accent); color:#1a1206; }
.wrap { width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--pad); position:relative; z-index:2; }

.skip-link { position:absolute; left:1rem; top:-3rem; z-index:300; background:var(--accent); color:#1a1206; padding:0.6rem 1rem; border-radius:10px; font-weight:600; transition:top 0.2s var(--ease); }
.skip-link:focus { top:1rem; }
:focus-visible { outline:2px solid var(--accent); outline-offset:3px; border-radius:4px; }

/* ----------  living dawn + atmosphere  ---------- */
#ambient { position:fixed; inset:0; z-index:0; pointer-events:none; width:100%; height:100%; transition:opacity 0.7s var(--ease); }
[data-theme="paper"] #ambient { opacity:0.55; }
.vignette { position:fixed; inset:0; z-index:1; pointer-events:none; background:radial-gradient(125% 95% at 50% 18%, transparent 55%, rgba(0,0,0,0.55) 100%); transition:opacity 0.7s var(--ease); }
[data-theme="paper"] .vignette { background:radial-gradient(125% 95% at 50% 18%, transparent 60%, rgba(120,90,40,0.10) 100%); }
.grain { position:fixed; inset:0; z-index:92; pointer-events:none; opacity:0.05; mix-blend-mode:soft-light; 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='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
.cursor-glow { position:fixed; top:0; left:0; z-index:2; pointer-events:none; width:44rem; height:44rem; border-radius:50%; transform:translate3d(-200vw,-200vh,0); will-change:transform; background:radial-gradient(circle, rgba(var(--glow),0.09), transparent 60%); mix-blend-mode:screen; opacity:0; transition:opacity 0.8s var(--ease); }
body.has-pointer .cursor-glow { opacity:1; }
.scroll-progress { position:fixed; top:0; left:0; right:0; height:2px; z-index:200; transform:scaleX(0); transform-origin:left center; will-change:transform; background:linear-gradient(90deg, var(--accent-2), var(--accent)); box-shadow:0 0 12px rgba(var(--glow),0.5); }

/* ----------  reveal: rise + blur to focus  ---------- */
.js .reveal { opacity:0; transform:translateY(42px); filter:blur(10px); transition:opacity var(--reveal-dur) var(--spring), transform var(--reveal-dur) var(--spring), filter var(--reveal-dur) var(--ease); transition-delay:calc(var(--d,0) * 100ms); }
.js .reveal.in { opacity:1; transform:none; filter:blur(0); }

/* ----------  typography  ---------- */
.display { font-family:var(--serif); font-weight:340; font-variation-settings:"opsz" 144,"SOFT" 0; line-height:0.98; letter-spacing:-0.02em; font-size:clamp(2.85rem,9vw,7rem); }
.statement { font-family:var(--serif); font-weight:360; font-variation-settings:"opsz" 80; line-height:1.08; letter-spacing:-0.015em; font-size:clamp(2rem,5vw,3.7rem); }
.section-title { font-family:var(--serif); font-weight:380; font-variation-settings:"opsz" 60; line-height:1.1; letter-spacing:-0.01em; font-size:clamp(1.7rem,3.6vw,2.85rem); max-width:22ch; }
.accent-em { color:var(--accent); font-style:italic; font-variation-settings:"opsz" 144,"wght" 360,"SOFT" 0; animation:breatheType 8s ease-in-out infinite; text-shadow:0 0 38px rgba(var(--glow),0.16); }
@keyframes breatheType { 0%,100% { font-variation-settings:"opsz" 144,"wght" 348,"SOFT" 0; } 50% { font-variation-settings:"opsz" 144,"wght" 392,"SOFT" 40; } }
.eyebrow, .kicker { font-family:var(--sans); text-transform:uppercase; letter-spacing:0.24em; font-size:0.74rem; font-weight:600; color:var(--accent); display:inline-flex; align-items:center; gap:0.7rem; }
.eyebrow::before, .kicker::before { content:""; width:1.8rem; height:1px; background:currentColor; opacity:0.5; }
.kicker { color:var(--muted); }
.lede { font-size:clamp(1.12rem,1.4vw,1.4rem); color:var(--ink-2); max-width:40ch; line-height:1.55; }

/* ----------  buttons (magnetic)  ---------- */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:0.5rem; font-family:var(--sans); font-weight:600; letter-spacing:0.01em; background:var(--accent); color:#1a1206; padding:0.85rem 1.5rem; border-radius:100px; border:1px solid transparent; transform:translate(var(--mx,0px), var(--my,0px)) scale(var(--bscale,1)); transition:transform 0.4s var(--spring), background 0.3s var(--ease), box-shadow 0.3s var(--ease); box-shadow:0 1px 0 rgba(255,255,255,0.18) inset, 0 10px 30px -12px rgba(var(--glow),0.6); }
.btn:hover { --bscale:1.03; filter:brightness(1.06); box-shadow:0 1px 0 rgba(255,255,255,0.22) inset, 0 18px 46px -12px rgba(var(--glow),0.72); }
.btn:active { --bscale:0.99; }
.btn-lg { padding:1rem 1.9rem; font-size:1.05rem; }
.btn-sm { padding:0.6rem 1.15rem; font-size:0.92rem; }
.btn-ghost { background:transparent; color:var(--ink); border-color:var(--line-strong); box-shadow:none; }
.btn-ghost:hover { --bscale:1.02; filter:none; background:rgba(var(--glow),0.06); border-color:var(--accent); color:var(--ink); box-shadow:none; }

/* ----------  nav + theme switch  ---------- */
.nav { position:sticky; top:0; z-index:100; -webkit-backdrop-filter:blur(7px); backdrop-filter:blur(7px); background:transparent; border-bottom:1px solid transparent; transition:border-color 0.5s var(--ease), background 0.5s var(--ease), -webkit-backdrop-filter 0.5s var(--ease), backdrop-filter 0.5s var(--ease); }
.nav.scrolled { border-bottom-color:var(--line); -webkit-backdrop-filter:blur(20px) saturate(140%); backdrop-filter:blur(20px) saturate(140%); background:var(--bg); background:color-mix(in srgb, var(--bg) 92%, transparent); }
.nav-inner { display:flex; align-items:center; gap:1.25rem; height:70px; }
.wordmark { font-family:var(--serif); font-weight:420; font-size:1.6rem; letter-spacing:-0.02em; color:var(--ink); }
.nav-links { display:flex; gap:1.6rem; margin-left:auto; }
.nav-links a { font-size:0.95rem; color:var(--ink-2); position:relative; padding:0.2rem 0; transition:color 0.25s var(--ease); }
.nav-links a::after { content:""; position:absolute; left:0; bottom:-2px; height:1.5px; width:0; background:var(--accent); transition:width 0.35s var(--spring); }
.nav-links a:hover { color:var(--ink); }
.nav-links a:hover::after { width:100%; }

.theme-switch { display:flex; gap:9px; align-items:center; }
.theme-dot { width:16px; height:16px; border-radius:50%; background:var(--s); border:2px solid transparent; cursor:pointer; padding:0; transition:transform 0.25s var(--spring), border-color 0.25s var(--ease); box-shadow:inset 0 0 0 1px rgba(0,0,0,0.35), 0 2px 6px rgba(0,0,0,0.3); }
.theme-dot:hover { transform:scale(1.22); }
.theme-dot[aria-pressed="true"] { border-color:var(--ink); transform:scale(1.1); }

/* ----------  hero  ---------- */
.hero { position:relative; min-height:100svh; display:flex; align-items:center; padding:8rem 0 6.5rem; overflow:hidden; }
.hero-glow { position:absolute; z-index:0; top:40%; left:66%; width:52rem; height:52rem; transform:translate(-50%,-50%); background:radial-gradient(circle, rgba(var(--glow),0.16), rgba(var(--glow),0.05) 38%, transparent 64%); filter:blur(22px); animation:breathe 10s ease-in-out infinite; }
@keyframes breathe { 0%,100% { transform:translate(-50%,-50%) scale(1); opacity:0.7; } 50% { transform:translate(-50%,-50%) scale(1.1); opacity:0.95; } }
.hero-inner { position:relative; z-index:2; max-width:56rem; }
.hero .eyebrow { margin-bottom:1.5rem; }
.hero h1 { margin-bottom:1.6rem; }
.hero .lede { margin-bottom:2.4rem; }
.cta-row { display:flex; flex-wrap:wrap; gap:0.9rem; align-items:center; }
.fineprint { margin-top:1.4rem; color:var(--muted); font-size:0.95rem; letter-spacing:0.02em; }
.scroll-hint { position:absolute; bottom:1.4rem; left:50%; transform:translateX(-50%); z-index:2; width:26px; height:42px; border:1.5px solid var(--line-strong); border-radius:14px; display:grid; place-items:start center; padding-top:7px; }
.scroll-hint span { width:4px; height:8px; border-radius:4px; background:var(--accent); animation:scrolldot 1.9s var(--ease) infinite; }
@keyframes scrolldot { 0% { opacity:0; transform:translateY(-3px); } 40% { opacity:1; } 80%,100% { opacity:0; transform:translateY(11px); } }

/* ----------  bands  ---------- */
.band { padding:clamp(5.5rem,13vh,10rem) 0; position:relative; }
.band-body { font-size:clamp(1.1rem,1.3vw,1.32rem); color:var(--ink-2); max-width:52ch; margin-top:1.6rem; line-height:1.6; }
.thesis .statement { max-width:20ch; }
.thesis { border-top:1px solid var(--line); border-bottom:1px solid var(--line); }

/* ----------  how it works  ---------- */
.how-grid { display:grid; grid-template-columns:1.05fr 0.95fr; gap:clamp(2.5rem,6vw,5rem); align-items:center; }
.steps { list-style:none; margin-top:2.2rem; display:grid; gap:2.4rem; }
.step-n { font-family:var(--serif); font-style:italic; font-size:1rem; color:var(--accent); letter-spacing:0.04em; display:block; margin-bottom:0.5rem; }
.steps h3 { font-family:var(--serif); font-weight:400; font-size:clamp(1.4rem,2.4vw,1.85rem); letter-spacing:-0.01em; line-height:1.15; margin-bottom:0.5rem; }
.steps p { color:var(--muted); max-width:34ch; }

.demo { display:flex; justify-content:center; perspective:1200px; }
.demo-card { width:100%; max-width:25rem; background:linear-gradient(165deg, var(--bg-3), var(--bg-2)); border:1px solid var(--line); border-radius:26px; padding:2rem 1.8rem 1.6rem; box-shadow:0 50px 90px -45px rgba(0,0,0,0.85), 0 0 0 1px rgba(var(--glow),0.04); position:relative; overflow:hidden; transform:rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)); transform-style:preserve-3d; transition:transform 0.4s var(--ease), background 0.6s var(--ease); }
.demo-card::before { content:""; position:absolute; top:-40%; right:-30%; width:75%; height:75%; background:radial-gradient(circle, rgba(var(--glow),0.18), transparent 65%); filter:blur(12px); opacity:0; transition:opacity 1.4s var(--ease); }
.demo-card.in::before { opacity:1; }
.demo-label { text-transform:uppercase; letter-spacing:0.2em; font-size:0.68rem; color:var(--muted); margin-bottom:0.9rem; position:relative; }
.demo-task { font-family:var(--serif); font-weight:420; font-size:1.7rem; line-height:1.1; color:#1a1206; background:var(--accent); padding:1.1rem 1.3rem; border-radius:16px; margin-bottom:1.5rem; box-shadow:0 16px 34px -16px rgba(var(--glow),0.72); transform-origin:center; position:relative; transform:scale(1.04); transition:transform 1s var(--spring); }
.demo-card.in .demo-task { transform:scale(1); }
.demo-steps { list-style:none; display:grid; gap:0.85rem; position:relative; }
.js .demo-steps li { display:flex; align-items:flex-start; gap:0.7rem; color:var(--ink-2); font-size:1rem; line-height:1.4; opacity:0; transform:translateY(16px) scale(0.96); filter:blur(6px); transition:opacity 0.7s var(--spring), transform 0.7s var(--spring), filter 0.7s var(--ease); }
.demo-steps .dot { flex:none; width:9px; height:9px; margin-top:0.45rem; border-radius:50%; border:1.5px solid var(--accent); }
.js .demo-foot { margin-top:1.4rem; color:var(--muted); font-size:0.85rem; letter-spacing:0.02em; position:relative; opacity:0; transition:opacity 0.8s var(--ease) 0.9s; }
.demo-card.in .demo-foot { opacity:1; }
.demo-card.in .demo-steps li { opacity:1; transform:none; filter:blur(0); }
.demo-card.in .demo-steps li:nth-child(1) { transition-delay:0.28s; }
.demo-card.in .demo-steps li:nth-child(2) { transition-delay:0.46s; }
.demo-card.in .demo-steps li:nth-child(3) { transition-delay:0.64s; }
.demo-card.in .demo-steps li:nth-child(4) { transition-delay:0.82s; }

/* ----------  pillars  ---------- */
.section-title + .pillars, .kicker + .section-title { margin-top:1rem; }
.pillars { margin-top:3rem; display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; }
.pillar { background:var(--bg); padding:2.2rem 1.9rem; transition:background 0.5s var(--ease); }
.pillar:hover { background:var(--bg-2); }
.ico { width:30px; height:30px; fill:none; stroke:var(--accent); stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; margin-bottom:1.1rem; }
.pillar h3 { font-family:var(--serif); font-weight:420; font-size:1.3rem; margin-bottom:0.5rem; letter-spacing:-0.005em; }
.pillar p { color:var(--muted); font-size:0.98rem; line-height:1.5; }

/* ----------  voice  ---------- */
.voice { text-align:center; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.voice-inner { display:grid; justify-items:center; gap:0.4rem; }
.voice .statement, .voice .band-body { margin-inline:auto; }
.voice .band-body { text-align:center; }
.voice-wave { display:flex; align-items:center; gap:6px; height:46px; margin-bottom:1.6rem; }
.voice-wave i { width:5px; height:14px; border-radius:4px; background:var(--accent); animation:eq 1.4s ease-in-out infinite; }
.voice-wave i:nth-child(2){animation-delay:0.12s} .voice-wave i:nth-child(3){animation-delay:0.24s} .voice-wave i:nth-child(4){animation-delay:0.36s} .voice-wave i:nth-child(5){animation-delay:0.48s} .voice-wave i:nth-child(6){animation-delay:0.6s} .voice-wave i:nth-child(7){animation-delay:0.72s}
@keyframes eq { 0%,100% { height:12px; opacity:0.5; } 50% { height:40px; opacity:1; } }

/* ----------  platforms  ---------- */
.platforms { margin-top:3rem; display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.plat { display:grid; gap:0.55rem; align-content:start; background:var(--bg-2); border:1px solid var(--line); border-radius:var(--r); padding:1.8rem; min-height:11rem; transition:transform 0.45s var(--spring), border-color 0.45s var(--ease), background 0.6s var(--ease); }
.plat.live:hover { transform:translateY(-5px); border-color:var(--accent); }
.plat-tag { justify-self:start; font-size:0.72rem; text-transform:uppercase; letter-spacing:0.16em; font-weight:700; color:var(--accent); background:rgba(var(--glow),0.1); padding:0.3rem 0.65rem; border-radius:100px; }
.plat-tag.soon { color:var(--muted); background:rgba(232,226,210,0.05); }
.plat-name { font-family:var(--serif); font-weight:420; font-size:1.7rem; margin-top:0.5rem; }
.plat-line { color:var(--muted); font-size:0.98rem; }
.plat.live { position:relative; }
.plat.live::after { content:"\2192"; position:absolute; top:1.6rem; right:1.6rem; color:var(--accent); font-size:1.2rem; opacity:0; transform:translateX(-6px); transition:opacity 0.35s var(--ease), transform 0.35s var(--spring); }
.plat.live:hover::after { opacity:1; transform:none; }

/* ----------  closer  ---------- */
.closer { text-align:center; overflow:hidden; position:relative; }
.closer-glow { position:absolute; bottom:-30%; left:50%; transform:translateX(-50%); width:55rem; height:40rem; background:radial-gradient(ellipse at center, rgba(var(--glow),0.16), transparent 62%); filter:blur(18px); animation:breathe 10s ease-in-out infinite; }
.closer-inner { position:relative; z-index:2; display:grid; justify-items:center; gap:1.6rem; }
.closer-title { margin-bottom:0.2rem; }
.closer .lede { text-align:center; }

/* ----------  footer  ---------- */
.footer { border-top:1px solid var(--line); padding:3.5rem 0; position:relative; z-index:2; }
.footer-inner { display:flex; flex-wrap:wrap; gap:1.5rem 3rem; align-items:center; justify-content:space-between; }
.footer-brand { display:flex; align-items:baseline; gap:0.9rem; }
.footer-brand .wordmark { font-size:1.4rem; }
.footer-brand p { color:var(--muted); font-style:italic; font-family:var(--serif); }
.footer-links { display:flex; gap:1.6rem; }
.footer-links a { color:var(--ink-2); font-size:0.95rem; transition:color 0.25s var(--ease); }
.footer-links a:hover { color:var(--accent); }
.footer-note { color:var(--muted); font-size:0.85rem; width:100%; padding-top:0.5rem; border-top:1px solid var(--line); margin-top:0.5rem; }

/* ----------  responsive  ---------- */
@media (max-width:860px) {
  .nav-links { display:none; }
  .theme-switch { margin-left:auto; }
  .how-grid { grid-template-columns:1fr; }
  .demo { order:-1; }
  .pillars { grid-template-columns:repeat(2,1fr); }
  .platforms { grid-template-columns:1fr; }
}
@media (max-width:520px) {
  .pillars { grid-template-columns:1fr; }
  .cta-row { flex-direction:column; align-items:stretch; }
  .cta-row .btn { width:100%; }
  .footer-inner { flex-direction:column; align-items:flex-start; }
  .theme-dot { width:18px; height:18px; }
}

/* ----------  reduced motion: calm means calm  ---------- */
@media (prefers-reduced-motion:reduce) {
  html { scroll-behavior:auto; }
  *, *::before, *::after { animation:none !important; transition:none !important; }
  .reveal { opacity:1 !important; transform:none !important; filter:none !important; }
  .demo-steps li, .demo-task, .demo-foot, .demo-card::before { opacity:1 !important; transform:none !important; filter:none !important; }
  .demo-card { transform:none !important; }
  .cursor-glow { display:none; }
  .hero-inner { transform:none !important; }
  .accent-em { text-shadow:none; }
  .hero-glow, .closer-glow { opacity:0.8; }
}

/* ============================================================
   Editorial layer: less landing page, more typeset manifesto.
   ============================================================ */

/* quiet secondary action, replaces the generic second pill */
.text-link { display:inline-flex; align-items:center; gap:0.4rem; font-family:var(--sans); font-weight:600; font-size:1.02rem; color:var(--ink-2); letter-spacing:0.01em; transition:color 0.25s var(--ease); }
.text-link::after { content:"\2192"; display:inline-block; transition:transform 0.3s var(--spring); }
.text-link:hover { color:var(--accent); }
.text-link:hover::after { transform:translateX(5px); }

/* chapter numerals on section kickers, like a book's volumes */
.kicker .ch { font-family:var(--serif); font-style:italic; font-weight:400; font-size:1.2em; color:var(--accent); text-transform:none; letter-spacing:0; }

/* drop cap: a literary opening to the thesis */
.dropcap::first-letter { font-family:var(--serif); font-weight:400; font-size:3.4em; line-height:0.74; float:left; margin:0.06em 0.14em 0 0; color:var(--accent); }

/* the principles, as a ruled editorial list with serif numerals */
.manifesto { margin-top:3rem; display:grid; grid-template-columns:repeat(2,1fr); column-gap:3.5rem; border-bottom:1px solid var(--line); }
.principle { display:flex; gap:1.3rem; align-items:flex-start; padding:1.6rem 0; border-top:1px solid var(--line); }
.principle .num { font-family:var(--serif); font-style:italic; font-weight:400; font-size:1.5rem; line-height:1.05; color:var(--accent); min-width:2.4rem; }
.principle .ptext { flex:1; }
.principle h3 { font-family:var(--serif); font-weight:420; font-size:1.22rem; letter-spacing:-0.005em; margin-bottom:0.3rem; }
.principle p { color:var(--muted); font-size:0.96rem; line-height:1.5; }

@media (max-width:740px) {
  .manifesto { grid-template-columns:1fr; column-gap:0; }
}
@media (max-width:520px) {
  .cta-row .text-link { width:auto; align-self:center; padding-top:0.4rem; }
}

/* footer: a quiet editorial sign off with ways to reach a human */
.footer-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:2rem 3rem; align-items:start; }
.footer-col { display:flex; flex-direction:column; gap:0.7rem; }
.footer-h { font-family:var(--sans); text-transform:uppercase; letter-spacing:0.18em; font-size:0.7rem; font-weight:700; color:var(--muted); margin-bottom:0.3rem; }
.footer-col a { color:var(--ink-2); font-size:0.96rem; transition:color 0.25s var(--ease); }
.footer-col a:hover { color:var(--accent); }
.footer-mail { display:flex; flex-direction:column; line-height:1.3; }
.footer-mail span { font-size:0.78rem; color:var(--muted); }
.footer-grid + .wrap .footer-note { width:100%; padding-top:1.5rem; margin-top:2rem; border-top:1px solid var(--line); color:var(--muted); font-size:0.85rem; }
@media (max-width:640px) { .footer-grid { grid-template-columns:1fr; gap:1.8rem; } }

/* first-view polish: keep the bar uncrowded on phones, and never let the scroll
   cue collide with hero content on short or landscape viewports. */
@media (max-width:680px) {
  .nav .btn { display:none; }              /* the hero's Download button is right below */
  .nav-inner { gap:1rem; }
}
@media (max-height:700px) {
  .scroll-hint { display:none; }
}
/* without JS, the page is fully visible (the .js gate above hides only when JS runs) */
.no-js-fallback { }

/* render-only-what-is-near: below-the-fold bands are skipped by layout and
   paint until the reader approaches them. The intrinsic size keeps the
   scrollbar honest. (The hero is excluded; it is the first paint.) */
section.band { content-visibility:auto; contain-intrinsic-size:auto 760px; }

/* ----------  legal pages (/privacy, /terms): the same typeset world, still  ---------- */
.legal-top { display:flex; justify-content:space-between; align-items:baseline; gap:1rem; max-width:780px; margin:0 auto; padding:1.7rem var(--pad) 0; }
.legal-wrap { max-width:780px; margin:0 auto; padding:2.2rem var(--pad) 4.5rem; }
.legal-wrap h1 { font-family:var(--serif); font-weight:380; font-variation-settings:"opsz" 60; font-size:clamp(2rem,5vw,3rem); letter-spacing:-0.015em; line-height:1.08; color:var(--ink); margin:0.5rem 0 1rem; }
.legal-wrap .lede { max-width:none; }
.legal-body { margin-top:1.2rem; }
.legal-body h3 { font-family:var(--serif); font-weight:420; font-size:1.18rem; letter-spacing:-0.005em; color:var(--ink); margin:2.1rem 0 0.35rem; }
.legal-body p { color:var(--ink-2); margin:0.55rem 0 0; line-height:1.66; }
.legal-body a { color:var(--accent); text-decoration:underline; text-underline-offset:3px; }
.legal-cross { margin-top:3rem; padding-top:1.5rem; border-top:1px solid var(--line); color:var(--muted); font-size:0.95rem; }
.legal-cross a { color:var(--accent); }
.legal-foot { max-width:780px; margin:0 auto; padding:0 var(--pad) 3rem; color:var(--muted); font-size:0.88rem; }
