/* ============================================================
   BELHASIN GAMES — design system
   One stylesheet, shared by every page, so the whole site
   feels like a single hand-built artifact.
   ============================================================ */

/* ---------- 1. Design tokens ---------- */
:root{
  /* base surfaces */
  --bg:        #06060e;
  --bg-2:      #0a0a16;
  --bg-3:      #11111f;
  --surface:   rgba(255,255,255,.04);
  --surface-2: rgba(255,255,255,.06);
  --border:    rgba(255,255,255,.10);
  --border-2:  rgba(255,255,255,.18);

  /* ink */
  --ink:       #f5f6ff;
  --muted:     #aeb2cc;
  --muted-2:   #6f7390;

  /* studio signature gradient (pink -> violet -> cyan) */
  --brand-1: #ff5d8f;
  --brand-2: #a070ff;
  --brand-3: #38e1ff;
  --brand: linear-gradient(110deg, var(--brand-1), var(--brand-2) 48%, var(--brand-3));

  /* the accent is re-pointed per game via [data-theme] */
  --accent:   #a070ff;
  --accent-2: #38e1ff;
  --glow:     rgba(160,112,255,.45);

  /* type */
  --font-display: 'Syne', 'Trebuchet MS', sans-serif;
  --font-body:    'Inter', system-ui, sans-serif;
  --font-mono:    'Space Mono', ui-monospace, monospace;

  /* metrics */
  --maxw: 1240px;
  --radius: 20px;
  --radius-sm: 12px;
  --ease: cubic-bezier(.22,1,.36,1);
  --ease-soft: cubic-bezier(.4,0,.2,1);
  --nav-h: 76px;
}

/* per-game palettes ------------------------------------------ */
[data-theme="space"]   { --accent:#46d6ff; --accent-2:#7c8bff; --glow:rgba(70,214,255,.42); }
[data-theme="superman"]{ --accent:#4a86ff; --accent-2:#ff4d4d; --glow:rgba(74,134,255,.45); }
[data-theme="avatar"]  { --accent:#ffb646; --accent-2:#5fd2c0; --glow:rgba(255,182,70,.40); }
[data-theme="gta"]     { --accent:#8bff9b; --accent-2:#ffd23f; --glow:rgba(139,255,155,.38); }

/* ---------- 2. Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.6;
  letter-spacing:.01em;
  overflow-x:hidden;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* ambient page backdrop: faint aurora + grain feel */
body::before{
  content:"";
  position:fixed; inset:0; z-index:-2;
  background:
    radial-gradient(60vw 60vw at 12% -8%, rgba(160,112,255,.16), transparent 60%),
    radial-gradient(55vw 55vw at 100% 8%, rgba(56,225,255,.12), transparent 60%),
    radial-gradient(50vw 50vw at 50% 120%, rgba(255,93,143,.12), transparent 60%),
    var(--bg);
}
body::after{ /* subtle starfield dots */
  content:"";
  position:fixed; inset:0; z-index:-2; opacity:.5;
  background-image:
    radial-gradient(1px 1px at 20% 30%, rgba(255,255,255,.5), transparent),
    radial-gradient(1px 1px at 70% 60%, rgba(255,255,255,.35), transparent),
    radial-gradient(1px 1px at 40% 80%, rgba(255,255,255,.30), transparent),
    radial-gradient(1.5px 1.5px at 85% 20%, rgba(255,255,255,.40), transparent),
    radial-gradient(1px 1px at 55% 15%, rgba(255,255,255,.30), transparent);
  background-size:600px 600px,700px 700px,500px 500px,800px 800px,650px 650px;
  pointer-events:none;
}

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; border-radius:4px; }
::selection{ background:var(--accent); color:#05060a; }

/* slim custom scrollbar */
::-webkit-scrollbar{ width:11px; }
::-webkit-scrollbar-track{ background:var(--bg-2); }
::-webkit-scrollbar-thumb{ background:linear-gradient(var(--brand-2),var(--brand-3)); border-radius:99px; border:3px solid var(--bg-2); }

/* ---------- 3. Typography ---------- */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:800; line-height:1.02; letter-spacing:-.02em; }
.h-xl{ font-size:clamp(2.8rem, 8vw, 7rem); }
.h-lg{ font-size:clamp(2.2rem, 5.2vw, 4.2rem); }
.h-md{ font-size:clamp(1.6rem, 3.2vw, 2.6rem); }
p{ color:var(--muted); }
strong{ color:var(--ink); font-weight:600; }

.kicker{
  font-family:var(--font-mono);
  font-size:.74rem; letter-spacing:.42em; text-transform:uppercase;
  color:var(--accent);
  display:inline-flex; align-items:center; gap:.7em;
}
.kicker::before{ content:""; width:26px; height:1px; background:var(--accent); display:inline-block; opacity:.8; }

.gradient-text{
  background:var(--brand);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.accent-text{ color:var(--accent); }

/* ---------- 4. Layout helpers ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,48px); }
.section{ position:relative; padding-block:clamp(80px,12vh,150px); }
.section-head{ max-width:720px; margin-bottom:54px; }
.section-head p{ margin-top:18px; font-size:1.08rem; }
.center{ text-align:center; margin-inline:auto; }
.eyebrow-row{ display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }

/* ---------- 5. Scroll progress + page transition ---------- */
#progress{
  position:fixed; top:0; left:0; height:3px; width:0;
  background:var(--brand); z-index:120; box-shadow:0 0 14px var(--glow);
  transition:width .1s linear;
}
#page-fade{
  position:fixed; inset:0; z-index:200; pointer-events:none;
  background:var(--bg);
  opacity:0; transition:opacity .5s var(--ease);
}
#page-fade.show{ opacity:1; pointer-events:all; }
/* entrance: the whole page eases up on first paint */
body.is-loading #page-fade{ opacity:1; }

/* ---------- 6. Navbar ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  height:var(--nav-h);
  display:flex; align-items:center;
  transition:background .4s var(--ease), backdrop-filter .4s, border-color .4s, height .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  height:64px;
  background:rgba(8,8,16,.72);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--border);
}
.nav .container{ display:flex; align-items:center; justify-content:space-between; gap:24px; }

.brand{ display:flex; align-items:center; gap:12px; font-family:var(--font-display); font-weight:800; font-size:1.18rem; letter-spacing:-.01em; }
.brand .logo{ width:38px; height:38px; flex:none; filter:drop-shadow(0 4px 12px var(--glow)); }
.brand b{ background:var(--brand); -webkit-background-clip:text; background-clip:text; color:transparent; }
.brand span{ color:var(--ink); }

.nav-links{ display:flex; align-items:center; gap:6px; }
.nav-links a{
  position:relative; padding:10px 16px; font-size:.95rem; font-weight:500; color:var(--muted);
  border-radius:99px; transition:color .25s, background .25s;
}
.nav-links a:hover{ color:var(--ink); }
.nav-links a.active{ color:var(--ink); }
.nav-links a::after{
  content:""; position:absolute; left:16px; right:16px; bottom:5px; height:2px;
  background:var(--brand); border-radius:2px; transform:scaleX(0); transform-origin:left;
  transition:transform .35s var(--ease);
}
.nav-links a:hover::after, .nav-links a.active::after{ transform:scaleX(1); }
.nav-cta{ margin-left:8px; }

.nav-toggle{ display:none; background:none; border:1px solid var(--border-2); border-radius:10px; width:44px; height:44px; color:var(--ink); }
.nav-toggle span{ display:block; width:20px; height:2px; background:currentColor; margin:4px auto; transition:.3s; }

/* ---------- 7. Buttons ---------- */
.btn{
  --bw:1px;
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  padding:15px 28px; border-radius:99px;
  font-weight:600; font-size:.98rem; letter-spacing:.01em;
  border:var(--bw) solid var(--border-2); background:var(--surface); color:var(--ink);
  transition:transform .3s var(--ease), box-shadow .3s, background .3s, border-color .3s, color .3s;
  will-change:transform;
}
.btn:hover{ transform:translateY(-3px); border-color:var(--border-2); background:var(--surface-2); }
.btn:active{ transform:translateY(-1px); }
.btn .ar{ transition:transform .3s var(--ease); }
.btn:hover .ar{ transform:translateX(4px); }

.btn-primary{
  border:none; color:#06060e; font-weight:700;
  background:var(--brand);
  background-size:180% 180%;
  box-shadow:0 10px 30px -10px var(--glow), inset 0 0 0 1px rgba(255,255,255,.12);
  animation:btnShift 7s ease infinite;
}
.btn-primary:hover{ box-shadow:0 18px 45px -12px var(--glow); transform:translateY(-3px) scale(1.015); }
@keyframes btnShift{ 0%,100%{background-position:0% 50%} 50%{background-position:100% 50%} }

.btn-accent{
  border:none; color:#06060e; font-weight:700;
  background:linear-gradient(110deg,var(--accent),var(--accent-2));
  box-shadow:0 12px 34px -12px var(--glow);
}
.btn-accent:hover{ transform:translateY(-3px) scale(1.015); box-shadow:0 20px 50px -14px var(--glow); }

.btn-lg{ padding:18px 36px; font-size:1.05rem; }
.btn-ghost{ background:transparent; }
.btn-row{ display:flex; gap:16px; flex-wrap:wrap; align-items:center; }

/* play pill with little live dot */
.play-dot{ width:8px; height:8px; border-radius:50%; background:#06060e; box-shadow:0 0 0 0 rgba(0,0,0,.4); animation:pulse 1.8s infinite; }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(6,6,14,.5)} 70%{box-shadow:0 0 0 7px rgba(6,6,14,0)} 100%{box-shadow:0 0 0 0 rgba(6,6,14,0)} }

/* ---------- 8. Reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal-l{ opacity:0; transform:translateX(-44px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal-r{ opacity:0; transform:translateX(44px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal-l.in,.reveal-r.in{ opacity:1; transform:none; }
.reveal-scale{ opacity:0; transform:scale(.92); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal-scale.in{ opacity:1; transform:none; }
[data-delay="1"]{ transition-delay:.08s } [data-delay="2"]{ transition-delay:.16s }
[data-delay="3"]{ transition-delay:.24s } [data-delay="4"]{ transition-delay:.32s }
[data-delay="5"]{ transition-delay:.40s } [data-delay="6"]{ transition-delay:.48s }
@media (prefers-reduced-motion: reduce){
  .reveal,.reveal-l,.reveal-r,.reveal-scale{ opacity:1 !important; transform:none !important; }
}

/* ---------- 9. HERO (home) ---------- */
.hero{ position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden; padding-top:var(--nav-h); }
.hero-bg{ position:absolute; inset:-12% -2% 0 -2%; z-index:-1; }
.hero-bg .layer{ position:absolute; inset:0; background-size:cover; background-position:center; opacity:.5; }
.hero-veil{ position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg, rgba(6,6,14,.55) 0%, rgba(6,6,14,.35) 35%, rgba(6,6,14,.85) 85%, var(--bg) 100%); }

.hero-inner{ position:relative; width:100%; }
.hero h1{ margin:.2em 0 .3em; }
.hero .lead{ font-size:clamp(1.05rem,1.6vw,1.3rem); max-width:560px; }
.hero .btn-row{ margin-top:38px; }
.hero-meta{ margin-top:46px; display:flex; gap:38px; flex-wrap:wrap; }
.hero-meta .stat b{ font-family:var(--font-display); font-size:1.9rem; display:block; }
.hero-meta .stat span{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted-2); }

/* floating game sprites in the hero */
.hero-sprites{ position:absolute; inset:0; z-index:-1; pointer-events:none; }
.hero-sprites img{ position:absolute; image-rendering:pixelated; filter:drop-shadow(0 18px 30px rgba(0,0,0,.6)); opacity:.92; }
.float{ animation:float 7s ease-in-out infinite; }
.float.d2{ animation-duration:9s; animation-delay:-2s; }
.float.d3{ animation-duration:8s; animation-delay:-4s; }
@keyframes float{ 0%,100%{transform:translateY(0)} 50%{transform:translateY(-22px)} }

.scroll-cue{ position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:2;
  font-family:var(--font-mono); font-size:.62rem; letter-spacing:.35em; color:var(--muted-2); text-transform:uppercase;
  display:flex; flex-direction:column; align-items:center; gap:10px; }
.scroll-cue .mouse{ width:24px; height:38px; border:2px solid var(--border-2); border-radius:14px; position:relative; }
.scroll-cue .mouse::after{ content:""; position:absolute; left:50%; top:7px; width:3px; height:7px; border-radius:2px; background:var(--accent); transform:translateX(-50%); animation:wheel 1.6s infinite; }
@keyframes wheel{ 0%{opacity:0; transform:translate(-50%,0)} 30%{opacity:1} 100%{opacity:0; transform:translate(-50%,12px)} }

/* ---------- 10. Marquee ---------- */
.marquee{ overflow:hidden; border-block:1px solid var(--border); background:rgba(255,255,255,.015); padding:18px 0; }
.marquee-track{ display:flex; gap:48px; width:max-content; animation:scrollX 32s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-track span{ font-family:var(--font-display); font-weight:800; font-size:1.25rem; color:var(--muted-2); display:inline-flex; align-items:center; gap:48px; letter-spacing:.02em; }
.marquee-track span::after{ content:"✦"; color:var(--accent); font-size:.9rem; }
@keyframes scrollX{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion: reduce){ .marquee-track{ animation:none; } }

/* ---------- 11. SHOWCASE panels (alternating full-bleed) ---------- */
.showcase{ position:relative; min-height:92vh; display:flex; align-items:center; overflow:hidden; padding-block:90px; }
.showcase + .showcase{ border-top:1px solid var(--border); }
.showcase-bg{ position:absolute; inset:-10% 0; z-index:0; background-size:cover; background-position:center; will-change:transform; }
.showcase-veil{ position:absolute; inset:0; z-index:1; }
.showcase[data-side="left"] .showcase-veil{ background:linear-gradient(90deg, rgba(5,5,12,.94) 0%, rgba(5,5,12,.78) 42%, rgba(5,5,12,.25) 80%, transparent 100%); }
.showcase[data-side="right"] .showcase-veil{ background:linear-gradient(270deg, rgba(5,5,12,.94) 0%, rgba(5,5,12,.78) 42%, rgba(5,5,12,.25) 80%, transparent 100%); }
.showcase::after{ content:""; position:absolute; inset:0; z-index:1; background:linear-gradient(180deg,var(--bg),transparent 18%,transparent 82%,var(--bg)); }
.showcase .container{ position:relative; z-index:2; }
.showcase[data-side="right"] .showcase-card{ margin-left:auto; }

.showcase-card{ max-width:560px; }
.showcase-card .num{ font-family:var(--font-mono); color:var(--accent); font-size:.8rem; letter-spacing:.3em; }
.showcase-card h2{ margin:.35em 0 .4em; }
.showcase-card .tagline{ color:var(--accent); font-family:var(--font-display); font-weight:700; font-size:1.05rem; margin-bottom:14px; }
.showcase-card p{ font-size:1.05rem; }
.chips{ display:flex; flex-wrap:wrap; gap:9px; margin:24px 0 30px; }
.chip{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.08em; padding:7px 13px; border-radius:99px;
  border:1px solid var(--border-2); color:var(--muted); background:var(--surface); }
.chip.hot{ color:var(--accent); border-color:color-mix(in srgb, var(--accent) 50%, transparent); }

/* ---------- 12. CARDS (games grid) ---------- */
.grid-games{ display:grid; grid-template-columns:repeat(2,1fr); gap:26px; }
.card{
  position:relative; border-radius:var(--radius); overflow:hidden; isolation:isolate;
  border:1px solid var(--border); background:var(--bg-3); min-height:380px; display:flex;
  transition:transform .5s var(--ease), box-shadow .5s, border-color .5s;
  transform-style:preserve-3d; will-change:transform;
}
.card:hover{ border-color:var(--border-2); box-shadow:0 30px 70px -30px var(--glow), 0 0 0 1px var(--border-2); }
.card .card-img{ position:absolute; inset:0; z-index:-1; background-size:cover; background-position:center; transition:transform .8s var(--ease), filter .6s; }
.card:hover .card-img{ transform:scale(1.07); }
.card::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg, rgba(6,6,14,.15) 0%, rgba(6,6,14,.55) 50%, rgba(6,6,14,.96) 100%); }
.card .shine{ position:absolute; inset:0; z-index:1; pointer-events:none; opacity:0; transition:opacity .4s;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,50%), color-mix(in srgb,var(--accent) 22%, transparent), transparent 60%); }
.card:hover .shine{ opacity:1; }
.card-body{ position:relative; z-index:2; margin-top:auto; padding:26px; }
.card .tag{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; color:var(--accent); }
.card h3{ font-size:1.7rem; margin:.3em 0 .35em; }
.card p{ font-size:.95rem; color:var(--muted); max-width:42ch; }
.card .card-foot{ margin-top:18px; display:flex; align-items:center; gap:14px; }
.card .open{ font-family:var(--font-mono); font-size:.78rem; letter-spacing:.12em; color:var(--ink);
  display:inline-flex; align-items:center; gap:8px; }
.card .open .ar{ transition:transform .3s var(--ease); }
.card:hover .open .ar{ transform:translateX(5px); }
.card .badge{ position:absolute; top:18px; right:18px; z-index:2; font-family:var(--font-mono); font-size:.62rem;
  letter-spacing:.16em; padding:6px 11px; border-radius:99px; background:rgba(6,6,14,.6); border:1px solid var(--border-2);
  backdrop-filter:blur(6px); color:var(--accent); text-transform:uppercase; }
.card.wide{ grid-column:span 2; min-height:340px; }

/* ---------- 13. Stats / feature strips ---------- */
.feature-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.feature{ padding:30px; border-radius:var(--radius); border:1px solid var(--border); background:var(--surface);
  transition:transform .4s var(--ease), border-color .4s, background .4s; }
.feature:hover{ transform:translateY(-6px); border-color:var(--border-2); background:var(--surface-2); }
.feature .ico{ width:52px; height:52px; border-radius:14px; display:grid; place-items:center; margin-bottom:18px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2)); color:#06060e; }
.feature h4{ font-size:1.2rem; margin-bottom:8px; }
.feature p{ font-size:.96rem; }

.statband{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center; }
.statband .s b{ font-family:var(--font-display); font-size:clamp(2.2rem,4vw,3.4rem); display:block;
  background:var(--brand); -webkit-background-clip:text; background-clip:text; color:transparent; }
.statband .s span{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--muted-2); }

/* ---------- 14. CTA band ---------- */
.cta{ position:relative; border-radius:28px; overflow:hidden; padding:clamp(48px,7vw,90px); text-align:center;
  border:1px solid var(--border-2); background:
   radial-gradient(80% 120% at 50% 0%, rgba(160,112,255,.20), transparent 60%),
   radial-gradient(60% 120% at 100% 100%, rgba(56,225,255,.18), transparent 60%),
   var(--bg-3); }
.cta h2{ margin-bottom:18px; }
.cta p{ max-width:560px; margin:0 auto 32px; font-size:1.1rem; }

/* ---------- 15. Footer ---------- */
.footer{ border-top:1px solid var(--border); padding-block:60px 40px; margin-top:60px; }
.footer-top{ display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; margin-bottom:40px; }
.footer .brand{ font-size:1.4rem; margin-bottom:14px; }
.footer .blurb{ max-width:320px; font-size:.95rem; }
.footer-cols{ display:flex; gap:64px; flex-wrap:wrap; }
.footer-col h5{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted-2); margin-bottom:16px; }
.footer-col a{ display:block; color:var(--muted); padding:5px 0; font-size:.95rem; transition:color .25s, transform .25s; }
.footer-col a:hover{ color:var(--ink); transform:translateX(4px); }
.footer-bottom{ border-top:1px solid var(--border); padding-top:26px; display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap;
  font-size:.85rem; color:var(--muted-2); font-family:var(--font-mono); letter-spacing:.04em; }

/* ---------- 16. PAGE HERO (interior pages) ---------- */
.page-hero{ position:relative; min-height:62vh; display:flex; align-items:flex-end; overflow:hidden; padding-top:var(--nav-h); }
.page-hero .pbg{ position:absolute; inset:-8% 0 0 0; z-index:0; background-size:cover; background-position:center; }
.page-hero::after{ content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(6,6,14,.4) 0%, rgba(6,6,14,.55) 40%, rgba(6,6,14,.96) 100%); }
.page-hero .container{ position:relative; z-index:2; padding-bottom:56px; }
.page-hero h1{ margin:.2em 0 .25em; }
.page-hero .lead{ max-width:620px; font-size:1.12rem; }
.breadcrumb{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted-2); margin-bottom:8px; }
.breadcrumb a:hover{ color:var(--accent); }

/* ---------- 17. GAME DETAIL ---------- */
.detail-grid{ display:grid; grid-template-columns:1.4fr .9fr; gap:54px; align-items:start; }
.lede p{ font-size:1.12rem; margin-bottom:18px; color:var(--muted); }
.lede p strong{ color:var(--ink); }

.gallery{ display:grid; grid-template-columns:repeat(12,1fr); gap:16px; }
.gallery figure{ position:relative; border-radius:var(--radius-sm); overflow:hidden; border:1px solid var(--border); }
.gallery img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.gallery figure:hover img{ transform:scale(1.06); }
.gallery figcaption{ position:absolute; left:0; right:0; bottom:0; padding:18px 16px 12px; font-family:var(--font-mono);
  font-size:.72rem; letter-spacing:.08em; color:#eef; background:linear-gradient(transparent, rgba(6,6,14,.85)); }
.gallery .g-wide{ grid-column:span 8; aspect-ratio:16/9; }
.gallery .g-tall{ grid-column:span 4; }
.gallery .g-half{ grid-column:span 6; aspect-ratio:16/10; }
.gallery .g-third{ grid-column:span 4; aspect-ratio:4/3; }

.panel{ border:1px solid var(--border); border-radius:var(--radius); background:var(--surface); padding:28px; }
.panel + .panel{ margin-top:22px; }
.panel h3{ font-size:1.05rem; font-family:var(--font-mono); font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-bottom:18px; }
.spec{ display:flex; justify-content:space-between; gap:16px; padding:11px 0; border-bottom:1px dashed var(--border); font-size:.95rem; }
.spec:last-child{ border-bottom:none; }
.spec span{ color:var(--muted-2); }
.spec b{ color:var(--ink); font-weight:600; text-align:right; }

.controls-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:12px; }
.ctrl{ border:1px solid var(--border); border-radius:12px; padding:14px; background:var(--bg-3); }
.ctrl .keys{ display:flex; gap:6px; flex-wrap:wrap; margin-bottom:9px; }
.key{ font-family:var(--font-mono); font-size:.74rem; min-width:30px; text-align:center; padding:5px 9px; border-radius:7px;
  background:#1b1b2c; border:1px solid var(--border-2); box-shadow:0 2px 0 rgba(0,0,0,.5); color:var(--ink); }
.ctrl small{ color:var(--muted); font-size:.85rem; }

.feature-list{ display:grid; gap:14px; }
.feature-list li{ list-style:none; display:flex; gap:14px; align-items:flex-start; padding:16px 18px; border-radius:14px;
  border:1px solid var(--border); background:var(--surface); transition:border-color .3s, transform .3s; }
.feature-list li:hover{ border-color:var(--border-2); transform:translateX(4px); }
.feature-list .dot{ flex:none; width:10px; height:10px; border-radius:50%; margin-top:7px; background:linear-gradient(var(--accent),var(--accent-2)); box-shadow:0 0 12px var(--glow); }
.feature-list b{ display:block; margin-bottom:3px; }
.feature-list p{ font-size:.92rem; margin:0; }

/* sticky play bar inside detail hero */
.play-cluster{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; margin-top:26px; }
.play-note{ font-family:var(--font-mono); font-size:.74rem; color:var(--muted-2); letter-spacing:.04em; }

/* ---------- 18. ABOUT ---------- */
.about-quote{ font-family:var(--font-display); font-weight:700; font-size:clamp(1.5rem,3vw,2.4rem); line-height:1.25; letter-spacing:-.01em; }
.about-quote .gradient-text{ display:inline; }
.story p{ font-size:1.12rem; margin-bottom:22px; }
.story p.big{ font-size:1.3rem; color:var(--ink); font-family:var(--font-display); font-weight:600; line-height:1.4; }
.thanks-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:20px; }
.thanks{ padding:28px; border-radius:var(--radius); border:1px solid var(--border); background:var(--surface);
  transition:transform .4s var(--ease), border-color .4s; }
.thanks:hover{ transform:translateY(-6px); border-color:var(--border-2); }
.thanks .who{ font-family:var(--font-display); font-weight:800; font-size:1.25rem; margin-bottom:8px; }
.thanks .role{ font-family:var(--font-mono); font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); margin-bottom:12px; }
.thanks p{ font-size:.95rem; }
.timeline{ display:grid; gap:0; }
.tl{ display:grid; grid-template-columns:120px 1fr; gap:26px; padding:24px 0; border-bottom:1px solid var(--border); }
.tl .day{ font-family:var(--font-display); font-weight:800; font-size:1.4rem; color:var(--accent); }
.tl h4{ font-size:1.2rem; margin-bottom:6px; }
.tl p{ font-size:.98rem; margin:0; }

/* ---------- 19. Responsive ---------- */
@media (max-width:980px){
  .detail-grid{ grid-template-columns:1fr; }
  .feature-grid,.statband{ grid-template-columns:repeat(2,1fr); }
  .gallery .g-wide,.gallery .g-tall,.gallery .g-half,.gallery .g-third{ grid-column:span 12; aspect-ratio:16/9; }
}
@media (max-width:760px){
  body{ font-size:16px; }
  .nav-links{ position:fixed; inset:0 0 0 auto; width:min(82vw,340px); flex-direction:column; align-items:stretch;
    justify-content:center; gap:6px; background:rgba(8,8,16,.96); backdrop-filter:blur(20px);
    padding:90px 26px 40px; transform:translateX(102%); transition:transform .5s var(--ease); border-left:1px solid var(--border); }
  .nav-links.open{ transform:none; }
  .nav-links a{ font-size:1.15rem; padding:14px 16px; }
  .nav-links a::after{ display:none; }
  .nav-toggle{ display:block; z-index:101; }
  .nav.menu-open .nav-toggle span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
  .nav.menu-open .nav-toggle span:nth-child(2){ opacity:0; }
  .nav.menu-open .nav-toggle span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }
  .grid-games{ grid-template-columns:1fr; }
  .card.wide{ grid-column:span 1; }
  .feature-grid,.statband{ grid-template-columns:1fr; }
  .showcase[data-side] .showcase-veil{ background:linear-gradient(180deg, rgba(5,5,12,.55), rgba(5,5,12,.95)); }
  .showcase-card{ max-width:none; }
  .hero-meta{ gap:24px; }
  .tl{ grid-template-columns:1fr; gap:6px; }
  .footer-top{ flex-direction:column; }
}

/* page-load body lock during fade */
body.is-loading{ overflow:hidden; }
