:root {
  --carbon: #111014;
  --charcoal: #242229;
  --lilac: #D7C7FF;
  --peach: #FFD1C2;
  --mint: #BDEFD8;
  --blue: #A8D8FF;
  --gold: #D7B66F;
  --chalk: #F7F1EA;
  --display: "Jost", "Poppins", "Futura", "Montserrat", sans-serif;
  --label: "Montserrat", "Poppins", "Futura", sans-serif;
  --body: "DM Sans", "Inter", sans-serif;
  --mono: "Space Mono", monospace;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  min-height: 100vh;
  overflow-x: hidden;
  color: var(--chalk);
  background:
    radial-gradient(circle at 18% 18%, rgba(215, 199, 255, 0.12), transparent 28vw),
    radial-gradient(circle at 86% 22%, rgba(189, 239, 216, 0.10), transparent 24vw),
    radial-gradient(circle at 44% 88%, rgba(255, 209, 194, 0.10), transparent 34vw),
    var(--carbon);
  font-family: var(--body);
}

body::before,
body::after,
.grain-layer,
.pastel-reflection {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
}

body::before {
  z-index: 0;
  opacity: 0.52;
  background:
    repeating-linear-gradient(117deg, rgba(247, 241, 234, 0.018) 0 1px, transparent 1px 8px),
    repeating-linear-gradient(24deg, rgba(168, 216, 255, 0.018) 0 1px, transparent 1px 10px),
    linear-gradient(140deg, rgba(36, 34, 41, 0.82), rgba(17, 16, 20, 0.96));
}

body::after {
  z-index: 1;
  opacity: 0.28;
  background:
    radial-gradient(circle at 12% 24%, rgba(247,241,234,.14) 0 1px, transparent 1.6px),
    radial-gradient(circle at 45% 62%, rgba(247,241,234,.10) 0 1px, transparent 1.8px),
    radial-gradient(circle at 70% 36%, rgba(247,241,234,.08) 0 1px, transparent 1.7px);
  background-size: 41px 47px, 53px 59px, 67px 61px;
  mix-blend-mode: screen;
}

.grain-layer {
  z-index: 2;
  opacity: .46;
  background:
    linear-gradient(90deg, transparent 0 49%, rgba(255,255,255,.035) 50%, transparent 51% 100%) 0 0 / 9px 13px,
    repeating-radial-gradient(ellipse at 30% 40%, rgba(247,241,234,.034) 0 1px, transparent 1px 7px),
    repeating-linear-gradient(3deg, transparent 0 12px, rgba(215,199,255,.025) 13px, transparent 14px 22px);
  filter: contrast(140%);
}

.pastel-reflection {
  z-index: 3;
  transform: translateX(-42%) rotate(-18deg);
  background: linear-gradient(90deg, transparent 0 25%, rgba(215,199,255,.16), rgba(255,209,194,.19), rgba(189,239,216,.13), transparent 75% 100%);
  animation: reflectionSlide 9s ease-in-out infinite alternate;
  mix-blend-mode: screen;
}

@keyframes reflectionSlide {
  from { transform: translateX(-46%) rotate(-18deg); opacity: .38; }
  to { transform: translateX(36%) rotate(-18deg); opacity: .72; }
}

.lounge-shell { position: relative; z-index: 5; }

.scene {
  min-height: 100vh;
  position: relative;
  display: grid;
  place-items: center;
  padding: clamp(28px, 5vw, 76px);
  isolation: isolate;
}

.scene::before {
  content: "";
  position: absolute;
  inset: 11vh -12vw auto -12vw;
  height: 52vh;
  transform: rotate(-17deg);
  border-radius: 44px;
  background:
    linear-gradient(100deg, rgba(36,34,41,.88), rgba(17,16,20,.95) 38%, rgba(36,34,41,.92)),
    repeating-linear-gradient(120deg, rgba(247,241,234,.04) 0 1px, transparent 1px 12px);
  box-shadow: 0 42px 90px rgba(0,0,0,.56), inset 0 0 0 1px rgba(247,241,234,.06), inset 0 22px 60px rgba(247,241,234,.035);
  z-index: -1;
}

.carbon-door { overflow: hidden; }

.shutter-lines {
  position: absolute;
  inset: 0;
  opacity: .16;
  background: repeating-linear-gradient(0deg, transparent 0 34px, rgba(247,241,234,.16) 35px, transparent 37px 72px);
  mask-image: linear-gradient(to bottom, black, transparent 72%);
}

.diagonal-counter {
  position: absolute;
  width: 132vw;
  height: min(58vh, 620px);
  left: -15vw;
  top: 21vh;
  transform: rotate(-18deg);
  border-radius: 42px;
  background:
    radial-gradient(circle at 20% 42%, rgba(255,209,194,.12), transparent 22%),
    radial-gradient(circle at 76% 58%, rgba(168,216,255,.11), transparent 24%),
    linear-gradient(100deg, #242229 0%, #111014 44%, #242229 100%);
  box-shadow: 0 55px 120px rgba(0,0,0,.72), inset 0 0 0 1px rgba(215,182,111,.16), inset 0 -20px 80px rgba(0,0,0,.48);
  overflow: hidden;
}

.diagonal-counter::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(118deg, rgba(247,241,234,.032) 0 1px, transparent 1px 11px),
    repeating-linear-gradient(28deg, rgba(215,199,255,.026) 0 1px, transparent 1px 10px);
  opacity: .72;
}

.circuit-map {
  position: absolute;
  inset: 10% 4%;
  width: 92%;
  height: 80%;
  fill: none;
  stroke: var(--gold);
  stroke-width: 3;
  filter: drop-shadow(0 0 8px rgba(215,182,111,.34));
  opacity: .78;
}

.circuit-map circle { fill: var(--gold); stroke: rgba(247,241,234,.34); stroke-width: 2; }
.trace { stroke-dasharray: 760; stroke-dashoffset: 760; animation: traceDraw 4.2s ease forwards; }
.trace-b { animation-delay: .45s; }
.trace-c { animation-delay: .8s; }
@keyframes traceDraw { to { stroke-dashoffset: 0; } }

.hero-mark-wrap {
  position: relative;
  max-width: 1180px;
  width: 100%;
  padding-top: 9vh;
}

.micro-code,
.label-chip,
.drawer-label,
.ticket span,
.receipt-strip,
.rollup-tag {
  font-family: var(--mono);
  letter-spacing: .12em;
  text-transform: uppercase;
}

.micro-code {
  color: rgba(189,239,216,.78);
  font-size: clamp(10px, 1.2vw, 13px);
  margin: 0 0 10px;
}

.hero-mark {
  position: relative;
  margin: 0;
  font-family: var(--display);
  font-size: clamp(68px, 17vw, 238px);
  line-height: .78;
  letter-spacing: -.075em;
  color: rgba(247,241,234,.08);
  text-shadow: 0 1px 0 rgba(255,255,255,.16), 0 28px 38px rgba(0,0,0,.64), inset 0 1px 0 rgba(215,182,111,.4);
  -webkit-text-stroke: 1px rgba(247,241,234,.17);
}

.glitch::before,
.glitch::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
}

.glitch::before { color: var(--peach); transform: translate(0); }
.glitch::after { color: var(--blue); transform: translate(0); }
.glitch.is-glitching::before { animation: glitchPeach .54s steps(2, end); opacity: .6; }
.glitch.is-glitching::after { animation: glitchBlue .54s steps(2, end); opacity: .5; }
@keyframes glitchPeach { 20%{transform:translate(-8px,2px);clip-path:inset(14% 0 72% 0)} 45%{transform:translate(6px,-1px);clip-path:inset(58% 0 25% 0)} 70%{transform:translate(-3px,0);clip-path:inset(34% 0 48% 0)} 100%{transform:translate(0);clip-path:inset(0)} }
@keyframes glitchBlue { 18%{transform:translate(7px,-2px);clip-path:inset(72% 0 10% 0)} 48%{transform:translate(-5px,1px);clip-path:inset(20% 0 64% 0)} 68%{transform:translate(4px,0);clip-path:inset(45% 0 35% 0)} 100%{transform:translate(0);clip-path:inset(0)} }

.door-note {
  max-width: 520px;
  margin: 24px 0 0 auto;
  color: rgba(247,241,234,.76);
  font-size: clamp(16px, 2vw, 22px);
  line-height: 1.35;
}

.rollup-tag {
  position: absolute;
  left: 7vw;
  bottom: 11vh;
  color: var(--carbon);
  background: var(--peach);
  border-radius: 999px;
  padding: 10px 18px;
  box-shadow: 4px 7px 0 rgba(215,199,255,.25);
  transform: rotate(-9deg);
  font-size: 11px;
}

.coaster-nav {
  position: fixed;
  z-index: 20;
  top: 22px;
  right: 24px;
  display: flex;
  gap: 9px;
  transform: rotate(-4deg);
}

.nav-sticker {
  border: 1px solid rgba(247,241,234,.18);
  border-radius: 999px;
  padding: 10px 13px;
  color: rgba(247,241,234,.82);
  background: rgba(36,34,41,.7);
  backdrop-filter: blur(12px);
  font-family: var(--label);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  cursor: pointer;
  transition: transform .35s ease, background .35s ease, color .35s ease, box-shadow .35s ease;
}

.nav-sticker:hover,
.nav-sticker.active {
  color: var(--carbon);
  background: var(--mint);
  box-shadow: 0 0 24px rgba(189,239,216,.28);
  transform: translateY(-3px) rotate(2deg);
}

.stitch {
  position: fixed;
  top: -10vh;
  bottom: -10vh;
  width: 2px;
  z-index: 4;
  opacity: .3;
  background: repeating-linear-gradient(to bottom, transparent 0 13px, var(--gold) 14px 18px, transparent 19px 30px);
}
.stitch-left { left: 4vw; transform: rotate(-2deg); }
.stitch-right { right: 7vw; transform: rotate(3deg); }

.scene-title-block {
  position: absolute;
  left: clamp(24px, 7vw, 90px);
  top: 15vh;
  max-width: 580px;
}
.scene-title-block.right { left: auto; right: clamp(24px, 7vw, 90px); text-align: right; }
.label-chip {
  display: inline-flex;
  color: var(--gold);
  font-size: 11px;
  margin-bottom: 13px;
}
h2 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(42px, 8.8vw, 120px);
  line-height: .88;
  letter-spacing: -.055em;
  color: rgba(247,241,234,.9);
}

.drawer-stack {
  width: min(520px, 88vw);
  margin: 26vh auto 0 8vw;
  display: grid;
  gap: 14px;
  transform: rotate(-3deg);
}
.drawer {
  padding: 20px 24px;
  border: 1px solid rgba(247,241,234,.12);
  border-radius: 20px 8px 20px 8px;
  background: linear-gradient(110deg, rgba(36,34,41,.86), rgba(17,16,20,.72));
  box-shadow: 15px 18px 44px rgba(0,0,0,.34), inset 0 0 0 1px rgba(215,182,111,.08);
  transform: translateX(-26px);
  opacity: .76;
  transition: transform .55s ease, opacity .55s ease, border-color .55s ease;
}
.drawer.open,
.drawer:hover { transform: translateX(26px); opacity: 1; border-color: rgba(215,182,111,.38); }
.drawer-label { color: var(--blue); font-size: 10px; }
.drawer p { margin: 9px 0 0; color: rgba(247,241,234,.72); line-height: 1.55; }

.coaster-orbit {
  position: absolute;
  right: 13vw;
  bottom: 14vh;
  width: 250px;
  height: 250px;
  border-radius: 50%;
  border: 1px dashed rgba(215,182,111,.32);
}
.coaster {
  --x: 34px;
  --y: 46px;
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: 88px;
  height: 88px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: var(--carbon);
  background: radial-gradient(circle, rgba(247,241,234,.58), var(--mint) 58%, rgba(189,239,216,.42));
  box-shadow: 0 0 36px rgba(189,239,216,.28), inset 0 0 0 12px rgba(17,16,20,.08);
  transition: left .8s ease, top .8s ease;
}
.coaster span { font-family: var(--display); font-weight: 900; font-size: 36px; }
.condensation {
  position: absolute;
  inset: 50px;
  border: 1px solid rgba(168,216,255,.34);
  border-radius: 50%;
  filter: blur(.2px);
}

.ticket-rail {
  position: absolute;
  left: 7vw;
  bottom: 12vh;
  display: flex;
  gap: 15px;
  align-items: flex-end;
}
.ticket {
  width: 186px;
  min-height: 210px;
  padding: 18px;
  color: var(--carbon);
  border-radius: 8px 8px 26px 8px;
  box-shadow: 16px 23px 45px rgba(0,0,0,.35);
  transform: rotate(var(--tilt));
  transition: transform .4s ease, filter .4s ease;
}
.ticket:hover { transform: rotate(var(--tilt)) translateY(-12px); filter: drop-shadow(0 0 18px rgba(247,241,234,.14)); }
.ticket.peach { --tilt: -7deg; background: var(--peach); }
.ticket.blue { --tilt: 4deg; background: var(--blue); }
.ticket.lilac { --tilt: -2deg; background: var(--lilac); }
.ticket strong { display: block; margin: 18px 0 8px; font-family: var(--display); font-size: 28px; line-height: .9; letter-spacing: -.04em; }
.ticket p { margin: 0; line-height: 1.3; }

.matchbook {
  position: absolute;
  left: 48vw;
  top: 26vh;
  width: min(310px, 38vw);
  min-height: 128px;
  border: 0;
  border-radius: 18px 18px 8px 8px;
  padding: 0;
  background: var(--gold);
  color: var(--carbon);
  box-shadow: 0 24px 50px rgba(0,0,0,.42);
  font-family: var(--label);
  cursor: pointer;
  transform: rotate(8deg);
  overflow: hidden;
}
.matchbook-cover { display: block; padding: 22px; text-transform: uppercase; letter-spacing: .14em; font-weight: 800; }
.matchbook-line {
  display: block;
  max-height: 0;
  padding: 0 22px;
  overflow: hidden;
  background: var(--chalk);
  font-family: var(--body);
  line-height: 1.4;
  transition: max-height .55s ease, padding .55s ease;
}
.matchbook.open .matchbook-line { max-height: 150px; padding: 18px 22px 24px; }

.signal-window {
  position: absolute;
  right: 10vw;
  bottom: 11vh;
  width: min(45vw, 560px);
  aspect-ratio: 14 / 9;
  border: 1px solid rgba(189,239,216,.18);
  border-radius: 34px;
  background: rgba(36,34,41,.38);
  backdrop-filter: blur(10px);
  box-shadow: inset 0 0 60px rgba(189,239,216,.05);
}
.atom-circuit { width: 100%; height: 100%; fill: none; stroke: var(--mint); stroke-width: 2; opacity: .72; filter: drop-shadow(0 0 10px rgba(189,239,216,.24)); }
.atom-circuit circle { fill: var(--mint); }

.constellation {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(102deg, transparent 0 34%, rgba(215,182,111,.18) 34.2%, transparent 35% 100%),
    radial-gradient(circle at 72% 26%, rgba(215,199,255,.16), transparent 20vw);
}
.star { position: absolute; width: 8px; height: 8px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 20px var(--gold); }
.s1 { left: 22%; top: 28%; }.s2 { left: 38%; top: 42%; }.s3 { left: 61%; top: 31%; }.s4 { left: 76%; top: 55%; }.s5 { left: 48%; top: 72%; }.s6 { left: 84%; top: 22%; }
.pour-card {
  width: min(680px, 88vw);
  margin-left: auto;
  margin-right: 6vw;
  padding: clamp(24px, 4vw, 54px);
  border-radius: 34px;
  background: linear-gradient(135deg, rgba(36,34,41,.82), rgba(17,16,20,.62));
  border: 1px solid rgba(247,241,234,.12);
  box-shadow: 0 34px 90px rgba(0,0,0,.42), inset 0 0 0 1px rgba(215,182,111,.10);
}
.pour-card p { color: rgba(247,241,234,.76); font-size: 19px; line-height: 1.5; }
.receipt-strip {
  margin-top: 32px;
  padding: 18px;
  display: grid;
  gap: 9px;
  color: var(--carbon);
  background: var(--chalk);
  border-radius: 3px 18px 3px 18px;
  font-size: 10px;
}

.scene-meter {
  position: fixed;
  z-index: 21;
  left: 24px;
  bottom: 22px;
  width: 160px;
  height: 5px;
  border-radius: 999px;
  background: rgba(247,241,234,.16);
  overflow: hidden;
}
.scene-meter span { display: block; height: 100%; width: 0; background: linear-gradient(90deg, var(--peach), var(--mint), var(--blue)); transition: width .25s ease; }

@media (max-width: 800px) {
  .coaster-nav { left: 12px; right: 12px; justify-content: center; flex-wrap: wrap; transform: none; }
  .nav-sticker { padding: 8px 10px; }
  .scene { padding: 86px 20px 44px; }
  .door-note { margin-left: 0; }
  .drawer-stack { margin: 34vh auto 0; }
  .coaster-orbit { right: 5vw; bottom: 8vh; width: 170px; height: 170px; opacity: .85; }
  .coaster { width: 64px; height: 64px; }
  .ticket-rail { position: relative; left: auto; bottom: auto; flex-direction: column; margin: 34vh auto 0; }
  .ticket { width: min(310px, 82vw); min-height: 140px; }
  .matchbook { left: 8vw; top: 38vh; width: 260px; }
  .signal-window { width: 82vw; right: 9vw; bottom: 5vh; }
  .scene-title-block.right { text-align: left; left: 24px; right: auto; }
  .pour-card { margin: 18vh auto 0; }
}
