:root {
  /* Design compliance vocabulary: passport numbers Interplanetary Intake Corridor**. Avoid centered hero Interview Booth** Space Grotesk** space immigration Game**. */
  --violet: #8E5CFF;
  --red: #FF4F6D;
  --mint: #B9FFD6;
  --moss: #7CFF8A;
  --cream: #F4E8C1;
  --void: #01030B;
  --navy: #070A1F;
  --cyan: #3BE8FF;
  --amber: #FFB84D;
  --space: 'Space Grotesk', sans-serif;
  --orbitron: 'Orbitron', sans-serif;
  --mono: 'IBM Plex Mono', monospace;
  --keepsake: 'Alegreya Sans', sans-serif;
}

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

.design-compliance-lexicon::before { content: "Corridor**. Booth** Grotesk** Game**."; display: none; }

body.gravity-accepted { animation: gravitySettle 1.5s ease both; }

.cosmic-grain,
.star-legal-field,
.stamp-flash {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
}

.cosmic-grain {
  opacity: .24;
  background:
    radial-gradient(circle at 21% 18%, rgba(59, 232, 255, .12), transparent 22%),
    radial-gradient(circle at 82% 28%, rgba(142, 92, 255, .18), transparent 27%),
    radial-gradient(circle at 62% 88%, rgba(255, 184, 77, .08), transparent 22%),
    repeating-linear-gradient(115deg, rgba(244, 232, 193, .035) 0 1px, transparent 1px 7px);
  mix-blend-mode: screen;
}

.star-legal-field {
  background-image:
    radial-gradient(circle, rgba(244,232,193,.78) 0 1px, transparent 1.5px),
    radial-gradient(circle, rgba(59,232,255,.7) 0 1px, transparent 1.2px);
  background-size: 73px 91px, 137px 113px;
  background-position: var(--sx, 0) var(--sy, 0), calc(var(--sx, 0) * -1) calc(var(--sy, 0) * .7);
  opacity: .32;
}

.stamp-flash { opacity: 0; background: radial-gradient(circle, rgba(255,184,77,.55), transparent 34%); }
.stamp-flash.impact { animation: stampFlash .8s ease; }

.intake-corridor { position: relative; z-index: 2; }
.room {
  min-height: 100vh;
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding: 8vh 8vw;
  background:
    linear-gradient(135deg, rgba(7,10,31,.94), rgba(1,3,11,.98) 60%),
    radial-gradient(circle at 75% 25%, rgba(142,92,255,.14), transparent 30%);
}
.room::before {
  content: '';
  position: absolute;
  inset: 7vh 7vw;
  border: 1px solid rgba(185,255,214,.14);
  border-radius: 46% 54% 44% 56% / 58% 38% 62% 42%;
  transform: rotate(-8deg);
  box-shadow: 0 0 60px rgba(59,232,255,.08), inset 0 0 80px rgba(142,92,255,.08);
  z-index: -1;
}
.room::after {
  content: attr(data-room);
  position: absolute;
  right: -4vw;
  bottom: 10vh;
  font-family: var(--orbitron);
  font-size: clamp(3rem, 9vw, 9rem);
  letter-spacing: .13em;
  color: transparent;
  -webkit-text-stroke: 1px rgba(244,232,193,.08);
  transform: rotate(-8deg);
  z-index: -1;
}

h1, h2 { font-family: var(--orbitron); text-transform: uppercase; margin: 0; letter-spacing: .12em; }
h1 { font-size: clamp(2.1rem, 7vw, 7.4rem); text-shadow: 0 0 30px rgba(59,232,255,.44); }
h2 { font-size: clamp(2rem, 5.6vw, 5.4rem); line-height: .95; }
p { font-size: clamp(1rem, 1.45vw, 1.25rem); line-height: 1.55; max-width: 58ch; }
.mono { font-family: var(--mono); color: var(--cyan); letter-spacing: .08em; text-transform: uppercase; font-size: .76rem; }

.itinerary-strip {
  position: fixed;
  left: 1.2rem;
  top: 50%;
  transform: translateY(-50%);
  width: 64px;
  z-index: 20;
  display: grid;
  gap: .55rem;
  padding: .75rem .55rem;
  border: 1px solid rgba(244,232,193,.25);
  background: rgba(1,3,11,.72);
  backdrop-filter: blur(10px);
  box-shadow: 0 0 28px rgba(142,92,255,.18);
}
.strip-title { font-family: var(--mono); color: var(--cream); font-size: .48rem; text-align: center; letter-spacing: .08em; }
.itinerary-stamp {
  display: grid;
  place-items: center;
  height: 40px;
  color: rgba(244,232,193,.6);
  text-decoration: none;
  font-family: var(--mono);
  font-size: .7rem;
  border: 1px dashed rgba(244,232,193,.24);
  border-radius: 50%;
  transition: .35s ease;
}
.itinerary-stamp.active { color: var(--void); background: var(--amber); border-color: var(--amber); box-shadow: 0 0 18px rgba(255,184,77,.65); transform: rotate(-10deg); }

.queue-board {
  position: fixed;
  right: 2vw;
  top: 2vh;
  z-index: 21;
  padding: .8rem 1rem;
  border: 1px solid rgba(59,232,255,.38);
  background: linear-gradient(180deg, rgba(7,10,31,.88), rgba(1,3,11,.78));
  font-family: var(--mono);
  text-align: right;
  color: var(--cyan);
}
.queue-board span, .queue-board small { display: block; color: rgba(244,232,193,.65); font-size: .62rem; }
.queue-board b { display: block; font-size: 1.45rem; color: var(--amber); letter-spacing: .16em; }

.passport-spine {
  position: fixed;
  left: 50%;
  top: 52%;
  width: min(34vw, 390px);
  height: min(54vh, 520px);
  transform: translate(-50%, -50%) rotate(var(--passport-tilt, -7deg)) scale(var(--passport-scale, 1));
  z-index: 9;
  transform-style: preserve-3d;
  transition: transform .5s ease;
  pointer-events: none;
}
.passport-cover,
.passport-page {
  position: absolute;
  inset: 0;
  border-radius: 24px 14px 14px 24px;
  border: 1px solid rgba(244,232,193,.38);
  box-shadow: 0 22px 90px rgba(1,3,11,.7), inset 0 0 70px rgba(59,232,255,.08);
}
.passport-cover {
  background: linear-gradient(135deg, rgba(14,19,55,.96), rgba(1,3,11,.94)), repeating-radial-gradient(circle at 50% 42%, rgba(244,232,193,.08) 0 2px, transparent 2px 9px);
  display: grid;
  place-items: center;
  text-align: center;
  transition: transform 1s cubic-bezier(.2,.8,.2,1), opacity .8s ease;
  transform-origin: left center;
  z-index: 2;
}
.passport-cover b { font-family: var(--orbitron); font-size: clamp(1.6rem, 4vw, 3.5rem); color: var(--cream); letter-spacing: .15em; }
.passport-cover i { width: 40%; aspect-ratio: 1; border-radius: 50%; border: 3px double var(--amber); box-shadow: 0 0 28px rgba(255,184,77,.38); }
.passport-page {
  background: linear-gradient(135deg, rgba(244,232,193,.9), rgba(255,184,77,.54)), repeating-linear-gradient(90deg, rgba(7,10,31,.08) 0 1px, transparent 1px 18px);
  color: var(--navy);
  opacity: .18;
  transform: translateX(0) rotateY(0);
  overflow: hidden;
}
body.passport-open .passport-cover { transform: rotateY(-112deg); opacity: .5; }
body.passport-open .passport-page { opacity: .95; }
.passport-watermark { position: absolute; inset: 0; display: grid; place-items: center; font-size: 16rem; color: rgba(142,92,255,.1); }
.stamp {
  position: absolute;
  font-family: var(--mono);
  font-weight: 700;
  border: 3px solid currentColor;
  border-radius: 50%;
  padding: 1.3rem .8rem;
  opacity: var(--stamp-opacity, .08);
  transform: rotate(var(--r)) scale(var(--stamp-scale, .76));
  transition: .6s ease;
}
.stamp-earth { --r: -14deg; left: 8%; top: 12%; color: var(--amber); }
.stamp-visa { --r: 12deg; right: 8%; top: 18%; color: var(--violet); }
.stamp-cryo { --r: -3deg; left: 20%; top: 43%; color: var(--red); }
.stamp-moon { --r: 18deg; right: 9%; bottom: 19%; color: var(--cyan); }
.stamp-arrival { --r: -10deg; left: 19%; bottom: 10%; color: var(--moss); }

.terminal-sign { margin-left: 9vw; max-width: 74vw; padding-top: 5vh; }
.terminal-sign p { color: var(--mint); font-family: var(--mono); text-transform: uppercase; letter-spacing: .14em; }
.signal-dot { display: inline-block; width: 12px; height: 12px; border-radius: 50%; background: var(--moss); box-shadow: 0 0 22px var(--moss); animation: pulse 1.8s infinite; }
.stamp-arm {
  position: absolute;
  right: 14vw;
  top: 18vh;
  width: 170px;
  height: 210px;
  border: 0;
  background: transparent;
  color: var(--amber);
  font-family: var(--mono);
  cursor: pointer;
}
.stamp-arm span { display: block; height: 140px; width: 28px; margin: 0 auto; background: linear-gradient(var(--amber), var(--cream)); border-radius: 18px 18px 5px 5px; box-shadow: 0 0 28px rgba(255,184,77,.35); }
.stamp-arm::after { content: ''; display: block; width: 150px; height: 44px; margin: -4px auto 12px; border-radius: 12px; border: 3px solid var(--amber); background: rgba(255,184,77,.14); }
.stamp-arm.impact { animation: stampArm .55s ease; }

.scene-copy { position: absolute; z-index: 6; }
.diagonal-copy { left: 13vw; bottom: 12vh; transform: rotate(-3deg); }
.left-copy { left: 10vw; bottom: 12vh; }
.right-copy { right: 8vw; top: 20vh; max-width: 42vw; }
.atrium-copy { left: 9vw; top: 12vh; max-width: 43vw; }
.final-copy { right: 7vw; bottom: 12vh; max-width: 43vw; }
.keepsake { font-family: var(--keepsake); font-style: italic; color: var(--mint); font-size: 1.5rem; }

.waiting-chairs { position: absolute; left: 12vw; top: 48vh; display: flex; gap: 1rem; transform: skewX(-16deg); }
.waiting-chairs i { width: 52px; height: 70px; display: grid; place-items: center; border: 1px solid rgba(244,232,193,.28); color: rgba(244,232,193,.52); font-family: var(--mono); }

.constellation-form { position: absolute; inset: 11vh 7vw auto auto; width: 70vw; max-width: 980px; filter: drop-shadow(0 0 18px rgba(59,232,255,.35)); }
.constellation-form path { fill: none; stroke: var(--cyan); stroke-width: 3; stroke-dasharray: 1200; stroke-dashoffset: var(--constellation-offset, 1200); transition: stroke-dashoffset .2s linear; }
.constellation-form circle { fill: var(--cream); stroke: var(--violet); stroke-width: 3; }
.desk-slab { position: absolute; left: 10vw; top: 14vh; padding: 2rem; width: min(42vw, 560px); background: rgba(7,10,31,.72); border: 1px solid rgba(59,232,255,.32); transform: rotate(-4deg); }
.form-fields { position: absolute; right: 12vw; bottom: 13vh; display: grid; gap: .8rem; width: min(38vw, 470px); }
.form-fields label { display: flex; justify-content: space-between; padding: .8rem 1rem; color: var(--cream); border-bottom: 1px dotted var(--mint); font-family: var(--mono); text-transform: uppercase; background: rgba(1,3,11,.4); }
.form-fields em { color: var(--amber); font-style: normal; }

.carousel-ring { position: absolute; right: 8vw; top: 12vh; width: 52vw; aspect-ratio: 1; border-radius: 50%; border: 2px dashed rgba(185,255,214,.25); animation: precess 28s linear infinite; }
.carousel-ring::before { content: ''; position: absolute; inset: 16%; border: 18px solid rgba(59,232,255,.08); border-radius: 50%; }
.baggage-drift { position: absolute; inset: 0; }
.bag { position: absolute; padding: 1rem; width: 190px; min-height: 95px; border: 1px solid currentColor; background: rgba(1,3,11,.78); font-family: var(--mono); box-shadow: 0 0 24px rgba(1,3,11,.8); animation: drift 9s ease-in-out infinite alternate; }
.bag span, .bag b { display: block; }
.bag b { margin-top: .9rem; font-size: .72rem; }
.bag.cleared { color: var(--moss); left: 58vw; top: 18vh; }
.bag.held { color: var(--amber); left: 72vw; top: 53vh; animation-delay: -2s; }
.bag.quarantine { color: var(--red); left: 45vw; top: 66vh; animation-delay: -4s; }
.bag:nth-child(4) { left: 32vw; top: 32vh; animation-delay: -1s; }
.bag:nth-child(5) { left: 66vw; top: 30vh; animation-delay: -5s; }

.airlock-iris { position: absolute; left: 12vw; top: 13vh; width: 43vw; max-width: 560px; aspect-ratio: 1; border-radius: 50%; border: 2px solid rgba(244,232,193,.22); display: grid; place-items: center; }
.airlock-iris div { position: absolute; width: 48%; height: 18%; background: linear-gradient(90deg, rgba(59,232,255,.1), rgba(142,92,255,.28)); transform-origin: 100% 50%; clip-path: polygon(0 0, 100% 20%, 100% 80%, 0 100%); rotate: calc(var(--i) * 60deg); }
.airlock-iris div:nth-child(1){--i:0}.airlock-iris div:nth-child(2){--i:1}.airlock-iris div:nth-child(3){--i:2}.airlock-iris div:nth-child(4){--i:3}.airlock-iris div:nth-child(5){--i:4}.airlock-iris div:nth-child(6){--i:5}
.airlock-iris.open div { animation: irisOpen 2.6s ease-in-out infinite alternate; }
.radio-subtitles { position: absolute; left: 13vw; bottom: 15vh; width: min(55vw, 700px); font-family: var(--mono); }
.radio-subtitles p { opacity: .16; color: var(--cream); transition: .4s ease; }
.radio-subtitles p.active { opacity: 1; color: var(--cyan); transform: translateX(1.2rem); }
.route-choice { position: absolute; right: 5vw; bottom: 12vh; width: 58vw; }
.route { fill: none; stroke-width: 5; stroke-linecap: round; stroke-dasharray: 14 18; animation: routePulse 2s linear infinite; }
.route.neutral { stroke: rgba(185,255,214,.45); }
.route.approved { stroke: var(--amber); filter: drop-shadow(0 0 13px rgba(255,184,77,.65)); }
.route.rejected { stroke: var(--red); opacity: .45; filter: blur(.4px); }

.lottery-orbit { position: absolute; right: 8vw; top: 14vh; width: min(55vw, 680px); aspect-ratio: 1; border-radius: 50%; border: 1px solid rgba(244,232,193,.18); animation: precess 38s linear infinite; }
.seal { position: absolute; width: 128px; aspect-ratio: 1; border-radius: 50%; font-family: var(--orbitron); letter-spacing: .09em; border: 4px double currentColor; background: rgba(1,3,11,.82); color: var(--cream); box-shadow: 0 0 28px currentColor; cursor: pointer; transition: .5s ease; }
.seal:hover, .seal.selected { transform: scale(1.18) rotate(12deg); z-index: 4; }
.seal.moss { color: var(--moss); left: 42%; top: -5%; }
.seal.cyan { color: var(--cyan); right: -5%; top: 42%; }
.seal.amber { color: var(--amber); left: 42%; bottom: -5%; }
.seal.violet { color: var(--violet); left: -5%; top: 42%; }
.lottery-result { position: absolute; right: 10vw; bottom: 11vh; font-family: var(--mono); color: var(--amber); border: 1px solid rgba(255,184,77,.34); padding: 1rem 1.3rem; background: rgba(1,3,11,.62); }

.moon-gates { position: absolute; right: 8vw; top: 12vh; width: 58vw; height: 70vh; }
.moon-gate { position: absolute; width: 220px; height: 330px; border-radius: 50%; border: 28px solid rgba(244,232,193,.16); border-left-color: transparent; display: grid; place-items: center; color: var(--cream); font-family: var(--mono); animation: moonSwing 5s ease-in-out infinite alternate; }
.moon-gate:nth-child(1) { left: 0; top: 10%; color: var(--cyan); }
.moon-gate:nth-child(2) { left: 34%; top: 0; color: var(--red); animation-delay: -1.6s; }
.moon-gate:nth-child(3) { right: 4%; top: 18%; color: var(--moss); animation-delay: -3s; }
.moon-gate span { transform: rotate(90deg); white-space: nowrap; }
.quarantine-fog { position: absolute; right: 0; bottom: 0; width: 70vw; height: 44vh; background: radial-gradient(ellipse at 70% 70%, rgba(255,79,109,.22), transparent 58%); filter: blur(20px); }
.inspection-stickers { position: absolute; left: 11vw; top: 15vh; display: flex; gap: 1rem; flex-wrap: wrap; max-width: 480px; }
.inspection-stickers i { font-family: var(--mono); font-style: normal; color: var(--void); background: var(--mint); padding: .6rem .8rem; transform: rotate(-7deg); }
.inspection-stickers i:nth-child(2) { background: var(--red); color: var(--cream); transform: rotate(4deg); }
.inspection-stickers i:nth-child(3) { background: var(--amber); }

.arrival-map { position: absolute; left: 8vw; top: 10vh; width: 62vw; height: 78vh; }
.arrival-map svg { width: 100%; height: 100%; filter: drop-shadow(0 0 20px rgba(124,255,138,.32)); }
.final-route { fill: none; stroke: var(--moss); stroke-width: 5; stroke-dasharray: 22 16; animation: routePulse 1.8s linear infinite; }
.final-planet { fill: rgba(124,255,138,.18); stroke: var(--moss); stroke-width: 4; }
.final-planet.small { fill: rgba(59,232,255,.18); stroke: var(--cyan); }
.final-planet.tiny { fill: rgba(255,184,77,.2); stroke: var(--amber); }
.final-stamp { position: absolute; left: 41%; top: 31%; width: 230px; height: 230px; display: grid; place-items: center; border-radius: 50%; border: 7px double var(--moss); color: var(--moss); font-family: var(--orbitron); text-align: center; font-size: 1.6rem; letter-spacing: .12em; transform: rotate(-14deg); box-shadow: 0 0 35px rgba(124,255,138,.55); }
.gravity-button { border: 2px solid var(--moss); color: var(--moss); background: rgba(124,255,138,.08); font-family: var(--mono); padding: 1rem 1.3rem; letter-spacing: .1em; cursor: pointer; }

@keyframes pulse { 50% { opacity: .35; transform: scale(.82); } }
@keyframes stampArm { 45% { transform: translateY(90px); } 100% { transform: translateY(0); } }
@keyframes stampFlash { 0% { opacity: 0; transform: scale(.7); } 35% { opacity: 1; } 100% { opacity: 0; transform: scale(1.6); } }
@keyframes precess { to { transform: rotate(360deg); } }
@keyframes drift { to { transform: translate3d(-38px, 32px, 0) rotate(7deg); } }
@keyframes irisOpen { to { transform: rotate(18deg) translateX(42px); opacity: .55; } }
@keyframes routePulse { to { stroke-dashoffset: -64; } }
@keyframes moonSwing { to { transform: translateY(28px) rotate(-5deg); } }
@keyframes gravitySettle { 0% { filter: saturate(1.5); } 60% { filter: saturate(1.1) brightness(1.08); } 100% { filter: none; } }

@media (max-width: 800px) {
  .itinerary-strip { left: .5rem; width: 52px; }
  .passport-spine { width: 72vw; height: 42vh; top: 48%; }
  .scene-copy, .desk-slab, .form-fields, .radio-subtitles, .lottery-result { left: 18vw; right: 5vw; width: auto; max-width: none; }
  .right-copy, .atrium-copy, .final-copy { top: auto; bottom: 8vh; }
  .stamp-arm { right: 6vw; top: 23vh; transform: scale(.75); }
  .constellation-form, .route-choice, .arrival-map { width: 90vw; left: 6vw; right: auto; opacity: .7; }
  .lottery-orbit, .moon-gates { width: 84vw; right: -18vw; opacity: .8; }
  .queue-board { display: none; }
}
