/* ════════════════════════════════════════════════════════════════
   OPT Digital - Onboarding shared stylesheet
   Used by every step (index / form / connect / call / welcome).
   ════════════════════════════════════════════════════════════════ */

/* ── Bethany Elingston (OPT heading font - self-hosted) ── */
@font-face{
  font-family:"Bethany Elingston";
  src:url("fonts/BethanyElingston.otf") format("opentype");
  font-weight:400;font-style:normal;font-display:swap;
}
/* ── Tokens ─────────────────────────────────────────────────── */
:root{
  --opt-yellow:#f4e14a;
  --opt-yellow-deep:#f5c518;
  --ink:#15161a;
  --ink-soft:#3b3d44;
  --ink-mute:#8a8d96;
  --paper:#ffffff;
  --paper-2:#fbfbf9;
  --line:#e9e6da;
  --font-display:"Bethany Elingston","Cormorant Garamond",Georgia,serif;
  --font-body:"Inter Tight","Inter",system-ui,-apple-system,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0;}
/* Nothing scales past its container - guards against any device width. */
img,svg,video,iframe{max-width:100%;}
html{height:100%;-webkit-text-size-adjust:100%;}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:
    repeating-linear-gradient(0deg, rgba(20,22,30,.035) 0 1px, transparent 1px 66px),
    repeating-linear-gradient(90deg, rgba(20,22,30,.035) 0 1px, transparent 1px 66px),
    radial-gradient(1200px 620px at 50% -8%, #fffdf2 0%, var(--paper) 46%, var(--paper-2) 100%) fixed;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;min-height:100dvh;
  overflow-x:hidden;
  position:relative;
}

/* ── Stage / layering ───────────────────────────────────────── */
.stage{
  position:relative;
  min-height:100vh;min-height:100dvh;
  display:flex;flex-direction:column;align-items:center;
  justify-content:safe center;
  padding:36px 20px 48px;
  isolation:isolate;
}
#confetti{position:fixed;inset:0;z-index:9999;pointer-events:none;}
.hero{position:relative;z-index:3;width:100%;display:flex;flex-direction:column;align-items:center;}

/* ── Logo ───────────────────────────────────────────────────── */
.logo{display:inline-flex;align-items:center;margin-bottom:14px;animation:dropIn .8s cubic-bezier(.2,.8,.2,1) both;}
.logo svg,.logo img{height:42px;width:auto;display:block;filter:drop-shadow(0 6px 16px rgba(244,225,74,.30));}

/* ── Progress stepper ───────────────────────────────────────── */
.stepper{width:100%;max-width:620px;margin:0 auto 22px;opacity:0;animation:fadeUp .6s ease .15s both;}
.stepper ol{list-style:none;display:flex;align-items:flex-start;justify-content:space-between;gap:2px;}
.stepper li{position:relative;flex:1 1 0;display:flex;flex-direction:column;align-items:center;gap:7px;text-decoration:none;}
/* connector line behind the dots */
.stepper li::before{content:"";position:absolute;top:13px;right:50%;width:100%;height:2px;background:var(--line);z-index:0;}
.stepper li:first-child::before{display:none;}
.stepper li.done::before,.stepper li.current::before{background:var(--opt-yellow-deep);}
.stepper .dot{
  position:relative;z-index:1;width:27px;height:27px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;font-variant-numeric:tabular-nums;
  background:#fff;border:2px solid var(--line);color:var(--ink-mute);
  transition:transform .2s ease;
}
.stepper .lbl{font-size:10.5px;font-weight:600;letter-spacing:.04em;color:var(--ink-mute);text-align:center;line-height:1.2;}
.stepper li.done .dot{background:var(--opt-yellow);border-color:var(--opt-yellow);color:#1a1700;}
.stepper li.done .lbl{color:var(--ink-soft);}
.stepper li.current .dot{
  background:#fff;border-color:var(--opt-yellow-deep);color:var(--ink);
  box-shadow:0 0 0 4px rgba(244,225,74,.28);
}
.stepper li.current .lbl{color:var(--ink);font-weight:700;}
a.stepper-li{cursor:pointer;}
a.stepper-li:hover .dot{transform:translateY(-2px);}
@media (max-width:560px){ .stepper .lbl{display:none;} .stepper{margin-bottom:18px;} }

/* ── Eyebrow (shimmering) ───────────────────────────────────── */
.eyebrow{
  font-size:13px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;margin-bottom:11px;
  background:linear-gradient(100deg,var(--ink-mute) 0%,var(--ink-mute) 38%,#d9b400 48%,var(--opt-yellow-deep) 52%,var(--ink-mute) 62%,var(--ink-mute) 100%);
  background-size:220% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
  animation:eyebrowShimmer 4.2s linear 1s infinite, fadeUp .7s ease .2s both;
}
@keyframes eyebrowShimmer{0%{background-position:140% 0;}100%{background-position:-40% 0;}}

/* ── Greeting chip ──────────────────────────────────────────── */
.greeting{
  display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600;color:var(--ink-soft);
  background:#fff;border:1px solid #efe7c2;padding:7px 15px 7px 11px;border-radius:999px;
  box-shadow:0 8px 24px -14px rgba(180,150,0,.6);margin-bottom:16px;
  opacity:0;transform:translateY(8px) scale(.96);animation:popChip .6s cubic-bezier(.34,1.5,.64,1) 1.2s forwards;
}
.greeting .wave{display:inline-block;font-size:15px;transform-origin:70% 70%;animation:wave 2.4s ease 1.8s 3;}
.greeting b{color:var(--ink);}
@keyframes wave{0%,60%,100%{transform:rotate(0);}10%{transform:rotate(16deg);}20%{transform:rotate(-10deg);}30%{transform:rotate(16deg);}40%{transform:rotate(-6deg);}50%{transform:rotate(10deg);}}

/* ── Heading (word-by-word reveal) ──────────────────────────── */
h1{
  font-family:var(--font-display);font-weight:400;color:var(--ink);
  font-size:clamp(32px,4.8vw,56px);line-height:1.14;letter-spacing:0;
  text-align:center;max-width:min(22ch,92vw);margin:0 auto 2px;
}
h1 .step{display:block;font-style:italic;font-weight:500;color:var(--ink-soft);font-size:.6em;margin-top:.1em;}
h1 .w{display:inline-block;opacity:0;filter:blur(10px);transform:translateY(26px) rotateX(40deg);transform-origin:bottom;animation:wordIn .72s cubic-bezier(.2,.85,.25,1) forwards;animation-delay:var(--d,0s);}
@keyframes wordIn{to{opacity:1;filter:blur(0);transform:none;}}

/* intro sub-line under a heading */
.lede{max-width:54ch;text-align:center;color:var(--ink-soft);font-size:clamp(14px,1.6vw,16.5px);line-height:1.55;margin:10px auto 0;opacity:0;animation:fadeUp .7s ease 1s both;}

/* ── Video frame (step 1) ───────────────────────────────────── */
.video-wrap{position:relative;z-index:3;width:min(680px,90vw);margin:22px auto 0;border-radius:18px;opacity:0;transform:translateY(34px) scale(.97);animation:videoRise .9s cubic-bezier(.2,.8,.2,1) .4s forwards;}
.video-glow{position:absolute;inset:-3px;border-radius:20px;z-index:-1;background:linear-gradient(135deg,var(--opt-yellow),#fff6c2 40%,var(--opt-yellow-deep));filter:blur(22px);opacity:.45;animation:glowPulse 5s ease-in-out infinite;}
@keyframes glowPulse{0%,100%{opacity:.32;}50%{opacity:.6;}}
.video-frame{position:relative;z-index:2;aspect-ratio:16/9;width:100%;border-radius:18px;overflow:hidden;background:#0c0e13;border:1px solid rgba(0,0,0,.06);box-shadow:0 40px 90px -36px rgba(20,22,30,.55),0 6px 22px -10px rgba(20,22,30,.28);animation:floaty 7s ease-in-out 2.4s infinite;}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}
.poster{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(120% 90% at 50% 0%,#1b2230 0%,#0c0e13 60%),repeating-linear-gradient(0deg,transparent,transparent 38px,rgba(255,255,255,.03) 39px),repeating-linear-gradient(90deg,transparent,transparent 38px,rgba(255,255,255,.03) 39px);color:#fff;gap:16px;text-align:center;}
.poster .play{position:relative;width:78px;height:78px;border-radius:50%;background:var(--opt-yellow);color:#1a1700;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 26px -6px rgba(244,197,24,.7);cursor:pointer;border:none;transition:transform .25s cubic-bezier(.34,1.55,.64,1),background .2s ease;}
.poster .play::before,.poster .play::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid rgba(244,225,74,.85);pointer-events:none;animation:playRing 4s cubic-bezier(.2,.6,.3,1) infinite;}
.poster .play::after{animation-delay:2s;}
@keyframes playRing{0%{transform:scale(1);opacity:.85;}80%{opacity:0;}100%{transform:scale(2.5);opacity:0;}}
.poster .play:hover{transform:scale(1.12);background:#ffe85c;}
.poster .play:active{transform:scale(1.04);}
.poster .play svg{margin-left:5px;transition:transform .25s ease;}
.poster .play:hover svg{transform:scale(1.08);}
.poster .ptitle{font-family:var(--font-display);font-size:clamp(18px,3vw,26px);font-weight:600;}
.poster .pmeta{font-size:12.5px;color:#aeb4c2;letter-spacing:.04em;}
.poster .phint{display:none;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#fff;opacity:.95;text-shadow:0 1px 8px rgba(0,0,0,.7);}
.poster .pbar{position:absolute;left:0;right:0;bottom:0;height:6px;background:rgba(255,255,255,.12);}
.poster .pbar i{display:block;height:100%;width:34%;background:var(--opt-yellow);}
.poster .vimeo{position:absolute;right:14px;bottom:16px;font-size:12px;font-weight:600;color:#cfd4de;opacity:.85;}
.poster.playing{background:radial-gradient(closest-side at 50% 50%,rgba(0,0,0,.32),rgba(0,0,0,0) 72%);gap:18px;}
.poster.playing .ptitle,.poster.playing .pmeta,.poster.playing .pbar,.poster.playing .vimeo{display:none;}
.poster.playing .phint{display:block;}

/* ── Custom OPT-branded video controls ──────────────────────── */
.vctrls{position:absolute;left:0;right:0;bottom:0;z-index:4;display:flex;flex-direction:column;background:linear-gradient(to top,rgba(8,10,14,.94),rgba(8,10,14,0));opacity:0;transform:translateY(8px);transition:opacity .3s ease,transform .3s ease;pointer-events:none;font-family:var(--font-body);padding-top:30px;}
.video-frame.show-ctrls .vctrls{opacity:1;transform:none;pointer-events:auto;}
.vprog{position:relative;width:100%;height:6px;background:rgba(255,255,255,.22);cursor:pointer;transition:height .15s ease;}
.vprog:hover{height:10px;}
.vprog-buf{position:absolute;inset:0 auto 0 0;height:100%;width:0;background:rgba(255,255,255,.18);}
.vprog-fill{position:absolute;inset:0 auto 0 0;height:100%;width:0;background:var(--opt-yellow);animation:barPulse 2s ease-in-out infinite;}
.vprog-handle{position:absolute;top:50%;left:0;width:15px;height:15px;border-radius:50%;background:var(--opt-yellow);transform:translate(-50%,-50%);box-shadow:0 1px 6px rgba(0,0,0,.55);}
.vprog-handle::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:2px solid var(--opt-yellow);animation:handlePulse 2s ease-out infinite;}
.vrow{display:flex;align-items:center;gap:9px;padding:8px 13px 12px;}
.vbtn{flex:0 0 auto;background:none;border:none;color:#fff;cursor:pointer;width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;transition:background .15s ease,transform .15s ease;}
.vbtn:hover{background:rgba(255,255,255,.16);transform:scale(1.06);}
.vbtn svg{width:20px;height:20px;}
.vtime{flex:0 0 auto;color:#fff;font-size:12.5px;font-weight:600;font-variant-numeric:tabular-nums;opacity:.92;white-space:nowrap;}
.vtime.vsep{opacity:.5;margin:0 -2px;}
.vspacer{flex:1 1 auto;}
.vvol{display:flex;align-items:center;flex:0 0 auto;}
.vol-track{position:relative;width:74px;height:5px;border-radius:999px;background:rgba(255,255,255,.25);cursor:pointer;}
.vol-fill{position:absolute;inset:0 auto 0 0;height:100%;width:100%;border-radius:999px;background:var(--opt-yellow);}
.vol-handle{position:absolute;top:50%;left:100%;width:12px;height:12px;border-radius:50%;background:#fff;transform:translate(-50%,-50%);box-shadow:0 1px 4px rgba(0,0,0,.55);}
@keyframes barPulse{0%,100%{box-shadow:0 0 6px 0 rgba(244,225,74,.35);}50%{box-shadow:0 0 16px 2px rgba(244,225,74,.85);}}
@keyframes handlePulse{0%{transform:scale(1);opacity:.8;}70%{opacity:0;}100%{transform:scale(2.4);opacity:0;}}
.video-frame:fullscreen{width:100vw;height:100vh;max-width:none;border:0;border-radius:0;aspect-ratio:auto;animation:none;background:#000;}
.video-frame:fullscreen video{object-fit:contain;}
.video-frame:fullscreen .vctrls{opacity:1;transform:none;pointer-events:auto;}
.video-frame:-webkit-full-screen{width:100vw;height:100vh;max-width:none;border:0;border-radius:0;aspect-ratio:auto;animation:none;background:#000;}
.video-frame:-webkit-full-screen video{object-fit:contain;}
.video-frame:-webkit-full-screen .vctrls{opacity:1;transform:none;pointer-events:auto;}

/* ── Panel / card (form, connect, booking) ──────────────────── */
.panel{
  width:min(680px,94vw);margin:26px auto 0;position:relative;z-index:3;
  background:rgba(255,255,255,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid var(--line);border-radius:20px;padding:28px 28px 26px;
  box-shadow:0 30px 70px -34px rgba(20,22,30,.4),0 4px 14px -8px rgba(20,22,30,.18);
  opacity:0;transform:translateY(26px) scale(.985);animation:videoRise .9s cubic-bezier(.2,.8,.2,1) 1.1s forwards;
}
.panel-wide{width:min(820px,94vw);}
@media (max-width:560px){ .panel{padding:22px 18px 20px;border-radius:16px;} }

/* ── Form ───────────────────────────────────────────────────── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px 16px;}
.field{display:flex;flex-direction:column;gap:6px;}
.field.full{grid-column:1 / -1;}
.field label{font-size:12px;font-weight:600;color:var(--ink-soft);letter-spacing:.01em;}
.field label .req{color:var(--opt-yellow-deep);}
.field input,.field select,.field textarea{
  font-family:var(--font-body);font-size:14.5px;color:var(--ink);
  background:#fff;border:1.5px solid var(--line);border-radius:11px;padding:11px 13px;width:100%;
  transition:border-color .15s ease,box-shadow .15s ease;
}
.field textarea{resize:vertical;min-height:84px;}
.field input::placeholder,.field textarea::placeholder{color:#b6b3a8;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--opt-yellow-deep);box-shadow:0 0 0 4px rgba(244,225,74,.25);}
.field input:user-invalid{border-color:#e26d6d;}
.field .hint{font-size:11px;color:var(--ink-mute);}
@media (max-width:560px){ .form-grid{grid-template-columns:1fr;} }

/* ── Connect cards (step 3) ─────────────────────────────────── */
.connect-list{display:flex;flex-direction:column;gap:12px;}
.connect-card{display:flex;align-items:center;gap:14px;background:#fff;border:1.5px solid var(--line);border-radius:14px;padding:14px 15px;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease;}
.connect-card:hover{border-color:#dcd6c2;box-shadow:0 14px 30px -20px rgba(20,22,30,.4);transform:translateY(-1px);}
.connect-card .cc-ic{flex:0 0 44px;width:44px;height:44px;border-radius:12px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;}
.connect-card .cc-ic svg{width:26px;height:26px;display:block;}
.connect-card .cc-tx{flex:1;min-width:0;}
.connect-card .cc-name{font-size:14.5px;font-weight:700;color:var(--ink);}
.connect-card .cc-desc{font-size:12px;color:var(--ink-mute);margin-top:1px;}
.cc-btn{flex:0 0 auto;font-family:var(--font-body);font-weight:600;font-size:13px;border-radius:999px;padding:9px 17px;cursor:pointer;border:1.5px solid var(--ink);background:#fff;color:var(--ink);transition:background .15s ease,color .15s ease,border-color .15s ease,transform .12s ease;}
.cc-btn:hover{background:var(--ink);color:#fff;transform:translateY(-1px);}
.connect-card.connected{border-color:#bfe6c8;background:linear-gradient(0deg,#f4fbf5,#fff);}
.cc-status{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:#16a34a;}
.cc-status svg{width:18px;height:18px;}

/* ── Booking embed (step 4) ─────────────────────────────────── */
.booking{width:min(820px,94vw);margin:24px auto 0;position:relative;z-index:3;border-radius:20px;overflow:hidden;border:1px solid var(--line);background:#fff;box-shadow:0 30px 70px -34px rgba(20,22,30,.4);opacity:0;transform:translateY(26px);animation:videoRise .9s cubic-bezier(.2,.8,.2,1) 1.1s forwards;}
.booking iframe{width:100%;min-height:640px;border:0;display:block;}
.booking-fallback{padding:42px 26px;text-align:center;color:var(--ink-soft);}
.booking-fallback .bf-ic{width:62px;height:62px;margin:0 auto 14px;border-radius:50%;background:#fff7cf;display:flex;align-items:center;justify-content:center;}
.booking-fallback .bf-ic svg{width:30px;height:30px;}
@media (max-width:560px){ .booking iframe{min-height:560px;} }

/* ── Buttons / nav row ──────────────────────────────────────── */
.cta{margin-top:24px;position:relative;z-index:3;isolation:isolate;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:var(--font-body);font-weight:600;font-size:15.5px;color:#1a1700;background:var(--opt-yellow);border:none;border-radius:999px;padding:15px 30px;cursor:pointer;text-decoration:none;box-shadow:0 16px 38px -14px rgba(244,197,24,.85);transition:transform .24s cubic-bezier(.34,1.5,.64,1),box-shadow .24s ease,background .24s ease;}
.cta.reveal{opacity:0;transform:translateY(14px);animation:fadeUp .7s ease 1.9s forwards;}
.cta-label,.cta svg{position:relative;z-index:1;}
.cta svg{transition:transform .24s cubic-bezier(.34,1.5,.64,1);}
.cta::before{content:"";position:absolute;top:0;left:-140%;z-index:0;width:55%;height:100%;pointer-events:none;background:linear-gradient(100deg,transparent,rgba(255,255,255,.65),transparent);transform:skewX(-18deg);}
.cta:hover{transform:translateY(-3px) scale(1.025);background:#ffe85c;box-shadow:0 26px 54px -14px rgba(244,197,24,1);}
.cta:hover::before{animation:ctaShine .8s ease;}
.cta:hover svg{transform:translateX(5px);}
.cta:active{transform:translateY(-1px) scale(.985);}
.cta[disabled]{opacity:.5;cursor:not-allowed;filter:grayscale(.3);}
.cta[disabled]:hover{transform:none;box-shadow:0 16px 38px -14px rgba(244,197,24,.85);}
@keyframes ctaShine{0%{left:-140%;}100%{left:140%;}}
.cta-note{margin-top:13px;font-size:12.5px;color:var(--ink-mute);z-index:3;}

.btn-row{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:24px;width:100%;max-width:min(680px,94vw);position:relative;z-index:3;}
.btn-row .cta{margin-top:0;}
.btn-back{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-weight:600;font-size:14px;color:var(--ink-soft);background:none;border:none;cursor:pointer;text-decoration:none;padding:10px 6px;border-radius:10px;transition:color .15s ease,transform .15s ease;}
.btn-back:hover{color:var(--ink);transform:translateX(-3px);}
.btn-back svg{width:17px;height:17px;}

/* ── Lead cards (step 1 + step 5) ───────────────────────────── */
.lead{position:absolute;z-index:1;width:240px;}
.lead.floating{animation:leadFloat var(--floatDur,6s) ease-in-out infinite;animation-delay:var(--floatDelay,0s);}
.lead.floating:hover{animation-play-state:paused;}
@keyframes leadFloat{0%,100%{transform:translate(0,0);}50%{transform:translate(var(--fx,0px),var(--fy,-5px));}}
.lead-inner{position:relative;display:flex;align-items:center;gap:11px;background:rgba(255,255,255,.80);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(20,22,30,.05);border-radius:14px;padding:11px 13px;box-shadow:0 18px 40px -22px rgba(20,22,30,.28);opacity:0;transform:rotate(var(--rot,0deg));}
.lead.show .lead-inner{animation:leadOut 1s cubic-bezier(.2,.8,.2,1) forwards;}
.lead .ic{flex:0 0 36px;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:#fff;box-shadow:0 1px 3px rgba(20,22,30,.16),inset 0 0 0 1px rgba(20,22,30,.05);transition:transform .25s cubic-bezier(.34,1.55,.64,1);}
.lead .ic svg{width:22px;height:22px;display:block;}
.lead .tx{min-width:0;flex:1;}
.lead .t1{font-size:9.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);}
.lead .t2{font-size:12.5px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.lead .t3{font-size:11px;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.lead .time{position:absolute;top:11px;right:12px;font-size:10px;color:var(--ink-mute);}
@keyframes leadOut{0%{opacity:0;transform:translateX(var(--fromX)) translateY(6px) scale(.95) rotate(var(--rot,0deg));}22%{opacity:.58;}100%{opacity:.58;transform:translateX(0) translateY(0) scale(1) rotate(var(--rot,0deg));}}
.lead-inner.settled{animation:none;opacity:.58;cursor:pointer;transform:rotate(var(--rot,0deg));transition:transform .4s cubic-bezier(.34,1.4,.64,1),opacity .3s ease,box-shadow .4s ease,background .3s ease;}
.lead:hover .lead-inner.settled{opacity:1;background:rgba(255,255,255,.98);transform:translateX(var(--hoverX,0)) scale(1.05) rotate(0deg);box-shadow:0 26px 55px -18px rgba(20,22,30,.42);}
.lead:hover .lead-inner.settled .ic{transform:scale(1.1) rotate(-4deg);}

/* ── Shared keyframes ───────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:none;}}
@keyframes dropIn{from{opacity:0;transform:translateY(-14px);}to{opacity:1;transform:none;}}
@keyframes popChip{to{opacity:1;transform:none;}}
@keyframes videoRise{to{opacity:1;transform:none;}}
@keyframes floaty{0%,100%{transform:translateY(0);}50%{transform:translateY(-9px);}}

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width:1180px){ .lead{display:none;} }
@media (max-width:900px){
  .stage{padding:30px 18px 44px;}
  h1{font-size:clamp(30px,6.5vw,52px);}
  .video-wrap{width:92vw;}
}
@media (max-width:600px){
  .stage{padding:24px 15px 34px;}
  .logo svg,.logo img{height:38px;}
  .eyebrow{font-size:11px;letter-spacing:.2em;margin-bottom:10px;}
  .greeting{font-size:12.5px;padding:6px 13px 6px 10px;margin-bottom:14px;}
  h1{font-size:clamp(23px,6.4vw,32px);width:100%;max-width:100%;line-height:1.16;overflow-wrap:break-word;}
  h1 .step{font-size:.6em;}
  .lede{font-size:14px;}
  .video-wrap{width:94vw;margin-top:16px;}
  .cta{font-size:15px;padding:14px 24px;}
  .cta-note{font-size:11.5px;}
  .poster .play{width:62px;height:62px;}
  .poster .ptitle{font-size:18px;}
  .poster .pmeta{font-size:10.5px;}
  .vctrls{padding-top:26px;}
  .vrow{gap:8px;padding:7px 10px 10px;}
  .vbtn{width:38px;height:38px;}
  .vbtn svg{width:21px;height:21px;}
  .vtime{font-size:11px;}
  .vvol,.vtime.vsep,.vtime.t-dur{display:none;}
  .panel{margin-top:20px;}
  .btn-row{flex-direction:row;}
}
@media (max-width:380px){
  .stage{padding:20px 12px 28px;}
  h1{font-size:clamp(20px,6vw,26px);}
  .eyebrow{font-size:10px;letter-spacing:.1em;}
  .video-wrap{width:96vw;}
  .vrow{gap:6px;padding:6px 8px 9px;}
  .vbtn{width:34px;height:34px;}
}
/* short / laptop viewports (step 1 video): compress to keep CTA in view */
@media (min-width:901px) and (max-height:880px){
  .stage{padding-top:22px;padding-bottom:28px;}
  .logo{margin-bottom:10px;} .logo svg,.logo img{height:38px;}
  .stepper{margin-bottom:16px;}
  .eyebrow{margin-bottom:8px;} .greeting{margin-bottom:10px;}
  h1{font-size:clamp(28px,3.4vw,44px);}
  .video-wrap{width:min(600px,78vw);margin-top:14px;}
  .cta{margin-top:16px;}
}

/* Reduce-motion: ambient loops off; the CTA pulses stay (intentional). */
/* ── Rank On Maps visual (step 5): 3-D map surface + 2-D pin overlay ── */
.romap{position:relative;z-index:3;width:min(760px,94vw);aspect-ratio:760/440;margin:26px auto 6px;}
.romap.go{animation:romapBob 7s ease-in-out 1.4s infinite;}   /* gentle idle bob (2-D, keeps pins aligned) */
@keyframes romapBob{0%,100%{transform:translateY(0);}50%{transform:translateY(-7px);}}
.romap-scene{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  perspective:1300px;perspective-origin:50% 38%;z-index:1;}
/* flanking mini maps for depth — decorative, sit behind the main map */
.rmini{position:absolute;top:13%;width:47%;aspect-ratio:7/5;z-index:0;pointer-events:none;
  perspective:900px;opacity:0;transform:translateY(22px);filter:blur(var(--mblur,1.5px));}
.romap.go .rmini{animation:rminiIn 1.1s ease 1s forwards;}
@keyframes rminiIn{to{opacity:var(--mop,.48);transform:translateY(0);}}
.rmini-l{left:-27%;}
.rmini-r{right:-27%;}
.rmini-plane{position:absolute;inset:0;border-radius:14px;
  background:linear-gradient(150deg,#eef2f7,#dde5ee 58%,#d2dbe6);
  box-shadow:0 28px 54px -26px rgba(25,45,35,.4);transform:rotateX(46deg) rotateZ(-17deg);}
.rmini-l .rmini-plane{transform:rotateX(46deg) rotateZ(-26deg);}
.rmini-r .rmini-plane{transform:rotateX(46deg) rotateZ(22deg);}
.rmini-plane::before{content:"";position:absolute;inset:0;border-radius:14px;opacity:.5;
  background:repeating-linear-gradient(0deg,transparent 0 9%,rgba(150,165,188,.5) 9% 10%),
             repeating-linear-gradient(90deg,transparent 0 7%,rgba(150,165,188,.5) 7% 8%);}
.rmini-plane::after{content:"";position:absolute;left:10%;top:24%;width:30%;height:32%;border-radius:10px;background:rgba(120,200,140,.4);}
.rmini-dot{position:absolute;width:11px;height:11px;border-radius:50%;background:#22c55e;
  box-shadow:0 3px 6px -2px rgba(0,0,0,.3);transform:translate(-50%,-50%);}
@media (max-width:900px){ .rmini{display:none;} }   /* no side room — hide the flankers */
.romap-plane{position:relative;display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:repeat(5,1fr);
  gap:clamp(3px,1vw,10px);width:78%;aspect-ratio:7/5;padding:clamp(8px,2vw,18px);border-radius:18px;
  background:linear-gradient(150deg,#eef2f7,#dde5ee 58%,#d2dbe6);
  box-shadow:0 50px 90px -30px rgba(25,45,35,.5),inset 0 1px 0 rgba(255,255,255,.6);
  transform:rotateX(46deg) rotateZ(-17deg);transform-style:preserve-3d;}
.romap.go .romap-plane{animation:planeIn 1.15s cubic-bezier(.2,.85,.25,1) both;}   /* tilt into place once */
@keyframes planeIn{
  0%{opacity:0;transform:rotateX(66deg) rotateZ(-24deg) translateZ(-40px) scale(.9);}
  100%{opacity:1;transform:rotateX(46deg) rotateZ(-17deg) translateZ(0) scale(1);}
}
/* street grid + park block painted on the map surface */
.romap-plane::before{content:"";position:absolute;inset:0;border-radius:18px;pointer-events:none;opacity:.5;
  background:repeating-linear-gradient(0deg,transparent 0 8.4%,rgba(150,165,188,.5) 8.4% 9.2%),
             repeating-linear-gradient(90deg,transparent 0 6.4%,rgba(150,165,188,.5) 6.4% 7%);}
.romap-plane::after{content:"";position:absolute;left:9%;top:23%;width:29%;height:34%;border-radius:12px;
  background:rgba(120,200,140,.42);pointer-events:none;}
.rc-cell{width:100%;height:100%;}   /* invisible measurement anchor */
/* flat 2-D pins layered over the 3-D grid — always perfectly round */
.romap-pins{position:absolute;inset:0;z-index:5;pointer-events:none;}
.rc-pin{position:absolute;border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:800;line-height:1;font-variant-numeric:tabular-nums;background:#ef4444;
  box-shadow:0 6px 12px -3px rgba(0,0,0,.4);
  transform:translate(-50%,-50%) scale(0);transform-origin:center;
  transition:transform .45s cubic-bezier(.34,1.56,.64,1),background .3s ease;}
.rc-pin.rc-centre{box-shadow:0 0 0 3px #fff,0 8px 18px -4px rgba(0,0,0,.5);}
/* live FX layer over the map: win notifications + firework sparks */
.romap-fx{position:absolute;inset:0;z-index:6;pointer-events:none;}
.rc-notif{position:absolute;display:flex;align-items:center;gap:7px;white-space:nowrap;
  background:#fff;border:1px solid var(--line);border-radius:11px;padding:6px 10px 6px 7px;
  box-shadow:0 12px 24px -10px rgba(20,22,30,.4);
  transform:translate(-50%,-50%);opacity:0;animation:rcNotif 2.8s cubic-bezier(.2,.8,.2,1) forwards;}
.rc-notif .ic{width:20px;height:20px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;}
.rc-notif .ic svg{width:18px;height:18px;}
.rc-notif .tx{font-size:11.5px;font-weight:700;color:var(--ink);line-height:1;}
@keyframes rcNotif{
  0%{opacity:0;transform:translate(-50%,-50%) translateY(10px) scale(.86);}
  12%{opacity:1;transform:translate(-50%,-50%) translateY(-4px) scale(1);}
  80%{opacity:1;transform:translate(-50%,-50%) translateY(-10px) scale(1);}
  100%{opacity:0;transform:translate(-50%,-50%) translateY(-20px) scale(.96);}
}
.rc-spark{position:absolute;width:7px;height:7px;border-radius:2px;
  transform:translate(-50%,-50%);animation:rcSpark .9s ease-out forwards;}
@keyframes rcSpark{
  0%{opacity:1;transform:translate(-50%,-50%) translate(0,0) scale(.5) rotate(0);}
  100%{opacity:0;transform:translate(-50%,-50%) translate(var(--dx),var(--dy)) scale(1) rotate(160deg);}
}

/* ── Step 3: Leadsie access grant (bold, animated) ─────────────── */
.leadsie-panel{text-align:center;display:flex;flex-direction:column;align-items:center;
  max-width:560px;margin:34px auto 0;padding:6px 18px;}   /* no white card - sits on the page */
.leadsie-hero{display:flex;flex-direction:column;align-items:center;gap:16px;margin:6px 0 20px;}
.leadsie-badge{position:relative;width:96px;height:96px;border-radius:28px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(150deg,#2a2d38,#0c0e14);
  box-shadow:0 24px 48px -16px rgba(20,22,30,.62),inset 0 1px 0 rgba(255,255,255,.08);}
.leadsie-badge svg{width:48px;height:48px;position:relative;z-index:2;}
.leadsie-ring{position:absolute;inset:0;border-radius:28px;border:2px solid var(--opt-yellow);opacity:0;
  animation:leadsiePulse 2.6s ease-out infinite;}
.leadsie-ring.d2{animation-delay:1.3s;}
@keyframes leadsiePulse{0%{transform:scale(.9);opacity:.65;}100%{transform:scale(1.7);opacity:0;}}
.leadsie-logos{display:flex;align-items:center;gap:11px;}
.ll-chip{width:44px;height:44px;border-radius:13px;background:#fff;border:1px solid var(--line);
  box-shadow:0 9px 20px -10px rgba(20,22,30,.42);display:flex;align-items:center;justify-content:center;
  animation:llBob 3s ease-in-out infinite;}
.ll-chip svg{width:24px;height:24px;}
.ll-chip:nth-child(2){animation-delay:.45s;}
.ll-chip:nth-child(3){animation-delay:.9s;}
@keyframes llBob{0%,100%{transform:translateY(0);}50%{transform:translateY(-5px);}}
.leadsie-title{font-family:var(--font-display);font-size:26px;line-height:1.1;color:var(--ink);margin-bottom:8px;}
.leadsie-sub{font-size:14px;color:var(--ink-soft);max-width:46ch;margin:0 auto 22px;line-height:1.55;}
.leadsie-cta{animation:leadsieGlow 2.2s ease-in-out infinite;}
@keyframes leadsieGlow{
  0%,100%{box-shadow:0 16px 38px -14px rgba(244,197,24,.85),0 0 0 0 rgba(244,225,74,.55);}
  50%{box-shadow:0 18px 44px -12px rgba(244,197,24,.95),0 0 0 14px rgba(244,225,74,0);}
}
/* Step 4: Calendly embed sizing (tall enough to avoid inner-scroll clipping) */
.cal-embed{height:1000px;}
@media (max-width:600px){ .cal-embed{height:1160px;} }

/* step-5 "what's next" boxes slide in one after another, after the climb starts */
body[data-step="5"] .connect-card{opacity:0;animation:fadeUp .6s cubic-bezier(.2,.8,.2,1) forwards;}
body[data-step="5"] .connect-card:nth-child(1){animation-delay:2s;}
body[data-step="5"] .connect-card:nth-child(2){animation-delay:2.18s;}
body[data-step="5"] .connect-card:nth-child(3){animation-delay:2.36s;}

/* mobile: keep the map centred and in frame */
@media (max-width:600px){
  .romap{aspect-ratio:auto;height:auto;width:96vw;margin:18px auto 6px;}
  .romap-scene{position:relative;inset:auto;height:clamp(230px,66vw,320px);perspective:760px;}
  .romap-plane{width:92%;}
}

@media (prefers-reduced-motion:reduce){
  .video-frame,.video-glow,.greeting .wave,.lead.floating{animation:none !important;}
  .eyebrow{animation:fadeUp .6s ease both !important;}
  /* the step-5 map tilt-in + ranking climb stay ON intentionally —
     they're the centrepiece of the "welcome in" moment */
}
