/* ============================================================
   RAG bot — landing styles
   Warm light system, generous whitespace, Golos Text grotesque
   ============================================================ */

/* ------------------------------------------------------------
   Fonts — self-hosted Golos Text (OFL), woff2 subsets.
   Subsets: cyrillic + latin + latin-ext (latin-ext carries ₽ U+20BD).
   Weights 400/500/600/700 — the only ones used below.
   Regenerate with: node fonts/build.mjs
   ------------------------------------------------------------ */
@font-face{
  font-family:'Golos Text'; font-style:normal; font-weight:400; font-display:swap;
  src:url('fonts/Golos-Text-400-cyrillic.woff2') format('woff2');
  unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face{
  font-family:'Golos Text'; font-style:normal; font-weight:400; font-display:swap;
  src:url('fonts/Golos-Text-400-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face{
  font-family:'Golos Text'; font-style:normal; font-weight:400; font-display:swap;
  src:url('fonts/Golos-Text-400-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face{
  font-family:'Golos Text'; font-style:normal; font-weight:500; font-display:swap;
  src:url('fonts/Golos-Text-500-cyrillic.woff2') format('woff2');
  unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face{
  font-family:'Golos Text'; font-style:normal; font-weight:500; font-display:swap;
  src:url('fonts/Golos-Text-500-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face{
  font-family:'Golos Text'; font-style:normal; font-weight:500; font-display:swap;
  src:url('fonts/Golos-Text-500-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face{
  font-family:'Golos Text'; font-style:normal; font-weight:600; font-display:swap;
  src:url('fonts/Golos-Text-600-cyrillic.woff2') format('woff2');
  unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face{
  font-family:'Golos Text'; font-style:normal; font-weight:600; font-display:swap;
  src:url('fonts/Golos-Text-600-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face{
  font-family:'Golos Text'; font-style:normal; font-weight:600; font-display:swap;
  src:url('fonts/Golos-Text-600-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face{
  font-family:'Golos Text'; font-style:normal; font-weight:700; font-display:swap;
  src:url('fonts/Golos-Text-700-cyrillic.woff2') format('woff2');
  unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face{
  font-family:'Golos Text'; font-style:normal; font-weight:700; font-display:swap;
  src:url('fonts/Golos-Text-700-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face{
  font-family:'Golos Text'; font-style:normal; font-weight:700; font-display:swap;
  src:url('fonts/Golos-Text-700-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root{
  /* surfaces */
  --bg:        #FBF9F6;
  --bg-warm:   #F6F0E8;
  --surface:   #FFFFFF;

  /* ink */
  --ink:       #211D19;
  --ink-2:     #5E564C;
  --ink-3:     #938A7E;
  --hair:      #EAE3D9;
  --hair-soft: #F0EAE1;

  /* accent (terracotta) — overridden by Tweaks */
  --accent:        #C0613D;
  --accent-strong: color-mix(in oklab, var(--accent) 84%, #1a0e07);
  --accent-tint:   color-mix(in oklab, var(--accent) 12%, var(--bg));
  --accent-tint-2: color-mix(in oklab, var(--accent) 6%,  var(--surface));
  --accent-ink:    color-mix(in oklab, var(--accent) 70%, #160c05);
  --on-accent:     #fff;

  /* geometry */
  --radius: 20px;
  --radius-sm: 12px;
  --maxw: 1140px;
  --readw: 700px;

  --font: 'Golos Text', system-ui, -apple-system, 'Segoe UI', sans-serif;

  /* rhythm */
  --section-y: clamp(84px, 12vh, 168px);
}

*{ box-sizing:border-box; }

html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }

body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font);
  font-size:19px;
  line-height:1.65;
  font-weight:400;
  letter-spacing:-0.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

@media (prefers-reduced-motion: no-preference){
  html{ scroll-behavior:smooth; }
}

::selection{ background:var(--accent-tint); color:var(--accent-ink); }

/* ---------- layout primitives ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(22px,5vw,56px); }
.read{ max-width:var(--readw); }
.section{ padding-block:var(--section-y); }
.section--tight{ padding-block:clamp(56px,8vh,104px); }

/* hairline divider */
.rule{ height:1px; background:var(--hair); border:0; margin:0; }

/* ---------- type ---------- */
h1,h2,h3{ margin:0; font-weight:600; letter-spacing:-0.025em; line-height:1.08; color:var(--ink); }
p{ margin:0; }

.eyebrow{
  font-size:13px; font-weight:600; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--accent-ink); margin:0;
}
.kicker{
  font-size:13px; font-weight:600; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--ink-3); display:flex; align-items:center; gap:12px;
}
.kicker::before{ content:""; width:26px; height:1.5px; background:var(--accent); border-radius:2px; }

h1.hero-title{ font-size:clamp(2.4rem, 4.4vw, 3.7rem); font-weight:700; letter-spacing:-0.035em; line-height:1.04; }
h2.section-title{ font-size:clamp(2rem, 3.8vw, 3rem); letter-spacing:-0.03em; }
h3{ font-size:clamp(1.2rem,1.6vw,1.4rem); letter-spacing:-0.02em; }

.lead{ font-size:clamp(1.2rem,1.7vw,1.45rem); line-height:1.55; color:var(--ink-2); }
.muted{ color:var(--ink-2); }
.dim{ color:var(--ink-3); }
.accent{ color:var(--accent-ink); }
strong{ font-weight:600; color:var(--ink); }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  font:inherit; font-weight:600; font-size:1.02rem; letter-spacing:-0.01em;
  padding:1rem 1.6rem; border-radius:999px; border:1.5px solid transparent;
  cursor:pointer; text-decoration:none; line-height:1;
  transition:transform .18s cubic-bezier(.3,.7,.4,1), background .18s, box-shadow .18s, color .18s, border-color .18s;
}
.btn--primary{
  background:var(--accent); color:var(--on-accent);
  box-shadow:0 1px 2px rgba(60,30,12,.18), 0 10px 26px -12px color-mix(in oklab,var(--accent) 70%,transparent);
}
.btn--primary:hover{ background:var(--accent-strong); transform:translateY(-2px); box-shadow:0 2px 4px rgba(60,30,12,.2), 0 18px 36px -14px color-mix(in oklab,var(--accent) 72%,transparent); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--hair); }
.btn--ghost:hover{ border-color:var(--ink); transform:translateY(-2px); }
.btn .arr{ display:inline-flex; transition:transform .18s; }
.btn .arr svg{ width:1.15em; height:1.15em; display:block; }
.btn:hover .arr{ transform:translateX(3px); }

/* button + supporting microcopy */
.cta-group{ display:flex; flex-direction:column; gap:.85rem; align-items:flex-start; }
.cta-note{ font-size:.95rem; color:var(--ink-3); letter-spacing:0; }
.cta-note b{ color:var(--ink-2); font-weight:600; }

[data-btn="outline"] .btn--primary{
  background:transparent; color:var(--accent-ink);
  border-color:color-mix(in oklab,var(--accent) 45%,var(--hair));
  box-shadow:none;
}
[data-btn="outline"] .btn--primary:hover{ background:var(--accent-tint); border-color:var(--accent); }

/* ---------- sharp / soft corner tweak ---------- */
[data-corner="sharp"]{ --radius:5px; --radius-sm:4px; }
[data-corner="sharp"] .btn{ border-radius:6px; }

/* =====================================================
   HEADER
   ===================================================== */
.site-header{
  position:sticky; top:0; z-index:50;
  background:color-mix(in oklab, var(--bg) 82%, transparent);
  -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s, background .3s;
}
.site-header[data-stuck="1"]{ border-bottom-color:var(--hair); }
.site-header .wrap{ display:flex; align-items:center; justify-content:space-between; gap:24px; padding-block:18px; }
.brand{ display:inline-flex; align-items:center; gap:10px; font-weight:600; font-size:1.12rem; letter-spacing:-0.02em; color:var(--ink); text-decoration:none; }
.brand .dot{ width:13px; height:13px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 4px var(--accent-tint); }
.brand small{ font-weight:500; color:var(--ink-3); font-size:.78rem; letter-spacing:.02em; }
.header-cta{ display:flex; align-items:center; gap:22px; }
.header-cta a.txt{ color:var(--ink-2); text-decoration:none; font-size:.98rem; font-weight:500; }
.header-cta a.txt:hover{ color:var(--ink); }
.header-cta .btn{ padding:.7rem 1.15rem; font-size:.95rem; }
@media (max-width:760px){ .header-cta a.txt{ display:none; } }

/* =====================================================
   HERO  (3 layouts via [data-hero])
   ===================================================== */
.hero{ position:relative; overflow:hidden; padding-block:clamp(56px,8vh,108px) var(--section-y); }
.hero-grid{ display:grid; gap:clamp(40px,5vw,72px); align-items:center; }
.hero-copy{ display:flex; flex-direction:column; gap:1.7rem; max-width:36ch; }
.hero-copy .eyebrow{ margin-bottom:-.4rem; }
.hero-sub{ font-size:clamp(1.12rem,1.5vw,1.32rem); line-height:1.55; color:var(--ink-2); max-width:34ch; }
.hero-audience{ font-size:1rem; color:var(--ink-3); display:flex; align-items:center; gap:12px; }
.hero-audience::before{ content:""; flex:0 0 22px; height:1.5px; background:var(--hair); }
.hero-media{ position:relative; display:flex; justify-content:center; }

/* soft atmospheric wash behind hero */
.hero::before{
  content:""; position:absolute; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(60% 70% at 82% 18%, var(--accent-tint), transparent 70%),
    radial-gradient(50% 60% at 8% 92%, color-mix(in oklab,var(--accent) 5%,transparent), transparent 72%);
  opacity:.75;
}

/* hero flag — the master tagline as a soft pill */
.hero-flag{ align-self:flex-start; display:inline-flex; align-items:center; gap:9px;
  font-size:.92rem; font-weight:500; letter-spacing:-0.005em; color:var(--accent-ink);
  background:var(--accent-tint); padding:.5rem .9rem .5rem .8rem; border-radius:999px;
  border:1px solid color-mix(in oklab,var(--accent) 20%, transparent); }
.hero-flag .d{ width:8px; height:8px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 3px color-mix(in oklab,var(--accent) 22%,transparent); }

/* A — split */
[data-hero="a"] .hero-grid{ grid-template-columns: 1.02fr 0.98fr; }
/* B — centered */
[data-hero="b"] .hero-grid{ grid-template-columns:1fr; justify-items:center; text-align:center; max-width:1000px; margin-inline:auto; }
[data-hero="b"] .hero-copy{ align-items:center; max-width:none; }
[data-hero="b"] .hero-flag{ align-self:center; }
[data-hero="b"] .hero-copy .hero-title{ max-width:18ch; }
[data-hero="b"] .hero-sub{ max-width:52ch; }
[data-hero="b"] .hero-audience::before{ display:none; }
[data-hero="b"] .cta-group{ align-items:center; }
[data-hero="b"] .hero-media{ margin-top:clamp(36px,5vh,64px); width:100%; }
/* C — editorial / overlap */
[data-hero="c"] .hero-grid{ grid-template-columns:1.12fr 0.88fr; gap:clamp(32px,5vw,72px); align-items:end; }
[data-hero="c"] .hero-copy{ max-width:none; }
[data-hero="c"] .hero-copy .hero-title{ font-size:clamp(2.7rem,6.6vw,5.3rem); letter-spacing:-0.04em; max-width:13ch; }
[data-hero="c"] .hero-sub{ max-width:40ch; }
[data-hero="c"] .hero-media{ justify-content:flex-end; }
[data-hero="c"] .hero-media .chat{ max-width:392px; }
[data-hero="c"] .hero-media::before{
  content:""; position:absolute; right:-7%; top:-9%; bottom:-9%; width:80%; z-index:-1;
  background:var(--bg-warm); border-radius:var(--radius);
}

@media (max-width:860px){
  [data-hero] .hero-grid{ grid-template-columns:1fr !important; text-align:left; justify-items:stretch; }
  [data-hero] .hero-copy{ align-items:flex-start !important; max-width:none; }
  [data-hero] .hero-flag{ align-self:flex-start; }
  [data-hero] .cta-group{ align-items:flex-start !important; }
  [data-hero="c"] .hero-media{ justify-content:flex-start; }
  [data-hero="c"] .hero-media::before{ display:none; }
  .hero-media{ margin-top:8px; }
}

/* =====================================================
   CHAT WIDGET MOCKUP
   ===================================================== */
.chat{
  width:100%; max-width:412px; background:var(--surface);
  border:1px solid var(--hair); border-radius:24px;
  box-shadow:
    0 1px 0 #fff inset,
    0 2px 6px rgba(40,26,14,.05),
    0 30px 60px -28px rgba(60,38,20,.35);
  overflow:hidden; display:flex; flex-direction:column;
}
[data-corner="sharp"] .chat{ border-radius:8px; }
.chat-bar{
  display:flex; align-items:center; gap:11px; padding:14px 16px;
  border-bottom:1px solid var(--hair-soft);
  background:linear-gradient(var(--surface), color-mix(in oklab,var(--bg-warm) 40%, var(--surface)));
}
.chat-ava{ position:relative; width:38px; height:38px; border-radius:50%; flex:0 0 auto;
  background:radial-gradient(120% 120% at 30% 25%, color-mix(in oklab,var(--accent) 70%,#fff), var(--accent));
  display:grid; place-items:center; color:#fff; font-weight:700; font-size:1rem; box-shadow:0 4px 10px -4px color-mix(in oklab,var(--accent) 60%,transparent); }
.chat-ava i{ position:absolute; right:-1px; bottom:-1px; width:11px; height:11px; border-radius:50%; background:#37b24d; border:2.5px solid var(--surface); }
.chat-meta{ display:flex; flex-direction:column; line-height:1.25; }
.chat-meta b{ font-size:.96rem; font-weight:600; letter-spacing:-0.01em; }
.chat-meta span{ font-size:.78rem; color:var(--ink-3); display:flex; align-items:center; gap:5px; }
.chat-meta span::before{ content:""; width:6px; height:6px; border-radius:50%; background:#37b24d; }

.chat-body{ padding:20px 16px 8px; display:flex; flex-direction:column; gap:11px;
  background:
    linear-gradient(var(--bg) , var(--bg));
}
.msg{ max-width:84%; padding:11px 14px; font-size:.96rem; line-height:1.45; border-radius:18px; position:relative; }
.msg.bot{ align-self:flex-start; background:var(--surface); border:1px solid var(--hair); color:var(--ink); border-bottom-left-radius:6px; box-shadow:0 1px 2px rgba(40,26,14,.04); }
.msg.user{ align-self:flex-end; background:var(--accent); color:var(--on-accent); border-bottom-right-radius:6px; }
.msg.user.q{ background:color-mix(in oklab,var(--accent) 90%, #2a1206); }
.msg small{ display:block; font-size:.72rem; margin-top:5px; opacity:.55; letter-spacing:.01em; }
.msg .price{ font-weight:600; color:var(--accent-ink); }

/* contact-capture chip inside chat */
.capture{ align-self:flex-start; max-width:88%; margin-top:2px;
  border:1px dashed color-mix(in oklab,var(--accent) 40%, var(--hair)); border-radius:14px;
  background:var(--accent-tint-2); padding:10px 12px; display:flex; align-items:center; gap:10px; }
.capture .field{ flex:1; font-size:.86rem; color:var(--ink-3); background:var(--surface); border:1px solid var(--hair); border-radius:8px; padding:7px 10px; }
.capture .send{ width:32px; height:32px; flex:0 0 auto; border-radius:8px; background:var(--accent); color:#fff; display:grid; place-items:center; }

/* message entrance — only on the animated (hero) chat */
.chat-body.is-animated > *{ animation:msgIn .34s cubic-bezier(.3,.7,.4,1) both; }
@keyframes msgIn{ from{ opacity:0; transform:translateY(8px) scale(.98); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion: reduce){ .chat-body.is-animated > *{ animation:none; } }

.typing{ align-self:flex-start; display:flex; gap:4px; padding:12px 14px; background:var(--surface); border:1px solid var(--hair); border-radius:18px; border-bottom-left-radius:6px; }
.typing i{ width:7px; height:7px; border-radius:50%; background:var(--ink-3); opacity:.5; animation:blink 1.3s infinite both; }
.typing i:nth-child(2){ animation-delay:.18s; } .typing i:nth-child(3){ animation-delay:.36s; }
@keyframes blink{ 0%,60%,100%{ transform:translateY(0); opacity:.35; } 30%{ transform:translateY(-3px); opacity:.9; } }

.chat-input{ display:flex; align-items:center; gap:10px; padding:13px 16px 16px; border-top:1px solid var(--hair-soft); }
.chat-input .box{ flex:1; font-size:.9rem; color:var(--ink-3); background:var(--bg); border:1px solid var(--hair); border-radius:999px; padding:11px 15px; }
.chat-input .go{ width:40px; height:40px; flex:0 0 auto; border-radius:50%; background:var(--accent); color:#fff; display:grid; place-items:center; box-shadow:0 6px 14px -6px color-mix(in oklab,var(--accent) 65%,transparent); }

/* annotations around the demo chat */
.demo-stage{ position:relative; display:flex; justify-content:center; padding-block:8px; }
.demo-stage .chat{ max-width:440px; z-index:1; }
.anno{ position:absolute; max-width:210px; font-size:.92rem; line-height:1.4; color:var(--ink-2); display:none; }
.anno b{ color:var(--ink); font-weight:600; display:block; margin-bottom:2px; letter-spacing:-0.01em; }
.anno .tag{ display:inline-flex; align-items:center; gap:7px; font-size:.74rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--accent-ink); margin-bottom:7px; }
.anno .tag i{ width:18px; height:18px; border-radius:50%; background:var(--accent-tint); color:var(--accent-ink); display:grid; place-items:center; font-size:.7rem; font-style:normal; }
@media (min-width:1040px){
  .anno{ display:block; }
  .anno-1{ right:calc(50% + 232px); top:118px; text-align:right; }
  .anno-1 .tag{ flex-direction:row-reverse; }
  .anno-2{ left:calc(50% + 232px); bottom:96px; }
}

/* =====================================================
   GENERIC SECTION PIECES
   ===================================================== */
.section-head{ display:flex; flex-direction:column; gap:1.1rem; max-width:30ch; }
.section-head.center{ align-items:center; text-align:center; max-width:24ch; margin-inline:auto; }

/* big readable prose block */
.prose{ font-size:clamp(1.2rem,1.65vw,1.5rem); line-height:1.62; color:var(--ink-2); max-width:38ch; }
.prose strong{ color:var(--ink); font-weight:600; }

/* band with warm panel */
.band{ background:var(--bg-warm); }

/* ---------- "Что меняется" — flowing statement ---------- */
.shift{ display:grid; grid-template-columns:minmax(0,0.85fr) minmax(0,1.15fr); gap:clamp(36px,6vw,90px); align-items:start; }
@media (max-width:860px){ .shift{ grid-template-columns:1fr; gap:28px; } }

/* ---------- pains list ---------- */
.pains{ display:grid; grid-template-columns:minmax(0,0.8fr) minmax(0,1.2fr); gap:clamp(36px,6vw,90px); align-items:start; }
.pains-q{ font-size:clamp(1.5rem,2.4vw,2.1rem); font-weight:600; letter-spacing:-0.025em; line-height:1.2; color:var(--ink); max-width:16ch; }
.pain-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; }
.pain-list li{ display:flex; gap:18px; padding:22px 0; border-top:1px solid var(--hair); font-size:1.1rem; line-height:1.5; color:var(--ink-2); }
.pain-list li:last-child{ border-bottom:1px solid var(--hair); }
.pain-list li .n{ flex:0 0 auto; font-size:.82rem; font-weight:600; color:var(--accent-ink); font-variant-numeric:tabular-nums; padding-top:.35rem; min-width:1.6rem; letter-spacing:.04em; }
.pains .cta-group{ margin-top:2.6rem; }
@media (max-width:860px){ .pains{ grid-template-columns:1fr; gap:30px; } }

/* ---------- process / how we implement ---------- */
.how{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(40px,6vw,84px); align-items:start; }
.steps{ list-style:none; margin:0; padding:0; counter-reset:s; display:flex; flex-direction:column; gap:6px; }
.steps li{ display:flex; gap:18px; padding:18px 0; align-items:flex-start; }
.steps li .s{ counter-increment:s; flex:0 0 auto; width:38px; height:38px; border-radius:50%; border:1.5px solid var(--accent); color:var(--accent-ink); display:grid; place-items:center; font-weight:600; font-size:.95rem; }
.steps li .s::before{ content:counter(s); }
.steps li p{ font-size:1.05rem; line-height:1.5; color:var(--ink-2); padding-top:.35rem; }
.aside-note{ border:1px solid var(--hair); background:var(--surface); border-radius:var(--radius); padding:26px 28px; display:flex; flex-direction:column; gap:14px; }
[data-corner="sharp"] .aside-note{ border-radius:6px; }
.aside-note .tag{ display:inline-flex; align-items:center; gap:9px; font-size:.78rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--accent-ink); }
.aside-note .tag .shield{ width:22px; height:22px; border-radius:7px; background:var(--accent-tint); display:grid; place-items:center; color:var(--accent-ink); }
.aside-note p{ font-size:1.02rem; line-height:1.55; color:var(--ink-2); }
@media (max-width:860px){ .how{ grid-template-columns:1fr; gap:34px; } }

/* ---------- pricing: big figure + airy details ---------- */
.price-feature{ display:grid; grid-template-columns:1.05fr 0.95fr; gap:clamp(40px,6vw,92px); align-items:start; }
.price-hero .label, .price-line .label{ font-size:.85rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.price-big{ font-size:clamp(3.4rem,8vw,6.2rem); font-weight:700; letter-spacing:-0.045em; line-height:.92; color:var(--ink); margin-top:.55rem; }
.price-big span{ font-size:.3em; font-weight:600; color:var(--accent-ink); letter-spacing:-0.01em; margin-left:.12em; }
.price-hero-sub{ margin-top:1.5rem; font-size:1.12rem; line-height:1.55; color:var(--ink-2); max-width:32ch; }
.price-aside{ display:flex; flex-direction:column; gap:clamp(26px,3.4vw,42px); padding-left:clamp(0px,3vw,40px); border-left:1px solid var(--hair); }
.price-mid{ font-size:clamp(1.9rem,2.8vw,2.5rem); font-weight:700; letter-spacing:-0.03em; color:var(--ink); margin-top:.45rem; line-height:1; }
.price-mid span{ font-size:.42em; font-weight:600; color:var(--ink-3); }
.price-line .sub{ margin-top:.9rem; font-size:1rem; line-height:1.5; color:var(--ink-2); max-width:38ch; }
.price-aside .pricing-note{ margin-top:0; font-size:clamp(1.08rem,1.35vw,1.24rem); line-height:1.55; color:var(--ink-2); max-width:42ch; }
.price-aside .pricing-note strong{ color:var(--ink); font-weight:600; }
@media (max-width:860px){
  .price-feature{ grid-template-columns:1fr; gap:34px; }
  .price-aside{ border-left:0; padding-left:0; border-top:1px solid var(--hair); padding-top:32px; }
}

/* ---------- arrive / vision: three beats in rhythm ---------- */
.arrive-beats{ display:flex; flex-direction:column; }
.beat{ display:grid; grid-template-columns:auto 1fr; gap:clamp(22px,4vw,60px); align-items:start; padding:clamp(28px,3.8vw,48px) 0; border-top:1px solid var(--hair); }
.beat:last-child{ border-bottom:1px solid var(--hair); }
.beat-n{ font-size:.9rem; font-weight:600; color:var(--accent-ink); font-variant-numeric:tabular-nums; letter-spacing:.08em; padding-top:.85rem; }
.beat p{ font-size:clamp(1.4rem,2.3vw,2rem); font-weight:500; letter-spacing:-0.025em; line-height:1.3; color:var(--ink); max-width:30ch; text-wrap:balance; margin:0; }
.beat--final p{ color:var(--accent-ink); font-weight:600; }
@media (max-width:640px){ .beat{ grid-template-columns:1fr; gap:10px; } .beat-n{ padding-top:0; } }

/* ---------- testimonial ---------- */
.quote{ max-width:30ch; }
.quote-mark{ font-size:4rem; line-height:.6; color:var(--accent); font-weight:700; height:.5em; display:block; }
.quote blockquote{ margin:0; font-size:clamp(1.35rem,2.3vw,2rem); font-weight:500; letter-spacing:-0.02em; line-height:1.4; color:var(--ink); }
.quote .who{ margin-top:1.8rem; display:flex; align-items:center; gap:14px; }
.quote .who .av{ width:50px; height:50px; border-radius:50%; flex:0 0 auto; background:radial-gradient(120% 120% at 30% 25%, color-mix(in oklab,var(--accent) 55%,#fff), color-mix(in oklab,var(--accent) 88%,#000)); color:#fff; display:grid; place-items:center; font-weight:700; }
.quote .who div{ line-height:1.35; }
.quote .who b{ font-weight:600; color:var(--ink); display:block; }
.quote .who span{ color:var(--ink-3); font-size:.95rem; }
.quote-grid{ display:grid; grid-template-columns:1.4fr 1fr; gap:clamp(36px,6vw,80px); align-items:center; }
.metrics{ display:flex; flex-direction:column; gap:0; }
.metrics .m{ padding:20px 0; border-top:1px solid var(--hair); }
.metrics .m:last-child{ border-bottom:1px solid var(--hair); }
.metrics .m .v{ font-size:clamp(1.8rem,2.6vw,2.3rem); font-weight:700; letter-spacing:-0.03em; color:var(--accent-ink); line-height:1; }
.metrics .m .k{ font-size:.95rem; color:var(--ink-2); margin-top:7px; }
@media (max-width:860px){ .quote-grid{ grid-template-columns:1fr; gap:36px; } }

/* ---------- objections (FAQ) ---------- */
.faq{ display:flex; flex-direction:column; }
.faq-item{ padding:32px 0; border-top:1px solid var(--hair); display:grid; grid-template-columns:1fr 1.25fr; gap:clamp(28px,5vw,72px); align-items:start; }
.faq-item:last-child{ border-bottom:1px solid var(--hair); }
.faq-item .obj{ font-size:clamp(1.15rem,1.7vw,1.4rem); font-weight:600; letter-spacing:-0.02em; line-height:1.35; color:var(--ink); }
.faq-item .ans{ font-size:1.08rem; line-height:1.6; color:var(--ink-2); }
.faq-item .ans strong{ color:var(--ink); }
@media (max-width:760px){ .faq-item{ grid-template-columns:1fr; gap:14px; } }

/* ---------- comparison ---------- */
.compare{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.4vw,32px); }
.cmp{ background:var(--surface); border:1px solid var(--hair); border-radius:var(--radius); padding:clamp(28px,3vw,38px); display:flex; flex-direction:column; gap:20px; }
[data-corner="sharp"] .cmp{ border-radius:6px; }
.cmp-minus{ display:flex; gap:13px; font-size:1.04rem; line-height:1.5; color:var(--ink-3); }
.cmp-minus .ic{ flex:0 0 auto; width:24px; height:24px; border-radius:7px; background:var(--hair-soft); color:var(--ink-3); display:grid; place-items:center; margin-top:1px; }
.cmp-minus .ic svg{ width:13px; height:13px; }
.cmp-plus{ display:flex; gap:13px; font-size:1.1rem; line-height:1.5; color:var(--ink); font-weight:500; padding-top:20px; border-top:1px solid var(--hair-soft); }
.cmp-plus .ic{ flex:0 0 auto; width:24px; height:24px; border-radius:7px; background:var(--accent-tint); color:var(--accent-ink); display:grid; place-items:center; margin-top:1px; }
.cmp-plus .ic svg{ width:14px; height:14px; }
@media (max-width:860px){ .compare{ grid-template-columns:1fr; } }

/* =====================================================
   FINAL CTA
   ===================================================== */
.final{ position:relative; overflow:hidden; }
.final-card{ background:var(--ink); color:#fff; border-radius:calc(var(--radius) + 8px); padding:clamp(44px,6vw,84px); position:relative; overflow:hidden; }
[data-corner="sharp"] .final-card{ border-radius:8px; }
.final-card::before{ content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(70% 120% at 88% 8%, color-mix(in oklab,var(--accent) 60%,transparent), transparent 60%); opacity:.85; }
.final-card > *{ position:relative; }
.final-card .eyebrow{ color:color-mix(in oklab,var(--accent) 60%,#fff); }
.final-card h2{ color:#fff; font-size:clamp(2rem,3.6vw,2.9rem); max-width:18ch; margin-top:1rem; }
.final-card p{ color:rgba(255,255,255,.72); font-size:clamp(1.1rem,1.5vw,1.28rem); line-height:1.55; max-width:46ch; margin-top:1.3rem; }
.lead-form{ margin-top:2.4rem; display:flex; gap:12px; max-width:520px; flex-wrap:wrap; }
.lead-form input{ flex:1; min-width:220px; font:inherit; font-size:1.02rem; padding:1rem 1.3rem; border-radius:999px; border:1.5px solid rgba(255,255,255,.18); background:rgba(255,255,255,.06); color:#fff; outline:none; }
.lead-form input::placeholder{ color:rgba(255,255,255,.5); }
.lead-form input:focus{ border-color:var(--accent); background:rgba(255,255,255,.1); }
.lead-form .btn--primary{ box-shadow:none; }
[data-corner="sharp"] .lead-form input:not([type="checkbox"]), [data-corner="sharp"] .lead-form .btn{ border-radius:6px; }

.lead-form .consent{ flex-basis:100%; display:flex; gap:10px; align-items:flex-start;
  margin-top:.4rem; font-size:.86rem; line-height:1.45; color:rgba(255,255,255,.6); cursor:pointer; }
.lead-form .consent--optional{ margin-top:.1rem; }
.lead-form .consent input{ flex:0 0 auto; width:17px; height:17px; min-width:0; margin:.12rem 0 0;
  padding:0; border:0; border-radius:4px; background:none; accent-color:var(--accent); cursor:pointer; }
.lead-form .consent a{ color:rgba(255,255,255,.82); text-decoration:underline; text-underline-offset:2px; }
.lead-form .consent a:hover{ color:#fff; }
.lead-form .lead-status{ flex-basis:100%; margin:.6rem 0 0; font-size:.92rem; line-height:1.45; color:rgba(255,255,255,.82); }
.lead-form .lead-status.is-error{ color:#ff9b8c; }

.final-card .reassure{ margin-top:1.3rem; max-width:none; font-size:.92rem; color:rgba(255,255,255,.5); }

/* =====================================================
   FOOTER
   ===================================================== */
.site-footer{ padding-block:48px; }
.site-footer .wrap{ display:flex; flex-direction:column; gap:18px; }
.site-footer .foot-brand{ display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.site-footer .brand{ font-size:1rem; }
.site-footer small{ color:var(--ink-3); font-size:.88rem; }
.site-footer .foot-legal{ display:flex; gap:24px; flex-wrap:wrap; }
.site-footer .foot-legal a{ color:var(--ink-2); text-decoration:none; font-size:.9rem; }
.site-footer .foot-legal a:hover{ color:var(--accent); }
.site-footer .foot-req{ color:var(--ink-3); font-size:.84rem; line-height:1.6; }

/* =====================================================
   SCROLL REVEAL
   Content is always visible (no opacity gating) for robustness across
   throttled/paused render contexts. The .reveal class is kept as a hook.
   ===================================================== */
