/* ============================================================
   Ons Reis — stylesheet
   ============================================================ */
:root{
  --sand:#f2e8d7;
  --sand-2:#e8dac1;
  --paper:#faf5ec;
  --ink:#2a241f;
  --ink-soft:#6b6053;
  --ochre:#c4632b;
  --ochre-dark:#9d4c1c;
  --ochre-soft:#e9b27e;
  --green:#3a5240;
  --green-dark:#2b3d30;
  --sage:#e9efe0;
  --sage-2:#dde8cf;
  --sky:#577a89;
  --line:#e3dcc9;
  --card:#fffdf9;
  --shadow:0 8px 30px rgba(60,42,20,.12);
  --shadow-sm:0 2px 10px rgba(60,42,20,.09);
  --radius:14px;
  --radius-sm:9px;
  --maxw:1680px;
  --serif:"Playfair Display","Georgia",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);
  background:var(--paper);line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--ochre-dark);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 34px}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(251,247,240,.92);backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{display:flex;align-items:center;gap:18px;height:84px}
.brand{display:flex;align-items:center;gap:15px;text-decoration:none;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand .mark{
  width:62px;height:62px;border-radius:50%;overflow:hidden;
  background:#fff;border:1.5px solid var(--line);
  display:grid;place-items:center;box-shadow:var(--shadow-sm);flex:none;
}
.brand .mark img{width:100%;height:100%;object-fit:cover;display:block}
.brand .name{font-family:var(--serif);font-weight:700;font-size:1.62rem;line-height:1.05}
.brand .tag{font-size:.78rem;color:var(--ink-soft);letter-spacing:.08em;text-transform:uppercase}
.nav{margin-left:auto;display:flex;gap:6px;align-items:center}
.nav a{
  padding:8px 14px;border-radius:999px;color:var(--ink-soft);font-weight:600;font-size:.95rem;
}
.nav a:hover{background:var(--sand);color:var(--ink);text-decoration:none}
.nav a.active{background:var(--green);color:#fff}
.menu-btn{display:none;margin-left:auto;background:none;border:1px solid var(--line);border-radius:9px;padding:8px 10px;font-size:1.1rem;cursor:pointer}

/* ---------- Photographic hero (Ken Burns slideshow) ---------- */
.hero{position:relative;color:#fff;overflow:hidden;display:flex;align-items:flex-end;
  min-height:clamp(580px,90vh,920px);background:#17130d}
.hero-bg{position:absolute;inset:0;z-index:0;background:#17130d center/cover no-repeat}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;will-change:opacity,transform;animation:heroFade 27s ease-in-out infinite}
.hero-slide:nth-child(1){animation-delay:0s}
.hero-slide:nth-child(2){animation-delay:9s}
.hero-slide:nth-child(3){animation-delay:18s}
@keyframes heroFade{
  0%{opacity:0;transform:scale(1.05)}
  3%{opacity:1}
  30%{opacity:1;transform:scale(1.12)}
  36%{opacity:0}
  100%{opacity:0;transform:scale(1.12)}
}
.hero-scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(90deg,rgba(12,10,7,.68),rgba(12,10,7,.38) 46%,rgba(12,10,7,.08) 100%),
             linear-gradient(0deg,rgba(12,10,7,.64),rgba(12,10,7,0) 48%)}
.hero .wrap{position:relative;z-index:2;width:100%;padding:120px 20px 66px}
.hero-text{max-width:780px}
.eyebrow{display:inline-block;font-family:var(--sans);text-transform:uppercase;letter-spacing:.32em;
  font-size:.72rem;font-weight:600;margin:0 0 18px;opacity:.92}
.hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(2.6rem,6.6vw,5.4rem);line-height:1.01;
  letter-spacing:-.005em;margin:0 0 18px;text-shadow:0 2px 40px rgba(0,0,0,.45)}
.hero p.lead{font-size:clamp(1.04rem,1.5vw,1.32rem);font-weight:300;max-width:46ch;opacity:.96;margin:0 0 28px;
  text-shadow:0 1px 16px rgba(0,0,0,.4)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin:0 0 32px}
.hero .stats{display:flex;gap:40px;flex-wrap:wrap;padding-top:26px;border-top:1px solid rgba(255,255,255,.24);max-width:540px}
.hero .stat b{display:block;font-family:var(--serif);font-weight:600;font-size:2.1rem;line-height:1}
.hero .stat span{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;opacity:.85}
.scroll-hint{position:absolute;left:50%;bottom:18px;z-index:2;color:#fff;opacity:.85;font-size:1.4rem;
  text-decoration:none;animation:bob 1.9s ease-in-out infinite}
.scroll-hint:hover{opacity:1;text-decoration:none}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}
@media (prefers-reduced-motion:reduce){.hero-slide,.scroll-hint{animation:none}.hero-slide:first-child{opacity:1}}

/* ---------- Header transparent over hero (home), solid on scroll ---------- */
.home .site-header{position:fixed;top:0;left:0;right:0;background:transparent;backdrop-filter:none;
  border-bottom:1px solid rgba(255,255,255,.16);transition:background .35s ease,border-color .35s ease}
.home .site-header .brand .mark{border-color:rgba(255,255,255,.5)}
.home .site-header .brand .name{color:#fff}
.home .site-header .brand .tag{color:rgba(255,255,255,.82)}
.home .site-header .nav a{color:rgba(255,255,255,.92)}
.home .site-header .nav a:hover{background:rgba(255,255,255,.16);color:#fff}
.home .site-header .nav a.active{background:var(--ochre);color:#fff}
.home .site-header .menu-btn{color:#fff;border-color:rgba(255,255,255,.45)}
.home .site-header.scrolled{background:rgba(250,245,236,.94);backdrop-filter:saturate(140%) blur(8px);border-bottom-color:var(--line)}
.home .site-header.scrolled .brand .mark{border-color:var(--line)}
.home .site-header.scrolled .brand .name{color:var(--ink)}
.home .site-header.scrolled .brand .tag{color:var(--ink-soft)}
.home .site-header.scrolled .nav a{color:var(--ink-soft)}
.home .site-header.scrolled .nav a:hover{background:var(--sand);color:var(--ink)}
.home .site-header.scrolled .nav a.active{background:var(--green);color:#fff}
.home .site-header.scrolled .menu-btn{color:var(--ink);border-color:var(--line)}
.btn{
  display:inline-block;padding:12px 22px;border-radius:999px;font-weight:700;cursor:pointer;border:none;font-size:.98rem;
}
.btn-primary{background:var(--ochre);color:#fff}
.btn-primary:hover{background:var(--ochre-dark);text-decoration:none;color:#fff}
.btn-ghost{background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.4)}
.btn-ghost:hover{background:rgba(255,255,255,.24);text-decoration:none;color:#fff}

/* ---------- Verken / kaart-afdeling ---------- */
.explore{background:linear-gradient(180deg,var(--sand) 0%,var(--paper) 100%);border-bottom:1px solid var(--line);padding:50px 0 56px}
.explore-head{text-align:center;max-width:640px;margin:0 auto 30px}
.explore-head h2{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.1rem);margin:0 0 8px}
.explore-head p{color:var(--ink-soft);margin:0}
.explore-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:stretch}
.map-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);display:flex;flex-direction:column;justify-content:center}
.map-card h3{margin:.1rem .2rem .5rem;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);font-weight:700;text-align:center}
#sa-map{width:100%;height:auto;display:block;max-width:600px;margin:0 auto}
#sa-map path.prov{fill:#e9cfa6;stroke:#fff;stroke-width:1.1;cursor:pointer;transition:fill .15s}
#sa-map path.prov:hover{fill:var(--ochre)}
#sa-map path.prov.empty{fill:#e3ddd0;cursor:default}
#sa-map path.prov.empty:hover{fill:#e3ddd0}
#sa-map path.lesotho{fill:#d3ccbb;stroke:#fff;stroke-width:1;stroke-dasharray:3 3;cursor:default}
.map-fallback{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;padding:8px}
.map-fallback button{background:var(--sand);border:1px solid var(--line);border-radius:999px;padding:7px 13px;font-weight:600;cursor:pointer;color:var(--green-dark)}
.map-tip{display:flex;align-items:center;justify-content:center;gap:18px;font-size:.78rem;color:var(--ink-soft);margin-top:8px}
.map-tip i{display:inline-block;width:13px;height:13px;border-radius:3px;vertical-align:-2px;margin-right:5px}

/* provinsie-lys langs kaart */
.explore-list{display:flex;flex-direction:column;justify-content:center;gap:9px}
.explore-list .eh{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);font-weight:700;margin-bottom:2px}
.prov-row{display:flex;align-items:center;gap:13px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:10px 18px;cursor:pointer;transition:.15s;width:100%;font:inherit}
.prov-row:hover{border-color:var(--ochre);transform:translateX(4px);box-shadow:var(--shadow-sm)}
.prov-row .pn{font-weight:700;color:var(--ink);min-width:118px;text-align:left}
.prov-row .bar{flex:1;height:8px;background:var(--sand-2);border-radius:5px;overflow:hidden}
.prov-row .bar i{display:block;height:100%;border-radius:5px;background:linear-gradient(90deg,#e0a460,var(--ochre-dark))}
.prov-row .pc{font-weight:700;color:var(--green);min-width:24px;text-align:right}

/* ---------- Parallaks-fotoband (beweeg met rol) ---------- */
.parallax{position:relative;color:#fff;text-align:center;overflow:hidden;
  padding:clamp(84px,12vw,156px) 20px;
  background-color:#1a160f;background-position:center;background-size:cover;background-repeat:no-repeat;
  background-attachment:fixed}
.parallax::before{content:"";position:absolute;inset:0;
  background:linear-gradient(rgba(18,14,8,.52),rgba(18,14,8,.62))}
.parallax .inner{position:relative;z-index:1;max-width:780px;margin:0 auto}
.parallax .eyebrow{display:inline-block;font-family:var(--sans);text-transform:uppercase;letter-spacing:.3em;font-size:.72rem;font-weight:600;opacity:.92;margin:0 0 16px}
.parallax h2{font-family:var(--serif);font-weight:600;font-size:clamp(1.8rem,3.6vw,3rem);line-height:1.08;margin:0 0 16px;text-shadow:0 2px 26px rgba(0,0,0,.45)}
.parallax p{max-width:54ch;margin:0 auto 26px;opacity:.95;font-weight:300;font-size:clamp(1rem,1.4vw,1.18rem)}
@media (max-width:860px){.parallax{background-attachment:scroll}}

/* ---------- Filter bar ---------- */
.filters{background:var(--green-dark);position:sticky;top:70px;z-index:40;box-shadow:0 8px 24px rgba(22,32,24,.22)}
.filters .wrap{padding:18px 34px;display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.filters-label{font-family:var(--serif);font-size:1.1rem;color:#fff;margin-right:4px;align-self:center}
.prov-pills{display:flex;flex-wrap:wrap;gap:7px}
.pill{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.3);border-radius:999px;padding:7px 14px;
  font-weight:500;font-size:.85rem;letter-spacing:.01em;cursor:pointer;color:#eef1e8;white-space:nowrap;transition:.15s;
}
.pill:hover{background:rgba(255,255,255,.18);border-color:#fff;color:#fff}
.pill.active{background:var(--ochre);border-color:var(--ochre);color:#fff}
.pill .n{opacity:.65;margin-left:5px;font-size:.82em}
.pill.active .n{opacity:.9}
.filters .spacer{flex:1 1 auto}
.search-box{position:relative;min-width:190px}
.search-box input{
  border:none;border-bottom:1.5px solid rgba(255,255,255,.4);border-radius:0;padding:9px 6px 9px 26px;font-size:.95rem;width:230px;color:#fff;
  background:transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23cdddc4' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='M21 21l-4.2-4.2'/%3E%3C/svg%3E") no-repeat left center;
}
.search-box input:focus{outline:none;border-bottom-color:var(--ochre-soft)}
.search-box input::placeholder{color:rgba(255,255,255,.72)}

/* sub filter row: streke + kategorie */
.subfilters{display:flex;flex-wrap:wrap;gap:8px;align-items:center;width:100%;margin-top:4px}
.subfilters .label{font-size:.72rem;text-transform:uppercase;letter-spacing:.09em;color:rgba(255,255,255,.78);font-weight:600;margin-right:4px}
.chip{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.28);border-radius:999px;padding:5px 12px;font-size:.8rem;cursor:pointer;color:#eef1e8;transition:.15s}
.chip:hover{border-color:#fff;color:#fff}
.chip.active{background:var(--ochre);border-color:var(--ochre);color:#fff}

/* ---------- Results ---------- */
.results{padding:34px 0 70px}
.results-head{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:20px}
.results-head h2{font-family:var(--serif);font-size:1.7rem;margin:0}
.results-head .count{color:var(--ink-soft);font-size:.95rem}
.clear-link{font-size:.9rem;cursor:pointer;background:none;border:none;color:var(--ochre-dark);font-weight:600;padding:0}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .18s, box-shadow .18s;display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card a.cover{display:block;position:relative;aspect-ratio:4/3;background:var(--sand-2);overflow:hidden}
.card a.cover img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.card:hover a.cover img{transform:scale(1.05)}
.card .badge{
  position:absolute;left:12px;top:12px;display:flex;gap:6px;flex-wrap:wrap;
}
.tagpill{background:rgba(44,38,32,.82);color:#fff;border-radius:999px;padding:4px 10px;font-size:.72rem;font-weight:600;backdrop-filter:blur(2px)}
.tagpill.prov{background:var(--green-dark)}
.card .body{padding:16px 18px 18px;display:flex;flex-direction:column;flex:1}
.card .body h3{font-family:var(--serif);font-size:1.18rem;margin:0 0 8px;line-height:1.25}
.card .body h3 a{color:var(--ink)}
.card .body h3 a:hover{color:var(--ochre-dark);text-decoration:none}
.card .excerpt{color:var(--ink-soft);font-size:.92rem;margin:0 0 14px;flex:1}
.card .meta{display:flex;gap:12px;align-items:center;font-size:.8rem;color:var(--ink-soft);border-top:1px solid var(--line);padding-top:11px}
.card .meta .streek{margin-left:auto;font-weight:600;color:var(--green)}
.no-results{text-align:center;padding:60px 20px;color:var(--ink-soft)}
.no-results h3{font-family:var(--serif);color:var(--ink);font-size:1.4rem}

/* ---------- Article page ---------- */
/* deursigtige kop oor die hero-foto, soliede kop sodra mens scroll */
:is(.article,.met-hero) .site-header{position:fixed;top:0;left:0;right:0;background:linear-gradient(180deg,rgba(18,14,9,.46),rgba(18,14,9,0));backdrop-filter:none;border-bottom:1px solid rgba(255,255,255,.14);transition:background .35s ease,border-color .35s ease}
:is(.article,.met-hero) .site-header .brand .mark{border-color:rgba(255,255,255,.5)}
:is(.article,.met-hero) .site-header .brand .name{color:#fff}
:is(.article,.met-hero) .site-header .brand .tag{color:rgba(255,255,255,.82)}
:is(.article,.met-hero) .site-header .nav a{color:rgba(255,255,255,.92)}
:is(.article,.met-hero) .site-header .nav a:hover{background:rgba(255,255,255,.16);color:#fff}
:is(.article,.met-hero) .site-header .menu-btn{color:#fff;border-color:rgba(255,255,255,.45)}
:is(.article,.met-hero) .site-header.scrolled{background:rgba(250,245,236,.94);backdrop-filter:saturate(140%) blur(8px);border-bottom-color:var(--line)}
:is(.article,.met-hero) .site-header.scrolled .brand .mark{border-color:var(--line)}
:is(.article,.met-hero) .site-header.scrolled .brand .name{color:var(--ink)}
:is(.article,.met-hero) .site-header.scrolled .brand .tag{color:var(--ink-soft)}
:is(.article,.met-hero) .site-header.scrolled .nav a{color:var(--ink-soft)}
:is(.article,.met-hero) .site-header.scrolled .nav a:hover{background:var(--sand);color:var(--ink)}
:is(.article,.met-hero) .site-header.scrolled .menu-btn{color:var(--ink);border-color:var(--line)}
.article-hero{position:relative;height:min(56vh,500px);background:var(--green-dark);overflow:hidden}
.article-hero img{width:100%;height:100%;object-fit:cover;opacity:.92}
.article-hero .scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,16,10,.78) 0%,rgba(20,16,10,.15) 55%,rgba(20,16,10,.35) 100%)}
.article-hero .cap{position:absolute;left:0;right:0;bottom:0;color:#fff;padding:30px 0}
.article-hero .cap .wrap{max-width:840px}
.article-hero .crumbs{font-size:.85rem;opacity:.9;margin-bottom:10px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.article-hero .crumbs a{color:#fff;opacity:.9}
.article-hero .crumbs .sep{opacity:.5}
.article-hero h1{font-family:var(--serif);font-size:2.4rem;line-height:1.1;margin:0 0 12px;max-width:20ch}
.article-hero .ameta{display:flex;gap:16px;flex-wrap:wrap;font-size:.9rem;opacity:.95}
.article-hero .byskrif{font-size:.8rem;opacity:.85;margin-top:8px;font-style:italic}
.article-body{max-width:1320px;margin:0 auto;padding:46px 48px 30px;font-size:1.1rem}
.article-body p{margin-top:0;margin-bottom:1.25em}
.article-body h2{font-family:var(--serif);font-size:1.65rem;margin:1.9em 0 .6em;color:var(--green-dark);border-bottom:2px solid var(--sand-2);padding-bottom:.2em}
/* enkel-foto's en video's matig groot en gesentreer; galery span die volle breedte */
.article-body>figure{max-width:1000px;margin-left:auto;margin-right:auto}
.article-body figure{margin:1.8em 0;text-align:center}
.article-body figure img{border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);width:100%}
.article-body figcaption{font-size:.85rem;color:var(--ink-soft);margin-top:8px;font-style:italic}
/* foto-galery: rooster van kleiner foto's, gewoonlik onderaan 'n artikel */
.article-body .galery{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px;margin:1.8em 0}
.article-body .galery figure{margin:0}
.article-body .galery figure img{height:190px;object-fit:cover;display:block}
.article-body .galery figcaption{font-size:.8rem;margin-top:6px}
/* responsiewe video-inbedding (YouTube) */
.article-body .video-embed{position:relative;width:100%;max-width:860px;aspect-ratio:16/9;margin:1.8em auto .4em;border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow-sm);background:#000}
.article-body .video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.article-body .video-byskrif{font-size:.85rem;color:var(--ink-soft);margin:0 0 1.8em;text-align:center;font-style:italic}
.article-body .info-tabel{width:100%;max-width:920px;border-collapse:collapse;margin:1.8em 0;font-size:.95rem;background:var(--sand);border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow-sm)}
.article-body .info-tabel th,.article-body .info-tabel td{text-align:left;padding:11px 15px;border-bottom:1px solid var(--line);vertical-align:top}
.article-body .info-tabel th{width:42%;background:var(--sand-2);font-weight:700;color:var(--green-dark)}
.article-body .info-tabel tr:last-child th,.article-body .info-tabel tr:last-child td{border-bottom:none}
.article-foot{max-width:760px;margin:0 auto;padding:0 20px 50px}
.source-note{background:var(--sand);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 18px;font-size:.88rem;color:var(--ink-soft)}
.back-link{display:inline-block;margin:8px 0 26px;font-weight:600}
.more-section{background:var(--sand);border-top:1px solid var(--line);padding:44px 0 64px}
.more-section h2{font-family:var(--serif);font-size:1.5rem;margin:0 0 20px}

/* ---------- Static page ---------- */
/* ---------- Banier vir teksbladsye (Wie is ons / Kontak) ---------- */
.page-hero{position:relative;height:min(48vh,440px);overflow:hidden;background:#17130d;color:#fff;display:flex;align-items:flex-end}
.page-hero .hero-bg{position:absolute;inset:0;z-index:0}
.page-hero .scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(16,12,8,.5) 0%,rgba(16,12,8,.18) 42%,rgba(16,12,8,.74) 100%)}
.page-hero .wrap{position:relative;z-index:2;width:100%;padding:0 40px 46px}
.page-hero .eyebrow{display:inline-block;text-transform:uppercase;letter-spacing:.3em;font-size:.72rem;font-weight:600;margin:0 0 14px;opacity:.92}
.page-hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(2.3rem,5vw,3.8rem);line-height:1.04;margin:0;text-shadow:0 2px 34px rgba(0,0,0,.5)}
.page-hero p.lead{font-size:clamp(1.02rem,1.5vw,1.28rem);font-weight:300;max-width:54ch;margin:14px 0 0;opacity:.96;text-shadow:0 1px 16px rgba(0,0,0,.4)}
/* Bewegende foto-agtergrond agter die teks (Wie is ons / Kontak) */
.agtergrond{position:fixed;inset:0;z-index:-1;overflow:hidden;background:#17130d}
.agtergrond .hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;
  will-change:opacity,transform;animation:heroFade 30s ease-in-out infinite}
.agtergrond .hero-slide:nth-child(1){animation-delay:0s}
.agtergrond .hero-slide:nth-child(2){animation-delay:10s}
.agtergrond .hero-slide:nth-child(3){animation-delay:20s}
.agtergrond-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,12,8,.55),rgba(16,12,8,.4))}
.met-hero{background:#17130d}
/* deursigtige titel-blok wat op die bewegende agtergrond sit */
.page-titel{position:relative;color:#fff;padding:128px 0 26px}
.page-titel .eyebrow{display:inline-block;text-transform:uppercase;letter-spacing:.3em;font-size:.72rem;font-weight:600;margin:0 0 14px;opacity:.92}
.page-titel h1{font-family:var(--serif);font-weight:600;font-size:clamp(2.3rem,5vw,3.8rem);line-height:1.04;margin:0;text-shadow:0 2px 34px rgba(0,0,0,.55)}
.page-titel p.lead{font-size:clamp(1.02rem,1.5vw,1.28rem);font-weight:300;max-width:54ch;margin:14px 0 0;opacity:.96;text-shadow:0 1px 16px rgba(0,0,0,.45)}
/* die skryf-paneel: lig, met skaduwee, sodat dit teen die agtergrond uitstaan */
.met-hero .page{background:rgba(250,245,236,.78);
  backdrop-filter:blur(10px) saturate(115%);-webkit-backdrop-filter:blur(10px) saturate(115%);
  border:1px solid rgba(255,255,255,.55);
  box-shadow:0 24px 70px rgba(0,0,0,.38);border-radius:18px;padding:44px 50px;margin:0 auto 70px}
.page{max-width:1040px;margin:0 auto;padding:50px 40px}
.page h1{font-family:var(--serif);font-size:2.3rem;margin:0 0 .4em}
.page h2{font-family:var(--serif);color:var(--green-dark);margin:1.6em 0 .4em}
.page p{margin:0 0 1.1em;font-size:1.06rem}
.page .lead{font-size:1.2rem;color:var(--ink-soft)}
.contact-card{background:var(--sand);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;margin-top:24px}
.contact-card div{margin-bottom:8px}

/* ---------- Footer ---------- */
.site-footer{background:var(--green-dark);color:#e8e2d6;padding:40px 0 28px;margin-top:0}
.site-footer .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
.site-footer h4{font-family:var(--serif);color:#fff;margin:0 0 12px;font-size:1.1rem}
.site-footer a{color:#f0c89a}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer li{margin-bottom:7px}
.site-footer .copy{grid-column:1/-1;border-top:1px solid rgba(255,255,255,.15);margin-top:22px;padding-top:16px;font-size:.82rem;opacity:.8}

/* ---------- Responsive ---------- */
@media (max-width:860px){
  .hero{min-height:clamp(500px,82vh,680px)}
  .hero .wrap{padding:100px 20px 48px}
  .explore-grid{grid-template-columns:1fr;gap:26px}
  .explore-list{max-width:480px;margin:0 auto;width:100%}
  .map-card{max-width:480px;margin:0 auto;width:100%}
  .prov-row .pn{min-width:96px}
  .nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--paper);flex-direction:column;padding:10px 20px;border-bottom:1px solid var(--line);gap:4px;box-shadow:var(--shadow)}
  .home .site-header .nav a{color:var(--ink-soft)}
  .home .site-header .nav a:hover{background:var(--sand);color:var(--ink)}
  .nav.open{display:flex}
  .nav a{width:100%}
  .menu-btn{display:block}
  .filters{position:static}
  .site-header .wrap{height:74px}
  .filters .spacer{display:none}
  .search-box input{width:100%}
  .search-box{width:100%}
  .site-footer .wrap{grid-template-columns:1fr}
  .article-hero h1{font-size:1.8rem}
}

@media (max-width:540px){
  .site-header .wrap{height:66px;gap:10px}
  .brand .mark{width:48px;height:48px}
  .brand .name{font-size:1.25rem}
  .brand .tag{font-size:.66rem}
  .hero{min-height:clamp(440px,76vh,600px)}
  .hero .wrap{padding:88px 18px 40px}
  .hero .stats{gap:24px;padding-top:20px}
  .hero .stat b{font-size:1.7rem}
  .hero-cta .btn{flex:1 1 auto;text-align:center}
  .explore{padding:38px 0 42px}
  .grid{grid-template-columns:1fr;gap:18px}
  .results{padding:26px 0 54px}
  .results-head h2{font-size:1.4rem}
  .filters .wrap{padding:14px 16px;gap:10px}
  .prov-pills{gap:6px}
  .pill{font-size:.84rem;padding:6px 11px}
  .subfilters{gap:6px}
  .prov-row{padding:9px 14px;gap:10px}
  .prov-row .pn{min-width:84px;font-size:.92rem}
  .article-body{font-size:1.02rem;padding:34px 18px 24px}
  .article-hero{height:min(46vh,360px)}
  .page{padding:38px 18px}
  .page h1{font-size:1.9rem}
}
