/* ============================================================
   KettleIQ — marketing site styles
   Brand: Space Black #020617, Electric Cyan #061CD4, Cyan Glow #22D3EE
   Font: Söhne → Plus Jakarta Sans → Inter fallback
   ============================================================ */
:root{
  --font-sans:'Söhne','Plus Jakarta Sans','Inter',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --font-mono:'JetBrains Mono','Fira Code',ui-monospace,monospace;
  --ink:#08080a;
  --ink-2:#1a2333;
  --paper:#fbfaf7;
  --paper-2:#f2efe9;
  --line:#e5e1d8;
  --line-dk:#1f2937;
  --muted:#6b7280;
  --muted-dk:#8a93a4;
  /* accent = bright teal cyan */
  --amber:#15C5E8;          /* primary teal-cyan (kept var name for churn) */
  --amber-glow:#1AD6F0;     /* bright glow cyan */
  --cyan:#15C5E8;
  --burgundy:#6b163f;
  --radius-lg:22px;
  --radius-md:14px;
  --radius-sm:10px;
  --max:1280px;
  --pad:clamp(18px,4vw,40px);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
/* scroll-behavior:smooth removed — it was hijacking wheel input and causing
   runaway scroll. Native wheel scroll is 1:1 and feels correct. */
body{
  font-family:var(--font-sans);
  font-feature-settings:"ss01","cv11";
}
.serif-italic{
  font-family:'Fraunces','Playfair Display',Georgia,serif;
  font-style:italic;
  font-weight:400;
  letter-spacing:-.01em;
}
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  font-size:17px;
  line-height:1.5;
  overflow-x:hidden;
}
img,video,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--amber);color:#fff}

/* ---------- Utilities ---------- */
.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.section{padding:clamp(72px,10vw,140px) 0;position:relative}
.section.tight{padding:clamp(48px,6vw,90px) 0}
.eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--amber);display:inline-flex;align-items:center;gap:10px;margin:0 0 18px}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--amber);box-shadow:0 0 12px var(--amber-glow)}
.dark .eyebrow{color:var(--amber-glow)}
.dark .eyebrow::before{box-shadow:0 0 18px var(--amber-glow)}

h1,h2,h3,h4{margin:0;font-weight:600;letter-spacing:-.025em;line-height:1.02}
h1{font-size:clamp(44px,7.5vw,120px);line-height:1;letter-spacing:-.04em;font-weight:800}
h2{font-size:clamp(34px,5vw,72px);letter-spacing:-.028em}
h3{font-size:clamp(22px,2.4vw,32px);letter-spacing:-.015em;line-height:1.15}
p{margin:0}

/* ---------- Dark sections ---------- */
.dark{background:var(--ink);color:#fff}
.dark .eyebrow{color:var(--amber-glow)}
.dark .muted{color:var(--muted-dk)}
.muted{color:var(--muted)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:18px 28px;border-radius:999px;
  font-weight:500;font-size:20px;letter-spacing:-.005em;
  transition:transform .25s cubic-bezier(.2,.8,.2,1),background .25s,color .25s,box-shadow .25s;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:var(--amber);color:#fff;box-shadow:0 10px 30px -10px rgba(194,79,12,.5)}
.btn-amber{background:var(--amber-glow);color:#042b33;font-weight:600}
.btn-amber:hover{background:#3ce0f5;box-shadow:0 14px 40px -12px rgba(26,214,240,.55)}
.btn-cyan{background:#06B6D4;color:#020617;font-weight:600}
.btn-cyan:hover{background:#38BDF8;box-shadow:0 10px 40px -10px rgba(6,182,212,.6)}
.btn-ghost{background:transparent;color:inherit;border:1px solid currentColor;opacity:.95}
.btn-ghost:hover{background:rgba(0,0,0,.06)}
.dark .btn-ghost:hover{background:rgba(255,255,255,.08)}
.btn-white{background:#fff;color:var(--ink)}
.btn svg{width:16px;height:16px}
.btn-arrow{position:relative;transition:padding .25s}
.btn-arrow .arr{transition:transform .3s}
.btn-arrow:hover .arr{transform:translateX(4px)}

/* ---------- Navbar ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:14px var(--pad);
  display:flex;align-items:center;justify-content:space-between;
  transition:background .3s,backdrop-filter .3s,border-color .3s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(5,5,10,.85);
  backdrop-filter:blur(18px) saturate(1.3);
  -webkit-backdrop-filter:blur(18px) saturate(1.3);
  border-bottom-color:rgba(255,255,255,.08);
}
.nav .logo{font-weight:600;font-size:22px;letter-spacing:-.02em;color:#fff;mix-blend-mode:difference}
.nav .logo .q{color:var(--amber-glow);font-weight:700;font-style:normal}
.nav-links{display:flex;align-items:center;gap:6px;color:#fff;mix-blend-mode:difference}
.nav-links a{padding:8px 14px;border-radius:999px;font-size:15px;font-weight:450;opacity:.9;transition:opacity .2s,background .2s}
.nav-links a:hover{opacity:1;background:rgba(255,255,255,.08)}
.nav-cta{display:flex;gap:10px;align-items:center}
@media (max-width:900px){.nav-links{display:none}}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:100vh;min-height:100svh;
  background:#05050a;color:#fff;overflow:hidden;
  display:flex;flex-direction:column;justify-content:center;
  padding-top:160px;padding-bottom:120px;
}
.hero-video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;opacity:.55;z-index:0;
  filter:contrast(1.05) saturate(1.1);
  transform:scale(1.08);
}
.hero::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(120% 80% at 70% 30%, transparent 0%, rgba(5,5,10,.6) 60%, rgba(5,5,10,.95) 100%),
    linear-gradient(180deg,rgba(5,5,10,.2) 0%, rgba(5,5,10,.1) 40%, rgba(5,5,10,.95) 100%);
  z-index:1;pointer-events:none;
}
.hero > .container{position:relative;z-index:2;width:100%;max-width:1300px;margin:0 auto}
.hero-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:4vw;align-items:end;justify-content:space-between}
@media (max-width:1040px){
  .hero-grid{grid-template-columns:1fr;gap:60px;justify-items:start}
  .hero-graphic { width: 100%; max-width: 480px; margin-bottom: 60px; }
}

.hero h1{
  color:#fff;
  max-width:18ch;
  font-size:clamp(48px,7vw,104px);
  line-height:1.02;
  letter-spacing:-.04em;
  font-weight:800;
}
.hero-single{max-width:780px}
/* Accent = Fraunces serif italic in Electric Cyan — the emotional pull line */
.hero-accent{
  font-family:'Fraunces','Playfair Display',Georgia,serif;
  font-style:italic;
  font-weight:400;
  color:#06B6D4;
  letter-spacing:-.01em;
  display:block;
}
/* The italic pull line below the H1 — same font, scaled slightly smaller */
.hero-headline-2{
  margin:0 0 28px;
  font-size:clamp(36px,5vw,80px);
  line-height:1.0;
  letter-spacing:-.025em;
  color:#fff;
  font-weight:800;
  max-width:22ch;
}
.hero-microcopy{
  margin-top:22px;
  font-size:14px;
  color:#CBD5E1;
  letter-spacing:.02em;
}
.hero-tagline{
  margin-top:10px;
  font-size:14px;
  color:#CBD5E1;
  font-style:italic;
  font-weight:500;
}
.hero-sub{margin:20px 0 36px;font-size:clamp(17px,1.3vw,20px);line-height:1.55;color:#F1F5F9;max-width:44ch}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{margin-top:28px;display:flex;gap:22px;color:#a8a295;font-size:14px;flex-wrap:wrap}
.hero-meta span{display:inline-flex;align-items:center;gap:8px}
.hero-meta .dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 10px rgba(34,197,94,.6)}

/* AI command bar card */
.hero-graphic{position:relative}
.hero-graphic::before{
  content:"";position:absolute;inset:-80px;
  background:radial-gradient(circle at center, rgba(2,6,23,0.95) 0%, transparent 70%);
  z-index:0;pointer-events:none;
}
.aicard{
  position:relative;z-index:1;width:100%;max-width:594px;margin-left:auto;
  background:rgba(10, 10, 11, 0.82); /* Near-black frosted — matches homepage dark cards */
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.08);
  border-left:4px solid #F59E0B; /* Amber Beer Glow — matches the voice-card accent pattern */
  border-radius:16px;padding:22px 24px 20px;
  box-shadow:0 30px 80px -20px rgba(0,0,0,0.8),-24px 0 60px -24px rgba(245,158,11,.28);
  color:#FFFFFF;
}
.aicard .row{display:flex;align-items:center;gap:10px;font-size:13px;color:#94A3B8;margin-bottom:14px}
.aicard .row .rdot{width:8px;height:8px;border-radius:50%;background:#F59E0B;box-shadow:0 0 8px #F59E0B}
.aicard .prompt{font-size:19px;font-weight:450;line-height:1.3;color:#fff;letter-spacing:-.01em;min-height:52px}
.aicard .cursor{display:inline-block;width:2px;height:1em;background:var(--amber-glow);animation:blink 1s steps(2) infinite;vertical-align:-3px;margin-left:2px}
@keyframes blink{50%{opacity:0}}
.aicard .answers{margin-top:16px;border-top:1px solid rgba(255,255,255,.08);padding-top:14px;font-size:19px;line-height:1.35;color:#94A3B8}
/* Chat input bar — mention / add / voice / send (Monday-style footer controls) */
.ai-input-bar{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.08)}
.ai-input-left,.ai-input-right{display:flex;align-items:center;gap:6px}
.ai-ibtn{background:transparent;border:none;padding:8px;border-radius:8px;color:#94A3B8;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:color .2s,background .2s}
.ai-ibtn:hover{color:#fff;background:rgba(255,255,255,.05)}
.ai-ibtn svg{width:18px;height:18px}
.ai-send{background:#06B6D4;border:none;color:#020617;width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,transform .2s,box-shadow .2s}
.ai-send:hover{background:#38BDF8;transform:translateY(-1px);box-shadow:0 6px 20px -6px rgba(6,182,212,.6)}
.ai-send svg{width:16px;height:16px}
.aicard .answers .li{display:flex;align-items:center;gap:10px;padding:6px 0}
.aicard .answers .li .tick{color:#06B6D4}
.aicard .ricky{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#06B6D4;background:rgba(6,182,212,.15);padding:4px 10px;border-radius:999px;border:1px solid rgba(6,182,212,.3);margin-bottom:12px}

.scroll-cue{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:3;color:#CBD5E1;font-size:11px;font-weight:600;letter-spacing:.3em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:10px;animation:bob 2.8s ease-in-out infinite}
.scroll-cue .bar{width:1px;height:42px;background:linear-gradient(180deg,transparent,#CBD5E1)}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}

/* ---------- Logo marquee ---------- */
/* Brewery strip — trust row directly under hero, infinite horizontal marquee */
.brewery-strip{padding:40px 0 44px;background:var(--paper);border-bottom:1px solid var(--line);overflow:hidden}
.bs-eyebrow{text-align:center;font-size:13px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:rgba(2,6,23,.62);margin:0 auto 24px;max-width:90%}
.bs-marquee{position:relative;width:100%;overflow:hidden;mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%)}
.bs-track{display:inline-flex;gap:0;animation:bsScroll 96s linear infinite;will-change:transform}
.bs-row{display:inline-flex;align-items:center;gap:120px;padding-right:120px;flex-shrink:0}
.bs-name{display:inline-flex;align-items:center;gap:16px;font-size:32px;font-weight:600;letter-spacing:-.02em;color:#94A3B8;white-space:nowrap}
.bs-ph{font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#94A3B8;border:1px solid #94A3B8;border-radius:3px;padding:3px 7px;line-height:1}
@keyframes bsScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.bs-marquee:hover .bs-track{animation-play-state:paused}
@media (prefers-reduced-motion:reduce){.bs-track{animation:none;transform:none}.bs-marquee{mask-image:none;-webkit-mask-image:none;overflow-x:auto}}
@media (max-width:700px){.bs-name{font-size:22px}.bs-row{gap:72px;padding-right:72px}.bs-eyebrow{font-size:11px;letter-spacing:.16em}}

.marquee-section{padding:56px 0;background:var(--paper);border-bottom:1px solid var(--line)}
.tb-wrap{display:grid;grid-template-columns:1fr 1px 1fr 1px 1.15fr 1px 1.15fr;align-items:center;gap:32px}
@media (max-width:900px){.tb-wrap{grid-template-columns:1fr 1fr;gap:40px 32px}.tb-divider{display:none}}
.tb-divider{height:56px;width:1px;background:rgba(2,6,23,.12)}
.tb-item{display:flex;flex-direction:column;gap:8px}
.tb-num{font-family:var(--font-mono);font-size:clamp(32px,3.6vw,44px);font-weight:600;letter-spacing:-.03em;color:#020617;line-height:1;font-variant-numeric:tabular-nums}
.tb-num .tb-dash{color:#06B6D4;margin:0 2px}
.tb-label{font-size:13px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#020617;line-height:1.4}
.tb-sub{display:block;font-size:13px;font-weight:400;letter-spacing:0;text-transform:none;color:rgba(2,6,23,.62);margin-top:4px;line-height:1.5}
.tb-eye{font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:#06B6D4;display:inline-flex;align-items:center;gap:8px;margin-bottom:4px}
.tb-dot{width:5px;height:5px;border-radius:50%;background:#06B6D4}
.tb-title{font-size:20px;font-weight:600;letter-spacing:-.02em;color:#020617;line-height:1.15}

/* ---------- Before / After ---------- */
.beforeafter{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:stretch}
@media (max-width:860px){.beforeafter{grid-template-columns:1fr}}
.ba-card{border-radius:var(--radius-lg);overflow:hidden;background:#111;color:#fff;display:flex;flex-direction:column}
.ba-card-img{position:relative;height:320px;overflow:hidden;width:100%}
.ba-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s cubic-bezier(.2,.8,.2,1)}
.ba-card:hover .ba-card-img img{transform:scale(1.04)}
.ba-card .inner{padding:36px;width:100%;flex:1}
.ba-card .tag{font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;margin-bottom:14px;opacity:.85}
.ba-card.before .tag{color:#C2410C}
.ba-card.after .tag{color:var(--amber-glow)}
.ba-card h3{font-size:clamp(26px,2.6vw,36px);color:#fff;max-width:18ch}
.ba-card p{margin-top:12px;color:#94A3B8;max-width:34ch;font-size:15px;line-height:1.5}
.ba-divider{text-align:center;padding:36px 0;font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:500}
.ba-divider .arrow{display:inline-block;width:80px;height:1px;background:currentColor;vertical-align:middle;margin:0 14px}

/* ---------- Testimonial ---------- */
.testimonial{padding:clamp(60px,8vw,100px) var(--pad);background:#0a0a0b;color:#fff;text-align:center;border-bottom:1px solid rgba(255,255,255,.05)}
.testimonial p{font-size:clamp(19px,2.2vw,28px);line-height:1.55;max-width:44ch;margin:0 auto;font-weight:400;color:#e8e6e0}
.testimonial .author{margin-top:32px;font-size:14px;color:var(--muted-dk);letter-spacing:.05em;text-transform:uppercase}
.testimonial .author strong{color:#fff;font-weight:600}

/* ---------- Section titles ---------- */
.section-title{display:grid;grid-template-columns:1fr 1.3fr;gap:60px;align-items:end;margin-bottom:64px}
@media (max-width:900px){.section-title{grid-template-columns:1fr;gap:24px}}
.section-title h2{max-width:14ch}
.section-title .lede{font-size:19px;line-height:1.5;color:var(--muted);max-width:52ch}
.dark .section-title .lede{color:#b8b2a4}

/* hero-aligned stacked variant — eyebrow + cyan italic accent */
.section-title.title-stacked{display:block;max-width:900px;margin-bottom:64px}
.section-title.title-stacked .eyebrow{margin:0 0 80px}
.section-title.title-stacked h2{max-width:20ch;text-wrap:balance;margin-bottom:28px;letter-spacing:-.035em;line-height:1}
.section-title.title-stacked .lede{font-size:17px;line-height:1.75;color:#020617;opacity:.78;max-width:700px}
.section-accent{font-family:'Fraunces','Playfair Display',Georgia,serif;font-style:italic;font-weight:400;color:#06B6D4;letter-spacing:-.01em}

/* ---------- Module cards (monday-style grid, but ours) ---------- */
.modules{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.mod{
  border-radius:var(--radius-lg);padding:32px;position:relative;overflow:hidden;
  min-height:380px;display:flex;flex-direction:column;justify-content:space-between;
  transition:transform .4s cubic-bezier(.2,.8,.2,1);cursor:default;
}
.mod:hover{transform:translateY(-4px)}
.mod .logo-row{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;letter-spacing:-.01em}
.mod .logo-row .dot{width:16px;height:16px;border-radius:4px;display:inline-block}
.mod h3{font-size:clamp(24px,2.2vw,32px);max-width:16ch;margin-top:10px}
.mod p.sub{font-size:15px;line-height:1.45;margin-top:10px;max-width:38ch;opacity:.85}
.mod .shot{margin-top:22px;border-radius:10px;overflow:hidden;border:1px solid rgba(0,0,0,.08);box-shadow:0 20px 40px -18px rgba(0,0,0,.25);transition:transform .5s}
.mod:hover .shot{transform:translateY(-4px)}
.mod .shot img{width:100%;display:block}

.mod.a{grid-column:span 5;background:#fef3e8;color:#3a1e08}
.mod.a .dot{background:var(--burgundy)}
.mod.b{grid-column:span 7;background:#0a0a0b;color:#fff}
.mod.b .dot{background:var(--cyan)}
.mod.c{grid-column:span 4;background:#efe9df;color:#1a2333}
.mod.c .dot{background:#22c55e}
.mod.d{grid-column:span 4;background:#f3e8ec;color:#3a0f23}
.mod.d .dot{background:var(--burgundy)}
.mod.e{grid-column:span 4;background:#0a0a0b;color:#fff}
.mod.e .dot{background:var(--amber-glow)}
@media (max-width:960px){
  .mod{grid-column:span 12 !important}
}

/* ---------- Feature spotlight (maintenance) ---------- */
.spotlight{position:relative;padding:clamp(90px,12vw,180px) 0}
.spotlight .parallax-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.25;z-index:0}
.spotlight .container{position:relative;z-index:1}
.spotlight-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:72px;align-items:center}
@media (max-width:1040px){.spotlight-grid{grid-template-columns:1fr;gap:48px}}
.spotlight h2{color:#fff;max-width:14ch}
.spotlight h2 em{font-style:normal;font-family:'Fraunces','Playfair Display',Georgia,serif;color:var(--amber-glow);font-weight:500;letter-spacing:-.015em}
.spot-bullets{margin-top:36px;display:flex;flex-direction:column;gap:22px}
.spot-bullet{display:grid;grid-template-columns:40px 1fr;gap:18px;align-items:start;padding-top:18px;border-top:1px solid rgba(255,255,255,.12)}
.spot-bullet .n{font-variant-numeric:tabular-nums;font-size:14px;color:var(--amber-glow);font-weight:600}
.spot-bullet h4{font-size:18px;font-weight:500;color:#fff;margin:0 0 6px;letter-spacing:-.01em}
.spot-bullet p{font-size:15px;color:#b8b2a4;line-height:1.5;max-width:44ch}
.spotlight-frame{border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 40px 100px -20px rgba(0,0,0,.8);transform-style:preserve-3d;transition:transform .6s}

/* ---------- Ricky AI ---------- */
.ricky-wrap{background:linear-gradient(180deg,#faf8f3 0%, #f2efe9 100%);border-radius:28px;padding:clamp(48px,6vw,96px);position:relative;overflow:hidden}
.ricky-wrap::before{content:"";position:absolute;inset:-20% -10% auto auto;width:60%;height:60%;background:radial-gradient(circle,rgba(229,159,11,.18) 0%, transparent 60%);pointer-events:none}
.ricky-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative;z-index:1}
@media (max-width:960px){.ricky-grid{grid-template-columns:1fr}}
.ricky-chat{background:#fff;border-radius:20px;padding:22px;box-shadow:0 30px 80px -20px rgba(0,0,0,.18);border:1px solid var(--line)}
.ricky-bubble{display:flex;gap:14px;margin-bottom:18px}
.ricky-bubble .av{width:36px;height:36px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;letter-spacing:-.02em}
.ricky-bubble.u .av{background:#e5e1d8;color:#1a2333}
.ricky-bubble.r .av{background:linear-gradient(135deg,var(--amber-glow),var(--amber));color:#fff}
.ricky-bubble .msg{background:#f5f2ec;border-radius:14px;padding:12px 16px;font-size:15px;line-height:1.45;max-width:440px}
.ricky-bubble.r .msg{background:#111;color:#fff}
.ricky-bubble.r .msg strong{color:var(--amber-glow)}
.ricky-input{display:flex;align-items:center;gap:10px;border-top:1px solid var(--line);padding-top:14px;color:var(--muted);font-size:14px}
.ricky-input .ic{width:20px;height:20px;color:var(--amber)}
.ricky-input .typing{flex:1;color:var(--ink);min-height:20px}

/* ---------- MRP prediction showcase ---------- */
.showcase{display:grid;grid-template-columns:.9fr 1.3fr;gap:64px;align-items:center}
@media (max-width:960px){.showcase{grid-template-columns:1fr}}
.showcase-frame{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);box-shadow:0 40px 100px -30px rgba(0,0,0,.25);background:#fff}
.showcase-frame img{width:100%;display:block}
.bullet-list{margin-top:32px;display:flex;flex-direction:column;gap:18px}
.bullet{display:grid;grid-template-columns:28px 1fr;gap:14px;align-items:start}
.bullet svg{width:22px;height:22px;color:var(--amber);margin-top:4px}
.bullet h4{font-size:18px;font-weight:500;margin:0 0 4px}
.bullet p{font-size:15px;color:var(--muted);line-height:1.5;max-width:44ch}

/* ---------- Compare strip ---------- */
.compare{background:#0a0a0b;color:#fff;border-radius:28px;padding:clamp(40px,5vw,64px);overflow:hidden}
.compare-head{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:end;margin-bottom:40px}
@media (max-width:860px){.compare-head{grid-template-columns:1fr}}
.compare-table{width:100%;border-collapse:separate;border-spacing:0;font-size:17px}
.compare-table th,.compare-table td{padding:18px 18px;text-align:left;border-bottom:1px solid rgba(255,255,255,.08)}
.compare-table th{font-weight:700;font-size:14px;letter-spacing:.05em;text-transform:uppercase;color:#94A3B8}
.compare-table th.us,.compare-table td.us{background:rgba(229,159,11,.06)}
.compare-table th.us{color:var(--amber-glow)}
.compare-table td.cap{color:#e8e6e0;max-width:420px;font-size:18px;font-weight:600;line-height:1.3}
.compare-table td:not(.cap){font-size:17px;font-weight:400;line-height:1.4}
/* Row hover — whole row lights up in amber, KettleiQ column stays visibly
   distinct with a darker wash, capability cell brightens to white, and a thin
   top/bottom amber hairline frames the full row so it reads as one unit. */
.compare-table tbody tr td{transition:background-color .25s ease,color .25s ease,box-shadow .25s ease}
.compare-table tbody tr:hover td{background:rgba(245,158,11,.12);box-shadow:inset 0 1px 0 rgba(245,158,11,.35),inset 0 -1px 0 rgba(245,158,11,.35)}
.compare-table tbody tr:hover td.us{background:rgba(245,158,11,.24)}
.compare-table tbody tr:hover td.cap{color:#fff;box-shadow:inset 3px 0 0 #F59E0B,inset 0 1px 0 rgba(245,158,11,.35),inset 0 -1px 0 rgba(245,158,11,.35)}
.compare-table tbody tr:hover td.nope{color:#94A3B8}
.check{color:#22c55e;font-weight:600}
.warn{color:var(--amber-glow)}
.nope{color:#6b7280}
.compare-foot{margin-top:28px;font-size:18px;font-weight:400;color:#94A3B8;max-width:none;line-height:1.5}
/* Closer tagline below the comparison table — lives on the light page bg */
.compare-coda{margin:80px auto 0;max-width:780px;text-align:center;font-size:28px;font-weight:400;line-height:1.35;color:#020617;letter-spacing:-.01em}
@media (max-width:768px){.compare-coda{font-size:22px;margin-top:56px}}

/* ---------- Stat row ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:48px}
@media (max-width:860px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{border-top:1px solid var(--line);padding-top:20px}
.dark .stat{border-top-color:rgba(255,255,255,.15)}
.stat .k{font-size:clamp(42px,5vw,64px);font-weight:500;letter-spacing:-.04em;line-height:1;font-variant-numeric:tabular-nums}
.stat .k em{font-style:normal;color:var(--amber)}
.dark .stat .k em{color:var(--amber-glow)}
.stat .l{font-size:14px;color:var(--muted);margin-top:10px;max-width:24ch;line-height:1.4}
.dark .stat .l{color:#a8a295}

/* ---------- Mobile showcase ---------- */
.mobile-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:72px;align-items:center}
@media (max-width:960px){.mobile-wrap{grid-template-columns:1fr}}
/* Phone sits on a soft rounded charcoal panel with cyan glow — straight, no tilt.
   The image's non-transparent white edges blend into the panel's light band,
   which feels intentional (phone on product card) instead of stray white. */
.phone-frame{position:relative;max-width:360px;aspect-ratio:9/16;margin:0 auto;border-radius:36px;overflow:hidden;transform:none;box-shadow:0 0 80px rgba(6,182,212,.20),0 30px 60px -20px rgba(0,0,0,.45),inset 0 0 0 1px rgba(255,255,255,.04)}
.phone-frame img{width:100%;height:100%;object-fit:cover;display:block}

/* ---------- FAQ ---------- */
.faq-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line);padding:6px 0}
.faq-q{width:100%;text-align:left;padding:22px 0;display:flex;align-items:center;justify-content:space-between;gap:20px;font-size:clamp(18px,1.6vw,22px);font-weight:500;letter-spacing:-.01em}
.faq-q .plus{width:22px;height:22px;flex-shrink:0;position:relative;transition:transform .4s}
.faq-q .plus::before,.faq-q .plus::after{content:"";position:absolute;inset:50% 0;height:1.5px;background:currentColor;transform:translateY(-50%)}
.faq-q .plus::after{transform:translateY(-50%) rotate(90deg);transition:transform .4s}
.faq-item.open .plus::after{transform:translateY(-50%) rotate(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.2,.8,.2,1);color:var(--muted);font-size:16px;line-height:1.55}
.faq-a .inner{padding-bottom:22px;max-width:72ch}
.faq-a .inner p + p{margin-top:16px}

/* ---------- Final CTA ---------- */
.final{position:relative;overflow:hidden;min-height:70vh;display:flex;align-items:center;background:#050509;color:#fff}
.final video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.35}
.final::after{content:"";position:absolute;inset:0;background:radial-gradient(60% 60% at 50% 50%, transparent 0, rgba(5,5,9,.9) 100%)}
.final .container{position:relative;z-index:2;text-align:center;padding:120px var(--pad)}
.final h2{font-size:clamp(48px,8vw,130px);color:#fff;max-width:14ch;margin:0 auto}
.final h2 em{font-style:italic;font-family:'Fraunces','Playfair Display',Georgia,serif;color:#06B6D4;font-weight:500;letter-spacing:-.01em}
.final .sub{margin:28px auto 36px;font-size:19px;color:#c5c0b3;max-width:56ch}
.final .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- Footer ---------- */
footer{background:#050509;color:#94A3B8;padding:96px 0 48px;border-top:1px solid #1a1a20}
.foot-grid{display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:56px}
@media (max-width:960px){.foot-grid{grid-template-columns:1fr 1fr;gap:40px}.foot-brand{grid-column:1 / -1}}
@media (max-width:560px){.foot-grid{grid-template-columns:1fr;gap:32px}}
.foot-grid h5{color:#fff;font-size:15px;letter-spacing:.14em;text-transform:uppercase;margin:0 0 22px;font-weight:600}
.foot-grid ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.foot-grid a{font-size:17px;color:#94A3B8;transition:color .2s}
.foot-grid a:hover{color:#06B6D4}
.foot-logo{font-size:34px;font-weight:700;letter-spacing:-.03em;color:#fff;margin-bottom:16px}
.foot-logo .q{color:#06B6D4;font-style:normal;font-weight:700}
.foot-tag{max-width:32ch;line-height:1.35;font-size:19px;font-weight:500;color:#fff;margin-bottom:0}
.foot-tag em{font-family:'Fraunces','Lora',serif;font-style:italic;font-weight:400;color:#06B6D4;letter-spacing:-.01em}
.foot-bottom{margin-top:72px;padding-top:28px;border-top:1px solid #1a1a20;display:flex;justify-content:space-between;flex-wrap:wrap;gap:20px;font-size:15px;color:#94A3B8;align-items:center}
.foot-bottom a{color:#94A3B8;transition:color .2s}
.foot-bottom a:hover{color:#06B6D4}
.foot-trust{color:rgba(148,163,184,.75);font-style:italic;font-family:'Fraunces','Lora',serif;font-size:15px}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(60px);transition:opacity 1.1s cubic-bezier(.16,.84,.3,1),transform 1.1s cubic-bezier(.16,.84,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}
.reveal.d2{transition-delay:.2s}
.reveal.d3{transition-delay:.3s}
.reveal.d4{transition-delay:.4s}
/* Heading-led cascade: eyebrow → h2 → lede → body each slide up 60px,
   staggered 0.14s apart, so the heading block feels composed line by line. */
.reveal.reveal-stack>*{opacity:0;transform:translateY(60px);transition:opacity 1.1s cubic-bezier(.16,.84,.3,1),transform 1.1s cubic-bezier(.16,.84,.3,1)}
.reveal.reveal-stack.in>*{opacity:1;transform:none}
.reveal.reveal-stack.in>*:nth-child(1){transition-delay:0s}
.reveal.reveal-stack.in>*:nth-child(2){transition-delay:.14s}
.reveal.reveal-stack.in>*:nth-child(3){transition-delay:.28s}
.reveal.reveal-stack.in>*:nth-child(4){transition-delay:.42s}

/* ==========================================================
   TYPE SYSTEM REFRESH  (branch: type-system-refresh)
   Nav 15/500 · Hero 96/700 · Variant B 88/700 · Variant C 64/700
   Eyebrow 16/600 cyan "·" · Body 17px floor · Numbered list 14/18/17
   ========================================================== */

/* ---------- NAV (Stripe-proportioned: 18px nav text, 26px logo) ---------- */
.nav .logo{font-size:26px;font-weight:700;letter-spacing:-.04em;line-height:1;color:#fff}
.nav .logo .q{color:#06B6D4;font-weight:700;font-style:normal}
.nav-links{gap:32px}
.nav-links a{font-size:18px;font-weight:500;opacity:1;padding:8px 4px;letter-spacing:0;color:#fff;border-radius:0;background:transparent}
.nav-links a:hover{color:#06B6D4;background:transparent;opacity:1}
.nav-links a.is-active{color:#06B6D4}
.nav-cta{display:flex;align-items:center;gap:32px}
.nav-signin{font-size:18px;font-weight:500;color:#fff;padding:8px 4px;transition:color .2s}
.nav-signin:hover{color:#06B6D4}
.nav-cta-btn{font-size:18px;font-weight:600;padding:14px 24px;letter-spacing:0}

/* ---------- EYEBROW (all variants) — 20/500 cyan with cyan "·" lead
   80px margin-bottom = 1.0× H1 size — uniform eyebrow→heading rhythm across all sections. */
.eyebrow{font-size:20px;font-weight:500;color:#06B6D4;letter-spacing:.1em;text-transform:uppercase;gap:10px;margin:0 0 80px;align-items:baseline}
.eyebrow::before{content:"·";background:none;box-shadow:none;width:auto;height:auto;border-radius:0;color:#06B6D4;font-weight:700;font-size:26px;line-height:.6}
.dark .eyebrow{color:#06B6D4}
.dark .eyebrow::before{color:#06B6D4;box-shadow:none}

/* ---------- Unified italic heading accent — Fraunces italic / cyan / weight 500 ---------- */
h1 em, h2 em, h3 em,
.compare-coda em,
.section-accent,
.hero-accent,
.serif-italic{
  font-family:'Fraunces','Playfair Display',Georgia,serif;
  font-style:italic;
  font-weight:500;
  color:#06B6D4;
  letter-spacing:-.01em;
}

/* ---------- VARIANT A · Hero · 80/700 ----------
   letter-spacing -0.04em: display-type tracking rule (skill §typography).
   Tighter glyph clumps read crisper and let the eyebrow above breathe. */
.hero h1{font-size:80px;font-weight:700;letter-spacing:-.04em;line-height:.95;max-width:18ch;color:#fff}
.hero-accent{font-size:80px;font-weight:500;letter-spacing:-.04em;line-height:.95;font-family:'Fraunces','Playfair Display',Georgia,serif;font-style:italic;color:#06B6D4}
.hero-sub{font-size:20px;font-weight:400;color:#CBD5E1;line-height:1.5;max-width:60ch;margin:28px 0 40px}
@media (max-width:1100px){.hero h1,.hero-accent{font-size:64px}}
@media (max-width:768px){.hero h1,.hero-accent{font-size:48px}}
@media (max-width:480px){.hero h1,.hero-accent{font-size:36px}}

/* ---------- VARIANT B · Solid-dark sections · 88/700 ---------- *
 * Applies to: "One platform" (#platform), Ricky AI, Compare, Mobile, FAQ, Before/After */
.section-title h2,
.ricky-wrap h2,
.compare-head h2,
.mobile-wrap h2{font-size:88px;font-weight:700;letter-spacing:-.02em;line-height:.95;max-width:none}
@media (max-width:1100px){.section-title h2,.ricky-wrap h2,.compare-head h2,.mobile-wrap h2{font-size:64px}}
@media (max-width:768px){.section-title h2,.ricky-wrap h2,.compare-head h2,.mobile-wrap h2{font-size:48px}}
@media (max-width:480px){.section-title h2,.ricky-wrap h2,.compare-head h2,.mobile-wrap h2{font-size:36px}}

/* ---------- VARIANT C · Maintenance (image bg) · 64/700 ---------- */
.spotlight h2{font-size:64px;font-weight:700;letter-spacing:-.02em;line-height:.98;max-width:none}
.spotlight h2 em{font-weight:500;font-style:italic;font-family:'Fraunces','Playfair Display',Georgia,serif;color:#06B6D4}
@media (max-width:1100px){.spotlight h2{font-size:52px}}
@media (max-width:768px){.spotlight h2{font-size:40px}}
@media (max-width:480px){.spotlight h2{font-size:32px}}
/* Maintenance eyebrow — full container width, single line */
.spot-eyebrow{display:block;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis;margin:0 0 40px}
@media (max-width:900px){
  .spot-eyebrow{white-space:normal;overflow:visible}
}
/* Spec gradient overlay on image background for text contrast */
.spotlight .parallax-bg{opacity:1 !important;transform:none !important}
.spotlight::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(90deg,rgba(2,6,23,.95) 0%,rgba(2,6,23,.88) 25%,rgba(2,6,23,.55) 48%,transparent 65%)}
.spotlight .container{position:relative;z-index:2}

/* ---------- LEDE / BODY paragraphs (19px in section heads, 17px floor elsewhere) ---------- */
.section-title .lede{font-size:19px;font-weight:400;line-height:1.5;max-width:60ch;color:#94A3B8}
.section:not(.dark) .section-title .lede{color:#334155}
.dark .section-title .lede{color:#CBD5E1}
.section-title.title-stacked .lede{font-size:19px;line-height:1.5;color:#334155;max-width:60ch}

/* ---------- NUMBERED LIST (maintenance 01/02/03) ---------- */
.spot-bullets{gap:20px;margin-top:40px}
.spot-bullet{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start;padding-top:20px}
.spot-bullet .n{font-size:14px;font-weight:700;color:#06B6D4;font-variant-numeric:tabular-nums;line-height:1.3;padding-top:2px}
.spot-bullet h4{font-size:18px;font-weight:600;line-height:1.3;margin:0 0 8px;color:#fff;letter-spacing:-.005em}
.spot-bullet p{font-size:17px;font-weight:400;line-height:1.5;max-width:40ch;color:#CBD5E1}

/* ---------- SECTION SPACING ----------
   Eyebrow→heading gap is set globally on .eyebrow (80px, 1.0× H1).
   Per-section overrides removed for consistent rhythm. */
.section-title{margin-bottom:64px}
.section-title h2,
.section-title.title-stacked h2,
.ricky-wrap h2,
.compare-head h2,
.mobile-wrap h2,
.spotlight h2{margin-bottom:28px}

/* ---------- 17px BODY FLOOR across cards & secondary content ---------- */
.mod p.sub{font-size:17px;line-height:1.5;max-width:40ch;font-weight:400}
.ba-card p{font-size:17px;line-height:1.5;font-weight:400}
.bullet p{font-size:17px;line-height:1.5;font-weight:400}
.bullet h4{font-size:18px;font-weight:600;line-height:1.3}
.stat .l{font-size:17px;line-height:1.5;color:#CBD5E1}
.faq-q span{font-size:18px;font-weight:600;line-height:1.3}
.faq-a .inner{font-size:17px;line-height:1.6;color:#94A3B8}

/* ---------- Microcopy (exempt; 13–15px band) ---------- */
.hero-microcopy{font-size:20px;color:#CBD5E1;line-height:1.5;margin-top:24px}
.tb-sub{font-size:13px}
.tb-label{font-size:13px}
.ba-card .tag{font-size:13px}

/* ========== WAITLIST PAGE ========== */
body.dark-page{background:#05050a;color:#fff}
.waitlist{padding:160px 0 120px;min-height:100vh;display:flex;align-items:center;background:#05050a;color:#fff;position:relative;overflow:hidden}
.waitlist .container{position:relative;z-index:1}
.waitlist-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:start}
@media (max-width:960px){.waitlist-grid{grid-template-columns:1fr;gap:48px}}
.waitlist-pitch h1{font-size:80px;font-weight:700;letter-spacing:-.04em;line-height:.95;color:#fff;max-width:14ch}
@media (max-width:1100px){.waitlist-pitch h1{font-size:64px}}
@media (max-width:768px){.waitlist-pitch h1{font-size:48px}}
.waitlist-sub{font-size:48px;font-weight:500;font-style:italic;font-family:'Fraunces','Playfair Display',Georgia,serif;color:#06B6D4;letter-spacing:-.02em;line-height:1;margin:20px 0 36px}
@media (max-width:1100px){.waitlist-sub{font-size:40px}}
@media (max-width:768px){.waitlist-sub{font-size:32px}}
.waitlist-body{font-size:20px;font-weight:400;color:#94A3B8;line-height:1.5;max-width:60ch;margin-bottom:28px}
.waitlist-perks{list-style:none;padding:0;margin:0 0 28px;display:flex;flex-direction:column;gap:20px}
.waitlist-perks li{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start;padding-top:20px;border-top:1px solid rgba(255,255,255,.12);font-size:18px;line-height:1.5;color:#94A3B8}
.waitlist-perks .perk-num{font-size:14px;font-weight:700;color:#06B6D4;font-variant-numeric:tabular-nums;padding-top:2px}
.waitlist-perks strong{color:#fff;font-weight:600}
.waitlist-coda{font-size:18px;font-weight:400;color:#94A3B8;line-height:1.5;max-width:60ch;font-style:italic;opacity:.8}

/* Form card — cream/paper card on near-black page for maximum lift.
   Dark text inside, pure-white inputs, cyan focus ring, cyan CTA. */
.waitlist-form-wrap{align-self:end}
@media (max-width:960px){.waitlist-form-wrap{align-self:auto}}
.waitlist-form{background:var(--paper);color:#020617;border:1px solid var(--line);border-radius:20px;padding:36px;position:relative;z-index:1;box-shadow:0 50px 100px -25px rgba(0,0,0,.7),0 0 120px -30px rgba(255,255,255,.12),0 0 60px -10px rgba(6,182,212,.10)}

/* Scoped eyebrow weight bump for the waitlist pitch */
.waitlist .eyebrow{font-weight:600;color:#06B6D4}
.waitlist .eyebrow::before{color:#06B6D4;opacity:1}
.form-title{font-size:28px;font-weight:700;letter-spacing:-.02em;color:#020617;margin:0 0 24px}
.form-row{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.form-row label{font-size:15px;font-weight:500;color:rgba(2,6,23,.72);letter-spacing:0}
.form-row .form-optional{color:rgba(2,6,23,.48);font-weight:400}
.form-row input{font-family:inherit;font-size:17px;font-weight:400;color:#020617;background:#fff;border:1px solid var(--line);border-radius:10px;padding:14px 16px;transition:border-color .2s,background .2s,box-shadow .2s}
.form-row input:hover{border-color:rgba(2,6,23,.24)}
.form-row input:focus{outline:none;border-color:#06B6D4;background:#fff;box-shadow:0 0 0 3px rgba(6,182,212,.18)}
.form-submit{width:100%;justify-content:center;margin-top:8px}
.form-fine{font-size:14px;color:rgba(2,6,23,.5);text-align:center;margin-top:16px;line-height:1.5}

/* Success state — same cream card, dark copy, cyan accent border */
.waitlist-success{background:var(--paper);color:#020617;border:1px solid rgba(6,182,212,.45);border-radius:20px;padding:48px 36px;text-align:center;box-shadow:0 50px 100px -25px rgba(0,0,0,.7),0 0 120px -30px rgba(255,255,255,.12)}
.waitlist-success h2{font-size:28px;font-weight:700;color:#020617;letter-spacing:-.02em;margin-bottom:12px}
.waitlist-success p{font-size:17px;color:rgba(2,6,23,.65);line-height:1.5}

/* ==========================================================
   WHY SWITCH — Pain voices → Migration → Intelligence band
   Three back-to-back dark sections that land before the compare table.
   ========================================================== */

/* Why-switch page hero — light paper, centered, cyan eyebrow */
.whyswitch-hero{background:var(--paper);color:#020617;padding:clamp(120px,14vw,180px) var(--pad) clamp(56px,7vw,90px);text-align:center;position:relative;overflow:hidden}
.whyswitch-hero > .container{position:relative;z-index:1;max-width:980px}
.whyswitch-hero .eyebrow{color:#06B6D4;margin-bottom:32px}
.whyswitch-hero h1{font-size:clamp(48px,6.8vw,92px);font-weight:700;letter-spacing:-.04em;line-height:1;max-width:22ch;margin:0 auto;color:#020617}
.whyswitch-hero h1 em{font-family:'Fraunces','Lora',serif;font-style:italic;font-weight:400;color:#06B6D4;letter-spacing:-.02em}
.whyswitch-lede{font-size:clamp(17px,1.4vw,20px);color:rgba(2,6,23,.65);margin:32px auto 0;max-width:58ch;line-height:1.55}

/* Alternating section backgrounds — Pain (DARK) → Hero (LIGHT) →
   Migration (DARK) → Band (LIGHT) → Final (DARK). */
.switch-pain,.switch-migration{background:#05050a;color:#fff}
.switch-band{background:var(--paper);color:#020617}
.switch-pain{padding-top:clamp(120px,14vw,180px);padding-bottom:clamp(72px,10vw,130px)}
.switch-migration{padding-top:clamp(80px,10vw,130px);padding-bottom:clamp(80px,10vw,130px)}
.switch-band{padding-top:clamp(72px,10vw,130px);padding-bottom:clamp(96px,12vw,150px);border-top:1px solid var(--line)}

/* -- Pain voices (3 quote cards) -- DARK section variant -- */
.voices{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1200px;margin:0 auto}
@media (max-width:960px){.voices{grid-template-columns:1fr}}
.voice{background:#0a0a0b;border:1px solid rgba(255,255,255,.08);border-left:3px solid #06B6D4;border-radius:14px;padding:32px 28px;display:flex;flex-direction:column;gap:22px;transition:transform .3s ease,border-color .3s ease,box-shadow .3s ease}
.voice:hover{transform:translateY(-3px);border-color:rgba(6,182,212,.35);box-shadow:0 30px 60px -25px rgba(6,182,212,.22)}
.voice:nth-child(2){border-left-color:#F59E0B}
.voice:nth-child(2):hover{border-color:rgba(245,158,11,.4);box-shadow:0 30px 60px -25px rgba(245,158,11,.25)}
.voice:nth-child(3){border-left-color:#C2410C}
.voice:nth-child(3):hover{border-color:rgba(194,65,12,.4);box-shadow:0 30px 60px -25px rgba(194,65,12,.25)}
.voice-tag{display:inline-flex;align-self:flex-start;padding:5px 10px;border:1px solid #C2410C;border-radius:5px;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#C2410C;background:rgba(194,65,12,.12)}
.voice-tag-amber{border-color:#F59E0B;color:#F59E0B;background:rgba(245,158,11,.12)}
.voice blockquote{margin:0;font-family:'Fraunces','Lora',serif;font-style:italic;font-weight:400;font-size:18px;line-height:1.55;color:#e8e6e0;letter-spacing:-.005em}
.voice-author{display:flex;align-items:center;gap:12px;margin-top:auto;padding-top:16px;border-top:1px solid rgba(255,255,255,.06)}
.voice-author .av{width:34px;height:34px;border-radius:50%;background:#C2410C;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;letter-spacing:.04em;flex-shrink:0}
.voice-author .av.star{background:#F59E0B;color:#020617;font-size:14px}
.voice-author strong{display:block;font-size:15px;font-weight:600;color:#fff;line-height:1.2}
.voice-author span{display:block;font-size:13px;color:#94A3B8;margin-top:3px;line-height:1.2}

/* -- Migration section (steps + side card) -- */
.migration-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(32px,5vw,72px);align-items:center;max-width:1200px;margin:0 auto}
@media (max-width:900px){.migration-grid{grid-template-columns:1fr}}
.switch-migration h2{font-size:clamp(40px,6vw,80px)}
.migration-intro{margin:24px auto 0;color:#94A3B8;font-size:18px;line-height:1.55;max-width:58ch;text-align:center}
.migration-steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:32px;position:relative}
.migration-steps li{display:grid;grid-template-columns:48px 1fr;gap:20px;position:relative}
.migration-steps li:not(:last-child)::after{content:"";position:absolute;left:23px;top:52px;bottom:-32px;width:1px;background:rgba(255,255,255,.1)}
.step-n{width:40px;height:40px;border-radius:50%;border:1px solid #06B6D4;color:#06B6D4;display:inline-flex;align-items:center;justify-content:center;font-family:'JetBrains Mono',monospace;font-size:17px;font-weight:500;flex-shrink:0;background:#05050a;z-index:1}
.migration-steps h4{font-size:18px;font-weight:600;color:#fff;letter-spacing:-.01em;line-height:1.3;margin-top:8px}
.migration-steps p{margin-top:8px;color:#94A3B8;font-size:15px;line-height:1.55;max-width:50ch}

.migration-card{background:#0a0a0b;border:1px solid rgba(255,255,255,.08);border-left:4px solid #06B6D4;border-radius:18px;padding:clamp(32px,4vw,48px);position:relative;box-shadow:-24px 0 60px -24px rgba(6,182,212,.32),0 40px 80px -30px rgba(0,0,0,.55),0 0 80px -20px rgba(255,255,255,.06)}
.migration-card h3{font-size:clamp(24px,2.2vw,30px);font-weight:600;letter-spacing:-.02em;line-height:1.2;color:#fff;position:relative}
.migration-card h3 em{font-family:'Fraunces','Lora',serif;font-style:italic;font-weight:400;color:#06B6D4;letter-spacing:-.01em}
.migration-check{list-style:none;padding:0;margin:28px 0 32px;display:flex;flex-direction:column;gap:12px;position:relative}
.migration-check li{padding-left:28px;position:relative;font-size:15px;line-height:1.45;color:#e8e6e0}
.migration-check li::before{content:"✓";position:absolute;left:0;top:0;color:#22C55E;font-weight:700;font-size:16px;font-family:'JetBrains Mono',monospace}
.migration-cta{position:relative}

/* Centered section titles on pain + migration + band (shared treatment:
   centered block, tighter eyebrow-to-heading rhythm — matches the why-switch hero). */
.switch-pain .section-title,
.switch-migration .section-title,
.switch-band .section-title{max-width:860px;margin-left:auto;margin-right:auto}
.switch-pain .section-title .eyebrow,
.switch-migration .section-title .eyebrow,
.switch-band .section-title .eyebrow,
.final .eyebrow{margin-bottom:32px}

/* -- Intelligence layer band -- LIGHT section variant -- */
.switch-band h2{font-size:clamp(44px,6.2vw,88px);line-height:1;color:#020617}
.switch-band h2 em{color:#06B6D4}
.switch-band-sub{margin:32px auto 0;color:rgba(2,6,23,.65);font-size:clamp(17px,1.4vw,20px);line-height:1.55;max-width:56ch;text-align:center}
.switch-band-cta{margin:40px auto 0;display:inline-flex;color:#020617;border-color:rgba(2,6,23,.25)}
.switch-band-cta:hover{background:rgba(2,6,23,.05);border-color:#020617}

/* ==========================================================
   PRICING PAGE
   Hero (dark) → tier grid (paper) → enterprise row (dark card) →
   add-ons (paper) → FAQ → final CTA → footer.
   Palette-compliant: Electric Cyan / Space Black / Slate Gray / Paper.
   ========================================================== */

/* Hero */
.pricing-hero{background:#020617;color:#fff;padding:clamp(120px,14vw,180px) var(--pad) clamp(120px,12vw,160px);text-align:center;position:relative;overflow:hidden;border-bottom:1px solid #0a0a0b}
.pricing-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(55% 70% at 50% 0%,rgba(6,182,212,.10) 0%,transparent 60%);pointer-events:none}
.pricing-hero > .container{position:relative;z-index:1;max-width:980px}
.pricing-hero .eyebrow{color:#06B6D4;margin-bottom:32px}
.pricing-hero .eyebrow::before{background:#06B6D4;box-shadow:0 0 12px #06B6D4}
.pricing-hero h1{font-size:clamp(56px,7.5vw,104px);font-weight:700;letter-spacing:-.04em;line-height:.98;max-width:16ch;margin:0 auto;color:#fff}
.pricing-hero h1 em{font-family:'Fraunces','Lora',serif;font-style:italic;font-weight:400;color:#06B6D4;letter-spacing:-.02em}
.pricing-lede{font-size:clamp(17px,1.4vw,20px);color:#94A3B8;margin:32px auto 0;max-width:56ch;line-height:1.55}

/* Billing toggle */
.billing-toggle{display:inline-flex;margin-top:44px;padding:5px;border-radius:999px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);gap:2px}
.billing-btn{padding:11px 24px;border:none;background:transparent;color:rgba(255,255,255,.7);font-size:14px;font-weight:500;letter-spacing:-.01em;cursor:pointer;border-radius:999px;transition:background-color .25s ease,color .25s ease;font-family:inherit;display:inline-flex;align-items:center;gap:10px}
.billing-btn:hover{color:#fff}
.billing-btn.is-active{background:#06B6D4;color:#020617;font-weight:600}
.save-badge{display:inline-block;font-size:10px;font-weight:700;color:#22C55E;letter-spacing:.14em;text-transform:uppercase;padding:3px 8px;border:1px solid rgba(34,197,94,.4);border-radius:999px;background:rgba(34,197,94,.08)}
.billing-btn.is-active .save-badge{color:#020617;border-color:rgba(2,6,23,.3);background:rgba(2,6,23,.12)}

/* Tier grid section (paper, sits on top of dark hero) */
.pricing-tiers{background:var(--paper);color:#020617;padding:clamp(72px,9vw,120px) 0 clamp(72px,8vw,110px);position:relative;margin-top:-64px;border-radius:40px 40px 0 0;z-index:2}
.pricing-tiers > .container{max-width:1280px}
.tier-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
@media (max-width:960px){.tier-grid{grid-template-columns:1fr;gap:20px}}

/* Tier card */
.tier{background:#fff;border:1px solid var(--line);border-radius:22px;padding:40px 32px;display:flex;flex-direction:column;gap:28px;transition:transform .35s cubic-bezier(.16,.84,.3,1),box-shadow .35s cubic-bezier(.16,.84,.3,1),border-color .35s;position:relative}
.tier:hover{transform:translateY(-4px);box-shadow:0 40px 80px -30px rgba(2,6,23,.18);border-color:rgba(6,182,212,.25)}

/* Popular card — cyan accent border + elevated shadow */
.tier-popular{border-color:#06B6D4;box-shadow:0 30px 70px -25px rgba(6,182,212,.22)}
.tier-popular:hover{border-color:#06B6D4;box-shadow:0 50px 90px -28px rgba(6,182,212,.28)}

.popular-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:#06B6D4;color:#020617;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:6px 14px;border-radius:999px;white-space:nowrap;box-shadow:0 8px 24px -8px rgba(6,182,212,.5)}

/* Tier head — name, price, tagline, CTA */
.tier-head{display:flex;flex-direction:column;gap:0;padding-bottom:24px;border-bottom:1px solid var(--line)}
.tier-name{display:inline-block;font-size:13px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#06B6D4}
.tier-price{display:flex;align-items:baseline;gap:2px;margin-top:18px}
.tier-price .currency{font-family:'JetBrains Mono',monospace;font-size:26px;font-weight:500;color:#020617;align-self:flex-start;margin-top:14px}
.tier-price .amount{font-family:'JetBrains Mono',monospace;font-size:clamp(64px,6.2vw,80px);font-weight:600;letter-spacing:-.04em;color:#020617;line-height:1;font-variant-numeric:tabular-nums}
.tier-price .per{font-size:16px;color:#94A3B8;margin-left:8px;font-weight:500;align-self:flex-end;margin-bottom:10px}
.tier-tagline{font-size:16px;color:rgba(2,6,23,.7);margin-top:10px;line-height:1.5;min-height:48px}
.tier-cta{width:100%;justify-content:center;margin-top:22px}
.tier .btn-ghost.tier-cta{border-color:rgba(2,6,23,.2);color:#020617;background:transparent}
.tier .btn-ghost.tier-cta:hover{background:rgba(2,6,23,.04);border-color:#020617}

/* Feature groups inside tier */
.tier-features{display:flex;flex-direction:column;gap:26px}
.feature-group h4{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#94A3B8;margin-bottom:14px}
.feature-group-inherit h4{color:#06B6D4}
.feature-group ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.feature-group li{position:relative;padding-left:28px;font-size:15px;line-height:1.45;color:#020617;font-weight:400}
.feature-group li::before{content:"";position:absolute;left:0;top:4px;width:18px;height:18px;border-radius:50%;background-color:#22C55E;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-size:11px 11px;background-repeat:no-repeat;background-position:center}

/* Enterprise row (dark card) */
.enterprise-row{margin:48px auto 0;background:#020617;color:#fff;border-radius:22px;padding:clamp(32px,4vw,56px);display:grid;grid-template-columns:1.7fr 1fr;align-items:center;gap:clamp(24px,4vw,56px);position:relative;overflow:hidden;border:1px solid #1f2937}
.enterprise-row::before{content:"";position:absolute;right:-80px;top:-80px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(245,158,11,.18) 0%,transparent 65%);pointer-events:none}
@media (max-width:860px){.enterprise-row{grid-template-columns:1fr}}
.enterprise-name{color:#F59E0B}
.enterprise-left h3{font-size:clamp(24px,2.2vw,30px);font-weight:600;letter-spacing:-.02em;line-height:1.2;margin-top:16px;color:#fff;max-width:28ch}
.enterprise-left p{font-size:16px;color:#94A3B8;margin-top:14px;line-height:1.55;max-width:52ch}
.enterprise-right{display:flex;flex-direction:column;align-items:flex-start;gap:20px;position:relative;z-index:1}
.enterprise-price{font-family:'JetBrains Mono',monospace;font-size:clamp(40px,4.2vw,56px);font-weight:600;letter-spacing:-.03em;color:#F59E0B;line-height:1}

/* Full feature comparison table (pricing page) — white card on paper bg,
   cyan category rows, green checks, slate-gray missing, amber dev flag. */
.cmp-section{background:var(--paper);color:#020617;padding:clamp(72px,9vw,120px) 0;border-top:1px solid var(--line)}
.cmp-inner{max-width:1200px}
.cmp-header h2{color:#020617;font-size:clamp(40px,5vw,64px);line-height:1;max-width:18ch}
.cmp-header h2 em{font-family:'Fraunces','Lora',serif;font-style:italic;font-weight:400;color:#06B6D4;letter-spacing:-.01em}
.cmp-sub{margin:16px auto 0;font-size:18px;line-height:1.55;color:rgba(2,6,23,.62);max-width:52ch}
.cmp-scroll{position:relative;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:14px;border:1px solid var(--line);background:#fff;box-shadow:0 30px 70px -30px rgba(2,6,23,.14)}
/* Right-edge fade — hints at horizontal scrollability on narrow viewports. */
.cmp-scroll::after{content:"";position:absolute;top:0;right:0;bottom:0;width:36px;background:linear-gradient(to right,rgba(255,255,255,0) 0%,rgba(255,255,255,.96) 100%);pointer-events:none;border-radius:0 13px 13px 0;opacity:0;transition:opacity .2s}
.cmp-scroll.has-overflow::after{opacity:1}
.cmp-table{width:100%;border-collapse:separate;border-spacing:0;font-size:15px;min-width:920px}
.cmp-table thead th{text-align:left;padding:18px 22px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:#94A3B8;border-bottom:1px solid var(--line);background:var(--paper);white-space:nowrap}
.cmp-table thead th:not(:last-child){border-right:1px solid var(--line)}
.cmp-table thead th:first-child{color:#020617}
.cmp-table thead th.th-kiq{color:#06B6D4}
.cmp-table thead th.th-ekos,.cmp-table thead th.th-ollie,.cmp-table thead th.th-crafted{color:#94A3B8}
.cmp-table tbody td{padding:14px 22px;border-bottom:1px solid var(--line);color:#020617;vertical-align:top;line-height:1.45}
.cmp-table tbody td:not(:last-child){border-right:1px solid var(--line)}
.cmp-table tbody tr:last-child td{border-bottom:none}
.cmp-table tbody tr:hover td{background:rgba(6,182,212,.04)}
.cmp-table tbody tr.cmp-group td{padding:18px 22px 10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.16em;color:#06B6D4;background:var(--paper);border-bottom:1px solid var(--line)}
.cmp-table tbody tr.cmp-group:hover td{background:var(--paper)}
.cmp-table tbody td.cmp-feat{font-weight:600;color:#020617}
.cmp-table tbody td.cmp-yes{color:#020617;font-weight:500}
.cmp-table tbody td.cmp-no{color:#94A3B8}
.cmp-table tbody td.cmp-dev{color:#F59E0B;font-style:italic}
.cmp-foot{margin-top:20px;font-size:14px;color:rgba(2,6,23,.5);line-height:1.55;max-width:80ch}

/* Narrow-viewport — shrink table so more columns fit without needing to scroll;
   when scroll is still needed, the right-edge fade hints at it. */
@media (max-width:960px){
  .cmp-table{font-size:13px;min-width:760px}
  .cmp-table thead th{font-size:10px;padding:12px 14px}
  .cmp-table tbody td{padding:10px 14px}
  .cmp-table tbody tr.cmp-group td{padding:14px 14px 8px;font-size:10px}
  .cmp-scroll::after{width:28px}
}
@media (max-width:600px){
  .cmp-table{min-width:640px}
  .cmp-table thead th,.cmp-table tbody td{padding:9px 12px}
}

/* Add-ons section */
.addons-section{background:var(--paper);padding:clamp(72px,10vw,140px) 0;color:#020617;border-top:1px solid var(--line)}
.addons-section > .container{max-width:1280px}
.addon-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:860px){.addon-grid{grid-template-columns:1fr}}
.addon-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px 28px;transition:transform .3s,border-color .3s,box-shadow .3s}
.addon-card:hover{transform:translateY(-3px);border-color:rgba(6,182,212,.35);box-shadow:0 24px 50px -20px rgba(2,6,23,.12)}
.addon-header{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:12px}
.addon-header h3{font-size:19px;font-weight:600;letter-spacing:-.01em;color:#020617;line-height:1.3}
.addon-price{font-family:'JetBrains Mono',monospace;font-size:22px;font-weight:600;color:#06B6D4;letter-spacing:-.02em;white-space:nowrap;line-height:1}
.addon-price span{font-size:13px;color:#94A3B8;font-weight:500;margin-left:2px}
.addon-card p{font-size:15px;color:rgba(2,6,23,.62);line-height:1.55;margin:0}

/* Tighten tier internals on narrow screens */
@media (max-width:600px){
  .tier{padding:32px 24px;gap:24px}
  .tier-head{padding-bottom:20px}
  .tier-price .amount{font-size:56px}
  .enterprise-row{padding:32px 24px;margin-top:32px}
  .enterprise-price{font-size:40px}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .hero-video{display:none}
  .final video{display:none}
}
