:root {
  --cream: #FFF2D8;
  --velvet: #8E1F3F;
  --ink: #23140F;
  --gold: #B88A3D;
  --pistachio: #B8CFA3;
  --cherry: #E84D6A;
  --glass: #A9DCE8;
  --caramel: #8A5A2B;
  --bodoni: "Bodoni 72", "Bodoni 72 Smallcaps", Didot, "Bodoni MT", Georgia, serif;
  --cormorant: "Cormorant Garamond", Cormorant, Garamond, Georgia, serif;
  --script: "Snell Roundhand", "Apple Chancery", "Brush Script MT", cursive;
  --sans: "Nunito Sans", Avenir, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  color: var(--ink);
  background: var(--cream);
  font-family: var(--cormorant);
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background:
    radial-gradient(circle at 20% 15%, rgba(232,77,106,.13), transparent 28%),
    radial-gradient(circle at 80% 30%, rgba(169,220,232,.16), transparent 24%),
    repeating-linear-gradient(90deg, rgba(35,20,15,.035) 0 1px, transparent 1px 7px),
    repeating-radial-gradient(circle at 50% 50%, rgba(184,138,61,.05) 0 1px, transparent 1px 12px);
  mix-blend-mode: multiply;
}

.scene {
  min-height: 100vh;
  position: relative;
  display: grid;
  place-items: center;
  padding: 7rem clamp(1rem, 4vw, 5rem);
  isolation: isolate;
  overflow: hidden;
}

.scene::after {
  content: "";
  position: absolute;
  inset: 1.3rem;
  border: 1px solid rgba(184,138,61,.45);
  border-radius: 45% 45% 2rem 2rem / 2rem 2rem 3rem 3rem;
  pointer-events: none;
}

h1, h2, .chapter-number {
  font-family: var(--bodoni);
  font-weight: 600;
  letter-spacing: -.04em;
}

h1 {
  margin: 0;
  font-size: clamp(4rem, 13vw, 12rem);
  color: transparent;
  background: linear-gradient(100deg, var(--cream), #ffffff, var(--gold), var(--cream));
  -webkit-background-clip: text;
  background-clip: text;
  filter: drop-shadow(0 0 20px rgba(255,242,216,.5));
}

h2 {
  margin: .45rem 0 1rem;
  font-size: clamp(2.4rem, 5vw, 6.4rem);
  line-height: .88;
}

p { font-size: clamp(1.1rem, 1.8vw, 1.55rem); line-height: 1.45; }

.tiny-script, .ribbon, .napkin { font-family: var(--script); }

.salon-nav {
  position: fixed;
  right: 1.1rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  display: grid;
  gap: .5rem;
  padding: .7rem .55rem;
  background: rgba(255,242,216,.7);
  border: 1px solid var(--gold);
  border-radius: 999px;
  box-shadow: 0 20px 50px rgba(35,20,15,.2);
  backdrop-filter: blur(6px);
}

.salon-nav a {
  writing-mode: vertical-rl;
  text-decoration: none;
  color: var(--velvet);
  font-family: var(--sans);
  font-size: .64rem;
  text-transform: uppercase;
  letter-spacing: .2em;
  opacity: .7;
}

.salon-nav a.active { color: var(--ink); opacity: 1; }

.bell {
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid var(--caramel);
  border-radius: 50%;
  background: radial-gradient(circle at 50% 30%, #fff6c9, var(--gold) 58%, var(--caramel));
  cursor: pointer;
}

.bell span {
  display: block;
  width: 1.15rem;
  height: .45rem;
  margin: 1.05rem auto 0;
  background: var(--ink);
  border-radius: 50%;
}

.bell.rung { animation: ring .45s ease; }

@keyframes ring { 20% { transform: rotate(-15deg); } 55% { transform: rotate(13deg); } }

.sugar-dust {
  position: fixed;
  inset: 0;
  z-index: 9;
  pointer-events: none;
}

.grain {
  position: absolute;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--cream);
  box-shadow: 0 0 10px var(--gold);
  animation: floatGrain 5s linear forwards;
}

@keyframes floatGrain { to { transform: translateY(-130px) scale(.25); opacity: 0; } }

.frosted-window {
  background: radial-gradient(circle at 50% 45%, rgba(184,138,61,.35), transparent 35%), linear-gradient(160deg, #120908, var(--ink) 46%, #090505);
  color: var(--cream);
}

.frost-pane {
  width: min(1050px, 88vw);
  min-height: 68vh;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 5rem 2rem;
  position: relative;
  border: 3px double rgba(255,242,216,.45);
  border-radius: 48% 48% 2rem 2rem / 2.5rem 2.5rem 2rem 2rem;
  background: rgba(169,220,232,.13);
  box-shadow: inset 0 0 90px rgba(169,220,232,.24), 0 0 80px rgba(184,138,61,.15);
  overflow: hidden;
}

.condensation {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(110deg, transparent 16%, rgba(255,255,255,.19) 17% 18%, transparent 19% 38%, rgba(255,255,255,.15) 39% 40%, transparent 41%),
    radial-gradient(circle at 30% 20%, rgba(255,255,255,.3), transparent 18%),
    repeating-radial-gradient(circle, rgba(255,255,255,.13) 0 1px, transparent 1px 9px);
  filter: blur(1px);
  animation: fingerTrace 6s ease-in-out infinite alternate;
}

@keyframes fingerTrace { from { clip-path: inset(0 100% 0 0); } to { clip-path: inset(0 0 0 0); } }

.window-copy { max-width: 44rem; color: rgba(255,242,216,.86); }

.hanging-sign {
  position: absolute;
  left: 5%;
  top: 2rem;
  writing-mode: vertical-rl;
  padding: 1rem .5rem;
  color: var(--gold);
  border: 1px solid var(--gold);
  font-family: var(--bodoni);
  letter-spacing: .08em;
  background: rgba(35,20,15,.75);
}

.curtain {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 28vw;
  z-index: 2;
  background: repeating-linear-gradient(90deg, var(--velvet) 0 24px, #65132d 25px 48px, #a3264c 49px 56px);
  box-shadow: inset 0 0 50px rgba(35,20,15,.6);
  transition: transform 1.2s cubic-bezier(.65,0,.15,1);
}

.curtain-left { left: 0; border-radius: 0 0 70% 0; }
.curtain-right { right: 0; border-radius: 0 0 0 70%; }
.frosted-window.entered .curtain-left { transform: translateX(-86%); }
.frosted-window.entered .curtain-right { transform: translateX(86%); }

.candle-row { position: absolute; bottom: 3rem; display: flex; gap: 4rem; }
.candle-row i, .greenhouse::before {
  width: .9rem; height: 2.8rem; border-radius: .3rem; background: var(--cream); display: block; position: relative;
}
.candle-row i::before, .greenhouse::before {
  content: ""; position: absolute; left: 50%; top: -.9rem; width: .75rem; height: 1.1rem; transform: translateX(-50%);
  background: radial-gradient(circle, #fff8c9, var(--cherry) 55%, transparent 70%); border-radius: 50% 50% 35% 35%; animation: flicker 1.5s infinite alternate;
}
@keyframes flicker { to { transform: translateX(-50%) scaleY(1.25) rotate(4deg); opacity: .72; } }

.porcelain-counter {
  background: linear-gradient(rgba(255,242,216,.75), rgba(255,242,216,.9)), radial-gradient(circle at 85% 15%, rgba(232,77,106,.18), transparent 28%), var(--cream);
  grid-template-columns: minmax(280px, 42%) 1fr;
  gap: 3rem;
}

.wallpaper, .wallpaper::before {
  position: absolute; inset: 0; z-index: -1;
  background: radial-gradient(ellipse at center, transparent 0 35%, rgba(142,31,63,.08) 36% 38%, transparent 39%) 0 0/90px 70px;
}

.chapter-number {
  position: absolute;
  left: 2.2rem;
  top: 1.5rem;
  color: rgba(184,138,61,.24);
  font-size: clamp(6rem, 15vw, 14rem);
}

.arched-card, .angled-menu, .oval-frame, .glasshouse-copy, .last-note {
  background: rgba(255,242,216,.86);
  border: 2px solid var(--gold);
  box-shadow: 0 24px 70px rgba(35,20,15,.17), inset 0 0 0 8px rgba(184,138,61,.09);
  padding: clamp(1.5rem, 4vw, 4rem);
  position: relative;
}

.arched-card { border-radius: 50% 50% 1.2rem 1.2rem / 4rem 4rem 1.2rem 1.2rem; transform: rotate(-2deg); }
.ribbon { color: var(--cherry); font-size: clamp(1.5rem, 2.4vw, 2.4rem); }

.display-case { display: flex; align-items: end; gap: clamp(1rem, 2vw, 2rem); }
.cake-stand { width: 30%; min-width: 135px; height: 390px; display: grid; align-content: end; justify-items: center; position: relative; }
.cake-stand.short { height: 310px; } .cake-stand.tall { height: 450px; }
.dome { position: absolute; bottom: 105px; width: 100%; height: 210px; border: 2px solid rgba(169,220,232,.85); border-radius: 50% 50% 8% 8%; background: linear-gradient(110deg, rgba(169,220,232,.28), transparent 55%); }
.cake-stand::after { content: ""; width: 82%; height: 1rem; border-radius: 50%; background: var(--gold); box-shadow: 0 35px 0 -8px var(--caramel); }
.cake-stand b { position: relative; z-index: 1; display: block; margin-bottom: 105px; }
.tart { width: 105px; height: 105px; border-radius: 50%; background: conic-gradient(var(--cherry), var(--glass), var(--pistachio), var(--gold), var(--cherry)); border: 12px solid var(--caramel); }
.eclair { width: 140px; height: 48px; border-radius: 50px; background: linear-gradient(90deg, var(--caramel), var(--gold), var(--caramel)); box-shadow: inset 0 8px rgba(255,242,216,.35); }
.jelly { width: 85px; height: 92px; border-radius: 18px 18px 42px 42px; background: linear-gradient(145deg, var(--glass), rgba(232,77,106,.45)); }
.cake-stand em { font-family: var(--sans); text-transform: uppercase; letter-spacing: .16em; font-size: .66rem; color: var(--velvet); }
.spoon-shadow { position: absolute; right: 12%; bottom: 12%; width: 220px; height: 32px; background: rgba(35,20,15,.2); border-radius: 50%; transform: rotate(-16deg); filter: blur(6px); }

.macaron-clockwork { background: radial-gradient(circle at 45% 45%, rgba(169,220,232,.36), transparent 32%), linear-gradient(120deg, var(--pistachio), var(--cream)); grid-template-columns: 1fr minmax(280px, 42%); }
.clock-frame { width: min(520px, 78vw); aspect-ratio: 1; border: 14px double var(--gold); border-radius: 50%; position: relative; background: radial-gradient(circle, var(--cream) 0 18%, rgba(255,242,216,.52) 19% 62%, transparent 63%); box-shadow: inset 0 0 45px rgba(35,20,15,.2), 0 30px 90px rgba(35,20,15,.16); }
.macaron-ring { position: absolute; inset: 6%; border-radius: 50%; background: repeating-conic-gradient(var(--cherry) 0 12deg, var(--cream) 12deg 24deg, var(--pistachio) 24deg 36deg, var(--gold) 36deg 48deg); mask: radial-gradient(transparent 0 52%, #000 53% 64%, transparent 65%); animation: rotate 28s linear infinite; }
.ring-two { inset: 19%; animation-direction: reverse; animation-duration: 21s; opacity: .8; }
@keyframes rotate { to { transform: rotate(360deg); } }
.clock-hands { position: absolute; inset: 0; display: grid; place-items: center; }
.clock-hands i, .clock-hands b { position: absolute; transform-origin: bottom; bottom: 50%; width: 6px; border-radius: 99px; background: var(--ink); }
.clock-hands i { height: 33%; animation: rotate 18s linear infinite; } .clock-hands b { height: 24%; transform: rotate(80deg); animation: rotate 48s linear infinite; }
.sugar-cubes { position: absolute; left: 50%; bottom: -2rem; display: flex; gap: .7rem; transform: translateX(-50%); }
.sugar-cubes span { width: 38px; height: 38px; background: #fff; border: 1px solid rgba(138,90,43,.4); transform: rotate(12deg); box-shadow: 0 8px 20px rgba(35,20,15,.15); }
.angled-menu { transform: rotate(3deg); clip-path: polygon(4% 0, 100% 6%, 96% 100%, 0 94%); }

.velvet-booth { background: radial-gradient(circle at 48% 58%, rgba(232,77,106,.24), transparent 28%), linear-gradient(100deg, #4c0e22, var(--velvet) 48%, #380918); color: var(--cream); }
.booth-curtains span { position: absolute; top: 0; bottom: 0; width: 18%; background: repeating-linear-gradient(90deg, #5f102a 0 18px, #9d2349 19px 36px); }
.booth-curtains span:first-child { left: 0; } .booth-curtains span:last-child { right: 0; }
.oval-frame { width: min(700px, 82vw); min-height: 430px; display: grid; place-items: center; text-align: center; border-radius: 50%; background: rgba(35,20,15,.35); color: var(--cream); border-color: var(--gold); }
.teacup { position: absolute; right: 17%; bottom: 13%; width: 150px; height: 95px; border-radius: 0 0 70px 70px; background: var(--cream); box-shadow: inset 0 -15px var(--pistachio); }
.teacup span { position: absolute; right: -42px; top: 20px; width: 58px; height: 45px; border: 10px solid var(--cream); border-left: 0; border-radius: 0 50px 50px 0; }
.teacup i { position: absolute; left: 42px; bottom: 80px; width: 18px; height: 80px; border-radius: 50%; border-left: 3px solid rgba(255,242,216,.75); animation: steam 3.2s ease-in-out infinite; }
.teacup i:nth-child(3) { left: 70px; animation-delay: .7s; } .teacup i:nth-child(4) { left: 96px; animation-delay: 1.2s; }
@keyframes steam { 50% { transform: translateY(-30px) translateX(15px); opacity: .35; } to { transform: translateY(-60px) translateX(-8px); opacity: 0; } }
.artifact-button { border: 1px solid var(--gold); background: var(--cream); color: var(--velvet); padding: .85rem 1.3rem; border-radius: 999px; font-family: var(--sans); text-transform: uppercase; letter-spacing: .16em; font-size: .7rem; cursor: pointer; box-shadow: 0 12px 30px rgba(35,20,15,.16); }
#menuButton { position: absolute; left: 13%; bottom: 18%; }
.folding-menu { position: absolute; left: 13%; bottom: 24%; width: 260px; padding: 1.3rem; color: var(--ink); background: var(--cream); border: 1px solid var(--gold); transform: rotateY(88deg); transform-origin: left; transition: transform .7s ease; box-shadow: 0 20px 50px rgba(35,20,15,.3); }
.folding-menu.open { transform: rotateY(0deg) rotate(-3deg); }

.conservatory { background: linear-gradient(180deg, var(--glass), var(--cream) 58%, var(--pistachio)); grid-template-columns: minmax(280px, 38%) 1fr; }
.glasshouse-copy { border-radius: 2rem 2rem 48% 48% / 2rem 2rem 3rem 3rem; }
.greenhouse { width: min(620px, 82vw); height: 620px; position: relative; border: 10px double var(--gold); border-radius: 50% 50% 1rem 1rem / 4rem 4rem 1rem 1rem; background: linear-gradient(90deg, rgba(255,255,255,.35), transparent), repeating-linear-gradient(90deg, transparent 0 90px, rgba(35,20,15,.12) 91px 94px), rgba(169,220,232,.42); }
.arch-window { position: absolute; inset: 2rem; border: 2px solid rgba(35,20,15,.2); border-radius: 50% 50% 1rem 1rem / 4rem 4rem 1rem 1rem; }
.rose { position: absolute; left: 20%; top: 35%; width: 120px; height: 120px; border-radius: 50%; background: repeating-conic-gradient(var(--cherry) 0 16deg, var(--cream) 17deg 26deg); box-shadow: 0 0 30px rgba(232,77,106,.35); }
.rose-two { left: auto; right: 18%; top: 48%; width: 90px; height: 90px; background: repeating-conic-gradient(var(--pistachio) 0 18deg, var(--glass) 19deg 32deg); }
.bell-jar { position: absolute; left: 50%; bottom: 5rem; width: 180px; height: 230px; transform: translateX(-50%); border: 3px solid rgba(255,242,216,.9); border-radius: 50% 50% 12px 12px; background: rgba(255,255,255,.16); }
.bell-jar b { position: absolute; left: 50%; bottom: 30px; width: 100px; height: 65px; transform: translateX(-50%); border-radius: 50% 50% 35% 35%; background: var(--cherry); }
.bell-jar i { position: absolute; left: 75px; top: 80px; width: 20px; height: 70px; border-left: 2px solid rgba(255,255,255,.75); border-radius: 50%; animation: steam 4s infinite; }
.bell-jar i:last-child { left: 110px; animation-delay: 1s; }
.fork-stars span { position: absolute; width: 46px; height: 3px; background: var(--cream); box-shadow: 0 0 14px white; transform: rotate(30deg); animation: twinkle 2.4s infinite alternate; }
.fork-stars span:nth-child(1) { left: 12%; top: 19%; } .fork-stars span:nth-child(2) { right: 16%; top: 22%; animation-delay: .6s; } .fork-stars span:nth-child(3) { left: 22%; bottom: 22%; animation-delay: 1s; } .fork-stars span:nth-child(4) { right: 23%; bottom: 30%; animation-delay: 1.4s; }
@keyframes twinkle { to { opacity: .25; transform: rotate(390deg) scale(.7); } }

.final-table { background: radial-gradient(circle at 72% 20%, rgba(169,220,232,.42), transparent 18%), linear-gradient(180deg, var(--ink), #3b191d 58%, var(--velvet)); color: var(--cream); }
.moon { position: absolute; right: 14%; top: 10%; width: 150px; height: 150px; border-radius: 50%; background: var(--cream); box-shadow: 0 0 70px rgba(255,242,216,.65); }
.last-note { max-width: 760px; color: var(--cream); background: rgba(35,20,15,.5); text-align: center; border-radius: 2rem; }
.last-note em { color: var(--glass); }
.reserve { margin-top: 1rem; }
.cafe-table { position: absolute; bottom: 8%; right: 12%; width: 330px; height: 130px; border-radius: 50%; background: radial-gradient(ellipse, var(--cream), var(--gold)); box-shadow: 0 35px 0 -18px var(--caramel), 0 40px 70px rgba(0,0,0,.28); }
.cafe-table::after { content: ""; position: absolute; left: 50%; top: 70%; width: 24px; height: 190px; transform: translateX(-50%); background: var(--caramel); }
.porcelain-cup { position: absolute; left: 55px; top: 23px; width: 75px; height: 48px; border-radius: 0 0 35px 35px; background: var(--cream); box-shadow: inset 0 -8px var(--glass); }
.porcelain-cup span { position: absolute; right: -24px; top: 10px; width: 33px; height: 27px; border: 6px solid var(--cream); border-left: 0; border-radius: 0 25px 25px 0; }
.napkin { position: absolute; right: 48px; top: 22px; width: 92px; height: 70px; display: grid; place-items: center; color: var(--velvet); background: white; transform: rotate(8deg); box-shadow: 0 8px 18px rgba(35,20,15,.22); }

.scene:not(.entered) .arched-card,
.scene:not(.entered) .angled-menu,
.scene:not(.entered) .oval-frame,
.scene:not(.entered) .glasshouse-copy,
.scene:not(.entered) .last-note,
.scene:not(.entered) .display-case,
.scene:not(.entered) .clock-frame,
.scene:not(.entered) .greenhouse {
  opacity: .25;
  transform: translateY(50px) scale(.98);
}

.scene.entered .arched-card,
.scene.entered .angled-menu,
.scene.entered .oval-frame,
.scene.entered .glasshouse-copy,
.scene.entered .last-note,
.scene.entered .display-case,
.scene.entered .clock-frame,
.scene.entered .greenhouse {
  transition: opacity .9s ease, transform 1s cubic-bezier(.2,.7,.1,1);
}

@media (max-width: 820px) {
  .porcelain-counter, .macaron-clockwork, .conservatory { grid-template-columns: 1fr; }
  .display-case { transform: scale(.82); transform-origin: top center; }
  .salon-nav { right: .35rem; }
  .cafe-table, .teacup { opacity: .55; }
}
