/* =========================================================
   MineRaid · TRIBES · "COLD OPEN"
   Display: Chakra Petch · Numerals: Oxanium · Body: Sora
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Chakra+Petch:wght@500;600;700&family=Oxanium:wght@500;600;700;800&family=Sora:wght@300;400;500;600&display=swap');

:root{
  --powder:#FBFCFA; --aqua:#55FFFF; --ice:#8EEBFF; --cyan:#00CFFF;
  --navy:#061126; --raid:#0A1F44; --shadow:#020817;
  --steel:#6F86A6; --muted:#9DB0C6; --body:#C2D2E4;
  --line:rgba(142,235,255,.14); --line2:rgba(157,176,198,.14);
  --realm-accent:#55FFFF;            /* retinted by the carousel only */
  /* motion + easing tokens (one language for the whole page) */
  --ease:cubic-bezier(.16,1,.3,1);
  --ease-out:cubic-bezier(.22,.61,.36,1);
  --d1:.25s; --d2:.4s; --d3:.62s; --d4:.9s;
  /* surfaces, radius + gradients */
  --card:rgba(10,28,58,.4); --card-2:rgba(8,24,58,.35);
  --r-sm:11px; --r-md:16px; --r-lg:22px;
  --glow:0 0 22px rgba(85,255,255,.25);
  --grad-ice:linear-gradient(100deg,var(--aqua),var(--cyan));
  --grad-title:linear-gradient(180deg,#fff,#8fe3ff 65%,#2fb0ff);
  --grad-final:linear-gradient(180deg,#fff,#7fdcff);
  /* rhythm */
  --sec-y:clamp(84px,11vw,128px);
  --pad-x:clamp(18px,5vw,40px);
  --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Sora',sans-serif;background:var(--shadow);color:var(--body);
  line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body.boot{overflow:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
h1,h2,h3,h4{font-family:'Chakra Petch',sans-serif;color:var(--powder);line-height:1.02;
  letter-spacing:.5px;text-transform:uppercase}
b,strong{color:var(--powder);font-weight:600}
::selection{background:var(--aqua);color:var(--shadow)}
.num{font-family:'Oxanium',sans-serif;font-variant-numeric:tabular-nums}
/* visible keyboard focus everywhere (never rely on hover/color alone) */
:focus-visible{outline:2px solid var(--aqua);outline-offset:3px;border-radius:5px}
a:focus-visible,button:focus-visible{outline:2px solid var(--aqua);outline-offset:3px}

/* ---- ambient background field + aurora + grain ---- */
.bg-field{position:fixed;inset:0;z-index:-3;
  background:radial-gradient(1200px 760px at 72% -8%,#0b2a5e 0%,transparent 55%),
    radial-gradient(900px 620px at -5% 30%,#08183a 0%,transparent 60%),
    linear-gradient(180deg,#061126,#020817 72%)}
.bg-aurora{position:fixed;inset:-10%;z-index:-2;opacity:.22;pointer-events:none;
  background:url('../assets/img/aurora.webp') center/cover no-repeat;
  mask-image:linear-gradient(180deg,transparent,#000 30%,#000 70%,transparent);
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 30%,#000 70%,transparent);
  animation:auroraDrift 38s linear infinite}
@keyframes auroraDrift{0%{transform:translateX(-3%) scale(1.05)}50%{transform:translateX(3%) scale(1.12)}100%{transform:translateX(-3%) scale(1.05)}}
.bg-grain{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 1.2s steps(3) infinite}
@keyframes grain{0%{transform:translate(0,0)}33%{transform:translate(-4px,3px)}66%{transform:translate(3px,-4px)}}

/* =========================================================
   LOAD SEQUENCE
   ========================================================= */
#boot{position:fixed;inset:0;z-index:9999;background:var(--shadow);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .7s var(--ease),visibility .7s}
#boot.done{opacity:0;visibility:hidden}
#boot .b-logo{width:90px;opacity:0;filter:drop-shadow(0 0 26px rgba(85,255,255,.5));
  animation:bootPulse 1.4s var(--ease) infinite}
@keyframes bootPulse{0%,100%{opacity:.5;transform:scale(.96)}50%{opacity:1;transform:scale(1.02)}}

/* fixed chrome */
#progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:300;
  background:linear-gradient(90deg,var(--aqua),var(--cyan));box-shadow:0 0 14px rgba(85,255,255,.6)}
#cursor{position:fixed;width:360px;height:360px;left:0;top:0;z-index:1;pointer-events:none;
  transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(85,255,255,.10),transparent 62%);opacity:0;transition:opacity .4s}
#hero.in-view ~ #cursor,#hero:hover~#cursor{opacity:1}

/* toast */
#toast{position:fixed;left:50%;bottom:30px;z-index:400;transform:translate(-50%,160%);
  display:flex;align-items:center;gap:9px;padding:13px 20px;border-radius:12px;font-weight:600;font-size:14px;
  color:var(--powder);background:linear-gradient(180deg,#0c2348,#061126);border:1px solid var(--line);
  box-shadow:0 16px 44px rgba(0,0,0,.55),0 0 22px rgba(85,255,255,.25);transition:transform .5s var(--ease)}
#toast.show{transform:translate(-50%,0)}
#toast svg{color:var(--aqua)}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:'Chakra Petch';font-weight:600;
  font-size:14px;letter-spacing:1px;text-transform:uppercase;padding:13px 22px;border-radius:11px;
  cursor:pointer;border:1px solid transparent;position:relative;overflow:hidden;
  transition:transform .3s var(--ease),box-shadow .3s,background .3s,color .3s,border-color .3s}
.btn svg{flex:none}
.btn-ghost{background:rgba(142,235,255,.05);border-color:var(--line);color:var(--ice)}
.btn-ghost:hover{background:rgba(142,235,255,.12);border-color:var(--aqua);color:var(--powder);transform:translateY(-2px)}
.btn:disabled{opacity:.6;cursor:not-allowed}

/* command CTA */
.cmd{font-family:'Chakra Petch';font-weight:700;letter-spacing:2px;text-transform:uppercase;
  font-size:15px;color:var(--powder);padding:17px 30px;border-radius:13px;cursor:pointer;position:relative;
  background:linear-gradient(180deg,rgba(12,33,72,.85),rgba(6,17,38,.9));
  border:1px solid transparent;
  background-clip:padding-box;
  box-shadow:0 0 0 1px rgba(142,235,255,.25),inset 0 0 22px rgba(85,255,255,.10),0 16px 40px rgba(0,0,0,.45);
  transition:transform .3s var(--ease),box-shadow .35s}
.cmd::before{content:"";position:absolute;inset:0;border-radius:13px;padding:1px;pointer-events:none;
  background:linear-gradient(120deg,var(--ice),var(--cyan),transparent 60%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude}
.cmd::after{content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.35),transparent);
  transform:skewX(-18deg);animation:sheen 5.5s ease-in-out infinite}
.cmd:hover{transform:translateY(-3px);box-shadow:0 0 0 1px var(--aqua),inset 0 0 30px rgba(85,255,255,.22),0 22px 54px rgba(0,180,255,.35)}
.cmd:hover::after{animation:sheenFire .7s ease forwards}
.cmd span{position:relative;z-index:2;display:inline-flex;align-items:center;gap:10px}
@keyframes sheen{0%,82%,100%{left:-60%}90%{left:130%}}
@keyframes sheenFire{from{left:-60%}to{left:130%}}
.cmd-lg{font-size:18px;padding:20px 38px}

/* copy-ip pill */
.ip-pill{display:inline-flex;align-items:center;gap:10px;font-family:'Oxanium';font-weight:600;
  letter-spacing:1px;font-size:14px;color:var(--ice);padding:11px 18px;border-radius:30px;cursor:pointer;
  background:rgba(8,24,58,.55);border:1px solid var(--line);transition:.3s var(--ease);position:relative;overflow:hidden}
.ip-pill:hover{border-color:var(--aqua);color:var(--powder);transform:translateY(-2px)}
.ip-pill svg{color:var(--aqua)}
.ip-pill.copied{color:#021;background:linear-gradient(135deg,var(--aqua),var(--cyan));border-color:transparent}
.ip-pill.copied svg{color:#021}

/* =========================================================
   NAV  (logo docks here on scroll)
   ========================================================= */
#nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;
  padding:20px clamp(18px,5vw,46px);transition:padding .35s,background .35s,backdrop-filter .35s,border-color .35s;
  border-bottom:1px solid transparent}
#nav.scrolled{padding:12px clamp(18px,5vw,46px);background:rgba(4,9,22,.8);backdrop-filter:blur(16px);border-bottom-color:var(--line)}
.nav-slot{display:flex;align-items:center;min-width:200px;height:34px}
.nav-slot img{height:0;opacity:0;transition:height .4s var(--ease),opacity .35s}
#nav.scrolled .nav-slot img{height:30px;opacity:1}
.nav-links{display:flex;gap:28px}
.nav-links a{font-family:'Chakra Petch';font-size:13px;font-weight:500;letter-spacing:1px;text-transform:uppercase;
  color:var(--muted);position:relative;transition:color .25s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--aqua);
  box-shadow:0 0 10px var(--aqua);transition:width .3s var(--ease)}
.nav-links a:hover{color:var(--powder)}
.nav-links a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:12px}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-burger span{width:24px;height:2px;background:var(--powder);border-radius:2px;transition:.3s}

/* =========================================================
   HERO  (4 parallax planes)
   ========================================================= */
#hero{position:relative;min-height:100vh;min-height:100dvh;overflow:hidden;
  display:flex;align-items:center;justify-content:center;text-align:center;perspective:1200px;
  padding:clamp(104px,13vh,140px) 20px 40px}
.plane{position:absolute;inset:-6% -3%;will-change:transform}
.plane img{width:100%;height:112%;object-fit:cover}
.p-far{z-index:-3;opacity:.5}.p-far img{filter:blur(2px) brightness(.7)}
.p-mid{z-index:-2}.p-mid img{opacity:.82}
.p-scrim{position:absolute;inset:0;z-index:-1;
  background:radial-gradient(75% 70% at 50% 42%,transparent,rgba(2,8,23,.72) 80%),
    linear-gradient(180deg,rgba(4,9,22,.55) 0%,rgba(2,8,23,.4) 40%,rgba(2,8,23,.95) 100%)}
.p-fore{position:absolute;left:0;right:0;bottom:-2%;z-index:0;height:40%;
  background:linear-gradient(180deg,transparent,rgba(2,8,23,.9));will-change:transform}
.hero-veil{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.18;
  background-image:linear-gradient(rgba(85,255,255,.5) 1px,transparent 1px),linear-gradient(90deg,rgba(85,255,255,.5) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(60% 55% at 50% 38%,#000,transparent 78%);
  -webkit-mask-image:radial-gradient(60% 55% at 50% 38%,#000,transparent 78%)}
.scanline{position:absolute;left:0;right:0;top:0;height:140px;z-index:3;pointer-events:none;opacity:0;
  background:linear-gradient(180deg,transparent,rgba(85,255,255,.35),transparent);mix-blend-mode:screen}
.scanline.fire{animation:scan 1.3s ease forwards}
@keyframes scan{0%{top:-140px;opacity:.9}100%{top:100%;opacity:0}}

.hero-inner{position:relative;z-index:2;max-width:1000px;padding:0 20px}
.hero-tag{font-family:'Oxanium';font-weight:600;font-size:13px;letter-spacing:5px;color:var(--ice);
  display:inline-flex;align-items:center;gap:10px;margin-bottom:14px;opacity:0;animation:rise .8s var(--ease) .9s forwards}
.hero-tag i{width:24px;height:1px;background:var(--aqua);display:inline-block}
.hero-logo{width:min(82vw,612px);margin:0 auto 2px;filter:drop-shadow(0 18px 50px rgba(0,0,0,.6)) drop-shadow(0 0 30px rgba(85,255,255,.25));
  clip-path:inset(0 100% 0 0);filter:blur(8px);opacity:0;transform:scale(1.08)}
.hero-logo.reveal-logo{animation:logoWipe 1s var(--ease) .35s forwards}
@keyframes logoWipe{to{clip-path:inset(0 0 0 0);filter:blur(0);opacity:1;transform:scale(1)}}
.hero-h1{font-family:'Chakra Petch';font-weight:700;text-transform:uppercase;
  font-size:clamp(36px,6vw,84px);letter-spacing:8px;text-indent:8px;margin-top:0;line-height:.96;
  background:var(--grad-title);-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 6px 22px rgba(0,160,255,.35));
  opacity:0;animation:rise .9s var(--ease) .8s forwards}
.hero-sub{font-size:clamp(15px,1.8vw,18px);color:var(--body);max-width:600px;margin:10px auto 22px;
  opacity:0;animation:rise .8s var(--ease) 1.05s forwards}
.hero-sub b{color:var(--ice)}

/* countdown */
.countdown{display:inline-flex;align-items:flex-start;gap:8px;padding:16px 22px;border-radius:16px;
  background:rgba(6,17,38,.5);border:1px solid var(--line);backdrop-filter:blur(8px);margin-bottom:22px;
  opacity:0;animation:rise .8s var(--ease) 1.2s forwards}
.cd-u{display:flex;flex-direction:column;align-items:center;min-width:62px}
.cd-n{font-family:'Oxanium';font-weight:700;font-size:clamp(30px,4.4vw,46px);color:var(--powder);line-height:1;
  text-shadow:0 0 22px rgba(85,255,255,.3)}
.cd-n.tick{animation:tick .4s var(--ease)}
@keyframes tick{0%{transform:translateY(-26%);opacity:0;filter:blur(3px)}100%{transform:none;opacity:1}}
.cd-l{font-family:'Chakra Petch';font-size:10px;letter-spacing:2px;color:var(--steel);margin-top:7px}
.cd-s{font-family:'Oxanium';font-size:clamp(24px,3.6vw,38px);color:var(--aqua);opacity:.45;line-height:1.25}
.countdown.mini{padding:12px 18px;background:rgba(6,17,38,.4)}
.countdown.mini .cd-n{font-size:clamp(26px,3.6vw,38px)}.countdown.mini .cd-u{min-width:52px}

.hero-cta{display:flex;gap:14px;align-items:center;justify-content:center;flex-wrap:wrap;
  opacity:0;animation:rise .8s var(--ease) 1.35s forwards}
.hero-foot{display:flex;gap:10px;justify-content:center;margin-top:18px;flex-wrap:wrap;
  opacity:0;animation:rise .8s var(--ease) 1.5s forwards}
.ghost-link{font-family:'Chakra Petch';font-size:12px;letter-spacing:1px;text-transform:uppercase;
  color:var(--steel);padding:6px 4px;transition:color .25s}
.ghost-link:hover{color:var(--ice)}
@keyframes rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* =========================================================
   STICKY CTA BAR
   ========================================================= */
#stickybar{position:fixed;left:0;right:0;bottom:0;z-index:180;transform:translateY(120%);
  display:flex;align-items:center;justify-content:center;gap:14px;padding:13px 20px;
  background:rgba(4,9,22,.86);backdrop-filter:blur(16px);border-top:1px solid var(--line);
  transition:transform .5s var(--ease)}
#stickybar.show{transform:translateY(0)}
#stickybar .sb-label{font-family:'Chakra Petch';font-size:13px;letter-spacing:1px;color:var(--muted);text-transform:uppercase}
@media(max-width:620px){#stickybar .sb-label{display:none}}

/* =========================================================
   SECTION SHELL + kinetic reveal
   ========================================================= */
.section{max-width:var(--maxw);margin:0 auto;padding:var(--sec-y) var(--pad-x);position:relative}
/* soft seam between stacked sections so they read as one continuous world */
.section + .section::before,.beat + .section::before,.section + .beat::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:min(620px,72%);height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent)}
.kicker{font-family:'Oxanium';font-weight:600;font-size:12px;letter-spacing:4px;color:var(--aqua);text-transform:uppercase}
.sec-head{margin-bottom:50px;max-width:760px}
.sec-head h2{font-size:clamp(34px,5.4vw,62px);font-weight:700;margin-top:14px}
.sec-head p{margin-top:16px;color:var(--muted);font-size:16px;max-width:560px}
.grad{background:linear-gradient(100deg,var(--aqua),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.hl{color:var(--aqua)}

/* shard reveal */
.reveal{opacity:0;transform:translateY(40px);
  clip-path:polygon(0 0,100% 0,100% 100%,0 100%);
  transition:opacity .9s var(--ease),transform .9s var(--ease),clip-path .9s var(--ease)}
.reveal.shard{clip-path:polygon(0 8%,100% 0,100% 100%,0 92%)}
.reveal.in{opacity:1;transform:none;clip-path:polygon(0 0,100% 0,100% 100%,0 100%)}
.word{display:inline-block;opacity:0;transform:translateY(28px);
  transition:opacity .7s var(--ease),transform .7s var(--ease);transition-delay:var(--wd,0s)}
.in .word{opacity:1;transform:none}

/* stagger engine: grid/list children cascade in when their container enters.
   uses an animation (not a transition) so hover transforms stay instant afterward.
   on animationend each item gets .shown, handing control back to its own hovers. */
.stagger-item{opacity:0}
.stagger.in > .stagger-item{animation:staggerIn var(--d3) var(--ease) both;animation-delay:calc(var(--si,0) * 60ms)}
.stagger-item.shown{animation:none;opacity:1;transform:none}
@keyframes staggerIn{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}

/* =========================================================
   POWER THE CORE
   ========================================================= */
.core{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.core-meter{position:relative;height:380px;border:1px solid var(--line);border-radius:20px;overflow:hidden;--tilt:0deg;
  background:radial-gradient(120% 85% at 50% 0%,rgba(12,30,62,.55),rgba(3,9,22,.9));
  box-shadow:inset 0 0 70px rgba(0,0,0,.55),0 24px 70px rgba(0,0,0,.45)}
.core-meter::after{content:"";position:absolute;inset:0;z-index:5;pointer-events:none;border-radius:20px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),inset 0 -44px 60px rgba(0,40,90,.32),inset 0 0 60px rgba(85,255,255,.05)}
.liquid{position:absolute;left:-5%;right:-5%;bottom:0;height:0;z-index:1;
  background:linear-gradient(180deg,rgba(85,255,255,.4),rgba(0,170,255,.27) 55%,rgba(0,110,255,.2));
  transform-origin:bottom center;transform:rotate(var(--tilt));filter:saturate(1.2);
  transition:height 1.9s var(--ease),transform .6s var(--ease);will-change:height,transform}
.core.in .liquid{height:80%}
.liquid::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(174,224,255,.22),transparent 26%)}
.wave{position:absolute;left:50%;top:0;width:300%;aspect-ratio:1;z-index:1;mix-blend-mode:screen;
  border-radius:42% 45% 47% 44%;background:rgba(85,255,255,.38);
  transform:translate(-50%,-87%);animation:waveSpin 8s linear infinite;will-change:rotate}
.wave.w2{border-radius:47% 43% 45% 46%;background:rgba(0,207,255,.28);transform:translate(-50%,-85%);animation-duration:12s;animation-direction:reverse}
.wave.w3{border-radius:45% 47% 43% 48%;background:rgba(142,235,255,.16);transform:translate(-50%,-89%);animation-duration:17s}
@keyframes waveSpin{to{rotate:360deg}}
.core-crystal{position:absolute;top:24px;left:50%;transform:translateX(-50%);width:92px;z-index:4;
  filter:drop-shadow(0 0 32px rgba(85,255,255,.7));animation:coreBob 4.5s ease-in-out infinite}
@keyframes coreBob{50%{transform:translateX(-50%) translateY(-12px)}}
.core-readout{position:absolute;bottom:22px;left:0;right:0;text-align:center;z-index:4}
.core-readout .num{font-size:46px;font-weight:700;color:var(--powder);text-shadow:0 0 26px rgba(85,255,255,.5)}
.core-readout small{display:block;font-family:'Chakra Petch';font-size:11px;letter-spacing:2px;color:var(--ice);margin-top:4px;text-transform:uppercase}
.core-copy p{font-size:16px;margin-bottom:16px}
.ticks{list-style:none;display:grid;gap:12px;margin-top:18px}
.ticks li{position:relative;padding-left:28px;font-size:15px}
.ticks li::before{content:"";position:absolute;left:0;top:4px;width:16px;height:16px;border-radius:5px;background:linear-gradient(135deg,var(--aqua),var(--cyan))}
.ticks li::after{content:"";position:absolute;left:4px;top:8px;width:6px;height:3px;border-left:2px solid #021;border-bottom:2px solid #021;transform:rotate(-45deg)}

/* telemetry stats (contracts) */
.telemetry{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:8px}
.tcell{padding:22px;border:1px solid var(--line);border-radius:14px;background:rgba(10,28,58,.4)}
.tcell .num{font-size:clamp(30px,4vw,46px);font-weight:700;color:var(--powder)}
.tcell .tu{font-family:'Oxanium';font-size:18px;color:var(--aqua);margin-left:3px}
.tcell p{font-size:13px;color:var(--muted);margin-top:6px;letter-spacing:.3px}

/* contracts feature mini-grid */
.fgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:30px}
.fcard{padding:26px;border:1px solid var(--line);border-radius:16px;background:rgba(10,28,58,.4);transition:border-color .3s,transform .3s}
.fcard:hover{border-color:rgba(85,255,255,.45);transform:translateY(-4px)}
.fcard h3{font-size:19px;margin-bottom:8px}
.fcard p{font-size:14px;color:var(--muted)}
.fcard .fi{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;margin-bottom:16px;
  background:linear-gradient(135deg,rgba(85,255,255,.16),rgba(0,207,255,.06));border:1px solid var(--line)}
.fcard .fi svg{width:24px;height:24px;color:var(--aqua)}

/* =========================================================
   RAID full-bleed parallax beat
   ========================================================= */
.beat{position:relative;height:96vh;min-height:620px;display:flex;align-items:center;overflow:hidden;margin:40px 0}
.beat-bg{position:absolute;inset:-8% 0;z-index:-2;will-change:transform}
.beat-bg img{width:100%;height:116%;object-fit:cover;opacity:.5}
.beat-scrim{position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,rgba(2,8,23,.92),rgba(2,8,23,.45) 60%,transparent),linear-gradient(0deg,rgba(2,8,23,.9),transparent 50%)}
.beat-inner{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,5vw,40px);width:100%}
.beat-inner .copy{max-width:540px}
.beat-inner h2{font-size:clamp(40px,6vw,76px)}
.beat-inner p{margin:18px 0 26px;font-size:17px;color:var(--body)}

/* =========================================================
   CLASS RAIL
   ========================================================= */
.rail{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:4px 2px}
.cls{position:relative;aspect-ratio:3/4.2;
  border:1px solid var(--line);border-radius:18px;overflow:hidden;background:linear-gradient(180deg,#0a1c3a,#050e20);
  transition:transform .4s var(--ease),border-color .4s,filter .4s}
.cls img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.cls::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 32%,rgba(3,9,22,.96))}
.cls .meta{position:absolute;left:0;right:0;bottom:0;padding:20px;z-index:2}
.cls .meta h3{font-size:23px}
.cls .meta span{font-family:'Oxanium';font-size:11px;letter-spacing:2px;color:var(--aqua);text-transform:uppercase}
.cls .meta p{font-size:13px;color:var(--muted);margin-top:9px;max-height:0;overflow:hidden;opacity:0;transition:.45s var(--ease)}
.cls .bar{position:absolute;left:20px;bottom:14px;height:2px;width:0;background:var(--aqua);box-shadow:0 0 10px var(--aqua);z-index:3;transition:width .4s var(--ease)}
.rail:hover .cls{filter:brightness(.6) saturate(.7)}
.rail .cls:hover{filter:brightness(1.08) saturate(1.15);transform:translateY(-6px);border-color:rgba(85,255,255,.5)}
.cls:hover img{transform:scale(1.07)}
.cls:hover .meta p{max-height:80px;opacity:1}
.cls:hover .bar{width:46px}
.class-note{text-align:center;margin-top:22px;color:var(--muted);font-size:15px}

/* =========================================================
   REALM CAROUSEL
   ========================================================= */
.realm{--ra:var(--realm-accent)}
.realm-chips{display:flex;gap:10px;justify-content:center;margin-bottom:26px;flex-wrap:wrap}
.chip{font-family:'Chakra Petch';font-size:13px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);
  padding:10px 20px;border-radius:30px;border:1px solid var(--line);background:rgba(8,24,58,.4);cursor:pointer;
  transition:.3s var(--ease)}
.chip:hover{color:var(--powder)}
.chip.active{color:#021;background:var(--realm-accent);border-color:transparent;box-shadow:0 0 22px color-mix(in srgb,var(--realm-accent) 55%,transparent)}
.stage{position:relative;border:1px solid var(--line);border-radius:22px;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.5);aspect-ratio:3/2;background:#02060f}
.realm-name{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:1;
  font-family:'Chakra Petch';font-weight:700;font-size:clamp(60px,16vw,200px);letter-spacing:6px;
  color:color-mix(in srgb,var(--realm-accent) 22%,transparent);pointer-events:none;user-select:none;
  transition:color .5s}
.slide{position:absolute;inset:0;z-index:2;opacity:0;
  clip-path:polygon(0 0,0 0,0 100%,0 100%);transition:clip-path .6s var(--ease),opacity .4s}
.slide img{width:100%;height:100%;object-fit:cover}
.slide::after{content:"";position:absolute;inset:0;background:radial-gradient(60% 60% at 50% 50%,transparent,rgba(2,8,23,.4))}
.slide.active{opacity:1;clip-path:polygon(0 0,100% 0,100% 100%,0 100%);z-index:3}
.slide.leaving{opacity:1;clip-path:polygon(100% 0,100% 0,100% 100%,100% 100%);z-index:2}
.flash{position:absolute;inset:0;z-index:6;background:linear-gradient(180deg,transparent,rgba(85,255,255,.5),transparent);
  mix-blend-mode:screen;opacity:0;pointer-events:none;height:120px}
.flash.fire{animation:scan .6s ease}
.pins{position:absolute;inset:0;z-index:5;pointer-events:none}
.pin{position:absolute;transform:translate(-50%,-50%);pointer-events:auto}
.pin .dot{width:12px;height:12px;border-radius:50%;background:var(--realm-accent);
  box-shadow:0 0 0 0 color-mix(in srgb,var(--realm-accent) 70%,transparent);animation:ping 2s infinite;cursor:pointer}
@keyframes ping{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--realm-accent) 60%,transparent)}70%{box-shadow:0 0 0 12px transparent}100%{box-shadow:0 0 0 0 transparent}}
.pin .card{position:absolute;left:50%;bottom:20px;transform:translateX(-50%) translateY(8px);
  width:max-content;max-width:200px;padding:9px 13px;border-radius:10px;opacity:0;
  background:rgba(4,11,26,.92);border:1px solid var(--line);backdrop-filter:blur(6px);
  transition:.3s var(--ease);pointer-events:none}
.pin:hover .card{opacity:1;transform:translateX(-50%) translateY(0);border-color:var(--realm-accent)}
.pin .card h4{font-size:13px;color:var(--powder);text-transform:none}
.pin .card p{font-size:11.5px;color:var(--muted);margin-top:3px;line-height:1.4}
.pin.staggered .dot{opacity:0}
.pin.show .dot{opacity:1;transition:opacity .4s var(--ease) var(--pd,0s)}
.realm-desc{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-top:20px;flex-wrap:wrap}
.realm-desc p{font-size:15px;color:var(--muted);max-width:560px}
.realm-arrows{display:flex;gap:10px}
.realm-arrows button{width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:rgba(8,24,58,.5);
  color:var(--ice);cursor:pointer;display:grid;place-items:center;transition:.25s}
.realm-arrows button:hover{border-color:var(--aqua);color:var(--powder)}

/* =========================================================
   MODES (Tribes / Battlegrounds TBA)
   ========================================================= */
.modes{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.mode{position:relative;border:1px solid var(--line);border-radius:22px;overflow:hidden;background:rgba(8,24,58,.35);transition:border-color .35s,transform .35s}
.mode:hover{border-color:rgba(85,255,255,.45);transform:translateY(-4px)}
.mode .mimg{position:relative;height:260px;overflow:hidden}
.mode .mimg img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.mode:hover .mimg img{transform:scale(1.08)}
.mode .mimg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(8,24,58,.96))}
.mode.tba .mimg img{filter:grayscale(.55) brightness(.55)}
.mbody{padding:24px 26px 28px;margin-top:-46px;position:relative}
.mtag{display:inline-flex;align-items:center;gap:7px;font-family:'Chakra Petch';font-size:11px;letter-spacing:2px;
  padding:6px 12px;border-radius:30px;margin-bottom:12px}
.mtag.on{background:rgba(54,224,122,.14);color:#5bf0a0;border:1px solid rgba(54,224,122,.4)}
.mtag.on i{width:8px;height:8px;border-radius:50%;background:#5bf0a0;box-shadow:0 0 8px #5bf0a0;animation:ping 1.6s infinite}
.mtag.soon{background:rgba(142,235,255,.1);color:var(--ice);border:1px solid var(--line);animation:tbaPulse 2.8s ease-in-out infinite}
@keyframes tbaPulse{0%,100%{box-shadow:0 0 0 0 rgba(142,235,255,0)}50%{box-shadow:0 0 0 5px rgba(142,235,255,.07)}}
.mbody h3{font-size:32px;margin-bottom:10px}
.mbody p{font-size:15px;color:var(--muted);margin-bottom:18px;max-width:92%}

/* =========================================================
   FINAL CTA
   ========================================================= */
.final{position:relative;overflow:hidden;text-align:center;padding:var(--sec-y) 20px}
.final-bg{position:absolute;inset:0;z-index:-2;will-change:transform}
.final-bg img{width:100%;height:118%;object-fit:cover;opacity:.4}
.final-scrim{position:absolute;inset:0;z-index:-1;background:radial-gradient(60% 60% at 50% 50%,rgba(6,17,38,.4),rgba(2,8,23,.95))}
.final h2{font-size:clamp(46px,9vw,118px);font-weight:700;letter-spacing:4px;
  background:var(--grad-final);-webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 60px rgba(85,255,255,.3)}
.final .staff-line{margin-top:22px;font-size:14px;color:var(--muted)}
.final .staff-line a{color:var(--ice);font-weight:600;border-bottom:1px solid var(--line);transition:color .25s,border-color .25s}
.final .staff-line a:hover{color:var(--powder);border-color:var(--aqua)}
.final .date{font-family:'Oxanium';font-weight:700;font-size:clamp(22px,4vw,40px);letter-spacing:8px;color:var(--ice);margin:10px 0 24px}
.final p{font-size:16px;color:var(--body);max-width:520px;margin:0 auto 26px}
.final .hero-cta{animation:none;opacity:1}

/* =========================================================
   FOOTER  (minimal, legal, NO owner credit)
   ========================================================= */
#footer{border-top:1px solid var(--line);background:rgba(3,8,18,.7);padding:64px var(--pad-x) 30px}
.foot-top{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:34px}
.foot-brand img{height:48px;margin-bottom:18px;filter:drop-shadow(0 0 18px rgba(85,255,255,.18))}
.foot-brand p{font-size:14px;color:var(--muted);max-width:300px;margin-bottom:18px}
.foot-actions{display:flex;flex-wrap:wrap;gap:10px}
.foot-col h5{font-family:'Chakra Petch';font-size:12px;letter-spacing:2px;color:var(--powder);text-transform:uppercase;margin-bottom:16px}
.foot-col a,.foot-meta{display:block;font-size:14px;color:var(--muted);margin-bottom:10px;transition:color .2s}
.foot-col a:hover{color:var(--aqua)}
.foot-meta b{color:var(--ice)}
/* privacy CTA pill */
.privacy-cta{display:inline-flex;align-items:center;gap:8px;font-family:'Chakra Petch';font-weight:600;font-size:12px;
  letter-spacing:1px;text-transform:uppercase;color:var(--ice);padding:11px 16px;border-radius:30px;
  background:rgba(8,24,58,.55);border:1px solid var(--line);transition:.3s var(--ease)}
.privacy-cta:hover{border-color:var(--aqua);color:var(--powder);transform:translateY(-2px)}
.privacy-cta svg{color:var(--aqua)}
/* developer contact card */
.dev-contact{display:flex;align-items:center;gap:11px;padding:12px 14px;border-radius:var(--r-sm);margin-bottom:12px;
  background:var(--card-2);border:1px solid var(--line);transition:border-color .3s,transform .3s}
.dev-contact:hover{border-color:rgba(85,255,255,.45);transform:translateY(-2px)}
.dev-contact .dc-ic{flex:none;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;
  background:linear-gradient(135deg,rgba(85,255,255,.18),rgba(0,207,255,.06));border:1px solid var(--line)}
.dev-contact .dc-ic svg{width:18px;height:18px;color:var(--aqua)}
.dev-contact .dc-t{display:flex;flex-direction:column;line-height:1.25}
.dev-contact .dc-t small{font-family:'Oxanium';font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--steel)}
.dev-contact .dc-t b{font-size:14px;color:var(--powder)}
.foot-bottom{max-width:var(--maxw);margin:38px auto 0;padding-top:20px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;font-family:'Oxanium';font-size:12px;color:var(--steel)}
.foot-bottom a{color:var(--steel)}.foot-bottom a:hover{color:var(--ice)}

/* =========================================================
   LEGAL PAGE
   ========================================================= */
.legal{max-width:820px;margin:0 auto;padding:140px clamp(18px,5vw,40px) 90px}
.legal h1{font-size:clamp(38px,6vw,64px);margin-bottom:10px}
.legal .upd{font-family:'Oxanium';color:var(--steel);font-size:13px;letter-spacing:1px;margin-bottom:40px}
.legal h2{font-size:22px;margin:36px 0 12px;color:var(--ice)}
.legal p,.legal li{font-size:15px;color:var(--body);line-height:1.8}
.legal ul{margin:10px 0 10px 22px}
.legal a{color:var(--aqua)}
.back-link{font-family:'Chakra Petch';font-size:13px;letter-spacing:1px;color:var(--ice);text-transform:uppercase}

/* =========================================================
   CONTACT PAGE
   ========================================================= */
.subpage #nav .nav-slot img{height:28px;opacity:1}
.nav-links a.active{color:var(--aqua)}
.nav-links a.active::after{width:100%}
.contact-hero{position:relative;min-height:100vh;min-height:100dvh;overflow:hidden;display:flex;align-items:center;
  padding:clamp(118px,15vh,170px) clamp(18px,5vw,40px) 96px}
.contact-bg{position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(96deg,rgba(2,8,23,.97) 0%,rgba(2,8,23,.86) 30%,rgba(2,8,23,.4) 56%,rgba(2,8,23,.06) 100%),
    linear-gradient(0deg,rgba(2,8,23,.92),transparent 32%),
    url('../assets/img/job.webp') right center/cover no-repeat,
    url('../assets/img/hero2.webp') right center/cover no-repeat;
  animation:bgFloat 26s ease-in-out infinite}
@keyframes bgFloat{50%{transform:scale(1.045)}}
.contact-inner{position:relative;max-width:640px;width:100%}
.contact-h1{font-size:clamp(54px,9.5vw,124px);line-height:.9;letter-spacing:2px;text-shadow:0 10px 44px rgba(0,0,0,.6)}
.contact-h1 .grad{background:var(--grad-title);-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 6px 22px rgba(0,160,255,.35))}
.contact-rule{width:124px;height:3px;background:var(--grad-ice);border-radius:3px;margin:26px 0 28px;box-shadow:var(--glow)}
.contact-sub{font-size:clamp(16px,1.9vw,19px);color:var(--body);max-width:520px;margin-bottom:34px;line-height:1.7}
.contact-sub b{color:var(--ice)}
.contact-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-bottom:42px}
.roles{max-width:560px;border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 26px;
  background:rgba(6,17,38,.55);backdrop-filter:blur(10px);box-shadow:0 20px 60px rgba(0,0,0,.4)}
.roles>h4{font-family:'Chakra Petch';font-size:12px;letter-spacing:2.5px;color:var(--ice);text-transform:uppercase;margin-bottom:20px}
.roles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.role .role-ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;margin-bottom:13px;
  background:linear-gradient(135deg,rgba(85,255,255,.16),rgba(0,207,255,.06));border:1px solid var(--line)}
.role .role-ic svg{width:22px;height:22px;color:var(--aqua)}
.role b{display:block;font-family:'Chakra Petch';font-size:14px;color:var(--powder);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.role p{font-size:12.5px;color:var(--muted);line-height:1.5}
@media(max-width:860px){
  .contact-bg{background:
    linear-gradient(180deg,rgba(2,8,23,.8),rgba(2,8,23,.93)),
    url('../assets/img/job.webp') 72% center/cover no-repeat,
    url('../assets/img/hero2.webp') 72% center/cover no-repeat}
  .roles-grid{grid-template-columns:1fr;gap:12px}
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:1024px){
  .core{grid-template-columns:1fr;gap:30px}
  .fgrid,.telemetry{grid-template-columns:repeat(2,1fr)}
  .foot-top{grid-template-columns:1fr 1fr;gap:30px}
  .foot-brand{grid-column:1/-1}
}
@media(max-width:760px){
  .nav-links{display:none}.nav-right .btn-ghost{display:none}.nav-burger{display:flex}
  #nav.open .nav-links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;
    background:rgba(4,9,22,.97);border-bottom:1px solid var(--line)}
  #nav.open .nav-links a{padding:15px 22px;border-bottom:1px solid rgba(255,255,255,.05)}
  .modes,.fgrid,.telemetry{grid-template-columns:1fr}
  .rail{grid-template-columns:repeat(2,1fr)}
  .foot-top{grid-template-columns:1fr}
  .beat{height:auto;padding:80px 0}
  .beat-bg img{height:100%}
  /* tap targets >=44px on touch */
  .foot-col a{min-height:44px;display:flex;align-items:center}
  .ip-pill,.privacy-cta,.ghost-link,.back-link,.realm-arrows button{min-height:44px}
  .ghost-link{display:inline-flex;align-items:center}
}

@media(max-width:480px){
  .countdown{gap:4px;padding:12px 12px}
  .countdown .cd-u{min-width:48px}
  .countdown .cd-s{font-size:22px}
  .cd-l{font-size:9px;letter-spacing:1px}
  .hero-tag{font-size:11px;letter-spacing:3px}
  .sec-head{margin-bottom:38px}
  .telemetry{gap:12px}
  .tcell{padding:18px}
  .core-meter{height:300px}
  .mbody h3{font-size:26px}
  .final .date{letter-spacing:5px}
  .foot-bottom{justify-content:center;text-align:center}
}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .bg-aurora,.bg-grain,.cmd::after,.mtag.soon,.mtag.on i,.scanline{animation:none}
  .hero-logo{clip-path:none;filter:none;opacity:1;transform:none}
  .hero-h1{opacity:1!important;animation:none!important}
  .reveal{opacity:1;transform:none;clip-path:none}.word{opacity:1;transform:none}
  /* safety net: keep stagger children visible when motion is reduced */
  .stagger-item{opacity:1!important;transform:none!important;animation:none!important}
  #cursor{display:none}
}
