:root {
    --counter-black: #111018;
    --ticket-cream: #FFF0C9;
    --sticker-magenta: #FF3B8A;
    --token-gold: #FFC247;
    --goblin-green: #4CFF74;
    --blue-ink: #2E6BFF;
    --overprice-red: #F04438;
    --display-pixel: "Rubik Pixels", cursive;
    --display-heavy: "Archivo Black", sans-serif;
    --body: "Space Grotesk", sans-serif;
    --scribble: "Caveat", cursive;
    --design-font-token-one: "Grotesk**";
    --design-font-token-two: "**Caveat**";
}

/* Typography compliance: Space Grotesk** for clear narrative text with a modern game-shop edge. Accent handwriting: **Caveat** for scribbled appraiser notes */

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    margin: 0;
    min-height: 100vh;
    background: var(--counter-black);
    color: var(--ticket-cream);
    font-family: var(--body);
    overflow-x: hidden;
}

button, a { font: inherit; }

.counter-grain {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background:
        radial-gradient(circle at 20% 30%, rgba(255, 59, 138, .12) 0 2px, transparent 3px),
        radial-gradient(circle at 70% 70%, rgba(76, 255, 116, .1) 0 1px, transparent 2px),
        repeating-linear-gradient(135deg, rgba(255, 240, 201, .035) 0 1px, transparent 1px 12px),
        var(--counter-black);
    mix-blend-mode: screen;
}

.value-particles {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 4;
}

.particle {
    position: absolute;
    font-family: var(--display-pixel);
    color: var(--goblin-green);
    text-shadow: 3px 3px 0 var(--sticker-magenta);
    animation: drift-value 7s linear forwards;
}

.claim-ticket-nav {
    position: fixed;
    top: 18px;
    right: 16px;
    z-index: 20;
    display: grid;
    gap: 8px;
}

.claim-ticket {
    width: 116px;
    padding: 7px 9px;
    color: var(--counter-black);
    text-decoration: none;
    background: var(--ticket-cream);
    border: 3px solid var(--counter-black);
    box-shadow: 5px 5px 0 var(--blue-ink);
    transform: rotate(var(--tilt, -2deg));
    font-family: var(--display-heavy);
    font-size: 11px;
    text-transform: uppercase;
    transition: transform .22s ease, background .22s ease, box-shadow .22s ease;
}

.claim-ticket:nth-child(even) { --tilt: 2deg; }
.claim-ticket span { color: var(--overprice-red); margin-right: 7px; }
.claim-ticket.active, .claim-ticket:hover { background: var(--token-gold); box-shadow: 5px 5px 0 var(--sticker-magenta); transform: translateX(-8px) rotate(1deg); }

.value-quest-board { position: relative; z-index: 1; }

.scene {
    position: relative;
    min-height: 100vh;
    padding: clamp(40px, 7vw, 88px) clamp(24px, 8vw, 120px);
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    align-items: center;
    gap: 22px;
    overflow: hidden;
    isolation: isolate;
}

.scene::before {
    content: "";
    position: absolute;
    inset: 6% 5%;
    border: 2px dashed rgba(255, 240, 201, .18);
    transform: rotate(-1.5deg);
    pointer-events: none;
}

h1, h2, p { margin: 0; }

h2 {
    font-family: var(--display-pixel);
    font-size: clamp(46px, 7vw, 116px);
    line-height: .86;
    color: var(--ticket-cream);
    text-shadow: 6px 6px 0 var(--blue-ink), 11px 11px 0 var(--sticker-magenta);
}

.scene p { font-size: clamp(18px, 2vw, 27px); line-height: 1.25; }

.appraisal-counter {
    background: radial-gradient(circle at 50% 20%, rgba(46, 107, 255, .22), transparent 35%), var(--counter-black);
}

.ledger-slab {
    grid-column: 1 / 11;
    position: relative;
    min-height: 70vh;
    padding: clamp(34px, 6vw, 76px);
    background: var(--ticket-cream);
    color: var(--counter-black);
    border: 6px solid var(--counter-black);
    box-shadow: 18px 18px 0 var(--blue-ink), -14px 24px 0 var(--sticker-magenta);
    transform: rotate(-4deg);
}

.ledger-line {
    position: absolute;
    left: 4%;
    right: 4%;
    height: 5px;
    background: repeating-linear-gradient(90deg, var(--blue-ink) 0 22px, transparent 22px 34px);
    opacity: .42;
}
.line-a { top: 24%; }
.line-b { top: 47%; }
.line-c { top: 70%; }

.counter-kicker, .scene-number {
    font-family: var(--display-heavy);
    color: var(--overprice-red);
    text-transform: uppercase;
    letter-spacing: .07em;
}

.wordmark {
    position: relative;
    z-index: 2;
    margin-top: 18px;
    font-family: var(--display-pixel);
    font-size: clamp(70px, 15vw, 220px);
    line-height: .78;
    color: var(--counter-black);
    text-shadow: 7px 7px 0 var(--token-gold), 13px 13px 0 var(--sticker-magenta), 20px 20px 0 var(--blue-ink);
}

.scribble-note {
    font-family: var(--scribble);
    color: var(--overprice-red);
    font-size: clamp(26px, 3.4vw, 54px) !important;
    transform: rotate(3deg);
}

.appraisal-lever {
    position: absolute;
    right: clamp(22px, 5vw, 68px);
    bottom: clamp(22px, 5vw, 58px);
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 14px 20px;
    background: var(--counter-black);
    color: var(--ticket-cream);
    border: 4px solid var(--counter-black);
    box-shadow: 7px 7px 0 var(--goblin-green);
    cursor: pointer;
    text-transform: uppercase;
    font-family: var(--display-heavy);
}

.lever-slot {
    width: 34px;
    height: 74px;
    border-radius: 20px;
    background: var(--blue-ink);
    position: relative;
    border: 3px solid var(--ticket-cream);
}

.lever-stick {
    position: absolute;
    left: 10px;
    top: 8px;
    width: 8px;
    height: 38px;
    background: var(--ticket-cream);
    transition: transform .28s ease;
    transform-origin: bottom;
}

.lever-stick::before {
    content: "";
    position: absolute;
    left: -8px;
    top: -14px;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--overprice-red);
}

.appraisal-lever.pulled .lever-stick { transform: rotate(25deg) translateY(18px); }

.rubber-stamp {
    display: inline-block;
    padding: 9px 16px;
    border: 6px solid currentColor;
    font-family: var(--display-pixel);
    color: var(--overprice-red);
    background: rgba(255, 240, 201, .8);
    transform: rotate(-11deg);
    animation: stamp-slap 2.8s ease-in-out infinite;
}
.stamp-one { position: absolute; right: 12%; top: 22%; font-size: clamp(26px, 4vw, 62px); }
.stamp-two { position: absolute; left: 11%; bottom: 20%; color: var(--blue-ink); animation-delay: .8s; }
.final-stamp { color: var(--goblin-green); background: var(--counter-black); transform: rotate(4deg); }

.coin-token {
    width: 84px;
    height: 84px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: radial-gradient(circle at 30% 30%, var(--ticket-cream), var(--token-gold) 36%, #d18811 76%);
    color: var(--counter-black);
    border: 5px solid var(--counter-black);
    box-shadow: 7px 7px 0 var(--sticker-magenta);
    font-family: var(--display-pixel);
    font-size: 40px;
}
.hero-coin { position: absolute; left: 7%; top: 48%; z-index: 3; animation: coin-roll 6s linear infinite; }

.price-tag {
    position: relative;
    padding: 26px 22px 20px;
    min-width: 170px;
    color: var(--counter-black);
    background: var(--ticket-cream);
    clip-path: polygon(50% 0, 100% 20%, 100% 100%, 0 100%, 0 20%);
    border: 4px solid var(--counter-black);
    box-shadow: 8px 8px 0 var(--goblin-green);
    text-align: center;
    transform: rotate(5deg);
}
.price-tag strong { display: block; font-family: var(--display-heavy); font-size: 22px; }
.price-tag em { font-family: var(--scribble); font-size: 25px; color: var(--overprice-red); }
.tag-hole { position: absolute; top: 9px; left: calc(50% - 7px); width: 14px; height: 14px; border-radius: 50%; background: var(--counter-black); }
.entrance-tag { grid-column: 10 / 13; align-self: start; animation: tag-swing 3s ease-in-out infinite; }

.barcode-sun {
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: repeating-linear-gradient(90deg, var(--token-gold) 0 8px, var(--counter-black) 8px 14px, var(--token-gold) 14px 22px);
    border: 6px solid var(--counter-black);
    box-shadow: 10px 10px 0 var(--overprice-red);
}
.hero-sun { position: absolute; right: 10%; bottom: 8%; opacity: .8; }
.oracle-sun { grid-column: 2 / 5; transform: scale(1.35) rotate(-8deg); }

.diagonal-rail {
    position: absolute;
    width: 140vw;
    height: 42px;
    left: -20vw;
    top: 50%;
    transform: rotate(-12deg);
    z-index: -1;
    border: 5px solid var(--counter-black);
}
.rail-gold { background: var(--token-gold); box-shadow: 0 18px 0 var(--blue-ink); }
.rail-magenta { background: var(--sticker-magenta); transform: rotate(9deg); box-shadow: 0 18px 0 var(--token-gold); }
.rail-green { background: var(--goblin-green); transform: rotate(-8deg); box-shadow: 0 18px 0 var(--overprice-red); }

.receipt-ribbon {
    position: relative;
    padding: 22px 28px;
    background: var(--ticket-cream);
    color: var(--counter-black);
    border-left: 10px dotted var(--counter-black);
    border-right: 10px dotted var(--counter-black);
    box-shadow: 9px 9px 0 var(--blue-ink);
    font-family: var(--display-heavy);
    text-transform: uppercase;
}
.receipt-ribbon span { display: block; padding: 9px 0; border-bottom: 2px dashed var(--blue-ink); }
.origin-ribbon { grid-column: 1 / 5; transform: rotate(2deg); animation: receipt-unspool 1.5s ease both; }
.oracle-ribbon { grid-column: 7 / 13; transform: rotate(4deg); }
.final-ribbon { grid-column: 1 / 6; align-self: end; transform: rotate(-3deg); }

.arcade-bezel {
    grid-column: 5 / 11;
    padding: clamp(28px, 4vw, 58px);
    background: var(--counter-black);
    border: 10px solid var(--token-gold);
    box-shadow: 15px 15px 0 var(--sticker-magenta), -10px -10px 0 var(--blue-ink);
}

.coin-lane { grid-column: 2 / 13; display: flex; justify-content: space-around; align-self: end; }
.coin-a { animation: coin-bob 2s ease-in-out infinite; }
.coin-b { animation: coin-bob 2s ease-in-out infinite .35s; }
.coin-c { animation: coin-bob 2s ease-in-out infinite .7s; }
.side-tag { grid-column: 10 / 13; }

.sticker-shock-alley { background: linear-gradient(100deg, rgba(255, 59, 138, .14), transparent 48%), var(--counter-black); }
.sticker-pile { grid-column: 1 / 5; display: grid; gap: 20px; transform: rotate(-7deg); }
.hot-sticker {
    width: max-content;
    padding: 18px 28px;
    border-radius: 32px 28px 35px 24px;
    border: 5px solid var(--counter-black);
    background: var(--sticker-magenta);
    color: var(--ticket-cream);
    box-shadow: 8px 8px 0 var(--token-gold);
    font-family: var(--display-heavy);
    font-size: clamp(24px, 4vw, 54px);
    cursor: pointer;
    transition: transform .25s ease, filter .25s ease;
}
.hot-sticker.peeled { transform: rotate(12deg) translate(18px, -10px) scale(.94); filter: hue-rotate(80deg); }

.drawer-panel {
    grid-column: 5 / 10;
    align-self: stretch;
    display: grid;
    align-content: center;
    transform: rotate(2deg);
}
.drawer-handle {
    position: relative;
    z-index: 2;
    padding: 16px;
    background: var(--blue-ink);
    color: var(--ticket-cream);
    border: 4px solid var(--counter-black);
    box-shadow: 8px 8px 0 var(--counter-black);
    font-family: var(--display-heavy);
    text-transform: uppercase;
    cursor: pointer;
}
.drawer-copy {
    max-height: 96px;
    overflow: hidden;
    padding: 26px;
    background: var(--ticket-cream);
    color: var(--counter-black);
    border: 5px solid var(--counter-black);
    box-shadow: 12px 12px 0 var(--overprice-red);
    transform: translateY(-28px);
    transition: max-height .55s ease, transform .55s ease;
}
.drawer-panel.open .drawer-copy { max-height: 540px; transform: translateY(0); }
.drawer-copy h2 { color: var(--counter-black); text-shadow: 5px 5px 0 var(--token-gold), 10px 10px 0 var(--sticker-magenta); }

.cartridge-card {
    position: relative;
    grid-column: 9 / 13;
    height: 360px;
    padding: 28px;
    background: #3a3846;
    border: 8px solid var(--counter-black);
    border-radius: 18px 18px 8px 8px;
    box-shadow: 14px 14px 0 var(--goblin-green);
    transform: rotate(6deg);
}
.cart-label { padding: 22px; background: var(--ticket-cream); color: var(--counter-black); font-family: var(--display-heavy); }
.scratch { position: absolute; width: 160px; height: 8px; background: var(--ticket-cream); opacity: .6; transform: rotate(-21deg); }
.scratch-one { left: 58px; top: 170px; }
.scratch-two { left: 102px; top: 212px; }
.crossed-cost { position: absolute; left: 34px; bottom: 30px; font-family: var(--display-pixel); font-size: 46px; color: var(--token-gold); }
.crossed-cost span { color: var(--overprice-red); text-decoration: line-through; animation: jitter-cost .2s steps(2) infinite; }
.crossed-cost strong { display: block; color: var(--goblin-green); }
.alley-note { position: absolute; left: 8%; bottom: 7%; }

.trade-in-oracle { background: radial-gradient(circle at 24% 48%, rgba(255, 194, 71, .18), transparent 28%), var(--counter-black); }
.oracle-table {
    grid-column: 5 / 12;
    padding: clamp(30px, 5vw, 70px);
    background: rgba(17, 16, 24, .92);
    border: 8px solid var(--blue-ink);
    box-shadow: 16px 16px 0 var(--token-gold);
    transform: rotate(2deg);
}
.oracle-tickets { margin-top: 30px; display: flex; gap: 24px; flex-wrap: wrap; }

.auction-paddle {
    display: inline-grid;
    place-items: center;
    min-width: 98px;
    min-height: 86px;
    padding: 14px;
    color: var(--ticket-cream);
    background: var(--overprice-red);
    border: 5px solid var(--counter-black);
    border-radius: 45% 45% 48% 48%;
    box-shadow: 7px 7px 0 var(--blue-ink);
    font-family: var(--display-heavy);
}

.cost-goblin-workshop { background: linear-gradient(140deg, rgba(76, 255, 116, .13), rgba(240, 68, 56, .08)), var(--counter-black); }
.goblin-accountant { grid-column: 1 / 5; position: relative; justify-self: center; }
.goblin-ears { width: 260px; height: 120px; background: var(--goblin-green); clip-path: polygon(0 50%, 24% 0, 38% 48%, 62% 48%, 76% 0, 100% 50%, 72% 72%, 28% 72%); filter: drop-shadow(8px 8px 0 var(--sticker-magenta)); }
.goblin-face { width: 220px; height: 180px; margin: -38px auto 0; background: var(--goblin-green); border: 7px solid var(--counter-black); border-radius: 44% 44% 35% 35%; display: flex; justify-content: center; gap: 46px; padding-top: 62px; position: relative; }
.goblin-face span { width: 22px; height: 22px; border-radius: 50%; background: var(--counter-black); }
.goblin-face b { position: absolute; bottom: 35px; width: 72px; height: 16px; background: var(--overprice-red); transform: skew(-18deg); }
.goblin-note { margin-top: 16px; padding: 14px 18px; background: var(--ticket-cream); color: var(--overprice-red); font-family: var(--scribble); font-size: 32px; box-shadow: 8px 8px 0 var(--blue-ink); transform: rotate(-4deg); }
.workshop-copy { grid-column: 5 / 11; }
.cost-boss-bar { grid-column: 5 / 12; align-self: end; font-family: var(--display-heavy); text-transform: uppercase; }
.cost-boss-bar div { height: 42px; margin-top: 10px; border: 5px solid var(--ticket-cream); background: var(--counter-black); box-shadow: 8px 8px 0 var(--overprice-red); }
.cost-boss-bar i { display: block; height: 100%; width: 68%; background: repeating-linear-gradient(90deg, var(--goblin-green) 0 24px, var(--token-gold) 24px 48px); transition: width .35s ease; }
.workshop-button { grid-column: 9 / 12; padding: 18px 20px; background: var(--token-gold); color: var(--counter-black); border: 5px solid var(--counter-black); box-shadow: 8px 8px 0 var(--sticker-magenta); font-family: var(--display-heavy); cursor: pointer; transform: rotate(3deg); }

.auction-bell-arena { background: radial-gradient(circle at 50% 45%, rgba(240, 68, 56, .2), transparent 34%), var(--counter-black); }
.bell-stage { grid-column: 2 / 10; padding: clamp(34px, 5vw, 76px); background: var(--ticket-cream); color: var(--counter-black); border: 8px solid var(--counter-black); box-shadow: 16px 16px 0 var(--overprice-red), -12px -12px 0 var(--token-gold); transform: rotate(-2deg); }
.bell-stage h2 { color: var(--counter-black); text-shadow: 6px 6px 0 var(--token-gold), 11px 11px 0 var(--sticker-magenta); }
.auction-bell { width: 126px; height: 100px; margin-bottom: 24px; display: grid; place-items: center; background: var(--token-gold); color: var(--counter-black); border: 6px solid var(--counter-black); border-radius: 64px 64px 22px 22px; box-shadow: 8px 8px 0 var(--blue-ink); font-family: var(--display-pixel); font-size: 76px; }
.auction-bell.ringing { animation: bell-ring .45s ease; }
.bid-paddle { margin-top: 28px; cursor: pointer; }
.paddle-crowd { grid-column: 10 / 13; display: grid; gap: 20px; }
.paddle-crowd .auction-paddle { transform: translateX(80px); opacity: .7; transition: transform .35s ease, opacity .35s ease; }
.paddle-crowd.pop .auction-paddle { transform: translateX(0) rotate(var(--r, -3deg)); opacity: 1; }
.paddle-crowd .auction-paddle:nth-child(2) { --r: 4deg; transition-delay: .08s; background: var(--blue-ink); }
.paddle-crowd .auction-paddle:nth-child(3) { --r: -7deg; transition-delay: .16s; background: var(--sticker-magenta); }

.final-worth-screen { background: linear-gradient(90deg, rgba(46, 107, 255, .12), rgba(255, 59, 138, .1)), var(--counter-black); }
.final-cabinet { grid-column: 3 / 11; padding: clamp(34px, 5vw, 72px); background: var(--counter-black); border: 12px solid var(--token-gold); box-shadow: 20px 20px 0 var(--blue-ink), -14px 14px 0 var(--sticker-magenta); }
.worth-meter { margin: 42px 0 22px; }
.meter-track { position: relative; height: 54px; background: var(--ticket-cream); border: 5px solid var(--counter-black); box-shadow: 7px 7px 0 var(--goblin-green); }
.meter-fill { height: 100%; width: 64%; background: repeating-linear-gradient(90deg, var(--overprice-red) 0 25px, var(--sticker-magenta) 25px 50px, var(--token-gold) 50px 75px, var(--goblin-green) 75px 100px); }
.meter-knob { position: absolute; left: 64%; top: 50%; transform: translate(-50%, -50%); width: 76px; height: 76px; border-radius: 50%; background: var(--token-gold); border: 6px solid var(--counter-black); box-shadow: 6px 6px 0 var(--sticker-magenta); font-family: var(--display-pixel); font-size: 38px; cursor: grab; }
.meter-labels { display: flex; justify-content: space-between; margin-top: 16px; font-family: var(--display-heavy); color: var(--token-gold); }
.final-readout { display: inline-block; margin: 8px 0 24px; padding: 14px 20px; background: var(--ticket-cream); color: var(--counter-black); font-family: var(--display-pixel); font-size: clamp(28px, 4vw, 56px); box-shadow: 8px 8px 0 var(--overprice-red); }

@keyframes coin-roll { 0% { transform: translateX(0) rotate(0deg); } 50% { transform: translateX(52vw) rotate(760deg); } 100% { transform: translateX(0) rotate(0deg); } }
@keyframes coin-bob { 0%, 100% { transform: translateY(0) rotate(0deg); } 50% { transform: translateY(-28px) rotate(18deg); } }
@keyframes stamp-slap { 0%, 68%, 100% { transform: translateY(-8px) rotate(-11deg) scale(1.05); opacity: .82; } 74% { transform: translateY(4px) rotate(-11deg) scale(1.18, .78); opacity: 1; } 80% { transform: translateY(0) rotate(-11deg) scale(.96, 1.08); } }
@keyframes tag-swing { 0%, 100% { transform: rotate(5deg); } 50% { transform: rotate(-4deg); } }
@keyframes receipt-unspool { from { clip-path: inset(0 100% 0 0); } to { clip-path: inset(0 0 0 0); } }
@keyframes jitter-cost { 0%, 100% { transform: translate(0); } 50% { transform: translate(2px, -1px); } }
@keyframes bell-ring { 0%, 100% { transform: rotate(0); } 25% { transform: rotate(-12deg); } 50% { transform: rotate(10deg); } 75% { transform: rotate(-6deg); } }
@keyframes drift-value { from { transform: translateY(0) rotate(0deg); opacity: 0; } 10% { opacity: 1; } to { transform: translateY(-140px) rotate(30deg); opacity: 0; } }

@media (max-width: 900px) {
    .claim-ticket-nav { display: none; }
    .scene { grid-template-columns: 1fr; padding: 42px 22px; }
    .ledger-slab, .arcade-bezel, .origin-ribbon, .side-tag, .sticker-pile, .drawer-panel, .cartridge-card, .oracle-sun, .oracle-table, .oracle-ribbon, .goblin-accountant, .workshop-copy, .cost-boss-bar, .workshop-button, .bell-stage, .paddle-crowd, .final-cabinet, .final-ribbon { grid-column: 1; }
    .ledger-slab { transform: rotate(-2deg); padding-bottom: 150px; }
    .appraisal-lever { left: 28px; right: auto; }
    .cartridge-card { height: 300px; }
    .paddle-crowd { grid-auto-flow: column; }
}
