/* ── Tabea & Roman — Hochzeit ─────────────────────────────── */
:root{
  /* warm cream palette (default) */
  --bg:        #faf3e8;
  --bg-soft:   #f3e9d6;
  --bg-deep:   #ead9bd;
  --ink:       #2a201a;
  --ink-soft:  #5a4a3d;
  --ink-mute:  #8a7867;
  --paper:     #fffaf0;
  --line:      #d9c8a8;
  --accent:    #b8654a;
  --accent-2:  #8a4a32;
  --accent-soft:#e7c4b3;
  --shadow:    0 14px 40px -16px rgba(80, 50, 30, .25);
  --shadow-sm: 0 4px 14px -6px rgba(80, 50, 30, .18);

  --img-filter: none;
}

[data-palette="sage"]{
  --bg:        #f1efe4;
  --bg-soft:   #e3e2d0;
  --bg-deep:   #cfcfb6;
  --ink:       #20281f;
  --ink-soft:  #455142;
  --ink-mute:  #7d8978;
  --paper:     #fbfaf2;
  --line:      #c2c4a7;
  --accent:    #5e7a55;
  --accent-2:  #3f5638;
  --accent-soft:#bdcdb1;
}

[data-palette="burgundy"]{
  --bg:        #f7ecea;
  --bg-soft:   #ecd6d2;
  --bg-deep:   #dcb9b3;
  --ink:       #2a1a1a;
  --ink-soft:  #5a3a3a;
  --ink-mute:  #8c6a67;
  --paper:     #fff7f4;
  --line:      #d6b3ab;
  --accent:    #8d2b35;
  --accent-2:  #621920;
  --accent-soft:#dba4a4;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:"DM Sans","Helvetica Neue",Helvetica,Arial,sans-serif;
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* ── Type system ──────────────────────────────────────────── */
.f-serif{ font-family:"Cormorant Garamond", "Georgia", serif; font-weight:500; }
.f-hand{ font-family:"Caveat","Bradley Hand", cursive; font-weight:500; }
.f-sans{ font-family:"DM Sans", sans-serif; }

h1,h2,h3,h4{ margin:0; font-family:"Cormorant Garamond","Georgia",serif; font-weight:500; color:var(--ink); }
h1{ font-size:clamp(56px, 9vw, 132px); line-height:.95; font-style:italic; letter-spacing:-.01em; }
h2{ font-size:clamp(36px, 4.6vw, 64px); line-height:1.02; font-style:italic; letter-spacing:-.005em; }
h3{ font-size:clamp(22px, 2.2vw, 30px); line-height:1.15; font-weight:500; }
h4{ font-size:18px; font-weight:600; font-family:"DM Sans",sans-serif; letter-spacing:.02em; }

p{ margin:0; text-wrap:pretty; }
a{ color:inherit; text-decoration:none; border-bottom:1px solid var(--accent); padding-bottom:1px; }
a:hover{ color:var(--accent); }

.eyebrow{
  font-family:"DM Sans",sans-serif;
  font-size:11px; font-weight:500;
  letter-spacing:.32em; text-transform:uppercase;
  color:var(--ink-mute);
}
.hand{
  font-family:"Caveat",cursive;
  color:var(--accent);
  font-size:1.4em;
  line-height:1;
}

/* ── Layout helpers ───────────────────────────────────────── */
.wrap{ max-width:1180px; margin:0 auto; padding:0 32px; }
.wrap-narrow{ max-width:780px; margin:0 auto; padding:0 32px; }
.section{ padding:140px 0; position:relative; }
.section--tight{ padding:88px 0; }
.section--bg{ background:var(--bg-soft); }
.section--deep{ background:var(--bg-deep); }

.rule{
  display:flex; align-items:center; gap:18px;
  color:var(--ink-mute); font-size:11px; letter-spacing:.3em; text-transform:uppercase;
}
.rule::before, .rule::after{
  content:""; flex:1; height:1px; background:var(--line);
}

/* ── Sticky nav ───────────────────────────────────────────── */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 32px;
  font-family:"DM Sans",sans-serif; font-size:12.5px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink); mix-blend-mode:multiply;
  transition: background .3s, color .3s, mix-blend-mode .3s;
}
.nav.solid{
  background:rgba(250,243,232,.82);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid rgba(0,0,0,.05);
  mix-blend-mode:normal;
}
.nav-monogram{ font-family:"Cormorant Garamond",serif; font-style:italic; font-size:22px; letter-spacing:0; text-transform:none; line-height:1; }
.nav-links{ display:flex; gap:28px; }
.nav-links a{ border:0; padding:0; color:inherit; opacity:.78; }
.nav-links a:hover{ opacity:1; color:var(--accent); }
@media(max-width:780px){ .nav-links{ display:none; } }

/* ── Hero ─────────────────────────────────────────────────── */
.hero{
  position:relative; min-height:100vh; padding:120px 32px 80px;
  display:grid; grid-template-columns: 1.05fr .95fr; gap:48px; align-items:center;
  max-width:1320px; margin:0 auto;
}
@media(max-width:900px){ .hero{ grid-template-columns: 1fr; padding-top:140px; } }

.hero-text{ position:relative; }
.hero-eyebrow{ margin-bottom:18px; display:flex; align-items:center; gap:12px; }
.hero-eyebrow .dot{ width:6px; height:6px; border-radius:99px; background:var(--accent); }

.hero-headline{
  font-family:"Caveat",cursive;
  color:var(--accent);
  font-size:clamp(48px, 6.4vw, 84px);
  line-height:.95;
  margin-bottom:-8px;
  margin-left:6px;
  transform:rotate(-2deg);
  display:inline-block;
}

.hero-names{
  font-family:"Cormorant Garamond",serif;
  font-style:italic; font-weight:500;
  font-size:clamp(72px, 11vw, 168px);
  line-height:.88; letter-spacing:-.015em;
  color:var(--ink);
}
.hero-amp{
  font-family:"Caveat",cursive; font-style:normal;
  color:var(--accent); font-size:.62em; font-weight:500;
  display:inline-block; vertical-align:.18em; margin:0 .04em;
}
.hero-meta{
  display:grid; grid-template-columns: auto 1px auto 1px auto; gap:18px;
  margin-top:42px; align-items:center;
}
.hero-meta .v{ width:1px; height:32px; background:var(--line); }
.hero-meta .lbl{ font-size:10.5px; letter-spacing:.28em; text-transform:uppercase; color:var(--ink-mute); margin-bottom:4px; }
.hero-meta .val{ font-family:"Cormorant Garamond",serif; font-style:italic; font-size:22px; line-height:1.1; }
@media(max-width:520px){
  .hero-meta{ grid-template-columns: 1fr; gap:14px; }
  .hero-meta .v{ display:none; }
}

.hero-scroll{
  margin-top:64px; display:inline-flex; align-items:center; gap:14px;
  font-size:11px; letter-spacing:.3em; text-transform:uppercase; color:var(--ink-mute);
}
.hero-scroll::after{
  content:""; width:60px; height:1px; background:var(--ink-mute);
  animation: scrollLine 2.4s ease-in-out infinite;
}
@keyframes scrollLine{
  0%,100%{ transform:scaleX(.4); transform-origin:left; }
  50%{ transform:scaleX(1); transform-origin:left; }
}

.hero-cta{
  margin-top:48px; display:flex; gap:14px; flex-wrap:wrap; align-items:center;
}
.btn-primary{
  display:inline-flex; align-items:center; justify-content:center;
  padding:16px 28px; background:var(--ink); color:var(--paper);
  border:0; border-bottom:0;
  font-family:"DM Sans",sans-serif; font-size:12px; letter-spacing:.3em; text-transform:uppercase;
  transition: background .2s, transform .15s;
}
.btn-primary:hover{ background:var(--accent); color:var(--paper); transform:translateY(-1px); }
.btn-ghost{
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 20px;
  border:0; border-bottom:0;
  font-family:"DM Sans",sans-serif; font-size:12px; letter-spacing:.3em; text-transform:uppercase;
  color:var(--ink-soft);
}
.btn-ghost:hover{ color:var(--accent); }
.btn-ghost svg{ animation: bounceDown 2s ease-in-out infinite; }
@keyframes bounceDown{
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(4px); }
}

/* Calendar dropdown */
.cal-wrap{ position:relative; margin-top:22px; display:inline-block; }
.cal-trigger{
  display:inline-flex; align-items:center; gap:10px;
  padding:11px 16px;
  background:transparent;
  border:1px solid var(--line); color:var(--ink-soft);
  font-family:"DM Sans",sans-serif; font-size:11.5px; letter-spacing:.22em; text-transform:uppercase;
  cursor:pointer; transition: all .2s;
}
.cal-trigger:hover{ border-color:var(--accent); color:var(--accent); }
.cal-menu{
  position:absolute; top:calc(100% + 6px); left:0; z-index:20;
  background:var(--paper); border:1px solid var(--line);
  min-width:240px;
  box-shadow: var(--shadow);
  display:flex; flex-direction:column;
}
.cal-menu a{
  padding:12px 18px; border:0;
  font-family:"DM Sans",sans-serif; font-size:14px;
  color:var(--ink); border-bottom:1px solid var(--line);
}
.cal-menu a:last-child{ border-bottom:0; }
.cal-menu a:hover{ background:var(--bg); color:var(--accent); }

/* Mobile sticky CTA */
.mobile-sticky{
  position:fixed; bottom:16px; left:16px; right:16px; z-index:60;
  display:none; align-items:center; justify-content:center; gap:10px;
  padding:16px 22px;
  background:var(--ink); color:var(--paper);
  border:0; border-bottom:0;
  font-family:"DM Sans",sans-serif; font-size:13px; letter-spacing:.3em; text-transform:uppercase;
  box-shadow: 0 10px 30px -8px rgba(0,0,0,.4);
  opacity:0; pointer-events:none; transform: translateY(80px);
  transition: opacity .3s, transform .3s;
}
.mobile-sticky.show{ opacity:1; pointer-events:auto; transform:none; }
.mobile-sticky:hover{ background:var(--accent); color:var(--paper); }
@media(max-width:780px){
  .mobile-sticky{ display:flex; }
}

.hero-photo{
  position:relative; aspect-ratio: 3/4;
  border-radius:2px; overflow:hidden;
  box-shadow: var(--shadow);
  transform:rotate(1.2deg);
}
.hero-photo img{ width:100%; height:100%; object-fit:cover; display:block; }
.hero-photo::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(42,32,26,.15));
  pointer-events:none;
}

.hero-stamp{
  position:absolute; right:-20px; top:-20px;
  width:140px; height:140px; border-radius:99px;
  border:1px solid var(--accent);
  display:grid; place-items:center; text-align:center;
  background:var(--paper);
  transform:rotate(-8deg);
  font-family:"Cormorant Garamond",serif; font-style:italic;
  box-shadow: var(--shadow-sm);
}
.hero-stamp .top{ font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:var(--ink-mute); font-style:normal; font-family:"DM Sans",sans-serif; }
.hero-stamp .big{ font-size:42px; line-height:1; color:var(--accent); margin:4px 0; }
.hero-stamp .bot{ font-size:13px; color:var(--ink-soft); }

.hero-scribble{
  position:absolute; left:-8px; top:-22px;
  font-family:"Caveat",cursive; color:var(--ink);
  font-size:32px; transform:rotate(-4deg);
  z-index:3; line-height:1;
  background:var(--paper);
  padding:8px 18px 6px;
  border:1px solid var(--line);
  box-shadow: var(--shadow-sm);
  white-space:nowrap;
}
.hero-scribble::before{
  content:""; position:absolute; left:50%; top:-8px;
  width:14px; height:14px; background:var(--accent);
  border-radius:99px; transform:translateX(-50%) rotate(8deg);
  box-shadow: 0 0 0 3px var(--paper);
}

/* ── Countdown ────────────────────────────────────────────── */
.cd{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:1px;
  background:var(--line); border:1px solid var(--line);
  margin-top:42px;
}
.cd-cell{
  background:var(--paper);
  padding:28px 12px; text-align:center;
}
.cd-num{
  font-family:"Cormorant Garamond",serif; font-style:italic;
  font-size:clamp(48px, 7vw, 86px); line-height:1; color:var(--ink);
  font-variant-numeric: tabular-nums;
}
.cd-lbl{
  margin-top:8px;
  font-size:10.5px; letter-spacing:.28em; text-transform:uppercase;
  color:var(--ink-mute);
}

/* ── Story ────────────────────────────────────────────────── */
.story{ position:relative; }
.story-quote{
  font-family:"Cormorant Garamond",serif; font-style:italic;
  font-size:clamp(28px, 3.4vw, 44px); line-height:1.25;
  text-align:center; color:var(--ink);
}
.story-quote .hand{ display:inline; font-size:1.1em; line-height:1; }
.story-meta{
  margin-top:28px; text-align:center;
  font-size:14px; color:var(--ink-soft);
  letter-spacing:.04em;
}
.story-photos{
  margin-top:64px; padding-bottom:48px;
  display:grid; grid-template-columns: 1fr 1fr 1fr; gap:28px; align-items:end;
}
.story-photos figure{ margin:0; position:relative; }
.story-photos img{ width:100%; aspect-ratio:3/4; object-fit:cover; display:block; box-shadow:var(--shadow-sm); }
.story-photos figure:nth-child(1){ transform:rotate(-2deg); }
.story-photos figure:nth-child(2){ transform:translateY(-22px) rotate(.5deg); }
.story-photos figure:nth-child(3){ transform:rotate(2deg); }
.story-photos figcaption{
  position:absolute; left:50%; bottom:-44px; transform:translateX(-50%) rotate(-3deg);
  font-family:"Caveat",cursive; font-size:24px; color:var(--accent);
  white-space:nowrap;
}
@media(max-width:680px){ .story-photos{ grid-template-columns: 1fr; } .story-photos figure{ transform:none !important; } }

/* photo filter only applies to gallery + story-photos imgs */
.story-photos img,
.gallery img{ filter: var(--img-filter); transition: filter .3s ease; }

/* ── Agenda timeline ──────────────────────────────────────── */
.agenda{
  position:relative; max-width:880px; margin:0 auto; padding:0 32px;
}
.agenda::before{
  content:""; position:absolute; left:calc(50% - .5px); top:0; bottom:0;
  width:1px; background:var(--line);
}
@media(max-width:780px){
  .agenda{ padding:0 20px; }
  .agenda::before{ left:44px; }
}

.ag-item{
  display:grid; grid-template-columns: 1fr 64px 1fr;
  gap:24px; align-items:center;
  position:relative; padding:32px 0;
}
@media(max-width:780px){
  .ag-item{
    display:flex; gap:20px; align-items:flex-start;
    padding:20px 0;
  }
  .ag-item .ag-time-l, .ag-item .ag-time-r{ display:none !important; }
  .ag-item .ag-icon{ order:0; flex-shrink:0; box-shadow: 0 0 0 6px var(--bg); }
  .ag-item .ag-card,
  .ag-item .ag-card-l{
    order:1; flex:1 1 auto; min-width:0; text-align:left !important;
    padding:18px 20px;
  }
  .ag-item .ag-card h3,
  .ag-item .ag-card-l h3{ font-size:22px; }
  .ag-item .ag-card p,
  .ag-item .ag-card-l p{ font-size:14px; }
}
.ag-time-l, .ag-time-r{
  font-family:"Cormorant Garamond",serif; font-style:italic;
  font-size:28px; color:var(--ink-soft); line-height:1; padding-top:6px;
}
.ag-time-r{ text-align:left; }
.ag-time-l{ text-align:right; }
.ag-icon{
  width:64px; height:64px; border-radius:99px;
  background:var(--paper); border:1px solid var(--line);
  display:grid; place-items:center; color:var(--accent);
  position:relative; z-index:2;
  box-shadow: 0 0 0 6px var(--bg);
}
.ag-icon svg{ width:28px; height:28px; }
.ag-card{
  background:var(--paper); border:1px solid var(--line);
  padding:22px 24px; border-radius:2px; box-shadow: var(--shadow-sm);
  position:relative;
}
.ag-card-l{ text-align:right; }
.ag-card h3{ font-family:"Cormorant Garamond",serif; font-style:italic; font-size:26px; }
.ag-card p{ margin-top:6px; font-size:14.5px; color:var(--ink-soft); }
.ag-time-mobile{ display:none; }
@media(max-width:780px){
  .ag-time-mobile{
    display:block; font-family:"Cormorant Garamond",serif; font-style:italic;
    color:var(--accent); font-size:20px; margin-bottom:4px; line-height:1;
  }
}

/* ── Generic info card ────────────────────────────────────── */
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:32px; align-items:stretch; }
.grid-3{ display:grid; grid-template-columns:repeat(3, 1fr); gap:24px; align-items:stretch; }
.grid-4{ display:grid; grid-template-columns:repeat(4, 1fr); gap:20px; align-items:stretch; }
@media(max-width:780px){ .grid-2,.grid-3,.grid-4{ grid-template-columns:1fr; } }

.grid-2 > .fade, .grid-3 > .fade, .grid-4 > .fade{ height:100%; display:flex; }
.grid-2 > .fade > .card, .grid-3 > .fade > .card, .grid-4 > .fade > .card{ flex:1; display:flex; flex-direction:column; }
.card .meta{ margin-top:auto; }

.card{
  background:var(--paper); border:1px solid var(--line);
  padding:32px; border-radius:2px;
}
.card h3{ font-family:"Cormorant Garamond",serif; font-style:italic; font-size:28px; margin-bottom:8px; }
.card .eyebrow{ margin-bottom:14px; display:block; }
.card p{ color:var(--ink-soft); font-size:15.5px; }
.card .meta{ margin-top:18px; padding-top:18px; border-top:1px solid var(--line); display:flex; gap:18px; flex-wrap:wrap; font-size:13.5px; color:var(--ink-soft); }
.card .meta b{ color:var(--ink); font-weight:500; }

.contact-meta > div{
  display:flex; flex-direction:column; gap:8px;
}
.contact-meta > div > b{
  margin-bottom:4px;
}
.contact-meta a{
  display:inline-flex; align-items:center; gap:8px;
  width:fit-content;
  padding:0; border-bottom:1px solid var(--accent);
  font-size:13.5px; color:var(--ink);
}
.contact-meta a::before{
  content:""; display:inline-block;
  width:14px; height:14px; flex-shrink:0;
  background:currentColor; opacity:.65;
  -webkit-mask-size:contain; mask-size:contain;
  -webkit-mask-repeat:no-repeat; mask-repeat:no-repeat;
  -webkit-mask-position:center; mask-position:center;
}
.contact-meta a[href^="tel:"]::before{
  -webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'><path d='M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6 19.79 19.79 0 0 1-3.07-8.67A2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72c.13.96.37 1.9.72 2.81a2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45c.91.35 1.85.59 2.81.72A2 2 0 0 1 22 16.92Z'/></svg>");
          mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'><path d='M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6 19.79 19.79 0 0 1-3.07-8.67A2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72c.13.96.37 1.9.72 2.81a2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45c.91.35 1.85.59 2.81.72A2 2 0 0 1 22 16.92Z'/></svg>");
}
.contact-meta a[href^="https://wa.me"]::before{
  -webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'><path d='M12.04 2C6.58 2 2.13 6.45 2.13 11.91c0 2.1.55 4.15 1.6 5.96L2 22l4.27-1.12a9.86 9.86 0 0 0 4.77 1.21h.01c5.46 0 9.91-4.45 9.91-9.91 0-2.65-1.03-5.14-2.9-7.01A9.84 9.84 0 0 0 12.04 2Zm5.78 14.13c-.24.68-1.42 1.32-1.97 1.36-.5.04-1 .19-3.42-.81-2.86-1.18-4.66-4.13-4.8-4.33-.14-.2-1.14-1.52-1.14-2.9 0-1.38.72-2.05.98-2.33.25-.28.55-.35.74-.35h.53c.17 0 .4-.07.62.48.24.59.81 2.03.88 2.18.07.15.12.32.02.51-.1.2-.15.32-.29.5-.15.18-.31.4-.44.54-.15.15-.3.31-.13.6.17.3.78 1.28 1.66 2.08 1.14 1.02 2.1 1.34 2.4 1.5.3.15.47.13.65-.07.18-.2.75-.88.95-1.18.2-.3.4-.25.66-.15.27.1 1.7.8 1.99.95.29.15.49.22.56.34.07.13.07.73-.17 1.38Z'/></svg>");
          mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'><path d='M12.04 2C6.58 2 2.13 6.45 2.13 11.91c0 2.1.55 4.15 1.6 5.96L2 22l4.27-1.12a9.86 9.86 0 0 0 4.77 1.21h.01c5.46 0 9.91-4.45 9.91-9.91 0-2.65-1.03-5.14-2.9-7.01A9.84 9.84 0 0 0 12.04 2Zm5.78 14.13c-.24.68-1.42 1.32-1.97 1.36-.5.04-1 .19-3.42-.81-2.86-1.18-4.66-4.13-4.8-4.33-.14-.2-1.14-1.52-1.14-2.9 0-1.38.72-2.05.98-2.33.25-.28.55-.35.74-.35h.53c.17 0 .4-.07.62.48.24.59.81 2.03.88 2.18.07.15.12.32.02.51-.1.2-.15.32-.29.5-.15.18-.31.4-.44.54-.15.15-.3.31-.13.6.17.3.78 1.28 1.66 2.08 1.14 1.02 2.1 1.34 2.4 1.5.3.15.47.13.65-.07.18-.2.75-.88.95-1.18.2-.3.4-.25.66-.15.27.1 1.7.8 1.99.95.29.15.49.22.56.34.07.13.07.73-.17 1.38Z'/></svg>");
}
.contact-meta a[href^="mailto:"]::before{
  -webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'><rect x='3' y='5' width='18' height='14' rx='2'/><path d='M3 7l9 7 9-7'/></svg>");
          mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'><rect x='3' y='5' width='18' height='14' rx='2'/><path d='M3 7l9 7 9-7'/></svg>");
}
.contact-meta a:hover{ color:var(--accent); border-bottom-color:var(--accent-2); }
.map-link{
  display:inline-flex; align-items:center; gap:8px;
  margin-top:18px; padding-top:14px;
  border:0; border-top:1px dashed var(--line);
  width:100%;
  font-size:12.5px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--accent); font-weight:500;
}
.map-link:hover{ color:var(--accent-2); }
.map-link svg{ flex-shrink:0; }

/* Section heading block */
.sec-head{ text-align:center; margin-bottom:64px; }
.sec-head .hand{ display:block; margin-bottom:8px; font-size:42px; }
.sec-head h2{ margin-bottom:14px; }
.sec-head .sub{ color:var(--ink-soft); max-width:560px; margin:0 auto; }

/* ── FAQ ──────────────────────────────────────────────────── */
.faq{ max-width:780px; margin:0 auto; }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-item:first-child{ border-top:1px solid var(--line); }
.faq-q{
  padding:22px 0; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:24px;
  font-family:"Cormorant Garamond",serif; font-style:italic; font-size:22px; color:var(--ink);
  user-select:none;
}
.faq-q .plus{
  width:22px; height:22px; flex-shrink:0; position:relative; opacity:.7;
  transition: transform .3s;
}
.faq-q .plus::before, .faq-q .plus::after{
  content:""; position:absolute; left:0; top:50%; width:22px; height:1px; background:currentColor;
}
.faq-q .plus::after{ transform:rotate(90deg); transition: opacity .3s; }
.faq-item.open .faq-q .plus{ transform:rotate(180deg); }
.faq-item.open .faq-q .plus::after{ opacity:0; }
.faq-a{
  max-height:0; overflow:hidden; transition: max-height .35s ease;
  font-size:15.5px; color:var(--ink-soft);
}
.faq-item.open .faq-a{ max-height:300px; }
.faq-a > div{ padding:0 0 22px; }

/* ── Gallery ──────────────────────────────────────────────── */
.gallery{
  columns: 3; column-gap: 16px;
}
@media(max-width:900px){ .gallery{ columns:2; } }
@media(max-width:540px){ .gallery{ columns:1; } }
.gallery figure{
  margin:0 0 16px; break-inside: avoid; position:relative;
  box-shadow: var(--shadow-sm);
}
.gallery img{ width:100%; display:block; }
.gallery figcaption{
  position:absolute; left:14px; bottom:10px;
  font-family:"Caveat",cursive; color:#fff;
  font-size:22px; text-shadow:0 1px 6px rgba(0,0,0,.45);
}

/* ── RSVP form ────────────────────────────────────────────── */
.rsvp-wrap{
  background:var(--paper); border:1px solid var(--line);
  max-width:780px; margin:0 auto; padding:56px clamp(24px, 5vw, 64px);
  position:relative;
}
.rsvp-wrap::before{
  content:""; position:absolute; inset:8px; border:1px solid var(--line); pointer-events:none;
}
.rsvp-head{ text-align:center; margin-bottom:40px; }
.rsvp-head .hand{ font-size:48px; display:block; margin-bottom:4px; }
.rsvp-head h2{ margin-bottom:14px; }
.rsvp-head .sub{ color:var(--ink-soft); }

.form-row{ margin-bottom:22px; }
.form-row label{
  display:block; font-size:11px; letter-spacing:.28em; text-transform:uppercase;
  color:var(--ink-mute); margin-bottom:8px; font-weight:500;
}
.form-row label .opt{
  text-transform:none; letter-spacing:.02em; color:var(--ink-mute); font-style:italic; font-weight:400;
  font-family:"Cormorant Garamond",serif; font-size:14px; margin-left:6px;
}
.field-hint{
  font-size:13.5px; color:var(--ink-soft); line-height:1.5;
  margin:-2px 0 10px;
}
.form-row input[type=text],
.form-row input[type=email],
.form-row input[type=number],
.form-row textarea,
.form-row select{
  width:100%; padding:12px 14px;
  background:transparent;
  border:none; border-bottom:1px solid var(--line);
  font:inherit; color:var(--ink);
  outline:none; transition: border-color .2s;
}
.form-row input:focus, .form-row textarea:focus, .form-row select:focus{
  border-bottom-color:var(--accent);
}
.form-row textarea{ resize:vertical; min-height:90px; }

.form-grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
@media(max-width:600px){ .form-grid-2{ grid-template-columns:1fr; gap:0; } }

.choice-row{ display:flex; gap:10px; flex-wrap:wrap; }
.choice{
  padding:11px 18px; border:1px solid var(--line); background:var(--bg);
  cursor:pointer; font-size:14px; color:var(--ink-soft);
  transition: all .15s;
  font-family:"DM Sans",sans-serif;
}
.choice:hover{ border-color:var(--accent); color:var(--ink); }
.choice.active{ background:var(--accent); border-color:var(--accent); color:var(--paper); }

.stepper{ display:inline-flex; align-items:center; gap:0; border:1px solid var(--line); }
.stepper button{
  width:42px; height:42px; background:transparent; border:0; cursor:pointer;
  font-size:18px; color:var(--ink); font-family:inherit;
}
.stepper button:hover{ background:var(--bg); }
.stepper .v{ min-width:42px; text-align:center; font-family:"Cormorant Garamond",serif; font-style:italic; font-size:24px; }

.btn-submit{
  display:block; width:100%; padding:18px 24px; margin-top:14px;
  background:var(--ink); color:var(--paper);
  border:0; cursor:pointer;
  font-family:"DM Sans",sans-serif; font-size:13px; letter-spacing:.32em; text-transform:uppercase;
  transition: background .2s;
}
.btn-submit:hover{ background:var(--accent); }
.btn-submit:disabled{ opacity:.5; cursor:not-allowed; }

.rsvp-success{
  text-align:center; padding:40px 0;
}
.rsvp-success .big{
  font-family:"Cormorant Garamond",serif; font-style:italic;
  font-size:56px; color:var(--accent); line-height:1;
}
.rsvp-success .hand{ font-size:32px; display:block; margin:10px 0 18px; }

/* ── Footer ───────────────────────────────────────────────── */
.footer{
  text-align:center; padding:80px 24px 60px;
  background:var(--ink); color:var(--bg);
}
.footer .mono{ font-family:"Cormorant Garamond",serif; font-style:italic; font-size:42px; }
.footer .amp{ font-family:"Caveat",cursive; color:var(--accent-soft); font-size:.7em; vertical-align:.1em; }
.footer .sub{ margin-top:10px; font-size:12px; letter-spacing:.32em; text-transform:uppercase; opacity:.6; }
.footer .heart{ display:inline-block; margin-top:18px; color:var(--accent-soft); }

/* ── Misc ─────────────────────────────────────────────────── */
.tag-pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 12px; border:1px solid var(--line); border-radius:99px;
  font-size:12px; color:var(--ink-soft); background:var(--paper);
}
.tag-pill .dot{ width:6px; height:6px; border-radius:99px; background:var(--accent); }

.pinch{ max-width:680px; margin:0 auto; text-align:center; color:var(--ink-soft); }

/* small subtle leaf SVG accent */
.leaf{
  position:absolute; pointer-events:none; opacity:.25;
  color:var(--accent);
}

/* Note-card: handwritten-feeling soft request */
.note-card{
  position:relative;
  max-width:720px; margin:0 auto;
  background:var(--paper);
  border:1px solid var(--line);
  padding:48px clamp(28px, 5vw, 56px);
  box-shadow: var(--shadow-sm);
  text-align:center;
}
.note-card::before{
  content:""; position:absolute; inset:8px;
  border:1px dashed var(--line); pointer-events:none;
}
.note-card .note-eyebrow{
  display:block;
  font-size:30px; color:var(--accent);
  margin-bottom:10px;
}
.note-card h3{
  font-family:"Cormorant Garamond",serif; font-style:italic;
  font-size:clamp(26px, 3vw, 36px);
  line-height:1.15;
  margin-bottom:18px;
}
.note-card p{
  color:var(--ink-soft); font-size:16px; line-height:1.6;
  max-width:520px; margin:0 auto;
}
.note-tape{
  position:absolute; width:100px; height:24px;
  background: rgba(184, 101, 74, .18);
  border:1px solid rgba(184, 101, 74, .12);
}
.note-tape--l{ top:-12px; left:32px; transform:rotate(-4deg); }
.note-tape--r{ top:-12px; right:32px; transform:rotate(3deg); }

/* Animated fade-in on scroll */
.fade{ opacity:0; transform: translateY(14px); transition: opacity .8s ease, transform .8s ease; }
.fade.in{ opacity:1; transform:none; }
