:root {
  --design-typography-note: "Interaction object-led theatrical: Space Grotesk* Grotesk** mechanical labels";
  --midnight: #171124;
  --milk: #FFF7E8;
  --cyan: #21F4D0;
  --banana: #FFE66D;
  --orange: #FF9B21;
  --pink: #FF4FA3;
  --ink: #241A2E;
  --melon: #B6FF3B;
  --fat: "Cooper Black", "Arial Rounded MT Bold", "Noto Sans KR", system-ui, sans-serif;
  --sans: "Noto Sans KR", "Apple SD Gothic Neo", "Malgun Gothic", system-ui, sans-serif;
  --space: "Space Grotesk", "Trebuchet MS", system-ui, sans-serif;
  --pen: "Comic Sans MS", "Apple Chancery", cursive;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  overflow-x: hidden;
  color: var(--milk);
  background: var(--midnight);
  font-family: var(--sans);
}

.arcade {
  position: relative;
  background:
    radial-gradient(circle at 16% 10%, rgba(255,79,163,.22), transparent 25rem),
    radial-gradient(circle at 82% 38%, rgba(33,244,208,.16), transparent 26rem),
    linear-gradient(180deg, #171124 0%, #241A2E 53%, #FFF7E8 100%);
}

.arcade::before, .arcade::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 3;
}
.arcade::before {
  background-image:
    radial-gradient(circle, rgba(255,247,232,.16) 0 1px, transparent 1.5px),
    linear-gradient(90deg, rgba(255,230,109,.07) 1px, transparent 1px);
  background-size: 24px 24px, 68px 68px;
  mix-blend-mode: screen;
  opacity: .45;
}
.arcade::after {
  background: repeating-linear-gradient(100deg, transparent 0 12px, rgba(255,255,255,.035) 13px, transparent 14px);
  opacity: .55;
}

.room {
  min-height: 100vh;
  position: relative;
  overflow: hidden;
  padding: clamp(28px, 4vw, 62px);
  isolation: isolate;
}
.room::before {
  content: attr(data-room);
  position: absolute;
  top: 24px;
  right: 28px;
  font-family: var(--space);
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--cyan);
  font-size: 12px;
  opacity: .85;
}

.room h1, .room h2 {
  font-family: var(--fat);
  letter-spacing: -.055em;
  line-height: .82;
  margin: 0;
  text-shadow: 6px 7px 0 var(--ink), 10px 13px 0 rgba(255,79,163,.38);
  color: var(--banana);
}
.room h1 { position: absolute; left: 8vw; bottom: 12vh; font-size: clamp(4rem, 13vw, 13rem); }
.room h2 { position: absolute; z-index: 2; font-size: clamp(3.8rem, 10vw, 11rem); }
.scene-copy {
  position: absolute;
  z-index: 4;
  max-width: 420px;
  color: var(--milk);
  font-size: clamp(1rem, 1.45vw, 1.26rem);
  line-height: 1.65;
  background: rgba(36,26,46,.72);
  border: 2px solid rgba(255,247,232,.22);
  border-radius: 24px;
  padding: 18px 20px;
  box-shadow: 0 18px 0 rgba(0,0,0,.14), inset 0 1px 16px rgba(255,255,255,.08);
}

.token {
  position: fixed;
  left: var(--token-x, 84vw);
  top: var(--token-y, 34vh);
  width: 74px;
  height: 74px;
  z-index: 20;
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: var(--ink);
  font-family: var(--fat);
  background: radial-gradient(circle at 32% 22%, var(--milk), var(--banana) 38%, var(--orange) 78%);
  border: 4px solid var(--ink);
  box-shadow: 0 0 24px rgba(255,230,109,.5), 8px 12px 0 rgba(0,0,0,.26);
  transform: translate(-50%, -50%) rotate(var(--token-r, 0deg)) scale(var(--token-s, 1));
  transition: transform .18s ease-out;
}
.token span { transform: rotate(-8deg); }
.cursor-spark {
  position: fixed;
  z-index: 19;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  pointer-events: none;
  background: radial-gradient(circle, var(--cyan), transparent 68%);
  opacity: 0;
  transform: translate(-50%, -50%);
}
.room-meter {
  position: fixed;
  left: 24px;
  top: 22px;
  z-index: 21;
  display: flex;
  gap: 12px;
  align-items: center;
  color: var(--milk);
  font-family: var(--space);
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 12px;
}
.room-meter i { width: 11px; height: 11px; border-radius: 50%; background: var(--melon); box-shadow: 0 0 18px var(--melon); }

.coin-room {
  background: radial-gradient(circle at 70% 18%, rgba(255,79,163,.27), transparent 22rem), var(--midnight);
  border: 18px solid var(--ink);
  box-shadow: inset 0 0 0 10px rgba(33,244,208,.12);
}
.cabinet-shine { position: absolute; inset: 6vh 7vw; border-radius: 46px; border: 3px solid rgba(255,247,232,.14); background: linear-gradient(120deg, rgba(255,255,255,.09), transparent 42%); }
.wordmark { position: absolute; top: 13vh; left: 12vw; transform: rotate(-8deg); }
.sticker {
  z-index: 5;
  display: inline-block;
  padding: 14px 22px;
  color: var(--ink);
  font-family: var(--fat);
  background: var(--milk);
  border: 3px solid var(--ink);
  border-radius: 28px 18px 34px 16px;
  box-shadow: 8px 10px 0 var(--pink);
}
.hangul-bubble { position: absolute; left: 18vw; top: 24vh; color: var(--melon); font-family: var(--pen); font-size: clamp(1.8rem, 4vw, 4.4rem); transform: rotate(5deg); }
.coin-slot { position: absolute; right: 17vw; top: 15vh; height: 58vh; width: 160px; border-radius: 999px; background: var(--ink); border: 8px solid var(--cyan); box-shadow: 0 0 42px var(--cyan), inset 0 0 34px #000; }
.coin-slot::before { content: "("; position: absolute; inset: -42px auto auto -70px; font-family: var(--fat); font-size: 32rem; line-height: .8; color: var(--pink); text-shadow: 0 0 28px var(--pink); }
.coin-slot span { position: absolute; inset: 11% 43%; border-radius: 999px; background: linear-gradient(var(--banana), var(--orange)); box-shadow: 0 0 28px var(--banana); }
.type-receipt { left: 8vw; top: 40vh; }
.receipt { position: absolute; z-index: 4; padding: 12px 18px; color: var(--ink); background: var(--milk); border: 2px dashed var(--ink); font-family: var(--space); text-transform: uppercase; letter-spacing: .07em; box-shadow: 0 10px 0 rgba(0,0,0,.18); }
.coin-room .scene-copy { right: 32vw; bottom: 8vh; }
.jelly-button { position: absolute; z-index: 6; border: 3px solid var(--ink); border-radius: 999px; padding: 16px 24px; color: var(--ink); background: var(--melon); font-family: var(--space); font-weight: 800; text-transform: uppercase; box-shadow: 0 9px 0 var(--ink), inset 0 7px 14px rgba(255,255,255,.45); cursor: pointer; }
#dropButton { right: 10vw; bottom: 13vh; }
.jelly-button:active { transform: translateY(7px); box-shadow: 0 2px 0 var(--ink); }
.burst { position: absolute; color: var(--cyan); font-family: var(--fat); font-size: 42px; animation: pop 1.8s ease-in-out infinite alternate; }
.burst-a { left: 48vw; top: 18vh; } .burst-b { right: 12vw; top: 10vh; animation-delay: .3s; color: var(--banana); } .burst-c { left: 34vw; bottom: 20vh; animation-delay: .8s; color: var(--pink); }

.gumball-room { background: radial-gradient(circle at 50% 52%, rgba(33,244,208,.18), transparent 28rem), #241A2E; }
.tube-rail { position: absolute; inset: 8vh 0 auto 0; width: 100vw; height: 50vh; overflow: visible; }
#tubePath { fill: none; stroke: var(--cyan); stroke-width: 18; stroke-linecap: round; opacity: .42; filter: drop-shadow(0 0 12px #21F4D0); }
.tumbler { position: absolute; left: 8vw; top: 14vh; width: min(540px, 78vw); aspect-ratio: 1; border-radius: 50%; background: radial-gradient(circle at 35% 24%, rgba(255,247,232,.42), rgba(33,244,208,.18) 35%, rgba(255,79,163,.12) 62%, rgba(255,247,232,.08)); border: 12px solid rgba(255,247,232,.34); box-shadow: inset 0 0 50px rgba(255,255,255,.22), 0 30px 80px rgba(0,0,0,.28); transform: rotate(var(--tumbler-r, 0deg)); transition: transform .18s ease-out; }
.rim-text { position: absolute; inset: 18px; border-radius: 50%; display: grid; place-items: center; font-family: var(--space); font-size: 12px; color: var(--banana); letter-spacing: .2em; text-align: center; border: 2px dashed rgba(255,230,109,.45); }
.capsule { position: absolute; width: 116px; height: 76px; border-radius: 999px; border: 3px solid var(--ink); display: grid; place-items: center; color: var(--ink); font-family: var(--fat); box-shadow: inset 0 10px 15px rgba(255,255,255,.42), 8px 10px 0 rgba(0,0,0,.18); animation: capsuleTilt 3.6s ease-in-out infinite alternate; }
.cap-cyan { left: 18%; top: 22%; background: var(--cyan); } .cap-pink { right: 16%; top: 28%; background: var(--pink); animation-delay: -.6s; } .cap-melon { left: 38%; bottom: 19%; background: var(--melon); animation-delay: -.9s; } .cap-orange { left: 19%; bottom: 32%; background: var(--orange); animation-delay: -1.4s; } .cap-banana { right: 20%; bottom: 27%; background: var(--banana); animation-delay: -2s; }
.label-stack { position: absolute; right: 11vw; top: 18vh; display: grid; gap: 12px; max-width: 420px; }
.label-stack span { color: var(--pink); font-family: var(--fat); font-size: 8rem; line-height: .8; }
.label-stack strong { color: var(--milk); font-family: var(--fat); font-size: clamp(2.4rem, 5vw, 5rem); line-height: .9; }
.label-stack em, .scribble { color: var(--melon); font-family: var(--pen); font-size: 2rem; }
.note-one { position: absolute; right: 16vw; bottom: 18vh; transform: rotate(-8deg); }
.side-copy { right: 10vw; bottom: 28vh; }

.sticker-room { background: linear-gradient(135deg, #171124, #241A2E 60%, rgba(255,79,163,.2)); }
.sticker-room h2 { left: 7vw; top: 10vh; color: var(--cyan); text-shadow: 6px 7px 0 var(--ink), 10px 13px 0 rgba(182,255,59,.35); }
.sticker-cloud { position: absolute; inset: 9vh 5vw 10vh 28vw; }
.peel { position: absolute; cursor: pointer; font-size: clamp(1.1rem, 2vw, 2rem); transition: transform .5s cubic-bezier(.2,1.6,.35,1), box-shadow .5s; }
.peel.peeled { transform: rotate(var(--r)) translateY(-22px) rotateX(38deg); box-shadow: 10px 18px 0 var(--cyan); }
.s1 { left: 9%; top: 10%; --r: -7deg; } .s2 { left: 42%; top: 4%; --r: 8deg; background: var(--melon); } .s3 { left: 18%; top: 38%; --r: 12deg; background: var(--banana); } .s4 { right: 12%; top: 34%; --r: -11deg; background: var(--pink); } .s5 { left: 38%; bottom: 8%; --r: 5deg; background: var(--cyan); } .s6 { right: 4%; bottom: 16%; --r: -4deg; background: var(--orange); }
.curl { left: 8vw; bottom: 16vh; transform: rotate(4deg); }
.jelly-arrow { position: absolute; right: 14vw; top: 18vh; color: var(--melon); font-family: var(--fat); font-size: 8rem; filter: drop-shadow(8px 8px 0 var(--ink)); animation: wobble 1.7s ease-in-out infinite; }
.sticker-room .scene-copy { right: 8vw; bottom: 8vh; }

.claw-room { background: radial-gradient(circle at 20% 80%, rgba(255,155,33,.2), transparent 23rem), #171124; }
.claw-room h2 { left: 8vw; bottom: 9vh; color: var(--pink); }
.claw-rail { position: absolute; inset: 3vh 0 0 0; width: 100vw; height: 86vh; }
.diagonal-track { stroke: var(--ink); stroke-width: 46; stroke-linecap: round; }
.neon-track { stroke: var(--banana); stroke-width: 8; stroke-linecap: round; stroke-dasharray: 24 22; filter: drop-shadow(0 0 12px #FFE66D); }
.claw { position: absolute; left: var(--claw-x, 54vw); top: var(--claw-y, 26vh); z-index: 7; width: 120px; height: 150px; transform: rotate(14deg); transition: left .2s ease-out, top .2s ease-out; }
.claw::before { content: ""; position: absolute; left: 50%; top: -110px; width: 8px; height: 120px; background: var(--cyan); box-shadow: 0 0 16px var(--cyan); }
.claw span { position: absolute; top: 18px; left: 31px; width: 58px; height: 58px; border-radius: 50%; display: grid; place-items: center; background: var(--orange); border: 4px solid var(--ink); color: var(--ink); font-family: var(--fat); font-size: 46px; }
.claw i { position: absolute; bottom: 20px; width: 14px; height: 72px; background: var(--milk); border: 3px solid var(--ink); transform-origin: top; border-radius: 999px; }
.claw i:nth-child(1){ left: 27px; transform: rotate(26deg); } .claw i:nth-child(2){ left: 54px; } .claw i:nth-child(3){ right: 27px; transform: rotate(-26deg); }
.contradiction { position: absolute; z-index: 5; max-width: 360px; color: var(--milk); font-family: var(--pen); font-size: clamp(1.8rem, 3vw, 3.2rem); }
.yes { left: 12vw; top: 23vh; color: var(--melon); transform: rotate(-7deg); } .no { right: 12vw; bottom: 25vh; color: var(--pink); transform: rotate(7deg); }
.speech { position: absolute; right: 13vw; top: 18vh; padding: 18px 22px; background: var(--milk); color: var(--ink); border: 3px solid var(--ink); border-radius: 28px; font-family: var(--space); box-shadow: 8px 9px 0 var(--cyan); }
.claw-copy { left: 42vw; bottom: 11vh; }

.prize-room { color: var(--ink); background: radial-gradient(circle at 50% 28%, #FFE66D, #FFF7E8 36%, #FF9B21 100%); }
.prize-room::before { color: var(--ink); }
.prize-room h2 { left: 7vw; top: 10vh; color: var(--ink); text-shadow: 6px 7px 0 #FFF7E8, 10px 13px 0 rgba(255,79,163,.55); }
.hatch-glow { position: absolute; left: 50%; bottom: 10vh; width: min(720px, 86vw); height: 250px; transform: translateX(-50%); border-radius: 50% 50% 30px 30px; background: radial-gradient(ellipse at center, rgba(255,255,255,.92), rgba(33,244,208,.32), transparent 68%); filter: blur(2px); }
.prize-tray { position: absolute; left: 50%; bottom: 14vh; width: min(660px, 84vw); height: 210px; transform: translateX(-50%); border-radius: 36px; background: linear-gradient(#241A2E, #171124); border: 8px solid var(--ink); box-shadow: inset 0 18px 30px rgba(255,255,255,.12), 0 28px 0 rgba(36,26,46,.24); }
.final-token { position: absolute; left: 50%; top: 38%; transform: translate(-50%, -50%) rotate(-4deg); padding: 24px 38px; border-radius: 999px; border: 5px solid var(--ink); background: radial-gradient(circle at 30% 18%, var(--milk), var(--cyan) 46%, var(--melon)); color: var(--ink); font-family: var(--fat); font-size: clamp(1.8rem, 4vw, 4rem); box-shadow: 0 0 34px var(--cyan), 10px 14px 0 rgba(0,0,0,.25); }
.confetti { position: absolute; width: 18px; height: 18px; border-radius: 50%; background: var(--pink); animation: confetti 2.2s ease-in-out infinite alternate; }
.c1{left:12%;top:28%;background:var(--melon)} .c2{left:25%;bottom:20%;background:var(--cyan);animation-delay:.2s} .c3{right:22%;top:18%;background:var(--banana);animation-delay:.5s} .c4{right:10%;bottom:25%;background:var(--pink);animation-delay:.8s} .c5{left:50%;bottom:12%;background:var(--orange);animation-delay:1s}
.final-receipt { right: 8vw; top: 24vh; transform: rotate(5deg); }
.final-copy { right: 8vw; bottom: 38vh; background: rgba(255,247,232,.7); color: var(--ink); border-color: var(--ink); }
.open-button { right: 10vw; bottom: 11vh; background: var(--pink); }
.prize-room.opened .final-token { animation: prizePop .9s cubic-bezier(.2,1.6,.3,1) both; }

@keyframes pop { from { transform: scale(.8) rotate(-8deg); } to { transform: scale(1.25) rotate(9deg); } }
@keyframes capsuleTilt { from { transform: translateY(0) rotate(-8deg); } to { transform: translateY(15px) rotate(12deg); } }
@keyframes wobble { 0%,100%{ transform: rotate(-7deg) scale(1); } 50%{ transform: rotate(8deg) scale(1.08); } }
@keyframes confetti { from { transform: translateY(0) rotate(0); } to { transform: translateY(-24px) rotate(180deg); } }
@keyframes prizePop { 0% { transform: translate(-50%, -50%) rotate(-4deg) scale(.88); } 60% { transform: translate(-50%, -80%) rotate(5deg) scale(1.18); } 100% { transform: translate(-50%, -50%) rotate(-4deg) scale(1); } }

@media (max-width: 760px) {
  .token { width: 58px; height: 58px; }
  .room { padding: 22px; }
  .coin-slot { right: 6vw; width: 112px; height: 48vh; }
  .coin-slot::before { font-size: 22rem; left: -52px; }
  .scene-copy, .coin-room .scene-copy, .side-copy, .sticker-room .scene-copy, .claw-copy, .final-copy { left: 6vw; right: auto; bottom: 8vh; max-width: 86vw; }
  .label-stack { left: 7vw; right: auto; top: 58vh; }
  .sticker-cloud { inset: 24vh 2vw 14vh 4vw; }
  .claw-room h2, .room h1, .prize-room h2 { left: 6vw; }
  .receipt { max-width: 80vw; }
  .final-receipt { left: 7vw; right: auto; }
}
