:root{--ivory:#f7f3eb;--cream:#ede3d4;--paper:#fffdf8;--sage:#6e725f;--sage-dark:#3d4034;--gold:#a57a35;--wine:#5b121b;--ink:#2f271e;--muted:rgba(47,39,30,.66);--script:"Great Vibes",cursive;--serif:"Cormorant Garamond",Georgia,serif;--sans:Inter,system-ui,-apple-system,Segoe UI,sans-serif}
*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--ivory)}
body{margin:0;background:var(--ivory);color:var(--ink);font-family:var(--serif);-webkit-font-smoothing:antialiased}
body.locked{overflow:hidden}
a{color:inherit}
button,input,select,textarea{font:inherit}
img,video{display:block;max-width:100%}
.intro{position:fixed;inset:0;z-index:1000;background:var(--ivory);overflow:hidden;cursor:pointer}
.intro video{width:100%;height:100%;object-fit:cover}
.intro:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 54% 46%,transparent 0 19%,rgba(247,243,235,.04) 31%,rgba(247,243,235,.35) 100%);pointer-events:none}
.intro-tap{position:absolute;left:50%;bottom:max(26px,env(safe-area-inset-bottom));z-index:3;min-height:48px;border:1px solid rgba(47,39,30,.16);border-radius:999px;padding:0 22px;background:rgba(255,253,248,.82);box-shadow:0 18px 60px rgba(47,39,30,.16);color:var(--sage-dark);font-family:var(--sans);font-size:.8rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase;transform:translateX(-50%);transition:.3s ease;white-space:nowrap}
.intro-flash{position:absolute;left:50%;top:50%;z-index:2;width:20px;height:20px;border-radius:50%;background:white;opacity:0;transform:translate(-50%,-50%) scale(.2);box-shadow:0 0 90px 80px rgba(255,255,255,.72)}
.intro-flash.show{animation:flash .95s ease forwards}
.intro.hide{opacity:0;visibility:hidden;transition:opacity .75s ease,visibility .75s ease}
.page{min-height:100svh;overflow:hidden}
.section{position:relative;padding:clamp(68px,11vw,128px) 18px}
.narrow{width:min(760px,100%);margin:0 auto;text-align:center}
.paper{background:var(--paper)}
.gold{background:#c5a46d;color:white}
.kicker{margin:0 0 16px;font-family:var(--sans);font-size:.73rem;font-weight:900;letter-spacing:.26em;text-transform:uppercase;color:var(--gold)}
h2{margin:0;font-family:var(--script);font-size:clamp(4.3rem,14vw,7.2rem);font-weight:400;line-height:.78;color:var(--gold)}
p{font-size:clamp(1.05rem,2.5vw,1.22rem);line-height:1.75}
.mini-art{width:92px;max-height:120px;object-fit:contain;margin:0 auto 22px;opacity:.82}
.hero{position:relative;min-height:100svh;display:grid;place-items:start center;overflow:hidden;color:white;background:#111}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(30,22,14,.18),rgba(30,22,14,.38) 52%,rgba(30,22,14,.5))}
.lang-pill{position:absolute;right:18px;top:18px;z-index:3;display:flex;align-items:center;border-radius:999px;padding:6px;background:rgba(255,253,248,.92);box-shadow:0 12px 34px rgba(0,0,0,.22)}
.lang-pill span{display:grid;place-items:center;min-width:42px;height:34px;border-radius:999px;background:#8b662d;color:white;font-family:var(--sans);font-size:.72rem;font-weight:900}
.hero-content{position:relative;z-index:2;width:min(680px,100%);padding:clamp(82px,15vh,126px) 18px 34px;text-align:center;text-shadow:0 8px 34px rgba(0,0,0,.35)}
.eyebrow{margin:0 0 clamp(22px,4vh,34px);font-family:var(--sans);font-size:.78rem;font-weight:900;letter-spacing:.42em;text-transform:uppercase}
.hero h1{display:grid;gap:clamp(8px,1.5vh,16px);margin:0;font-family:var(--script);font-size:clamp(5.7rem,18vw,9.6rem);font-weight:400;line-height:.72}
.hero h1 small{font-family:var(--serif);font-size:.28em;line-height:1}
.divider{display:flex;align-items:center;justify-content:center;gap:14px;margin:44px auto 16px;color:white}
.divider:before,.divider:after{content:"";width:90px;height:1px;background:rgba(255,255,255,.42)}
.date{margin:0;font-family:var(--sans);font-size:clamp(1.18rem,4vw,1.8rem);font-weight:900;letter-spacing:.16em;text-transform:uppercase}
.rsvp-jump{display:inline-grid;place-items:center;margin-top:38px;color:white;font-family:var(--sans);font-size:.72rem;font-weight:900;letter-spacing:.22em;text-decoration:none;text-transform:uppercase}
.rsvp-jump:after{content:"⌄";font-size:1.4rem;line-height:1}
.sound{position:fixed;right:18px;bottom:18px;z-index:50;width:54px;height:54px;border:0;border-radius:999px;background:rgba(255,253,248,.9);box-shadow:0 15px 40px rgba(47,39,30,.18);color:var(--gold);font-family:var(--sans);font-weight:950}
.countdown{text-align:center;background:var(--ivory)}
.count-grid{width:min(560px,100%);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.count-grid div{min-height:112px;display:grid;place-items:center;border-radius:28px;background:rgba(255,253,248,.64);box-shadow:0 18px 44px rgba(47,39,30,.06)}
.count-grid strong{font-family:var(--serif);font-size:clamp(2.4rem,8vw,4.4rem);font-weight:600;color:var(--sage-dark);line-height:.8}
.count-grid span{font-family:var(--sans);font-size:.67rem;font-weight:900;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.welcome{background:var(--ivory)}
.welcome p,.transport p,.rsvp p{color:var(--muted)}
.venue{background:var(--ivory);text-align:center}
.venue:before,.venue:after{content:"";position:absolute;left:0;right:0;height:80px;background:linear-gradient(180deg,var(--paper),transparent);top:0}
.venue-logo{width:min(520px,100%);margin:16px auto 4px}
.venue-date{margin:8px 0;color:var(--gold);font-family:var(--sans);font-weight:900;letter-spacing:.12em;text-transform:uppercase}
.address{margin:0 0 18px;color:var(--muted)}
.text-link{display:inline-flex;align-items:center;gap:8px;border-bottom:1px solid rgba(165,122,53,.38);padding-bottom:4px;color:var(--gold);font-family:var(--sans);font-size:.78rem;font-weight:900;letter-spacing:.15em;text-decoration:none;text-transform:uppercase}
.timeline{position:relative;width:min(540px,100%);margin:38px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:0 46px}
.timeline:before{content:"";position:absolute;top:4px;bottom:4px;left:50%;width:1px;background:linear-gradient(180deg,transparent,rgba(47,39,30,.24),transparent)}
.timeline div{position:relative;min-height:86px;display:grid;align-content:start}
.timeline div:after{content:"✦";position:absolute;top:1px;color:var(--gold);font-size:.82rem}
.timeline div:nth-child(odd){text-align:right}
.timeline div:nth-child(odd):after{right:-29px}
.timeline div:nth-child(even){grid-column:2;text-align:left;transform:translateY(42px)}
.timeline div:nth-child(even):after{left:-29px}
.timeline b{font-family:var(--sans);font-size:.86rem;font-weight:950;letter-spacing:.2em;color:var(--gold)}
.timeline span{display:block;margin-top:6px;font-family:var(--sans);font-size:.82rem;font-weight:900;letter-spacing:.16em;text-transform:uppercase;color:var(--sage-dark)}
.image-section{min-height:72svh;display:grid;place-items:center;overflow:hidden;padding:80px 18px}
.image-section>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.image-section:after{content:"";position:absolute;inset:0;background:rgba(247,243,235,.25)}
.glass-card{position:relative;z-index:1;width:min(670px,100%);border-radius:24px;padding:36px 24px;background:rgba(255,253,248,.78);box-shadow:0 30px 90px rgba(47,39,30,.16);backdrop-filter:blur(12px);text-align:center}
.dress-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:28px}
.dress-grid h3,.event-card h3{margin:0;font-family:var(--script);font-size:2.5rem;font-weight:400;color:var(--gold)}
.dress-grid p{margin:6px 0 0;color:var(--muted);font-size:1rem}
.gold .kicker,.gold h2,.gold p{color:white}
.event-card{width:min(670px,100%);margin:18px auto 0;border-radius:18px;padding:28px 20px;background:rgba(255,253,248,.94);box-shadow:0 24px 70px rgba(47,39,30,.16);color:var(--ink);text-align:center}
.event-card img{width:82px;height:82px;object-fit:contain;margin:0 auto 12px}
.event-card p{margin:10px 0 0;color:var(--muted);font-size:1rem}
.info-card{width:min(680px,100%);margin:28px auto 0;border-radius:20px;padding:30px 20px;background:white;box-shadow:0 24px 70px rgba(47,39,30,.08);text-align:center}
.info-card hr{width:54px;border:0;border-top:1px solid rgba(47,39,30,.12);margin:24px auto}
.map-card{width:100%;height:min(420px,58vh);margin:22px auto 16px;border-radius:24px;overflow:hidden;border:1px solid rgba(47,39,30,.1);box-shadow:0 18px 52px rgba(47,39,30,.1);background:#e7dfd3}
.map-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:12px auto 0}
.map-button{min-height:48px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:0 16px;background:var(--sage-dark);color:white;font-family:var(--sans);font-size:.78rem;font-weight:950;letter-spacing:.06em;text-decoration:none}
.map-button.light{border:1px solid rgba(47,39,30,.12);background:#fbfaf6;color:var(--sage-dark)}
.elegante-pin{display:grid;place-items:center;width:44px!important;height:44px!important;border-radius:999px;background:white;box-shadow:0 12px 30px rgba(47,39,30,.25);font-size:1.35rem}
.gallery{padding:34px 0;background:var(--ivory);display:grid;gap:14px}
.gallery-row{display:flex;gap:14px;width:max-content;animation:marquee 34s linear infinite}
.gallery-row.reverse{animation-direction:reverse}
.gallery-row img{width:min(44vw,310px);aspect-ratio:4/5;border-radius:24px;object-fit:cover;box-shadow:0 18px 50px rgba(47,39,30,.1)}
.rsvp-form{display:grid;gap:13px;width:min(560px,100%);margin:28px auto 0;border-radius:24px;padding:20px;background:white;box-shadow:0 24px 70px rgba(47,39,30,.08);text-align:left}
.rsvp-form label{display:grid;gap:7px}
.rsvp-form label span,.guest-row>span{font-family:var(--sans);font-size:.7rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.rsvp-form input,.rsvp-form select,.rsvp-form textarea{width:100%;min-height:48px;border:1px solid rgba(47,39,30,.12);border-radius:14px;padding:12px;background:#fbfaf6;color:var(--ink)}
.rsvp-form textarea{min-height:96px;resize:vertical}
.guest-row{display:grid;gap:8px}
.stepper{display:grid;grid-template-columns:46px 1fr 46px;gap:8px}
.stepper button{border:1px solid rgba(165,122,53,.3);border-radius:14px;background:white;color:var(--gold);font-family:var(--sans);font-size:1.4rem;font-weight:900}
.stepper input{text-align:center;font-family:var(--sans);font-weight:900}
.submit{min-height:50px;border:0;border-radius:999px;background:var(--sage-dark);color:white;font-family:var(--sans);font-weight:950}
.notice{min-height:22px;color:var(--gold);font-family:var(--sans);font-size:.84rem;font-weight:900;text-align:center}
.footer{padding:86px 18px 118px;background:var(--ivory);text-align:center;color:var(--gold)}
.footer p{margin:0;font-family:var(--script);font-size:clamp(5rem,18vw,9rem);line-height:.72;color:var(--gold)}
.footer span{display:block;margin:4px 0;font-family:var(--serif);font-size:2rem;color:var(--sage-dark)}
.footer small{display:block;margin-top:28px;font-family:var(--sans);font-weight:900;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
@keyframes flash{0%{opacity:0;transform:translate(-50%,-50%) scale(.2)}34%{opacity:1;transform:translate(-50%,-50%) scale(8)}100%{opacity:0;transform:translate(-50%,-50%) scale(18)}}
@keyframes marquee{to{transform:translateX(calc(-50% - 7px))}}
@media(max-width:760px){
  .intro video{object-position:center}
  .hero-content{padding-top:clamp(82px,13vh,112px)}
  .eyebrow{margin-bottom:24px;font-size:.68rem;letter-spacing:.34em}
  .hero h1{font-size:clamp(4.5rem,22vw,7rem);gap:10px;line-height:.76}
  .divider{margin:28px auto 12px}
  .date{font-size:clamp(1rem,4.2vw,1.25rem)}
  .countdown{padding-left:10px;padding-right:10px}
  .count-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}
  .count-grid div{min-height:78px;border-radius:18px}
  .count-grid strong{font-size:clamp(1.55rem,8vw,2.25rem)}
  .count-grid span{font-size:.54rem;letter-spacing:.08em}
  h2{font-size:clamp(3.25rem,15vw,5.2rem)}
  .timeline{grid-template-columns:1fr;gap:22px}
  .timeline:before{left:18px}
  .timeline div,.timeline div:nth-child(odd),.timeline div:nth-child(even){grid-column:1;padding-left:42px;text-align:left;transform:none;min-height:0}
  .timeline div:nth-child(odd):after,.timeline div:nth-child(even):after{left:11px;right:auto}
  .dress-grid{grid-template-columns:1fr}
  .map-actions{grid-template-columns:1fr}
  .gallery-row img{width:64vw;border-radius:20px}
  .lang-pill{right:12px;top:12px}
  .sound{right:14px;bottom:14px}
}
@media(prefers-reduced-motion:reduce){
  *,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition:none!important;scroll-behavior:auto!important}
}
