/* ==== base / theme ==== */
:root{
  --bg:#0b0b0c; --ink:#e5e5e5; --muted:#b3b3b3;
  --card:#0f0f10; --br:#1f1f22;
  --accent:#8fe3cf; --accent2:#8aa2ff; --accent3:#ffb06b;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:#0a0a0b;color:var(--ink);
  font:400 15px/1.5 Inter, system-ui, -apple-system, Segoe UI, Roboto, sans-serif;}

/* film grain (base) */
.bgfx:before{content:"";position:fixed;inset:0;z-index:-3;background:
  radial-gradient(1200px 600px at 50% 20%, rgba(120,120,255,0.05), transparent 50%),
  radial-gradient(900px 500px at 50% 120%, rgba(255,120,160,0.05), transparent 55%),
  linear-gradient(#0a0a0b,#090909);}
.grain{position:fixed;inset:0;z-index:-1;opacity:.06;mix-blend:soft-light;
  background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="160" height="160"><filter id="n"><feTurbulence type="fractalNoise" baseFrequency="0.9" numOctaves="2" stitchTiles="stitch"/></filter><rect width="100%" height="100%" filter="url(%23n)" opacity="0.45"/></svg>');}

/* PARALLAX blobs */
#plx{position:fixed;inset:0;pointer-events:none;z-index:-2}
.plx-layer{position:absolute;inset:auto;filter:blur(80px);opacity:.45;will-change:transform}
.l1{width:36vw;height:36vw;left:-10vw;top:12vh;
  background:radial-gradient(circle at 30% 30%, rgba(143,227,207,.9), transparent 60%);}
.l2{width:34vw;height:34vw;right:-12vw;bottom:8vh;
  background:radial-gradient(circle at 70% 60%, rgba(138,162,255,.85), transparent 60%);}
.l3{width:28vw;height:28vw;left:50%;top:60%;
  background:radial-gradient(circle at 40% 60%, rgba(255,176,107,.6), transparent 60%);}

/* header */
.topbar{position:sticky;top:0;z-index:20;display:flex;justify-content:space-between;align-items:center;
  padding:12px 16px;border-bottom:1px solid var(--br);background:rgba(10,10,11,.6);backdrop-filter:blur(6px)}
.brand{display:flex;align-items:center;gap:8px;color:#d7d7d9;font-weight:700;letter-spacing:.12em}
.brand .thin{opacity:.6;font-weight:600}
.dot{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block;box-shadow:0 0 12px rgba(143,227,207,.6)}
.nav a{color:#c7c7c7;text-decoration:none;margin-left:14px;font-size:13px}
.nav a:hover{color:#fff}

/* hero */
.hero{min-height:52svh;display:flex;align-items:flex-end;padding:24px 16px}
.hero-inner{max-width:1100px;margin:0 auto;width:100%}
.hero h1{margin:0 0 8px;font-size:30px;letter-spacing:.02em;font-weight:800}
.lead{margin:0;color:#c9c9c9}

/* layout / panels */
main{max-width:1100px;margin:0 auto 80px;padding:0 16px}
.panel{margin:28px 0 0;padding:16px;border:1px solid var(--br);border-radius:16px;background:rgba(15,15,16,.5)}
.panel h2{margin:0 0 8px;font-size:18px}
.prose p{margin:10px 0 0;color:#d7d7db}
.prose em{color:#e9e9ea}
.prose strong{color:#fff}

/* gallery */
.rg-section{margin-top:20px}
.rg-title{font:700 12px/1.2 Inter, system-ui;letter-spacing:.25em;color:#cfcfcf;margin:0 0 12px 2px}
.rg-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media (min-width:680px){.rg-grid{grid-template-columns:1fr 1fr}}
.rg-card{position:relative;aspect-ratio:16/9;overflow:hidden;border-radius:16px;background:#0f0f10;
  border:1px solid var(--br);cursor:pointer;padding:0;transition:transform .18s ease, box-shadow .18s ease}
.rg-card:hover{transform:scale(1.01);box-shadow:0 8px 30px rgba(0,0,0,.45)}
.rg-poster,.rg-preview{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
/* scanlines */
.rg-card:after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.075;mix-blend:screen;
  background-image:repeating-linear-gradient(to bottom, rgba(255,255,255,.7) 0, rgba(255,255,255,.7) 1px, transparent 2px, transparent 3px);}
.rg-preview{opacity:0;transition:opacity .35s}
.rg-card .rg-preview[src]{opacity:1}
.rg-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.66),transparent 55%);opacity:.95;pointer-events:none}
.rg-meta{position:absolute;left:14px;right:14px;bottom:12px;display:flex;flex-direction:column;gap:4px;pointer-events:none}
.rg-name{font-weight:800;font-size:14px;text-shadow:0 2px 10px rgba(0,0,0,.6)}
.rg-tags{font-size:11px;color:#b3b3b3;letter-spacing:.06em;text-transform:uppercase}

/* about */
.about .about-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media (min-width:860px){.about .about-grid{grid-template-columns:1.1fr .9fr}}
.portrait .hint{display:block;margin-top:8px;color:#a8a8aa}
.portrait-frame{position:relative;overflow:visible}
.cutout{
  position:absolute; right:-18px; bottom:10px; width:min(48vw,320px);
  transform:rotate(-2deg); filter:drop-shadow(0 18px 32px rgba(0,0,0,.55));
  z-index:2; pointer-events:none;
}
.model-off{display:none}

/* skills — game stat cards */
.stats-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media (min-width:760px){.stats-grid{grid-template-columns:1fr 1fr}}
.stat-card{
  position:relative; display:flex; gap:14px; align-items:flex-start;
  padding:14px; border-radius:16px; background:linear-gradient(180deg,#0c0c0e,#0b0b0c);
  border:1px solid #1e1f23; box-shadow:inset 0 0 0 1px rgba(255,255,255,.03);
  overflow:hidden; transform-style:preserve-3d; transition:transform .2s ease, box-shadow .2s ease;
}
.stat-card:hover{ transform:translateY(-2px); box-shadow:0 14px 40px rgba(0,0,0,.35) }
.stat-card:before{
  content:""; position:absolute; inset:-1px; border-radius:16px;
  background:linear-gradient(120deg, rgba(143,227,207,.35), rgba(138,162,255,.25), transparent 60%);
  mask:linear-gradient(#000,transparent 65%); opacity:.6; pointer-events:none;
}
.stat-icon{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
  border:1px solid #24262b; font-size:22px}
.stat-body{flex:1;min-width:0}
.stat-title{display:flex;align-items:center;gap:8px;margin:0 0 6px}
.stat-title strong{font-weight:800}
.stat-tag{font-size:11px;color:#b9bbc0;background:#121316;border:1px solid #272a30;border-radius:999px;padding:2px 8px}
.stat-desc{margin:0;color:#cfd0d4}
.stat-bar{margin-top:8px;height:12px;border-radius:999px;border:1px solid #26272b;background:#0d0e10;overflow:hidden}
.stat-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--accent),var(--accent2) 60%,var(--accent3));box-shadow:0 0 12px rgba(143,227,207,.35) inset;transition:width .9s cubic-bezier(.2,.8,.2,1)}
.stat-val{margin-left:8px;font-variant-numeric:tabular-nums;color:#c9cbd0}

/* buttons */
.links{display:flex;gap:10px;flex-wrap:wrap}
.btn{display:inline-block;border:1px solid var(--br);background:#0c0c0d;color:#ddd;text-decoration:none;border-radius:10px;padding:8px 12px}
.btn:hover{background:#151517}

/* modal */
.rg-modal{position:fixed;inset:0;background:rgba(0,0,0,.86);display:grid;place-items:center;padding:16px;z-index:9999}
.rg-modal[hidden]{display:none}
.rg-player{max-width:min(100%,1100px);width:100%;height:auto;background:#000;border:1px solid var(--br);border-radius:14px}
.rg-close{position:absolute;top:14px;right:14px;background:#111;border:1px solid #333;color:#ddd;border-radius:10px;width:40px;height:40px;font-size:22px;cursor:pointer}
.rg-close:hover{background:#1a1a1a}

/* footer */
.footer{padding:32px 16px;text-align:center;color:#9fa0a3;border-top:1px solid var(--br);background:rgba(10,10,11,.6)}

/* reveal on scroll */
[data-reveal]{opacity:0;transform:translateY(14px);transition:opacity .6s ease, transform .6s ease}
[data-reveal].reveal-in{opacity:1;transform:none}

/* sales */
.sales-section{margin:28px 0 0;padding:16px;border:1px solid var(--br);border-radius:16px;background:rgba(15,15,16,.5)}
.sales-section h2{margin:0 0 8px;font-size:18px}
.sales-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media (min-width:760px){.sales-grid{grid-template-columns:1fr 1fr}}
.sale-card{padding:14px;border:1px solid #1e1f23;border-radius:14px;background:linear-gradient(180deg,#0c0c0e,#0b0b0c)}
.sale-card h3{margin:0 0 6px;font-weight:800}
.sale-card .mut{color:#b9bbc0;margin:0 0 6px}
.sale-card p{margin:0;color:#cfd0d4}
