:root {
  --ivory:#fffaf3; --cream:#f8efe3; --paper:#f4e9d9; --gold:#c99b5b; --gold-soft:#e7ceaa;
  --terracotta:#b85d38; --terracotta-deep:#9c4529; --olive:#3b4a3c; --brown:#503b30;
  --ink:#42342c; --muted:#817064; --footer:#30382f;
  --serif:"Cormorant Garamond", Georgia, serif; --script:"Great Vibes", cursive;
  --sans:"Plus Jakarta Sans", Arial, sans-serif;
  --shadow:0 16px 38px rgba(82,56,38,.16); --shadow-soft:0 8px 24px rgba(82,56,38,.10);
}
*{box-sizing:border-box} html{scroll-behavior:smooth} body{margin:0;background:#ede3d7;color:var(--ink);font-family:var(--sans)}
body.locked{overflow:hidden} img{max-width:100%;display:block} button,input,select,textarea{font:inherit} button{cursor:pointer}
[hidden]{display:none!important}.section{position:relative;padding:44px 18px;overflow:hidden}
.invitation{width:100%;max-width:1100px;margin:auto;min-height:100vh;background:var(--ivory);box-shadow:var(--shadow)}
.wedding-script{font-family:var(--script);font-size:clamp(2rem,8vw,3.2rem);line-height:1;color:var(--brown);margin:0}
.button-primary{border:0;border-radius:999px;min-height:53px;padding:0 30px;display:inline-flex;align-items:center;justify-content:center;gap:18px;background:linear-gradient(120deg,var(--terracotta),#c86b44);color:#fff9ee;font-family:var(--serif);font-weight:700;font-size:1.34rem;box-shadow:0 9px 18px rgba(157,73,40,.24)}
.button-primary .heart{border-left:1px solid rgba(255,255,255,.4);padding-left:18px}.button-primary.compact{min-height:42px;padding:0 22px;font-size:.84rem;font-family:var(--sans);font-weight:600;gap:10px}
.loading-screen{position:fixed;inset:0;z-index:100;background:var(--cream);display:grid;place-content:center;gap:18px;transition:.38s}
.loading-screen.loaded{opacity:0;visibility:hidden}.loading-screen img{width:104px;margin:auto}.loading-line{width:116px;height:2px;background:var(--gold-soft);overflow:hidden}.loading-line span{display:block;width:42%;height:100%;background:var(--terracotta);animation:load 1s ease infinite}
@keyframes load{from{transform:translateX(-100%)}to{transform:translateX(340%)}}

/* COVER — refined only, mendekati referensi */
.cover{
  position:fixed;
  inset:0;
  z-index:50;
  overflow:hidden;
  background:#f2e2d0;
  transition:transform .78s cubic-bezier(.63,0,.37,1),opacity .78s ease;
}
.cover.close{transform:translateY(-105%);opacity:0}
.cover-photo{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 38%;
  transform:scale(1.32);
  transform-origin:center 42%;
  filter:saturate(1.02) contrast(1.035) brightness(1.01);
}
.cover-overlay{
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse at 50% 18%, rgba(255,250,240,.82) 0%, rgba(255,249,237,.22) 25%, transparent 43%),
    linear-gradient(180deg, rgba(255,246,232,.39) 0%, rgba(255,246,232,.04) 34%, rgba(39,29,22,.08) 56%, rgba(255,248,237,.58) 73%, rgba(255,249,241,.96) 100%);
}
.cover-corner{
  position:absolute;
  z-index:1;
  top:-4px;
  width:clamp(105px,31vw,165px);
  opacity:.74;
  filter:drop-shadow(0 3px 5px rgba(90,56,30,.08));
}
.cover-corner-tl{left:-6px}
.cover-corner-tr{right:-6px}
.cover-flower{
  position:absolute;
  z-index:2;
  width:clamp(138px,38vw,220px);
  bottom:-48px;
  opacity:.75;
  filter:drop-shadow(0 8px 14px rgba(90,56,30,.08));
}
.cover-flower-left{left:-53px}
.cover-flower-right{right:-53px}
.cover-brand{
  position:absolute;
  z-index:3;
  top:max(31px,env(safe-area-inset-top));
  left:0;
  right:0;
  display:flex;
  justify-content:center;
}
.cover-monogram{
  width:clamp(110px,29vw,136px);
  opacity:.94;
  filter:drop-shadow(0 3px 8px rgba(90,56,30,.10));
}
.cover-title{
  position:absolute;
  z-index:3;
  left:18px;
  right:18px;
  bottom:clamp(274px,35.5svh,322px);
  text-align:center;
}
.cover-title::before{
  content:"";
  position:absolute;
  z-index:-1;
  left:50%;
  top:54%;
  width:min(96%,360px);
  height:98px;
  transform:translate(-50%,-50%);
  background:radial-gradient(ellipse, rgba(255,248,236,.58), rgba(255,248,236,0) 72%);
  pointer-events:none;
}
.cover-title .wedding-script{
  font-family:var(--script);
  font-size:clamp(1.72rem,7.6vw,2.34rem);
  font-weight:400;
  line-height:1;
  margin:0 0 4px;
  color:#49362b;
  text-shadow:0 1px 10px rgba(255,250,240,.95);
}
.couple-name{
  font-family:var(--serif);
  font-size:clamp(2.54rem,11.3vw,3.72rem);
  font-weight:700;
  letter-spacing:-.035em;
  line-height:.93;
  margin:0;
  text-shadow:0 1px 13px rgba(255,248,235,.92);
}
.couple-name span:first-child{color:#a94f32}
.couple-name em{
  color:#c29962;
  font-style:normal;
  font-weight:500;
  padding:0 .04em;
}
.couple-name span:last-child{color:#35453a}
.cover-event-date{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin:10px 0 0;
  font:600 clamp(.82rem,3.45vw,.96rem)/1.2 var(--serif);
  letter-spacing:.035em;
  color:#523d32;
  text-shadow:0 1px 8px rgba(255,248,236,.95);
}
.cover-event-date::before,
.cover-event-date::after{
  content:"";
  width:28px;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--gold));
}
.cover-event-date::after{background:linear-gradient(90deg,var(--gold),transparent)}
.invited-card{
  position:absolute;
  z-index:4;
  left:8.7%;
  right:8.7%;
  bottom:max(18px,env(safe-area-inset-bottom));
  padding:16px 18px 13px;
  text-align:center;
  border-radius:23px;
  background:
    radial-gradient(circle at 50% 0, rgba(255,255,255,.77), rgba(255,251,243,.3) 50%, transparent 80%),
    rgba(255,250,242,.965);
  border:1px solid rgba(204,162,105,.42);
  box-shadow:0 12px 30px rgba(72,49,35,.15), inset 0 1px rgba(255,255,255,.84);
  backdrop-filter:blur(4px);
}
.invited-card::before{
  content:"✦";
  position:absolute;
  top:-10px;
  left:50%;
  transform:translateX(-50%);
  width:31px;
  height:19px;
  display:grid;
  place-items:center;
  color:var(--gold);
  font-size:.65rem;
  background:#fffaf2;
  border-radius:999px;
}
.invited-card p{
  font:500 clamp(.98rem,4.15vw,1.13rem)/1.2 var(--serif);
  letter-spacing:.015em;
  color:#413229;
  margin:0 0 2px;
}
.guest-name{
  min-height:auto;
  margin:10px 10px 15px;
  padding:3px 8px 12px;
  border:0;
  border-bottom:1px solid rgba(185,92,55,.34);
  border-radius:0;
  display:grid;
  place-items:center;
  font:700 clamp(1.18rem,5.1vw,1.44rem)/1.15 var(--serif);
  letter-spacing:.01em;
  color:var(--terracotta);
}
.invited-card .button-primary{
  width:100%;
  min-height:51px;
  border:1px solid rgba(143,63,35,.18);
  background:linear-gradient(105deg,#ad4f2e,#c36740 58%,#b35431);
  font-size:clamp(1.15rem,5vw,1.32rem);
  box-shadow:0 7px 16px rgba(157,73,40,.22), inset 0 1px rgba(255,255,255,.19);
}
.invited-card .button-primary .heart{font-size:.92em}
.invited-card small{
  display:block;
  margin-top:12px;
  color:#806c60;
  font-size:clamp(.56rem,2.3vw,.62rem);
  line-height:1.35;
}
.sparkles i{
  position:absolute;
  z-index:2;
  width:6px;
  height:6px;
  border-radius:50%;
  background:#fff;
  box-shadow:0 0 0 5px rgba(255,255,255,.13),0 0 18px 7px rgba(255,255,255,.64);
  animation:sparkle 3.2s ease-in-out infinite;
}
.sparkles i:nth-child(1){top:17%;left:17%}
.sparkles i:nth-child(2){top:23%;right:18%;animation-delay:.7s}
.sparkles i:nth-child(3){top:47%;left:12%;animation-delay:1.4s}
.sparkles i:nth-child(4){top:53%;right:13%;animation-delay:2s}
@keyframes sparkle{50%{opacity:.22;transform:scale(.65)}}

/* Header */
.site-header{position:sticky;top:0;z-index:20;background:rgba(255,250,243,.91);backdrop-filter:blur(12px);border-bottom:1px solid rgba(201,155,91,.16)}
.header-inner{height:62px;padding:0 16px;display:flex;align-items:center;justify-content:space-between;max-width:1000px;margin:auto}.header-logo{width:49px}.desktop-nav{display:none}.mini-button{height:38px;border:1px solid var(--gold-soft);border-radius:22px;background:#fff9ef;color:var(--terracotta);display:flex;align-items:center;gap:9px;padding:0 13px;font-size:.76rem}

/* Hero mobile */
.hero{padding:18px 14px 42px;background:radial-gradient(circle at 50% 0,rgba(231,199,150,.25),transparent 31%),var(--ivory)}
.watermark{position:absolute;pointer-events:none;opacity:.09}.hero-watermark{right:-50px;top:10px;width:150px}.hero-visual{position:relative;border-radius:10px 10px 26px 26px;overflow:hidden;min-height:520px;box-shadow:var(--shadow-soft)}
.hero-visual>img{width:100%;height:520px;object-fit:cover;object-position:center 31%}
.hero-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(255,249,239,.8),rgba(255,249,239,.03) 30%,transparent 58%,rgba(81,55,37,.14))}
.hero-visual-brand{position:absolute;z-index:1;top:18px;left:0;right:0;text-align:center}.hero-visual-brand img{width:72px;margin:0 auto 5px}.hero-visual-brand p{font:400 1.3rem/1 var(--script);margin:0;color:var(--brown)}.hero-visual-brand h2{margin:4px 0 0;font:600 2.35rem/.9 var(--serif);color:var(--terracotta)}.hero-visual-brand h2 em{color:var(--olive);font-style:normal}
.event-summary{position:relative;z-index:2;margin:-48px 16px 12px;padding:14px 16px;background:rgba(255,250,243,.98);border:1px solid var(--gold-soft);border-radius:15px;box-shadow:var(--shadow-soft);display:grid;gap:8px}
.event-summary div{display:flex;align-items:flex-start;gap:11px;color:var(--olive);font-size:.78rem}.event-summary strong{font-size:.82rem}.event-summary p{margin:0;line-height:1.48}.event-symbol{font-size:1.1rem;color:var(--terracotta);line-height:1}
.countdown-card{margin:0 16px;background:#fff9ef;border:1px solid var(--gold-soft);border-radius:15px;padding:13px 10px 11px;text-align:center;box-shadow:var(--shadow-soft)}.countdown-card p{margin:0 0 11px;font:600 .96rem var(--serif);color:var(--brown)}.countdown-card p span{color:var(--gold)}
.countdown{display:flex;align-items:center;justify-content:center;gap:8px}.countdown div{min-width:44px;display:grid;gap:2px}.countdown strong{font:600 1.95rem/1 var(--serif);color:var(--terracotta)}.countdown span{font-size:.59rem;color:var(--olive)}.countdown b{color:var(--gold);font-size:1.15rem}

/* Headings and opening */
.jawa-divider{width:min(190px,48vw);height:auto;opacity:.7;margin:0 auto 5px}.section-heading{display:flex;align-items:center;justify-content:center;gap:12px;margin:0 0 24px}.section-heading h2{font:600 clamp(1.36rem,5.4vw,1.9rem)/1 var(--serif);margin:0;color:var(--brown);white-space:nowrap}.section-heading span{height:1px;width:32px;background:linear-gradient(90deg,transparent,var(--gold))}.section-heading span:last-child{background:linear-gradient(90deg,var(--gold),transparent)}
.opening{text-align:center;padding-top:30px;padding-bottom:34px;background:#fffaf3}.opening-salam{font:400 clamp(1.7rem,7vw,2.25rem)/1.1 var(--script);margin:10px auto 10px;color:var(--brown)}.opening-copy{max-width:570px;margin:0 auto;font-size:.78rem;line-height:1.8;color:var(--muted)}

/* Couple */
.couple{background:linear-gradient(180deg,#fffaf3,#fbf2e7);padding-top:40px}.watermark-right{right:-55px;top:38px;width:170px}.watermark-left{left:-58px;top:34px;width:170px}.couple-layout{position:relative;z-index:1;display:grid;grid-template-columns:1fr 58px 1fr;gap:8px;align-items:center;max-width:640px;margin:auto}
.person-card{text-align:center;padding:9px 7px 14px;background:#fffaf3;border:1px solid var(--gold-soft);border-radius:68px 68px 10px 10px;box-shadow:var(--shadow-soft)}
.portrait{height:175px;border-radius:57px 57px 10px 10px;overflow:hidden;background:var(--paper)}.portrait img{width:100%;height:100%;object-fit:cover;object-position:center top}.person-card h3{font:400 clamp(1.05rem,4.4vw,1.34rem)/1 var(--script);color:var(--terracotta);margin:12px 0 3px}.person-card .degree{font-size:.61rem;font-weight:600;color:var(--olive);margin:0 0 6px}.person-card p:not(.degree){margin:0;font-size:.6rem;line-height:1.48;color:var(--muted)}.middle-monogram img{width:58px;margin:auto}

/* Story */
.story{background:#fbf2e7;padding-top:34px}.timeline{max-width:750px;margin:auto;display:grid;grid-template-columns:repeat(3,1fr);gap:9px;position:relative}.timeline::before{content:"";position:absolute;top:25px;left:12%;right:12%;height:1px;background:var(--gold-soft)}
.timeline-item{position:relative;text-align:center}.story-icon{position:relative;z-index:1;margin:auto auto 10px;width:50px;height:50px;display:grid;place-items:center;background:#fffaf2;border:1px solid var(--gold-soft);border-radius:12px;color:var(--terracotta);font-size:1.35rem}.timeline-item h3{font:600 .78rem/1.2 var(--serif);margin:0 0 4px}.timeline-item strong{display:block;font-size:.62rem;color:var(--terracotta);margin-bottom:5px}.timeline-item p{font-size:.57rem;line-height:1.5;color:var(--muted);margin:0}

/* Gallery */
.gallery{background:#fffaf3;text-align:center;padding-top:35px}.section-floral{position:absolute;left:-55px;bottom:-34px;width:190px;opacity:.19;pointer-events:none}.gallery-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin:0 auto 14px;max-width:800px}.gallery-photo{display:block;padding:0;border:0;min-height:96px;border-radius:11px;background:#efe2d1;overflow:hidden;opacity:1;transform:none;box-shadow:0 3px 10px rgba(82,56,38,.08);transition:transform .22s ease,box-shadow .22s ease}.gallery-photo:hover{transform:translateY(-2px);box-shadow:0 8px 18px rgba(82,56,38,.15)}.gallery-photo img{display:block;width:100%;height:100%;min-height:96px;object-fit:cover;object-position:center}.gallery-photo:first-child,.gallery-photo:nth-child(2){grid-column:span 2;min-height:130px}.gallery-photo:first-child img,.gallery-photo:nth-child(2) img{height:130px}.gallery-photo:nth-child(3){grid-column:span 1;min-height:130px}.gallery-photo:nth-child(3) img{height:130px}.gallery-photo:nth-child(4){grid-column:span 2}.gallery-photo:nth-child(5){grid-column:span 3}

/* Events */
.events{background:#fcf4e9;padding-top:36px}.events-grid{position:relative;z-index:1;display:grid;gap:11px;max-width:920px;margin:auto}.event-card,.map-card{border:1px solid var(--gold-soft);background:#fffaf3;border-radius:13px;padding:17px 14px;text-align:left;box-shadow:0 4px 13px rgba(81,55,37,.05)}.event-icon{font-size:1.28rem;color:var(--terracotta);margin-bottom:6px}.event-card h3,.map-card h3{font:600 1.25rem/1 var(--serif);color:var(--brown);margin:0 0 11px}.event-card p{font-size:.72rem;line-height:1.6;margin:4px 0;color:var(--olive)}.entertainment{margin-top:9px!important;padding:6px 8px;border-radius:7px;background:#f5ead9;color:var(--terracotta)!important;font-weight:600}.map-preview{height:122px;border-radius:10px;background:linear-gradient(135deg,#efe8dc,#faf5ed);display:grid;place-items:center;text-align:center;margin-bottom:12px;position:relative;overflow:hidden}.map-preview::after{content:"";position:absolute;inset:0;background-image:linear-gradient(35deg,transparent 45%,rgba(198,155,91,.14) 46%,transparent 47%),linear-gradient(-35deg,transparent 45%,rgba(198,155,91,.12) 46%,transparent 47%);background-size:58px 58px}.map-pin{position:relative;z-index:1;color:var(--terracotta);font-size:1.35rem}.map-preview p{position:relative;z-index:1;font-size:.65rem;color:var(--muted);margin:0}



/* Wedding Gift — kartu rekening sesuai gaya referensi */
.intro-copy{
  margin:0 0 15px;
  color:var(--muted);
  font-size:.7rem;
  line-height:1.65;
  text-align:center;
}
.gift-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:9px;
}
.bank-card{
  position:relative;
  overflow:hidden;
  min-height:143px;
  padding:12px 9px 10px;
  border:1px solid var(--gold-soft);
  border-radius:11px;
  background:linear-gradient(145deg,#fffdf8,#f6ebda);
  text-align:center;
}
.bank-card::after{
  content:"";
  position:absolute;
  right:-24px;
  top:-32px;
  width:76px;
  height:76px;
  border-radius:50%;
  background:rgba(201,155,91,.10);
}
.bank-card-head{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  margin-bottom:12px;
}
.bank-card-head strong{
  font-family:var(--sans);
  font-size:.87rem;
  font-weight:700;
  letter-spacing:.01em;
}
.bank-chip{
  display:inline-block;
  width:6px;
  height:17px;
  border-radius:4px;
  transform:skew(-11deg);
}
.bank-bri .bank-card-head strong{color:#1268af}
.bank-bri .bank-chip{background:#f47521;box-shadow:7px 0 0 #1268af}
.bank-mandiri .bank-card-head strong{color:#163d72}
.bank-mandiri .bank-chip{background:#f8b91b;box-shadow:7px 0 0 #163d72}
.account-number{
  position:relative;
  z-index:1;
  margin:0 0 6px;
  color:var(--olive);
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.04em;
  white-space:nowrap;
}
.account-holder{
  position:relative;
  z-index:1;
  min-height:26px;
  margin:0 0 10px;
  color:var(--muted);
  font-size:.57rem;
  line-height:1.35;
}
.copy-account{
  position:relative;
  z-index:1;
  min-height:29px;
  padding:0 10px;
  border:1px solid var(--gold-soft);
  border-radius:999px;
  background:#fff9ef;
  color:var(--terracotta);
  font-size:.58rem;
  font-weight:600;
}
.copy-account:active{
  transform:scale(.98);
}
@media (max-width:350px){
  .gift-list{grid-template-columns:1fr;}
}

/* RSVP and wishes */
.interaction{background:#fbf1e5;display:grid;gap:13px}.gift-card,.rsvp-card{border:1px solid var(--gold-soft);background:#fffaf3;border-radius:14px;padding:18px 15px;box-shadow:var(--shadow-soft)}.section-heading.small{margin-bottom:16px}.section-heading.small h2{font-size:1.2rem}.rsvp-form{display:grid;gap:9px}.rsvp-form input,.rsvp-form select,.rsvp-form textarea{width:100%;border:1px solid #e5d4bc;background:#fffaf2;border-radius:8px;padding:11px 12px;font-size:.72rem;color:var(--ink);outline:none}.rsvp-form textarea{resize:vertical}.rsvp-form .button-primary{margin-top:3px;width:max-content;justify-self:center}.form-notice{font-size:.65rem;margin:4px 0 0;color:var(--terracotta);text-align:center}
.wishes{text-align:center;background:#f9efe3;padding-top:28px}.wish-list{display:grid;gap:10px;max-width:920px;margin:0 auto 15px}.wish-card{background:#fffaf3;border:1px solid var(--gold-soft);border-radius:12px;padding:12px;display:grid;grid-template-columns:42px 1fr 18px;gap:10px;text-align:left}.avatar{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:#efe0cc;font:700 1.25rem var(--serif);color:var(--terracotta)}.wish-card h3{font-size:.74rem;margin:0 0 4px}.wish-card p{font-size:.65rem;line-height:1.55;margin:0 0 5px}.wish-card small{font-size:.56rem;color:var(--muted)}.wish-heart{color:var(--terracotta);font-size:.8rem;align-self:end}

/* Footer/navigation */
.footer{position:relative;overflow:hidden;background:var(--footer);color:#f2e6d1;padding:28px 15px 82px;text-align:center;border-top:2px solid var(--gold)}.footer-floral{position:absolute;left:50%;bottom:-72px;transform:translateX(-50%);width:min(300px,82vw);opacity:.2}.footer-grid{position:relative;z-index:1;display:grid;grid-template-columns:1fr 74px 1fr;align-items:center;gap:8px;max-width:580px;margin:0 auto 17px}.footer-grid h3{margin:0 0 4px;font:400 1.65rem var(--script);color:var(--gold-soft)}.footer-grid p{margin:0;font-size:.62rem;line-height:1.65}.footer-grid img{width:72px}.footer small{position:relative;z-index:1;font-size:.57rem;color:rgba(242,230,209,.7)}
.bottom-nav{position:fixed;z-index:30;left:50%;bottom:max(10px,env(safe-area-inset-bottom));transform:translate(-50%,130%);display:grid;grid-template-columns:repeat(5,1fr);width:min(calc(100vw - 26px),390px);padding:6px;background:#fff9ef;border:1px solid var(--gold-soft);box-shadow:0 8px 24px rgba(75,49,33,.18);border-radius:999px;transition:transform .38s}.bottom-nav.show{transform:translate(-50%,0)}.bottom-nav a{text-decoration:none;color:var(--brown);border-radius:999px;padding:7px 3px;display:grid;justify-items:center;gap:2px;font-size:.55rem}.bottom-nav span{font-size:1rem}.bottom-nav a.active{background:var(--terracotta);color:#fff}
.lightbox{position:fixed;z-index:80;inset:0;padding:32px;background:rgba(27,21,17,.9);display:grid;place-items:center}.lightbox img{max-height:87vh;max-width:min(100%,800px);border-radius:14px}.lightbox button{position:absolute;right:18px;top:16px;border:0;background:none;color:#fff;font-size:2rem}.toast{position:fixed;z-index:90;left:50%;bottom:86px;transform:translate(-50%,14px);opacity:0;visibility:hidden;transition:.2s;padding:11px 16px;border-radius:999px;background:var(--olive);color:#fff9ef;font-size:.7rem;box-shadow:var(--shadow);text-align:center;max-width:calc(100vw - 36px)}.toast.show{opacity:1;visibility:visible;transform:translate(-50%,0)}
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}.reveal.shown{opacity:1;transform:none}

@media (max-height:720px) and (max-width:480px){
 .cover-photo{transform:scale(1.43);transform-origin:center 42%}.cover-brand{top:18px}.cover-monogram{width:96px}.cover-title{bottom:256px}.couple-name{font-size:2.44rem}.invited-card{left:9%;right:9%;padding:13px 15px 11px}.guest-name{margin:8px 7px 12px;padding-bottom:9px}.invited-card small{margin-top:9px}
}
@media (min-width:640px){
 .section{padding:54px 42px}.hero{display:grid;grid-template-columns:.85fr 1.15fr;gap:24px;align-items:center;padding:48px}
 .hero-visual{grid-column:2;grid-row:1 / 3;min-height:570px}.hero-visual>img{height:570px}.event-summary{grid-column:1;grid-row:1;margin:0;padding:22px}
 .countdown-card{grid-column:1 / 3;max-width:590px;width:100%;justify-self:center;margin-top:-52px;z-index:3}
 .portrait{height:250px}.events-grid{grid-template-columns:repeat(3,1fr)}.interaction{grid-template-columns:1fr 1fr;padding-left:44px;padding-right:44px}.wish-list{grid-template-columns:repeat(2,1fr)}
 .footer{padding-bottom:32px}
}
@media (min-width:820px){
 .header-inner{height:72px}.desktop-nav{display:flex;gap:27px}.desktop-nav a{text-decoration:none;color:var(--brown);font-size:.73rem}.bottom-nav{display:none}
}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}}


/* ===============================================================
   V9 — REFERENCE CORRECTION / BACKEND PRESERVED
   Fokus: kemiripan desain referensi, stabil di mobile dan desktop.
   =============================================================== */

/* Fail-safe: konten tidak boleh hilang meskipun API/animasi tidak berjalan. */
.reveal {
  opacity: 1 !important;
  transform: none !important;
}
.invitation {
  max-width: 768px;
  padding-bottom: 74px;
}

/* COVER: editorial, tetap menggunakan foto pasangan sendiri. */
.cover-photo {
  object-position: center 37%;
  filter: saturate(1.03) contrast(1.06) brightness(.96);
}
.cover-overlay {
  background:
    radial-gradient(ellipse at 50% 17%, rgba(255,248,234,.75) 0%, rgba(255,248,234,.10) 33%, transparent 48%),
    linear-gradient(180deg, rgba(49,36,28,.08) 0%, transparent 22%, rgba(36,27,22,.13) 48%, rgba(255,247,235,.54) 70%, rgba(255,250,242,.96) 100%);
}
.cover-monogram { width: clamp(118px,31vw,142px); }
.cover-title {
  bottom: clamp(276px,35.2svh,316px);
}
.cover-title .wedding-script {
  font-size: clamp(1.86rem,8vw,2.42rem);
  color: #423229;
}
.couple-name {
  font-size: clamp(2.78rem,12.2vw,3.92rem);
  font-weight: 700;
  letter-spacing: -.045em;
}
.invited-card {
  left: 8.5%;
  right: 8.5%;
  padding: 15px 18px 14px;
  border-color: rgba(201,155,91,.34);
  background: rgba(255,250,242,.972);
}
.guest-name {
  font-size: clamp(1.22rem,5.25vw,1.48rem);
  margin-bottom: 14px;
}
.invited-card .button-primary {
  min-height: 53px;
}

/* Header terasa lebih ringan seperti referensi. */
.site-header {
  border-bottom: 1px solid rgba(201,155,91,.12);
}
.header-logo { width: 53px; }

/* Hero mobile: komposisi kartu dan nav tidak saling menutup. */
.hero {
  padding: 17px 14px 30px;
}
.hero-desktop-copy {
  display: none;
}
.hero-visual {
  min-height: 535px;
  border-radius: 10px 10px 20px 20px;
}
.hero-visual > img {
  height: 535px;
  object-position: center 34%;
}
.hero-visual-brand img { width: 79px; }
.hero-visual-brand p { font-size: 1.45rem; }
.hero-visual-brand h2 { font-size: 2.52rem; }
.event-summary {
  margin-top: -54px;
  padding: 15px 17px;
  border-radius: 14px;
}
.countdown-card {
  margin-bottom: 76px;
  padding: 14px 10px 12px;
}
.bottom-nav {
  bottom: max(9px, env(safe-area-inset-bottom));
  width: min(calc(100vw - 30px), 370px);
  padding: 5px;
}

/* Compact spacing: referensi lebih padat dan terstruktur. */
.opening {
  padding-top: 26px;
  padding-bottom: 27px;
}
.opening-copy {
  max-width: 470px;
}
.couple {
  padding-top: 30px;
  padding-bottom: 34px;
}
.couple-layout {
  grid-template-columns: minmax(0,1fr) 45px minmax(0,1fr);
  gap: 8px;
}
.person-card {
  padding: 9px 8px 13px;
}
.portrait { height: 186px; }
.person-card p:not(.degree) {
  font-size: .64rem;
}
.middle-monogram img { width: 45px; }

.story {
  padding-top: 28px;
  padding-bottom: 30px;
}
.timeline {
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
}
.timeline::before {
  left: 8%;
  right: 8%;
}
.story-icon {
  width: 44px;
  height: 44px;
  font-size: 1.13rem;
}
.timeline-item h3 { font-size: .69rem; }
.timeline-item strong { font-size: .59rem; }
.timeline-item p { font-size: .52rem; }

.gallery {
  padding-top: 29px;
  padding-bottom: 34px;
}
.gallery-grid {
  gap: 9px;
  margin-bottom: 15px;
}
.gallery-photo {
  background: #efe3d3;
}
.gallery-photo.image-error::after {
  content: "Foto belum tersedia";
  display: grid;
  place-items: center;
  min-height: 98px;
  color: var(--muted);
  font-size: .6rem;
}
.gallery-photo.image-error img { display: none; }

.events {
  padding-top: 29px;
  padding-bottom: 34px;
}
.events-grid { gap: 10px; }
.interaction {
  padding-top: 29px;
  padding-bottom: 32px;
  gap: 11px;
}
.wishes {
  padding-top: 26px;
  padding-bottom: 34px;
}

/* Wedding Gift: Mandiri + DANA/OVO sesuai data final pengguna. */
.bank-mandiri .bank-card-head strong { color: #183e73; }
.bank-mandiri .bank-chip { background: #f9bb24; box-shadow: 7px 0 0 #173c70; }
.bank-wallet .bank-card-head strong { color: #1189d3; }
.bank-wallet .bank-chip { background: #1189d3; box-shadow: 7px 0 0 #653fa3; }
.account-number {
  font-size: .66rem;
  letter-spacing: .025em;
}

/* Desktop/tablet: halaman dibuat seperti lembar undangan referensi, tidak melebar kosong. */
@media (min-width: 640px) {
  body {
    background: #eee4d7;
  }
  .invitation {
    max-width: 768px;
    padding-bottom: 0;
  }
  .section {
    padding-left: 30px;
    padding-right: 30px;
  }
  .cover {
    left: 50%;
    right: auto;
    width: min(100vw, 480px);
    transform: translateX(-50%);
    box-shadow: 0 16px 45px rgba(69,48,34,.17);
  }
  .cover.close {
    transform: translate(-50%, -105%);
  }
  .hero {
    grid-template-columns: .86fr 1.14fr;
    column-gap: 18px;
    row-gap: 0;
    padding: 35px 30px 34px;
    align-items: center;
  }
  .hero-desktop-copy {
    display: block;
    grid-column: 1;
    grid-row: 1;
    align-self: center;
    padding: 10px 0 56px;
  }
  .hero-desktop-copy .wedding-script {
    font-size: 2.3rem;
    margin-bottom: 7px;
  }
  .hero-desktop-name {
    margin: 0 0 11px;
    font: 700 3.54rem/.87 var(--serif);
    letter-spacing: -.04em;
  }
  .hero-desktop-name span:first-child { color: var(--terracotta); }
  .hero-desktop-name em { color: var(--gold); font-style: normal; font-weight: 500; }
  .hero-desktop-name span:last-child { color: var(--olive); }
  .hero-desktop-date {
    margin: 0 0 4px;
    font: 700 1.02rem var(--serif);
    color: var(--brown);
  }
  .hero-desktop-location {
    margin: 0 0 18px;
    font-size: .67rem;
    line-height: 1.6;
    color: var(--olive);
  }
  .save-date-editorial {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--terracotta);
  }
  .save-date-editorial > span { font-size: 1.5rem; }
  .save-date-editorial strong {
    display: block;
    font-size: .68rem;
    color: var(--brown);
  }
  .save-date-editorial small {
    font-size: .58rem;
    color: var(--muted);
  }
  .hero-visual {
    grid-column: 2;
    grid-row: 1 / 3;
    min-height: 470px;
    border-radius: 9px;
  }
  .hero-visual > img {
    height: 470px;
    object-position: center 32%;
  }
  .hero-visual-brand {
    display: none;
  }
  .event-summary {
    display: none;
  }
  .countdown-card {
    grid-column: 1 / 3;
    width: min(470px, 85%);
    justify-self: end;
    position: relative;
    z-index: 2;
    margin: -80px 18px 0 0;
    padding: 13px 14px 12px;
  }
  .portrait { height: 246px; }
  .story .timeline { max-width: 620px; }
  .gallery-grid { max-width: 670px; }
  .events-grid { grid-template-columns: repeat(3, 1fr); }
  .interaction { grid-template-columns: 1fr 1fr; }
  .wish-list { grid-template-columns: repeat(2, 1fr); }
  .footer { padding-bottom: 30px; }
}

@media (min-width: 820px) {
  .header-inner { max-width: 704px; }
  .desktop-nav { gap: 22px; }
}


/* ===============================================================
   V10 — DESKTOP COVER FIX ONLY
   Android/mobile tidak berubah. Pada desktop cover menutup penuh
   halaman belakang, sedangkan panel undangan tampil terpusat rapi.
   =============================================================== */
@media (min-width: 640px) {
  /* Hapus efek halaman di belakang cover yang sebelumnya terlihat. */
  .cover {
    left: 0;
    right: 0;
    width: 100vw;
    max-width: none;
    transform: none;
    background:
      radial-gradient(circle at 50% 36%, #f8efdf 0%, #efe3d3 49%, #e7dac9 100%);
    box-shadow: none;
  }

  .cover.close {
    transform: translateY(-105%);
  }

  /* Membentuk panel vertikal utama di tengah; cocok dengan orientasi Android. */
  .cover::after {
    content: "";
    position: absolute;
    z-index: 0;
    top: 0;
    bottom: 0;
    left: 50%;
    width: min(480px, 100vw);
    transform: translateX(-50%);
    box-shadow:
      0 0 0 1px rgba(201,155,91,.12),
      0 18px 54px rgba(67,47,34,.13);
    pointer-events: none;
  }

  .cover-photo {
    left: 50%;
    right: auto;
    width: min(480px, 100vw);
    transform: translateX(-50%) scale(1.32);
    transform-origin: center 42%;
    object-position: center 37%;
  }

  .cover-overlay {
    left: 50%;
    right: auto;
    width: min(480px, 100vw);
    transform: translateX(-50%);
  }

  /* Semua ornamen dan konten cover mengikuti panel tengah, bukan viewport penuh. */
  .cover-corner {
    width: 146px;
  }
  .cover-corner-tl {
    left: calc(50% - 240px - 6px);
  }
  .cover-corner-tr {
    right: calc(50% - 240px - 6px);
  }
  .cover-flower {
    width: 192px;
  }
  .cover-flower-left {
    left: calc(50% - 240px - 50px);
  }
  .cover-flower-right {
    right: calc(50% - 240px - 50px);
  }

  .cover-brand {
    left: 50%;
    right: auto;
    width: 480px;
    transform: translateX(-50%);
    top: 32px;
  }
  .cover-monogram {
    width: 126px;
  }

  .cover-title {
    left: 50%;
    right: auto;
    width: 448px;
    transform: translateX(-50%);
    bottom: clamp(278px, 36vh, 320px);
  }
  .cover-title .wedding-script {
    font-size: 2.18rem;
  }
  .couple-name {
    font-size: 3.52rem;
  }

  .invited-card {
    left: 50%;
    right: auto;
    width: 404px;
    transform: translateX(-50%);
    bottom: 19px;
  }

  .sparkles i:nth-child(1) { left: calc(50% - 180px); }
  .sparkles i:nth-child(2) { right: calc(50% - 180px); }
  .sparkles i:nth-child(3) { left: calc(50% - 198px); }
  .sparkles i:nth-child(4) { right: calc(50% - 198px); }
}

/* Layar desktop pendek: jaga kartu dan judul tetap masuk satu viewport. */
@media (min-width: 640px) and (max-height: 760px) {
  .cover-photo {
    transform: translateX(-50%) scale(1.42);
  }
  .cover-brand {
    top: 18px;
  }
  .cover-monogram {
    width: 96px;
  }
  .cover-title {
    bottom: 256px;
  }
  .couple-name {
    font-size: 2.72rem;
  }
  .invited-card {
    width: 386px;
    padding: 13px 17px 11px;
  }
}
