:root{
  --bg:#0d0726;
  --bg2:#1a0d40;
  --cyan:#34e7ff;
  --purple:#9b5cff;
  --pink:#ff5cc8;
  --gold:#ffd166;
  --text:#eaf0ff;
  --muted:#9aa3c7;
  --glass:rgba(20,12,48,0.45);
  --maxw:1200px;
  --font:'Segoe UI',system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font);
  background:radial-gradient(ellipse at 50% 0%, #241155 0%, var(--bg2) 38%, var(--bg) 100%);
  background-attachment:fixed;
  color:var(--text);
  overflow-x:hidden;
  line-height:1.6;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ---------- WebGL canvas ---------- */
#space-canvas{
  position:fixed;inset:0;width:100%;height:100%;
  z-index:0;display:block;
}
#parallax-layer{
  position:fixed;inset:0;z-index:1;pointer-events:none;overflow:hidden;
}
.astro-float{
  position:absolute;width:clamp(90px,11vw,190px);
  will-change:transform;
}
.astro-drift{
  width:100%;will-change:transform;
  animation:astrodrift var(--dur,16s) ease-in-out infinite;
  animation-delay:var(--delay,0s);
}
.astro-float img{
  display:block;width:100%;
  filter:drop-shadow(0 0 22px rgba(52,231,255,.45));
  opacity:.85;will-change:transform;
  animation:astrospin var(--sdur,52s) linear infinite;
}
@keyframes astrodrift{
  0%  {transform:translate(0,0)}
  25% {transform:translate(3.5vw,-2.5vh)}
  50% {transform:translate(-1.5vw,-5vh)}
  75% {transform:translate(-4vw,-1.5vh)}
  100%{transform:translate(0,0)}
}
@keyframes astrospin{ from{transform:rotate(0)} to{transform:rotate(360deg)} }
@media (prefers-reduced-motion:reduce){ .astro-drift,.astro-float img{animation:none} }
.ship-fly{
  position:absolute;left:0;pointer-events:none;will-change:transform;
  animation:shipfly var(--dur,55s) linear infinite;
  animation-delay:var(--delay,0s);
}
.ship-bob{
  will-change:transform;transform-origin:50% 50%;
  animation:shipbob var(--bdur,4s) ease-in-out infinite;
}
.ship-fly img{
  display:block;width:100%;
  transform:scaleX(var(--flip,1));
  opacity:.85;
}
@keyframes shipfly{
  0%  {transform:translateX(-22vw)}
  100%{transform:translateX(122vw)}
}
/* pitch + roll, like the ship is steering through space */
@keyframes shipbob{
  0%,100%{transform:translateY(0)    rotate(-7deg)}
  50%    {transform:translateY(-16px) rotate(7deg)}
}
@media (prefers-reduced-motion:reduce){
  .ship-fly{animation:none;display:none}
  .ship-bob{animation:none}
}

/* ---------- Intro ---------- */
#intro{
  position:fixed;inset:0;z-index:100;
  background:radial-gradient(circle at 50% 40%,#10052e,#05010f 70%);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .8s ease,visibility .8s;
}
#intro.hidden{opacity:0;visibility:hidden}
.intro-inner{text-align:center;width:min(90vw,420px)}
.intro-logo{width:130px;margin:0 auto 28px;animation:floaty 3s ease-in-out infinite}
.intro-bar{height:4px;background:rgba(255,255,255,.12);border-radius:99px;overflow:hidden}
#intro-fill{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--cyan),var(--purple));transition:width .3s}
.intro-text{margin-top:16px;letter-spacing:.32em;font-size:.72rem;color:var(--muted)}
#enter-btn{
  margin-top:26px;padding:14px 34px;border:1px solid var(--cyan);
  background:transparent;color:var(--cyan);letter-spacing:.22em;font-size:.8rem;
  border-radius:99px;cursor:pointer;transition:.3s;
  box-shadow:0 0 22px rgba(52,231,255,.25);
}
#enter-btn:hover{background:var(--cyan);color:#04101a;box-shadow:0 0 40px rgba(52,231,255,.6)}

/* ---------- Nav ---------- */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px clamp(16px,4vw,48px);
  background:linear-gradient(180deg,rgba(5,1,15,.85),transparent);
  transition:background .3s;
}
#nav.solid{background:rgba(5,1,15,.82);backdrop-filter:blur(12px);border-bottom:1px solid rgba(155,92,255,.18)}
.nav-brand{display:flex;align-items:center;gap:12px;font-weight:700;letter-spacing:.16em;font-size:.82rem}
.nav-brand img{width:34px}
.nav-links{display:flex;align-items:center;gap:clamp(14px,2vw,30px);font-size:.84rem;letter-spacing:.08em}
.nav-links a{color:var(--muted);transition:.2s}
.nav-links a:hover{color:var(--text)}
.nav-cta{
  padding:9px 18px;border-radius:99px;color:#04101a!important;
  background:linear-gradient(90deg,var(--cyan),var(--purple));font-weight:600;
  box-shadow:0 0 20px rgba(52,231,255,.35);
}
.nav-cta:hover{filter:brightness(1.1)}

/* ---------- Layout ---------- */
main{position:relative;z-index:2}
.section{max-width:var(--maxw);margin:0 auto;padding:clamp(70px,12vh,140px) clamp(18px,4vw,40px)}
.eyebrow{letter-spacing:.34em;font-size:.7rem;color:var(--cyan);margin-bottom:14px;text-transform:uppercase}
.section-head{text-align:center;max-width:680px;margin:0 auto 56px}
.section-head h2{font-size:clamp(2rem,5vw,3.4rem);letter-spacing:.04em;line-height:1.05}
.section-lead{color:var(--muted);margin-top:16px}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:100vh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;
  padding:0 18px;
}
.hero-content{max-width:780px}
/* Cinematic cadet video — right side, dropped low, full character in frame */
.hero-video-card{
  position:absolute;right:clamp(14px,5vw,72px);bottom:26px;z-index:1;
  height:min(56vh,520px);aspect-ratio:3/5;   /* matches the video's native frame — no crop */
  border-radius:18px;overflow:hidden;
  border:1px solid rgba(52,231,255,.35);
  box-shadow:0 0 44px rgba(155,92,255,.35), 0 18px 60px rgba(0,0,0,.55);
  pointer-events:none;
}
.hero-video-card video{
  display:block;width:100%;height:100%;object-fit:cover;
}
@media(max-width:900px){
  /* small screens: tuck it under the words instead of overlapping them */
  .hero-video-card{position:static;margin:26px auto 0;height:min(42vh,360px)}
}
@media(prefers-reduced-motion:reduce){
  .hero-video-card video{display:none}
  .hero-video-card{background:url('/assets/video/hero-poster.jpg') center/cover}
}
.hero-title{
  font-size:clamp(2.8rem,9vw,6.6rem);line-height:.95;letter-spacing:.02em;font-weight:800;
  background:linear-gradient(180deg,#fff 30%,var(--cyan) 75%,var(--purple));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 60px rgba(52,231,255,.18);
  margin:10px 0 22px;
}
.hero-sub{color:var(--muted);font-size:clamp(1rem,2.4vw,1.25rem);max-width:560px;margin:0 auto 36px}
.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.btn{
  padding:15px 32px;border-radius:99px;font-size:.82rem;letter-spacing:.16em;font-weight:600;
  cursor:pointer;transition:.25s;border:1px solid transparent;
}
.btn-primary{background:linear-gradient(90deg,var(--cyan),var(--purple));color:#04101a;box-shadow:0 0 28px rgba(52,231,255,.4)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 48px rgba(155,92,255,.6)}
.btn-ghost{border-color:rgba(255,255,255,.3);color:var(--text)}
.btn-ghost:hover{border-color:var(--cyan);color:var(--cyan);box-shadow:0 0 24px rgba(52,231,255,.3)}
.btn-fest{
  background:linear-gradient(120deg,var(--pink,#ff5cc8),var(--purple) 55%,var(--cyan));
  color:#120018;border:none;box-shadow:0 0 30px rgba(255,92,200,.45);
}
.btn-fest:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 0 52px rgba(255,92,200,.7)}
.nav-fest{
  color:#ffd9f2!important;font-weight:700;
  text-shadow:0 0 14px rgba(255,92,200,.6);
}
.nav-fest:hover{color:#fff!important}
.scroll-hint{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  font-size:.65rem;letter-spacing:.3em;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:10px;
}
.scroll-hint span{width:1px;height:40px;background:linear-gradient(var(--cyan),transparent);animation:scrolldot 2s infinite}

/* ---------- Collections ---------- */
.collections-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px;
}
.col-card{
  position:relative;border-radius:18px;overflow:hidden;cursor:pointer;
  background:var(--glass);border:1px solid rgba(155,92,255,.2);
  backdrop-filter:blur(6px);transition:transform .35s,box-shadow .35s,border-color .35s;
  transform:translateY(30px);opacity:0;
}
.col-card.in{transform:translateY(0);opacity:1}
.col-card:hover{transform:translateY(-8px) scale(1.015);border-color:var(--cyan);box-shadow:0 18px 50px rgba(52,231,255,.25)}
.col-media{aspect-ratio:1/1;overflow:hidden;position:relative}
.col-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.col-card:hover .col-media img{transform:scale(1.08)}
.col-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(5,1,15,.9))}
.col-soon{position:absolute;top:12px;left:12px;z-index:3;padding:5px 11px;border-radius:999px;
  font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:#05010f;
  background:linear-gradient(90deg,var(--gold),var(--pink));box-shadow:0 4px 16px rgba(255,92,200,.4)}
.col-card.is-soon{cursor:default}
.col-card.is-soon:hover{transform:none;border-color:rgba(155,92,255,.2);box-shadow:none}
.col-card.is-soon:hover .col-media img{transform:none}
.col-card.is-soon .col-link{color:var(--muted)}
.col-card.is-soon .col-link::after{content:""}
.col-body{position:relative;padding:18px 20px 22px;margin-top:-46px;z-index:2}
.col-tag{font-size:.62rem;letter-spacing:.26em;color:var(--cyan);text-transform:uppercase}
.col-name{font-size:1.18rem;font-weight:700;margin:6px 0 10px;line-height:1.2}
.col-desc{font-size:.82rem;color:var(--muted);min-height:38px}
.col-link{
  display:inline-flex;align-items:center;gap:8px;margin-top:14px;
  font-size:.74rem;letter-spacing:.14em;color:var(--text);font-weight:600;
}
.col-link::after{content:"→";transition:transform .25s}
.col-card:hover .col-link::after{transform:translateX(5px)}
.col-link{color:var(--cyan)}
.col-stats{display:flex;gap:18px;margin-top:12px}
.col-stats span{display:flex;flex-direction:column;font-size:.64rem;letter-spacing:.12em;color:var(--muted);text-transform:uppercase}
.col-stats b{font-size:1.05rem;color:var(--text);letter-spacing:0}
.cover-fallback{object-fit:contain!important;padding:22%;background:radial-gradient(circle at 50% 40%,#1a0c44,#0a0420)}

/* ---------- Gallery ---------- */
.gallery-strip{display:flex;gap:18px;overflow-x:auto;padding:10px 4px 26px;scroll-snap-type:x mandatory}
.gallery-strip::-webkit-scrollbar{height:8px}
.gallery-strip::-webkit-scrollbar-thumb{background:rgba(155,92,255,.4);border-radius:99px}
.gallery-item{
  flex:0 0 auto;width:300px;aspect-ratio:1/1;border-radius:16px;overflow:hidden;
  scroll-snap-align:center;border:1px solid rgba(155,92,255,.25);position:relative;
}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery-item:hover img{transform:scale(1.07)}

/* ---------- Lore ---------- */
.lore{max-width:1100px}
.lore-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:50px;align-items:center}
.lore-text h2{font-size:clamp(1.8rem,4vw,2.8rem);margin:6px 0 20px;line-height:1.08}
.lore-text p{color:var(--muted);margin-bottom:16px}
.lore-text .btn{margin-top:12px;display:inline-block}
.lore-art img{border-radius:20px;border:1px solid rgba(155,92,255,.3);box-shadow:0 20px 60px rgba(155,92,255,.25);animation:floaty 7s ease-in-out infinite}

/* ---------- Footer ---------- */
#footer{position:relative;z-index:2;text-align:center;padding:60px 20px 110px;border-top:1px solid rgba(155,92,255,.15)}
.footer-logos{display:flex;gap:24px;justify-content:center;align-items:center;margin-bottom:18px}
.footer-logos img{height:40px;width:auto;opacity:.9}
.footer-tag{letter-spacing:.16em;font-size:.78rem;color:var(--text)}
.footer-copy{color:var(--muted);font-size:.74rem;margin-top:8px}

/* ---------- Audio player ---------- */
.audio-player{
  position:fixed;bottom:20px;right:20px;z-index:60;
  display:flex;align-items:center;gap:12px;
  padding:10px 16px 10px 10px;border-radius:99px;
  background:var(--glass);backdrop-filter:blur(14px);
  border:1px solid rgba(52,231,255,.3);box-shadow:0 8px 30px rgba(0,0,0,.5);
}
.audio-toggle,.audio-next{
  width:40px;height:40px;border-radius:50%;border:none;cursor:pointer;
  background:linear-gradient(135deg,var(--cyan),var(--purple));color:#04101a;
  font-size:.9rem;display:grid;place-items:center;transition:.2s;
}
.audio-next{width:34px;height:34px;background:transparent;color:var(--muted);border:1px solid rgba(255,255,255,.2)}
.audio-toggle:hover{filter:brightness(1.15)}
.audio-meta{display:flex;flex-direction:column;gap:4px;min-width:96px;
  background:transparent;border:none;padding:0;cursor:pointer;text-align:left;color:inherit;font:inherit}
.audio-meta:hover #audio-title{color:var(--cyan)}
#audio-title{font-size:.72rem;letter-spacing:.08em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}
.audio-eq{display:flex;gap:3px;align-items:flex-end;height:12px}
.audio-eq i{width:3px;height:4px;background:var(--cyan);border-radius:2px}
.audio-player.playing .audio-eq i{animation:eq .9s ease-in-out infinite}
.audio-eq i:nth-child(2){animation-delay:.15s}
.audio-eq i:nth-child(3){animation-delay:.3s}
.audio-eq i:nth-child(4){animation-delay:.45s}
.audio-eq i:nth-child(5){animation-delay:.6s}

/* volume */
.audio-vol-wrap{display:flex;align-items:center;gap:5px}
.audio-vol-ico{font-size:.78rem;opacity:.7}
.audio-vol{width:64px;height:4px;cursor:pointer;accent-color:var(--cyan);
  -webkit-appearance:none;appearance:none;background:rgba(255,255,255,.2);border-radius:3px}
.audio-vol::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;
  background:var(--cyan);cursor:pointer;box-shadow:0 0 6px rgba(52,231,255,.7)}
.audio-vol::-moz-range-thumb{width:12px;height:12px;border:none;border-radius:50%;background:var(--cyan);cursor:pointer}

/* playlist popup */
.audio-list{position:absolute;bottom:calc(100% + 12px);right:0;width:240px;max-height:46vh;
  overflow-y:auto;padding:8px;border-radius:16px;
  background:rgba(8,6,22,.92);backdrop-filter:blur(16px);
  border:1px solid rgba(52,231,255,.3);box-shadow:0 12px 40px rgba(0,0,0,.6)}
.audio-row{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;
  background:transparent;border:none;border-radius:10px;cursor:pointer;color:var(--muted);
  font:inherit;font-size:.74rem;text-align:left;transition:.15s}
.audio-row:hover{background:rgba(52,231,255,.12);color:#fff}
.audio-row.active{background:linear-gradient(90deg,rgba(52,231,255,.22),rgba(155,92,255,.18));color:#fff}
.audio-row-num{font-size:.62rem;opacity:.6;min-width:18px}
.audio-row-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ---------- Animations ---------- */
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes scrolldot{0%{opacity:0;transform:translateY(-10px)}50%{opacity:1}100%{opacity:0;transform:translateY(10px)}}
@keyframes eq{0%,100%{height:4px}50%{height:12px}}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .nav-links a:not(.nav-cta){display:none}
  .lore-grid{grid-template-columns:1fr;gap:30px}
  .lore-art{order:-1}
}
@media(max-width:480px){
  .audio-meta{display:none}
  .nav-brand span{display:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto}
}

/* ============================================================
   CINEMATIC SECTION BACKGROUNDS
   ============================================================ */
.section, .hero{position:relative}
.section-bg{
  position:absolute; inset:-10% 0 -10% 0; z-index:0;
  background-size:cover; background-position:center;
  pointer-events:none; will-change:transform;
  opacity:.5;
}
.section-bg::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(5,1,15,.42), rgba(5,1,15,.66) 60%, var(--bg));
}
.section-bg.dim::after{
  background:linear-gradient(180deg, rgba(5,1,15,.58), rgba(5,1,15,.74));
}
.hero .section-bg::after{
  background:radial-gradient(circle at 50% 30%, rgba(5,1,15,.25), rgba(5,1,15,.78) 70%, var(--bg));
}
.hero-content, .section-head, .collections-grid, .lore-grid{position:relative; z-index:2}

/* ============================================================
   COSMOS — multi-zoom WebGL gallery
   ============================================================ */
.cosmos-section{padding-bottom:0}
.cosmos{
  position:relative; z-index:2; width:100%; height:82vh; min-height:520px;
  margin-top:28px; border-top:1px solid rgba(52,231,255,.16);
  border-bottom:1px solid rgba(155,92,255,.16);
  overflow:hidden; cursor:grab;
  /* Translucent glass so the floating crew drifts behind the cadet field */
  background:radial-gradient(circle at 50% 50%, rgba(10,6,38,.5), rgba(5,1,15,.72) 75%);
}
.cosmos:active{cursor:grabbing}
#cosmos-canvas{position:absolute; inset:0; width:100%; height:100%; display:block}
.cosmos-hint{
  position:absolute; left:50%; bottom:22px; transform:translateX(-50%);
  z-index:3; letter-spacing:.28em; font-size:.66rem; color:var(--muted);
  display:flex; align-items:center; gap:10px; pointer-events:none;
  background:rgba(5,1,15,.4); padding:8px 16px; border-radius:99px;
  border:1px solid rgba(255,255,255,.08); backdrop-filter:blur(6px);
}
.cosmos-hint span{color:var(--cyan); animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:1}}

.cosmos-focus{
  position:absolute; inset:0; z-index:5;
  display:flex; align-items:center; justify-content:center;
  background:rgba(3,1,12,.72); backdrop-filter:blur(8px);
  opacity:0; transition:opacity .35s ease;
}
.cosmos-focus.show{opacity:1}
.cosmos-focus[hidden]{display:none}
.focus-card{
  display:flex; gap:28px; align-items:center; max-width:760px; padding:24px;
  flex-wrap:wrap; justify-content:center;
}
.focus-card img{
  width:min(46vw,340px); border-radius:18px;
  box-shadow:0 0 60px rgba(52,231,255,.4), 0 0 120px rgba(155,92,255,.25);
  border:1px solid rgba(255,255,255,.14);
  animation:focusIn .5s cubic-bezier(.2,.8,.2,1);
}
@keyframes focusIn{from{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}
.focus-info{text-align:left; max-width:300px}
.focus-tag{
  display:inline-block; font-size:.66rem; letter-spacing:.22em;
  color:var(--cyan); border:1px solid rgba(52,231,255,.4);
  padding:4px 12px; border-radius:99px; margin-bottom:14px;
}
.focus-info h3{font-size:clamp(1.4rem,3vw,2rem); margin-bottom:18px; line-height:1.1}
.focus-close{
  position:absolute; top:18px; right:20px; z-index:6;
  width:42px; height:42px; border-radius:50%;
  background:rgba(20,12,48,.6); border:1px solid rgba(255,255,255,.2);
  color:var(--text); font-size:1rem; cursor:pointer; transition:.25s;
}
.focus-close:hover{background:var(--pink); color:#fff; transform:rotate(90deg)}
@media(max-width:640px){
  .cosmos{height:70vh}
  .focus-card{gap:16px}
  .focus-info{text-align:center}
}
