/* ============================================================================
   Wallie — marketing site
   Editorial personal-finance site. Cream + coral + ink. Inter Tight / Geist Mono.
   ========================================================================== */

:root {
  --cream: #F5EDE0;  --cream-deep: #EFE4D2;  --paper: #FFF8EC;
  --ink: #1A1410;  --ink-soft: #3D2E24;  --ink-mid: #6B5849;  --ink-faint: rgba(26,20,16,0.45);
  --coral: #E8704A;  --coral-deep: #C9532E;  --coral-light: #F4A37E;
  --mint: #2F6A48;  --mint-deep: #1F5232;  --mint-soft: #7BB394;
  --butter: #F5C97A;
  --rule: rgba(26,20,16,0.10);  --rule-soft: rgba(26,20,16,0.055);

  --f-display: 'Inter Tight', system-ui, -apple-system, sans-serif;
  --f-sans: 'Inter Tight', system-ui, -apple-system, sans-serif;
  --f-mono: 'Geist Mono', ui-monospace, monospace;

  --maxw: 1200px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--cream); color: var(--ink); font-family: var(--f-sans); -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
::selection { background: var(--coral); color: var(--paper); }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 32px; }

/* ── Type primitives ─────────────────────────────────────────── */
.eyebrow { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--coral-deep); font-weight: 500; display: inline-flex; align-items: center; gap: 9px; }
.eyebrow::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--coral); }
.eyebrow.on-dark { color: var(--coral-light); }
.display { font-family: var(--f-display); font-weight: 400; letter-spacing: -0.04em; line-height: 0.98; margin: 0; }
.display em { font-style: italic; color: var(--coral-deep); }
.serif-i { font-style: italic; }
.num { font-family: var(--f-display); font-weight: 400; letter-spacing: -0.03em; font-variant-numeric: tabular-nums; }
.lede { font-size: 19px; line-height: 1.55; color: var(--ink-mid); }

/* ── Buttons ─────────────────────────────────────────────────── */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 9px; font-weight: 600; font-size: 15px; padding: 13px 24px; border-radius: 999px; border: none; transition: transform .16s ease, box-shadow .16s ease, background .16s; white-space: nowrap; }
.btn .arr { transition: transform .2s ease; }
.btn:hover .arr { transform: translateX(3px); }
.btn-ink { background: var(--ink); color: var(--cream); }
.btn-ink:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(26,20,16,0.22); }
.btn-coral { background: var(--coral); color: var(--paper); }
.btn-coral:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(201,83,46,0.32); }
.btn-ghost { background: transparent; color: var(--ink); border: 1.5px solid var(--rule); }
.btn-ghost:hover { border-color: var(--ink); }
.btn-sm { padding: 9px 17px; font-size: 13.5px; }

/* ── Nav ─────────────────────────────────────────────────────── */
.nav { position: sticky; top: 14px; z-index: 100; margin: 14px auto 0; max-width: var(--maxw); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; padding: 10px 12px 10px 22px; margin: 0 32px; background: rgba(255,248,236,0.72); backdrop-filter: blur(20px) saturate(1.4); -webkit-backdrop-filter: blur(20px) saturate(1.4); border: 1px solid var(--rule); border-radius: 999px; }
.nav-brand { display: flex; align-items: center; gap: 10px; font-family: var(--f-display); font-size: 20px; letter-spacing: -0.03em; }
.nav-brand .mark { width: 36px; height: 36px; border-radius: 10px; background: var(--coral); display: flex; align-items: center; justify-content: center; font-size: 17px; box-shadow: 0 3px 10px rgba(201,83,46,0.3); }
.nav-links { display: flex; gap: 2px; }
.nav-links a { padding: 9px 15px; border-radius: 999px; font-size: 14px; font-weight: 500; color: var(--ink-mid); transition: background .15s, color .15s; }
.nav-links a:hover { background: rgba(26,20,16,0.05); color: var(--ink); }
.nav-cta { display: flex; gap: 8px; align-items: center; }

/* ── Hero ────────────────────────────────────────────────────── */
.hero { padding: 72px 0 64px; }
.hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 56px; align-items: center; }
.hero-tag { display: inline-flex; align-items: center; gap: 9px; padding: 6px 14px 6px 7px; background: var(--paper); border: 1px solid var(--rule); border-radius: 999px; font-size: 12.5px; font-weight: 500; color: var(--ink-mid); margin-bottom: 26px; }
.hero-tag .badge { background: var(--mint); color: var(--paper); padding: 2px 9px; border-radius: 999px; font-size: 11px; font-weight: 600; letter-spacing: 0.02em; }
.hero h1 { font-family: var(--f-display); font-weight: 400; font-size: clamp(52px, 6.2vw, 86px); letter-spacing: -0.045em; line-height: 0.96; }
.hero h1 em { font-style: italic; color: var(--coral-deep); }
.hero .lede { margin: 26px 0 30px; max-width: 440px; }
.hero-ctas { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.hero-meta { margin-top: 30px; display: flex; gap: 22px; flex-wrap: wrap; font-size: 12.5px; color: var(--ink-mid); }
.hero-meta span { display: inline-flex; align-items: center; gap: 6px; }
.hero-meta .ck { color: var(--mint); font-weight: 700; }

/* Freedom card (hero visual) */
.freedom { background: var(--ink); border-radius: 28px; padding: 34px 34px 30px; color: var(--cream); position: relative; overflow: hidden; box-shadow: 0 30px 70px rgba(26,20,16,0.28); }
.freedom::before { content: ''; position: absolute; right: -90px; top: -90px; width: 280px; height: 280px; border-radius: 50%; background: radial-gradient(circle, rgba(232,112,74,0.42), transparent 70%); }
.freedom-head { display: flex; align-items: center; justify-content: space-between; position: relative; }
.freedom-head .lab { font-family: var(--f-mono); font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(245,237,224,0.6); }
.freedom-head .live { display: inline-flex; align-items: center; gap: 7px; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.12em; color: var(--coral-light); }
.freedom-head .live .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--coral); animation: pulse 1.8s ease-in-out infinite; }
@keyframes pulse { 0%,100% { opacity: 1; transform: scale(1); } 50% { opacity: .4; transform: scale(.7); } }
.freedom-q { font-family: var(--f-display); font-size: 22px; letter-spacing: -0.02em; line-height: 1.15; margin: 20px 0 22px; position: relative; }
.freedom-q em { font-style: italic; color: var(--coral-light); }
.countdown { display: flex; align-items: flex-start; gap: 8px; position: relative; }
.cd-unit { flex: 1; display: flex; flex-direction: column; align-items: center; }
.cd-unit .v { font-family: var(--f-display); font-weight: 400; font-size: clamp(46px, 6vw, 68px); letter-spacing: -0.05em; line-height: 0.84; font-variant-numeric: tabular-nums; }
.cd-unit .u { font-family: var(--f-mono); font-size: 9.5px; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(245,237,224,0.55); margin-top: 11px; }
.cd-sep { font-family: var(--f-display); font-size: 40px; color: rgba(245,237,224,0.25); line-height: 1; padding-top: 4px; }
.freedom-foot { margin-top: 26px; padding-top: 18px; border-top: 1px solid rgba(245,237,224,0.14); position: relative; }
.fp-bar { height: 7px; border-radius: 999px; background: rgba(245,237,224,0.12); overflow: hidden; }
.fp-bar i { display: block; height: 100%; width: 50%; border-radius: 999px; background: linear-gradient(90deg, var(--coral), var(--coral-light)); }
.fp-row { display: flex; justify-content: space-between; margin-top: 11px; font-family: var(--f-mono); font-size: 10.5px; letter-spacing: 0.06em; color: rgba(245,237,224,0.6); }
.fp-row b { color: var(--cream); }

/* ── Trust band ──────────────────────────────────────────────── */
.band { padding: 26px 0 8px; }
.band-inner { display: flex; align-items: center; justify-content: center; gap: 14px 44px; flex-wrap: wrap; padding-top: 26px; border-top: 1px solid var(--rule); }
.band-label { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-faint); }
.band-name { font-family: var(--f-display); font-weight: 500; font-size: 21px; letter-spacing: -0.02em; opacity: 0.5; }

/* ── Section scaffold ────────────────────────────────────────── */
section { scroll-margin-top: 90px; }
.sec { padding: 96px 0; }
.sec-head { max-width: 760px; }
.sec-title { font-family: var(--f-display); font-weight: 400; font-size: clamp(34px, 4.4vw, 54px); letter-spacing: -0.035em; line-height: 1.0; margin: 16px 0 0; }
.sec-title em { font-style: italic; color: var(--coral-deep); }
.sec-sub { font-size: 17px; line-height: 1.55; color: var(--ink-mid); margin: 18px 0 0; max-width: 540px; }

/* ── Shift (editorial statement) ─────────────────────────────── */
.shift { padding: 40px 0 96px; }
.shift-line { font-family: var(--f-display); font-weight: 400; font-size: clamp(36px, 5.2vw, 72px); letter-spacing: -0.04em; line-height: 1.02; max-width: 1000px; }
.shift-line .mut { color: var(--ink-faint); }
.shift-line em { font-style: italic; color: var(--coral-deep); }

/* ── Bento ───────────────────────────────────────────────────── */
.bento { display: grid; grid-template-columns: repeat(6, 1fr); grid-auto-rows: 240px; gap: 14px; margin-top: 52px; }
.cell { background: var(--paper); border: 1px solid var(--rule-soft); border-radius: 22px; padding: 26px; position: relative; overflow: hidden; display: flex; flex-direction: column; transition: transform .2s ease, box-shadow .2s ease; }
.cell:hover { transform: translateY(-3px); box-shadow: 0 18px 40px rgba(26,20,16,0.08); }
.cell .tag { font-family: var(--f-mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-mid); display: inline-flex; align-items: center; gap: 7px; }
.cell .tag::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--coral); }
.cell h3 { font-family: var(--f-display); font-weight: 400; font-size: 27px; letter-spacing: -0.025em; line-height: 1.05; margin: 12px 0 8px; }
.cell h3 em { font-style: italic; color: var(--coral-deep); }
.cell p { font-size: 14px; line-height: 1.5; color: var(--ink-mid); margin: 0; }
.cell .art { margin-top: auto; padding-top: 18px; }
.cell.dark { background: var(--ink); color: var(--cream); }
.cell.dark h3 { color: var(--cream); }
.cell.dark p { color: rgba(245,237,224,0.66); }
.cell.dark .tag { color: var(--coral-light); }
.cell.coral { background: var(--coral); color: var(--paper); }
.cell.coral h3 { color: var(--paper); }
.cell.coral p { color: rgba(255,248,236,0.88); }
.cell.coral .tag { color: rgba(255,248,236,0.85); }
.cell.coral .tag::before { background: var(--paper); }
.c-net { grid-column: span 4; grid-row: span 2; }
.c-count { grid-column: span 2; grid-row: span 2; }
.c-dial { grid-column: span 2; }
.c-ask { grid-column: span 2; }
.c-trust { grid-column: span 2; }
.c-pulse { grid-column: span 3; }
.c-coast { grid-column: span 3; }

/* bento art */
.bignum { font-family: var(--f-display); font-weight: 400; font-size: 62px; letter-spacing: -0.04em; line-height: 1; }
.bignum em { font-style: italic; color: var(--coral-deep); }
.dark .bignum em, .coral .bignum em { color: var(--coral-light); }
.acct-row { display: flex; flex-wrap: wrap; gap: 7px; }
.acct-chip { padding: 7px 12px; border-radius: 999px; font-size: 12.5px; display: inline-flex; align-items: center; gap: 7px; white-space: nowrap; background: var(--cream); border: 1px solid var(--rule); }
.acct-chip .d { width: 7px; height: 7px; border-radius: 50%; }
.nw-line { display: flex; align-items: flex-end; gap: 18px; }
.nw-line .big { font-family: var(--f-display); font-weight: 400; font-size: clamp(44px, 5vw, 64px); letter-spacing: -0.04em; line-height: 0.9; font-variant-numeric: tabular-nums; }
.nw-line .up { font-family: var(--f-mono); font-size: 12px; color: var(--mint); padding-bottom: 6px; }
.pulse-bars { display: flex; gap: 3px; height: 56px; align-items: flex-end; }
.pulse-bars i { flex: 1; border-radius: 3px 3px 0 0; background: var(--coral); }
.mini-count { display: flex; gap: 6px; align-items: baseline; }
.mini-count .v { font-family: var(--f-display); font-size: 40px; letter-spacing: -0.04em; line-height: 0.9; }
.mini-count .u { font-family: var(--f-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(245,237,224,0.6); }
.mini-ask { background: rgba(26,20,16,0.04); border: 1px solid var(--rule); border-radius: 12px; padding: 11px 13px; font-size: 13px; color: var(--ink-mid); display: flex; align-items: center; gap: 9px; }
.mini-ask .mk { width: 24px; height: 24px; border-radius: 7px; background: var(--coral); flex-shrink: 0; }
.coast-row { display: flex; align-items: center; gap: 10px; }
.coast-row + .coast-row { margin-top: 9px; }
.coast-dot { width: 22px; height: 22px; border-radius: 50%; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.coast-dot.done { background: var(--coral); color: var(--paper); }
.coast-dot.todo { border: 1.5px dashed var(--ink-faint); }
.coast-row .t { font-size: 13.5px; font-weight: 500; }
.coast-row .a { margin-left: auto; font-family: var(--f-display); font-size: 16px; letter-spacing: -0.02em; }

/* ── Dial showpiece ──────────────────────────────────────────── */
.dial-sec { background: var(--ink); color: var(--cream); border-radius: 36px; margin: 0 32px; padding: 80px 0; position: relative; overflow: hidden; }
.dial-sec::before { content: ''; position: absolute; left: -120px; bottom: -120px; width: 380px; height: 380px; border-radius: 50%; background: radial-gradient(circle, rgba(232,112,74,0.28), transparent 70%); }
.dial-wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 48px; display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 56px; align-items: center; position: relative; }
.dial-sec .sec-title { color: var(--cream); }
.dial-sec .sec-title em { color: var(--coral-light); }
.dial-sec .sec-sub { color: rgba(245,237,224,0.66); }
.dial-readout { margin-top: 30px; display: flex; align-items: center; gap: 18px; }
.dial-readout .age { font-family: var(--f-display); font-size: 96px; letter-spacing: -0.05em; line-height: 0.82; color: var(--coral-light); font-variant-numeric: tabular-nums; }
.dial-readout .meta .l { font-family: var(--f-mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(245,237,224,0.55); }
.dial-readout .meta .in { font-family: var(--f-display); font-size: 22px; letter-spacing: -0.02em; margin-top: 6px; }
.dial-readout .meta .delta { font-size: 13.5px; color: var(--mint-soft); margin-top: 4px; }
.dial-stage { display: flex; flex-direction: column; align-items: center; }
.dial-svg { width: 100%; max-width: 380px; cursor: grab; touch-action: none; }
.dial-svg:active { cursor: grabbing; }
.dial-hint { font-family: var(--f-mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(245,237,224,0.4); margin-top: 6px; }
.dial-curve { width: 100%; max-width: 460px; margin-top: 8px; }

/* ── Proof ───────────────────────────────────────────────────── */
.proof-grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.proof-cell { padding: 40px 22px; border-right: 1px solid var(--rule); }
.proof-cell:last-child { border-right: none; }
.proof-cell .n { font-family: var(--f-display); font-weight: 400; font-size: 58px; letter-spacing: -0.035em; line-height: 1; }
.proof-cell .n em { font-style: italic; color: var(--coral-deep); }
.proof-cell .l { font-size: 13.5px; color: var(--ink-mid); margin-top: 12px; line-height: 1.45; }

/* ── Roadmap ─────────────────────────────────────────────────── */
.road-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 56px; }
.road-list { background: var(--rule-soft); border-radius: 18px; overflow: hidden; display: flex; flex-direction: column; gap: 1px; }
.road-row { background: var(--paper); padding: 18px 22px; display: flex; align-items: center; gap: 18px; }
.road-row .when { font-family: var(--f-mono); font-size: 11px; font-weight: 500; letter-spacing: 0.06em; color: var(--coral-deep); width: 64px; flex-shrink: 0; }
.road-row .what { font-family: var(--f-display); font-size: 17px; letter-spacing: -0.015em; flex: 1; }
.road-row .pill { font-family: var(--f-mono); font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase; padding: 4px 9px; border-radius: 999px; }
.pill.live { background: var(--mint); color: var(--paper); }
.pill.beta { background: rgba(232,112,74,0.14); color: var(--coral-deep); }
.pill.soon { background: rgba(26,20,16,0.06); color: var(--ink-mid); }

/* ── Trust cards ─────────────────────────────────────────────── */
.trust-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 44px; }
.trust-card { background: var(--paper); border: 1px solid var(--rule-soft); border-radius: 18px; padding: 28px; }
.trust-card .ico { width: 40px; height: 40px; border-radius: 11px; background: var(--cream); border: 1px solid var(--rule); display: flex; align-items: center; justify-content: center; margin-bottom: 18px; color: var(--coral-deep); }
.trust-card h3 { font-family: var(--f-display); font-weight: 400; font-size: 20px; letter-spacing: -0.02em; margin: 0 0 8px; }
.trust-card p { font-size: 14px; line-height: 1.55; color: var(--ink-mid); margin: 0; }

/* ── Final CTA ───────────────────────────────────────────────── */
.final { padding: 110px 0; text-align: center; }
.final .mk { width: 72px; height: 72px; border-radius: 21px; background: var(--coral); display: inline-flex; align-items: center; justify-content: center; font-size: 36px; box-shadow: 0 14px 34px rgba(201,83,46,0.34); }
.final h2 { font-family: var(--f-display); font-weight: 400; font-size: clamp(48px, 6.5vw, 88px); letter-spacing: -0.045em; line-height: 0.96; margin: 28px 0 0; }
.final h2 em { font-style: italic; color: var(--coral-deep); }
.final p { font-size: 17px; color: var(--ink-mid); max-width: 440px; margin: 20px auto 30px; line-height: 1.55; }
.final-form { display: flex; gap: 8px; max-width: 460px; margin: 0 auto; padding: 7px; background: var(--paper); border: 1px solid var(--rule); border-radius: 999px; }
.final-form input { flex: 1; padding: 11px 18px; border: none; background: transparent; font-size: 15px; font-family: inherit; outline: none; color: var(--ink); }
.final-form input::placeholder { color: var(--ink-faint); }

/* ── Footer ──────────────────────────────────────────────────── */
.footer { padding: 44px 0 56px; border-top: 1px solid var(--rule); margin-top: 40px; }
.footer-inner { display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; font-size: 13.5px; color: var(--ink-mid); }
.footer-brand { display: flex; align-items: center; gap: 9px; font-family: var(--f-display); font-size: 17px; }
.footer-links { display: flex; gap: 22px; flex-wrap: wrap; }
.footer-links a:hover { color: var(--ink); }

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 920px) {
  .nav-links { display: none; }
  .hero-grid, .dial-wrap, .road-grid { grid-template-columns: 1fr; gap: 40px; }
  .bento { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 200px; }
  .c-net, .c-count, .c-dial, .c-ask, .c-trust, .c-pulse, .c-coast { grid-column: span 2; grid-row: span 1; }
  .c-net, .c-count { grid-row: span 1; }
  .proof-grid { grid-template-columns: 1fr 1fr; }
  .proof-cell:nth-child(2n) { border-right: none; }
  .proof-cell:nth-child(-n+2) { border-bottom: 1px solid var(--rule); }
  .trust-grid { grid-template-columns: 1fr; }
  .dial-sec { margin: 0 16px; border-radius: 28px; }
  .dial-wrap { padding: 0 28px; }
}
@media (max-width: 560px) {
  .wrap { padding: 0 18px; }
  .nav-inner { margin: 0 16px; }
  .sec { padding: 64px 0; }
  .bento { grid-template-columns: 1fr; }
  .c-net, .c-count, .c-dial, .c-ask, .c-trust, .c-pulse, .c-coast { grid-column: span 1; }
  .proof-grid { grid-template-columns: 1fr; }
  .proof-cell { border-right: none; border-bottom: 1px solid var(--rule); }
  .final-form { flex-direction: column; border-radius: 20px; }
  .final-form .btn { width: 100%; }
  .dial-readout .age { font-size: 72px; }
}

/* ════════════════════════════════════════════════════════════════
   FEATURES PAGE
   ════════════════════════════════════════════════════════════════ */

/* page intro */
.page-intro { padding: 72px 0 8px; }
.page-intro h1 { font-family: var(--f-display); font-weight: 400; font-size: clamp(44px, 5.6vw, 76px); letter-spacing: -0.045em; line-height: 0.98; margin: 18px 0 0; }
.page-intro h1 em { font-style: italic; color: var(--coral-deep); }
.page-intro .lede { margin-top: 22px; max-width: 480px; }

/* feature index strip */
.feat-index { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 36px; padding-bottom: 8px; }
.feat-index a { display: inline-flex; align-items: center; gap: 8px; padding: 8px 15px; border-radius: 999px; background: var(--paper); border: 1px solid var(--rule); font-size: 13.5px; font-weight: 500; color: var(--ink-mid); transition: border-color .15s, color .15s, transform .15s; }
.feat-index a:hover { border-color: var(--ink); color: var(--ink); transform: translateY(-1px); }
.feat-index a .ix { font-family: var(--f-mono); font-size: 11px; color: var(--coral-deep); }

/* alternating feature rows */
.feature { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; padding: 80px 0; border-top: 1px solid var(--rule); scroll-margin-top: 96px; }
.feature .feature-copy .ix { font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.18em; color: var(--coral-deep); }
.feature .feature-copy h2 { font-family: var(--f-display); font-weight: 400; font-size: clamp(30px, 3.6vw, 44px); letter-spacing: -0.035em; line-height: 1.02; margin: 14px 0 0; }
.feature .feature-copy h2 em { font-style: italic; color: var(--coral-deep); }
.feature .feature-copy p { font-size: 16.5px; line-height: 1.6; color: var(--ink-mid); margin: 18px 0 0; max-width: 460px; }
.feat-points { margin: 22px 0 0; display: flex; flex-direction: column; gap: 11px; }
.feat-points li { list-style: none; display: flex; gap: 11px; align-items: flex-start; font-size: 14.5px; line-height: 1.45; color: var(--ink-soft); }
.feat-points .ck { color: var(--mint); font-weight: 700; flex-shrink: 0; margin-top: 1px; }
.feature.rev .feature-media { order: -1; }

/* feature media card */
.feat-card { background: var(--paper); border: 1px solid var(--rule-soft); border-radius: 24px; padding: 30px; box-shadow: 0 20px 50px rgba(26,20,16,0.07); }
.feat-card.dark { background: var(--ink); color: var(--cream); }
.feat-card.dark .nw-line .big { color: var(--cream); }
.feat-lab { font-family: var(--f-mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-mid); }
.feat-card.dark .feat-lab { color: rgba(245,237,224,0.55); }

/* static countdown (presentational, on features) */
.cd-static { display: flex; align-items: flex-start; gap: 8px; margin-top: 18px; }

/* chat mock */
.chat { display: flex; flex-direction: column; gap: 12px; }
.chat-row { display: flex; gap: 10px; align-items: flex-end; }
.chat-row.me { justify-content: flex-end; }
.bub { padding: 11px 15px; border-radius: 16px; font-size: 14px; line-height: 1.4; max-width: 82%; }
.bub.them { background: var(--cream); border: 1px solid var(--rule); border-bottom-left-radius: 5px; }
.bub.me { background: var(--ink); color: var(--cream); border-bottom-right-radius: 5px; }
.bub.them b { color: var(--coral-deep); }
.chat-mk { width: 34px; height: 34px; border-radius: 9px; background: var(--coral); flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: 16px; }

/* categories */
.cats { margin-top: 4px; }
.cat { margin-top: 14px; }
.cat-top { display: flex; justify-content: space-between; font-size: 13.5px; margin-bottom: 6px; }
.cat-top b { font-weight: 500; }
.cat-top .v { font-family: var(--f-display); letter-spacing: -0.01em; }
.cat-track { height: 7px; border-radius: 999px; background: rgba(232,112,74,0.12); overflow: hidden; }
.cat-fill { height: 100%; border-radius: 999px; background: var(--coral); }

/* dial on features: keep dial-sec but allow standalone */
.feature .dial-svg { max-width: 320px; }

@media (max-width: 920px) {
  .feature { grid-template-columns: 1fr; gap: 36px; padding: 56px 0; }
  .feature.rev .feature-media { order: 0; }
}

/* ── Request access modal ── */
.ra-overlay { position: fixed; inset: 0; z-index: 9999; background: rgba(0,0,0,0.55); display: flex; align-items: center; justify-content: center; padding: 20px; backdrop-filter: blur(4px); animation: raFadeIn 0.2s ease; }
@keyframes raFadeIn { from { opacity: 0; } to { opacity: 1; } }
.ra-modal { position: relative; background: var(--cream, #F5EDE0); border-radius: 20px; padding: 40px 36px; max-width: 420px; width: 100%; box-shadow: 0 30px 80px rgba(0,0,0,0.3); }
.ra-close { position: absolute; top: 14px; right: 18px; background: none; border: none; font-size: 26px; color: var(--ink-mid, #6B5849); cursor: pointer; line-height: 1; }
.ra-title { font-family: var(--f-sans); font-weight: 700; font-size: 22px; letter-spacing: -0.02em; margin: 0 0 8px; color: var(--ink, #1A1410); }
.ra-sub { font-size: 14px; color: var(--ink-mid, #6B5849); margin: 0 0 20px; line-height: 1.5; }
.ra-form { display: flex; gap: 10px; }
.ra-input { flex: 1; padding: 12px 16px; border-radius: 12px; border: 1.5px solid rgba(26,20,16,0.1); background: #fff; font-size: 15px; font-family: var(--f-sans); color: var(--ink, #1A1410); outline: none; transition: border-color 0.15s; }
.ra-input:focus { border-color: var(--coral, #E8704A); }
.ra-submit { padding: 12px 22px; border-radius: 12px; border: none; background: var(--coral, #E8704A); color: #fff; font-size: 14px; font-weight: 600; font-family: var(--f-sans); cursor: pointer; white-space: nowrap; transition: background 0.15s; }
.ra-submit:hover { background: var(--coral-deep, #C9532E); }
.ra-submit:disabled { opacity: 0.6; cursor: default; }
.ra-submit[aria-busy="true"] .ra-submit-label::after {
  content: "";
  display: inline-block;
  width: 14px;
  height: 14px;
  margin-left: 8px;
  vertical-align: -2px;
  border: 2px solid rgba(255,255,255,0.35);
  border-top-color: #fff;
  border-radius: 50%;
  animation: raSpin 0.7s linear infinite;
}
@keyframes raSpin { to { transform: rotate(360deg); } }
.ra-msg { margin: 16px 0 0; font-size: 14px; line-height: 1.4; }
.ra-msg--ok { color: var(--mint, #2F6A48); }
.ra-msg--err { color: var(--coral-deep, #C9532E); }
@media (max-width: 500px) {
  .ra-modal { padding: 30px 24px; }
  .ra-form { flex-direction: column; }
}

/* ── Cookie notice ── */
.cookie-notice {
  position: fixed;
  bottom: 16px;
  left: 16px;
  right: 16px;
  max-width: 520px;
  margin: 0 auto;
  z-index: 9000;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 14px;
  background: var(--cream, #F5EDE0);
  border: 1px solid rgba(26,20,16,0.1);
  box-shadow: 0 12px 40px rgba(0,0,0,0.12);
  font-size: 13px;
  color: var(--ink-mid, #6B5849);
}
.cookie-notice p { margin: 0; flex: 1; line-height: 1.45; }
.cookie-notice a { color: var(--coral-deep, #C9532E); text-decoration: underline; }
.cookie-notice__ok {
  flex-shrink: 0;
  padding: 8px 14px;
  border: none;
  border-radius: 10px;
  background: var(--coral, #E8704A);
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  font-family: var(--f-sans);
  cursor: pointer;
}

