/* ============================================================
   SOVEREIGN — App Landing Page
   © 2026 Gen X Girl Club LLC
   ============================================================ */

:root {
  --bg:           #0A0A0A;
  --surface-1:    #1A1A1A;
  --surface-2:    #2A2A2A;
  --surface-3:    #3A3A3A;
  --pink:         #E84B8A;
  --pink-dark:    #BE185D;
  --pink-light:   #F472B6;
  --pink-glow:    rgba(232, 75, 138, 0.15);
  --pink-glow-2:  rgba(232, 75, 138, 0.30);
  --white:        #FFFFFF;
  --text-2:       #D1D5DB;
  --text-3:       #9CA3AF;
  --green:        #34D399;
  --gold:         #D4A853;

  --display: 'Playfair Display', Georgia, serif;
  --sans:    'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  --radius-sm: 10px;
  --radius:    14px;
  --radius-lg: 20px;

  --shadow-pink:  0 12px 40px -8px rgba(232, 75, 138, 0.45);
  --shadow-card:  0 1px 0 rgba(255,255,255,0.02) inset, 0 8px 32px rgba(0,0,0,0.4);
}

/* ---------- Reset / Base ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--white);
  line-height:1.6;
  font-size:16px;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

/* ---------- Background field ---------- */
.bg-field{
  position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(900px 600px at 88% -10%, var(--pink-glow-2), transparent 60%),
    radial-gradient(700px 500px at -10% 30%, var(--pink-glow), transparent 65%),
    radial-gradient(800px 600px at 50% 110%, rgba(190,24,93,0.18), transparent 65%),
    var(--bg);
  pointer-events:none;
}
.bg-noise{
  position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay;
}

/* ---------- Layout ---------- */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 24px}
section{position:relative;padding:96px 0}
.section-tight{padding:72px 0}

/* ---------- Typography ---------- */
.eyebrow{
  font-family:var(--sans);font-size:11px;font-weight:600;
  letter-spacing:4px;text-transform:uppercase;color:var(--pink);
  margin-bottom:18px;display:inline-block;
}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;letter-spacing:-0.01em;color:var(--white)}
h1{font-size:clamp(34px,5.6vw,56px);line-height:1.08}
h2{font-size:clamp(28px,3.8vw,40px);line-height:1.15}
h3{font-size:22px;line-height:1.2}
p{color:var(--text-2)}
.lead{font-size:18px;color:var(--text-2);max-width:560px;line-height:1.6}
.muted{color:var(--text-3)}

/* ---------- Nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:16px 0;
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  background:rgba(10,10,10,0.55);
  border-bottom:1px solid rgba(255,255,255,0.04);
  transition:background .3s ease, border-color .3s ease;
}
.nav.scrolled{background:rgba(10,10,10,0.85);border-bottom-color:rgba(255,255,255,0.06)}
.nav-row{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--display);font-size:20px;font-weight:700;letter-spacing:.02em}
.brand-mark{
  width:28px;height:28px;border-radius:8px;
  background:linear-gradient(135deg,var(--pink),var(--pink-dark));
  box-shadow:0 6px 20px -6px var(--pink);
  display:grid;place-items:center;
  position:relative;
}
.brand-mark::after{
  content:"";position:absolute;inset:6px;border-radius:4px;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.55), transparent 60%);
}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-size:14px;color:var(--text-2);transition:color .2s}
.nav-links a:hover{color:var(--white)}
.nav .btn{padding:10px 18px;font-size:14px}
@media (max-width: 760px){.nav-links{display:none}}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 26px;border-radius:var(--radius);font-family:var(--sans);
  font-weight:600;font-size:15px;letter-spacing:.01em;
  background:linear-gradient(135deg,var(--pink) 0%, var(--pink-dark) 100%);
  color:var(--white);box-shadow:var(--shadow-pink);
  transition:transform .2s ease, box-shadow .25s ease, filter .2s ease;
  position:relative;overflow:hidden;
}
.btn::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 0%, rgba(255,255,255,.2) 50%, transparent 100%);
  transform:translateX(-100%);transition:transform .8s ease;
}
.btn:hover{transform:translateY(-2px) scale(1.015);box-shadow:0 16px 50px -10px rgba(232,75,138,.6)}
.btn:hover::after{transform:translateX(100%)}
.btn:active{transform:translateY(0) scale(.99)}
.btn-ghost{
  background:transparent;border:1px solid var(--surface-2);color:var(--white);
  box-shadow:none;
}
.btn-ghost:hover{border-color:var(--pink);background:rgba(232,75,138,.06)}
.btn-block{width:100%}

/* ---------- App Store Badge ---------- */
.app-badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 18px;background:#000;
  border:1px solid rgba(255,255,255,.18);border-radius:10px;
  transition:transform .2s ease,border-color .2s ease;
  font-family:var(--sans);
}
.app-badge:hover{transform:translateY(-2px);border-color:var(--pink)}
.app-badge svg{width:24px;height:24px;flex-shrink:0;fill:var(--white)}
.app-badge .badge-text{display:flex;flex-direction:column;line-height:1.1;text-align:left}
.app-badge .badge-sm{font-size:9.5px;letter-spacing:1px;color:var(--text-2);text-transform:uppercase}
.app-badge .badge-lg{font-size:18px;font-weight:600;color:var(--white);font-family:var(--sans);letter-spacing:.01em}

/* ---------- HERO ---------- */
.hero{
  min-height:100vh;padding-top:130px;padding-bottom:80px;
  display:flex;align-items:center;
  position:relative;overflow:hidden;
}
.hero-grid{
  display:grid;grid-template-columns:1.15fr 0.85fr;gap:60px;align-items:center;
}
.hero-copy{position:relative;z-index:2;animation:fadeUp .9s ease both}
.hero-copy .lead{margin:22px 0 32px}
.hero-cta-row{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:22px}
.hero-cta-row .btn{padding:16px 30px;font-size:16px}
.social-proof{display:flex;align-items:center;gap:14px;margin-top:28px}
.avatars{display:flex}
.avatars span{
  width:32px;height:32px;border-radius:50%;
  display:grid;place-items:center;font-size:11px;font-weight:700;
  color:var(--white);
  border:2px solid var(--bg);
  margin-left:-8px;
  font-family:var(--sans);
}
.avatars span:first-child{margin-left:0}
.avatars span:nth-child(1){background:linear-gradient(135deg,#7c1d52,#E84B8A)}
.avatars span:nth-child(2){background:linear-gradient(135deg,#BE185D,#F472B6)}
.avatars span:nth-child(3){background:linear-gradient(135deg,#5B1B4A,#E84B8A)}
.avatars span:nth-child(4){background:linear-gradient(135deg,#9d174d,#F472B6)}
.avatars span:nth-child(5){background:linear-gradient(135deg,#831843,#E84B8A)}
.social-text{font-size:13px;color:var(--text-3)}
.social-text strong{color:var(--white);font-weight:600}

/* Phone mockup */
.phone-wrap{
  position:relative;display:flex;justify-content:center;align-items:center;
  animation:fadeUp 1.1s .15s ease both;
}
.phone-glow{
  position:absolute;inset:-30px;border-radius:50%;
  background:radial-gradient(closest-side, var(--pink-glow-2), transparent 70%);
  filter:blur(40px);z-index:0;
  animation:pulse 6s ease-in-out infinite;
}
.phone{
  position:relative;z-index:1;
  width:300px;height:610px;
  background:linear-gradient(160deg,#1f1f22 0%, #0d0d0f 100%);
  border-radius:48px;
  padding:14px;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:
    0 50px 100px -20px rgba(0,0,0,0.7),
    0 30px 60px -20px rgba(232,75,138,.25),
    inset 0 0 0 2px #2a2a2c,
    inset 0 1px 0 rgba(255,255,255,.06);
  transform:rotate(-2deg);
  animation:float 7s ease-in-out infinite;
}
.phone-screen{
  position:relative;width:100%;height:100%;
  background:#050505;border-radius:36px;overflow:hidden;
  border:1px solid #1a1a1a;
}
.phone-screen-img{
  display:block;width:100%;height:100%;
  object-fit:cover;object-position:top center;
  border-radius:36px;
}
.dynamic-island{
  position:absolute;top:10px;left:50%;transform:translateX(-50%);
  width:108px;height:32px;background:#000;border-radius:20px;z-index:10;
}
.phone-status{
  position:absolute;top:14px;left:0;right:0;padding:0 28px;
  display:flex;justify-content:space-between;align-items:center;
  font-size:11px;font-weight:600;color:var(--white);z-index:11;
}
.phone-status .left{padding-left:8px}
.phone-status .right{display:flex;gap:5px;align-items:center;padding-right:8px}
.phone-status svg{width:14px;height:10px;fill:var(--white)}

/* Phone screen content — Home Dashboard */
.dash{padding:60px 22px 24px;height:100%;display:flex;flex-direction:column;gap:14px}
.dash-greet{font-family:var(--display);font-size:20px;color:var(--white);line-height:1.2;margin-top:4px}
.dash-greet small{display:block;font-family:var(--sans);font-size:11px;color:var(--text-3);font-weight:500;letter-spacing:.5px;text-transform:uppercase;margin-bottom:6px}
.scan-card{
  position:relative;
  background:linear-gradient(160deg, rgba(232,75,138,.18) 0%, rgba(190,24,93,.08) 100%);
  border:1px solid rgba(232,75,138,.35);
  border-radius:18px;padding:18px;overflow:hidden;
}
.scan-card::before{
  content:"";position:absolute;top:-30px;right:-30px;width:120px;height:120px;
  background:radial-gradient(circle, rgba(244,114,182,.4), transparent 60%);
  filter:blur(20px);
}
.scan-label{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--pink-light);font-weight:600;position:relative}
.scan-state{font-family:var(--display);font-size:22px;color:var(--white);margin-top:6px;position:relative}
.gauge{
  position:relative;margin:16px auto 4px;width:130px;height:130px;
}
.gauge svg{transform:rotate(-90deg)}
.gauge .bg-ring{fill:none;stroke:rgba(255,255,255,.08);stroke-width:8}
.gauge .fg-ring{fill:none;stroke:url(#gaugeGrad);stroke-width:8;stroke-linecap:round;
  stroke-dasharray:339.292;stroke-dashoffset:84.823;
  filter:drop-shadow(0 0 6px rgba(232,75,138,.6));
  animation:gaugeFill 3s ease-in-out infinite alternate;
}
.gauge-num{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;
}
.gauge-num strong{font-family:var(--display);font-size:32px;color:var(--white);line-height:1}
.gauge-num span{font-size:9px;letter-spacing:1.5px;color:var(--text-3);text-transform:uppercase;margin-top:4px;font-weight:600}
.scan-meta{display:flex;justify-content:space-between;font-size:10px;color:var(--text-3);margin-top:10px;position:relative}
.scan-meta strong{color:var(--white);font-weight:600;font-size:11px}

.tile-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.tile{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  border-radius:12px;padding:11px;
  display:flex;flex-direction:column;gap:6px;
}
.tile-icon{
  width:24px;height:24px;border-radius:6px;
  background:linear-gradient(135deg,var(--pink),var(--pink-dark));
  display:grid;place-items:center;
}
.tile-icon svg{width:13px;height:13px;fill:var(--white)}
.tile-title{font-size:11px;font-weight:600;color:var(--white)}
.tile-sub{font-size:9px;color:var(--text-3);letter-spacing:.3px}

.dock{
  margin-top:auto;display:grid;grid-template-columns:repeat(4,1fr);gap:6px;
  padding:8px;background:rgba(255,255,255,.04);border-radius:14px;
  border:1px solid rgba(255,255,255,.05);
}
.dock-item{padding:6px 0;text-align:center;border-radius:8px;font-size:9px;color:var(--text-3);font-weight:600;letter-spacing:.4px}
.dock-item.active{background:rgba(232,75,138,.18);color:var(--pink-light)}

/* ---------- PROBLEM ---------- */
.problem{position:relative}
.problem-inner{max-width:680px;margin:0 auto;text-align:center}
.problem-inner h2{margin:14px 0 28px}
.problem-inner p{font-size:17px;line-height:1.75;margin-bottom:18px}
.problem-quote{
  margin-top:36px;padding:22px 28px;border-left:3px solid var(--pink);
  background:rgba(232,75,138,0.08);border-radius:0 12px 12px 0;
  text-align:left;
}
.problem-quote strong{color:var(--white);font-size:17px;line-height:1.55;display:block}

/* ---------- SCANNER (Hero Feature) ---------- */
.scanner-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.scanner-copy h2{margin:14px 0 18px}
.scanner-pills{display:flex;flex-direction:column;gap:14px;margin:32px 0}
.pill{
  display:flex;gap:14px;align-items:flex-start;
  background:var(--surface-1);
  border:1px solid var(--surface-2);
  border-radius:var(--radius);padding:16px 18px;
  transition:transform .2s ease, border-color .2s ease, background .2s ease;
}
.pill:hover{transform:translateY(-2px);border-color:rgba(232,75,138,.45);background:rgba(232,75,138,.05)}
.pill-dot{
  width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:6px;
  box-shadow:0 0 12px currentColor;
}
.pill-dot.storm{color:#FF6B9E;background:#FF6B9E}
.pill-dot.shift{color:var(--gold);background:var(--gold)}
.pill-dot.recover{color:var(--green);background:var(--green)}
.pill-content strong{display:block;color:var(--white);font-size:15px;font-weight:600;margin-bottom:4px;font-family:var(--sans)}
.pill-content span{font-size:14px;color:var(--text-2);line-height:1.5}
.scanner-sub{font-size:14px;color:var(--text-3);line-height:1.7}

/* Scanner phone variation */
.scanner-phone .scan-state{color:var(--green)}
.scanner-phone .scan-label{color:var(--green)}

/* ---------- FEATURES ---------- */
.features-head{text-align:center;max-width:680px;margin:0 auto 56px}
.features-head h2{margin:14px 0 16px}
.features-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.feature{
  position:relative;
  background:var(--surface-1);
  border:1px solid var(--surface-2);
  border-radius:var(--radius);
  padding:28px;
  transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease;
  overflow:hidden;
}
.feature::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;
  background:linear-gradient(135deg, rgba(232,75,138,.4), transparent 50%);
  opacity:0;transition:opacity .3s ease;z-index:-1;
}
.feature:hover{transform:translateY(-4px);border-color:rgba(232,75,138,.45);box-shadow:0 20px 40px -20px rgba(232,75,138,.3)}
.feature-icon{
  width:48px;height:48px;border-radius:12px;
  background:linear-gradient(135deg, rgba(232,75,138,.18), rgba(190,24,93,.08));
  border:1px solid rgba(232,75,138,.3);
  display:grid;place-items:center;margin-bottom:18px;
}
.feature-icon svg{width:22px;height:22px;stroke:var(--pink);fill:none;stroke-width:1.8}
.feature h3{font-family:var(--display);font-size:22px;margin-bottom:10px;color:var(--white)}
.feature p{font-size:15px;color:var(--text-2);line-height:1.6}

/* ---------- C.A.L.M. ---------- */
.calm-head{text-align:center;max-width:720px;margin:0 auto 48px}
.calm-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.calm-card{
  background:var(--surface-1);
  border:1px solid var(--surface-2);
  border-left:3px solid var(--pink);
  border-radius:var(--radius);
  padding:24px;
  transition:transform .25s ease, background .25s ease;
}
.calm-card:hover{transform:translateY(-4px);background:rgba(232,75,138,.04)}
.calm-letter{
  font-family:var(--display);font-size:48px;font-weight:700;
  color:var(--pink);line-height:1;margin-bottom:10px;
  text-shadow:0 0 30px rgba(232,75,138,.4);
}
.calm-card h3{font-family:var(--display);font-size:18px;margin-bottom:8px;color:var(--white)}
.calm-card p{font-size:14px;color:var(--text-2);line-height:1.55}

/* ---------- INSIDE SOVEREIGN (Tour) ---------- */
.tour{position:relative}
.tour-head{text-align:center;max-width:720px;margin:0 auto 56px}
.tour-head h2{margin:14px 0 16px}

.tour-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:18px;
  align-items:stretch;
}
.tour-card{
  position:relative;
  background:var(--surface-1);
  border:1px solid var(--surface-2);
  border-radius:var(--radius);
  padding:22px 18px 24px;
  display:flex;flex-direction:column;
  margin:0;
  transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease;
  overflow:hidden;
}
.tour-card:hover{
  transform:translateY(-4px);
  border-color:rgba(232,75,138,.4);
  box-shadow:0 18px 40px -18px rgba(232,75,138,.3);
}

.tour-card-feature{
  background:
    radial-gradient(420px 240px at 50% -20%, rgba(232,75,138,.22), transparent 65%),
    var(--surface-1);
  border-color:rgba(232,75,138,.4);
}
.tour-badge{
  position:absolute;top:14px;right:14px;
  font-size:9.5px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--white);
  background:linear-gradient(135deg,var(--pink),var(--pink-dark));
  padding:5px 10px;border-radius:999px;
  box-shadow:0 6px 16px -6px var(--pink);
}

.tour-frame{
  position:relative;
  align-self:center;
  width:180px;
  aspect-ratio:9/19.5;
  background:linear-gradient(160deg,#1f1f22 0%, #0d0d0f 100%);
  border-radius:28px;padding:6px;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:
    0 24px 50px -18px rgba(0,0,0,0.65),
    0 14px 30px -16px rgba(232,75,138,.25),
    inset 0 0 0 1.2px #2a2a2c,
    inset 0 1px 0 rgba(255,255,255,.06);
  margin:6px 0 22px;
}
.tour-frame::before{
  content:"";position:absolute;inset:-14px;border-radius:50%;
  background:radial-gradient(closest-side, rgba(232,75,138,.22), transparent 70%);
  filter:blur(24px);z-index:-1;
}
.tour-frame img{
  display:block;width:100%;height:100%;
  border-radius:22px;
  object-fit:cover;object-position:top center;
  image-rendering:auto;
}

.tour-card figcaption{display:flex;flex-direction:column;gap:8px}
.tour-label{
  font-size:10.5px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:var(--pink);
}
.tour-card h3{
  font-family:var(--display);font-size:19px;color:var(--white);line-height:1.25;
}
.tour-card p{font-size:13.5px;color:var(--text-2);line-height:1.55}

@media (max-width:1100px){
  .tour-grid{grid-template-columns:repeat(2, 1fr);gap:18px}
}
@media (max-width:560px){
  .tour-grid{grid-template-columns:1fr}
  .tour-frame{width:200px}
}

/* ---------- TESTIMONIALS ---------- */
.testimonials-head{text-align:center;max-width:680px;margin:0 auto 48px}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.testi{
  position:relative;
  background:var(--surface-1);
  border:1px solid var(--surface-2);
  border-radius:var(--radius);
  padding:28px 26px;
}
.testi-quote-mark{
  position:absolute;top:14px;left:20px;
  font-family:var(--display);font-size:64px;color:var(--pink);
  line-height:1;opacity:.5;
}
.stars{display:flex;gap:3px;margin-bottom:14px;position:relative}
.stars svg{width:14px;height:14px;fill:var(--gold)}
.testi-text{font-size:15.5px;line-height:1.65;color:var(--text-2);position:relative;margin-bottom:18px}
.testi-name{font-size:13px;font-weight:600;color:var(--pink);letter-spacing:.5px}

/* ---------- ABOUT ---------- */
.about-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:60px;align-items:center}
.about-photo{
  position:relative;
  aspect-ratio:1/1;max-width:380px;
  border-radius:24px;
  background:linear-gradient(160deg, rgba(232,75,138,.25), rgba(190,24,93,.05));
  border:1px solid rgba(232,75,138,.3);
  display:grid;place-items:center;
  overflow:hidden;
}
.about-photo::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 20%, rgba(244,114,182,.25), transparent 50%);
}
.about-initials{
  font-family:var(--display);font-size:72px;font-weight:700;color:var(--white);
  width:140px;height:140px;border-radius:50%;
  background:linear-gradient(135deg,var(--pink),var(--pink-dark));
  display:grid;place-items:center;
  box-shadow:0 30px 60px -10px rgba(232,75,138,.5);
  position:relative;z-index:2;
}
.about-copy h2{margin:14px 0 6px}
.about-credential{font-size:14px;color:var(--pink);font-weight:600;letter-spacing:.5px;margin-bottom:18px;text-transform:uppercase}
.about-copy p{font-size:16px;line-height:1.7;margin-bottom:16px}
.about-location{font-size:13px;color:var(--text-3);margin-top:18px;display:flex;align-items:center;gap:6px}
.about-location svg{width:14px;height:14px;stroke:var(--text-3);fill:none;stroke-width:1.8}

/* ---------- DOWNLOAD CTA ---------- */
.download-cta{
  position:relative;text-align:center;
  padding:96px 24px;
  border-radius:24px;margin:0 24px;
  background:
    radial-gradient(800px 400px at 50% 100%, rgba(232,75,138,.25), transparent 60%),
    linear-gradient(180deg, rgba(232,75,138,.06), rgba(10,10,10,1) 70%);
  border:1px solid rgba(232,75,138,.2);
  overflow:hidden;
}
.download-cta::before{
  content:"";position:absolute;top:-100px;left:50%;transform:translateX(-50%);
  width:600px;height:200px;
  background:radial-gradient(closest-side, rgba(232,75,138,.4), transparent 70%);
  filter:blur(60px);
}
.download-cta h2{margin-bottom:14px;position:relative;font-size:clamp(28px,3.4vw,40px)}
.download-cta .lead{margin:0 auto 32px;max-width:560px;position:relative}
.download-cta .cta-row{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;align-items:center;position:relative}
.download-cta .download-fine{font-size:11px;color:var(--text-3);margin-top:16px;position:relative}

/* ---------- FAQ ---------- */
.faq-head{text-align:center;max-width:680px;margin:0 auto 48px}
.faq{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.faq-item{
  background:var(--surface-1);
  border:1px solid var(--surface-2);
  border-radius:12px;overflow:hidden;
  transition:border-color .2s ease;
}
.faq-item.open{border-color:rgba(232,75,138,.4)}
.faq-q{
  width:100%;text-align:left;padding:18px 22px;
  display:flex;justify-content:space-between;align-items:center;gap:18px;
  font-size:15px;font-weight:600;color:var(--white);
  font-family:var(--sans);
}
.faq-q .chev{
  width:22px;height:22px;flex-shrink:0;border-radius:50%;
  background:rgba(232,75,138,.12);display:grid;place-items:center;
  transition:transform .3s ease, background .2s ease;
}
.faq-q .chev svg{width:11px;height:11px;stroke:var(--pink);fill:none;stroke-width:2.5}
.faq-item.open .chev{transform:rotate(180deg);background:rgba(232,75,138,.25)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .35s ease;
}
.faq-a-inner{padding:0 22px 20px;font-size:14.5px;line-height:1.7;color:var(--text-2)}

/* ---------- FOOTER ---------- */
.footer{
  border-top:1px solid var(--surface-2);
  padding:72px 0 36px;background:rgba(0,0,0,.4);
}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand .brand{margin-bottom:18px}
.footer-brand p{font-size:14px;color:var(--text-3);max-width:340px;line-height:1.6}
.footer-col h4{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--white);margin-bottom:18px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col a{font-size:14px;color:var(--text-3);transition:color .2s ease}
.footer-col a:hover{color:var(--pink)}
.footer-social{display:flex;gap:10px;margin-top:18px}
.footer-social a{
  width:38px;height:38px;border-radius:10px;
  background:var(--surface-1);border:1px solid var(--surface-2);
  display:grid;place-items:center;
  transition:border-color .2s ease, background .2s ease;
}
.footer-social a:hover{border-color:var(--pink);background:rgba(232,75,138,.08)}
.footer-social svg{width:16px;height:16px;fill:var(--text-2)}
.footer-social a:hover svg{fill:var(--pink)}
.footer-bottom{
  padding-top:24px;border-top:1px solid var(--surface-2);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
  font-size:12px;color:var(--text-3);
}

/* ---------- LEGAL PAGES ---------- */
.legal-hero{
  padding-top:160px;padding-bottom:48px;text-align:center;
  border-bottom:1px solid var(--surface-2);
}
.legal-hero .eyebrow{margin-bottom:14px}
.legal-hero h1{font-size:clamp(32px,4.2vw,48px);margin-bottom:14px}
.legal-hero p{color:var(--text-3);font-size:14px;max-width:560px;margin:0 auto}
.legal-body{padding:64px 0 96px}
.legal-content{max-width:780px;margin:0 auto;font-family:var(--sans)}
.legal-content h2{
  font-family:var(--display);font-size:26px;color:var(--white);
  margin:48px 0 16px;padding-bottom:12px;
  border-bottom:1px solid var(--surface-2);
}
.legal-content h2:first-child{margin-top:0}
.legal-content h3{font-family:var(--display);font-size:18px;color:var(--white);margin:28px 0 12px}
.legal-content p{margin-bottom:16px;font-size:15px;line-height:1.75;color:var(--text-2)}
.legal-content ul,.legal-content ol{margin:0 0 16px 22px;color:var(--text-2)}
.legal-content li{font-size:15px;line-height:1.7;margin-bottom:8px}
.legal-content strong{color:var(--white);font-weight:600}
.legal-content a{color:var(--pink);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.legal-content a:hover{color:var(--pink-light)}
.legal-content blockquote{
  margin:18px 0;padding:14px 22px;
  border-left:3px solid var(--pink);background:rgba(232,75,138,.06);
  border-radius:0 8px 8px 0;
  font-size:14px;color:var(--text-2);line-height:1.7;
}
.legal-toc{
  background:var(--surface-1);border:1px solid var(--surface-2);
  border-radius:14px;padding:22px 26px;margin-bottom:40px;
}
.legal-toc h3{font-family:var(--sans);font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--pink);margin:0 0 14px}
.legal-toc ol{margin:0;padding-left:18px;column-count:2;column-gap:24px}
@media (max-width:640px){.legal-toc ol{column-count:1}}
.legal-toc li{font-size:13px;margin-bottom:6px}
.legal-toc a{color:var(--text-2);text-decoration:none}
.legal-toc a:hover{color:var(--pink)}

/* ---------- Animations ---------- */
@keyframes fadeUp{
  0%{opacity:0;transform:translateY(20px)}
  100%{opacity:1;transform:translateY(0)}
}
@keyframes float{
  0%,100%{transform:rotate(-2deg) translateY(0)}
  50%{transform:rotate(-2deg) translateY(-10px)}
}
@keyframes pulse{
  0%,100%{opacity:.6;transform:scale(1)}
  50%{opacity:.9;transform:scale(1.04)}
}
@keyframes gaugeFill{
  0%{stroke-dashoffset:200}
  100%{stroke-dashoffset:84}
}
@keyframes shimmer{
  0%{background-position:-200% 0}
  100%{background-position:200% 0}
}

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease, transform .8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal.delay-1{transition-delay:.08s}
.reveal.delay-2{transition-delay:.16s}
.reveal.delay-3{transition-delay:.24s}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 980px){
  .hero{padding-top:110px}
  .hero-grid{grid-template-columns:1fr;gap:40px;text-align:center}
  .hero-copy{order:2}
  .phone-wrap{order:1}
  .hero-cta-row{justify-content:center}
  .social-proof{justify-content:center}
  .scanner-grid{grid-template-columns:1fr;gap:48px}
  .scanner-grid .phone-wrap{order:2}
  .features-grid{grid-template-columns:1fr}
  .calm-grid{grid-template-columns:1fr 1fr;gap:14px}
  .testi-grid{grid-template-columns:1fr;gap:18px}
  .about-grid{grid-template-columns:1fr;gap:36px;text-align:center}
  .about-photo{margin:0 auto}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  section{padding:72px 0}
}
@media (max-width: 640px){
  .container{padding:0 20px}
  .phone{width:260px;height:530px}
  .hero{padding-top:96px;min-height:auto}
  .calm-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;text-align:center;gap:36px}
  .footer-col ul{align-items:center}
  .footer-bottom{justify-content:center;text-align:center}
  .footer-social{justify-content:center}
  .download-cta{margin:0;border-radius:0;border-left:0;border-right:0;padding:64px 20px}
  .hero-cta-row .btn{width:100%}
  .btn{width:100%;max-width:340px}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .phone{animation:none}
  .phone-glow{animation:none}
  .gauge .fg-ring{animation:none}
}
