/* ───────────────────── tokens ───────────────────── */
:root{
  --navy:#1a2942;
  --navy-deep:#0f1a2e;
  --navy-mid:#243453;
  --gold:#b08a4a;
  --gold-light:#d4b572;
  --gold-soft:#e8d5a8;
  --cream:#f5ede0;
  --cream-deep:#ebe0cc;
  --paper:#faf6ed;
  --ink:#2a2418;
  --ink-soft:#5a4e3e;

  --maxw:1100px;
  --pad:32px;
  --section-y:110px;

  --ff-display:'Italiana', 'Cormorant Garamond', serif;
  --ff-serif:'Cormorant Garamond', Georgia, serif;
  --ff-sans:'Inter', system-ui, sans-serif;
}
@media (max-width:700px){
  :root{ --section-y:80px; --pad:22px; }
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--ff-serif);
  font-size:18px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
button{ font:inherit; cursor:pointer; }
a{ color:inherit; }

/* ───────────────────── top banner ───────────────────── */
.topbar{
  position:fixed; top:0; left:0; right:0; z-index:60;
  background:var(--navy-deep);
  color:var(--gold-light);
  border-bottom:1px solid rgba(176,138,74,.25);
  font-family:var(--ff-sans);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  text-align:center;
  padding:9px 16px;
  display:flex; align-items:center; justify-content:center; gap:14px;
  flex-wrap:wrap;
}
.topbar__dot{ color:var(--gold); }
.topbar a{
  color:var(--cream);
  text-decoration:none;
  border-bottom:1px solid var(--gold);
  padding-bottom:1px;
  transition:color .25s ease;
}
.topbar a:hover{ color:var(--gold-light); }
.topbar strong{ color:var(--gold-light); font-weight:500; }
@media (max-width:600px){
  .topbar{ font-size:.62rem; letter-spacing:.18em; gap:8px; padding:7px 12px; }
}

/* ───────────────────── nav ───────────────────── */
.nav{
  position:fixed; top:var(--topbar-h, 36px); left:0; right:0; z-index:50;
  padding:18px var(--pad);
  display:flex; align-items:center; justify-content:space-between;
  transition:padding .35s ease, background-color .35s ease, backdrop-filter .35s ease, border-color .35s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  padding:10px var(--pad);
  top:var(--topbar-h, 32px);
  background:rgba(15,26,46,.72);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom-color:rgba(176,138,74,.22);
}
.nav__brand{
  font-family:var(--ff-display);
  font-size:1.45rem;
  color:var(--gold-light);
  letter-spacing:.08em;
  text-decoration:none;
}
.nav__links{
  display:flex; gap:30px; list-style:none; margin:0; padding:0;
}
.nav__links a{
  font-family:var(--ff-sans);
  font-size:.74rem;
  text-transform:uppercase;
  letter-spacing:.25em;
  color:rgba(245,237,224,.82);
  text-decoration:none;
  position:relative;
  padding:6px 0;
  white-space:nowrap;
}
.nav__links a::after{
  content:""; position:absolute; left:50%; right:50%; bottom:0;
  height:1px; background:var(--gold-light);
  transition:left .35s ease, right .35s ease;
}
.nav__links a:hover::after{ left:0; right:0; }
.nav__burger{
  display:none;
  width:36px; height:36px; border:1px solid rgba(232,213,168,.4);
  background:transparent; color:var(--gold-soft);
  border-radius:2px;
}
.nav__burger span{ display:block; height:1px; background:currentColor; margin:5px 8px; }
@media (max-width:960px){
  .nav__links{ display:none; }
  .nav__burger{ display:block; }
  .nav__links.open{
    display:flex; flex-direction:column; gap:18px;
    position:absolute; top:100%; left:0; right:0;
    padding:24px var(--pad);
    background:rgba(15,26,46,.96);
    backdrop-filter:blur(12px);
    border-bottom:1px solid rgba(176,138,74,.22);
  }
}

/* ───────────────────── ornament ───────────────────── */
.ornament{
  position:relative;
  width:min(280px, 60%);
  height:1px;
  margin:22px auto;
  background:linear-gradient(90deg, transparent, var(--gold) 30%, var(--gold) 70%, transparent);
}
.ornament::after{
  content:"◆";
  position:absolute; left:50%; top:50%;
  transform:translate(-50%,-50%);
  color:var(--gold);
  font-size:.7rem;
  background:var(--paper);
  padding:0 14px;
  letter-spacing:0;
}
.ornament--on-cream::after{ background:var(--cream); }
.ornament--on-navy::after{ background:var(--navy-deep); color:var(--gold-light); }

/* ───────────────────── typography helpers ───────────────────── */
.eyebrow{
  font-family:var(--ff-serif);
  font-style:italic;
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:.4em;
  font-size:.78rem;
  color:var(--gold);
}
.eyebrow--light{ color:var(--gold-light); }
h1,h2,h3,h4{ margin:0; font-weight:400; }
.h-display{ font-family:var(--ff-display); }
.section-title{
  font-family:var(--ff-display);
  font-size:clamp(2.4rem, 6vw, 4rem);
  text-align:center;
  line-height:1.05;
  letter-spacing:.01em;
}
.section-head{
  text-align:center;
  margin-bottom:64px;
}
.section-head .eyebrow{ display:block; margin-bottom:14px; }
.section-head p{
  max-width:560px; margin:18px auto 0;
  color:var(--ink-soft);
  font-size:1.05rem;
  line-height:1.7;
}

/* ───────────────────── section frames ───────────────────── */
section{ position:relative; padding:var(--section-y) var(--pad); }
.section-inner{ max-width:var(--maxw); margin:0 auto; }
.section--paper{ background:var(--paper); }
.section--cream{ background:var(--cream); }
.section--cream .ornament{ background:linear-gradient(90deg, transparent, var(--gold), transparent); }
.section--cream .ornament::after{ background:var(--cream); }

/* ───────────────────── buttons ───────────────────── */
.btn{
  display:inline-block;
  font-family:var(--ff-sans);
  font-weight:500;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.25em;
  padding:16px 32px;
  background:var(--navy);
  color:var(--cream);
  border:1px solid var(--navy);
  text-decoration:none;
  transition:background .35s ease, color .35s ease, border-color .35s ease, transform .25s ease;
  cursor:pointer;
}
.btn:hover{ background:var(--gold); border-color:var(--gold); color:var(--navy-deep); }
.btn--ghost{
  background:transparent;
  color:var(--gold-light);
  border-color:var(--gold);
}
.btn--ghost:hover{ background:var(--gold); color:var(--navy-deep); }
.btn--small{ padding:12px 22px; font-size:.7rem; }

/* ───────────────────── HERO ───────────────────── */
.hero{
  min-height:100vh;
  padding-top:180px;
  background:
    radial-gradient(900px 600px at 50% 30%, rgba(176,138,74,.18), transparent 65%),
    radial-gradient(700px 500px at 20% 80%, rgba(176,138,74,.10), transparent 70%),
    radial-gradient(700px 500px at 85% 20%, rgba(212,181,114,.08), transparent 70%),
    linear-gradient(180deg, var(--navy-deep) 0%, var(--navy) 60%, var(--navy-deep) 100%);
  color:var(--cream);
  padding:140px var(--pad) 80px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.hero{ padding:180px var(--pad) 90px; }
.hero::before{
  /* twinkling stars */
  content:"";
  position:absolute; inset:0;
  background-image:
    radial-gradient(1.5px 1.5px at 12% 18%, rgba(232,213,168,.9), transparent 60%),
    radial-gradient(1px 1px at 78% 28%, rgba(232,213,168,.7), transparent 60%),
    radial-gradient(1.5px 1.5px at 42% 8%, rgba(232,213,168,.8), transparent 60%),
    radial-gradient(1px 1px at 88% 62%, rgba(232,213,168,.6), transparent 60%),
    radial-gradient(2px 2px at 22% 72%, rgba(212,181,114,.7), transparent 60%),
    radial-gradient(1px 1px at 62% 82%, rgba(232,213,168,.6), transparent 60%),
    radial-gradient(1.2px 1.2px at 36% 48%, rgba(232,213,168,.7), transparent 60%),
    radial-gradient(1px 1px at 92% 12%, rgba(232,213,168,.85), transparent 60%),
    radial-gradient(1.5px 1.5px at 8% 52%, rgba(212,181,114,.6), transparent 60%),
    radial-gradient(1px 1px at 70% 55%, rgba(232,213,168,.75), transparent 60%);
  animation:twinkle 8s ease-in-out infinite;
  pointer-events:none;
}
.hero::after{
  /* second twinkle layer offset */
  content:"";
  position:absolute; inset:0;
  background-image:
    radial-gradient(1px 1px at 18% 32%, rgba(232,213,168,.5), transparent 60%),
    radial-gradient(1px 1px at 56% 22%, rgba(212,181,114,.55), transparent 60%),
    radial-gradient(1.2px 1.2px at 82% 78%, rgba(232,213,168,.5), transparent 60%),
    radial-gradient(1px 1px at 30% 88%, rgba(232,213,168,.5), transparent 60%),
    radial-gradient(1px 1px at 48% 64%, rgba(232,213,168,.45), transparent 60%);
  animation:twinkle 11s ease-in-out -3s infinite;
  pointer-events:none;
}
@keyframes twinkle{
  0%,100%{ opacity:.4; }
  50%{ opacity:.85; }
}

.hero__inner{ position:relative; z-index:2; max-width:900px; }
.hero .eyebrow{ opacity:0; transform:translateY(20px); animation:fadeUp .9s ease forwards; }
.hero__eyebrow{
  font-size:clamp(.95rem, 1.6vw, 1.25rem) !important;
  letter-spacing:.55em !important;
  display:inline-block;
  padding-bottom:14px;
  border-bottom:1px solid rgba(176,138,74,.4);
  margin-bottom:14px;
}
.hero h1{
  font-family:var(--ff-display);
  font-size:clamp(3.5rem, 11vw, 7.5rem);
  line-height:1;
  letter-spacing:.02em;
  margin:28px 0 8px;
  opacity:0; transform:translateY(28px);
  animation:fadeUp 1.1s ease .1s forwards;
}
.hero h1 .amp{
  font-family:var(--ff-serif);
  font-style:italic;
  font-weight:400;
  color:var(--gold-light);
  padding:0 .15em;
}
.hero__date{
  font-family:var(--ff-serif);
  font-style:italic;
  font-size:clamp(1.1rem, 2vw, 1.4rem);
  color:var(--gold-soft);
  margin-top:28px;
  opacity:0; transform:translateY(20px);
  animation:fadeUp .9s ease .3s forwards;
}
.hero__bigdate{
  display:flex; align-items:center; justify-content:center; gap:clamp(18px,3vw,42px);
  margin:30px 0 8px;
  opacity:0; transform:translateY(20px);
  animation:fadeUp .9s ease .32s forwards;
}
.hero__bigdate .num{
  font-family:var(--ff-display);
  font-size:clamp(2.6rem, 7vw, 4.6rem);
  color:var(--gold-light);
  line-height:1;
  letter-spacing:.04em;
}
.hero__bigdate .sep{
  display:inline-block;
  width:8px; height:8px; transform:rotate(45deg);
  background:var(--gold);
}
.hero__bigdate .month{
  font-family:var(--ff-serif);
  font-style:italic;
  font-size:clamp(1.6rem, 3.6vw, 2.4rem);
  color:var(--gold-soft);
  letter-spacing:.04em;
}
.hero__roman{
  font-family:var(--ff-display);
  letter-spacing:.5em;
  font-size:1rem;
  color:rgba(232,213,168,.7);
  margin-top:6px;
  opacity:0; transform:translateY(20px);
  animation:fadeUp .9s ease .35s forwards;
}
.hero__loc{
  font-family:var(--ff-sans);
  text-transform:uppercase;
  letter-spacing:.35em;
  font-size:.85rem;
  color:rgba(245,237,224,.78);
  margin-top:30px;
  opacity:0; transform:translateY(20px);
  animation:fadeUp .9s ease .4s forwards;
}
@keyframes fadeUp{
  to{ opacity:1; transform:translateY(0); }
}

.countdown{
  margin-top:64px;
  display:flex; gap:0; justify-content:center;
  opacity:0; transform:translateY(20px);
  animation:fadeUp .9s ease .5s forwards;
}
.countdown__cell{
  min-width:96px;
  padding:0 22px;
  border-right:1px solid rgba(232,213,168,.25);
}
.countdown__cell:last-child{ border-right:0; }
.countdown__num{
  font-family:var(--ff-display);
  font-size:clamp(2.2rem, 5vw, 3rem);
  color:var(--gold-light);
  line-height:1;
}
.countdown__label{
  font-family:var(--ff-sans);
  font-size:.66rem;
  text-transform:uppercase;
  letter-spacing:.3em;
  color:rgba(245,237,224,.65);
  margin-top:10px;
}
@media (max-width:600px){
  .countdown__cell{ min-width:0; padding:0 14px; }
}

.scroll-hint{
  position:absolute; bottom:34px; left:50%; transform:translateX(-50%);
  font-family:var(--ff-sans);
  text-transform:uppercase;
  letter-spacing:.4em;
  font-size:.65rem;
  color:rgba(232,213,168,.65);
  z-index:2;
  opacity:0; animation:fadeUp .9s ease 1.1s forwards;
}
.scroll-hint::after{
  content:""; display:block; width:1px; height:38px; margin:14px auto 0;
  background:linear-gradient(180deg, var(--gold), transparent);
  animation:scrollPulse 2.4s ease-in-out infinite;
}
@keyframes scrollPulse{
  0%,100%{ opacity:.4; transform:scaleY(.8); transform-origin:top; }
  50%{ opacity:1; transform:scaleY(1.1); }
}

/* ───────────────────── story ───────────────────── */
.story__couple{
  text-align:center;
  font-family:var(--ff-display);
  font-size:clamp(2rem, 5vw, 3rem);
  line-height:1.15;
}
.story__couple .amp{
  display:block;
  font-family:var(--ff-serif);
  font-style:italic;
  font-size:clamp(4rem, 12vw, 7rem);
  color:var(--gold);
  line-height:1;
  margin:14px 0;
}
.story__text{
  max-width:640px; margin:48px auto 0;
  text-align:center;
  font-size:1.18rem;
  line-height:1.85;
  color:var(--ink-soft);
}
/* ───────────────────── story slider ───────────────────── */
.story-slider {
  margin-top: 72px;
  position: relative;
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
}
.story-slider__track {
  display: flex;
  gap: 20px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 4px 8px 20px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.story-slider__track::-webkit-scrollbar { display: none; }
.story-slider__track .ph {
  flex: 0 0 calc(33.333% - 14px);
  aspect-ratio: 3/4;
  scroll-snap-align: center;
}
.story-slider__btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px; height: 44px;
  background: rgba(15, 26, 46, 0.85);
  color: var(--gold-light);
  border: 1px solid var(--gold);
  font-size: 1.4rem;
  cursor: pointer;
  z-index: 5;
  transition: background 0.2s;
}
.story-slider__btn:hover { background: var(--gold); color: var(--navy-deep); }
.story-slider__btn--prev { left: -22px; }
.story-slider__btn--next { right: -22px; }
.story-slider__dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 16px;
}
.story-slider__dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(176, 138, 74, 0.3);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background 0.2s, transform 0.2s;
}
.story-slider__dot.active {
  background: var(--gold);
  transform: scale(1.3);
}

@media (max-width: 800px) {
  .story-slider__track .ph {
    flex: 0 0 calc(100% - 30px);
    aspect-ratio: 4/5;
  }
  .story-slider__btn--prev { left: 4px; }
  .story-slider__btn--next { right: 4px; }
}

/* ───────────────────── photo placeholders ───────────────────── */
.ph{
  position:relative;
  background:
    repeating-linear-gradient(45deg,
      rgba(176,138,74,.10) 0 2px,
      rgba(176,138,74,.04) 2px 18px),
    linear-gradient(135deg, var(--cream-deep), var(--cream));
  border:1px solid rgba(176,138,74,.22);
  overflow:hidden;
  cursor:pointer;
  transition:transform .5s ease;
}
.ph--dark{
  background:
    repeating-linear-gradient(45deg,
      rgba(232,213,168,.08) 0 2px,
      rgba(232,213,168,.02) 2px 18px),
    linear-gradient(135deg, var(--navy-mid), var(--navy-deep));
  border-color:rgba(176,138,74,.30);
}
.ph__label{
  position:absolute; inset:auto 0 0 0;
  padding:14px 18px;
  font-family:'JetBrains Mono', 'Courier New', monospace;
  font-size:.66rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--ink-soft);
  background:linear-gradient(180deg, transparent, rgba(250,246,237,.92) 60%);
}
.ph--dark .ph__label{
  color:var(--gold-soft);
  background:linear-gradient(180deg, transparent, rgba(15,26,46,.92) 60%);
}
.ph__corner{
  position:absolute; top:14px; right:14px;
  width:18px; height:18px;
  border-top:1px solid var(--gold);
  border-right:1px solid var(--gold);
}
.ph__corner--bl{
  top:auto; right:auto; bottom:14px; left:14px;
  border-top:0; border-right:0;
  border-bottom:1px solid var(--gold);
  border-left:1px solid var(--gold);
}
.ph:hover{ transform:scale(1.02); }
.ph:hover .ph__zoom{ transform:scale(1.06); }
.ph__zoom{
  position:absolute; inset:0;
  background:
    repeating-linear-gradient(135deg,
      rgba(176,138,74,.12) 0 2px,
      rgba(176,138,74,.04) 2px 22px),
    radial-gradient(ellipse at 50% 40%, rgba(212,181,114,.18), transparent 60%);
  transition:transform 7s ease;
}
.ph--dark .ph__zoom{
  background:
    repeating-linear-gradient(135deg,
      rgba(232,213,168,.06) 0 2px,
      rgba(232,213,168,.02) 2px 22px),
    radial-gradient(ellipse at 50% 30%, rgba(176,138,74,.18), transparent 60%);
}

/* ───────────────────── programma ───────────────────── */
.timeline{
  max-width:720px; margin:0 auto;
  display:grid;
  grid-template-columns:auto 1fr;
  column-gap:48px;
  row-gap:0;
}
.tl-time, .tl-event{
  padding:22px 0;
  border-bottom:1px solid rgba(176,138,74,.22);
}
.tl-time{
  font-family:var(--ff-display);
  font-size:1.5rem;
  color:var(--gold);
  letter-spacing:.05em;
  white-space:nowrap;
}
.tl-event h4{
  font-family:var(--ff-serif);
  font-weight:500;
  font-size:1.4rem;
  color:var(--ink);
  margin-bottom:4px;
}
.tl-event p{
  margin:0;
  color:var(--ink-soft);
  font-size:1rem;
}
.timeline > div:last-child, .timeline > div:nth-last-child(2){ border-bottom:0; }

.note{
  margin-top:48px;
  max-width:720px;
  padding:22px 26px;
  border-left:2px solid var(--gold);
  background:rgba(176,138,74,.06);
  font-style:italic;
  color:var(--ink-soft);
  margin-left:auto; margin-right:auto;
}
.note strong{
  font-family:var(--ff-sans);
  font-style:normal;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.25em;
  font-size:.72rem;
  color:var(--gold);
  display:block;
  margin-bottom:8px;
}

/* ───────────────────── locatie ───────────────────── */
.loc-hero{
  margin-bottom:64px;
  aspect-ratio:21/9;
  position:relative;
}
.loc-grid{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:56px;
  align-items:start;
}
@media (max-width:800px){
  .loc-grid{ grid-template-columns:1fr; gap:32px; }
}
.loc-info h3{
  font-family:var(--ff-display);
  font-size:2.2rem;
  margin-bottom:18px;
}
.loc-info p{ color:var(--ink-soft); line-height:1.8; margin:0 0 12px; }
.loc-info address{
  font-style:normal;
  font-family:var(--ff-sans);
  font-size:.92rem;
  letter-spacing:.02em;
  color:var(--ink);
  margin-top:24px;
  padding-top:24px;
  border-top:1px solid rgba(176,138,74,.25);
  line-height:1.8;
}
.map{
  aspect-ratio:4/3;
  border:1px solid rgba(176,138,74,.28);
  filter:sepia(.35) saturate(.85) contrast(.95);
  background:var(--cream-deep);
}
.tips{
  margin-top:64px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
@media (max-width:800px){ .tips{ grid-template-columns:1fr; } }
.tip{
  text-align:center;
  padding:30px 24px;
  border:1px solid rgba(176,138,74,.22);
  background:rgba(255,255,255,.4);
}
.tip__icon{
  font-family:var(--ff-display);
  color:var(--gold);
  font-size:1.8rem;
  letter-spacing:.2em;
  margin-bottom:10px;
}
.tip h4{
  font-family:var(--ff-serif);
  font-weight:500;
  font-size:1.2rem;
  margin-bottom:8px;
}
.tip p{ font-size:.95rem; color:var(--ink-soft); margin:0; }

/* ───────────────────── slapen ───────────────────── */
.disclaimer{
  max-width:640px;
  margin:0 auto 56px;
  text-align:center;
  font-style:italic;
  color:var(--ink-soft);
}
.cards-2{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:28px;
}
.cards-3{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
  margin-top:64px;
}
@media (max-width:800px){
  .cards-2, .cards-3{ grid-template-columns:1fr; }
}
.card{
  position:relative;
  background:var(--paper);
  padding:32px 30px;
  border:1px solid rgba(176,138,74,.28);
  transition:transform .35s ease, box-shadow .35s ease;
}
.card:hover{ transform:translateY(-3px); box-shadow:0 20px 50px rgba(15,26,46,.12); }
.card--featured{
  background:linear-gradient(180deg, #fff9eb, var(--paper));
  border:1px solid var(--gold);
  box-shadow:0 8px 30px rgba(176,138,74,.15);
}
.card--featured::before{
  content:""; position:absolute; inset:8px;
  border:1px solid rgba(176,138,74,.35);
  pointer-events:none;
}
.badge{
  display:inline-block;
  font-family:var(--ff-sans);
  font-size:.65rem;
  font-weight:500;
  letter-spacing:.3em;
  text-transform:uppercase;
  padding:6px 12px;
  background:var(--gold);
  color:var(--navy-deep);
  margin-bottom:18px;
}
.card h4{
  font-family:var(--ff-display);
  font-size:1.6rem;
  margin-bottom:6px;
}
.card__rating{
  color:var(--gold);
  letter-spacing:.15em;
  font-size:.9rem;
  margin-bottom:10px;
}
.card__addr{
  font-family:var(--ff-sans);
  font-size:.82rem;
  color:var(--ink-soft);
  margin-bottom:14px;
}
.card__desc{
  font-size:.98rem;
  color:var(--ink-soft);
  line-height:1.6;
  margin-bottom:22px;
}
.card__links{
  display:flex; gap:10px; flex-wrap:wrap;
}
.card--taxi{
  text-align:center;
  padding:38px 26px;
}
.card--taxi h4{ font-size:1.4rem; margin-bottom:18px; }
.card--taxi .phone{
  display:block;
  font-family:var(--ff-display);
  font-size:1.5rem;
  color:var(--navy);
  letter-spacing:.04em;
  text-decoration:none;
  padding:14px 0;
  border-top:1px solid rgba(176,138,74,.25);
  border-bottom:1px solid rgba(176,138,74,.25);
  margin-bottom:18px;
  transition:color .3s ease;
}
.card--taxi .phone:hover{ color:var(--gold); }

/* ───────────────────── RSVP ───────────────────── */
.rsvp-card{
  position:relative;
  max-width:720px;
  margin:0 auto;
  background:var(--paper);
  padding:64px 56px;
  border:1px solid var(--gold);
  box-shadow:0 30px 80px rgba(15,26,46,.12);
}
.rsvp-card::before{
  content:""; position:absolute; inset:8px;
  border:1px solid rgba(176,138,74,.35);
  pointer-events:none;
}
@media (max-width:600px){
  .rsvp-card{ padding:44px 26px; }
}
.field{ margin-bottom:24px; position:relative; }
.field label{
  display:block;
  font-family:var(--ff-sans);
  text-transform:uppercase;
  font-size:.72rem;
  letter-spacing:.25em;
  color:var(--ink-soft);
  margin-bottom:10px;
}
.field input[type=text], .field input[type=email], .field input[type=number], .field textarea, .field select{
  width:100%;
  padding:12px 4px;
  background:transparent;
  border:none;
  border-bottom:1px solid rgba(176,138,74,.4);
  font-family:var(--ff-serif);
  font-size:1.1rem;
  color:var(--ink);
  outline:none;
  transition:border-color .3s ease;
}
.field input:focus, .field textarea:focus, .field select:focus{ border-bottom-color:var(--gold); }
.field textarea{ resize:vertical; min-height:80px; }
.attend-toggle{
  display:flex; gap:14px; margin-top:8px;
}
.attend-toggle label{
  flex:1;
  display:block;
  padding:18px;
  border:1px solid rgba(176,138,74,.4);
  text-align:center;
  cursor:pointer;
  font-family:var(--ff-display);
  font-size:1.3rem;
  letter-spacing:.05em;
  color:var(--ink-soft);
  transition:all .3s ease;
  margin:0;
  text-transform:none;
}
.attend-toggle input{ position:absolute; opacity:0; pointer-events:none; }
.attend-toggle input:checked + label{
  background:var(--navy);
  color:var(--gold-light);
  border-color:var(--navy);
}
.checks{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
}
.checks--auto{
  grid-template-columns:repeat(auto-fit, minmax(150px, 1fr));
}
@media (max-width:500px){ .checks{ grid-template-columns:1fr; } }
.check{
  display:flex; align-items:center; gap:12px;
  padding:12px 14px;
  border:1px solid rgba(176,138,74,.22);
  cursor:pointer;
  font-size:1rem;
  transition:background .3s ease, border-color .3s ease;
}
.check:hover{ background:rgba(176,138,74,.06); }
.check input{ accent-color:var(--gold); }
.check input:checked + span{ color:var(--ink); font-weight:500; }
.conditional{
  max-height:0;
  overflow:hidden;
  opacity:0;
  transition:max-height .55s ease, opacity .35s ease, margin .35s ease;
}
.conditional.show{
  max-height:3000px;
  opacity:1;
  margin-top:8px;
}
.conditional .field{
  animation:fadeUpSoft .6s ease backwards;
}
.conditional.show .field:nth-child(1){ animation-delay:.05s; }
.conditional.show .field:nth-child(2){ animation-delay:.12s; }
.conditional.show .field:nth-child(3){ animation-delay:.19s; }
.conditional.show .field:nth-child(4){ animation-delay:.26s; }
.conditional.show .field:nth-child(5){ animation-delay:.33s; }
.conditional.show .field:nth-child(6){ animation-delay:.40s; }
.conditional.show .field:nth-child(7){ animation-delay:.47s; }
.conditional.show .field:nth-child(8){ animation-delay:.54s; }
@keyframes fadeUpSoft{
  from{ opacity:0; transform:translateY(14px); }
  to{ opacity:1; transform:translateY(0); }
}
.rsvp-card .btn{ display:block; width:100%; margin-top:14px; }
.rsvp-success{
  text-align:center;
  padding:24px 0;
}
.rsvp-success h3{
  font-family:var(--ff-display);
  font-size:2.4rem;
  color:var(--gold);
  margin-bottom:14px;
}
.rsvp-success p{ color:var(--ink-soft); }

/* ───────────────────── gastenboek ───────────────────── */
.gb-form{
  max-width:640px;
  margin:0 auto 56px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.gb-form .field{ margin:0; }
.gb-form .field--full{ grid-column:1 / -1; }
.gb-form button{ grid-column:1 / -1; justify-self:center; }
@media (max-width:600px){ .gb-form{ grid-template-columns:1fr; } }
.gb-list{
  max-width:760px;
  margin:0 auto;
  display:grid;
  gap:24px;
}
.gb-entry{
  position:relative;
  padding:34px 36px 32px;
  background:var(--paper);
  border:1px solid rgba(176,138,74,.25);
}
.gb-entry::before{
  content:"“";
  position:absolute;
  top:-14px; left:18px;
  font-family:var(--ff-display);
  font-size:8rem;
  line-height:1;
  color:var(--gold);
  opacity:.2;
  pointer-events:none;
}
.gb-entry__msg{
  font-family:var(--ff-serif);
  font-style:italic;
  font-size:1.15rem;
  color:var(--ink);
  line-height:1.65;
  margin:0 0 14px;
}
.gb-entry__meta{
  display:flex; justify-content:space-between;
  font-family:var(--ff-sans);
  font-size:.72rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.gb-entry__name{ color:var(--gold); }

/* ───────────────────── galerij ───────────────────── */
.gallery{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  grid-auto-rows:200px;
  gap:14px;
}
.gallery .ph{ aspect-ratio:auto; }
.gallery .g-tall{ grid-row:span 2; }
.gallery .g-wide{ grid-column:span 2; }
@media (max-width:800px){
  .gallery{ grid-template-columns:repeat(2,1fr); grid-auto-rows:160px; }
  .gallery .g-wide{ grid-column:span 2; }
}

/* lightbox */
.lightbox{
  position:fixed; inset:0; z-index:200;
  background:rgba(15,26,46,.94);
  display:none;
  align-items:center; justify-content:center;
  padding:40px;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.lightbox.open{ display:flex; animation:fadeIn .35s ease; }
@keyframes fadeIn{ from{opacity:0;} to{opacity:1;} }
.lightbox__inner{
  position:relative;
  max-width:1100px; width:100%;
  aspect-ratio:16/10;
  background:
    repeating-linear-gradient(45deg,
      rgba(232,213,168,.10) 0 2px,
      rgba(232,213,168,.03) 2px 22px),
    linear-gradient(135deg, var(--navy-mid), var(--navy-deep));
  border:1px solid rgba(176,138,74,.4);
}
.lightbox__label{
  position:absolute; bottom:24px; left:32px;
  font-family:var(--ff-display);
  color:var(--gold-light);
  font-size:1.5rem;
  letter-spacing:.06em;
}
.lightbox__close{
  position:absolute; top:30px; right:30px;
  width:46px; height:46px;
  background:transparent;
  border:1px solid var(--gold);
  color:var(--gold-light);
  font-size:1.3rem;
  cursor:pointer;
  transition:background .3s, color .3s;
}
.lightbox__close:hover{ background:var(--gold); color:var(--navy-deep); }

/* ───────────────────── dresscode ───────────────────── */
.dresscode{
  background:
    radial-gradient(800px 500px at 50% 0%, rgba(176,138,74,.16), transparent 60%),
    linear-gradient(180deg, var(--navy-deep), var(--navy) 60%, var(--navy-deep));
  color:var(--cream);
}
.dresscode .section-title{ color:var(--cream); }
.dresscode .section-head .eyebrow{ color:var(--gold-light); }
.dresscode .section-head p{ color:rgba(245,237,224,.75); }
.dresscode .ornament{ background:linear-gradient(90deg, transparent, var(--gold), transparent); }
.dresscode .ornament::after{ background:var(--navy); color:var(--gold-light); }
.dc-card{
  position:relative;
  max-width:880px; margin:0 auto;
  padding:64px 56px;
  background:rgba(15,26,46,.6);
  border:1px solid var(--gold);
  text-align:center;
}
.dc-card::before{
  content:""; position:absolute; inset:8px;
  border:1px solid rgba(176,138,74,.35);
  pointer-events:none;
}
.dc-card__head{
  font-family:var(--ff-display);
  font-size:clamp(2.4rem, 5vw, 3.6rem);
  color:var(--gold-light);
  letter-spacing:.04em;
  line-height:1;
}
.dc-card__sub{
  font-family:var(--ff-serif);
  font-style:italic;
  color:var(--gold-soft);
  font-size:1.1rem;
  margin-top:14px;
}
.dc-split{
  display:grid; grid-template-columns:1fr auto 1fr;
  gap:48px; align-items:start;
  margin-top:48px;
  text-align:left;
}
.dc-split__divider{
  width:1px; align-self:stretch;
  background:linear-gradient(180deg, transparent, var(--gold) 30%, var(--gold) 70%, transparent);
}
.dc-col h4{
  font-family:var(--ff-serif);
  font-style:italic;
  font-weight:400;
  font-size:1.6rem;
  color:var(--gold-light);
  margin-bottom:18px;
  letter-spacing:.04em;
}
.dc-col ul{
  list-style:none; padding:0; margin:0;
  font-family:var(--ff-serif);
  font-size:1.08rem;
  color:rgba(245,237,224,.88);
  line-height:1.8;
}
.dc-col li{
  padding:6px 0 6px 22px;
  position:relative;
}
.dc-col li::before{
  content:"◆"; position:absolute; left:0; top:10px;
  font-size:.55rem; color:var(--gold);
}
.dc-note{
  margin-top:40px;
  padding-top:30px;
  border-top:1px solid rgba(176,138,74,.3);
  font-family:var(--ff-serif);
  font-style:italic;
  font-size:1.05rem;
  color:rgba(245,237,224,.78);
  max-width:620px;
  margin-left:auto; margin-right:auto;
}
.dc-palette{
  display:flex; gap:24px; justify-content:center; flex-wrap:wrap;
  margin-top:32px;
}
.dc-swatch{
  display:flex; flex-direction:column; align-items:center; gap:10px;
  border:none;
  width:auto; height:auto;
  position:relative;
  background:transparent !important;
}
.dc-swatch::before{
  content:"";
  display:block;
  width:52px; height:52px;
  background:var(--c, #000);
  border:1px solid rgba(176,138,74,.4);
}
.dc-swatch::after{
  content:attr(data-label);
  position:static;
  transform:none;
  font-family:var(--ff-sans);
  font-size:.62rem; text-transform:uppercase; letter-spacing:.18em;
  color:rgba(245,237,224,.65);
  white-space:nowrap;
}
@media (max-width:760px){
  .dc-card{ padding:48px 26px; }
  .dc-split{ grid-template-columns:1fr; gap:30px; }
  .dc-split__divider{ width:60%; height:1px; justify-self:center; background:linear-gradient(90deg, transparent, var(--gold), transparent); }
}

/* ───────────────────── cadeau ───────────────────── */
.gift-tip{
  max-width:680px; margin:0 auto;
  position:relative;
  padding:36px 44px 36px 56px;
  background:var(--paper);
  border-left:2px solid var(--gold);
  font-family:var(--ff-serif);
  font-style:italic;
  font-size:1.18rem;
  line-height:1.7;
  color:var(--ink);
  box-shadow:0 18px 40px rgba(15,26,46,.06);
}
.gift-tip::before{
  content:"“";
  position:absolute;
  top:-22px; left:18px;
  font-family:var(--ff-display);
  font-size:6rem; line-height:1;
  color:var(--gold);
  opacity:.35;
}
@media (max-width:600px){
  .gift-tip{ padding:30px 26px 30px 32px; font-size:1.05rem; }
}

.welkom{ padding-top:90px; padding-bottom:90px; }
.welkom .cm-intro{ margin:0 auto; }
.welkom__eyebrow{
  display:block;
  margin-bottom:20px;
  text-align:center;
}
.welkom .cm-intro{ background:var(--paper); }

/* ───────────────────── ceremoniemeesters ───────────────────── */
.cm-intro{
  position:relative;
  max-width:760px;
  margin:0 auto 56px;
  padding:48px 56px 44px;
  background:var(--paper);
  border:1px solid rgba(176,138,74,.28);
  text-align:center;
}
.cm-intro::before{
  content:"“";
  position:absolute;
  top:-14px; left:24px;
  font-family:var(--ff-display);
  font-size:7rem; line-height:1;
  color:var(--gold);
  opacity:.25;
  pointer-events:none;
}
.cm-intro p{
  font-family:var(--ff-serif);
  font-style:italic;
  font-size:1.18rem;
  line-height:1.75;
  color:var(--ink);
  margin:0 0 22px;
}
.cm-intro p + p{ margin-top:14px; }
.cm-intro__sign{
  display:inline-block;
  margin-top:6px;
  padding-top:18px;
  border-top:1px solid rgba(176,138,74,.3);
  font-family:var(--ff-display);
  font-size:1.25rem;
  letter-spacing:.04em;
  color:var(--gold);
}
.cm-intro__role{
  display:block;
  font-family:var(--ff-sans);
  font-style:normal;
  font-size:.68rem;
  text-transform:uppercase;
  letter-spacing:.32em;
  color:var(--ink-soft);
  margin-top:6px;
}
@media (max-width:600px){
  .cm-intro{ padding:40px 26px; }
  .cm-intro p{ font-size:1.05rem; }
}
.cm-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
  max-width:820px;
  margin:0 auto;
}
@media (max-width:700px){ .cm-grid{ grid-template-columns:1fr; } }
.cm-split {
  display: grid;
  grid-template-columns: 0.7fr 1fr;
  gap: 32px;
  max-width: 1000px;
  margin: 0 auto;
  align-items: center;
}
.cm-split__photo {
  aspect-ratio: 3/4;
  width: 100%;
}
.cm-split__list {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media (max-width: 600px) {
  .cm-split {
    grid-template-columns: 0.8fr 1fr;
    gap: 16px;
  }
  .cm-split__list {
    gap: 14px;
  }
}

.cm{
  padding:24px 20px;
  text-align:left;
  background:var(--paper);
  border:1px solid rgba(176,138,74,.28);
  transition:transform .35s ease, box-shadow .35s ease;
}
.cm:hover{ transform:translateY(-3px); box-shadow:0 20px 50px rgba(15,26,46,.12); }
.cm h4{
  font-family:var(--ff-display);
  font-size:clamp(1.2rem, 3vw, 1.6rem);
  margin-bottom:6px;
  line-height:1.1;
}
.cm__role{
  font-family:var(--ff-serif);
  font-style:italic;
  color:var(--gold);
  margin-bottom:22px;
}
.cm a{
  display:block;
  font-family:var(--ff-sans);
  font-size:clamp(.78rem, 2vw, .9rem);
  text-decoration:none;
  padding:4px 0;
  color:var(--ink);
  letter-spacing:.04em;
  word-break:break-word;
  transition:color .3s ease;
}
.cm a:hover{ color:var(--gold); }

/* ───────────────────── footer ───────────────────── */
.footer{
  background:
    radial-gradient(700px 400px at 50% 30%, rgba(176,138,74,.14), transparent 60%),
    var(--navy-deep);
  color:var(--cream);
  padding:100px var(--pad) 68px;
  text-align:center;
  position:relative;
}
.footer .ornament{ background:linear-gradient(90deg, transparent, var(--gold), transparent); margin-bottom:48px; }
.footer__name{
  font-family:var(--ff-display);
  font-size:clamp(3rem, 9vw, 5.4rem);
  letter-spacing:.04em;
  color:var(--cream);
  line-height:1;
}
.footer__date{
  display:flex; align-items:center; justify-content:center; gap:clamp(14px, 2.4vw, 26px);
  margin-top:36px;
}
.footer__date .n{
  font-family:var(--ff-display);
  font-size:clamp(1.8rem, 4vw, 2.6rem);
  color:var(--gold-light);
  letter-spacing:.08em;
  line-height:1;
}
.footer__date .s{
  display:inline-block;
  width:6px; height:6px; transform:rotate(45deg);
  background:var(--gold);
}
.footer__sub{
  font-family:var(--ff-sans);
  font-size:.72rem;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:rgba(232,213,168,.55);
  margin-top:42px;
}

/* ───────────────────── reveal ───────────────────── */
.reveal{
  opacity:0;
  transform:translateY(36px);
  transition:opacity 1s ease, transform 1s cubic-bezier(.2,.7,.2,1);
}
.reveal.in{ opacity:1; transform:translateY(0); }

/* parallax helper */
.parallax{ will-change:transform; }

/* ───────────────────── admin ───────────────────── */
.admin-toolbar{
  position:fixed; bottom:20px; right:20px; z-index:300;
  display:flex; align-items:center; gap:6px; flex-wrap:wrap;
  padding:8px 10px;
  max-width:calc(100vw - 40px);
  background:rgba(15,26,46,.96);
  color:var(--cream);
  border:1px solid var(--gold);
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
  font-family:var(--ff-sans);
  font-size:.7rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  box-shadow:0 18px 50px rgba(0,0,0,.45);
}
.admin-toolbar[hidden]{ display:none; }
.admin-toolbar__brand{
  font-family:var(--ff-display);
  font-size:.95rem;
  letter-spacing:.12em;
  color:var(--gold-light);
  padding:0 12px 0 6px;
  text-transform:none;
  border-right:1px solid rgba(176,138,74,.3);
  margin-right:4px;
}
.admin-toolbar__hint{
  color:rgba(245,237,224,.55);
  font-style:italic;
  letter-spacing:.05em;
  text-transform:none;
  padding:0 8px;
  flex-basis:100%;
  font-size:.7rem;
}
.admin-toolbar button{
  background:transparent;
  color:var(--cream);
  border:1px solid rgba(176,138,74,.4);
  padding:7px 12px;
  cursor:pointer;
  font:inherit;
  letter-spacing:inherit;
  text-transform:inherit;
  transition:all .2s;
}
.admin-toolbar button[hidden]{ display:none; }
.admin-toolbar button:hover{
  background:var(--gold);
  color:var(--navy-deep);
  border-color:var(--gold);
}
.admin-toolbar button.active{
  background:var(--gold);
  color:var(--navy-deep);
  border-color:var(--gold);
}
.admin-toolbar__close{
  margin-left:4px;
  padding:7px 10px !important;
}

.admin-modal{
  position:fixed; inset:0; z-index:400;
  background:rgba(15,26,46,.85);
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center;
  padding:20px;
}
.admin-modal[hidden]{ display:none; }
.admin-modal__inner{
  background:var(--paper);
  border:1px solid var(--gold);
  padding:48px 40px;
  max-width:440px; width:100%;
  position:relative;
}
.admin-modal__inner::before{
  content:""; position:absolute; inset:8px;
  border:1px solid rgba(176,138,74,.3);
  pointer-events:none;
}
.admin-modal .eyebrow{ display:block; margin-bottom:14px; }
.admin-modal h3{
  font-family:var(--ff-display);
  font-size:2rem;
  margin-bottom:10px;
  color:var(--navy);
}
.admin-modal p{
  font-family:var(--ff-serif);
  color:var(--ink-soft);
  margin:0 0 26px;
  font-size:1rem;
  line-height:1.6;
}
.admin-modal input{
  width:100%;
  padding:12px 4px;
  background:transparent;
  border:none;
  border-bottom:1px solid rgba(176,138,74,.4);
  font-family:var(--ff-serif);
  font-size:1.1rem;
  outline:none;
  margin-bottom:24px;
}
.admin-modal input:focus{ border-bottom-color:var(--gold); }
.admin-modal__row{ display:flex; gap:10px; justify-content:flex-end; }
.admin-modal button{
  font-family:var(--ff-sans);
  font-size:.74rem;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.22em;
  padding:13px 24px;
  border:1px solid var(--navy);
  background:transparent;
  color:var(--navy);
  cursor:pointer;
  transition:all .2s;
}
.admin-modal button.primary{ background:var(--navy); color:var(--cream); }
.admin-modal button:hover{ background:var(--gold); color:var(--navy-deep); border-color:var(--gold); }
.admin-modal__err{
  margin-top:16px;
  color:#a04a4a;
  font-style:italic;
  font-size:.95rem;
}
.admin-modal__err[hidden]{ display:none; }

/* edit-mode visuals */
.edit-mode [contenteditable="true"]{
  cursor:text;
  outline-offset:3px;
  transition:outline .15s, background .15s;
}
.edit-mode [contenteditable="true"]:hover{
  outline:1px dashed rgba(176,138,74,.65);
  background:rgba(176,138,74,.06);
}
.edit-mode [contenteditable="true"]:focus{
  outline:1px solid var(--gold);
  background:rgba(176,138,74,.10);
}
.edit-mode .nav__links a,
.edit-mode .nav__brand,
.edit-mode .topbar a{ pointer-events:auto; }
