/* =========================================================
   Prima & Kasit — Wedding
   A golden-hour / misty-mountain editorial aesthetic
   ========================================================= */

:root {
  /* "After Dusk" — Mae Wan forest palette
     white · oat · walnut · old burgundy · olivenite · midnight pines · trefoil */
  --bg:        #19221b;   /* midnight pine — base */
  --bg-deep:   #131a14;   /* deeper pine — alternate sections */
  --ink:       #e7ddc7;   /* oat — primary text */
  --ink-soft:  #b4ab92;   /* muted oat */
  --forest:    #0e140d;   /* darkest — feature bands */
  --forest-2:  #2b3422;   /* olivenite */
  --sage:      #8c9a6d;   /* trefoil / olive accent */
  --gold:      #c2925a;   /* walnut — candlelight */
  --gold-deep: #cda062;   /* warm gold accent (readable on dark) */
  --cream:     #f4efe3;   /* near-white — brightest text */
  --oat:       #ddd1b9;   /* oat surface tone */
  --burgundy:  #5b3a42;   /* old burgundy */
  --ink-dark:  #18201a;   /* dark text, for any light surface */
  --line:      rgba(231, 221, 199, 0.16);  /* hairline on dark */

  --serif: "Cormorant Garamond", Georgia, serif;
  --sans:  "Jost", "Helvetica Neue", sans-serif;

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--serif);
  background: var(--bg);
  color: var(--ink);
  line-height: 1.5;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

/* ---------- Paper grain + mist atmosphere ---------- */
body::before {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none; z-index: 9000;
  opacity: 0.045;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Shared typography helpers ---------- */
.eyebrow {
  font-family: var(--sans);
  font-weight: 400;
  font-size: 0.72rem;
  letter-spacing: 0.42em;
  text-transform: uppercase;
  color: var(--gold-deep);
}
.script { font-style: italic; font-weight: 400; color: var(--gold-deep); }

.section { position: relative; padding: clamp(5rem, 12vw, 11rem) clamp(1.4rem, 6vw, 7rem); }
.section--center { text-align: center; }
.wrap { max-width: 1180px; margin: 0 auto; }
.wrap--narrow { max-width: 760px; margin: 0 auto; }

.h-rule {
  width: 1px; height: clamp(48px, 8vw, 88px);
  background: linear-gradient(var(--gold), transparent);
  margin: 1.6rem auto;
}
.section-title {
  font-weight: 300;
  font-size: clamp(2.4rem, 6vw, 4.6rem);
  line-height: 1.02;
  letter-spacing: 0.01em;
}

/* =========================================================
   NAV
   ========================================================= */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.5rem clamp(1.4rem, 5vw, 3.4rem);
  transition: background 0.5s var(--ease), padding 0.5s var(--ease),
              box-shadow 0.5s var(--ease), color 0.5s var(--ease);
  color: var(--cream);
  mix-blend-mode: normal;
}
.nav.scrolled {
  background: rgba(14, 20, 13, 0.82);
  backdrop-filter: blur(12px);
  color: var(--ink);
  padding-top: 1rem; padding-bottom: 1rem;
  box-shadow: 0 1px 0 var(--line);
}
.nav__brand {
  font-family: var(--serif);
  font-size: 1.45rem;
  letter-spacing: 0.18em;
  font-weight: 500;
}
.nav__links { display: flex; gap: clamp(1rem, 2.4vw, 2.4rem); align-items: center; }
.nav__links a {
  font-family: var(--sans);
  font-size: 0.74rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  position: relative;
  padding: 0.2rem 0;
  opacity: 0.92;
}
.nav__links a::after {
  content: ""; position: absolute; left: 0; bottom: -2px;
  width: 0; height: 1px; background: currentColor;
  transition: width 0.4s var(--ease);
}
.nav__links a:hover::after { width: 100%; }
.nav__links a.cta {
  border: 1px solid currentColor;
  padding: 0.62rem 1.3rem;
  border-radius: 100px;
  opacity: 1;
}
.nav__links a.cta::after { display: none; }
.nav__links a.cta:hover { background: var(--gold); border-color: var(--gold); color: var(--cream); }
.nav__toggle { display: none; }

/* =========================================================
   HERO
   ========================================================= */
.hero {
  position: relative; height: 100svh; min-height: 620px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; color: var(--cream);
  overflow: hidden;
}
.hero__img {
  position: absolute; inset: 0;
  background-image: -webkit-image-set(url("assets/photos/photo4.webp") type("image/webp"), url("assets/photos/photo4.jpg") type("image/jpeg"));
  background-image: image-set(url("assets/photos/photo4.webp") type("image/webp"), url("assets/photos/photo4.jpg") type("image/jpeg"));
  background-position: center 38%; background-size: cover; background-repeat: no-repeat;
  transform: scale(1.12);
  will-change: transform;
}
.hero__img::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(8,12,7,0.55) 0%, rgba(8,12,7,0.12) 30%, rgba(8,12,7,0.28) 62%, rgba(8,12,7,0.82) 100%);
}
.hero__inner { position: relative; z-index: 2; padding: 0 1.4rem; }
.hero__eyebrow {
  font-family: var(--sans);
  font-size: clamp(0.7rem, 1.4vw, 0.86rem);
  letter-spacing: 0.5em; text-transform: uppercase;
  margin-bottom: 1.7rem; text-indent: 0.5em;
}
.hero__names {
  font-weight: 300;
  font-size: clamp(3.6rem, 15vw, 11rem);
  line-height: 0.86; letter-spacing: 0.01em;
  text-shadow: 0 2px 40px rgba(0,0,0,0.28);
}
.hero__names .amp {
  display: block; font-style: italic; font-weight: 300;
  font-size: clamp(1.6rem, 5vw, 3rem); color: #e9d4ab;
  margin: 0.35em 0; letter-spacing: 0.02em;
}
.hero__meta {
  margin-top: 2rem;
  font-family: var(--sans);
  font-size: clamp(0.78rem, 1.6vw, 0.96rem);
  letter-spacing: 0.32em; text-transform: uppercase;
  display: flex; gap: 1.1rem; justify-content: center; align-items: center; flex-wrap: wrap;
}
.hero__meta .dot { width: 4px; height: 4px; border-radius: 50%; background: var(--gold); }
.hero__scroll {
  position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%);
  z-index: 2; font-family: var(--sans); font-size: 0.62rem;
  letter-spacing: 0.34em; text-transform: uppercase; color: var(--cream);
  display: flex; flex-direction: column; align-items: center; gap: 0.7rem; opacity: 0.85;
}
.hero__scroll .bar { width: 1px; height: 46px; background: var(--cream); animation: scrollPulse 2.4s var(--ease) infinite; transform-origin: top; }
@keyframes scrollPulse { 0%,100%{ transform: scaleY(0.3); opacity:0.4 } 50%{ transform: scaleY(1); opacity:1 } }

/* =========================================================
   COUNTDOWN STRIP
   ========================================================= */
.countdown {
  background: var(--forest); color: var(--cream);
  padding: clamp(2.6rem, 6vw, 4rem) 1.4rem;
  text-align: center;
}
.countdown__label { font-family: var(--sans); font-size: 0.7rem; letter-spacing: 0.4em; text-transform: uppercase; color: var(--sage); margin-bottom: 1.6rem; }
.countdown__grid { display: flex; justify-content: center; gap: clamp(1.4rem, 6vw, 4.5rem); }
.cd-unit { display: flex; flex-direction: column; align-items: center; min-width: 60px; }
.cd-unit .num { font-size: clamp(2.6rem, 8vw, 4.4rem); font-weight: 300; line-height: 1; font-variant-numeric: tabular-nums; }
.cd-unit .lbl { font-family: var(--sans); font-size: 0.62rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--sage); margin-top: 0.7rem; }

/* =========================================================
   WELCOME / INTRO
   ========================================================= */
.intro { text-align: center; background: var(--bg); }
.intro__lead {
  font-size: clamp(1.6rem, 3.4vw, 2.6rem);
  font-weight: 300; line-height: 1.4; color: var(--ink);
  max-width: 22ch; margin: 0 auto;
}
.intro__lead em { color: var(--gold-deep); }
.intro__msg { margin-top: 2rem; font-size: clamp(1.05rem, 2vw, 1.3rem); color: var(--ink-soft); max-width: 48ch; margin-inline: auto; }

/* =========================================================
   DETAILS / SCHEDULE
   ========================================================= */
.details { background: var(--forest); color: var(--cream); }
.details .eyebrow { color: var(--sage); }
.details .section-title { color: var(--cream); }
.cards { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.4rem, 4vw, 2.6rem); margin-top: clamp(2.6rem, 6vw, 4rem); }
.card {
  background: rgba(250,245,236,0.05);
  border: 1px solid rgba(250,245,236,0.16);
  padding: clamp(1.8rem, 4vw, 3rem);
  position: relative; overflow: hidden;
}
.card__day { font-family: var(--sans); font-size: 0.68rem; letter-spacing: 0.34em; text-transform: uppercase; color: var(--gold); }
.card__name { font-size: clamp(1.8rem, 3.4vw, 2.6rem); font-weight: 300; margin: 0.6rem 0 0.2rem; line-height: 1.08; }
.card__when { font-family: var(--sans); font-size: 0.84rem; letter-spacing: 0.06em; color: var(--sage); margin-bottom: 1.6rem; }
.timeline { list-style: none; border-top: 1px solid rgba(250,245,236,0.16); }
.timeline li {
  display: flex; gap: 1.2rem; align-items: baseline;
  padding: 0.85rem 0; border-bottom: 1px solid rgba(250,245,236,0.12);
}
.timeline .t { font-family: var(--sans); font-size: 0.8rem; letter-spacing: 0.08em; color: var(--gold); min-width: 4.6rem; font-variant-numeric: tabular-nums; }
.timeline .e { font-size: 1.18rem; color: var(--cream); }
.card__note { margin-top: 1.5rem; font-size: 1.1rem; color: rgba(250,245,236,0.82); line-height: 1.55; }
.card__meta { margin-top: 1.7rem; display: flex; flex-direction: column; gap: 0.6rem; }
.card__meta .row { display: flex; gap: 0.7rem; align-items: center; font-family: var(--sans); font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--sage); }
.card__meta .row b { color: var(--cream); font-weight: 400; letter-spacing: 0.06em; text-transform: none; font-family: var(--serif); font-size: 1.05rem; }
.details__venue { text-align: center; margin-top: clamp(2.6rem,6vw,4rem); }
.details__venue .place { font-size: clamp(1.4rem,3vw,2rem); font-weight: 300; }
.btn-line {
  display: inline-flex; align-items: center; gap: 0.6rem;
  font-family: var(--sans); font-size: 0.74rem; letter-spacing: 0.24em; text-transform: uppercase;
  border: 1px solid var(--gold); color: var(--gold);
  padding: 0.85rem 1.7rem; border-radius: 100px; margin-top: 1.4rem;
  transition: all 0.4s var(--ease);
}
.btn-line:hover { background: var(--gold); color: var(--forest); }

/* =========================================================
   FULL-BLEED BANNER
   ========================================================= */
.banner { position: relative; height: clamp(360px, 60vh, 620px); overflow: hidden; display: flex; align-items: center; justify-content: center; }
.banner__img { position: absolute; inset: 0; background-size: cover; background-position: center; will-change: transform; }
.banner--1 .banner__img {
  background-image: -webkit-image-set(url("assets/photos/photo5.webp") type("image/webp"), url("assets/photos/photo5.jpg") type("image/jpeg"));
  background-image: image-set(url("assets/photos/photo5.webp") type("image/webp"), url("assets/photos/photo5.jpg") type("image/jpeg"));
}
.banner--2 .banner__img {
  background-image: -webkit-image-set(url("assets/photos/photo6.webp") type("image/webp"), url("assets/photos/photo6.jpg") type("image/jpeg"));
  background-image: image-set(url("assets/photos/photo6.webp") type("image/webp"), url("assets/photos/photo6.jpg") type("image/jpeg"));
  background-position: center 30%;
}
.banner::after { content:""; position:absolute; inset:0; background: rgba(8,12,7,0.5); }
.banner__quote { position: relative; z-index: 2; color: var(--cream); text-align: center; padding: 0 1.4rem; max-width: 22ch; }
.banner__quote p { font-size: clamp(1.6rem, 4vw, 3rem); font-weight: 300; font-style: italic; line-height: 1.25; text-shadow: 0 2px 30px rgba(0,0,0,0.4); }

/* =========================================================
   GALLERY
   ========================================================= */
.gallery { background: var(--bg); }
.gallery__grid {
  margin-top: clamp(2.6rem, 6vw, 4rem);
  columns: 3; column-gap: 14px;
}
.gallery__grid figure { break-inside: avoid; margin-bottom: 14px; overflow: hidden; position: relative; }
.gallery__grid img { width: 100%; transition: transform 1.1s var(--ease), filter 0.6s var(--ease); filter: saturate(0.96); }
.gallery__grid figure:hover img { transform: scale(1.06); filter: saturate(1.06); }
.gallery__grid figure::after {
  content:""; position:absolute; inset:0;
  background: linear-gradient(transparent 55%, rgba(35,41,31,0.28));
  opacity: 0; transition: opacity 0.5s var(--ease);
}
.gallery__grid figure:hover::after { opacity: 1; }

/* =========================================================
   TRAVEL / STAY
   ========================================================= */
.travel { background: var(--bg-deep); }
.travel__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.4rem, 4vw, 2.6rem); margin-top: clamp(2.6rem,6vw,4rem); }
.tcard { text-align: left; }
.tcard__no { font-family: var(--serif); font-style: italic; font-size: 2.4rem; color: var(--gold); line-height: 1; }
.tcard h3 { font-size: 1.5rem; font-weight: 400; margin: 0.7rem 0 0.6rem; }
.tcard p { color: var(--ink-soft); font-size: 1.08rem; }
.travel__note {
  margin-top: clamp(2.6rem,6vw,4rem); text-align: center;
  border: 1px solid var(--line); padding: clamp(1.6rem,4vw,2.6rem);
  background: rgba(231, 221, 199, 0.04);
}
.travel__note .eyebrow { display:block; margin-bottom: 0.9rem; }
.travel__note p { color: var(--ink-soft); font-size: 1.15rem; max-width: 56ch; margin: 0 auto; }

/* =========================================================
   FAQ
   ========================================================= */
.faq { background: var(--bg); }
.faq__list { margin-top: clamp(2.4rem,5vw,3.4rem); border-top: 1px solid var(--line); }
.faq__item { border-bottom: 1px solid var(--line); }
.faq__q {
  width: 100%; background: none; border: none; cursor: pointer;
  display: flex; justify-content: space-between; align-items: center; gap: 1.4rem;
  padding: 1.6rem 0.4rem; text-align: left;
  font-family: var(--serif); font-size: clamp(1.2rem, 2.4vw, 1.55rem); color: var(--ink); font-weight: 400;
}
.faq__q .ico { flex: none; width: 26px; height: 26px; position: relative; transition: transform 0.45s var(--ease); }
.faq__q .ico::before, .faq__q .ico::after { content:""; position:absolute; background: var(--gold-deep); transition: opacity 0.4s var(--ease); }
.faq__q .ico::before { top: 50%; left: 0; right: 0; height: 1.5px; transform: translateY(-50%); }
.faq__q .ico::after  { left: 50%; top: 0; bottom: 0; width: 1.5px; transform: translateX(-50%); }
.faq__item.open .ico { transform: rotate(135deg); }
.faq__a { max-height: 0; overflow: hidden; transition: max-height 0.5s var(--ease); }
.faq__a p { padding: 0 0.4rem 1.7rem; color: var(--ink-soft); font-size: 1.12rem; max-width: 60ch; }

/* =========================================================
   RSVP / CLOSING
   ========================================================= */
.closing {
  position: relative; text-align: center; color: var(--cream);
  padding: clamp(6rem, 14vw, 12rem) 1.4rem;
  overflow: hidden;
}
.closing__img { position:absolute; inset:0; background: url("assets/photos/photo6.jpg") center 28% / cover; will-change: transform; }
.closing__img::after { content:""; position:absolute; inset:0; background: linear-gradient(rgba(20,24,16,0.55), rgba(20,24,16,0.7)); }
.closing__inner { position: relative; z-index: 2; }
.closing .section-title { color: var(--cream); }
.closing p { margin: 1.6rem auto 0; max-width: 46ch; font-size: clamp(1.1rem,2vw,1.3rem); color: rgba(250,245,236,0.9); }
.btn-fill {
  display: inline-block; margin-top: 2.4rem;
  font-family: var(--sans); font-size: 0.78rem; letter-spacing: 0.26em; text-transform: uppercase;
  background: var(--gold); color: var(--forest);
  padding: 1.15rem 2.6rem; border-radius: 100px;
  transition: all 0.4s var(--ease); border: 1px solid var(--gold);
}
.btn-fill:hover { background: transparent; color: var(--cream); border-color: var(--cream); }
.closing__handle { margin-top: 2rem; font-family: var(--sans); font-size: 0.74rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--sage); }

/* ---------- Footer ---------- */
.footer { background: var(--forest); color: var(--sage); text-align: center; padding: 3rem 1.4rem; }
.footer .mono { font-family: var(--serif); font-size: 1.8rem; color: var(--cream); letter-spacing: 0.2em; }
.footer .meta { font-family: var(--sans); font-size: 0.7rem; letter-spacing: 0.28em; text-transform: uppercase; margin-top: 1rem; }

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
.reveal { opacity: 0; transform: translateY(34px); transition: opacity 1s var(--ease), transform 1s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
.reveal[data-d="1"]{ transition-delay: 0.1s } .reveal[data-d="2"]{ transition-delay: 0.2s }
.reveal[data-d="3"]{ transition-delay: 0.3s } .reveal[data-d="4"]{ transition-delay: 0.4s }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 860px) {
  .nav__links { gap: 1rem; }
  .nav__links a:not(.cta) { display: none; }
  .cards { grid-template-columns: 1fr; }
  .gallery__grid { columns: 2; }
  .travel__grid { grid-template-columns: 1fr; gap: 2.4rem; text-align: center; }
  .tcard { text-align: center; }
}
@media (max-width: 520px) {
  .countdown__grid { gap: 1.1rem; }
  .cd-unit { min-width: 0; }
  .hero__meta { gap: 0.7rem; }
  .gallery__grid { columns: 1; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
  .reveal { opacity: 1; transform: none; }
}

/* =========================================================
   ADD-TO-CALENDAR + CARD INTRO
   ========================================================= */
.card__intro { color: rgba(250,245,236,.82); font-size: 1.1rem; margin-bottom: 1.4rem; }
.card__cal { margin-top: 1.8rem; }
.card__cal[hidden] { display: none; }

/* =========================================================
   STAY / ACCOMMODATION
   ========================================================= */
.stay { background: var(--bg); }
.stay__lead { max-width: 60ch; margin: 1.8rem auto 0; color: var(--ink-soft); font-size: clamp(1.05rem,2vw,1.25rem); }
.stay__grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2.4vw, 1.6rem); margin-top: clamp(2.6rem,6vw,4rem);
}
.hotel {
  background: rgba(231, 221, 199, 0.045); border: 1px solid var(--line);
  padding: clamp(1.6rem, 2.6vw, 2.2rem); display: flex; flex-direction: column;
  position: relative; transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease), background 0.5s var(--ease);
}
.hotel:hover { transform: translateY(-5px); background: rgba(231, 221, 199, 0.08); box-shadow: 0 26px 50px -28px rgba(0,0,0,.6); }
.hotel__rank {
  align-self: flex-start; font-family: var(--sans); font-size: 0.6rem;
  letter-spacing: 0.24em; text-transform: uppercase; color: var(--sage);
  border: 1px solid var(--line); border-radius: 100px; padding: 0.35rem 0.8rem; margin-bottom: 1.3rem;
}
.hotel__rank--gold { color: var(--gold-deep); border-color: rgba(173,138,82,.5); }
.hotel__name { font-size: clamp(1.35rem, 2.4vw, 1.7rem); font-weight: 400; line-height: 1.12; }
.hotel__loc { font-family: var(--sans); font-size: 0.74rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold-deep); margin: 0.7rem 0 1rem; }
.hotel__desc { color: var(--ink-soft); font-size: 1.04rem; flex: 1; }
.hotel__tag { margin-top: 1.3rem; font-family: var(--sans); font-size: 0.68rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--sage); }
.hotel__link {
  margin-top: 1.4rem; align-self: flex-start; font-family: var(--sans);
  font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold-deep);
  border-bottom: 1px solid rgba(173,138,82,.4); padding-bottom: 2px; transition: color 0.3s var(--ease), border-color 0.3s var(--ease);
}
.hotel__link:hover { color: var(--forest); border-color: var(--forest); }
.stay__note { text-align: center; margin-top: clamp(2.6rem,6vw,3.6rem); }
.stay__note p { color: var(--ink-soft); font-size: 1.1rem; max-width: 58ch; margin: 0 auto; font-style: italic; }

/* =========================================================
   RSVP FORM
   ========================================================= */
.rsvp { background: var(--bg-deep); }
.rsvp__lead { max-width: 50ch; margin: 1.6rem auto 0; color: var(--ink-soft); font-size: clamp(1.05rem,2vw,1.25rem); }
.rsvp__lead strong { color: var(--gold-deep); font-weight: 500; }
.rsvp__form {
  max-width: 720px; margin: clamp(2.6rem,6vw,3.6rem) auto 0;
  display: grid; grid-template-columns: 1fr 1fr; gap: 1.4rem 1.6rem;
}
.field { display: flex; flex-direction: column; gap: 0.55rem; text-align: left; }
.field[hidden] { display: none; }
.field--full { grid-column: 1 / -1; }
.field label {
  font-family: var(--sans); font-size: 0.7rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-soft);
}
.field label .opt { text-transform: none; letter-spacing: 0; color: var(--sage); font-size: 0.92em; }
.field input, .field select, .field textarea {
  font-family: var(--serif); font-size: 1.1rem; color: var(--ink);
  background: rgba(0, 0, 0, 0.22); border: 1px solid var(--line); border-radius: 2px;
  padding: 0.85rem 0.95rem; width: 100%; transition: border-color 0.3s var(--ease), box-shadow 0.3s var(--ease);
}
.field input::placeholder, .field textarea::placeholder { color: rgba(180, 171, 146, 0.55); }
.field select option { background: #19221b; color: var(--ink); }
.field textarea { resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none; border-color: var(--gold); box-shadow: 0 0 0 3px rgba(173,138,82,.14);
}
.field select { appearance: none; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238a6c3c' stroke-width='1.4' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 1rem center; padding-right: 2.4rem;
}
.rsvp__submit { text-align: center; margin-top: 0.6rem; }
.btn-fill {
  display: inline-block; font-family: var(--sans); font-size: 0.78rem;
  letter-spacing: 0.26em; text-transform: uppercase; background: var(--gold); color: var(--forest);
  padding: 1.15rem 2.6rem; border-radius: 100px; border: 1px solid var(--gold); cursor: pointer;
  transition: all 0.4s var(--ease);
}
.btn-fill:hover { background: var(--forest); color: var(--cream); border-color: var(--forest); }
.btn-fill:disabled { opacity: 0.55; cursor: progress; }
.form__status { margin-top: 1.2rem; font-size: 1.05rem; min-height: 1.4em; }
.form__status.ok { color: var(--gold-deep); font-style: italic; font-size: 1.25rem; }
.form__status.err { color: #d98b7d; }
.rsvp__handle {
  text-align: center; margin-top: 2.6rem; font-family: var(--sans);
  font-size: 0.74rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--sage);
}
.rsvp__handle em { font-family: var(--serif); text-transform: none; letter-spacing: 0.04em; font-size: 1.1rem; color: var(--gold-deep); }

@media (max-width: 720px) {
  .stay__grid { grid-template-columns: 1fr; }
  .rsvp__form { grid-template-columns: 1fr; }
}
