/* =========================================================================
   Hennie & Jolinda — Eukalyptus Trouportaal (gaste-werf)
   Herskep van die Claude Design-ontwerp. Kleure/fonte as veranderlikes.
   ========================================================================= */
:root{
  --cream:#FAF6EE; --cream2:#F2ECDD; --card:#fff;
  --ink:#34402A; --ink2:#2b3322;
  --olive:#4F5D3A; --sage:#8C9A6E; --sage2:#6E7C50; --sage3:#5C6B43;
  --gold:#b9a77e; --gold2:#cdbf9e; --sand:#CFC2A0;
  --muted:#5b6150; --muted2:#7a7f6c; --muted3:#9aa088; --muted4:#8a8f7c;
  --line:rgba(110,124,80,.18); --line2:rgba(110,124,80,.3);
  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Jost','Segoe UI',system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:110px}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--cream)}
img{max-width:100%;display:block}
button{font-family:inherit}

[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity 1s cubic-bezier(.2,.7,.2,1),transform 1s cubic-bezier(.2,.7,.2,1)}
[data-reveal].in{opacity:1;transform:none}
@keyframes kenburns{0%{transform:scale(1.04)}100%{transform:scale(1.15)}}
@keyframes twinkle{0%,100%{opacity:.15;transform:scale(.6)}50%{opacity:1;transform:scale(1.1)}}
@keyframes fadeup{0%{opacity:0;transform:translateY(22px)}100%{opacity:1;transform:translateY(0)}}
@keyframes growline{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@keyframes scrollcue{0%{transform:translateY(-110%)}100%{transform:translateY(320%)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

.hidden{display:none !important}

/* ───── Velde (gate) ───── */
.fld{font-family:var(--serif);font-size:20px;color:var(--ink);background:rgba(255,255,255,.9);
  border:1px solid rgba(110,124,80,.3);border-radius:2px;padding:14px 16px;width:100%;outline:none;transition:border-color .25s}
.fld:focus{border-color:var(--sage)}
.fld::placeholder{color:#a6ab97;font-style:italic}

.link{position:relative;background:none;border:0;cursor:pointer;color:var(--muted3);
  font-family:var(--sans);font-size:10px;letter-spacing:2px;text-transform:uppercase}
.link::after{content:'';position:absolute;left:0;bottom:-4px;width:0;height:1px;background:var(--sage2);transition:width .3s}
.link:hover::after{width:100%}

/* ════════ GATE ════════ */
.gate{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:24px}
.gate__bg{position:absolute;inset:0;background:url('../foto/wandel.jpg') center 28%/cover no-repeat;animation:kenburns 30s ease-in-out infinite alternate}
.gate__veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(34,42,26,.78),rgba(40,49,32,.6),rgba(28,35,20,.82))}
.gate__card{position:relative;width:100%;max-width:430px;background:rgba(250,246,238,.97);border-radius:5px;
  box-shadow:0 40px 90px -30px rgba(20,26,14,.7);padding:48px 40px;text-align:center;animation:fadeup 1s ease both}
.gate__names{font-family:var(--serif);font-style:italic;font-size:30px;color:var(--sage)}
.gate__names .amp{color:var(--gold);font-size:22px}
.gate__sub{font-family:var(--sans);font-size:10px;letter-spacing:4px;text-transform:uppercase;color:#a6ab97;margin:10px 0 30px}
.gate__h{font-family:var(--serif);font-weight:300;font-size:34px;margin:0 0 8px;color:var(--ink)}
.gate__p{font-family:var(--serif);font-size:17px;font-weight:300;line-height:1.6;color:var(--muted);margin:0 0 28px}
.gate__err{font-family:var(--sans);font-size:12px;color:#c6543f;letter-spacing:.5px;margin:14px 0 0}
.gate__btn{margin-top:24px;width:100%;font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:3px;
  text-transform:uppercase;color:var(--cream);background:var(--ink);border:0;border-radius:2px;padding:17px;cursor:pointer;transition:background .3s}
.gate__btn:hover{background:var(--olive)}
.gate__foot{margin-top:24px;display:flex;justify-content:center;gap:18px}
.gate__hint{font-family:var(--sans);font-size:10px;color:#bcae8f;margin:22px 0 0;letter-spacing:.5px}

/* paper grein */
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px 180px}

/* ════════ NAV ════════ */
.nav{position:sticky;top:0;z-index:500;background:rgba(250,246,238,.92);backdrop-filter:blur(12px);
  border-top:2px solid var(--gold);border-bottom:1px solid var(--line)}
.nav__in{max-width:1180px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:14px 26px}
.nav__brand{background:none;border:0;cursor:pointer;font-family:var(--serif);font-style:italic;font-size:22px;color:var(--olive)}
.nav__links{display:flex;align-items:center;gap:26px;overflow-x:auto}
.nav__link{background:none;border:0;cursor:pointer;font-family:var(--sans);font-size:11px;font-weight:400;letter-spacing:2px;
  text-transform:uppercase;color:#6b7257;white-space:nowrap;position:relative}
.nav__link::after{content:'';position:absolute;left:0;bottom:-4px;width:0;height:1px;background:var(--sage2);transition:width .3s}
.nav__link:hover::after{width:100%}
.nav__rsvp{background:var(--olive);border:0;cursor:pointer;font-family:var(--sans);font-size:11px;font-weight:500;
  letter-spacing:2px;text-transform:uppercase;color:var(--cream);padding:10px 18px;border-radius:2px;white-space:nowrap}
/* Hamburger-knoppie — versteek op groot skerms, wys op tablet/mobiel (sien media-navraag onder) */
.nav__toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:40px;
  background:none;border:0;cursor:pointer;padding:9px 8px}
.nav__toggle span{display:block;height:2px;width:100%;background:var(--olive);border-radius:2px;
  transition:transform .3s ease,opacity .2s ease}

/* ════════ algemene afdeling-elemente ════════ */
.wrap{max-width:1180px;margin:0 auto;padding:0 26px}
.eyebrow{display:flex;align-items:center;justify-content:center;gap:13px;margin:0 0 16px}
.eyebrow span.l{width:34px;height:1px;background:rgba(185,167,126,.65)}
.eyebrow span.d{width:6px;height:6px;background:var(--gold);transform:rotate(45deg);display:inline-block}
.kicker{font-family:var(--sans);font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--sage2);margin:0 0 14px}
.h2{font-family:var(--serif);font-weight:300;font-size:clamp(34px,5vw,54px);color:var(--ink);margin:0}
.h2 em{font-style:italic;color:var(--sage2)}
.center{text-align:center}

.btn-fill{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--cream);
  background:var(--olive);border:0;padding:16px 32px;border-radius:2px;cursor:pointer;box-shadow:0 14px 30px -14px rgba(52,64,42,.7);transition:all .3s}
.btn-fill:hover{background:#3f4a2e;transform:translateY(-2px)}
.btn-ghost{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--olive);
  background:none;border:1px solid rgba(79,93,58,.4);padding:16px 32px;border-radius:2px;cursor:pointer;transition:all .3s;text-decoration:none;display:inline-block}
.btn-ghost:hover{background:rgba(79,93,58,.07);border-color:rgba(79,93,58,.7)}

/* ════════ HERO ════════ */
.hero{position:relative;overflow:hidden;max-width:1180px;margin:0 auto;padding:clamp(48px,7vw,96px) 26px clamp(78px,9vw,112px);
  display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(28px,5vw,76px);align-items:center;min-height:90vh}
.hero__pre{display:flex;align-items:center;gap:16px;margin:0 0 24px;animation:fadeup 1s ease .1s both}
.hero__pre span{width:40px;height:1px;background:var(--gold);display:inline-block;transform-origin:left;animation:growline 1.1s ease .35s both}
.hero__pre p{font-family:var(--sans);font-size:11px;letter-spacing:5px;text-transform:uppercase;color:var(--sage2);margin:0}
.hero__names{font-family:var(--serif);font-weight:300;color:var(--ink);line-height:.92;margin:0;
  animation:fadeup 1.1s ease .25s both;font-size:clamp(58px,9.4vw,116px)}
.hero__names em{font-style:italic;color:var(--sage3)}
.hero__meta{display:flex;align-items:center;gap:18px;margin:30px 0 28px;animation:fadeup 1.1s ease .55s both}
.hero__meta span{width:66px;height:1px;background:var(--gold);display:inline-block;transform-origin:left;animation:growline 1.1s ease .8s both}
.hero__meta p{font-family:var(--sans);font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--muted4);margin:0}
.hero__intro{font-family:var(--serif);font-size:clamp(19px,2.4vw,23px);font-weight:300;line-height:1.7;color:var(--muted);
  max-width:440px;margin:0;animation:fadeup 1.1s ease .65s both}
.hero__cta{display:flex;gap:14px;margin-top:38px;flex-wrap:wrap;animation:fadeup 1.1s ease .8s both}
.hero__media{position:relative;animation:fadeup 1.2s ease .35s both}
.hero__frame{position:absolute;inset:-16px;border:1px solid rgba(110,124,80,.35);border-radius:290px 290px 6px 6px;pointer-events:none}
.hero__img{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:270px 270px 6px 6px;box-shadow:0 38px 84px -30px rgba(52,64,42,.62)}
.hero__img .bg{position:absolute;inset:0;background:url('../foto/wandel.jpg') center 26%/cover no-repeat;animation:kenburns 26s ease-in-out infinite alternate}
.hero__img .veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(34,42,26,0) 58%,rgba(34,42,26,.3))}
.twinkle{position:absolute;background:radial-gradient(circle,#fff 0%,rgba(255,255,255,.8) 22%,transparent 60%);animation:twinkle 3.6s ease-in-out infinite}
.hero__badge{position:absolute;left:-28px;bottom:38px;width:106px;height:106px;border-radius:50%;background:var(--cream);
  border:1px solid rgba(185,167,126,.7);box-shadow:0 18px 40px -16px rgba(52,64,42,.55);display:flex;flex-direction:column;
  align-items:center;justify-content:center;animation:floaty 6s ease-in-out infinite}
.hero__badge i{position:absolute;inset:7px;border-radius:50%;border:1px solid rgba(185,167,126,.32)}
.hero__badge b{font-family:var(--serif);font-style:italic;font-size:31px;color:var(--sage3);line-height:1;font-weight:400}
.hero__badge small{font-family:var(--sans);font-size:8px;letter-spacing:2px;text-transform:uppercase;color:var(--muted3);margin-top:4px}
.hero__cue{position:absolute;left:26px;bottom:26px;display:flex;align-items:center;gap:12px;animation:fadeup 1s ease 1.2s both}
.hero__cue .track{position:relative;width:1px;height:44px;background:rgba(110,124,80,.22);overflow:hidden;display:inline-block}
.hero__cue .track i{position:absolute;left:0;top:0;width:1px;height:14px;background:var(--sage2);animation:scrollcue 1.9s ease-in-out infinite}
.hero__cue span{font-family:var(--sans);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--muted3)}

/* ════════ COUNTDOWN ════════ */
.cd-band{background:var(--cream2);border-top:1px solid rgba(110,124,80,.15);border-bottom:1px solid rgba(110,124,80,.15)}
.cd-band .inner{max-width:1180px;margin:0 auto;padding:clamp(48px,6vw,80px) 26px;text-align:center}
.cd-pre{font-family:var(--sans);font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--sage2);margin:0 0 36px}
.cd{display:flex;align-items:stretch;justify-content:center;gap:clamp(12px,2.4vw,24px);flex-wrap:wrap}
.cd__cell{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;width:clamp(76px,13vw,130px);
  padding:clamp(16px,2.6vw,28px) 8px;background:var(--cream);border:1px solid rgba(185,167,126,.5);border-radius:4px;box-shadow:0 18px 42px -26px rgba(52,64,42,.5)}
.cd__cell i{position:absolute;inset:6px;border:1px solid rgba(185,167,126,.2);border-radius:2px;pointer-events:none}
.cd__num{font-family:var(--serif);font-weight:300;font-size:clamp(40px,6.4vw,72px);line-height:1;color:var(--ink)}
.cd__line{width:26px;height:1px;background:var(--gold2);margin:11px 0 9px}
.cd__lab{font-family:var(--sans);font-size:10px;font-weight:400;letter-spacing:3px;text-transform:uppercase;color:var(--sage2)}
.cd__cell--dark{background:var(--ink)}
.cd__cell--dark .cd__num{color:#eef0e3}
.cd__cell--dark .cd__line{background:var(--sage)}
.cd__cell--dark .cd__lab{color:#a7b58c}
.cd__cell--dark i{border-color:rgba(205,214,180,.18)}
.cd-cap{font-family:var(--serif);font-style:italic;font-size:21px;color:var(--muted4);margin:34px 0 0}

/* ════════ SEKSIES ════════ */
.section{padding:clamp(56px,9vw,110px) 26px}
.section--alt{background:var(--cream2)}
.section--ink{background:var(--ink);color:#eef0e3}
.section-narrow{max-width:1080px;margin:0 auto}
.section-mid{max-width:760px;margin:0 auto}
.head{text-align:center;margin-bottom:clamp(40px,6vw,64px)}

/* ── twee-kolom storie ── */
.two{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);align-items:center}
.two + .two{margin-top:clamp(40px,6vw,80px)}
.two__img{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:4px}
.two__img img{width:100%;height:100%;object-fit:cover}
.two__img i{position:absolute;inset:10px;border:1px solid rgba(250,246,238,.45);pointer-events:none;border-radius:2px}
.two__img--l{box-shadow:8px 8px 0 rgba(110,124,80,.16)}
.two__img--r{box-shadow:-8px 8px 0 rgba(110,124,80,.16)}
.chap{display:flex;align-items:center;gap:14px;margin:0 0 16px}
.chap b{font-family:var(--serif);font-style:italic;font-size:42px;color:var(--gold2);line-height:1;font-weight:400}
.chap span.l{width:30px;height:1px;background:var(--gold2)}
.chap span.t{font-family:var(--sans);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--muted3)}
.chap-h{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(26px,3vw,34px);color:var(--ink);margin:0 0 18px}
.prose{font-family:var(--serif);font-size:19px;font-weight:300;line-height:1.85;color:var(--muted);margin:0 0 16px}
.prose:last-child{margin-bottom:0}

/* ── program ── */
.day{display:flex;align-items:center;gap:16px;background:#e3dcc7;border-left:3px solid var(--sage2);padding:14px 20px;margin:8px 0 26px}
.day:first-child{margin-top:0}
.day b{font-family:var(--serif);font-size:30px;font-weight:300;color:var(--olive);line-height:1}
.day .d1{font-family:var(--sans);font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--ink)}
.day .d2{font-family:var(--sans);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted3)}
.tl{display:grid;grid-template-columns:96px 1fr;gap:20px;padding:0 0 26px;border-left:1px solid var(--line2);margin-left:8px;padding-left:26px;position:relative}
.tl:last-child{padding-bottom:0}
.tl i{position:absolute;left:-5px;top:5px;width:9px;height:9px;border-radius:50%;background:var(--cream);border:1.5px solid var(--sage2)}
.tl .t{font-family:var(--sans);font-size:12px;letter-spacing:2px;color:var(--sage2);padding-top:2px}
.tl h4{font-family:var(--serif);font-weight:500;font-size:22px;color:var(--ink);margin:0 0 4px}
.tl p{font-family:var(--serif);font-size:17px;font-weight:300;color:var(--muted2);margin:0;line-height:1.6}

/* ── galery ── */
.gal{column-count:3;column-gap:18px}
.gal__tile{break-inside:avoid;margin-bottom:18px;width:100%;display:block;padding:0;border:0;background:#e7e1d2;cursor:pointer;overflow:hidden;position:relative;border-radius:3px}
.gal__tile img{width:100%;display:block;transition:transform .9s cubic-bezier(.2,.7,.2,1),filter .6s ease;filter:saturate(.96)}
.gal__tile:hover img{transform:scale(1.045);filter:saturate(1.05)}
.gal__tile::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(52,64,42,.28));opacity:0;transition:opacity .5s}
.gal__tile:hover::after{opacity:1}
.lb{position:fixed;inset:0;z-index:9000;background:rgba(28,35,20,.94);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:3vw}
.lb img{max-width:88vw;max-height:88vh;object-fit:contain;border-radius:3px;box-shadow:0 30px 80px -20px rgba(0,0,0,.7)}
.lb__x{position:absolute;top:22px;right:26px;background:none;border:0;color:#cdd6b4;font-family:var(--sans);font-size:12px;letter-spacing:3px;text-transform:uppercase;cursor:pointer}
.lb__nav{position:absolute;top:50%;transform:translateY(-50%);background:none;border:0;color:#cdd6b4;font-size:38px;cursor:pointer;padding:18px;line-height:1}
.lb__nav--prev{left:18px}.lb__nav--next{right:18px}
.lb__count{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);font-family:var(--sans);font-size:11px;letter-spacing:3px;color:rgba(205,214,180,.8)}

/* ── verblyf ── */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.vcard{background:#fff;border:1px solid var(--line);border-radius:4px;padding:30px 28px;transition:transform .35s,box-shadow .35s}
.vcard:hover{transform:translateY(-5px);box-shadow:0 26px 52px -28px rgba(52,64,42,.45)}
.vcard .dot{display:inline-block;width:9px;height:9px;background:var(--sage);transform:rotate(45deg);margin-bottom:18px}
.vcard h3{font-family:var(--serif);font-weight:500;font-size:24px;color:var(--ink);margin:0 0 4px}
.vcard .far{font-family:var(--sans);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted3)}
.vcard p{font-family:var(--serif);font-size:17px;font-weight:300;line-height:1.65;color:#6b7257;margin:14px 0 0}
.vnote{text-align:center;font-family:var(--serif);font-style:italic;font-size:19px;color:var(--muted4);margin:34px auto 0;max-width:560px}
/* Ligging-kaart onderaan Verblyf */
.vmap{margin-top:38px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;
  background:var(--card);border:1px solid var(--line2);border-top:2px solid var(--gold);
  border-radius:4px;padding:26px 30px;box-shadow:0 24px 50px -32px rgba(52,64,42,.45)}
.vmap__pin{flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  width:52px;height:52px;border-radius:50%;color:var(--olive);
  background:var(--cream2);border:1px solid var(--gold2)}
.vmap__txt{flex:1;min-width:220px}
.vmap__kicker{margin:0 0 3px;font-family:var(--sans);font-size:10px;font-weight:500;
  letter-spacing:2.5px;text-transform:uppercase;color:var(--muted3)}
.vmap__txt h3{margin:0 0 5px;font-family:var(--serif);font-weight:500;font-size:26px;color:var(--ink)}
.vmap__sub{margin:0;font-family:var(--serif);font-size:16.5px;font-weight:300;line-height:1.55;color:#6b7257}
.vmap__btn{flex:0 0 auto;display:inline-flex;align-items:center;background:var(--olive);color:var(--cream);
  text-decoration:none;font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:2px;
  text-transform:uppercase;padding:14px 22px;border-radius:2px;white-space:nowrap;
  transition:background .3s,transform .3s}
.vmap__btn:hover{background:var(--sage3);transform:translateY(-2px)}
@media (max-width:640px){
  .vmap{flex-direction:column;text-align:center;padding:28px 22px;gap:14px}
  .vmap__btn{width:100%;justify-content:center}
}

/* ── tema ── */
.swatches{display:flex;gap:18px;margin-top:32px;flex-wrap:wrap}
.sw{text-align:center}
.sw i{display:block;width:60px;height:60px;border-radius:50%;box-shadow:inset 0 0 0 1px rgba(110,124,80,.25),0 8px 18px -10px rgba(52,64,42,.4)}
.sw span{font-family:var(--sans);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted3);display:block;margin-top:10px}

/* ── geskenke ── */
.gift-p{font-family:var(--serif);font-size:20px;font-weight:300;line-height:1.8;color:rgba(238,240,227,.85);margin:0 auto 36px;max-width:520px}
.bankbox{position:relative;display:inline-block;text-align:left;background:rgba(255,255,255,.05);border:1px solid rgba(205,214,180,.25);border-radius:4px;padding:34px 44px}
.bankbox i{position:absolute;inset:7px;border:1px solid rgba(205,214,180,.12);border-radius:2px;pointer-events:none}
.bankrow{display:flex;justify-content:space-between;gap:40px;padding:9px 0;border-bottom:1px solid rgba(205,214,180,.12)}
.bankrow:last-child{border-bottom:0}
.bankrow .k{font-family:var(--sans);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:#a7b58c}
.bankrow .v{font-family:var(--serif);font-size:19px;color:#fdfbf4}
.section--ink .eyebrow span.l{background:rgba(205,214,180,.4)}
.section--ink .eyebrow span.d{background:#a7b58c}
.section--ink .kicker{color:#a7b58c}
.section--ink .h2{color:#fdfbf4}
.section--ink .h2 em{color:#cdd6b4}

/* ── vrae ── */
.det{border-bottom:1px solid rgba(110,124,80,.22)}
.det summary{display:flex;justify-content:space-between;align-items:center;gap:20px;padding:22px 4px;list-style:none;cursor:pointer}
.det summary::-webkit-details-marker{display:none}
.det .q{display:flex;align-items:center;gap:16px}
.det .q i{width:7px;height:7px;background:var(--gold2);transform:rotate(45deg);flex-shrink:0;display:inline-block}
.det .q span{font-family:var(--serif);font-size:23px;font-weight:400;color:var(--ink)}
.det .plus{flex-shrink:0;font-family:var(--sans);font-size:22px;color:var(--sage);transition:transform .3s;line-height:1}
.det[open] .plus{transform:rotate(45deg)}
.det p{font-family:var(--serif);font-size:18px;font-weight:300;line-height:1.75;color:#6b7257;margin:0 4px 24px}

/* ── rsvp ── */
.rsvp-sub{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--muted4);margin:18px 0 0}
.rsvp-card{background:#fff;border:1px solid rgba(110,124,80,.16);border-radius:5px;padding:clamp(28px,5vw,52px);box-shadow:0 24px 60px -34px rgba(52,64,42,.5);max-width:620px;margin:0 auto}
.rin{font-family:var(--serif);font-size:20px;font-weight:400;color:var(--ink);background:transparent;border:0;border-bottom:1px solid rgba(110,124,80,.32);border-radius:0;padding:11px 2px;width:100%;outline:none;transition:border-color .25s}
.rin:focus{border-bottom-color:var(--sage2)}
.rin::placeholder{color:#a6ab97;font-style:italic}
textarea.rin{min-height:86px;resize:vertical;line-height:1.55;border:1px solid rgba(110,124,80,.26);border-radius:3px;background:#fbf8f1;padding:13px 15px;font-size:18px}
textarea.rin:focus{border-color:var(--sage)}
.rq{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--sage2);margin:0 0 16px;display:block}
.rnum{font-family:var(--serif);font-style:italic;font-size:27px;color:var(--gold2);line-height:1;flex-shrink:0}
.rgrp{padding-top:28px;border-top:1px solid rgba(110,124,80,.16)}
.rrow{display:flex;align-items:baseline;gap:14px;margin:0 0 16px}
.choices{display:flex;gap:14px;flex-wrap:wrap}
.choice{font-family:var(--sans);font-size:13px;font-weight:400;letter-spacing:1px;padding:15px 22px;border-radius:3px;cursor:pointer;
  transition:all .25s;flex:1;text-align:center;background:#fbf8f1;color:var(--olive);border:1px solid rgba(79,93,58,.32);min-width:120px}
.choice.big{padding:17px 26px}
.choice.on{background:var(--olive);color:var(--cream);border:1px solid var(--olive);box-shadow:0 12px 26px -12px rgba(79,93,58,.75);transform:translateY(-1px)}
.rsend{margin-top:6px;font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--cream);
  background:var(--ink);border:0;border-radius:2px;padding:18px 30px;cursor:pointer;width:100%;transition:background .3s}
.rsend:hover{background:var(--olive)}
.rsend:disabled{opacity:.6;cursor:default}
.rerr{font-family:var(--sans);font-size:12px;letter-spacing:1px;color:#b5654d;text-align:center;margin:0}
.rsvp-songs{display:flex;flex-direction:column;gap:14px}
.rsvp-song{display:flex;align-items:center;gap:14px}
.rsvp-song b{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--gold2);width:18px;flex-shrink:0}
.rsvp-addgas{margin-top:12px;background:none;border:1px dashed rgba(79,93,58,.5);color:var(--olive);font-family:var(--sans);font-size:12px;letter-spacing:1px;padding:10px 16px;border-radius:3px;cursor:pointer;transition:all .2s}
.rsvp-addgas:hover{background:rgba(79,93,58,.07);border-color:var(--olive)}
.rsvp-thanks{text-align:center;padding:30px 10px}
.rsvp-thanks .seal{width:84px;height:84px;border-radius:50%;border:1px solid rgba(185,167,126,.6);margin:0 auto;display:flex;align-items:center;justify-content:center;position:relative}
.rsvp-thanks .seal i{position:absolute;inset:6px;border-radius:50%;border:1px solid rgba(185,167,126,.3)}
.rsvp-thanks .seal b{font-family:var(--serif);font-style:italic;font-size:30px;color:var(--sage);font-weight:400}
.rsvp-thanks h3{font-family:var(--serif);font-weight:300;font-size:clamp(34px,5vw,52px);color:var(--ink);margin:22px 0 18px}
.rsvp-thanks p{font-family:var(--serif);font-size:21px;font-weight:300;line-height:1.7;color:var(--muted);max-width:480px;margin:0 auto}

/* ── footer ── */
.foot{background:var(--ink2);color:rgba(205,214,180,.7);text-align:center;padding:64px 26px 48px}
.foot__seal{width:80px;height:80px;border-radius:50%;border:1px solid rgba(205,214,180,.35);margin:0 auto 24px;display:flex;align-items:center;justify-content:center;position:relative}
.foot__seal i{position:absolute;inset:6px;border-radius:50%;border:1px solid rgba(205,214,180,.18)}
.foot__seal b{font-family:var(--serif);font-style:italic;font-size:27px;color:#cdd6b4;font-weight:400}
.foot__names{font-family:var(--serif);font-style:italic;font-size:34px;color:#cdd6b4}
.foot__names .amp{color:#9aa67f}
.foot__date{font-family:var(--sans);font-size:11px;letter-spacing:4px;text-transform:uppercase;margin:12px 0 30px}
.foot__tel{display:flex;justify-content:center;gap:44px;flex-wrap:wrap;margin-bottom:34px}
.foot__tel .lab{font-family:var(--sans);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:#8a9270;margin-bottom:6px}
.foot__tel .num{font-family:var(--serif);font-size:19px;color:#eef0e3}
.foot__links{display:flex;justify-content:center;gap:22px;align-items:center;border-top:1px solid rgba(205,214,180,.15);padding-top:26px;max-width:520px;margin:0 auto}
.foot__links a,.foot__links button{color:#8a9270}

/* ════════ Responsief ════════ */
@media (max-width:880px){ .gal{column-count:2} }
@media (max-width:768px){
  .two{grid-template-columns:1fr !important;gap:clamp(30px,8vw,46px)}
  .hero{grid-template-columns:1fr !important;min-height:auto;padding-bottom:60px}
  .hero__cue{display:none}
  .two .two__img{order:-1}
  /* keep die swewende H&J-merkie binne die prent op klein skerms */
  .hero__badge{left:8px;bottom:8px;width:84px;height:84px}
  .hero__badge b{font-size:25px}
  .nav__links{gap:16px}
}
@media (max-width:520px){
  .gal{column-count:1}
  .nav__brand{font-size:20px}
  .choices{flex-direction:column}
  .hero__names{font-size:clamp(44px,13vw,72px)}
  .hero__intro{font-size:18px}
  .section{padding:48px 20px}
  .bankbox{padding:26px 24px}
  .bankrow{gap:18px}
  .nav__in{padding:12px 18px}
}

/* ════════ Hamburger-kieslys (tablet & mobiel) ════════ */
@media (max-width:860px){
  .nav__in{position:relative}
  .nav__toggle{display:flex}
  .nav__links{
    position:absolute;top:calc(100% + 1px);left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--cream);border-bottom:1px solid var(--line2);
    padding:6px 20px 18px;box-shadow:0 26px 40px -26px rgba(52,64,42,.55);
    max-height:calc(100vh - 62px);overflow-y:auto;overflow-x:hidden;
    /* toe (versteek) toestand */
    opacity:0;visibility:hidden;transform:translateY(-8px);
    transition:opacity .22s ease,transform .22s ease,visibility .22s;
  }
  .nav.open .nav__links{opacity:1;visibility:visible;transform:none}
  .nav__link{width:100%;text-align:left;padding:15px 4px;font-size:12.5px;border-bottom:1px solid var(--line)}
  .nav__link::after{display:none}
  .nav__rsvp{width:100%;text-align:center;margin-top:14px;padding:14px}
  /* hamburger → X wanneer oop */
  .nav.open .nav__toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav.open .nav__toggle span:nth-child(2){opacity:0}
  .nav.open .nav__toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* ════════ Galery: horisontale rol-strook op mobiel ════════ */
/* In plaas van 'n lang vertikale stapel: netjiese kaarte langs mekaar, rol na regs.
   Elke kaart het dieselfde hoogte; die foto vul dit sonder om te vervorm (tik = volle foto). */
@media (max-width:640px){
  .gal{
    column-count:initial;
    display:flex;flex-wrap:nowrap;gap:12px;
    overflow-x:auto;overflow-y:hidden;
    scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
    padding:2px 2px 14px;
    /* netjiese dun rolstaaf */
    scrollbar-width:thin;scrollbar-color:var(--line2) transparent;
  }
  .gal::-webkit-scrollbar{height:6px}
  .gal::-webkit-scrollbar-thumb{background:var(--line2);border-radius:8px}
  .gal::-webkit-scrollbar-track{background:transparent}
  .gal__tile{
    flex:0 0 72%;height:88vw;max-height:440px;
    margin-bottom:0;scroll-snap-align:center;
  }
  .gal__tile img{width:100%;height:100%;object-fit:cover}
}

/* duideliker fokus vir toeganklikheid (toetsbord-navigasie) */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{
  outline:2px solid var(--sage2);outline-offset:2px;border-radius:2px;
}
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto}
  [data-reveal]{opacity:1;transform:none;transition:none}
  .hero__img .bg,.gate__bg{animation:none}
}
