/* ============================================================
   Funcell Games — v4 studio-first.
   Minimal + 2.5D: layered parallax cards, video loop, native
   swipe gallery. No WebGL, no scroll hijacking, no pinning.
   Works with JS disabled (reveals gated on .js, native scroll).
   ============================================================ */
:root{
  --bg:#0c0810;
  --bg2:#120a16;
  --bg3:#160d1c;
  --panel:#1c1226;
  --line:#2c1f38;
  --text:#f6f2f8;
  --muted:#a89db4;
  --pink:#ff2e88;
  --pink-deep:#e6197d;
  --pink-btn:#d4156f;
  --gold:#f3c44d;
  --cream:#f4efe7;
  --cream2:#ece5d8;
  --ink:#171019;
  --ink-mut:#6b6070;
  --display:'Anton','Arial Narrow',sans-serif;
  --body:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --wrap:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--body);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img,video{display:block;max-width:100%}
::selection{background:var(--pink);color:#fff}
:focus-visible{outline:2px solid var(--pink);outline-offset:3px;border-radius:4px}
.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 24px}
section{position:relative;padding:clamp(60px,7vw,96px) 0}
section[id]{scroll-margin-top:90px}
.gold{color:var(--gold)}

/* ---------- preloader ---------- */
.pre{position:fixed;inset:0;z-index:500;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;
  animation:preFail .4s ease 5s forwards} /* CSS-only failsafe: self-hides even if scripts hang */
@keyframes preFail{to{opacity:0;visibility:hidden}}
.pre.done{display:none;animation:none}
.pre-logo{height:34px;width:auto}
.pre-count{font-family:var(--display);font-size:clamp(3rem,9vw,5.5rem);line-height:1;color:var(--pink)}
.pre-bar{width:min(320px,60vw);height:2px;background:var(--line);border-radius:2px;overflow:hidden}
.pre-bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--pink),var(--gold))}

/* ---------- chrome ---------- */
.progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:220;background:linear-gradient(90deg,var(--pink),var(--gold))}
.cursor-glow{position:fixed;top:0;left:0;width:540px;height:540px;border-radius:50%;pointer-events:none;z-index:1;transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(255,46,136,.09),transparent 60%);opacity:0;mix-blend-mode:screen}
@media (hover:hover){.cursor-glow{opacity:1}}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--body);font-weight:700;font-size:.95rem;
  padding:.85em 1.65em;border-radius:999px;border:1.5px solid transparent;cursor:pointer;white-space:nowrap;
  transition:transform .2s,box-shadow .25s,background .2s,color .2s,border-color .2s}
.btn-sm{padding:.6em 1.15em;font-size:.85rem}
.btn-pink{background:var(--pink-btn);color:#fff;box-shadow:0 10px 34px -12px var(--pink)}
.btn-pink:hover{transform:translateY(-2px);box-shadow:0 16px 42px -12px var(--pink)}
.btn-ghost{background:rgba(255,255,255,.02);color:var(--text);border-color:rgba(255,255,255,.26);backdrop-filter:blur(4px)}
.btn-ghost:hover{border-color:var(--pink);color:var(--pink);transform:translateY(-2px)}
.play-ico{font-size:.7em;transform:translateY(.5px)}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;width:100%;z-index:200;transition:background .3s,border-color .3s,backdrop-filter .3s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(12,8,16,.78);backdrop-filter:blur(14px);border-bottom-color:var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:78px}
.logo img{height:39px;width:auto}
.nav-links{display:flex;align-items:center;gap:26px}
.nav-links a:not(.btn){font-size:.92rem;color:var(--muted);transition:color .2s}
.nav-links a:not(.btn):hover,.nav-links a:not(.btn).active{color:var(--text)}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav-burger span{width:24px;height:2px;background:var(--text);transition:.3s}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- hero (studio identity + floating game art) ---------- */
.hero{min-height:100svh;display:flex;align-items:center;overflow:hidden;padding:0}
.hero-bg{position:absolute;inset:0;z-index:0;background:
  radial-gradient(900px 600px at 78% 30%,rgba(255,46,136,.14),transparent 60%),
  radial-gradient(700px 500px at 65% 75%,rgba(243,196,77,.08),transparent 60%),
  linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%)}
.grain{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.06;mix-blend-mode:overlay;
  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")}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr 1fr;align-items:center;gap:30px;padding-top:100px;padding-bottom:120px}
.kicker{font-size:.78rem;font-weight:800;letter-spacing:.3em;text-transform:uppercase;color:var(--pink);margin:0 0 20px}
.hero-title{font-family:var(--display);font-weight:400;font-size:clamp(3.6rem,10vw,8.2rem);line-height:.9;margin:0;text-shadow:0 14px 70px rgba(0,0,0,.5)}
.hero-title .line{display:block}
.hero-title em{font-style:normal}
.hero-sub{font-size:clamp(1rem,1.9vw,1.25rem);color:#d9d1e0;margin:26px 0 34px;max-width:480px}
.hero-sub strong{color:#fff;font-weight:600}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* floating cards — 2.5D: JS moves .float-card (scroll+mouse), CSS bobs .fc-img */
.hero-art{position:relative;height:min(560px,62vh)}
.float-card{position:absolute;will-change:transform}
.fc-img{display:block;width:100%;height:100%;border-radius:20px;background:var(--img) center/cover no-repeat;
  border:1px solid rgba(255,255,255,.12);box-shadow:0 30px 70px -25px rgba(0,0,0,.75);
  animation:bob 6s ease-in-out infinite}
.fc-1{width:min(250px,24vw);aspect-ratio:3/4;right:6%;top:24%;z-index:4}
.fc-1 .fc-img{animation-duration:7s}
.fc-2{width:min(150px,14vw);aspect-ratio:1;right:42%;top:6%;z-index:3}
.fc-2 .fc-img{animation-duration:5.6s;animation-delay:-2s}
.fc-3{width:min(120px,11vw);aspect-ratio:1;right:2%;top:2%;z-index:2;opacity:.85}
.fc-3 .fc-img{filter:blur(1.5px);animation-duration:8s;animation-delay:-4s}
.fc-4{width:min(170px,16vw);aspect-ratio:1;right:46%;bottom:10%;z-index:3}
.fc-4 .fc-img{animation-duration:6.4s;animation-delay:-1s}
.fc-5{width:min(155px,15vw);aspect-ratio:1;right:6%;bottom:4%;z-index:3}
.fc-5 .fc-img{animation-duration:7.4s;animation-delay:-3s}
.fc-6{width:min(95px,9vw);aspect-ratio:1;right:30%;top:44%;z-index:1;opacity:.7}
.fc-6 .fc-img{filter:blur(2.5px);animation-duration:9s;animation-delay:-5s}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ticker */
.ticker{position:absolute;left:0;right:0;bottom:0;z-index:3;border-top:1px solid rgba(255,255,255,.1);background:rgba(12,8,16,.55);backdrop-filter:blur(8px);overflow:hidden;padding:14px 0}
.ticker-track{display:flex;white-space:nowrap;animation:tick 28s linear infinite;width:max-content}
.ticker-track span{font-family:var(--display);font-size:.95rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(246,242,248,.75);padding-right:2em}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- stats ---------- */
.stats{background:var(--bg2);border-bottom:1px solid var(--line);padding:0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:64px 24px}
.stat{text-align:center}
.stat-num{font-family:var(--display);font-size:clamp(2.6rem,5vw,4rem);line-height:1}
.stat-label{margin-top:10px;color:var(--muted);font-size:.85rem}

/* ---------- shared type ---------- */
.eyebrow{font-size:.78rem;font-weight:800;letter-spacing:.3em;text-transform:uppercase;color:var(--pink);margin:0 0 16px}
.eyebrow-dark{color:#c1135f}
.section-title{font-family:var(--display);font-weight:400;font-size:clamp(2.2rem,5vw,3.8rem);line-height:1.02;margin:0 0 18px;max-width:20ch}
.section-title.ink{color:var(--ink)}
.lede{font-size:1.1rem;color:#d6cede;max-width:520px;margin:0}
.bg-word{position:absolute;top:20px;right:-30px;z-index:0;font-family:var(--display);font-size:clamp(7rem,22vw,18rem);line-height:1;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.05);pointer-events:none;user-select:none;will-change:transform}

/* ---------- new release ---------- */
.release{background:linear-gradient(180deg,var(--bg2),var(--bg3));overflow:hidden}
.release .wrap{position:relative;z-index:1}
.chip{display:inline-block;background:var(--pink-btn);color:#fff;font-size:.72rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;padding:.5em 1.1em;border-radius:999px;margin:0 0 18px;box-shadow:0 8px 24px -8px var(--pink)}
.release-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(34px,5vw,70px);align-items:center}
.release-title{font-family:var(--display);font-weight:400;font-size:clamp(2.8rem,6vw,5rem);line-height:.95;margin:0 0 8px}
.release-title em{font-style:normal}
.release-tag{font-weight:700;letter-spacing:.05em;text-transform:uppercase;font-size:.92rem;color:var(--gold);margin:0 0 20px}
.release-copy .lede{margin-bottom:24px}
.metric{display:flex;align-items:center;gap:16px;margin:0 0 26px}
.metric-num{font-family:var(--display);font-size:2.8rem;color:var(--gold);line-height:1}
.metric-note{color:var(--muted);font-size:.85rem;line-height:1.4}
.release-cta{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.store-link img{height:42px;width:auto;transition:transform .2s,opacity .2s}
.store-link:hover img{transform:translateY(-2px);opacity:.9}
.reel{position:relative;border-radius:22px;overflow:hidden;border:1px solid var(--line);aspect-ratio:16/9;background:#000;
  box-shadow:0 50px 100px -40px rgba(0,0,0,.9)}
.reel video{width:100%;height:100%;object-fit:cover}

.release{padding-bottom:clamp(52px,6vw,72px)}

/* gallery — native swipe + arrow controls + keyboard-reachable */
.gallery-wrap{position:relative}
.gallery{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;
  padding:44px 24px 6px max(24px,calc((100vw - 1180px)/2 + 24px))}
.gallery::-webkit-scrollbar{display:none}
.gallery:focus-visible{outline:2px solid var(--pink);outline-offset:-6px;border-radius:10px}
.shot{flex:0 0 min(230px,62vw);scroll-snap-align:center;margin:0}
.gal-arrow{position:absolute;top:calc(50% - 14px);transform:translateY(-50%);z-index:3;width:46px;height:46px;border-radius:50%;
  border:1px solid var(--line);background:rgba(12,8,16,.82);backdrop-filter:blur(8px);color:var(--text);font-size:1.7rem;line-height:1;cursor:pointer;
  display:grid;place-items:center;transition:background .2s,border-color .2s,color .2s}
.gal-arrow:hover{border-color:var(--pink);color:var(--pink)}
.gal-prev{left:14px}
.gal-next{right:14px}
@media (max-width:719px){.gal-arrow{display:none}}
.shot figcaption{margin-top:12px;font-size:.85rem;color:var(--muted);text-align:center}
.phone{aspect-ratio:1242/2208;border-radius:26px;overflow:hidden;border:1px solid var(--line);background:#000;
  box-shadow:0 34px 70px -30px rgba(0,0,0,.85),0 0 0 5px rgba(255,255,255,.02)}
.phone img{width:100%;height:100%;object-fit:cover}

/* ---------- coming soon (Plot Twist) ---------- */
.coming{background:var(--bg3);overflow:hidden;padding-top:clamp(52px,6vw,72px)}
.coming-title{font-size:clamp(3.2rem,7.5vw,6.2rem)}
.coming .wrap{position:relative;z-index:1}
.coming-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(34px,5vw,70px);align-items:center}
.coming-grid .pt-media{align-self:center;max-width:580px}
.chip-gold{background:var(--gold);color:#1a1009;box-shadow:0 8px 24px -8px rgba(243,196,77,.6)}
.pt-media{position:relative;border-radius:22px;overflow:hidden;border:1px solid var(--line);aspect-ratio:2/1;background:#000;
  box-shadow:0 50px 100px -40px rgba(0,0,0,.9)}
.pt-media img{width:100%;height:100%;object-fit:cover}
.pt-fallback{display:none;position:absolute;inset:0;flex-direction:column;align-items:center;justify-content:center;line-height:.9;
  font-family:var(--display);font-size:clamp(2.6rem,6vw,4.6rem);letter-spacing:.04em;
  background:linear-gradient(120deg,#3c1052 0%,#a1136c 45%,#ff2e88 70%,#ff7a3c 100%)}
.pt-media.no-art .pt-fallback{display:flex}
.coming-badges{display:flex;gap:12px;flex-wrap:wrap}
.soon-badge{display:inline-flex;align-items:center;gap:.6em;font-size:.85rem;font-weight:600;color:var(--muted);
  border:1px solid var(--line);border-radius:999px;padding:.65em 1.2em}
.soon-badge i{width:7px;height:7px;border-radius:50%;background:var(--gold);animation:soonPulse 1.8s ease-in-out infinite}
@keyframes soonPulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ---------- games ---------- */
.games{background:var(--bg2);overflow:hidden}
.games .wrap{position:relative;z-index:1}
.games-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:250px;gap:16px;margin:40px 0 0}
.game{position:relative;isolation:isolate;border:1px solid var(--line);border-radius:18px;padding:20px;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;
  transition:transform .3s cubic-bezier(.2,.7,.2,1),border-color .3s,box-shadow .3s}
.game::before{content:"";position:absolute;inset:0;z-index:0;background:var(--img) center/cover no-repeat;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.game::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(12,8,16,.04) 30%,rgba(12,8,16,.4) 60%,rgba(8,5,11,.94))}
.game:hover{transform:translateY(-6px);border-color:var(--pink);box-shadow:0 26px 56px -24px rgba(255,46,136,.55)}
.game:hover::before{transform:scale(1.08)}
.game-new{border-color:rgba(255,46,136,.55)}
.game-num{position:absolute;top:13px;right:16px;z-index:3;font-family:var(--display);font-size:1.7rem;color:#fff;line-height:1;text-shadow:0 2px 14px rgba(0,0,0,.9)}
.game-body{position:relative;z-index:2}
.game h3{margin:0;font-size:1.14rem}
.ribbon{position:absolute;top:15px;left:16px;z-index:3;background:var(--pink-btn);color:#fff;font-size:.7rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:.4em .85em;border-radius:999px;box-shadow:0 6px 18px -6px var(--pink)}

/* ---------- milestones ---------- */
.milestones{background:linear-gradient(180deg,var(--bg2),var(--bg3))}
.ms-list{margin-top:40px;border-top:1px solid var(--line)}
.ms-row{display:grid;grid-template-columns:200px 1fr;gap:30px;align-items:center;padding:34px 0;border-bottom:1px solid var(--line);transition:background .25s,padding-left .25s}
.ms-row:hover{background:rgba(255,46,136,.04);padding-left:14px}
.ms-year{font-family:var(--display);font-size:clamp(2.4rem,6vw,4.2rem);line-height:1;color:transparent;-webkit-text-stroke:1.5px rgba(246,242,248,.55);transition:color .3s,-webkit-text-stroke-color .3s}
.ms-row:hover .ms-year{color:var(--pink);-webkit-text-stroke-color:var(--pink)}
.ms-year.gold{color:var(--gold);-webkit-text-stroke:0}
.ms-card h3{margin:0 0 6px;font-size:1.25rem}
.ms-card p{margin:0;color:var(--muted);font-size:.95rem}
.ms-now,.ms-next{border-bottom-color:var(--gold)}

/* ---------- studio (light) ---------- */
.studio{background:var(--cream);color:var(--ink)}
.studio-lede{font-size:1.16rem;color:#3b3340;max-width:720px;margin:0 0 44px}
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.mv{background:#fff;border:1px solid var(--cream2);border-radius:18px;padding:30px 30px;box-shadow:0 30px 60px -40px rgba(0,0,0,.25)}
.mv h3{font-family:var(--display);font-weight:400;font-size:1.5rem;margin:0 0 10px;color:var(--ink)}
.mv p{margin:0;color:#4a4250}

/* ---------- team (light) ---------- */
.team{background:var(--cream2);color:var(--ink)}
.team-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:40px}
.person{position:relative;aspect-ratio:3/4;border-radius:14px;overflow:hidden;background:#ddd4c4}
.person img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05);transition:transform .45s ease,filter .45s ease}
.person:hover img{transform:scale(1.06);filter:grayscale(0)}
.person-cap{position:absolute;inset:auto 0 0 0;padding:30px 14px 12px;background:linear-gradient(0deg,rgba(12,8,16,.88),transparent);color:#fff}
.person-cap h3{margin:0;font-size:.92rem;line-height:1.25}
.person-cap p{margin:2px 0 0;font-size:.72rem;color:rgba(255,255,255,.75)}
.person-mono{display:grid;place-items:center;font-family:var(--display);font-size:2.2rem;color:#fff;background:linear-gradient(135deg,var(--pink),#3a1130);width:100%;height:100%}

/* ---------- contact ---------- */
.contact{background:linear-gradient(180deg,var(--bg3),var(--bg))}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,80px);align-items:center}
.contact-list{list-style:none;padding:0;margin:26px 0 28px;display:flex;flex-direction:column;gap:16px}
.contact-list li{display:flex;flex-direction:column;gap:2px}
.contact-list span{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.contact-list a,.contact-list address{font-style:normal;font-size:1.1rem;color:var(--text)}
.contact-list a:hover{color:var(--pink)}
.socials{display:flex;gap:10px}
.socials a{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;font-size:.8rem;color:var(--muted);transition:.2s}
.socials a:hover{border-color:var(--pink);color:var(--pink);transform:translateY(-2px)}
.contact-form{display:flex;flex-direction:column;gap:14px;background:var(--panel);border:1px solid var(--line);border-radius:20px;padding:30px}
.contact-form .row{display:flex;gap:14px}
.contact-form input,.contact-form textarea{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:14px 16px;color:var(--text);font-family:inherit;font-size:.95rem;resize:vertical}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--pink)}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--muted);opacity:1}
.form-note a{color:var(--gold)}
.contact-form .btn{justify-content:center}
.form-note{margin:0;color:var(--muted);font-size:.78rem;text-align:center}

/* ---------- footer ---------- */
.foot{background:var(--bg);border-top:1px solid var(--line);padding:0 0 30px;overflow:hidden}
.foot-marquee{border-bottom:1px solid var(--line);padding:22px 0;overflow:hidden}
.foot-marquee-track{display:flex;white-space:nowrap;animation:tick 30s linear infinite;width:max-content}
.foot-marquee-track span{font-family:var(--display);font-size:clamp(2rem,6vw,4rem);line-height:1;color:transparent;-webkit-text-stroke:1px rgba(246,242,248,.22);letter-spacing:.04em;padding-right:.5em}
.foot-stores{display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap;padding-top:36px}
.foot-stores p{margin:0;color:var(--muted);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase}
.store-badges{display:flex;gap:12px;align-items:center}
.store-badges a img{width:auto;transition:transform .2s,opacity .2s}
.store-badges a:hover img{transform:translateY(-2px);opacity:.9}
.badge-ios{height:44px}
.badge-play{height:46px}
.foot-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;padding-top:30px}
.foot-links{display:flex;gap:22px;flex-wrap:wrap}
.foot-links a{color:var(--muted);font-size:.9rem}
.foot-links a:hover{color:var(--text)}
.copy{color:var(--muted);font-size:.82rem;margin:0}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;z-index:400;width:100%;height:100%;max-width:100%;max-height:100%;border:none;margin:0;padding:24px;background:transparent;color:var(--text);place-items:center;overflow:hidden}
.modal[open]{display:grid}
.modal::backdrop{background:rgba(4,2,8,.92);backdrop-filter:blur(8px)}
.modal-body{width:min(960px,100%);aspect-ratio:16/9;background:#000;border-radius:14px;overflow:hidden;box-shadow:0 30px 90px -20px #000}
.modal-body video{width:100%;height:100%}
.modal-close{position:absolute;top:18px;right:24px;background:none;border:none;color:#fff;font-size:2.4rem;line-height:1;cursor:pointer;opacity:.85;z-index:1}
.modal-close:hover{color:var(--pink);opacity:1}

/* ---------- reveals (only when JS can animate) ---------- */
.js [data-anim]{opacity:0;transform:translateY(18px)}
.js [data-hero]{opacity:0}

/* ---------- responsive ---------- */
@media (max-width:959.98px){
  .nav-links{position:fixed;top:78px;right:0;width:min(280px,80vw);height:calc(100vh - 78px);flex-direction:column;align-items:flex-start;gap:22px;
    background:rgba(12,8,16,.97);backdrop-filter:blur(14px);padding:34px;transform:translateX(110%);visibility:hidden;transition:transform .35s,visibility .35s;border-left:1px solid var(--line)}
  .nav-links.open{transform:none;visibility:visible}
  .nav-burger{display:flex}
  .hero-grid{grid-template-columns:1fr;gap:10px;padding-top:120px}
  .hero-art{height:300px;margin-top:10px}
  .fc-1{width:160px;right:4%;top:10%}
  .fc-2{width:110px;right:48%;top:0}
  .fc-4{width:120px;right:56%;bottom:8%}
  .fc-3,.fc-6{display:none}
  .fc-5{width:100px;right:14%;bottom:0}
  .release-grid,.coming-grid,.contact-grid,.mv-grid{grid-template-columns:1fr}
  .coming-grid .pt-media{order:-1}
  .games-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}
  .team-grid{grid-template-columns:repeat(3,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:34px}
  .ms-row{grid-template-columns:110px 1fr;gap:18px}
}
@media (max-width:560px){
  .games-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:170px}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .contact-form .row{flex-direction:column}
  .foot-inner{flex-direction:column;align-items:flex-start}
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .ticker-track,.foot-marquee-track,.fc-img,.soon-badge i{animation:none}
  .js [data-anim],.js [data-hero]{opacity:1;transform:none}
  .cursor-glow{display:none}
  .pre{display:none}
}
