* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  --dark: #080510;
  --violet: #211136;
  --purple: #6d2dff;
  --pink: #ff4fa3;
  --gold: #ffe7a6;
  --cyan: #7ee7ff;
  --white: #fff8ff;
  --glass: rgba(255, 255, 255, 0.115);
  --border: rgba(255, 255, 255, 0.24);
}

html,
body {
  width: 100%;
  min-height: 100%;
  overflow: hidden;
}

html {
  scrollbar-width: none;
}

body::-webkit-scrollbar,
.scene-card::-webkit-scrollbar {
  display: none;
}

body {
  font-family: Arial, sans-serif;
  color: var(--white);
  background:
    radial-gradient(circle at 18% 16%, rgba(255, 79, 163, .27), transparent 24%),
    radial-gradient(circle at 82% 18%, rgba(126, 231, 255, .18), transparent 26%),
    radial-gradient(circle at 50% 90%, rgba(109, 45, 255, .3), transparent 34%),
    linear-gradient(140deg, #07040d, #170922 45%, #090411);
}

#codeRain {
  position: fixed;
  inset: 0;
  z-index: 0;
  width: 100vw;
  height: 100vh;
  opacity: .48;
  filter: contrast(1.25) brightness(1.1);
  pointer-events: none;
}

.cinema-overlay {
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(0,0,0,.55) 0%, transparent 14%, transparent 82%, rgba(0,0,0,.58) 100%),
    radial-gradient(circle at center, transparent 28%, rgba(0,0,0,.34) 100%);
}

.premium-lights {
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
}

.light {
  position: absolute;
  width: 280px;
  height: 280px;
  border-radius: 50%;
  filter: blur(54px);
  opacity: .35;
  animation: lightFloat 9s ease-in-out infinite;
  transform: translate3d(var(--mx, 0px), var(--my, 0px), 0);
}

.l1 { left: -70px; top: 12%; background: var(--pink); }
.l2 { right: -90px; top: 18%; background: var(--cyan); animation-delay: -2s; }
.l3 { left: 33%; bottom: -120px; background: var(--purple); animation-delay: -4s; }

.main {
  position: relative;
  z-index: 2;
  width: 100vw;
  height: 100svh;
}

.page {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 28px 18px 96px;
  opacity: 0;
  visibility: hidden;
  transform: translateX(44px) scale(.985);
  transition: opacity .62s ease, transform .62s ease, visibility .62s;
}

.page.active {
  opacity: 1;
  visibility: visible;
  transform: translateX(0) scale(1);
}

.page.active .reveal,
.page.active .intro-card {
  animation: sceneReveal .75s ease both;
}

.scene-card {
  position: relative;
  width: min(92vw, 980px);
  max-height: calc(100svh - 132px);
  overflow: hidden;
  -webkit-overflow-scrolling: touch;
  padding: clamp(20px, 3.2vw, 34px);
  border-radius: 36px;
  text-align: center;
  background:
    linear-gradient(155deg, rgba(255,255,255,.18), rgba(255,255,255,.06)),
    radial-gradient(circle at 20% 0%, rgba(255, 79, 163, .16), transparent 30%);
  border: 1px solid var(--border);
  box-shadow:
    0 34px 92px rgba(0,0,0,.48),
    inset 0 1px 0 rgba(255,255,255,.22);
  backdrop-filter: blur(18px);
}

.scene-card::before {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(125deg, rgba(255,231,166,.7), rgba(255,79,163,.15), rgba(126,231,255,.5));
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask-composite: exclude;
  -webkit-mask-composite: xor;
  pointer-events: none;
}

.scan-line {
  display: none;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  padding: 8px 14px;
  border-radius: 999px;
  color: var(--gold);
  font-size: 12px;
  letter-spacing: .11em;
  text-transform: uppercase;
  background: rgba(255,255,255,.09);
  border: 1px solid rgba(255,255,255,.15);
}

h1 {
  font-size: clamp(2.1rem, 7vw, 5rem);
  line-height: .95;
  letter-spacing: -.055em;
  text-shadow: 0 18px 44px rgba(0,0,0,.45);
}

h1 span,
h2 span {
  color: var(--gold);
}

h2 {
  font-size: clamp(2rem, 7vw, 4rem);
  line-height: 1;
  letter-spacing: -.045em;
  margin-bottom: 16px;
}

.lead,
.sub {
  width: min(680px, 100%);
  margin: 12px auto 0;
  color: rgba(255,248,255,.82);
  line-height: 1.75;
}

.gift-core,
.final-core {
  width: 92px;
  height: 92px;
  margin: 4px auto 18px;
  display: grid;
  place-items: center;
  border-radius: 34px;
  font-size: 46px;
  background:
    radial-gradient(circle at 35% 25%, rgba(255,255,255,.5), transparent 30%),
    linear-gradient(145deg, rgba(255,231,166,.28), rgba(255,79,163,.18));
  border: 1px solid rgba(255,255,255,.24);
  box-shadow: 0 22px 60px rgba(255,79,163,.28), inset 0 0 28px rgba(255,255,255,.14);
  animation: premiumFloat 3.2s ease-in-out infinite;
}

.btn,
.mini-btn,
.scene-nav button,
.gallery-control,
.lightbox-close,
.lightbox-nav {
  border: none;
  cursor: pointer;
  color: #1d0e22;
  background: linear-gradient(135deg, #fff7d7, #ff99c8 54%, #9feeff);
  box-shadow: 0 18px 44px rgba(255,79,163,.28);
  font-weight: 800;
  transition: transform .24s ease, box-shadow .24s ease, filter .24s ease;
}

.btn {
  margin-top: 18px;
  padding: 15px 24px;
  border-radius: 999px;
  font-size: 1rem;
}

.btn:active,
.mini-btn:active,
.scene-nav button:active,
.gallery-control:active {
  transform: scale(.95);
}

.tap-hint {
  margin-top: 10px;
  color: rgba(255,248,255,.62);
  font-size: .86rem;
}

.hero-stage {
  display: grid;
  grid-template-columns: 1fr minmax(230px, 340px);
  gap: 26px;
  align-items: center;
  margin-top: 20px;
  text-align: left;
}

.hero-copy p {
  color: rgba(255,248,255,.86);
  line-height: 1.78;
}

.type-box {
  min-height: 118px;
  margin-top: 18px;
  padding: 20px;
  border-radius: 26px;
  background: rgba(0,0,0,.22);
  border: 1px solid rgba(255,255,255,.16);
  line-height: 1.72;
}

.cursor {
  animation: blink .75s infinite;
  font-weight: 900;
}

.premium-photo-frame {
  position: relative;
  width: min(76vw, 330px);
  aspect-ratio: 1 / 1.16;
  margin: auto;
  border-radius: 42px;
  padding: 11px;
  background: linear-gradient(145deg, rgba(255,255,255,.28), rgba(255,255,255,.08));
  border: 1px solid rgba(255,255,255,.22);
  box-shadow: 0 28px 74px rgba(0,0,0,.42);
  transform-style: preserve-3d;
}

.premium-photo-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 34px;
  display: block;
}

.frame-glow {
  position: absolute;
  inset: 12%;
  z-index: -1;
  background: rgba(255,79,163,.45);
  filter: blur(34px);
  transform: translateZ(-20px);
}

.page-actions {
  display: flex;
  gap: 12px;
  justify-content: center;
  margin-top: 24px;
  flex-wrap: wrap;
}

.mini-btn {
  padding: 12px 18px;
  border-radius: 999px;
}

.mini-btn.ghost {
  color: var(--white);
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.17);
  box-shadow: none;
}

.timeline-cinema {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 18px;
}

.timeline-card {
  min-height: 190px;
  padding: 22px;
  text-align: left;
  color: var(--white);
  background:
    linear-gradient(155deg, rgba(255,255,255,.15), rgba(255,255,255,.055));
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 28px;
  box-shadow: 0 22px 46px rgba(0,0,0,.24);
}

.timeline-card span {
  color: var(--gold);
  font-size: 1.55rem;
  font-weight: 900;
}

.timeline-card strong {
  display: block;
  margin: 12px 0 8px;
  font-size: 1.15rem;
}

.timeline-card p {
  color: rgba(255,248,255,.76);
  line-height: 1.6;
}

.orbit-gallery {
  position: relative;
  height: min(55vh, 430px);
  margin: 20px auto 0;
  width: min(100%, 920px);
  perspective: 1200px;
  overflow: hidden;
  border-radius: 34px;
}

.orbit-track {
  position: relative;
  width: 100%;
  height: 100%;
  touch-action: pan-y;
}

.orbit-card {
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(58vw, 250px);
  height: min(72vw, 320px);
  margin-left: calc(min(58vw, 250px) / -2);
  margin-top: calc(min(72vw, 320px) / -2);
  padding: 10px;
  border-radius: 32px;
  color: var(--white);
  background: linear-gradient(155deg, rgba(255,255,255,.21), rgba(255,255,255,.075));
  border: 1px solid rgba(255,255,255,.24);
  box-shadow: 0 32px 72px rgba(0,0,0,.34);
  transition: transform .6s ease, opacity .6s ease, filter .6s ease;
  overflow: hidden;
}

.orbit-card img {
  width: 100%;
  height: calc(100% - 35px);
  object-fit: cover;
  display: block;
  border-radius: 25px;
}

.orbit-card span {
  display: block;
  padding-top: 9px;
  color: var(--gold);
  letter-spacing: .09em;
  font-size: .78rem;
  text-transform: uppercase;
}

.gallery-control {
  position: absolute;
  top: 50%;
  z-index: 9;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  font-size: 34px;
  line-height: 42px;
}

.gallery-control.prev { left: 10px; }
.gallery-control.next { right: 10px; }

.letter-paper {
  position: relative;
  width: min(720px, 100%);
  max-height: 0;
  margin: 22px auto 0;
  overflow: hidden;
  padding: 0 24px;
  border-radius: 28px;
  text-align: left;
  color: #321324;
  background:
    linear-gradient(135deg, rgba(255,255,255,.95), rgba(255,238,248,.94));
  box-shadow: 0 22px 60px rgba(0,0,0,.34);
  transition: max-height .8s ease, padding .8s ease, transform .8s ease;
  transform: rotateX(28deg) scale(.94);
  transform-origin: top;
}

.letter-paper.open {
  max-height: 420px;
  padding: 26px;
  transform: rotateX(0) scale(1);
}

.letter-paper p {
  line-height: 1.8;
  margin-bottom: 10px;
}

.letter-shine {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,.72), transparent);
  transform: translateX(-100%);
  animation: letterShine 3.5s ease-in-out infinite;
}

.final-sec p {
  width: min(680px, 100%);
  margin: 0 auto;
  color: rgba(255,248,255,.83);
  line-height: 1.75;
}

.scene-nav {
  position: fixed;
  z-index: 20;
  left: 50%;
  bottom: 22px;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(16px);
}

.scene-nav button {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  font-size: 30px;
  line-height: 38px;
}

.dots {
  display: flex;
  gap: 7px;
}

.dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.35);
  transition: width .25s ease, background .25s ease;
}

.dot.active {
  width: 25px;
  background: var(--gold);
}

.photo-lightbox {
  position: fixed;
  inset: 0;
  z-index: 60;
  display: none;
  place-items: center;
  padding: 22px;
  background: rgba(4,2,8,.9);
  backdrop-filter: blur(13px);
}

.photo-lightbox.open {
  display: grid;
}

.photo-lightbox img {
  max-width: min(92vw, 680px);
  max-height: 72vh;
  object-fit: contain;
  border-radius: 30px;
  border: 1px solid rgba(255,255,255,.2);
  box-shadow: 0 34px 90px rgba(0,0,0,.55);
}

.lightbox-close,
.lightbox-nav {
  position: fixed;
  z-index: 61;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  font-size: 31px;
}

.lightbox-close { right: 18px; top: 18px; }
.lightbox-prev { left: 14px; top: 50%; }
.lightbox-next { right: 14px; top: 50%; }

#lightboxCaption {
  position: fixed;
  bottom: 30px;
  color: var(--gold);
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: .86rem;
}

.confetti,
.spark {
  position: fixed;
  z-index: 70;
  pointer-events: none;
}

.confetti {
  top: -12px;
  width: 9px;
  height: 15px;
  border-radius: 4px;
  animation: confettiFall 4s linear forwards;
}

.spark {
  color: var(--gold);
  animation: sparkFly 950ms ease-out forwards;
}

@keyframes sceneReveal {
  from { opacity: 0; transform: translateY(22px) scale(.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes scan {
  50% { top: 100%; }
}

@keyframes premiumFloat {
  50% { transform: translateY(-10px) rotate(4deg); }
}

@keyframes lightFloat {
  50% { transform: translate3d(calc(var(--mx, 0px) + 20px), calc(var(--my, 0px) - 20px), 0) scale(1.08); }
}

@keyframes blink {
  0%, 50% { opacity: 1; }
  50.01%, 100% { opacity: 0; }
}

@keyframes letterShine {
  45%, 100% { transform: translateX(100%); }
}

@keyframes confettiFall {
  0% { transform: translateY(-20px) rotate(0); opacity: 1; }
  100% { transform: translateY(110vh) rotate(720deg); opacity: 0; }
}

@keyframes sparkFly {
  0% { opacity: 1; transform: translate(-50%, -50%) scale(.7); }
  100% { opacity: 0; transform: translate(calc(-50% + var(--x)), calc(-50% + var(--y))) scale(1.7); }
}

@media (max-width: 760px) {
  .page {
    padding: 22px 14px 92px;
  }

  .scene-card {
    border-radius: 30px;
    padding: 22px 16px;
  }

  .hero-stage {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .type-box {
    text-align: left;
    min-height: 140px;
  }

  .timeline-cinema {
    grid-template-columns: 1fr;
  }

  .timeline-card {
    min-height: auto;
    padding: 18px;
  }

  .orbit-gallery {
    height: 52vh;
  }

  .gallery-control {
    display: none;
  }
}


/* Premium quick fix: remove visible scrollbars and prevent overflow */
* {
  max-width: 100%;
}

.page,
.main,
.scene-card {
  overflow-x: hidden !important;
}

.scene-card {
  scrollbar-width: none;
}

.scene-card::-webkit-scrollbar {
  width: 0;
  height: 0;
}

@media (min-width: 900px) {
  .intro-card {
    transform: scale(0.94);
    transform-origin: center;
  }
}






/* === FIXED BOX PAGE SYSTEM: NO SCROLL NEEDED === */
html,
body {
  width: 100vw !important;
  height: 100vh !important;
  height: 100svh !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  overscroll-behavior: none !important;
}

body {
  position: fixed !important;
  inset: 0 !important;
}

*,
*::before,
*::after {
  max-width: 100%;
  scrollbar-width: none !important;
  -ms-overflow-style: none !important;
}

*::-webkit-scrollbar {
  width: 0 !important;
  height: 0 !important;
  display: none !important;
}

.main {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100svh !important;
  overflow: hidden !important;
}

.page {
  position: absolute !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100svh !important;
  min-height: 0 !important;
  padding: 16px 16px 86px !important;
  display: grid !important;
  place-items: center !important;
  overflow: hidden !important;
}

.page:not(.active) {
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.page.active {
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}

/* The whole page is fixed inside this box */
.scene-card {
  width: min(82vw, 900px) !important;
  height: calc(100svh - 128px) !important;
  max-height: calc(100svh - 128px) !important;
  min-height: 0 !important;
  overflow: hidden !important;
  padding: clamp(14px, 2.1vw, 26px) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
}

/* Remove old scale/overflow behavior */
.intro-card {
  transform: none !important;
}

/* Compact premium intro so everything fits inside the fixed box */
.eyebrow {
  margin-bottom: 8px !important;
  padding: 6px 11px !important;
  font-size: 10.5px !important;
  line-height: 1.1 !important;
}

.gift-core,
.final-core {
  width: clamp(52px, 7svh, 72px) !important;
  height: clamp(52px, 7svh, 72px) !important;
  font-size: clamp(26px, 4svh, 36px) !important;
  margin: 0 auto 10px !important;
  flex: 0 0 auto !important;
}

h1 {
  font-size: clamp(2rem, 5.2vw, 4.2rem) !important;
  line-height: 0.96 !important;
  margin: 0 !important;
}

h2 {
  font-size: clamp(1.7rem, 4.4vw, 3.1rem) !important;
  line-height: 1 !important;
  margin-bottom: 10px !important;
}

.lead,
.sub,
.final-sec p {
  width: min(560px, 100%) !important;
  margin: 9px auto 0 !important;
  font-size: clamp(0.82rem, 1.45vw, 0.98rem) !important;
  line-height: 1.5 !important;
}

.btn {
  margin-top: 12px !important;
  padding: 11px 20px !important;
  font-size: 0.92rem !important;
}

.tap-hint {
  margin-top: 7px !important;
  font-size: 0.78rem !important;
  line-height: 1.25 !important;
}

/* Scene inner layouts must fit without scrolling */
.hero-stage {
  grid-template-columns: 1fr minmax(190px, 280px) !important;
  gap: 18px !important;
  margin-top: 12px !important;
  max-height: 58% !important;
  overflow: hidden !important;
}

.hero-copy p {
  font-size: 0.92rem !important;
  line-height: 1.55 !important;
}

.type-box {
  min-height: 82px !important;
  max-height: 112px !important;
  margin-top: 10px !important;
  padding: 14px !important;
  font-size: 0.9rem !important;
  line-height: 1.5 !important;
  overflow: hidden !important;
}

.premium-photo-frame {
  width: min(35vw, 250px) !important;
  max-height: 270px !important;
}

.timeline-cinema {
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 10px !important;
  margin-top: 14px !important;
  overflow: hidden !important;
}

.timeline-card {
  min-height: 0 !important;
  padding: 16px !important;
}

.timeline-card span {
  font-size: 1.25rem !important;
}

.timeline-card strong {
  margin: 8px 0 6px !important;
  font-size: 1rem !important;
}

.timeline-card p {
  font-size: 0.86rem !important;
  line-height: 1.45 !important;
}

.orbit-gallery {
  height: min(43svh, 310px) !important;
  margin-top: 12px !important;
  overflow: hidden !important;
}

.orbit-card {
  width: min(45vw, 210px) !important;
  height: min(54vw, 260px) !important;
  margin-left: calc(min(45vw, 210px) / -2) !important;
  margin-top: calc(min(54vw, 260px) / -2) !important;
}

.page-actions {
  margin-top: 14px !important;
  gap: 10px !important;
  flex: 0 0 auto !important;
}

.mini-btn {
  padding: 10px 16px !important;
  font-size: 0.9rem !important;
}

.letter-paper.open {
  max-height: 220px !important;
  padding: 18px !important;
}

.letter-paper {
  margin-top: 14px !important;
}

.letter-paper p {
  font-size: 0.9rem !important;
  line-height: 1.55 !important;
}

/* Bottom navigation only */
.scene-nav {
  bottom: 18px !important;
  z-index: 30 !important;
}

.scene-nav button {
  width: 40px !important;
  height: 40px !important;
}

/* Small laptops / browser bars */
@media (max-height: 720px) {
  .page {
    padding: 10px 14px 78px !important;
  }

  .scene-card {
    height: calc(100svh - 104px) !important;
    max-height: calc(100svh - 104px) !important;
    padding: 12px 18px !important;
  }

  .gift-core,
  .final-core {
    width: 52px !important;
    height: 52px !important;
    font-size: 26px !important;
    margin-bottom: 7px !important;
  }

  h1 {
    font-size: clamp(1.8rem, 4.6vw, 3.5rem) !important;
  }

  h2 {
    font-size: clamp(1.55rem, 4vw, 2.6rem) !important;
  }

  .lead,
  .sub,
  .tap-hint {
    font-size: 0.78rem !important;
  }

  .btn {
    padding: 9px 18px !important;
    margin-top: 9px !important;
  }

  .page-actions {
    margin-top: 10px !important;
  }

  .orbit-gallery {
    height: min(39svh, 270px) !important;
  }
}

/* Phone layout: still fixed inside the box */
@media (max-width: 760px) {
  .page {
    padding: 12px 10px 82px !important;
  }

  .scene-card {
    width: min(94vw, 560px) !important;
    height: calc(100svh - 112px) !important;
    max-height: calc(100svh - 112px) !important;
    padding: 15px 13px !important;
  }

  h1 {
    font-size: clamp(2rem, 10vw, 3.35rem) !important;
  }

  .hero-stage {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    text-align: center !important;
    max-height: none !important;
  }

  .premium-photo-frame {
    width: min(52vw, 210px) !important;
  }

  .type-box {
    min-height: 82px !important;
    max-height: 104px !important;
  }

  .timeline-cinema {
    grid-template-columns: 1fr !important;
  }

  .timeline-card {
    padding: 12px !important;
  }

  .timeline-card p {
    display: none !important;
  }

  .orbit-gallery {
    height: 40svh !important;
  }

  .orbit-card {
    width: min(58vw, 210px) !important;
    height: min(72vw, 260px) !important;
    margin-left: calc(min(58vw, 210px) / -2) !important;
    margin-top: calc(min(72vw, 260px) / -2) !important;
  }
}


/* === INSIDE BUTTONS ONLY === */
.scene-nav {
  display: none !important;
}

.page {
  padding-bottom: 16px !important;
}

.scene-card {
  height: calc(100svh - 40px) !important;
  max-height: calc(100svh - 40px) !important;
}

@media (max-width: 760px) {
  .page {
    padding-bottom: 12px !important;
  }

  .scene-card {
    height: calc(100svh - 28px) !important;
    max-height: calc(100svh - 28px) !important;
  }
}


/* === CINEMATIC PREMIUM TRANSITIONS === */
.scene-transition {
  position: fixed;
  inset: 0;
  z-index: 55;
  pointer-events: none;
  opacity: 0;
  background:
    radial-gradient(circle at center, rgba(255, 231, 166, 0.18), transparent 24%),
    linear-gradient(115deg, transparent 0%, rgba(255, 79, 163, 0.20) 42%, rgba(126, 231, 255, 0.18) 58%, transparent 100%),
    rgba(5, 2, 10, 0.2);
  transform: scaleX(0);
  transform-origin: left center;
  backdrop-filter: blur(0px);
}

.scene-transition.play {
  animation: premiumSceneWipe 760ms cubic-bezier(.2,.8,.2,1) forwards;
}

.page {
  transition:
    opacity 640ms cubic-bezier(.2,.8,.2,1),
    transform 640ms cubic-bezier(.2,.8,.2,1),
    filter 640ms cubic-bezier(.2,.8,.2,1),
    visibility 640ms ease !important;
}

.page.is-exiting {
  opacity: 0 !important;
  transform: translateX(-34px) scale(0.965) !important;
  filter: blur(8px) brightness(0.72) !important;
}

.page.active {
  animation: cameraEnter 760ms cubic-bezier(.2,.8,.2,1) both;
}

.page.active .scene-card {
  animation: cardCinematicIn 820ms cubic-bezier(.2,.8,.2,1) both;
}

.page.active .eyebrow {
  animation: layerUp 700ms 130ms cubic-bezier(.2,.8,.2,1) both;
}

.page.active h1,
.page.active h2 {
  animation: titleCinematicIn 760ms 210ms cubic-bezier(.2,.8,.2,1) both;
}

.page.active .lead,
.page.active .sub,
.page.active .hero-copy,
.page.active .timeline-cinema,
.page.active .orbit-gallery,
.page.active .letter-paper,
.page.active .final-sec p {
  animation: layerUp 760ms 320ms cubic-bezier(.2,.8,.2,1) both;
}

.page.active .page-actions,
.page.active .btn,
.page.active .tap-hint {
  animation: layerUp 700ms 470ms cubic-bezier(.2,.8,.2,1) both;
}

.premium-photo-frame,
.gift-core,
.final-core {
  will-change: transform;
}

.page.active .premium-photo-frame,
.page.active .gift-core,
.page.active .final-core {
  animation: premiumObjectIn 900ms 260ms cubic-bezier(.2,.8,.2,1) both, premiumFloat 3.2s ease-in-out infinite 950ms;
}

body.transitioning #codeRain {
  filter: contrast(1.38) brightness(1.34) blur(0.5px);
}

body.transitioning .premium-lights {
  opacity: 0.82;
}

@keyframes premiumSceneWipe {
  0% {
    opacity: 0;
    transform: scaleX(0);
    backdrop-filter: blur(0px);
  }
  35% {
    opacity: 1;
    transform: scaleX(1);
    backdrop-filter: blur(8px);
  }
  68% {
    opacity: 1;
    transform: scaleX(1);
    backdrop-filter: blur(10px);
  }
  100% {
    opacity: 0;
    transform: scaleX(1);
    backdrop-filter: blur(0px);
  }
}

@keyframes cameraEnter {
  0% {
    opacity: 0;
    transform: translateX(44px) scale(1.035);
    filter: blur(10px) brightness(1.2);
  }
  55% {
    opacity: 1;
    filter: blur(0px) brightness(1.05);
  }
  100% {
    opacity: 1;
    transform: translateX(0) scale(1);
    filter: blur(0) brightness(1);
  }
}

@keyframes cardCinematicIn {
  0% {
    opacity: 0;
    transform: translateY(24px) scale(0.965);
    filter: blur(8px);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
}

@keyframes titleCinematicIn {
  0% {
    opacity: 0;
    transform: translateY(22px) scale(0.96);
    letter-spacing: -0.09em;
    filter: blur(9px);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
}

@keyframes layerUp {
  0% {
    opacity: 0;
    transform: translateY(18px);
    filter: blur(7px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }
}

@keyframes premiumObjectIn {
  0% {
    opacity: 0;
    transform: translateY(18px) scale(0.86) rotate(-4deg);
    filter: blur(8px);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1) rotate(0deg);
    filter: blur(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .scene-transition.play,
  .page.active,
  .page.active .scene-card,
  .page.active .eyebrow,
  .page.active h1,
  .page.active h2,
  .page.active .lead,
  .page.active .sub,
  .page.active .hero-copy,
  .page.active .timeline-cinema,
  .page.active .orbit-gallery,
  .page.active .letter-paper,
  .page.active .final-sec p,
  .page.active .page-actions,
  .page.active .btn,
  .page.active .tap-hint {
    animation: none !important;
  }
}


.music-toggle{
position:fixed;
top:16px;
right:16px;
z-index:90;
width:48px;
height:48px;
border-radius:50%;
border:1px solid rgba(255,255,255,.18);
background:linear-gradient(145deg,rgba(255,255,255,.18),rgba(255,255,255,.08));
backdrop-filter:blur(14px);
color:white;
font-size:20px;
cursor:pointer;
box-shadow:0 14px 34px rgba(255,79,163,.24);
}

.music-toggle.muted{
opacity:.55;
}

#codeRain{
opacity:.32 !important;
}

.page#welcomePage .scene-card{
background:
radial-gradient(circle at top, rgba(255,231,166,.16), transparent 35%),
linear-gradient(155deg, rgba(255,255,255,.16), rgba(255,255,255,.05));
}

.page#galleryPage .scene-card{
background:
radial-gradient(circle at center, rgba(109,45,255,.22), transparent 36%),
linear-gradient(160deg, rgba(255,255,255,.14), rgba(255,255,255,.05));
}

.orbit-gallery{
perspective:1600px !important;
}

.orbit-card{
box-shadow:
0 34px 90px rgba(0,0,0,.42),
0 0 36px rgba(255,79,163,.12);
}

.orbit-card img{
transition:transform .7s ease;
}

.orbit-card:hover img{
transform:scale(1.05);
}

.active-memory-caption{
margin-top:12px;
color:var(--gold);
letter-spacing:.08em;
text-transform:uppercase;
font-size:.82rem;
opacity:.92;
}

.scene-transition.play{
animation-duration:620ms !important;
}

.page{
transition-duration:520ms !important;
}

.page.is-exiting{
filter:blur(5px) brightness(.82) !important;
transform:translateX(-24px) scale(.982) !important;
}

.final-core{
box-shadow:
0 0 42px rgba(255,79,163,.42),
0 0 80px rgba(126,231,255,.16);
}


/* === MOBILE SPACING BALANCE FIX === */
@media (max-width: 760px) {
  body {
    overflow: hidden !important;
  }

  .page {
    padding: 10px 10px 10px !important;
    align-items: center !important;
  }

  .scene-card {
    width: min(91vw, 520px) !important;
    height: calc(100svh - 24px) !important;
    max-height: calc(100svh - 24px) !important;
    padding: 18px 14px !important;
    justify-content: center !important;
    gap: 8px !important;
  }

  .eyebrow {
    margin-bottom: 8px !important;
    padding: 7px 12px !important;
    font-size: 10px !important;
    line-height: 1.1 !important;
    width: 100% !important;
    justify-content: center !important;
  }

  .gift-core,
  .final-core {
    width: 56px !important;
    height: 56px !important;
    font-size: 28px !important;
    margin: 0 auto 8px !important;
  }

  h1 {
    font-size: clamp(2rem, 9.2vw, 3.15rem) !important;
    line-height: 0.96 !important;
    margin: 0 !important;
  }

  h2 {
    font-size: clamp(1.65rem, 7vw, 2.35rem) !important;
    line-height: 1.03 !important;
    margin: 4px 0 8px !important;
  }

  .lead,
  .sub,
  .final-sec p {
    margin: 8px auto 0 !important;
    font-size: 0.84rem !important;
    line-height: 1.45 !important;
  }

  .btn {
    width: 100% !important;
    margin-top: 12px !important;
    padding: 12px 18px !important;
  }

  .tap-hint {
    margin-top: 8px !important;
    font-size: 0.78rem !important;
  }

  .music-toggle {
    top: 108px !important;
    right: 14px !important;
    width: 42px !important;
    height: 42px !important;
    font-size: 18px !important;
  }

  /* Hero page */
  #heroPage .scene-card {
    justify-content: center !important;
  }

  .hero-stage {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    margin-top: 8px !important;
    text-align: center !important;
  }

  .hero-copy p {
    font-size: 0.84rem !important;
    line-height: 1.45 !important;
    margin: 0 auto !important;
  }

  .type-box {
    min-height: 82px !important;
    max-height: 96px !important;
    margin-top: 8px !important;
    padding: 12px !important;
    font-size: 0.82rem !important;
    line-height: 1.45 !important;
  }

  .premium-photo-frame {
    width: min(45vw, 180px) !important;
    max-height: 205px !important;
    margin: 0 auto !important;
  }

  .active-memory-caption {
    margin-top: 8px !important;
    font-size: 0.68rem !important;
    line-height: 1.2 !important;
  }

  .page-actions {
    margin-top: 10px !important;
    gap: 8px !important;
  }

  .mini-btn {
    padding: 10px 15px !important;
    font-size: 0.86rem !important;
  }

  /* Timeline page */
  .timeline-cinema {
    margin-top: 8px !important;
    gap: 8px !important;
  }

  .timeline-card {
    padding: 11px !important;
  }

  .timeline-card span {
    font-size: 1rem !important;
  }

  .timeline-card strong {
    margin: 4px 0 0 !important;
    font-size: 0.92rem !important;
  }

  .timeline-card p {
    display: none !important;
  }

  /* Gallery page */
  .orbit-gallery {
    height: 38svh !important;
    margin-top: 8px !important;
  }

  .orbit-card {
    width: min(55vw, 190px) !important;
    height: min(68vw, 235px) !important;
    margin-left: calc(min(55vw, 190px) / -2) !important;
    margin-top: calc(min(68vw, 235px) / -2) !important;
  }

  /* Letter page */
  .letter-paper {
    margin-top: 10px !important;
  }

  .letter-paper.open {
    max-height: 190px !important;
    padding: 15px !important;
  }

  .letter-paper p {
    font-size: 0.82rem !important;
    line-height: 1.45 !important;
  }

  /* Final page */
  #finalPage .scene-card {
    justify-content: center !important;
  }

  .final-sec .btn {
    margin-top: 14px !important;
  }

  .confetti {
    width: 7px !important;
    height: 12px !important;
    opacity: 0.75 !important;
  }
}

/* Extra small height phones */
@media (max-width: 760px) and (max-height: 760px) {
  .scene-card {
    padding: 13px 12px !important;
  }

  h1 {
    font-size: clamp(1.75rem, 8.4vw, 2.75rem) !important;
  }

  h2 {
    font-size: clamp(1.45rem, 6.2vw, 2rem) !important;
  }

  .gift-core,
  .final-core {
    width: 48px !important;
    height: 48px !important;
    font-size: 24px !important;
  }

  .type-box {
    max-height: 82px !important;
    min-height: 72px !important;
    font-size: 0.78rem !important;
  }

  .premium-photo-frame {
    width: min(40vw, 150px) !important;
  }

  .orbit-gallery {
    height: 34svh !important;
  }
}


/* FLOATING MEMORY SYSTEM */

.floating-memory-stage{
position:relative;
width:100%;
height:min(48svh,420px);
display:flex;
align-items:center;
justify-content:center;
perspective:1800px;
overflow:hidden;
margin-top:10px;
}

.memory-layer{
position:absolute;
inset:0;
background:
radial-gradient(circle at center, rgba(126,231,255,.08), transparent 42%),
radial-gradient(circle at 30% 20%, rgba(255,79,163,.12), transparent 28%);
filter:blur(10px);
opacity:.7;
}

.memory-glow{
position:absolute;
width:280px;
height:280px;
border-radius:50%;
background:radial-gradient(circle, rgba(180,110,255,.22), transparent 70%);
filter:blur(20px);
animation:memoryGlowFloat 6s ease-in-out infinite;
}

.floating-memory-card{
position:absolute;
width:min(38vw,220px);
height:min(50vw,300px);
border-radius:28px;
overflow:hidden;
cursor:pointer;
transition:
transform .75s cubic-bezier(.2,.8,.2,1),
opacity .75s ease,
filter .75s ease;
box-shadow:
0 28px 60px rgba(0,0,0,.42),
0 0 28px rgba(255,79,163,.14);
border:1px solid rgba(255,255,255,.12);
}

.floating-memory-card img{
width:100%;
height:100%;
object-fit:cover;
transition:transform 1s ease;
}

.floating-memory-card.active{
z-index:10;
transform:translateZ(180px) scale(1.08);
opacity:1;
}

.floating-memory-card.left-1{
transform:translateX(-160px) rotateY(22deg) scale(.92);
opacity:.88;
}

.floating-memory-card.left-2{
transform:translateX(-290px) rotateY(34deg) scale(.76);
opacity:.46;
filter:blur(1.6px);
}

.floating-memory-card.right-1{
transform:translateX(160px) rotateY(-22deg) scale(.92);
opacity:.88;
}

.floating-memory-card.right-2{
transform:translateX(290px) rotateY(-34deg) scale(.76);
opacity:.46;
filter:blur(1.6px);
}

.floating-memory-card.active img{
transform:scale(1.05);
}

.floating-memory-card.active{
animation:mainMemoryFloat 5.5s ease-in-out infinite;
}

@keyframes mainMemoryFloat{
0%,100%{
transform:translateY(0) scale(1.08);
}
50%{
transform:translateY(-12px) scale(1.1);
}
}

@keyframes memoryGlowFloat{
0%,100%{
transform:translateY(0);
opacity:.7;
}
50%{
transform:translateY(-16px);
opacity:1;
}
}

@media (max-width:760px){

.floating-memory-stage{
height:36svh;
}

.floating-memory-card{
width:min(46vw,190px);
height:min(62vw,250px);
}

.floating-memory-card.left-1{
transform:translateX(-95px) rotateY(20deg) scale(.84);
}

.floating-memory-card.left-2{
transform:translateX(-165px) rotateY(30deg) scale(.64);
}

.floating-memory-card.right-1{
transform:translateX(95px) rotateY(-20deg) scale(.84);
}

.floating-memory-card.right-2{
transform:translateX(165px) rotateY(-30deg) scale(.64);
}

.floating-memory-card.active{
transform:scale(1.02);
}

.memory-glow{
width:200px;
height:200px;
}
}


/* FLOATING MEMORY FINGER DRAG FIX */
.floating-memory-stage {
  touch-action: none !important;
  cursor: grab;
}

.floating-memory-stage:active {
  cursor: grabbing;
}

.floating-memory-card {
  will-change: transform, opacity, filter;
}


/* ===== 10/10 PREMIUM POLISH ===== */

body{
letter-spacing:.01em;
}

#codeRain{
opacity:.22 !important;
filter:contrast(1.05) brightness(.96) !important;
}

.scene-card{
backdrop-filter:blur(14px) !important;
box-shadow:
0 28px 70px rgba(0,0,0,.34),
inset 0 1px 0 rgba(255,255,255,.12) !important;
}

h1{
font-size:clamp(2rem,6vw,4.7rem) !important;
line-height:.98 !important;
letter-spacing:-.045em !important;
}

h2{
font-size:clamp(1.7rem,4vw,3rem) !important;
letter-spacing:-.03em !important;
}

.lead,
.sub,
.hero-copy p,
.final-sec p{
max-width:540px !important;
font-size:clamp(.84rem,1.3vw,.98rem) !important;
line-height:1.65 !important;
color:rgba(255,248,255,.84) !important;
}

.page-actions{
margin-top:16px !important;
}

.mini-btn,
.btn{
transition:
transform .24s ease,
background .24s ease,
opacity .24s ease !important;
}

.btn:hover,
.mini-btn:hover{
transform:translateY(-2px);
}

.page{
transition:
opacity .5s ease,
transform .5s ease,
filter .5s ease !important;
}

.page.is-exiting{
transform:translateY(10px) scale(.99) !important;
opacity:0 !important;
filter:brightness(.82) blur(2px) !important;
}

.page.active{
animation:none !important;
}

.scene-transition{
background:
linear-gradient(180deg,
rgba(10,6,18,.12),
rgba(10,6,18,.22),
rgba(10,6,18,.12)) !important;
}

.scene-transition.play{
animation:softSceneFlow .56s ease forwards !important;
}

@keyframes softSceneFlow{
0%{
opacity:0;
}
35%{
opacity:1;
}
100%{
opacity:0;
}
}

/* Elegant orbit gallery */

.premium-orbit{
height:min(46svh,360px) !important;
margin-top:12px !important;
perspective:1400px !important;
}

.orbit-card{
background:rgba(255,255,255,.08) !important;
border:1px solid rgba(255,255,255,.14) !important;
box-shadow:
0 24px 60px rgba(0,0,0,.34),
0 0 18px rgba(255,255,255,.04) !important;
transition:
transform .65s cubic-bezier(.2,.8,.2,1),
opacity .65s ease,
filter .65s ease !important;
}

.orbit-card img{
transition:transform 1s ease !important;
}

.orbit-card span{
font-size:.72rem !important;
letter-spacing:.08em !important;
color:rgba(255,231,166,.92) !important;
}

.orbit-card:hover img{
transform:scale(1.03);
}

.gallery-control{
background:rgba(255,255,255,.14) !important;
color:white !important;
backdrop-filter:blur(12px);
box-shadow:none !important;
}

.gallery-control:hover{
background:rgba(255,255,255,.22) !important;
}

.active-memory-caption{
font-size:.74rem !important;
opacity:.8 !important;
margin-top:10px !important;
}

/* softer final page */

.final-core{
box-shadow:
0 0 34px rgba(255,79,163,.22),
0 0 64px rgba(126,231,255,.08) !important;
}

.confetti{
opacity:.55 !important;
}

/* mobile polish */

@media (max-width:760px){

.scene-card{
padding:16px 14px !important;
}

.hero-stage{
gap:12px !important;
}

.type-box{
background:rgba(255,255,255,.05) !important;
border:1px solid rgba(255,255,255,.08) !important;
}

.orbit-gallery{
height:35svh !important;
}

.orbit-card{
width:min(56vw,200px) !important;
height:min(70vw,255px) !important;
}

.music-toggle{
top:14px !important;
right:14px !important;
background:rgba(255,255,255,.12) !important;
}
}


/* === MINIMAL BUGFIX ONLY === */

/* Gallery navigation must be visible/clickable if missing before */
.gallery-page-actions,
#galleryPage .page-actions {
  display: flex !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  position: relative !important;
  z-index: 80 !important;
}

/* Decorative layers must not block clicks */
#codeRain,
#stars,
.cinema-overlay,
.premium-lights,
.romantic-atmosphere,
.romantic-particles,
.scene-transition {
  pointer-events: none !important;
}

/* Keep needed buttons clickable */
.music-toggle,
.orbit-card,
.gallery-control,
.gallery-arrow,
.page-actions,
.btn,
.main-btn,
.mini-btn,
.lightbox-close,
.close-btn,
.lightbox-nav,
.nav {
  pointer-events: auto !important;
}

.music-toggle {
  z-index: 9999 !important;
  cursor: pointer !important;
}

/* Photo viewer above page */
.photo-lightbox,
.lightbox {
  z-index: 9000 !important;
}

.photo-lightbox.open,
.lightbox.open {
  display: grid !important;
}

/* Prevent close button and music button overlap: close goes left in photo viewer */
.photo-lightbox.open .lightbox-close,
.photo-lightbox.open .close-btn,
.lightbox.open .lightbox-close,
.lightbox.open .close-btn {
  top: 16px !important;
  left: 16px !important;
  right: auto !important;
  z-index: 9999 !important;
}

/* Hide music button only while lightbox is open */
body.lightbox-open .music-toggle {
  opacity: 0 !important;
  pointer-events: none !important;
}

@media (max-width: 760px) {
  .photo-lightbox.open .lightbox-close,
  .photo-lightbox.open .close-btn,
  .lightbox.open .lightbox-close,
  .lightbox.open .close-btn {
    top: 12px !important;
    left: 12px !important;
    right: auto !important;
  }
}


/* === ANNIVERSARY PREMIUM THEME OVERRIDE - SAME STYLE BASE === */
body{
  background:
    radial-gradient(circle at 18% 16%, rgba(255, 120, 185, .18), transparent 28%),
    radial-gradient(circle at 82% 14%, rgba(255, 225, 180, .12), transparent 24%),
    radial-gradient(circle at 50% 90%, rgba(120, 70, 180, .18), transparent 36%),
    linear-gradient(145deg, #0b030d, #231022 55%, #060106) !important;
}

#codeRain{
  opacity:.18 !important;
  filter:contrast(1.02) brightness(.9) !important;
}

.scene-card,
.card{
  background:
    linear-gradient(155deg, rgba(255,255,255,.14), rgba(255,255,255,.05)),
    radial-gradient(circle at top, rgba(255,120,185,.10), transparent 42%) !important;
  border:1px solid rgba(255,255,255,.14) !important;
  box-shadow:
    0 30px 90px rgba(0,0,0,.42),
    inset 0 1px 0 rgba(255,255,255,.08) !important;
}

.main-btn,
.mini-btn:not(.ghost),
.btn,
.gallery-control,
.gallery-arrow,
.close-btn,
.lightbox-close,
.lightbox-nav{
  background:linear-gradient(135deg,#fff2ca,#ff9bc8) !important;
  color:#341625 !important;
}

h1 span,
h2,
.eyebrow,
.active-memory-caption,
.gallery-caption,
#lightboxCaption{
  color:#ffe2a9 !important;
}

.music-toggle{
  background:rgba(255,255,255,.12) !important;
  box-shadow:0 14px 34px rgba(255,120,185,.22) !important;
}

.type-box,
.typing-box,
.letter-box{
  background:rgba(255,255,255,.05) !important;
  border:1px solid rgba(255,255,255,.10) !important;
}

.romantic-atmosphere{
  position:fixed;
  inset:0;
  pointer-events:none;
  overflow:hidden;
  z-index:0;
}

.romantic-atmosphere span{
  position:absolute;
  font-size:24px;
  color:#ffd6ec;
  opacity:.48;
  animation:floatRomantic 8s ease-in-out infinite;
  text-shadow:0 0 18px rgba(255,120,185,.28);
}

.romantic-atmosphere span:nth-child(1){left:10%;top:18%}
.romantic-atmosphere span:nth-child(2){left:82%;top:16%;animation-delay:-1s}
.romantic-atmosphere span:nth-child(3){left:18%;top:80%;animation-delay:-2s}
.romantic-atmosphere span:nth-child(4){left:72%;top:74%;animation-delay:-3s}
.romantic-atmosphere span:nth-child(5){left:48%;top:8%;animation-delay:-4s}

@keyframes floatRomantic{
  50%{transform:translateY(-18px);opacity:.28}
}


/* === HARD MUSIC OVERLAY FIX === */

/* Big fixed hitbox above everything */
#musicHitBox {
  position: fixed !important;
  top: 0 !important;
  right: 0 !important;
  width: 96px !important;
  height: 96px !important;
  z-index: 2147483647 !important;
  pointer-events: auto !important;
  touch-action: none !important;
  cursor: pointer !important;
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  background: transparent !important;
  -webkit-tap-highlight-color: transparent !important;
}

/* Visible button inside hitbox */
#musicToggleVisual {
  position: absolute !important;
  top: 16px !important;
  right: 16px !important;
  width: 52px !important;
  height: 52px !important;
  border-radius: 50% !important;
  border: 2px solid rgba(255,255,255,.85) !important;
  background: rgba(45,45,55,.9) !important;
  color: #fff !important;
  font-size: 24px !important;
  line-height: 48px !important;
  text-align: center !important;
  pointer-events: none !important;
  user-select: none !important;
  -webkit-user-select: none !important;
  box-shadow: 0 0 22px rgba(255,120,185,.42) !important;
}

#musicToggleVisual.muted {
  opacity: .65 !important;
}

/* Full-screen decorative layers must not catch taps */
#codeRain,
#stars,
.bg,
.orb,
.cinema-overlay,
.romantic-atmosphere,
.romantic-particles,
.premium-lights,
.scene-transition,
.light,
canvas {
  pointer-events: none !important;
}

@media (max-width: 760px) {
  #musicHitBox {
    width: 92px !important;
    height: 92px !important;
  }

  #musicToggleVisual {
    top: 12px !important;
    right: 12px !important;
    width: 52px !important;
    height: 52px !important;
    line-height: 48px !important;
  }
}


/* === INDEPENDENT AUDIO MUTE CONTROL - FINAL VERIFIED === */
#audioMuteLayer {
  position: fixed !important;
  top: 0 !important;
  right: 0 !important;
  width: 96px !important;
  height: 96px !important;
  z-index: 2147483647 !important;
  pointer-events: auto !important;
  touch-action: manipulation !important;
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  background: transparent !important;
  isolation: isolate !important;
}

#audioMuteButton {
  position: absolute !important;
  top: 14px !important;
  right: 14px !important;
  width: 54px !important;
  height: 54px !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 50% !important;
  border: 2px solid rgba(255,255,255,.88) !important;
  background: rgba(45,45,55,.92) !important;
  color: #fff !important;
  font-size: 24px !important;
  line-height: 50px !important;
  text-align: center !important;
  cursor: pointer !important;
  pointer-events: auto !important;
  touch-action: manipulation !important;
  user-select: none !important;
  -webkit-user-select: none !important;
  -webkit-tap-highlight-color: transparent !important;
  box-shadow: 0 0 22px rgba(255,120,185,.42) !important;
  z-index: 2147483647 !important;
}

#audioMuteButton.muted {
  opacity: .65 !important;
}

#audioMuteIcon {
  pointer-events: none !important;
}

/* Decorative/full-screen layers cannot block the independent audio control. */
#codeRain,
#stars,
.bg,
.orb,
.cinema-overlay,
.romantic-atmosphere,
.romantic-particles,
.premium-lights,
.scene-transition,
.light,
canvas[aria-hidden="true"] {
  pointer-events: none !important;
}

@media (max-width: 760px) {
  #audioMuteLayer {
    width: 92px !important;
    height: 92px !important;
  }

  #audioMuteButton {
    top: 12px !important;
    right: 12px !important;
    width: 52px !important;
    height: 52px !important;
    line-height: 48px !important;
  }
}


/* === GALLERY ONLY UPGRADE: ROMANTIC CINEMATIC ORBIT === */
#galleryPage .scene-card,
.gallery-sec .scene-card,
.gallery-scene,
.gallery-sec {
  position: relative !important;
  overflow: hidden !important;
}

.gallery-premium-aura {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}

.gallery-premium-aura span {
  position: absolute;
  width: 190px;
  height: 190px;
  border-radius: 50%;
  filter: blur(38px);
  opacity: .24;
  animation: galleryAuraFloat 9s ease-in-out infinite;
}

.gallery-premium-aura span:nth-child(1) {
  left: -70px;
  top: 18%;
  background: rgba(255, 120, 185, .75);
}

.gallery-premium-aura span:nth-child(2) {
  right: -70px;
  top: 30%;
  background: rgba(255, 226, 169, .55);
  animation-delay: -2.5s;
}

.gallery-premium-aura span:nth-child(3) {
  left: 38%;
  bottom: -90px;
  background: rgba(135, 80, 210, .62);
  animation-delay: -5s;
}

#galleryPage .eyebrow,
#galleryPage h2,
#galleryPage .sub,
#galleryPage .gallery-hint,
#galleryPage .orbit-gallery,
#galleryPage .active-memory-caption,
#galleryPage .page-actions,
.gallery-sec .eyebrow,
.gallery-sec h2,
.gallery-sec .sub,
.gallery-sec .gallery-hint,
.gallery-sec .orbit-gallery,
.gallery-sec .active-memory-caption,
.gallery-sec .page-actions {
  position: relative;
  z-index: 2;
}

.gallery-hint {
  margin: -2px auto 10px;
  font-size: .82rem;
  line-height: 1.4;
  color: rgba(255, 248, 252, .68);
  letter-spacing: .03em;
}

.orbit-gallery {
  border-radius: 32px !important;
  background:
    radial-gradient(circle at center, rgba(255,120,185,.10), transparent 44%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015)) !important;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 22px 70px rgba(0,0,0,.18);
}

.orbit-track {
  transform-style: preserve-3d;
}

.orbit-card {
  transform-style: preserve-3d !important;
  backface-visibility: hidden !important;
  will-change: transform, opacity, filter !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  background:
    linear-gradient(145deg, rgba(255,255,255,.18), rgba(255,255,255,.05)) !important;
  box-shadow:
    0 26px 68px rgba(0,0,0,.42),
    0 0 28px rgba(255,120,185,.10) !important;
}

.orbit-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    linear-gradient(120deg, transparent 15%, rgba(255,255,255,.28) 48%, transparent 72%);
  opacity: 0;
  transform: translateX(-120%);
  transition: opacity .45s ease;
}

.orbit-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background: linear-gradient(180deg, transparent 48%, rgba(10,3,12,.42) 100%);
}

.orbit-card.active-memory {
  box-shadow:
    0 34px 86px rgba(0,0,0,.52),
    0 0 34px rgba(255,120,185,.26),
    0 0 80px rgba(255,226,169,.08) !important;
  border-color: rgba(255,226,169,.45) !important;
}

.orbit-card.active-memory::before {
  opacity: 1;
  animation: galleryShine 3.4s ease-in-out infinite;
}

.orbit-card img {
  transition: transform 1.1s ease, filter .65s ease !important;
}

.orbit-card.active-memory img {
  transform: scale(1.055);
  filter: saturate(1.04) contrast(1.02);
}

.orbit-card:not(.active-memory) img {
  filter: saturate(.88) brightness(.86);
}

.gallery-control,
.gallery-arrow {
  transition:
    transform .25s ease,
    background .25s ease,
    opacity .25s ease !important;
}

.gallery-control:hover,
.gallery-arrow:hover {
  background: rgba(255,255,255,.22) !important;
}

.active-memory-caption,
.gallery-caption {
  transition: opacity .32s ease, transform .32s ease;
  min-height: 1.2em;
}

.active-memory-caption.caption-pop,
.gallery-caption.caption-pop {
  animation: captionPop .38s ease both;
}

@keyframes galleryAuraFloat {
  0%, 100% { transform: translate3d(0,0,0) scale(1); }
  50% { transform: translate3d(18px,-18px,0) scale(1.08); }
}

@keyframes galleryShine {
  0%, 55% { transform: translateX(-120%); opacity: 0; }
  65% { opacity: .72; }
  100% { transform: translateX(130%); opacity: 0; }
}

@keyframes captionPop {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

@media (max-width: 760px) {
  .gallery-hint {
    font-size: .72rem;
    margin-top: -4px;
    margin-bottom: 6px;
  }

  .orbit-gallery {
    border-radius: 26px !important;
  }

  .gallery-premium-aura span {
    width: 140px;
    height: 140px;
    filter: blur(30px);
  }
}


/* === GALLERY 3D DEPTH UPGRADE === */
.orbit-gallery {
  perspective: 1900px !important;
  transform-style: preserve-3d !important;
}

.orbit-track {
  transform-style: preserve-3d !important;
  perspective: 1900px !important;
  will-change: transform !important;
}

.orbit-card {
  transform-style: preserve-3d !important;
  transform-origin: center center !important;
  will-change: transform, opacity, filter !important;
}

.orbit-card.active-memory {
  box-shadow:
    0 38px 95px rgba(0,0,0,.58),
    0 0 42px rgba(255,120,185,.32),
    0 0 90px rgba(255,226,169,.12) !important;
}

.orbit-card.active-memory::after {
  background:
    linear-gradient(180deg, transparent 45%, rgba(10,3,12,.38) 100%),
    radial-gradient(circle at 50% 12%, rgba(255,255,255,.16), transparent 34%) !important;
}

.orbit-card.depth-left,
.orbit-card.depth-right {
  box-shadow:
    0 22px 54px rgba(0,0,0,.42),
    0 0 18px rgba(255,120,185,.08) !important;
}

.orbit-card.depth-back {
  opacity: .32 !important;
  filter: blur(1.6px) brightness(.72) saturate(.78) !important;
}

@media (max-width: 760px) {
  .orbit-gallery,
  .orbit-track {
    perspective: 1300px !important;
  }
}


/* === FINAL EXPERIENCE UPGRADE: CINEMATIC ROMANTIC POLISH === */
.soft-memory-particles {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

.soft-memory-particles span {
  position: absolute;
  width: 5px;
  height: 5px;
  border-radius: 999px;
  background: rgba(255, 226, 169, .74);
  box-shadow: 0 0 14px rgba(255, 226, 169, .50), 0 0 26px rgba(255, 120, 185, .28);
  opacity: .48;
  animation: romanticDust 12s ease-in-out infinite;
}

.soft-memory-particles span:nth-child(1) { left: 12%; top: 78%; animation-delay: 0s; }
.soft-memory-particles span:nth-child(2) { left: 28%; top: 18%; animation-delay: -2s; width: 4px; height: 4px; }
.soft-memory-particles span:nth-child(3) { left: 74%; top: 22%; animation-delay: -4s; }
.soft-memory-particles span:nth-child(4) { left: 86%; top: 70%; animation-delay: -6s; width: 6px; height: 6px; }
.soft-memory-particles span:nth-child(5) { left: 44%; top: 88%; animation-delay: -8s; }
.soft-memory-particles span:nth-child(6) { left: 58%; top: 12%; animation-delay: -10s; width: 3px; height: 3px; }

.depth-light {
  position: fixed;
  left: 0;
  top: 0;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  z-index: 0;
  pointer-events: none;
  transform: translate3d(calc(var(--light-x, 50vw) - 160px), calc(var(--light-y, 45vh) - 160px), 0);
  background: radial-gradient(circle, rgba(255, 226, 169, .14), rgba(255, 120, 185, .08) 35%, transparent 72%);
  filter: blur(18px);
  opacity: .78;
  transition: transform .18s ease-out, opacity .35s ease;
}

.page {
  transform-style: preserve-3d !important;
  backface-visibility: hidden !important;
  transition:
    opacity .62s cubic-bezier(.22,.8,.22,1),
    transform .62s cubic-bezier(.22,.8,.22,1),
    filter .62s cubic-bezier(.22,.8,.22,1),
    visibility .62s ease !important;
}

.page.is-exiting {
  opacity: 0 !important;
  transform: translate3d(0, 18px, -80px) scale(.985) !important;
  filter: blur(4px) brightness(.84) !important;
}

.page.active .scene-card,
.page.active .card,
.page.active .glass {
  animation: luxurySceneEnter .78s cubic-bezier(.2,.8,.2,1) both;
}

.scene-card,
.card,
.glass {
  position: relative;
}

.scene-card::after,
.card::after,
.glass::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(130deg, rgba(255,255,255,.12), transparent 22%, transparent 70%, rgba(255,255,255,.04));
  opacity: .62;
}

body.music-playing .scene-card,
body.music-playing .card,
body.music-playing .glass {
  box-shadow:
    0 30px 90px rgba(0,0,0,.42),
    0 0 34px rgba(255,120,185,.10),
    inset 0 1px 0 rgba(255,255,255,.08) !important;
}

.forever-line {
  margin: 16px auto 0;
  max-width: 420px;
  color: rgba(255, 226, 169, .86);
  font-size: .92rem;
  line-height: 1.55;
  letter-spacing: .03em;
  font-style: italic;
  animation: finalLineGlow 4s ease-in-out infinite;
}

.final-core,
.heart-core,
.gift-core {
  animation: premiumFloat 3.4s ease-in-out infinite, softHeartGlow 4s ease-in-out infinite !important;
}

.timeline-card,
.timeline-item {
  transform-style: preserve-3d;
  transition: transform .35s ease, background .35s ease, box-shadow .35s ease !important;
}

.timeline-card:hover,
.timeline-item:hover {
  transform: translateY(-6px) rotateX(3deg) rotateY(-3deg) !important;
  box-shadow: 0 26px 60px rgba(0,0,0,.32), 0 0 24px rgba(255,120,185,.13) !important;
}

@keyframes romanticDust {
  0%, 100% { transform: translate3d(0,0,0) scale(1); opacity: .30; }
  45% { opacity: .72; }
  50% { transform: translate3d(18px,-46px,0) scale(1.25); }
}

@keyframes luxurySceneEnter {
  0% { opacity: 0; transform: translate3d(0, 26px, -80px) scale(.97); filter: blur(6px); }
  100% { opacity: 1; transform: translate3d(0, 0, 0) scale(1); filter: blur(0); }
}

@keyframes softHeartGlow {
  0%, 100% { box-shadow: 0 18px 48px rgba(255,120,185,.22), 0 0 0 rgba(255,226,169,0); }
  50% { box-shadow: 0 22px 58px rgba(255,120,185,.32), 0 0 34px rgba(255,226,169,.14); }
}

@keyframes finalLineGlow {
  0%, 100% { opacity: .72; text-shadow: 0 0 0 rgba(255,226,169,0); }
  50% { opacity: 1; text-shadow: 0 0 18px rgba(255,226,169,.26); }
}

@media (max-width: 760px) {
  .depth-light {
    width: 220px;
    height: 220px;
    transform: translate3d(calc(var(--light-x, 50vw) - 110px), calc(var(--light-y, 45vh) - 110px), 0);
    opacity: .58;
  }

  .soft-memory-particles span {
    opacity: .38;
  }

  .forever-line {
    font-size: .82rem;
    margin-top: 12px;
  }
}

/* === ANNIVERSARY PREMIUM ULTIMATE EXPERIENCE UPGRADE === */
#premiumDepthLight{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.72;background:radial-gradient(circle at var(--light-x,50%) var(--light-y,45%),rgba(255,214,236,.18),rgba(255,120,185,.08) 18%,transparent 42%);mix-blend-mode:screen;transition:opacity .45s ease}
#softParticleLayer{position:fixed;inset:0;z-index:2;pointer-events:none;overflow:hidden}
.soft-particle{position:absolute;width:4px;height:4px;border-radius:999px;background:rgba(255,226,240,.72);box-shadow:0 0 14px rgba(255,120,185,.65);animation:softParticleDrift var(--dur,8s) ease-in-out infinite;opacity:.58}
.soft-particle.heart{width:auto;height:auto;background:transparent;box-shadow:none;color:rgba(255,226,240,.58);font-size:12px}
@keyframes softParticleDrift{0%{transform:translate3d(0,18px,0) scale(.8);opacity:0}18%{opacity:.58}50%{transform:translate3d(var(--dx,14px),-34px,0) scale(1);opacity:.7}100%{transform:translate3d(calc(var(--dx,14px) * -1),-86px,0) scale(.72);opacity:0}}
.page,.story-page{transition:opacity .72s cubic-bezier(.2,.8,.2,1),transform .72s cubic-bezier(.2,.8,.2,1),filter .72s cubic-bezier(.2,.8,.2,1),visibility .72s ease!important;transform-style:preserve-3d}
.page.is-exiting,.story-page.is-exiting{opacity:0!important;transform:translateY(16px) translateZ(-80px) scale(.982)!important;filter:blur(3px) brightness(.82)!important}
.page.active,.story-page.active{animation:luxurySceneIn .78s cubic-bezier(.2,.8,.2,1) both}
@keyframes luxurySceneIn{0%{opacity:0;transform:translateY(24px) translateZ(-70px) scale(.985);filter:blur(4px) brightness(1.08)}100%{opacity:1;transform:translateY(0) translateZ(0) scale(1);filter:blur(0) brightness(1)}}
.timeline-card,.timeline-item,.story-node{position:relative;overflow:hidden;transform-style:preserve-3d;transition:transform .45s cubic-bezier(.2,.8,.2,1),box-shadow .45s ease,border-color .45s ease!important}
.timeline-card::before,.timeline-item::before,.story-node::before{content:"";position:absolute;inset:-1px;border-radius:inherit;pointer-events:none;background:linear-gradient(120deg,transparent,rgba(255,226,169,.18),transparent);opacity:0;transform:translateX(-80%);transition:opacity .35s ease}
.timeline-card:hover,.timeline-item:hover,.story-node:hover{transform:translateY(-4px) rotateX(3deg) rotateY(-3deg);box-shadow:0 24px 60px rgba(0,0,0,.34),0 0 26px rgba(255,120,185,.16)!important;border-color:rgba(255,226,169,.28)!important}
.timeline-card:hover::before,.timeline-item:hover::before,.story-node:hover::before{opacity:1;animation:storyNodeShine 1.8s ease}
@keyframes storyNodeShine{from{transform:translateX(-80%)}to{transform:translateX(90%)}}
#galleryPage .scene-card,.gallery-sec .scene-card,.gallery-scene,.gallery-sec{position:relative!important;overflow:hidden!important}
.gallery-premium-aura{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0}
.gallery-premium-aura span{position:absolute;width:190px;height:190px;border-radius:50%;filter:blur(38px);opacity:.22;animation:galleryAuraFloat 9s ease-in-out infinite}
.gallery-premium-aura span:nth-child(1){left:-70px;top:18%;background:rgba(255,120,185,.75)}
.gallery-premium-aura span:nth-child(2){right:-70px;top:30%;background:rgba(255,226,169,.55);animation-delay:-2.5s}
.gallery-premium-aura span:nth-child(3){left:38%;bottom:-90px;background:rgba(135,80,210,.62);animation-delay:-5s}
.gallery-hint{position:relative;z-index:2;margin:-2px auto 10px;font-size:.8rem;line-height:1.4;color:rgba(255,248,252,.66);letter-spacing:.03em}
.orbit-gallery{position:relative;z-index:2;perspective:1900px!important;transform-style:preserve-3d!important;border-radius:32px!important;background:radial-gradient(circle at center,rgba(255,120,185,.10),transparent 44%),linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.015))!important;border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 22px 70px rgba(0,0,0,.18)}
.orbit-track{transform-style:preserve-3d!important;perspective:1900px!important;will-change:transform!important}
.orbit-card{transform-style:preserve-3d!important;transform-origin:center center!important;backface-visibility:hidden!important;will-change:transform,opacity,filter!important;border:1px solid rgba(255,255,255,.18)!important;background:linear-gradient(145deg,rgba(255,255,255,.18),rgba(255,255,255,.05))!important;box-shadow:0 26px 68px rgba(0,0,0,.42),0 0 28px rgba(255,120,185,.10)!important}
.orbit-card::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(120deg,transparent 15%,rgba(255,255,255,.26) 48%,transparent 72%);opacity:0;transform:translateX(-120%)}
.orbit-card::after{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;background:linear-gradient(180deg,transparent 45%,rgba(10,3,12,.38) 100%),radial-gradient(circle at 50% 12%,rgba(255,255,255,.12),transparent 34%)}
.orbit-card.active-memory{box-shadow:0 38px 95px rgba(0,0,0,.58),0 0 42px rgba(255,120,185,.32),0 0 90px rgba(255,226,169,.12)!important;border-color:rgba(255,226,169,.45)!important}
.orbit-card.active-memory::before{opacity:1;animation:galleryShine 3.4s ease-in-out infinite}
.orbit-card img{transition:transform 1.1s ease,filter .65s ease!important;will-change:transform}
.orbit-card.active-memory img{transform:scale(1.065) translate3d(var(--photo-x,0px),var(--photo-y,0px),0);filter:saturate(1.04) contrast(1.02)}
.orbit-card:not(.active-memory) img{filter:saturate(.88) brightness(.86)}
.orbit-card.depth-back{opacity:.34!important;filter:blur(1.5px) brightness(.74) saturate(.8)!important}
.active-memory-caption,.gallery-caption{transition:opacity .32s ease,transform .32s ease;min-height:1.2em}
.active-memory-caption.caption-pop,.gallery-caption.caption-pop{animation:captionPop .38s ease both}
@keyframes galleryAuraFloat{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(18px,-18px,0) scale(1.08)}}
@keyframes galleryShine{0%,55%{transform:translateX(-120%);opacity:0}65%{opacity:.62}100%{transform:translateX(130%);opacity:0}}
@keyframes captionPop{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:760px){#premiumDepthLight{opacity:.58}.gallery-hint{font-size:.72rem;margin-top:-4px;margin-bottom:6px}.orbit-gallery,.orbit-track{perspective:1300px!important}.orbit-gallery{border-radius:26px!important}.gallery-premium-aura span{width:140px;height:140px;filter:blur(30px)}}


/* === BIRTHDAY PREMIUM BRIGHT MOOD OVERRIDE === */
:root{
--birthday-pink:#ff77c8;
--birthday-gold:#ffd978;
--birthday-purple:#8b6dff;
}

body{
filter:saturate(1.06) brightness(1.03);
}

#premiumDepthLight{
background:
radial-gradient(circle at var(--light-x,50%) var(--light-y,45%),
rgba(255,230,150,.18),
rgba(255,119,200,.12) 18%,
transparent 42%) !important;
}

.gallery-premium-aura span:nth-child(1){
background:rgba(255,119,200,.82)!important;
}

.gallery-premium-aura span:nth-child(2){
background:rgba(255,217,120,.72)!important;
}

.gallery-premium-aura span:nth-child(3){
background:rgba(139,109,255,.68)!important;
}

.soft-particle{
background:rgba(255,240,170,.85)!important;
box-shadow:0 0 16px rgba(255,119,200,.55)!important;
}

.orbit-gallery{
background:
radial-gradient(circle at center, rgba(255,119,200,.12), transparent 44%),
linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)) !important;
}

.orbit-card.active-memory{
box-shadow:
0 38px 95px rgba(0,0,0,.45),
0 0 42px rgba(255,119,200,.34),
0 0 90px rgba(255,217,120,.18)!important;
}

