
/* === BRAND TOKENS ========================================= */
:root {
  --abyss:        #1A0830;
  --midnight:     #220D3C;
  --deep-violet:  #3B2E92;
  --purple:       #5B21B6;
  --coral:        #E9375A;
  --magenta:      #E3028C;
  --orange:       #F97316;
  --green:        #059669;
  --white:        #FFFFFF;
  --muted:        rgba(255,255,255,0.60);

  --grad-sig:     linear-gradient(130deg,#220D3C 0%,#3B2E92 25%,#5B21B6 50%,#E9375A 75%,#E3028C 100%);
  --grad-cm:      linear-gradient(135deg,#E9375A,#E3028C);
  --grad-orange:  linear-gradient(135deg,#F97316,#E9375A);
  --grad-green:   linear-gradient(135deg,#059669,#10B981);
  --grad-purple:  linear-gradient(135deg,#3B2E92,#5B21B6);

  --strip: 52px;
  --ease: cubic-bezier(0.16,1,0.3,1);
  --font: 'Plus Jakarta Sans', sans-serif;
}

/* === RESET ================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--midnight);color:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}

/* === NAV SIDE STRIP ======================================= */
.strip {
  position:fixed; left:0; top:0;
  width:var(--strip); height:100vh;
  background:var(--coral); z-index:300;
  display:flex; flex-direction:column;
  align-items:center; justify-content:space-between;
  padding:28px 0; cursor:pointer;
  transition:background .3s ease;
  user-select:none;
}
.strip:hover{background:var(--magenta)}

.strip-bolt svg{width:24px;height:auto}

.strip-label {
  writing-mode:vertical-rl;
  text-orientation:mixed;
  transform:rotate(180deg);
  font-size:9px;font-weight:800;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--white);margin-top:12px;
}

.strip-burger{display:flex;flex-direction:column;gap:5px;padding:8px}
.strip-burger span{
  display:block;width:20px;height:2px;
  background:var(--white);border-radius:2px;
  transition:all .3s var(--ease);transform-origin:center;
}
.nav-open .strip-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-open .strip-burger span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-open .strip-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* === NAV OVERLAY ========================================== */
.overlay {
  position:fixed; inset:0; z-index:290;
  display:grid; grid-template-columns:var(--strip) 1fr;
  pointer-events:none; visibility:hidden;
}
.overlay-panel {
  grid-column:2;
  background:var(--abyss);
  transform:translateX(-100%);
  transition:transform .6s var(--ease);
  display:flex; flex-direction:column;
  justify-content:center;
  padding:80px 80px 80px 64px;
  overflow:hidden; position:relative;
}
.overlay-panel::after{
  content:''; position:absolute;
  right:-120px; bottom:-120px;
  width:480px; height:480px;
  background:var(--grad-sig);
  border-radius:50%; opacity:.15; filter:blur(80px);
  pointer-events:none;
}
.nav-open .overlay{pointer-events:auto;visibility:visible}
.nav-open .overlay-panel{transform:translateX(0)}

.overlay-tag{
  font-size:10px;font-weight:800;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--coral);margin-bottom:48px;
}
.overlay-links{list-style:none;margin-bottom:56px}
.overlay-links > li{margin-bottom:0}

/* Row: link + expand button side by side */
.nav-row{
  display:flex;
  align-items:center;
  gap:16px;
}
.nav-row > a{
  flex:1;
  font-size:clamp(28px,3.8vw,52px);
  font-weight:800;line-height:1.15;
  color:var(--white);
  transition:color .2s,transform .2s;
}
.nav-row > a:hover{color:var(--coral);transform:translateX(10px)}

/* Expand chevron — only visible on touch/mobile */
.nav-expand{
  display:none; /* hidden on desktop; shown via media query */
  flex-shrink:0;
  width:32px;height:32px;
  background:none;border:1px solid rgba(255,255,255,.18);
  border-radius:50%;cursor:pointer;
  align-items:center;justify-content:center;
  color:rgba(255,255,255,.55);
  font-size:16px;line-height:1;
  transition:border-color .2s,color .2s,transform .3s;
  padding:0;
}
.nav-expand:hover{border-color:var(--coral);color:var(--coral)}
.overlay-links > li.open .nav-expand{
  transform:rotate(45deg);
  border-color:var(--coral);color:var(--coral);
}

/* Sub-nav: hidden by default, revealed on hover (desktop) or .open (mobile) */
.overlay-subnav{
  list-style:none;
  display:flex;flex-direction:row;flex-wrap:wrap;
  gap:0 20px;
  max-height:0;
  overflow:hidden;
  opacity:0;
  transition:max-height .35s var(--ease), opacity .25s ease, padding .35s var(--ease);
  padding:0 0 0 2px;
}
.overlay-subnav a{
  font-size:15px;font-weight:600;
  letter-spacing:.04em;
  color:rgba(255,255,255,.42);
  transition:color .2s;white-space:nowrap;
}
.overlay-subnav a:hover{color:var(--coral)}

/* Reveal on desktop hover */
@media (hover:hover){
  .overlay-links > li.has-sub:hover .overlay-subnav{
    max-height:56px;opacity:1;
    padding:8px 0 20px 2px;
  }
}
/* Reveal when toggled open (mobile) */
.overlay-links > li.open .overlay-subnav{
  max-height:56px;opacity:1;
  padding:8px 0 20px 2px;
}
.overlay-foot{display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.btn-coral{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--grad-cm);color:var(--white);
  font-size:12px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  padding:14px 28px;border-radius:3px;
  transition:opacity .2s;
}
.btn-coral:hover{opacity:.88}
.overlay-contact{font-size:13px;color:var(--muted)}
.overlay-contact a{color:var(--white)}
.overlay-contact a:hover{color:var(--coral)}

/* === TOP BAR ============================================== */
.topbar{
  position:fixed; top:0;
  left:var(--strip); right:0; height:70px;
  z-index:280;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 48px;
  transition:background .4s,backdrop-filter .4s;
}
.topbar.scrolled{
  background:rgba(26,8,48,.85);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,.07);
}
.logo{display:block;line-height:0}
.logo svg{height:26px;width:auto;display:block}
.toplinks{display:flex;align-items:center;gap:28px;list-style:none}
.toplinks a{font-size:13px;font-weight:600;color:var(--muted);letter-spacing:.03em;transition:color .2s}
.toplinks a:hover{color:var(--white)}
.toplinks .pill{
  background:var(--coral);color:var(--white);
  padding:9px 20px;border-radius:3px;
  font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  transition:background .2s;
}
.toplinks .pill:hover{background:var(--magenta)}

/* === PAGE WRAP ============================================ */
.page{margin-left:var(--strip)}

/* === HERO ================================================= */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:flex-end;
  background:var(--abyss);overflow:hidden;
  padding-bottom:180px;
}

/* Glow blobs */
.hero::before{
  content:'';position:absolute;
  left:-200px;top:-100px;
  width:640px;height:640px;
  background:radial-gradient(circle,rgba(91,33,182,.28) 0%,transparent 68%);
  z-index:0;pointer-events:none;
}
.hero::after{
  content:'';position:absolute;
  right:-100px;bottom:80px;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(249,115,22,.08) 0%,transparent 68%);
  z-index:0;pointer-events:none;
}

/* Cape SVG — sits above photo */
.cape{
  position:absolute;right:-60px;top:-40px;
  width:70%;max-width:880px;
  z-index:2;pointer-events:none;opacity:.55;
}

/* Big ghost bolt */
.hero-bolt{
  position:absolute;right:7%;top:50%;
  transform:translateY(-50%);
  width:34%;max-width:400px;
  opacity:.06;z-index:3;pointer-events:none;
}

/* ── Parallax photo panel ── */
.hero-photo-wrap{
  position:absolute;
  right:0;top:0;bottom:0;
  width:58%;
  overflow:hidden;
  z-index:1;
}
.hero-photo-inner{
  position:absolute;
  top:-25%;bottom:-25%;
  left:0;right:0;
  will-change:transform;
}
.hero-photo-inner img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 15%;
  display:block;
}
/* Gradient: dark on left (blends with hero bg), dark at bottom (covers stats) */
.hero-photo-overlay{
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(to right, var(--abyss) 0%, rgba(26,8,48,.82) 22%, rgba(26,8,48,.35) 55%, rgba(26,8,48,.08) 100%),
    linear-gradient(to bottom, rgba(26,8,48,.35) 0%, transparent 35%, rgba(26,8,48,.95) 100%);
}

/* === HERO BOLT STRIKE ANIMATION ========================== */
.hero-bolt-anim{
  position:absolute;inset:0;
  z-index:2;pointer-events:none;
}
/* White radial pre-flash */
.bolt-flash{
  position:absolute;
  top:28%;left:50%;
  transform:translate(-50%,-50%);
  width:70%;padding-bottom:70%;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.88) 0%,rgba(255,255,255,0) 62%);
  opacity:0;
}
/* SVG positioned centrally in the photo panel */
.bolt-svg{
  position:absolute;
  top:5%;left:50%;
  transform:translateX(-48%);
  width:44%;height:auto;
  overflow:visible;
}
/* Two stacked paths — stroke traces first, fill floods after */
.bolt-stroke{
  fill:none;
  stroke:var(--coral);
  stroke-width:2.5;
  stroke-linejoin:miter;
  stroke-dasharray:1000;   /* overridden by JS with exact path length */
  stroke-dashoffset:1000;
}
.bolt-fill{
  fill:var(--coral);
  fill-opacity:0;
  stroke:none;
}
/* All animations triggered together by adding .fired */
.hero-bolt-anim.fired .bolt-flash{
  animation:boltFlash .52s cubic-bezier(0,.4,.6,1) forwards;
}
.hero-bolt-anim.fired .bolt-stroke{
  animation:
    boltStrike 360ms cubic-bezier(.6,0,.8,.5) 110ms forwards,
    boltStrokeFade 180ms ease 450ms forwards;
}
.hero-bolt-anim.fired .bolt-fill{
  animation:boltFillFlood 80ms linear 445ms forwards;
}
.hero-bolt-anim.fired .bolt-svg{
  animation:
    boltGlow 1600ms ease 445ms both,
    boltPulse 4.5s ease-in-out 2050ms infinite;
}

@keyframes boltFlash{
  0%  {opacity:0;transform:translate(-50%,-50%) scale(.45)}
  18% {opacity:.88;transform:translate(-50%,-50%) scale(1)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(2.4)}
}
@keyframes boltStrike{
  from{stroke-dashoffset:var(--bolt-len,1000)}
  to  {stroke-dashoffset:0}
}
@keyframes boltStrokeFade{
  from{stroke-opacity:1}
  to  {stroke-opacity:0}
}
@keyframes boltFillFlood{
  from{fill-opacity:0}
  to  {fill-opacity:1}
}
@keyframes boltGlow{
  0%  {filter:drop-shadow(0 0 0px rgba(233,55,90,0))}
  22% {filter:drop-shadow(0 0 22px rgba(233,55,90,.95)) drop-shadow(0 0 55px rgba(233,55,90,.5))}
  100%{filter:drop-shadow(0 0 7px rgba(233,55,90,.28))}
}
@keyframes boltPulse{
  0%,100%{opacity:1}
  50%    {opacity:.75}
}

.hero-content{
  position:relative;z-index:2;
  padding:0 72px;max-width:880px;
}

.kicker{
  display:inline-flex;align-items:center;gap:10px;
  font-size:10px;font-weight:800;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--coral);margin-bottom:32px;
  opacity:0;transform:translateY(16px);
  animation:fadeUp .7s var(--ease) .15s forwards;
}
.kicker::before{content:'';width:28px;height:2px;background:var(--coral)}

.hero-h1{
  font-size:clamp(52px,8vw,112px);
  font-weight:800;line-height:.95;
  letter-spacing:-.03em;margin-bottom:36px;
  opacity:0;transform:translateY(28px);
  animation:fadeUp .9s var(--ease) .3s forwards;
}
.gtext{
  background:var(--grad-cm);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero-h1 .ln{display:block;color:var(--white)}

.hero-body{
  font-size:clamp(16px,1.6vw,20px);
  font-weight:400;line-height:1.65;
  color:rgba(255,255,255,.70);
  max-width:540px;margin-bottom:48px;
  opacity:0;transform:translateY(16px);
  animation:fadeUp .9s var(--ease) .48s forwards;
}

.hero-ctas{
  display:flex;align-items:center;gap:24px;flex-wrap:wrap;
  opacity:0;transform:translateY(16px);
  animation:fadeUp .9s var(--ease) .62s forwards;
}
.btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--grad-cm);color:var(--white);
  font-size:13px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  padding:18px 36px;border-radius:3px;
  box-shadow:0 8px 36px rgba(233,55,90,.36);
  transition:opacity .2s,transform .2s;
}
.btn-primary:hover{opacity:.9;transform:translateY(-2px)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  font-size:14px;font-weight:600;
  color:rgba(255,255,255,.75);
  border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:2px;
  transition:color .2s,border-color .2s;
}
.btn-ghost:hover{color:var(--white);border-color:var(--coral)}

/* Scroll cue */
.scroll-cue{
  position:absolute;bottom:32px;right:52px;
  z-index:2;display:flex;flex-direction:column;
  align-items:center;gap:8px;
  opacity:0;animation:fadeIn 1s ease 1.2s forwards;
}
.scroll-line{
  width:1px;height:44px;
  background:linear-gradient(to bottom,var(--coral),transparent);
  animation:pulse 2s ease-in-out infinite 1.4s;
}
.scroll-txt{
  writing-mode:vertical-rl;font-size:9px;
  font-weight:700;letter-spacing:.2em;
  text-transform:uppercase;color:var(--muted);
}

/* Stat band */
.hero-stats{
  position:absolute;bottom:0;left:0;right:0;
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid rgba(255,255,255,.08);
  z-index:2;opacity:0;
  animation:fadeIn 1s ease .95s forwards;
}
.stat{
  padding:22px 36px;
  border-right:1px solid rgba(255,255,255,.08);
}
.stat:last-child{border-right:none}
.stat-n{
  font-size:clamp(28px,3vw,42px);
  font-weight:800;letter-spacing:-.03em;
  line-height:1;margin-bottom:5px;
}
.stat-n--coral{ background:var(--grad-cm); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.stat-n--orange{ background:var(--grad-orange); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.stat-n--green{ background:var(--grad-green); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.stat-l{font-size:12px;font-weight:500;color:var(--muted);line-height:1.4}
/* count-up initial state — invisible & nudged down; JS adds .counting when animation starts */
.stat-n[data-target]{
  opacity:0;
  transform:translateY(10px);
  transition:opacity .35s ease, transform .35s ease;
}
.stat-n.counting{
  opacity:1;
  transform:translateY(0);
}

@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{to{opacity:1}}
@keyframes pulse{0%,100%{transform:scaleY(1);opacity:1}50%{transform:scaleY(.55);opacity:.35}}

/* === BRAND FILM =========================================== */
.film{
  background:var(--midnight);
  padding:120px 72px;position:relative;overflow:hidden;
}
.film::before{
  content:'';position:absolute;
  left:50%;top:50%;transform:translate(-50%,-50%);
  width:600px;height:600px;
  background:radial-gradient(circle,rgba(91,33,182,.14) 0%,transparent 70%);
  pointer-events:none;
}
.film::after{
  content:'';position:absolute;
  right:0;bottom:0;width:400px;height:400px;
  background:radial-gradient(circle,rgba(249,115,22,.07) 0%,transparent 70%);
  pointer-events:none;
}
.film-inner{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;position:relative;
}
.sec-label{
  font-size:10px;font-weight:800;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--coral);margin-bottom:22px;
  display:flex;align-items:center;gap:10px;
}
.sec-label::before{content:'';width:22px;height:2px;background:var(--coral)}
.film h2{
  font-size:clamp(32px,3.5vw,52px);
  font-weight:800;letter-spacing:-.03em;
  line-height:1.08;margin-bottom:22px;
}
.film p{
  font-size:17px;line-height:1.72;
  color:rgba(255,255,255,.66);
}
.film p em{color:var(--white);font-style:normal;font-weight:600}
.video-box{
  aspect-ratio:16/9;background:var(--abyss);
  border-radius:4px;position:relative;
  overflow:hidden;border:1px solid rgba(255,255,255,.07);
  cursor:pointer;transition:transform .3s;
}
.video-box:hover{transform:scale(1.01)}
/* Video poster photo */
.video-poster{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center top;
  display:block;
  filter:grayscale(.15) brightness(.78);
  transition:filter .4s;
}
.video-box:hover .video-poster{ filter:grayscale(0) brightness(.88); }
/* Gradient overlay over photo — preserves brand feel */
.video-bg{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(135deg,rgba(34,13,60,.68) 0%,rgba(91,33,182,.38) 50%,rgba(233,55,90,.22) 100%);
}
.play-btn{
  position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);
  width:72px;height:72px;border-radius:50%;
  background:rgba(255,255,255,.1);
  backdrop-filter:blur(8px);
  border:1.5px solid rgba(255,255,255,.28);
  display:flex;align-items:center;justify-content:center;
  transition:all .25s;
  z-index:2;
}
.video-cap{ z-index:2; }
.video-box:hover .play-btn{background:var(--coral);border-color:var(--coral);transform:translate(-50%,-50%) scale(1.08)}
.play-btn svg{margin-left:4px}
.video-cap{
  position:absolute;bottom:16px;left:18px;
  font-size:10px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.55);
}

/* === SECTION HEADER ======================================= */
.sec-head{
  max-width:1100px;margin:0 auto 72px;
  padding:0 72px;
  display:grid;grid-template-columns:1fr 1fr;
  gap:60px;align-items:end;
}
.sec-head h2{
  font-size:clamp(36px,4vw,58px);
  font-weight:800;letter-spacing:-.03em;
  line-height:1.05;color:var(--white);
}
.sec-head p{
  font-size:17px;line-height:1.7;
  color:rgba(255,255,255,.62);align-self:end;
}

/* === PILLARS ============================================== */
.pillars{
  background:var(--abyss);
  padding:120px 0;position:relative;overflow:hidden;
}
.pillars::after{
  content:'';position:absolute;
  right:-200px;bottom:-200px;width:700px;height:700px;
  background:radial-gradient(circle,rgba(233,55,90,.09) 0%,transparent 70%);
  pointer-events:none;
}
.pillars-grid{
  max-width:1100px;margin:0 auto;
  padding:0 72px;
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2px;
}

/* Card */
.card{
  position:relative;padding:48px 40px 44px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);
  overflow:hidden;
  transition:transform .3s,border-color .3s;cursor:default;
}
.card:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.15)}
.card:first-child{border-radius:4px 0 0 4px}
.card:last-child{border-radius:0 4px 4px 0}

/* Accent bar */
.card::before{
  content:'';position:absolute;
  top:0;left:0;right:0;height:3px;
}
.card-mojo::before{background:var(--grad-orange)}
.card-chi::before{background:var(--grad-sig)}
.card-roi::before{background:var(--grad-green)}

/* Hover glow */
.card::after{
  content:'';position:absolute;
  top:-80px;right:-80px;
  width:240px;height:240px;
  border-radius:50%;opacity:0;
  transition:opacity .4s;pointer-events:none;
}
.card-mojo::after{background:radial-gradient(circle,rgba(249,115,22,.2) 0%,transparent 70%)}
.card-chi::after{background:radial-gradient(circle,rgba(91,33,182,.22) 0%,transparent 70%)}
.card-roi::after{background:radial-gradient(circle,rgba(5,150,105,.22) 0%,transparent 70%)}
.card:hover::after{opacity:1}

.card-icon{width:52px;height:52px;margin-bottom:26px;position:relative;z-index:1}
.card-tag{
  display:inline-block;font-size:9px;
  font-weight:800;letter-spacing:.22em;
  text-transform:uppercase;padding:5px 10px;
  border-radius:2px;margin-bottom:18px;
  position:relative;z-index:1;
}
.card-mojo .card-tag{background:rgba(249,115,22,.13);color:#FB923C}
.card-chi  .card-tag{background:rgba(91,33,182,.16);color:#A78BFA}
.card-roi  .card-tag{background:rgba(5,150,105,.13);color:#34D399}

.card-name{
  font-size:26px;font-weight:800;
  letter-spacing:-.02em;color:var(--white);
  margin-bottom:5px;line-height:1.1;
  position:relative;z-index:1;
}
.card-sub{
  font-size:12px;font-weight:600;
  color:var(--muted);letter-spacing:.04em;
  margin-bottom:18px;position:relative;z-index:1;
}
.card-desc{
  font-size:15px;line-height:1.72;
  color:rgba(255,255,255,.60);font-weight:400;
  margin-bottom:30px;position:relative;z-index:1;
}
.card-link{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  position:relative;z-index:1;
  transition:gap .2s;
}
.card:hover .card-link{gap:13px}
.card-mojo .card-link{color:#FB923C}
.card-chi  .card-link{color:#A78BFA}
.card-roi  .card-link{color:#34D399}

/* === METHOD =============================================== */
.method{
  padding:120px 72px;background:var(--midnight);
  position:relative;overflow:hidden;
}
.method-inner{max-width:1100px;margin:0 auto}
.method-top{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;margin-bottom:80px;
}
.method h2{
  font-size:clamp(32px,3.5vw,50px);
  font-weight:800;letter-spacing:-.03em;
  line-height:1.08;
}
.method-body{font-size:17px;line-height:1.75;color:rgba(255,255,255,.64)}
.method-body strong{color:var(--white);font-weight:600}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.step{
  padding-top:30px;position:relative;
  border-top:1px solid rgba(255,255,255,.1);
}
.step-01{border-top-color:rgba(249,115,22,.28)}
.step-02{border-top-color:rgba(233,55,90,.28)}
.step-03{border-top-color:rgba(52,211,153,.28)}
.step-num{
  font-size:10px;font-weight:800;
  letter-spacing:.2em;margin-bottom:12px;
}
.step-01 .step-num{color:#FB923C}
.step-02 .step-num{color:var(--coral)}
.step-03 .step-num{color:#34D399}
.step h3{
  font-size:20px;font-weight:700;
  letter-spacing:-.02em;color:var(--white);margin-bottom:10px;
}
.step p{font-size:15px;line-height:1.65;color:rgba(255,255,255,.58)}

/* === SOCIAL PROOF ========================================= */
.proof{
  padding:120px 0 0;
  background:var(--abyss);overflow:hidden;
}
.proof-head{
  text-align:center;margin-bottom:72px;padding:0 72px;
}
.proof-kicker{
  font-size:10px;font-weight:800;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--coral);margin-bottom:18px;
  display:flex;align-items:center;justify-content:center;gap:12px;
}
.proof-kicker::before,.proof-kicker::after{
  content:'';width:36px;height:1px;background:rgba(255,255,255,.15);
}
.proof-head h2{
  font-size:clamp(32px,3.5vw,52px);
  font-weight:800;letter-spacing:-.03em;line-height:1.08;
  max-width:600px;margin:0 auto;
}

/* Logo strip */
.logo-strip{
  overflow:hidden;
  padding:36px 0;
  border-top:1px solid rgba(255,255,255,.07);
  border-bottom:1px solid rgba(255,255,255,.07);
  margin-bottom:72px;
}
.logo-track{
  display:flex;gap:64px;
  width:max-content;
  animation:scrollLoop 28s linear infinite;
}
.logo-strip:hover .logo-track{animation-play-state:paused}
.logo-item{
  font-size:13px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.2);white-space:nowrap;
  display:flex;align-items:center;gap:12px;
  transition:color .2s;
}
.logo-item:hover{color:rgba(255,255,255,.45)}
.logo-item::before{content:'✦';font-size:9px;opacity:.5}
.logo-item:nth-child(3n+1)::before{color:var(--coral)}
.logo-item:nth-child(3n+2)::before{color:#FB923C}
.logo-item:nth-child(3n)::before{color:#34D399}
@keyframes scrollLoop{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Testimonials */
.testi-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  max-width:1100px;margin:0 auto;
  padding:0 72px 80px;gap:24px;
}
.testi{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);
  border-radius:4px;padding:36px;
  transition:border-color .3s,transform .3s;
}
.testi:hover{border-color:rgba(233,55,90,.22);transform:translateY(-3px)}
.testi-q{
  font-size:15px;line-height:1.75;
  color:rgba(255,255,255,.76);
  font-style:italic;margin-bottom:26px;
}
.testi-q::before{
  content:'"';font-size:40px;
  line-height:.8;color:var(--coral);
  font-style:normal;font-weight:800;
  display:block;margin-bottom:10px;
}
.testi-author{display:flex;align-items:center;gap:14px}
.testi-av{
  width:52px;height:52px;border-radius:50%;
  background:var(--grad-sig);
  flex-shrink:0;overflow:hidden;
  border:2px solid rgba(255,255,255,.12);
}
.testi-av img{
  width:100%;height:100%;
  object-fit:cover;object-position:center top;
  display:block;
}
.testi-name{font-size:14px;font-weight:700}
.testi-role{font-size:12px;color:var(--muted);margin-top:2px}

/* === ARTICLES ============================================= */
.articles{
  padding:120px 72px;background:var(--midnight);position:relative;
}
.articles-inner{max-width:1100px;margin:0 auto}
.articles-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:28px;margin-top:64px;
}
.art{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);
  border-radius:4px;overflow:hidden;
  display:flex;flex-direction:column;
  transition:border-color .3s,transform .3s;cursor:pointer;
}
.art:hover{border-color:rgba(255,255,255,.15);transform:translateY(-4px)}
.art-img{aspect-ratio:16/9;position:relative;overflow:hidden}
.art-bg{ position:absolute;inset:0;background:#1A0830; }

/* Photo: desaturated + colour-graded by default */
.art-bg img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  display:block;
  filter:grayscale(.5) saturate(.65) brightness(.88);
  transition:transform .6s ease, filter .6s ease;
}
/* Hover: full natural colour, slight brightness boost */
.art:hover .art-bg img{
  transform:scale(1.04);
  filter:grayscale(0) saturate(1.12) brightness(1.02);
}

/* Colour grade overlays — fade out on hover */
.art-bg-1::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(249,115,22,.52) 0%,rgba(233,55,90,.32) 100%);
  mix-blend-mode:multiply;pointer-events:none;
  transition:opacity .6s ease;
}
.art-bg-2::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(59,46,146,.58) 0%,rgba(227,2,140,.38) 100%);
  mix-blend-mode:multiply;pointer-events:none;
  transition:opacity .6s ease;
}
.art-bg-3::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(5,150,105,.58) 0%,rgba(59,46,146,.38) 100%);
  mix-blend-mode:multiply;pointer-events:none;
  transition:opacity .6s ease;
}
/* Fade colour grade out on hover — reveal full photo */
.art:hover .art-bg-1::after,
.art:hover .art-bg-2::after,
.art:hover .art-bg-3::after{ opacity:0; }

.art-icon{
  position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);opacity:.22;
}
.art-body{padding:26px 26px 30px;flex:1;display:flex;flex-direction:column}
.art-cat{
  font-size:9px;font-weight:800;
  letter-spacing:.2em;text-transform:uppercase;margin-bottom:10px;
}
.art-cat-1{color:#FB923C}
.art-cat-2{color:var(--coral)}
.art-cat-3{color:#34D399}
.art-title{
  font-size:17px;font-weight:700;
  letter-spacing:-.02em;line-height:1.3;
  color:var(--white);margin-bottom:10px;flex:1;
}
.art-ex{
  font-size:14px;line-height:1.65;
  color:rgba(255,255,255,.52);margin-bottom:18px;
}
.art-read{
  font-size:11px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  display:flex;align-items:center;gap:6px;
  transition:gap .2s;
}
.art:hover .art-read{gap:10px}
.art-read-1{color:#FB923C}
.art-read-2{color:var(--coral)}
.art-read-3{color:#34D399}

/* === PULLQUOTE ============================================ */
.pullquote{
  padding:100px 72px;
  position:relative;overflow:hidden;text-align:center;
}
/* Photo layer — sits beneath everything */
.pq-photo{
  position:absolute;inset:0;z-index:0;
}
.pq-photo img{
  width:100%;height:100%;
  object-fit:cover;object-position:center 30%;
  display:block;
  filter:grayscale(.6) brightness(.55);
}
/* Signature gradient over the photo */
.pullquote::before{
  content:'';position:absolute;inset:0;z-index:1;
  background:var(--grad-sig);
  opacity:.88;
}
/* Dot texture on top */
.pullquote::after{
  content:'';position:absolute;inset:0;z-index:2;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E") center;
  pointer-events:none;
}
.pullquote-inner{position:relative;z-index:3;max-width:860px;margin:0 auto}
.pq-bolt{width:44px;margin:0 auto 24px;opacity:.6}
.pq-text{
  font-size:clamp(24px,3.5vw,44px);
  font-weight:700;line-height:1.25;
  letter-spacing:-.02em;font-style:italic;
  color:var(--white);margin-bottom:24px;
}
.pq-attr{
  font-size:12px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.6);
}
.pq-attr strong{color:var(--white)}

/* === CTA ================================================== */
.cta{
  background:var(--abyss);
  position:relative;overflow:hidden;
  padding:0;
}
/* Split layout */
.cta-split{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:580px;
}
/* Left: text */
.cta-text{
  padding:100px 64px 100px 72px;
  position:relative;z-index:1;
  display:flex;flex-direction:column;justify-content:center;
}
/* Purple glow behind text */
.cta-text::before{
  content:'';position:absolute;
  left:-100px;top:50%;transform:translateY(-50%);
  width:600px;height:500px;
  background:radial-gradient(ellipse,rgba(91,33,182,.2) 0%,transparent 68%);
  pointer-events:none;z-index:0;
}
/* Right: photo */
.cta-photo{
  position:relative;overflow:hidden;
}
.cta-photo img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center top;
  display:block;
}
/* Gradient fades photo into the dark background on the left edge */
.cta-photo::before{
  content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(to right,var(--abyss) 0%,rgba(26,8,48,.3) 30%,transparent 70%);
}
/* Subtle brand colour wash */
.cta-photo::after{
  content:'';position:absolute;inset:0;z-index:2;
  background:linear-gradient(160deg,rgba(91,33,182,.22) 0%,rgba(233,55,90,.14) 100%);
}
.cta-inner{
  position:relative;z-index:1;
}
.cta-kicker{
  font-size:10px;font-weight:800;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--coral);margin-bottom:26px;
  display:flex;align-items:center;gap:12px;
}
.cta-kicker::before{
  content:'';width:36px;height:1px;background:rgba(255,255,255,.14);
}
.cta h2{
  font-size:clamp(36px,4.5vw,64px);
  font-weight:800;letter-spacing:-.03em;
  line-height:1.02;margin-bottom:22px;
}
.cta h2 span{
  background:var(--grad-cm);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
}
.cta-sub{
  font-size:17px;line-height:1.65;
  color:rgba(255,255,255,.62);
  max-width:480px;margin-bottom:44px;
}
.cta-acts{display:flex;gap:20px;flex-wrap:wrap}

/* === FOOTER =============================================== */
footer{
  background:var(--abyss);
  border-top:1px solid rgba(255,255,255,.07);
  padding:64px 72px 40px;
}
.footer-top{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:48px;margin-bottom:52px;
  max-width:1100px;margin-left:auto;margin-right:auto;
}
.footer-brand .logo{margin-bottom:14px}
.footer-brand .logo svg{height:22px}
.footer-tag{
  font-size:14px;line-height:1.6;
  color:rgba(255,255,255,.46);max-width:280px;margin-bottom:22px;
}
.footer-social{display:flex;gap:10px}
.footer-social a{
  width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;color:rgba(255,255,255,.45);
  transition:all .2s;
}
.footer-social a:hover{border-color:var(--coral);color:var(--coral)}
.col-title{
  font-size:10px;font-weight:800;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--white);margin-bottom:18px;
}
.col-links{list-style:none;display:flex;flex-direction:column;gap:10px}
.col-links a{font-size:14px;color:rgba(255,255,255,.46);transition:color .2s}
.col-links a:hover{color:var(--white)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.07);
  padding-top:26px;
  display:flex;justify-content:space-between;align-items:center;
  max-width:1100px;margin:0 auto;flex-wrap:wrap;gap:10px;
}
.footer-copy{font-size:12px;color:rgba(255,255,255,.3)}
.footer-legal{display:flex;gap:22px}
.footer-legal a{font-size:12px;color:rgba(255,255,255,.3);transition:color .2s}
.footer-legal a:hover{color:rgba(255,255,255,.65)}

/* === SCROLL REVEAL ======================================== */
.reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity .8s var(--ease),transform .8s var(--ease);
}
.reveal.in{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}
.d2{transition-delay:.2s}
.d3{transition-delay:.3s}
.d4{transition-delay:.4s}

/* === RESPONSIVE =========================================== */

/* --- Tablet: 900px ---------------------------------------- */
@media (max-width: 900px) {

  /* 3-col grids → 1-col */
  .pillars-grid,
  .steps,
  .testi-grid,
  .articles-grid {
    grid-template-columns: 1fr;
  }

  /* Pillar card corners reset */
  .card:first-child,
  .card:last-child { border-radius: 4px; }

  /* 2-col grids → 1-col */
  .film-inner,
  .method-top,
  .sec-head {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  /* Section padding tighten */
  .film,
  .method,
  .articles,
  .cta,
  .pullquote { padding-left: 48px; padding-right: 48px; }

  .pillars-grid,
  .testi-grid { padding-left: 48px; padding-right: 48px; }

  .sec-head,
  .proof-head { padding-left: 48px; padding-right: 48px; }

  /* Footer 4-col → 2-col */
  .footer-top {
    grid-template-columns: 1fr 1fr;
    gap: 36px;
  }
  footer { padding-left: 48px; padding-right: 48px; }

  /* Hero */
  .hero-content { padding: 0 48px; }
  .hero-stats { grid-template-columns: repeat(3,1fr); }

  /* Articles inner */
  .articles-inner .sec-head { padding: 0; }
}

/* --- Mobile: 640px ---------------------------------------- */
@media (max-width: 640px) {

  /* Side strip → top bar on mobile */
  :root { --strip: 0px; }

  .strip {
    width: 100%;
    height: 56px;
    flex-direction: row;
    justify-content: space-between;
    padding: 0 20px;
    bottom: auto;
    top: 0; left: 0;
    z-index: 300;
  }
  .strip-bolt {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 10px;
  }
  .strip-bolt svg { width: 18px; }
  .strip-label {
    writing-mode: horizontal-tb;
    transform: none;
    font-size: 9px;
    margin-top: 0;
    letter-spacing: .2em;
  }
  .strip-burger { padding: 6px; }

  /* Nav overlay: full screen (no grid needed) */
  .overlay { grid-template-columns: 1fr; }
  .overlay-panel {
    grid-column: 1;
    padding: 80px 32px 48px;
  }

  /* Top bar: sit below the strip */
  .topbar {
    left: 0;
    top: 56px;
    padding: 0 20px;
    height: 60px;
  }
  .toplinks { gap: 16px; }
  .toplinks li:first-child { display: none; } /* hide Contact, keep mojo pill */

  /* Page offset: now pushed down by strip height */
  .page { margin-left: 0; padding-top: 116px; }

  /* Hero */
  .hero { padding-bottom: 0; min-height: auto; padding-top: 60px; }
  /* Reduce photo panel on mobile — full width, less dominant */
  .hero-photo-wrap { width: 100%; opacity: 0.4; }
  .hero-photo-overlay {
    background:
      linear-gradient(to right, var(--abyss) 0%, rgba(26,8,48,.95) 50%, var(--abyss) 100%),
      linear-gradient(to bottom, rgba(26,8,48,.5) 0%, transparent 40%, rgba(26,8,48,.98) 100%);
  }
  .hero-content { padding: 48px 24px 0; }
  .hero-h1 { font-size: clamp(44px,12vw,72px); }
  .hero-body { font-size: 16px; }
  .hero-ctas { flex-direction: column; align-items: flex-start; gap: 16px; }
  .btn-primary { width: 100%; justify-content: center; }

  /* Stats band → stack */
  .hero-stats {
    position: relative;
    grid-template-columns: 1fr;
    border-top: none;
    margin-top: 48px;
  }
  .stat {
    border-right: none;
    border-top: 1px solid rgba(255,255,255,.08);
    padding: 20px 24px;
  }

  /* Cape: smaller + repositioned */
  .cape { width: 100%; right: -20%; top: 0; opacity: .5; }
  .hero-bolt { display: none; }
  .scroll-cue { display: none; }

  /* Section padding */
  .film,
  .method,
  .articles,
  .cta,
  .pullquote {
    padding: 72px 24px;
  }
  .pillars { padding: 72px 0; }
  .pillars-grid,
  .testi-grid { padding: 0 24px; }

  /* Section headers */
  .sec-head,
  .proof-head { padding: 0 24px; }

  /* Film */
  .film-inner { grid-template-columns: 1fr; gap: 32px; }

  /* Method */
  .method-top { grid-template-columns: 1fr; gap: 28px; }
  .steps { grid-template-columns: 1fr; gap: 32px; }

  /* Social proof */
  .proof { padding-top: 72px; }

  /* Testimonials */
  .testi-grid { gap: 16px; }

  /* Articles */
  .articles-inner .sec-head { grid-template-columns: 1fr; gap: 16px; padding: 0; }
  .articles-grid { gap: 16px; }

  /* Pullquote */
  .pq-text { font-size: clamp(22px,5.5vw,32px); }

  /* CTA */
  /* CTA: stack on mobile */
  .cta-split { grid-template-columns: 1fr; }
  .cta-text { padding: 72px 24px; }
  .cta-photo { min-height: 280px; }
  .cta-acts { flex-direction: column; align-items: flex-start; }
  .cta-acts .btn-primary,
  .cta-acts .btn-ghost { width: 100%; justify-content: center; }

  /* Footer */
  .footer-top { grid-template-columns: 1fr; gap: 32px; }
  footer { padding: 48px 24px 32px; }
  .footer-bottom { flex-direction: column; align-items: flex-start; gap: 12px; }
  .footer-legal { flex-wrap: wrap; gap: 14px; }

  /* Overlay nav links smaller */
  .nav-row > a { font-size: clamp(24px,7.5vw,38px); }
  .overlay-subnav a { font-size: 13px; }
  /* Show expand button on touch screens */
  .nav-expand { display: flex; }
}

/* --- Small mobile: 400px ---------------------------------- */
@media (max-width: 400px) {
  .hero-h1 { font-size: 40px; }
  .nav-row > a { font-size: 26px; }
}
