:root{
  --bg:#f6f7fb;
  --card:#ffffff;
  --card2:#fbfcff;
  --text:#0b1220;
  --muted:#4b5567;
  --line:rgba(15,23,42,.12);
  --brand:#2563eb;
  --brand2:#7c3aed;
  --shadow: 0 18px 60px rgba(15,23,42,.12);
  --radius:18px;
  --max:1080px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:radial-gradient(900px 600px at 20% -10%, rgba(37,99,235,.12), transparent 60%), radial-gradient(900px 600px at 90% 10%, rgba(124,58,237,.10), transparent 55%), var(--bg); color:var(--text); font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;}

a{color:inherit; text-decoration:none}
.container{max-width:var(--max); margin:0 auto; padding:0 18px;}

.brandHero{display:flex; flex-direction:column; line-height:1.0; margin:0;}
.brandHero__mark{font-family:"Cherry Bomb One", Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif; font-weight:400; letter-spacing:-.01em; font-size:30px; color:#fff;
  text-shadow:
    0 2px 0 rgba(0,0,0,.55),
    0 10px 32px rgba(0,0,0,.65);
}

.brandHero__tm{font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif; font-weight:800; font-size:.62em; vertical-align:super; letter-spacing:0; margin-left:2px;}
.brandHero__sub{font-size:14px; color:rgba(255,255,255,.90); margin-top:4px; font-weight:800;
  text-shadow:
    0 2px 0 rgba(0,0,0,.55),
    0 10px 32px rgba(0,0,0,.65);
}


.btn{display:inline-flex; align-items:center; justify-content:center; gap:10px; padding:14px 16px; border-radius:14px; border:1px solid var(--line); font-weight:700; letter-spacing:-.01em;}
.btn--small{padding:10px 12px; border-radius:12px; font-size:13px;}
.btn--primary{background:linear-gradient(135deg, rgba(37,99,235,.14), rgba(124,58,237,.12)); border-color:rgba(37,99,235,.28);}
.btn--primary:hover{border-color:rgba(110,231,255,.55)}
.btn--ghost{background:transparent; color:var(--text);}
.btn--ghostOverlay{color:rgba(255,255,255,.92); border-color:rgba(255,255,255,.22); background:rgba(0,0,0,.16);}

.hero{padding:0;}
.hero--overlay{position:relative; min-height: 74vh; display:flex;}
.hero__bg{position:absolute; inset:0; background-image:url('./assets/hero-square.jpg?v=1'); background-size:cover; background-position:center; filter:saturate(1.05) contrast(1.05);}
.hero--overlay:before{content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.22) 52%, rgba(0,0,0,.78) 100%);} 
.hero__overlay{position:relative; padding:22px 18px 22px; width:100%; min-height: 74vh; display:flex; flex-direction:column; justify-content:space-between;}

.heroTop{display:flex; align-items:flex-start;}
.heroBottom{display:block;}

.kicker{display:inline-block; color:var(--muted); font-weight:600; font-size:13px; border:1px solid var(--line); padding:9px 12px; border-radius:999px; background:rgba(255,255,255,.03)}
.kicker--overlay{color:rgba(255,255,255,.92); border-color:rgba(255,255,255,.22); background:rgba(0,0,0,.18); backdrop-filter: blur(10px);
  text-shadow:
    0 2px 0 rgba(0,0,0,.55),
    0 10px 32px rgba(0,0,0,.65);
}

.heroTitle{margin:14px 0 8px; font-size:40px; line-height:1.05; letter-spacing:-.04em; color:#fff;
  text-shadow:
    0 2px 0 rgba(0,0,0,.55),
    0 10px 40px rgba(0,0,0,.65);
}
.lead{margin:0 0 14px; font-size:16px; line-height:1.55;}
.lead--overlay{color:rgba(255,255,255,.90);
  text-shadow:
    0 2px 0 rgba(0,0,0,.55),
    0 10px 40px rgba(0,0,0,.65);
} 

.checks{list-style:none; padding:0; margin:0 0 16px; display:grid; gap:10px;}
.checks li{position:relative; padding-left:28px; color:var(--muted); font-weight:600;}
.checks li:before{content:""; position:absolute; left:0; top:2px; width:18px; height:18px; border-radius:6px; background:rgba(37,99,235,.12); border:1px solid rgba(37,99,235,.22); box-shadow:0 0 0 3px rgba(37,99,235,.06) inset;}

.hero__ctas{display:flex; gap:10px; flex-wrap:wrap; margin:10px 0 8px;}
.micro{font-size:12px; color:var(--muted); margin:10px 0 0;}

.muted{color:var(--muted)}

.imgWrap{margin:0; padding:14px; background:rgba(255,255,255,.82); border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.imgWrap img{width:100%; height:auto; display:block; border-radius:16px; border:1px solid var(--line); background:#fff;}
.imgWrap--kit{padding:12px; border:1px solid var(--line); border-radius:16px; background:rgba(255,255,255,.78); box-shadow:var(--shadow); margin:12px 0 16px;}
.imgWrap--kit img{border-radius:14px;}

.kitGallery{display:grid; grid-template-columns:1fr; gap:12px; margin:12px 0 16px;}
@media (min-width: 860px){
  .kitGallery{grid-template-columns:repeat(2,1fr);}
}
.videoPlaceholder p{margin:14px 0 0; font-weight:700; letter-spacing:-.02em}
.play{width:62px; height:62px; border-radius:20px; border:1px solid rgba(255,255,255,.16); background:rgba(255,255,255,.06); position:relative;}
.play:after{content:""; position:absolute; left:24px; top:18px; width:0; height:0; border-left:18px solid rgba(232,238,247,.9); border-top:13px solid transparent; border-bottom:13px solid transparent;}

/* Quote video section */
.quoteVideo{position:relative; overflow:hidden; border-radius:18px; border:1px solid var(--line); box-shadow:var(--shadow); background:#0b1220;}
.quoteVideo video{width:100%; height:auto; display:block; object-fit:cover; aspect-ratio:9/16;}
@media (min-width: 860px){
  .quoteVideo video{aspect-ratio:16/9;}
}
.quoteVideo:before{content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.22) 0%, rgba(0,0,0,.70) 100%);} 
.quoteVideo__overlay{position:absolute; inset:0; display:flex; align-items:flex-end; padding:16px;}
.quoteVideo__text{max-width:680px; color:#fff; font-weight:900; letter-spacing:-.03em; line-height:1.08; font-size:22px;
  text-shadow:
    0 2px 0 rgba(0,0,0,.55),
    0 10px 40px rgba(0,0,0,.65);
}
@media (min-width: 860px){
  .quoteVideo__overlay{padding:22px;}
  .quoteVideo__text{font-size:32px;}
}

.socialProof{padding:10px 0 18px;}
.proofRow{display:grid; grid-template-columns:repeat(3,1fr); gap:10px;}
.proofItem{border:1px solid var(--line); border-radius:16px; padding:14px 12px; background:rgba(255,255,255,.72); text-align:center;}
.proofNum{display:block; font-size:22px; font-weight:900; letter-spacing:-.03em;}
.proofLabel{display:block; font-size:12px; color:var(--muted); font-weight:700; margin-top:4px;}

.section{padding:26px 0;}
.section.alt{background:rgba(255,255,255,.55); border-top:1px solid var(--line); border-bottom:1px solid var(--line);}

h2{margin:0 0 10px; font-size:24px; letter-spacing:-.03em;}
.sublead{margin:0 0 16px; color:var(--muted); line-height:1.6}

.steps{display:grid; grid-template-columns:1fr; gap:12px; margin-top:12px;}
.step{border:1px solid var(--line); border-radius:16px; padding:14px 14px 16px; background:rgba(255,255,255,.78);}
.step__num{width:32px; height:32px; border-radius:12px; display:grid; place-items:center; font-weight:900; border:1px solid rgba(110,231,255,.35); background:rgba(110,231,255,.12); margin-bottom:10px;}
.step h3{margin:0 0 6px; letter-spacing:-.02em}
.step p{margin:0; color:var(--muted); line-height:1.55}

.callout{margin-top:16px; border:1px solid rgba(124,58,237,.22); background:rgba(124,58,237,.08); padding:14px; border-radius:16px; color:rgba(11,18,32,.92); line-height:1.55}

.kit{display:grid; grid-template-columns:1fr; gap:12px;}
.kit__card{border:1px solid var(--line); border-radius:16px; padding:14px; background:rgba(255,255,255,.78)}
.bullets{margin:10px 0 0; padding:0 0 0 18px; color:var(--muted);}
.bullets li{margin:6px 0;}
.fineprint{margin:14px 0 0; font-size:12px; color:rgba(168,179,196,.9); line-height:1.55}

.buyCard{border:1px solid rgba(37,99,235,.18); background:linear-gradient(180deg, rgba(37,99,235,.08), rgba(124,58,237,.06)); border-radius:22px; padding:16px; box-shadow:var(--shadow); display:grid; gap:14px;}
.buyBtns{display:flex; gap:10px; flex-wrap:wrap; margin-top:10px;}

.priceBox{border:1px solid var(--line); border-radius:18px; background:rgba(255,255,255,.78); padding:14px;}
.priceBox__row{display:flex; justify-content:space-between; gap:10px; margin:10px 0;}
.divider{height:1px; background:var(--line); margin:12px 0;}

.faq details{border:1px solid var(--line); border-radius:16px; background:rgba(255,255,255,.78); padding:12px 14px; margin:10px 0;}
.faq summary{cursor:pointer; font-weight:800; letter-spacing:-.02em;}
.faq p{margin:10px 0 0; color:var(--muted); line-height:1.55}

.footer{padding:26px 0 96px;}
.footer__inner{display:grid; gap:12px;}
.footer__links{display:flex; gap:14px; flex-wrap:wrap;}
.footer__links a{color:var(--muted); font-weight:700; font-size:13px;}
.footer__links a:hover{color:var(--text)}
.brand--footer .brand__mark{font-size:16px}

.stickyFooter{position:fixed; left:0; right:0; bottom:0; z-index:40; padding:10px 0; background:rgba(246,247,251,.90); border-top:1px solid var(--line); backdrop-filter:saturate(120%) blur(10px);}
.stickyFooter__inner{display:flex;}
.btn--wide{width:100%; padding:14px 16px;}

.srOnly{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0;}

@media (min-width: 860px){
  .hero--overlay{min-height: 78vh;}
  .heroTitle{font-size:56px;}
  .steps{grid-template-columns:repeat(3,1fr)}
  .kit{grid-template-columns:repeat(2,1fr)}
  .buyCard{grid-template-columns:1.1fr .9fr; padding:20px;}
  .footer__inner{grid-template-columns:1fr auto; align-items:start}
}

@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto !important; transition:none !important; animation:none !important;}
}
