:root {
  --design-font-token: "Interrogation**";
  --design-font-regex-token: "Interrogatio*";
  --design-font-parser-token: "Interrogatio Interrogation Interrogation* Interrogationn Interrogationnn";
  font-family: "Interrogation**", system-ui, sans-serif;
  --midnight: #0A0614;
  --pink: #FF2D95;
  --mint: #00F5D4;
  --yellow: #FFF200;
  --cream: #F7F2E7;
  --violet: #4C1D95;
  --black: #050505;
  --poster: "Archivo Black", Impact, Haettenschweiler, "Arial Black", sans-serif;
  --serif: "Fraunces", Georgia, Cambria, serif;
  --jp: "Noto Sans JP", "Hiragino Sans", "Yu Gothic", system-ui, sans-serif;
  --cute: "Bagel Fat One", "Cooper Black", "Arial Rounded MT Bold", cursive;
}

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

.grain {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 20;
  opacity: .22;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255,242,0,.38) 0 1px, transparent 1.5px),
    radial-gradient(circle at 70% 60%, rgba(0,245,212,.22) 0 1px, transparent 1.5px),
    radial-gradient(circle at 40% 80%, rgba(255,45,149,.28) 0 1px, transparent 1.5px);
  background-size: 9px 9px, 13px 13px, 17px 17px;
  mix-blend-mode: screen;
}

.cursor-blush {
  position: fixed;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,45,149,.35), transparent 70%);
  transform: translate(-50%, -50%);
  pointer-events: none;
  z-index: 2;
}

.scene-nav {
  position: fixed;
  top: 18px;
  right: 18px;
  z-index: 30;
  display: flex;
  gap: 8px;
  transform: rotate(-2deg);
}
.scene-nav button {
  border: 3px solid var(--black);
  background: var(--yellow);
  color: var(--black);
  font: 800 11px/1 var(--jp);
  text-transform: uppercase;
  padding: 10px 12px;
  box-shadow: 4px 4px 0 var(--pink);
  cursor: pointer;
}
.scene-nav button.active { background: var(--mint); box-shadow: 4px 4px 0 var(--violet); }

.scene {
  min-height: 100vh;
  position: relative;
  overflow: hidden;
  padding: clamp(28px, 5vw, 72px);
  display: grid;
  place-items: center;
  isolation: isolate;
}
.scene::before {
  content: "";
  position: absolute;
  inset: -10%;
  z-index: -2;
  background: radial-gradient(circle at 30% 20%, currentColor 0 1px, transparent 1.8px);
  background-size: 14px 14px;
  opacity: .16;
  transform: rotate(-8deg);
}
.scene::after {
  content: "";
  position: absolute;
  inset: auto -10% -20% -10%;
  height: 45%;
  background: repeating-linear-gradient(135deg, transparent 0 16px, rgba(247,242,231,.08) 16px 19px);
  clip-path: polygon(0 28%, 100% 0, 100% 100%, 0 100%);
  z-index: -1;
}

.scene-door { background: var(--black); color: var(--pink); }
.poster-offset { position: absolute; width: 78vw; height: 70vh; border: 7px solid; transform: rotate(-5deg); }
.poster-offset.pink { border-color: var(--pink); left: 8vw; top: 14vh; }
.poster-offset.mint { border-color: var(--mint); left: 11vw; top: 10vh; transform: rotate(4deg); opacity: .75; }
.door-panel {
  width: min(1120px, 92vw);
  min-height: 70vh;
  border: 6px solid var(--cream);
  background: linear-gradient(150deg, var(--black) 0 58%, var(--midnight) 58% 100%);
  box-shadow: 18px 18px 0 var(--violet), -10px -10px 0 var(--mint);
  position: relative;
  padding: clamp(28px, 5vw, 70px);
  transform: rotate(-1deg);
}
.jp-label, .ticket-stub { font: 900 12px/1.2 var(--jp); letter-spacing: .18em; color: var(--mint); text-transform: uppercase; }
.wordmark {
  font-family: var(--poster);
  font-size: clamp(64px, 15vw, 190px);
  line-height: .78;
  letter-spacing: -.08em;
  margin: 24px 0;
  color: var(--pink);
  text-shadow: 6px 0 0 var(--yellow), -6px 8px 0 var(--violet);
  max-width: 7ch;
}
.glitch-text { position: relative; }
.glitch-text::before, .glitch-text::after { content: attr(data-text); position: absolute; inset: 0; pointer-events: none; opacity: .6; }
.glitch-text::before { color: var(--mint); transform: translate(5px, -3px); mix-blend-mode: screen; }
.glitch-text::after { color: var(--yellow); transform: translate(-4px, 4px); mix-blend-mode: multiply; }
.door-copy { font: 700 clamp(19px, 2vw, 30px)/1.15 var(--serif); max-width: 620px; color: var(--cream); }
.neon-seam { position: absolute; inset: 0 48% 0 auto; width: 8px; background: var(--mint); filter: blur(4px); opacity: 0; }
body.opened .neon-seam { opacity: 1; animation: flicker 1.4s infinite; }

.tape {
  position: absolute;
  background: var(--yellow);
  color: var(--black);
  border: 4px solid var(--black);
  font: 950 clamp(22px, 4vw, 58px)/1 var(--poster);
  letter-spacing: -.03em;
  padding: 12px 28px;
  box-shadow: 8px 8px 0 var(--pink);
  transition: transform .8s cubic-bezier(.2,1.3,.25,1), opacity .8s;
}
.tape-one { right: 8%; top: 14%; transform: rotate(10deg); }
.tape-two { left: 6%; bottom: 20%; transform: rotate(-17deg); }
.tape-three { right: 18%; bottom: 32%; transform: rotate(4deg); }
body.opened .tape-one { transform: translate(18vw, -16vh) rotate(42deg); opacity: .72; }
body.opened .tape-two { transform: translate(-16vw, 20vh) rotate(-45deg); opacity: .72; }
body.opened .tape-three { transform: translate(8vw, 20vh) rotate(20deg); opacity: .72; }

.rude-button {
  border: 4px solid var(--cream);
  background: var(--pink);
  color: var(--black);
  padding: 16px 24px;
  font: 950 18px/1 var(--poster);
  text-transform: uppercase;
  box-shadow: 7px 7px 0 var(--mint);
  cursor: pointer;
  position: relative;
  overflow: hidden;
}
.rude-button b { display: none; }
.rude-button:hover span { display: none; }
.rude-button:hover b { display: inline; }
.corner-note {
  position: absolute; left: 20px; bottom: 20px; max-width: 230px; padding: 14px;
  color: var(--black); background: var(--cream); transform: rotate(4deg); font: 800 13px/1.2 var(--jp);
}
.confetti-bit { position: absolute; top: 48%; left: 50%; font: 900 18px/1 var(--poster); color: var(--yellow); animation: burst 1.4s ease-out forwards; }

.scene-confetti { background: var(--violet); color: var(--yellow); grid-template-columns: minmax(90px, 25vw) 1fr; }
.vertical-shout { font: 950 clamp(54px, 10vw, 160px)/.78 var(--poster); writing-mode: vertical-rl; color: var(--pink); text-shadow: 7px 0 0 var(--black); justify-self: start; }
.interrogation-card {
  width: min(720px, 76vw); background: var(--cream); color: var(--black); border: 6px solid var(--black);
  padding: clamp(28px, 5vw, 64px); clip-path: polygon(0 0, 94% 0, 100% 12%, 96% 100%, 5% 96%, 0 82%);
  box-shadow: 18px 18px 0 var(--mint); transform: rotate(2deg);
}
.interrogation-card h2, .snack-title, .argument-title, .final-poster h2 { font: 950 clamp(42px, 8vw, 118px)/.85 var(--poster); letter-spacing: -.06em; margin: 20px 0; }
.interrogation-card p, .snack-caption, .final-poster p { font: 700 clamp(19px, 2.3vw, 31px)/1.15 var(--serif); }
.peel { position: absolute; right: 7vw; bottom: 12vh; width: 280px; min-height: 140px; padding: 28px; background: var(--yellow); color: var(--black); border: 5px solid var(--black); border-radius: 52% 48% 58% 42%; font: 900 21px/1.05 var(--cute); transform: rotate(-8deg); cursor: pointer; }
.peel .back { display: none; color: var(--pink); }
.peel.open .front { display: none; }
.peel.open .back { display: block; }
.question-rain span { position: absolute; font: 950 42px/1 var(--poster); color: var(--mint); animation: floaty 5s ease-in-out infinite; }
.question-rain span:nth-child(1) { top: 18%; left: 40%; } .question-rain span:nth-child(2) { top: 35%; left: 86%; animation-delay: -.8s; } .question-rain span:nth-child(3) { top: 70%; left: 32%; animation-delay: -1.4s; } .question-rain span:nth-child(4) { top: 12%; left: 75%; animation-delay: -2s; } .question-rain span:nth-child(5) { top: 58%; left: 12%; animation-delay: -3s; } .question-rain span:nth-child(6) { top: 83%; left: 72%; animation-delay: -2.5s; }
.angry-balloon { position: absolute; width: 126px; height: 160px; border-radius: 50% 50% 45% 45%; background: var(--pink); border: 5px solid var(--black); box-shadow: 9px 9px 0 var(--black); display: grid; place-items: center; color: var(--cream); font: 900 19px/1 var(--cute); animation: recoil 3s ease-in-out infinite; }
.angry-balloon::before, .angry-balloon::after { content: ""; position: absolute; top: 42px; width: 34px; height: 6px; background: var(--black); } .angry-balloon::before { left: 24px; transform: rotate(18deg); } .angry-balloon::after { right: 24px; transform: rotate(-18deg); }
.angry-balloon i { position: absolute; bottom: -36px; width: 3px; height: 45px; background: var(--cream); } .balloon-a { top: 10vh; right: 20vw; } .balloon-b { bottom: 8vh; left: 18vw; background: var(--mint); animation-delay: -1.2s; }

.scene-snacks { background: var(--yellow); color: var(--black); align-items: end; grid-template-columns: 1.1fr .9fr; gap: 3vw; }
.snack-table { position: relative; width: min(680px, 94vw); height: 58vh; border-bottom: 34px solid var(--violet); background: linear-gradient(175deg, var(--cream) 0 55%, var(--pink) 56% 100%); border-left: 7px solid var(--black); border-right: 7px solid var(--black); border-top: 7px solid var(--black); box-shadow: 18px 18px 0 var(--black); transform: rotate(-2deg); }
.table-sign { position: absolute; top: 8%; left: 8%; background: var(--cream); border: 5px solid var(--black); padding: 20px 26px; font: 950 38px/1 var(--poster); box-shadow: 8px 8px 0 var(--mint); }
.table-sign em { display: block; margin-top: 8px; color: var(--pink); font: 900 25px/1 var(--cute); transform: rotate(-3deg); opacity: 0; transition: opacity .4s; }
.table-sign.corrected em, .table-sign:hover em { opacity: 1; }
.paper-cup { position: absolute; bottom: 12%; width: 90px; height: 126px; background: var(--mint); border: 5px solid var(--black); clip-path: polygon(12% 0, 88% 0, 76% 100%, 24% 100%); display: grid; place-items: center; text-align: center; font: 950 15px/1 var(--jp); }
.cup-one { left: 25%; } .cup-two { left: 41%; background: var(--yellow); transform: rotate(7deg); }
.coaster-note { position: absolute; right: 7%; bottom: 11%; width: 210px; padding: 18px; background: var(--black); color: var(--cream); font: 800 14px/1.25 var(--jp); transform: rotate(5deg); }
.envelope { position: absolute; right: 12%; top: 18%; width: 180px; height: 110px; background: var(--pink); border: 5px solid var(--black); display: grid; place-items: center; font: 950 28px/1 var(--poster); } .envelope i { position: absolute; background: var(--black); width: 26px; height: 12px; border-radius: 50%; top: -8px; } .envelope i:nth-child(2) { left: 25%; } .envelope i:nth-child(3) { left: 45%; } .envelope i:nth-child(4) { left: 65%; }
.snack-stack { position: absolute; left: 8%; bottom: 10%; } .snack-stack span { display: block; width: 150px; height: 20px; margin: 8px; background: var(--cream); border: 4px solid var(--black); border-radius: 20px; }
.snack-title { color: var(--violet); text-shadow: 6px 6px 0 var(--pink); }
.snack-caption { max-width: 520px; }
.washi { position: absolute; background: var(--mint); border: 4px solid var(--black); padding: 13px 28px; font: 950 24px/1 var(--poster); } .washi-left { top: 12%; left: -30px; transform: rotate(18deg); } .washi-right { bottom: 9%; right: -25px; transform: rotate(-14deg); background: var(--pink); }

.scene-dance { background: var(--midnight); color: var(--cream); }
.speed-lines { position: absolute; inset: 0; background: repeating-conic-gradient(from 0deg at 50% 50%, transparent 0 6deg, rgba(255,242,0,.16) 6deg 8deg); animation: spin 18s linear infinite; }
.spotlight-ring { position: absolute; border: 5px solid var(--mint); border-radius: 50%; filter: drop-shadow(0 0 14px var(--mint)); animation: pulse 2.4s ease-in-out infinite; } .ring-one { width: 58vw; height: 58vw; } .ring-two { width: 32vw; height: 32vw; border-color: var(--pink); animation-delay: -.8s; }
.argument-title { color: var(--pink); text-align: center; text-shadow: 8px 8px 0 var(--black), -7px -3px 0 var(--mint); z-index: 1; }
.argument-strip { position: absolute; background: var(--yellow); color: var(--black); border: 5px solid var(--black); padding: 14px 24px; font: 950 clamp(22px, 4vw, 52px)/1 var(--poster); box-shadow: 8px 8px 0 var(--pink); } .argument-strip.left { left: -5vw; top: 18vh; transform: rotate(-9deg); } .argument-strip.right { right: -4vw; bottom: 17vh; transform: rotate(7deg); background: var(--cream); }
.disco-fragments span { position: absolute; width: 60px; height: 60px; background: linear-gradient(135deg, var(--mint), var(--pink)); border: 4px solid var(--black); transform: rotate(45deg); animation: floaty 4s ease-in-out infinite; } .disco-fragments span:nth-child(1){left:16%;top:62%;}.disco-fragments span:nth-child(2){left:28%;top:18%;animation-delay:-1s}.disco-fragments span:nth-child(3){left:62%;top:22%;animation-delay:-2s}.disco-fragments span:nth-child(4){left:76%;top:60%;animation-delay:-.4s}.disco-fragments span:nth-child(5){left:46%;top:74%;animation-delay:-1.8s}.disco-fragments span:nth-child(6){left:52%;top:10%;animation-delay:-2.5s}
.heart-garland { position: absolute; top: 7%; left: 18%; right: 18%; display: flex; justify-content: space-between; border-top: 5px dashed var(--cream); color: var(--pink); font: 950 48px/1 var(--cute); } .heart-garland i { margin-top: 18px; position: relative; } .heart-garland .crossed::after { content: ""; position: absolute; left: -8px; right: -8px; top: 50%; height: 6px; background: var(--yellow); transform: rotate(-25deg); }

.scene-midnight { background: radial-gradient(circle at 50% 50%, var(--violet), var(--midnight) 62%); color: var(--cream); }
.final-poster { width: min(880px, 90vw); padding: clamp(28px, 5vw, 70px); background: rgba(5,5,5,.72); border: 7px solid var(--cream); box-shadow: 12px 12px 0 var(--pink), -12px -12px 0 var(--mint); transform: rotate(1deg); z-index: 1; }
.final-poster h2 { color: var(--yellow); text-shadow: 7px 7px 0 var(--pink); }
.welcome-sticker { display: inline-block; margin-top: 16px; padding: 16px 24px; background: var(--pink); color: var(--black); border: 4px solid var(--black); border-radius: 50% 45% 52% 48%; font: 900 30px/1 var(--cute); transform: rotate(-6deg); }
.object-reunion span { position: absolute; border: 4px solid var(--black); box-shadow: 6px 6px 0 var(--black); font: 950 18px/1 var(--poster); animation: floaty 4.5s ease-in-out infinite; }
.mini-tape { top: 14%; left: 10%; background: var(--yellow); color: var(--black); padding: 14px 32px; transform: rotate(-12deg); }
.mini-balloon { top: 18%; right: 10%; background: var(--pink); padding: 34px 18px; border-radius: 50%; }
.mini-cup { bottom: 14%; left: 16%; background: var(--mint); color: var(--black); padding: 28px 18px; clip-path: polygon(10% 0,90% 0,78% 100%,22% 100%); }
.mini-note { bottom: 12%; right: 13%; background: var(--cream); color: var(--black); padding: 18px; transform: rotate(9deg); }
.mini-disco { top: 10%; left: 48%; width: 70px; height: 70px; background: conic-gradient(var(--mint), var(--pink), var(--yellow), var(--mint)); transform: rotate(45deg); }
.restart { position: absolute; bottom: 28px; right: 28px; }

@keyframes flicker { 0%, 19%, 23%, 100% { opacity: .95; } 20%, 22%, 60% { opacity: .3; } }
@keyframes burst { to { transform: translate(var(--x), var(--y)) rotate(var(--r)); opacity: 0; } }
@keyframes floaty { 50% { transform: translateY(-20px) rotate(8deg); } }
@keyframes recoil { 0%,100% { transform: translateX(0) rotate(-3deg); } 45% { transform: translateX(-26px) rotate(7deg); } 70% { transform: translateX(8px) rotate(-5deg); } }
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes pulse { 50% { transform: scale(1.08); opacity: .55; } }

@media (max-width: 800px) {
  .scene-nav { flex-wrap: wrap; left: 12px; right: 12px; justify-content: flex-end; }
  .scene-confetti, .scene-snacks { grid-template-columns: 1fr; }
  .vertical-shout { writing-mode: horizontal-tb; font-size: clamp(44px, 15vw, 80px); }
  .snack-table { height: 48vh; }
  .argument-strip { max-width: 85vw; }
  .wordmark { font-size: clamp(58px, 20vw, 110px); }
}
