:root{
  --bg-cream:#f6f3ef;
  --text:#0f172a;
  --muted:#6b7280;
  --muted2:#94a3b8;
  --blue:#0b63ff;
  --blue-dark:#074fd2;
  --nav-dark:#111827;
  --hero-sky-1:#8fc6ff;
  --hero-sky-2:#cfe7ff;
  --hero-sky-3:#f4fbff;
  --shadow:0 18px 45px rgba(2,8,23,.10);
  --shadow2:0 10px 28px rgba(2,8,23,.12);
  --radius:18px;
  --container:1120px;
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Google Sans", Roboto, system-ui, -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;
  color:var(--text);
  background:#fff;
}
[hidden]{display:none!important}

a{color:inherit;text-decoration:none}

.container{
  width:min(var(--container), calc(100% - 64px));
  margin:0 auto;
}

/* Reference overlay removed */

/* Nav */
.top{
  position:sticky;
  top:0;
  z-index:10;
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(1.2) blur(8px);
}

/* Anchor offsets for sticky header */
section[id]{scroll-margin-top:92px}
.nav{
  height:76px;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  font-weight:800;
  letter-spacing:-.02em;
}
.brand-dots{display:flex;gap:7px;align-items:center}
.dot{width:12px;height:12px;border-radius:999px;display:block}
.dot-1{background:#111827}
.dot-2{background:#9ca3af}
.brand-name{font-size:26px;line-height:1}

.menu{
  display:flex;
  gap:34px;
  font-size:14px;
  color:#0f172a;
  font-weight:700;
}
.menu-item{display:flex;gap:6px;align-items:center}
.chev{font-size:12px;transform:translateY(1px);opacity:.8}

.nav-actions{display:flex;align-items:center;gap:18px}
.signin{font-size:14px;color:#111827;font-weight:500}

.pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:14px 28px;
  font-weight:700;
  font-size:14px;
}
.pill--small{padding:10px 16px;font-size:13px;background:var(--blue);color:#fff}
.pill--primary{
  background:var(--blue);
  color:#fff;
  box-shadow:0 10px 22px rgba(11,99,255,.18);
}
.pill--primary:hover{background:var(--blue-dark)}
.pill--dark{
  background:#111827;
  color:#fff;
  padding:14px 22px;
  font-weight:700;
}
.pill--light{
  background:#fff;
  color:#0b63ff;
  padding:12px 22px;
  font-weight:800;
}

/* Hero */
.hero{
  background:
    radial-gradient(circle at 35% 26%, rgba(255,255,255,.90), rgba(255,255,255,0) 52%),
    radial-gradient(circle at 72% 32%, rgba(255,255,255,.70), rgba(255,255,255,0) 55%),
    linear-gradient(180deg, var(--hero-sky-1) 0%, var(--hero-sky-2) 40%, var(--hero-sky-3) 100%);
  padding:84px 0 62px;
  border-bottom:1px solid rgba(15,23,42,.04);
}
.hero-inner{text-align:center}
.hero-title{
  margin:0;
  font-size:74px;
  line-height:.98;
  letter-spacing:-.045em;
  font-weight:800;
  color:#111827;
}
.hero-subtitle{
  max-width:860px;
  /* form sits below subtitle now, so we don't need the huge gap here */
  margin:22px auto 40px;
  font-size:18px;
  line-height:1.55;
  color:rgba(15,23,42,.74);
  font-weight:600;
}
.hero-note{
  margin-top:12px;
  font-size:12px;
  color:rgba(15,23,42,.56);
  font-weight:700;
}
.hero-apply{
  width:min(720px, 100%);
  margin:0 auto 52px;
}
.hero-apply-form{
  display:flex;
  gap:10px;
  align-items:stretch;
}
.ha-field{flex:1;display:flex;flex-direction:column;gap:6px}
.ha-field--email{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.ha-field--email .ha-email{flex:1}
.ha-input{
  height:54px;
  border-radius:12px;
  background:#fff;
  border:1px solid rgba(148,163,184,.55);
  box-shadow:0 1px 0 rgba(2,8,23,.04), 0 6px 18px rgba(2,8,23,.06);
  display:flex;
  align-items:center;
  padding:0 18px;
}
.ha-prefix{color:#94a3b8;font-weight:900;margin-right:6px}
.ha-input input{
  width:100%;
  border:none;
  outline:none;
  font-weight:800;
  font-size:15px;
  color:#0f172a;
}
.ha-email{
  height:54px;
  border-radius:12px;
  background:#fff;
  border:1px solid rgba(148,163,184,.55);
  box-shadow:0 1px 0 rgba(2,8,23,.04), 0 6px 18px rgba(2,8,23,.06);
  padding:0 18px;
  outline:none;
  font-weight:800;
  font-size:15px;
  color:#0f172a;
}
.ha-email::placeholder,.ha-input input::placeholder{color:#94a3b8;font-weight:800}
.ha-btn{
  height:54px;
  min-width:54px;
  padding:0 20px;
  border-radius:999px;
  border:none;
  background:var(--blue);
  color:#fff;
  font-weight:900;
  font-size:18px;
  cursor:pointer;
  box-shadow:0 10px 24px rgba(11,99,255,.26);
  flex-shrink:0;
}
.ha-btn:hover:not(:disabled){background:var(--blue-dark)}
.ha-btn:disabled{
  opacity:0.6;
  cursor:not-allowed;
}
.error--hero{
  min-height:12px;
  color:#ef4444;
  text-align:left;
}
.hero-success{
  margin-top:12px;
  font-size:12px;
  font-weight:900;
  color:#16a34a;
}
.hero-note{
  margin-top:16px;
}

.ha-input:focus-within,
.ha-email:focus{
  border-color:rgba(11,99,255,.55);
  box-shadow:0 0 0 4px rgba(11,99,255,.14), 0 6px 18px rgba(2,8,23,.06);
}
.hero-mock{
  position:relative;
  margin:0 auto 44px;
  /* back to the earlier scale, but a tiny bit wider so images read clearly */
  width:min(1040px, calc(100vw - 64px));
}

.hero-apply{padding-top:0}
.glow{
  position:absolute;
  width:140px;
  height:140px;
  filter:blur(24px);
  opacity:.65;
}
.glow--left{left:-32px;top:106px;background:radial-gradient(circle at 30% 30%, #fde68a 0%, rgba(253,230,138,0) 70%)}
.glow--right{right:-36px;bottom:-12px;background:radial-gradient(circle at 35% 35%, #f9a8d4 0%, rgba(249,168,212,0) 70%)}

/* Before/After paired strip (hero) */
.parallax{
  position:relative;
  border-radius:28px;
  box-shadow:var(--shadow);
  border:1px solid rgba(15,23,42,.06);
  overflow:hidden;
  background:linear-gradient(90deg, #a8d7ff 0%, #d9ecff 48%, #ffffff 100%);
}
.parallax-bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 15% 30%, rgba(255,255,255,.78), rgba(255,255,255,0) 55%),
    radial-gradient(circle at 86% 18%, rgba(59,130,246,.20), rgba(59,130,246,0) 58%),
    linear-gradient(180deg, rgba(255,255,255,.00), rgba(255,255,255,.25));
  pointer-events:none;
}
.parallax-strip{
  position:relative;
  display:grid;
  /* desktop: 2 pairs side-by-side (total 4 images visible) */
  grid-template-columns:repeat(2, 1fr);
  gap:20px;
  padding:24px 24px 26px;
}
.pair{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  align-items:stretch;
}
.shot{
  position:relative;
  border-radius:26px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 18px 40px rgba(2,8,23,.18);
  transform:translate3d(var(--px, 0px), var(--py, 0px), 0);
  transition:transform 120ms ease-out;
  width:100%;
  aspect-ratio:4 / 5; /* Instagram portrait */
}
.pair .shot:nth-child(1){z-index:1}
.pair .shot:nth-child(2){
  z-index:2;
  --px: -6px; /* minimal overlap */
}
.shot img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}
.tag{
  position:absolute;
  top:12px;
  left:12px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  letter-spacing:-.01em;
  backdrop-filter: blur(10px);
  border:1px solid rgba(15,23,42,.10);
  box-shadow:0 10px 20px rgba(2,8,23,.10);
}
.tag--before{
  background:rgba(255,255,255,.68);
  color:rgba(15,23,42,.78);
}
.tag--after{
  background:rgba(255,255,255,.82);
  color:#0b63ff;
}

/* Revenue indicator on "After" images */
.earn-badge{
  position:absolute;
  top:12px;
  right:12px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(34,197,94,.26);
  box-shadow:0 10px 22px rgba(2,8,23,.10);
  font-size:12px;
  font-weight:900;
  color:#16a34a;
  backdrop-filter: blur(10px);
}
.earn-dot{
  width:8px;
  height:8px;
  border-radius:999px;
  background:#22c55e;
  box-shadow:0 0 0 3px rgba(34,197,94,.18);
  animation:earnPulse 1.9s ease-in-out infinite;
}
@keyframes earnPulse{
  0%,100%{transform:scale(1); box-shadow:0 0 0 3px rgba(34,197,94,.18)}
  50%{transform:scale(1.12); box-shadow:0 0 0 6px rgba(34,197,94,.12)}
}

.trusted{padding:36px 0 0}
.trusted-label{
  font-size:11px;
  letter-spacing:.14em;
  color:#94a3b8;
  font-weight:800;
  margin-bottom:16px;
}
.trusted-avatars{
  display:flex;
  justify-content:center;
  margin:0 0 16px;
}
.avatar-stack{
  display:flex;
  align-items:center;
  justify-content:center;
}
.avatar-circle{
  width:38px;
  height:38px;
  border-radius:999px;
  background:#fff;
  border:2px solid rgba(255,255,255,.92);
  box-shadow:0 10px 22px rgba(2,8,23,.12);
  overflow:hidden;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-left:-10px;
}
.avatar-circle:first-child{margin-left:0}
.avatar-circle img{width:100%;height:100%;object-fit:cover;display:block}
.avatar-more{
  background:rgba(255,255,255,.90);
  color:#0f172a;
  font-size:12px;
  font-weight:900;
  letter-spacing:-.01em;
}
.trusted-logos{
  display:flex;
  justify-content:center;
  gap:38px;
  color:#9ca3af;
  font-weight:700;
  align-items:center;
  user-select:none;
}
.logo{opacity:.85}
.logo--g{font-size:28px;font-weight:900}
.logo--spotify{font-size:14px;font-weight:800}
.logo--a{font-size:26px;font-weight:900}
.logo--airbnb{font-size:20px;font-weight:900}
.logo--yt{font-size:18px;font-weight:900}
.logo--stripe{font-size:15px;font-weight:800}

/* Feature blocks */
.feature{padding:82px 0;background:#fff}
.feature--tint{background:#f7f3ef}
.feature-inner{
  display:grid;
  grid-template-columns:1fr 520px;
  gap:60px;
  align-items:center;
}
.feature-inner--swap{grid-template-columns:520px 1fr}
.copy{text-align:left}
.kicker{
  font-size:11px;
  letter-spacing:.16em;
  font-weight:900;
  color:#3b82f6;
  margin-bottom:10px;
}
.kicker--pink{color:#fb7185}
.kicker--green{color:#22c55e}
.h2{
  margin:0 0 14px;
  font-size:34px;
  line-height:1.12;
  letter-spacing:-.03em;
  font-weight:800;
  color:#111827;
}
.p{
  margin:0 0 18px;
  color:#6b7280;
  font-size:14px;
  line-height:1.65;
  font-weight:500;
}
.bullets{
  margin:10px 0 16px;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
  color:#475569;
  font-weight:600;
  font-size:13px;
}
.b-dot{
  width:8px;height:8px;border-radius:999px;background:#0b63ff;display:inline-block;margin-right:10px;
}
.link{color:#0b63ff;font-weight:700;font-size:13px}

.ticks{
  margin:18px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
  color:rgba(15,23,42,.85);
  font-weight:650;
}
.ticks li{
  display:flex;
  gap:10px;
  align-items:flex-start;
  line-height:1.35;
}
.ticks li::before{
  content:"✓";
  width:18px;
  flex:0 0 18px;
  height:18px;
  margin-top:1px;
  border-radius:6px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(34,197,94,.12);
  color:rgb(21,128,61);
  font-weight:900;
}

.visual-card{
  position:relative;
  width:520px;
  height:280px;
  border-radius:22px;
  background:linear-gradient(135deg,#0b1220,#2c2f3c);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.vc-shadow{position:absolute;inset:0;background:radial-gradient(circle at 40% 20%, rgba(255,255,255,.12), rgba(255,255,255,0) 60%)}
.vc-inner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.vc-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.02);
}
.vc-app{
  width:210px;height:210px;border-radius:26px;
  background:linear-gradient(135deg,#0f172a,#111827);
  box-shadow:0 18px 40px rgba(0,0,0,.35);
  display:flex;align-items:center;justify-content:center;
}
.vc-n{
  font-weight:900;
  font-size:96px;
  color:#e11d48;
  text-shadow:0 14px 18px rgba(225,29,72,.25);
}

/* Phone mock */
.phone{
  width:520px;
  display:flex;
  justify-content:center;
}
.phone--img{
  position:relative;
  width:380px;
  height:auto;
  border-radius:24px;
  overflow:hidden;
  box-shadow:var(--shadow);
  border:none;
  background:transparent;
}
.phone--img .phone-img{
  position:static;
  width:100%;
  height:auto;
  display:block;
}
/* Old phone mockup styles removed - now using simple image */

.cards{display:flex;gap:14px;margin:20px 0 22px}
.mini-card{
  flex:1;
  background:#fff;
  border:1px solid rgba(15,23,42,.06);
  border-radius:14px;
  padding:14px 14px;
  display:flex;
  gap:12px;
  box-shadow:0 8px 18px rgba(2,8,23,.06);
}
.mini-ic{
  width:30px;height:30px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;color:#111827;
  background:#f3f4f6;
}
.mini-ic--pink{background:#ffe4e6;color:#e11d48}
.mini-ic--purple{background:#ede9fe;color:#7c3aed}
.mini-title{font-weight:900;color:#111827;font-size:13px;margin-top:1px}
.mini-sub{color:#6b7280;font-size:11px;line-height:1.35;margin-top:2px;font-weight:600}

/* Video mock */
.video{width:520px}
.video-frame{
  height:280px;
  border-radius:18px;
  background:linear-gradient(135deg,#0b1220,#2b2f38);
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
  border:1px solid rgba(15,23,42,.06);
}
.video-bars{
  position:absolute;left:0;right:0;bottom:0;height:42%;
  background:linear-gradient(180deg, rgba(255,255,255,0), rgba(255,255,255,.07));
}
.video-play{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-size:36px;font-weight:900;color:rgba(255,255,255,.9);
  text-shadow:0 8px 18px rgba(0,0,0,.35);
}

/* Quote */
.quote{padding:72px 0 64px;background:#fff}
.quote-inner{text-align:center;max-width:760px}
.quote-mark{color:#0b63ff;font-weight:900;font-size:44px;line-height:1;margin-bottom:10px}
.quote-text{
  margin:0;
  font-size:22px;
  font-weight:800;
  letter-spacing:-.02em;
  line-height:1.25;
  color:#111827;
}
.quote-person{
  margin-top:18px;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:12px;
}
.person-ava{width:36px;height:36px;border-radius:999px;background:linear-gradient(135deg,#e2e8f0,#94a3b8)}
.person-name{font-weight:900;font-size:13px;color:#111827}
.person-role{font-size:11px;color:#6b7280;font-weight:600;margin-top:1px}

/* CTA */
.cta{
  background:#fff;
  padding:58px 0 54px;
}
.cta-inner{text-align:center;color:#0f172a}
.cta-title{margin:0;font-weight:900;font-size:30px;letter-spacing:-.02em;color:#0f172a}
.cta-sub{margin:10px 0 20px;color:#475569;font-weight:600;font-size:13px}
.cta-note{margin-top:10px;color:#64748b;font-weight:600;font-size:11px}

/* Invite-only application */
.apply-card{
  width:min(720px, 100%);
  margin:22px auto 0;
  background:rgba(255,255,255,.98);
  border-radius:18px;
  padding:18px;
  box-shadow:0 18px 48px rgba(2,8,23,.22);
  border:1px solid rgba(255,255,255,.25);
  color:#0f172a;
}
.apply-form{display:grid;gap:14px;text-align:left}
.field{display:grid;gap:8px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field-row--single{grid-template-columns:1fr}
.label{font-size:12px;font-weight:900;color:#0f172a}
.input-wrap{
  display:flex;
  align-items:center;
  border:1px solid rgba(15,23,42,.12);
  border-radius:999px;
  background:#fff;
  padding:0 12px;
  height:54px;
  box-shadow:0 8px 18px rgba(2,8,23,.06);
}
.prefix{color:#94a3b8;font-weight:900;margin-right:6px}
.apply-form input[type="text"],
.apply-form input[type="email"],
.apply-form input[type="tel"]{
  width:100%;
  height:54px;
  border:1px solid rgba(15,23,42,.12);
  border-radius:999px;
  padding:0 16px;
  outline:none;
  font-weight:700;
  font-size:15px;
  color:#0f172a;
  box-shadow:0 14px 30px rgba(2,8,23,.08);
}
.input-wrap input{
  height:52px;
  border:none;
  padding:0;
  box-shadow:none;
}
.apply-form input::placeholder{color:#94a3b8;font-weight:700}
.error{
  min-height:14px;
  font-size:11px;
  font-weight:800;
  color:#dc2626;
}
.field--check{margin-top:2px}
.check{
  display:flex;
  gap:10px;
  align-items:flex-start;
  font-size:12px;
  font-weight:700;
  color:#334155;
  line-height:1.35;
}
.check input{margin-top:2px}
.apply-btn{
  height:54px;
  border-radius:999px;
  border:none;
  background:var(--blue);
  color:#fff;
  font-weight:900;
  font-size:14px;
  cursor:pointer;
  box-shadow:0 14px 26px rgba(11,99,255,.22);
}
.apply-btn:hover:not(:disabled){background:var(--blue-dark)}
.apply-btn:disabled{
  opacity:0.6;
  cursor:not-allowed;
}

.apply-form input[type="text"]:focus,
.apply-form input[type="email"]:focus,
.apply-form input[type="tel"]:focus{
  border-color:rgba(11,99,255,.55);
  box-shadow:0 18px 46px rgba(11,99,255,.16);
}
.apply-fineprint{
  margin-top:-6px;
  font-size:11px;
  font-weight:700;
  color:#64748b;
  text-align:center;
}
.apply-success{
  padding:14px 10px 6px;
  display:grid;
  gap:10px;
  text-align:center;
}
.success-title{font-size:16px;font-weight:900;color:#0f172a}
.success-sub{font-size:12px;font-weight:700;color:#475569;line-height:1.45}

/* Footer */
.footer{
  background:#111827;
  color:#e5e7eb;
  padding:52px 0 22px;
}
.footer-inner{
  display:grid;
  grid-template-columns:240px 1fr;
  gap:60px;
  align-items:flex-start;
}
.brand--footer .brand-name{font-size:24px}
.social{display:flex;gap:10px;margin-top:12px;color:#9ca3af}
.soc{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;font-size:14px}

.footer-cols{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:44px;
}
.col-title{
  font-weight:900;
  font-size:12px;
  margin-bottom:12px;
  color:#f3f4f6;
}
.col a{
  display:block;
  font-size:12px;
  font-weight:600;
  color:#9ca3af;
  margin:10px 0;
}
.footer-bottom{
  margin-top:26px;
  padding-top:16px;
  border-top:1px solid rgba(148,163,184,.14);
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.muted{color:#9ca3af;font-size:11px;font-weight:600}

/* Responsive */
@media (max-width: 980px){
  .menu{display:none}
  .hero-title{font-size:60px}
  .feature-inner, .feature-inner--swap{grid-template-columns:1fr;gap:34px}
  .visual-card,.video{width:100%}
  .visual-card{height:250px}
  .phone{width:100%}
  .footer-inner{grid-template-columns:1fr;gap:26px}
  .footer-cols{grid-template-columns:repeat(2,1fr)}

  .hero-mock{
    width:min(980px, calc(100vw - 48px));
  }
  /* mobile/tablet: stack pairs so it becomes a clean 2x2 grid */
  .parallax-strip{grid-template-columns:1fr;gap:18px;padding:22px}
  .pair{gap:12px}
  .pair .shot:nth-child(2){--px:-4px}
}
@media (max-width: 560px){
  .container{width:min(var(--container), calc(100% - 32px))}
  .hero{padding:64px 0 52px}
  .hero-title{font-size:44px}
  .hero-subtitle{margin:18px auto 22px}
  .hero-apply{margin:0 auto 34px}
  .hero-note{margin-top:12px}
  .hero-apply-form{flex-direction:column;gap:10px}
  .ha-field, .ha-field--email{flex:none}
  .ha-btn{width:100%;height:54px;font-size:16px}
  .error--hero{text-align:left}
  .hero-mock{
    width:calc(100vw - 32px);
  }
  .parallax-strip{padding:18px 14px;gap:14px}
  .pair{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:12px;
  }
  
  /* Avatar circles - better mobile spacing */
  .avatar-circle{
    width:44px;
    height:44px;
    margin-left:-12px;
  }
  .avatar-circle:first-child{margin-left:0}
  
  /* Bullets in feature sections */
  .bullets{margin:10px 0 14px}
  .bullet{padding:8px 0}
  .pair .shot:nth-child(2){--px:0px}
  .shot{border-radius:22px}
  .avatar-circle{width:34px;height:34px;margin-left:-9px}
  .phone--img{width:min(420px, 100%)}
  .field-row{grid-template-columns:1fr}
  .cards{flex-direction:column}
  .footer-cols{grid-template-columns:1fr}
}


