/* ───────────────────────── tokens ───────────────────────── */
:root{
  /* Default: G&E palette — blush cream + deep rust + copper + olive */
  --bg:        #f3ebdf;   /* soft paper cream */
  --bg-2:      #e8d9c6;   /* blush card */
  --bg-3:      #d9c4ad;   /* deeper blush */
  --ink:       #3a1f12;   /* deep rust-brown text */
  --ink-soft:  #6a4434;   /* secondary text */
  --ink-mute:  rgba(58,31,18,.58);
  --rule:      rgba(58,31,18,.18);
  --accent:    #a96a52;   /* terracotta copper */
  --accent-2:  #6c6b3f;   /* olive green */
  --gold:      #a96a52;
  --paper:     #fbf4e8;

  --display: "Cormorant Garamond", "EB Garamond", Georgia, serif;
  --body:    "Outfit", "Karla", ui-sans-serif, system-ui, sans-serif;
  --script:  "Pinyon Script", "Cormorant Garamond", cursive;
  --mono:    "JetBrains Mono", ui-monospace, monospace;

  --maxw: 1180px;
  --maxw-narrow: 760px;
  --gutter: clamp(20px, 4vw, 56px);
}

/* palette swaps — all rooted in the G&E moodboard */

/* Olive-forward: same palette, olive promoted to primary accent */
body[data-palette="olive"]{
  --bg:#f1ece0; --bg-2:#e3dcc5; --bg-3:#d2c9ab;
  --ink:#2e2e1c; --ink-soft:#4d4d2e; --ink-mute:rgba(46,46,28,.58);
  --rule:rgba(46,46,28,.18);
  --accent:#6c6b3f; --accent-2:#a96a52; --gold:#a96a52; --paper:#f7f3e6;
}
/* Deep rust: dark mood, low-light reception feel */
body[data-palette="deep"]{
  --bg:#ece0d0; --bg-2:#dcc9b3; --bg-3:#c5ad94;
  --ink:#2a140a; --ink-soft:#5e2e1c; --ink-mute:rgba(42,20,10,.58);
  --rule:rgba(42,20,10,.18);
  --accent:#5e2e1c; --accent-2:#a96a52; --gold:#a96a52; --paper:#f6ebd9;
}
/* Blush-forward: lightest, softest version */
body[data-palette="blush"]{
  --bg:#f7eee0; --bg-2:#ecd9c0; --bg-3:#dcc1a3;
  --ink:#3a1f12; --ink-soft:#7a503d; --ink-mute:rgba(58,31,18,.55);
  --rule:rgba(58,31,18,.16);
  --accent:#b67e63; --accent-2:#6c6b3f; --gold:#b67e63; --paper:#fbf3e5;
}

/* font swaps */
body[data-fonts="cormorant"]{ --display:"Cormorant Garamond", Georgia, serif; --body:"Outfit", ui-sans-serif, system-ui, sans-serif; }
body[data-fonts="garamond"] { --display:"EB Garamond", Georgia, serif;          --body:"Karla", ui-sans-serif, system-ui, sans-serif; }
body[data-fonts="dmserif"]  { --display:"DM Serif Display", Georgia, serif;     --body:"DM Sans", ui-sans-serif, system-ui, sans-serif; }

/* ───────────────────────── base ───────────────────────── */
*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
/* hidden attribute must beat our flex/grid display rules */
[hidden]{ display:none !important; }
html{ scroll-behavior:smooth; }
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--body);
  font-weight:400;
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  background-image:
    radial-gradient(1200px 600px at 80% -10%, rgba(108,107,63,.08), transparent 60%),
    radial-gradient(900px 500px at -10% 100%, rgba(169,106,82,.10), transparent 60%);
  background-attachment:fixed;
}
img{ max-width:100%; display:block; }
a{ color:inherit; }

::selection{ background:var(--accent); color:var(--paper); }

/* paper texture: very subtle noise from layered conic + linear */
body::before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none;
  background:
    repeating-linear-gradient(0deg, rgba(42,34,26,.012) 0 1px, transparent 1px 3px),
    repeating-linear-gradient(90deg, rgba(42,34,26,.012) 0 1px, transparent 1px 3px);
  mix-blend-mode:multiply;
  z-index:0;
}

/* ───────────────────────── nav ───────────────────────── */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px clamp(16px, 4vw, 40px);
  background:linear-gradient(to bottom, color-mix(in oklab, var(--bg) 92%, transparent), color-mix(in oklab, var(--bg) 60%, transparent) 70%, transparent);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.nav-mark{
  font-family:var(--display);
  font-weight:500;
  font-size:20px;
  letter-spacing:.08em;
  text-decoration:none;
  color:var(--ink);
}
.nav-mark .amp{ font-style:italic; color:var(--accent); }
.nav-links{ display:flex; gap:clamp(10px, 2vw, 28px); align-items:center; }
.nav-links a{
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
  text-decoration:none;
  color:var(--ink-soft);
  padding:6px 2px;
  border-bottom:1px solid transparent;
  transition:color .2s, border-color .2s;
}
.nav-links a:hover{ color:var(--ink); border-bottom-color:var(--accent); }
.nav-cta{
  background:var(--ink);
  color:var(--paper) !important;
  padding:8px 16px !important;
  border-radius:999px;
  border:none !important;
}
.nav-cta:hover{ background:var(--accent); border:none !important; }

@media (max-width: 640px){
  .nav-links{ gap:10px; }
  .nav-links a:not(.nav-cta){ display:none; }
}

/* ───────────────────────── hero (default: centered) ───────────────────────── */
.hero{
  position:relative;
  min-height:100vh;
  padding:140px var(--gutter) 140px;
  display:grid;
  place-items:center;
  text-align:center;
  overflow:hidden;
}
.hero-photo{ display:none; }
.hero-inner{
  position:relative; z-index:2;
  max-width:780px;
  width:100%;
}
.hero-eyebrow{
  display:flex; align-items:center; justify-content:center; gap:14px;
  font-size:13px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-mute);
  margin-bottom:28px;
}
.hero-eyebrow span:first-child,.hero-eyebrow span:last-child{
  display:inline-block; width:28px; height:1px; background:var(--ink-mute); text-indent:-9999px; overflow:hidden;
}
.hero-names{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(56px, 11vw, 148px);
  line-height:.95;
  letter-spacing:-.01em;
  margin:0;
  display:flex; flex-direction:column; gap:0;
}
.hero-name{ display:block; }
.hero-amp{
  font-family:var(--script);
  font-size:.7em;
  color:var(--accent);
  line-height:.7;
  margin:.05em 0;
  font-weight:400;
}
.hero-meta{
  margin-top:30px;
  font-size:14px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-soft);
  display:flex; flex-wrap:wrap; justify-content:center; align-items:center;
  gap:14px;
}
.hero-meta .dot{
  width:5px; height:5px; border-radius:50%; background:var(--accent); display:inline-block;
  transform:rotate(45deg);
}
.hero-verse{
  font-family:var(--display);
  font-style:italic;
  font-size:clamp(17px, 2vw, 21px);
  line-height:1.55;
  color:var(--ink-soft);
  max-width:560px;
  margin:32px auto 0;
}
.hero-verse .hero-cite{
  display:block;
  margin-top:8px;
  font-style:normal;
  font-family:var(--body);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-mute);
}
.hero-countdown{
  margin:44px auto 0;
  display:flex; flex-wrap:wrap; justify-content:center; gap:0;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  padding:18px 0;
  max-width:560px;
}
.cd-unit{
  flex:1 1 80px;
  display:flex; flex-direction:column; align-items:center;
  position:relative;
}
.cd-unit + .cd-unit::before{
  content:""; position:absolute; left:0; top:18%; bottom:18%; width:1px; background:var(--rule);
}
.cd-num{
  font-family:var(--display);
  font-size:clamp(32px, 4vw, 44px);
  line-height:1;
  font-variant-numeric:tabular-nums;
  color:var(--ink);
}
.cd-lbl{
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-mute);
  margin-top:6px;
}
.hero-ctas{
  margin-top:36px;
  display:flex; justify-content:center; gap:12px; flex-wrap:wrap;
}

.scroll-hint{
  position:absolute; bottom:32px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--ink-mute);
}
@media (max-height: 820px){
  .scroll-hint{ display:none; }
}
.scroll-hint .scroll-line{
  width:1px; height:36px; background:linear-gradient(to bottom, var(--ink-mute), transparent);
  animation: scrollPulse 2.4s ease-in-out infinite;
}
@keyframes scrollPulse{
  0%,100%{ transform:scaleY(.5); transform-origin:top; opacity:.6; }
  50%{ transform:scaleY(1); transform-origin:top; opacity:1; }
}

/* hero variants */
body[data-hero="split"] .hero{
  grid-template-columns: 1fr 1fr;
  text-align:left;
  place-items:center;
  gap:clamp(24px, 4vw, 64px);
  padding-top:120px;
}
body[data-hero="split"] .hero-photo{
  display:block;
  width:100%; aspect-ratio: 3/4; max-height:80vh;
}
body[data-hero="split"] .hero-inner{ max-width:560px; }
body[data-hero="split"] .hero-eyebrow{ justify-content:flex-start; }
body[data-hero="split"] .hero-eyebrow span:first-child{ display:none; }
body[data-hero="split"] .hero-names{ font-size:clamp(48px, 8vw, 110px); }
body[data-hero="split"] .hero-meta{ justify-content:flex-start; }
body[data-hero="split"] .hero-verse{ margin-left:0; }
body[data-hero="split"] .hero-countdown{ margin-left:0; }
body[data-hero="split"] .hero-ctas{ justify-content:flex-start; }
body[data-hero="split"] .scroll-hint{ display:none; }
@media (max-width: 880px){
  body[data-hero="split"] .hero{ grid-template-columns:1fr; text-align:center; }
  body[data-hero="split"] .hero-eyebrow,
  body[data-hero="split"] .hero-meta,
  body[data-hero="split"] .hero-ctas{ justify-content:center; }
  body[data-hero="split"] .hero-eyebrow span:first-child{ display:inline-block; }
  body[data-hero="split"] .hero-photo{ aspect-ratio: 4/3; max-height:50vh; }
}

body[data-hero="fullbleed"] .hero{ padding-top:160px; }
body[data-hero="fullbleed"] .hero-photo{
  display:block;
  position:absolute; inset:0;
  z-index:1;
}
body[data-hero="fullbleed"] .hero-photo .ph{
  width:100%; height:100%; border-radius:0;
}
body[data-hero="fullbleed"] .hero::after{
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(42,34,26,.55), rgba(42,34,26,.35) 40%, rgba(42,34,26,.7));
}
body[data-hero="fullbleed"] .hero-inner{
  color:#f6efe5;
}
body[data-hero="fullbleed"] .hero-names,
body[data-hero="fullbleed"] .cd-num{ color:#f6efe5; }
body[data-hero="fullbleed"] .hero-eyebrow,
body[data-hero="fullbleed"] .hero-meta,
body[data-hero="fullbleed"] .hero-verse,
body[data-hero="fullbleed"] .cd-lbl,
body[data-hero="fullbleed"] .hero-verse .hero-cite,
body[data-hero="fullbleed"] .scroll-hint{ color:rgba(246,239,229,.85); }
body[data-hero="fullbleed"] .hero-eyebrow span:first-child,
body[data-hero="fullbleed"] .hero-eyebrow span:last-child{ background:rgba(246,239,229,.6); }
body[data-hero="fullbleed"] .hero-amp{ color:#f6efe5; }
body[data-hero="fullbleed"] .hero-countdown{ border-color:rgba(246,239,229,.35); }
body[data-hero="fullbleed"] .cd-unit + .cd-unit::before{ background:rgba(246,239,229,.35); }
body[data-hero="fullbleed"] .btn-ghost{ color:#f6efe5; border-color:rgba(246,239,229,.6); }
body[data-hero="fullbleed"] .btn-ghost:hover{ background:rgba(246,239,229,.15); }

/* ───────────────────────── buttons ───────────────────────── */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:14px 26px;
  border-radius:999px;
  font-family:var(--body);
  font-size:14px;
  letter-spacing:.14em;
  text-transform:uppercase;
  text-decoration:none;
  cursor:pointer;
  border:1px solid transparent;
  transition:transform .15s ease, background .2s, color .2s, border-color .2s;
}
.btn-lg{ padding:18px 36px; font-size:14px; }
.btn:active{ transform:translateY(1px); }
.btn-primary{
  background:var(--ink); color:var(--paper); border-color:var(--ink);
}
.btn-primary:hover{ background:var(--accent); border-color:var(--accent); }
.btn-ghost{
  background:transparent; color:var(--ink); border-color:var(--ink);
}
.btn-ghost:hover{ background:var(--ink); color:var(--paper); }

/* ───────────────────────── sections + rules ───────────────────────── */
.section{
  position:relative;
  padding:clamp(80px, 10vw, 140px) var(--gutter);
  max-width:var(--maxw);
  margin:0 auto;
}
.section-head{
  text-align:center;
  margin-bottom:60px;
}
.kicker{
  display:inline-block;
  font-size:12px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--ink-mute);
  margin-bottom:14px;
}
.section-title{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(36px, 5.5vw, 64px);
  line-height:1.05;
  margin:0;
  letter-spacing:-.005em;
}
.section-sub{
  font-family:var(--display);
  font-style:italic;
  font-size:clamp(16px, 1.5vw, 19px);
  color:var(--ink-soft);
  margin:18px auto 0;
  max-width:580px;
}

/* section divider — motif-driven */
.section-rule{
  display:flex; justify-content:center; margin-bottom:60px;
}
.rule-deco{
  display:flex; align-items:center; gap:14px;
  width:100%; max-width:280px;
  color:var(--accent);
}
.rule-deco::before, .rule-deco::after{
  content:""; flex:1; height:1px; background:currentColor; opacity:.45;
}
/* motif: dots (default) */
body[data-motif="dots"] .rule-deco{ position:relative; }
body[data-motif="dots"] .rule-deco{
  background:none;
}
body[data-motif="dots"] .rule-deco::before,
body[data-motif="dots"] .rule-deco::after{
  background:currentColor; opacity:.4;
}
body[data-motif="dots"] .rule-deco{
}
.rule-deco span{
  width:5px; height:5px; background:currentColor; border-radius:50%; display:inline-block;
}
.rule-deco i{
  width:8px; height:8px; background:currentColor; display:inline-block;
  transform:rotate(45deg);
}

/* motif: sprig */
body[data-motif="sprig"] .rule-deco::before,
body[data-motif="sprig"] .rule-deco::after{ opacity:.35; }

/* motif: mono — monogram circle */
body[data-motif="mono"] .rule-deco{
  background:none;
}

/* motif: none — clean thin rule */
body[data-motif="none"] .rule-deco{ max-width:80px; }
body[data-motif="none"] .rule-deco::before,
body[data-motif="none"] .rule-deco::after{ opacity:.25; }

/* ───────────────────────── story ───────────────────────── */
.story-grid{
  display:grid;
  grid-template-columns: 5fr 6fr;
  gap:clamp(28px, 5vw, 72px);
  align-items:center;
  max-width:var(--maxw-narrow);
  margin:0 auto;
  max-width:1000px;
}
.story-photo{ aspect-ratio: 3/4; }
.story-photo .ph{ width:100%; height:100%; }
.story-text p{ margin:0 0 18px; font-size:17px; line-height:1.75; color:var(--ink-soft); }
.story-lede{
  font-family:var(--display);
  font-style:italic;
  font-size:clamp(20px, 2vw, 26px) !important;
  line-height:1.45 !important;
  color:var(--ink) !important;
  margin-bottom:24px !important;
}
.story-sign{
  margin-top:32px !important;
  display:flex; flex-direction:column; gap:6px;
  font-size:14px !important;
  color:var(--ink-mute) !important;
  letter-spacing:.04em;
}
.story-sig{
  font-family:var(--script);
  font-size:34px;
  color:var(--accent);
  line-height:1;
}
@media (max-width: 760px){
  .story-grid{ grid-template-columns:1fr; }
}

/* ───────────────────────── schedule ───────────────────────── */
.schedule{
  list-style:none; padding:0; margin:0;
  max-width:680px;
  margin-left:auto; margin-right:auto;
  display:flex; flex-direction:column;
}
.sch-item{
  display:grid;
  grid-template-columns: 140px 1fr;
  gap:36px;
  padding:28px 0;
  border-top:1px solid var(--rule);
  position:relative;
}
.sch-item:last-child{ border-bottom:1px solid var(--rule); }
.sch-time{
  font-family:var(--display);
  font-size:34px;
  line-height:1;
  color:var(--ink);
  font-variant-numeric:tabular-nums;
  padding-top:2px;
}
.sch-ampm{ font-size:16px; color:var(--ink-mute); margin-left:2px; vertical-align:baseline; }
.sch-body h3{
  font-family:var(--display);
  font-weight:500;
  font-size:24px;
  margin:0 0 6px;
  letter-spacing:-.005em;
}
.sch-body p{ margin:0; color:var(--ink-soft); font-size:16px; line-height:1.6; }
.sch-item--feature{
  background:linear-gradient(to right, transparent, var(--bg-2) 20%, var(--bg-2) 80%, transparent);
  border-radius:4px;
  padding-left:24px;
  padding-right:24px;
  margin:0 -24px;
}
.sch-item--feature .sch-time{ color:var(--accent); }
.sch-item--feature .sch-body h3{ color:var(--accent); }

@media (max-width: 640px){
  .sch-item{ grid-template-columns:1fr; gap:8px; padding:22px 0; }
  .sch-time{ font-size:24px; }
  .sch-ampm{ font-size:14px; }
  .sch-item--feature{ margin:0; padding:22px 16px; }
}

/* ───────────────────────── venue ───────────────────────── */
.section-venue{ }
.venue-grid{
  display:grid;
  grid-template-columns: 7fr 5fr;
  gap:clamp(28px, 5vw, 72px);
  align-items:start;
}
.venue-photo{ aspect-ratio: 4/5; }
.venue-photo .ph{ width:100%; height:100%; }
.venue-info{ display:flex; flex-direction:column; gap:28px; }
.venue-block{ display:flex; flex-direction:column; gap:6px; }
.venue-label{
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:500;
}
.venue-addr{
  font-family:var(--display);
  font-size:24px;
  line-height:1.3;
  margin:0;
  color:var(--ink);
}
.venue-block p{ margin:0; color:var(--ink-soft); font-size:16px; line-height:1.65; }
.lnk{
  display:inline-block;
  margin-top:6px;
  font-size:13px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--accent);
  text-decoration:none;
  border-bottom:1px solid currentColor;
  padding-bottom:2px;
  align-self:flex-start;
}
.lnk:hover{ color:var(--ink); }
@media (max-width: 760px){
  .venue-grid{ grid-template-columns:1fr; }
  .venue-photo{ aspect-ratio:4/3; }
}

/* ───────────────────────── gallery ───────────────────────── */
/* Portrait-friendly: every tile is a 3:4 frame so vertical photos show
   in full without cropping the heads/feet. One feature tile spans 2 cols. */
.gallery{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:18px;
}
.gallery .ph{
  width:100%;
  aspect-ratio: 3/4;
}
.ph--g1{ grid-column: span 2; grid-row: span 2; aspect-ratio: 1/1; }
.ph--g2,.ph--g3,.ph--g4,.ph--g5,.ph--g6{ aspect-ratio: 3/4; }
@media (max-width: 760px){
  .gallery{ grid-template-columns: repeat(2, 1fr); gap:12px; }
  .ph--g1{ grid-column: span 2; grid-row: span 1; aspect-ratio: 4/3; }
}

/* ───────────────────────── registry ───────────────────────── */
.registry-card{
  max-width:560px;
  margin:0 auto;
  padding:clamp(36px, 5vw, 60px);
  background:var(--paper);
  border:1px solid var(--rule);
  border-radius:6px;
  text-align:center;
  position:relative;
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset, 0 30px 60px -30px rgba(42,34,26,.18);
}
.reg-mark{
  font-family:var(--display);
  font-size:60px;
  line-height:1;
  color:var(--ink);
  margin-bottom:20px;
  display:flex; justify-content:center; align-items:baseline; gap:6px;
}
.reg-amp{ font-family:var(--script); color:var(--accent); font-size:.65em; }
.reg-text{ font-family:var(--display); font-style:italic; font-size:20px; color:var(--ink-soft); margin:0 0 28px; }
.reg-note{ font-size:13px; color:var(--ink-mute); margin:24px 0 0; letter-spacing:.04em; }

/* ───────────────────────── RSVP ───────────────────────── */
.rsvp{
  max-width:580px;
  margin:0 auto;
  display:flex; flex-direction:column; gap:28px;
  position:relative;
}
.field{ display:flex; flex-direction:column; gap:10px; }
.field > label{
  font-size:13px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--ink-soft);
  font-weight:500;
}
.field .opt{ text-transform:none; letter-spacing:.02em; color:var(--ink-mute); font-weight:400; }
.field input[type="text"],
.field input[type="number"],
.field textarea{
  width:100%;
  font:inherit;
  font-size:17px;
  padding:14px 16px;
  background:var(--paper);
  border:1px solid var(--rule);
  border-radius:4px;
  color:var(--ink);
  transition:border-color .2s, background .2s;
}
.field input:focus,.field textarea:focus{
  outline:none;
  border-color:var(--accent);
  background:#fff;
}
.field textarea{ resize:vertical; min-height:90px; }
.hint{
  font-size:13px; color:var(--ink-mute); margin:0; line-height:1.5;
}

/* radio cards */
.choice{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.choice input[type="radio"]{ position:absolute; opacity:0; pointer-events:none; }
.choice-card{
  cursor:pointer;
  border:1px solid var(--rule);
  border-radius:6px;
  padding:18px 18px;
  background:var(--paper);
  text-align:center;
  transition:border-color .2s, background .2s, transform .15s;
  display:flex; flex-direction:column; gap:4px;
}
.choice-card:hover{ border-color:var(--ink-soft); }
.choice-card .choice-title{
  font-family:var(--display);
  font-size:22px;
  color:var(--ink);
  font-weight:500;
}
.choice-card .choice-sub{
  font-size:13px; color:var(--ink-mute);
  letter-spacing:.04em;
}
.choice input[type="radio"]:checked + .choice-card{
  border-color:var(--accent);
  background:#fff;
  box-shadow:0 0 0 1px var(--accent) inset;
}
.choice input[type="radio"]:checked + .choice-card .choice-title{
  color:var(--accent);
}
@media (max-width:520px){
  .choice{ grid-template-columns:1fr; }
}

/* stepper */
.stepper{
  display:flex; align-items:center; gap:0;
  width:fit-content;
  border:1px solid var(--rule);
  border-radius:999px;
  background:var(--paper);
  overflow:hidden;
}
.stepper .step{
  appearance:none;
  border:none;
  background:transparent;
  width:48px; height:48px;
  font:inherit;
  font-size:22px;
  color:var(--ink);
  cursor:pointer;
  transition:background .2s, color .2s;
}
.stepper .step:hover{ background:var(--bg-2); color:var(--accent); }
.stepper input{
  width:64px; height:48px;
  border:none !important;
  background:transparent !important;
  text-align:center;
  font-family:var(--display);
  font-size:22px;
  color:var(--ink);
  padding:0 !important;
  -moz-appearance:textfield;
}
.stepper input::-webkit-outer-spin-button,
.stepper input::-webkit-inner-spin-button{ -webkit-appearance:none; margin:0; }

/* "show only if attending=yes" */
.rsvp[data-attending="no"] .field[data-when="yes"]{ display:none; }
.rsvp[data-attending=""] .field[data-when="yes"]{ display:none; }

/* additional guest name inputs */
.guest-list{
  display:flex; flex-direction:column; gap:10px;
}
.guest-list .gl-row{
  display:flex; align-items:center; gap:12px;
}
.guest-list .gl-num{
  flex:0 0 auto;
  width:28px; height:28px;
  border-radius:50%;
  background:var(--accent);
  color:var(--paper);
  display:grid; place-items:center;
  font-family:var(--display);
  font-size:14px;
  font-variant-numeric:tabular-nums;
}
.guest-list input{
  flex:1 1 auto;
  font:inherit;
  font-size:17px;
  padding:14px 16px;
  background:var(--paper);
  border:1px solid var(--rule);
  border-radius:4px;
  color:var(--ink);
  transition:border-color .2s, background .2s;
}
.guest-list input:focus{
  outline:none;
  border-color:var(--accent);
  background:#fff;
}

.rsvp-actions{
  display:flex; flex-direction:column; align-items:center; gap:18px;
  margin-top:8px;
}
.rsvp-help{
  font-size:14px; color:var(--ink-mute); text-align:center; line-height:1.6; margin:0;
}
.br-sm{ display:none; }
@media (max-width: 520px){ .br-sm{ display:inline; } }

.rsvp-confirm{
  background:var(--paper);
  border:1px solid var(--rule);
  border-radius:6px;
  padding:48px 32px;
  text-align:center;
  display:flex; flex-direction:column; align-items:center; gap:14px;
}
.confirm-mark{
  display:grid; place-items:center;
  width:56px; height:56px; border-radius:50%;
  background:var(--accent); color:var(--paper);
  font-size:26px; line-height:1;
  margin-bottom:6px;
}
.rsvp-confirm h3{
  font-family:var(--display); font-weight:500;
  font-size:32px; margin:0;
}
.rsvp-confirm p{ margin:0; color:var(--ink-soft); font-size:16px; max-width:380px; }
#rsvp-edit{ background:transparent; border:none; cursor:pointer; padding:0; }

/* ───────────────────────── footer ───────────────────────── */
.foot{
  text-align:center;
  padding:80px var(--gutter) 60px;
  border-top:1px solid var(--rule);
  background:var(--bg-2);
}
.foot-mono{
  font-family:var(--display);
  font-size:42px;
  line-height:1;
  margin-bottom:16px;
  display:flex; justify-content:center; align-items:baseline; gap:10px;
}
.foot-amp{ font-family:var(--script); color:var(--accent); font-size:.7em; }
.foot-date{
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-mute);
  margin:0 0 18px;
}
.foot-verse{
  font-family:var(--display);
  font-style:italic;
  font-size:17px;
  color:var(--ink-soft);
  max-width:480px; margin:0 auto;
}

/* ───────────────────────── placeholder cards ───────────────────────── */
.ph{
  position:relative;
  overflow:hidden;
  background:
    repeating-linear-gradient(135deg, rgba(58,31,18,.08) 0 8px, rgba(58,31,18,.02) 8px 16px),
    linear-gradient(135deg, var(--bg-3), var(--bg-2));
  border:1px solid var(--rule);
  border-radius:4px;
  display:grid; place-items:center;
  color:var(--ink-mute);
}
.ph > img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  display:block;
}
/* when an image loads, hide the placeholder label behind it */
.ph:has(img:not([style*="display: none"])) .ph-label{ display:none; }
.ph-label{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  background:rgba(251,246,236,.85);
  padding:6px 10px;
  border:1px solid var(--rule);
  border-radius:2px;
  color:var(--ink-soft);
}
.ph--hero{ aspect-ratio: 1/1; }
.ph--portrait{ aspect-ratio: 3/4; }
.ph--venue{ aspect-ratio: 4/5; }

/* ── wedding-color palette swatches ───────────────────── */
.palette-swatches{
  list-style:none; padding:0;
  margin:14px 0 8px;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:14px;
}
.palette-swatches li{
  display:flex; flex-direction:column; align-items:center;
  gap:8px;
  min-width:0;
  text-align:center;
}
.palette-swatches .swatch{
  width:100%;
  aspect-ratio:1/1;
  max-width:90px;
  border-radius:50%;
  position:relative;
  box-shadow:
    inset 0 0 0 4px var(--paper),
    inset 0 0 0 5px var(--rule),
    0 10px 24px -14px rgba(58,31,18,.55);
}
.palette-swatches .swatch-name{
  font-family:var(--display);
  font-size:16px;
  color:var(--ink);
  line-height:1.1;
}
.palette-swatches .swatch-hex{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.08em;
  color:var(--ink-mute);
}
.palette-note{
  font-family:var(--display);
  font-style:italic;
  font-size:15px !important;
  color:var(--ink-mute) !important;
  margin:14px 0 0 !important;
  line-height:1.55 !important;
}
@media (max-width: 420px){
  .palette-swatches{ gap:8px; }
  .palette-swatches .swatch-hex{ display:none; }
  .palette-swatches .swatch-name{ font-size:14px; }
}

/* gentle accent treatment for the adults-only note */
.venue-block--aside{
  background:var(--paper);
  border:1px solid var(--rule);
  border-left:3px solid var(--accent);
  padding:18px 22px;
  border-radius:4px;
}
.venue-block--aside .venue-label{ margin-bottom:6px; }
.venue-block--aside p{ font-family:var(--display); font-style:italic; font-size:17px; line-height:1.55; color:var(--ink); }

/* ───────────────────────── happily ever after shower ───────────────────────── */
.section-shower{ padding-top:0; }
.shower-card{
  max-width:640px;
  margin:0 auto;
  padding:clamp(40px, 5vw, 64px) clamp(28px, 4vw, 56px);
  background:var(--paper);
  border:1px solid var(--rule);
  border-radius:6px;
  text-align:center;
  position:relative;
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset, 0 30px 60px -30px rgba(42,34,26,.18);
}
.shower-card::before,
.shower-card::after{
  content:"";
  position:absolute; left:50%; transform:translateX(-50%);
  width:80px; height:1px; background:var(--accent); opacity:.5;
}
.shower-card::before{ top:24px; }
.shower-card::after{ bottom:24px; }
.shower-script{
  font-family:var(--script);
  font-size:clamp(44px, 6vw, 68px);
  line-height:1;
  color:var(--accent);
  margin:0 0 24px;
  font-weight:400;
}
.shower-lede{
  font-family:var(--display);
  font-size:clamp(20px, 2vw, 24px);
  line-height:1.5;
  color:var(--ink);
  margin:0 0 18px;
}
.shower-lede strong{ font-weight:500; color:var(--accent); }
.shower-note{
  font-size:16px;
  line-height:1.7;
  color:var(--ink-soft);
  margin:0;
  max-width:480px;
  margin-left:auto; margin-right:auto;
}
