/* ============================================================
   Nauco Labs — styles.css
   One stylesheet, two themes. Set the theme with a class on <body>:
     <body class="theme-game">    → Storage Mayhem (home, press)
     <body class="theme-studio">   → Nauco Labs studio page
   Component rules read semantic tokens, so they auto-theme.
   ============================================================ */

/* ---------- semantic tokens per theme ---------- */
body.theme-game{
  --bg:#241A12; --surface:#21170F; --surface-2:#2C2014; --line:#73471A;
  --fg:#F7EBCC; --muted:#E0BD85;
  --cta:#B87A33; --cta-hover:#F2BD4D; --cta-text:#241408;
  --accent-soft:#F2BD4D; --danger:#B8472E; --node:#F2BD4D;
  --font-display:'Skranji',system-ui,sans-serif;
  --font-ui:'Inter',system-ui,sans-serif;
  --font-corp:'Space Grotesk',system-ui,sans-serif;
  --font-eyebrow:var(--font-ui);
}
body.theme-studio{
  --bg:#0B0E14; --surface:#121722; --surface-2:#1B2230; --line:#232D3D;
  --fg:#E8ECF1; --muted:#8A96A6;
  --cta:#4D6FFF; --cta-hover:#6885ff; --cta-text:#0B0E14;
  --accent-soft:#38D4E6; --danger:#B8472E; --node:#4D6FFF;
  --font-display:'Space Grotesk',system-ui,sans-serif;
  --font-ui:'Manrope',system-ui,sans-serif;
  --font-corp:'Space Grotesk',system-ui,sans-serif;
  --font-mono:'JetBrains Mono',monospace;
  --font-eyebrow:var(--font-mono);
}
:root{ --r-sm:7px; --r-md:11px; --r-lg:14px; --ease:cubic-bezier(.2,.7,.2,1);
  --maxw:1120px; --gutter:clamp(20px,5vw,40px); }

/* ---------- base ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{background:var(--bg);color:var(--fg);font-family:var(--font-ui);
  font-size:15.5px;line-height:26px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body.theme-game{background-image:
  radial-gradient(120% 80% at 50% -10%,rgba(242,189,77,.06),transparent 55%),
  repeating-linear-gradient(180deg,rgba(0,0,0,.06) 0 2px,transparent 2px 4px)}
body.theme-studio{background-image:radial-gradient(120% 70% at 50% -10%,rgba(77,111,255,.05),transparent 55%)}
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
section{padding-block:clamp(52px,8vw,90px)}
a{color:var(--fg);text-decoration:none}
h1,h2,h3{font-family:var(--font-display);line-height:1.12;color:var(--fg)}
.eyebrow{font-family:var(--font-eyebrow);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;color:var(--muted)}
body.theme-studio .eyebrow{font-size:11px;letter-spacing:.2em;font-weight:500}
.muted{color:var(--muted)}
a:focus-visible,.btn:focus-visible,button:focus-visible{outline:2px solid var(--cta);outline-offset:3px;border-radius:var(--r-sm)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-ui);font-size:15px;font-weight:700;
  padding:13px 22px;border-radius:var(--r-md);border:1px solid transparent;cursor:pointer;text-decoration:none;
  transition:background .2s var(--ease),border-color .2s var(--ease),transform .15s var(--ease),box-shadow .2s var(--ease)}
.btn:hover{text-decoration:none}
.btn-primary{background:var(--cta);color:var(--cta-text)}
.btn-primary:hover{background:var(--cta-hover);transform:translateY(-1px)}
body.theme-game .btn-primary{box-shadow:0 1px 0 rgba(242,189,77,.4) inset,0 6px 18px rgba(0,0,0,.35)}
.btn-ghost{background:transparent;color:var(--fg);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--accent-soft);color:var(--accent-soft)}
.btn svg{width:17px;height:17px}
.ctas{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.link-arrow{color:var(--muted);font-size:14px;font-weight:500;transition:color .2s var(--ease)}
.link-arrow:hover{color:var(--fg)}
.link-arrow .a{color:var(--accent-soft)}

/* ---------- header / footer (corporate frame) ---------- */
.site-header{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:blur(9px);border-bottom:1px solid color-mix(in srgb,var(--line) 70%,transparent)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;padding-block:13px;gap:18px}
.brand{display:inline-flex;align-items:center;gap:10px}
.isotype{width:25px;height:25px;color:var(--fg);flex:none}
.wm{font-family:var(--font-corp);font-size:14px;letter-spacing:.09em;color:var(--muted)}
.wm b{font-weight:700;color:var(--fg);letter-spacing:.09em}
.nav{display:flex;gap:clamp(14px,3vw,26px);align-items:center}
.nav a{font-family:var(--font-ui);font-size:14px;font-weight:500;color:var(--muted);transition:color .2s var(--ease)}
.nav a:hover{color:var(--fg)}
.site-footer{border-top:1px solid var(--line);padding-block:40px 46px}
body.theme-game .site-footer{background:linear-gradient(180deg,transparent,rgba(0,0,0,.18))}
.footer-top{display:flex;justify-content:space-between;gap:26px;flex-wrap:wrap;align-items:flex-start;margin-bottom:26px}
.footer-credit{max-width:34ch;color:var(--muted);font-size:13.5px;line-height:22px;margin-top:12px}
.footer-credit .art{color:var(--fg)}
.footer-links{display:flex;gap:22px;flex-wrap:wrap}
.footer-links a{font-size:14px;color:var(--muted)}
.footer-links a:hover{color:var(--fg)}
.footer-sig{font-family:var(--font-corp);font-size:12px;color:var(--muted);letter-spacing:.04em;
  padding-top:18px;border-top:1px solid color-mix(in srgb,var(--line) 55%,transparent);
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}
.footer-sig a{color:var(--muted)}
.footer-sig .node{color:var(--node)}

/* ============================================================
   HOME (theme-game)
   ============================================================ */
body.theme-game .hero{padding-block:clamp(36px,6vw,64px)}
body.theme-game .hero .wrap{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(26px,4vw,48px);align-items:center}
body.theme-game .hero .eyebrow{margin-bottom:16px}
.hero h1{color:var(--fg)}
body.theme-game .hero h1{font-size:clamp(40px,8.5vw,76px);line-height:.98;text-shadow:0 2px 0 rgba(0,0,0,.35);margin-bottom:18px}
.hero h1 .l2{color:var(--cta-hover)}
body.theme-game .hero .tag{font-size:clamp(16px,2.3vw,18px);line-height:27px;color:var(--muted);max-width:42ch;margin-bottom:26px}
.hero .meta{font-family:var(--font-ui);font-size:13px;color:var(--muted);letter-spacing:.02em;margin-top:18px}
.keyart{position:relative;border-radius:var(--r-lg);aspect-ratio:4/3;border:2px solid var(--line);
  box-shadow:0 0 0 1px rgba(0,0,0,.4),0 18px 40px rgba(0,0,0,.45);
  background:radial-gradient(90% 70% at 50% 30%,rgba(184,122,51,.30),transparent 60%),linear-gradient(180deg,var(--surface-2),var(--surface));
  display:grid;place-items:center;overflow:hidden}
.keyart .ph{font-family:var(--font-ui);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-align:center}
.stamp{position:absolute;top:14px;right:14px;transform:rotate(7deg);font-family:var(--font-display);font-size:13px;color:var(--fg);
  background:var(--danger);border:2px solid color-mix(in srgb,var(--danger) 70%,#000);padding:7px 12px;border-radius:var(--r-sm);
  box-shadow:0 4px 10px rgba(0,0,0,.4);letter-spacing:.02em}
.pitch{border-top:1px solid color-mix(in srgb,var(--line) 50%,transparent)}
.pitch .lede{font-family:var(--font-display);font-size:clamp(20px,3.4vw,28px);line-height:1.3;color:var(--fg);max-width:24ch;margin-top:8px}
.pitch .body{color:var(--muted);max-width:54ch;margin-top:14px}
.trailer{margin-top:30px;border:2px solid var(--line);border-radius:var(--r-lg);aspect-ratio:16/9;
  background:linear-gradient(180deg,var(--surface-2),var(--surface));display:grid;place-items:center;color:var(--muted);
  font-family:var(--font-ui);font-size:13px;letter-spacing:.1em;text-transform:uppercase;text-align:center}
.trailer .play{width:64px;height:64px;border-radius:50%;border:2px solid var(--accent-soft);display:grid;place-items:center;margin:0 auto 12px;color:var(--accent-soft)}
.loop{border-top:1px solid color-mix(in srgb,var(--line) 50%,transparent)}
.loop h2{font-size:clamp(26px,4.5vw,34px);color:var(--fg);margin-top:8px}
.section-head{margin-bottom:30px}
.ledger{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px}
.entry{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:20px;position:relative}
.entry::before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:3px;border-radius:3px;background:var(--cta)}
.entry.rent::before{background:var(--danger)}
.entry h3{font-size:18px;color:var(--fg);margin-bottom:6px;padding-left:10px;font-family:var(--font-display)}
.entry p{font-size:14.5px;line-height:23px;color:var(--muted);padding-left:10px}
.gallery{border-top:1px solid color-mix(in srgb,var(--line) 50%,transparent)}
.gallery .shots{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.shot{aspect-ratio:16/10;border:2px solid var(--line);border-radius:var(--r-md);background:linear-gradient(180deg,var(--surface-2),var(--surface));
  display:grid;place-items:center;font-family:var(--font-ui);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.gallery .shot.big{grid-column:span 2;grid-row:span 2;aspect-ratio:auto}
.cta-band{border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:radial-gradient(120% 120% at 50% 0%,rgba(184,122,51,.16),transparent 60%);text-align:center}
.cta-band h2{font-size:clamp(26px,5vw,38px);color:var(--fg);margin-bottom:10px}
.cta-band p{color:var(--muted);margin-bottom:24px}
.cta-band .ctas{justify-content:center}
.cta-band .free{margin-top:16px;font-size:13px;color:var(--muted);letter-spacing:.04em}
.contact{border-top:1px solid color-mix(in srgb,var(--line) 50%,transparent)}
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-top:8px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:22px}
.card.press{border-color:var(--cta);background:linear-gradient(180deg,rgba(184,122,51,.12),var(--surface))}
.card .who{font-family:var(--font-ui);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.card.press .who{color:var(--accent-soft)}
.card .email{font-family:var(--font-display);font-size:clamp(17px,2.3vw,20px);color:var(--fg);display:inline-block;margin-bottom:8px;word-break:break-all}
.card .email:hover{color:var(--accent-soft)}
.card p{font-size:14px;line-height:22px;color:var(--muted)}
.card .kit{display:inline-block;margin-top:12px;font-size:14px;font-weight:700;color:var(--cta)}
.card .kit:hover{color:var(--cta-hover)}

/* ============================================================
   STUDIO (theme-studio)
   ============================================================ */
body.theme-studio .hero{padding-top:clamp(44px,7vw,76px);border-bottom:1px solid var(--line)}
body.theme-studio .hero .eyebrow{display:block;margin-bottom:18px}
body.theme-studio .hero h1{font-size:clamp(32px,6.5vw,46px);font-weight:700;letter-spacing:-.015em;line-height:1.1;max-width:18ch;margin-bottom:20px}
body.theme-studio .hero .sub{color:var(--muted);max-width:50ch;font-size:17px;line-height:28px}
.status{font-family:var(--font-mono,var(--font-ui));font-size:12px;color:var(--muted);letter-spacing:.02em}
.hero .status{margin-top:26px}
.status .ok{color:var(--accent-soft)}
body.theme-studio .accent-acid{color:#B4D255}
.cols{display:grid;grid-template-columns:1fr;gap:clamp(36px,5vw,52px)}
.block{max-width:60ch}
.block .eyebrow{display:block;margin-bottom:12px}
.block h2{font-size:clamp(22px,4vw,26px);font-weight:600;margin-bottom:14px}
.block p+p{margin-top:14px}
.pull{font-family:var(--font-display);font-weight:500;font-size:clamp(19px,3vw,23px);line-height:1.4;color:var(--fg);
  border-left:2px solid var(--cta);padding-left:18px;margin:22px 0}
.tags{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.tag{font-family:var(--font-mono,var(--font-ui));font-size:11px;letter-spacing:.06em;color:var(--muted);
  border:1px solid var(--line);border-radius:var(--r-sm);padding:5px 10px}
.credit{font-size:14px;color:var(--muted);margin-top:18px}
.credit a{color:var(--accent-soft)}
.now{border-top:1px solid var(--line)}
.game-card{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:center;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(22px,3vw,32px)}
.game-card .art{aspect-ratio:4/3;border:1px dashed var(--line);border-radius:var(--r-md);background:var(--surface-2);
  display:grid;place-items:center;font-family:var(--font-mono,var(--font-ui));font-size:11px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}
.game-card h2{font-size:clamp(22px,4vw,26px);font-weight:600;margin-bottom:8px}
.game-card p{color:var(--muted);margin-bottom:18px}
.emails{display:flex;gap:28px;flex-wrap:wrap;margin-top:14px}
.emails a{font-family:var(--font-display);font-weight:600;font-size:18px;color:var(--fg)}
.emails a:hover{color:var(--cta)}
.emails .lab{display:block;font-family:var(--font-mono,var(--font-ui));font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
body.theme-studio h2{font-size:clamp(22px,4vw,26px);font-weight:600}

/* ============================================================
   PRESS KIT (theme-game)
   ============================================================ */
.kit-head{padding-block:clamp(34px,6vw,56px) 8px}
.kit-head .eyebrow{margin-bottom:12px}
.kit-head h1{font-size:clamp(34px,7vw,58px);line-height:1;margin-bottom:14px;color:var(--fg)}
.kit-head h1 .l2{color:var(--cta-hover)}
.kit-head p{color:var(--muted);max-width:56ch;margin-bottom:20px}
.kit-head a{color:var(--accent-soft)}
.kit{display:grid;grid-template-columns:300px 1fr;gap:clamp(24px,4vw,44px);padding-block:30px 70px;align-items:start}
.factsheet{position:sticky;top:74px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px}
.factsheet h2{font-size:18px;margin-bottom:14px;font-family:var(--font-display)}
.factsheet .row{padding:10px 0;border-top:1px solid color-mix(in srgb,var(--line) 50%,transparent)}
.factsheet .row:first-of-type{border-top:0}
.factsheet dt{font-family:var(--font-ui);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.factsheet dd{font-size:14.5px;color:var(--fg)}
.factsheet dd a{color:var(--accent-soft)}
.factsheet .ph{color:var(--muted);font-style:italic}
.content>section{padding-bottom:34px;margin-bottom:34px;border-bottom:1px solid color-mix(in srgb,var(--line) 45%,transparent)}
.content>section:last-child{border-bottom:0;margin-bottom:0}
.content h2{font-size:clamp(20px,3.5vw,26px);margin-bottom:14px;color:var(--fg);font-family:var(--font-display)}
.content h3{font-family:var(--font-ui);font-weight:700;font-size:15px;color:var(--fg);margin-bottom:4px}
.content p{color:var(--muted);max-width:64ch}.content p+p{margin-top:12px}
.content a{color:var(--accent-soft)}
.short{color:var(--fg)!important;font-size:17px;line-height:27px}
.flist{display:grid;gap:12px;margin-top:6px}
.flist .f{padding-left:14px;border-left:3px solid var(--cta)}
.flist .f.rent{border-color:var(--danger)}
.flist .f p{margin-top:2px;font-size:14px;line-height:22px}
.assets-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:14px}
.content .shots{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.content .shot{aspect-ratio:16/10;border:2px solid var(--line);border-radius:var(--r-sm);background:linear-gradient(180deg,var(--surface-2),var(--surface));
  display:grid;place-items:center;font-family:var(--font-ui);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.logos{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.logobox{aspect-ratio:3/2;border:1px dashed var(--line);border-radius:var(--r-sm);background:var(--surface);display:grid;place-items:center;color:var(--muted);font-size:11px;letter-spacing:.06em}
.credits .line{display:flex;gap:8px;flex-wrap:wrap;padding:7px 0;border-top:1px solid color-mix(in srgb,var(--line) 40%,transparent)}
.credits .line:first-of-type{border-top:0}
.credits .role{min-width:130px;color:var(--muted);font-size:13px}
.credits .val{color:var(--fg);font-size:14px}
.links a{display:inline-block;margin-right:18px}
.contact-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cc{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:18px}
.cc.press{border-color:var(--cta);background:linear-gradient(180deg,rgba(184,122,51,.12),var(--surface))}
.cc .who{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.cc.press .who{color:var(--accent-soft)}
.cc a.email{font-family:var(--font-display);font-size:17px;color:var(--fg)}
.cc p{font-size:13px;line-height:20px;margin-top:6px;color:var(--muted)}
.note{font-size:13px;color:var(--muted);font-style:italic}

/* ---------- responsive ---------- */
@media (max-width:820px){
  .kit{grid-template-columns:1fr}.factsheet{position:static}
  .contact-cards{grid-template-columns:1fr}.content .shots,.logos{grid-template-columns:1fr 1fr}
}
@media (max-width:780px){
  body.theme-game .hero .wrap{grid-template-columns:1fr}.keyart{order:-1}
  .gallery .shots{grid-template-columns:1fr 1fr}.gallery .shot.big{grid-column:span 2;grid-row:auto;aspect-ratio:16/10}
  .game-card{grid-template-columns:1fr}.game-card .art{order:-1}
}

/* ---------- motion ---------- */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(14px);animation:rise .7s var(--ease) forwards}
  .d1{animation-delay:.06s}.d2{animation-delay:.14s}.d3{animation-delay:.22s}.d4{animation-delay:.30s}
  @keyframes rise{to{opacity:1;transform:none}}
}
