:root{
  --cream:#f5ecd7; --cream-2:#ede0c2;
  --daun:#5a7a4f; --daun-dark:#3f5a38;
  --kayu:#6b4a2b; --kayu-dark:#3d2a18;
  --emas:#b38b3f; --ink:#2b241a;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{width:100%;overflow-x:hidden;background:var(--cream);color:var(--ink);font-family:'Poppins',sans-serif;}
body.locked{overflow:hidden;height:100vh;}
.batik-bg{
  background-color:var(--cream);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'><g fill='none' stroke='%235a7a4f' stroke-width='1' opacity='0.18'><circle cx='60' cy='60' r='26'/><circle cx='60' cy='60' r='14'/><path d='M60 20 Q70 40 60 60 Q50 80 60 100'/><path d='M20 60 Q40 50 60 60 Q80 70 100 60'/><path d='M30 30 Q60 45 90 30'/><path d='M30 90 Q60 75 90 90'/></g></svg>");
  background-size:180px 180px;
}
h1,h2,h3,.serif{font-family:'Cormorant Garamond',serif;letter-spacing:.5px;}
.display{font-family:'Playfair Display',serif;font-style:italic;}

#lockscreen{
  position:fixed;inset:0;z-index:1000;
  background:linear-gradient(180deg, rgba(30,20,10,.25) 0%, rgba(30,20,10,.75) 100%),
    url("https://images.unsplash.com/photo-1606800052052-a08af7148866?auto=format&fit=crop&w=1200&q=80") center/cover no-repeat;
  display:flex;flex-direction:column;justify-content:space-between;align-items:center;
  padding:48px 28px 56px;color:#fff;text-align:center;
  transition:opacity .9s ease, transform .9s ease;
}
#lockscreen.closing{opacity:0;transform:translateY(-40px);pointer-events:none;}
#lockscreen .ornament{font-size:12px;letter-spacing:6px;text-transform:uppercase;color:var(--cream);opacity:.85;}
#lockscreen .ornament::before,#lockscreen .ornament::after{content:"";display:inline-block;width:28px;height:1px;background:var(--cream);vertical-align:middle;margin:0 10px;opacity:.7;}
#lockscreen .middle{display:flex;flex-direction:column;align-items:center;gap:14px;}
#lockscreen .hello{font-family:'Playfair Display',serif;font-style:italic;font-size:18px;color:#f3e9cf;}
#lockscreen .names{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:54px;line-height:1.05;text-shadow:0 2px 20px rgba(0,0,0,.45);}
#lockscreen .amp{color:var(--emas);font-style:italic;}
#lockscreen .date{margin-top:6px;font-size:13px;letter-spacing:4px;text-transform:uppercase;}
#lockscreen .guest{margin-top:22px;font-size:13px;opacity:.9;}
#lockscreen .guest b{display:block;font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;margin-top:4px;}
.btn-open{margin-top:10px;background:var(--cream);color:var(--kayu-dark);border:none;border-radius:999px;padding:14px 34px;font-family:'Poppins',sans-serif;font-size:14px;letter-spacing:2px;text-transform:uppercase;font-weight:500;cursor:pointer;box-shadow:0 10px 30px rgba(0,0,0,.35);transition:transform .25s ease, background .25s ease;}
.btn-open i{margin-right:8px;color:var(--daun-dark);}
.btn-open:hover{transform:translateY(-2px);background:#fff;}

.app{max-width:480px;margin:0 auto;position:relative;box-shadow:0 0 40px rgba(0,0,0,.08);min-height:100vh;}
section{padding:72px 26px;position:relative;}
.center{text-align:center;}
.eyebrow{font-size:11px;letter-spacing:5px;text-transform:uppercase;color:var(--daun-dark);margin-bottom:14px;}
.eyebrow::before,.eyebrow::after{content:"";display:inline-block;width:22px;height:1px;background:var(--daun);vertical-align:middle;margin:0 10px;opacity:.6;}
h2.section-title{font-size:34px;font-weight:600;color:var(--kayu-dark);margin-bottom:10px;}
.divider{width:60px;height:1px;background:var(--emas);margin:18px auto;position:relative;}
.divider::before{content:"❋";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);color:var(--emas);background:var(--cream);padding:0 8px;font-size:12px;}

#hero{min-height:100vh;padding:80px 26px 60px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;
  background:linear-gradient(180deg, rgba(245,236,215,.6) 0%, rgba(245,236,215,.95) 100%),
    url("https://images.unsplash.com/photo-1519741497674-611481863552?auto=format&fit=crop&w=900&q=80") center/cover no-repeat;}
#hero .wilujeng{font-family:'Playfair Display',serif;font-style:italic;font-size:18px;color:var(--kayu);margin-bottom:16px;}
#hero .couple{font-family:'Cormorant Garamond',serif;font-weight:700;font-size:64px;line-height:1;color:var(--kayu-dark);}
#hero .couple .amp{color:var(--emas);font-style:italic;font-weight:400;}
#hero .sub{margin-top:18px;font-size:13px;letter-spacing:3px;text-transform:uppercase;color:var(--daun-dark);}
#hero .big-date{margin-top:28px;display:flex;gap:18px;align-items:center;justify-content:center;color:var(--kayu-dark);}
#hero .big-date .d{font-family:'Cormorant Garamond',serif;font-size:42px;font-weight:600;line-height:1;}
#hero .big-date .m{font-size:11px;letter-spacing:3px;text-transform:uppercase;}
#hero .big-date .line{width:1px;height:56px;background:var(--emas);opacity:.6;}
#hero .scroll-hint{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);color:var(--kayu);font-size:11px;letter-spacing:3px;text-transform:uppercase;opacity:.7;animation:bounce 2s infinite;}
@keyframes bounce{0%,100%{transform:translate(-50%,0);}50%{transform:translate(-50%,6px);}}

#quote{background:var(--daun-dark);color:var(--cream);}
#quote .eyebrow{color:var(--emas);}
#quote .eyebrow::before,#quote .eyebrow::after{background:var(--emas);}
#quote h2.section-title{color:var(--cream);}
#quote .ayat{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:20px;line-height:1.7;margin:20px auto;max-width:420px;}
#quote .ref{display:inline-block;margin-top:14px;font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--emas);}

.event-card{background:#fff;border:1px solid var(--cream-2);border-radius:18px;padding:28px 22px;margin:16px 0;text-align:center;box-shadow:0 8px 24px rgba(107,74,43,.08);position:relative;overflow:hidden;}
.event-card .pita{position:absolute;top:14px;left:50%;transform:translateX(-50%);font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--emas);}
.event-card h3{font-size:28px;color:var(--kayu-dark);margin:18px 0 10px;font-weight:600;}
.event-card .row{display:flex;align-items:center;justify-content:center;gap:10px;font-size:14px;color:var(--ink);margin:6px 0;}
.event-card .row i{color:var(--daun-dark);width:18px;}
.event-card .addr{font-size:13px;color:#6b5c43;line-height:1.6;margin-top:6px;}
.event-card .btn-maps{display:inline-flex;align-items:center;gap:8px;margin-top:16px;background:var(--daun-dark);color:var(--cream);padding:10px 20px;border-radius:999px;font-size:12px;letter-spacing:2px;text-transform:uppercase;text-decoration:none;transition:background .2s;}
.event-card .btn-maps:hover{background:var(--daun);}

#countdown-sec{background:var(--cream-2);}
.countdown{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;max-width:420px;margin:24px auto 0;}
.cd-box{background:#fff;border:1px solid var(--cream);border-radius:14px;padding:16px 6px;text-align:center;box-shadow:0 6px 18px rgba(107,74,43,.08);}
.cd-box .n{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:700;color:var(--daun-dark);line-height:1;}
.cd-box .l{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--kayu);margin-top:6px;}

#lokasi .map-wrap{margin-top:20px;border-radius:18px;overflow:hidden;box-shadow:0 10px 26px rgba(107,74,43,.12);border:1px solid var(--cream-2);}
#lokasi iframe{width:100%;height:240px;border:0;display:block;}

.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:24px;}
.gallery .item{aspect-ratio:1/1;overflow:hidden;border-radius:10px;position:relative;cursor:pointer;box-shadow:0 6px 16px rgba(107,74,43,.1);}
.gallery .item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;}
.gallery .item:hover img{transform:scale(1.08);}
.gallery .item.wide{grid-column:span 2;aspect-ratio:2/1;}

.lightbox{position:fixed;inset:0;background:rgba(20,14,6,.92);z-index:1500;display:none;align-items:center;justify-content:center;padding:24px;}
.lightbox.open{display:flex;}
.lightbox img{max-width:100%;max-height:85vh;border-radius:10px;}
.lightbox .close{position:absolute;top:20px;right:22px;color:#fff;background:transparent;border:none;font-size:28px;cursor:pointer;}

#rsvp{background:var(--daun-dark);color:var(--cream);}
#rsvp .eyebrow{color:var(--emas);}
#rsvp .eyebrow::before,#rsvp .eyebrow::after{background:var(--emas);}
#rsvp h2.section-title{color:var(--cream);}
.form{max-width:420px;margin:22px auto 0;display:flex;flex-direction:column;gap:12px;}
.form input,.form select,.form textarea{width:100%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);color:var(--cream);padding:14px 16px;border-radius:12px;font-family:inherit;font-size:14px;outline:none;transition:border .2s,background .2s;}
.form input::placeholder,.form textarea::placeholder{color:rgba(245,236,215,.55);}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--emas);background:rgba(255,255,255,.12);}
.form select option{color:var(--ink);}
.form textarea{min-height:90px;resize:vertical;}
.form button{background:var(--emas);color:var(--kayu-dark);border:none;border-radius:999px;padding:14px;font-family:inherit;font-size:13px;font-weight:600;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:transform .2s,background .2s;margin-top:6px;}
.form button:hover{transform:translateY(-2px);background:#d4a653;}

.wishes{max-width:420px;margin:34px auto 0;display:flex;flex-direction:column;gap:12px;max-height:360px;overflow-y:auto;padding-right:4px;}
.wishes::-webkit-scrollbar{width:5px;}
.wishes::-webkit-scrollbar-thumb{background:var(--emas);border-radius:10px;}
.wish{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:14px 16px;}
.wish .n{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:600;color:var(--cream);}
.wish .st{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--emas);margin-top:2px;}
.wish .m{font-size:13px;line-height:1.55;margin-top:8px;color:rgba(245,236,215,.88);}

#closing{text-align:center;padding:90px 26px;
  background:linear-gradient(180deg, rgba(245,236,215,.85), rgba(245,236,215,.95)),
    url("https://images.unsplash.com/photo-1519225421980-715cb0215aed?auto=format&fit=crop&w=900&q=80") center/cover no-repeat;}
#closing .thanks{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:22px;color:var(--kayu);margin-top:14px;}
#closing .couple-sm{font-family:'Cormorant Garamond',serif;font-size:38px;font-weight:700;color:var(--kayu-dark);margin-top:10px;}
#closing .foot{margin-top:28px;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--kayu);opacity:.75;}

#musicBtn{position:fixed;bottom:22px;right:22px;z-index:900;width:52px;height:52px;border-radius:50%;background:var(--daun-dark);color:var(--cream);border:none;display:none;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 10px 24px rgba(0,0,0,.3);transition:transform .25s;}
#musicBtn.show{display:flex;}
#musicBtn:hover{transform:scale(1.08);}
#musicBtn.playing i{animation:spin 4s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

.wish{
  position: relative;
  background: #fff;
  border-radius: 14px;
  padding: 14px 16px;
  margin-bottom: 12px;
  box-shadow: 0 6px 20px rgba(0,0,0,.06);
  border: 1px solid rgba(0,0,0,.05);
}

.wish-head{
  display:flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 6px;
}

.wish .n{
  font-weight: 600;
  font-size: 14px;
  color: #3b2f22;
}

.wish .t{
  font-size: 11px;
  opacity: .6;
  color: #7a6b52;
  white-space: nowrap;
}

.wish .st{
  font-size: 11px;
  color: #b08b5b;
  margin-bottom: 6px;
}

.wish .m{
  font-size: 13px;
  line-height: 1.5;
  color: #4a3b2c;
}

.rekening{
  font-size:16px;
  font-weight:600;
  letter-spacing:1px;
  margin:10px 0;
  color:#3b2f22;
}

#amplop .event-card{
  margin-bottom:20px;
  text-align:center;
}

.modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.6);
  justify-content: center;
  align-items: center;
  z-index: 9999;
}

.modal-box {
  background: #fff;
  padding: 20px;
  max-width: 400px;
  width: 90%;
  border-radius: 12px;
  text-align: center;
  position: relative;
  animation: pop .2s ease;
}

@keyframes pop {
  from { transform: scale(.9); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}

.modal .close {
  position: absolute;
  top: 10px;
  right: 12px;
  font-size: 20px;
  cursor: pointer;
}

.contact-btn {
  margin-top: 15px;
  font-size: 13px;
  color: #8a6d3b;
  cursor: pointer;
  text-decoration: underline;
}

.email-btn {
  display: inline-block;
  margin-top: 15px;
  padding: 10px 15px;
  background: #8a6d3b;
  color: #fff;
  border-radius: 8px;
  text-decoration: none;
}