/* ================================================================
   GREASE MOB — THE SYNDICATE
   Harlem noir · graffiti gold · slime green · neon grime
   ================================================================ */

:root{
  --black:#0a0805;
  --black-2:#050403;
  --ink:#12100b;
  --panel:#151109;
  --gold-1:#8a5a06;
  --gold-2:#f5c518;
  --gold-3:#ffe37a;
  --gold-4:#b8860b;
  --green-1:#5cff1f;
  --green-2:#a6ff00;
  --green-3:#26ff6a;
  --red:#ff2d2d;
  --neon:#22e6ff;
  --ember:#ff6a00;
  --smoke:rgba(255,220,150,.06);
  --txt:#efe6d2;
  --txt-dim:#b3a892;
  --txt-faint:#7d7361;
  --edge:rgba(245,197,24,.16);
  --gold-grad:linear-gradient(180deg,#fff4c2 0%,#ffe37a 18%,#f5c518 46%,#c98f14 74%,#8a5a06 100%);
  --green-grad:linear-gradient(180deg,#e8ffcf 0%,#a6ff00 30%,#5cff1f 60%,#1f9e12 100%);
  --ff-head:'Anton',Impact,sans-serif;
  --ff-tag:'Bangers',cursive;
  --ff-label:'Bebas Neue',sans-serif;
  --ff-body:'Oswald','Segoe UI',sans-serif;
  --ff-marker:'Permanent Marker',cursive;
  --shadow:0 30px 80px rgba(0,0,0,.7);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
  background:var(--black-2);
  color:var(--txt);
  font-family:var(--ff-body);
  font-weight:300;
  line-height:1.6;
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  cursor:none;
}
body.locked{overflow:hidden;height:100vh}
@media (pointer:coarse){body{cursor:auto}}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--green-2);color:#08210a}

/* ---------- background grain + vignette ---------- */
.grain{
  position:fixed;inset:0;z-index:2;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grainShift 3s steps(4) infinite;
}
@keyframes grainShift{0%{transform:translate(0,0)}25%{transform:translate(-3%,2%)}50%{transform:translate(2%,-3%)}75%{transform:translate(-2%,-2%)}100%{transform:translate(3%,3%)}}
body::after{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 30%,transparent 40%,rgba(0,0,0,.55) 100%);
}

/* ---------- fx canvas (embers) ---------- */
.fx-canvas{position:fixed;inset:0;z-index:0;pointer-events:none}

/* ---------- custom cursor ---------- */
.cursor,.cursor-dot{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;border-radius:50%;mix-blend-mode:screen;will-change:transform}
.cursor{width:34px;height:34px;margin:-17px 0 0 -17px;border:1.5px solid rgba(245,197,24,.8);transition:width .2s,height .2s,margin .2s,background .2s;box-shadow:0 0 14px rgba(245,197,24,.5)}
.cursor-dot{width:6px;height:6px;margin:-3px 0 0 -3px;background:var(--gold-3);box-shadow:0 0 10px var(--gold-2)}
.cursor.hot{width:56px;height:56px;margin:-28px 0 0 -28px;background:rgba(166,255,0,.14);border-color:var(--green-2);box-shadow:0 0 22px rgba(166,255,0,.6)}
@media (pointer:coarse){.cursor,.cursor-dot{display:none}}

/* ================= AGE GATE ================= */
.gate{
  position:fixed;inset:0;z-index:10000;display:grid;place-items:center;
  background:radial-gradient(120% 120% at 50% 0%,#1a1206 0%,#050302 60%,#000 100%);
  text-align:center;padding:24px;transition:opacity .8s ease,visibility .8s;
}
.gate.hide{opacity:0;visibility:hidden;pointer-events:none}
.gate-smoke{position:absolute;inset:0;opacity:.5;pointer-events:none;
  background:
    radial-gradient(40% 30% at 20% 80%,rgba(120,90,20,.35),transparent 70%),
    radial-gradient(45% 35% at 80% 70%,rgba(60,90,30,.28),transparent 70%),
    radial-gradient(50% 40% at 50% 20%,rgba(150,110,30,.25),transparent 70%);
  filter:blur(10px);animation:smokeDrift 14s ease-in-out infinite alternate}
@keyframes smokeDrift{0%{transform:translate(-3%,2%) scale(1.05)}100%{transform:translate(4%,-3%) scale(1.15)}}
.gate-inner{position:relative;max-width:560px;animation:gateIn 1s cubic-bezier(.2,.8,.2,1) both}
@keyframes gateIn{from{opacity:0;transform:translateY(30px) scale(.96);filter:blur(8px)}to{opacity:1;transform:none;filter:none}}
.gate-logo{width:min(360px,74vw);margin:0 auto 6px;filter:drop-shadow(0 10px 30px rgba(245,197,24,.35));animation:swing 6s ease-in-out infinite}
@keyframes swing{0%,100%{transform:rotate(-1.5deg)}50%{transform:rotate(1.5deg)}}
.gate-badge{font-family:var(--ff-head);font-size:clamp(40px,9vw,68px);line-height:1;color:transparent;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;
  filter:drop-shadow(0 2px 0 #3a2600);margin:4px 0}
.gate-badge span{color:var(--green-2);-webkit-text-fill-color:var(--green-2)}
.gate-title{font-family:var(--ff-head);font-size:clamp(26px,6vw,44px);letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}
.gate-title em{font-style:normal;color:transparent;background:var(--green-grad);-webkit-background-clip:text;background-clip:text}
.gate-sub{color:var(--txt-dim);font-size:clamp(15px,2.4vw,18px);max-width:440px;margin:0 auto 26px}
.gate-sub b{color:var(--gold-3)}
.gate-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.gate-fine{margin-top:26px;font-size:12px;color:var(--txt-faint);max-width:440px;margin-inline:auto;letter-spacing:.3px}

/* ================= BUTTONS ================= */
.btn{
  position:relative;display:inline-flex;align-items:center;gap:10px;
  font-family:var(--ff-label);letter-spacing:1.4px;font-size:17px;
  padding:15px 30px;border-radius:2px;cursor:none;border:none;
  text-transform:uppercase;transition:transform .25s,box-shadow .25s,filter .25s;overflow:hidden;
}
@media(pointer:coarse){.btn{cursor:pointer}}
.btn-gold{background:var(--gold-grad);color:#1a1200;font-weight:700;box-shadow:0 8px 26px rgba(245,197,24,.34),inset 0 1px 0 rgba(255,255,255,.5)}
.btn-gold:hover{filter:brightness(1.08) saturate(1.1);box-shadow:0 12px 40px rgba(245,197,24,.55)}
.btn-gold::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 20%,rgba(255,255,255,.8) 48%,transparent 60%);transform:translateX(-120%);animation:shine 3.4s ease-in-out infinite}
@keyframes shine{0%,60%{transform:translateX(-120%)}100%{transform:translateX(120%)}}
.btn-outline{background:transparent;color:var(--gold-3);border:1.5px solid var(--edge);box-shadow:inset 0 0 0 rgba(245,197,24,0)}
.btn-outline:hover{border-color:var(--gold-2);color:#fff;box-shadow:inset 0 0 30px rgba(245,197,24,.18),0 0 22px rgba(245,197,24,.25)}
.btn-ghost{background:transparent;color:var(--txt-faint);border:1.5px solid rgba(255,255,255,.12)}
.btn-ghost:hover{color:var(--red);border-color:var(--red)}
.btn.big{font-size:20px;padding:18px 40px}
.play-tri{width:0;height:0;border-left:12px solid currentColor;border-top:8px solid transparent;border-bottom:8px solid transparent}

/* ================= NAV ================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px clamp(16px,4vw,44px);
  transition:background .4s,backdrop-filter .4s,padding .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{background:rgba(8,6,3,.82);backdrop-filter:blur(14px);border-bottom-color:var(--edge);padding-top:9px;padding-bottom:9px}
.nav-brand img{height:40px;filter:drop-shadow(0 3px 8px rgba(0,0,0,.6));transition:transform .3s}
.nav-brand:hover img{transform:rotate(-3deg) scale(1.05)}
.nav-links{display:flex;align-items:center;gap:clamp(14px,2.2vw,30px)}
.nav-links a{font-family:var(--ff-label);letter-spacing:1.6px;font-size:16px;color:var(--txt-dim);position:relative;transition:color .25s}
.nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;background:var(--gold-grad);transition:width .3s}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after{width:100%}
.nav-cta{padding:9px 20px;background:var(--gold-grad);color:#1a1200!important;border-radius:2px;font-weight:700;box-shadow:0 6px 18px rgba(245,197,24,.3)}
.nav-cta:hover{filter:brightness(1.1)}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;z-index:901}
.nav-burger span{width:26px;height:2.5px;background:var(--gold-3);transition:transform .3s,opacity .3s;border-radius:2px}
.nav-burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

@media(max-width:860px){
  .nav-burger{display:flex}
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(78vw,320px);
    flex-direction:column;justify-content:center;gap:26px;
    background:rgba(6,5,3,.97);backdrop-filter:blur(18px);
    transform:translateX(100%);transition:transform .45s cubic-bezier(.2,.8,.2,1);
    border-left:1px solid var(--edge);padding:40px;
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:24px}
}

/* ================= HERO ================= */
.hero{position:relative;min-height:100svh;display:grid;place-items:center;overflow:hidden;text-align:center;padding:120px 20px 90px}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;filter:saturate(1.05) contrast(1.05) brightness(.62);transform:scale(1.08);will-change:transform}
.hero-scrim{position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(90% 70% at 50% 40%,transparent 20%,rgba(5,3,2,.7) 100%),
    linear-gradient(180deg,rgba(5,3,2,.55) 0%,transparent 30%,transparent 55%,var(--black-2) 100%);
}
.hero-embers{position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background:radial-gradient(2px 2px at 20% 80%,rgba(255,180,60,.9),transparent),radial-gradient(2px 2px at 70% 60%,rgba(166,255,0,.7),transparent),radial-gradient(1.5px 1.5px at 40% 90%,rgba(255,140,40,.8),transparent)}
.hero-inner{position:relative;max-width:920px;animation:heroRise 1.2s .1s cubic-bezier(.2,.8,.2,1) both}
@keyframes heroRise{from{opacity:0;transform:translateY(40px);filter:blur(6px)}to{opacity:1;transform:none;filter:none}}
.hero-kicker{display:inline-flex;align-items:center;gap:9px;font-family:var(--ff-label);letter-spacing:3px;font-size:14px;color:var(--gold-3);border:1px solid var(--edge);padding:7px 16px;border-radius:40px;background:rgba(20,14,4,.5);margin-bottom:26px}
.pulse{width:8px;height:8px;border-radius:50%;background:var(--green-2);box-shadow:0 0 10px var(--green-2);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}
.hero-logo{width:min(660px,88vw);margin:0 auto;filter:drop-shadow(0 18px 40px rgba(0,0,0,.7)) drop-shadow(0 0 30px rgba(245,197,24,.25));animation:logoFloat 7s ease-in-out infinite;will-change:transform}
@keyframes logoFloat{0%,100%{transform:translateY(0) rotate(-.6deg)}50%{transform:translateY(-14px) rotate(.6deg)}}
.hero-drip{width:min(560px,80vw);height:34px;margin:-6px auto 0;color:var(--green-2)}
.hero-drip svg{width:100%;height:100%;fill:currentColor;filter:drop-shadow(0 6px 10px rgba(92,255,31,.4));animation:dripPulse 4s ease-in-out infinite}
@keyframes dripPulse{0%,100%{transform:scaleY(1)}50%{transform:scaleY(1.35)}}
.hero-tag{font-family:var(--ff-tag);font-size:clamp(30px,7vw,64px);letter-spacing:2px;line-height:1;margin:18px 0 6px;text-shadow:0 4px 0 rgba(0,0,0,.4)}
.grease-word{color:transparent;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 2px 6px rgba(245,197,24,.4))}
.green-word{color:transparent;background:var(--green-grad);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 2px 8px rgba(92,255,31,.45))}
.hero-lede{max-width:620px;margin:16px auto 30px;color:var(--txt-dim);font-size:clamp(15px,2.3vw,19px)}
.hero-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--txt-faint);font-family:var(--ff-label);letter-spacing:3px;font-size:12px}
.cue-line{width:1.5px;height:44px;background:rgba(245,197,24,.2);overflow:hidden;position:relative}
.cue-line i{position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--gold-2);animation:cueRun 1.8s ease-in-out infinite}
@keyframes cueRun{0%{top:-50%}100%{top:100%}}

/* ================= MARQUEE ================= */
.marquee{position:relative;z-index:3;overflow:hidden;border-top:2px solid var(--gold-1);border-bottom:2px solid var(--gold-1);
  background:linear-gradient(90deg,#1a1206,#0d0a04,#1a1206);transform:rotate(-1.4deg);width:104%;margin:40px -2% ;padding:14px 0}
.marquee-row{display:flex;width:max-content;animation:scrollX 26s linear infinite}
.marquee-row span{font-family:var(--ff-head);font-size:clamp(20px,3.4vw,34px);letter-spacing:2px;white-space:nowrap;color:transparent;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;padding-right:8px}
.marquee-row b{color:var(--green-2);-webkit-text-fill-color:var(--green-2)}
@keyframes scrollX{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee:hover .marquee-row{animation-play-state:paused}

/* ================= SECTION SHELLS ================= */
section{position:relative;z-index:3;padding:clamp(70px,10vw,130px) clamp(18px,5vw,80px)}
.section-tag{font-family:var(--ff-label);letter-spacing:4px;font-size:14px;color:var(--green-2);margin-bottom:14px}
.section-title{font-family:var(--ff-head);font-size:clamp(38px,7vw,82px);line-height:.95;letter-spacing:1px;text-transform:uppercase}
.gold-text{color:transparent;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 2px 10px rgba(245,197,24,.3))}
.section-lede{color:var(--txt-dim);max-width:560px;margin-top:16px;font-size:clamp(15px,2.2vw,18px)}

/* ---------- SYNDICATE ---------- */
.syndicate{max-width:1100px;margin:0 auto;text-align:center}
.manifesto{font-family:var(--ff-head);font-size:clamp(28px,5vw,58px);line-height:1.08;text-transform:uppercase;letter-spacing:.5px;max-width:960px;margin:8px auto 0}
.manifesto em{font-style:normal;color:transparent;background:var(--green-grad);-webkit-background-clip:text;background-clip:text}
.stats{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(24px,6vw,80px);margin-top:56px}
.stat b{display:block;font-family:var(--ff-head);font-size:clamp(46px,8vw,84px);line-height:1;color:transparent;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text}
.stat span{font-family:var(--ff-label);letter-spacing:2px;color:var(--txt-faint);font-size:15px}

/* ---------- FAMILIES ---------- */
.families{max-width:1280px;margin:0 auto}
.fam-head{text-align:center;margin-bottom:54px}
.fam-head .section-lede{margin-inline:auto}
.fam-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px}
.fam-card{position:relative;border-radius:14px;overflow:hidden;background:linear-gradient(180deg,#161009,#0b0805);
  border:1px solid rgba(245,197,24,.12);transform-style:preserve-3d;transition:transform .3s,box-shadow .4s,border-color .4s;will-change:transform}
.fam-card::before{content:"";position:absolute;inset:0;border-radius:14px;padding:1px;
  background:linear-gradient(140deg,var(--acc),transparent 45%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.5;transition:opacity .4s}
.fam-card:hover{box-shadow:0 30px 60px rgba(0,0,0,.6),0 0 40px -8px var(--acc);border-color:transparent}
.fam-card:hover::before{opacity:1}
.fam-media{aspect-ratio:1/1;overflow:hidden;background:#000;position:relative}
.fam-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.8,.2,1);transform:scale(1.02)}
.fam-card:hover .fam-media img{transform:scale(1.12)}
.fam-card[data-fam="outlaws"] .fam-media img{object-fit:cover;object-position:center}
.locked-media{display:grid;place-items:center;aspect-ratio:1/1;
  background:repeating-linear-gradient(45deg,#0d0a05,#0d0a05 14px,#120d06 14px,#120d06 28px)}
.locked-media .lock{font-size:52px;filter:grayscale(1) drop-shadow(0 0 14px rgba(255,45,45,.4));opacity:.7}
.locked .fam-media::after{content:"CLASSIFIED";position:absolute;inset:0;display:grid;place-items:center;font-family:var(--ff-head);font-size:26px;color:rgba(255,45,45,.14);letter-spacing:6px;transform:rotate(-16deg)}
.fam-body{padding:20px 20px 24px}
.fam-status{font-family:var(--ff-label);letter-spacing:2px;font-size:12px;color:var(--red);display:inline-block;margin-bottom:8px}
.made-tag{color:var(--green-2);text-shadow:0 0 12px rgba(92,255,31,.6)}
.fam-body h3{font-family:var(--ff-head);font-size:clamp(21px,2.6vw,27px);letter-spacing:.5px;line-height:1;text-transform:uppercase}
.fam-role{font-family:var(--ff-label);letter-spacing:1.6px;font-size:13px;color:var(--gold-3);margin:7px 0 10px}
.fam-desc{color:var(--txt-dim);font-size:14.5px;line-height:1.5}
.fam-open{display:inline-block;margin-top:14px;font-family:var(--ff-label);letter-spacing:2px;font-size:14px;color:var(--green-2);opacity:0;transform:translateX(-6px);transition:opacity .3s,transform .3s}
.fam-card.made:hover .fam-open{opacity:1;transform:none}
.fam-card.locked{filter:saturate(.7)}

/* ---------- GODFATHER DROP ---------- */
.drop{overflow:hidden}
.drop-bg{position:absolute;inset:0;z-index:-1;
  background:radial-gradient(70% 60% at 20% 30%,rgba(120,70,10,.22),transparent 60%),radial-gradient(60% 50% at 90% 80%,rgba(40,90,20,.16),transparent 60%)}
.drop-head{text-align:center;margin-bottom:48px}
.drop-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,70px);align-items:center;max-width:1200px;margin:0 auto}
.jar-stage{position:relative;border-radius:16px;overflow:hidden;background:#000;aspect-ratio:4/5;box-shadow:var(--shadow),0 0 60px -14px rgba(255,150,40,.4)}
.jar-video{width:100%;height:100%;object-fit:cover}
.jar-glow{position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 50% 55%,transparent 40%,rgba(0,0,0,.5) 100%);mix-blend-mode:multiply}
.jar-thumbs{display:flex;gap:10px;margin-top:14px}
.jar-thumbs img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:8px;background:#000;border:1px solid rgba(245,197,24,.14);opacity:.55;transition:opacity .3s,border-color .3s,transform .3s;cursor:none}
.jar-thumbs img:hover,.jar-thumbs img.active{opacity:1;border-color:var(--gold-2);transform:translateY(-3px)}
.drop-boss{font-family:var(--ff-marker);font-size:clamp(20px,3vw,30px);color:var(--gold-3);display:block;margin-bottom:16px;transform:rotate(-1.5deg)}
.drop-story{color:var(--txt-dim);font-size:clamp(15px,2vw,17.5px);margin-bottom:16px;line-height:1.7}
.drop-story b{color:var(--gold-3);font-weight:500}
.drop-callout{margin:22px 0;font-family:var(--ff-tag);font-size:clamp(24px,4vw,40px);line-height:1;display:flex;flex-direction:column}
.drop-meta{display:flex;gap:26px;flex-wrap:wrap;margin-top:22px;border-top:1px solid var(--edge);padding-top:20px}
.drop-meta b{display:block;font-family:var(--ff-label);letter-spacing:2px;font-size:12px;color:var(--txt-faint)}
.drop-meta span{font-family:var(--ff-body);font-weight:500;color:var(--txt)}

/* ---------- THE CODE ---------- */
.code{max-width:1000px;margin:0 auto}
.code-head{text-align:center;margin-bottom:48px}
.code-head .section-lede{margin-inline:auto}
.code-list{list-style:none;display:grid;gap:14px}
.code-item{display:flex;align-items:center;gap:22px;padding:22px 26px;border-radius:12px;
  background:linear-gradient(100deg,rgba(22,16,9,.9),rgba(9,7,4,.6));border:1px solid rgba(245,197,24,.1);
  transition:border-color .3s,transform .3s,box-shadow .3s}
.code-item:hover{border-color:var(--edge);transform:translateX(8px);box-shadow:-6px 0 0 0 var(--green-2)}
.code-num{font-family:var(--ff-head);font-size:clamp(34px,5vw,54px);line-height:1;min-width:64px;color:transparent;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text}
.code-item h4{font-family:var(--ff-head);font-size:clamp(19px,2.6vw,26px);letter-spacing:.5px;text-transform:uppercase}
.code-item p{color:var(--txt-dim);font-size:15px;margin-top:2px}

/* ---------- VAULT ---------- */
.vault{max-width:1280px;margin:0 auto}
.vault-head{text-align:center;margin-bottom:44px}
.vault-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.vault-clip{position:relative;border-radius:14px;overflow:hidden;background:#000;aspect-ratio:16/10;border:1px solid rgba(245,197,24,.1)}
.vault-clip.big{grid-row:span 2;aspect-ratio:auto}
.vault-clip video{width:100%;height:100%;object-fit:cover;filter:brightness(.82) saturate(1.1);transition:filter .4s,transform .6s}
.vault-clip:hover video{filter:brightness(1) saturate(1.2);transform:scale(1.05)}
.vault-clip figcaption{position:absolute;left:0;bottom:0;right:0;padding:26px 20px 16px;font-family:var(--ff-label);letter-spacing:2px;color:var(--gold-3);
  background:linear-gradient(transparent,rgba(0,0,0,.85))}
.vault-clip::after{content:"";position:absolute;inset:0;border-radius:14px;box-shadow:inset 0 0 0 1px rgba(245,197,24,0);transition:box-shadow .4s}
.vault-clip:hover::after{box-shadow:inset 0 0 0 1px var(--edge),inset 0 0 40px rgba(245,197,24,.12)}
@media(max-width:720px){.vault-grid{grid-template-columns:1fr}.vault-clip.big{grid-row:auto}}

/* ---------- CONNECT ---------- */
.connect{text-align:center;overflow:hidden}
.connect-glow{position:absolute;inset:0;z-index:-1;
  background:radial-gradient(50% 60% at 50% 40%,rgba(245,197,24,.14),transparent 70%),radial-gradient(40% 50% at 50% 90%,rgba(92,255,31,.1),transparent 70%)}
.connect-inner{max-width:720px;margin:0 auto}
.connect-title{font-family:var(--ff-head);font-size:clamp(38px,8vw,90px);line-height:.95;text-transform:uppercase;margin-bottom:18px}
.connect-lede{color:var(--txt-dim);font-size:clamp(15px,2.2vw,19px);margin-bottom:32px;max-width:560px;margin-inline:auto}
.list-form{display:flex;gap:10px;max-width:520px;margin:26px auto 0;flex-wrap:wrap}
.list-form input{flex:1;min-width:220px;padding:15px 18px;border-radius:2px;border:1.5px solid var(--edge);background:rgba(10,8,4,.8);color:var(--txt);font-family:var(--ff-body);font-size:15px;cursor:none}
.list-form input:focus{outline:none;border-color:var(--gold-2);box-shadow:0 0 20px rgba(245,197,24,.2)}
.list-form input::placeholder{color:var(--txt-faint)}
.list-msg{min-height:22px;margin-top:14px;font-family:var(--ff-label);letter-spacing:1.5px;color:var(--green-2)}

/* ================= FOOTER ================= */
.footer{position:relative;z-index:3;text-align:center;padding:60px 20px 40px;border-top:1px solid var(--edge);background:linear-gradient(180deg,transparent,rgba(8,6,3,.9))}
.foot-logo{width:150px;margin:0 auto 14px;opacity:.9}
.foot-tag{font-family:var(--ff-tag);font-size:clamp(18px,3vw,26px);letter-spacing:2px;color:transparent;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;margin-bottom:20px}
.foot-links{display:flex;gap:26px;justify-content:center;flex-wrap:wrap;margin-bottom:22px}
.foot-links a{font-family:var(--ff-label);letter-spacing:2px;color:var(--txt-dim);font-size:15px;transition:color .3s}
.foot-links a:hover{color:var(--gold-2)}
.foot-fine{color:var(--txt-faint);font-size:12.5px;max-width:620px;margin:0 auto 12px;letter-spacing:.3px}
.foot-copy{color:var(--txt-faint);font-size:12px;letter-spacing:1px}

/* ================= REVEAL ANIMATIONS ================= */
.reveal{opacity:0;transform:translateY(38px);filter:blur(6px);transition:opacity .9s cubic-bezier(.2,.8,.2,1),transform .9s cubic-bezier(.2,.8,.2,1),filter .9s}
.reveal.in{opacity:1;transform:none;filter:none}
.reveal-words span.w{display:inline-block;opacity:0;transform:translateY(18px) rotate(4deg);transition:opacity .6s,transform .6s}
.reveal-words.in span.w{opacity:1;transform:none}
.fam-card{opacity:0;transform:translateY(40px)}
.fam-card.in{opacity:1;transform:none;transition:opacity .7s,box-shadow .4s,border-color .4s}
.code-item{opacity:0;transform:translateX(-30px)}
.code-item.in{opacity:1;transform:none;transition:opacity .7s,transform .7s,border-color .3s,box-shadow .3s}

/* ================= RESPONSIVE ================= */
@media(max-width:860px){
  .drop-grid{grid-template-columns:1fr}
  .jar-stage{max-width:440px;margin:0 auto}
  .manifesto{font-size:clamp(24px,7vw,40px)}
}

/* ---- MOBILE PERF + FIT ---- */
@media(max-width:900px){
  .grain{display:none}                 /* feTurbulence + blend is a phone GPU killer */
  .hero-video{transform:scale(1.04)}
  section{padding-left:clamp(16px,5vw,80px);padding-right:clamp(16px,5vw,80px)}
}
@media(max-width:600px){
  .hero{padding-top:104px}
  .hero-kicker{font-size:10.5px;letter-spacing:1.4px;padding:6px 12px;gap:7px;max-width:calc(100vw - 32px)}
  .hero-lede{font-size:15px}
  .stats{gap:22px 34px}
  .stat b{font-size:clamp(42px,15vw,60px)}
  .fam-grid{gap:16px}
  .code-item{gap:14px;padding:18px 18px}
  .code-num{min-width:44px}
  .code-item:hover{transform:none}     /* no sideways shove that could overflow on touch */
  .drop-meta{gap:18px}
  .list-form input{min-width:0}
  .marquee-row span{font-size:22px}
  .foot-links{gap:18px}
}
/* kill hover-only motion on touch devices so nothing shifts off-screen */
@media(hover:none){
  .code-item:hover{transform:none;box-shadow:none;border-color:rgba(245,197,24,.1)}
  .fam-card:hover{transform:none}
  .btn:hover{transform:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;animation-iteration-count:1!important;transition-duration:.15s!important;scroll-behavior:auto}
  .reveal,.fam-card,.code-item{opacity:1;transform:none;filter:none}
}
