*{box-sizing:border-box;}

body{
margin:0;
font-family:system-ui;
background:#fff;
color:#0b1220;
}

img{
display:block;
max-width:100%;
}

.page{
padding:28px;
}

.site-shell{
width:min(1280px,94vw);
margin:0 auto;
border-radius:44px;
overflow:hidden;
background:#fff;
box-shadow:0 30px 90px rgba(0,0,0,0.12);
border:1px solid rgba(15,25,40,0.08);
}

/* HERO */

.hero{
position:relative;
height:min(62vh,520px);
overflow:hidden;
}

.hero-bg{
  position:absolute;
  left:0;
  top:0;
  height:100%;
  width:auto;
  min-width:100%;
  object-fit:unset;
  transform:scale(1.02);
  transform-origin:left center;
}

/* HERO HOLOGRAM */

.hero-hologram-center{
  position:absolute;
  left:70px;
  bottom:15%;
  width:285px;

  transform:scale(0.7);
  transform-origin:bottom left;

  z-index:4;
  pointer-events:none;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  overflow:visible;
}

.juju-hologram{
position:relative;
z-index:4;
display:block;
width:100%;
height:auto;
opacity:0;
transform:translateY(95px) scale(0.90);
mix-blend-mode:screen;
filter:
brightness(1.18)
contrast(1.14)
saturate(0.96)
hue-rotate(20deg)
drop-shadow(0 0 8px rgba(170,235,255,0.42))
drop-shadow(0 0 18px rgba(95,200,255,0.34))
drop-shadow(0 0 42px rgba(0,130,255,0.28))
drop-shadow(0 0 78px rgba(0,70,255,0.18));
animation:
jujuReveal 2.9s cubic-bezier(.18,.78,.18,1) 0.12s forwards,
jujuFlicker 0.5s linear 0.55s 2,
jujuIdle 5.6s ease-in-out 3.2s infinite,
jujuGlowPulse 4s ease-in-out 3.2s infinite;
}

.juju-portal{
position:absolute;
left:50%;
bottom:14px;
transform:translateX(-50%);
width:76%;
height:30px;
border-radius:50%;
z-index:1;
opacity:0;
background:
radial-gradient(
ellipse at center,
rgba(110,230,255,0.98) 0%,
rgba(70,190,255,0.82) 26%,
rgba(0,110,255,0.38) 52%,
rgba(0,70,200,0.00) 76%
);
filter:blur(13px);
animation:
portalPulse 1.9s ease-out 0s forwards,
portalIdle 4.2s ease-in-out 2.4s infinite;
}

.juju-rings{
position:absolute;
left:50%;
bottom:2px;
width:86%;
height:330px;
transform:translateX(-50%);
z-index:2;
pointer-events:none;
}

.juju-rings span{
position:absolute;
left:50%;
bottom:0;
width:100%;
height:24px;
transform:translateX(-50%) scale(0.62);
border-radius:50%;
border:1px solid rgba(120,225,255,0.95);
box-shadow:
0 0 10px rgba(100,210,255,0.54),
inset 0 0 10px rgba(80,180,255,0.24),
0 0 22px rgba(0,110,255,0.20);
opacity:0;
}

.juju-rings span:nth-child(1){
animation:ringRiseTall 2.5s ease-out 0.10s forwards;
}

.juju-rings span:nth-child(2){
animation:ringRiseTall 2.5s ease-out 0.62s forwards;
}

.juju-rings span:nth-child(3){
animation:ringRiseTall 2.5s ease-out 1.14s forwards;
}

/* ENERGY HELIX */

.juju-helix{
position:absolute;
left:50%;
bottom:2%;
transform:translateX(-50%);
width:108%;
height:108%;
pointer-events:none;
}

.juju-helix-back{
z-index:3;
opacity:0.92;
}

.juju-helix-front{
z-index:5;
opacity:0.96;
}

.helix{
position:absolute;
left:50%;
transform:translateX(-50%);
border-radius:50%;
pointer-events:none;
mix-blend-mode:screen;
}

.helix::before{
content:"";
position:absolute;
inset:0;
border-radius:50%;
}

.helix-a{
bottom:-2%;
width:88%;
height:16%;
filter:blur(1.8px);
animation:
helixRiseBackA 3.4s cubic-bezier(.2,.72,.2,1) 0.22s forwards,
helixIdleBack 6s ease-in-out 3.7s infinite;
}

.helix-a::before{
border:2px solid rgba(170,255,170,0.92);
border-top-color:rgba(110,255,120,0.42);
border-left-color:rgba(110,255,120,0.24);
box-shadow:
0 0 16px rgba(170,255,170,0.62),
0 0 38px rgba(90,255,120,0.34),
0 0 70px rgba(0,210,90,0.18),
inset 0 0 10px rgba(210,255,220,0.10);
}

.helix-b{
bottom:13%;
width:76%;
height:14%;
filter:blur(1.8px);
animation:
helixRiseBackB 3.4s cubic-bezier(.2,.72,.2,1) 0.72s forwards,
helixIdleBack 6.2s ease-in-out 3.9s infinite reverse;
}

.helix-b::before{
border:2px solid rgba(160,255,175,0.82);
border-right-color:rgba(110,255,130,0.28);
border-bottom-color:rgba(110,255,130,0.18);
box-shadow:
0 0 14px rgba(160,255,175,0.50),
0 0 30px rgba(70,255,120,0.24),
0 0 54px rgba(0,200,90,0.12);
}

.helix-c{
bottom:3%;
width:82%;
height:15%;
filter:blur(1.4px);
animation:
helixRiseFrontA 3.2s cubic-bezier(.2,.72,.2,1) 0.48s forwards,
helixIdleFront 5.7s ease-in-out 3.8s infinite;
}

.helix-c::before{
border:2px solid rgba(190,255,190,0.98);
border-left-color:rgba(120,255,140,0.34);
border-bottom-color:rgba(120,255,140,0.22);
box-shadow:
0 0 18px rgba(190,255,190,0.70),
0 0 42px rgba(90,255,130,0.40),
0 0 74px rgba(0,210,100,0.18);
}

.helix-d{
bottom:24%;
width:68%;
height:13%;
filter:blur(1.4px);
animation:
helixRiseFrontB 3.15s cubic-bezier(.2,.72,.2,1) 1.05s forwards,
helixIdleFront 5.9s ease-in-out 4.1s infinite reverse;
}

.helix-d::before{
border:2px solid rgba(185,255,185,0.92);
border-top-color:rgba(120,255,145,0.28);
border-right-color:rgba(120,255,145,0.18);
box-shadow:
0 0 16px rgba(185,255,185,0.60),
0 0 34px rgba(85,255,125,0.30),
0 0 60px rgba(0,200,95,0.14);
}

.helix-d::before{
  border:2px solid rgba(185,255,185,0.92);
  border-top-color:rgba(120,255,145,0.28);
  border-right-color:rgba(120,255,145,0.18);
  box-shadow:
  0 0 16px rgba(185,255,185,0.60),
  0 0 34px rgba(85,255,125,0.30),
  0 0 60px rgba(0,200,95,0.14);
}

.site-shell{
  max-width:1400px;
  margin:0 auto;
}

@media (max-width:1100px){
  .hero-hologram-center{
    width:235px;
    left:70px;
    bottom:5%;
    transform:scale(0.6);
  }
}

.hero{
  position:relative;
}

/* DEPLOY PANELS */

.hero-system-panels{
position:absolute;
top:30%;
left:53%;
width:42%;
height:50%;
z-index:7;
display:grid;
grid-template-columns:1fr 1fr;
grid-template-rows:1fr 1fr;
column-gap:34px;
row-gap:28px;
pointer-events:none;
align-items:stretch;
justify-items:stretch;
}

.system-panel{
position:relative;
display:block;
width:100%;
height:100%;
min-width:0;
min-height:0;
opacity:0;
transform:
perspective(1100px)
rotateX(19deg)
translate3d(-90px,48px,0)
scale(0.82);
transform-origin:50% 100%;
filter:blur(6px);
pointer-events:none;
}

.system-panel.is-live{
animation:panelDeploy 0.92s cubic-bezier(.18,.84,.18,1) forwards;
}

.system-panel-inner{
position:relative;
height:100%;
padding:18px 22px 18px 22px;
border-radius:24px;
overflow:hidden;
background:
linear-gradient(
to bottom,
rgba(22,40,70,0.74) 0%,
rgba(11,24,46,0.72) 44%,
rgba(7,19,38,0.76) 100%
);
border:1px solid rgba(140,225,255,0.52);
backdrop-filter:blur(12px);
-webkit-backdrop-filter:blur(12px);
box-shadow:
0 0 18px rgba(120,215,255,0.22),
0 0 34px rgba(60,145,255,0.14),
inset 0 1px 0 rgba(255,255,255,0.10),
inset 0 -20px 50px rgba(0,0,0,0.10);
}

.system-panel-inner::before{
content:"";
position:absolute;
inset:0;
border-radius:24px;
pointer-events:none;
background:
linear-gradient(
to bottom,
rgba(255,255,255,0.10) 0%,
rgba(255,255,255,0.03) 18%,
rgba(255,255,255,0.00) 42%
);
}

.system-panel-inner::after{
content:"";
position:absolute;
left:16px;
right:16px;
bottom:10px;
height:10px;
border-radius:999px;
pointer-events:none;
background:
radial-gradient(
ellipse at center,
rgba(115,220,255,0.70) 0%,
rgba(55,150,255,0.28) 42%,
rgba(0,110,255,0.00) 78%
);
filter:blur(4px);
opacity:0.85;
}

.system-panel-topline{
position:relative;
z-index:2;
font-size:17px;
font-weight:900;
letter-spacing:0.08em;
text-transform:uppercase;
color:rgba(244,248,255,0.98);
text-shadow:0 0 12px rgba(140,225,255,0.18);
white-space:nowrap;
overflow:hidden;
text-overflow:ellipsis;
}

.system-panel-sub{
position:relative;
z-index:2;
margin-top:8px;
font-size:17px;
font-weight:500;
color:rgba(241,247,255,0.92);
line-height:1.25;
}

.system-panel-visual{
position:absolute;
left:18px;
right:18px;
bottom:18px;
height:46%;
border-radius:18px;
overflow:hidden;
pointer-events:none;
}

.visual-trace{
background:
radial-gradient(circle at 50% 85%, rgba(80,170,255,0.25), rgba(0,0,0,0) 60%),
repeating-linear-gradient(
to right,
rgba(110,200,255,0.10) 0px,
rgba(110,200,255,0.10) 1px,
rgba(0,0,0,0) 1px,
rgba(0,0,0,0) 16px
),
repeating-linear-gradient(
to bottom,
rgba(110,200,255,0.07) 0px,
rgba(110,200,255,0.07) 1px,
rgba(0,0,0,0) 1px,
rgba(0,0,0,0) 12px
);
}

.visual-trace::before{
content:"";
position:absolute;
left:12%;
right:12%;
top:52%;
height:2px;
border-radius:999px;
background:linear-gradient(
90deg,
rgba(0,0,0,0),
rgba(90,255,130,0.75),
rgba(190,255,110,0.95),
rgba(0,0,0,0)
);
transform:rotate(-13deg);
filter:blur(0.3px);
box-shadow:0 0 14px rgba(135,255,150,0.55);
}

.visual-wave{
background:
radial-gradient(circle at 50% 90%, rgba(80,170,255,0.18), rgba(0,0,0,0) 60%),
repeating-linear-gradient(
to bottom,
rgba(120,200,255,0.08) 0px,
rgba(120,200,255,0.08) 1px,
rgba(0,0,0,0) 1px,
rgba(0,0,0,0) 10px
);
}

.visual-wave::before{
content:"";
position:absolute;
left:8%;
right:8%;
top:48%;
height:2px;
border-radius:999px;
background:linear-gradient(
90deg,
rgba(0,0,0,0),
rgba(120,220,255,0.4),
rgba(120,255,170,0.9),
rgba(0,0,0,0)
);
box-shadow:0 0 12px rgba(120,255,170,0.45);
transform:rotate(-8deg);
}

.visual-grid{
background:
radial-gradient(circle at 50% 90%, rgba(80,170,255,0.18), rgba(0,0,0,0) 60%),
repeating-linear-gradient(
to right,
rgba(110,200,255,0.08) 0px,
rgba(110,200,255,0.08) 1px,
rgba(0,0,0,0) 1px,
rgba(0,0,0,0) 16px
),
repeating-linear-gradient(
to bottom,
rgba(110,200,255,0.06) 0px,
rgba(110,200,255,0.06) 1px,
rgba(0,0,0,0) 1px,
rgba(0,0,0,0) 12px
);
}

.visual-grid::before{
content:"";
position:absolute;
left:18%;
right:18%;
top:46%;
height:2px;
border-radius:999px;
background:linear-gradient(
90deg,
rgba(0,0,0,0),
rgba(90,210,255,0.42),
rgba(255,255,255,0.95),
rgba(0,0,0,0)
);
box-shadow:0 0 12px rgba(120,220,255,0.38);
}

.system-panel-cta{
text-decoration:none;
pointer-events:auto;
}

.system-panel-cta .system-panel-inner{
border-color:rgba(160,240,255,0.72);
box-shadow:
0 0 22px rgba(135,225,255,0.30),
0 0 40px rgba(70,155,255,0.16),
0 0 62px rgba(0,120,255,0.09),
inset 0 1px 0 rgba(255,255,255,0.14),
inset 0 -22px 56px rgba(0,0,0,0.10);
}

.system-panel-cta .system-panel-topline{
font-size:14px;
letter-spacing:0.16em;
color:rgba(220,239,255,0.86);
}

.system-panel-cta-text{
position:relative;
z-index:2;
margin-top:18px;
font-size:28px;
font-weight:950;
letter-spacing:0.04em;
color:rgba(248,252,255,0.98);
text-shadow:
0 0 18px rgba(150,235,255,0.28),
0 0 32px rgba(85,170,255,0.18);
}

.visual-cta{
background:
radial-gradient(circle at 50% 88%, rgba(85,180,255,0.16), rgba(0,0,0,0) 62%),
linear-gradient(
90deg,
rgba(0,0,0,0),
rgba(120,220,255,0.12),
rgba(0,0,0,0)
);
}

.system-panel-cta .visual-cta::before{
content:"";
position:absolute;
left:22%;
right:22%;
bottom:18%;
height:2px;
border-radius:999px;
background:linear-gradient(
90deg,
rgba(0,0,0,0),
rgba(155,245,255,0.75),
rgba(0,0,0,0)
);
box-shadow:0 0 14px rgba(120,235,255,0.40);
}

.system-panel-cta:hover .system-panel-inner{
box-shadow:
0 0 24px rgba(145,235,255,0.38),
0 0 52px rgba(70,160,255,0.22),
0 0 76px rgba(0,120,255,0.12),
inset 0 1px 0 rgba(255,255,255,0.18),
inset 0 -22px 56px rgba(0,0,0,0.08);
}

.panel-1{ align-self:start; justify-self:start; }
.panel-2{ align-self:start; justify-self:start; }
.panel-3{ align-self:start; justify-self:start; }
.panel-4{ align-self:start; justify-self:start; }

/* PARTICLES */

.hero-particles{
position:absolute;
left:50%;
bottom:2%;
transform:translateX(-50%);
width:300px;
height:460px;
z-index:3;
pointer-events:none;
filter:blur(0.2px);
}

.hero-particles span{
position:absolute;
bottom:0;
width:8px;
height:8px;
border-radius:50%;
background:radial-gradient(circle, rgba(220,250,255,1) 0%, rgba(130,220,255,0.85) 42%, rgba(0,140,255,0) 78%);
box-shadow:
0 0 14px rgba(180,245,255,0.82),
0 0 34px rgba(80,180,255,0.52);
opacity:0;
}

.hero-particles span:nth-child(1){ left:8%;  animation:particleForm1 3s cubic-bezier(.2,.75,.2,1) 0.00s forwards; }
.hero-particles span:nth-child(2){ left:18%; animation:particleForm2 3.1s cubic-bezier(.2,.75,.2,1) 0.10s forwards; }
.hero-particles span:nth-child(3){ left:28%; animation:particleForm3 2.9s cubic-bezier(.2,.75,.2,1) 0.20s forwards; }
.hero-particles span:nth-child(4){ left:40%; animation:particleForm4 3.15s cubic-bezier(.2,.75,.2,1) 0.05s forwards; }
.hero-particles span:nth-child(5){ left:52%; animation:particleForm2 3s cubic-bezier(.2,.75,.2,1) 0.22s forwards; }
.hero-particles span:nth-child(6){ left:64%; animation:particleForm4 3.2s cubic-bezier(.2,.75,.2,1) 0.14s forwards; }
.hero-particles span:nth-child(7){ left:76%; animation:particleForm1 2.95s cubic-bezier(.2,.75,.2,1) 0.28s forwards; }
.hero-particles span:nth-child(8){ left:86%; animation:particleForm3 3.1s cubic-bezier(.2,.75,.2,1) 0.16s forwards; }

.juju-holo-scan{
position:absolute;
left:50%;
bottom:0;
transform:translateX(-50%);
width:96%;
height:100%;
z-index:5;
opacity:0;
background:
linear-gradient(
to bottom,
rgba(255,255,255,0) 0%,
rgba(120,220,255,0.05) 30%,
rgba(170,240,255,0.64) 50%,
rgba(120,220,255,0.10) 68%,
rgba(255,255,255,0) 100%
);
filter:blur(10px);
animation:scanPass 2s ease-out 0.55s forwards;
}

/* silhouette assembly shimmer */
.hero-hologram-center::before{
content:"";
position:absolute;
left:50%;
bottom:0;
transform:translateX(-50%);
width:96%;
height:100%;
z-index:6;
pointer-events:none;
opacity:0;
mix-blend-mode:screen;
background:
linear-gradient(
to bottom,
rgba(255,255,255,0) 0%,
rgba(180,240,255,0.16) 18%,
rgba(255,255,255,0.40) 32%,
rgba(120,220,255,0.14) 48%,
rgba(255,255,255,0.30) 62%,
rgba(120,220,255,0.10) 78%,
rgba(255,255,255,0) 100%
),
repeating-linear-gradient(
to bottom,
rgba(190,240,255,0.20) 0px,
rgba(190,240,255,0.20) 2px,
rgba(255,255,255,0) 3px,
rgba(255,255,255,0) 10px
);
filter:blur(2px);
-webkit-mask-image:
linear-gradient(to top, rgba(0,0,0,1), rgba(0,0,0,0.15)),
radial-gradient(circle at 50% 55%, rgba(0,0,0,0.95) 0%, rgba(0,0,0,0.90) 28%, rgba(0,0,0,0.55) 44%, rgba(0,0,0,0.08) 62%, transparent 74%);
-webkit-mask-composite: source-in;
mask-image:
linear-gradient(to top, rgba(0,0,0,1), rgba(0,0,0,0.15)),
radial-gradient(circle at 50% 55%, rgba(0,0,0,0.95) 0%, rgba(0,0,0,0.90) 28%, rgba(0,0,0,0.55) 44%, rgba(0,0,0,0.08) 62%, transparent 74%);
animation:
silhouetteBuild 2.6s ease-out 0.35s forwards,
silhouetteSweep 1.8s ease-out 0.7s 1;
}

.hero-hologram-center::after{
content:"";
position:absolute;
inset:0;
z-index:4;
opacity:0.23;
pointer-events:none;
background:
repeating-linear-gradient(
to bottom,
rgba(170,230,255,0.12) 0px,
rgba(170,230,255,0.12) 2px,
rgba(255,255,255,0) 3px,
rgba(255,255,255,0) 7px
);
-webkit-mask-image:linear-gradient(to top, rgba(0,0,0,1), rgba(0,0,0,0.15));
mask-image:linear-gradient(to top, rgba(0,0,0,1), rgba(0,0,0,0.15));
}

/* ANIMATIONS */

@keyframes jujuReveal{
0%{
opacity:0;
transform:translateY(95px) scale(0.90);
clip-path:inset(100% 0 0 0);
filter:
brightness(1.55)
contrast(1.1)
saturate(0.7)
hue-rotate(22deg)
drop-shadow(0 0 18px rgba(170,240,255,0.72))
drop-shadow(0 0 44px rgba(80,180,255,0.48));
}
18%{
opacity:0.18;
transform:translateY(72px) scale(0.93);
clip-path:inset(82% 0 0 0);
}
40%{
opacity:0.48;
transform:translateY(42px) scale(0.97);
clip-path:inset(56% 0 0 0);
}
68%{
opacity:0.82;
transform:translateY(16px) scale(1);
clip-path:inset(20% 0 0 0);
}
100%{
opacity:1;
transform:translateY(0) scale(1);
clip-path:inset(0 0 0 0);
filter:
brightness(1.18)
contrast(1.14)
saturate(0.96)
hue-rotate(20deg)
drop-shadow(0 0 8px rgba(170,235,255,0.42))
drop-shadow(0 0 18px rgba(95,200,255,0.34))
drop-shadow(0 0 42px rgba(0,130,255,0.28))
drop-shadow(0 0 78px rgba(0,70,255,0.18));
}
}

@keyframes jujuFlicker{
0%{opacity:0.72;}
18%{opacity:0.36;}
36%{opacity:0.86;}
58%{opacity:0.52;}
100%{opacity:1;}
}

@keyframes jujuIdle{
0%,100%{
transform:translateY(0) scale(1);
}
50%{
transform:translateY(-9px) scale(1.004);
}
}

@keyframes jujuGlowPulse{
0%,100%{
filter:
brightness(1.18)
contrast(1.14)
saturate(0.96)
hue-rotate(20deg)
drop-shadow(0 0 8px rgba(170,235,255,0.42))
drop-shadow(0 0 18px rgba(95,200,255,0.34))
drop-shadow(0 0 42px rgba(0,130,255,0.28))
drop-shadow(0 0 78px rgba(0,70,255,0.18));
}
50%{
filter:
brightness(1.23)
contrast(1.16)
saturate(1)
hue-rotate(22deg)
drop-shadow(0 0 9px rgba(180,240,255,0.48))
drop-shadow(0 0 22px rgba(100,210,255,0.38))
drop-shadow(0 0 52px rgba(0,135,255,0.34))
drop-shadow(0 0 96px rgba(0,76,255,0.22));
}
}

@keyframes portalPulse{
0%{
opacity:0;
transform:translateX(-50%) scale(0.28);
}
55%{
opacity:1;
transform:translateX(-50%) scale(1.14);
}
100%{
opacity:0.94;
transform:translateX(-50%) scale(1);
}
}

@keyframes portalIdle{
0%,100%{
opacity:0.76;
}
50%{
opacity:1;
}
}

@keyframes ringRiseTall{
0%{
opacity:0;
transform:translateX(-50%) translateY(0) scale(0.55);
}
10%{
opacity:0.96;
}
70%{
opacity:0.78;
}
100%{
opacity:0;
transform:translateX(-50%) translateY(-285px) scale(1.18);
}
}

@keyframes helixRiseBackA{
0%{
opacity:0;
transform:translateX(-50%) translateY(38px) rotate(-8deg) scale(0.72);
}
20%{
opacity:0.88;
}
100%{
opacity:1;
transform:translateX(-50%) translateY(-198px) rotate(7deg) scale(1.01);
}
}

@keyframes helixRiseBackB{
0%{
opacity:0;
transform:translateX(-50%) translateY(28px) rotate(10deg) scale(0.7);
}
24%{
opacity:0.74;
}
100%{
opacity:0.82;
transform:translateX(-50%) translateY(-162px) rotate(-8deg) scale(0.96);
}
}

@keyframes helixRiseFrontA{
0%{
opacity:0;
transform:translateX(-50%) translateY(18px) rotate(-6deg) scale(0.82);
}
20%{
opacity:0.92;
}
100%{
opacity:1;
transform:translateX(-50%) translateY(-98px) rotate(8deg) scale(0.98);
}
}

@keyframes helixRiseFrontB{
0%{
opacity:0;
transform:translateX(-50%) translateY(22px) rotate(8deg) scale(0.76);
}
20%{
opacity:0.86;
}
100%{
opacity:0.92;
transform:translateX(-50%) translateY(-172px) rotate(-6deg) scale(0.94);
}
}

@keyframes helixIdleBack{
0%,100%{
transform:translateX(-50%) translateY(-198px) rotate(7deg) scale(1.01);
opacity:0.72;
}
50%{
transform:translateX(-50%) translateY(-191px) rotate(2deg) scale(1.03);
opacity:0.9;
}
}

@keyframes helixIdleFront{
0%,100%{
opacity:0.74;
}
50%{
opacity:0.96;
}
}

@keyframes panelDeploy{
0%{
opacity:0;
transform:
perspective(1100px)
rotateX(24deg)
translate3d(-90px,48px,0)
scale(0.82);
filter:blur(6px);
}
54%{
opacity:1;
transform:
perspective(1100px)
rotateX(15deg)
translate3d(10px,-5px,0)
scale(1.015);
filter:blur(0px);
}
73%{
transform:
perspective(1100px)
rotateX(21deg)
translate3d(-8px,3px,0)
scale(0.995);
}
100%{
opacity:1;
transform:
perspective(1100px)
rotateX(19deg)
translate3d(0,0,0)
scale(1);
filter:blur(0px);
}
}

@keyframes scanPass{
0%{
opacity:0;
transform:translateX(-50%) translateY(150px);
}
18%{
opacity:0.98;
}
100%{
opacity:0;
transform:translateX(-50%) translateY(-320px);
}
}

@keyframes silhouetteBuild{
0%{
opacity:0;
clip-path:inset(100% 0 0 0);
}
22%{
opacity:0.18;
clip-path:inset(72% 0 0 0);
}
52%{
opacity:0.42;
clip-path:inset(38% 0 0 0);
}
82%{
opacity:0.26;
clip-path:inset(10% 0 0 0);
}
100%{
opacity:0;
clip-path:inset(0 0 0 0);
}
}

@keyframes silhouetteSweep{
0%{
transform:translateX(-50%) translateY(120px);
filter:blur(3px);
}
100%{
transform:translateX(-50%) translateY(-180px);
filter:blur(1px);
}
}

@keyframes particleForm1{
0%{
opacity:0;
transform:translateY(0) translateX(0) scale(0.35);
}
12%{
opacity:1;
}
72%{
opacity:0.95;
transform:translateY(-250px) translateX(42px) scale(1.25);
}
100%{
opacity:0;
transform:translateY(-290px) translateX(62px) scale(0.25);
}
}

@keyframes particleForm2{
0%{
opacity:0;
transform:translateY(0) translateX(0) scale(0.3);
}
12%{
opacity:0.95;
}
74%{
opacity:0.92;
transform:translateY(-320px) translateX(18px) scale(1.15);
}
100%{
opacity:0;
transform:translateY(-360px) translateX(4px) scale(0.22);
}
}

@keyframes particleForm3{
0%{
opacity:0;
transform:translateY(0) translateX(0) scale(0.35);
}
12%{
opacity:1;
}
70%{
opacity:0.9;
transform:translateY(-210px) translateX(-34px) scale(1.3);
}
100%{
opacity:0;
transform:translateY(-255px) translateX(-56px) scale(0.2);
}
}

@keyframes particleForm4{
0%{
opacity:0;
transform:translateY(0) translateX(0) scale(0.32);
}
10%{
opacity:1;
}
76%{
opacity:0.95;
transform:translateY(-365px) translateX(-12px) scale(1.18);
}
100%{
opacity:0;
transform:translateY(-405px) translateX(-26px) scale(0.2);
}
}

.hero-fade{
position:absolute;
left:0;
right:0;
bottom:0;
height:200px;
background:linear-gradient(
to bottom,
rgba(255,255,255,0) 0%,
rgba(255,255,255,0.65) 55%,
rgba(255,255,255,0.92) 100%
);
}

.topbar{
  position:sticky;
  top:14px;
  z-index:1000;

  padding:14px 22px;
  margin:14px auto 8px; /* ↓ this controls spacing above hero */

  width:min(1200px, calc(100% - 40px)); /* MATCH HERO */

  border-radius:26px;
  background:#0b1120;
  border:1.5px solid #d4af37;

  box-shadow:
    0 18px 50px rgba(0,0,0,.35),
    inset 0 1px 0 rgba(255,255,255,.05);

  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);

  box-sizing:border-box;
}

.topbar-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}

.brand{
  display:flex;
  align-items:center;
  flex:0 0 auto;
}

.brand-mark{
  display:block;
  height:88px;
  width:auto;

  object-fit:contain;

  filter:drop-shadow(0 0 6px rgba(212,175,55,.25));
}

.nav{
  display:flex;
  align-items:center;
  justify-content:flex-end;

  gap:10px; /* tighter for pill look */

  position:relative;
  overflow:visible;

  flex:0 0 auto; /* 🔥 important fix */
}

.nav-link,
.nav-dropdown-toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;

  min-height:40px;
  padding:0 16px;

  border-radius:999px;

  color:#eef4ff;
  text-decoration:none;
  font-size:12px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;

  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);

  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.05),
    0 6px 14px rgba(0,0,0,.18);

  transition:
    all .18s ease;
}

.nav-link:hover,
.nav-dropdown-toggle:hover{
  color:#f4ddb0;

  background:rgba(255,255,255,.08);
  border-color:rgba(212,175,55,.35);

  transform:translateY(-1px);

  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 10px 22px rgba(0,0,0,.22);
}

.nav-dropdown-toggle::after{
  content:"▾";
  margin-left:6px;
  font-size:10px;
  opacity:.6;
  transform:translateY(-1px);
}

.nav-dropdown-menu{
  position:absolute;
  top:calc(100% - 2px);
  left:50%;
  transform:translateX(-50%);
  min-width:230px;
  padding:10px;
  border-radius:16px;
  background:rgba(12,17,30,.97);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 18px 40px rgba(0,0,0,.28);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .18s ease, visibility .18s ease, transform .18s ease;
  z-index:999;
}

.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu,
.nav-dropdown-menu:hover{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateX(-50%) translateY(4px);
}

.nav-dropdown-item{
  display:block;
  padding:11px 13px;
  border-radius:12px;
  color:#eef4ff;
  text-decoration:none;
  font-size:12px;
  font-weight:800;
  letter-spacing:.1em;
  text-transform:uppercase;
  transition:background .18s ease, color .18s ease;
}

.nav-dropdown-item:hover{
  background:rgba(255,255,255,.06);
  color:#f4ddb0;
}

.nav-dropdown::after{
  content:"";
  position:absolute;
  top:100%;
  left:0;
  width:100%;
  height:16px;
}

@media (max-width: 980px){
  .topbar{
    padding:10px 14px;
    margin:14px auto 0;
    width:calc(100% - 20px);
    border-radius:14px;

    /* KEEP BORDER CONSISTENT */
    border:1.5px solid #d4af37;
  }

  .topbar-inner{
    gap:14px;
  }
}

  .brand-mark{
    height:94px;
  }

/* HEADLINE BOX */

.steps-headline{
position:relative;
z-index:6;
margin-top:-40px;
padding:0 28px 14px 28px;
display:flex;
justify-content:center;
}

.steps-headline-box{
width:min(900px, 100%);
padding:16px 22px;
border-radius:18px;
background:rgba(255,255,255,0.86);
border:1px solid rgba(15,25,40,0.10);
backdrop-filter:blur(10px);
box-shadow:
0 18px 55px rgba(0,0,0,0.12),
inset 0 1px 0 rgba(255,255,255,0.55);
text-align:center;
}

.steps-h2{
margin:0;
font-size:28px;
font-weight:950;
letter-spacing:0.02em;
color:#0b1220;
}

/* STEPS */

.steps{
position:relative;
z-index:4;
margin-top:-20px;
padding:0 28px 26px 28px;
display:grid;
grid-template-columns:repeat(3, minmax(0,1fr));
gap:22px;
align-items:stretch;
}

.step-card{
border-radius:34px;
overflow:hidden;
background:rgba(235,239,244,0.92);
border:1px solid rgba(12,18,30,0.06);
box-shadow:
0 22px 60px rgba(0,0,0,0.16),
inset 0 1px 0 rgba(255,255,255,0.40);
display:flex;
flex-direction:column;
transition:transform .20s ease, box-shadow .20s ease;
}

.step-card:hover{
transform:translateY(-8px);
box-shadow:
0 30px 75px rgba(0,0,0,0.22),
inset 0 1px 0 rgba(255,255,255,0.45);
}

.step-video-card{
cursor:pointer;
}

.step-head{
display:flex;
align-items:center;
gap:16px;
padding:14px 20px 12px 20px;
height:70px;
}

.step-num{
font-weight:900;
font-size:45px;
line-height:1;
color:rgba(86,133,173,0.78);
}

.step-title{
font-size:21px;
font-weight:900;
white-space:nowrap;
overflow:hidden;
text-overflow:ellipsis;
}

.step-media{
height:152px;
overflow:hidden;
border-top:1px solid rgba(0,0,0,0.05);
position:relative;
background:#0d1118;
}

.step-media img{
width:100%;
height:100%;
object-fit:cover;
transition:transform .35s ease, opacity .22s ease;
}

.step-preview-video{
position:absolute;
inset:0;
width:100%;
height:100%;
object-fit:cover;
opacity:0;
transition:opacity .22s ease, transform .35s ease;
transform:scale(1.02);
pointer-events:none;
}

.step-card:hover .step-media img,
.step-card.is-previewing .step-media img{
opacity:0;
}

.step-card:hover .step-preview-video,
.step-card.is-previewing .step-preview-video{
opacity:1;
transform:scale(1.06);
}

.step-media::after{
content:"";
position:absolute;
inset:0;
background:linear-gradient(
to top,
rgba(0,0,0,0.55),
rgba(0,0,0,0.08)
);
opacity:0;
transition:opacity .25s ease;
pointer-events:none;
}

.step-play{
position:absolute;
top:50%;
left:50%;
transform:translate(-50%,-50%);
width:74px;
height:74px;
border-radius:999px;
background:rgba(0,0,0,0.40);
border:1px solid rgba(230,202,118,0.65);
backdrop-filter:blur(8px);
opacity:0;
transition:opacity .25s ease, transform .25s ease;
pointer-events:none;
}

.step-play::before{
content:"";
position:absolute;
left:30px;
top:21px;
border-left:20px solid rgba(255,255,255,0.95);
border-top:14px solid transparent;
border-bottom:14px solid transparent;
}

.step-preview-badge{
position:absolute;
left:12px;
bottom:12px;
padding:7px 11px;
border-radius:999px;
font-size:11px;
letter-spacing:0.16em;
text-transform:uppercase;
font-weight:900;
color:rgba(255,255,255,0.96);
background:rgba(0,0,0,0.42);
border:1px solid rgba(230,202,118,0.55);
backdrop-filter:blur(8px);
opacity:0;
transform:translateY(4px);
transition:opacity .22s ease, transform .22s ease;
pointer-events:none;
}

.step-card:hover .step-media::after,
.step-card.is-previewing .step-media::after{
opacity:1;
}

.step-card:hover .step-play,
.step-card.is-previewing .step-play{
opacity:1;
transform:translate(-50%,-50%) scale(1.03);
}

.step-card:hover .step-preview-badge,
.step-card.is-previewing .step-preview-badge{
opacity:1;
transform:translateY(0);
}

/* FEATURES */

.features{
padding:6px 28px 28px 28px;
display:grid;
grid-template-columns:repeat(2,1fr);
gap:22px;
}

.feature-card{
border-radius:34px;
overflow:hidden;
background:rgba(235,239,244,0.92);
border:1px solid rgba(12,18,30,0.06);
box-shadow:
0 22px 60px rgba(0,0,0,0.16),
inset 0 1px 0 rgba(255,255,255,0.40);
transition:transform .22s ease, box-shadow .22s ease;
}

.feature-card:hover{
transform:translateY(-8px);
box-shadow:
0 30px 80px rgba(0,0,0,0.22),
inset 0 1px 0 rgba(255,255,255,0.45);
}

.feature-head{
display:flex;
align-items:baseline;
gap:16px;
padding:18px 20px 12px 20px;
}

.feature-num{
font-weight:900;
font-size:56px;
color:rgba(86,133,173,0.78);
}

.feature-title{
font-size:22px;
font-weight:900;
}

/* VIDEO PREVIEW */

.video-preview{
margin:10px auto 14px auto;
width:min(340px,62%);
aspect-ratio:9/16;
border-radius:28px;
overflow:hidden;
background:#0d1118;
display:grid;
place-items:center;
position:relative;
cursor:pointer;
}

.video-preview img{
width:100%;
height:100%;
object-fit:cover;
transform:scale(1.01);
filter:contrast(1.02) brightness(0.98);
}

@keyframes playPulse{
0%{ box-shadow:0 0 0 rgba(230,202,118,0.00); }
50%{ box-shadow:0 0 26px rgba(230,202,118,0.28); }
100%{ box-shadow:0 0 0 rgba(230,202,118,0.00); }
}

.play{
width:82px;
height:82px;
border-radius:999px;
background:rgba(0,0,0,0.45);
border:1px solid rgba(230,202,118,0.70);
position:absolute;
top:50%;
left:50%;
transform:translate(-50%,-50%);
backdrop-filter:blur(8px);
animation:playPulse 2.2s ease-in-out infinite;
}

.play:before{
content:"";
position:absolute;
left:34px;
top:24px;
border-left:22px solid white;
border-top:16px solid transparent;
border-bottom:16px solid transparent;
}

/* VIDEO MODAL */

.video-modal{
position:fixed;
inset:0;
background:rgba(0,0,0,0.78);
display:none;
align-items:center;
justify-content:center;
z-index:9999;
}

.video-modal.open{
display:flex;
}

.video-modal-inner{
width:min(1100px,92vw);
max-height:92vh;
background:#000;
border-radius:18px;
overflow:hidden;
position:relative;
display:flex;
align-items:center;
justify-content:center;
box-shadow:0 30px 110px rgba(0,0,0,0.55);
}

.video-modal-inner iframe,
.video-modal-inner video{
width:100%;
height:auto;
max-height:92vh;
border:0;
display:block;
background:#000;
}

#localVideoPlayer{
display:none;
}

.video-close{
position:absolute;
top:12px;
right:12px;
width:36px;
height:36px;
border-radius:999px;
border:1px solid rgba(255,255,255,0.20);
background:rgba(0,0,0,0.55);
color:rgba(255,255,255,0.92);
font-size:20px;
line-height:1;
cursor:pointer;
z-index:3;
}

/* SECTION 05 COMPARISON SLIDERS */

.compare-stack{
padding:10px 18px 18px 18px;
display:grid;
gap:16px;
}

.compare-divider{
height:2px;
margin:0 22px;
background:linear-gradient(
90deg,
rgba(230,202,118,0),
rgba(230,202,118,0.65),
rgba(230,202,118,0)
);
}

.compare-block{
display:grid;
gap:10px;
}

.compare-labels{
display:flex;
justify-content:space-between;
align-items:center;
padding:0 4px;
}

.compare-tag{
font-size:12px;
letter-spacing:0.16em;
text-transform:uppercase;
font-weight:900;
color:rgba(10,16,26,0.55);
}

.compare{
position:relative;
border-radius:26px;
background:#fff;
overflow:hidden;
box-shadow:
0 12px 32px rgba(0,0,0,0.12),
0 2px 8px rgba(0,0,0,0.08);
height:460px;
cursor:ew-resize;
user-select:none;
touch-action:none;
transition:transform .25s ease, box-shadow .25s ease;
}

.compare::before{
content:"";
position:absolute;
inset:0;
border-radius:26px;
pointer-events:none;
z-index:2;
background:linear-gradient(
120deg,
rgba(230,202,118,0) 0%,
rgba(230,202,118,0.22) 45%,
rgba(230,202,118,0) 100%
);
opacity:0;
transition:opacity .35s ease;
}

.compare:hover::before{
opacity:.65;
}

.compare:hover{
transform:translateY(-8px) scale(1.015);
box-shadow:
0 30px 70px rgba(0,0,0,0.22),
0 10px 26px rgba(0,0,0,0.12),
0 0 18px rgba(230,202,118,0.25);
}

.compare.dragging{
cursor:grabbing;
}

.compare-after,
.compare-before{
position:absolute;
inset:0;
width:100%;
height:100%;
object-fit:cover;
}

.compare-before-wrap{
position:absolute;
inset:0;
width:50%;
overflow:hidden;
z-index:1;
}

.compare-handle{
position:absolute;
top:0;
bottom:0;
left:50%;
transform:translateX(-50%);
width:0;
pointer-events:none;
z-index:3;
}

.compare-line{
position:absolute;
top:0;
bottom:0;
left:50%;
transform:translateX(-50%);
width:2px;
background:rgba(255,255,255,0.85);
box-shadow:0 0 0 1px rgba(0,0,0,0.08);
}

.compare-knob{
position:absolute;
top:50%;
left:50%;
transform:translate(-50%,-50%);
width:56px;
height:56px;
border-radius:999px;
background:rgba(0,0,0,0.42);
border:1px solid rgba(230,202,118,0.70);
backdrop-filter:blur(10px);
box-shadow:
0 16px 36px rgba(0,0,0,0.25),
inset 0 1px 0 rgba(255,255,255,0.18);
}

.compare-knob::before,
.compare-knob::after{
content:"";
position:absolute;
top:50%;
width:0;
height:0;
border-top:8px solid transparent;
border-bottom:8px solid transparent;
opacity:.95;
}

.compare-knob::before{
left:16px;
transform:translateY(-50%);
border-right:10px solid rgba(255,255,255,0.95);
}

.compare-knob::after{
right:16px;
transform:translateY(-50%);
border-left:10px solid rgba(255,255,255,0.95);
}

/* BACKSWING SLIDER (show full club) */

.compare.compare-contain{
background:#0d1118;
}

.compare.compare-contain .compare-after,
.compare.compare-contain .compare-before{
object-fit:contain;
object-position:center;
}

/* FEATURE FOOTER */

.feature-foot{
padding:0 20px 18px 20px;
display:flex;
justify-content:center;
}

.feature-note{
font-size:13px;
letter-spacing:0.10em;
text-transform:uppercase;
font-weight:800;
color:rgba(10,16,26,0.55);
}

.shell-bottom-space{
height:34px;
}

/* TESTIMONIAL DECK */

.testimonials-deck-section{
position:relative;
padding:18px 28px 10px 28px;
z-index:4;
}

.testimonials-deck-head{
text-align:center;
max-width:860px;
margin:0 auto 30px auto;
}

.testimonials-kicker{
font-size:12px;
font-weight:900;
letter-spacing:0.22em;
text-transform:uppercase;
color:rgba(164,124,44,0.95);
margin-bottom:10px;
}

.testimonials-title{
margin:0;
font-size:40px;
line-height:1.02;
font-weight:950;
letter-spacing:0.01em;
color:#0b1220;
}

.testimonials-intro{
margin:12px auto 0 auto;
max-width:700px;
font-size:18px;
line-height:1.5;
color:rgba(11,18,32,0.66);
}

.testimonial-deck{
position:relative;
width:min(1180px,100%);
height:720px;
margin:0 auto;
perspective:2600px;
perspective-origin:50% 50%;
transform-style:preserve-3d;
isolation:isolate;
}

.deck-card{
position:absolute;
top:42px;
width:330px;
height:560px;
cursor:pointer;
outline:none;
transform-style:preserve-3d;
transition:
left .42s cubic-bezier(.2,.82,.2,1),
transform .42s cubic-bezier(.2,.82,.2,1),
filter .28s ease,
opacity .28s ease;
will-change:left,transform;
}

/* 8-card resting positions */
.deck-card[data-card="1"]{
left:6%;
transform:translateY(0) translateZ(0) rotateZ(-1deg) rotateY(74deg) scale(.975);
z-index:8;
}

.deck-card[data-card="2"]{
left:13%;
transform:translateY(4px) translateZ(-8px) rotateZ(-.8deg) rotateY(78deg) scale(.968);
z-index:7;
}

.deck-card[data-card="3"]{
left:21%;
transform:translateY(8px) translateZ(-14px) rotateZ(-.5deg) rotateY(82deg) scale(.962);
z-index:6;
}

.deck-card[data-card="4"]{
left:30%;
transform:translateY(10px) translateZ(-18px) rotateZ(-.2deg) rotateY(86deg) scale(.956);
z-index:5;
}

.deck-card[data-card="5"]{
left:40%;
transform:translateY(10px) translateZ(-18px) rotateZ(.2deg) rotateY(-86deg) scale(.956);
z-index:4;
}

.deck-card[data-card="6"]{
left:49%;
transform:translateY(8px) translateZ(-14px) rotateZ(.5deg) rotateY(-82deg) scale(.962);
z-index:3;
}

.deck-card[data-card="7"]{
left:57%;
transform:translateY(4px) translateZ(-8px) rotateZ(.8deg) rotateY(-78deg) scale(.968);
z-index:2;
}

.deck-card[data-card="8"]{
left:64%;
transform:translateY(0) translateZ(0) rotateZ(1deg) rotateY(-74deg) scale(.975);
z-index:1;
}

.deck-card-shell{
position:relative;
height:100%;
border-radius:32px;
overflow:hidden;
padding:26px 24px 22px 24px;
background:
linear-gradient(
180deg,
rgba(20,34,56,0.97) 0%,
rgba(12,24,44,0.94) 46%,
rgba(8,18,34,0.985) 100%
);
border:1px solid rgba(212,171,78,0.46);
backdrop-filter:blur(16px);
-webkit-backdrop-filter:blur(16px);
box-shadow:
0 24px 70px rgba(0,0,0,0.22),
0 10px 26px rgba(0,0,0,0.12),
0 0 0 1px rgba(255,255,255,0.03) inset,
inset 0 1px 0 rgba(255,255,255,0.12),
inset 0 -18px 40px rgba(0,0,0,0.18);
transition:
box-shadow .30s ease,
border-color .30s ease,
transform .30s ease,
opacity .30s ease;
}

.deck-card-edge{
position:absolute;
top:16px;
bottom:16px;
right:10px;
width:8px;
border-radius:999px;
background:
linear-gradient(
180deg,
rgba(255,232,176,0.70) 0%,
rgba(212,171,78,0.95) 35%,
rgba(124,89,22,0.90) 100%
);
box-shadow:
0 0 14px rgba(212,171,78,0.22),
inset 0 1px 0 rgba(255,255,255,0.30);
opacity:.88;
transition:opacity .28s ease, box-shadow .28s ease;
pointer-events:none;
}

.deck-card-shell::before{
content:"";
position:absolute;
inset:0;
border-radius:32px;
pointer-events:none;
background:
linear-gradient(
180deg,
rgba(255,255,255,0.15) 0%,
rgba(255,255,255,0.05) 16%,
rgba(255,255,255,0.00) 42%
);
}

.deck-card-shell::after{
content:"";
position:absolute;
left:16px;
right:16px;
bottom:10px;
height:14px;
border-radius:999px;
pointer-events:none;
background:
radial-gradient(
ellipse at center,
rgba(212,171,78,0.34) 0%,
rgba(212,171,78,0.14) 40%,
rgba(0,0,0,0) 76%
);
filter:blur(6px);
opacity:.95;
}

.deck-card-topline{
position:relative;
z-index:2;
font-size:12px;
font-weight:900;
letter-spacing:0.18em;
text-transform:uppercase;
color:rgba(228,204,147,0.90);
}

.deck-card-title{
position:relative;
z-index:2;
margin:18px 0 16px 0;
font-size:29px;
line-height:1.04;
font-weight:950;
letter-spacing:-0.01em;
color:rgba(248,252,255,0.98);
text-shadow:
0 12px 28px rgba(0,0,0,0.18),
0 0 14px rgba(255,255,255,0.04);
}

.deck-card-quote{
position:relative;
z-index:2;
margin:0;
font-size:18px;
line-height:1.55;
color:rgba(232,241,250,0.90);
max-width:92%;
}

.deck-card-meta{
position:absolute;
left:24px;
right:24px;
bottom:22px;
z-index:2;
display:flex;
flex-direction:column;
gap:6px;
padding-top:16px;
border-top:1px solid rgba(212,171,78,0.22);
}

.deck-card-name{
font-size:15px;
font-weight:900;
letter-spacing:0.06em;
color:rgba(248,252,255,0.98);
text-transform:uppercase;
}

.deck-card-role{
font-size:12px;
font-weight:800;
letter-spacing:0.14em;
text-transform:uppercase;
color:rgba(228,204,147,0.76);
}

.deck-card-glow{
position:absolute;
left:-10%;
bottom:6%;
width:80%;
height:36%;
pointer-events:none;
background:
radial-gradient(
ellipse at center,
rgba(212,171,78,0.22) 0%,
rgba(95,180,255,0.10) 35%,
rgba(0,0,0,0) 72%
);
filter:blur(24px);
opacity:.32;
z-index:1;
transition:opacity .26s ease;
}

.deck-card:not(.is-active){
filter:saturate(.74) brightness(.76);
}

.deck-card:not(.is-active) .deck-card-shell{
opacity:.76;
}

.deck-card:not(.is-active) .deck-card-title,
.deck-card:not(.is-active) .deck-card-quote,
.deck-card:not(.is-active) .deck-card-meta,
.deck-card:not(.is-active) .deck-card-topline{
opacity:.24;
}

.deck-card.is-active{
z-index:30 !important;
filter:none;
}

.deck-card.is-active .deck-card-shell{
opacity:1;
border-color:rgba(226,189,99,0.84);
box-shadow:
0 40px 110px rgba(0,0,0,0.30),
0 0 40px rgba(212,171,78,0.14),
0 0 74px rgba(95,180,255,0.05),
inset 0 1px 0 rgba(255,255,255,0.15),
inset 0 -18px 40px rgba(0,0,0,0.14);
}

.deck-card.is-active .deck-card-edge{
opacity:1;
box-shadow:
0 0 18px rgba(212,171,78,0.32),
inset 0 1px 0 rgba(255,255,255,0.34);
}

.deck-card.is-active .deck-card-glow{
opacity:1;
}

.deck-card.is-active .deck-card-title,
.deck-card.is-active .deck-card-quote,
.deck-card.is-active .deck-card-meta,
.deck-card.is-active .deck-card-topline{
opacity:1;
}

/* pop-out positions for 8 cards */
.deck-card[data-card="1"].is-active{
left:0%;
transform:translateY(-16px) translateZ(140px) rotateZ(-.35deg) rotateY(7deg) scale(1.04);
}

.deck-card[data-card="2"].is-active{
left:10%;
transform:translateY(-18px) translateZ(145px) rotateZ(-.28deg) rotateY(5deg) scale(1.045);
}

.deck-card[data-card="3"].is-active{
left:20%;
transform:translateY(-18px) translateZ(150px) rotateZ(-.15deg) rotateY(3deg) scale(1.05);
}

.deck-card[data-card="4"].is-active{
left:31%;
transform:translateY(-20px) translateZ(160px) rotateZ(-.05deg) rotateY(1deg) scale(1.055);
}

.deck-card[data-card="5"].is-active{
left:45%;
transform:translateY(-20px) translateZ(160px) rotateZ(.05deg) rotateY(-1deg) scale(1.055);
}

.deck-card[data-card="6"].is-active{
left:58%;
transform:translateY(-18px) translateZ(150px) rotateZ(.15deg) rotateY(-3deg) scale(1.05);
}

.deck-card[data-card="7"].is-active{
left:69%;
transform:translateY(-18px) translateZ(145px) rotateZ(.28deg) rotateY(-5deg) scale(1.045);
}

.deck-card[data-card="8"].is-active{
left:78%;
transform:translateY(-16px) translateZ(140px) rotateZ(.35deg) rotateY(-7deg) scale(1.04);
}

.deck-card:hover .deck-card-shell{
border-color:rgba(226,189,99,0.76);
box-shadow:
0 34px 96px rgba(0,0,0,0.28),
0 0 34px rgba(212,171,78,0.10),
inset 0 1px 0 rgba(255,255,255,0.14),
inset 0 -18px 40px rgba(0,0,0,0.14);
}

.deck-card:hover .deck-card-edge{
opacity:1;
}

.deck-card:hover .deck-card-glow{
opacity:1;
}

.deck-card:focus-visible .deck-card-shell{
outline:none;
box-shadow:
0 0 0 2px rgba(255,255,255,0.20),
0 0 0 5px rgba(212,171,78,0.20),
0 34px 96px rgba(0,0,0,0.28);
}

/* RESPONSIVE */

@media (max-width:1260px){
.hero-system-panels{
top:31%;
left:53.5%;
width:41%;
height:46%;
column-gap:26px;
row-gap:22px;
}

.system-panel-topline{
font-size:15px;
}

.system-panel-sub{
font-size:16px;
}

.system-panel-cta-text{
font-size:24px;
}
}

.hero-particles{
width:250px;
height:390px;
}

.juju-rings{
height:260px;
}

.juju-helix{
width:114%;
height:106%;
bottom:1%;
}

.hero-system-panels{
top:33%;
left:54.5%;
width:39%;
height:42%;
column-gap:18px;
row-gap:18px;
}

.system-panel-inner{
padding:14px 16px 14px 16px;
border-radius:20px;
}

.system-panel-topline{
font-size:13px;
}

.system-panel-sub{
font-size:14px;
}

.system-panel-cta .system-panel-topline{
font-size:11px;
}

.system-panel-cta-text{
font-size:20px;
}

.system-panel-visual{
left:14px;
right:14px;
bottom:14px;
}

.testimonial-deck{
height:680px;
}

.deck-card{
width:290px;
height:530px;
}

.deck-card-title{
font-size:26px;
}

.deck-card-quote{
font-size:17px;
}

.deck-card[data-card="1"]{
left:4%;
transform:translateY(0) rotateY(62deg) rotateZ(-1deg) scale(.97);
}

.deck-card[data-card="2"]{
left:11%;
transform:translateY(4px) rotateY(68deg) rotateZ(-.8deg) scale(.965);
}

.deck-card[data-card="3"]{
left:19%;
transform:translateY(8px) rotateY(74deg) rotateZ(-.5deg) scale(.96);
}

.deck-card[data-card="4"]{
left:28%;
transform:translateY(10px) rotateY(80deg) rotateZ(-.2deg) scale(.955);
}

.deck-card[data-card="5"]{
left:39%;
transform:translateY(10px) rotateY(-80deg) rotateZ(.2deg) scale(.955);
}

.deck-card[data-card="6"]{
left:48%;
transform:translateY(8px) rotateY(-74deg) rotateZ(.5deg) scale(.96);
}

.deck-card[data-card="7"]{
left:56%;
transform:translateY(4px) rotateY(-68deg) rotateZ(.8deg) scale(.965);
}

.deck-card[data-card="8"]{
left:63%;
transform:translateY(0) rotateY(-62deg) rotateZ(1deg) scale(.97);
}

.deck-card[data-card="1"].is-active{
left:-1%;
transform:translateY(-14px) rotateY(6deg) scale(1.03);
}

.deck-card[data-card="2"].is-active{
left:9%;
transform:translateY(-15px) rotateY(4deg) scale(1.035);
}

.deck-card[data-card="3"].is-active{
left:20%;
transform:translateY(-16px) rotateY(2deg) scale(1.04);
}

.deck-card[data-card="4"].is-active{
left:32%;
transform:translateY(-17px) rotateY(1deg) scale(1.045);
}

.deck-card[data-card="5"].is-active{
left:47%;
transform:translateY(-17px) rotateY(-1deg) scale(1.045);
}

.deck-card[data-card="6"].is-active{
left:60%;
transform:translateY(-16px) rotateY(-2deg) scale(1.04);
}

.deck-card[data-card="7"].is-active{
left:71%;
transform:translateY(-15px) rotateY(-4deg) scale(1.035);
}

.deck-card[data-card="8"].is-active{
left:81%;
transform:translateY(-14px) rotateY(-6deg) scale(1.03);
}

@media (max-width:768px){
.page{
padding:14px;
}

.site-shell{
width:min(100%,96vw);
border-radius:28px;
}

.hero{
height:min(50vh,420px);
}

.hero-particles{
width:170px;
height:250px;
bottom:6%;
}

.juju-portal{
height:20px;
bottom:10px;
}

.juju-rings{
height:150px;
width:86%;
}

.juju-rings span{
height:14px;
}

.juju-helix{
width:116%;
height:102%;
bottom:1%;
}

.helix-a,.helix-b,.helix-c,.helix-d{
filter:blur(1.4px);
}

.hero-system-panels{
display:none;
}

.steps{
grid-template-columns:1fr;
}

.features{
grid-template-columns:1fr;
}

.step-title,
.feature-title{
white-space:normal;
}

.testimonials-deck-section{
padding:8px 18px 4px 18px;
}

.testimonials-title{
font-size:30px;
}

.testimonials-intro{
font-size:16px;
}

.testimonial-deck{
height:auto;
display:grid;
gap:16px;
perspective:none;
}

.deck-card,
.deck-card[data-card],
.deck-card.is-active{
position:relative;
left:auto !important;
top:auto;
width:100%;
height:auto;
transform:none !important;
z-index:auto !important;
}

.deck-card-shell{
padding:22px 20px 20px 20px;
border-radius:24px;
}

.deck-card-edge{
right:8px;
top:12px;
bottom:12px;
opacity:.72;
}

.deck-card-title{
font-size:24px;
}

.deck-card-quote{
font-size:17px;
max-width:100%;
}

.deck-card-meta{
position:relative;
left:auto;
right:auto;
bottom:auto;
margin-top:18px;
padding-top:14px;
}
}
/* =========================
   COLLECTIBLE SHOWCASE
   ========================= */

.collectible-overlay{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(4,8,18,.85);
  backdrop-filter:blur(12px);
  z-index:9999;
  opacity:0;
  pointer-events:none;
  transition:opacity .35s ease;
}

.collectible-overlay.active{
  opacity:1;
  pointer-events:auto;
}

.collectible-stage{
  perspective:1600px;
  position:relative;
}

.collectible-item{
  animation:collectibleEnter .7s cubic-bezier(.2,.9,.3,1),
            collectibleFloat 4s ease-in-out infinite .7s;
}

.collectible-item img{
  height:85vh;
  width:auto;
  max-width:96vw;
  border-radius:20px;
  box-shadow:
    0 40px 120px rgba(0,0,0,.7),
    0 0 80px rgba(120,170,255,.35);
}

.collectible-item .trade-card-art img{
  height:80vh;
  width:auto;
  max-width:90vw;
  object-fit:contain;
  animation:cardFloat 6s ease-in-out infinite;
}

@keyframes cardFloat{
  0%{ transform:translateY(0px); }
  50%{ transform:translateY(-14px); }
  100%{ transform:translateY(0px); }
}

.collectible-item .badge{
  transform:scale(1.8);
}

@keyframes collectibleEnter{
  0%{
    opacity:0;
    transform:translateY(80px) rotateY(-100deg) scale(.4);
  }
  60%{
    transform:translateY(-6px) rotateY(10deg) scale(1.05);
  }
  100%{
    opacity:1;
    transform:translateY(0) rotateY(0) scale(1);
  }
}

@keyframes collectibleFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-14px)}
}

.compare-side-by-side{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:16px;
  margin-top:12px;
}

.compare-side-card{
  position:relative;
  border-radius:28px;
  overflow:hidden;
  background:#000;
}

.compare-side-by-side{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:18px;
  margin-top:14px;
  align-items:start;
}

.compare-side-card{
  position:relative;
  border-radius:28px;
  overflow:hidden;
  background:#000;
  min-width:0;
}

.compare-side-card img{
  display:block;
  width:100%;
  aspect-ratio:4 / 5;
  object-fit:cover;

  transform: scale(1.15);
  object-position: center 40%;
}

.compare-side-title{
  position:absolute;
  top:14px;
  left:16px;
  z-index:2;
  font-size:12px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#fff;
}

@media (max-width: 900px){
  .compare-side-by-side{
    grid-template-columns:1fr;
    gap:14px;
  }
}

/* LEFT — zoom IN */
.compare-side-card img.traditional{
  transform: scale(1.59);
  object-position: center 40%;
}

/* RIGHT — zoom OUT */
.compare-side-card img.juju{
  transform: scale(1.01);
  object-position: center 50%;
}

/* =========================================
   JUJU SWING COURSE OFFER SECTION
   ========================================= */

.course-offer-section{
  padding:96px 22px 110px;
}

.course-offer-shell{
  width:min(1280px, 100%);
  margin:0 auto;
}

.course-offer-head{
  max-width:860px;
  margin:0 auto 34px;
  text-align:center;
}

.course-offer-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(255,214,119,.08);
  border:1px solid rgba(255,214,119,.14);
  color:#cfa452;
  font-size:11px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.course-offer-title{
  margin:16px 0 0;
  font-size:clamp(34px, 4.8vw, 56px);
  line-height:1.02;
  letter-spacing:-.03em;
  font-weight:900;
  color:#081225;
}

.course-offer-sub{
  max-width:760px;
  margin:16px auto 0;
  font-size:17px;
  line-height:1.7;
  color:rgba(8,18,37,.70);
}

.course-offer-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:22px;
  margin-top:34px;
}

.course-offer-card{
  border-radius:28px;
  overflow:hidden;
  background:#eef2f7;
  border:1px solid rgba(8,18,37,.08);
  box-shadow:
    0 18px 40px rgba(8,18,37,.08),
    inset 0 1px 0 rgba(255,255,255,.4);
}

.course-offer-image-wrap{
  position:relative;
  background:#dfe6ef;
}

.course-offer-image-wrap img{
  display:block;
  width:100%;
  aspect-ratio:4 / 5;
  object-fit:cover;
}

.course-offer-card-copy{
  padding:18px 18px 20px;
}

.course-offer-card-title{
  font-size:18px;
  line-height:1.2;
  font-weight:900;
  color:#081225;
  margin-bottom:8px;
}

.course-offer-card-text{
  margin:0;
  font-size:14px;
  line-height:1.65;
  color:rgba(8,18,37,.72);
}

.course-pricing-shell{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:22px;
  margin-top:34px;
}

.course-price-card{
  padding:28px 26px 26px;
  border-radius:30px;
  background:
    linear-gradient(180deg, rgba(13,19,35,.96), rgba(8,12,24,.98));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:
    0 24px 60px rgba(0,0,0,.22),
    inset 0 1px 0 rgba(255,255,255,.04);
}

.course-price-card-featured{
  border:1px solid rgba(228,183,90,.34);
  box-shadow:
    0 24px 70px rgba(0,0,0,.24),
    0 0 0 1px rgba(228,183,90,.10) inset;
}

.course-price-kicker{
  font-size:11px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#d4b06a;
}

.course-price-amount{
  margin-top:14px;
  font-size:54px;
  line-height:1;
  font-weight:900;
  letter-spacing:-.04em;
  color:#f6fbff;
}

.course-price-amount span{
  font-size:22px;
  letter-spacing:0;
  color:rgba(246,251,255,.72);
}

.course-price-copy{
  margin:16px 0 0;
  max-width:520px;
  font-size:16px;
  line-height:1.7;
  color:rgba(226,235,247,.76);
}

.course-price-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  margin-top:22px;
  padding:0 24px;
  border-radius:999px;
  text-decoration:none;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  color:#f6fbff;
  font-size:13px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  transition:
    transform .18s ease,
    box-shadow .18s ease,
    background .18s ease;
}

.course-price-cta:hover{
  transform:translateY(-2px);
  background:rgba(255,255,255,.10);
  box-shadow:0 14px 30px rgba(0,0,0,.18);
}

.course-price-cta-gold{
  color:#081225;
  background:
    linear-gradient(135deg, #f4ddb0 0%, #e6b85d 46%, #f7e5be 100%);
  border-color:rgba(255,255,255,.18);
}

.course-price-cta-gold:hover{
  background:
    linear-gradient(135deg, #f8e6bf 0%, #edc166 46%, #faebca 100%);
}

@media (max-width: 1100px){
  .course-offer-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .course-pricing-shell{
    grid-template-columns:1fr;
  }
}

@media (max-width: 720px){
  .course-offer-section{
    padding:78px 16px 92px;
  }

  .course-offer-grid{
    grid-template-columns:1fr;
  }

  .course-offer-title{
    font-size:34px;
  }

  .course-offer-sub{
    font-size:15px;
  }

  .course-price-card{
    padding:22px 20px 20px;
    border-radius:24px;
  }

  .course-offer-card{
    border-radius:22px;
  }

  .course-price-amount{
    font-size:44px;
  }
}

.course-offer-proof{
  position:relative;
  margin:38px auto 18px;
  max-width:980px;
  padding:34px 28px 30px;
  text-align:center;
  border-radius:28px;
  background:
    radial-gradient(circle at 50% 0%, rgba(228,183,90,.12), transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,.58), rgba(255,255,255,.38));
  border:1px solid rgba(8,18,37,.08);
  box-shadow:
    0 16px 36px rgba(8,18,37,.06),
    inset 0 1px 0 rgba(255,255,255,.55);
  overflow:hidden;
}

.course-offer-proof-line{
  width:120px;
  height:2px;
  margin:0 auto 18px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(230,184,93,0), rgba(230,184,93,.95), rgba(230,184,93,0));
}

.course-offer-proof-kicker{
  font-size:11px;
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#b78b34;
  margin-bottom:14px;
}

.course-offer-proof-title{
  margin:0;
  font-size:clamp(28px, 3vw, 42px);
  line-height:1.18;
  font-weight:900;
  letter-spacing:-.03em;
  color:#081225;
}

.course-offer-proof-title span{
  display:block;
  margin-top:8px;
}

.course-offer-proof-sub{
  max-width:760px;
  margin:16px auto 0;
  font-size:16px;
  line-height:1.7;
  color:rgba(8,18,37,.68);
}

@media (max-width: 720px){
  .course-offer-proof{
    padding:24px 18px 22px;
    border-radius:22px;
  }

  .course-offer-proof-title{
    font-size:28px;
  }

  .course-offer-proof-sub{
    font-size:15px;
  }
}

/* =========================================
   VIDEO REVIEWS SECTION
   ========================================= */

.video-reviews-section{
  padding:0 22px 110px;
}

.video-reviews-shell{
  width:min(1280px, 100%);
  margin:0 auto;
}

.video-reviews-head{
  max-width:860px;
  margin:0 auto 34px;
  text-align:center;
}

.video-reviews-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(255,214,119,.08);
  border:1px solid rgba(255,214,119,.14);
  color:#cfa452;
  font-size:11px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.video-reviews-title{
  margin:16px 0 0;
  font-size:clamp(34px, 4.8vw, 56px);
  line-height:1.02;
  letter-spacing:-.03em;
  font-weight:900;
  color:#081225;
}

.video-reviews-sub{
  max-width:760px;
  margin:16px auto 0;
  font-size:17px;
  line-height:1.7;
  color:rgba(8,18,37,.70);
}

.video-reviews-intro{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:28px;
  align-items:center;
  margin-top:34px;
  padding:30px;
  border-radius:30px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.62), rgba(255,255,255,.42));
  border:1px solid rgba(8,18,37,.08);
  box-shadow:
    0 18px 40px rgba(8,18,37,.06),
    inset 0 1px 0 rgba(255,255,255,.55);
}

.video-reviews-copy p{
  margin:0 0 22px;
  font-size:16px;
  line-height:1.8;
  color:rgba(8,18,37,.74);
}

.video-reviews-copy p:last-child{
  margin-bottom:0;
}

.video-reviews-intro-visual{
  position:relative;
  display:flex;
  justify-content:center;
}

.video-reviews-intro-visual img{
  display:block;
  width:min(360px, 100%);
  aspect-ratio:1 / 1;
  object-fit:cover;
  object-position:center 42%;
  border-radius:50%;
  border:1px solid rgba(8,18,37,.08);
  box-shadow:
    0 18px 40px rgba(8,18,37,.10),
    inset 0 1px 0 rgba(255,255,255,.40);
  filter:contrast(1.05) saturate(1.05);
}

.video-reviews-intro-visual::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:50%;
  background:radial-gradient(circle at center, transparent 60%, rgba(0,0,0,.18));
  pointer-events:none;
}

.video-reviews-proof{
  position:relative;
  margin:34px auto 18px;
  max-width:980px;
  padding:34px 28px 30px;
  text-align:center;
  border-radius:28px;
  background:
    radial-gradient(circle at 50% 0%, rgba(228,183,90,.12), transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,.58), rgba(255,255,255,.38));
  border:1px solid rgba(8,18,37,.08);
  box-shadow:
    0 16px 36px rgba(8,18,37,.06),
    inset 0 1px 0 rgba(255,255,255,.55);
  overflow:hidden;
}

.video-reviews-proof-line{
  width:120px;
  height:2px;
  margin:0 auto 18px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(230,184,93,0), rgba(230,184,93,.95), rgba(230,184,93,0));
}

.video-reviews-proof-kicker{
  font-size:11px;
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#b78b34;
  margin-bottom:14px;
}

.video-reviews-proof-title{
  margin:0;
  font-size:clamp(28px, 3vw, 42px);
  line-height:1.18;
  font-weight:900;
  letter-spacing:-.03em;
  color:#081225;
}

.video-reviews-proof-title span{
  display:block;
  margin-top:8px;
}

.video-reviews-proof-sub{
  max-width:760px;
  margin:16px auto 0;
  font-size:16px;
  line-height:1.7;
  color:rgba(8,18,37,.68);
}

.video-review-pack-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:22px;
  margin-top:34px;
}

.video-review-pack-card{
  border-radius:30px;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(13,19,35,.96), rgba(8,12,24,.98));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:
    0 24px 60px rgba(0,0,0,.22),
    inset 0 1px 0 rgba(255,255,255,.04);
}

.video-review-pack-card-featured{
  border:1px solid rgba(228,183,90,.34);
  box-shadow:
    0 24px 70px rgba(0,0,0,.24),
    0 0 0 1px rgba(228,183,90,.10) inset;
}

.video-review-pack-image-wrap{
  background:#0b1322;
}

.video-review-pack-image-wrap img{
  display:block;
  width:100%;
  aspect-ratio:4 / 3;
  object-fit:cover;
}

.video-review-pack-copy{
  padding:24px 22px 24px;
}

.video-review-pack-kicker{
  font-size:11px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#d4b06a;
}

.video-review-pack-title{
  margin-top:12px;
  font-size:28px;
  line-height:1.08;
  font-weight:900;
  letter-spacing:-.03em;
  color:#f6fbff;
}

.video-review-pack-text{
  margin:14px 0 0;
  font-size:15px;
  line-height:1.75;
  color:rgba(226,235,247,.76);
}

.video-review-pack-price{
  margin-top:18px;
  font-size:42px;
  line-height:1;
  font-weight:900;
  letter-spacing:-.04em;
  color:#f6fbff;
}

.video-review-pack-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  margin-top:22px;
  padding:0 24px;
  border-radius:999px;
  text-decoration:none;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  color:#f6fbff;
  font-size:13px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  transition:
    transform .18s ease,
    box-shadow .18s ease,
    background .18s ease;
}

.video-review-pack-cta:hover{
  transform:translateY(-2px);
  background:rgba(255,255,255,.10);
  box-shadow:0 14px 30px rgba(0,0,0,.18);
}

.video-review-pack-cta-gold{
  color:#081225;
  background:
    linear-gradient(135deg, #f4ddb0 0%, #e6b85d 46%, #f7e5be 100%);
  border-color:rgba(255,255,255,.18);
}

.video-review-pack-cta-gold:hover{
  background:
    linear-gradient(135deg, #f8e6bf 0%, #edc166 46%, #faebca 100%);
}

@media (max-width: 980px){
  .video-reviews-intro{
    grid-template-columns:1fr;
  }

  .video-review-pack-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width: 720px){
  .video-reviews-section{
    padding:0 16px 92px;
  }

  .video-reviews-title{
    font-size:34px;
  }

  .video-reviews-sub,
  .video-reviews-copy p,
  .video-reviews-proof-sub{
    font-size:15px;
  }

  .video-reviews-intro{
    padding:20px;
    border-radius:24px;
  }

  .video-reviews-proof{
    padding:24px 18px 22px;
    border-radius:22px;
  }

  .video-reviews-proof-title{
    font-size:28px;
  }

  .video-review-pack-card{
    border-radius:24px;
  }

  .video-review-pack-title{
    font-size:24px;
  }

  .video-review-pack-price{
    font-size:36px;
  }
}

/* =========================================
   REMOTE LESSONS SECTION
   ========================================= */

.remote-lessons-section{
  padding:0 22px 110px;
}

.remote-lessons-shell{
  width:min(1280px, 100%);
  margin:0 auto;
}

.remote-lessons-head{
  max-width:860px;
  margin:0 auto 34px;
  text-align:center;
}

.remote-lessons-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(255,214,119,.08);
  border:1px solid rgba(255,214,119,.14);
  color:#cfa452;
  font-size:11px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.remote-lessons-title{
  margin:16px 0 0;
  font-size:clamp(34px, 4.8vw, 56px);
  line-height:1.02;
  letter-spacing:-.03em;
  font-weight:900;
  color:#081225;
}

.remote-lessons-sub{
  max-width:760px;
  margin:16px auto 0;
  font-size:17px;
  line-height:1.7;
  color:rgba(8,18,37,.70);
}

.remote-lessons-card{
  display:grid;
  grid-template-columns:.92fr 1.08fr;
  gap:26px;
  align-items:stretch;
  border-radius:32px;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(13,19,35,.96), rgba(8,12,24,.98));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:
    0 24px 60px rgba(0,0,0,.22),
    inset 0 1px 0 rgba(255,255,255,.04);
}

.remote-lessons-image-wrap{
  background:#0b1322;
}

.remote-lessons-image-wrap img{
  display:block;
  width:100%;
  height:100%;
  min-height:100%;
  object-fit:cover;
  object-position:center center;
}

.remote-lessons-copy{
  padding:30px 28px 30px;
  display:flex;
  flex-direction:column;
  gap:24px;
}

.remote-lessons-mini-kicker{
  font-size:11px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#d4b06a;
}

.remote-lessons-card-title{
  margin:12px 0 0;
  font-size:clamp(28px, 3vw, 40px);
  line-height:1.06;
  font-weight:900;
  letter-spacing:-.03em;
  color:#f6fbff;
}

.remote-lessons-card-text{
  margin:16px 0 0;
  font-size:16px;
  line-height:1.75;
  color:rgba(226,235,247,.76);
}

.remote-lessons-includes{
  padding:22px 22px 18px;
  border-radius:24px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.03),
    0 10px 26px rgba(0,0,0,.16);
}

.remote-lessons-includes-title{
  font-size:14px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#f3dcae;
  margin-bottom:14px;
}

.remote-lessons-list{
  margin:0;
  padding-left:18px;
  color:rgba(226,235,247,.82);
}

.remote-lessons-list li{
  margin-bottom:10px;
  font-size:15px;
  line-height:1.65;
}

.remote-lessons-list li:last-child{
  margin-bottom:0;
}

.remote-lessons-pricing{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:16px;
}

.remote-lessons-price-card{
  padding:20px 18px 18px;
  border-radius:22px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.03),
    0 10px 24px rgba(0,0,0,.14);
}

.remote-lessons-price-card-featured{
  border:1px solid rgba(228,183,90,.34);
  box-shadow:
    0 16px 34px rgba(0,0,0,.16),
    0 0 0 1px rgba(228,183,90,.10) inset;
}

.remote-lessons-price-label{
  font-size:10px;
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#d4b06a;
}

.remote-lessons-price-amount{
  margin-top:12px;
  font-size:42px;
  line-height:1;
  font-weight:900;
  letter-spacing:-.04em;
  color:#f6fbff;
}

.remote-lessons-price-amount span{
  font-size:18px;
  letter-spacing:0;
  color:rgba(246,251,255,.72);
}

.remote-lessons-payment-box{
  padding:22px 22px 18px;
  border-radius:24px;
  background:
    radial-gradient(circle at 50% 0%, rgba(228,183,90,.10), transparent 40%),
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.03));
  border:1px solid rgba(228,183,90,.18);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.04),
    0 12px 28px rgba(0,0,0,.14);
}

.remote-lessons-payment-title{
  font-size:14px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#f3dcae;
  margin-bottom:14px;
}

.remote-lessons-payment-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:12px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.remote-lessons-payment-row:last-child{
  border-bottom:none;
  padding-bottom:0;
}

.remote-lessons-pay-label{
  font-size:15px;
  font-weight:800;
  color:#f6fbff;
}

.remote-lessons-pay-value{
  font-size:15px;
  font-weight:700;
  color:rgba(226,235,247,.78);
  text-align:right;
}

@media (max-width: 1100px){
  .remote-lessons-card{
    grid-template-columns:1fr;
  }

  .remote-lessons-image-wrap img{
    aspect-ratio:4 / 3;
    height:auto;
  }
}

@media (max-width: 720px){
  .remote-lessons-section{
    padding:0 16px 92px;
  }

  .remote-lessons-title{
    font-size:34px;
  }

  .remote-lessons-sub,
  .remote-lessons-card-text,
  .remote-lessons-list li,
  .remote-lessons-pay-value{
    font-size:15px;
  }

  .remote-lessons-card{
    border-radius:24px;
  }

  .remote-lessons-copy{
    padding:22px 20px 22px;
    gap:18px;
  }

  .remote-lessons-card-title{
    font-size:30px;
  }

  .remote-lessons-pricing{
    grid-template-columns:1fr;
  }

  .remote-lessons-price-amount{
    font-size:36px;
  }

  .remote-lessons-includes,
  .remote-lessons-payment-box,
  .remote-lessons-price-card{
    border-radius:20px;
  }

  .remote-lessons-payment-row{
    align-items:flex-start;
    flex-direction:column;
    gap:6px;
  }

  .remote-lessons-pay-value{
    text-align:left;
  }
}

.remote-lessons-sub{
  max-width:760px;
  margin:16px auto 0;
  font-size:17px;
  line-height:1.7;
  color:rgba(8,18,37,.70);
}

.remote-lessons-payment-note{
  margin-bottom:10px;
  font-size:13px;
  line-height:1.6;
  color:rgba(226,235,247,.62);
}

.payment-clickable{
  cursor:pointer;
  transition:
    transform .18s ease,
    background .18s ease,
    box-shadow .18s ease;
}

.payment-clickable:hover{
  background:rgba(255,255,255,.05);
  transform:translateY(-2px);
  box-shadow:0 10px 22px rgba(0,0,0,.12);
  text-decoration:none;
}

/* =========================================
   IN PERSON LESSONS SECTION
   ========================================= */

.inperson-lessons-section{
  padding:0 22px 110px;
}

.inperson-lessons-shell{
  width:min(1280px, 100%);
  margin:0 auto;
}

.inperson-lessons-head{
  max-width:860px;
  margin:0 auto 34px;
  text-align:center;
}

.inperson-lessons-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(255,214,119,.08);
  border:1px solid rgba(255,214,119,.14);
  color:#cfa452;
  font-size:11px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.inperson-lessons-title{
  margin:16px 0 0;
  font-size:clamp(34px, 4.8vw, 56px);
  line-height:1.02;
  letter-spacing:-.03em;
  font-weight:900;
  color:#081225;
}

.inperson-lessons-sub{
  max-width:760px;
  margin:16px auto 0;
  font-size:17px;
  line-height:1.7;
  color:rgba(8,18,37,.70);
}

.inperson-lessons-card{
  display:grid;
  grid-template-columns:.92fr 1.08fr;
  gap:26px;
  align-items:stretch;
  border-radius:32px;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(13,19,35,.96), rgba(8,12,24,.98));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:
    0 24px 60px rgba(0,0,0,.22),
    inset 0 1px 0 rgba(255,255,255,.04);
}

.inperson-lessons-image-wrap{
  position:relative;
  overflow:hidden;
  background:#0b1322;
}

.inperson-lessons-image-wrap img{
  display:block;
  width:100%;
  height:100%;
  min-height:100%;
  object-fit:cover;
  object-position:center center;
  filter:
    brightness(.95)
    contrast(1.05)
    saturate(1.05);
}

.inperson-lessons-image-wrap::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 70% 20%, rgba(255,200,120,.25), transparent 40%),
    linear-gradient(to top, rgba(10,15,25,.4), transparent 60%);
  pointer-events:none;
}

.inperson-lessons-ui{
  position:absolute;
  bottom:20px;
  left:20px;
  z-index:2;
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:12px;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  color:#fff;
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
}

.inperson-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:#4dff88;
  box-shadow:0 0 10px #4dff88;
}

.inperson-lessons-copy{
  padding:30px 28px 30px;
  display:flex;
  flex-direction:column;
  gap:24px;
}

.inperson-lessons-mini-kicker{
  font-size:11px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#d4b06a;
}

.inperson-lessons-card-title{
  margin:12px 0 0;
  font-size:clamp(28px, 3vw, 40px);
  line-height:1.06;
  font-weight:900;
  letter-spacing:-.03em;
  color:#f6fbff;
}

.inperson-lessons-card-text{
  margin:16px 0 0;
  font-size:16px;
  line-height:1.75;
  color:rgba(226,235,247,.76);
}

.inperson-lessons-pricing{
  display:grid;
  gap:16px;
}

.inperson-price-card{
  padding:20px 18px 18px;
  border-radius:22px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.03),
    0 10px 24px rgba(0,0,0,.14);
}

.inperson-price-card-featured{
  border:1px solid rgba(228,183,90,.34);
  box-shadow:
    0 16px 34px rgba(0,0,0,.16),
    0 0 0 1px rgba(228,183,90,.10) inset;
}

.inperson-price-label{
  font-size:10px;
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#d4b06a;
}

.inperson-price-amount{
  margin-top:12px;
  font-size:42px;
  line-height:1;
  font-weight:900;
  letter-spacing:-.04em;
  color:#f6fbff;
}

.inperson-price-sub{
  margin-top:8px;
  font-size:14px;
  font-weight:700;
  color:rgba(226,235,247,.68);
}

.inperson-lessons-note{
  font-size:14px;
  line-height:1.7;
  color:rgba(226,235,247,.68);
}

.inperson-lessons-contact-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  width:fit-content;
  padding:0 24px;
  border-radius:999px;
  text-decoration:none;
  background:
    linear-gradient(135deg, #f4ddb0 0%, #e6b85d 46%, #f7e5be 100%);
  border:1px solid rgba(255,255,255,.18);
  color:#081225;
  font-size:13px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  transition:
    transform .18s ease,
    box-shadow .18s ease,
    filter .18s ease;
}

.inperson-lessons-contact-cta:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 30px rgba(0,0,0,.18);
  filter:brightness(1.03);
}

.inperson-lessons-payment-box{
  padding:22px 22px 18px;
  border-radius:24px;
  background:
    radial-gradient(circle at 50% 0%, rgba(228,183,90,.10), transparent 40%),
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.03));
  border:1px solid rgba(228,183,90,.18);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.04),
    0 12px 28px rgba(0,0,0,.14);
}

.inperson-lessons-payment-title{
  font-size:14px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#f3dcae;
  margin-bottom:10px;
}

.inperson-lessons-payment-note{
  margin-bottom:10px;
  font-size:13px;
  line-height:1.6;
  color:rgba(226,235,247,.62);
}

.inperson-lessons-payment-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:12px 14px;
  margin-bottom:8px;
  border-radius:10px;
  background:rgba(255,255,255,.03);
  border-bottom:1px solid rgba(255,255,255,.08);
}

.inperson-lessons-payment-row:last-child{
  margin-bottom:0;
  border-bottom:none;
}

.inperson-lessons-pay-label{
  font-size:15px;
  font-weight:800;
  color:#f6fbff;
}

.inperson-lessons-pay-value{
  font-size:15px;
  font-weight:700;
  color:rgba(226,235,247,.78);
  text-align:right;
}

.payment-clickable{
  cursor:pointer;
  transition:
    transform .18s ease,
    background .18s ease,
    box-shadow .18s ease;
}

.payment-clickable:hover{
  background:rgba(255,255,255,.05);
  transform:translateY(-2px);
  box-shadow:0 10px 22px rgba(0,0,0,.12);
  text-decoration:none;
}

@media (max-width: 1100px){
  .inperson-lessons-card{
    grid-template-columns:1fr;
  }

  .inperson-lessons-image-wrap img{
    aspect-ratio:4 / 3;
    height:auto;
  }
}

@media (max-width: 720px){
  .inperson-lessons-section{
    padding:0 16px 92px;
  }

  .inperson-lessons-title{
    font-size:34px;
  }

  .inperson-lessons-sub,
  .inperson-lessons-card-text,
  .inperson-lessons-pay-value{
    font-size:15px;
  }

  .inperson-lessons-card{
    border-radius:24px;
  }

  .inperson-lessons-copy{
    padding:22px 20px 22px;
    gap:18px;
  }

  .inperson-lessons-card-title{
    font-size:30px;
  }

  .inperson-price-amount{
    font-size:36px;
  }

  .inperson-lessons-payment-box,
  .inperson-price-card{
    border-radius:20px;
  }

  .inperson-lessons-payment-row{
    align-items:flex-start;
    flex-direction:column;
    gap:6px;
  }

  .inperson-lessons-pay-value{
    text-align:left;
  }
}

.hero{
  position:relative;
}

.hero-overlay-link{
  position:absolute;
  inset:0;
  z-index:2;
}

/* =========================================
   GLOBAL MOBILE FIT FIX
   ========================================= */

html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

img,
video,
iframe {
  max-width: 100%;
}

* {
  box-sizing: border-box;
}

@media (max-width: 760px) {
  body {
    width: 100%;
    overflow-x: hidden;
  }

  .topbar,
  .topbar-inner,
  .page,
  .site-shell,
  .hero,
  section,
  main {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
  }

  .topbar-inner {
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
  }

  .brand {
    width: 100%;
    display: flex;
    justify-content: center;
  }

  .brand-mark {
    max-width: 120px;
    height: auto;
  }

  .nav {
    width: 100%;
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: visible;
    gap: 10px;
    padding: 0 8px 8px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .nav::-webkit-scrollbar {
    display: none;
  }

  .nav-link,
  .nav-dropdown-toggle {
    flex: 0 0 auto;
    white-space: nowrap;
    font-size: 12px;
    padding: 9px 12px;
  }

  .nav-dropdown {
    flex: 0 0 auto;
  }

  .steps,
  .features,
  .course-offer-grid,
  .video-review-pack-grid,
  .remote-lessons-card,
  .inperson-lessons-card {
    grid-template-columns: 1fr !important;
    flex-direction: column !important;
  }

  .hero-bg {
    width: 100%;
    height: auto;
    object-fit: cover;
  }

  .feature-card,
  .step-card,
  .course-offer-card,
  .video-review-pack-card,
  .remote-lessons-card,
  .inperson-lessons-card {
    width: 100%;
    max-width: 100%;
  }

  h1,
  h2,
  h3 {
    word-break: normal;
    overflow-wrap: break-word;
  }
}

/* =========================================
   MOBILE NAV HORIZONTAL SCROLL FIX
   ========================================= */

@media (max-width: 760px) {
  .topbar,
  .topbar-inner {
    overflow-x: visible !important;
  }

  .nav {
    width: 100vw !important;
    max-width: 100vw !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: visible !important;
    justify-content: flex-start !important;
    padding: 0 14px 10px !important;
    gap: 10px !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none;
  }

  .nav::-webkit-scrollbar {
    display: none;
  }

  .nav-link,
  .nav-dropdown,
  .nav-dropdown-toggle {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
  }
}