/* =========================================================================
   Winkelcentrum Geldermalsen - styles.css
   Component-gebaseerde stylesheet (mobile-first), in de huisstijl van de
   huidige site: Inter Tight (koppen) + Source Sans Pro (tekst), grote bulky
   titels, rode (#d00408) en donkere vlakken, pill-knoppen.
   ========================================================================= */

/* 1. CUSTOM PROPERTIES ---------------------------------------------------- */
:root {
  --rood: #d00408;          /* brand rood: koppen, accenten, rode vlakken, footer */
  --rood-donker: #a80306;
  --rood-zacht: #fdecec;
  --groen: #6fae3d;

  --ink: #181715;           /* donkere tekst + donkere vlakken/knoppen */
  --bruin: #2d2119;         /* warme bruine footer */
  --tekst: #232020;         /* bodytekst */
  --zand: #f7f4f0;          /* subtiele lichte sectie */
  --wit: #ffffff;
  --lijn: #e7e1da;

  --font-kop: "Inter Tight", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-tekst: "Source Sans Pro", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --ruimte-2xs: .5rem;
  --ruimte-xs: .75rem;
  --ruimte-s: 1rem;
  --ruimte-m: 1.5rem;
  --ruimte-l: 2.5rem;
  --ruimte-xl: clamp(3.5rem, 6vw, 5.5rem);
  --ruimte-2xl: clamp(4.5rem, 9vw, 8rem);

  --breedte: 1240px;
  --breedte-smal: 820px;
  --rand-inline: clamp(1.1rem, 5vw, 3rem);

  --radius: 18px;
  --radius-s: 12px;
  --radius-pill: 50px;
  --schaduw: 0 24px 50px -30px rgba(24, 23, 21, .45);
  --schaduw-zacht: 0 14px 34px -26px rgba(24, 23, 21, .4);
  --transitie: .25s ease;
}

/* 2. RESET & BASIS -------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  font-family: var(--font-tekst);
  font-size: clamp(1.05rem, 1rem + .25vw, 1.18rem);
  line-height: 1.7;
  color: var(--tekst);
  background: var(--wit);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  overflow-wrap: break-word;
}
img, svg { display: block; max-width: 100%; height: auto; }
/* picture transparant maken voor layout zodat <img height:100%> de container vult */
picture { display: contents; }
a { color: var(--rood); text-decoration: none; transition: color var(--transitie); }
a:hover { color: var(--rood-donker); }
ul, ol { padding: 0; list-style: none; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}

/* 3. TYPOGRAFIE ----------------------------------------------------------- */
h1, h2, h3, h4 {
  font-family: var(--font-kop);
  color: var(--ink);
  line-height: 1.04;
  font-weight: 600;
  letter-spacing: -.02em;
}
h1 { font-size: clamp(2.7rem, 1.6rem + 5.4vw, 6.4rem); }
h2 { font-size: clamp(2rem, 1.3rem + 3vw, 3.75rem); }
h3 { font-size: clamp(1.35rem, 1.1rem + 1vw, 1.85rem); }
h4 { font-size: 1.2rem; }
p { max-width: 70ch; }

.ooglabel {
  display: inline-block;
  font-family: var(--font-tekst);
  font-weight: 700;
  font-size: .82rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--rood);
  margin-bottom: var(--ruimte-s);
}
.kop-rood { color: var(--rood); }

/* 4. HULPKLASSEN ---------------------------------------------------------- */
.container { width: 100%; max-width: var(--breedte); margin-inline: auto; padding-inline: var(--rand-inline); }
.container--smal { max-width: var(--breedte-smal); }

.sectie { padding-block: var(--ruimte-2xl); }
.sectie--krap { padding-block: var(--ruimte-xl); }
.sectie--kort-onder { padding-bottom: var(--ruimte-l); }
/* sluit een volgend zand-blok strakker aan (bv. kaart -> nieuwsbrief) */
.sectie--kort-onder + .sectie--zand { padding-top: var(--ruimte-l); }
.sectie--zand { background: var(--zand); }
.sectie--rood { background: var(--rood); color: #fff; }
.sectie--rood h1, .sectie--rood h2, .sectie--rood h3 { color: #fff; }
.sectie--rood .ooglabel { color: #ffd4d5; }
.sectie--inkt { background: var(--ink); color: #e9e2dc; }
.sectie--inkt h1, .sectie--inkt h2, .sectie--inkt h3 { color: #fff; }
.sectie--inkt .ooglabel { color: #ff9a9c; }

.sectie-kop { margin-bottom: var(--ruimte-l); max-width: 52rem; }
.sectie-kop p { max-width: 48rem; margin-top: var(--ruimte-s); }
.tekst-centreren { text-align: center; }
.tekst-centreren .sectie-kop, .sectie-kop.tekst-centreren { margin-inline: auto; max-width: 58rem; }
.tekst-centreren p { margin-inline: auto; }

.grid { display: grid; gap: var(--ruimte-m); }
.grid > * { min-width: 0; }
.grid--2, .grid--3, .grid--4 { grid-template-columns: 1fr; }
@media (min-width: 600px) { .grid--4, .grid--3 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 820px) { .grid--2 { grid-template-columns: 1fr 1fr; align-items: center; gap: var(--ruimte-xl); } }
@media (min-width: 980px) { .grid--3 { grid-template-columns: repeat(3, 1fr); } .grid--4 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .grid--4 { grid-template-columns: repeat(4, 1fr); } }
.grid--2-kaarten { gap: var(--ruimte-m); }
@media (min-width: 820px) { .grid--2-kaarten { grid-template-columns: 1fr 1fr; align-items: stretch; } }
@media (min-width: 820px) { .grid--intro { grid-template-columns: 1fr 1.3fr; } }
/* tekst/beeld-sectie met groter beeldblok */
@media (min-width: 820px) { .grid--beeld { grid-template-columns: 1fr 1.4fr; gap: var(--ruimte-xl); } }

/* 5. KNOPPEN -------------------------------------------------------------- */
.knop {
  display: inline-flex;
  align-items: center;
  gap: .6em;
  font-family: var(--font-tekst);
  font-weight: 600;
  font-size: 1.06rem;
  line-height: 1;
  padding: .95em 1.9em;
  border-radius: var(--radius-pill);
  border: 2px solid transparent;
  cursor: pointer;
  transition: transform var(--transitie), background var(--transitie), color var(--transitie), border-color var(--transitie);
}
.knop:hover { transform: translateY(-2px); }
.knop svg { width: 1.1em; height: 1.1em; }
/* primair = donker (op lichte achtergrond), met rode pijl */
.knop--primair { background: var(--ink); color: #fff; }
.knop--primair:hover { background: #000; color: #fff; }
.knop--primair svg { color: var(--rood); }
/* rood = op donkere/lichte achtergrond */
.knop--rood { background: var(--rood); color: #fff; }
.knop--rood:hover { background: var(--rood-donker); color: #fff; }
/* licht = wit (op donkere/foto achtergrond) */
.knop--licht { background: #fff; color: var(--ink); }
.knop--licht:hover { background: var(--zand); color: var(--ink); }
.knop--licht svg { color: var(--rood); }
/* lijn op donker */
.knop--lijn-wit { border-color: rgba(255,255,255,.7); color: #fff; background: transparent; }
.knop--lijn-wit:hover { background: #fff; color: var(--ink); }

.tekstlink {
  display: inline-flex; align-items: center; gap: .45em;
  font-weight: 700; color: var(--rood); overflow-wrap: anywhere;
}
.tekstlink svg { width: 1em; height: 1em; transition: transform var(--transitie); flex: 0 0 auto; }
.tekstlink:hover svg { transform: translateX(3px); }
.sectie--inkt .tekstlink, .sectie--rood .tekstlink { color: #fff; }

/* 6. HEADER & NAVIGATIE (altijd wit) ------------------------------------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--wit);
  border-bottom: 1px solid var(--lijn);
}
.site-header__binnen {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--ruimte-m); padding-block: .7rem;
}
.site-logo { display: inline-flex; flex: 0 0 auto; }
.site-logo img { height: 52px; width: auto; }

.hoofdnav { display: flex; align-items: center; }
.hoofdnav__lijst { display: flex; align-items: center; gap: clamp(.6rem, 1.6vw, 1.6rem); }
.hoofdnav__lijst a {
  display: inline-block; white-space: nowrap;
  font-weight: 600; font-size: 1.02rem; color: var(--ink);
  padding: .4rem .1rem; position: relative;
}
.hoofdnav__lijst a::after {
  content: ""; position: absolute; left: .1rem; right: .1rem; bottom: -.1rem;
  height: 2px; background: var(--rood); transform: scaleX(0); transform-origin: left;
  transition: transform var(--transitie);
}
.hoofdnav__lijst a:hover, .hoofdnav__lijst a:focus-visible { color: var(--rood); }
.hoofdnav__lijst a:hover::after, .hoofdnav__lijst a[aria-current="page"]::after { transform: scaleX(1); }
.hoofdnav__lijst a[aria-current="page"] { color: var(--rood); }

.nav-toggle {
  display: none; flex-direction: column; justify-content: center; gap: 5px;
  width: 48px; height: 48px; padding: 11px; background: var(--rood);
  border: none; border-radius: var(--radius-s); cursor: pointer; flex: 0 0 auto;
  position: relative; z-index: 120; /* blijft bovenop het open menupaneel, zodat je kunt sluiten */
}
.nav-toggle span { display: block; height: 3px; border-radius: 3px; background: #fff; transition: transform .25s ease, opacity .2s ease; }
/* hamburger -> kruisje wanneer het menu open is */
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

@media (max-width: 1024px) {
  .nav-toggle { display: flex; }
  .hoofdnav {
    position: fixed; inset: 0 0 0 auto; width: min(82vw, 360px); z-index: 105;
    flex-direction: column; align-items: stretch; justify-content: flex-start;
    background: var(--wit); padding: 5.5rem var(--ruimte-l) var(--ruimte-l);
    box-shadow: var(--schaduw); transform: translateX(100%);
    transition: transform .3s ease; overflow-y: auto;
  }
  .hoofdnav.is-open { transform: translateX(0); }
  .hoofdnav__lijst { flex-direction: column; align-items: stretch; gap: 0; }
  .hoofdnav__lijst li { border-bottom: 1px solid var(--lijn); }
  .hoofdnav__lijst a { display: block; padding: 1rem .1rem; font-size: 1.15rem; }
  .hoofdnav__lijst a::after { display: none; }
  body.nav-open { overflow: hidden; }
  .nav-overlay { position: fixed; inset: 0; background: rgba(24,23,21,.5); opacity: 0; visibility: hidden; transition: opacity .3s ease; z-index: 99; }
  .nav-overlay.is-open { opacity: 1; visibility: visible; }
}

/* 7. HERO (groot, gecentreerd, beeld-overlay) ----------------------------- */
.hero { position: relative; isolation: isolate; color: #fff; text-align: center; }
.hero__media { position: absolute; inset: 0; z-index: -2; overflow: hidden; }
.hero__media img { width: 100%; height: 100%; object-fit: cover; }
.hero::after {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(180deg, rgba(24,23,21,.45) 0%, rgba(24,23,21,.45) 45%, rgba(24,23,21,.62) 100%);
}
.hero__binnen { padding-block: clamp(4.5rem, 13vw, 9rem); }
.hero h1 { color: #fff; text-shadow: 0 2px 30px rgba(0,0,0,.3); line-height: 1; }
.hero p {
  color: #fff; font-weight: 600; max-width: 56ch; margin-inline: auto;
  font-size: clamp(1.05rem, 1rem + .5vw, 1.35rem); margin-top: var(--ruimte-m);
  text-shadow: 0 1px 16px rgba(0,0,0,.35);
}
.hero__acties { display: flex; flex-wrap: wrap; gap: var(--ruimte-s); margin-top: var(--ruimte-l); justify-content: center; }
.hero--compact .hero__binnen { padding-block: clamp(3.5rem, 8vw, 5.5rem); }

/* 7b. PAGINAKOP (titel die op 1 regel past op desktop) ------------------- */
.paginakop { font-size: clamp(2rem, 1.2rem + 3.5vw, 3.6rem); color: var(--rood); }
.kop-compact { font-size: clamp(2rem, 1.2rem + 3.5vw, 3.6rem); }

/* 7c. MINI-EVENT (compacte, subtiele uitgelicht-balk) -------------------- */
.mini-event {
  display: inline-flex; align-items: center; gap: .9rem; flex-wrap: wrap;
  background: var(--rood-zacht); border: 1px solid #f3d2d3;
  border-radius: var(--radius-pill); padding: .55rem 1.3rem .55rem .55rem;
  color: var(--ink); font-weight: 500; transition: transform var(--transitie), box-shadow var(--transitie);
}
.mini-event:hover { transform: translateY(-2px); box-shadow: var(--schaduw-zacht); color: var(--ink); }
.mini-event__chip { background: var(--rood); color: #fff; font-weight: 700; font-size: .78rem; letter-spacing: .04em; text-transform: uppercase; padding: .4em .85em; border-radius: var(--radius-pill); }
.mini-event strong { font-weight: 700; }
.mini-event span.datum { color: var(--rood-donker); }
.mini-event svg { width: 1.05em; height: 1.05em; color: var(--rood); transition: transform var(--transitie); }
.mini-event:hover svg { transform: translateX(3px); }
/* op mobiel: nette kaart-vorm i.p.v. pill, chip boven de tekst, geen los pijltje */
@media (max-width: 600px) {
  .mini-event { flex-direction: column; align-items: flex-start; gap: .65rem; border-radius: var(--radius); padding: 1rem 1.2rem; }
  .mini-event > svg { display: none; }
}

/* 11b. AGENDA-LIJST (compact) -------------------------------------------- */
.agenda { border-top: 1px solid var(--lijn); }
.agenda__item { display: flex; gap: var(--ruimte-m); padding: var(--ruimte-m) 0; border-bottom: 1px solid var(--lijn); }
.agenda__datum { flex: 0 0 12rem; font-family: var(--font-kop); font-weight: 600; color: var(--rood); font-size: 1.05rem; padding-top: .15rem; }
.agenda__info h3 { font-size: 1.35rem; line-height: 1.15; }
.agenda__info p { font-size: 1rem; margin-top: .25rem; }
.agenda__tag { display: inline-block; background: var(--rood); color: #fff; font-size: .72rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; padding: .2em .7em; border-radius: var(--radius-pill); margin-bottom: .4rem; }
.agenda__item--uitgelicht { background: var(--rood-zacht); border-radius: var(--radius); border-bottom-color: transparent; padding: var(--ruimte-m); margin-block: var(--ruimte-2xs); }
@media (max-width: 600px) {
  .agenda__item { flex-direction: column; gap: .35rem; }
  .agenda__datum { flex: none; }
}

/* 7d. ONTDEK-SECTIE (licht, foto + uitklapbare bolletjes) ---------------- */
.ontdek { position: relative; isolation: isolate; overflow: hidden; background: var(--zand); color: var(--tekst); padding-block: var(--ruimte-2xl); }
/* heel transparante landkaart-structuur op de achtergrond */
.ontdek::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image: url(img/ontdek-kaart.jpg);
  background-image: image-set(url(img/ontdek-kaart.webp) type("image/webp"), url(img/ontdek-kaart.jpg) type("image/jpeg"));
  background-size: cover; background-position: center;
  opacity: .07; filter: grayscale(.55);
}
.ontdek > .container { position: relative; z-index: 1; }
.ontdek__kop h1 { color: var(--rood); font-size: clamp(2.4rem, 1.6rem + 3vw, 4.5rem); }
.ontdek__kop p { color: var(--tekst); max-width: 44rem; margin-top: var(--ruimte-s); }
.ontdek__interactie { display: grid; gap: var(--ruimte-l); margin-top: var(--ruimte-xl); }
@media (min-width: 860px) { .ontdek__interactie { grid-template-columns: 1.35fr 1fr; align-items: center; } }
.ontdek__scene { position: relative; isolation: isolate; border-radius: var(--radius); overflow: hidden; min-height: 460px; box-shadow: var(--schaduw); }
.ontdek__bg { display: block; position: absolute; inset: 0; z-index: 0; }
.ontdek__bg img { width: 100%; height: 100%; object-fit: cover; }
.ontdek__scene::after { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(to top, rgba(24,23,21,.42), rgba(24,23,21,.05)); }
.ontdek__dot {
  position: absolute; z-index: 2; width: 56px; height: 56px; border-radius: 50%;
  border: 2px solid #fff; background: rgba(255,255,255,.92);
  color: var(--rood); font-family: var(--font-kop); font-weight: 600; font-size: 1.2rem;
  cursor: pointer; display: grid; place-items: center; box-shadow: 0 6px 18px -8px rgba(0,0,0,.5);
  transition: transform var(--transitie), background var(--transitie), box-shadow var(--transitie);
}
.ontdek__dot:hover { transform: scale(1.08); }
.ontdek__dot.is-actief { background: var(--rood); color: #fff; border-color: #fff; box-shadow: 0 0 0 6px rgba(208,4,8,.25); }
.ontdek__paneel {
  background: var(--wit); border: 1px solid var(--lijn); border-radius: var(--radius);
  padding: var(--ruimte-l); box-shadow: var(--schaduw-zacht);
}
.ontdek__paneel h3 { color: var(--ink); font-size: 1.7rem; }
.ontdek__paneel p { color: var(--tekst); margin: var(--ruimte-2xs) 0 var(--ruimte-m); }
/* op mobiel compacter: lagere foto + minder ruimte naar het paneel */
@media (max-width: 600px) {
  .ontdek__interactie { gap: var(--ruimte-m); margin-top: var(--ruimte-l); }
  .ontdek__scene { min-height: 250px; }
  .ontdek__paneel { padding: var(--ruimte-m); }
  .ontdek__paneel .knop { width: 100%; justify-content: center; white-space: nowrap; font-size: .92rem; padding-inline: 1.1em; }
}

/* 8. UITGELICHT-EVENEMENT BALK -------------------------------------------- */
.uitgelicht { position: relative; z-index: 2; margin-top: -3rem; }
.uitgelicht__kaart {
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--ruimte-m);
  background: var(--ink); color: #fff; border-radius: var(--radius);
  padding: var(--ruimte-l); box-shadow: var(--schaduw);
}
.uitgelicht__datum {
  flex: 0 0 auto; display: flex; flex-direction: column; align-items: center; justify-content: center;
  width: 104px; height: 104px; background: var(--rood); color: #fff; border-radius: var(--radius-s); line-height: 1;
}
.uitgelicht__datum .dag { font-family: var(--font-kop); font-size: 2.4rem; font-weight: 600; }
.uitgelicht__datum .maand { font-weight: 700; font-size: .82rem; text-transform: uppercase; letter-spacing: .08em; margin-top: .25rem; }
.uitgelicht__tekst { flex: 1 1 16rem; }
.uitgelicht__tekst .ooglabel { color: #ff9a9c; }
.uitgelicht__tekst h2 { color: #fff; font-size: clamp(1.5rem, 1.2rem + 1.4vw, 2.2rem); }
.uitgelicht__tekst p { color: #e9e2dc; margin-top: .35rem; }
.uitgelicht .knop { flex: 0 0 auto; }

/* 9a. BEELDKAART (foto met titel-overlay, zoals home) --------------------- */
.beeldkaart {
  position: relative; display: block; border-radius: var(--radius);
  overflow: hidden; box-shadow: var(--schaduw-zacht); color: #fff;
  aspect-ratio: 16 / 10; transition: transform var(--transitie), box-shadow var(--transitie);
}
.beeldkaart:hover { transform: translateY(-5px); box-shadow: var(--schaduw); color: #fff; }
.beeldkaart img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.beeldkaart:hover img { transform: scale(1.05); }
.beeldkaart::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(24,23,21,0) 35%, rgba(24,23,21,.78) 100%); }
.beeldkaart__inhoud { position: absolute; inset: auto 0 0 0; z-index: 1; padding: var(--ruimte-l); }
.beeldkaart__inhoud h3 { color: #fff; font-size: clamp(1.6rem, 1.2rem + 1.6vw, 2.4rem); }
.beeldkaart__inhoud p { color: #f2ece8; margin-top: .35rem; font-size: 1rem; max-width: 34ch; }

/* 9b. KAART (foto-boven + tekst-onder, zoals geschiedenis/dagje) ---------- */
.kaart {
  display: flex; flex-direction: column; background: var(--wit);
  border: 1px solid var(--lijn); border-radius: var(--radius); overflow: hidden;
  box-shadow: var(--schaduw-zacht); height: 100%;
  transition: transform var(--transitie), box-shadow var(--transitie);
}
a.kaart:hover { transform: translateY(-5px); box-shadow: var(--schaduw); }
.kaart__media { aspect-ratio: 16 / 11; overflow: hidden; }
.kaart__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.kaart:hover .kaart__media img { transform: scale(1.05); }
.kaart__body { padding: var(--ruimte-l); display: flex; flex-direction: column; gap: var(--ruimte-2xs); flex: 1; }
.kaart__body p { color: var(--tekst); font-size: 1rem; }

/* 9c. INFOKAART (tekst-kaart) -------------------------------------------- */
.infokaart {
  background: var(--wit); border: 1px solid var(--lijn); border-radius: var(--radius);
  padding: var(--ruimte-l); box-shadow: var(--schaduw-zacht); height: 100%;
}
.infokaart__icoon {
  width: 56px; height: 56px; display: grid; place-items: center;
  background: var(--rood-zacht); color: var(--rood); border-radius: var(--radius-s);
  margin-bottom: var(--ruimte-s); font-family: var(--font-kop); font-weight: 600; font-size: 1.4rem;
}
.infokaart__icoon svg { width: 28px; height: 28px; }
/* alle lijn-icoontjes nette afgeronde hoeken/uiteinden */
.infokaart__icoon svg, .pijler__icoon svg, .uitlichtkaart__icoon svg { stroke-linecap: round; stroke-linejoin: round; }
.infokaart h3 { margin-bottom: var(--ruimte-2xs); }
.infokaart p { font-size: 1rem; }
.contact-namen { font-weight: 600; color: #6b625d; font-size: .95rem; margin-bottom: var(--ruimte-2xs); }
.infokaart .tekstlink { margin-top: var(--ruimte-s); font-size: .9rem; }

/* TODO-kaart */
.kaart--todo {
  border: 2px dashed var(--lijn); background: var(--zand); box-shadow: none;
  display: grid; place-items: center; text-align: center; padding: var(--ruimte-l);
  min-height: 180px; color: var(--tekst); border-radius: var(--radius);
}
.kaart--todo strong { color: var(--ink); display: block; }

/* 9d. LEAD-tekst + PIJLERS (bv. Onze missie) ----------------------------- */
.lead { font-family: var(--font-kop); font-weight: 500; color: var(--ink); font-size: clamp(1.3rem, 1.1rem + 1vw, 1.85rem); line-height: 1.3; }
.lead .kop-rood, .lead strong { color: var(--rood); font-weight: 600; }

.pijler { text-align: center; }
.pijler__icoon {
  width: 64px; height: 64px; margin: 0 auto var(--ruimte-s);
  display: grid; place-items: center; border-radius: 50%;
  background: var(--rood-zacht); color: var(--rood);
}
.pijler__icoon svg { width: 30px; height: 30px; }
.pijler h3 { font-size: 1.25rem; margin-bottom: .25rem; }
.pijler p { font-size: 1rem; margin-inline: auto; max-width: 30ch; }

/* 9e. WERKGROEP-KAART (donker, foto met overlay, witte letters) ----------- */
.wg-kaart {
  position: relative; overflow: hidden; isolation: isolate;
  border-radius: var(--radius); background: var(--ink); color: #fff;
  padding: var(--ruimte-l);
  min-height: 240px; display: flex; flex-direction: column; justify-content: flex-end;
  box-shadow: var(--schaduw-zacht); transition: transform var(--transitie), box-shadow var(--transitie);
}
.wg-kaart:hover { transform: translateY(-5px); box-shadow: var(--schaduw); }
.wg-kaart__bg {
  position: absolute; inset: 0; z-index: -2; width: 100%; height: 100%;
  object-fit: cover; opacity: .55; transition: transform .5s ease;
}
.wg-kaart:hover .wg-kaart__bg { transform: scale(1.05); }
.wg-kaart::after {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(180deg, rgba(24,23,21,.35) 0%, rgba(24,23,21,.55) 55%, rgba(24,23,21,.88) 100%);
}
.wg-kaart__cat { font-weight: 700; font-size: .92rem; color: #ff9a9c; margin-bottom: .25rem; }
.wg-kaart h3 { color: #fff; font-size: 1.5rem; line-height: 1.12; }

/* 9f. UITLICHTKAART (grote kaart met hoek-icoon) ------------------------- */
.uitlichtkaart {
  position: relative; background: var(--wit); border: 1px solid var(--lijn);
  border-radius: var(--radius); padding: var(--ruimte-xl); box-shadow: var(--schaduw-zacht);
  height: 100%;
}
.uitlichtkaart__icoon {
  position: absolute; top: var(--ruimte-l); right: var(--ruimte-l);
  width: 60px; height: 60px; display: grid; place-items: center;
  background: var(--rood-zacht); color: var(--rood); border-radius: var(--radius-s);
}
.uitlichtkaart__icoon svg { width: 32px; height: 32px; }
.uitlichtkaart h3 { font-size: clamp(1.6rem, 1.3rem + 1vw, 2.1rem); padding-right: 70px; }
.uitlichtkaart p { margin-top: var(--ruimte-s); }
@media (max-width: 600px) {
  .uitlichtkaart { padding: var(--ruimte-l); }
  .uitlichtkaart__icoon { top: var(--ruimte-m); right: var(--ruimte-m); width: 52px; height: 52px; }
  .uitlichtkaart__icoon svg { width: 28px; height: 28px; }
}
.uitlichtkaart__tags { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: var(--ruimte-m); }
.uitlichtkaart__tag {
  background: var(--zand); border: 1px solid var(--lijn); border-radius: var(--radius-pill);
  padding: .35em 1em; font-size: .88rem; font-weight: 600; color: var(--ink);
}

/* 9h. PARTNER-LOGOKAART -------------------------------------------------- */
.logo-kaart {
  background: var(--wit); border: 1px solid var(--lijn); border-radius: var(--radius);
  padding: var(--ruimte-l); box-shadow: var(--schaduw-zacht); text-align: center; height: 100%;
}
.logo-kaart__logo {
  height: 80px; display: grid; place-items: center; margin-bottom: var(--ruimte-s);
  background: var(--zand); border-radius: var(--radius-s);
  font-family: var(--font-kop); font-weight: 600; color: #b3aca6; letter-spacing: .02em;
}
.logo-kaart__logo img { max-height: 56px; width: auto; }
.logo-kaart h3 { font-size: 1.2rem; }
.logo-kaart p { font-size: .95rem; margin-top: .25rem; }

/* 9g. KAART-SECTIE (Leaflet + OpenStreetMap) ----------------------------- */
.kaart-sectie__kaart {
  height: clamp(360px, 52vh, 540px); border-radius: var(--radius);
  box-shadow: var(--schaduw); overflow: hidden; position: relative; z-index: 0;
}
.leaflet-container { font: inherit; }
.kaart-zoek { display: flex; gap: .6rem; margin-bottom: var(--ruimte-m); max-width: 560px; }
.kaart-zoek input { flex: 1; min-width: 0; font: inherit; padding: .8em 1.2em; border: 2px solid var(--lijn); border-radius: var(--radius-pill); background: #fff; color: var(--ink); }
.kaart-zoek input:focus-visible { outline: none; border-color: var(--rood); }
.kaart-zoek .knop { flex: 0 0 auto; }
.kaart-melding { margin-top: var(--ruimte-s); font-size: .95rem; color: #6b625d; min-height: 1.2em; }

/* 10. STATS --------------------------------------------------------------- */
.stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--ruimte-l); text-align: center; }
.stats__getal { font-family: var(--font-kop); font-size: clamp(2.4rem, 1.6rem + 3vw, 4rem); font-weight: 600; color: var(--rood); line-height: 1; }
.stats__label { font-weight: 600; color: var(--ink); margin-top: .4rem; }
.sectie--rood .stats__getal, .sectie--inkt .stats__getal { color: #fff; }
.sectie--rood .stats__label, .sectie--inkt .stats__label { color: #fff; }
@media (max-width: 540px) { .stats { grid-template-columns: 1fr; gap: var(--ruimte-l); } }

/* 11. TEKST/BEELD-BLOK ---------------------------------------------------- */
.beeldblok__media img { border-radius: var(--radius); box-shadow: var(--schaduw); width: 100%; }
@media (min-width: 820px) {
  .beeldblok--omgedraaid .beeldblok__media { order: 0; }
  .beeldblok--omgedraaid .beeldblok__tekst { order: -1; }
}
.beeldblok__tekst > * + * { margin-top: var(--ruimte-s); }
.beeldblok__tekst h1 { font-size: clamp(2rem, 1.3rem + 3vw, 3.75rem); }
.beeldblok__tekst .knop, .beeldblok__tekst .tekstlink { margin-top: var(--ruimte-m); }

/* 12. REVIEWS (subtiele kaarten in een slider) --------------------------- */
.review {
  background: var(--wit); color: var(--tekst); border: 1px solid var(--lijn);
  border-radius: var(--radius); padding: var(--ruimte-l); height: 100%;
  display: flex; flex-direction: column; box-shadow: var(--schaduw-zacht);
}
.review__quote { font-family: var(--font-kop); font-weight: 500; font-size: 1.25rem; line-height: 1.35; color: var(--ink); }
.review__quote::before { content: "\201C"; color: var(--rood); font-weight: 600; }
.review__quote::after { content: "\201D"; color: var(--rood); font-weight: 600; }
.review__persoon { margin-top: var(--ruimte-m); padding-top: var(--ruimte-s); border-top: 1px solid var(--lijn); }
.review__naam { display: block; font-weight: 700; color: var(--ink); line-height: 1.3; }
.review__rol { display: block; font-size: .92rem; color: #6b625d; margin-top: .15rem; }

/* Slider (horizontaal, scroll-snap + pijlen) */
.slider { position: relative; }
.slider__spoor {
  display: flex; gap: var(--ruimte-m); overflow-x: auto; scroll-snap-type: x mandatory;
  scroll-behavior: smooth; padding: 4px 4px var(--ruimte-s);
  scrollbar-width: none; -ms-overflow-style: none;
}
.slider__spoor::-webkit-scrollbar { display: none; }
.slider__spoor > * { scroll-snap-align: start; flex: 0 0 86%; }
@media (min-width: 640px) { .slider__spoor > * { flex-basis: 46%; } }
@media (min-width: 980px) { .slider__spoor > * { flex-basis: 31.5%; } }
.slider__knoppen { display: flex; gap: var(--ruimte-xs); justify-content: center; margin-top: var(--ruimte-m); }
.slider__knop {
  width: 48px; height: 48px; border-radius: 50%; border: 2px solid var(--lijn);
  background: var(--wit); color: var(--ink); cursor: pointer; display: grid; place-items: center;
  transition: background var(--transitie), color var(--transitie), border-color var(--transitie);
}
.slider__knop:hover { background: var(--rood); border-color: var(--rood); color: #fff; }
.slider__knop svg { width: 20px; height: 20px; }

/* 13. NIEUWSBRIEF (donker vlak, zoals 'Kom erbij') ----------------------- */
.nieuwsbrief { background: var(--ink); color: #e9e2dc; border-radius: var(--radius); padding: clamp(2rem, 5vw, 4rem); }
.nieuwsbrief--rood { background: linear-gradient(135deg, var(--rood) 0%, var(--rood-donker) 100%); color: #ffe6e6; }
.nieuwsbrief--rood p { color: #ffe0e0; }
.nieuwsbrief--rood .veld label { color: #ffe6e6; }
.nieuwsbrief--rood .nieuwsbrief__binnen { align-items: start; }
.nieuwsbrief__binnen { display: grid; gap: var(--ruimte-l); align-items: center; }
@media (min-width: 880px) { .nieuwsbrief__binnen { grid-template-columns: 1fr 1fr; } }
.nieuwsbrief h2 { color: #fff; }
.nieuwsbrief p { color: #cfc7c0; margin-top: var(--ruimte-s); }
.nieuwsbrief__form { display: grid; gap: var(--ruimte-s); }
.nieuwsbrief__form .veld input { background: rgba(255,255,255,.97); border: 2px solid transparent; }
.nieuwsbrief__form .veld label { color: #e9e2dc; }
.nieuwsbrief__form .knop { justify-content: center; }
.nieuwsbrief small { display: block; color: #a99f97; margin-top: var(--ruimte-2xs); font-size: .85rem; }

/* 14. FORMULIEREN --------------------------------------------------------- */
.veld { display: grid; gap: .4rem; }
.veld label { font-weight: 600; color: var(--ink); font-size: .98rem; }
.veld input, .veld textarea, .veld select {
  font: inherit; width: 100%; padding: .9em 1em; border: 2px solid var(--lijn);
  border-radius: var(--radius-s); background: var(--wit); color: var(--ink); transition: border-color var(--transitie);
}
.veld textarea { min-height: 150px; resize: vertical; }
.veld input:focus-visible, .veld textarea:focus-visible, .veld select:focus-visible { outline: none; border-color: var(--rood); }
.veld--vereist label::after { content: " *"; color: var(--rood); }
.formulier { display: grid; gap: var(--ruimte-s); }
@media (min-width: 620px) { .formulier__rij { display: grid; grid-template-columns: 1fr 1fr; gap: var(--ruimte-s); } }

/* 15. FOOTER (donker grijs vlak, zoals de donkere secties) ---------------- */
.site-footer { background: var(--ink); color: #c4bdb7; padding-block: var(--ruimte-xl) var(--ruimte-l); }
.site-footer a { color: #fff; }
.site-footer a:hover { color: #ff9a9c; }
.footer-grid { display: grid; gap: var(--ruimte-l); grid-template-columns: 1fr; }
@media (min-width: 760px) { .footer-grid { grid-template-columns: 1.5fr 1fr 1fr; gap: var(--ruimte-xl); } }
.footer-merk picture { display: inline-block; background: var(--wit); padding: .7rem 1rem; border-radius: var(--radius-s); margin-bottom: var(--ruimte-s); }
.footer-merk img { height: 46px; width: auto; display: block; }
.footer-merk p { color: #b3aca6; }
.site-footer h4 { color: #fff; font-family: var(--font-tekst); font-weight: 700; font-size: 1.05rem; letter-spacing: .02em; margin-bottom: var(--ruimte-s); }
.footer-links li + li, .footer-contact li + li { margin-top: .55rem; }
.footer-socials { display: flex; gap: var(--ruimte-xs); margin-top: var(--ruimte-m); }
.footer-socials a { width: 46px; height: 46px; display: grid; place-items: center; background: rgba(255,255,255,.12); border-radius: 50%; transition: background var(--transitie), transform var(--transitie); }
.footer-socials a:hover { background: var(--rood); transform: translateY(-2px); }
.footer-socials a:hover svg { fill: #fff; }
.footer-socials svg { width: 21px; height: 21px; fill: #fff; transition: fill var(--transitie); }
.footer-onder {
  margin-top: var(--ruimte-l); padding-top: var(--ruimte-m); border-top: 1px solid rgba(255,255,255,.18);
  display: flex; flex-wrap: wrap; gap: var(--ruimte-2xs); justify-content: space-between; font-size: .9rem; color: #8f8983;
}
.footer-onder a { color: #fff; font-weight: 600; }

/* 16. NOTITIE / OVERIG ---------------------------------------------------- */
.notitie { background: var(--rood-zacht); border-left: 4px solid var(--rood); border-radius: var(--radius-s); padding: var(--ruimte-m); color: var(--ink); }
.notitie strong { color: var(--rood-donker); }
.mt-l { margin-top: var(--ruimte-l); }

/* 17. TOEGANKELIJKHEID ---------------------------------------------------- */
:focus-visible { outline: 3px solid var(--rood); outline-offset: 2px; border-radius: 3px; }
.sectie--rood :focus-visible, .hero :focus-visible { outline-color: #fff; }
.skip-link { position: absolute; left: 1rem; top: -100px; background: var(--rood); color: #fff; padding: .7rem 1.2rem; border-radius: var(--radius-s); z-index: 200; font-weight: 600; transition: top var(--transitie); }
.skip-link:focus { top: 1rem; color: #fff; }
.visueel-verborgen { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* 18. ZACHTE ENTRANCE (verbergt content NIET; faalt veilig) -------------- */
@media (prefers-reduced-motion: no-preference) {
  .reveal { opacity: 0; transform: translateY(20px); transition: opacity .6s ease, transform .6s ease; }
  .reveal.is-zichtbaar { opacity: 1; transform: none; }
}
