:root {
    /* Space Grotesk** for interface-like route labels */
    --cream: #F3E5C3;
    --cyan: #37E6D4;
    --indigo: #17213A;
    --midnight: #071019;
    --violet: #7B4DFF;
    --persimmon: #FF5A36;
    --gold: #FFD166;
    --green: #2DBA78;
    --bebas: "Bebas Neue", sans-serif;
    --fraunces: "Fraunces", serif;
    --jp: "Noto Sans JP", sans-serif;
    --space: "Space Grotesk", sans-serif;
}

* { box-sizing: border-box; }

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

body {
    margin: 0;
    color: var(--cream);
    background:
        radial-gradient(circle at 20% 10%, rgba(123,77,255,.22), transparent 28rem),
        radial-gradient(circle at 80% 85%, rgba(55,230,212,.14), transparent 24rem),
        var(--midnight);
    font-family: var(--space);
    overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; border: 0; cursor: pointer; }

.grain {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 50;
    opacity: .22;
    background-image:
        radial-gradient(circle, rgba(243,229,195,.26) 0 1px, transparent 1.5px),
        linear-gradient(115deg, transparent 0 47%, rgba(255,209,102,.08) 48% 50%, transparent 51% 100%);
    background-size: 13px 17px, 61px 61px;
    mix-blend-mode: overlay;
}

.flashlight {
    position: fixed;
    width: 32rem;
    height: 32rem;
    border-radius: 50%;
    left: -16rem;
    top: -16rem;
    pointer-events: none;
    z-index: 45;
    opacity: .28;
    background: radial-gradient(circle, rgba(243,229,195,.18) 0 8%, rgba(55,230,212,.08) 18%, transparent 63%);
    mix-blend-mode: screen;
    transform: translate3d(var(--mx, 50vw), var(--my, 50vh), 0);
}

.route-nav {
    position: fixed;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    gap: .55rem;
    z-index: 60;
}

.route-token {
    writing-mode: vertical-rl;
    font-family: var(--jp);
    font-size: .72rem;
    letter-spacing: .08em;
    padding: .65rem .35rem;
    color: rgba(243,229,195,.68);
    background: rgba(23,33,58,.72);
    border: 1px dashed rgba(243,229,195,.23);
    box-shadow: 0 0 0 rgba(55,230,212,0);
    transition: color .3s ease, border-color .3s ease, box-shadow .3s ease, transform .3s ease;
}

.route-token.is-lit {
    color: var(--cyan);
    border-color: var(--cyan);
    transform: translateX(-.2rem) rotate(-2deg);
    box-shadow: 0 0 22px rgba(55,230,212,.34);
}

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

.scene::before {
    content: attr(data-chapter);
    position: absolute;
    left: clamp(1rem, 3vw, 3rem);
    top: clamp(1rem, 3vw, 3rem);
    font-family: var(--bebas);
    font-size: clamp(5rem, 14vw, 13rem);
    line-height: .8;
    color: rgba(243,229,195,.055);
    letter-spacing: .03em;
    z-index: -1;
}

.scene::after {
    content: attr(data-label);
    position: absolute;
    left: clamp(1rem, 3vw, 3rem);
    bottom: 1.2rem;
    font-family: var(--jp);
    color: rgba(243,229,195,.48);
    letter-spacing: .18em;
    font-size: .72rem;
}

.gate {
    background:
        linear-gradient(180deg, rgba(7,16,25,.92), rgba(23,33,58,.72) 52%, rgba(7,16,25,.98)),
        radial-gradient(ellipse at 50% 85%, rgba(55,230,212,.18), transparent 35%);
}

.rain-field, .rain-field::before, .rain-field::after {
    position: absolute;
    inset: -20%;
    content: "";
    background-image: repeating-linear-gradient(102deg, transparent 0 18px, rgba(55,230,212,.21) 19px 20px, transparent 21px 34px);
    transform: translateY(var(--rain, 0));
    animation: rainFall 1.4s linear infinite;
    opacity: .38;
}
.rain-field::before { animation-duration: 2.1s; opacity: .22; background-size: 140px 140px; }
.rain-field::after { animation-duration: .85s; opacity: .16; }

@keyframes rainFall { to { transform: translateY(8rem); } }

.moon {
    position: absolute;
    right: 16vw;
    top: 8vh;
    width: 5.5rem;
    height: 5.5rem;
    border-radius: 50%;
    display: grid;
    place-items: center;
    font-family: var(--jp);
    color: var(--midnight);
    background: var(--gold);
    box-shadow: 0 0 50px rgba(255,209,102,.45), inset -1rem -.6rem 0 rgba(255,90,54,.22);
}

.alley-perspective {
    min-height: calc(100vh - 8rem);
    display: grid;
    grid-template-columns: minmax(8rem, 1fr) minmax(18rem, 2.2fr) minmax(8rem, 1fr);
    align-items: stretch;
    gap: clamp(.5rem, 2vw, 2rem);
    perspective: 950px;
}

.wall {
    position: relative;
    background: linear-gradient(135deg, rgba(23,33,58,.92), rgba(7,16,25,.7));
    border: 1px solid rgba(243,229,195,.08);
    transform-style: preserve-3d;
    overflow: hidden;
}
.wall-left { transform: rotateY(18deg) skewY(-4deg); transform-origin: right center; }
.wall-right { transform: rotateY(-18deg) skewY(4deg); transform-origin: left center; }
.wall::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(243,229,195,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(243,229,195,.035) 1px, transparent 1px);
    background-size: 38px 38px;
}

.street-plane {
    position: relative;
    transform: rotateX(62deg) translateY(6vh);
    transform-origin: bottom center;
    background:
        repeating-linear-gradient(45deg, transparent 0 36px, rgba(243,229,195,.07) 37px 42px),
        linear-gradient(160deg, #071019, #17213A 45%, #071019);
    border: 1px solid rgba(55,230,212,.16);
    box-shadow: 0 35px 90px rgba(0,0,0,.65), inset 0 0 60px rgba(55,230,212,.08);
    overflow: hidden;
}

.route-svg { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; }
#masterRoute {
    fill: none;
    stroke: var(--cyan);
    stroke-width: 16;
    stroke-linecap: round;
    stroke-dasharray: var(--routeLength, 1600);
    stroke-dashoffset: calc(var(--routeLength, 1600) * (1 - var(--routeProgress, .08)));
    filter: drop-shadow(0 0 18px #37E6D4);
}

.neon-title {
    position: absolute;
    left: 50%;
    top: 5%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    font-family: var(--bebas);
    font-size: clamp(2.4rem, 5vw, 5.6rem);
    line-height: .8;
    letter-spacing: .03em;
    color: var(--persimmon);
    text-shadow: 0 0 10px #FF5A36, 0 0 28px rgba(255,90,54,.7);
}
.neon-title span { animation: signFlicker 4s infinite; }
.neon-title span:nth-child(3n) { color: var(--cyan); text-shadow: 0 0 10px #37E6D4, 0 0 25px rgba(55,230,212,.65); animation-delay: .7s; }
.neon-title span:nth-child(4n) { color: var(--gold); text-shadow: 0 0 12px #FFD166; animation-delay: 1.4s; }

@keyframes signFlicker {
    0%, 18%, 21%, 53%, 57%, 100% { opacity: 1; transform: translateX(0); }
    19%, 55% { opacity: .35; transform: translateX(2px); }
}

.sticker-cluster { position: absolute; left: 1rem; bottom: 4rem; display: grid; gap: .55rem; transform: rotate(-6deg); }
.sticker-cluster span, .ticket-note, .paper-strip, .inventory-tag, .last-ticket {
    font-family: var(--jp);
    background: var(--cream);
    color: var(--midnight);
    border: 2px solid var(--midnight);
    box-shadow: .28rem .28rem 0 rgba(255,90,54,.7);
    padding: .55rem .75rem;
}
.ticket-note { position: absolute; right: 1rem; top: 20%; transform: rotate(8deg); max-width: 12rem; text-transform: uppercase; letter-spacing: .06em; }
.ticket-note.stamped { animation: stampImpact .42s cubic-bezier(.2,1.6,.5,1); box-shadow: .15rem .15rem 0 var(--green); }
@keyframes stampImpact { 0% { transform: rotate(8deg) scale(1.2); } 100% { transform: rotate(8deg) scale(1); } }

.window-grid { position: absolute; bottom: 12%; left: 12%; right: 12%; display: grid; grid-template-columns: repeat(3, 1fr); gap: .7rem; }
.window-grid i { aspect-ratio: 1.2; background: rgba(255,209,102,.17); border: 1px solid rgba(255,209,102,.3); box-shadow: inset 0 0 16px rgba(255,209,102,.12); }
.window-grid i:nth-child(2n) { background: rgba(55,230,212,.13); }

.puddle { position: absolute; border-radius: 50%; background: radial-gradient(ellipse, rgba(55,230,212,.45), rgba(123,77,255,.18) 46%, transparent 70%); mix-blend-mode: screen; animation: ripple 3.7s infinite; }
.puddle-one { width: 18rem; height: 7rem; left: 14%; bottom: 16%; }
.puddle-two { width: 10rem; height: 4rem; right: 13%; top: 27%; animation-delay: 1.2s; }
@keyframes ripple { 50% { transform: scale(1.08); filter: brightness(1.25); } }

.crosswalk { position: absolute; left: 26%; top: 47%; width: 22rem; height: 9rem; transform: rotate(-17deg); background: repeating-linear-gradient(90deg, rgba(243,229,195,.85) 0 18px, transparent 18px 38px); display: grid; place-items: center; font-family: var(--fraunces); color: var(--gold); text-shadow: 0 0 12px var(--midnight); }
.margin-whisper { position: absolute; left: 6vw; bottom: 8vh; max-width: 28rem; font-family: var(--fraunces); font-size: clamp(1.1rem, 2vw, 1.55rem); line-height: 1.35; color: rgba(243,229,195,.8); }

.arcade { background: linear-gradient(90deg, #071019, #17213A 50%, #071019); }
.vertical-label { position: absolute; left: 4vw; top: 10vh; font-family: var(--bebas); font-size: clamp(4rem, 10vw, 10rem); line-height: .82; color: var(--gold); text-shadow: 0 0 28px rgba(255,209,102,.32); }
.shop-canyon { min-height: 88vh; margin-left: clamp(7rem, 18vw, 18rem); display: grid; grid-template-columns: 1.1fr .8fr .7fr; gap: 2rem; align-items: center; transform: skewY(-3deg); }
.awning { padding: 2rem; background: var(--persimmon); color: var(--midnight); box-shadow: 1rem 1rem 0 rgba(7,16,25,.55); }
.shop-sign { display: block; font-family: var(--bebas); font-size: clamp(3rem, 7vw, 7rem); line-height: .85; color: var(--cream); text-shadow: .16rem .16rem 0 var(--midnight); }
.awning p, .stall p, .folding-map p { font-family: var(--fraunces); line-height: 1.45; font-size: 1.15rem; }
.vending-machine { min-height: 28rem; padding: 1rem; background: linear-gradient(180deg, var(--indigo), var(--midnight)); border: .5rem solid var(--cyan); box-shadow: 0 0 50px rgba(55,230,212,.28); }
.vend-glass { display: grid; grid-template-columns: repeat(2,1fr); gap: .7rem; min-height: 20rem; padding: 1rem; background: radial-gradient(circle, rgba(55,230,212,.25), rgba(7,16,25,.88)); }
.vend-glass span { display: grid; place-items: center; border: 1px solid rgba(243,229,195,.24); font-family: var(--jp); color: var(--gold); }
.object-button, .wrong-turn, .station-plate { background: var(--cream); color: var(--midnight); padding: .8rem 1rem; margin-top: 1rem; font-family: var(--space); font-weight: 700; text-transform: uppercase; box-shadow: .25rem .25rem 0 var(--violet); }
.hanging-charms { align-self: start; display: flex; gap: .5rem; flex-wrap: wrap; }
.hanging-charms span { writing-mode: vertical-rl; min-height: 7rem; padding: .8rem .45rem; background: var(--gold); color: var(--midnight); font-family: var(--jp); box-shadow: 0 1rem 1.5rem rgba(0,0,0,.35); animation: charmSwing 3s ease-in-out infinite; transform-origin: top; }
.hanging-charms span:nth-child(2n) { background: var(--green); animation-delay: .5s; }
@keyframes charmSwing { 50% { transform: rotate(5deg); } }
.lamp-post { position: absolute; right: 8vw; bottom: 11vh; width: 2rem; height: 55vh; background: var(--midnight); border-left: .35rem solid rgba(243,229,195,.2); }
.lamp-post::before { content: ""; position: absolute; top: -2rem; left: -2rem; width: 6rem; height: 6rem; border-radius: 50%; background: radial-gradient(circle, var(--gold), transparent 66%); }
.lamp-post span { position: relative; display: block; width: max-content; margin: 2.5rem 0 0 -2.7rem; padding: .35rem; background: var(--violet); font-family: var(--jp); transform: rotate(-8deg); }
.cat-guardian { position: absolute; width: 5rem; height: 3rem; right: 22vw; bottom: 8vh; background: var(--midnight); border-radius: 50% 50% 30% 30%; box-shadow: 0 0 0 .2rem var(--cream); }
.cat-guardian::before, .cat-guardian::after { content: ""; position: absolute; top: -.8rem; width: 1.4rem; height: 1.4rem; background: var(--midnight); transform: rotate(45deg); }
.cat-guardian::before { left: .6rem; } .cat-guardian::after { right: .6rem; }
.cat-guardian span::before, .cat-guardian span::after { content: ""; position: absolute; top: 1rem; width: .45rem; height: .45rem; border-radius: 50%; background: var(--gold); box-shadow: 0 0 10px var(--gold); }
.cat-guardian span::before { left: 1.5rem; } .cat-guardian span::after { right: 1.5rem; }
.paper-strip { position: absolute; left: 25vw; bottom: 6vh; transform: rotate(2deg); max-width: 26rem; }

.oracle { background: radial-gradient(ellipse at center, rgba(123,77,255,.24), transparent 55%), var(--midnight); display: grid; place-items: center; }
.tunnel-shell { width: min(76rem, 92vw); min-height: 70vh; border-radius: 50% 50% 0 0 / 22% 22% 0 0; padding: clamp(2rem, 4vw, 4rem); background: linear-gradient(180deg, rgba(23,33,58,.95), rgba(7,16,25,.98)); border: 2px solid rgba(55,230,212,.22); box-shadow: inset 0 0 80px rgba(123,77,255,.2); position: relative; }
h2 { margin: 0; font-family: var(--bebas); font-size: clamp(4rem, 10vw, 9rem); line-height: .82; letter-spacing: .02em; }
.oracle h2 { color: var(--cyan); text-shadow: 0 0 20px rgba(55,230,212,.5); }
.station-plates { display: flex; flex-wrap: wrap; gap: .8rem; margin: 1rem 0; }
.station-plate { margin-top: 0; box-shadow: .25rem .25rem 0 var(--persimmon); }
.station-plate.is-open { background: var(--cyan); }
.subway-map { width: 100%; height: min(45vh, 28rem); overflow: visible; }
.serpent { fill: none; stroke-width: 14; stroke-linecap: round; stroke-dasharray: 18 20; animation: trainTrace 8s linear infinite; filter: drop-shadow(0 0 13px currentColor); }
.serpent-cyan { stroke: var(--cyan); color: var(--cyan); }
.serpent-gold { stroke: var(--gold); color: var(--gold); animation-delay: -2s; }
.serpent-violet { stroke: var(--violet); color: var(--violet); animation-delay: -4s; }
@keyframes trainTrace { to { stroke-dashoffset: -260; } }
.stations circle { fill: var(--cream); stroke: var(--midnight); stroke-width: 5; }
.oracle-voice { font-family: var(--fraunces); font-size: clamp(1.2rem, 2vw, 1.7rem); color: var(--gold); max-width: 46rem; }
.tile-wall { position: absolute; left: 0; right: 0; bottom: 0; display: grid; grid-template-columns: repeat(5,1fr); opacity: .6; }
.tile-wall span { border: 1px solid rgba(243,229,195,.15); padding: 1rem; font-family: var(--jp); text-align: center; color: rgba(243,229,195,.52); }

.rooftop { background: linear-gradient(180deg, #17213A, #071019 70%); }
.roof-panorama { position: relative; min-height: 74vh; margin-top: 8vh; padding: 2rem; border: 1px solid rgba(243,229,195,.13); background: linear-gradient(155deg, rgba(7,16,25,.42), rgba(45,186,120,.09)); transform: rotate(-1deg); }
.rooftop h2 { color: var(--green); }
.water-tower { position: absolute; right: 8vw; top: 6vh; width: 7rem; height: 7rem; border-radius: 50%; display: grid; place-items: center; font-family: var(--bebas); font-size: 4rem; color: var(--midnight); background: var(--green); box-shadow: 0 0 35px rgba(45,186,120,.35); }
.water-tower::after { content: ""; position: absolute; top: 6.8rem; left: 1rem; right: 1rem; height: 8rem; border-left: .35rem solid var(--green); border-right: .35rem solid var(--green); }
.laundry-line { position: absolute; left: 8vw; right: 18vw; top: 25vh; height: 2px; background: var(--cream); transform: rotate(-5deg); }
.laundry-line i { position: relative; display: inline-block; width: 3rem; height: 4rem; margin-left: clamp(1rem, 6vw, 6rem); background: var(--persimmon); transform-origin: top; animation: flagWave 2.7s ease-in-out infinite; }
.laundry-line i:nth-child(2n) { background: var(--cyan); animation-delay: .4s; }
.laundry-line i:nth-child(3n) { background: var(--gold); animation-delay: .8s; }
@keyframes flagWave { 50% { transform: skewX(-9deg) rotate(3deg); } }
.inventory-tags { position: absolute; left: 8vw; bottom: 12vh; display: flex; flex-wrap: wrap; gap: 1rem; max-width: 45rem; }
.inventory-tag { transform: rotate(var(--rot, -2deg)); }
.inventory-tag:nth-child(2) { --rot: 3deg; background: var(--green); }
.inventory-tag:nth-child(3) { --rot: -5deg; background: var(--gold); }
.inventory-tag:nth-child(4) { --rot: 4deg; background: var(--cyan); }
.inventory-readout { position: absolute; right: 7vw; bottom: 10vh; width: min(28rem, 42vw); font-family: var(--fraunces); font-size: 1.35rem; color: var(--cream); }
.roof-blocks { position: absolute; inset: auto 0 0; height: 24vh; display: flex; align-items: end; gap: .8rem; padding: 0 5vw; z-index: -1; }
.roof-blocks span { flex: 1; height: var(--h, 70%); background: var(--indigo); border-top: .35rem solid rgba(243,229,195,.12); transform: skewX(-14deg); }
.roof-blocks span:nth-child(2) { --h: 95%; } .roof-blocks span:nth-child(3) { --h: 55%; } .roof-blocks span:nth-child(4) { --h: 80%; } .roof-blocks span:nth-child(5) { --h: 48%; }

.market { background: radial-gradient(circle at 60% 30%, rgba(255,90,54,.18), transparent 30rem), #071019; }
.market-maze { position: relative; min-height: 78vh; margin: 8vh auto 0; width: min(72rem, 88vw); transform: rotate(.8deg); }
.market h2 { color: var(--persimmon); }
.stall { position: absolute; padding: 1.2rem; background: var(--cream); color: var(--midnight); border: 3px solid var(--midnight); box-shadow: .7rem .7rem 0 var(--violet); width: min(22rem, 42vw); }
.stall b { font-family: var(--bebas); font-size: 2.4rem; color: var(--persimmon); }
.stall-a { left: 2%; top: 24%; transform: rotate(-5deg); }
.stall-b { right: 6%; top: 18%; transform: rotate(4deg); box-shadow: .7rem .7rem 0 var(--cyan); }
.stall-c { left: 30%; bottom: 6%; transform: rotate(-2deg); box-shadow: .7rem .7rem 0 var(--gold); }
.wrong-turn { position: absolute; left: 42%; top: 50%; background: var(--persimmon); box-shadow: .25rem .25rem 0 var(--cyan); }
.hidden-alley { position: absolute; right: 3%; bottom: 2%; max-width: 25rem; padding: 1rem; font-family: var(--fraunces); background: rgba(23,33,58,.9); border: 1px dashed var(--gold); transform: translateY(2rem) rotate(6deg); opacity: 0; transition: opacity .4s ease, transform .4s ease; }
.hidden-alley.revealed { opacity: 1; transform: translateY(0) rotate(0); }
.festival-wire { position: absolute; left: -5vw; right: -5vw; top: 15vh; height: 3px; background: var(--cream); transform: rotate(-4deg); }
.festival-wire i { display: inline-block; width: 2rem; height: 3rem; margin-left: 10vw; background: var(--gold); border-radius: 0 0 50% 50%; box-shadow: 0 0 22px var(--gold); }
.festival-wire i:nth-child(2n) { background: var(--persimmon); box-shadow: 0 0 22px var(--persimmon); }
.festival-wire i:nth-child(3n) { background: var(--cyan); box-shadow: 0 0 22px var(--cyan); }

.dawn { display: grid; place-items: center; background: linear-gradient(180deg, #071019 0%, #17213A 45%, rgba(255,209,102,.28) 100%); }
.folding-map { position: relative; width: min(78rem, 92vw); min-height: 74vh; padding: clamp(2rem, 5vw, 5rem); background: linear-gradient(145deg, rgba(243,229,195,.95), rgba(255,209,102,.85)); color: var(--midnight); clip-path: polygon(0 6%, 18% 0, 37% 7%, 61% 1%, 82% 8%, 100% 2%, 96% 100%, 72% 94%, 51% 100%, 28% 93%, 6% 100%); box-shadow: 0 2rem 5rem rgba(0,0,0,.45); overflow: hidden; }
.folding-map::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(90deg, rgba(7,16,25,.08) 1px, transparent 1px), linear-gradient(rgba(7,16,25,.08) 1px, transparent 1px); background-size: 4rem 4rem; transform: rotate(-7deg) scale(1.15); }
.folding-map h2, .folding-map p, .last-ticket { position: relative; z-index: 2; }
.folding-map h2 { color: var(--indigo); max-width: 50rem; }
.folding-map p { max-width: 38rem; font-size: 1.35rem; }
.skyline { position: absolute; left: 0; right: 0; bottom: 0; height: 38%; display: flex; align-items: end; gap: .4rem; padding: 0 3rem; opacity: .9; }
.skyline span { flex: 1; height: var(--h, 55%); background: var(--indigo); clip-path: polygon(0 20%, 35% 20%, 35% 0, 63% 0, 63% 20%, 100% 20%, 100% 100%, 0 100%); }
.skyline span:nth-child(2) { --h: 78%; } .skyline span:nth-child(3) { --h: 48%; } .skyline span:nth-child(4) { --h: 86%; } .skyline span:nth-child(5) { --h: 60%; } .skyline span:nth-child(6) { --h: 72%; }
.final-route { position: absolute; inset: 14% 4% 4%; width: 92%; height: 72%; z-index: 1; }
#finalRoute { fill: none; stroke: var(--persimmon); stroke-width: 13; stroke-linecap: round; stroke-dasharray: var(--finalLength, 1500); stroke-dashoffset: calc(var(--finalLength, 1500) * (1 - var(--routeProgress, .08))); filter: drop-shadow(0 0 10px #FF5A36); }
.last-ticket { display: inline-block; margin-top: 1rem; background: var(--midnight); color: var(--cream); box-shadow: .28rem .28rem 0 var(--cyan); }

.scene-active .shop-canyon, .scene-active .tunnel-shell, .scene-active .roof-panorama, .scene-active .market-maze, .scene-active .folding-map { animation: districtWake .8s ease both; }
@keyframes districtWake { from { filter: brightness(.72); transform: translateY(1.2rem) rotate(-1deg); } }

@media (max-width: 820px) {
    .route-nav { display: none; }
    .scene { padding: 1rem; }
    .alley-perspective { grid-template-columns: 1fr; min-height: 92vh; }
    .wall { min-height: 18rem; transform: none; }
    .street-plane { min-height: 32rem; transform: rotateX(50deg); order: 2; }
    .shop-canyon { margin-left: 0; grid-template-columns: 1fr; transform: none; padding-top: 18vh; }
    .vertical-label { font-size: 4rem; }
    .stall { position: relative; left: auto; right: auto; top: auto; bottom: auto; width: auto; margin: 1rem 0; }
    .wrong-turn, .hidden-alley { position: relative; left: auto; right: auto; top: auto; bottom: auto; display: block; margin: 1rem 0; }
    .inventory-readout { position: relative; right: auto; bottom: auto; width: auto; margin-top: 42vh; }
    .inventory-tags { position: relative; left: auto; bottom: auto; margin-top: 8rem; }
}
