/* ════════════════════════════════════════
   STYLE.CSS — Undangan Pernikahan Premium
   Tema: Sage Green Elegant
════════════════════════════════════════ */
:root{
  --sg:#3d5a47;--sg2:#5a7a65;--sg3:#7a9e87;--sg4:#a8c5b0;--sg5:#d4e6da;
  --cr:#f7f3ec;--cr2:#f0ebe0;--cr3:#fdfbf7;
  --gd:#b8975a;--gd2:#d4b97a;
  --dk:#0d1a10;--dk2:#1a2a1e;--dk3:#2c3e30;
  --tx:#2c3e30;--tx2:#5a6b5e;--tx3:#8a9e8e;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Jost',sans-serif;color:var(--tx);overflow-x:hidden;background:var(--cr);}

/* ── PARTICLES ── */
#pcv{position:fixed;inset:0;pointer-events:none;z-index:1;}

/* ── MUSIC BTN ── */
#mbt{position:fixed;top:20px;right:20px;z-index:500;width:48px;height:48px;border-radius:50%;
  background:rgba(253,251,247,.94);backdrop-filter:blur(16px);border:1px solid var(--sg5);
  cursor:pointer;display:none;align-items:center;justify-content:center;font-size:18px;
  box-shadow:0 4px 24px rgba(61,90,71,.15);transition:all .3s;}
#mbt.show{display:flex;}
#mbt:hover{transform:scale(1.08);}
#mbt.playing{animation:mpl 2s ease-in-out infinite;}
@keyframes mpl{
  0%,100%{box-shadow:0 4px 20px rgba(61,90,71,.15);}
  50%{box-shadow:0 0 0 12px rgba(90,122,101,.07),0 4px 20px rgba(61,90,71,.15);}
}

/* ── LIGHTBOX ── */
#lbox{position:fixed;inset:0;background:rgba(6,14,8,.96);z-index:600;
  display:none;align-items:center;justify-content:center;backdrop-filter:blur(10px);}
#lbox.open{display:flex;}
#lbox img{max-width:90vw;max-height:90vh;object-fit:contain;border:1px solid rgba(168,197,176,.15);}
#lbox-x{position:absolute;top:24px;right:28px;background:none;border:none;
  color:rgba(253,251,247,.45);font-size:28px;cursor:pointer;transition:color .2s;}
#lbox-x:hover{color:var(--cr3);}

/* ── LOADING ── */
#ld{position:fixed;inset:0;background:var(--dk);z-index:999;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:20px;transition:opacity .8s;}
#ld.hide{opacity:0;pointer-events:none;}
.ld-seal{width:64px;height:64px;border-radius:50%;
  background:radial-gradient(circle at 36% 30%,var(--sg3),var(--sg));
  display:flex;align-items:center;justify-content:center;font-size:26px;
  animation:sealG 1.5s ease-in-out infinite;}
@keyframes sealG{
  0%,100%{box-shadow:0 0 20px rgba(61,90,71,.6),0 0 0 3px rgba(184,151,90,.4);}
  50%{box-shadow:0 0 40px rgba(61,90,71,.9),0 0 0 8px rgba(184,151,90,.15);}
}
.ld-dots{display:flex;gap:6px;}
.ld-dot{width:6px;height:6px;border-radius:50%;background:rgba(168,197,176,.4);
  animation:ldd 1.2s ease-in-out infinite;}
.ld-dot:nth-child(2){animation-delay:.2s;}
.ld-dot:nth-child(3){animation-delay:.4s;}
@keyframes ldd{
  0%,100%{opacity:.3;transform:scale(.8);}
  50%{opacity:1;transform:scale(1.2);background:rgba(212,185,122,.7);}
}
.ld-txt{font-size:9px;letter-spacing:5px;color:rgba(168,197,176,.4);text-transform:uppercase;}

/* ══ COVER ══ */
#cover{position:fixed;inset:0;z-index:200;
  background:linear-gradient(160deg,#060e08 0%,var(--dk2) 35%,var(--dk3) 70%,#3d5a47 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:40px 24px;overflow:hidden;
  transition:opacity 1.5s cubic-bezier(.4,0,.2,1),transform 1.5s cubic-bezier(.4,0,.2,1);}
#cover.away{opacity:0;transform:scale(1.06) translateY(-16px);pointer-events:none;}
.cvg{position:absolute;border-radius:50%;pointer-events:none;animation:gp 4s ease-in-out infinite;}
.cvg.g1{width:700px;height:700px;background:radial-gradient(circle,rgba(90,122,101,.15),transparent 70%);top:-180px;left:-180px;}
.cvg.g2{width:600px;height:600px;background:radial-gradient(circle,rgba(184,151,90,.09),transparent 70%);bottom:-160px;right:-160px;animation-delay:2s;}
@keyframes gp{0%,100%{opacity:.6;}50%{opacity:1;}}
.cv-pre{font-size:9px;letter-spacing:7px;color:rgba(212,185,122,.45);text-transform:uppercase;animation:fU .9s ease .2s both;}
.cv-names{margin:24px 0 6px;animation:fU .9s ease .5s both;}
.cv-bride,.cv-groom{font-family:'Great Vibes',cursive;color:var(--cr3);font-size:clamp(56px,13vw,100px);display:block;line-height:1;}
.cv-amp{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--gd2);font-size:clamp(28px,5vw,44px);display:block;margin:-4px 0;opacity:.75;}
.cv-date{font-size:10px;letter-spacing:5px;color:rgba(212,185,122,.4);text-transform:uppercase;margin-bottom:44px;animation:fU .9s ease .8s both;}

/* Envelope */
.env{width:210px;height:140px;position:relative;margin:0 auto 40px;
  overflow:hidden;border-radius:3px 3px 6px 6px;
  animation:fU .9s ease 1s both,envF 5s ease-in-out 2s infinite;}
@keyframes envF{0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}
.env-body{position:absolute;inset:0;background:linear-gradient(160deg,rgba(253,251,247,.11),rgba(240,235,224,.07));border:1px solid rgba(212,185,122,.2);border-radius:3px 3px 6px 6px;overflow:hidden;}
.env-body::after{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent 35%,rgba(255,255,255,.07) 50%,transparent 65%);animation:envS 4s linear infinite;border-radius:3px 3px 6px 6px;}
@keyframes envS{0%{transform:translateX(-100%);}100%{transform:translateX(200%);}}
.env-flap{position:absolute;top:0;left:0;right:0;height:52%;clip-path:polygon(0 0,50% 90%,100% 0);background:rgba(253,251,247,.07);border-bottom:1px solid rgba(212,185,122,.12);}
.env-bl{position:absolute;left:0;top:0;bottom:0;width:50%;clip-path:polygon(0 0,100% 46%,0 100%);background:rgba(0,0,0,.07);}
.env-br{position:absolute;right:0;top:0;bottom:0;width:50%;clip-path:polygon(100% 0,0 46%,100% 100%);background:rgba(0,0,0,.05);}
.env-bt{position:absolute;bottom:0;left:0;right:0;height:52%;clip-path:polygon(0 100%,50% 0,100% 100%);background:rgba(0,0,0,.06);}
.env-seal{position:absolute;top:50%;left:50%;transform:translate(-50%,-44%);
  width:54px;height:54px;border-radius:50%;
  background:radial-gradient(circle at 36% 30%,var(--sg3),var(--sg));
  display:flex;align-items:center;justify-content:center;font-size:22px;z-index:2;
  animation:sealG 3s ease-in-out infinite;}
.cv-btn{padding:16px 54px;background:transparent;border:1px solid rgba(184,151,90,.38);
  color:var(--gd2);font-family:'Jost',sans-serif;font-weight:300;font-size:11px;
  letter-spacing:5px;text-transform:uppercase;cursor:pointer;transition:all .5s;
  position:relative;overflow:hidden;animation:fU .9s ease 1.3s both;}
.cv-btn::before{content:'';position:absolute;inset:0;background:rgba(184,151,90,.1);
  transform:scaleX(0);transform-origin:left;transition:transform .5s;}
.cv-btn:hover::before{transform:scaleX(1);}
.cv-btn:hover{color:#fff;letter-spacing:6px;}

/* ══ MAIN ══ */
#main{display:none;}
#main.visible{display:block;}

/* ── HERO ── */
#hero{min-height:100vh;
  background:linear-gradient(180deg,#060e08 0%,var(--dk2) 25%,var(--dk3) 55%,var(--cr2) 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:80px 24px 120px;position:relative;overflow:hidden;}
#hlv{position:absolute;inset:0;pointer-events:none;overflow:hidden;}
.lf{position:absolute;border-radius:50% 0 50% 0;animation:lfF linear infinite;}
@keyframes lfF{
  0%{opacity:0;transform:translateY(-30px) rotate(0deg);}
  8%{opacity:.6;}88%{opacity:.2;}
  100%{opacity:0;transform:translateY(110vh) rotate(560deg) translateX(55px);}
}
.pe{will-change:transform;}
.h-ey{font-size:9px;letter-spacing:7px;color:rgba(212,185,122,.55);text-transform:uppercase;margin-bottom:28px;animation:fU .9s ease .4s both;}
.h-nm{animation:fU .9s ease .65s both;}
.h-bride,.h-groom{font-family:'Great Vibes',cursive;color:var(--cr3);display:block;font-size:clamp(62px,13vw,112px);line-height:1;}
.h-a{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--gd2);font-size:clamp(28px,5vw,46px);display:block;margin:-4px 0;opacity:.72;}
.h-vl{width:1px;height:90px;background:linear-gradient(180deg,transparent,var(--gd),transparent);margin:30px auto;animation:fU .9s ease .9s both;}
.h-dt{font-family:'Cormorant Garamond',serif;font-size:clamp(14px,2.5vw,19px);color:rgba(212,185,122,.78);letter-spacing:4px;animation:fU .9s ease 1.1s both;}
.h-lc{font-size:10px;letter-spacing:3px;color:rgba(253,251,247,.28);text-transform:uppercase;margin-top:10px;animation:fU .9s ease 1.3s both;}
.h-scr{position:absolute;bottom:44px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;animation:fU .9s ease 1.9s both;}
.h-scrl{width:1px;height:56px;background:linear-gradient(180deg,transparent,rgba(212,185,122,.38));animation:scA 2.2s ease-in-out infinite;}
@keyframes scA{
  0%{transform:scaleY(0);transform-origin:top;}
  50%{transform:scaleY(1);transform-origin:top;}
  51%{transform-origin:bottom;}
  100%{transform:scaleY(0);transform-origin:bottom;}
}
.h-scrt{font-size:8px;letter-spacing:3px;color:rgba(212,185,122,.28);text-transform:uppercase;}
@keyframes fU{from{opacity:0;transform:translateY(30px);}to{opacity:1;transform:translateY(0);}}

/* ── SECTIONS ── */
.sec{padding:100px 24px;}
.si{max-width:780px;margin:0 auto;}
.sey{font-size:9px;letter-spacing:5px;color:var(--sg3);text-transform:uppercase;text-align:center;margin-bottom:14px;}
.sti{font-family:'Cormorant Garamond',serif;font-size:clamp(34px,6vw,52px);font-weight:300;text-align:center;color:var(--sg);line-height:1.15;margin-bottom:24px;}
.sbo{font-size:13px;line-height:2.1;color:var(--tx2);text-align:center;font-weight:300;max-width:500px;margin:0 auto;}
.ldv{display:flex;align-items:center;gap:20px;max-width:340px;margin:80px auto;padding:0 24px;}
.ldl{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--sg5));}
.ldl.r{background:linear-gradient(90deg,var(--sg5),transparent);}
.ldi{color:var(--sg4);font-size:16px;}

/* ── COUPLE ── */
#couple{background:var(--cr2);}
.cg{display:grid;grid-template-columns:1fr 80px 1fr;align-items:center;margin-top:68px;}
@media(max-width:620px){.cg{grid-template-columns:1fr;gap:44px;}}
.pc{text-align:center;}
.pf{width:180px;height:222px;margin:0 auto 24px;position:relative;}
.pfb{position:absolute;inset:0;border:1px solid var(--sg5);border-radius:90px 90px 50px 50px;transition:border-color .5s;}
.pf:hover .pfb{border-color:var(--sg4);}
.pf::after{content:'';position:absolute;inset:-7px;border:1px solid rgba(168,197,176,.18);border-radius:97px 97px 57px 57px;pointer-events:none;}
.pimg{width:100%;height:100%;object-fit:cover;border-radius:88px 88px 48px 48px;display:block;}
.pph{width:100%;height:100%;border-radius:88px 88px 48px 48px;background:linear-gradient(160deg,var(--sg5),var(--cr2));display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--sg4);font-size:30px;gap:8px;}
.pph span{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--tx3);}
.pn{font-family:'Great Vibes',cursive;font-size:42px;color:var(--sg);}
.pfl{font-size:10px;letter-spacing:2px;color:var(--sg3);text-transform:uppercase;margin:4px 0 10px;font-weight:300;}
.ppr{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:14px;color:var(--tx3);line-height:1.8;}
.cc{display:flex;flex-direction:column;align-items:center;gap:12px;}
.ca{font-family:'Great Vibes',cursive;font-size:62px;color:var(--gd);line-height:1;}
.cvl{width:1px;height:40px;background:linear-gradient(180deg,transparent,var(--sg5),transparent);}

/* ── QUOTE ── */
#quote{background:var(--sg);padding:80px 24px;text-align:center;}
.qt-q{font-family:'Cormorant Garamond',serif;font-size:100px;color:rgba(212,185,122,.18);line-height:.3;font-style:italic;}
.qt-tx{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(16px,2.6vw,21px);color:rgba(253,251,247,.78);line-height:2;max-width:580px;margin:0 auto 16px;}
.qt-rf{font-size:9px;letter-spacing:4px;color:var(--gd2);text-transform:uppercase;}

/* ── EVENTS ── */
#events{background:var(--cr3);padding:0;}
.ev-hd{max-width:780px;margin:0 auto;padding:100px 24px 64px;text-align:center;}
.ev-grid{display:grid;grid-template-columns:1fr 1fr;background:var(--sg5);gap:2px;}
@media(max-width:560px){.ev-grid{grid-template-columns:1fr;}}
.ec{background:var(--cr3);padding:60px 36px;text-align:center;position:relative;}
.ec::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--sg4),transparent);}
.ec-badge{display:inline-block;font-size:8px;letter-spacing:4px;text-transform:uppercase;color:var(--sg3);border:1px solid var(--sg5);padding:7px 18px;margin-bottom:28px;}
.ec-icon{font-size:32px;display:block;margin-bottom:16px;}
.ec-day{font-family:'Cormorant Garamond',serif;font-size:76px;font-weight:300;color:var(--sg);line-height:1;}
.ec-my{font-size:11px;letter-spacing:4px;color:var(--sg3);text-transform:uppercase;margin:6px 0 24px;}
.ec-time{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--tx);margin-bottom:16px;}
.ec-vn{font-size:13px;color:var(--tx);margin-bottom:4px;}
.ec-va{font-size:11px;color:var(--tx3);line-height:1.7;}
.ec-map{display:inline-flex;align-items:center;gap:6px;margin-top:18px;padding:9px 20px;border:1px solid var(--sg5);color:var(--sg3);font-size:10px;letter-spacing:2px;text-decoration:none;text-transform:uppercase;transition:all .3s;}
.ec-map:hover{background:var(--sg5);color:var(--sg);}

/* ── COUNTDOWN ── */
#countdown{background:linear-gradient(160deg,var(--sg),var(--sg2));padding:100px 24px;text-align:center;}
#countdown .sey{color:rgba(212,185,122,.5);}
#countdown .sti{color:var(--cr3);}
.cdr{display:flex;align-items:flex-start;justify-content:center;margin-top:64px;flex-wrap:wrap;}
.cdi{text-align:center;padding:0 28px;}
.cdn{font-family:'Cormorant Garamond',serif;font-size:clamp(56px,9vw,82px);font-weight:300;color:var(--cr3);line-height:1;display:block;}
.cdl{font-size:8px;letter-spacing:4px;color:rgba(212,185,122,.5);text-transform:uppercase;margin-top:8px;}
.cds{font-family:'Cormorant Garamond',serif;font-size:52px;color:rgba(168,197,176,.25);line-height:1;padding-top:4px;}

/* ── GALLERY ── */
#gallery{background:var(--cr2);}
.gal-masonry{columns:3;gap:10px;margin-top:64px;}
@media(max-width:500px){.gal-masonry{columns:2;}}
.gm{break-inside:avoid;margin-bottom:10px;position:relative;overflow:hidden;cursor:pointer;background:var(--sg5);}
.gm img{width:100%;display:block;transition:transform .6s;}
.gm:hover img{transform:scale(1.06);}
.gm-ov{position:absolute;inset:0;background:rgba(44,62,48,.42);opacity:0;transition:opacity .3s;display:flex;align-items:center;justify-content:center;color:var(--cr3);font-size:22px;}
.gm:hover .gm-ov{opacity:1;}

/* ── MAPS ── */
#maps{background:var(--cr3);}
.map-box{margin-top:56px;border:1px solid var(--sg5);overflow:hidden;position:relative;}
.map-box iframe{width:100%;height:380px;border:none;display:block;filter:grayscale(.25);}
.map-open{position:absolute;bottom:20px;right:20px;display:inline-flex;align-items:center;gap:8px;background:var(--sg);color:var(--cr3);padding:12px 24px;font-family:'Jost',sans-serif;font-size:10px;letter-spacing:3px;text-transform:uppercase;text-decoration:none;transition:background .3s;}
.map-open:hover{background:var(--sg2);}

/* ── GIFTS ── */
#gifts{background:var(--cr2);text-align:center;}
.gift-wrap{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-top:56px;}
.gcard{background:var(--cr3);border:1px solid var(--sg5);padding:36px 36px 28px;min-width:260px;flex:1;max-width:320px;text-align:center;position:relative;}
.gcard::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--sg4),transparent);}
.gcard-logo{width:56px;height:56px;border-radius:50%;object-fit:contain;margin:0 auto 12px;display:block;background:var(--sg5);padding:6px;}
.gcard-logo-ph{width:56px;height:56px;border-radius:50%;background:var(--sg5);display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 12px;}
.gcard-bank{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--sg3);margin-bottom:14px;}
.gcard-no{font-family:'Cormorant Garamond',serif;font-size:28px;color:var(--sg);margin-bottom:4px;}
.gcard-hold{font-size:12px;color:var(--tx3);}
.gcard-copy{margin-top:18px;padding:9px 22px;background:transparent;border:1px solid var(--sg5);color:var(--sg3);font-family:'Jost',sans-serif;font-size:9px;letter-spacing:3px;text-transform:uppercase;cursor:pointer;transition:all .3s;}
.gcard-copy:hover,.gcard-copy.ok{background:var(--sg5);color:var(--sg);}

/* ── RSVP ── */
#rsvp{background:var(--cr);}
.rsvp-w{max-width:540px;margin:64px auto 0;}
.ri{width:100%;padding:16px 20px;background:var(--cr3);border:none;border-bottom:1px solid var(--sg5);font-family:'Jost',sans-serif;font-size:13px;color:var(--tx);margin-bottom:18px;outline:none;transition:border-color .3s;letter-spacing:.5px;}
.ri:focus{border-color:var(--sg3);}
.ri::placeholder{color:var(--tx3);}
.ri-sl{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237a9e87' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 18px center;background-color:var(--cr3);cursor:pointer;}
.rb{width:100%;padding:18px;background:var(--sg);color:var(--cr3);border:none;font-family:'Jost',sans-serif;font-size:10px;letter-spacing:5px;text-transform:uppercase;cursor:pointer;transition:background .3s;margin-top:8px;}
.rb:hover{background:var(--sg2);}
.rb:disabled{opacity:.6;cursor:not-allowed;}
.rok{padding:18px 20px;background:var(--sg5);border-left:3px solid var(--sg3);font-size:13px;color:var(--sg);display:none;margin-top:14px;line-height:1.6;}
.ucl{max-width:540px;margin:52px auto 0;}
.ucc{padding:22px 26px;background:var(--cr3);border-left:2px solid var(--sg4);margin-bottom:10px;}
.uct{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;}
.ucn{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--sg);}
.ucs{font-size:9px;letter-spacing:2px;color:var(--sg3);}
.ucm{font-size:12px;color:var(--tx2);font-style:italic;line-height:1.7;}

/* ── FOOTER ── */
#footer{background:linear-gradient(160deg,#060e08,var(--dk2),#060e08);padding:100px 24px 60px;text-align:center;}
.ft-n{font-family:'Great Vibes',cursive;font-size:clamp(52px,9vw,82px);color:var(--cr3);margin-bottom:24px;}
.ft-t{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:15px;color:rgba(253,251,247,.3);max-width:380px;margin:0 auto 40px;line-height:1.9;}
.ft-l{width:1px;height:60px;background:linear-gradient(180deg,transparent,rgba(184,151,90,.2),transparent);margin:0 auto 28px;}
.ft-c{font-size:9px;letter-spacing:3px;color:rgba(253,251,247,.15);text-transform:uppercase;}

/* ── REVEAL ── */
.rv{opacity:0;transform:translateY(44px);transition:opacity .9s ease,transform .9s ease;}
.rv.in{opacity:1;transform:translateY(0);}
.d1{transition-delay:.12s;}.d2{transition-delay:.24s;}.d3{transition-delay:.36s;}
