*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --gold:#c9a96e;--gold-l:#ecdeb4;--gold-d:#7a5a18;
  --rose:#6b1535;--blush:#f4c2d0;--ivory:#fdf6ee;
  --deep:#04010a;--champ:#f7e7ce;
}

html,body{width:100%;height:100%;overflow:hidden;
  background:var(--deep);font-family:'Cormorant Garamond',serif;
  color:var(--ivory);cursor:none}

.cur{position:fixed;width:26px;height:26px;
  border:1.5px solid rgba(201,169,110,.75);border-radius:50%;
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .18s,height .18s,border-color .3s;mix-blend-mode:screen}
.cur2{position:fixed;width:5px;height:5px;background:var(--gold);
  border-radius:50%;pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);transition:transform .06s}

#bgCanvas{position:fixed;inset:0;pointer-events:none;z-index:1}

#photoBg{
  position:fixed;
  inset:0;
  z-index:2;
  background:var(--deep);
  display:flex;
  justify-content:center;
  align-items:flex-end; 
  opacity:0;
  transition:none;
  will-change:transform,opacity,filter;
}

.main-photo{
  height:100%;
  width:100%;
  object-fit:cover;
  transform:translateX(0);
  transform: translateY(4%);
  filter: drop-shadow(0 25px 50px rgba(0, 0, 0, 0.264));
}

#photoBg .ph-grad{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 80% at 40% 50%,rgba(120,60,80,.55) 0%,transparent 65%),
    radial-gradient(ellipse 80% 80% at 60% 50%,rgba(30,8,20,.9) 0%,transparent 70%),
    linear-gradient(135deg,#1a0510 0%,#0d0208 40%,#180a14 100%);
}
#photoBg .ph-silhouette{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
}
#photoBg .ph-silhouette svg{opacity:.18}

#photoOverlay{
  position:fixed;inset:0;z-index:3;
  background:rgba(4,1,10,0);
  transition:background 1.6s ease;
  pointer-events:none;
}

#vignette{
  position:fixed;inset:0;z-index:4;pointer-events:none;
  background:radial-gradient(ellipse 80% 80% at 50% 50%,transparent 30%,rgba(4,1,10,.72) 100%);
  opacity:0;transition:opacity 1.5s ease;
}

#doorsStage{
  position:fixed;inset:0;z-index:10;
  perspective:1800px;perspective-origin:50% 48%;
  pointer-events:none;
}
#doorsStage.active{pointer-events:all}

.door{
  position:absolute;top:0;height:100%;width:50%;
  transform-style:preserve-3d;backface-visibility:hidden;
  will-change:transform;
  transition:transform 3.2s cubic-bezier(.77,0,.13,1),box-shadow 3.2s ease;
}
.door-l{
  left:0;transform-origin:0% 50%;transform:rotateY(0deg);
  border-right:1px solid rgba(201,169,110,.5);
  box-shadow:inset -40px 0 80px rgba(0,0,0,.5);
}
.door-r{
  right:0;transform-origin:100% 50%;transform:rotateY(0deg);
  border-left:1px solid rgba(201,169,110,.5);
  box-shadow:inset 40px 0 80px rgba(0,0,0,.5);
}
#doorsStage.open .door-l{transform:rotateY(-92deg)}
#doorsStage.open .door-r{transform:rotateY(92deg)}

.door-face{
  position:absolute;inset:0;
  background:linear-gradient(180deg,#1e0c08 0%,#120504 35%,#0e0303 65%,#1c0907 100%);
}

.door-grain{
  position:absolute;inset:0;opacity:.06;
  background:repeating-linear-gradient(
    88deg,
    transparent 0,transparent 2px,
    rgba(180,120,60,.3) 2px,rgba(180,120,60,.3) 3px
  );
}
.door-sheen{
  position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(255,255,255,0) 0%,rgba(255,255,255,.04) 50%,rgba(255,255,255,0) 100%);
  animation:sheen 6s ease-in-out infinite;
}
@keyframes sheen{0%,100%{opacity:.3}50%{opacity:1}}

.mol{position:absolute;border:1px solid rgba(201,169,110,.25);pointer-events:none}
.mol1{top:1.4rem;bottom:1.4rem;left:1.4rem;right:1.4rem}
.mol2{top:2rem;bottom:2rem;left:2rem;right:2rem}
.mol3{top:2.6rem;bottom:2.6rem;left:2.6rem;right:2.6rem;border-color:rgba(201,169,110,.1)}

.door-arch{
  position:absolute;top:0;left:0;right:0;height:120px;
  background:linear-gradient(180deg,rgba(201,169,110,.12) 0%,transparent 100%);
}

.door-floor{
  position:absolute;bottom:0;left:0;right:0;height:80px;
  background:linear-gradient(0deg,rgba(0,0,0,.5) 0%,transparent 100%);
}

.d-edge{
  position:absolute;top:0;bottom:0;width:2px;
  background:linear-gradient(180deg,transparent 0%,var(--gold-d) 15%,var(--gold) 50%,var(--gold-d) 85%,transparent 100%);
}
.door-l .d-edge{right:0}.door-r .d-edge{left:0}

.d-handle-wrap{
  position:absolute;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
}
.door-l .d-handle-wrap{right:1.8rem}
.door-r .d-handle-wrap{left:1.8rem}
.d-handle{
  width:10px;height:52px;
  background:linear-gradient(180deg,var(--gold-d),var(--gold),var(--gold-l) 50%,var(--gold),var(--gold-d));
  border-radius:12px;
  box-shadow:0 0 14px rgba(201,169,110,.35),inset 0 0 4px rgba(255,255,255,.1);
}
.d-ring{
  width:24px;height:24px;border:1.5px solid var(--gold);border-radius:50%;
  box-shadow:0 0 8px rgba(201,169,110,.3);
}

.door-svg{position:absolute;inset:0;width:100%;height:100%;opacity:.45;pointer-events:none}

#scenesRoot{
  position:fixed;inset:0;z-index:20;pointer-events:none;
}

.scene{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:none;
}
.scene.on{pointer-events:all}

#s0{flex-direction:column;text-align:center;align-items:center;background:transparent}

.s0-crown{
  opacity:0;animation:crownIn 1.8s .1s cubic-bezier(.34,1.56,.64,1) both;
  filter:drop-shadow(0 0 30px rgba(201,169,110,.9));
  margin-bottom:1.6rem;
}
.s0-crown svg{animation:float 5s ease-in-out infinite}

.s0-tag{
  font-family:'Cinzel',serif;font-size:.62rem;letter-spacing:.7em;
  color:var(--gold);text-transform:uppercase;
  opacity:0;animation:fadeUp 1.2s .5s both;margin-bottom:1.6rem;
}
.s0-name{
  font-family:'Great Vibes',cursive;
  font-size:clamp(5rem,13vw,12rem);line-height:1;
  color:#fff;
  text-shadow:0 0 40px rgba(255,255,255,.3),0 2px 60px rgba(201,169,110,.3);
  opacity:0;animation:fadeUp 1.8s .7s both,namePulse 6s 2.5s ease-in-out infinite;
}
.s0-rule{
  display:flex;align-items:center;gap:1.5rem;
  width:min(400px,85vw);margin:1.6rem auto;
  opacity:0;animation:fadeUp 1.2s 1s both;
}
.s0-rule hr{flex:1;border:none;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-d),var(--gold),var(--gold-d),transparent)}
.s0-rule i{color:var(--gold);font-style:normal}
.s0-xv{
  font-family:'Cinzel',serif;font-size:clamp(.7rem,1.8vw,.95rem);letter-spacing:.5em;
  color:var(--gold-l);text-transform:uppercase;
  opacity:0;animation:fadeUp 1.2s 1.1s both;
}
.s0-date{
  font-size:1.1rem;font-style:italic;color:rgba(244,194,208,.65);
  margin-top:.5rem;opacity:0;animation:fadeUp 1.2s 1.3s both;
}
.s0-hint{
  position:absolute;bottom:3rem;
  display:flex;flex-direction:column;align-items:center;gap:.8rem;
  opacity:0;animation:fadeIn 1s 2.4s both;
}
.s0-hint span{font-family:'Cinzel',serif;font-size:.52rem;letter-spacing:.45em;color:rgba(201,169,110,.6);text-transform:uppercase}
.s0-arr{width:16px;height:16px;border-right:1px solid var(--gold);border-bottom:1px solid var(--gold);transform:rotate(45deg);animation:arrowB 1.6s ease-in-out infinite}

#s1{flex-direction:column;text-align:center;justify-content:flex-end;padding-bottom:8vh;background:transparent}
.s1-caption{
  opacity:0;transform:translateY(30px);
  transition:opacity 1.6s 1.8s ease,transform 1.6s 1.8s cubic-bezier(.25,.46,.45,.94);
}
.s1-caption.show{opacity:1;transform:translateY(0)}
.s1-name{
  font-family:'Great Vibes',cursive;font-size:clamp(4rem,10vw,9rem);
  color:#fff;line-height:1;
  text-shadow:0 4px 40px rgba(0,0,0,.8),0 0 80px rgba(201,169,110,.25);
}
.s1-sub{
  font-family:'Cinzel',serif;font-size:clamp(.6rem,1.4vw,.78rem);
  letter-spacing:.55em;color:var(--gold-l);text-transform:uppercase;margin-top:.8rem;
}
.s1-line{
  width:180px;height:1px;margin:.9rem auto;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:0;transition:opacity 1.4s 2.4s ease;
}
.s1-line.show{opacity:1}

#s2,#s3,#s4{
  flex-direction:column;
  background:transparent;
}

.glass{
  background:rgba(4,1,10,.72);
  border:1px solid rgba(201,169,110,.18);
  padding:3rem 3.5rem;
  position:relative;
  width:min(700px,92vw);
}
.glass::before{
  content:'';position:absolute;inset:8px;
  border:1px solid rgba(201,169,110,.07);pointer-events:none;
}

.glass .ga{position:absolute;width:28px;height:28px;border-color:var(--gold);border-style:solid;opacity:.55}
.glass .ga.tl{top:-1px;left:-1px;border-width:1.5px 0 0 1.5px}
.glass .ga.tr{top:-1px;right:-1px;border-width:1.5px 1.5px 0 0}
.glass .ga.bl{bottom:-1px;left:-1px;border-width:0 0 1.5px 1.5px}
.glass .ga.br{bottom:-1px;right:-1px;border-width:0 1.5px 1.5px 0}

.stitle{font-family:'Great Vibes',cursive;font-size:clamp(2.8rem,6vw,5rem);color:var(--champ);text-shadow:0 0 30px rgba(201,169,110,.25);margin-bottom:.3rem;line-height:1.1}
.ssub{font-family:'Cinzel',serif;font-size:.6rem;letter-spacing:.5em;color:var(--gold);text-transform:uppercase;margin-bottom:2.5rem}

.scene-in{
  opacity:1;
  transform:none;
}
.scene-entering .scene-in{
  animation:sceneInAnim .8s forwards;
}
@keyframes sceneInAnim{
  from{opacity:0;transform:translateY(40px) scale(.97)}
  to{opacity:1;transform:none}
}

.cd-grid{display:flex;gap:1.2rem;align-items:center;justify-content:center;flex-wrap:wrap}
.cd-cell{display:flex;flex-direction:column;align-items:center;gap:.5rem}
.cd-num{
  width:100px;height:100px;display:flex;align-items:center;justify-content:center;
  font-family:'Cormorant Garamond',serif;font-size:3.6rem;font-weight:300;color:var(--gold-l);
  border:1px solid rgba(201,169,110,.22);position:relative;
  text-shadow:0 0 20px rgba(201,169,110,.35);
  background:rgba(201,169,110,.04);
}
.cd-num::before{content:'';position:absolute;inset:6px;border:1px solid rgba(201,169,110,.07)}
.cd-lbl{font-family:'Cinzel',serif;font-size:.55rem;letter-spacing:.3em;color:var(--blush);text-transform:uppercase}
.cd-sep{font-size:2.5rem;color:rgba(201,169,110,.25);font-weight:200;padding-bottom:1.2rem}

.prog{position:relative;text-align:left;margin-top:.5rem}
.prog::before{
  content:'';position:absolute;left:4.5rem;top:0;bottom:0;width:1px;
  background:linear-gradient(to bottom,transparent,var(--gold),rgba(201,169,110,.2),transparent);
}
.pi{
  display:flex;gap:1.6rem;align-items:flex-start;padding:.9rem 0;
  border-bottom:1px solid rgba(201,169,110,.06);
  opacity:1;
}
.scene-entering .pi{animation:piAnim .6s forwards}
@keyframes piAnim{from{opacity:0;transform:translateX(-22px)}to{opacity:1;transform:none}}
.scene-entering .pi:nth-child(1){animation-delay:.3s}
.scene-entering .pi:nth-child(2){animation-delay:.45s}
.scene-entering .pi:nth-child(3){animation-delay:.6s}
.scene-entering .pi:nth-child(4){animation-delay:.75s}
.scene-entering .pi:nth-child(5){animation-delay:.9s}
.pi-t{font-family:'Cinzel',serif;font-size:.58rem;letter-spacing:.15em;color:var(--gold);width:4.5rem;flex-shrink:0;padding-top:.2rem;text-align:right}
.pi-dot{width:9px;height:9px;border:1.5px solid var(--gold);border-radius:50%;flex-shrink:0;margin-top:.28rem;z-index:1;background:rgba(4,1,10,.8);box-shadow:0 0 10px rgba(201,169,110,.6)}
.pi-name{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:600;color:var(--champ)}
.pi-desc{font-family:'Cinzel',serif;font-size:.55rem;color:rgba(244,194,208,.5);letter-spacing:.14em;margin-top:.15rem}

.ri{
  width:100%;background:transparent;border:none;
  border-bottom:1px solid rgba(201,169,110,.2);
  padding:.85rem 0;color:var(--ivory);
  font-family:'Cormorant Garamond',serif;font-size:1.05rem;
  outline:none;transition:border-color .3s;margin-bottom:1.1rem;display:block;
}
.ri:focus{border-bottom-color:var(--gold)}
.ri::placeholder{color:rgba(253,246,238,.2);font-style:italic}
.rb{
  width:100%;padding:1.05rem;background:transparent;
  border:1px solid rgba(201,169,110,.5);
  color:var(--champ);font-family:'Cinzel',serif;
  font-size:.65rem;letter-spacing:.4em;text-transform:uppercase;
  cursor:pointer;transition:all .5s;position:relative;overflow:hidden;margin-top:.3rem;
}
.rb::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(201,169,110,0),rgba(201,169,110,.15),rgba(201,169,110,0));
  transform:translateX(-100%);transition:transform .6s ease;
}
.rb:hover::after{transform:translateX(100%)}
.rb:hover{border-color:var(--gold);box-shadow:0 0 30px rgba(201,169,110,.2),inset 0 0 20px rgba(201,169,110,.05)}
.rb span{position:relative;z-index:1}

.nav-dots{
  position:fixed;right:2rem;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;gap:.85rem;z-index:200;
}
.nd{
  width:7px;height:7px;border-radius:50%;
  border:1px solid rgba(201,169,110,.35);cursor:pointer;
  transition:all .4s ease;position:relative;
}
.nd::before{
  content:'';position:absolute;inset:-5px;border-radius:50%;
}
.nd.on{
  background:var(--gold);border-color:var(--gold);
  box-shadow:0 0 14px rgba(201,169,110,.8),0 0 28px rgba(201,169,110,.3);
}

.sc-label{
  position:fixed;left:2.5rem;bottom:2.5rem;z-index:200;
  font-family:'Cinzel',serif;font-size:.52rem;letter-spacing:.38em;
  color:rgba(201,169,110,.45);text-transform:uppercase;pointer-events:none;
  transition:opacity .6s ease;
}

#flash{
  position:fixed;inset:0;z-index:15;pointer-events:none;
  background:rgba(201,169,110,0);transition:background .0s;
}

@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes crownIn{from{opacity:0;transform:translateY(-50px) scale(.6)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes float{0%,100%{transform:translateY(0) rotate(-1.5deg)}50%{transform:translateY(-10px) rotate(1.5deg)}}
@keyframes arrowB{0%,100%{transform:rotate(45deg)}50%{transform:rotate(45deg) translate(4px,4px)}}
@keyframes namePulse{
  0%,100%{text-shadow:0 0 40px rgba(255,255,255,.3),0 2px 60px rgba(201,169,110,.3)}
  50%{text-shadow:0 0 70px rgba(255,255,255,.4),0 2px 100px rgba(201,169,110,.45)}
}

@media(max-width:600px){
  .cd-num{width:74px;height:74px;font-size:2.6rem}
  .cd-sep{display:none}
  .glass{padding:2rem 1.5rem}
  .prog::before{left:3.8rem}
  .pi-t{width:3.8rem;font-size:.5rem}
  .nav-dots{right:1rem}
}