:root {
    --ink: #121018;
    --mint: #B7FFCF;
    --coral: #FF4F64;
    --violet: #7A4DFF;
    --cream: #F6E8C8;
    --coin: #B58B34;
    --blue: #26305F;
    --chalk: #E9EDF2;
    --glitch: "Rubik Glitch", system-ui;
    --grotesque: "Bricolage Grotesque", sans-serif;
    --serif: "Instrument Serif", serif;
}

* { box-sizing: border-box; }

html {
    scroll-behavior: smooth;
    background: var(--ink);
}

body {
    margin: 0;
    color: var(--chalk);
    font-family: var(--grotesque);
    background:
        radial-gradient(circle at 20% 10%, rgba(122, 77, 255, .32), transparent 30vw),
        radial-gradient(circle at 80% 25%, rgba(183, 255, 207, .14), transparent 28vw),
        linear-gradient(110deg, #121018 0%, #171328 46%, #26305F 100%);
    overflow-x: hidden;
}

button, a { font: inherit; }

.grain,
.stage-light {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 20;
}

.grain {
    opacity: .18;
    mix-blend-mode: screen;
    background-image:
        repeating-radial-gradient(circle at 17% 23%, rgba(246, 232, 200, .5) 0 1px, transparent 1px 7px),
        repeating-linear-gradient(93deg, transparent 0 11px, rgba(233, 237, 242, .07) 12px 13px);
}

.stage-light {
    background: radial-gradient(circle at var(--mx, 50%) var(--my, 20%), rgba(183, 255, 207, .16), transparent 19rem);
}

.curtain {
    position: fixed;
    top: 0;
    bottom: 0;
    width: 7.5vw;
    z-index: 15;
    pointer-events: none;
    background:
        repeating-linear-gradient(90deg, rgba(18, 16, 24, .25) 0 11px, rgba(255, 79, 100, .16) 12px 24px),
        linear-gradient(180deg, #2a1020, #121018 54%, #3b1427);
    box-shadow: inset 0 0 28px rgba(0, 0, 0, .75), 0 0 35px rgba(0, 0, 0, .45);
    transform: translateX(calc(var(--open, 0) * -2vw));
}

.curtain-right { right: 0; transform: translateX(calc(var(--open, 0) * 2vw)); }
.curtain-left { left: 0; }

.tag-nav {
    position: fixed;
    right: 2.1rem;
    top: 50%;
    transform: translateY(-50%);
    z-index: 30;
    display: grid;
    gap: .72rem;
}

.nav-tag {
    position: relative;
    min-width: 6.3rem;
    padding: .58rem .8rem .52rem 1.15rem;
    color: var(--ink);
    text-decoration: none;
    font-weight: 800;
    font-size: .78rem;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: .05em;
    background: var(--cream);
    border: 2px solid var(--ink);
    box-shadow: 5px 5px 0 var(--coral);
    clip-path: polygon(12% 0, 100% 0, 100% 100%, 12% 100%, 0 50%);
    transition: transform .35s ease, box-shadow .35s ease, background .35s ease;
}

.nav-tag span {
    color: var(--violet);
    margin-right: .35rem;
}

.nav-tag.active,
.nav-tag:hover {
    background: var(--mint);
    transform: translateX(-.55rem) rotate(-3deg);
    box-shadow: 7px 7px 0 var(--violet);
}

.scroll-receipt {
    position: fixed;
    left: 2.2rem;
    top: 2rem;
    bottom: 2rem;
    width: .55rem;
    z-index: 25;
    background: repeating-linear-gradient(180deg, rgba(246, 232, 200, .18) 0 14px, transparent 14px 24px);
    border-left: 1px dashed rgba(246, 232, 200, .45);
    border-right: 1px dashed rgba(246, 232, 200, .25);
}

.scroll-receipt span {
    display: block;
    width: 100%;
    height: calc(var(--scroll, 0) * 100%);
    background: linear-gradient(var(--mint), var(--coral), var(--violet));
    box-shadow: 0 0 18px var(--mint);
}

.room {
    position: relative;
    min-height: 100vh;
    padding: 8vw 10vw 7vw 12vw;
    display: grid;
    align-items: center;
    overflow: hidden;
    isolation: isolate;
}

.room::before {
    content: attr(data-room);
    position: absolute;
    left: 10vw;
    top: 2.1rem;
    color: rgba(246, 232, 200, .35);
    font-size: .85rem;
    text-transform: uppercase;
    letter-spacing: .18em;
    z-index: -1;
}

.room::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(18, 16, 24, .86), transparent 18%, transparent 82%, rgba(18, 16, 24, .86));
    z-index: -2;
}

.window-room {
    grid-template-columns: minmax(18rem, 1fr) minmax(20rem, .85fr);
    gap: 5vw;
}

.receipt-roll {
    position: absolute;
    top: -8vh;
    left: 17vw;
    width: 28vw;
    min-width: 19rem;
    height: 118vh;
    padding: 18vh 2rem 2rem;
    color: rgba(18, 16, 24, .86);
    background:
        repeating-linear-gradient(0deg, transparent 0 36px, rgba(18, 16, 24, .09) 37px 38px),
        linear-gradient(var(--cream), #e7d4a8);
    transform: rotate(-4deg) translateY(calc(var(--scroll, 0) * 12vh));
    box-shadow: 0 0 45px rgba(0, 0, 0, .35);
    opacity: .86;
    z-index: -1;
}

.receipt-roll::before,
.receipt-roll::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    height: .7rem;
    background: repeating-linear-gradient(90deg, transparent 0 10px, rgba(18, 16, 24, .22) 10px 16px);
}

.receipt-roll::before { top: 0; }
.receipt-roll::after { bottom: 0; }

.receipt-line {
    display: flex;
    justify-content: space-between;
    padding: 1rem 0;
    border-bottom: 1px dashed rgba(18, 16, 24, .38);
    font-size: clamp(1rem, 2vw, 1.65rem);
    font-weight: 800;
}

.receipt-line.whisper {
    display: block;
    font-family: var(--serif);
    font-style: italic;
    font-weight: 400;
    color: rgba(18, 16, 24, .62);
}

.coin-moon {
    position: absolute;
    right: 18vw;
    top: 13vh;
    width: 10rem;
    height: 10rem;
    border-radius: 50%;
    background: radial-gradient(circle at 34% 32%, #F6E8C8, var(--coin) 42%, #704a18 70%);
    box-shadow: 0 0 60px rgba(181, 139, 52, .6);
    opacity: .76;
}

.crooked-sign,
.exit-sign,
.dangling-tag {
    position: relative;
    transform: rotate(var(--tilt, -5deg));
    transform-origin: 50% -2rem;
    transition: transform .28s ease;
}

.crooked-sign {
    max-width: 47rem;
    padding: 2rem 2.2rem 2.45rem;
    color: var(--ink);
    background: var(--cream);
    border: 4px solid var(--ink);
    box-shadow: 1rem 1rem 0 var(--coral), 0 0 0 .8rem rgba(183, 255, 207, .1), 0 0 70px rgba(183, 255, 207, .23);
    clip-path: polygon(4% 0, 100% 3%, 96% 100%, 0 94%);
}

.tag-hole {
    width: 1.2rem;
    height: 1.2rem;
    border-radius: 50%;
    background: var(--ink);
    border: 3px solid var(--coin);
    box-shadow: inset 0 0 0 3px var(--cream);
}

.crooked-sign p,
.kicker {
    margin: 0 0 .7rem;
    color: var(--coral);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .13em;
}

h1,
h2,
.wheel-center {
    font-family: var(--glitch);
    font-weight: 400;
    letter-spacing: .02em;
}

h1 {
    margin: .35rem 0;
    font-size: clamp(4rem, 11vw, 11.5rem);
    line-height: .78;
    color: var(--ink);
    text-shadow: .06em .04em 0 var(--mint), -.04em -.03em 0 var(--violet);
    animation: flicker 4.5s infinite steps(1);
}

.markdown {
    display: inline-block;
    padding: .45rem .7rem;
    color: var(--cream);
    background: var(--coral);
    font-weight: 900;
    transform: rotate(-3deg);
}

.gap-slit {
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: clamp(.5rem, 1.2vw, 1rem);
    background: var(--mint);
    box-shadow: 0 0 45px 15px rgba(183, 255, 207, .48), 0 0 90px rgba(122, 77, 255, .55);
    transform: skewX(-10deg) translateX(-50%);
    opacity: .8;
    z-index: -1;
}

.intro-copy {
    align-self: end;
    max-width: 32rem;
    margin-top: 10rem;
}

.serif {
    font-family: var(--serif);
    font-style: italic;
    color: var(--mint);
    font-size: clamp(1.35rem, 2.5vw, 2.25rem);
}

.intro-copy h2,
.room-title-block h2,
.exit-ledger h2 {
    margin: 0;
    font-size: clamp(3rem, 7.5vw, 8rem);
    line-height: .84;
    color: var(--cream);
    text-shadow: .05em .04em 0 rgba(255, 79, 100, .7), -.04em -.03em 0 rgba(122, 77, 255, .9);
}

.choice-row {
    display: flex;
    flex-wrap: wrap;
    gap: .85rem;
    margin: 2rem 0 1rem;
}

.choice {
    border: 2px solid var(--cream);
    color: var(--cream);
    background: rgba(18, 16, 24, .45);
    padding: .82rem 1rem;
    text-transform: uppercase;
    font-weight: 900;
    letter-spacing: .05em;
    box-shadow: .35rem .35rem 0 var(--violet);
    cursor: pointer;
    transition: transform .25s ease, background .25s ease, color .25s ease;
}

.choice:hover,
.choice.chosen {
    transform: translate(-.18rem, -.18rem) rotate(-2deg);
    background: var(--mint);
    color: var(--ink);
}

.marginalia {
    min-height: 2.6em;
    font-family: var(--serif);
    color: var(--cream);
    font-size: 1.35rem;
}

.ghost-auditor,
.apparition {
    position: absolute;
    pointer-events: none;
}

.ghost-one {
    right: 10vw;
    bottom: 10vh;
    width: 5rem;
    height: 6.5rem;
    background: rgba(233, 237, 242, .75);
    border-radius: 50% 50% 18% 18%;
    filter: drop-shadow(0 0 20px rgba(183, 255, 207, .55));
    animation: float 5s ease-in-out infinite;
}

.ghost-one::before,
.ghost-one::after {
    content: "";
    position: absolute;
    top: 2rem;
    width: .55rem;
    height: .55rem;
    border-radius: 50%;
    background: var(--ink);
}
.ghost-one::before { left: 1.55rem; }
.ghost-one::after { right: 1.55rem; }
.ghost-one i { position: absolute; right: -1.2rem; top: 3.2rem; width: 2rem; height: 1.5rem; background: var(--cream); border: 2px solid var(--ink); }

.hall-room {
    grid-template-columns: .8fr 1.2fr;
    gap: 3vw;
    background: linear-gradient(135deg, rgba(38, 48, 95, .45), rgba(18, 16, 24, .92));
}

.price-wheel {
    position: relative;
    width: min(42vw, 34rem);
    aspect-ratio: 1;
    border-radius: 50%;
    border: 3px dashed var(--cream);
    background: radial-gradient(circle, rgba(183, 255, 207, .14), transparent 45%), conic-gradient(from 20deg, var(--violet), var(--coral), var(--coin), var(--blue), var(--violet));
    box-shadow: inset 0 0 0 1.4rem rgba(18, 16, 24, .72), 0 0 55px rgba(122, 77, 255, .42);
    transform: rotate(calc(var(--wheel, 0deg) + 8deg));
    transition: transform .3s ease-out;
}

.wheel-label {
    position: absolute;
    padding: .6rem .8rem;
    color: var(--ink);
    background: var(--cream);
    border: 2px solid var(--ink);
    font-weight: 900;
    box-shadow: .35rem .35rem 0 var(--coral);
}
.wheel-label.value { top: 10%; left: 38%; background: var(--mint); }
.wheel-label.price { right: -5%; top: 48%; background: var(--coral); color: var(--cream); }
.wheel-label.cost { bottom: 8%; left: 10%; background: var(--violet); color: var(--cream); }

.wheel-center {
    position: absolute;
    inset: 35%;
    display: grid;
    place-items: center;
    color: var(--mint);
    background: var(--ink);
    border-radius: 50%;
    font-size: clamp(2rem, 5vw, 5rem);
    box-shadow: 0 0 30px var(--mint);
}

.haggle-grid {
    display: grid;
    grid-template-columns: 1fr 14rem;
    gap: 1.2rem;
    align-items: start;
}

.chalkboard {
    min-height: 17rem;
    padding: 1.4rem;
    border: 8px solid #5b3718;
    background: #172319;
    box-shadow: 1rem 1rem 0 rgba(0, 0, 0, .28);
    transform: rotate(2deg);
}

#chalkLine {
    color: var(--chalk);
    font-size: clamp(2rem, 4vw, 4.2rem);
    line-height: .95;
    font-weight: 800;
}

.chalk-scribble { color: rgba(233, 237, 242, .55); font-size: 2rem; transform: rotate(-3deg); }

.sticker-stack {
    position: relative;
    min-height: 12rem;
    background: var(--cream);
    border: 2px dashed var(--ink);
    transform: rotate(-6deg);
}

.red-sticker {
    position: absolute;
    inset: 1.5rem .8rem auto;
    padding: 1.3rem .7rem;
    color: var(--cream);
    background: var(--coral);
    font-weight: 900;
    font-size: 1.55rem;
    text-align: center;
    clip-path: polygon(7% 0, 18% 8%, 32% 0, 44% 9%, 59% 0, 71% 8%, 90% 0, 100% 13%, 94% 32%, 100% 49%, 92% 68%, 100% 91%, 85% 100%, 68% 93%, 52% 100%, 36% 92%, 20% 100%, 0 87%, 7% 69%, 0 50%, 9% 31%, 0 12%);
    cursor: pointer;
    transition: transform .55s cubic-bezier(.2, .9, .1, 1), opacity .4s ease;
}

.red-sticker.peeled { transform: translate(4rem, -2rem) rotate(22deg); opacity: .42; }
.hidden-note { position: absolute; left: 1rem; right: 1rem; bottom: 1rem; color: var(--ink); font-family: var(--serif); font-size: 1.5rem; }

.dangling-tag {
    padding: 1.2rem;
    min-height: 11rem;
    color: var(--ink);
    background: var(--cream);
    border: 3px solid var(--ink);
    box-shadow: .6rem .6rem 0 var(--coin);
}

.dangling-tag strong { display: block; font-family: var(--glitch); font-size: 5rem; line-height: .85; color: var(--violet); }
.dangling-tag span { font-weight: 800; }

.ghost-hand {
    position: absolute;
    width: 10rem;
    height: 3.2rem;
    border-radius: 3rem;
    background: rgba(233, 237, 242, .52);
    filter: blur(.2px) drop-shadow(0 0 16px rgba(183, 255, 207, .45));
}
.ghost-hand::after { content: ""; position: absolute; right: -1.4rem; top: -.55rem; width: 3.6rem; height: 3.6rem; border-radius: 48%; background: rgba(233, 237, 242, .56); }
.hand-left { left: -2rem; bottom: 25vh; transform: rotate(-8deg); }
.hand-right { right: 8vw; top: 23vh; transform: scaleX(-1) rotate(14deg); }

.catacomb-room {
    background: linear-gradient(180deg, #121018, #0d0b12 40%, #26305F);
}

.barcode-shutters {
    position: absolute;
    inset: 0;
    display: flex;
    gap: 2vw;
    opacity: .33;
    z-index: -1;
}
.barcode-shutters span { flex: 1; background: linear-gradient(90deg, transparent, var(--ink) 20%, var(--cream) 21%, var(--ink) 24%, transparent 40%); transform: translateY(calc(var(--scroll, 0) * -18vh)); }

.diagonal { transform: rotate(-5deg); max-width: 48rem; }

.receipt-trail {
    position: absolute;
    inset: 8vh 5vw;
    width: 90vw;
    height: 82vh;
    z-index: -1;
}

.receipt-trail path {
    fill: none;
    stroke: var(--mint);
    stroke-width: 10;
    stroke-linecap: round;
    stroke-dasharray: 1;
    stroke-dashoffset: calc(1 - var(--path, 0));
    filter: drop-shadow(0 0 14px var(--mint));
    opacity: .72;
}

.receipt-columns {
    display: flex;
    justify-content: flex-end;
    align-items: end;
    gap: 1rem;
    min-height: 62vh;
}

.receipt-strip {
    width: 12rem;
    padding: 1.4rem 1rem;
    color: var(--ink);
    background:
        repeating-linear-gradient(0deg, transparent 0 32px, rgba(18, 16, 24, .12) 33px 34px),
        var(--cream);
    box-shadow: .65rem .65rem 0 rgba(255, 79, 100, .7);
    transform: rotate(var(--r, 4deg));
}
.receipt-strip:nth-child(2) { --r: -5deg; }
.receipt-strip:nth-child(3) { --r: 7deg; }
.receipt-strip.tall { min-height: 23rem; }
.receipt-strip b, .receipt-strip span, .receipt-strip em { display: block; margin-bottom: 1rem; }
.receipt-strip b { color: var(--violet); text-transform: uppercase; }
.catacomb-note { position: absolute; left: 12vw; bottom: 8vh; max-width: 28rem; }

.apparition-room {
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    background: radial-gradient(circle at 64% 50%, rgba(183, 255, 207, .18), transparent 28rem), linear-gradient(120deg, #26305F, #121018 62%);
}

.rightward { grid-column: 2; }

.triad {
    grid-row: 1;
    display: grid;
    gap: 1rem;
    align-self: center;
}

.triad-card {
    position: relative;
    padding: 1.2rem 1.4rem;
    border: 2px solid var(--cream);
    background: rgba(18, 16, 24, .62);
    box-shadow: .6rem .6rem 0 rgba(0, 0, 0, .26);
    transform: translateX(calc(var(--drift, 0) * 1rem));
    transition: transform .25s ease-out;
}

.triad-card h3 {
    margin: 0 0 .25rem;
    font-family: var(--glitch);
    font-weight: 400;
    font-size: clamp(2.5rem, 5vw, 5.8rem);
}
.triad-card p { margin: 0; font-size: 1.2rem; }
.value-card { color: var(--mint); }
.price-card { color: var(--coral); margin-left: 5vw; }
.cost-card { color: var(--violet); margin-left: 10vw; filter: drop-shadow(1rem .8rem 0 rgba(122, 77, 255, .22)); }

.apparition {
    right: 12vw;
    bottom: 12vh;
    width: 18rem;
    height: 24rem;
    animation: float 6s ease-in-out infinite;
}
.ghost-body {
    position: absolute;
    inset: 0;
    background: linear-gradient(rgba(233, 237, 242, .78), rgba(183, 255, 207, .22));
    border-radius: 50% 50% 28% 28%;
    clip-path: polygon(0 22%, 18% 0, 50% 6%, 78% 0, 100% 23%, 100% 100%, 84% 88%, 68% 100%, 50% 88%, 32% 100%, 15% 88%, 0 100%);
    filter: drop-shadow(0 0 45px var(--mint));
}
.ghost-body::before, .ghost-body::after { content: ""; position: absolute; top: 33%; width: 1rem; height: 1.5rem; border-radius: 50%; background: var(--ink); }
.ghost-body::before { left: 38%; }
.ghost-body::after { right: 38%; }
.clipboard { position: absolute; right: -2rem; top: 48%; padding: .8rem; color: var(--ink); background: var(--cream); border: 2px solid var(--ink); transform: rotate(8deg); font-weight: 800; }

.coupon-rain span {
    position: absolute;
    color: var(--ink);
    background: var(--cream);
    padding: .35rem .6rem;
    border: 1px dashed var(--ink);
    font-weight: 900;
    animation: drift 8s linear infinite;
}
.coupon-rain span:nth-child(1) { left: 12%; top: 10%; animation-delay: -1s; }
.coupon-rain span:nth-child(2) { left: 32%; top: 22%; animation-delay: -4s; }
.coupon-rain span:nth-child(3) { right: 24%; top: 8%; animation-delay: -2s; }
.coupon-rain span:nth-child(4) { right: 12%; top: 35%; animation-delay: -6s; }
.coupon-rain span:nth-child(5) { left: 54%; top: 68%; animation-delay: -3s; }

.exit-room {
    grid-template-columns: 1fr minmax(14rem, 22rem);
    background: linear-gradient(135deg, #121018, #1d143b 50%, #26305F);
}

.velvet-rope {
    position: absolute;
    left: 8vw;
    right: 8vw;
    top: 20vh;
    height: .75rem;
    background: repeating-linear-gradient(90deg, var(--coral) 0 30px, #8d2030 30px 60px);
    border-radius: 1rem;
    box-shadow: 0 0 22px rgba(255, 79, 100, .45);
    transform: rotate(-2deg);
}

.exit-ledger {
    max-width: 62rem;
    padding: 2rem;
    background: rgba(18, 16, 24, .5);
    border-left: .6rem solid var(--mint);
}

.large { max-width: 46rem; color: var(--cream); }

.ledger-lines {
    display: grid;
    gap: .8rem;
    margin: 2rem 0;
}

.ledger-lines span {
    display: block;
    padding: .8rem 1rem;
    color: var(--ink);
    background: var(--cream);
    border-left: .8rem solid var(--coral);
    font-weight: 700;
}
.ledger-lines b { color: var(--violet); text-transform: uppercase; margin-right: 1rem; }

.exit-sign {
    align-self: center;
    padding: 1.5rem;
    color: var(--ink);
    background: var(--mint);
    border: 3px solid var(--ink);
    box-shadow: .8rem .8rem 0 var(--coral), 0 0 45px rgba(183, 255, 207, .45);
}
.exit-sign strong { display: block; font-family: var(--glitch); font-size: 5rem; font-weight: 400; }

@keyframes flicker {
    0%, 8%, 10%, 48%, 50%, 100% { opacity: 1; filter: none; }
    9%, 49% { opacity: .72; filter: hue-rotate(30deg); }
}

@keyframes float {
    0%, 100% { transform: translateY(0) rotate(-2deg); }
    50% { transform: translateY(-1rem) rotate(3deg); }
}

@keyframes drift {
    0% { transform: translateY(-20vh) rotate(0deg); opacity: 0; }
    15%, 80% { opacity: .85; }
    100% { transform: translateY(75vh) rotate(360deg); opacity: 0; }
}

@media (max-width: 860px) {
    .room, .window-room, .hall-room, .apparition-room, .exit-room {
        grid-template-columns: 1fr;
        padding: 7rem 2rem 5rem 3rem;
    }
    .tag-nav { right: .75rem; gap: .4rem; }
    .nav-tag { min-width: 3.2rem; font-size: 0; padding: .55rem .7rem .5rem 1rem; }
    .nav-tag span { font-size: .78rem; }
    .scroll-receipt { left: .7rem; }
    .price-wheel { width: min(76vw, 28rem); }
    .haggle-grid, .receipt-columns { display: grid; grid-template-columns: 1fr; }
    .rightward { grid-column: auto; }
    .apparition { position: relative; right: auto; bottom: auto; width: 13rem; height: 17rem; justify-self: center; }
    .receipt-roll { left: 9vw; width: 60vw; opacity: .55; }
    .curtain { width: 3.5vw; }
}
