:root {
  /* Design typography tokens: JetBrains Mono sparingly for stamped batch codes; Space Grotesk* Grotesk** for product notes. */
  --charcoal: #171615;
  --gray: #6F6A62;
  --carmine: #D92754;
  --blush: #F28AAE;
  --lime: #B8FF3D;
  --silver: #C7D0D5;
  --pearl: #FFF1D8;
  --plum: #4A2348;
  --teal: #1CA79B;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  min-height: 100vh;
  color: var(--pearl);
  background:
    radial-gradient(circle at 18% 12%, rgba(242, 138, 174, .18), transparent 25vw),
    radial-gradient(circle at 92% 22%, rgba(184, 255, 61, .12), transparent 28vw),
    linear-gradient(118deg, #090807 0%, var(--charcoal) 46%, #23151f 100%);
  font-family: 'Space Grotesk', sans-serif;
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 2;
  opacity: .22;
  background-image:
    radial-gradient(circle, rgba(255, 241, 216, .75) 0 1px, transparent 1.5px),
    linear-gradient(90deg, transparent 0 47%, rgba(199, 208, 213, .16) 48% 49%, transparent 50%);
  background-size: 27px 31px, 11px 100%;
  mix-blend-mode: screen;
}

a { color: inherit; text-decoration: none; }

.powder-field {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 3;
  overflow: hidden;
}

.powder-speck {
  position: absolute;
  width: var(--s);
  height: var(--s);
  border-radius: 50%;
  background: var(--c);
  opacity: .48;
  filter: blur(.3px);
  animation: powderRise var(--d) linear infinite;
}

.progress-rail {
  position: fixed;
  left: 20px;
  top: 8vh;
  width: 4px;
  height: 84vh;
  z-index: 20;
  border-radius: 999px;
  background: rgba(111, 106, 98, .45);
  box-shadow: 0 0 0 1px rgba(255, 241, 216, .08);
}

.progress-rail span {
  display: block;
  width: 100%;
  height: 0%;
  border-radius: inherit;
  background: linear-gradient(var(--gray), var(--carmine), var(--blush), var(--teal), var(--lime));
  box-shadow: 0 0 18px rgba(184, 255, 61, .5);
}

.station-nav {
  position: fixed;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 20;
  display: grid;
  gap: 11px;
}

.station-nav a {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  color: var(--silver);
  padding: 6px 8px;
  transform: rotate(-7deg);
  background: rgba(23, 22, 21, .75);
  border: 1px solid rgba(199, 208, 213, .22);
  transition: color .25s, background .25s, transform .25s;
}

.station-nav a.active { color: var(--charcoal); background: var(--lime); transform: rotate(5deg) scale(1.08); }

.compact-progress {
  position: fixed;
  left: 42px;
  bottom: 24px;
  width: 46px;
  height: 46px;
  z-index: 22;
  border-radius: 50%;
  background: conic-gradient(var(--carmine) var(--progress, 0deg), rgba(199,208,213,.18) 0);
  border: 3px solid var(--silver);
  box-shadow: inset 0 0 15px rgba(255,255,255,.28), 0 0 18px rgba(242, 138, 174, .35);
}

.compact-progress span { position: absolute; inset: 11px; border-radius: 50%; background: var(--charcoal); border: 1px solid var(--pearl); }

.station {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  padding: clamp(70px, 8vw, 120px) clamp(42px, 9vw, 136px);
  isolation: isolate;
}

.station::after {
  content: "";
  position: absolute;
  inset: -20%;
  z-index: -2;
  background:
    radial-gradient(circle at var(--mx, 40%) var(--my, 40%), rgba(255, 241, 216, .09), transparent 26vw),
    repeating-linear-gradient(132deg, transparent 0 38px, rgba(199, 208, 213, .035) 39px 41px);
}

h1, h2 {
  font-family: 'Shrikhand', cursive;
  font-weight: 400;
  letter-spacing: -.045em;
  line-height: .84;
  margin: 0;
  text-shadow: 0 4px 0 rgba(74, 35, 72, .7), 0 0 28px rgba(242, 138, 174, .22);
}

h1 { font-size: clamp(44px, 9vw, 132px); color: var(--pearl); transform: scaleX(-1) rotate(-4deg); }
h2 { font-size: clamp(58px, 10vw, 156px); color: var(--blush); max-width: 900px; }

p { font-family: 'Fraunces', serif; font-size: clamp(19px, 2.1vw, 31px); line-height: 1.15; }

.batch, .station-number, .barcode-tag, .warning-label, .stamp-burst, .batch-grid, .final-tray {
  font-family: 'JetBrains Mono', monospace;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.diagonal-belt {
  position: absolute;
  width: 140vw;
  height: 190px;
  left: -22vw;
  top: 46%;
  transform: rotate(-18deg);
  z-index: -1;
  background:
    linear-gradient(90deg, rgba(255,255,255,.05), transparent 18%, rgba(255,255,255,.06) 36%, transparent 62%),
    repeating-linear-gradient(90deg, #10100f 0 34px, #211f1c 35px 67px);
  border-block: 8px solid rgba(111, 106, 98, .75);
  box-shadow: 0 28px 80px rgba(0,0,0,.55), inset 0 0 30px rgba(0,0,0,.9);
  animation: beltCreep 9s linear infinite;
}

.belt-wide { height: 270px; top: 40%; }
.belt-intro { top: 52%; }
.rollers { position: absolute; inset: 0; background: repeating-linear-gradient(90deg, transparent 0 78px, rgba(199,208,213,.18) 79px 86px); }

.inspection-lamp {
  position: absolute;
  top: -30px;
  left: 50%;
  width: 180px;
  height: 260px;
  transform: translateX(-50%);
  background: radial-gradient(ellipse at top, rgba(255,241,216,.88), rgba(255,241,216,.08) 54%, transparent 72%);
  clip-path: polygon(38% 0, 62% 0, 100% 100%, 0 100%);
  animation: flicker 4.8s infinite;
  mix-blend-mode: screen;
}

.compact-hero {
  position: absolute;
  left: 50%;
  top: 48%;
  width: min(72vw, 650px);
  aspect-ratio: 1;
  transform: translate(-50%, -50%) rotate(-8deg);
  perspective: 1200px;
}

.compact-lid, .compact-base {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 16px solid var(--silver);
  background: radial-gradient(circle at 40% 35%, #f6fbff, var(--silver) 34%, #687178 70%, #252525 100%);
  box-shadow: inset 0 0 45px rgba(255,255,255,.45), 0 40px 90px rgba(0,0,0,.7);
}

.compact-lid {
  transform-origin: 50% 102%;
  transform: rotateX(var(--lid, 0deg));
  transition: transform .4s ease-out;
  z-index: 2;
}

.compact-base {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  padding: 22%;
  background: radial-gradient(circle, #3b3934, #111);
}

.mirror-glass { position: absolute; inset: 12%; border-radius: 50%; display: grid; place-items: center; overflow: hidden; background: linear-gradient(135deg, rgba(255,255,255,.72), rgba(199,208,213,.24) 42%, rgba(74,35,72,.28)); }
.mirror-glass::before { content: ""; position: absolute; inset: -20%; background: linear-gradient(115deg, transparent 40%, rgba(255,255,255,.55) 47%, transparent 54%); animation: mirrorGlint 6s ease-in-out infinite; }
.crack-lines { position: absolute; inset: 6%; fill: none; stroke: rgba(23, 22, 21, .65); stroke-width: 3; stroke-linecap: round; }
.sliding-powder { position: absolute; width: 70%; height: 20%; left: 6%; bottom: 14%; border-radius: 50%; background: radial-gradient(ellipse, rgba(242,138,174,.75), rgba(217,39,84,.3) 52%, transparent 72%); filter: blur(8px); animation: powderSlide 8s ease-in-out infinite alternate; }
.pan { border-radius: 50%; background: conic-gradient(from 20deg, var(--carmine), var(--blush), var(--plum), var(--carmine)); box-shadow: inset 0 0 28px rgba(0,0,0,.45); }
.pan-pearl { background: conic-gradient(var(--pearl), var(--silver), var(--pearl)); }
.pan-teal { background: conic-gradient(var(--teal), var(--lime), var(--teal)); }

.hanging-tag, .copy-window, .label-sticker, .barcode-tag, .warning-label, .stamp-burst, .final-tray {
  background: rgba(255, 241, 216, .88);
  color: var(--charcoal);
  border: 2px solid rgba(23,22,21,.7);
  box-shadow: 8px 10px 0 rgba(0,0,0,.34);
}

.intro-tag { position: absolute; left: 8vw; bottom: 11vh; width: min(360px, 76vw); padding: 18px; transform: rotate(6deg); }
.intro-tag p { margin: 8px 0 0; font-size: 19px; font-family: 'Space Grotesk', sans-serif; }
.scroll-note { position: absolute; right: 8vw; bottom: 7vh; font-family: 'JetBrains Mono', monospace; font-size: 13px; text-transform: uppercase; color: var(--lime); }

.station-number { position: absolute; top: 42px; left: clamp(54px, 8vw, 120px); font-size: clamp(48px, 10vw, 150px); color: rgba(199,208,213,.22); }
.title-object { position: relative; margin-left: 12vw; padding-top: 18vh; }
.label-sticker { display: inline-block; padding: 7px 12px; font-family: 'Space Grotesk', sans-serif; font-weight: 700; transform: rotate(-4deg); }
.mirror-object h2 { margin-top: 18px; color: var(--pearl); }
.mirror-object::before { content: ""; position: absolute; width: 360px; height: 360px; left: -130px; top: 10vh; z-index: -1; border-radius: 50%; background: radial-gradient(circle at 35% 30%, var(--silver), rgba(199,208,213,.12) 60%, transparent 61%); border: 12px solid rgba(199,208,213,.45); }
.copy-window { position: absolute; right: 8vw; top: 24vh; width: min(450px, 72vw); padding: 24px; transform: rotate(-3deg); }
.copy-window p { color: var(--charcoal); margin: 0 0 16px; }
.copy-window .note { font-size: 18px; font-family: 'Space Grotesk', sans-serif; }
.object-pile { position: absolute; left: 10vw; bottom: 12vh; width: 420px; height: 150px; }
.object-pile i { position: absolute; display: block; filter: drop-shadow(0 18px 20px rgba(0,0,0,.45)); }
.tube { width: 38px; height: 150px; background: linear-gradient(var(--silver), var(--gray)); border-radius: 16px; transform: rotate(64deg); left: 100px; top: 0; }
.tube.short { height: 108px; background: linear-gradient(var(--teal), var(--lime)); left: 264px; top: 24px; transform: rotate(77deg); }
.lipstick { width: 48px; height: 135px; left: 178px; top: 6px; transform: rotate(41deg); background: linear-gradient(to top, var(--plum) 0 48%, var(--carmine) 49% 100%); clip-path: polygon(0 20%, 48% 0, 100% 20%, 100% 100%, 0 100%); }
.cap { width: 70px; height: 78px; left: 20px; top: 54px; background: var(--blush); border-radius: 16px; transform: rotate(-12deg); }
.wand { width: 190px; height: 8px; left: 190px; top: 102px; background: var(--charcoal); transform: rotate(-18deg); }
.wand::after { content:""; position:absolute; right:-36px; top:-13px; width:48px; height:34px; background: repeating-linear-gradient(90deg, var(--charcoal) 0 4px, var(--gray) 5px 7px); border-radius: 50%; }
.pan-disc { width: 96px; height: 96px; left: 300px; top: 22px; border-radius: 50%; background: conic-gradient(var(--pearl), var(--blush), var(--carmine), var(--pearl)); }
.barcode-tag { position: absolute; right: 20vw; bottom: 16vh; padding: 10px 14px; font-size: 13px; transform: rotate(10deg); }

.sort-station { background: radial-gradient(circle at 75% 50%, rgba(28,167,155,.2), transparent 40vw); }
.orbital-title { position: absolute; left: 9vw; top: 14vh; color: var(--lime); }
.sorting-chute { position: absolute; right: 8vw; top: 18vh; width: min(680px, 75vw); height: 62vh; }
.face-pan { position: absolute; width: 210px; height: 210px; border-radius: 50%; display: grid; place-items: center; border: 12px solid var(--silver); background: radial-gradient(circle at 38% 35%, var(--blush), var(--carmine)); box-shadow: inset 0 0 35px rgba(0,0,0,.4), 0 24px 50px rgba(0,0,0,.42); animation: panRotate 16s linear infinite; }
.face-pan span { font-family: 'JetBrains Mono', monospace; font-size: 12px; background: rgba(23,22,21,.78); padding: 6px; }
.face-pan:nth-child(1) { left: 0; top: 8%; }
.face-pan:nth-child(2) { right: 10%; top: 0; animation-duration: 19s; }
.face-pan:nth-child(3) { left: 18%; bottom: 2%; animation-duration: 23s; }
.face-pan:nth-child(4) { right: 0; bottom: 10%; animation-duration: 14s; }
.face-pan.silver { background: radial-gradient(circle, var(--pearl), var(--silver), var(--gray)); }
.face-pan.plum { background: radial-gradient(circle, var(--blush), var(--plum)); }
.face-pan.teal { background: radial-gradient(circle, var(--lime), var(--teal)); }
.caption-curve { position: absolute; left: 12vw; bottom: 13vh; width: 390px; color: var(--silver); transform: rotate(-8deg); }
.mascara-specimens { position: absolute; left: 48%; bottom: 10vh; display: flex; gap: 14px; transform: rotate(-18deg); }
.mascara-specimens b { width: 10px; height: 170px; background: linear-gradient(var(--gray), var(--charcoal)); border-radius: 8px; position: relative; }
.mascara-specimens b::before { content:""; position:absolute; top:-26px; left:-10px; width:30px; height:36px; background: repeating-linear-gradient(90deg, var(--pearl) 0 2px, var(--charcoal) 3px 5px); border-radius:50%; }

.crush-station { background: radial-gradient(circle at 25% 70%, rgba(217,39,84,.2), transparent 38vw), var(--charcoal); }
.crush-station h2 { position: absolute; right: 8vw; top: 22vh; color: var(--carmine); transform: rotate(4deg); }
.shaker-table { position: absolute; left: 5vw; top: 30vh; width: 54vw; height: 36vh; min-width: 520px; background: linear-gradient(120deg, #2e2b27, #100f0e); border: 10px solid var(--gray); transform: rotate(-8deg); animation: shake 1.2s steps(2) infinite; box-shadow: 0 34px 70px rgba(0,0,0,.6); }
.crush-drum { position: absolute; left: 8%; top: -28%; width: 250px; height: 250px; border-radius: 50%; background: conic-gradient(var(--gray), var(--silver), #292723, var(--gray)); border: 20px solid #0d0d0c; animation: panRotate 6s linear infinite; }
.terrazzo-slab { position: absolute; right: 6%; bottom: 16%; width: 46%; height: 42%; background: radial-gradient(circle at 12% 18%, var(--carmine) 0 8px, transparent 9px), radial-gradient(circle at 68% 34%, var(--lime) 0 6px, transparent 7px), radial-gradient(circle at 38% 72%, var(--teal) 0 10px, transparent 11px), radial-gradient(circle at 84% 78%, var(--blush) 0 9px, transparent 10px), var(--plum); border: 6px solid var(--pearl); }
.warning-label { position: absolute; left: 12vw; top: 17vh; padding: 10px 14px; font-size: 13px; transform: rotate(-7deg); background: var(--lime); }
.poem-copy { position: absolute; right: 10vw; bottom: 14vh; width: min(460px, 74vw); color: var(--pearl); }
.powder-plume { position: absolute; border-radius: 50%; filter: blur(20px); opacity: .6; animation: plume 5s ease-in-out infinite; }
.plume-one { left: 25vw; top: 28vh; width: 250px; height: 190px; background: var(--blush); }
.plume-two { left: 40vw; top: 52vh; width: 210px; height: 210px; background: var(--carmine); animation-delay: -2s; }

.altar-station { background: radial-gradient(circle at 50% 50%, rgba(255,241,216,.12), transparent 35vw), linear-gradient(160deg, var(--plum), var(--charcoal) 58%); }
.altar-tray { position: absolute; left: 10vw; top: 22vh; width: 56vw; max-width: 750px; height: 42vh; border: 16px solid var(--silver); border-radius: 48px; background: linear-gradient(135deg, rgba(199,208,213,.34), rgba(111,106,98,.28)); display: flex; align-items: center; justify-content: space-around; transform: rotate(-5deg); }
.refill-pan { width: clamp(145px, 15vw, 220px); height: clamp(145px, 15vw, 220px); border-radius: 50%; border: 12px solid var(--pearl); background: conic-gradient(var(--carmine) var(--fill, 0deg), rgba(23,22,21,.65) 0); box-shadow: inset 0 0 30px rgba(0,0,0,.55); transition: --fill 1s; }
.refill-pan span { display: block; width: 40%; height: 12%; margin: 24% auto; border-radius: 50%; background: rgba(255,255,255,.52); filter: blur(5px); }
.refill-pan.pearl { background: conic-gradient(var(--pearl) var(--fill, 0deg), rgba(23,22,21,.65) 0); }
.refill-pan.teal { background: conic-gradient(var(--teal) var(--fill, 0deg), rgba(23,22,21,.65) 0); }
.altar-station h2 { position: absolute; right: 7vw; top: 18vh; color: var(--pearl); }
.altar-copy { position: absolute; right: 9vw; bottom: 18vh; width: min(440px, 70vw); }
.recycle-mark { position: absolute; right: 18vw; bottom: 38vh; width: 220px; fill: none; stroke: var(--lime); stroke-width: 9; stroke-linecap: round; stroke-linejoin: round; stroke-dasharray: 410; stroke-dashoffset: var(--dash, 410); filter: drop-shadow(0 0 12px rgba(184,255,61,.5)); }
.stamp-burst { position: absolute; left: 18vw; bottom: 12vh; padding: 14px 18px; background: var(--carmine); color: var(--pearl); transform: rotate(8deg) scale(var(--stamp, .92)); transition: transform .3s; }

.fountain-station { background: radial-gradient(circle at 32% 35%, rgba(184,255,61,.18), transparent 35vw), linear-gradient(120deg, var(--charcoal), #071b19); }
.fountain-machine { position: absolute; left: 13vw; top: 17vh; width: 38vw; min-width: 350px; height: 70vh; }
.reservoir { position: absolute; top: 0; left: 18%; width: 64%; height: 32%; border-radius: 46% 46% 20% 20%; background: radial-gradient(circle at 35% 25%, var(--lime), var(--teal)); border: 12px solid var(--silver); box-shadow: inset 0 -35px 50px rgba(23,22,21,.35); }
.lime-stream { position: absolute; top: 29%; left: 48%; width: 36px; height: 38%; background: linear-gradient(var(--lime), rgba(28,167,155,.45)); border-radius: 0 0 28px 28px; filter: drop-shadow(0 0 22px var(--lime)); animation: pour 2.2s ease-in-out infinite; }
.refill-bottle { position: absolute; bottom: 8%; left: 34%; width: 32%; height: 28%; border-radius: 24px 24px 36px 36px; border: 10px solid var(--silver); background: linear-gradient(to top, var(--teal) 0 46%, rgba(199,208,213,.16) 47%); }
.fountain-copy { position: absolute; right: 8vw; top: 22vh; width: min(540px, 76vw); }
.fountain-copy h2 { margin: 20px 0; color: var(--lime); }
.safety-curtain { position: absolute; inset: 0; z-index: -1; background: repeating-linear-gradient(90deg, transparent 0 80px, rgba(199,208,213,.08) 81px 86px); transform: skewX(-9deg); }

.archive-station { background: radial-gradient(circle at 70% 35%, rgba(242,138,174,.2), transparent 36vw), linear-gradient(180deg, #130f12, #080807); }
.archive-station h2 { color: var(--blush); padding-top: 10vh; }
.archive-copy { width: min(620px, 80vw); color: var(--silver); }
.archive-orbit { position: absolute; right: 5vw; top: 13vh; width: 48vw; height: 60vh; min-width: 430px; animation: slowOrbit 28s linear infinite; }
.archive-compact { position: absolute; width: 220px; height: 220px; border-radius: 50%; border: 12px solid var(--silver); display: grid; place-items: center; background: radial-gradient(circle, var(--carmine), var(--plum)); box-shadow: inset 0 0 30px rgba(255,255,255,.2), 0 20px 50px rgba(0,0,0,.5); }
.archive-compact span { width: 70%; text-align: center; font-family: 'JetBrains Mono', monospace; font-size: 12px; text-transform: uppercase; }
.archive-compact:nth-child(1) { left: 0; top: 8%; }
.archive-compact:nth-child(2) { right: 4%; top: 22%; }
.archive-compact:nth-child(3) { left: 34%; bottom: 0; }
.archive-compact.teal { background: radial-gradient(circle, var(--lime), var(--teal)); color: var(--charcoal); }
.archive-compact.pearl { background: radial-gradient(circle, var(--pearl), var(--silver)); color: var(--charcoal); }
.final-tray { position: absolute; left: 10vw; bottom: 15vh; padding: 22px 32px; font-size: clamp(22px, 4vw, 58px); background: var(--pearl); transform: rotate(-3deg); }
.batch-grid { position: absolute; right: 8vw; bottom: 10vh; display: grid; gap: 8px; font-size: 12px; color: var(--lime); }

@keyframes beltCreep { to { background-position: 220px 0, 220px 0; } }
@keyframes flicker { 0%, 100% { opacity: .9; } 4% { opacity: .35; } 7% { opacity: .95; } 52% { opacity: .68; } 56% { opacity: 1; } }
@keyframes mirrorGlint { 0%, 30% { transform: translateX(-80%) rotate(8deg); } 70%, 100% { transform: translateX(80%) rotate(8deg); } }
@keyframes powderSlide { from { transform: translateX(-12%) rotate(-6deg); } to { transform: translateX(28%) rotate(7deg); } }
@keyframes powderRise { from { transform: translateY(110vh) translateX(0); } to { transform: translateY(-15vh) translateX(38px); } }
@keyframes panRotate { to { transform: rotate(360deg); } }
@keyframes shake { 0%, 100% { transform: rotate(-8deg) translate(0,0); } 50% { transform: rotate(-8deg) translate(5px,-3px); } }
@keyframes plume { 0%,100% { transform: scale(.7) translateY(30px); opacity: .2; } 50% { transform: scale(1.1) translateY(-16px); opacity: .58; } }
@keyframes pour { 0%,100% { transform: scaleY(.8); opacity: .72; } 50% { transform: scaleY(1.08); opacity: 1; } }
@keyframes slowOrbit { to { transform: rotate(360deg); } }

@media (max-width: 820px) {
  .station { padding-inline: 34px; }
  .station-nav { display: none; }
  .progress-rail { left: 10px; }
  .copy-window, .poem-copy, .altar-copy, .fountain-copy { position: relative; inset: auto; width: auto; margin-top: 34px; }
  .object-pile, .sorting-chute, .shaker-table, .altar-tray, .fountain-machine, .archive-orbit { transform: scale(.72) rotate(-6deg); transform-origin: left center; left: 6vw; min-width: 420px; }
  .archive-orbit { opacity: .75; }
  h2 { font-size: clamp(54px, 18vw, 100px); }
}
