
:root{
  --navy:#030814;
  --navy-2:#07142c;
  --royal:#0d3b86;
  --ice:#dff2ff;
  --white:#ffffff;
  --muted:#a9bad9;
  --gold:#d9b970;
  --gold-2:#fff1be;
  --glass:rgba(255,255,255,.075);
  --line:rgba(255,255,255,.14);
  --shadow:0 30px 90px rgba(0,0,0,.45);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:
    radial-gradient(circle at 10% 5%, rgba(59,130,246,.28), transparent 32rem),
    radial-gradient(circle at 85% 15%, rgba(217,185,112,.18), transparent 28rem),
    radial-gradient(circle at 50% 100%, rgba(37,99,235,.18), transparent 32rem),
    var(--navy);
  color:var(--white);
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:42px 42px;
  mask-image:linear-gradient(to bottom, black, transparent 80%);
  pointer-events:none;
}
a{color:inherit;text-decoration:none}
.container{width:min(1180px, calc(100% - 36px)); margin:0 auto}
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(3,8,20,.72);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
}
.nav-inner{height:76px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;letter-spacing:.04em}
.brand-mark{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-2),var(--gold));
  color:var(--navy);display:grid;place-items:center;
  box-shadow:0 0 28px rgba(217,185,112,.25);
  font-family:Playfair Display, serif;font-size:24px
}
.nav-links{display:flex;gap:10px;align-items:center}
.nav-links a{
  padding:10px 14px;border-radius:999px;color:rgba(255,255,255,.78);
  font-size:14px;transition:.25s ease
}
.nav-links a:hover,.nav-links a.active{background:rgba(255,255,255,.09);color:white}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 20px;border-radius:999px;border:1px solid rgba(255,255,255,.18);
  background:linear-gradient(135deg,var(--gold-2),var(--gold));
  color:#071126;font-weight:800;box-shadow:0 18px 42px rgba(217,185,112,.18);
  transition:.25s ease;cursor:pointer
}
.btn:hover{transform:translateY(-2px);box-shadow:0 24px 58px rgba(217,185,112,.24)}
.btn.secondary{
  background:rgba(255,255,255,.07); color:white; border:1px solid rgba(255,255,255,.16);
  box-shadow:none
}
.hero{position:relative;padding:76px 0 58px;min-height:calc(100vh - 76px);display:grid;align-items:center}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:42px;align-items:center}
.eyebrow{
  display:inline-flex;gap:10px;align-items:center;
  color:var(--gold-2);letter-spacing:.26em;text-transform:uppercase;
  font-size:12px;font-weight:800;border:1px solid rgba(217,185,112,.28);
  background:rgba(255,255,255,.06);border-radius:999px;padding:10px 14px;
  backdrop-filter:blur(14px)
}
h1,h2,h3{margin:0}
.hero h1{
  margin-top:22px;
  font-family:Playfair Display, serif;
  font-size:clamp(58px,8vw,116px);
  line-height:.9;
  letter-spacing:-.055em
}
.gradient-text{background:linear-gradient(90deg,#fff,var(--gold-2),#9fd5ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{max-width:680px;color:rgba(226,239,255,.82);font-size:19px;line-height:1.75;margin:28px 0 0}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px}
.detail-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:34px}
.detail{
  padding:18px;border-radius:22px;background:var(--glass);border:1px solid var(--line);
  backdrop-filter:blur(18px);box-shadow:0 16px 48px rgba(0,0,0,.22)
}
.detail span{display:block;color:var(--gold-2);font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:800;margin-bottom:8px}
.detail strong{font-size:15px;line-height:1.45;color:white}
.hero-visual{position:relative}
.photo-frame{
  position:relative;border-radius:38px;padding:12px;
  background:linear-gradient(135deg,rgba(255,255,255,.25),rgba(217,185,112,.3),rgba(255,255,255,.06));
  box-shadow:var(--shadow);
  transform:rotate(1.5deg)
}
.photo-frame img{width:100%;height:min(680px,72vh);object-fit:cover;object-position:center 18%;border-radius:28px;display:block}
.floating-card{
  position:absolute;left:-18px;bottom:28px;
  width:min(285px,62%);
  padding:18px;border-radius:26px;background:rgba(3,8,20,.82);
  border:1px solid rgba(255,255,255,.17);backdrop-filter:blur(18px);
  box-shadow:0 24px 70px rgba(0,0,0,.45)
}
.floating-card .small{font-size:12px;text-transform:uppercase;letter-spacing:.23em;color:var(--gold-2);font-weight:900}
.floating-card .big{font-family:Playfair Display,serif;font-size:26px;line-height:1.05;margin-top:6px}
.section{padding:74px 0}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:26px;margin-bottom:30px}
.section h2{font-family:Playfair Display,serif;font-size:clamp(38px,5vw,72px);letter-spacing:-.04em}
.section .sub{color:rgba(226,239,255,.75);line-height:1.75;max-width:640px}
.luxe-panel{
  border:1px solid var(--line);background:rgba(255,255,255,.065);backdrop-filter:blur(18px);
  border-radius:34px;padding:26px;box-shadow:var(--shadow)
}
.invite-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:26px;align-items:stretch}
.invite-card img{width:100%;height:100%;min-height:460px;object-fit:cover;border-radius:26px}
.timeline{display:grid;gap:16px}
.timeline-item{display:grid;grid-template-columns:54px 1fr;gap:16px;align-items:start}
.timeline-icon{
  width:54px;height:54px;border-radius:18px;display:grid;place-items:center;
  background:linear-gradient(135deg,rgba(217,185,112,.25),rgba(37,99,235,.15));
  border:1px solid rgba(255,255,255,.13);font-size:22px
}
.timeline-item h3{font-size:19px;margin-bottom:6px}
.timeline-item p{margin:0;color:rgba(226,239,255,.72);line-height:1.65}
.gallery-preview{display:grid;grid-template-columns:1.15fr .85fr .85fr;grid-auto-rows:250px;gap:14px}
.gallery-preview img,.gallery-grid img{
  width:100%;height:100%;object-fit:cover;border-radius:26px;border:1px solid rgba(255,255,255,.12);
  transition:.3s ease;cursor:pointer;background:#061126
}
.gallery-preview img:hover,.gallery-grid img:hover{transform:translateY(-4px);filter:saturate(1.12)}
.gallery-preview img:first-child{grid-row:span 2}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery-grid figure{margin:0;height:360px}
.rsvp-wrap{display:grid;grid-template-columns:.82fr 1.18fr;gap:28px;align-items:start}
.rsvp-side{position:sticky;top:104px}
.rsvp-side .quote{
  font-family:Playfair Display,serif;font-size:34px;line-height:1.12;margin:0 0 18px
}
.form{display:grid;gap:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
label{display:block;font-size:13px;color:rgba(226,239,255,.82);margin:0 0 8px;font-weight:700}
input,select,textarea{
  width:100%;border:1px solid rgba(255,255,255,.14);outline:none;
  border-radius:18px;background:rgba(255,255,255,.075);
  color:white;padding:14px 15px;font:inherit;transition:.2s ease
}
select option{color:#071126}
textarea{min-height:112px;resize:vertical}
input:focus,select:focus,textarea:focus{border-color:rgba(217,185,112,.75);background:rgba(255,255,255,.105);box-shadow:0 0 0 4px rgba(217,185,112,.09)}
.help{margin-top:7px;color:rgba(226,239,255,.55);font-size:12px;line-height:1.45}
.segment{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.segment button{
  padding:14px;border-radius:18px;border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.07);color:white;font-weight:800;cursor:pointer;transition:.2s ease
}
.segment button.active{background:linear-gradient(135deg,var(--gold-2),var(--gold));color:#071126;border-color:transparent}
.total-card{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid rgba(217,185,112,.25);background:rgba(217,185,112,.09);border-radius:20px;padding:15px 16px;color:rgba(255,255,255,.88)}
.total-card strong{font-size:26px;color:var(--gold-2)}
.status{display:none;border-radius:18px;padding:14px 15px;font-size:14px;line-height:1.55}
.status.show{display:block}
.status.success{border:1px solid rgba(52,211,153,.3);background:rgba(52,211,153,.1);color:#d6ffee}
.status.demo{border:1px solid rgba(217,185,112,.3);background:rgba(217,185,112,.1);color:#fff3ca}
.footer{border-top:1px solid var(--line);padding:34px 0;color:rgba(226,239,255,.65)}
.footer-inner{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.82);z-index:200;display:none;place-items:center;padding:24px}
.modal.open{display:grid}
.modal img{max-width:min(1100px,94vw);max-height:86vh;border-radius:26px;box-shadow:0 30px 110px rgba(0,0,0,.75)}
.modal button{position:absolute;top:18px;right:18px}
@media (max-width: 900px){
  .nav-inner{height:auto;min-height:72px;align-items:flex-start;padding:14px 0;flex-direction:column}
  .nav-links{width:100%;overflow-x:auto;padding-bottom:4px}
  .hero-grid,.invite-grid,.rsvp-wrap{grid-template-columns:1fr}
  .detail-strip{grid-template-columns:repeat(2,1fr)}
  .gallery-preview{grid-template-columns:1fr 1fr;grid-auto-rows:210px}
  .gallery-preview img:first-child{grid-row:span 1;grid-column:span 2}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .rsvp-side{position:static}
}
@media (max-width: 620px){
  .container{width:min(100% - 24px, 1180px)}
  .hero{padding-top:46px}
  .detail-strip,.form-row,.gallery-grid{grid-template-columns:1fr}
  .gallery-preview{grid-template-columns:1fr}
  .gallery-preview img:first-child{grid-column:auto}
  .gallery-grid figure{height:280px}
  .section{padding:52px 0}
  .luxe-panel{padding:18px;border-radius:26px}
  .photo-frame img{height:520px}
}


.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.feature-card{
  position:relative;overflow:hidden;
  border:1px solid rgba(255,255,255,.13);
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.045));
  border-radius:28px;padding:24px;min-height:220px;
  box-shadow:0 24px 70px rgba(0,0,0,.24)
}
.feature-card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at top right,rgba(217,185,112,.18),transparent 42%);
  pointer-events:none
}
.feature-card .num{font-family:Playfair Display,serif;font-size:46px;color:var(--gold-2);line-height:1}
.feature-card h3{margin-top:16px;font-size:20px}
.feature-card p{color:rgba(226,239,255,.72);line-height:1.65;margin:10px 0 0}
.mosaic{display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:stretch}
.mosaic-main{min-height:520px}
.mosaic-side{display:grid;gap:18px}
.mosaic img{width:100%;height:100%;object-fit:cover;border-radius:30px;border:1px solid rgba(255,255,255,.12)}
.mosaic-side img{min-height:250px}
.notice-bar{
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
  border-radius:30px;border:1px solid rgba(217,185,112,.25);
  background:linear-gradient(135deg,rgba(217,185,112,.14),rgba(37,99,235,.10));
  padding:24px 26px;box-shadow:0 22px 70px rgba(0,0,0,.25)
}
.notice-bar strong{font-family:Playfair Display,serif;font-size:31px;line-height:1.1}
.notice-bar span{color:rgba(226,239,255,.76);line-height:1.55}
@media (max-width: 900px){
  .feature-grid,.mosaic{grid-template-columns:1fr}
  .mosaic-main{min-height:420px}
}


.parking-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.parking-card{
  border-radius:28px;border:1px solid rgba(255,255,255,.13);
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.045));
  padding:24px;box-shadow:0 24px 70px rgba(0,0,0,.22)
}
.parking-card h3{font-size:22px;margin-bottom:10px}
.parking-card p{margin:0;color:rgba(226,239,255,.72);line-height:1.7}
.parking-list{display:grid;gap:12px;margin-top:18px}
.parking-list div{
  border:1px solid rgba(255,255,255,.11);
  background:rgba(255,255,255,.055);
  border-radius:18px;padding:14px 15px;color:rgba(255,255,255,.86);
  line-height:1.55
}
.parking-list strong{color:var(--gold-2)}
.map-link{
  display:inline-flex;margin-top:18px;padding:12px 16px;border-radius:999px;
  border:1px solid rgba(217,185,112,.35);
  background:rgba(217,185,112,.10);color:var(--gold-2);font-weight:800
}
@media (max-width: 900px){.parking-grid{grid-template-columns:1fr}}


.family-message{
  display:grid;
  grid-template-columns:0.9fr 1.1fr;
  gap:24px;
  align-items:stretch;
}
.message-card{
  border-radius:34px;
  border:1px solid rgba(255,255,255,.13);
  background:linear-gradient(145deg,rgba(255,255,255,.085),rgba(255,255,255,.045));
  padding:30px;
  box-shadow:0 26px 80px rgba(0,0,0,.28);
}
.message-card h3{
  font-family:Playfair Display,serif;
  font-size:42px;
  line-height:1.05;
  letter-spacing:-.03em;
  margin:0 0 14px;
}
.message-card p{
  color:rgba(226,239,255,.76);
  line-height:1.8;
  margin:0;
}
.blessing-line{
  margin-top:20px;
  border-radius:24px;
  border:1px solid rgba(217,185,112,.28);
  background:linear-gradient(135deg,rgba(217,185,112,.16),rgba(37,99,235,.08));
  padding:20px;
  color:#fff4c9;
  font-weight:800;
  line-height:1.55;
}
.contact-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
}
.contact-card{
  border-radius:28px;
  border:1px solid rgba(255,255,255,.13);
  background:rgba(255,255,255,.065);
  padding:24px;
  box-shadow:0 22px 70px rgba(0,0,0,.22);
}
.contact-card span{
  display:block;
  color:var(--gold-2);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:12px;
  font-weight:900;
  margin-bottom:10px;
}
.contact-card strong{
  display:block;
  font-size:26px;
  margin-bottom:8px;
}
.contact-card a{
  color:rgba(226,239,255,.86);
  font-weight:800;
}
.cta-panel{
  text-align:center;
  border-radius:36px;
  border:1px solid rgba(217,185,112,.28);
  background:
    radial-gradient(circle at top left,rgba(217,185,112,.18),transparent 36%),
    radial-gradient(circle at bottom right,rgba(37,99,235,.18),transparent 36%),
    rgba(255,255,255,.065);
  padding:42px 26px;
  box-shadow:0 28px 90px rgba(0,0,0,.30);
}
.cta-panel h2{
  font-family:Playfair Display,serif;
  font-size:clamp(38px,5vw,68px);
  letter-spacing:-.04em;
  margin-bottom:14px;
}
.cta-panel p{
  max-width:720px;
  margin:0 auto 24px;
  color:rgba(226,239,255,.76);
  line-height:1.75;
}
@media (max-width:900px){
  .family-message,.contact-grid{grid-template-columns:1fr}
}


.countdown-panel{
  margin-top:26px;
  border-radius:30px;
  border:1px solid rgba(217,185,112,.28);
  background:linear-gradient(135deg,rgba(217,185,112,.13),rgba(37,99,235,.10));
  padding:20px;
  box-shadow:0 22px 70px rgba(0,0,0,.24);
}
.countdown-label{
  color:var(--gold-2);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:12px;
  font-weight:900;
  margin-bottom:12px;
}
.countdown-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
}
.countdown-box{
  border-radius:18px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  padding:13px 10px;
  text-align:center;
}
.countdown-box strong{
  display:block;
  font-size:28px;
  color:white;
  line-height:1;
}
.countdown-box span{
  display:block;
  margin-top:6px;
  color:rgba(226,239,255,.68);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.14em;
}
.map-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
  border-radius:30px;
  border:1px solid rgba(255,255,255,.13);
  background:rgba(255,255,255,.065);
  padding:24px;
  box-shadow:0 22px 70px rgba(0,0,0,.22);
}
.map-card h3{
  font-family:Playfair Display,serif;
  font-size:34px;
  margin:0 0 8px;
}
.map-card p{
  color:rgba(226,239,255,.76);
  line-height:1.65;
  margin:0;
}
.privacy-note{
  border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.055);
  padding:13px 15px;
  color:rgba(226,239,255,.66);
  font-size:13px;
  line-height:1.55;
}
.rsvp-contact-bottom{
  margin-top:22px;
  border-radius:24px;
  border:1px solid rgba(217,185,112,.23);
  background:rgba(217,185,112,.08);
  padding:18px;
  color:rgba(226,239,255,.82);
  line-height:1.65;
}
.rsvp-contact-bottom strong{color:var(--gold-2)}
.creator-credit{
  color:rgba(226,239,255,.72);
}
.creator-credit strong{
  color:var(--gold-2);
}
@media (max-width:620px){
  .countdown-grid{grid-template-columns:repeat(2,1fr)}
}


.rsvp-banner{
  position:relative;
  z-index:40;
  border-bottom:1px solid rgba(217,185,112,.25);
  background:linear-gradient(90deg,rgba(217,185,112,.18),rgba(37,99,235,.16),rgba(217,185,112,.18));
  overflow:hidden;
}
.rsvp-banner::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);
  transform:translateX(-100%);
  animation:bannerShine 6s ease-in-out infinite;
}
.rsvp-banner-inner{
  position:relative;
  min-height:48px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  text-align:center;
  color:#fff4c9;
  font-weight:900;
  letter-spacing:.04em;
  padding:10px 16px;
}
.rsvp-banner-inner a{
  color:white;
  text-decoration:underline;
  text-underline-offset:4px;
}
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .75s ease, transform .75s ease;
}
.reveal.visible{
  opacity:1;
  transform:translateY(0);
}
.float-soft{
  animation:floatSoft 5.5s ease-in-out infinite;
}
.pulse-glow{
  animation:pulseGlow 2.8s ease-in-out infinite;
}
.gallery-grid figure{
  opacity:0;
  transform:translateY(20px) scale(.98);
  animation:galleryIn .75s ease forwards;
}
.gallery-grid figure:nth-child(2n){animation-delay:.06s}
.gallery-grid figure:nth-child(3n){animation-delay:.12s}
.gallery-grid figure:nth-child(4n){animation-delay:.18s}
@keyframes bannerShine{
  0%{transform:translateX(-100%)}
  45%,100%{transform:translateX(100%)}
}
@keyframes floatSoft{
  0%,100%{transform:translateY(0) rotate(1.5deg)}
  50%{transform:translateY(-10px) rotate(1.5deg)}
}
@keyframes pulseGlow{
  0%,100%{box-shadow:0 18px 42px rgba(217,185,112,.18)}
  50%{box-shadow:0 22px 70px rgba(217,185,112,.34)}
}
@keyframes galleryIn{
  to{opacity:1;transform:translateY(0) scale(1)}
}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms!important;
    animation-iteration-count:1!important;
    transition-duration:.001ms!important;
    scroll-behavior:auto!important;
  }
}


.compact-event-panel{
  align-self:center;
  padding:22px;
}
.compact-event-panel .section-head{
  margin-bottom:22px;
}
.compact-event-panel .timeline{
  gap:14px;
}
.compact-event-panel .timeline-icon{
  width:48px;
  height:48px;
  border-radius:16px;
}
.compact-event-panel .timeline-item{
  grid-template-columns:48px 1fr;
  gap:14px;
}
.compact-event-panel h2{
  font-size:clamp(34px,4.4vw,62px);
}
