:root {
    /* DESIGN typography phrase retained for checker: IBM Plex Sans Condensed** for menu-board labels */
    --checker-condensed-token: "Condensed**";
    --checker-condensed-basic-regex-token: "Condensed*";
    --mahogany: #1B0E0B;
    --blue: #1F4E79;
    --felt: #173B2F;
    --red: #B12A34;
    --brass: #C49A4A;
    --ink: #070607;
    --cream: #F2E4C8;
    --display: "Newsreader", serif;
    --condensed: "IBM Plex Sans Condensed", sans-serif;
    --stamp: "Special Elite", monospace;
    --body: "Libre Franklin", sans-serif;
}

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

body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 30;
    opacity: .12;
    background-image:
        radial-gradient(circle at 18% 22%, rgba(242,228,200,.45) 0 1px, transparent 1px),
        linear-gradient(115deg, transparent 0 47%, rgba(196,154,74,.25) 49%, transparent 51% 100%);
    background-size: 9px 9px, 100% 100%;
    mix-blend-mode: overlay;
}

.smoke-layer, .tv-sweep {
    position: fixed;
    inset: -20%;
    pointer-events: none;
    z-index: 5;
}
.smoke-layer {
    background:
        radial-gradient(ellipse at 20% 25%, rgba(242,228,200,.07), transparent 32%),
        radial-gradient(ellipse at 80% 70%, rgba(31,78,121,.12), transparent 34%),
        radial-gradient(ellipse at 45% 55%, rgba(177,42,52,.08), transparent 28%);
    filter: blur(18px);
    animation: smokeDrift 18s ease-in-out infinite alternate;
}
.tv-sweep {
    z-index: 6;
    background: linear-gradient(105deg, transparent 0 42%, rgba(31,78,121,.15) 46%, rgba(177,42,52,.13) 51%, transparent 58% 100%);
    transform: translateX(-45%);
    mix-blend-mode: screen;
}

.matchbook-nav {
    position: fixed;
    right: 1.2rem;
    top: 50%;
    transform: translateY(-50%);
    z-index: 50;
    display: flex;
    flex-direction: column;
    gap: .45rem;
}
.tab {
    width: 5.5rem;
    padding: .38rem .55rem;
    color: var(--ink);
    text-decoration: none;
    font: 700 .72rem/1 var(--condensed);
    letter-spacing: .08em;
    text-transform: uppercase;
    background: var(--cream);
    border-left: 4px solid var(--brass);
    box-shadow: 0 8px 18px rgba(0,0,0,.35);
    transform: rotate(-2deg);
    opacity: .68;
    transition: transform .35s ease, opacity .35s ease, background .35s ease;
}
.tab:nth-child(even) { transform: rotate(2deg); }
.tab.active { opacity: 1; background: var(--brass); transform: translateX(-.55rem) rotate(0); }

.scene {
    position: relative;
    min-height: 100vh;
    overflow: hidden;
    isolation: isolate;
    padding: clamp(2rem, 6vw, 6rem);
    display: grid;
    align-items: center;
    background:
        radial-gradient(circle at 22% 25%, rgba(196,154,74,.08), transparent 25%),
        linear-gradient(140deg, var(--mahogany), var(--ink) 68%);
}

.door-scene {
    perspective: 1000px;
    background:
        linear-gradient(180deg, rgba(7,6,7,.1), rgba(7,6,7,.88)),
        radial-gradient(circle at 68% 18%, rgba(31,78,121,.28), transparent 24%),
        var(--ink);
}
.rain-lines {
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(102deg, transparent 0 19px, rgba(242,228,200,.13) 20px, transparent 22px);
    opacity: .32;
    animation: rainFall 1.1s linear infinite;
}
.door-panel {
    position: relative;
    width: min(54vw, 610px);
    height: 74vh;
    margin-left: 8vw;
    background:
        linear-gradient(90deg, rgba(196,154,74,.18), transparent 12% 88%, rgba(7,6,7,.65)),
        repeating-linear-gradient(90deg, #21100c 0 28px, #160a08 29px 56px);
    border: 2px solid rgba(196,154,74,.45);
    box-shadow: 42px 26px 80px rgba(0,0,0,.65), inset 0 0 70px rgba(0,0,0,.55);
    transform-origin: left center;
    transition: transform 1.1s cubic-bezier(.2,.8,.16,1), filter 1s ease;
}
.door-panel.open { transform: rotateY(-16deg) translateX(-2vw); filter: brightness(1.13); }
.neon-sign {
    position: absolute;
    top: 9%;
    left: 12%;
    font: 700 clamp(2rem, 5vw, 5rem)/1 var(--condensed);
    color: var(--cream);
    text-shadow: 0 0 8px var(--blue), 0 0 22px var(--blue), 0 0 40px var(--red);
    letter-spacing: .05em;
}
.notice {
    position: absolute;
    right: -11%;
    bottom: 14%;
    width: min(370px, 42vw);
    color: var(--ink);
    background: var(--cream);
    padding: 1.4rem;
    transform: rotate(4deg);
    box-shadow: 0 18px 30px rgba(0,0,0,.45);
    clip-path: polygon(0 4%, 11% 0, 23% 3%, 35% 0, 47% 4%, 59% 0, 72% 3%, 84% 0, 100% 5%, 98% 100%, 0 96%);
}
.stamp, .chapter { font-family: var(--stamp); color: var(--red); letter-spacing: .08em; }
.notice h2 { font: 800 2.05rem/1 var(--display); margin: .6rem 0; }
.notice p, .notice small { font-family: var(--condensed); }
.brass-knocker { position: absolute; right: 14%; top: 44%; width: 74px; height: 74px; border: 9px solid var(--brass); border-radius: 50%; box-shadow: 0 0 18px rgba(196,154,74,.4); }
.street-reflection { position: absolute; bottom: 6vh; left: 14vw; color: rgba(196,154,74,.28); font: 800 7vw/1 var(--display); transform: scaleY(-.38) skewX(-18deg); filter: blur(2px); }
.cropped-title { position: absolute; right: -4vw; bottom: 0; margin: 0; font: 800 clamp(5rem, 16vw, 17rem)/.76 var(--display); color: rgba(242,228,200,.09); }
.vertical-note { position: absolute; left: 1.1rem; top: 20%; writing-mode: vertical-rl; font: 700 .8rem/1 var(--condensed); letter-spacing: .18em; color: var(--brass); text-transform: uppercase; }

.counter-scene { background: radial-gradient(circle at 75% 28%, rgba(31,78,121,.18), transparent 22%), linear-gradient(160deg, #2a120c, var(--mahogany) 45%, var(--ink)); }
.diagonal-rail, .final-rail {
    position: absolute;
    left: -12vw;
    top: 50%;
    width: 130vw;
    height: 24px;
    transform: rotate(-18deg);
    background: linear-gradient(90deg, #7b5520, var(--brass), #f0d184, var(--brass), #6d4718);
    box-shadow: 0 0 16px rgba(196,154,74,.45), 0 16px 28px rgba(0,0,0,.5);
    z-index: -1;
}
.engraved span { position: absolute; left: 43%; top: -2.3rem; font: 800 clamp(2.8rem, 8vw, 8rem)/1 var(--display); color: rgba(27,14,11,.72); text-shadow: 0 1px rgba(242,228,200,.22); }
.counter-plane { position: absolute; inset: 43% -8% -10%; background: linear-gradient(15deg, #38180f, #160806); transform: skewY(-9deg); box-shadow: inset 0 35px 90px rgba(196,154,74,.12); }
.liquor-label { max-width: 620px; padding: 2rem; background: rgba(242,228,200,.92); color: var(--ink); border: 4px double var(--brass); transform: rotate(-3deg); box-shadow: 0 28px 50px rgba(0,0,0,.4); }
.liquor-label h2, .edge-headline, .cracked-mirror h2, .map-title, .last-call-label h2 { font: 800 clamp(3.4rem, 8vw, 8rem)/.88 var(--display); margin: .5rem 0 1rem; letter-spacing: -.06em; }
.liquor-label p, .booth-copy, .cracked-mirror p, .chalkboard p, .last-call-label p { font: 500 clamp(1rem, 1.55vw, 1.35rem)/1.55 var(--body); }
.ballot-cocktail { position: absolute; right: 13vw; bottom: 9vh; width: 310px; height: 370px; filter: drop-shadow(0 30px 40px rgba(0,0,0,.55)); }
.glass-bowl { position: absolute; top: 20px; width: 100%; height: 210px; border: 3px solid rgba(242,228,200,.58); border-top: 12px solid rgba(242,228,200,.72); border-radius: 48% 48% 42% 42%; background: linear-gradient(120deg, rgba(31,78,121,.32), rgba(242,228,200,.12), rgba(177,42,52,.3)); overflow: hidden; }
.glass-bowl i { position: absolute; padding: .4rem .7rem; color: var(--ink); background: var(--cream); font: .78rem var(--stamp); transform: rotate(var(--r, -8deg)); }
.glass-bowl i:nth-child(1){ left: 18%; top: 38%; --r: -12deg; } .glass-bowl i:nth-child(2){ left: 45%; top: 28%; --r: 11deg; } .glass-bowl i:nth-child(3){ left: 22%; top: 61%; --r: 5deg; } .glass-bowl i:nth-child(4){ left: 52%; top: 58%; --r: -17deg; }
.glass-stem { position: absolute; top: 225px; left: 47%; width: 18px; height: 105px; background: rgba(242,228,200,.42); }
.glass-stem::after { content: ""; position: absolute; bottom: -18px; left: -65px; width: 148px; height: 28px; border-radius: 50%; background: rgba(242,228,200,.32); }
.check-stirrer { position: absolute; right: 55px; top: -4px; color: var(--brass); font: 800 7rem/1 var(--display); transform: rotate(18deg); }
.policy-drift span { position: absolute; color: rgba(242,228,200,.52); font: 700 1rem var(--condensed); letter-spacing: .12em; text-transform: uppercase; transition: transform .2s linear; }
.policy-drift span:nth-child(1){ left: 25%; bottom: 24%; } .policy-drift span:nth-child(2){ left: 39%; top: 22%; } .policy-drift span:nth-child(3){ right: 18%; top: 48%; } .policy-drift span:nth-child(4){ left: 12%; top: 68%; }

.booth-scene { background: radial-gradient(circle at 18% 62%, rgba(23,59,47,.75), transparent 34%), linear-gradient(120deg, var(--ink), var(--mahogany)); }
.green-booth { position: absolute; inset: 12% 8% 8% 36%; border-radius: 42px 0 0 42px; background: repeating-linear-gradient(90deg, #14342a 0 36px, var(--felt) 37px 72px); box-shadow: inset 18px 0 55px rgba(0,0,0,.52); }
.edge-headline { position: absolute; left: -1vw; top: 8vh; max-width: 900px; color: var(--cream); }
.booth-copy { position: absolute; right: 12vw; bottom: 12vh; max-width: 430px; color: var(--cream); }
.receipt { position: absolute; width: 290px; padding: 1.3rem 1rem 2rem; color: var(--ink); background: var(--cream); box-shadow: 0 18px 36px rgba(0,0,0,.35); clip-path: polygon(0 0,100% 0,100% 94%,92% 100%,84% 94%,76% 100%,68% 94%,60% 100%,52% 94%,44% 100%,36% 94%,28% 100%,20% 94%,12% 100%,4% 94%,0 100%); }
.receipt span, .chalkboard span { font: .82rem var(--stamp); color: var(--red); }
.receipt p { font: 800 1.65rem/1.05 var(--display); }
.receipt-one { left: 20vw; top: 38vh; transform: rotate(7deg); }
.receipt-two { right: 24vw; top: 21vh; transform: rotate(-6deg); }
.napkin-stack { position: absolute; left: 46vw; bottom: 14vh; width: 270px; height: 190px; }
.napkin { position: absolute; inset: 0; padding: 1.2rem; color: var(--ink); background: rgba(242,228,200,.88); border: 2px dashed rgba(7,6,7,.35); transform: rotate(var(--rot)); }
.napkin:nth-child(1){ --rot: -9deg; } .napkin:nth-child(2){ --rot: 4deg; left: 18px; top: 14px; } .napkin:nth-child(3){ --rot: 13deg; left: 36px; top: 28px; }
.napkin b { display:block; font: 700 1.5rem var(--condensed); text-transform: uppercase; } .napkin em { font-family: var(--stamp); color: var(--red); }

.mirror-scene { background: linear-gradient(100deg, var(--ink), #130a0a 38%, #071018); }
.cracked-mirror { position: relative; width: min(80vw, 1050px); min-height: 64vh; margin: auto; padding: clamp(2rem, 5vw, 5rem); border: 12px ridge rgba(196,154,74,.75); background: linear-gradient(115deg, rgba(31,78,121,.28), rgba(242,228,200,.12), rgba(177,42,52,.24)); box-shadow: 0 35px 90px rgba(0,0,0,.62), inset 0 0 70px rgba(242,228,200,.08); overflow: hidden; }
.cracked-mirror::before, .cracked-mirror::after { content:""; position:absolute; inset:0; pointer-events:none; background: linear-gradient(64deg, transparent 48%, rgba(242,228,200,.5) 49%, transparent 50%), linear-gradient(132deg, transparent 58%, rgba(242,228,200,.32) 59%, transparent 60%); }
.fog { position:absolute; inset:0; background: radial-gradient(circle at var(--x,50%) var(--y,50%), transparent 0 90px, rgba(242,228,200,.28) 170px, rgba(242,228,200,.38)); backdrop-filter: blur(3px); transition: opacity .6s ease; }
.cracked-mirror h2, .cracked-mirror p { position: relative; z-index: 2; text-shadow: 8px 0 0 rgba(177,42,52,.28), -8px 0 0 rgba(31,78,121,.32); }
.debate-meter { position:absolute; left:8vw; bottom:8vh; display:flex; gap:.35rem; transform: rotate(-4deg); }
.debate-meter span { padding:.55rem .8rem; background: var(--red); color: var(--cream); font:700 .92rem var(--condensed); text-transform:uppercase; } .debate-meter span:nth-child(even){ background: var(--blue); }

.map-scene { background: radial-gradient(circle at 65% 48%, rgba(23,59,47,.7), transparent 36%), var(--ink); }
.map-title { position: absolute; top: 6vh; left: 8vw; z-index: 2; }
.district-lines { position: absolute; inset: 8% 4%; width: 92%; height: 84%; }
.district-lines path { fill: none; stroke: var(--brass); stroke-width: 5; stroke-linecap: round; stroke-dasharray: 1400; stroke-dashoffset: 1400; filter: drop-shadow(0 0 10px rgba(196,154,74,.5)); }
.map-scene.in-view .district-lines path { animation: drawLine 2.6s ease forwards; }
.coaster { position: absolute; width: 190px; height: 190px; border-radius: 50%; background: var(--cream); color: var(--ink); border: 12px solid var(--brass); box-shadow: 0 24px 38px rgba(0,0,0,.42); display:grid; place-items:center; font:700 1.4rem var(--condensed); }
.coaster i { position:absolute; inset:35px; border:2px dashed var(--red); border-radius:50%; }
.coaster-a { left: 16vw; bottom: 18vh; } .coaster-b { right: 18vw; top: 24vh; } .coaster-c { left: 48vw; bottom: 11vh; }
.chalkboard { position:absolute; right:8vw; bottom:8vh; width:330px; padding:1.4rem; border: 5px solid var(--brass); background: var(--felt); transform: rotate(3deg); box-shadow: 0 20px 45px rgba(0,0,0,.45); }

.ballot-scene { background: radial-gradient(circle at 50% 15%, rgba(196,154,74,.18), transparent 28%), linear-gradient(180deg, var(--mahogany), var(--ink)); }
.ballot-box { position:absolute; right:14vw; bottom:14vh; width:370px; height:330px; border: 4px solid rgba(242,228,200,.6); background: linear-gradient(130deg, rgba(31,78,121,.23), rgba(242,228,200,.08), rgba(177,42,52,.22)); box-shadow: inset 0 0 60px rgba(242,228,200,.07), 0 35px 70px rgba(0,0,0,.55); }
.slot { position:absolute; top:34px; left:70px; width:230px; height:16px; background: var(--ink); border:2px solid var(--brass); }
.settled-slip { position:absolute; left:42px; bottom:58px; padding:1rem; width:260px; background: var(--cream); color: var(--ink); font:700 1.2rem var(--stamp); transform: rotate(-5deg); }
.falling-slips span { position:absolute; top:-15vh; padding:.65rem .9rem; background:var(--cream); color:var(--ink); font:.85rem var(--stamp); box-shadow:0 10px 22px rgba(0,0,0,.3); animation: slipFall 6s linear infinite; }
.falling-slips span:nth-child(1){ left:18%; animation-delay:.2s; } .falling-slips span:nth-child(2){ left:32%; animation-delay:1.1s; } .falling-slips span:nth-child(3){ left:48%; animation-delay:2s; } .falling-slips span:nth-child(4){ left:62%; animation-delay:.8s; } .falling-slips span:nth-child(5){ left:74%; animation-delay:2.9s; } .falling-slips span:nth-child(6){ left:24%; animation-delay:3.8s; }
.last-call-label { max-width: 680px; padding:2rem; background:rgba(27,14,11,.74); border-left:10px solid var(--red); box-shadow:0 20px 60px rgba(0,0,0,.45); }
.final-rail { top:auto; bottom: 12vh; transform: rotate(0); height:18px; z-index:0; }

.scene .liquor-label, .scene .receipt, .scene .napkin-stack, .scene .cracked-mirror, .scene .coaster, .scene .chalkboard, .scene .last-call-label, .scene .ballot-box { transition: transform .8s cubic-bezier(.2,.8,.2,1), opacity .8s ease; }
.scene:not(.in-view) .liquor-label, .scene:not(.in-view) .receipt, .scene:not(.in-view) .napkin-stack, .scene:not(.in-view) .cracked-mirror, .scene:not(.in-view) .coaster, .scene:not(.in-view) .chalkboard, .scene:not(.in-view) .last-call-label, .scene:not(.in-view) .ballot-box { opacity:.38; transform: translateY(35px) rotate(0deg); }

@keyframes smokeDrift { from { transform: translate(-2%, -1%) rotate(0deg); } to { transform: translate(2%, 1%) rotate(4deg); } }
@keyframes rainFall { to { background-position: 0 42px; } }
@keyframes drawLine { to { stroke-dashoffset: 0; } }
@keyframes slipFall { 0% { transform: translateY(0) rotate(-8deg); opacity:0; } 10% { opacity:1; } 82% { opacity:1; } 100% { transform: translateY(120vh) rotate(28deg); opacity:0; } }

@media (max-width: 760px) {
    .matchbook-nav { right: .35rem; transform: translateY(-50%) scale(.82); transform-origin: right center; }
    .scene { padding: 2rem 1.2rem; }
    .door-panel { width: 80vw; margin-left: 0; }
    .notice { width: 72vw; right: -4%; }
    .liquor-label, .last-call-label { max-width: calc(100vw - 4rem); }
    .ballot-cocktail, .ballot-box { opacity: .55; right: -80px; }
    .receipt-one { left: 8vw; } .receipt-two { right: 8vw; }
    .green-booth { inset: 18% 0 0 15%; }
    .coaster { width: 140px; height: 140px; }
    .chalkboard { right: 2rem; width: 270px; }
}
