:root {
  --charcoal: #17151F;
  --canvas: #F3E8D2;
  --blue: #A9D7FF;
  --violet: #6C35FF;
  --green: #8CFFB6;
  --vermillion: #FF4F3E;
  --yellow: #F7D64A;
  --scene-accent: #F7D64A;
  --scene-gel: #A9D7FF;
  --scene-ground: #17151F;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  min-height: 500vh;
  color: var(--canvas);
  font-family: "DM Sans", Inter, sans-serif;
  background: var(--charcoal);
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at var(--mx, 50%) var(--my, 45%), color-mix(in srgb, var(--scene-gel) 30%, transparent), transparent 18rem),
    repeating-linear-gradient(90deg, transparent 0 54px, rgba(247, 214, 74, .08) 55px 56px),
    linear-gradient(135deg, rgba(169, 215, 255, .08), transparent 45%, rgba(108, 53, 255, .12));
  mix-blend-mode: screen;
  z-index: 20;
}

.stage-shell {
  position: fixed;
  inset: 0;
  overflow: hidden;
  background:
    radial-gradient(ellipse at 50% 82%, rgba(243, 232, 210, .12), transparent 36%),
    linear-gradient(180deg, #17151F 0%, #221b30 55%, #17151F 100%);
}

.cursor-gel {
  position: fixed;
  width: 10rem;
  height: 10rem;
  margin: -5rem 0 0 -5rem;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(140, 255, 182, .28), rgba(169, 215, 255, .16) 45%, transparent 70%);
  pointer-events: none;
  transform: translate3d(-20rem, -20rem, 0);
  z-index: 30;
  mix-blend-mode: screen;
}

.cue-rail {
  position: fixed;
  left: clamp(1rem, 3vw, 2.5rem);
  bottom: clamp(1rem, 3vw, 2rem);
  display: flex;
  gap: .55rem;
  z-index: 25;
  transform: rotate(-2deg);
}

.cue {
  border: 0;
  color: var(--charcoal);
  background: var(--canvas);
  font-family: "Rubik Mono One", sans-serif;
  font-size: .55rem;
  letter-spacing: .02em;
  padding: .55rem .7rem;
  clip-path: polygon(5% 0, 100% 8%, 96% 100%, 0 90%);
  cursor: pointer;
  box-shadow: 0 .4rem 0 rgba(0, 0, 0, .35);
  transition: transform .25s ease, background .25s ease;
}

.cue span { display: block; color: var(--violet); }
.cue.active { background: var(--scene-accent); transform: translateY(-.4rem) rotate(2deg); }

.rigging-lines span {
  position: fixed;
  top: -10vh;
  width: 1px;
  height: 120vh;
  background: linear-gradient(var(--blue), transparent);
  opacity: .28;
  z-index: 4;
}
.rigging-lines span:nth-child(1) { left: 12%; transform: rotate(8deg); }
.rigging-lines span:nth-child(2) { left: 38%; transform: rotate(-5deg); }
.rigging-lines span:nth-child(3) { right: 30%; transform: rotate(11deg); }
.rigging-lines span:nth-child(4) { right: 9%; transform: rotate(-8deg); }

.turntable {
  position: absolute;
  inset: 0;
  transform-style: preserve-3d;
  perspective: 1100px;
}

.turntable::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -18vmin;
  width: 86vmin;
  height: 36vmin;
  transform: translateX(-50%) rotateX(62deg) rotateZ(var(--turn, 0deg));
  border-radius: 50%;
  border: 2px dashed rgba(247, 214, 74, .45);
  background: radial-gradient(circle, rgba(243,232,210,.13), rgba(23,21,31,.9) 65%);
  transition: transform .9s cubic-bezier(.2,.8,.2,1);
  z-index: 1;
}

.scene {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  opacity: 0;
  transform: rotateY(calc((var(--i, 0) - var(--active, 0)) * 42deg)) translateZ(-16rem) scale(.84);
  transition: opacity .7s ease, transform .9s cubic-bezier(.2,.8,.2,1), filter .7s ease;
  pointer-events: none;
  filter: saturate(.65) brightness(.65);
}
.scene.active { opacity: 1; transform: rotateY(0deg) translateZ(0) scale(1); pointer-events: auto; filter: none; z-index: 5; }

.scenic-flat {
  position: relative;
  width: min(70rem, 78vw);
  min-height: min(34rem, 62vh);
  padding: clamp(2rem, 5vw, 4.5rem);
  border: .18rem solid var(--charcoal);
  background: linear-gradient(135deg, color-mix(in srgb, var(--scene-ground) 84%, white), var(--scene-ground));
  box-shadow: 1.2rem 1.2rem 0 var(--scene-accent), 0 2rem 5rem rgba(0,0,0,.45);
  transform-origin: left center;
  clip-path: polygon(2% 0, 100% 4%, 96% 96%, 0 100%);
}

.scenic-flat::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: .16;
  background: repeating-linear-gradient(45deg, transparent 0 12px, var(--canvas) 13px 14px), radial-gradient(circle at 20% 20%, var(--scene-gel), transparent 30%);
  pointer-events: none;
}

.stencil {
  margin: 0 0 1rem;
  font-family: "Rubik Mono One", sans-serif;
  font-size: .7rem;
  color: var(--scene-accent);
  letter-spacing: .08em;
}

h1, h2 { font-family: "Bricolage Grotesque", sans-serif; margin: 0; line-height: .86; }
h2 { font-size: clamp(4rem, 12vw, 11rem); color: var(--canvas); text-shadow: .08em .08em 0 rgba(0,0,0,.28); }

.wood-word {
  display: flex;
  flex-wrap: wrap;
  gap: .1em;
  font-size: clamp(4.8rem, 16vw, 15rem);
  color: #F3E8D2;
  text-shadow: .035em .045em 0 #6f4b2d, .07em .09em 0 rgba(0,0,0,.55);
}
.wood-word span { display: inline-block; background: linear-gradient(90deg, #F3E8D2, #c08a4e); -webkit-background-clip: text; color: transparent; transform: rotate(var(--r, -2deg)); }
.wood-word span:nth-child(2n) { --r: 3deg; }

.director-note, .placard, .curator-card {
  position: relative;
  max-width: 32rem;
  margin: 1.4rem 0 0;
  padding: 1rem 1.2rem;
  background: rgba(243, 232, 210, .93);
  color: var(--charcoal);
  font-family: "Fraunces", serif;
  font-size: clamp(1.05rem, 2vw, 1.45rem);
  box-shadow: .5rem .5rem 0 rgba(0,0,0,.32);
  transform: rotate(-1.5deg);
}

.spotlight {
  position: absolute;
  top: -20vh;
  width: 36vw;
  height: 125vh;
  background: linear-gradient(to bottom, color-mix(in srgb, var(--scene-gel) 48%, transparent), transparent 78%);
  clip-path: polygon(42% 0, 58% 0, 100% 100%, 0 100%);
  opacity: .45;
  animation: sweep 7s ease-in-out infinite alternate;
  z-index: 0;
}
.spotlight.left { left: 5%; }
.spotlight.violet, .spotlight.final { right: 10%; }
.spotlight.green { left: 24%; }
.spotlight.amber { right: 24%; }

@keyframes sweep { from { transform: rotate(-8deg); } to { transform: rotate(9deg); } }

.pulley { position: absolute; top: 7%; width: 5rem; height: 5rem; border: .45rem solid var(--blue); border-radius: 50%; animation: pulley 8s linear infinite; }
.pulley i { position: absolute; left: 50%; top: 100%; width: 2px; height: 42vh; background: var(--blue); }
.pulley-a { left: 18%; } .pulley-b { right: 20%; animation-direction: reverse; }
@keyframes pulley { to { transform: rotate(360deg); } }

.floor-marks span { position: absolute; bottom: 15%; width: 7rem; height: 1rem; background: var(--yellow); transform: rotate(var(--a)); opacity: .9; }
.floor-marks span:nth-child(1) { left: 28%; --a: 8deg; } .floor-marks span:nth-child(2) { left: 48%; --a: -3deg; background: var(--vermillion); } .floor-marks span:nth-child(3) { right: 24%; --a: 14deg; background: var(--green); }

.hanging-tag { position: absolute; right: 10vw; top: 16vh; padding: 1.2rem; color: var(--charcoal); background: var(--yellow); font-family: "Fraunces", serif; transform: rotate(7deg); animation: sway 4s ease-in-out infinite alternate; box-shadow: .4rem .4rem 0 rgba(0,0,0,.35); }
@keyframes sway { to { transform: rotate(-5deg) translateY(.4rem); } }

.sample-wheel { position: absolute; right: 10vw; bottom: 16vh; width: 18rem; height: 18rem; border-radius: 50%; animation: wheel 12s linear infinite; }
.sample-wheel span { position: absolute; left: 50%; top: 50%; width: 5rem; height: 10rem; transform-origin: 0 0; background: var(--c); clip-path: polygon(12% 0,100% 10%,76% 100%,0 88%); transform: rotate(calc(var(--n, 0) * 72deg)) translateY(-9rem); }
.sample-wheel span:nth-child(1){--n:0}.sample-wheel span:nth-child(2){--n:1}.sample-wheel span:nth-child(3){--n:2}.sample-wheel span:nth-child(4){--n:3}.sample-wheel span:nth-child(5){--n:4}
@keyframes wheel { to { transform: rotate(360deg); } }

.swatches { position: absolute; left: 7vw; top: 18vh; display: grid; gap: .6rem; transform: rotate(-8deg); }
.swatches b { font-family: "Rubik Mono One"; font-size: .8rem; color: var(--charcoal); background: var(--yellow); padding: .4rem .8rem; }
.swatches i { width: 14rem; height: 3rem; background: var(--blue); clip-path: polygon(0 0, 96% 9%, 100% 92%, 4% 100%); box-shadow: .3rem .3rem 0 rgba(0,0,0,.24); }
.swatches i:nth-child(3){background:var(--violet)}.swatches i:nth-child(4){background:var(--green)}.swatches i:nth-child(5){background:var(--vermillion)}.swatches i:nth-child(6){background:var(--yellow)}

.mask-rack { position: absolute; right: 9vw; top: 25vh; display: flex; gap: 1.2rem; perspective: 700px; }
.mask { width: 8rem; height: 11rem; background: var(--canvas); border-radius: 50% 50% 45% 45%; border: .18rem solid var(--charcoal); position: relative; transform: rotateY(0); animation: flip 5s ease-in-out infinite; box-shadow: .6rem .6rem 0 var(--scene-accent); }
.mask.alt { background: var(--blue); animation-delay: .8s; }
.mask em { position: absolute; top: 38%; width: 1.1rem; height: .55rem; background: var(--charcoal); border-radius: 50%; }
.mask em:first-child { left: 30%; } .mask em:last-child { right: 30%; }
@keyframes flip { 50% { transform: rotateY(180deg) rotate(4deg); } }

.label-strip { position: absolute; left: 10vw; bottom: 18vh; padding: .8rem 1rem; color: var(--charcoal); background: var(--green); font-family: "Rubik Mono One"; font-size: .7rem; transform: rotate(3deg); }

.hinge-board { position: absolute; left: 8vw; top: 18vh; display: grid; transform: rotate(-6deg); }
.hinge-board span { min-width: 18rem; padding: 1rem 1.4rem; margin: -.05rem; border: .18rem solid var(--charcoal); background: var(--yellow); color: var(--charcoal); font-family: "Bricolage Grotesque"; font-size: 2.2rem; box-shadow: .5rem .5rem 0 rgba(0,0,0,.25); }
.hinge-board span:nth-child(2) { background: var(--vermillion); transform: translateX(3rem); }
.hinge-board span:nth-child(3) { background: var(--blue); transform: translateX(1rem); font-family: "Fraunces"; }

.paint-tools { position: absolute; right: 11vw; bottom: 18vh; display: flex; gap: .8rem; }
.paint-tools i { width: 3rem; height: 15rem; background: linear-gradient(var(--charcoal) 0 24%, var(--canvas) 24% 38%, var(--scene-accent) 38%); transform: rotate(var(--t)); box-shadow: .45rem .45rem 0 rgba(0,0,0,.28); }
.paint-tools i:nth-child(1){--t:14deg}.paint-tools i:nth-child(2){--t:-8deg;background:linear-gradient(var(--charcoal) 0 20%, var(--canvas) 20% 42%, var(--vermillion) 42%)}.paint-tools i:nth-child(3){--t:4deg;background:linear-gradient(var(--charcoal) 0 25%, var(--canvas) 25% 40%, var(--green) 40%)}

.final-sign { position: absolute; inset: auto auto 18vh 50%; transform: translateX(-50%); display: flex; gap: .06em; font-family: "Bricolage Grotesque"; font-weight: 800; font-size: clamp(5rem, 15vw, 14rem); color: var(--canvas); text-shadow: .03em .03em 0 var(--violet), .06em .06em 0 var(--vermillion), 0 0 2rem rgba(169,215,255,.55); }
.final-sign span { display: inline-block; transform: translateY(var(--drop, 2rem)) rotate(var(--rot, 0deg)); transition: transform .8s cubic-bezier(.2,.8,.2,1); }
.scene.active .final-sign span { --drop: 0rem; }
.final-sign span:nth-child(odd) { --rot: -3deg; color: var(--yellow); } .final-sign span:nth-child(even) { --rot: 3deg; color: var(--green); }
.curator-card { position: absolute; right: 8vw; top: 14vh; width: min(26rem, 78vw); }

.mechanical-caption { position: fixed; top: 1.2rem; right: 1.2rem; z-index: 25; color: var(--charcoal); background: var(--blue); padding: .7rem 1rem; transform: rotate(2deg); box-shadow: .35rem .35rem 0 rgba(0,0,0,.35); }
.mechanical-caption span { display: block; font-family: "Rubik Mono One"; font-size: .55rem; }
.mechanical-caption b { font-family: "Fraunces"; font-size: 1.4rem; }

@media (max-width: 760px) {
  .cue-rail { flex-wrap: wrap; max-width: 92vw; }
  .cue { font-size: .45rem; padding: .45rem; }
  .scenic-flat { width: 88vw; min-height: 54vh; }
  h2 { font-size: clamp(3.2rem, 18vw, 7rem); }
  .sample-wheel, .mask-rack, .hinge-board, .paint-tools { transform: scale(.68); transform-origin: center; }
  .mechanical-caption { display: none; }
}
