:root {
  /* compliance vocabulary: Interprets the sea through fashion materials—wet satin; Bodoni Moda, Space Grotesk, DM Sans, Inter */
  --deep: #05060A;
  --chrome: #C9D3DD;
  --pearl: #F2F5F7;
  --cyan: #72F1E8;
  --uv: #8B5CFF;
  --coral: #FF6F91;
  --teal: #063E46;
  --shadow: #1A1E2A;
  --soft-chrome: #8B97A3;
  --mx: 50%;
  --my: 44%;
  --scene-progress: 0;
  --display: "Bodoni Moda", "Bodoni 72", Didot, "Didot LT STD", "Times New Roman", serif;
  --space: "Space Grotesk", "Space", "Avenir Next", "Helvetica Neue", Arial, sans-serif;
  --body: "DM Sans", Inter, "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-token: "Grotesk**";
}

body[data-scene="1"] { background: radial-gradient(circle at var(--mx) var(--my), rgba(114, 241, 232, .22), transparent 24rem), radial-gradient(circle at 72% 20%, rgba(255, 111, 145, .18), transparent 24rem), linear-gradient(180deg, #05060A 0%, #063E46 55%, #05060A 100%); }
body[data-scene="2"] { background: radial-gradient(circle at var(--mx) var(--my), rgba(255, 111, 145, .18), transparent 25rem), radial-gradient(circle at 26% 20%, rgba(242, 245, 247, .16), transparent 22rem), linear-gradient(180deg, #05060A 0%, #1A1E2A 55%, #05060A 100%); }
body[data-scene="3"] { background: radial-gradient(circle at var(--mx) var(--my), rgba(114, 241, 232, .18), transparent 25rem), linear-gradient(180deg, #05060A 0%, #020307 45%, #063E46 100%); }
body[data-scene="4"] { background: radial-gradient(circle at var(--mx) var(--my), rgba(139, 92, 255, .28), transparent 24rem), linear-gradient(180deg, #05060A 0%, #1A1E2A 55%, #05060A 100%); }
body[data-scene="5"] { background: radial-gradient(circle at var(--mx) var(--my), rgba(114, 241, 232, .2), transparent 30rem), linear-gradient(180deg, #05060A 0%, #063E46 60%, #020307 100%); }

* { box-sizing: border-box; }

html {
  background: var(--deep);
  color: var(--pearl);
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: var(--body);
  overflow-x: hidden;
  background:
    radial-gradient(circle at var(--mx) var(--my), rgba(114, 241, 232, .16), transparent 24rem),
    radial-gradient(circle at 18% 12%, rgba(139, 92, 255, .22), transparent 28rem),
    linear-gradient(180deg, #05060A 0%, #090B12 48%, #020307 100%);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(90deg, transparent 0 11%, rgba(201, 211, 221, .035) 11.4%, transparent 12%),
    repeating-linear-gradient(0deg, rgba(242, 245, 247, .025) 0 1px, transparent 1px 6px);
  mix-blend-mode: screen;
  z-index: 5;
}

.lookbook { position: relative; }

.chrome-orbit {
  position: fixed;
  width: 42vmax;
  height: 42vmax;
  border: 1px solid rgba(201, 211, 221, .16);
  border-radius: 50%;
  left: calc(var(--mx) - 21vmax);
  top: calc(var(--my) - 21vmax);
  pointer-events: none;
  filter: blur(.2px);
  opacity: .5;
  z-index: 1;
  transition: left .25s ease, top .25s ease;
}

.style-scene {
  position: relative;
  min-height: 118vh;
  padding: 8vh 7vw;
  display: grid;
  grid-template-columns: 1fr;
  align-items: center;
  isolation: isolate;
}

.style-scene::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 42vh;
  background: linear-gradient(180deg, transparent, rgba(6, 62, 70, .28), #05060A);
  pointer-events: none;
  z-index: -1;
}

.sticky-stage {
  position: sticky;
  top: 0;
  min-height: 100vh;
  display: grid;
  place-items: center;
  overflow: hidden;
}

.backlight-grid {
  position: absolute;
  width: 78vw;
  height: 72vh;
  border-radius: 2rem;
  background:
    linear-gradient(90deg, transparent 49%, rgba(114, 241, 232, .14) 50%, transparent 51%),
    linear-gradient(180deg, transparent 49%, rgba(255, 111, 145, .11) 50%, transparent 51%);
  transform: perspective(900px) rotateX(58deg) translateY(16vh);
  opacity: .55;
}

.oval-mirror {
  width: min(52vw, 520px);
  height: min(78vh, 760px);
  min-width: 310px;
  border-radius: 50% / 46%;
  padding: clamp(10px, 1.5vw, 18px);
  background:
    linear-gradient(126deg, #F2F5F7 0%, #8B97A3 22%, #05060A 38%, #C9D3DD 58%, #F2F5F7 70%, #8B97A3 100%);
  box-shadow: 0 0 44px rgba(114, 241, 232, .28), inset 0 0 20px rgba(255,255,255,.45), 0 34px 90px rgba(0,0,0,.74);
  transform: rotateY(calc((var(--mx) - 50%) * .08)) rotateX(calc((var(--my) - 50%) * -.04));
  transition: transform .18s ease-out;
}

.oval-mirror.is-awake { animation: mirrorWake 1.2s ease both; }

.mirror-glass {
  position: relative;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  display: grid;
  place-items: center;
  overflow: hidden;
  background:
    radial-gradient(ellipse at 50% 24%, rgba(242, 245, 247, .2), transparent 28%),
    radial-gradient(ellipse at 72% 62%, rgba(139, 92, 255, .28), transparent 34%),
    linear-gradient(140deg, rgba(6, 62, 70, .8), rgba(5, 6, 10, .96) 42%, rgba(26, 30, 42, .88));
}

.mirror-glass::before {
  content: "";
  position: absolute;
  inset: -40%;
  background: linear-gradient(105deg, transparent 42%, rgba(242, 245, 247, .5) 48%, rgba(114, 241, 232, .26) 51%, transparent 58%);
  transform: translateX(-40%) rotate(8deg);
  animation: mirrorSweep 5.8s ease-in-out infinite;
  mix-blend-mode: screen;
}

.bevel-light {
  position: absolute;
  inset: 3%;
  border-radius: inherit;
  border: 1px solid rgba(242, 245, 247, .32);
  box-shadow: inset 0 0 44px rgba(114, 241, 232, .18), 0 0 14px rgba(114, 241, 232, .2);
  animation: bevelWake 4s linear infinite;
}

.korean-mark {
  position: absolute;
  top: 18%;
  font-family: var(--space);
  letter-spacing: .6em;
  color: rgba(201, 211, 221, .26);
  transform: translateX(.3em);
}

.wordmark,
.final-wordmark,
.final-reflection,
.oversize-fragment,
.scene-copy h2 {
  font-family: var(--display);
  font-weight: 700;
  letter-spacing: -.055em;
}

.wordmark {
  position: relative;
  margin: 0;
  font-size: clamp(4.7rem, 10vw, 10.5rem);
  line-height: .78;
  text-align: center;
  background: linear-gradient(100deg, #F2F5F7 0%, #C9D3DD 18%, #8B97A3 35%, #05060A 48%, #72F1E8 57%, #F2F5F7 74%, #8B97A3 100%);
  background-size: 240% 100%;
  color: transparent;
  -webkit-background-clip: text;
  background-clip: text;
  filter: drop-shadow(0 0 16px rgba(114,241,232,.32));
  animation: wordChrome 4.8s ease-in-out infinite;
}

.wordmark::after {
  content: attr(data-text);
  position: absolute;
  inset: .08em 0 auto;
  color: rgba(255, 111, 145, .24);
  transform: translate(3px, 2px) scaleY(.96);
  z-index: -1;
}

.garment-tag,
.scene-index,
.measurement-tag,
.bag-label,
.holo-label,
.foil-sticker,
.leave-tag,
.fabric-card {
  font-family: var(--space);
  text-transform: uppercase;
  letter-spacing: .14em;
}

.garment-tag {
  position: absolute;
  right: 8%;
  bottom: 24%;
  width: 172px;
  padding: 1rem .85rem;
  border: 1px solid rgba(201, 211, 221, .55);
  color: var(--chrome);
  font-size: .66rem;
  background: rgba(5, 6, 10, .58);
  transform-origin: 50% -20px;
  animation: tagSwing 3.4s ease-in-out infinite;
}

.shell-orbit {
  position: absolute;
  width: 30px;
  height: 44px;
  border-radius: 50% 50% 45% 45%;
  background: radial-gradient(circle at 32% 22%, #F2F5F7, #C9D3DD 38%, #8B97A3 62%, #063E46);
  box-shadow: inset -5px -7px 14px rgba(5,6,10,.5), 0 0 22px rgba(114,241,232,.28);
}

.shell-a { left: 18%; top: 34%; animation: shellFloat 7s ease-in-out infinite; }
.shell-b { right: 17%; top: 58%; animation: shellFloat 8s ease-in-out infinite reverse; }

.water-floor {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 34vh;
  overflow: hidden;
  background:
    radial-gradient(ellipse at 50% 10%, rgba(201, 211, 221, .2), transparent 32%),
    repeating-radial-gradient(ellipse at 50% 0%, rgba(114, 241, 232, .13) 0 1px, transparent 2px 18px),
    linear-gradient(180deg, rgba(5,6,10,0), #020307 42%, #05060A);
}

.tide-line {
  position: absolute;
  left: -20%;
  right: -20%;
  top: 22%;
  height: 2px;
  background: linear-gradient(90deg, transparent, #72F1E8, #8B5CFF, #72F1E8, transparent);
  filter: drop-shadow(0 0 14px #72F1E8);
  animation: tideMove 5s ease-in-out infinite;
}

.reflection {
  position: absolute;
  left: 50%;
  top: 17%;
  transform: translateX(-50%) scaleY(-1);
  opacity: .16;
  filter: blur(2px);
}

.scene-copy {
  position: absolute;
  z-index: 4;
  max-width: 330px;
  padding: 1.2rem;
  border: 1px solid rgba(201, 211, 221, .34);
  background: linear-gradient(145deg, rgba(242,245,247,.09), rgba(5,6,10,.48));
  backdrop-filter: blur(14px);
  box-shadow: 0 14px 60px rgba(0,0,0,.36), inset 0 0 25px rgba(255,255,255,.035);
  transform: translateY(var(--copy-y, 0px));
}

.first-copy { left: 7vw; bottom: 10vh; }
.right-copy { right: 7vw; top: 18vh; }
.left-copy { left: 7vw; top: 18vh; }

.scene-index {
  display: inline-block;
  margin-bottom: .7rem;
  color: var(--cyan);
  font-size: .68rem;
}

.scene-copy h2 {
  margin: 0;
  font-size: clamp(2.6rem, 5vw, 5rem);
  line-height: .86;
  color: var(--pearl);
}

.scene-copy p {
  margin: 1rem 0 0;
  color: rgba(242,245,247,.78);
  line-height: 1.55;
}

.charm-nav {
  position: fixed;
  right: 1.6rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 20;
  display: grid;
  gap: .85rem;
}

.charm {
  width: 24px;
  height: 24px;
  border: 1px solid rgba(242,245,247,.5);
  border-radius: 50%;
  background: radial-gradient(circle at 28% 22%, #F2F5F7, #8B97A3 40%, #05060A 72%);
  box-shadow: 0 0 0 3px rgba(114,241,232,0), 0 0 15px rgba(201,211,221,.22);
  cursor: pointer;
  transform: rotate(45deg);
  transition: transform .3s ease, box-shadow .3s ease;
}

.charm:nth-child(2n) { border-radius: 45% 50% 45% 8%; }
.charm.is-active { box-shadow: 0 0 0 3px rgba(114,241,232,.22), 0 0 24px rgba(114,241,232,.62); transform: rotate(135deg) scale(1.22); }
.charm span { display: none; }

.split-stage,
.counter-stage,
.runway-stage,
.lightwall-stage,
.pool-stage { perspective: 1200px; }

.vinyl-bag {
  position: relative;
  width: min(46vw, 430px);
  height: min(78vh, 670px);
  min-width: 290px;
  border-radius: 44% 44% 10% 10% / 12% 12% 8% 8%;
  border: 1px solid rgba(242,245,247,.44);
  background: linear-gradient(115deg, rgba(242,245,247,.14), rgba(114,241,232,.06), rgba(139,92,255,.18));
  box-shadow: inset 0 0 55px rgba(242,245,247,.12), 0 30px 80px rgba(0,0,0,.5);
  overflow: hidden;
  transform: rotateY(-12deg) rotateZ(-3deg);
}

.vinyl-bag::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(102deg, transparent 34%, rgba(242,245,247,.34) 44%, transparent 50% 100%);
  animation: vinylGlint 6s ease-in-out infinite;
}

.zipper-svg {
  position: absolute;
  inset: 5% 8%;
  width: 84%;
  height: 90%;
  fill: none;
}

.zipper-path {
  stroke: #C9D3DD;
  stroke-width: 4;
  stroke-linecap: round;
  stroke-dasharray: 14 12;
  animation: zipTravel 4s linear infinite;
  filter: drop-shadow(0 0 8px rgba(114,241,232,.65));
}

.zipper-pull {
  position: absolute;
  left: 47%;
  top: calc(10% + (var(--local-progress, .15) * 62%));
  width: 30px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 48% 48% 50% 8%;
  color: #05060A;
  font-family: var(--display);
  font-size: 1.35rem;
  background: linear-gradient(135deg, #F2F5F7, #8B97A3 42%, #72F1E8 74%, #05060A);
  box-shadow: 0 0 22px rgba(114,241,232,.46);
  transform: rotate(24deg);
}

.bag-glow {
  position: absolute;
  inset: 26% 22% 18%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(114,241,232,.7), rgba(139,92,255,.18) 42%, transparent 70%);
  filter: blur(22px);
  animation: glowPulse 3.8s ease-in-out infinite;
}

.bag-label {
  position: absolute;
  bottom: 2rem;
  left: 2rem;
  color: var(--pearl);
  font-size: .65rem;
}

.ribbon {
  position: absolute;
  width: 46vw;
  height: 76px;
  border-radius: 50%;
  background: linear-gradient(90deg, transparent, rgba(255,111,145,.82), rgba(114,241,232,.6), transparent);
  filter: blur(.5px);
  transform: rotate(-18deg);
  animation: ribbonWave 5.4s ease-in-out infinite;
}
.ribbon-one { top: 32vh; left: 9vw; }
.ribbon-two { top: 54vh; right: 3vw; animation-delay: -2s; opacity: .58; }

.acrylic-panel {
  position: absolute;
  right: 18vw;
  bottom: 18vh;
  width: 240px;
  padding: 1rem;
  color: var(--pearl);
  border: 1px solid rgba(242,245,247,.32);
  background: rgba(201,211,221,.08);
  backdrop-filter: blur(12px);
}
.fabric-card span { display: block; color: var(--coral); font-size: .65rem; margin-bottom: .7rem; }
.fabric-card strong { font-size: .78rem; font-weight: 500; }

.compact-large {
  width: min(56vw, 560px);
  aspect-ratio: 1;
  border-radius: 50%;
  position: relative;
  background: radial-gradient(circle at 30% 18%, #F2F5F7, #C9D3DD 21%, #8B97A3 37%, #05060A 70%);
  box-shadow: inset -22px -34px 54px rgba(0,0,0,.54), 0 28px 90px rgba(0,0,0,.65), 0 0 50px rgba(255,111,145,.16);
  transform: rotateX(62deg) rotateZ(-16deg);
}
.compact-lid {
  position: absolute;
  inset: 18%;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: var(--display);
  font-size: clamp(4rem, 10vw, 8rem);
  color: rgba(5,6,10,.5);
  border: 1px solid rgba(242,245,247,.4);
}
.compact-shine {
  position: absolute;
  inset: -20%;
  background: conic-gradient(from 20deg, transparent, rgba(114,241,232,.28), transparent, rgba(255,111,145,.22), transparent);
  border-radius: 50%;
  animation: rotateSlow 12s linear infinite;
}

.acrylic-tray {
  position: absolute;
  left: 11vw;
  bottom: 12vh;
  width: min(36vw, 360px);
  height: 110px;
  border: 1px solid rgba(242,245,247,.28);
  border-radius: 28px;
  background: linear-gradient(120deg, rgba(242,245,247,.1), rgba(114,241,232,.08), rgba(255,111,145,.08));
  box-shadow: inset 0 0 34px rgba(242,245,247,.08), 0 24px 60px rgba(0,0,0,.38);
  transform: rotateX(58deg) rotateZ(10deg);
}
.acrylic-tray span {
  position: absolute;
  top: 28px;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 25%, #F2F5F7, #C9D3DD 34%, #8B5CFF 72%);
}
.acrylic-tray span:nth-child(1) { left: 24%; }
.acrylic-tray span:nth-child(2) { left: 46%; background: radial-gradient(circle at 30% 25%, #F2F5F7, #FF6F91 42%, #1A1E2A); }
.acrylic-tray span:nth-child(3) { left: 68%; }

.pearl-counter { position: absolute; width: min(70vw, 720px); height: 42vh; }
.pearl {
  position: absolute;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 24%, #fff, #F2F5F7 28%, #C9D3DD 55%, #8B5CFF 100%);
  box-shadow: 0 0 22px rgba(242,245,247,.35);
  animation: pearlOrbit 6s ease-in-out infinite;
}
.p1 { left: 8%; top: 12%; } .p2 { right: 18%; top: 7%; animation-delay: -.8s; }
.p3 { left: 28%; bottom: 0; animation-delay: -1.5s; } .p4 { right: 6%; bottom: 18%; animation-delay: -2.4s; }
.p5 { left: 48%; top: -6%; animation-delay: -3s; } .p6 { left: 3%; bottom: 27%; animation-delay: -4s; }

.earring {
  position: absolute;
  width: 88px;
  height: 150px;
  border: 2px solid rgba(242,245,247,.66);
  border-radius: 50% 50% 44% 44%;
  filter: drop-shadow(0 0 18px rgba(114,241,232,.3));
}
.earring::after {
  content: "";
  position: absolute;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  left: 50%;
  bottom: -9px;
  transform: translateX(-50%);
  background: var(--coral);
  box-shadow: 0 0 20px rgba(255,111,145,.7);
}
.left-earring { left: 19vw; top: 24vh; animation: earringSwing 4s ease-in-out infinite; }
.right-earring { right: 18vw; top: 35vh; animation: earringSwing 4.8s ease-in-out infinite reverse; }
.foil-sticker { position: absolute; right: 10vw; bottom: 18vh; color: var(--coral); font-size: .68rem; }

.runway-perspective {
  position: absolute;
  inset: 5vh 10vw 0;
  transform: perspective(900px) rotateX(62deg);
  transform-origin: 50% 100%;
  background: linear-gradient(90deg, transparent, rgba(201,211,221,.08), transparent);
  overflow: hidden;
}
.liquid-stripe {
  position: absolute;
  left: 50%;
  top: -15%;
  width: 8vw;
  min-width: 74px;
  height: 132%;
  transform: translateX(-50%);
  background: linear-gradient(180deg, #F2F5F7, #72F1E8, #8B5CFF, #063E46, #05060A);
  filter: blur(.3px) drop-shadow(0 0 26px rgba(114,241,232,.5));
  clip-path: polygon(42% 0, 62% 0, 72% 28%, 55% 48%, 78% 72%, 48% 100%, 23% 100%, 45% 68%, 28% 42%, 43% 18%);
  animation: stripeLiquefy 5s ease-in-out infinite;
}
.water-beads span {
  position: absolute;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background: radial-gradient(circle at 28% 25%, #F2F5F7, rgba(114,241,232,.78) 38%, rgba(6,62,70,.1));
  box-shadow: 0 0 16px rgba(114,241,232,.48);
  animation: beadSlide 5s ease-in-out infinite;
}
.water-beads span:nth-child(1) { left: 44%; top: 12%; }
.water-beads span:nth-child(2) { left: 56%; top: 34%; animation-delay: -1.2s; }
.water-beads span:nth-child(3) { left: 48%; top: 58%; animation-delay: -2.4s; }
.water-beads span:nth-child(4) { left: 53%; top: 76%; animation-delay: -3.1s; }
.spotlight {
  position: absolute;
  top: 12%;
  width: 22vw;
  height: 80vh;
  background: linear-gradient(180deg, rgba(242,245,247,.25), transparent 74%);
  clip-path: polygon(45% 0, 55% 0, 100% 100%, 0 100%);
  mix-blend-mode: screen;
  animation: spotlightPan 7s ease-in-out infinite;
}
.s1 { left: 6%; } .s2 { left: 39%; animation-delay: -2s; } .s3 { right: 6%; animation-delay: -4s; }
.oversize-fragment {
  position: absolute;
  left: 7vw;
  bottom: 12vh;
  font-size: clamp(5rem, 17vw, 16rem);
  line-height: .72;
  color: transparent;
  -webkit-text-stroke: 1px rgba(201,211,221,.38);
  opacity: .78;
}
.measurement-tag {
  position: absolute;
  right: 14vw;
  bottom: 25vh;
  color: var(--cyan);
  font-size: .7rem;
  padding: 1rem;
  border-left: 1px solid var(--cyan);
}

.light-wall {
  position: absolute;
  inset: 6vh 12vw;
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 1vw;
}
.light-wall i {
  display: block;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(242,245,247,.7), rgba(139,92,255,.24), transparent);
  filter: blur(.2px) drop-shadow(0 0 24px rgba(139,92,255,.32));
  animation: wallPulse 2.6s ease-in-out infinite;
}
.light-wall i:nth-child(2n) { animation-delay: -1s; }
.sunglasses {
  display: flex;
  align-items: center;
  gap: 10px;
  transform: rotate(-8deg) translateY(-6vh);
  animation: glassesFloat 5s ease-in-out infinite;
}
.lens {
  width: min(18vw, 170px);
  height: min(12vw, 112px);
  border: 3px solid var(--chrome);
  background: linear-gradient(135deg, rgba(5,6,10,.8), rgba(114,241,232,.25));
  box-shadow: inset 0 0 20px rgba(242,245,247,.12), 0 0 25px rgba(114,241,232,.22);
}
.lens-left { border-radius: 62% 38% 50% 50%; }
.lens-right { border-radius: 38% 62% 50% 50%; }
.bridge { width: 42px; height: 16px; border-top: 3px solid var(--chrome); border-radius: 50%; }
.chrome-comb {
  position: absolute;
  right: 18vw;
  bottom: 18vh;
  width: 250px;
  height: 60px;
  background: repeating-linear-gradient(90deg, #C9D3DD 0 7px, transparent 7px 15px), linear-gradient(180deg, #F2F5F7, #8B97A3, #05060A);
  border-radius: 18px;
  transform: rotate(18deg);
}
.makeup-tray {
  position: absolute;
  left: 18vw;
  bottom: 22vh;
  width: min(34vw, 330px);
  height: 90px;
  border-radius: 24px;
  background: linear-gradient(130deg, rgba(242,245,247,.14), rgba(139,92,255,.18), rgba(114,241,232,.09));
  border: 1px solid rgba(242,245,247,.24);
  transform: rotate(-13deg) skewX(-8deg);
  box-shadow: inset 0 0 28px rgba(242,245,247,.08), 0 20px 60px rgba(0,0,0,.42);
}
.holo-label {
  position: absolute;
  left: 12vw;
  bottom: 14vh;
  padding: .9rem 1rem;
  color: var(--pearl);
  background: linear-gradient(90deg, rgba(114,241,232,.16), rgba(255,111,145,.14));
  border: 1px solid rgba(242,245,247,.28);
}

.reflection-pool {
  position: relative;
  width: min(82vw, 920px);
  height: min(70vh, 650px);
  border-radius: 50%;
  display: grid;
  place-items: center;
  overflow: hidden;
  background:
    radial-gradient(ellipse at 50% 35%, rgba(242,245,247,.15), transparent 25%),
    repeating-radial-gradient(ellipse at 50% 50%, rgba(114,241,232,.22) 0 1px, transparent 2px 28px),
    linear-gradient(140deg, #05060A, #063E46 55%, #05060A);
  box-shadow: inset 0 0 80px rgba(5,6,10,.86), 0 0 70px rgba(114,241,232,.2);
}
.pool-ripple {
  position: absolute;
  border: 1px solid rgba(201,211,221,.22);
  border-radius: 50%;
  animation: ripple 4.5s ease-in-out infinite;
}
.r1 { inset: 16%; } .r2 { inset: 26%; animation-delay: -1.5s; } .r3 { inset: 38%; animation-delay: -3s; }
.final-wordmark,
.final-reflection {
  position: absolute;
  margin: 0;
  font-size: clamp(4rem, 13vw, 12rem);
  color: var(--pearl);
  line-height: .8;
}
.final-wordmark { transform: translateY(-18%); text-shadow: 0 0 22px rgba(114,241,232,.25); }
.final-reflection {
  transform: translateY(48%) scaleY(-1);
  opacity: .24;
  color: var(--chrome);
  filter: blur(1.5px);
  animation: reflectionRipple 3s ease-in-out infinite;
}
.leave-tag { position: absolute; bottom: 12vh; color: var(--coral); font-size: .75rem; }

@keyframes mirrorSweep { 0%, 30% { transform: translateX(-58%) rotate(8deg); } 72%, 100% { transform: translateX(58%) rotate(8deg); } }
@keyframes bevelWake { 0%, 100% { box-shadow: inset 0 0 34px rgba(114,241,232,.16), 0 0 10px rgba(114,241,232,.1); } 50% { box-shadow: inset 0 0 66px rgba(114,241,232,.34), 0 0 30px rgba(114,241,232,.38); } }
@keyframes wordChrome { 0%,100% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } }
@keyframes tagSwing { 0%,100% { transform: rotate(-4deg); } 50% { transform: rotate(5deg); } }
@keyframes shellFloat { 0%,100% { transform: translateY(0) rotate(0deg); } 50% { transform: translateY(-28px) rotate(18deg); } }
@keyframes tideMove { 0%,100% { transform: translateX(-8%) scaleX(.8); } 50% { transform: translateX(8%) scaleX(1.08); } }
@keyframes vinylGlint { 0%,100% { transform: translateX(-45%); } 50% { transform: translateX(55%); } }
@keyframes zipTravel { to { stroke-dashoffset: -104; } }
@keyframes glowPulse { 0%,100% { opacity: .48; transform: scale(.9); } 50% { opacity: .96; transform: scale(1.08); } }
@keyframes ribbonWave { 0%,100% { transform: rotate(-18deg) translateX(-2vw) scaleY(.8); } 50% { transform: rotate(-10deg) translateX(3vw) scaleY(1.15); } }
@keyframes rotateSlow { to { transform: rotate(360deg); } }
@keyframes pearlOrbit { 0%,100% { transform: translate(0, 0); } 50% { transform: translate(18px, -24px); } }
@keyframes earringSwing { 0%,100% { transform: rotate(-9deg); } 50% { transform: rotate(10deg); } }
@keyframes stripeLiquefy { 0%,100% { clip-path: polygon(42% 0, 62% 0, 72% 28%, 55% 48%, 78% 72%, 48% 100%, 23% 100%, 45% 68%, 28% 42%, 43% 18%); } 50% { clip-path: polygon(30% 0, 70% 0, 56% 24%, 77% 48%, 48% 70%, 66% 100%, 32% 100%, 22% 72%, 46% 44%, 28% 20%); } }
@keyframes spotlightPan { 0%,100% { transform: translateX(-5%) skewX(-8deg); opacity: .38; } 50% { transform: translateX(8%) skewX(8deg); opacity: .68; } }
@keyframes wallPulse { 0%,100% { opacity: .35; transform: scaleY(.85); } 50% { opacity: .82; transform: scaleY(1); } }
@keyframes glassesFloat { 0%,100% { transform: rotate(-8deg) translateY(-6vh); } 50% { transform: rotate(5deg) translateY(-9vh); } }
@keyframes ripple { 0%,100% { transform: scale(.9); opacity: .2; } 50% { transform: scale(1.08); opacity: .62; } }
@keyframes reflectionRipple { 0%,100% { letter-spacing: -.055em; filter: blur(1.5px); } 50% { letter-spacing: -.02em; filter: blur(2.5px); } }
@keyframes mirrorWake { 0% { filter: brightness(1); } 38% { filter: brightness(1.42) saturate(1.25); box-shadow: 0 0 72px rgba(114,241,232,.48), inset 0 0 26px rgba(255,255,255,.6), 0 34px 100px rgba(0,0,0,.74); } 100% { filter: brightness(1); } }
@keyframes beadSlide { 0%,100% { transform: translateY(-12px) scale(.82); opacity: .46; } 50% { transform: translateY(38px) scale(1.08); opacity: .95; } }

@media (max-width: 760px) {
  .style-scene { padding: 6vh 5vw; min-height: 120vh; }
  .oval-mirror { width: 86vw; min-width: 0; }
  .scene-copy { left: 5vw; right: 5vw; top: auto; bottom: 8vh; max-width: none; }
  .charm-nav { right: .8rem; }
  .vinyl-bag { width: 78vw; min-width: 0; }
  .acrylic-panel, .measurement-tag, .foil-sticker, .chrome-comb { right: 8vw; }
  .left-earring { left: 7vw; }
  .right-earring { right: 8vw; }
  .light-wall { inset: 8vh 5vw; grid-template-columns: repeat(4, 1fr); }
  .acrylic-tray, .makeup-tray { left: 7vw; width: 64vw; }
}
