:root {
    --ink-black: #171225;
    --parchment-cream: #F7E7B4;
    --permit-magenta: #FF3EA5;
    --token-gold: #FFC857;
    --arcade-cyan: #20E3D2;
    --stamp-red: #E63B2E;
    --bruised-violet: #4B2A7B;
    --outline: 5px solid var(--ink-black);
    --display: "Bungee Shade", cursive;
    --ceremonial: "Fraunces", serif;
    --body: "Outfit", sans-serif;
    --pixel: "Silkscreen", monospace;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    margin: 0;
    overflow-x: hidden;
    color: var(--parchment-cream);
    background:
        radial-gradient(circle at 12% 18%, rgba(255, 62, 165, .23), transparent 26rem),
        radial-gradient(circle at 80% 72%, rgba(32, 227, 210, .2), transparent 26rem),
        linear-gradient(135deg, var(--ink-black), var(--bruised-violet) 55%, #171225);
    font-family: var(--body);
    cursor: none;
}

body.is-inserted .parchment-cartridge { transform: translate(-28vw, -18vh) rotate(-7deg) scale(.62); opacity: .45; }
body.has-key .permission-key { transform: rotate(360deg) scale(1.1); background: var(--arcade-cyan); }
body.is-granted .denied-stamp { color: var(--token-gold); border-color: var(--token-gold); transform: rotate(-4deg) scale(1); }
body.is-granted .denied-stamp::before { content: "GRANTED"; }
body.is-granted .denied-stamp { font-size: 0; }
body.is-granted .denied-stamp::before { font-size: clamp(2rem, 5vw, 5rem); }
body.gate-open .keyhole-portal { clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%); filter: drop-shadow(0 0 45px var(--arcade-cyan)); }

.grain-overlay {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 90;
    opacity: .18;
    background-image:
        repeating-radial-gradient(circle at 0 0, rgba(247, 231, 180, .22) 0 1px, transparent 1px 5px),
        repeating-linear-gradient(45deg, transparent 0 11px, rgba(255, 200, 87, .16) 11px 12px);
    mix-blend-mode: overlay;
}

.cursor-token {
    position: fixed;
    top: 0;
    left: 0;
    width: 58px;
    height: 58px;
    border: 4px solid var(--ink-black);
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: var(--token-gold);
    color: var(--ink-black);
    font: 700 .7rem var(--pixel);
    pointer-events: none;
    z-index: 100;
    box-shadow: 6px 6px 0 var(--permit-magenta);
    transform: translate(-50%, -50%);
}

.quest-stage { width: 400vw; min-height: 100vh; display: flex; }

.scene {
    position: relative;
    width: 100vw;
    min-height: 100vh;
    flex: 0 0 100vw;
    overflow: hidden;
    padding: clamp(1rem, 4vw, 4rem);
    isolation: isolate;
}

.scene::before {
    content: "";
    position: absolute;
    inset: 1rem;
    border: 4px dashed rgba(247, 231, 180, .25);
    pointer-events: none;
    z-index: -1;
}

.inventory-ribbon {
    position: fixed;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    z-index: 50;
    display: grid;
    gap: .65rem;
    padding: .75rem;
    background: linear-gradient(var(--parchment-cream), #e8cb7e);
    border: var(--outline);
    box-shadow: -8px 8px 0 var(--ink-black), -14px 14px 0 var(--permit-magenta);
    color: var(--ink-black);
}

.inventory-title, .inventory-item { font-family: var(--pixel); text-transform: uppercase; }
.inventory-title { writing-mode: vertical-rl; position: absolute; left: -2.2rem; top: .8rem; color: var(--token-gold); text-shadow: 2px 2px var(--ink-black); }
.inventory-item { padding: .5rem .65rem; border: 3px solid var(--ink-black); background: white; font-size: .72rem; transform: skew(-7deg); }
.inventory-item.is-lit { background: var(--arcade-cyan); box-shadow: 0 0 18px var(--arcade-cyan); }

.quest-map {
    position: fixed;
    left: 50%;
    bottom: 1rem;
    transform: translateX(-50%);
    z-index: 55;
    display: flex;
    gap: .4rem;
    padding: .45rem;
    background: var(--ink-black);
    border: 3px solid var(--parchment-cream);
}

button { font: inherit; color: inherit; }
.quest-map button, .ritual-button { cursor: none; }
.quest-map button {
    border: 0;
    padding: .55rem .75rem;
    background: var(--bruised-violet);
    color: var(--parchment-cream);
    font-family: var(--pixel);
    text-transform: uppercase;
}
.quest-map button.is-active { background: var(--permit-magenta); color: var(--ink-black); }

.kicker, .serial, .slot-label, .coin-return { font-family: var(--pixel); text-transform: uppercase; letter-spacing: .08em; }
.kicker { color: var(--arcade-cyan); text-shadow: 2px 2px var(--ink-black); }

.cartridge-vestibule { background: radial-gradient(circle at 50% 0, rgba(255, 200, 87, .18), transparent 35%), linear-gradient(110deg, var(--ink-black), var(--bruised-violet)); }
.stage-curtain { position: absolute; top: 0; bottom: 0; width: 16vw; background: repeating-linear-gradient(90deg, var(--stamp-red) 0 26px, #8f2019 26px 48px); z-index: -1; filter: drop-shadow(0 0 20px #000); }
.curtain-left { left: 0; clip-path: polygon(0 0, 100% 0, 72% 100%, 0 100%); }
.curtain-right { right: 0; clip-path: polygon(28% 0, 100% 0, 100% 100%, 0 100%); }

.marquee-frame { width: min(920px, 78vw); margin: 0 auto 2rem; text-align: center; padding: 1rem 1.3rem; background: var(--ink-black); border: 5px solid var(--token-gold); box-shadow: 0 0 0 8px var(--permit-magenta), 12px 12px 0 #000; }
.wordmark { margin: 0; font-family: var(--display); font-size: clamp(2.5rem, 8vw, 8rem); line-height: .9; color: var(--parchment-cream); text-shadow: 0 0 18px var(--permit-magenta), 5px 5px 0 var(--arcade-cyan); animation: flicker 3s infinite steps(1); }
.key-dot { color: var(--token-gold); display: inline-block; transform-origin: 50% 12%; animation: keyTwist 4s infinite ease-in-out; }
.marquee-bulbs { display: flex; justify-content: space-around; margin-top: .8rem; }
.marquee-bulbs span { width: 18px; height: 18px; border-radius: 50%; background: var(--token-gold); box-shadow: 0 0 14px var(--token-gold); animation: bulbBlink 1.2s infinite alternate; }
.marquee-bulbs span:nth-child(even) { animation-delay: .35s; background: var(--arcade-cyan); }

.vestibule-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: min(6vw, 5rem); align-items: center; max-width: 1180px; margin: 0 auto; }
.cabinet-shell { position: relative; padding: 2rem; background: linear-gradient(145deg, var(--permit-magenta), var(--bruised-violet)); border: 7px solid var(--ink-black); border-radius: 2rem 2rem .5rem .5rem; box-shadow: 18px 18px 0 #000; transform: rotate(-2deg); }
.cabinet-screen { position: relative; min-height: 370px; display: grid; place-items: center; background: radial-gradient(circle, rgba(32, 227, 210, .18), #0c0817 70%); border: 5px solid var(--ink-black); overflow: hidden; }
.cabinet-screen::before { content: ""; position: absolute; inset: 0; background: repeating-linear-gradient(0deg, transparent 0 10px, rgba(32, 227, 210, .08) 10px 12px); }
.cartridge-slot { width: 70%; height: 48px; border: 5px solid var(--token-gold); background: #05030a; box-shadow: inset 0 0 20px var(--arcade-cyan), 0 0 24px var(--arcade-cyan); }
.slot-label { position: absolute; top: 1.2rem; color: var(--arcade-cyan); }
.coin-return { margin-top: 1.4rem; color: var(--token-gold); }

.parchment-cartridge { justify-self: center; width: min(460px, 82vw); min-height: 330px; border: var(--outline); background: linear-gradient(120deg, var(--parchment-cream), #fff3c8 46%, #d9b967); color: var(--ink-black); padding: 2rem 2rem 3rem; text-align: left; box-shadow: 14px 14px 0 var(--stamp-red), 25px 25px 0 #000; transform: rotate(6deg); transition: transform .9s cubic-bezier(.2, 1.3, .3, 1), opacity .6s; }
.parchment-cartridge strong { display: block; font: 800 clamp(2rem, 5vw, 4.8rem) var(--ceremonial); line-height: .9; margin: 2rem 0 .8rem; }
.parchment-cartridge em { font-family: var(--pixel); font-style: normal; color: var(--bruised-violet); }
.connector-teeth { position: absolute; left: 10%; right: 10%; bottom: .8rem; height: 34px; background: repeating-linear-gradient(90deg, var(--token-gold) 0 24px, var(--ink-black) 24px 31px); border: 3px solid var(--ink-black); }

.denied-stamp { position: absolute; transform: rotate(-16deg) scale(.9); border: 7px solid var(--stamp-red); color: var(--stamp-red); padding: .3rem .8rem; font: 800 clamp(2rem, 5vw, 5rem) var(--ceremonial); opacity: .92; animation: deniedShake 2.8s infinite; }
.ticket-rail { position: absolute; left: 4vw; bottom: 15vh; display: flex; gap: 1rem; transform: rotate(-8deg); }
.ticket-rail span { padding: .6rem 1rem; background: var(--token-gold); color: var(--ink-black); border: 3px solid var(--ink-black); font-family: var(--pixel); box-shadow: 5px 5px 0 var(--permit-magenta); }

.clause-scroll { background: linear-gradient(100deg, #1b1230, var(--ink-black)); }
.diagonal-scroll { position: relative; width: min(1180px, 86vw); min-height: 72vh; margin: 8vh auto 0; padding: clamp(2rem, 5vw, 5rem); color: var(--ink-black); background: linear-gradient(135deg, transparent 0 6%, var(--parchment-cream) 6% 88%, transparent 88%), repeating-linear-gradient(45deg, #d4b96f 0 16px, var(--parchment-cream) 16px 34px); border: var(--outline); box-shadow: 18px 18px 0 var(--permit-magenta), 30px 30px 0 #000; transform: rotate(-2deg); }
.diagonal-scroll h2, .gatekeeper-card h2, .unlock-copy h2 { margin: 0; font-family: var(--display); line-height: .9; }
.diagonal-scroll h2 { font-size: clamp(3rem, 9vw, 9rem); color: var(--bruised-violet); text-shadow: 4px 4px 0 var(--token-gold); }
.diagonal-scroll p { max-width: 650px; font-size: clamp(1.1rem, 2vw, 1.6rem); font-weight: 600; }
.clause-ribbon { position: absolute; padding: .75rem 1rem; background: var(--stamp-red); color: var(--parchment-cream); border: 3px solid var(--ink-black); font-family: var(--pixel); box-shadow: 6px 6px 0 var(--ink-black); }
.ribbon-a { top: -1rem; right: 10%; transform: rotate(5deg); }
.ribbon-b { bottom: 12%; left: -2rem; transform: rotate(-7deg); }
.dotted-path { position: relative; height: 95px; margin: 2rem 0; border-top: 6px dotted var(--bruised-violet); }
.rule-sprite { position: absolute; top: -22px; width: 40px; height: 40px; background: var(--arcade-cyan); border: 4px solid var(--ink-black); image-rendering: pixelated; animation: march 4s infinite alternate ease-in-out; }
.rule-sprite i { position: absolute; inset: 9px 7px; background: var(--parchment-cream); border: 3px solid var(--ink-black); }
.sprite-one { left: 8%; }
.sprite-two { left: 42%; animation-delay: .7s; background: var(--token-gold); }
.sprite-three { left: 72%; animation-delay: 1.1s; background: var(--permit-magenta); }
.collectibles { display: flex; align-items: center; gap: 1.2rem; flex-wrap: wrap; }
.permission-key { display: inline-flex; align-items: center; gap: .7rem; padding: .85rem 1.2rem; border: var(--outline); background: var(--token-gold); color: var(--ink-black); font-family: var(--pixel); box-shadow: 8px 8px 0 var(--bruised-violet); transition: transform .8s, background .5s; }
.permission-key span { width: 70px; height: 26px; background: var(--token-gold); border: 4px solid var(--ink-black); border-radius: 20px 0 0 20px; position: relative; }
.permission-key span::after { content: ""; position: absolute; right: -26px; top: 6px; width: 30px; height: 12px; background: var(--ink-black); box-shadow: 14px 12px 0 var(--ink-black); }
.clause-coin, .hologram-sticker { width: 105px; height: 105px; display: grid; place-items: center; text-align: center; font-family: var(--pixel); color: var(--ink-black); border: 4px solid var(--ink-black); }
.clause-coin { border-radius: 50%; background: var(--token-gold); box-shadow: inset 0 0 0 8px #e8aa24; }
.hologram-sticker { background: linear-gradient(120deg, var(--permit-magenta), var(--arcade-cyan), var(--parchment-cream), var(--permit-magenta)); transform: rotate(9deg); animation: shimmer 2.2s infinite linear; }

.gatekeeper-booth { background: radial-gradient(circle at 56% 45%, rgba(230, 59, 46, .18), transparent 28rem), linear-gradient(135deg, var(--bruised-violet), var(--ink-black)); display: grid; place-items: center; }
.booth-roof { position: absolute; top: 7vh; padding: 1rem 3rem; background: repeating-linear-gradient(90deg, var(--token-gold) 0 28px, var(--stamp-red) 28px 56px); color: var(--ink-black); border: var(--outline); font: 700 clamp(1.2rem, 3vw, 3rem) var(--pixel); box-shadow: 10px 10px 0 #000; }
.gatekeeper-card { position: relative; width: min(680px, 78vw); padding: 5.5rem 2rem 2rem; text-align: center; color: var(--ink-black); background: var(--parchment-cream); border: var(--outline); box-shadow: 15px 15px 0 var(--arcade-cyan), 28px 28px 0 #000; }
.wig { position: absolute; top: -62px; left: 50%; width: 220px; height: 110px; transform: translateX(-50%); background: radial-gradient(circle, white 0 18px, transparent 19px), radial-gradient(circle at 25% 70%, white 0 22px, transparent 23px), radial-gradient(circle at 75% 70%, white 0 22px, transparent 23px); filter: drop-shadow(5px 5px 0 var(--ink-black)); }
.wax-seal { position: absolute; top: 30px; left: 50%; width: 92px; height: 92px; transform: translateX(-50%); border-radius: 50%; display: grid; place-items: center; background: var(--stamp-red); color: var(--parchment-cream); border: 5px solid var(--ink-black); font: 800 3rem var(--ceremonial); box-shadow: 0 0 0 8px rgba(230, 59, 46, .35); animation: bossBlink 3s infinite; }
.gatekeeper-card h2 { margin-top: 1rem; font-size: clamp(2.4rem, 6vw, 6rem); color: var(--bruised-violet); }
.gatekeeper-card p { font-size: 1.2rem; font-weight: 600; }
.stamp-handle { padding: 1rem 1.4rem; border: var(--outline); background: var(--stamp-red); color: var(--parchment-cream); font-family: var(--pixel); box-shadow: 8px 8px 0 var(--ink-black); transition: transform .15s; }
.stamp-handle.is-slammed { transform: translateY(18px) scale(.96); }
.stamp-pad { position: absolute; bottom: 8vh; width: 280px; height: 46px; background: var(--stamp-red); border: var(--outline); transform: rotate(-3deg); }
.stamp-result { position: absolute; right: 11vw; bottom: 17vh; padding: .3rem 1rem; border: 6px solid var(--stamp-red); color: var(--stamp-red); font: 800 clamp(2rem, 5vw, 5rem) var(--ceremonial); transform: rotate(12deg); opacity: .72; }
.stamp-result.granted { border-color: var(--token-gold); color: var(--token-gold); animation: stampPop .4s ease-out; }
.velvet-rope { position: absolute; left: 7vw; bottom: 12vh; display: flex; gap: 100px; }
.velvet-rope span { width: 20px; height: 130px; background: var(--token-gold); border: 4px solid var(--ink-black); position: relative; }
.velvet-rope span::after { content: ""; position: absolute; top: 35px; left: 10px; width: 120px; height: 30px; border-bottom: 12px solid var(--stamp-red); border-radius: 50%; }

.world-unlock { display: grid; grid-template-columns: .95fr 1.05fr; align-items: center; gap: 2rem; background: linear-gradient(135deg, var(--ink-black), #101a34 45%, var(--bruised-violet)); }
.keyhole-portal { width: min(560px, 78vw); height: min(720px, 76vh); justify-self: center; position: relative; overflow: hidden; border: 7px solid var(--token-gold); background: #05030a; clip-path: path("M280 0 C190 0 120 68 120 154 C120 212 150 263 196 291 L80 720 L480 720 L364 291 C410 263 440 212 440 154 C440 68 370 0 280 0 Z"); transition: clip-path 1.2s cubic-bezier(.2, 1, .25, 1), filter .8s; box-shadow: 0 0 0 10px var(--ink-black), 18px 18px 0 var(--permit-magenta); }
.world-layer { position: absolute; inset: 0; }
.stars { background: radial-gradient(circle at 20% 20%, var(--token-gold) 0 4px, transparent 5px), radial-gradient(circle at 70% 34%, var(--arcade-cyan) 0 5px, transparent 6px), radial-gradient(circle at 48% 10%, var(--permit-magenta) 0 4px, transparent 5px), linear-gradient(#11144a, #301858); animation: starDrift 7s infinite linear; }
.mountains { top: 36%; background: linear-gradient(135deg, transparent 0 45%, var(--arcade-cyan) 45% 51%, transparent 51%), linear-gradient(45deg, transparent 0 42%, var(--token-gold) 42% 52%, transparent 52%); opacity: .86; }
.city { top: 58%; background: repeating-linear-gradient(90deg, var(--ink-black) 0 42px, var(--bruised-violet) 42px 68px, var(--ink-black) 68px 95px); border-top: 6px solid var(--permit-magenta); }
.unlock-copy { max-width: 760px; }
.unlock-copy h2 { font-size: clamp(3.2rem, 9vw, 9rem); color: var(--token-gold); text-shadow: 5px 5px 0 var(--stamp-red), 0 0 22px var(--permit-magenta); }
.unlock-copy p:not(.kicker) { font-size: clamp(1.15rem, 2vw, 1.55rem); line-height: 1.45; }
.open-gate { padding: 1rem 1.5rem; border: var(--outline); background: var(--arcade-cyan); color: var(--ink-black); font-family: var(--pixel); box-shadow: 8px 8px 0 var(--permit-magenta); }
.final-tokens { position: absolute; right: 5vw; bottom: 10vh; display: flex; gap: .8rem; transform: rotate(-6deg); }
.final-tokens span { width: 80px; height: 80px; display: grid; place-items: center; border-radius: 50%; background: var(--token-gold); color: var(--ink-black); border: 4px solid var(--ink-black); font-family: var(--pixel); animation: tokenBounce 1.7s infinite alternate; }
.final-tokens span:nth-child(2) { animation-delay: .2s; background: var(--arcade-cyan); }
.final-tokens span:nth-child(3) { animation-delay: .4s; background: var(--permit-magenta); }
.final-tokens span:nth-child(4) { animation-delay: .6s; background: var(--stamp-red); color: var(--parchment-cream); }

@keyframes flicker { 0%, 8%, 11%, 100% { opacity: 1; } 9%, 10% { opacity: .55; } 45% { text-shadow: 0 0 28px var(--arcade-cyan), 5px 5px 0 var(--permit-magenta); } }
@keyframes keyTwist { 0%, 65%, 100% { transform: rotate(0); } 78% { transform: rotate(34deg); } }
@keyframes bulbBlink { from { opacity: .35; transform: scale(.82); } to { opacity: 1; transform: scale(1.08); } }
@keyframes deniedShake { 0%, 84%, 100% { translate: 0 0; } 86% { translate: -7px 0; } 88% { translate: 7px 0; } 90% { translate: -3px 0; } }
@keyframes march { from { transform: translateX(-20px) translateY(0); } to { transform: translateX(54px) translateY(-10px); } }
@keyframes shimmer { to { filter: hue-rotate(360deg); } }
@keyframes bossBlink { 0%, 47%, 53%, 100% { transform: translateX(-50%) scaleY(1); } 50% { transform: translateX(-50%) scaleY(.18); } }
@keyframes stampPop { from { transform: rotate(12deg) scale(2.2); opacity: 0; } to { transform: rotate(12deg) scale(1); opacity: .9; } }
@keyframes starDrift { to { transform: translateY(24px); } }
@keyframes tokenBounce { to { transform: translateY(-18px) rotate(12deg); } }

@media (max-width: 850px) {
    body { cursor: auto; }
    .cursor-token { display: none; }
    .quest-stage { width: 100%; display: block; }
    .scene { width: 100%; min-height: 100vh; }
    .vestibule-grid, .world-unlock { grid-template-columns: 1fr; }
    .inventory-ribbon { right: .3rem; transform: translateY(-50%) scale(.78); transform-origin: right center; }
    .quest-map { width: calc(100% - 1rem); justify-content: center; }
    .quest-map button { flex: 1; padding: .55rem .25rem; font-size: .65rem; }
    .ticket-rail, .final-tokens, .velvet-rope { display: none; }
    .stamp-result { right: 8vw; bottom: 8vh; }
    .diagonal-scroll { transform: rotate(0); }
}
