/* ============================================================
   ETHAN & ZOE — FROM DAY TO NIGHT
   A warm garden ceremony (light) that dissolves, past a sunset
   horizon, into a starlit reception (night) with a spinning disco ball.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Hanken+Grotesk:ital,wght@0,300..800;1,300..800&display=swap');

/* ---------- Tokens ---------- */
:root{
  /* day */
  --cream:#F5EFE1; --cream-2:#EFE6D2; --cream-3:#E7DBC0; --paper:#FBF7EC;
  --forest:#2E4434; --forest-2:#243a2c; --olive:#6E7A4C; --moss:#909C6B;
  --gold:#C8923A; --gold-2:#E0B25C; --terracotta:#B5613C; --clay:#C9764C;
  --ink:#2B2218; --brown:#5C4A35; --line:rgba(43,34,24,.16);

  /* night */
  --night:#0c1330; --night-2:#070b22; --night-3:#16204a;
  --panel:#19224d; --panel-2:#1f2a59;
  --moon:#EAE7FF; --lav:#B7B6E6; --lav-2:#8E8FC9;
  --star:#FDFDFF; --nline:rgba(234,231,255,.16);

  --serif:'DM Serif Display', Georgia, 'Times New Roman', serif;
  --sans:'Hanken Grotesk', system-ui, -apple-system, sans-serif;
  --maxw:1180px; --r:18px;
  --ease:cubic-bezier(.22,1,.36,1);
}

/* ---------- Reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);color:var(--ink);background:var(--cream);
  line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--gold);color:var(--forest)}

/* paper grain over the day half only */
.hero::after,.band.day::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:1;opacity:.5;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.045'/%3E%3C/svg%3E");
}

/* ---------- Typography ---------- */
.eyebrow{font-size:clamp(11px,1.1vw,13px);text-transform:uppercase;letter-spacing:.38em;font-weight:600;color:var(--terracotta)}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.02;letter-spacing:-.015em}
.h-sec{font-size:clamp(34px,6vw,68px);color:var(--forest)}
.h-sec.small{font-size:clamp(30px,4.6vw,52px);margin-top:14px}
p{text-wrap:pretty}
.para{color:var(--brown);font-size:17px;margin-top:16px;max-width:48ch}

/* ---------- Layout ---------- */
section{position:relative;z-index:2}
.band,.skyfall{scroll-margin-top:72px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,48px)}
.band{padding-block:clamp(72px,11vw,140px);overflow:hidden}
.band.pad-sm{padding-block:clamp(54px,8vw,104px)}
.center{text-align:center}
.bg-cream2{background:var(--cream-2)}
.sec-head{max-width:760px;margin:0 auto clamp(40px,6vw,68px)}
.sec-head .eyebrow{display:inline-block;margin-bottom:18px}
.sec-head p.lead{margin-top:18px;font-size:clamp(16px,1.6vw,19px);color:var(--brown);max-width:620px;margin-inline:auto}
.btnrow{margin-top:28px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.6em;font-weight:600;font-size:15px;letter-spacing:.02em;
  padding:15px 28px;border-radius:999px;background:var(--forest);color:var(--paper);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);box-shadow:0 6px 0 var(--forest-2)}
.btn:hover{transform:translateY(-3px);box-shadow:0 9px 0 var(--forest-2)}
.btn:active{transform:translateY(2px);box-shadow:0 3px 0 var(--forest-2)}
.btn--gold{background:var(--gold);color:var(--forest);box-shadow:0 6px 0 #a9772a}
.btn--gold:hover{box-shadow:0 9px 0 #a9772a}
.btn--ghost{background:transparent;color:var(--moon);box-shadow:inset 0 0 0 2px var(--lav);margin-top:18px}
.btn--ghost:hover{background:var(--lav);color:var(--night)}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}

/* ============================================================
   NAV (theme-aware)
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;display:flex;align-items:center;justify-content:space-between;
  padding:16px clamp(18px,5vw,40px);transition:background .5s var(--ease),box-shadow .5s var(--ease),padding .4s var(--ease)}
.nav__logo{font-family:var(--serif);font-size:22px;color:var(--forest);display:flex;align-items:center;gap:.4em;transition:color .5s var(--ease)}
.nav__logo b{font-weight:400}
.nav__logo .amp{color:var(--gold);font-style:italic}
.nav__links{display:flex;align-items:center;gap:4px}
.nav__links a{font-size:13.5px;font-weight:600;color:var(--brown);padding:9px 13px;border-radius:999px;transition:color .25s,background .25s}
.nav__links a:hover{color:var(--forest);background:rgba(110,122,76,.16)}
.nav__cta{margin-left:6px;padding:11px 20px;background:var(--terracotta);color:var(--paper)!important;font-weight:700;box-shadow:0 4px 0 #8f4b2e;transition:transform .3s var(--ease)}
.nav__cta:hover{transform:translateY(-2px)}
.nav__burger{display:none;width:44px;height:44px;border-radius:12px;background:var(--forest);color:var(--paper);font-size:18px;align-items:center;justify-content:center}

/* scrolled (day) */
.nav.scrolled{background:rgba(245,239,225,.9);backdrop-filter:blur(10px);box-shadow:0 1px 0 var(--line);padding-block:11px}

/* night theme — flips when scrolled into the reception */
body[data-theme="night"] .nav.scrolled{background:rgba(10,15,38,.82);box-shadow:0 1px 0 var(--nline)}
body[data-theme="night"] .nav__logo{color:var(--moon)}
body[data-theme="night"] .nav__logo .amp{color:var(--gold-2)}
body[data-theme="night"] .nav__links a{color:var(--lav)}
body[data-theme="night"] .nav__links a:hover{color:var(--moon);background:rgba(183,182,230,.16)}
body[data-theme="night"] .nav__burger{background:var(--panel-2);color:var(--moon)}

@media(max-width:940px){
  .nav__links{position:fixed;inset:0 0 0 auto;width:min(82vw,340px);flex-direction:column;align-items:stretch;
    justify-content:center;gap:4px;background:var(--forest);padding:80px 26px;transform:translateX(100%);transition:transform .5s var(--ease)}
  body[data-theme="night"] .nav__links{background:var(--night-2)}
  .nav__links.open{transform:none}
  .nav__links a{color:var(--paper);font-size:18px;padding:14px 16px;font-family:var(--serif)}
  body[data-theme="night"] .nav__links a{color:var(--moon)}
  .nav__links a:hover{background:rgba(255,255,255,.1)}
  .nav__links .nav__cta{margin:14px 0 0;text-align:center}
  .nav__burger{display:flex}
}

/* ============================================================
   HERO (day)
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;align-items:center;
  padding:118px 20px 56px;overflow:hidden;
  background:linear-gradient(180deg,#fef6e6 0%,var(--cream) 46%,var(--cream-2) 100%)}
.hero__sky{position:absolute;inset:0;z-index:0;overflow:hidden}
.cloud{position:absolute;background:rgba(255,255,255,.6);border-radius:100px;filter:blur(6px);opacity:.7}
.cloud::before,.cloud::after{content:"";position:absolute;background:inherit;border-radius:100px}
.c1{width:160px;height:30px;top:20%;left:8%;animation:drift 40s linear infinite}
.c1::before{width:80px;height:46px;top:-22px;left:30px}
.c2{width:120px;height:24px;top:14%;right:12%;animation:drift 54s linear infinite reverse}
.c2::before{width:60px;height:36px;top:-16px;left:24px}
.c3{width:200px;height:34px;top:64%;right:6%;opacity:.5;animation:drift 64s linear infinite}
.c3::before{width:90px;height:48px;top:-22px;left:50px}
@keyframes drift{from{transform:translateX(-40px)}to{transform:translateX(40px)}}

.hero__eyebrow{position:relative;z-index:4;margin-bottom:clamp(18px,3vw,28px);text-align:center}
.hero__inner{position:relative;z-index:4;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:clamp(10px,3vw,40px);max-width:1080px;width:100%}
.hero__name{font-family:var(--serif);color:var(--forest);font-size:clamp(48px,12vw,150px);line-height:.86;text-align:center}
.hero__name.left{text-align:right}.hero__name.right{text-align:left}
.hero__amp{display:flex;align-items:center;justify-content:center;position:relative}
.hero__amp .ring{position:absolute;width:170px;height:170px;border-radius:50%;border:2px solid var(--gold);opacity:.55}
.hero__amp .ring2{width:210px;height:210px;border-style:dashed;border-color:var(--terracotta);opacity:.4;animation:spin 80s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.hero__photo{width:clamp(170px,22vw,250px);height:clamp(230px,30vw,330px);border-radius:999px 999px 14px 14px;overflow:hidden;
  object-fit:cover;border:7px solid var(--paper);box-shadow:0 24px 50px -22px rgba(43,34,24,.55)}

.hero__meta{position:relative;z-index:4;margin-top:clamp(26px,4vw,40px);text-align:center;display:flex;flex-direction:column;align-items:center;gap:13px}
.hero__rule{display:flex;align-items:center;gap:14px;color:var(--terracotta);font-size:13px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;text-align:center}
.hero__rule::before,.hero__rule::after{content:"";width:42px;height:2px;background:linear-gradient(90deg,transparent,var(--terracotta));opacity:.55}
.hero__rule::after{background:linear-gradient(90deg,var(--terracotta),transparent)}
.hero__date{font-family:var(--serif);font-size:clamp(20px,2.6vw,30px);color:var(--ink)}
.hero__sub{font-size:14px;letter-spacing:.22em;text-transform:uppercase;color:var(--brown);font-weight:600}
.countdown{display:flex;gap:10px;margin-top:6px}
.cd{min-width:72px;background:var(--paper);border:1.5px solid var(--line);border-radius:14px;padding:11px 8px;text-align:center;box-shadow:0 8px 22px -16px rgba(43,34,24,.6)}
.cd b{display:block;font-family:var(--serif);font-size:28px;color:var(--forest);line-height:1}
.cd span{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--brown);font-weight:700}

@media(max-width:760px){
  .hero__inner{grid-template-columns:1fr;gap:4px}
  .hero__name.left,.hero__name.right{text-align:center}
  .hero__amp{order:-1;margin-bottom:6px}
}

/* ============================================================
   HERO TREES + section CTA bars
   ============================================================ */
.ctabar{margin-top:clamp(36px,5vw,60px);display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:16px 28px;
  text-align:center;padding:24px 30px;border-radius:18px;background:var(--paper);border:1.5px solid var(--line);
  box-shadow:0 28px 60px -42px rgba(43,34,24,.5)}
.ctabar span{font-family:var(--serif);font-style:italic;font-size:clamp(18px,2.2vw,24px);color:var(--forest)}
.ctabar--night{background:var(--panel);border-color:var(--nline);margin-top:32px}
.ctabar--night span{color:var(--moon)}

/* ============================================================
   THE CEREMONY cards
   ============================================================ */
.cer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,26px)}
@media(max-width:780px){.cer-grid{grid-template-columns:1fr}}
.cercard{background:var(--paper);border:1.5px solid var(--line);border-radius:var(--r);padding:32px 28px;text-align:center;
  box-shadow:0 28px 60px -42px rgba(43,34,24,.55)}
.cercard__ico{width:54px;height:54px;margin:0 auto 16px;border-radius:50%;background:var(--cream-2);border:1.5px solid var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:24px}
.cercard h3{font-size:24px;color:var(--forest);margin-bottom:10px}
.cercard p{color:var(--brown);font-size:15.5px;line-height:1.7}
.cercard p b{color:var(--ink)}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:clamp(132px,17vw,220px);gap:clamp(8px,1vw,14px)}
.gtile{position:relative;overflow:hidden;border-radius:14px;border:5px solid var(--paper);box-shadow:0 22px 44px -28px rgba(43,34,24,.55);background:var(--cream-3);transition:transform .45s var(--ease)}
.gtile img{width:100%;height:100%;object-fit:cover}
.gtile:hover{transform:translateY(-4px);z-index:2}
.gtile::after{content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;box-shadow:inset 0 0 0 1px rgba(200,146,58,.35)}
.g-a{grid-column:1/3;grid-row:1/3}
.g-b{grid-column:3/5;grid-row:1/2}
.g-c{grid-column:3/4;grid-row:2/3}
.g-d{grid-column:4/5;grid-row:2/3}
.g-e{grid-column:1/3;grid-row:3/4}
.g-f{grid-column:3/5;grid-row:3/4}
@media(max-width:760px){
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:clamp(140px,42vw,200px);gap:8px}
  .g-a,.g-b,.g-c,.g-d,.g-e,.g-f{grid-column:auto;grid-row:auto}
}

/* ============================================================
   SPLIT / INFO
   ============================================================ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px);align-items:center}
.split.rev{direction:rtl}.split.rev>*{direction:ltr}
@media(max-width:860px){.split{grid-template-columns:1fr}}
.framephoto{position:relative;aspect-ratio:4/5;border-radius:280px 280px 20px 20px;overflow:hidden;border:8px solid var(--paper);box-shadow:0 30px 60px -34px rgba(43,34,24,.6)}
.framephoto img{display:block;width:100%;height:100%;object-fit:cover;border-radius:inherit}
.framephoto--night{border-color:var(--panel-2);box-shadow:0 30px 70px -30px rgba(0,0,0,.7),0 0 40px -18px rgba(183,182,230,.5)}

.infolist{display:flex;flex-direction:column;gap:18px;margin-top:24px}
.infolist.tight{gap:13px}
.infoline{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start}
.infoline .ico{width:40px;height:40px;border-radius:12px;background:var(--cream-2);border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--forest);font-family:var(--serif);font-size:18px}
.infoline h4{font-size:16px;color:var(--forest);font-weight:800;margin-bottom:2px}
.infoline p{color:var(--brown);font-size:15px}

/* venue card (static) */
.venuecard{position:relative;border-radius:20px;overflow:hidden;border:8px solid var(--paper);aspect-ratio:5/4;
  box-shadow:0 30px 60px -34px rgba(43,34,24,.6);background:var(--cream-2)}
.venuecard__map{position:absolute;inset:0}
.venuecard__map img{width:100%;height:100%;object-fit:cover}
.venuecard__chip{position:absolute;left:14px;bottom:14px;z-index:3;display:inline-flex;align-items:center;gap:7px;
  background:var(--paper);color:var(--forest);font-weight:700;font-size:13px;padding:9px 15px;border-radius:999px;
  box-shadow:0 8px 20px -10px rgba(43,34,24,.6);border:1px solid var(--line)}
.venuecard__chip .mc-pin{width:10px;height:10px;border-radius:50%;background:var(--terracotta);border:2px solid var(--paper)}

/* place cards (stay) */
.cardgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:clamp(16px,2vw,26px)}
.placecard{display:flex;flex-direction:column;overflow:hidden;border-radius:var(--r);background:var(--paper);border:1.5px solid var(--line);
  box-shadow:0 28px 60px -42px rgba(43,34,24,.55);transition:transform .45s var(--ease)}
.placecard:hover{transform:translateY(-6px)}
.placecard img{width:100%;height:170px;object-fit:cover;display:block}
.placecard__body{padding:22px 22px 26px}
.placecard .tag{display:inline-block;font-size:11px;text-transform:uppercase;letter-spacing:.18em;font-weight:800;color:var(--terracotta);margin-bottom:10px}
.placecard h3{font-size:22px;color:var(--forest);margin-bottom:6px}
.placecard p{font-size:14.5px;color:var(--brown);margin-bottom:14px}
.placecard .meta{margin-top:auto;display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:700;color:var(--olive)}
.placecard a.go{font-weight:800;color:var(--terracotta)}

/* ============================================================
   ATTIRE
   ============================================================ */
.attire-palette{display:flex;flex-wrap:wrap;gap:14px;margin-top:20px}
.swatch{display:flex;flex-direction:column;align-items:center;gap:8px}
.swatch span{width:62px;height:62px;border-radius:50%;box-shadow:inset 0 0 0 3px var(--paper),0 8px 18px -10px rgba(43,34,24,.6)}
.swatch small{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--brown);font-weight:700}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.chip{padding:9px 16px;border-radius:999px;background:var(--cream-2);border:1.5px solid var(--line);font-size:13.5px;font-weight:600;color:var(--brown)}

/* ============================================================
   NIGHT WORLD
   ============================================================ */
.night{position:relative}

/* reception, feast, honeyfund, faq are normal light sections now */

/* ===== MENU (light cards) ===== */
.menu{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,40px)}
@media(max-width:820px){.menu{grid-template-columns:1fr}}
.menucard{background:var(--paper);border-radius:var(--r);border:1.5px solid var(--line);overflow:hidden;box-shadow:0 24px 50px -34px rgba(43,34,24,.55)}
.menucard__top{padding:26px 28px;color:var(--paper);display:flex;align-items:center;justify-content:space-between;gap:16px}
.menucard.thai .menucard__top{background:var(--forest)}
.menucard.bar .menucard__top{background:var(--terracotta)}
.menucard__top h3{color:var(--paper);font-size:28px}
.menucard__top .kicker{font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:800;opacity:.85}
.menucard__top .badge{font-family:var(--serif);font-style:italic;font-size:17px;background:rgba(255,255,255,.16);padding:8px 14px;border-radius:999px}
.menulist{padding:22px 28px 28px;display:flex;flex-direction:column;gap:2px}
.menuitem{display:flex;justify-content:space-between;align-items:baseline;gap:14px;padding:13px 0;border-bottom:1px dashed var(--line)}
.menuitem:last-child{border-bottom:none}
.menuitem b{font-family:var(--serif);font-size:19px;color:var(--forest);font-weight:400}
.menuitem .d{font-size:13.5px;color:var(--brown);flex:1;margin-left:14px}
.menuitem .v{font-size:10.5px;font-weight:800;letter-spacing:.12em;color:var(--olive);text-transform:uppercase;white-space:nowrap}
.note{font-size:12.5px;text-align:center;margin-top:24px;color:var(--brown);opacity:.85}
.note.left{text-align:left;margin-top:16px}

/* ===== HONEYFUND ===== */
.honey{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(24px,4vw,56px);align-items:center}
@media(max-width:860px){.honey{grid-template-columns:1fr}}
.fundcats{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:26px}
.fundcat{background:var(--paper);border:1.5px solid var(--line);border-radius:16px;padding:18px;text-align:center}
.fundcat b{display:block;font-family:var(--serif);font-size:18px;color:var(--forest)}
.fundcat small{font-size:12.5px;color:var(--brown)}
.payrow{display:flex;flex-wrap:wrap;gap:14px;margin-top:24px}
.paybtn{display:inline-flex;align-items:center;gap:10px;padding:15px 26px;border-radius:14px;font-weight:800;font-size:15px;color:#fff;box-shadow:0 6px 0 rgba(0,0,0,.28);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.paybtn.venmo{background:#3D95CE}.paybtn.stripe{background:#635BFF}
.paybtn:hover{transform:translateY(-3px)}
.paybtn.venmo:hover{box-shadow:0 9px 0 #2d6f9a}
.paybtn.stripe:hover{box-shadow:0 9px 0 #463fd6}
.paybtn:active{transform:translateY(2px);box-shadow:0 3px 0 rgba(0,0,0,.28)}

/* ===== FAQ ===== */
.faq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.qa{background:var(--paper);border:1.5px solid var(--line);border-radius:16px;overflow:hidden}
.qa__q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:18px;padding:22px 26px;text-align:left;font-family:var(--serif);font-size:clamp(18px,2vw,22px);color:var(--forest)}
.qa__q .pm{flex:none;width:32px;height:32px;border-radius:50%;background:var(--cream-2);border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--terracotta);transition:transform .4s var(--ease)}
.qa.open .qa__q .pm{transform:rotate(45deg)}
.qa__a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.qa__a div{padding:0 26px 24px;color:var(--brown);font-size:15.5px}
.qa__a b{color:var(--forest)}

/* ===== RSVP ===== */
.rsvp{background:var(--forest);color:var(--cream)}
.rsvp .h-sec{color:var(--paper)}
.rsvp .eyebrow{color:var(--gold-2)}
.rsvp .sec-head p.lead{color:rgba(245,239,225,.82)}
.rsvp .form{position:relative;overflow:hidden;max-width:680px;margin:0 auto;color:var(--ink);border-radius:24px;
  padding:clamp(28px,4vw,44px);background:var(--paper);border:1px solid var(--line);
  box-shadow:0 40px 80px -40px rgba(0,0,0,.5)}
#formFields,.form__ok{position:relative;z-index:1}
.field{margin-bottom:20px}
.field label{display:block;font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--forest);margin-bottom:8px}
.field input,.field textarea,.field select{width:100%;padding:14px 16px;border-radius:12px;border:1.5px solid var(--line);
  background:var(--cream);font-family:inherit;font-size:15.5px;color:var(--ink);transition:border .25s,box-shadow .25s}
.field input::placeholder,.field textarea::placeholder{color:#9b8a6f}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--olive);box-shadow:0 0 0 4px rgba(110,122,76,.18)}
.field textarea{resize:vertical;min-height:96px}
.field--row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:560px){.field--row{grid-template-columns:1fr}}
.segment{display:flex;gap:10px}
.segment label{flex:1;cursor:pointer;margin:0}
.segment input{position:absolute;opacity:0;pointer-events:none}
.segment span{display:flex;align-items:center;justify-content:center;padding:14px;border-radius:12px;border:1.5px solid var(--line);background:var(--cream);font-weight:700;font-size:15px;transition:all .25s;color:var(--ink)}
.segment input:checked+span{background:var(--forest);color:var(--paper);border-color:var(--forest)}
.segment .no input:checked+span{background:var(--terracotta);border-color:var(--terracotta);color:#fff}
.form .btn{width:100%;justify-content:center;margin-top:8px;font-size:16px}
.form__ok{display:none;text-align:center;padding:20px 0}
.form__ok.show{display:block;animation:pop .5s var(--ease)}
@keyframes pop{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:none}}
.form__ok h3{font-size:34px;color:var(--forest);margin-bottom:8px}
.form__ok p{color:var(--brown)}
.rsvp-count{display:inline-flex;align-items:center;gap:8px;margin-top:26px;font-size:13px;font-weight:700;color:var(--gold-2)}
.rsvp-count b{font-family:var(--serif);font-size:18px;color:var(--paper)}

/* ===== FOOTER ===== */
.footer{position:relative;z-index:2;background:var(--forest-2);color:var(--cream);text-align:center;padding:clamp(56px,8vw,92px) 20px 44px}
.footer .mono{font-family:var(--serif);font-size:clamp(40px,8vw,76px);color:var(--gold-2);line-height:.9}
.footer .mono .amp{font-style:italic;color:var(--paper)}
.footer .date{margin-top:14px;font-size:14px;letter-spacing:.28em;text-transform:uppercase;color:rgba(245,239,225,.75);font-weight:600}
.footer .top{margin-top:30px;display:inline-flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;color:var(--gold-2)}
.footer .fine{margin-top:30px;font-size:12px;color:rgba(245,239,225,.5)}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
}
