
:root{
  --ivory:#f6efe4;
  --cream:#fbf7f1;
  --gold:#b98a59;
  --gold-2:#d4b58a;
  --bronze:#8d694f;
  --wine:#6d3140;
  --forest:#425347;
  --ink:#1f1f1d;
  --muted:#6b645c;
  --line:rgba(33,29,24,.12);
  --shadow:0 24px 70px rgba(33,29,24,.10);
  --radius:28px;
  --radius-sm:18px;
  --container:min(1180px, calc(100vw - 32px));
  --bottom-nav-h:78px;
}

*{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:
    radial-gradient(circle at top left, rgba(185,138,89,.13), transparent 34%),
    radial-gradient(circle at bottom right, rgba(69,83,71,.08), transparent 30%),
    linear-gradient(180deg,#fcf8f2 0%,#f7f0e5 40%,#f2eadf 100%);
  color:var(--ink);
  overflow-x:hidden;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
button,input,textarea,select{font:inherit}
::selection{background:rgba(185,138,89,.26)}
.page-shell{position:relative; min-height:100vh; isolation:isolate}
.ambient{
  position:fixed; inset:auto;
  border-radius:50%;
  filter:blur(60px);
  z-index:-4;
  pointer-events:none;
  opacity:.45;
}
.ambient--one{width:340px;height:340px;left:-100px;top:120px;background:rgba(185,138,89,.18)}
.ambient--two{width:460px;height:460px;right:-160px;top:42vh;background:rgba(109,49,64,.10)}
.ambient--three{width:500px;height:500px;left:12vw;bottom:-180px;background:rgba(66,83,71,.10)}
.float-field{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-3;
  overflow:hidden;
}
.edge-flower{
  position:fixed;
  width:min(24vw,260px);
  opacity:.82;
  pointer-events:none;
  z-index:-2;
  filter:drop-shadow(0 16px 28px rgba(105,73,48,.12));
}
.edge-flower img{width:100%; height:auto; animation:slowFloat 10s ease-in-out infinite}
.edge-flower--tl{top:-8px;left:-8px;transform:rotate(8deg)}
.edge-flower--tr{top:-8px;right:-8px;transform:scaleX(-1) rotate(6deg)}
.edge-flower--bl{bottom:-8px;left:-8px;transform:scaleY(-1) rotate(6deg)}
.edge-flower--br{bottom:-10px;right:-10px;transform:scale(-1,-1) rotate(8deg)}
.page-shell.is-fullscreen .desktop-nav{backdrop-filter:blur(14px)}
.immersive-banner{
  position:fixed; inset:0;
  display:grid;
  place-items:end center;
  padding:16px 16px calc(var(--bottom-nav-h) + 16px + env(safe-area-inset-bottom));
  z-index:40;
  pointer-events:none;
}
.immersive-banner__card{
  pointer-events:auto;
  max-width:430px;
  width:100%;
  border:1px solid rgba(255,255,255,.55);
  background:rgba(255,255,255,.68);
  box-shadow:var(--shadow);
  backdrop-filter:blur(24px);
  border-radius:22px;
  padding:14px 16px;
  text-align:center;
  transform:translateY(0);
  animation:bannerIn .8s ease both;
}
.immersive-banner__card strong{display:block; font-size:15px; margin:2px 0 4px}
.immersive-banner__card p{margin:0; color:var(--muted); font-size:12px}
.immersive-banner.hidden{opacity:0; visibility:hidden; transition:.45s ease}

.container{width:var(--container); margin-inline:auto}
.hero{position:relative; padding:20px 0 64px; min-height:100svh; display:flex; align-items:center; overflow:clip}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(250,244,236,.6), rgba(246,239,228,.28) 35%, rgba(246,239,228,.88)),
    url("../svg/cover-pattern.svg") center top/cover no-repeat;
  transform:scale(1.03) translateY(var(--heroShift,0px));
  z-index:-2;
}
.hero::after{
  content:"";
  position:absolute; inset:auto 0 0 0;
  height:32%;
  background:linear-gradient(180deg, transparent, rgba(246,239,228,.85));
  z-index:-1;
}
.desktop-nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:10px 14px;
  margin-bottom:18px;
  border:1px solid rgba(97,74,50,.09);
  border-radius:24px;
  background:rgba(255,255,255,.48);
  backdrop-filter:blur(18px);
  box-shadow:0 16px 36px rgba(44,30,20,.06);
}
.desktop-brand{display:flex; align-items:center; gap:12px}
.desktop-brand img{width:46px; height:46px}
.desktop-brand strong{
  display:block;
  font-family:'Playfair Display',serif;
  font-size:16px;
  letter-spacing:.06em;
}
.desktop-brand span{display:block; color:var(--muted); font-size:12px}
.desktop-links{display:flex; align-items:center; gap:10px; flex-wrap:wrap}
.desktop-links a,.nav-btn{
  border:1px solid rgba(97,74,50,.12);
  background:rgba(255,255,255,.72);
  color:var(--ink);
  border-radius:999px;
  padding:10px 14px;
  font-size:13px;
  font-weight:600;
  letter-spacing:.02em;
}
.nav-btn--filled{background:linear-gradient(135deg, var(--ink), #4a3f38); color:#fff}
.hero-grid{
  display:grid;
  grid-template-columns: minmax(0,1.05fr) minmax(0,.95fr);
  gap:24px;
  align-items:center;
}
.hero-copy{padding:10px 0 10px}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--bronze);
}
.eyebrow::before{
  content:"";
  width:38px; height:1px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
}
.hero-title{
  margin:14px 0 10px;
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(44px,8vw,80px);
  line-height:.9;
  color:#241f1c;
  letter-spacing:-.02em;
}
.hero-title span{display:block}
.hero-and{
  margin:4px 0;
  font-size:26px;
  color:var(--gold);
}
.hero-lead{
  max-width:56ch;
  margin:16px 0 0;
  color:var(--muted);
  line-height:1.85;
  font-size:16px;
}
.hero-tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.hero-tags span{
  border:1px solid rgba(97,74,50,.12);
  background:rgba(255,255,255,.62);
  padding:10px 14px;
  border-radius:999px;
  font-size:13px;
  font-weight:600;
}
.hero-actions{display:flex; gap:12px; flex-wrap:wrap; margin-top:22px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:0 18px;
  border-radius:999px;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease, border-color .25s ease, opacity .25s ease;
  font-weight:700;
}
.btn:hover,.nav-btn:hover,.desktop-links a:hover{transform:translateY(-2px)}
.btn--gold{
  background:linear-gradient(135deg, #8d694f, #b98a59 40%, #d4b58a);
  color:#fff;
  box-shadow:0 16px 34px rgba(185,138,89,.24);
}
.btn--light{
  background:rgba(255,255,255,.82);
  border-color:rgba(97,74,50,.12);
}
.btn--ghost{
  background:transparent;
  border-color:rgba(97,74,50,.16);
}
.btn--full{width:100%}
.hero-card{display:grid; place-items:center; justify-self:end; width:100%}
.cover-lock__card{
  display:grid;
  gap:16px;
  justify-items:center;
  overflow:auto;
  max-height:100%;
}
.cover-lock__text{
  display:grid;
  gap:8px;
  justify-items:center;
}
.cover-portrait,
.hero-portrait{
  position:relative;
  width:min(100%, 430px);
  aspect-ratio: 4 / 5;
}
.cover-portrait{width:min(100%, 390px)}
.hero-portrait{width:min(100%, 460px)}
.cover-portrait__frame,
.hero-portrait__frame{
  position:absolute;
  overflow:hidden;
  border-radius:28px;
  background:linear-gradient(180deg, rgba(255,255,255,.9), rgba(244,233,219,.9));
  border:1px solid rgba(97,74,50,.12);
  box-shadow:0 18px 40px rgba(0,0,0,.12);
}
.cover-portrait__frame img,
.hero-portrait__frame img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.cover-portrait__frame--main,
.hero-portrait__frame--main{
  inset:0;
}
.cover-portrait__frame--accent,
.hero-portrait__frame--accent{
  width:38%;
  height:34%;
  right:-2%;
  bottom:-2%;
  border-radius:22px;
}
.cover-portrait__frame--accent{
  left:-2%;
  right:auto;
  bottom:2%;
}
.hero-portrait__frame--accent{
  right:-4%;
  bottom:4%;
}

.invitation-card{
  position:relative;
  width:min(100%, 560px);
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(24px);
  border:1px solid rgba(118,88,56,.16);
  border-radius:32px;
  box-shadow:var(--shadow);
  padding:24px 20px;
  overflow:hidden;
}
.invitation-card::before{
  content:"";
  position:absolute; inset:10px;
  border-radius:26px;
  border:1px solid rgba(185,138,89,.15);
  pointer-events:none;
}
.invitation-card__corner{
  position:absolute; width:92px; height:92px; opacity:.82; pointer-events:none;
  background:
    radial-gradient(circle at 52% 52%, rgba(185,138,89,.7) 0 4px, transparent 4px 100%),
    radial-gradient(circle at 24% 24%, rgba(109,49,64,.22) 0 7px, transparent 7px 100%);
  mask: radial-gradient(circle at 60% 60%, transparent 0 28px, #000 28px);
  filter:blur(.15px);
}
.invitation-card__corner--tl{top:0;left:0;transform:rotate(180deg)}
.invitation-card__corner--tr{top:0;right:0;transform:scaleX(-1)}
.invitation-card__corner--bl{bottom:0;left:0;transform:scaleY(-1)}
.invitation-card__corner--br{bottom:0;right:0}
.invitation-card__small{
  margin:0;
  text-align:center;
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:17px;
  color:#423c36;
}
.invitation-card__small--italic{margin-top:4px}
.invitation-card__body{
  margin:12px auto 10px;
  max-width:56ch;
  text-align:center;
  color:#51473e;
  line-height:1.8;
  font-size:15px;
}
.invitation-card__name{
  margin:12px 0 0;
  text-align:center;
  font-family:'Playfair Display',serif;
  font-size:clamp(28px,5vw,50px);
  line-height:1.1;
  letter-spacing:-.02em;
  color:#241f1c;
}
.invitation-card__name--secondary{font-size:clamp(26px,4.6vw,46px)}
.invitation-event{
  margin-top:18px;
  border-radius:22px;
  overflow:hidden;
}
.invitation-event__label{
  text-align:center;
  font-family:'Playfair Display',serif;
  font-size:17px;
  font-weight:700;
  color:#1f1f1d;
  margin-bottom:8px;
}
.invitation-event__row{
  display:grid;
  grid-template-columns: .95fr .55fr 1.7fr;
  gap:0;
  border-radius:999px;
  overflow:hidden;
  background:#2f2a28;
  color:#fff;
  font-size:10px;
  font-weight:700;
  letter-spacing:.02em;
}
.invitation-event__row span{
  padding:10px 12px;
  border-right:1px solid rgba(255,255,255,.15);
  display:flex; align-items:center; justify-content:center; text-align:center;
}
.invitation-event__row span:last-child{border-right:0}
.invitation-event--reception{padding-top:6px}
.invitation-date{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  font-family:'Playfair Display',serif;
  font-size:22px;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.invitation-date__day{
  font-family:'Cormorant Garamond',serif;
  font-size:48px;
  letter-spacing:0;
  font-style:italic;
  line-height:1;
}
.invitation-event__reception-time{
  text-align:center;
  margin-top:4px;
  font-size:16px;
  font-weight:900;
  letter-spacing:.02em;
}
.invitation-event__reception-address{
  text-align:center;
  margin-top:4px;
  font-size:18px;
  font-weight:800;
}
.invitation-event__reception-note{
  text-align:center;
  margin-top:0;
  font-size:14px;
  color:#51473e;
}
.invitation-card__closing{
  margin:16px auto 0;
  max-width:58ch;
  text-align:center;
  line-height:1.8;
  font-size:14px;
  color:#4d453c;
}
.invitation-card__closing--small{font-family:'Cormorant Garamond',serif; font-style:italic; font-size:17px}
.hero-divider{
  display:block;
  width:min(100%, 760px);
  margin:20px auto 0;
  opacity:.88;
  filter:drop-shadow(0 8px 18px rgba(108,79,47,.10));
}

.main-content{padding-bottom:calc(var(--bottom-nav-h) + 24px)}
.section{padding:30px 0}
.section--tight{padding-top:10px}
.section-head{max-width:800px}
.section-head--center{margin:0 auto 20px; text-align:center}
.section-head h3{
  margin:12px 0 10px;
  font-family:'Playfair Display',serif;
  font-size:clamp(28px,4vw,52px);
  line-height:1.08;
  letter-spacing:-.02em;
}
.section-head p{margin:0; color:var(--muted); line-height:1.8}
.quote-panel,.event-card,.profile-card,.story-card,.map-card,.venue-card,.bugis-panel,.family-list, .form-card,.guest-list-panel,.rsvp-card,.action-strip,.countdown,.cover-lock__card{
  background:rgba(255,255,255,.78);
  border:1px solid rgba(97,74,50,.11);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  backdrop-filter:blur(20px);
}
.quote-panel{
  padding:28px;
  text-align:center;
}
.quote-panel blockquote{
  margin:0;
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(26px,3vw,38px);
  line-height:1.35;
  color:#2c2622;
}
.quote-panel p{
  margin:14px auto 0;
  max-width:70ch;
  color:var(--muted);
  line-height:1.8;
}
.event-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:20px;
}
.event-card{
  padding:24px;
  position:relative;
  overflow:hidden;
}
.event-card::after{
  content:"";
  position:absolute; inset:auto -30px -30px auto;
  width:170px; height:170px;
  background:radial-gradient(circle, rgba(185,138,89,.18), transparent 68%);
  pointer-events:none;
}
.event-card--dark{
  background:linear-gradient(180deg, rgba(33,29,24,.98), rgba(59,46,36,.95));
  color:#fff;
}
.event-card--dark .event-card__line{border-color:rgba(255,255,255,.12)}
.event-card__badge{
  display:inline-flex;
  border:1px solid rgba(97,74,50,.12);
  border-radius:999px;
  padding:8px 12px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin-bottom:14px;
  background:rgba(255,255,255,.42);
}
.event-card--dark .event-card__badge{
  background:rgba(255,255,255,.08);
  color:#fff;
  border-color:rgba(255,255,255,.16);
}
.event-card h4{
  margin:0 0 18px;
  font-family:'Playfair Display',serif;
  font-size:28px;
}
.event-card__line{
  display:flex;
  align-items:flex-start;
  gap:16px;
  padding:14px 0;
  border-top:1px solid var(--line);
  line-height:1.7;
}
.event-card__line strong{min-width:88px; font-size:13px; letter-spacing:.12em; text-transform:uppercase}
.event-card__line span{color:inherit; opacity:.92}
.countdown{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  padding:16px;
}
.countdown__unit{
  text-align:center;
  border-radius:24px;
  background:linear-gradient(180deg, rgba(255,255,255,.84), rgba(248,240,230,.74));
  border:1px solid rgba(97,74,50,.10);
  padding:18px 14px;
}
.countdown__unit strong{
  display:block;
  font-family:'Playfair Display',serif;
  font-size:clamp(28px,6vw,54px);
  line-height:1;
}
.countdown__unit span{
  display:block;
  margin-top:10px;
  color:var(--muted);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.profile-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:20px;
}
.profile-card{
  overflow:hidden;
}
.profile-card img{
  width:100%;
  aspect-ratio: 4 / 3;
  object-fit:cover;
  background:#efe2d1;
}
.profile-card__body{padding:20px}
.profile-card__body h4{
  margin:10px 0 10px;
  font-family:'Playfair Display',serif;
  font-size:28px;
}
.profile-card__body p{margin:0; color:var(--muted); line-height:1.85}
.story-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
}
.story-card{
  padding:22px;
  position:relative;
  overflow:hidden;
}
.story-card::before{
  content:"";
  position:absolute; inset:auto -40px -40px auto;
  width:180px;height:180px;
  background:radial-gradient(circle, rgba(185,138,89,.12), transparent 72%);
}
.story-year{
  display:inline-flex;
  width:44px;height:44px;
  align-items:center;justify-content:center;
  border-radius:14px;
  background:rgba(33,29,24,.06);
  margin-bottom:12px;
  font-weight:900;
}
.story-card h4{
  margin:0 0 8px;
  font-family:'Playfair Display',serif;
  font-size:24px;
}
.story-card p{margin:0; color:var(--muted); line-height:1.8}
.gallery-strip{
  position:relative;
  display:flex;
  align-items:stretch;
  gap:12px;
}
.gallery-strip__btn{
  width:46px;
  min-width:46px;
  border:1px solid rgba(97,74,50,.12);
  background:rgba(255,255,255,.72);
  border-radius:999px;
  font-size:30px;
  cursor:pointer;
  box-shadow:0 10px 24px rgba(0,0,0,.08);
}
.gallery-track{
  display:flex;
  gap:14px;
  overflow:auto hidden;
  scroll-behavior:smooth;
  padding-bottom:6px;
  scrollbar-width:none;
  -ms-overflow-style:none;
}
.gallery-track::-webkit-scrollbar{display:none}
.gallery-card{
  flex:0 0 auto;
  width:220px;
  margin:0;
  border-radius:24px;
  overflow:hidden;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(97,74,50,.11);
  box-shadow:var(--shadow);
}
.gallery-card img{
  width:100%;
  aspect-ratio: 4 / 5;
  object-fit:cover;
}
.gallery-card figcaption{
  padding:12px 14px 14px;
  font-size:13px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--muted);
}
.map-layout{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:18px;
}
.map-card, .venue-card{overflow:hidden}
.map-card iframe{
  display:block;
  width:100%;
  height:100%;
  min-height:460px;
  border:0;
}
.venue-card{padding:24px}
.venue-card h4{
  margin:0 0 8px;
  font-family:'Playfair Display',serif;
  font-size:30px;
}
.venue-card p{margin:0 0 6px; line-height:1.8}
.muted{color:var(--muted)}
.venue-card__meta{
  display:grid;
  gap:12px;
  margin:18px 0 20px;
}
.venue-card__meta div{
  border-top:1px solid var(--line);
  padding-top:12px;
}
.venue-card__meta strong{
  display:block;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--bronze);
  margin-bottom:4px;
}
.venue-card__meta span{color:var(--muted); line-height:1.7}
.bugis-panel{
  display:grid;
  grid-template-columns:1fr .9fr;
  gap:18px;
  padding:24px;
}
.bugis-panel__copy h4,
.family-list h4,
.form-card h4,
.guest-list-panel h4,
.rsvp-side__box strong{
  margin:0 0 10px;
  font-family:'Playfair Display',serif;
  font-size:28px;
}
.bugis-panel__copy p{
  margin:0 0 12px;
  line-height:1.85;
  color:var(--muted);
}
.bugis-panel__ornament{
  border-radius:24px;
  overflow:hidden;
  min-height:100%;
}
.bugis-panel__ornament img{
  width:100%;
  height:100%;
  object-fit:cover;
  aspect-ratio: 4 / 3;
}
.family-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-top:18px;
  padding:22px 24px;
}
.family-list ul{
  margin:10px 0 0;
  padding-left:18px;
  line-height:1.9;
  color:var(--muted);
}
.guestbook-grid{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:18px;
}
.form-card,.guest-list-panel,.rsvp-card{
  padding:24px;
}
.form-card label,.rsvp-form label{
  display:block;
  font-size:14px;
  font-weight:700;
  margin-bottom:12px;
}
.form-card input,.form-card textarea,.rsvp-form input,.rsvp-form textarea,.rsvp-form select{
  width:100%;
  margin-top:8px;
  border:1px solid rgba(97,74,50,.14);
  background:rgba(255,255,255,.9);
  border-radius:18px;
  min-height:48px;
  padding:12px 14px;
  outline:none;
  color:var(--ink);
}
.form-card textarea,.rsvp-form textarea{resize:vertical; min-height:120px}
.form-card input:focus,.form-card textarea:focus,.rsvp-form input:focus,.rsvp-form textarea:focus,.rsvp-form select:focus{
  border-color:rgba(185,138,89,.55);
  box-shadow:0 0 0 4px rgba(185,138,89,.12);
}
.guest-list{
  display:grid;
  gap:12px;
  margin-top:14px;
}
.guest-item{
  padding:16px;
  border-radius:20px;
  background:rgba(246,239,228,.7);
  border:1px solid rgba(97,74,50,.08);
}
.guest-item header{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:baseline;
}
.guest-item header strong{font-size:15px}
.guest-item header small{color:var(--muted)}
.guest-item p{margin:10px 0 0; color:var(--muted); line-height:1.7}
.rsvp-card{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:18px;
}
.rsvp-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.rsvp-side{
  display:grid;
  gap:12px;
}
.rsvp-side__box{
  padding:18px;
  border-radius:20px;
  background:linear-gradient(180deg, rgba(33,29,24,.96), rgba(63,49,39,.92));
  color:#fff;
}
.rsvp-side__box span{display:block; margin-top:6px; color:rgba(255,255,255,.82); line-height:1.7}
.action-strip{
  display:flex;
  justify-content:center;
  gap:12px;
  flex-wrap:wrap;
  padding:18px;
}
.footer{
  padding:24px 0 120px;
  text-align:center;
}
.footer__title{
  margin:0 0 6px;
  font-family:'Playfair Display',serif;
  font-size:clamp(24px,4vw,34px);
}
.footer p{margin:0 0 8px; color:var(--muted)}
.footer small{color:var(--muted)}

.mobile-nav{
  position:fixed;
  left:50%;
  transform:translateX(-50%);
  bottom:max(10px, env(safe-area-inset-bottom));
  width:min(760px, calc(100vw - 16px));
  height:var(--bottom-nav-h);
  padding:10px;
  display:flex;
  gap:8px;
  z-index:60;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(97,74,50,.12);
  border-radius:24px;
  box-shadow:0 14px 40px rgba(0,0,0,.16);
  backdrop-filter:blur(22px);
}
.mobile-nav a{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  border-radius:18px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
  background:rgba(255,255,255,.45);
}
.mobile-nav a.is-active{
  color:#fff;
  background:linear-gradient(135deg, #2e2926, #6d3140);
}

.cover-lock{
  position:fixed; inset:0;
  display:grid;
  place-items:center;
  padding:24px 16px calc(var(--bottom-nav-h) + 24px + env(safe-area-inset-bottom));
  z-index:90;
  background:
    radial-gradient(circle at 20% 20%, rgba(185,138,89,.10), transparent 26%),
    radial-gradient(circle at 80% 80%, rgba(109,49,64,.08), transparent 28%),
    linear-gradient(180deg, rgba(251,247,241,.98), rgba(246,239,228,.98));
  backdrop-filter:blur(18px);
}
.cover-lock__card{
  width:min(760px, 100%);
  padding:28px 18px 18px;
  text-align:center;
}
.seal-wrap{
  width:82px; height:82px;
  margin:0 auto 8px;
  border-radius:50%;
  padding:6px;
  background:linear-gradient(135deg, rgba(255,255,255,.85), rgba(245,230,208,.92));
  border:1px solid rgba(97,74,50,.12);
  box-shadow:0 12px 30px rgba(0,0,0,.08);
}
.seal-wrap img{width:100%; height:100%}
.lock-intro{
  margin:0;
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(18px,3.6vw,28px);
  line-height:1.25;
}
.lock-intro--italic{font-style:italic; margin-top:4px}
.lock-text{
  margin:14px auto 0;
  max-width:62ch;
  color:#5a5149;
  line-height:1.8;
  font-size:15px;
}
.lock-text--small{font-weight:700}
.lock-names{
  margin:18px 0 0;
  font-family:'Playfair Display',serif;
  font-size:clamp(34px,5vw,56px);
  line-height:1.05;
}
.lock-between{
  display:block;
  margin:8px 0;
  font-size:22px;
  color:var(--bronze);
}
.lock-details{
  display:grid;
  gap:10px;
  margin:18px 0;
}
.lock-pill{
  padding:12px 14px;
  border-radius:999px;
  background:#2f2a28;
  color:#fff;
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
}
.tiny-note{
  margin:12px 0 0;
  color:var(--muted);
  font-size:12px;
}
.reveal{
  opacity:0;
  transform:translateY(18px) scale(.985);
  filter:blur(4px);
  transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1), filter .8s ease;
  transition-delay:var(--delay,0ms);
}
.reveal.is-in{
  opacity:1;
  transform:none;
  filter:none;
}
@keyframes slowFloat{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-10px) rotate(2deg)}
}
@keyframes bannerIn{
  from{transform:translateY(16px);opacity:0}
  to{transform:translateY(0);opacity:1}
}
.float-flower{
  position:absolute;
  width:var(--size,42px);
  height:var(--size,42px);
  left:var(--x);
  top:var(--y);
  opacity:var(--opacity, .38);
  transform:translate3d(0,0,0) rotate(var(--rot));
  animation:floatPetal var(--dur) linear infinite;
  animation-delay:var(--delay);
  will-change:transform,opacity;
  filter:drop-shadow(0 10px 12px rgba(75,54,34,.12));
}
.float-flower i{
  display:block;
  width:100%;
  height:100%;
  background:url("../svg/flower.svg") center/contain no-repeat;
  transform:rotate(0deg);
}
@keyframes floatPetal{
  0%{transform:translate3d(0, 8vh, 0) rotate(var(--rot)); opacity:0}
  10%{opacity:var(--opacity, .42)}
  50%{transform:translate3d(calc(var(--drift) * .55), 52vh, 0) rotate(calc(var(--rot) + 180deg));}
  90%{opacity:var(--opacity, .42)}
  100%{transform:translate3d(var(--drift), 112vh, 0) rotate(calc(var(--rot) + 360deg)); opacity:0}
}
.is-open .cover-lock{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:.5s ease;
}
.is-open .app-shell{
  animation:appIn .85s ease both;
}
@keyframes appIn{
  from{opacity:.7; transform:scale(.995)}
  to{opacity:1; transform:none}
}

@media (max-width: 1080px){
  .hero-grid{grid-template-columns:1fr; gap:18px}
  .hero-copy{order:1}
  .hero-card{order:0}
  .story-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .map-layout,.bugis-panel,.guestbook-grid,.rsvp-card,.family-list{grid-template-columns:1fr}
  .profile-grid{grid-template-columns:1fr}
}
@media (max-width: 860px){
  .hero-card{justify-self:stretch}
  .hero-portrait{width:min(100%, 420px)}
  .cover-portrait{width:min(100%, 340px)}
  .cover-lock__card{gap:14px}
  .cover-photo{width:min(100%, 420px)}
  .cover-lock__body{gap:10px}

  :root{--bottom-nav-h:74px}
  .desktop-nav{display:none}
  .event-grid{grid-template-columns:1fr}
  .countdown{grid-template-columns:repeat(2,minmax(0,1fr))}
  .gallery-strip{padding-inline:0}
  .gallery-track{padding-inline:2px}
  .gallery-card{width:200px}
  .mobile-nav{display:flex}
  .section{padding:26px 0}
  .cover-lock{padding:18px 12px calc(var(--bottom-nav-h) + 18px + env(safe-area-inset-bottom))}
  .hero{padding-top:10px}
  .hero-title{font-size:clamp(34px,10vw,58px)}
  .invitation-card{padding:18px 14px}
  .invitation-card__body{font-size:14px}
  .invitation-event__row{
    grid-template-columns:1fr;
    border-radius:18px;
  }
  .invitation-event__row span{justify-content:flex-start; text-align:left; border-right:0; border-bottom:1px solid rgba(255,255,255,.1)}
  .invitation-event__row span:last-child{border-bottom:0}
  .invitation-date{font-size:18px; gap:8px}
  .invitation-date__day{font-size:40px}
  .invitation-event__reception-time{font-size:14px}
  .invitation-event__reception-address{font-size:16px}
  .countdown__unit strong{font-size:38px}
  .map-card iframe{min-height:340px}
  .edge-flower{width:min(32vw,210px)}
}
@media (max-width: 560px){
  .container{width:min(100vw - 20px, 1000px)}
  .cover-lock__card{padding:18px 14px}
  .cover-photo{aspect-ratio: 3 / 4; border-radius:28px}
  .lock-names{font-size:clamp(28px,9vw,42px)}
  .cover-lock__date{font-size:11px}
  .hero{min-height:auto; padding-bottom:42px}
  .hero-tags{gap:8px}
  .hero-tags span{padding:8px 12px; font-size:12px}
  .hero-actions .btn{flex:1; min-width:calc(50% - 6px)}
  .quote-panel, .event-card, .profile-card__body, .story-card, .venue-card, .form-card, .guest-list-panel, .rsvp-card, .bugis-panel, .family-list{padding:18px}
  .section-head h3{font-size:clamp(24px,8vw,34px)}
  .countdown{gap:10px}
  .countdown__unit{padding:14px 10px}
  .countdown__unit strong{font-size:30px}
  .gallery-card{width:170px}
  .gallery-strip__btn{display:none}
  .action-strip .btn{flex:1; min-width:calc(50% - 6px)}
  .mobile-nav{
    width:calc(100vw - 12px);
    height:72px;
    padding:8px;
    gap:6px;
  }
  .mobile-nav a{font-size:10px}
  .lock-names{font-size:clamp(28px,9vw,42px)}
  .lock-details{gap:8px}
  .lock-pill{font-size:11px; padding:10px 12px}
  .edge-flower{width:min(40vw,190px)}
  .cover-portrait{width:min(100%, 300px)}
  .hero-portrait{width:min(100%, 340px)}
  .cover-lock__card{padding:20px 14px}

}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .float-flower,.edge-flower img{animation:none !important}
}
