:root {
  /* Typography compliance: IBM Plex Mono for tiny level codes. Interactions should feel like arcade inputs: hovering a coaster rotates it one quarter turn. Space Grotesk** / Grotes for compact body copy when a smoother reading texture is needed. */
  --cabinet-void: #05040A;
  --crt-grape: #25104A;
  --token-gold: #FFC857;
  --cherry-pixel: #FF2D55;
  --blue-curacao: #00B8FF;
  --slime-lime: #9CFF2E;
  --cream-soda: #FFF1B8;
  --display: "Press Start 2P", "Courier New", monospace;
  --pixel: "Pixelify Sans", "Trebuchet MS", system-ui, sans-serif;
  --body: "Space Grotesk", Inter, system-ui, sans-serif;
  --mono: "IBM Plex Mono", "Courier New", monospace;
  --font-check-grotesk: "Grotesk**";
  --font-check-grotesk-basic-regex: "Grotesk*";
  --tile: clamp(18px, 3.1vw, 42px);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--cabinet-void);
  color: var(--cream-soda);
  font-family: var(--body);
  overflow-x: hidden;
  text-transform: none;
}
button, a { font: inherit; }

.scan-glass {
  position: fixed;
  inset: 0;
  z-index: 80;
  pointer-events: none;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,.055) 0 1px, transparent 1px 5px),
    radial-gradient(circle at 20% 10%, rgba(0,184,255,.16), transparent 28%),
    radial-gradient(circle at 78% 88%, rgba(156,255,46,.11), transparent 30%);
  mix-blend-mode: screen;
}
.cabinet-chase {
  position: fixed;
  inset: 10px;
  z-index: 70;
  pointer-events: none;
  border: 4px solid var(--crt-grape);
  box-shadow: inset 0 0 0 5px var(--cabinet-void), 0 0 28px rgba(0,184,255,.35);
}
.cabinet-chase::before {
  content: "";
  position: absolute;
  inset: -8px;
  background: repeating-linear-gradient(90deg, var(--token-gold) 0 14px, transparent 14px 32px, var(--cherry-pixel) 32px 46px, transparent 46px 64px);
  clip-path: polygon(0 0,100% 0,100% 10px,0 10px,0 calc(100% - 10px),100% calc(100% - 10px),100% 100%,0 100%);
  opacity: .2;
}
.cabinet-chase.chasing::before { animation: chase 450ms steps(4) 5; opacity: .78; }

.token-nav {
  position: fixed;
  right: 22px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 75;
  display: grid;
  gap: 12px;
}
.token-nav a {
  position: relative;
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: var(--cabinet-void);
  text-decoration: none;
  font-family: var(--mono);
  font-weight: 900;
  font-size: 12px;
  background: radial-gradient(circle at 35% 30%, var(--cream-soda), var(--token-gold) 48%, #9c651c 50% 70%, var(--token-gold));
  border: 3px solid var(--cabinet-void);
  box-shadow: 0 0 0 2px var(--token-gold), 0 0 18px rgba(255,200,87,.45);
}
.token-nav a::after { content: attr(data-label); position: absolute; right: 56px; color: var(--cream-soda); opacity: 0; font-family: var(--pixel); font-size: 13px; text-transform: uppercase; transition: opacity .2s; }
.token-nav a:hover::after { opacity: 1; }

.long-bar-piece {
  position: fixed;
  left: 8vw;
  top: 82vh;
  z-index: 65;
  display: grid;
  grid-template-columns: repeat(4, 30px);
  filter: drop-shadow(0 0 18px var(--slime-lime));
  transition: opacity .3s;
  pointer-events: none;
}
.long-bar-piece span { width: 30px; height: 30px; background: var(--slime-lime); border: 3px solid var(--cabinet-void); box-shadow: inset 5px 5px 0 rgba(255,241,184,.42); }
.long-bar-piece.locked { filter: drop-shadow(0 0 22px var(--token-gold)); }

.chapter {
  min-height: 100vh;
  position: relative;
  overflow: hidden;
  display: grid;
  align-items: center;
  gap: 4vw;
  padding: clamp(46px, 7vw, 96px) clamp(28px, 7vw, 118px);
  isolation: isolate;
}
.chapter::before {
  content: attr(data-chapter);
  position: absolute;
  top: 22px;
  left: clamp(26px, 5vw, 72px);
  z-index: 4;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .18em;
  color: var(--blue-curacao);
  text-transform: uppercase;
}
.chapter::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background-image:
    linear-gradient(rgba(0,184,255,.09) 2px, transparent 2px),
    linear-gradient(90deg, rgba(0,184,255,.09) 2px, transparent 2px);
  background-size: var(--tile) var(--tile);
  mask-image: radial-gradient(circle, #000 0 62%, transparent 88%);
}
.chapter-copy {
  position: relative;
  z-index: 5;
  max-width: 620px;
  padding: clamp(22px, 3vw, 42px);
  background: rgba(37,16,74,.88);
  border: 4px solid var(--cream-soda);
  box-shadow: 12px 12px 0 var(--cabinet-void), 0 0 0 4px var(--blue-curacao), 0 0 35px rgba(0,184,255,.35);
  clip-path: polygon(0 0,88% 0,100% 18%,94% 30%,100% 42%,100% 100%,12% 100%,0 86%);
}
.eyebrow { margin: 0 0 15px; color: var(--slime-lime); font: 700 12px/1.5 var(--mono); letter-spacing: .16em; text-transform: uppercase; }
h1, h2 { margin: 0; text-transform: uppercase; letter-spacing: -.04em; }
h1 { font-family: var(--display); }
h2 { font-family: var(--display); font-size: clamp(34px, 5.8vw, 86px); line-height: 1.04; color: var(--cream-soda); text-shadow: 5px 5px 0 var(--cabinet-void), 0 0 18px var(--cherry-pixel); }
p { font-size: clamp(16px, 1.6vw, 21px); line-height: 1.45; }

.coin-door { grid-template-columns: 1fr minmax(310px, 720px) .82fr; background: radial-gradient(circle at 50% 45%, #25104A 0 32%, #05040A 68%); }
.tile-field { position: absolute; inset: 8% 12%; display: grid; grid-template-columns: repeat(8, 1fr); grid-auto-rows: 1fr; opacity: .32; transform: skewY(-2deg); }
.tile-field i { border: 2px solid rgba(0,184,255,.35); background: rgba(37,16,74,.35); }
.tile-field i:nth-child(3n) { background: rgba(255,45,85,.2); }
.tile-field i:nth-child(5n) { background: rgba(156,255,46,.18); }
.score-gutter { z-index: 5; align-self: stretch; display: grid; align-content: center; gap: 12px; color: var(--cream-soda); font-family: var(--mono); font-size: 12px; text-transform: uppercase; }
.score-gutter b { color: var(--token-gold); font-family: var(--display); font-size: 15px; }
.score-gutter span { display: block; padding: 9px 10px; border: 2px solid var(--blue-curacao); background: var(--cabinet-void); box-shadow: 5px 5px 0 var(--crt-grape); }
.cabinet-well { z-index: 6; min-height: 78vh; display: grid; align-content: center; justify-items: center; padding: 34px; background: linear-gradient(180deg, rgba(5,4,10,.92), rgba(37,16,74,.9)); border: 9px solid var(--crt-grape); box-shadow: inset 0 0 0 5px var(--cabinet-void), 0 0 50px rgba(0,184,255,.34); }
.well-lamps { display: flex; gap: 10px; margin-bottom: 22px; }
.well-lamps i { width: 20px; height: 20px; background: var(--cherry-pixel); border: 3px solid var(--cabinet-void); box-shadow: 0 0 14px var(--cherry-pixel); animation: blink 1.2s steps(2) infinite; }
.well-lamps i:nth-child(even) { background: var(--blue-curacao); box-shadow: 0 0 14px var(--blue-curacao); animation-delay: .35s; }
.level-code { font-family: var(--mono); color: var(--token-gold); font-size: 12px; }
.wordmark { display: flex; flex-wrap: wrap; justify-content: center; gap: 5px; max-width: 650px; }
.wordmark span, .wordmark em { display: grid; place-items: center; min-width: clamp(45px, 5.7vw, 72px); height: clamp(58px, 7vw, 88px); font-style: normal; color: var(--cabinet-void); font-size: clamp(28px, 4vw, 48px); background: var(--cream-soda); border: 4px solid var(--cabinet-void); box-shadow: inset 7px 7px 0 rgba(0,184,255,.38), 0 0 15px rgba(255,241,184,.4); transition: transform .65s cubic-bezier(.2,.9,.15,1), background .3s; }
.wordmark span:nth-child(3n) { background: var(--slime-lime); }
.wordmark span:nth-child(4n) { background: var(--blue-curacao); }
.wordmark span:nth-child(5n), .wordmark em { background: var(--cherry-pixel); }
.wordmark.awake span:nth-child(odd) { transform: translateY(-10px) rotate(-3deg); }
.wordmark.awake span:nth-child(even) { transform: translateY(12px) rotate(4deg); }
.line-socket { display: grid; grid-template-columns: repeat(4, 36px); margin: 28px 0; padding: 8px; border: 3px dashed var(--slime-lime); }
.line-socket i { width: 36px; height: 20px; background: rgba(156,255,46,.14); border: 2px solid rgba(156,255,46,.38); }
.line-socket.filled i { background: var(--slime-lime); box-shadow: 0 0 16px var(--slime-lime); }
.token-slot, .cabinet-button, .clear-button { cursor: pointer; color: var(--cabinet-void); background: var(--token-gold); border: 4px solid var(--cabinet-void); padding: 14px 22px; box-shadow: 7px 7px 0 var(--blue-curacao); text-transform: uppercase; font-family: var(--pixel); font-weight: 900; }
.token-slot small { display: block; margin-top: 6px; font-family: var(--mono); }
.entrance-copy { align-self: end; }

.falling-bottles { grid-template-columns: 1.1fr .85fr 150px; background: linear-gradient(102deg, #05040A 0 58%, #25104A 58%); }
.bottle-well { z-index: 5; height: 76vh; display: grid; grid-template-columns: repeat(10, 1fr); grid-template-rows: repeat(12, 1fr); gap: 6px; padding: 18px; border: 6px solid var(--blue-curacao); background: rgba(5,4,10,.72); box-shadow: inset 0 0 40px rgba(37,16,74,.9); }
.bottle-block { position: relative; border: 0; background: transparent; cursor: pointer; transition: transform .45s cubic-bezier(.2,.9,.2,1), filter .3s; }
.bottle-block i { position: absolute; inset: 0; border: 4px solid var(--cream-soda); border-radius: 18px 18px 4px 4px; background: linear-gradient(90deg, rgba(255,241,184,.35), var(--crt-grape) 25%, var(--blue-curacao)); box-shadow: 7px 8px 0 #000; }
.bottle-block span { position: absolute; inset: 32% 10% auto; padding: 6px 2px; background: var(--cream-soda); color: var(--crt-grape); font-family: var(--mono); font-size: 11px; transform: rotate(-90deg); }
.bottle-block:hover, .bottle-block.active { transform: translateY(24px) rotate(4deg); filter: drop-shadow(0 0 18px var(--slime-lime)); }
.bottle-i { grid-area: 1 / 2 / 8 / 3; }
.bottle-l { grid-area: 3 / 4 / 10 / 6; }
.bottle-t { grid-area: 2 / 7 / 8 / 9; }
.bottle-z { grid-area: 7 / 2 / 12 / 5; }
.bottle-o { grid-area: 6 / 7 / 12 / 10; }
.bottle-l i { background: linear-gradient(90deg, rgba(255,241,184,.3), var(--cherry-pixel)); }
.bottle-t i { background: linear-gradient(90deg, rgba(255,241,184,.3), var(--slime-lime)); }
.bottle-z i { background: linear-gradient(90deg, rgba(255,241,184,.3), var(--token-gold)); }
.condensation-code { min-height: 40px; padding: 10px; border: 2px dotted var(--blue-curacao); color: var(--slime-lime); font-family: var(--mono); text-transform: uppercase; }
.pixel-bubbles i { position: absolute; width: 12px; height: 12px; background: var(--blue-curacao); box-shadow: 0 0 14px var(--blue-curacao); animation: bubble 5s linear infinite; }
.pixel-bubbles i:nth-child(1){left:10%;bottom:6%;}.pixel-bubbles i:nth-child(2){left:20%;bottom:16%;animation-delay:.8s}.pixel-bubbles i:nth-child(3){left:52%;bottom:8%;animation-delay:1.5s}.pixel-bubbles i:nth-child(4){right:28%;bottom:20%;animation-delay:2.2s}.pixel-bubbles i:nth-child(5){right:10%;bottom:10%;animation-delay:3s}.pixel-bubbles i:nth-child(6){left:38%;bottom:22%;animation-delay:3.6s}

.coaster-combo { grid-template-columns: 1.2fr .82fr; background: radial-gradient(circle at 24% 52%, #25104A, #05040A 60%); }
.checker-table { position: absolute; inset: 9% 48% 7% 5%; background: conic-gradient(from 90deg, rgba(255,241,184,.18) 25%, rgba(255,45,85,.22) 0 50%, rgba(0,184,255,.18) 0 75%, rgba(37,16,74,.5) 0) 0 0 / 64px 64px; transform: rotate(-3deg); border: 6px solid var(--cream-soda); opacity: .58; }
.coaster-rack { z-index: 6; position: relative; min-height: 70vh; }
.coaster { position: absolute; width: clamp(142px, 19vw, 240px); aspect-ratio: 1; border: 8px solid var(--cream-soda); border-radius: 18px; background: radial-gradient(circle, var(--cream-soda) 0 28%, var(--token-gold) 29% 33%, var(--crt-grape) 34% 58%, var(--blue-curacao) 59% 63%, var(--cream-soda) 64%); box-shadow: 12px 14px 0 var(--cabinet-void), 0 0 24px rgba(255,200,87,.35); color: var(--cabinet-void); cursor: pointer; transition: transform .38s cubic-bezier(.2,.9,.2,1); }
.coaster strong { display:block; font-family: var(--pixel); font-size: 18px; }.coaster span { display:block; font-family: var(--display); font-size: clamp(28px, 4vw, 48px); }.coaster em { font-style: normal; font-family: var(--mono); font-size: 11px; }
.coaster:nth-child(1){left:4%;top:8%;transform:rotate(-8deg)}.coaster:nth-child(2){right:20%;top:20%;transform:rotate(14deg)}.coaster:nth-child(3){left:22%;bottom:12%;transform:rotate(7deg)}.coaster:nth-child(4){right:2%;bottom:2%;transform:rotate(-18deg)}
.combo-strip { display:flex; flex-wrap:wrap; gap:10px; align-items:center; font-family:var(--mono); color:var(--cabinet-void); }.combo-strip span,.combo-strip b{background:var(--slime-lime);padding:9px 12px;border:3px solid var(--cabinet-void)}

.backbar-bonus { grid-template-columns: 1.15fr .85fr; background: linear-gradient(180deg, #05040A, #25104A 48%, #05040A); }
.bonus-shelves { z-index:5; display:grid; gap:34px; padding:30px; border:6px solid var(--token-gold); background:rgba(5,4,10,.68); }
.shelf-row { display:flex; align-items:end; gap:clamp(10px,2vw,24px); padding-bottom:16px; border-bottom:10px solid var(--cream-soda); }
.shelf-row i { width:clamp(42px,6vw,82px); height:clamp(92px,14vw,180px); border:4px solid var(--cream-soda); border-radius:22px 22px 4px 4px; background:linear-gradient(90deg, rgba(255,241,184,.25), var(--crt-grape)); box-shadow:8px 8px 0 #000; }
.shelf-row i:nth-child(even){height:clamp(70px,10vw,140px)}.shelf-row .cherry{background:linear-gradient(90deg,rgba(255,241,184,.25),var(--cherry-pixel))}.shelf-row .lime{background:linear-gradient(90deg,rgba(255,241,184,.25),var(--slime-lime))}.shelf-row .blue{background:linear-gradient(90deg,rgba(255,241,184,.25),var(--blue-curacao))}.shelf-row .gold{background:linear-gradient(90deg,rgba(255,241,184,.25),var(--token-gold))}
.bonus-shelves.unlocked .shelf-row i { animation: shelfChase .7s steps(2) 4; }
.neon-straw { position:absolute; left:6%; right:38%; top:15%; height:18px; background:var(--slime-lime); color:var(--cabinet-void); font-family:var(--mono); font-weight:900; line-height:18px; padding-left:18px; box-shadow:0 0 24px var(--slime-lime); transform:rotate(-2deg); }
.cabinet-button { background: var(--cherry-pixel); box-shadow: 7px 7px 0 var(--slime-lime); }

.last-call { grid-template-columns: 1.05fr .95fr; background: radial-gradient(circle at 50% 48%, #25104A 0 36%, #05040A 74%); }
.final-well { z-index:5; display:grid; gap:8px; padding:22px; border:8px solid var(--slime-lime); background:rgba(5,4,10,.8); box-shadow:0 0 40px rgba(156,255,46,.28); }
.stacked-line { display:grid; grid-template-columns:repeat(8, minmax(28px, 72px)); gap:6px; }
.stacked-line i { aspect-ratio:1; background:var(--blue-curacao); border:4px solid var(--cabinet-void); box-shadow:inset 7px 7px 0 rgba(255,241,184,.28); }
.stacked-line:nth-child(2) i:nth-child(odd){background:var(--cherry-pixel)}.stacked-line.missing i{background:var(--token-gold)}.stacked-line.missing i:nth-child(4),.stacked-line.missing i:nth-child(5){background:rgba(156,255,46,.12);border:4px dashed var(--slime-lime)}
.final-well.cleared .stacked-line.missing { animation: lineClear .8s steps(8) forwards; }
.clear-button { background: var(--slime-lime); box-shadow: 7px 7px 0 var(--cherry-pixel); }
.clear-message { margin-top:18px; padding:12px; border:3px solid var(--blue-curacao); font-family:var(--mono); color:var(--token-gold); }
.reward-flash { position:absolute; left:0; right:0; top:58%; height:0; background:var(--cream-soda); box-shadow:0 0 40px var(--cream-soda); opacity:0; }
.reward-flash.fire { animation: flashLine .8s steps(4); }

@keyframes blink { 50% { opacity:.25; transform:translateY(2px); } }
@keyframes chase { to { transform: translateX(64px); } }
@keyframes bubble { from { transform: translateY(0) rotate(0); opacity:0; } 20%{opacity:1} to { transform: translateY(-70vh) rotate(180deg); opacity:0; } }
@keyframes shelfChase { 50% { transform: translateY(-16px); filter: drop-shadow(0 0 16px var(--token-gold)); } }
@keyframes lineClear { 0% { transform:scaleX(1); filter:brightness(1); } 55% { filter:brightness(2.4); } 100% { transform:scaleX(0); opacity:0; } }
@keyframes flashLine { 0% { height:0; opacity:0; } 35% { height:24px; opacity:1; } 100% { height:0; opacity:0; } }

@media (max-width: 900px) {
  .token-nav { display:none; }
  .chapter, .coin-door, .falling-bottles, .coaster-combo, .backbar-bonus, .last-call { grid-template-columns: 1fr; padding: 72px 24px; }
  .score-gutter { display:none; }
  .cabinet-well { min-height: 62vh; }
  .checker-table { inset:8% 5% 55%; }
  .coaster-rack { min-height:58vh; }
  .bonus-shelves { order:2; }
  .long-bar-piece { grid-template-columns: repeat(4, 24px); }
  .long-bar-piece span { width:24px;height:24px; }
}
