/* ═══════════════════════════════════════════════════════════
   FitSync V2 — landing page styles
   ═══════════════════════════════════════════════════════════ */

:root{
  --primary:        #1DB954;
  --primary-dark:   #17A346;
  --primary-soft:   rgba(29,185,84,.14);
  --primary-glow:   rgba(29,185,84,.35);
  --bg:             #0E1410;
  --bg-2:           #0A0F0C;
  --surface:        #161A17;
  --surface-2:      #1F2420;
  --surface-3:      #22272A;
  --fg:             #F4F5F2;
  --fg-2:           #E8EAE6;
  --muted:          #8B928D;
  --muted-2:        #6B716E;
  --divider:        #252A26;
  --sage:           #7FA28C;
  --clay:           #D49872;
  --lavender:       #B4ADD1;
  --peach:          #F2B68D;
  --coach-blue:     #4A90FF;
  --error:          #FF453A;

  --serif: "Newsreader", "PT Serif", Georgia, serif;
  --sans:  "Geist", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
  --mono:  "Geist Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
}

*,*::before,*::after{ box-sizing: border-box; }
html,body{ margin:0; padding:0; }
html{ scroll-behavior: smooth; }
body{
  background: var(--bg);
  color: var(--fg);
  font-family: var(--sans);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
a{ color: inherit; text-decoration: none; }
img{ display:block; max-width:100%; }
button{ font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }

/* ─── Type primitives ─── */
.eyebrow{
  font-family: var(--sans);
  font-size: 11px; font-weight: 500;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--primary);
}
h1,h2,h3,h4{ margin: 0; font-weight: 400; letter-spacing: -.015em; }
h1.display{
  font-family: var(--serif);
  font-size: clamp(54px, 8.4vw, 124px);
  line-height: .96; letter-spacing: -.025em; font-weight: 400;
}
h1.display .green{ color: var(--primary); font-style: italic; font-weight: 400; }
h2.section-title{
  font-family: var(--serif);
  font-size: clamp(40px, 5.4vw, 84px);
  line-height: 1.02; letter-spacing: -.022em; font-weight: 400;
}
h3.feat-title{
  font-family: var(--serif);
  font-size: clamp(26px, 2.4vw, 38px);
  line-height: 1.05; font-weight: 400;
}
.kicker{ color: var(--primary); font-style: italic; font-weight: 400; }
.lead{ font-size: clamp(16px, 1.15vw, 18px); line-height: 1.6; color: var(--muted); max-width: 56ch; }
.lead b{ color: var(--fg); }

/* ─── Layout ─── */
.wrap{ width: min(1280px, 92vw); margin: 0 auto; position: relative; }
section{ position: relative; padding: clamp(64px, 7vw, 110px) 0; }

/* ─── Nav ─── */
.nav{
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: blur(18px) saturate(150%);
  -webkit-backdrop-filter: blur(18px) saturate(150%);
  background: color-mix(in srgb, var(--bg) 78%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--divider) 70%, transparent);
}
.nav-inner{
  width: min(1280px, 92vw); margin: 0 auto;
  display: flex; align-items: center; gap: 36px; padding: 14px 0;
}
.brand{
  font-family: var(--serif); font-size: 22px;
  letter-spacing: -.01em; display: inline-flex; align-items: center; gap: 2px;
}
.brand b{ font-weight: 500; }
.brand i{ color: var(--primary); font-style: normal; font-weight: 500; }

.nav-links{ display: flex; gap: 28px; font-size: 14px; color: var(--muted); }
.nav-links a{ position: relative; transition: color .18s ease; }
.nav-links a:hover{ color: var(--fg); }
.nav-links a:hover::after{
  content:""; position: absolute; left: 0; right: 0; bottom: -4px;
  height: 1px; background: var(--primary);
}

.nav-cta{ margin-left: auto; display: flex; gap: 14px; align-items: center; }
.nav-link-sub{ font-size: 13px; color: var(--muted); transition: color .18s; }
.nav-link-sub:hover{ color: var(--primary); }
.nav-install .ico{ width: 14px; height: 14px; }

/* ─── Buttons ─── */
.btn{
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 13px 22px;
  border-radius: 999px;
  font-size: 14px; font-weight: 600;
  letter-spacing: -.005em;
  transition: transform .18s ease, background .18s ease, box-shadow .18s ease, border-color .18s ease;
  white-space: nowrap;
  text-align: center;
}
.btn:hover{ transform: translateY(-1px); }
.btn:active{ transform: translateY(0); }
.btn-lg{ padding: 17px 28px; font-size: 15px; }
.btn-sm{ padding: 9px 16px; font-size: 13px; }
.btn-block{ display: flex; width: 100%; padding: 16px 22px; }
.btn-block .btn-sub{ display: block; font-size: 11px; font-weight: 400; opacity: .7; margin-top: 2px; letter-spacing: 0; }

.btn-primary{
  background: var(--primary); color: #051a0c;
  box-shadow:
    0 14px 32px -10px var(--primary-glow),
    0 0 0 1px rgba(0,0,0,.1),
    inset 0 1px 0 rgba(255,255,255,.3);
}
.btn-primary:hover{ background: #2bcb63; box-shadow: 0 18px 40px -10px var(--primary-glow), 0 0 0 1px rgba(0,0,0,.1), inset 0 1px 0 rgba(255,255,255,.35); }
.btn-primary .ico{ color: #051a0c; }
.btn-primary svg{ width: 14px; height: 14px; }

.btn-ghost{
  background: rgba(255,255,255,.04);
  color: var(--fg);
  border: 1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(8px);
}
.btn-ghost:hover{ background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.22); }
.btn-ghost svg{ width: 14px; height: 14px; }

.btn-clay{
  background: var(--clay); color: #1a0e07;
  box-shadow: 0 14px 30px -10px rgba(212,152,114,.45), inset 0 1px 0 rgba(255,255,255,.25);
}
.btn-clay:hover{ background: #e2a984; }
.btn-clay svg{ width: 14px; height: 14px; }

/* ═══════════════════════════════════════════════════════════
   iPhone frame component — iPhone 15/16 Pro style
   Tuned for 1206×2436 screenshots (aspect ≈ 0.495)
   ═══════════════════════════════════════════════════════════ */
.iphone{
  --phone-w: 340px;
  --bezel: 10px;
  --status-h: 40px;
  width: var(--phone-w);
  aspect-ratio: 340 / 702;
  position: relative;
  /* outer drop shadow + side button silhouettes via filter */
  filter:
    drop-shadow(0 60px 80px rgba(0,0,0,.55))
    drop-shadow(0 25px 40px rgba(29,185,84,.18));
}
.iphone-sm{ --phone-w: 290px; --bezel: 9px; --status-h: 34px; }
.iphone-xs{ --phone-w: 240px; --bezel: 8px; --status-h: 28px; }
.iphone-md{ --phone-w: 320px; --bezel: 10px; --status-h: 38px; }
.iphone-mini{ --phone-w: 168px; --bezel: 6px; --status-h: 22px; }

/* Side buttons (silver slivers on the bezel edge) */
.iphone::before, .iphone::after{
  content:""; position: absolute;
  background: linear-gradient(90deg, #1a1f1c, #4a514c 30%, #1a1f1c);
  border-radius: 2px;
  z-index: 0;
}
.iphone::before{
  /* Volume up + down + silent switch (left side) */
  left: -2px; top: 22%;
  width: 3px; height: 7%;
  box-shadow:
    0 calc(var(--phone-w) * 0.06) 0 -1px #1a1f1c,
    0 calc(var(--phone-w) * 0.18) 0 0 #2a2f2c,
    0 calc(var(--phone-w) * 0.18) 0 -1px transparent,
    0 calc(var(--phone-w) * 0.32) 0 -1px #1a1f1c;
}
.iphone::after{
  /* Power button (right side) */
  right: -2px; top: 26%;
  width: 3px; height: 12%;
}

.iphone-bezel{
  position: absolute; inset: 0;
  border-radius: 50px;
  background:
    linear-gradient(160deg, #2a2f2b 0%, #0d100e 35%, #1c2520 70%, #0a0e0c 100%);
  padding: var(--bezel);
  overflow: hidden;
  z-index: 1;
  /* inner ring for the chamfered edge */
  box-shadow:
    inset 0 0 0 1.5px rgba(255,255,255,.05),
    inset 0 0 0 3px rgba(0,0,0,.4),
    inset 0 0 0 4px rgba(50,55,52,.5);
}
.iphone-bezel::before{
  /* outer edge highlight — top-left and bottom-right */
  content:""; position: absolute; inset: 0;
  border-radius: 50px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.14) 0%, transparent 25%),
    linear-gradient(315deg, rgba(255,255,255,.06) 0%, transparent 30%);
  pointer-events: none;
  z-index: 5;
  mix-blend-mode: screen;
}

/* The screen — has a status bar above the actual screenshot */
.iphone-screen{
  position: absolute;
  inset: var(--bezel);
  border-radius: calc(50px - var(--bezel));
  overflow: hidden;
  background: #0E1410;
  z-index: 2;
  display: flex; flex-direction: column;
}

/* iOS status bar — synthesized to match real phones.
   Sits ABOVE the screenshot so the FitSync app header lines up naturally. */
.iphone-statusbar{
  position: relative;
  flex: 0 0 var(--status-h);
  width: 100%;
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 0 calc(var(--phone-w) * 0.075);
  padding-top: calc(var(--status-h) * 0.32);
  color: #fff;
  font-family: -apple-system, "SF Pro Text", "Helvetica Neue", sans-serif;
  z-index: 4;
  background: #0E1410;
}
.iphone-statusbar .sb-time{
  font-size: calc(var(--phone-w) * 0.044);
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  z-index: 5;
}
.iphone-statusbar .sb-indicators{
  display: inline-flex; align-items: center;
  gap: calc(var(--phone-w) * 0.012);
  height: calc(var(--phone-w) * 0.04);
}
.iphone-statusbar .sb-indicators svg{
  height: 100%; width: auto;
  fill: #fff;
}

/* Dynamic Island — sits OVER the status bar, centered horizontally */
.iphone-island{
  position: absolute;
  top: calc(var(--status-h) * 0.20);
  left: 50%; transform: translateX(-50%);
  width: calc(var(--phone-w) * 0.34);
  height: calc(var(--phone-w) * 0.085);
  background: #000;
  border-radius: 999px;
  z-index: 6;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.04),
    inset 0 1px 1px rgba(255,255,255,.06);
}
.iphone-island::after{
  /* camera lens — subtle dot on the right side */
  content:""; position: absolute;
  right: 12%; top: 50%; transform: translateY(-50%);
  width: 22%; aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 35%, #2a4555 0%, #0a1820 40%, #000 75%);
}

/* The actual app screenshot */
.iphone-content{
  flex: 1;
  position: relative;
  overflow: hidden;
  background: #0E1410;
}
.iphone-content img{
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

/* Reflective glare on the glass */
.iphone-glare{
  position: absolute; inset: 0;
  border-radius: 50px;
  background:
    linear-gradient(115deg, rgba(255,255,255,.07) 0%, transparent 22%, transparent 78%, rgba(255,255,255,.03) 100%);
  pointer-events: none;
  z-index: 7;
  mix-blend-mode: screen;
}

/* ═══════════════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════════════ */
.hero{
  padding-top: clamp(48px, 5.5vw, 90px);
  padding-bottom: clamp(48px, 5.5vw, 90px);
  overflow: hidden;
}
.hero-bg{ position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 0; }
.hero-bg::before{
  content:""; position: absolute; top: -25%; right: -10%;
  width: 70vw; height: 70vw;
  background: radial-gradient(closest-side, rgba(29,185,84,.2), transparent 70%);
  filter: blur(20px);
}
.hero-bg::after{
  content:""; position: absolute; bottom: -40%; left: -10%;
  width: 50vw; height: 50vw;
  background: radial-gradient(closest-side, rgba(127,162,140,.12), transparent 70%);
  filter: blur(20px);
}

.hero-grid{
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  column-gap: 80px;
  align-items: center;
}
.hero-copy{ align-self: center; }

.hero-eyebrow{
  display: inline-flex; align-items: center; gap: 12px;
  padding: 7px 14px;
  border: 1px solid rgba(29,185,84,.32);
  background: var(--primary-soft);
  border-radius: 999px;
  color: var(--primary);
  font-size: 11px; letter-spacing: .14em; font-weight: 500;
  text-transform: uppercase;
  margin-bottom: 28px;
}
.hero-eyebrow .dot{
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--primary);
  box-shadow: 0 0 0 4px rgba(29,185,84,.18);
  animation: pulse 2s ease-in-out infinite;
}
.hero-eyebrow .eyebrow-divider{
  width: 1px; height: 12px; background: rgba(29,185,84,.35);
}
.hero-eyebrow .eyebrow-pwa{ color: rgba(255,255,255,.7); letter-spacing: .1em; }

@keyframes pulse{
  0%,100%{ box-shadow: 0 0 0 4px rgba(29,185,84,.18); }
  50%{ box-shadow: 0 0 0 8px rgba(29,185,84,.05); }
}

.hero h1{ margin-bottom: 24px; }
.hero-lead{ font-size: clamp(17px, 1.25vw, 20px); max-width: 50ch; }

.hero-ctas{ margin-top: 32px; display: flex; gap: 12px; flex-wrap: wrap; }

.hero-meta{
  margin-top: 28px;
  display: flex; gap: 24px; flex-wrap: wrap;
  font-size: 13px; color: var(--muted);
}
.meta-item{ display: inline-flex; align-items: center; gap: 8px; }
.meta-item svg{ width: 14px; height: 14px; color: var(--primary); flex: 0 0 14px; }
.meta-item b{ color: var(--fg); font-weight: 600; }

.store-row{
  margin-top: 32px;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px;
  max-width: 560px;
}
.store-coming{
  display: flex; align-items: center; gap: 11px;
  padding: 12px 14px;
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 14px;
  opacity: .65;
  position: relative;
}
.store-coming.live{ opacity: 1; border-color: rgba(29,185,84,.35); background: linear-gradient(135deg, rgba(29,185,84,.06), var(--surface)); }
.store-coming svg{ width: 22px; height: 22px; color: var(--fg); flex: 0 0 22px; }
.store-coming.live svg{ color: var(--primary); }
.store-coming-text{ display: flex; flex-direction: column; line-height: 1.1; min-width: 0; }
.store-coming-text .lab{ font-size: 9px; color: var(--muted); letter-spacing: .14em; text-transform: uppercase; }
.store-coming-text .val{ font-size: 13px; font-weight: 600; color: var(--fg); margin-top: 2px; }
.live-lab{ color: var(--primary) !important; display: inline-flex; align-items: center; gap: 5px; }
.live-dot{
  width: 6px; height: 6px; border-radius: 50%; background: var(--primary);
  animation: pulse-dot 1.6s ease-in-out infinite;
}
@keyframes pulse-dot{ 0%,100%{ opacity: 1; transform: scale(1); } 50%{ opacity: .5; transform: scale(.8); } }

/* Hero phone — DUAL phone showcase (dashboard + MyCoach, Cal AI style) */
.hero-phone-wrap{
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  padding: 32px 0;
  min-height: 600px;
}
.hp-glow{
  position: absolute; inset: 0;
  background:
    radial-gradient(closest-side at 30% 50%, rgba(29,185,84,.28), transparent 55%),
    radial-gradient(closest-side at 70% 50%, rgba(74,144,255,.16), transparent 55%);
  filter: blur(50px);
  pointer-events: none;
  z-index: 0;
}
.hero-phone-wrap .iphone{
  position: relative;
  z-index: 1;
  --phone-w: clamp(170px, 19vw, 240px);
  width: var(--phone-w);
  filter:
    drop-shadow(0 50px 70px rgba(0,0,0,.6))
    drop-shadow(0 20px 35px rgba(29,185,84,.2));
  transition: transform .4s cubic-bezier(.2,.8,.3,1), z-index 0s .3s;
}
.hero-phone-left{
  transform: rotate(-5deg) translate(20px, 30px);
  z-index: 1;
}
.hero-phone-right{
  transform: rotate(5deg) translate(-20px, -30px);
  z-index: 2;
}
.hero-phone-wrap .iphone:hover{
  transform: rotate(0) translateY(-6px) scale(1.02);
  z-index: 4;
  transition: transform .4s cubic-bezier(.2,.8,.3,1);
}

.hp-label{
  position: absolute;
  bottom: -32px; left: 50%; transform: translateX(-50%);
  font-size: 10px;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
  white-space: nowrap;
}
.hp-label-coach{
  color: var(--primary);
  display: inline-flex; align-items: center; gap: 6px;
}
.hp-label-coach .pulse-dot{
  width: 6px; height: 6px;
  box-shadow: 0 0 0 3px rgba(29,185,84,.18);
  flex: 0 0 6px;
}

/* Floating stickers — repositioned for the dual layout */
.sticker{
  position: absolute; z-index: 5;
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 14px;
  padding: 11px 16px;
  font-size: 12px; color: var(--fg);
  box-shadow: 0 24px 50px -16px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.03);
  display: flex; align-items: center; gap: 12px;
  backdrop-filter: blur(10px);
  animation: float 6s ease-in-out infinite;
}
.sticker b{ font-weight: 600; font-size: 13px; line-height: 1.2; }
.sticker .sub{ color: var(--muted); font-size: 11px; }
.sticker-1{ top: 8px; left: 0; animation-delay: 0s; }
.sticker-3{ bottom: 8px; right: 0; animation-delay: -3s; }

.pulse-dot{
  width: 10px; height: 10px; border-radius: 50%; background: var(--primary);
  box-shadow: 0 0 0 4px rgba(29,185,84,.18);
  animation: pulse 2s ease-in-out infinite;
  flex: 0 0 10px;
}

@keyframes float{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-6px); }
}

/* ─── Mobile-only hero dual phone showcase (hidden by default) ─── */
.hero-mobile-phones{ display: none; }


/* ═══════════════════════════════════════════════════════════
   TRUST BAR / MARQUEE
   ═══════════════════════════════════════════════════════════ */
.trust{
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
  padding: 0;
}
.marquee{
  overflow: hidden;
  padding: 22px 0;
  position: relative;
  border-bottom: 1px solid var(--divider);
}
.marquee::before, .marquee::after{
  content:""; position: absolute; top: 0; bottom: 0; width: 140px; z-index: 2; pointer-events: none;
}
.marquee::before{ left: 0; background: linear-gradient(90deg, var(--bg), transparent); }
.marquee::after{ right: 0; background: linear-gradient(270deg, var(--bg), transparent); }
.marquee-track{
  display: flex; gap: 28px;
  width: max-content;
  animation: scroll 50s linear infinite;
  align-items: center;
}
.marquee-track:hover{ animation-play-state: paused; }
.m-item{
  display: inline-flex; align-items: center; gap: 28px;
  font-family: var(--serif);
  font-size: clamp(24px, 2.8vw, 40px);
  line-height: 1;
  letter-spacing: -.015em;
  font-weight: 400;
  color: var(--fg);
  white-space: nowrap;
}
.m-item em{ font-style: italic; color: var(--primary); }
.m-star{ color: var(--primary); font-size: 18px; }
@keyframes scroll{ from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce){ .marquee-track{ animation: none; } }

.trust-row{
  display: grid; grid-template-columns: 1fr 1px 1fr 1px 1fr 1px 1fr; gap: 22px;
  align-items: center;
  padding: 32px 0;
}
.trust-stat{ text-align: center; }
.trust-v{ font-family: var(--serif); font-size: clamp(28px, 3.4vw, 44px); line-height: 1; letter-spacing: -.02em; color: var(--fg); font-weight: 400; }
.trust-l{ font-size: 12px; color: var(--muted); margin-top: 8px; max-width: 22ch; margin-left: auto; margin-right: auto; line-height: 1.4; }
.trust-sep{ width: 1px; height: 36px; background: var(--divider); justify-self: center; }

/* ═══════════════════════════════════════════════════════════
   VIDEO SECTION
   ═══════════════════════════════════════════════════════════ */
.video-section{ background: var(--bg); }
.section-head{ max-width: 720px; margin-bottom: 56px; }
.section-head.center{ margin: 0 auto 64px; text-align: center; }
.section-head .eyebrow{ display: inline-block; margin-bottom: 18px; }
.section-head .lead{ margin-top: 24px; }
.section-head.center .lead{ margin-left: auto; margin-right: auto; }

/* 9:16 portrait layout: copy on the left, phone-framed video on the right */
.video-section-grid{
  display: grid;
  grid-template-columns: 1fr 480px;
  gap: 64px;
  align-items: center;
}
.video-section-grid .section-head{
  margin: 0;
  max-width: none;
}

.video-side-meta{
  margin-top: 36px;
  display: flex; flex-direction: column;
  gap: 14px;
}
.vsm-row{
  display: flex; align-items: center; gap: 11px;
  font-size: 14px; color: var(--muted);
}
.vsm-row svg{ width: 16px; height: 16px; color: var(--primary); flex: 0 0 16px; }
.vsm-row b{ color: var(--fg); font-weight: 600; }
.vsm-dot{
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--primary);
  box-shadow: 0 0 0 4px rgba(29,185,84,.18);
  animation: pulse 2s ease-in-out infinite;
  flex: 0 0 9px;
}

.video-stage{
  position: relative;
  aspect-ratio: 16 / 9;
  border-radius: 24px;
  overflow: hidden;
  background: #000;
  border: 1px solid var(--divider);
  cursor: pointer;
  box-shadow: 0 60px 120px -40px rgba(0,0,0,.6), 0 30px 60px -25px rgba(29,185,84,.15);
}
/* Portrait variant — 9:16 with iPhone bezel framing */
.video-stage-portrait{
  aspect-ratio: 9 / 16;
  width: 100%;
  max-width: 380px;
  justify-self: center;
  margin: 0 auto;
  border-radius: 48px;
  border: 8px solid transparent;
  background: linear-gradient(160deg, #2a2f2b 0%, #0d100e 35%, #1c2520 70%, #0a0e0c 100%) padding-box;
  box-shadow:
    0 60px 90px -30px rgba(0,0,0,.65),
    0 30px 50px -20px rgba(29,185,84,.22),
    inset 0 0 0 1.5px rgba(255,255,255,.05);
}
.video-stage-portrait .video-bg{
  border-radius: 40px;
}
.video-phone-frame{
  position: absolute; inset: 0;
  border-radius: 40px;
  pointer-events: none;
  z-index: 4;
  box-shadow: inset 0 0 0 1.5px rgba(0,0,0,.4), inset 0 0 0 3px rgba(50,55,52,.4);
  background:
    linear-gradient(115deg, rgba(255,255,255,.05) 0%, transparent 25%, transparent 75%, rgba(255,255,255,.03) 100%);
  mix-blend-mode: screen;
}
.video-phone-island{
  position: absolute;
  top: 14px; left: 50%; transform: translateX(-50%);
  width: 100px; height: 30px;
  background: #000;
  border-radius: 999px;
  z-index: 5;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.04),
    inset 0 1px 1px rgba(255,255,255,.06),
    0 0 0 4px rgba(0,0,0,.3);
}
.video-phone-island::after{
  content:""; position: absolute;
  right: 10px; top: 50%; transform: translateY(-50%);
  width: 7px; height: 7px; border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, #2a4555 0%, #0a1820 40%, #000 75%);
}
.video-stage-portrait .video-corners{ display: none; }
.video-stage-portrait .video-overlay{
  border-radius: 40px;
}
.video-bg{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.video-overlay{
  position: absolute; inset: 0;
  background:
    radial-gradient(closest-side, transparent 30%, rgba(0,0,0,.4) 75%),
    linear-gradient(to top, rgba(0,0,0,.6), transparent 40%);
  display: flex; align-items: center; justify-content: center;
  transition: background .25s ease;
}
.video-stage:hover .video-overlay{ background: radial-gradient(closest-side, transparent 30%, rgba(0,0,0,.55) 75%), linear-gradient(to top, rgba(0,0,0,.65), transparent 40%); }
.video-play{
  width: 86px; height: 86px; border-radius: 50%;
  background: var(--primary);
  color: #051a0c;
  display: grid; place-items: center;
  box-shadow:
    0 20px 50px -10px rgba(29,185,84,.55),
    inset 0 1px 0 rgba(255,255,255,.3),
    0 0 0 0 rgba(29,185,84,.4);
  transition: transform .25s ease, box-shadow .25s ease;
  animation: pulse-play 2.4s ease-in-out infinite;
}
.video-play svg{ width: 32px; height: 32px; margin-left: 4px; }
.video-stage:hover .video-play{ transform: scale(1.08); }
@keyframes pulse-play{
  0%,100%{ box-shadow: 0 20px 50px -10px rgba(29,185,84,.55), inset 0 1px 0 rgba(255,255,255,.3), 0 0 0 0 rgba(29,185,84,.5); }
  50%{ box-shadow: 0 20px 50px -10px rgba(29,185,84,.55), inset 0 1px 0 rgba(255,255,255,.3), 0 0 0 24px rgba(29,185,84,0); }
}
.video-meta{
  position: absolute; bottom: 22px; left: 24px;
  display: flex; flex-direction: column; gap: 4px;
  pointer-events: none;
}
.vm-time{ font-family: var(--mono); font-size: 12px; color: rgba(255,255,255,.85); letter-spacing: .05em; }
.vm-cap{ font-size: 13px; color: rgba(255,255,255,.65); }

.video-corners .c{
  position: absolute;
  width: 24px; height: 24px;
  border: 2px solid var(--primary);
}
.video-corners .tl{ top: 16px; left: 16px; border-right: 0; border-bottom: 0; border-top-left-radius: 6px; }
.video-corners .tr{ top: 16px; right: 16px; border-left: 0; border-bottom: 0; border-top-right-radius: 6px; }
.video-corners .bl{ bottom: 16px; left: 16px; border-right: 0; border-top: 0; border-bottom-left-radius: 6px; }
.video-corners .br{ bottom: 16px; right: 16px; border-left: 0; border-top: 0; border-bottom-right-radius: 6px; }

/* ═══════════════════════════════════════════════════════════
   FEATURES GRID
   ═══════════════════════════════════════════════════════════ */
.feat-grid{
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 24px;
}
.feat-card{
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 24px;
  padding: 40px;
  display: grid; grid-template-columns: 1.1fr 1fr;
  gap: 36px; align-items: center;
  position: relative; overflow: hidden;
  grid-column: span 6;
}
.feat-card.feat-large{ grid-column: span 12; padding: 56px; gap: 56px; }
.feat-card.feat-large.flip .feat-phone-wrap{ order: -1; }

.feat-card::before{
  content:""; position: absolute;
  top: -30%; right: -20%;
  width: 60%; height: 80%;
  background: radial-gradient(closest-side, rgba(29,185,84,.08), transparent 70%);
  pointer-events: none;
}

.feat-num{
  font-family: var(--serif); font-style: italic;
  font-size: 14px; color: var(--primary);
  letter-spacing: -.005em;
}
.feat-title{ margin: 14px 0 18px; }
.feat-lead{ font-size: 15px; max-width: 36ch; line-height: 1.6; color: var(--muted); }

.feat-bullets{
  list-style: none; padding: 0; margin: 24px 0 0;
  display: grid; gap: 12px;
}
.feat-bullets li{
  display: flex; gap: 12px; align-items: flex-start;
  font-size: 14px; color: var(--fg-2);
  line-height: 1.5;
}
.feat-bullets li svg{
  flex: 0 0 18px; width: 18px; height: 18px;
  padding: 3px; border-radius: 6px;
  background: var(--primary-soft); color: var(--primary);
  margin-top: 1px;
}

.feat-phone-wrap{ display: grid; place-items: center; position: relative; }
.feat-phone-wrap::before{
  content:""; position: absolute;
  width: 100%; height: 100%;
  background: radial-gradient(closest-side, rgba(29,185,84,.14), transparent 60%);
  filter: blur(30px);
  pointer-events: none;
}
.feat-phone-wrap.small{ padding: 20px 0; }

/* ═══════════════════════════════════════════════════════════
   MYCOACH DEMO SECTION
   ═══════════════════════════════════════════════════════════ */
.coach-section{
  background: linear-gradient(180deg, var(--bg) 0%, #0b110d 100%);
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
  overflow: hidden;
}
.coach-grid{
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: center;
}
.coach-copy .section-title{ margin-top: 18px; max-width: 12ch; }
.coach-copy .lead{ margin-top: 24px; }
.coach-bullets{
  list-style: none; padding: 0; margin: 32px 0 0;
  display: grid; gap: 18px;
}
.coach-bullets li{
  display: flex; gap: 16px; align-items: flex-start;
}
.cb-ico{
  flex: 0 0 40px; width: 40px; height: 40px;
  border-radius: 11px;
  background: var(--primary-soft); color: var(--primary);
  display: grid; place-items: center;
}
.cb-ico svg{ width: 18px; height: 18px; }
.coach-bullets li b{ display: block; color: var(--fg); font-size: 15px; font-weight: 600; margin-bottom: 4px; }
.coach-bullets li span{ color: var(--muted); font-size: 13px; line-height: 1.55; }
.coach-cta-row{ margin-top: 36px; display: flex; gap: 12px; flex-wrap: wrap; }
.coach-cta-row .btn svg{ width: 12px; height: 12px; }

.coach-demo{ position: relative; display: grid; place-items: center; }
.coach-demo::before{
  content:""; position: absolute;
  width: 110%; height: 110%;
  background: radial-gradient(closest-side, rgba(29,185,84,.22), transparent 60%);
  filter: blur(40px);
  pointer-events: none;
  z-index: 0;
}

.chat-pop{
  position: absolute;
  z-index: 4;
  right: -40px; bottom: 80px;
  width: 380px;
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 20px;
  padding: 18px;
  box-shadow: 0 30px 60px -20px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.03);
  font-size: 13px;
  backdrop-filter: blur(20px);
}
.chat-head{
  display: flex; align-items: center; gap: 12px;
  padding-bottom: 14px; margin-bottom: 14px;
  border-bottom: 1px solid var(--divider);
}
.chat-spark{
  width: 32px; height: 32px; border-radius: 9px;
  background: var(--primary-soft); color: var(--primary);
  display: grid; place-items: center;
  flex: 0 0 32px;
}
.chat-spark svg{ width: 16px; height: 16px; }
.chat-head b{ display: block; font-size: 13px; font-weight: 600; color: var(--fg); }
.chat-sub{ font-size: 11px; color: var(--muted); }
.chat-typing{ margin-left: auto; display: inline-flex; gap: 3px; }
.chat-typing i{
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--primary);
  display: block;
  animation: typing 1.4s ease-in-out infinite;
}
.chat-typing i:nth-child(2){ animation-delay: .2s; }
.chat-typing i:nth-child(3){ animation-delay: .4s; }
@keyframes typing{
  0%,60%,100%{ opacity: .3; transform: translateY(0); }
  30%{ opacity: 1; transform: translateY(-3px); }
}

.chat-msg{ margin-bottom: 10px; display: flex; }
.chat-msg span{
  display: inline-block;
  padding: 10px 14px;
  border-radius: 14px;
  font-size: 13px; line-height: 1.45;
  max-width: 88%;
}
.chat-msg.user{ justify-content: flex-end; }
.chat-msg.user span{
  background: var(--surface-2);
  border: 1px solid var(--divider);
  color: var(--fg-2);
  border-bottom-right-radius: 4px;
}
.chat-msg.ai span{
  background: rgba(29,185,84,.08);
  border: 1px solid rgba(29,185,84,.22);
  color: var(--fg);
  border-bottom-left-radius: 4px;
}
.chat-msg.ai b{ color: var(--primary); font-weight: 600; }

.chat-tags{ display: flex; gap: 6px; flex-wrap: wrap; margin-top: 12px; }
.tag-chip{
  font-size: 10px;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--divider);
  color: var(--muted);
  letter-spacing: .04em;
}

/* ═══════════════════════════════════════════════════════════
   INSTALL / A2HS SECTION
   ═══════════════════════════════════════════════════════════ */
.install-section{
  background: var(--bg-2);
  position: relative;
  overflow: hidden;
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
}
.install-bg{
  position: absolute; inset: 0;
  background:
    radial-gradient(60% 80% at 50% 0%, rgba(29,185,84,.12), transparent 60%),
    radial-gradient(40% 50% at 90% 90%, rgba(127,162,140,.08), transparent 60%);
  pointer-events: none;
}
.install-section .wrap{ position: relative; z-index: 1; }

.install-tabs{
  display: flex; gap: 8px;
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 14px;
  padding: 6px;
  width: max-content;
  margin: 0 auto 48px;
}
.install-tab{
  display: inline-flex; align-items: center; gap: 9px;
  padding: 11px 20px;
  border-radius: 10px;
  font-size: 14px; font-weight: 600;
  color: var(--muted);
  transition: all .18s ease;
}
.install-tab svg{ width: 16px; height: 16px; }
.install-tab:hover{ color: var(--fg); }
.install-tab.active{
  background: var(--primary);
  color: #051a0c;
  box-shadow: 0 8px 20px -8px var(--primary-glow);
}

.install-panel{ display: none; }
.install-panel.active{ display: block; }

.install-steps{
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px;
}
.install-steps-android{ grid-template-columns: repeat(2, 1fr); max-width: 800px; margin: 0 auto; }

.install-step{
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 22px;
  padding: 28px;
  position: relative;
  display: flex; flex-direction: column;
}
.step-num{
  font-family: var(--serif); font-style: italic;
  font-size: 16px; color: var(--primary);
}

/* Step illustrations */
.step-illo{
  margin: 24px 0;
  background: var(--bg-2);
  border: 1px solid var(--divider);
  border-radius: 16px;
  padding: 24px;
  min-height: 200px;
  display: flex; flex-direction: column; justify-content: center;
  position: relative;
  overflow: hidden;
}

/* Illustration 1: Safari with Share */
.step-phone-mini{
  background: linear-gradient(180deg, #1a1f1c, #0d100e);
  border-radius: 18px;
  padding: 8px;
  margin: 0 auto;
  width: 100%; max-width: 200px;
  position: relative;
}
.step-phone-bar{
  height: 6px; width: 50px;
  background: #2a2f2b;
  border-radius: 3px;
  margin: 0 auto 10px;
}
.step-phone-content{
  background: #000;
  border-radius: 12px;
  padding: 14px 12px;
  text-align: center;
  position: relative;
}
.step-url{
  font-family: var(--mono);
  font-size: 11px;
  color: var(--fg-2);
  background: var(--surface-2);
  border-radius: 7px;
  padding: 6px 10px;
  margin-bottom: 30px;
}
.step-tap-circle{
  width: 60px; height: 60px;
  border-radius: 50%;
  background: var(--primary-soft);
  border: 2px solid var(--primary);
  display: grid; place-items: center;
  margin: 0 auto 12px;
  color: var(--primary);
  position: relative;
  animation: tap-ripple 2s ease-out infinite;
}
.step-tap-circle svg{ width: 24px; height: 24px; }
.step-tap-label{
  font-size: 11px; color: var(--primary); font-weight: 600;
  letter-spacing: .04em;
}
@keyframes tap-ripple{
  0%{ box-shadow: 0 0 0 0 rgba(29,185,84,.4); }
  100%{ box-shadow: 0 0 0 14px rgba(29,185,84,0); }
}

/* Illustration 2: Share sheet */
.step-illo-sheet{ padding: 16px; }
.sheet-header{
  font-size: 12px; font-weight: 600;
  color: var(--muted); letter-spacing: .08em;
  text-transform: uppercase;
  padding: 4px 10px 10px;
  border-bottom: 1px solid var(--divider);
  margin-bottom: 8px;
}
.sheet-row{
  display: flex; align-items: center; gap: 12px;
  padding: 9px 10px;
  border-radius: 9px;
  font-size: 13px; color: var(--fg-2);
}
.sheet-row.highlight{
  background: var(--primary-soft);
  border: 1px solid rgba(29,185,84,.3);
  color: var(--fg);
  box-shadow: 0 0 0 4px rgba(29,185,84,.08);
}
.sheet-row.highlight b{ color: var(--primary); font-weight: 600; }
.sheet-dot{
  width: 26px; height: 26px; border-radius: 7px;
  flex: 0 0 26px;
  display: grid; place-items: center;
}
.sheet-dot.copy{ background: #3b4a6b; }
.sheet-dot.bookmark{ background: #8b5a3b; }
.sheet-dot.a2hs{
  background: var(--primary); color: #051a0c;
}
.sheet-dot.a2hs svg{ width: 14px; height: 14px; }
.sheet-dot.print{ background: #4a4a52; }
.sheet-arrow{ margin-left: auto; width: 14px; height: 14px; color: var(--primary); }
.sheet-name{ font-weight: 500; }

/* Illustration 3: Confirm dialog */
.step-illo-confirm{ padding: 16px; }
.confirm-row{
  display: flex; align-items: center;
  padding: 10px 14px;
  background: var(--surface);
  border-radius: 12px;
  font-size: 12px;
  margin-bottom: 12px;
  border: 1px solid var(--divider);
}
.confirm-row span{ color: var(--muted); }
.confirm-row b{ flex: 1; text-align: center; font-weight: 500; color: var(--fg); }
.confirm-row .add-btn{
  color: var(--primary); font-weight: 700;
  background: rgba(29,185,84,.12);
  padding: 4px 10px;
  border-radius: 7px;
  animation: glow-pulse 2s ease-in-out infinite;
}
@keyframes glow-pulse{
  0%,100%{ background: rgba(29,185,84,.12); box-shadow: 0 0 0 0 rgba(29,185,84,.3); }
  50%{ background: rgba(29,185,84,.22); box-shadow: 0 0 0 6px rgba(29,185,84,0); }
}
.confirm-app{
  display: flex; align-items: center; gap: 12px;
  padding: 14px;
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 12px;
  margin-bottom: 12px;
}
.confirm-icon{
  width: 44px; height: 44px;
  background: var(--primary);
  border-radius: 11px;
  display: grid; place-items: center;
  box-shadow: 0 8px 16px -6px var(--primary-glow), inset 0 1px 0 rgba(255,255,255,.3);
}
.confirm-icon svg{ width: 24px; height: 24px; }
.confirm-meta{ display: flex; flex-direction: column; }
.confirm-meta b{ font-size: 14px; font-weight: 600; color: var(--fg); }
.confirm-meta span{ font-size: 11px; color: var(--muted); font-family: var(--mono); }
.confirm-hint{ font-size: 11px; color: var(--muted); text-align: center; }

/* Android illustrations */
.step-illo-android, .step-illo-android-menu{ padding: 14px; }
.and-bar{
  display: flex; align-items: center; gap: 8px;
  background: var(--surface-2);
  padding: 10px 12px;
  border-radius: 10px;
  margin-bottom: 12px;
}
.and-url{
  flex: 1; font-family: var(--mono);
  font-size: 12px; color: var(--fg-2);
}
.and-menu{ color: var(--muted); font-size: 18px; }
.and-banner{
  display: flex; align-items: center; gap: 12px;
  padding: 12px;
  background: var(--primary-soft);
  border: 1px solid rgba(29,185,84,.3);
  border-radius: 12px;
  font-size: 12px;
}
.and-banner svg{ width: 22px; height: 22px; color: var(--primary); flex: 0 0 22px; }
.and-banner span{ color: var(--fg-2); line-height: 1.4; flex: 1; }
.and-banner b{ color: var(--fg); }
.and-install-btn{
  flex: 0 0 auto !important;
  background: var(--primary); color: #051a0c !important;
  font-weight: 700 !important; font-size: 12px;
  padding: 7px 14px; border-radius: 999px;
}

.and-menu-list{
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 12px;
  padding: 6px;
}
.and-menu-row{
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px;
  font-size: 13px; color: var(--fg-2);
  border-radius: 8px;
}
.and-menu-row.hl{
  background: var(--primary-soft);
  color: var(--fg);
}
.and-menu-row.hl svg{ width: 16px; height: 16px; color: var(--primary); }
.and-menu-row.hl b{ color: var(--primary); font-weight: 600; }

/* Step body */
.step-body h4{
  font-family: var(--serif);
  font-size: 22px; font-weight: 500;
  letter-spacing: -.01em;
  margin-bottom: 8px;
}
.step-body p{
  font-size: 14px; line-height: 1.55;
  color: var(--muted);
  margin: 0;
}
.step-body p b{ color: var(--fg); font-weight: 600; }

/* Result */
.install-result{
  margin-top: 28px;
  display: flex; align-items: center; gap: 18px;
  padding: 20px 24px;
  background: linear-gradient(135deg, rgba(29,185,84,.08), rgba(29,185,84,.02));
  border: 1px solid rgba(29,185,84,.3);
  border-radius: 18px;
}
.result-icon{
  width: 44px; height: 44px; border-radius: 12px;
  background: var(--primary);
  color: #051a0c;
  display: grid; place-items: center;
  flex: 0 0 44px;
  box-shadow: 0 8px 20px -6px var(--primary-glow);
}
.result-icon svg{ width: 22px; height: 22px; }
.install-result b{ display: block; color: var(--fg); font-size: 15px; font-weight: 600; margin-bottom: 3px; }
.install-result span{ color: var(--muted); font-size: 13px; }

.install-cta{ text-align: center; margin-top: 56px; }
.install-cta .btn .ico{ width: 14px; height: 14px; }
.install-cta-sub{ font-size: 13px; color: var(--muted); margin-top: 14px; }
.install-cta-sub b{ color: var(--fg); }

/* ═══════════════════════════════════════════════════════════
   PRICING
   ═══════════════════════════════════════════════════════════ */
.pricing-section{ background: var(--bg); }
.price-grid{
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
.price-card{
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 24px;
  padding: 36px;
  display: flex; flex-direction: column;
  position: relative;
  overflow: hidden;
}
.price-pro{
  background: linear-gradient(160deg, rgba(29,185,84,.08), var(--surface) 60%);
  border-color: rgba(29,185,84,.35);
  box-shadow: 0 30px 60px -25px rgba(29,185,84,.25);
}
.price-coach{
  background: linear-gradient(160deg, rgba(212,152,114,.07), var(--surface) 60%);
  border-color: rgba(212,152,114,.25);
}
.price-flag{
  position: absolute; top: 18px; right: 18px;
  font-size: 10px; letter-spacing: .14em; text-transform: uppercase;
  padding: 5px 11px;
  background: var(--primary);
  color: #051a0c;
  border-radius: 999px;
  font-weight: 700;
}
.price-flag.clay-flag{ background: var(--clay); color: #1a0e07; }

.price-tag{
  padding-bottom: 18px;
  border-bottom: 1px solid var(--divider);
  margin-bottom: 18px;
}
.price-name{
  display: block;
  font-size: 13px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--muted); font-weight: 500;
  margin-bottom: 14px;
}
.price-amt{ display: inline-flex; align-items: baseline; gap: 6px; }
.price-amt b{
  font-family: var(--serif);
  font-size: 56px; line-height: 1; letter-spacing: -.02em;
  color: var(--fg); font-weight: 400;
}
.price-amt span{ font-size: 14px; color: var(--muted); }

.price-tag-line{
  font-size: 14px; color: var(--muted);
  margin: 0 0 24px;
  line-height: 1.5;
}

.price-features{
  list-style: none; padding: 0; margin: 0 0 32px;
  display: grid; gap: 12px;
  flex: 1;
}
.price-features li{
  display: flex; gap: 11px; align-items: flex-start;
  font-size: 14px; color: var(--fg-2);
}
.price-features li svg{
  flex: 0 0 18px; width: 18px; height: 18px;
  color: var(--primary);
  margin-top: 1px;
}
.price-features li.dim{ color: var(--muted-2); }
.price-features li.dim svg{ color: var(--muted-2); }
.price-features li b{ color: var(--fg); font-weight: 600; }

/* Beta callout */
.beta-card{
  margin-top: 56px;
  background: linear-gradient(135deg, rgba(29,185,84,.1), rgba(29,185,84,.02));
  border: 1px solid rgba(29,185,84,.3);
  border-radius: 24px;
  padding: 36px 40px;
  display: grid; grid-template-columns: 64px 1fr auto;
  gap: 28px; align-items: center;
}
.beta-icon{
  width: 64px; height: 64px;
  background: var(--primary-soft);
  border: 1px solid rgba(29,185,84,.3);
  border-radius: 16px;
  display: grid; place-items: center;
  color: var(--primary);
}
.beta-icon svg{ width: 28px; height: 28px; animation: spin 12s linear infinite; }
@keyframes spin{ from{ transform: rotate(0deg); } to{ transform: rotate(360deg); } }
.beta-body h3{
  font-family: var(--serif);
  font-size: clamp(22px, 2.4vw, 30px);
  font-weight: 500; letter-spacing: -.015em;
  line-height: 1.1;
  margin: 10px 0 8px;
  color: var(--fg);
}
.beta-body p{
  margin: 0;
  font-size: 14px; color: var(--muted); line-height: 1.55;
  max-width: 60ch;
}

/* ═══════════════════════════════════════════════════════════
   TESTIMONIALS — photo-rich cards
   ═══════════════════════════════════════════════════════════ */
.voices{
  background: var(--bg);
  border-top: 1px solid var(--divider);
}
.voice-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
.voice-card{
  margin: 0;
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 24px;
  overflow: hidden;
  display: flex; flex-direction: column;
  position: relative;
  transition: transform .35s cubic-bezier(.2,.8,.3,1), border-color .25s ease, box-shadow .25s ease;
}
.voice-card:hover{
  transform: translateY(-4px);
  border-color: rgba(29,185,84,.35);
  box-shadow: 0 30px 60px -25px rgba(0,0,0,.55), 0 0 0 1px rgba(29,185,84,.12);
}

/* Photo block — top of card */
.voice-photo{
  position: relative;
  aspect-ratio: 4 / 5;
  background: linear-gradient(160deg, #1a1f1c 0%, #0d100e 100%);
  overflow: hidden;
}
.voice-photo img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(.85) contrast(1.05) brightness(.92);
  transition: transform .9s cubic-bezier(.2,.8,.3,1), filter .35s ease;
}
.voice-card:hover .voice-photo img{
  transform: scale(1.06);
  filter: saturate(1) contrast(1.05) brightness(1);
}
.voice-photo-grad{
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, transparent 0%, transparent 35%, rgba(14,20,16,.4) 65%, rgba(14,20,16,.95) 100%),
    linear-gradient(45deg, rgba(29,185,84,.18) 0%, transparent 40%);
  pointer-events: none;
  z-index: 1;
}
.voice-photo-stars{
  position: absolute; top: 18px; right: 18px;
  z-index: 2;
  font-size: 14px;
  color: var(--primary);
  letter-spacing: .12em;
  background: rgba(14,20,16,.75);
  backdrop-filter: blur(8px);
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(29,185,84,.3);
}
.voice-photo-meta{
  position: absolute;
  left: 22px; right: 22px;
  bottom: 18px;
  z-index: 2;
}
.voice-photo-meta b{
  display: block;
  font-family: var(--serif);
  font-size: 22px;
  letter-spacing: -.01em;
  font-weight: 500;
  color: #fff;
  text-shadow: 0 2px 12px rgba(0,0,0,.6);
}
.voice-photo-meta span{
  display: block;
  font-size: 12px;
  color: rgba(255,255,255,.78);
  margin-top: 4px;
  letter-spacing: .02em;
  text-shadow: 0 1px 8px rgba(0,0,0,.6);
}

/* Fallback (Unsplash blocked / image fails) — show big initial */
.voice-photo-fallback{
  position: absolute; inset: 0;
  display: none;
  align-items: center; justify-content: center;
  font-family: var(--serif);
  font-size: clamp(80px, 12vw, 140px);
  font-weight: 500;
  letter-spacing: -.02em;
  z-index: 0;
}
.voice-photo.photo-fallback .voice-photo-fallback{ display: flex; }
.voice-photo.photo-fallback{ background: linear-gradient(160deg, rgba(29,185,84,.25), rgba(29,185,84,.05) 60%); }
.voice-photo .voice-photo-fallback.avatar-m{ color: rgba(29,185,84,.4); }
.voice-photo .voice-photo-fallback.avatar-s{ color: rgba(180,173,209,.4); }
.voice-photo .voice-photo-fallback.avatar-j{ color: rgba(212,152,114,.4); }

/* Quote body */
.voice-card blockquote{
  margin: 0;
  font-family: var(--serif);
  font-size: 19px; line-height: 1.42;
  letter-spacing: -.01em;
  color: var(--fg-2);
  font-weight: 400;
  padding: 28px 28px 0;
  flex: 1;
}
.voice-card blockquote::before{
  content: "";
  display: block;
  width: 24px; height: 2px;
  background: var(--primary);
  margin-bottom: 18px;
}

/* Bottom row — result + duration chips */
.voice-meta-row{
  display: flex; align-items: center;
  gap: 8px;
  padding: 22px 28px 26px;
  border-top: 0;
  margin-top: 22px;
}
.voice-result{
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--primary);
  padding: 6px 12px;
  background: var(--primary-soft);
  border: 1px solid rgba(29,185,84,.28);
  border-radius: 999px;
}
.voice-time{
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 6px 12px;
  border: 1px solid var(--divider);
  border-radius: 999px;
}

/* Aggregated stats row beneath cards */
.voice-stats{
  margin-top: 48px;
  padding: 28px 36px;
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 20px;
  display: grid;
  grid-template-columns: 1fr 1px 1fr 1px 1fr;
  gap: 22px;
  align-items: center;
}
.vs-item{ text-align: center; }
.vs-stars{ color: var(--primary); letter-spacing: .14em; font-size: 13px; margin-bottom: 8px; }
.vs-v{
  font-family: var(--serif);
  font-size: clamp(26px, 3vw, 38px);
  line-height: 1; letter-spacing: -.02em;
  color: var(--fg); font-weight: 400;
}
.vs-l{ font-size: 12px; color: var(--muted); margin-top: 8px; max-width: 30ch; margin-left: auto; margin-right: auto; line-height: 1.5; }
.vs-sep{ width: 1px; height: 42px; background: var(--divider); justify-self: center; }

/* ═══════════════════════════════════════════════════════════
   FAQ
   ═══════════════════════════════════════════════════════════ */
.faq-section{ background: var(--bg-2); border-top: 1px solid var(--divider); border-bottom: 1px solid var(--divider); }
.faq-grid{ display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: start; }
.faq-head{ position: sticky; top: 100px; }
.faq-head .section-title{ margin-top: 18px; }
.faq-head .lead{ margin-top: 24px; }

.faq-list{ display: grid; gap: 10px; }
.faq-item{
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 16px;
  transition: border-color .2s, background .2s;
}
.faq-item[open]{ border-color: rgba(29,185,84,.3); background: linear-gradient(160deg, rgba(29,185,84,.04), var(--surface) 60%); }
.faq-item summary{
  list-style: none;
  display: flex; align-items: center; gap: 16px;
  padding: 22px 24px;
  cursor: pointer;
  font-family: var(--serif);
  font-size: 19px; font-weight: 400;
  letter-spacing: -.005em;
  color: var(--fg);
}
.faq-item summary::-webkit-details-marker{ display: none; }
.faq-item summary > span{ flex: 1; }
.faq-item summary svg{
  width: 18px; height: 18px;
  color: var(--muted);
  transition: transform .25s ease, color .2s;
  flex: 0 0 18px;
}
.faq-item[open] summary svg{ transform: rotate(180deg); color: var(--primary); }
.faq-body{
  padding: 0 24px 22px 24px;
  font-size: 14px; line-height: 1.6;
  color: var(--muted);
}
.faq-body p{ margin: 0; }
.faq-body b{ color: var(--fg-2); }

/* ═══════════════════════════════════════════════════════════
   CTA
   ═══════════════════════════════════════════════════════════ */
.cta-section{ position: relative; overflow: hidden; padding: clamp(64px,7vw,110px) 0; }
.cta-bg{
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(80% 60% at 50% 0%, rgba(29,185,84,.22), transparent 60%),
    radial-gradient(60% 60% at 50% 100%, rgba(127,162,140,.10), transparent 60%);
}
.cta-card{
  position: relative; z-index: 1;
  border: 1px solid rgba(29,185,84,.3);
  background: linear-gradient(160deg, rgba(29,185,84,.08), rgba(10,15,12,.6));
  border-radius: 32px;
  padding: clamp(48px, 6vw, 96px);
  text-align: center;
  backdrop-filter: blur(20px);
}
.cta-card .section-title{ max-width: 18ch; margin: 18px auto 0; }
.cta-card .lead{ margin: 24px auto 0; max-width: 56ch; }
.cta-buttons{ display: flex; gap: 12px; justify-content: center; margin-top: 40px; flex-wrap: wrap; }
.cta-meta{
  margin-top: 28px;
  font-size: 13px; color: var(--muted);
}
.cta-meta b{ color: var(--primary); font-weight: 600; }

/* ═══════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════ */
footer{ padding: 64px 0 32px; border-top: 1px solid var(--divider); }
.foot-grid{ display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; }
.foot-col h5{ font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); margin: 0 0 16px; font-weight: 600; }
.foot-col ul{ list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.foot-col li a{ color: var(--fg-2); font-size: 14px; transition: color .18s; }
.foot-col li a:hover{ color: var(--primary); }
.foot-tag{ color: var(--muted); font-size: 13px; max-width: 36ch; margin-top: 14px; line-height: 1.5; }
.foot-platforms{ display: flex; gap: 8px; flex-wrap: wrap; margin-top: 18px; }
.foot-platform{
  font-size: 11px;
  padding: 5px 10px;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--divider);
  color: var(--muted);
  letter-spacing: .04em;
}
.foot-platform.live{ color: var(--primary); border-color: rgba(29,185,84,.3); display: inline-flex; align-items: center; gap: 6px; }
.foot-bottom{ margin-top: 48px; padding-top: 24px; border-top: 1px solid var(--divider); display: flex; align-items: center; justify-content: space-between; color: var(--muted); font-size: 12px; }
.tag-line{ font-family: var(--serif); font-style: italic; font-size: 18px; color: var(--muted); }

/* ═══════════════════════════════════════════════════════════
   VIDEO MODAL
   ═══════════════════════════════════════════════════════════ */
.video-modal{
  position: fixed; inset: 0; z-index: 100;
  display: grid; place-items: center;
  padding: 5vh 5vw;
}
.video-modal[hidden]{ display: none; }
.video-modal-backdrop{
  position: absolute; inset: 0;
  background: rgba(0,0,0,.85);
  backdrop-filter: blur(20px);
  animation: fade-in .3s ease;
}
.video-modal-card{
  position: relative;
  width: min(1200px, 100%);
  aspect-ratio: 16 / 9;
  background: #000;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--divider);
  box-shadow: 0 60px 120px -20px rgba(0,0,0,.8);
  animation: zoom-in .35s cubic-bezier(.2,.8,.3,1.2);
}
.video-modal-card video{ width: 100%; height: 100%; }
.video-close{
  position: absolute; top: 16px; right: 16px;
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(0,0,0,.6); color: var(--fg);
  display: grid; place-items: center;
  z-index: 2;
  border: 1px solid rgba(255,255,255,.15);
  backdrop-filter: blur(10px);
  transition: background .2s;
}
.video-close:hover{ background: var(--primary); color: #051a0c; border-color: var(--primary); }
.video-close svg{ width: 18px; height: 18px; }

@keyframes fade-in{ from{ opacity: 0; } to{ opacity: 1; } }
@keyframes zoom-in{ from{ opacity: 0; transform: scale(.92); } to{ opacity: 1; transform: scale(1); } }

/* ═══════════════════════════════════════════════════════════
   A2HS BOTTOM SHEET (mobile only)
   ═══════════════════════════════════════════════════════════ */
.a2hs-sheet{
  position: fixed; left: 12px; right: 12px; bottom: 12px;
  z-index: 60;
  display: none;
  align-items: center; gap: 12px;
  padding: 12px 14px;
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 18px;
  box-shadow: 0 24px 50px -10px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.04);
  backdrop-filter: blur(20px);
  transform: translateY(120%);
  transition: transform .35s cubic-bezier(.2,.8,.3,1);
}
.a2hs-sheet.show{ transform: translateY(0); }
.a2hs-icon{
  width: 40px; height: 40px; border-radius: 11px;
  background: var(--primary); color: #051a0c;
  display: grid; place-items: center;
  flex: 0 0 40px;
}
.a2hs-icon svg{ width: 20px; height: 20px; }
.a2hs-text{ flex: 1; display: flex; flex-direction: column; min-width: 0; }
.a2hs-text b{ font-size: 14px; color: var(--fg); font-weight: 600; }
.a2hs-text span{ font-size: 11px; color: var(--muted); }
.a2hs-dismiss{
  width: 26px; height: 26px; border-radius: 50%;
  color: var(--muted);
  display: grid; place-items: center;
  flex: 0 0 26px;
}
.a2hs-dismiss:hover{ background: var(--surface-2); color: var(--fg); }
.a2hs-dismiss svg{ width: 14px; height: 14px; }

/* ═══════════════════════════════════════════════════════════
   FADE-UP INTERSECTION ANIMATION
   ═══════════════════════════════════════════════════════════ */
/* Fade-up: opt-in via .js-fade-ready on <html>. Default state = visible
   so content always renders even if IntersectionObserver is unavailable. */
.fade-up{ transition: opacity .7s ease, transform .7s ease; }
html.js-fade-ready .fade-up{ opacity: 0; transform: translateY(20px); }
html.js-fade-ready .fade-up.in{ opacity: 1; transform: none; }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════ */
@media (max-width: 1100px){
  .hero-grid{ grid-template-columns: 1fr; gap: 64px; }
  .hero-copy{ order: 2; }
  .hero-phone-wrap{ order: 1; max-width: 720px; margin: 0 auto; }
  .feat-card{ grid-template-columns: 1fr; }
  .feat-card.feat-large{ grid-template-columns: 1fr; }
  .feat-card.feat-large.flip .feat-phone-wrap{ order: 0; }
  .coach-grid{ grid-template-columns: 1fr; gap: 64px; }
  .chat-pop{ right: -10px; }
  .faq-grid{ grid-template-columns: 1fr; gap: 48px; }
  .faq-head{ position: static; }
  .store-row{ max-width: 100%; }
  .install-steps{ grid-template-columns: 1fr; gap: 18px; max-width: 600px; margin: 0 auto; }
  .install-steps-android{ grid-template-columns: 1fr; }
  .price-grid{ grid-template-columns: 1fr; max-width: 520px; margin: 0 auto; }
  .beta-card{ grid-template-columns: 1fr; text-align: center; padding: 32px; }
  .beta-icon{ margin: 0 auto; }
  .voice-grid{ grid-template-columns: 1fr; max-width: 600px; margin: 0 auto; }
  .voice-stats{ grid-template-columns: 1fr 1fr; gap: 16px; padding: 24px; }
  .voice-stats .vs-sep{ display: none; }
  .trust-row{ grid-template-columns: 1fr 1fr; gap: 24px; padding: 28px 0; }
  .trust-sep{ display: none; }
  .video-section-grid{ grid-template-columns: 1fr; gap: 48px; }
  .video-stage-portrait{ max-width: 360px; }
}

@media (max-width: 720px){
  .nav-links{ display: none; }
  .nav-cta{ gap: 10px; }
  .nav-link-sub{ display: none; }
  .nav-install{ padding: 10px 16px; font-size: 13px; }
  .nav-inner{ gap: 12px; }

  section{ padding: 56px 0; }
  .section-head{ margin-bottom: 36px; }
  .section-head.center{ margin-bottom: 40px; }

  .hero{ padding-top: 24px; padding-bottom: 36px; }
  .hero-grid{ gap: 36px; }
  .hero-copy{ order: 2; }
  .hero-phone-wrap{
    order: 1;
    padding: 16px 0 28px;
    min-height: 0;
  }
  .hero-phone-wrap .iphone{
    --phone-w: min(160px, 40vw);
  }
  .hero-phone-left{
    transform: rotate(-5deg) translate(14px, 18px);
  }
  .hero-phone-right{
    transform: rotate(5deg) translate(-14px, -18px);
  }
  .hp-label{ font-size: 9px; bottom: -22px; }
  .sticker-1, .sticker-3{ display: none; }

  h1.display{ font-size: clamp(40px, 11vw, 56px); letter-spacing: -.025em; }
  .hero-lead{ font-size: 16px; }
  .hero-eyebrow{ font-size: 10px; padding: 5px 10px; gap: 8px; flex-wrap: wrap; }
  .eyebrow-divider{ display: none; }

  .hero-ctas{ flex-direction: column; gap: 10px; width: 100%; margin-top: 8px; }
  .hero-ctas .btn{ width: 100%; }
  .hero-meta{ gap: 12px; }
  .store-row{ grid-template-columns: 1fr; margin-top: 24px; }

  .iphone{ --phone-w: min(280px, 75vw); }
  .iphone-sm{ --phone-w: min(240px, 70vw); }
  .iphone-xs{ --phone-w: min(200px, 60vw); }
  .iphone-md{ --phone-w: min(260px, 72vw); }
  .sticker-1, .sticker-2, .sticker-3{ display: none; }

  .marquee{ padding: 16px 0; }
  .m-item{ font-size: clamp(22px, 6vw, 30px); gap: 20px; }
  .trust-row{ grid-template-columns: 1fr 1fr; gap: 18px; padding: 24px 0; }
  .trust-v{ font-size: 26px; }

  .video-stage{ aspect-ratio: 4 / 5; }
  .video-stage-portrait{ aspect-ratio: 9 / 16; max-width: 280px; border-radius: 38px; }
  .video-stage-portrait .video-bg{ border-radius: 30px; }
  .video-stage-portrait .video-overlay{ border-radius: 30px; }
  .video-phone-frame{ border-radius: 30px; }
  .video-phone-island{ width: 70px; height: 20px; top: 10px; }
  .video-section-grid{ grid-template-columns: 1fr; gap: 36px; }
  .video-side-meta{ align-items: center; text-align: center; }
  .video-side-meta .btn{ width: 100%; }
  .video-play{ width: 64px; height: 64px; }
  .video-play svg{ width: 24px; height: 24px; }
  .video-corners .c{ width: 18px; height: 18px; }
  .video-meta{ left: 16px; bottom: 16px; }

  h2.section-title{ font-size: clamp(30px, 9vw, 50px); }
  .feat-title{ font-size: clamp(22px, 7vw, 32px); }
  .feat-card{ padding: 28px 24px; }
  .feat-card.feat-large{ padding: 28px 24px; gap: 24px; }
  .feat-phone-wrap{ padding: 0; }

  .coach-grid{ gap: 36px; }
  .chat-pop{
    position: relative;
    right: auto; bottom: auto;
    width: 100%; margin-top: 24px;
  }
  .coach-cta-row{ flex-direction: column; }
  .coach-cta-row .btn{ width: 100%; }

  .install-tabs{ width: 100%; }
  .install-tab{ flex: 1; padding: 10px 14px; font-size: 13px; }
  .install-step{ padding: 22px; }
  .step-body h4{ font-size: 19px; }
  .install-result{ flex-direction: column; text-align: center; padding: 22px; gap: 14px; }

  .price-card{ padding: 28px 24px; }
  .price-amt b{ font-size: 44px; }
  .beta-card{ padding: 28px 22px; }
  .beta-body h3{ font-size: 22px; }

  .voice-card{ padding: 0; }
  .voice-card blockquote{ font-size: 17px; padding: 22px 22px 0; }
  .voice-meta-row{ padding: 18px 22px 24px; }
  .voice-photo-meta b{ font-size: 19px; }
  .voice-stats{ grid-template-columns: 1fr; gap: 18px; padding: 24px; }
  .voice-stats .vs-sep{ display: none; }

  .faq-item summary{ padding: 18px 20px; font-size: 16px; gap: 12px; }
  .faq-body{ padding: 0 20px 20px; font-size: 13px; }

  .cta-buttons{ flex-direction: column; }
  .cta-buttons .btn{ width: 100%; }

  .foot-grid{ grid-template-columns: 1fr 1fr; gap: 28px; }
  .foot-col:first-child{ grid-column: span 2; }
  .foot-bottom{ flex-direction: column; gap: 10px; text-align: center; }

  /* show A2HS bottom sheet on mobile */
  .a2hs-sheet{ display: flex; }
}

@media (max-width: 420px){
  .foot-grid{ grid-template-columns: 1fr; }
  .foot-col:first-child{ grid-column: span 1; }
  .trust-row{ grid-template-columns: 1fr; }
  .hero-eyebrow{ font-size: 9px; }
  h1.display{ font-size: clamp(36px, 10vw, 48px); }
}
