/* ═══════════════════════════════════════════════════════════
   RAEX STUDIOZ — THE DIGITAL FORGE
   One studio. Three heats: Games (ember) · Apps (molten) · Web (white-hot)
   ═══════════════════════════════════════════════════════════ */

:root{
  /* heats */
  --ember:#FF4A2E;--ember-soft:rgba(255,74,46,.14);
  --molten:#DFA83D;--molten-2:#F2C96B;--molten-soft:rgba(223,168,61,.14);
  --whitehot:#EFE9DC;--whitehot-soft:rgba(239,233,220,.10);
  /* surfaces */
  --bg:#07060A;--bg-2:#0B0A11;--bg-3:#110F18;--card:#0D0C14;
  --line:rgba(223,168,61,.14);--line-2:rgba(255,255,255,.06);
  /* text */
  --ink-3:#807C94;--ink-2:#B4B0C4;--ink:#F5F3FA;
  /* type */
  --f-display:'Clash Display',sans-serif;
  --f-body:'Satoshi',sans-serif;
  --f-mono:'JetBrains Mono',monospace;
  --heat:var(--molten);--heat-soft:var(--molten-soft);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink-2);font-family:var(--f-body);font-weight:400;overflow-x:hidden;-webkit-font-smoothing:antialiased}
::selection{background:var(--molten);color:#0B0A11}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:linear-gradient(var(--ember),var(--molten))}
img{display:block;max-width:100%}a{text-decoration:none;color:inherit}button{font-family:inherit;cursor:pointer}

/* grain + vignette */
body::before{content:'';position:fixed;inset:-50%;z-index:9001;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 7s steps(8) infinite}
@keyframes grain{0%,100%{transform:translate(0,0)}20%{transform:translate(-4%,3%)}40%{transform:translate(3%,-5%)}60%{transform:translate(-5%,-2%)}80%{transform:translate(4%,4%)}}
body::after{content:'';position:fixed;inset:0;z-index:9000;pointer-events:none;
  background:radial-gradient(ellipse at center,transparent 58%,rgba(0,0,0,.6) 100%)}

/* ── PRELOADER ── */
#loader{position:fixed;inset:0;z-index:99999;background:var(--bg);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:22px;transition:opacity .6s,visibility .6s}
#loader.done{opacity:0;visibility:hidden}
.loader-logo{width:64px;filter:drop-shadow(0 0 24px rgba(223,168,61,.6));animation:loaderPulse 1.2s ease-in-out infinite}
@keyframes loaderPulse{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.08);opacity:1}}
.loader-word{font-family:var(--f-mono);font-size:.66rem;letter-spacing:8px;text-transform:uppercase;color:var(--ink-3)}
.loader-word em{font-style:normal;color:var(--molten)}
.loader-bar{width:160px;height:1px;background:var(--line-2);overflow:hidden}
.loader-bar i{display:block;height:100%;width:40%;background:linear-gradient(90deg,var(--ember),var(--molten),var(--whitehot));animation:loadSlide 1s ease-in-out infinite}
@keyframes loadSlide{0%{transform:translateX(-100%)}100%{transform:translateX(400%)}}

/* ── HEAT GAUGE (scroll progress) ── */
#heatbar{position:fixed;top:0;left:0;height:2px;width:0;z-index:10000;
  background:linear-gradient(90deg,var(--ember),var(--molten),var(--whitehot));
  box-shadow:0 0 12px rgba(223,168,61,.7)}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:74px;display:flex;align-items:center;
  justify-content:space-between;padding:0 52px;transition:background .4s,border-color .4s,height .4s}
nav.scrolled{background:rgba(7,6,10,.97);border-bottom:1px solid var(--line);height:64px}
.logo{display:flex;align-items:center;gap:13px}
.logo img{height:38px;filter:drop-shadow(0 0 12px rgba(223,168,61,.45))}
.logo-text{font-family:var(--f-display);font-weight:600;font-size:1.12rem;letter-spacing:2px;color:var(--ink);text-transform:uppercase}
.logo-text em{font-style:normal;color:var(--molten)}
.nav-links{display:flex;gap:32px;list-style:none}
.nav-links a{font-family:var(--f-mono);font-size:.64rem;font-weight:500;letter-spacing:3px;text-transform:uppercase;
  color:var(--ink-3);transition:color .3s;position:relative;padding:4px 0}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--molten);transition:width .3s}
.nav-links a:hover{color:var(--molten)}.nav-links a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:18px}
.coin-badge{display:flex;align-items:center;gap:8px;font-family:var(--f-mono);font-size:.72rem;color:var(--molten-2);
  border:1px solid var(--line);padding:8px 14px;background:rgba(223,168,61,.05)}
.coin-badge svg{width:14px;height:14px}
.nav-cta{font-family:var(--f-mono);font-size:.62rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;
  padding:11px 24px;border:1px solid var(--molten);color:var(--molten);background:transparent;transition:all .3s;
  clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px))}
.nav-cta:hover{background:var(--molten);color:#0B0A11}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:8px}
.nav-burger span{width:22px;height:1.5px;background:var(--ink);transition:all .3s}

.coin-toast{position:fixed;top:86px;right:52px;z-index:2000;font-family:var(--f-mono);font-size:.7rem;letter-spacing:2px;
  color:var(--molten-2);background:rgba(13,12,20,.95);border:1px solid var(--line);padding:12px 20px;
  transform:translateY(-12px);opacity:0;pointer-events:none;transition:all .35s}
.coin-toast.show{transform:translateY(0);opacity:1}

/* ── HERO ── */
#hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
#hero canvas{position:absolute;inset:0;width:100%;height:100%}
.hero-grad{position:absolute;inset:0;transition:background 1.2s ease;
  background:radial-gradient(ellipse at 72% 42%,var(--heat-soft) 0%,transparent 52%),
  linear-gradient(to bottom,rgba(7,6,10,.2) 0%,rgba(7,6,10,.88) 100%)}
.hero-grid{position:absolute;inset:0;
  background-image:linear-gradient(rgba(223,168,61,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(223,168,61,.035) 1px,transparent 1px);
  background-size:72px 72px;mask-image:radial-gradient(ellipse at 55% 45%,black 25%,transparent 72%)}
.hero-inner{position:relative;z-index:2;max-width:1240px;margin:0 auto;padding:120px 52px 0;width:100%}
.hero-kicker{font-family:var(--f-mono);font-size:.66rem;letter-spacing:6px;text-transform:uppercase;color:var(--molten);
  display:flex;align-items:center;gap:16px;margin-bottom:30px;opacity:0;animation:riseIn .8s .15s ease forwards}
.hero-kicker::before{content:'';width:44px;height:1px;background:linear-gradient(90deg,var(--ember),var(--molten))}
.hero-h1{font-family:var(--f-display);font-weight:600;color:var(--ink);line-height:.92;letter-spacing:-1px;
  font-size:clamp(3.6rem,9vw,8rem);text-transform:uppercase;opacity:0;animation:riseIn .9s .3s ease forwards}
.hero-h1 .row2{display:flex;align-items:baseline;gap:24px;flex-wrap:wrap}
.hero-word{display:inline-block;font-size:clamp(4.4rem,12.5vw,11.5rem);font-weight:700;letter-spacing:-3px;line-height:1;
  color:var(--heat);transition:color .6s;position:relative;
  text-shadow:0 0 60px var(--heat-soft)}
.hero-word.swap{animation:wordSwap .7s ease}
@keyframes wordSwap{0%{opacity:1;transform:translateY(0);filter:blur(0)}45%{opacity:0;transform:translateY(26px);filter:blur(6px)}55%{opacity:0;transform:translateY(-26px);filter:blur(6px)}100%{opacity:1;transform:translateY(0);filter:blur(0)}}
.hero-word-outline{font-size:inherit;color:transparent;-webkit-text-stroke:1px rgba(245,243,250,.35)}
.hero-sub{font-size:1.06rem;font-weight:400;color:var(--ink-2);max-width:540px;line-height:1.85;margin:34px 0 46px;
  opacity:0;animation:riseIn .9s .5s ease forwards}
.hero-sub strong{color:var(--ink);font-weight:700}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:riseIn .9s .65s ease forwards}
.btn-solid{font-family:var(--f-mono);font-size:.68rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;
  padding:17px 44px;background:var(--molten);color:#0B0A11;border:none;transition:all .3s;position:relative;overflow:hidden;
  clip-path:polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,14px 100%,0 calc(100% - 14px))}
.btn-solid:hover{background:var(--molten-2);transform:translateY(-2px);box-shadow:0 14px 44px rgba(223,168,61,.35)}
.btn-ghost{font-family:var(--f-mono);font-size:.68rem;font-weight:500;letter-spacing:3px;text-transform:uppercase;
  padding:16px 44px;background:transparent;color:var(--ink);border:1px solid rgba(255,255,255,.2);transition:all .3s;
  clip-path:polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,14px 100%,0 calc(100% - 14px))}
.btn-ghost:hover{border-color:var(--ink);background:rgba(255,255,255,.05)}
.hero-foot{position:absolute;bottom:0;left:0;right:0;z-index:2;display:flex;align-items:flex-end;
  justify-content:space-between;padding:0 52px 38px}
.hero-scroll{display:flex;align-items:center;gap:12px;font-family:var(--f-mono);font-size:.6rem;letter-spacing:4px;
  text-transform:uppercase;color:var(--ink-3);opacity:0;animation:riseIn .9s .85s ease forwards}
.hero-scroll i{width:56px;height:1px;background:linear-gradient(90deg,var(--molten),transparent);animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{opacity:.4;transform:scaleX(.7)}50%{opacity:1;transform:scaleX(1)}}
.hero-stats{display:flex;gap:52px;opacity:0;animation:riseIn .9s .85s ease forwards}
.hstat b{font-family:var(--f-display);font-weight:600;font-size:2.1rem;color:var(--ink);line-height:1;display:block}
.hstat span{font-family:var(--f-mono);font-size:.56rem;letter-spacing:3px;text-transform:uppercase;color:var(--molten);margin-top:6px;display:block}
@keyframes riseIn{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

/* ── MARQUEE ── */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2);
  overflow:hidden;padding:20px 0;position:relative}
.marquee-track{display:flex;gap:0;white-space:nowrap;animation:marquee 30s linear infinite;width:max-content}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-family:var(--f-display);font-weight:600;font-size:1.05rem;letter-spacing:4px;
  text-transform:uppercase;color:var(--ink-3);padding:0 28px;display:flex;align-items:center;gap:28px}
.marquee-track span::after{content:'◆';font-size:.55rem;color:var(--molten)}
.marquee-track span.hot{color:var(--ember)}.marquee-track span.gold{color:var(--molten)}.marquee-track span.white{color:var(--whitehot)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ── SECTIONS ── */
section{padding:128px 0;position:relative}
.wrap{max-width:1240px;margin:0 auto;padding:0 52px}
.sec-label{font-family:var(--f-mono);font-size:.62rem;letter-spacing:6px;text-transform:uppercase;color:var(--molten);
  margin-bottom:22px;display:flex;align-items:center;gap:16px}
.sec-label::before{content:'';width:34px;height:1px;background:var(--molten)}
.sec-label i{font-style:normal;color:var(--ink-3)}
.sec-h2{font-family:var(--f-display);font-weight:600;font-size:clamp(2.5rem,5.4vw,4.6rem);color:var(--ink);
  letter-spacing:-1px;line-height:1;margin-bottom:18px;text-transform:uppercase}
.sec-h2 em{font-style:normal;color:var(--molten)}
.sec-h2 em.r{color:var(--ember)}.sec-h2 em.w{color:var(--whitehot)}
.sec-rule{width:52px;height:2px;background:linear-gradient(90deg,var(--ember),var(--molten));margin-bottom:56px}
.ghost-num{position:absolute;right:-16px;top:34px;font-family:var(--f-display);font-weight:700;font-size:24vw;
  color:transparent;-webkit-text-stroke:1px rgba(223,168,61,.05);line-height:1;pointer-events:none;user-select:none}

/* ── STUDIO / ABOUT ── */
#studio{background:var(--bg-2);overflow:hidden}
.studio-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:76px;align-items:start}
.studio-body p{font-size:1.04rem;line-height:1.9;color:var(--ink-2);margin-bottom:20px}
.studio-body strong{color:var(--ink);font-weight:700}
.studio-body em{color:var(--molten);font-style:italic}
.studio-quote{margin-top:36px;padding:26px 30px;border-left:2px solid var(--ember);background:var(--card);
  font-family:var(--f-display);font-weight:500;font-size:1.3rem;color:var(--ink);line-height:1.4}
.studio-quote small{display:block;margin-top:12px;font-family:var(--f-mono);font-size:.6rem;letter-spacing:3px;
  text-transform:uppercase;color:var(--ink-3)}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);margin-top:56px;border:1px solid var(--line)}
.stat-box{background:var(--bg-2);padding:30px 18px;text-align:center;transition:background .3s}
.stat-box:hover{background:var(--card)}
.stat-n{font-family:var(--f-display);font-weight:700;font-size:2.8rem;color:var(--molten);line-height:1}
.stat-l{font-family:var(--f-mono);font-size:.55rem;letter-spacing:3px;text-transform:uppercase;color:var(--ink-3);margin-top:10px}
.fact-panel{display:flex;flex-direction:column;gap:2px}
.fact{background:var(--card);padding:20px 24px;display:flex;align-items:center;gap:18px;
  border-left:2px solid transparent;transition:all .3s}
.fact:hover{background:var(--bg-3);border-left-color:var(--molten);padding-left:32px}
.fact-ico{font-size:1.4rem;flex-shrink:0;opacity:.85}
.fact-k{font-family:var(--f-mono);font-size:.58rem;letter-spacing:3px;text-transform:uppercase;color:var(--molten);margin-bottom:4px}
.fact-v{font-family:var(--f-display);font-weight:500;font-size:1rem;color:var(--ink);letter-spacing:.5px}
.fact-d{font-size:.82rem;color:var(--ink-3);margin-top:3px}

/* ── CRAFT (three heats) ── */
#craft{background:var(--bg)}
.craft-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--line-2);border:1px solid var(--line-2)}
.craft-panel{--pa:var(--molten);--pas:var(--molten-soft);
  background:var(--card);padding:52px 40px 44px;position:relative;overflow:hidden;transition:background .45s;min-height:520px;
  display:flex;flex-direction:column}
.craft-panel[data-heat=games]{--pa:var(--ember);--pas:var(--ember-soft)}
.craft-panel[data-heat=web]{--pa:var(--whitehot);--pas:var(--whitehot-soft)}
.craft-panel::before{content:'';position:absolute;inset:0;opacity:0;transition:opacity .45s;
  background:radial-gradient(ellipse at 50% 115%,var(--pas) 0%,transparent 62%)}
.craft-panel:hover{background:var(--bg-3)}
.craft-panel:hover::before{opacity:1}
.craft-panel::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--pa);
  transform:scaleX(0);transform-origin:left;transition:transform .5s ease}
.craft-panel:hover::after{transform:scaleX(1)}
.craft-num{font-family:var(--f-mono);font-size:.62rem;letter-spacing:4px;color:var(--pa);margin-bottom:34px;display:flex;justify-content:space-between}
.craft-num i{font-style:normal;color:var(--ink-3)}
.craft-glyph{width:56px;height:56px;margin-bottom:28px;color:var(--pa);transition:transform .45s;filter:drop-shadow(0 0 14px var(--pas))}
.craft-panel:hover .craft-glyph{transform:translateY(-6px) scale(1.06)}
.craft-title{font-family:var(--f-display);font-weight:600;font-size:1.9rem;color:var(--ink);text-transform:uppercase;
  letter-spacing:.5px;line-height:1;margin-bottom:18px}
.craft-desc{font-size:.94rem;line-height:1.8;color:var(--ink-3);margin-bottom:30px}
.craft-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto}
.craft-tags span{font-family:var(--f-mono);font-size:.58rem;letter-spacing:2px;text-transform:uppercase;
  color:var(--ink-2);border:1px solid var(--line-2);padding:7px 12px;transition:all .3s}
.craft-panel:hover .craft-tags span{border-color:var(--pas);color:var(--ink)}
.craft-heat{margin-top:26px;font-family:var(--f-mono);font-size:.56rem;letter-spacing:3px;text-transform:uppercase;color:var(--pa);
  display:flex;align-items:center;gap:10px}
.craft-heat::before{content:'';width:8px;height:8px;background:var(--pa);border-radius:50%;
  box-shadow:0 0 12px var(--pa);animation:heatBlink 1.8s ease-in-out infinite}
@keyframes heatBlink{0%,100%{opacity:1}50%{opacity:.35}}

/* ── WORK ── */
#work{background:var(--bg-2)}
.filter-row{display:flex;align-items:center;gap:2px;margin-bottom:52px;border-bottom:1px solid var(--line-2)}
.ftab{font-family:var(--f-mono);font-size:.62rem;font-weight:500;letter-spacing:3px;text-transform:uppercase;
  padding:14px 26px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--ink-3);
  transition:all .3s;margin-bottom:-1px}
.ftab:hover{color:var(--ink)}
.ftab.on{color:var(--molten);border-bottom-color:var(--molten)}
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.wcard{--wa:var(--molten);--was:var(--molten-soft);display:block;
  position:relative;overflow:hidden;aspect-ratio:4/3.4;background:var(--card);border:1px solid transparent;transition:border-color .4s}
.wcard[data-heat=games]{--wa:var(--ember);--was:var(--ember-soft)}
.wcard[data-heat=web]{--wa:var(--whitehot);--was:var(--whitehot-soft)}
.wcard:hover{border-color:var(--wa)}
.wcard-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:6rem;
  transition:transform .6s ease}
.wcard:hover .wcard-bg{transform:scale(1.09)}
.wcard-shade{position:absolute;inset:0;background:linear-gradient(to top,rgba(7,6,10,.96) 0%,rgba(7,6,10,.35) 55%,transparent 100%);transition:all .4s}
.wcard-num{position:absolute;top:20px;right:22px;font-family:var(--f-display);font-weight:700;font-size:1.5rem;
  color:transparent;-webkit-text-stroke:1px rgba(245,243,250,.28)}
.wcard-body{position:absolute;bottom:0;left:0;right:0;padding:26px;transform:translateY(44px);transition:transform .4s ease}
.wcard:hover .wcard-body{transform:translateY(0)}
.wcard-heat{font-family:var(--f-mono);font-size:.56rem;letter-spacing:4px;text-transform:uppercase;color:var(--wa);
  margin-bottom:8px;opacity:0;transition:opacity .4s .08s}
.wcard:hover .wcard-heat{opacity:1}
.wcard-name{font-family:var(--f-display);font-weight:600;font-size:1.6rem;letter-spacing:.5px;color:var(--ink);
  text-transform:uppercase;line-height:1;margin-bottom:10px}
.wcard-desc{font-size:.86rem;line-height:1.65;color:var(--ink-2);max-height:0;overflow:hidden;opacity:0;
  transition:max-height .4s,opacity .4s}
.wcard:hover .wcard-desc{max-height:130px;opacity:1}
.wcard-meta{display:flex;gap:14px;margin-top:12px;font-family:var(--f-mono);font-size:.6rem;letter-spacing:2px;
  text-transform:uppercase;color:var(--ink-3);opacity:0;transition:opacity .4s .12s}
.wcard:hover .wcard-meta{opacity:1}
.wcard-meta b{color:var(--molten-2);font-weight:500}
.wcard-link{margin-top:14px;font-family:var(--f-mono);font-size:.62rem;font-weight:700;letter-spacing:2px;
  text-transform:uppercase;color:var(--wa);opacity:0;transform:translateX(-6px);transition:opacity .4s .16s,transform .4s .16s}
.wcard:hover .wcard-link{opacity:1;transform:translateX(0)}
.wcard.slot{border:1px dashed var(--line);background:transparent;display:flex;align-items:center;justify-content:center}
.wcard.slot:hover{border-color:var(--wa);background:var(--card)}
.slot-inner{text-align:center;padding:32px}
.slot-plus{font-family:var(--f-display);font-weight:300;font-size:3.4rem;color:var(--wa);line-height:1;margin-bottom:14px;transition:transform .4s}
.wcard.slot:hover .slot-plus{transform:rotate(90deg)}
.slot-t{font-family:var(--f-display);font-weight:600;font-size:1.2rem;color:var(--ink);text-transform:uppercase;margin-bottom:8px}
.slot-d{font-size:.82rem;color:var(--ink-3);line-height:1.6}

/* ── PROCESS ── */
#process{background:var(--bg)}
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:var(--line-2);border:1px solid var(--line-2)}
.proc-step{background:var(--card);padding:42px 32px;position:relative;transition:background .35s;overflow:hidden}
.proc-step:hover{background:var(--bg-3)}
.proc-step::before{content:attr(data-n);position:absolute;top:-14px;right:6px;font-family:var(--f-display);font-weight:700;
  font-size:5.4rem;color:transparent;-webkit-text-stroke:1px rgba(223,168,61,.12);line-height:1}
.proc-k{font-family:var(--f-mono);font-size:.58rem;letter-spacing:3px;text-transform:uppercase;color:var(--molten);margin-bottom:16px}
.proc-t{font-family:var(--f-display);font-weight:600;font-size:1.45rem;color:var(--ink);text-transform:uppercase;margin-bottom:14px}
.proc-d{font-size:.88rem;line-height:1.75;color:var(--ink-3)}
.proc-step::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--ember),var(--molten));
  transform:scaleX(0);transform-origin:left;transition:transform .45s}
.proc-step:hover::after{transform:scaleX(1)}

/* ── ARCADE ── */
#arcade{background:var(--bg-2);overflow:hidden}
.arcade-intro{font-size:1rem;line-height:1.85;color:var(--ink-2);max-width:600px;margin-bottom:44px}
.mg-tabs{display:flex;gap:2px;margin-bottom:40px;flex-wrap:wrap}
.mg-tab{font-family:var(--f-mono);font-size:.62rem;letter-spacing:3px;text-transform:uppercase;padding:13px 30px;
  background:var(--card);border:1px solid var(--line-2);color:var(--ink-3);transition:all .3s}
.mg-tab:hover{color:var(--ink)}
.mg-tab.on{color:#0B0A11;background:var(--molten);border-color:var(--molten);font-weight:700}
.game-area{display:none;flex-direction:column;align-items:center;gap:22px}
.game-area.active{display:flex}
.game-hud{display:flex;gap:38px;font-family:var(--f-mono);font-size:.66rem;letter-spacing:3px;text-transform:uppercase;color:var(--ink-3)}
.game-hud em{font-style:normal;color:var(--molten-2);font-size:.9rem}
.game-canvas-wrap{position:relative;border:1px solid var(--line);box-shadow:0 0 60px rgba(223,168,61,.08)}
.game-canvas-wrap canvas{display:block;max-width:100%;height:auto}
.game-overlay{position:absolute;inset:0;background:rgba(7,6,10,.9);backdrop-filter:blur(4px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;padding:24px}
.game-overlay h3{font-family:var(--f-display);font-weight:600;font-size:2.2rem;letter-spacing:1px;color:var(--ink);text-transform:uppercase}
.game-overlay p{font-family:var(--f-mono);font-size:.68rem;letter-spacing:2px;color:var(--ink-3);line-height:1.9}
.game-btn{font-family:var(--f-mono);font-size:.64rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;
  padding:14px 38px;background:var(--molten);color:#0B0A11;border:none;transition:all .3s;
  clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px))}
.game-btn:hover{background:var(--molten-2)}
.memory-grid{display:grid;grid-template-columns:repeat(4,86px);gap:10px}
.mem-card{width:86px;height:86px;position:relative;cursor:pointer;transform-style:preserve-3d;transition:transform .45s}
.mem-card.flip{transform:rotateY(180deg)}
.mem-card .front,.mem-card .back{position:absolute;inset:0;backface-visibility:hidden;display:flex;align-items:center;justify-content:center}
.mem-card .front{background:var(--card);border:1px solid var(--line)}
.mem-card .front::after{content:'R';font-family:var(--f-display);font-weight:700;font-size:1.6rem;color:rgba(223,168,61,.22)}
.mem-card .back{background:var(--bg-3);border:1px solid var(--molten);transform:rotateY(180deg);font-size:2rem}
.mem-card.matched .back{border-color:var(--ember);box-shadow:0 0 18px rgba(255,74,46,.25)}

/* ── TEAM ── */
#team{background:var(--bg)}
.team-intro{font-size:1rem;line-height:1.85;color:var(--ink-2);max-width:640px;margin-bottom:52px}
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:2px;max-width:640px}
.tcard{background:var(--card);border:1px solid var(--line-2);transition:border-color .35s;overflow:hidden}
.tcard:hover{border-color:var(--line)}
.tcard-img{position:relative;aspect-ratio:1/1.05;overflow:hidden}
.tcard-photo{position:absolute;inset:0;background-size:cover;background-position:center;
  filter:grayscale(1) contrast(1.05);transition:filter .5s,transform .5s}
.tcard:hover .tcard-photo{filter:grayscale(.2);transform:scale(1.04)}
.tcard-socs{position:absolute;bottom:0;left:0;right:0;display:flex;gap:1px;transform:translateY(100%);transition:transform .35s;
  background:rgba(7,6,10,.9)}
.tcard:hover .tcard-socs{transform:translateY(0)}
.tcard-socs a{flex:1;text-align:center;padding:12px;font-family:var(--f-mono);font-size:.58rem;letter-spacing:2px;
  text-transform:uppercase;color:var(--ink-3);transition:all .3s}
.tcard-socs a:hover{color:#0B0A11;background:var(--molten)}
.tcard-info{padding:22px 24px 26px}
.tcard-name{font-family:var(--f-display);font-weight:600;font-size:1.3rem;color:var(--ink);text-transform:uppercase;letter-spacing:.5px}
.tcard-role{font-family:var(--f-mono);font-size:.58rem;letter-spacing:3px;text-transform:uppercase;color:var(--molten);margin:7px 0 12px}
.tcard-bio{font-size:.86rem;color:var(--ink-3);line-height:1.65;font-style:italic}

/* ── CAREERS ── */
#careers{background:var(--bg-2)}
.careers-intro{font-size:1rem;line-height:1.85;color:var(--ink-2);max-width:640px;margin-bottom:52px}
.jobs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px}
.jcard{background:var(--card);border:1px solid var(--line-2);padding:36px 34px;transition:all .35s;position:relative;overflow:hidden}
.jcard:hover{border-color:var(--line);background:var(--bg-3)}
.jcard::after{content:'';position:absolute;top:0;left:0;bottom:0;width:2px;background:linear-gradient(var(--ember),var(--molten));
  transform:scaleY(0);transform-origin:top;transition:transform .4s}
.jcard:hover::after{transform:scaleY(1)}
.jico{font-size:1.8rem;display:block;margin-bottom:18px}
.jtitle{font-family:var(--f-display);font-weight:600;font-size:1.5rem;color:var(--ink);text-transform:uppercase;letter-spacing:.5px}
.jtype{font-family:var(--f-mono);font-size:.56rem;letter-spacing:3px;text-transform:uppercase;color:var(--ember);margin:8px 0 14px}
.jdesc{font-size:.9rem;color:var(--ink-3);line-height:1.7;margin-bottom:24px}
.btn-det{font-family:var(--f-mono);font-size:.6rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;
  padding:12px 28px;background:transparent;border:1px solid var(--molten);color:var(--molten);transition:all .3s}
.btn-det:hover{background:var(--molten);color:#0B0A11}

/* ── CONTACT ── */
#contact{background:var(--bg)}
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:72px;align-items:start}
.cblock{margin-bottom:30px}
.clabel{font-family:var(--f-mono);font-size:.58rem;letter-spacing:4px;text-transform:uppercase;color:var(--molten);margin-bottom:10px}
.cval{font-size:1.02rem;color:var(--ink);line-height:1.7}
.cval a{color:var(--ink);border-bottom:1px solid var(--line);transition:all .3s}
.cval a:hover{color:var(--molten);border-color:var(--molten)}
.csocs{display:flex;gap:12px;margin-top:8px}
.csoc{font-family:var(--f-mono);font-size:.6rem;letter-spacing:2px;text-transform:uppercase;color:var(--ink-3);
  border:1px solid var(--line-2);padding:10px 18px;transition:all .3s}
.csoc:hover{color:var(--molten);border-color:var(--molten)}
.cform{display:flex;flex-direction:column;gap:22px}
.flabel{font-family:var(--f-mono);font-size:.58rem;letter-spacing:3px;text-transform:uppercase;color:var(--ink-3);
  display:block;margin-bottom:9px}
.finput{width:100%;background:var(--card);border:1px solid var(--line-2);color:var(--ink);padding:15px 18px;
  font-family:var(--f-body);font-size:.96rem;outline:none;transition:border-color .3s}
.finput:focus{border-color:var(--molten)}
textarea.finput{resize:vertical;min-height:130px}
.fselect-row{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.btn-send{font-family:var(--f-mono);font-size:.68rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;
  padding:17px;background:var(--molten);color:#0B0A11;border:none;transition:all .3s;
  clip-path:polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,14px 100%,0 calc(100% - 14px))}
.btn-send:hover{background:var(--molten-2)}
.btn-send:disabled{opacity:.6;cursor:wait}
.form-ok{display:none;font-family:var(--f-mono);font-size:.68rem;letter-spacing:2px;color:var(--molten-2);
  border:1px solid var(--line);padding:14px 18px;background:rgba(223,168,61,.06)}

/* ── FOOTER ── */
footer{border-top:1px solid var(--line);background:var(--bg-2);padding:44px 52px;display:flex;
  align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px}
.f-brand{font-family:var(--f-display);font-weight:600;font-size:1.1rem;letter-spacing:2px;color:var(--ink);text-transform:uppercase}
.f-brand em{font-style:normal;color:var(--molten)}
.f-tag{font-family:var(--f-mono);font-size:.6rem;letter-spacing:2px;color:var(--ink-3);margin-top:8px}
.f-tag b{color:var(--ember);font-weight:500}.f-tag i{font-style:normal;color:var(--molten)}.f-tag u{text-decoration:none;color:var(--whitehot)}
.f-socs{display:flex;gap:10px}
.f-soc{width:42px;height:42px;border:1px solid var(--line-2);display:flex;align-items:center;justify-content:center;
  color:var(--ink-3);transition:all .3s;font-size:1rem}
.f-soc:hover{color:var(--molten);border-color:var(--molten);transform:translateY(-3px)}

/* ── MODAL ── */
.overlay{position:fixed;inset:0;z-index:5000;background:rgba(7,6,10,.88);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;visibility:hidden;transition:all .35s}
.overlay.show{opacity:1;visibility:visible}
.modal{background:var(--bg-3);border:1px solid var(--line);max-width:680px;width:100%;max-height:84vh;overflow-y:auto;
  padding:46px;transform:translateY(24px);transition:transform .35s}
.overlay.show .modal{transform:translateY(0)}
.modal::-webkit-scrollbar{width:4px}
.modal-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px}
.modal-title{font-family:var(--f-display);font-weight:600;font-size:2rem;color:var(--ink);text-transform:uppercase;line-height:1}
.modal-type{font-family:var(--f-mono);font-size:.6rem;letter-spacing:3px;text-transform:uppercase;color:var(--ember);margin-top:10px}
.modal-x{background:none;border:1px solid var(--line-2);color:var(--ink-3);width:38px;height:38px;font-size:1rem;transition:all .3s;flex-shrink:0}
.modal-x:hover{color:var(--ink);border-color:var(--ink)}
.msec{margin-bottom:26px}
.msec h4{font-family:var(--f-mono);font-size:.62rem;letter-spacing:4px;text-transform:uppercase;color:var(--molten);margin-bottom:12px}
.msec p{font-size:.94rem;line-height:1.8;color:var(--ink-2)}
.msec ul{list-style:none}
.msec li{font-size:.92rem;line-height:1.7;color:var(--ink-2);padding-left:20px;position:relative;margin-bottom:7px}
.msec li::before{content:'◆';position:absolute;left:0;top:1px;font-size:.5rem;color:var(--molten)}
.btn-apply{font-family:var(--f-mono);font-size:.64rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;
  padding:15px 40px;background:var(--molten);color:#0B0A11;border:none;transition:all .3s;display:inline-block}
.btn-apply:hover{background:var(--molten-2)}

/* ── REVEALS ── */
.rv{opacity:0;transition:opacity .8s ease,transform .8s ease;will-change:opacity,transform}
.rv.from-left{transform:translateX(-36px)}
.rv.from-right{transform:translateX(36px)}
.rv.from-bottom{transform:translateY(36px)}
.rv.in{opacity:1;transform:translate(0,0)}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .rv{opacity:1;transform:none}
}

/* ── RESPONSIVE ── */
@media(max-width:1080px){
  .craft-grid{grid-template-columns:1fr}
  .craft-panel{min-height:0}
  .work-grid{grid-template-columns:repeat(2,1fr)}
  .proc-grid{grid-template-columns:repeat(2,1fr)}
  .studio-grid{grid-template-columns:1fr;gap:52px}
  .contact-grid{grid-template-columns:1fr;gap:52px}
  .ghost-num{display:none}
}
@media(max-width:860px){
  .nav-links{position:fixed;inset:64px 0 auto 0;background:rgba(7,6,10,.99);
    flex-direction:column;gap:0;padding:12px 0 24px;border-bottom:1px solid var(--line);
    transform:translateY(-130%);transition:transform .4s;z-index:-1}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding:14px 52px;font-size:.72rem}
  .nav-burger{display:flex}
  nav{padding:0 18px}
  nav .nav-cta{display:none}
  .logo{gap:9px}
  .logo img{height:32px}
  .logo-text{font-size:.9rem;letter-spacing:1px}
  .nav-right{gap:10px}
  .coin-badge{padding:6px 10px;font-size:.66rem}
}
@media(max-width:720px){
  .wrap{padding:0 24px}
  section{padding:88px 0}
  #hero{flex-direction:column;justify-content:center;align-items:stretch}
  .hero-inner{padding:110px 24px 0}
  .hero-word{font-size:clamp(2.9rem,14.5vw,11.5rem);letter-spacing:-1px}
  .hero-foot{position:static;padding:52px 24px 34px;flex-direction:column;align-items:flex-start;gap:24px}
  .hero-stats{gap:32px}
  .work-grid{grid-template-columns:1fr}
  .jobs-grid{grid-template-columns:1fr}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .proc-grid{grid-template-columns:1fr}
  .fselect-row{grid-template-columns:1fr}
  .memory-grid{grid-template-columns:repeat(4,minmax(56px,72px))}
  .mem-card{width:auto;height:auto;aspect-ratio:1}
  .modal{padding:30px 24px}
  footer{padding:36px 24px}
  .coin-toast{right:24px}
  .team-grid{max-width:100%}
}
