/* ════════════════════════════════════════════
   BIRTHDAY GATSBY — Stylesheet
   Template: Art Deco / Great Gatsby
   ════════════════════════════════════════════ */

/* ═══ DARK THEME (Default) ═══ */
:root {
  --black:#0a0a0a; --rich:#111111; --dark:#1a1a1a; --mid:#2d2d2d;
  --grey:#666666;  --silver:#aaaaaa; --light:#e0e0e0; --white:#f5f5f0;
  --cream:#faf8f2; --gold:#c9a84c;  --gold2:#e8cc80;  --gold3:#f5e4a0;
}

/* ═══ LIGHT THEME ═══ */
html[data-theme="light"] {
  --black:#f5f0e6; --rich:#ede7d8; --dark:#e0d8c8; --mid:#c4b89c;
  --grey:#7a6e58;  --silver:#5c5040; --light:#2a1e0c; --white:#1a0e00;
  --cream:#faf6ed; --gold:#8a6010;  --gold2:#6a4800;  --gold3:#4a2c00;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--black);
  font-family:'Josefin Sans',sans-serif;
  color:var(--light);
  overflow-x:hidden;
  cursor:none;
}

/* ═══ GRAIN ═══ */
#grain{
  position:fixed;inset:0;z-index:999;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:256px 256px;
  animation:grainMove 8s steps(10) infinite;
}
@keyframes grainMove{0%{transform:translate(0,0)}10%{transform:translate(-5%,-10%)}30%{transform:translate(3%,5%)}50%{transform:translate(-3%,8%)}70%{transform:translate(5%,-5%)}80%{transform:translate(-4%,3%)}100%{transform:translate(0,0)}}

/* ═══ VIGNETTE ═══ */
#vignette{
  position:fixed;inset:0;z-index:998;pointer-events:none;
  background:radial-gradient(ellipse 80% 80% at 50% 50%,transparent 40%,rgba(0,0,0,.6) 100%);
}

/* ═══ CURSOR ═══ */
#cur{
  position:fixed;z-index:9999;pointer-events:none;
  width:6px;height:6px;background:var(--gold);
  clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);
  transform:translate(-50%,-50%);
  transition:width .15s,height .15s;
  box-shadow:0 0 8px rgba(201,168,76,.6);
}
#cur-outer{
  position:fixed;z-index:9998;pointer-events:none;
  width:28px;height:28px;
  border:1px solid rgba(201,168,76,.5);
  border-radius:50%;
  transform:translate(-50%,-50%);
  transition:all .1s ease;
}
#cur-outer::before,#cur-outer::after{
  content:'';position:absolute;background:rgba(201,168,76,.4);
}
#cur-outer::before{width:1px;height:8px;top:-6px;left:50%;transform:translateX(-50%)}
#cur-outer::after{width:8px;height:1px;left:-6px;top:50%;transform:translateY(-50%)}

/* ═══ GOLD TRAIL ═══ */
.gold-trail{
  position:fixed;z-index:997;pointer-events:none;
  width:3px;height:3px;
  clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);
  background:var(--gold2);
  transform:translate(-50%,-50%);
  animation:trailFade .5s ease-out forwards;
}
@keyframes trailFade{
  0%{opacity:.8;transform:translate(-50%,-50%) scale(1)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(0)}
}

/* ═══ ART DECO BG ═══ */
#deco-bg{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 50% 0%,rgba(201,168,76,.04) 0%,transparent 60%),
    radial-gradient(ellipse at 0% 100%,rgba(201,168,76,.03) 0%,transparent 40%),
    radial-gradient(ellipse at 100% 100%,rgba(201,168,76,.03) 0%,transparent 40%),
    var(--black);
}
#deco-chevron{
  position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.025;
  background-image:
    repeating-linear-gradient(45deg,var(--gold) 0,var(--gold) 1px,transparent 1px,transparent 20px),
    repeating-linear-gradient(-45deg,var(--gold) 0,var(--gold) 1px,transparent 1px,transparent 20px);
}
#spotlight{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse 600px 600px at var(--sx,50%) var(--sy,30%),rgba(201,168,76,.04),transparent 70%);
  transition:background .3s ease;
}

/* ═══ COVER ═══ */
#cover{
  position:fixed;inset:0;z-index:200;
  display:flex;align-items:center;justify-content:center;
  background:var(--black);overflow:hidden;
  transition:opacity 1.8s ease;
}
#cover.gone{opacity:0;pointer-events:none;}
#cover.flicker{animation:projectorFlicker .3s steps(2) 3;}
@keyframes projectorFlicker{0%,100%{opacity:1}50%{opacity:.4}}

.film-strip{
  position:absolute;width:1px;
  background:linear-gradient(180deg,transparent,rgba(201,168,76,.2),transparent);
  animation:filmFall linear infinite;pointer-events:none;
}
@keyframes filmFall{0%{transform:translateY(-100%);opacity:0}10%{opacity:1}90%{opacity:.5}100%{transform:translateY(100vh);opacity:0}}

.beam{
  position:absolute;top:0;width:60px;
  background:linear-gradient(180deg,rgba(255,255,255,.04),transparent);
  transform-origin:top center;pointer-events:none;
  animation:beamSway ease-in-out infinite alternate;
}
@keyframes beamSway{0%{transform:skewX(-8deg)}100%{transform:skewX(8deg)}}

.cover-inner{width:min(440px,92vw);position:relative;text-align:center;}
.frame-outer{position:absolute;inset:-20px;border:1px solid rgba(201,168,76,.15);pointer-events:none;}
.frame-outer::before{content:'';position:absolute;inset:6px;border:1px solid rgba(201,168,76,.08);}
.frame-outer::after{
  content:'';position:absolute;inset:0;
  background:
    linear-gradient(90deg,transparent 20%,var(--gold) 50%,transparent 80%) top/200% 1px no-repeat,
    linear-gradient(90deg,transparent 20%,var(--gold) 50%,transparent 80%) bottom/200% 1px no-repeat,
    linear-gradient(180deg,transparent 20%,var(--gold) 50%,transparent 80%) left/1px 200% no-repeat,
    linear-gradient(180deg,transparent 20%,var(--gold) 50%,transparent 80%) right/1px 200% no-repeat;
  animation:frameSweep 4s linear infinite;
}
@keyframes frameSweep{0%{background-position:200% top,-200% bottom,left -200%,right 200%}100%{background-position:-200% top,200% bottom,left 200%,right -200%}}

.deco-corner{position:absolute;width:30px;height:30px;pointer-events:none;}
.dc::before,.dc::after{content:'';position:absolute;background:var(--gold);}
.dc::before{width:100%;height:1px;top:0;}
.dc::after{width:1px;height:100%;left:0;}
.dc.tl{top:-20px;left:-20px;}.dc.tr{top:-20px;right:-20px;transform:scaleX(-1);}
.dc.bl{bottom:-20px;left:-20px;transform:scaleY(-1);}.dc.br{bottom:-20px;right:-20px;transform:scale(-1);}
.dc-dot{position:absolute;width:6px;height:6px;background:var(--gold);clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);}
.dc.tl .dc-dot{bottom:0;right:0;}.dc.tr .dc-dot{bottom:0;left:0;}
.dc.bl .dc-dot{top:0;right:0;}.dc.br .dc-dot{top:0;left:0;}

.cover-card{
  padding:56px 40px 48px;
  background:linear-gradient(165deg,#141414,#0a0a0a);
  border:1px solid rgba(201,168,76,.2);
  position:relative;overflow:hidden;
  box-shadow:0 0 0 1px rgba(201,168,76,.06),0 40px 100px rgba(0,0,0,.8),0 0 60px rgba(0,0,0,.5),inset 0 0 60px rgba(0,0,0,.4);
  transform-style:preserve-3d;
  animation:cardSway 6s ease-in-out infinite;
  transition:transform .25s ease;
}
@keyframes cardSway{0%,100%{transform:rotateX(3deg) rotateY(0) translateY(0)}33%{transform:rotateX(2deg) rotateY(3deg) translateY(-10px)}66%{transform:rotateX(4deg) rotateY(-2deg) translateY(-8px)}}
.cover-card::after{
  content:'';position:absolute;left:0;right:0;height:80px;
  background:linear-gradient(180deg,transparent,rgba(201,168,76,.02),transparent);
  animation:scanDown 6s linear infinite;top:0;pointer-events:none;
}
@keyframes scanDown{0%{top:-80px}100%{top:100%}}

.cover-year{font-family:'Josefin Sans',sans-serif;font-size:.55rem;font-weight:100;letter-spacing:1em;color:rgba(201,168,76,.5);display:block;margin-bottom:20px;text-transform:uppercase;}
.deco-top{display:block;margin:0 auto 18px;width:200px;filter:drop-shadow(0 0 8px rgba(201,168,76,.3));}
.cover-presents{font-size:.52rem;font-weight:200;letter-spacing:.8em;color:var(--grey);text-transform:uppercase;display:block;margin-bottom:10px;}
.cover-title-pre{font-family:'Playfair Display',serif;font-size:.75rem;font-style:italic;font-weight:400;color:var(--silver);letter-spacing:.3em;display:block;margin-bottom:4px;}
.cover-name{font-family:'Playfair Display',serif;font-size:clamp(2.5rem,8vw,3.8rem);font-weight:900;font-style:italic;display:block;line-height:1;color:var(--white);text-shadow:0 0 30px rgba(255,255,255,.08);letter-spacing:.04em;position:relative;}
.cover-name::after{content:'';position:absolute;bottom:-4px;left:50%;transform:translateX(-50%);width:80%;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);}
.cover-roman{font-family:'Playfair Display',serif;font-size:clamp(1rem,3.5vw,1.5rem);font-weight:400;font-style:italic;color:var(--gold);display:block;margin:12px 0;letter-spacing:.3em;text-shadow:0 0 20px rgba(201,168,76,.4);animation:goldPulse 3s ease-in-out infinite alternate;}
@keyframes goldPulse{0%{text-shadow:0 0 15px rgba(201,168,76,.3)}100%{text-shadow:0 0 30px rgba(201,168,76,.7),0 0 60px rgba(201,168,76,.2)}}

.deco-rule{display:flex;align-items:center;gap:12px;margin:16px 0;}
.deco-rule::before,.deco-rule::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.4),transparent);}
.deco-rule-mid{display:flex;gap:6px;align-items:center;}
.deco-rule-mid span{width:5px;height:5px;clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);background:var(--gold);box-shadow:0 0 6px rgba(201,168,76,.5);}
.deco-rule-mid span:nth-child(2){width:8px;height:8px;}

.cover-info{font-size:.58rem;font-weight:200;letter-spacing:.5em;color:var(--silver);text-transform:uppercase;display:block;margin:12px 0 24px;line-height:2;}

/* Cover kepada guest */
.cover-kepada{margin:0 0 18px;padding:14px 20px;border:1px solid rgba(201,168,76,.15);background:rgba(201,168,76,.04);}
.cover-label{font-size:.45rem;font-weight:100;letter-spacing:.6em;color:var(--gold);text-transform:uppercase;margin-bottom:6px;}
.cover-guest-name{font-family:'Playfair Display',serif;font-size:1.1rem;font-style:italic;color:var(--light);}

.enter-btn{
  display:inline-block;padding:12px 44px;background:transparent;border:1px solid var(--gold);
  color:var(--gold);font-family:'Josefin Sans',sans-serif;font-size:.58rem;font-weight:300;
  letter-spacing:.6em;text-transform:uppercase;cursor:none;
  position:relative;overflow:hidden;transition:color .4s,box-shadow .4s;
  box-shadow:0 0 20px rgba(201,168,76,.08);text-shadow:0 0 10px rgba(201,168,76,.3);
}
.enter-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(201,168,76,.15),rgba(232,204,128,.1));transform:translateX(-100%);transition:transform .5s ease;}
.enter-btn:hover::before{transform:translateX(0);}
.enter-btn:hover{color:var(--gold2);box-shadow:0 0 40px rgba(201,168,76,.25);}
.enter-btn span{position:relative;z-index:1;}

.film-circles{display:flex;justify-content:center;gap:10px;margin-top:20px;}
.film-circle{width:28px;height:28px;border-radius:50%;border:1px solid rgba(201,168,76,.2);display:flex;align-items:center;justify-content:center;font-size:.5rem;font-weight:100;letter-spacing:.05em;color:rgba(201,168,76,.4);animation:circleGlow 2s ease-in-out infinite alternate;}
.film-circle:nth-child(1){animation-delay:0s}.film-circle:nth-child(2){animation-delay:.3s}
.film-circle:nth-child(3){animation-delay:.6s}.film-circle:nth-child(4){animation-delay:.9s;border-color:rgba(201,168,76,.5);color:var(--gold);box-shadow:0 0 12px rgba(201,168,76,.3);}
.film-circle:nth-child(5){animation-delay:1.2s}
@keyframes circleGlow{0%{opacity:.4}100%{opacity:1}}

/* ═══ MAIN ═══ */
#main{position:relative;z-index:2;opacity:0;pointer-events:none;transition:opacity 1s ease;}
#main.on{opacity:1;pointer-events:all;}

/* ═══ NAV ═══ */
nav{position:fixed;top:0;left:0;right:0;z-index:100;opacity:0;transition:opacity .6s;}
nav.on{opacity:1;}
.nav-top-line{height:2px;background:linear-gradient(90deg,transparent,var(--gold),var(--gold2),var(--gold),transparent);background-size:200%;animation:frameSweep 4s linear infinite;}
.nav-inner{background:rgba(10,10,10,.92);backdrop-filter:blur(16px);display:flex;justify-content:center;align-items:center;gap:0;padding:0 20px;border-bottom:1px solid rgba(201,168,76,.08);}
.nav-inner a{font-size:.5rem;font-weight:200;letter-spacing:.5em;color:var(--grey);text-transform:uppercase;text-decoration:none;padding:14px 18px;border-right:1px solid rgba(201,168,76,.08);transition:all .3s;position:relative;}
.nav-inner a:first-child{border-left:1px solid rgba(201,168,76,.08);}
.nav-inner a::after{content:'';position:absolute;bottom:0;left:20%;right:20%;height:1px;background:var(--gold);transform:scaleX(0);transition:transform .3s;}
.nav-inner a:hover{color:var(--gold2);}
.nav-inner a:hover::after{transform:scaleX(1);}
.nav-bottom-line{height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.2),transparent);}

/* ═══ SECTIONS ═══ */
section{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:110px 24px 80px;overflow:hidden;}

/* DECO BADGE */
.deco-badge{display:inline-flex;align-items:center;gap:12px;padding:7px 22px;border:1px solid rgba(201,168,76,.25);font-size:.5rem;font-weight:200;letter-spacing:.6em;color:var(--gold);text-transform:uppercase;margin-bottom:18px;position:relative;overflow:hidden;box-shadow:0 0 20px rgba(201,168,76,.05);}
.deco-badge::before,.deco-badge::after{content:'◆';font-size:.5rem;color:rgba(201,168,76,.5);}
.deco-badge .scan{position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(201,168,76,.1),transparent);transform:translateX(-100%);animation:badgeScan 4s ease infinite;}
@keyframes badgeScan{0%,100%{transform:translateX(-100%)}55%{transform:translateX(100%)}}

/* SEC TITLE */
.sec-title{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,6vw,4.2rem);font-weight:900;font-style:italic;text-align:center;line-height:1.1;color:var(--white);text-shadow:0 4px 30px rgba(255,255,255,.05);letter-spacing:.03em;}
.sec-title em{color:var(--gold);font-style:italic;text-shadow:0 0 30px rgba(201,168,76,.3);}
.sec-sub{font-size:.6rem;font-weight:200;letter-spacing:.5em;color:var(--grey);text-align:center;margin-top:8px;text-transform:uppercase;}

/* ═══ HERO ═══ */
#hero{text-align:center;}
.hero-fan{position:absolute;pointer-events:none;opacity:.06;font-size:8rem;filter:grayscale(1);}
.hf1{top:5%;left:-2%;}.hf2{bottom:5%;right:-2%;transform:scaleX(-1);}

.portrait-scene{perspective:800px;width:min(280px,70vw);height:min(280px,70vw);margin:0 auto 40px;position:relative;}
.portrait-3d{width:100%;height:100%;transform-style:preserve-3d;animation:portraitFloat 9s ease-in-out infinite;transition:transform .4s ease;position:relative;}
@keyframes portraitFloat{0%,100%{transform:rotateY(0) rotateX(6deg) translateY(0)}25%{transform:rotateY(8deg) rotateX(3deg) translateY(-15px)}50%{transform:rotateY(0) rotateX(-3deg) translateY(-22px)}75%{transform:rotateY(-8deg) rotateX(3deg) translateY(-12px)}}

.p-ring{position:absolute;border-radius:50%;border-style:solid;}
.pr1{inset:-4px;border-width:2px;border-color:transparent;background:linear-gradient(var(--black),var(--black)) padding-box,conic-gradient(var(--gold),var(--gold3),var(--silver),var(--gold2),var(--gold)) border-box;animation:ringRot 7s linear infinite;}
.pr2{inset:-16px;border-width:1px;border-color:rgba(201,168,76,.12);border-style:dashed;animation:ringRot 14s linear infinite reverse;}
.pr3{inset:-30px;border-width:1px;border-color:rgba(201,168,76,.06);animation:ringRot 22s linear infinite;}
.pr4{inset:-46px;border-width:1px;border-color:rgba(255,255,255,.04);border-style:dotted;animation:ringRot 30s linear infinite reverse;}
@keyframes ringRot{to{transform:rotate(360deg)}}

.deco-orb{position:absolute;font-size:1rem;animation:decoOrbit linear infinite;top:50%;left:50%;filter:drop-shadow(0 0 6px rgba(201,168,76,.6));color:var(--gold);}
@keyframes decoOrbit{0%{transform:rotate(var(--a)) translateX(var(--r)) rotate(calc(-1*var(--a)))}100%{transform:rotate(calc(var(--a)+360deg)) translateX(var(--r)) rotate(calc(-1*(var(--a)+360deg)))}}

.portrait-core{position:absolute;inset:22px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,#1a1a1a,#0a0a0a);box-shadow:0 0 60px rgba(201,168,76,.15),0 0 120px rgba(0,0,0,.5),inset 0 0 40px rgba(0,0,0,.6),inset 0 2px 15px rgba(201,168,76,.06);display:flex;align-items:center;justify-content:center;font-size:5rem;}
.portrait-core img{width:100%;height:100%;object-fit:cover;border-radius:50%;filter:grayscale(1) contrast(1.1) brightness(.85);opacity:.9;}
.portrait-core::after{content:'';position:absolute;inset:0;border-radius:50%;background:radial-gradient(ellipse at 35% 28%,rgba(201,168,76,.12),transparent 50%);}

.hero-text-wrap{opacity:0;animation:decoReveal 1.2s .3s ease-out forwards;}
@keyframes decoReveal{0%{opacity:0;transform:translateY(24px);filter:blur(6px)}100%{opacity:1;transform:none;filter:none}}

.hero-presents{font-size:.52rem;font-weight:100;letter-spacing:1em;color:var(--grey);display:block;margin-bottom:6px;text-transform:uppercase;}
.hero-name{font-family:'Playfair Display',serif;font-size:clamp(3rem,9vw,6rem);font-weight:900;font-style:italic;display:block;line-height:.95;color:var(--white);text-shadow:0 4px 30px rgba(255,255,255,.06);letter-spacing:.02em;}
.hero-turns{font-family:'Playfair Display',serif;font-size:clamp(1rem,3vw,1.6rem);font-weight:400;font-style:italic;color:var(--gold);display:block;margin-top:8px;letter-spacing:.3em;text-shadow:0 0 20px rgba(201,168,76,.4);animation:goldPulse 3s ease-in-out infinite alternate;}
.hero-tagline{font-size:.58rem;font-weight:100;letter-spacing:.5em;color:var(--grey);display:block;margin-top:12px;text-transform:uppercase;}

.hero-dates{display:flex;gap:0;margin-top:28px;overflow:hidden;opacity:0;animation:decoReveal 1.2s .5s ease-out forwards;border:1px solid rgba(201,168,76,.15);box-shadow:0 0 30px rgba(201,168,76,.06);}
.hd{padding:14px 20px;text-align:center;border-right:1px solid rgba(201,168,76,.12);transition:background .2s;position:relative;overflow:hidden;}
.hd:last-child{border-right:none;}
.hd::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(201,168,76,.05),transparent);opacity:0;transition:opacity .2s;}
.hd:hover::after{opacity:1;}
.hd .hn{font-family:'Playfair Display',serif;font-size:clamp(.9rem,2.5vw,1.6rem);font-style:italic;font-weight:700;color:var(--gold);display:block;line-height:1;text-shadow:0 0 15px rgba(201,168,76,.3);}
.hd .hl{font-size:.45rem;font-weight:100;letter-spacing:.45em;color:var(--grey);text-transform:uppercase;display:block;margin-top:4px;}

.scroll-cue{position:absolute;bottom:28px;display:flex;flex-direction:column;align-items:center;gap:8px;animation:cueFloat 2s ease-in-out infinite;}
@keyframes cueFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}
.scroll-cue .cue-line{width:1px;height:40px;background:linear-gradient(180deg,var(--gold),transparent);}
.scroll-cue .cue-txt{font-size:.45rem;font-weight:100;letter-spacing:.55em;color:var(--grey);text-transform:uppercase;}
.scroll-cue .cue-diamond{width:8px;height:8px;clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);background:var(--gold);box-shadow:0 0 8px rgba(201,168,76,.5);}

/* ═══ ABOUT ═══ */
#about{background:radial-gradient(ellipse at 50% 0%,rgba(201,168,76,.04),transparent 60%);}
.about-layout{display:flex;gap:50px;align-items:center;flex-wrap:wrap;justify-content:center;max-width:860px;width:100%;margin-top:48px;}

.film-portrait{position:relative;flex-shrink:0;}
.film-mat{width:min(230px,52vw);height:min(290px,65vw);background:var(--dark);border:2px solid rgba(201,168,76,.2);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:6rem;box-shadow:0 0 0 6px var(--black),0 0 0 7px rgba(201,168,76,.15),0 30px 60px rgba(0,0,0,.6);}
.film-mat img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.1) brightness(.8);}
.sprocket{position:absolute;top:0;bottom:0;width:18px;display:flex;flex-direction:column;justify-content:space-around;align-items:center;padding:8px 0;background:rgba(0,0,0,.6);}
.sprocket-left{left:0;}.sprocket-right{right:0;}
.sprocket-hole{width:8px;height:10px;background:var(--black);border:1px solid rgba(201,168,76,.15);}
.film-caption{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.75);padding:8px 20px;text-align:center;}
.film-caption span{font-size:.45rem;font-weight:100;letter-spacing:.4em;color:rgba(201,168,76,.7);text-transform:uppercase;}

.about-info{display:flex;flex-direction:column;gap:14px;max-width:300px;}
.info-row{display:flex;flex-direction:column;gap:5px;padding:16px 20px;border:1px solid rgba(201,168,76,.1);border-left:2px solid rgba(201,168,76,.4);background:rgba(255,255,255,.02);position:relative;overflow:hidden;transition:border-left-color .3s,transform .2s;cursor:default;}
.info-row:hover{border-left-color:var(--gold);transform:translateX(4px);}
.info-row::after{content:'';position:absolute;top:0;right:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent,rgba(201,168,76,.15),transparent);}
.ir-label{font-size:.48rem;font-weight:100;letter-spacing:.6em;color:var(--gold);text-transform:uppercase;}
.ir-val{font-family:'Playfair Display',serif;font-size:1.1rem;font-style:italic;color:var(--light);}
.ir-sub{font-size:.65rem;font-weight:200;color:var(--grey);}

/* ═══ EVENT ═══ */
#event{background:radial-gradient(ellipse at 50% 100%,rgba(201,168,76,.04),transparent 50%);}
.programme{width:100%;max-width:640px;margin-top:48px;border:1px solid rgba(201,168,76,.15);background:rgba(10,10,10,.8);position:relative;overflow:hidden;box-shadow:0 0 80px rgba(201,168,76,.06),0 30px 80px rgba(0,0,0,.5);}
.prog-head{padding:24px 32px;background:linear-gradient(135deg,rgba(201,168,76,.08),transparent);border-bottom:1px solid rgba(201,168,76,.12);text-align:center;position:relative;}
.prog-head::after{content:'';position:absolute;bottom:0;left:20%;right:20%;height:1px;background:var(--gold);opacity:.3;}
.prog-head-title{font-family:'Playfair Display',serif;font-size:1.4rem;font-style:italic;font-weight:700;color:var(--gold);letter-spacing:.1em;text-shadow:0 0 20px rgba(201,168,76,.3);}
.prog-head-sub{font-size:.5rem;font-weight:100;letter-spacing:.6em;color:var(--grey);text-transform:uppercase;margin-top:4px;}

.prog-item{display:flex;gap:0;border-bottom:1px solid rgba(201,168,76,.06);transition:background .2s;position:relative;overflow:hidden;cursor:default;}
.prog-item:last-child{border-bottom:none;}
.prog-item:hover{background:rgba(201,168,76,.03);}
.prog-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--gold),var(--gold2));transform:scaleY(0);transition:transform .3s;transform-origin:bottom;}
.prog-item:hover::before{transform:scaleY(1);}
.prog-time{width:100px;flex-shrink:0;padding:24px 20px;border-right:1px solid rgba(201,168,76,.08);display:flex;flex-direction:column;justify-content:center;text-align:right;}
.prog-t{font-family:'Playfair Display',serif;font-size:1rem;font-style:italic;color:var(--gold);font-weight:700;}
.prog-tz{font-size:.42rem;font-weight:100;letter-spacing:.3em;color:var(--grey);}
.prog-body{padding:24px 28px;flex:1;}
.prog-icon{font-size:1.5rem;margin-bottom:8px;display:block;filter:grayscale(.6);}
.prog-type{font-size:.48rem;font-weight:100;letter-spacing:.55em;color:var(--gold);text-transform:uppercase;margin-bottom:6px;}
.prog-name{font-family:'Playfair Display',serif;font-size:1.2rem;font-style:italic;color:var(--light);margin-bottom:8px;}
.prog-detail{font-size:.72rem;font-weight:200;color:var(--grey);line-height:2;}
.prog-detail strong{color:var(--silver);font-weight:300;display:block;}
.prog-foot{padding:18px 32px;background:rgba(201,168,76,.03);border-top:1px solid rgba(201,168,76,.08);text-align:center;}
.prog-foot-txt{font-size:.5rem;font-weight:100;letter-spacing:.45em;color:var(--grey);text-transform:uppercase;}

/* ═══ DRESSCODE ═══ */
#dresscode{min-height:auto;padding:80px 24px;background:rgba(0,0,0,.4);}
.dress-layout{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;max-width:700px;width:100%;margin-top:36px;}
.dress-card{flex:1;min-width:130px;max-width:170px;padding:0 0 20px;border:1px solid rgba(201,168,76,.1);background:rgba(10,10,10,.7);text-align:center;overflow:hidden;transition:transform .3s,border-color .3s,box-shadow .3s;cursor:default;}
.dress-card:hover{transform:translateY(-6px);border-color:rgba(201,168,76,.35);box-shadow:0 12px 40px rgba(0,0,0,.4),0 0 20px rgba(201,168,76,.08);}
.dc-swatch{height:70px;width:100%;position:relative;overflow:hidden;}
.dc-swatch::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(45deg,rgba(255,255,255,.03) 0,rgba(255,255,255,.03) 1px,transparent 1px,transparent 8px);}
.dc-icon{font-size:1.8rem;display:block;margin:14px 0 8px;filter:grayscale(.5);}
.dc-name{font-size:.5rem;font-weight:200;letter-spacing:.3em;color:var(--gold);text-transform:uppercase;}
.dc-hint{font-size:.65rem;font-weight:200;color:var(--grey);margin-top:4px;}

/* ═══ COUNTDOWN ═══ */
#countdown{background:linear-gradient(160deg,rgba(201,168,76,.06) 0%,transparent 50%,rgba(201,168,76,.03) 100%);position:relative;}
#countdown::before{content:'';position:absolute;inset:0;background:repeating-conic-gradient(from 0deg at 50% 50%,rgba(201,168,76,.015) 0deg,transparent 2deg,transparent 10deg);pointer-events:none;}
.cd-row{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:44px;position:relative;z-index:1;}
.cd-unit{text-align:center;cursor:default;transition:transform .2s;min-width:88px;}
.cd-unit:hover{transform:translateY(-8px) scale(1.04);}
.cd-face{width:88px;height:88px;position:relative;margin:0 auto 10px;}
.cd-face svg{position:absolute;inset:0;}
.cd-face-bg{position:absolute;inset:0;background:linear-gradient(135deg,#161616,#0c0c0c);border:1px solid rgba(201,168,76,.2);clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);box-shadow:0 0 20px rgba(201,168,76,.08),inset 0 0 20px rgba(0,0,0,.5);}
.cd-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.cd-n{font-family:'Playfair Display',serif;font-size:clamp(1.5rem,4vw,2rem);font-style:italic;font-weight:700;color:var(--gold);text-shadow:0 0 15px rgba(201,168,76,.5);line-height:1;}
.cd-l{font-size:.4rem;font-weight:100;letter-spacing:.4em;color:var(--grey);text-transform:uppercase;margin-top:4px;}
.cd-sep{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;margin-top:22px;}
.cd-sep span{width:5px;height:5px;clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);background:rgba(201,168,76,.3);}
.cd-sep span:nth-child(2){background:rgba(201,168,76,.5);width:7px;height:7px;}

/* ═══ GALLERY ═══ */
#gallery{min-height:auto;padding:80px 24px;}
.photo-wall{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;max-width:680px;width:100%;margin-top:44px;}
.pw{position:relative;overflow:hidden;cursor:pointer;background:var(--dark);aspect-ratio:1;border:1px solid rgba(201,168,76,.08);transition:transform .4s cubic-bezier(.34,1.4,.64,1),box-shadow .4s;box-shadow:0 4px 20px rgba(0,0,0,.4);}
.pw:nth-child(1){grid-row:span 2;aspect-ratio:unset;min-height:230px;}
.pw:nth-child(4){grid-column:span 2;aspect-ratio:2/1;}
.pw:hover{transform:scale(1.04) translateY(-5px);box-shadow:0 16px 50px rgba(0,0,0,.6),0 0 30px rgba(201,168,76,.1);z-index:5;}
.pw::before{content:'';position:absolute;inset:0;z-index:2;border:2px solid rgba(201,168,76,.2);opacity:0;transition:opacity .3s;pointer-events:none;}
.pw:hover::before{opacity:1;}
.pw img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.1) brightness(.6) sepia(.15);transition:transform .4s,filter .4s;display:block;}
.pw:hover img{transform:scale(1.07);filter:grayscale(1) contrast(1.15) brightness(.7) sepia(.15);}
.pw::after{content:'';position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse at 50% 50%,transparent 50%,rgba(0,0,0,.5) 100%);pointer-events:none;}
.pw-em{position:absolute;inset:0;z-index:1;display:flex;align-items:center;justify-content:center;font-size:3rem;background:var(--dark);filter:grayscale(1);}

/* ═══ RSVP ═══ */
.rsvp-telegram{width:100%;max-width:520px;margin-top:44px;}
.telegram-top{background:linear-gradient(135deg,rgba(201,168,76,.12),rgba(201,168,76,.06));border:1px solid rgba(201,168,76,.2);border-bottom:none;padding:14px 28px;display:flex;justify-content:space-between;align-items:center;}
.tg-pre{font-size:.48rem;font-weight:100;letter-spacing:.5em;color:var(--gold);text-transform:uppercase;}
.tg-num{font-family:'Playfair Display',serif;font-size:1rem;font-style:italic;color:var(--silver);}
.rsvp-card{background:rgba(8,8,8,.9);border:1px solid rgba(201,168,76,.15);padding:44px 36px;position:relative;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.6),0 0 40px rgba(201,168,76,.04);}
.rsvp-perf{position:absolute;left:0;right:0;height:10px;overflow:hidden;}
.rsvp-perf.top{top:0;}.rsvp-perf.bot{bottom:0;}
.rsvp-perf::after{content:'';display:block;height:100%;background:repeating-linear-gradient(90deg,transparent,transparent 12px,rgba(201,168,76,.15) 12px,rgba(201,168,76,.15) 13px);}
.rsvp-card::after{content:'';position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);top:0;animation:scanDown 8s linear infinite;pointer-events:none;opacity:.3;}
.rf{margin-bottom:20px;}
.rf label{display:block;font-size:.5rem;font-weight:100;letter-spacing:.6em;color:var(--gold);text-transform:uppercase;margin-bottom:8px;}
.rf input,.rf select,.rf textarea{width:100%;padding:11px 16px;background:rgba(255,255,255,.03);border:1px solid rgba(201,168,76,.12);border-bottom:1px solid rgba(201,168,76,.25);color:var(--light);font-family:'Josefin Sans',sans-serif;font-size:.85rem;font-weight:200;letter-spacing:.05em;outline:none;transition:border-color .2s,background .2s;}
.rf input:focus,.rf select:focus,.rf textarea:focus{border-color:rgba(201,168,76,.35);background:rgba(201,168,76,.03);}
.rf select option{background:#0a0a0a;}
.rf textarea{resize:vertical;min-height:88px;}
.att-row{display:flex;gap:10px;}
.att{flex:1;padding:12px 8px;background:rgba(255,255,255,.02);border:1px solid rgba(201,168,76,.1);text-align:center;font-size:.72rem;font-weight:200;cursor:pointer;color:var(--grey);transition:all .25s;letter-spacing:.1em;}
.att:hover{border-color:rgba(201,168,76,.35);color:var(--gold);background:rgba(201,168,76,.04);transform:translateY(-2px);}
.att.on{border-color:var(--gold);background:rgba(201,168,76,.08);color:var(--gold2);box-shadow:0 0 20px rgba(201,168,76,.1);}
.att .ae{font-size:1.2rem;display:block;margin-bottom:4px;filter:grayscale(.5);}
.send-btn{width:100%;padding:14px;background:transparent;border:1px solid var(--gold);color:var(--gold);font-family:'Josefin Sans',sans-serif;font-size:.58rem;font-weight:200;letter-spacing:.6em;text-transform:uppercase;cursor:pointer;position:relative;overflow:hidden;transition:color .4s,box-shadow .4s;box-shadow:0 0 20px rgba(201,168,76,.08);margin-top:6px;}
.send-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(201,168,76,.15),rgba(201,168,76,.08));transform:translateX(-100%);transition:transform .5s;}
.send-btn:hover::before{transform:translateX(0);}
.send-btn:hover{color:var(--gold2);box-shadow:0 0 40px rgba(201,168,76,.2);}
.send-btn span{position:relative;z-index:1;}

/* WA Button */
.wa-rsvp-btn{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 32px;
  background:transparent;
  border:1px solid rgba(37,211,102,.5);
  color:rgba(37,211,102,.9);
  font-family:'Josefin Sans',sans-serif;
  font-size:.58rem;font-weight:200;letter-spacing:.6em;
  text-transform:uppercase;text-decoration:none;
  margin-top:12px;
  position:relative;overflow:hidden;
  transition:all .3s;
}
.wa-rsvp-btn:hover{border-color:rgba(37,211,102,.9);color:#25d366;box-shadow:0 0 30px rgba(37,211,102,.15);}

.wish-scroll{max-width:520px;width:100%;margin-top:20px;display:flex;flex-direction:column;gap:10px;}
.wish{padding:16px 20px;background:rgba(255,255,255,.02);border:1px solid rgba(201,168,76,.08);border-left:2px solid rgba(201,168,76,.3);position:relative;overflow:hidden;}
.wish:nth-child(2n){border-left:none;border-right:2px solid rgba(255,255,255,.12);}
.wish::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,rgba(201,168,76,.4),transparent);}
.w-name{font-size:.5rem;font-weight:200;letter-spacing:.4em;color:var(--gold);margin-bottom:5px;text-transform:uppercase;}
.w-txt{font-size:.8rem;font-weight:200;color:var(--grey);line-height:1.8;font-style:italic;}

/* ═══ FOOTER ═══ */
footer{text-align:center;padding:90px 24px 60px;background:linear-gradient(180deg,transparent,var(--black));border-top:1px solid rgba(201,168,76,.08);position:relative;overflow:hidden;}
footer::before{content:'';position:absolute;bottom:-100px;left:50%;transform:translateX(-50%);width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,.04),transparent 70%);pointer-events:none;}
.footer-deco-top{display:flex;align-items:center;gap:16px;max-width:360px;margin:0 auto 24px;}
.footer-deco-top::before,.footer-deco-top::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.3),transparent);}
.footer-deco-top .fd-mid{display:flex;gap:6px;}
.footer-deco-top .fd-mid span{width:5px;height:5px;clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);background:var(--gold);box-shadow:0 0 6px rgba(201,168,76,.4);}
.footer-deco-top .fd-mid span:nth-child(2){width:8px;height:8px;}
.footer-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,6vw,3.5rem);font-weight:900;font-style:italic;color:var(--white);letter-spacing:.04em;text-shadow:0 4px 30px rgba(255,255,255,.05);}
.footer-sub{font-size:.55rem;font-weight:100;letter-spacing:.7em;color:var(--gold);display:block;margin:10px 0;text-transform:uppercase;text-shadow:0 0 20px rgba(201,168,76,.3);}
footer p{font-size:.65rem;font-weight:200;color:var(--grey);margin-top:6px;letter-spacing:.2em;}
.footer-year{font-family:'Playfair Display',serif;font-size:1.2rem;font-style:italic;color:rgba(201,168,76,.3);display:block;margin-top:20px;letter-spacing:.3em;}

/* ═══ REVEAL ═══ */
.rev{opacity:0;transform:translateY(22px);filter:blur(3px);transition:opacity 1s ease,transform 1s ease,filter 1s ease;}
.rev.on{opacity:1;transform:none;filter:none;}

/* ═══ BURST ═══ */
.gb{position:fixed;pointer-events:none;z-index:300;width:5px;height:5px;clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);background:var(--gold);animation:gbFly ease-out forwards;}
@keyframes gbFly{0%{transform:translate(-50%,-50%) scale(1);opacity:.9}100%{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(0);opacity:0}}

/* ═══ LOCATION ═══ */
#location{min-height:auto;padding:80px 24px;background:radial-gradient(ellipse at 50% 100%,rgba(201,168,76,.05),transparent 60%);}
.map-btn{display:inline-block;padding:12px 36px;background:transparent;border:1px solid var(--gold);color:var(--gold);font-family:'Josefin Sans',sans-serif;font-size:.58rem;font-weight:200;letter-spacing:.6em;text-transform:uppercase;text-decoration:none;transition:all .3s;margin-top:24px;}
.map-btn:hover{color:var(--gold2);box-shadow:0 0 30px rgba(201,168,76,.2);background:rgba(201,168,76,.05);}
.map-embed-wrap{max-width:700px;width:100%;margin-top:36px;overflow:hidden;border:1px solid rgba(201,168,76,.15);box-shadow:0 8px 40px rgba(0,0,0,.5);}
.map-embed-wrap iframe{display:block;width:100%;height:360px;filter:grayscale(1) contrast(1.1) brightness(.7);}

/* ═══ THEME TOGGLE ═══ */
#theme-toggle{
  position:fixed;bottom:22px;right:20px;z-index:500;
  width:44px;height:44px;
  background:rgba(10,10,10,.85);
  border:1px solid rgba(201,168,76,.35);
  color:var(--gold);
  font-size:1.1rem;
  cursor:pointer;
  display:none;
  align-items:center;justify-content:center;
  clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);
  transition:all .3s;
  box-shadow:0 0 16px rgba(201,168,76,.12);
}
#theme-toggle:hover{
  border-color:var(--gold);
  box-shadow:0 0 28px rgba(201,168,76,.3);
  color:var(--gold2);
}
#theme-toggle.on{display:flex;}

/* ═══ LIGHT MODE ADJUSTMENTS ═══ */
html[data-theme="light"] #grain{opacity:.012;}
html[data-theme="light"] #vignette{
  background:radial-gradient(ellipse 80% 80% at 50% 50%,transparent 40%,rgba(200,190,170,.3) 100%);
}
html[data-theme="light"] #deco-bg{
  background:
    radial-gradient(ellipse at 50% 0%,rgba(138,96,16,.07) 0%,transparent 60%),
    radial-gradient(ellipse at 0% 100%,rgba(138,96,16,.05) 0%,transparent 40%),
    radial-gradient(ellipse at 100% 100%,rgba(138,96,16,.05) 0%,transparent 40%),
    var(--black);
}
html[data-theme="light"] .nav-inner{background:rgba(245,240,230,.96);}
html[data-theme="light"] #cover{background:var(--black);}
html[data-theme="light"] .cover-card{
  background:linear-gradient(165deg,#f0ead8,#f5f0e6);
  border-color:rgba(138,96,16,.25);
  box-shadow:0 0 0 1px rgba(138,96,16,.1),0 40px 100px rgba(0,0,0,.1),inset 0 0 60px rgba(138,96,16,.04);
}
html[data-theme="light"] .programme{background:rgba(245,240,230,.95);}
html[data-theme="light"] .rsvp-card{background:rgba(248,244,236,.97);}
html[data-theme="light"] .rf input,
html[data-theme="light"] .rf select,
html[data-theme="light"] .rf textarea{
  background:rgba(138,96,16,.04);
  border-color:rgba(138,96,16,.2);
  border-bottom-color:rgba(138,96,16,.4);
  color:var(--light);
}
html[data-theme="light"] .rf select option{background:var(--rich);}
html[data-theme="light"] .dress-card{background:rgba(240,234,220,.9);}
html[data-theme="light"] .cd-face-bg{
  background:linear-gradient(135deg,#ede7d8,#f5f0e6);
  border-color:rgba(138,96,16,.25);
}
html[data-theme="light"] .info-row{background:rgba(138,96,16,.04);}
html[data-theme="light"] .wish{background:rgba(138,96,16,.04);}
html[data-theme="light"] .rsvp-perf::after{background:repeating-linear-gradient(90deg,transparent,transparent 12px,rgba(138,96,16,.2) 12px,rgba(138,96,16,.2) 13px);}
html[data-theme="light"] .pw-em{background:var(--dark);}
html[data-theme="light"] #theme-toggle{background:rgba(245,240,230,.92);}
html[data-theme="light"] .att{background:rgba(138,96,16,.04);border-color:rgba(138,96,16,.15);}
html[data-theme="light"] .att.on{background:rgba(138,96,16,.1);}
html[data-theme="light"] #spotlight{
  background:radial-gradient(ellipse 600px 600px at var(--sx,50%) var(--sy,30%),rgba(138,96,16,.05),transparent 70%);
}

@media(max-width:520px){
  .about-layout{gap:30px;}
  .photo-wall{grid-template-columns:repeat(2,1fr);}
  .photo-wall .pw:nth-child(1){grid-row:1;grid-column:span 2;min-height:160px;}
  .photo-wall .pw:nth-child(4){grid-column:span 2;}
  .rsvp-card{padding:32px 20px;}
  .prog-time{width:75px;padding:18px 12px;}
  .nav-inner a{padding:12px 10px;font-size:.44rem;letter-spacing:.35em;}
  .telegram-top{padding:12px 18px;}
}
