
:root{
  --bg:#000;
  --ink:#f2f2f2;
  --muted:#9f9f9f;
  --line:#f2f2f2;
  --panel:#080808;
  --panel2:#111;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:#000;
  color:var(--ink);
  font-family:'Space Mono',monospace;
  overflow-x:hidden;
  image-rendering:pixelated;
}
body:before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-2;
  background:
    radial-gradient(circle at 30% 20%,rgba(255,255,255,.08),transparent 18%),
    radial-gradient(circle at 80% 80%,rgba(255,255,255,.06),transparent 22%),
    #000;
}
.noise{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:50;
  opacity:.22;
  background:
    repeating-linear-gradient(0deg,rgba(255,255,255,.05) 0 1px,transparent 1px 5px),
    repeating-linear-gradient(90deg,rgba(255,255,255,.035) 0 1px,transparent 1px 9px);
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.maze-layout{
  width:min(1240px,calc(100% - 28px));
  margin:0 auto;
}
.hero-card{
  min-height:100vh;
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:auto 1fr;
  gap:18px;
  padding:24px 0;
}
.corner-nav{
  grid-column:1/-1;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  border:3px solid var(--line);
}
.corner-nav a{
  min-height:62px;
  display:grid;
  place-items:center;
  border-right:3px solid var(--line);
  font-family:'Press Start 2P',monospace;
  font-size:12px;
  transition:.15s;
}
.corner-nav a:last-child{border-right:0}
.corner-nav a:hover{background:#fff;color:#000}
.spiral-zone,.hero-text{
  border:3px solid var(--line);
  min-height:620px;
  background:rgba(10,10,10,.82);
  position:relative;
  overflow:hidden;
}
.spiral-zone{
  display:grid;
  place-items:center;
}
.spiral-zone img{
  width:min(520px,90%);
  position:relative;
  z-index:2;
}
.spiral{
  position:absolute;
  border:2px dashed rgba(255,255,255,.25);
  border-radius:50%;
  animation:spin 18s linear infinite;
}
.spiral.one{width:560px;height:560px}
.spiral.two{width:360px;height:360px;animation-direction:reverse}
@keyframes spin{to{transform:rotate(360deg)}}
.hero-text{
  padding:clamp(28px,5vw,70px);
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.micro,.split-scroll aside p,.map-title span,.book-left span,.mirror-title span{
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:3px;
  font-size:12px;
}
h1,h2,h3{
  font-family:'Press Start 2P',monospace;
  text-transform:uppercase;
}
h1{
  font-size:clamp(48px,8vw,80px);
  line-height:1.05;
  margin:24px 0;
}
.tag{
  font-size:24px;
  color:#d5d5d5;
}
.actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:34px;
}
.actions a{
  min-height:52px;
  padding:0 18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:3px solid var(--line);
  font-family:'Press Start 2P',monospace;
  font-size:11px;
}
.actions a:first-child{background:#fff;color:#000}
.wide-banner{
  padding:72px 0 110px;
}
.wide-banner img{
  width:100%;
  border:3px solid var(--line);
}
.split-scroll{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:18px;
  margin-bottom:110px;
}
.split-scroll aside,.split-scroll article{
  border:3px solid var(--line);
  background:rgba(8,8,8,.82);
}
.split-scroll aside{
  padding:28px;
  position:sticky;
  top:24px;
  height:max-content;
}
.split-scroll aside span,.map-title span,.book-left span,.mirror-title span{
  display:block;
  font-family:'Press Start 2P',monospace;
  font-size:42px;
  color:rgba(255,255,255,.24);
  margin-bottom:20px;
}
.split-scroll article{
  padding:clamp(28px,5vw,58px);
}
.split-scroll article p{
  font-size:21px;
  line-height:1.85;
  color:#d0d0d0;
}
.split-scroll article p:not(:last-child){margin-bottom:20px}
.map-board,.spellbook,.mirror-room{
  border:3px solid var(--line);
  background:rgba(8,8,8,.82);
  padding:clamp(24px,4vw,42px);
  margin-bottom:110px;
}
.map-title,.inventory-title,.mirror-title{
  border-bottom:3px solid var(--line);
  padding-bottom:20px;
  margin-bottom:22px;
}
h2{
  font-size:clamp(30px,5vw,40px);
  line-height:1.2;
}
.path{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  position:relative;
}
.node{
  min-height:250px;
  border:3px solid var(--line);
  padding:22px;
  background:#070707;
}
.node b{
  color:var(--muted);
}
.node h3{
  margin:20px 0;
  font-size:22px;
}
.node p{
  color:#bcbcbc;
  line-height:1.65;
}
.spellbook{
  display:grid;
  grid-template-columns:.75fr 1.25fr;
  gap:20px;
}
.book-left{
  border-right:3px solid var(--line);
  padding-right:24px;
}
.book-left p{
  color:var(--muted);
  margin-top:20px;
  line-height:1.8;
}
.book-right{
  display:grid;
  grid-template-columns:1.4fr repeat(2,1fr);
  gap:12px;
}
.book-right > div{
  min-height:145px;
  border:3px solid var(--line);
  background:#070707;
  padding:18px;
  display:grid;
  place-items:center;
  text-align:center;
}
.supply{
  grid-row:span 2;
  place-items:start!important;
  text-align:left!important;
}
.supply small,.supply span,.book-right div span{
  color:var(--muted);
  text-transform:uppercase;
  font-size:12px;
}
.supply strong{
  display:block;
  font-family:'Press Start 2P',monospace;
  font-size:clamp(20px,3vw,34px);
}
.book-right b{
  font-family:'Press Start 2P',monospace;
  font-size:30px;
}
.ca{
  grid-column:1/-1;
  color:var(--muted);
  border:3px solid var(--line);
  padding:16px;
  word-break:break-all;
}
.mirrors{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.mirrors a{
  min-height:170px;
  border:3px solid var(--line);
  background:#070707;
  display:grid;
  place-items:center;
  gap:10px;
  transition:.15s;
}
.mirrors a:hover{
  background:#fff;
  color:#000;
}
.mirrors img{width:68px;height:68px}
.mirrors span{
  font-family:'Press Start 2P',monospace;
  font-size:11px;
}
footer{
  padding:28px 0 44px;
  border-top:3px solid var(--line);
  display:flex;
  justify-content:space-between;
  gap:20px;
  color:var(--muted);
}
@media(max-width:950px){
  .hero-card,.split-scroll,.spellbook{grid-template-columns:1fr}
  .spiral-zone,.hero-text{min-height:auto}
  .book-left{border-right:0;border-bottom:3px solid var(--line);padding:0 0 22px}
  .path,.book-right,.mirrors,.corner-nav{grid-template-columns:1fr 1fr}
  .supply{grid-column:1/-1}
}
@media(max-width:560px){
  .path,.book-right,.mirrors,.corner-nav{grid-template-columns:1fr}
  .corner-nav a{border-right:0;border-bottom:3px solid var(--line)}
  h1{font-size:42px}
  footer{display:block;line-height:1.8}
}

/* === Sprinx animations === */
@keyframes float-y { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
@keyframes glow { 0%,100%{filter:drop-shadow(0 0 6px rgba(255,255,255,.25))} 50%{filter:drop-shadow(0 0 18px rgba(255,255,255,.55))} }
@keyframes spin-slow { to { transform: rotate(360deg) } }
@keyframes flicker { 0%,100%{opacity:.22} 47%{opacity:.18} 50%{opacity:.32} 53%{opacity:.2} }
.spiral-zone img { animation: float-y 5s ease-in-out infinite, glow 4s ease-in-out infinite; transition: transform .25s ease-out; will-change: transform; }
.spiral { animation: spin-slow 22s linear infinite; }
.spiral.two { animation-duration: 35s; animation-direction: reverse; }
.noise { animation: flicker 3.5s steps(2) infinite; }
.hero-text h1 { letter-spacing: 1px; animation: glow 6s ease-in-out infinite; }
.actions a { transition: transform .2s ease, background .2s ease, color .2s ease; }
.actions a:hover { transform: translateY(-2px) scale(1.03); }
.corner-nav a { position:relative; transition: color .2s ease; }
.corner-nav a:after{ content:""; position:absolute; left:50%; right:50%; bottom:6px; height:1px; background:#fff; transition: left .25s ease, right .25s ease; opacity:.7; }
.corner-nav a:hover:after{ left:18%; right:18%; }
.mirrors a { transition: transform .25s ease, filter .25s ease; }
.mirrors a:hover { transform: translateY(-4px) scale(1.05); filter: drop-shadow(0 0 12px rgba(255,255,255,.45)); }
.map-board .node { transition: transform .25s ease, box-shadow .25s ease; }
.map-board .node:hover { box-shadow: 0 0 0 1px #fff, 0 8px 24px rgba(255,255,255,.08); }
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .8s ease, transform .8s ease; }
.reveal.in { opacity: 1; transform: none; }
