/* ════════════════════════════════════════════════════════════════
   ClyM Contractum — Centrale Stylesheet
   Designrichting: Premium consulting (Deloitte-stijl)
   ════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Nunito+Sans:wght@300;400;600;700;800&family=Source+Sans+3:wght@300;400;500;600&display=swap');

/* ── Custom Properties ─────────────────────────────────────────── */
:root {
  --navy: #1B3A6B;
  --goud: #C49A00;
  --goud-licht: #d4aa00;
  --achtergrond: #F8F7F4;
  --lichtblauw: #E8EFF9;
  --groen: #2D6A4F;
  --ink: #1A1A2E;
  --muted: #6B7A8D;
  --border: #DDD8D0;
  --wit: #ffffff;
  --font-kop: 'Nunito Sans', sans-serif;
  --font-body: 'Source Sans 3', sans-serif;
  --radius: 6px;
  --max-breedte: 1160px;
  --sectie-padding: 96px 24px;
}

/* ── Zachte inlij-fade bij paginawissels ──────────────────────── */
/* Doel: bij klikken op een nav-link blijft de nav-balk volledig
   stabiel; alleen de inhoud (sections + footer) faden rustig in.
   Werkt in alle browsers, geen JS nodig.
   De nav (<nav class="nav">) is bewust uitgesloten zodat logo,
   menu-links en de navy active-bar niet mee-faden — zij ogen
   statisch doordat ze op elke pagina dezelfde positie hebben. */
@keyframes clym-inlij-fade {
  from { opacity: 0; }
  to   { opacity: 1; }
}

body > section,
body > footer {
  animation: clym-inlij-fade 220ms ease-out both;
}

/* Voorkeur: geen animatie voor wie `prefers-reduced-motion` heeft. */
@media (prefers-reduced-motion: reduce) {
  body > section,
  body > footer {
    animation: none;
  }
}

/* ── Reset ──────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0 }
html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  /* Stabiliseer scrollbar: voorkomt viewport-shift tussen korte en
     lange pagina's, zodat de nav-balk visueel op dezelfde plek blijft
     bij navigatie. `scrollbar-gutter: stable` is modern, `overflow-y:
     scroll` is de brede-compatibiliteits fallback. */
  overflow-y: scroll;
  scrollbar-gutter: stable;
  /* Voorkom horizontal scroll op mobiel zonder `position: sticky`
     (de nav-balk) te breken. `overflow-x: clip` clipt wel maar
     creëert géén containing-block — in tegenstelling tot `hidden`. */
  overflow-x: clip;
}

body { overflow-x: clip; }
img, svg { display: block; max-width: 100% }
a { text-decoration: none; color: inherit }
ul, ol { list-style: none }
button { font-family: inherit }

/* ── Typografie ─────────────────────────────────────────────────── */
body {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.75;
  color: var(--ink);
  background: var(--wit);
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-kop);
  line-height: 1.2;
  color: var(--ink);
}

h1 {
  font-weight: 700;
  font-size: 3rem;
  letter-spacing: -0.5px;
}

h2 {
  font-weight: 700;
  font-size: 2rem;
  letter-spacing: -0.3px;
}

h3 {
  font-weight: 600;
  font-size: 1.25rem;
}

h4 {
  font-weight: 600;
  font-size: 1.1rem;
}

p { margin-bottom: 1rem }
p:last-child { margin-bottom: 0 }

.lead {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: 1.2rem;
  line-height: 1.7;
  color: var(--muted);
}

.label {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.75rem;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--goud);
  display: block;
  margin-bottom: 8px;
}

.tekst-muted { color: var(--muted) }
.tekst-navy  { color: var(--navy) }
.tekst-goud  { color: var(--goud) }
.tekst-groen { color: var(--groen) }
.tekst-wit   { color: var(--wit) }

.tekst-center { text-align: center }
.tekst-klein  { font-size: 0.875rem }

/* ── Layout ─────────────────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--max-breedte);
  margin: 0 auto;
  padding: 0 24px;
}

.container.smal {
  max-width: 780px;
}

.grid {
  display: grid;
  gap: 32px;
}

.grid-2 { grid-template-columns: repeat(2, 1fr) }
.grid-3 { grid-template-columns: repeat(3, 1fr) }
.grid-4 { grid-template-columns: repeat(4, 1fr) }

.flex        { display: flex }
.flex-center { display: flex; align-items: center; justify-content: center }
.flex-between{ display: flex; align-items: center; justify-content: space-between }
.flex-col    { flex-direction: column }
.gap-8       { gap: 8px }
.gap-16      { gap: 16px }
.gap-24      { gap: 24px }
.gap-32      { gap: 32px }
.gap-48      { gap: 48px }

/* ── 1. Navigatie (.nav) ────────────────────────────────────────── */
.nav {
  position: sticky;
  top: 0;
  z-index: 100;
  height: 64px;
  background: var(--wit);
  border-bottom: 1px solid var(--border);
}

.nav .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
}

.nav-merk {
  font-family: var(--font-kop);
  font-weight: 800;
  font-size: 1.3rem;
  color: var(--ink);
  letter-spacing: -0.3px;
}

.nav-merk span {
  color: var(--goud);
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 32px;
}

.nav-links a {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 14px;
  color: var(--ink);
  transition: color 0.2s;
  padding: 4px 0;
  position: relative;
}

.nav-links a:hover,
.nav-links a.actief {
  color: var(--navy);
}

.nav-links a.actief::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--navy);
  border-radius: 1px;
}

.nav-mobiel {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  color: var(--ink);
}

/* ── 2. Hero (.hero) ────────────────────────────────────────────── */
.hero {
  padding: 120px 24px 96px;
  background: var(--wit);
  position: relative;
}

.hero .container {
  position: relative;
  z-index: 1;
  max-width: var(--max-breedte);
  margin: 0 auto;
}

.hero h1 {
  max-width: 640px;
  margin-bottom: 20px;
}

.hero .lead {
  max-width: 560px;
  margin-bottom: 36px;
}

.hero-acties {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

/* ── 3. Secties (.sectie) ───────────────────────────────────────── */
.sectie {
  padding: var(--sectie-padding);
}

.sectie .container {
  max-width: var(--max-breedte);
  margin: 0 auto;
}

.sectie-hero {
  padding: var(--sectie-padding);
  padding-top: 120px;
  text-align: center;
}

/* ── Hero: vaste hoogte, content gecentreerd ─────────────────── */
/* Hero-sectie: label (goud) begint op ELKE pagina op dezelfde
   verticale hoogte. De h1 en lead eronder schuiven automatisch mee.
   Daarom `align-items: flex-start` + vaste `padding-top` i.p.v.
   vertical centering — dan maakt de lengte van h1/lead geen verschil
   meer voor waar het label zichtbaar wordt.
   `min-height` i.p.v. `height` zodat de sectie meegroeit wanneer
   content wrapt (vooral op mobiel) — voorkomt dat witte hero-tekst
   over de witte achtergrond van sectie 2 loopt. */
.page-bg section:first-of-type {
  min-height: 370px;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 96px;
  padding-bottom: 48px;
}

.page-bg section:first-of-type .container {
  width: 100%;
}

.page-bg section:first-of-type .sectie-kop {
  margin-bottom: 0;
}

/* ── Cirkel-decoratie op page-bg (fixed, scrolt niet mee) ──────── */
.page-bg::before {
  content: '';
  position: fixed;
  top: -80px;
  right: -120px;
  width: 480px;
  height: 480px;
  background: rgba(255,255,255,0.18);
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
}

.page-bg::after {
  content: '';
  position: fixed;
  top: 60px;
  right: 40px;
  width: 200px;
  height: 200px;
  border: 2px solid rgba(255,255,255,0.35);
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
}

/* Secties boven cirkels */
.page-bg section {
  position: relative;
  z-index: 1;
}

.sectie-wit        { background: var(--wit) }
.sectie-licht      { background: var(--achtergrond) }
.sectie-navy       { background: var(--navy); color: var(--wit) }
.sectie-navy h2,
.sectie-navy h3,
.sectie-navy h4    { color: var(--wit) }
.sectie-navy .lead { color: rgba(255,255,255,0.7) }
.sectie-navy .label{ color: var(--goud) }

.sectie-header {
  max-width: 600px;
  margin-bottom: 56px;
}

.sectie-header.gecentreerd {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.sectie-header .label {
  margin-bottom: 12px;
}

.sectie-header h2 {
  margin-bottom: 16px;
}

/* ── 4. Knoppen ─────────────────────────────────────────────────── */
.btn-primair,
.btn-secondair,
.btn-goud {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 15px;
  border-radius: var(--radius);
  cursor: pointer;
  transition: background 0.2s, box-shadow 0.2s, transform 0.1s;
  white-space: nowrap;
}

.btn-primair {
  background: var(--navy);
  color: var(--wit);
  padding: 14px 28px;
  border: none;
}

.btn-primair:hover {
  background: #2A4F8A;
}

.btn-primair:active {
  transform: translateY(1px);
}

.btn-secondair {
  background: transparent;
  border: 1.5px solid var(--navy);
  color: var(--navy);
  padding: 13px 27px;
}

.btn-secondair:hover {
  background: var(--lichtblauw);
}

.btn-goud {
  background: var(--goud);
  color: var(--wit);
  padding: 14px 28px;
  border: none;
}

.btn-goud:hover {
  background: var(--goud-licht);
}

.btn-klein {
  padding: 8px 18px;
  font-size: 13px;
}

.btn-breed {
  width: 100%;
}

/* ── 5. Kaarten (.kaart) ────────────────────────────────────────── */
.kaart {
  background: var(--wit);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 32px;
  transition: box-shadow 0.2s;
}

.kaart:hover {
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
}

.kaart-icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--lichtblauw);
  color: var(--navy);
  border-radius: var(--radius);
  font-size: 1.4rem;
  margin-bottom: 20px;
}

.kaart h3 {
  margin-bottom: 12px;
}

.kaart p {
  color: var(--muted);
  font-size: 0.95rem;
}

/* ── 6. Pakket-kaarten (.pakket) ────────────────────────────────── */
.pakket {
  background: var(--wit);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 36px 32px;
  transition: box-shadow 0.2s, transform 0.2s;
  display: flex;
  flex-direction: column;
  position: relative; /* anker voor .pakket-ster */
}

/* Gouden ster-medaillon in de rechterbovenhoek van een pakketcard.
   Wordt getoond op het 'meest gekozen'-pakket en beweegt automatisch
   mee bij hover omdat hij een child is van .pakket. */
.pakket-ster {
  position: absolute;
  top: -16px;
  right: -14px;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--goud);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.35rem;
  font-weight: 700;
  box-shadow: 0 4px 14px rgba(196, 154, 0, 0.45);
  z-index: 2;
  /* Subtiele pulserende aandachttrekker */
  animation: clym-ster-pulse 2.4s ease-in-out infinite;
}

.pakket-ster::after {
  content: attr(data-tooltip);
  position: absolute;
  top: 56px;
  right: 0;
  background: var(--navy);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  white-space: nowrap;
  padding: 6px 10px;
  border-radius: 4px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s;
}

.pakket:hover .pakket-ster::after {
  opacity: 1;
}

@keyframes clym-ster-pulse {
  0%, 100% { transform: scale(1);    box-shadow: 0 4px 14px rgba(196, 154, 0, 0.45); }
  50%      { transform: scale(1.08); box-shadow: 0 6px 18px rgba(196, 154, 0, 0.65); }
}

@media (prefers-reduced-motion: reduce) {
  .pakket-ster { animation: none; }
}

.pakket:hover {
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
  transform: translateY(-6px);
}

.pakket-essentials  { border-top: 3px solid var(--navy) }
.pakket-professional{ border-top: 3px solid var(--goud) }
.pakket-enterprise  { border-top: 3px solid var(--groen) }

.pakket.aanbevolen {
  box-shadow: 0 8px 32px rgba(27, 58, 107, 0.15);
  transform: translateY(-4px);
}

.pakket.aanbevolen:hover {
  box-shadow: 0 12px 40px rgba(27, 58, 107, 0.2);
  transform: translateY(-10px);
}

.pakket-naam {
  font-family: var(--font-kop);
  font-weight: 700;
  font-size: 1.25rem;
  color: var(--ink);
  margin-bottom: 8px;
}

.pakket-prijs {
  font-family: var(--font-kop);
  font-weight: 800;
  font-size: 2rem;
  color: var(--navy);
  margin-bottom: 4px;
}

.pakket-prijs-toelichting {
  font-size: 0.85rem;
  color: var(--muted);
  margin-bottom: 24px;
}

.pakket-features {
  flex: 1;
  margin-bottom: 28px;
}

.pakket-features li {
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  font-size: 0.9rem;
  color: var(--ink);
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.pakket-features li:last-child {
  border-bottom: none;
}

.pakket-features li::before {
  content: '\2713';
  color: var(--goud);
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 1px;
}

.pakket-features li.inactief {
  color: var(--muted);
  opacity: 0.5;
}

.pakket-features li.inactief::before {
  content: '\2014';
  color: var(--muted);
}

/* ── 7. Badges (.badge) ─────────────────────────────────────────── */
.badge {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 20px;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  white-space: nowrap;
}

.badge-navy {
  background: var(--lichtblauw);
  color: var(--navy);
}

.badge-goud {
  background: #FFF8E1;
  color: #8B6D00;
}

.badge-groen {
  background: #E8F5E9;
  color: var(--groen);
}

.badge-wit {
  background: rgba(255, 255, 255, 0.15);
  color: var(--wit);
}

/* ── 8. Statistieken (.stat) ────────────────────────────────────── */
.stat {
  text-align: center;
}

.stat-getal {
  font-family: var(--font-kop);
  font-weight: 800;
  font-size: 3rem;
  color: var(--navy);
  line-height: 1.1;
  letter-spacing: -0.5px;
}

.stat-label {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 0.9rem;
  color: var(--muted);
  margin-top: 4px;
}

.sectie-navy .stat-getal { color: var(--wit) }
.sectie-navy .stat-label { color: rgba(255,255,255,0.65) }

/* ── 9. Vertrouwensbalk (.vertrouwensbalk) ──────────────────────── */
.vertrouwensbalk {
  padding: 40px 24px;
  background: var(--achtergrond);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.vertrouwensbalk .container {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 48px;
  flex-wrap: wrap;
}

.vertrouwensbalk-item {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.9rem;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 8px;
}

/* ── 10. Werkwijze / Stappen (.stappen) ─────────────────────────── */
.stappen {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 32px;
  counter-reset: stap;
}

.stap {
  counter-increment: stap;
  position: relative;
  padding-left: 0;
}

.stap::before {
  content: counter(stap);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: var(--goud);
  color: var(--wit);
  font-family: var(--font-kop);
  font-weight: 700;
  font-size: 1rem;
  border-radius: 50%;
  margin-bottom: 16px;
}

.stap h3 {
  margin-bottom: 8px;
}

.stap p {
  color: var(--muted);
  font-size: 0.9rem;
}

/* ── 11. Formulier (.formulier) ─────────────────────────────────── */
.formulier {
  max-width: 560px;
}

.formulier.gecentreerd {
  margin-left: auto;
  margin-right: auto;
}

.form-groep {
  margin-bottom: 20px;
}

.formulier-compact .form-groep {
  margin-bottom: 12px;
}

.formulier-compact .form-input,
.formulier-compact .form-textarea,
.formulier-compact .form-select {
  padding: 10px 14px;
  font-size: 0.9rem;
}

.formulier-compact .form-label {
  margin-bottom: 4px;
  font-size: 0.825rem;
}

.formulier-compact .form-textarea {
  min-height: 90px;
}

.form-label {
  display: block;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.875rem;
  color: var(--ink);
  margin-bottom: 6px;
}

.form-input,
.form-textarea,
.form-select {
  width: 100%;
  padding: 12px 16px;
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 0.95rem;
  color: var(--ink);
  background: var(--wit);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.form-input:focus,
.form-textarea:focus,
.form-select:focus {
  border-color: var(--navy);
  box-shadow: 0 0 0 3px rgba(27, 58, 107, 0.08);
}

.form-textarea {
  min-height: 120px;
  resize: vertical;
}

.form-hint {
  font-size: 0.8rem;
  color: var(--muted);
  margin-top: 4px;
}

/* ── 12. Scheidingslijn (.divider) ──────────────────────────────── */
.divider {
  border: none;
  border-top: 1px solid var(--border);
  margin: 0;
}

/* ── 13. Citaat (.citaat) ───────────────────────────────────────── */
.citaat {
  border-left: 3px solid var(--goud);
  padding: 20px 24px;
  background: var(--achtergrond);
  border-radius: 0 var(--radius) var(--radius) 0;
}

.citaat-tekst {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 1.05rem;
  font-style: italic;
  color: var(--ink);
  line-height: 1.7;
  margin-bottom: 12px;
}

/* Variant zonder italic, voor informatieve passages die de citaat-
   vormgeving gebruiken (gouden linkerrand + lichte achtergrond)
   maar inhoudelijk geen quote zijn. */
.citaat-tekst.niet-italic { font-style: normal; }

/* ── FAQ-sectie: transparant, FAQ-inhoud in lichte beige box ──
   De sectie zelf is transparant — de page-bg-foto schijnt door,
   net zoals bij het citaat op werkwijze.html. De FAQ-inhoud
   (accordeon-items) wordt in een lichte beige box geplaatst voor
   goede leesbaarheid. Geen gouden linkerrand (anders dan .citaat).
   Consistent op alle pagina's, ongeacht welke foto eronder ligt. */
.page-bg section.faq-sectie,
section.faq-sectie {
  background: transparent;
}

/* De sectie-kop-label en h2 boven de FAQ blijven gewoon leesbaar
   op de overlay (wit op donker dankzij page-bg odd-regels). */

/* De FAQ-box: semi-transparante beige, de foto schijnt licht door
   zoals bij de citaat-box op werkwijze.html. Geen gouden linker-
   rand, alle hoeken afgerond. */
.faq-sectie .formulier.gecentreerd {
  background: rgba(248, 247, 244, 0.60);
  border-radius: var(--radius);
  padding: 24px 32px;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}

/* Kleurregels voor de FAQ-box zijn verplaatst naar onder
   (sectie "FAQ-sectie kleurdefinities") om te winnen van de
   `.page-bg section:nth-of-type(odd) .accordeon-trigger*` regels
   die anders bij gelijke specificiteit later in het bestand staan. */

.citaat-auteur {
  font-weight: 600;
  font-size: 0.85rem;
  color: var(--muted);
}

/* ── 13a. Pakket-cards aligneren via CSS subgrid (pakketten.html)
   Alle drie de pakket-cards delen één gedeeld 8-rijig raster.
   Elk "kop + bijbehorende tekst"-paar (De vraag / Voor wie / Wat je
   krijgt) zit samen in één `.pakket-blok` en dus in één gedeelde
   subgrid-cel. De kopjes staan daardoor in alle drie de cards op
   dezelfde verticale positie, én hun tekst sluit er direct onder
   aan — geen losse witruimte meer.
   Browsers zonder subgrid-support vallen terug op de flex-layout. */
@supports (grid-template-rows: subgrid) {
  .grid.grid-3:has(> .pakket > .pakket-intro) {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows:
      auto    /* 1. pakket-naam */
      auto    /* 2. pakket-subkop */
      auto    /* 3. pakket-intro (italic muted) */
      auto    /* 4. .pakket-blok: De vraag + vraag-tekst */
      auto    /* 5. .pakket-blok: Voor wie + voor-wie-tekst */
      1fr     /* 6. .pakket-blok-groei: Wat je krijgt + features */
      auto    /* 7. pakket-afschaffing */
      auto;   /* 8. CTA-knop (offerte aanvragen) */
    /* row-gap uit: de elementen regelen hun eigen onderlinge
       spacing via margin-bottom. Anders komt 32 px grid-gap boven-
       op de margins wat dubbele ruimte geeft. */
    row-gap: 0;
    column-gap: 32px;
  }

  .grid.grid-3:has(> .pakket > .pakket-intro) > .pakket {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: subgrid;
    grid-row: span 8;
    /* De flex-defaults uitschakelen (ze zouden botsen met subgrid) */
    flex-direction: initial;
  }

  /* Op mobiel (één kolom onder elkaar) heeft gelijke-hoogte-
     synchronisatie geen zin — schakel subgrid uit. */
  @media (max-width: 960px) {
    .grid.grid-3:has(> .pakket > .pakket-intro) {
      grid-template-columns: 1fr;
      grid-template-rows: none;
    }
    .grid.grid-3:has(> .pakket > .pakket-intro) > .pakket {
      display: flex;
      flex-direction: column;
      grid-row: auto;
    }
  }
}

/* Wrapper die een blok-titel + bijbehorende tekst bij elkaar houdt.
   Kop en tekst liggen daardoor altijd direct tegen elkaar, ongeacht
   hoe hoog de gedeelde subgrid-cel is. */
.pakket-blok {
  display: flex;
  flex-direction: column;
  margin-bottom: 20px;
}

/* De blok-titel is binnen een wrapper het eerste kind; resetten we
   zijn top-margin zodat de kop tegen de bovenkant van de cel staat.
   De bottom-margin (6 px ruimte naar de tekst eronder) blijft. */
.pakket-blok > .pakket-blok-titel {
  margin-top: 0;
}

/* Het laatste blok ("Wat je krijgt") mag groeien zodat de features-
   lijst de beschikbare ruimte opvult en de CTA-knop netjes onderaan
   de card blijft hangen — ook wanneer subgrid uit staat op mobiel. */
.pakket-blok-groei {
  flex: 1;
  margin-bottom: 20px;
}
.pakket-blok-groei .pakket-features {
  flex: 1;
  margin-bottom: 0;
}

/* ── 13b. Pakket-content blokken (pakketten.html) ──────────────── */
/* Subkop direct onder pakket-naam (korte belofte) */
.pakket-subkop {
  font-family: var(--font-kop);
  font-weight: 700;
  font-size: 1rem;
  color: var(--navy);
  margin-bottom: 12px;
}

/* Intro-alinea in lichtere, italic stijl */
.pakket-intro {
  font-style: italic;
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.55;
  margin-bottom: 20px;
}

/* Blok-titels binnen card ("De vraag die we beantwoorden:" etc.) */
.pakket-blok-titel {
  font-family: var(--font-kop);
  font-weight: 700;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: var(--navy);
  margin: 16px 0 6px 0;
}

/* Tekst bij "De vraag die we beantwoorden" (geciteerd, italic) */
.pakket-vraag {
  font-style: italic;
  color: var(--ink);
  font-size: 0.95rem;
  line-height: 1.55;
  margin-bottom: 8px;
}

/* Korte doelgroep-tekst */
.pakket-voor-wie {
  font-size: 0.9rem;
  color: var(--ink);
  line-height: 1.55;
  margin-bottom: 8px;
}

/* Afschaffingsregel (type contract: eenmalig / jaarlijks) */
.pakket-afschaffing {
  font-weight: 700;
  color: var(--goud);
  font-size: 0.85rem;
  letter-spacing: 0.3px;
  margin: 16px 0 20px 0;
}

/* ── 13c. SDG-blok op pakketten.html ──────────────────────────── */
.sdg-blok {
  background: var(--wit);
  border: 1px solid var(--border);
  border-left: 4px solid var(--groen);
  border-radius: var(--radius);
  padding: 32px 32px;
  max-width: 820px;
  margin: 0 auto;
}

.sdg-blok h3 {
  font-family: var(--font-kop);
  font-weight: 800;
  font-size: 1.25rem;
  color: var(--navy);
  margin-bottom: 12px;
}

.sdg-blok p {
  color: var(--ink);
  line-height: 1.65;
  margin-bottom: 20px;
}

/* ── 13e. Formulier-helpertekst (bij intake.html) ─────────────── */
/* .form-hint bestaat al; alias met iets andere nadruk */
.form-helpertekst {
  font-size: 0.82rem;
  color: var(--muted);
  font-style: italic;
  margin-top: 4px;
  line-height: 1.5;
}

/* Sectie-kop binnen intake (sub-section headers) */
.intake-sectie-kop {
  font-family: var(--font-kop);
  font-weight: 800;
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--navy);
  margin: 40px 0 16px 0;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--goud);
}

.intake-sectie-kop:first-child {
  margin-top: 0;
}

/* ── 14. Footer (.footer) ───────────────────────────────────────── */
.footer {
  padding: 64px 24px 32px;
  background: var(--ink);
  color: rgba(255, 255, 255, 0.6);
}

.footer .container {
  max-width: var(--max-breedte);
  margin: 0 auto;
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
  margin-bottom: 48px;
}

.footer-merk {
  font-family: var(--font-kop);
  font-weight: 800;
  font-size: 1.5rem;
  color: var(--wit);
  margin-bottom: 12px;
}

.footer-merk span {
  color: var(--goud);
}

.footer h4 {
  color: var(--wit);
  font-size: 0.85rem;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin-bottom: 16px;
}

.footer a {
  color: rgba(255, 255, 255, 0.6);
  font-size: 0.9rem;
  display: block;
  padding: 4px 0;
  transition: color 0.2s;
}

.footer a:hover {
  color: var(--wit);
}

.footer-disclaimer {
  font-size: 0.65rem;
  line-height: 1;
  color: rgba(255, 255, 255, 0.25);
  text-align: center;
  margin-top: 12px;
  white-space: nowrap;
}

.footer-bodem {
  padding-top: 24px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.8rem;
}

/* ── 15. Accordeon (.accordeon) ─────────────────────────────────── */
.accordeon-item {
  border-bottom: 1px solid var(--border);
}

.accordeon-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 0;
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 1rem;
  color: var(--ink);
  text-align: left;
  transition: color 0.2s;
}

.accordeon-trigger:hover {
  color: var(--navy);
}

.accordeon-trigger::after {
  content: '+';
  font-size: 1.3rem;
  font-weight: 300;
  color: var(--muted);
  transition: transform 0.2s;
}

.accordeon-item.open .accordeon-trigger::after {
  content: '\2212';
}

.accordeon-inhoud {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.accordeon-item.open .accordeon-inhoud {
  max-height: 500px;
}

.accordeon-tekst {
  padding-bottom: 20px;
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.7;
}

/* ── 16. Tabel (.tabel) ─────────────────────────────────────────── */
.tabel {
  background: var(--wit);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: 0 1px 6px rgba(0,0,0,0.06);
  color: var(--ink);
}

.tabel table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}

.tabel th,
.tabel td {
  padding: 14px 16px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  font-size: 0.9rem;
  color: var(--ink);
}

.tabel th {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.75rem;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--wit);
  background: var(--navy);
  border-bottom: 2px solid var(--goud);
}

.tabel th:not(:first-child),
.tabel td:not(:first-child) {
  text-align: center;
}

.tabel tbody tr:nth-child(even) td {
  background: var(--achtergrond);
}


.tabel tr:hover td {
  background: var(--lichtblauw);
  color: var(--ink);
}

/* ── 17. Stat-balk (.stat-balk) ────────────────────────────────── */
.stat-balk {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: var(--achtergrond);
}

.stat-balk-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px 24px;
  text-align: center;
  border-right: 1px solid var(--border);
}

.stat-balk-item:last-child {
  border-right: none;
}

.stat-balk-getal {
  font-family: var(--font-kop);
  font-weight: 800;
  font-size: 2.4rem;
  color: var(--navy);
  line-height: 1;
  letter-spacing: -0.5px;
}

.stat-balk-label {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.85rem;
  color: var(--muted);
  margin-top: 8px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* ── 18. Sectie varianten ──────────────────────────────────────── */
.sectie-grijs {
  background: #F3F2EF;
}

.sectie-kop {
  max-width: 640px;
  margin-bottom: 56px;
}

.sectie-kop.gecentreerd {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.sectie-kop .label {
  margin-bottom: 12px;
}

.sectie-kop h2 {
  margin-bottom: 16px;
}

.sectie-kop p {
  color: var(--muted);
  font-size: 1.1rem;
  line-height: 1.7;
}

/* ── 19. Probleem-grid (.probleem-grid) ────────────────────────── */
.probleem-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}

.probleem-kaart {
  background: var(--wit);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 36px 32px;
  text-align: center;
  transition: box-shadow 0.2s, transform 0.2s;
}

.probleem-kaart:hover {
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
  transform: translateY(-2px);
}

.probleem-kaart-icoon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--lichtblauw);
  color: var(--navy);
  border-radius: 50%;
  font-size: 1.5rem;
  margin: 0 auto 20px;
}

.probleem-kaart h3 {
  margin-bottom: 12px;
  font-size: 1.15rem;
}

.probleem-kaart p {
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.65;
}

/* ── 20. Stappen-grid (.stappen-grid) ──────────────────────────── */
.stappen-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 48px;
  counter-reset: stap-nr;
}

.stappen-grid .stap {
  counter-increment: stap-nr;
  position: relative;
  text-align: center;
  padding: 0;
}

.stappen-grid .stap::before {
  content: counter(stap-nr);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  background: var(--goud);
  color: var(--wit);
  font-family: var(--font-kop);
  font-weight: 700;
  font-size: 1.2rem;
  border-radius: 50%;
  margin: 0 auto 20px;
}

.stappen-grid .stap h3 {
  margin-bottom: 10px;
  font-size: 1.15rem;
}

.stappen-grid .stap p {
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.65;
  max-width: 280px;
  margin: 0 auto;
}

.stappen-grid-4 {
  grid-template-columns: repeat(4, 1fr);
  gap: 36px;
}

/* Verbindingslijn tussen stappen */
.stappen-grid .stap:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 26px;
  left: calc(50% + 34px);
  width: calc(100% - 68px);
  height: 2px;
  background: var(--border);
  pointer-events: none;
}

/* ── 21. Modules-grid (.modules-grid) ──────────────────────────── */
.modules-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

/* 5 modules: 3 bovenste rij, 2 onderste gecentreerd */
.modules-grid.modules-5 {
  grid-template-columns: repeat(6, 1fr);
}

.modules-grid.modules-5 .module-kaart:nth-child(1) { grid-column: 1 / 3 }
.modules-grid.modules-5 .module-kaart:nth-child(2) { grid-column: 3 / 5 }
.modules-grid.modules-5 .module-kaart:nth-child(3) { grid-column: 5 / 7 }
.modules-grid.modules-5 .module-kaart:nth-child(4) { grid-column: 2 / 4 }
.modules-grid.modules-5 .module-kaart:nth-child(5) { grid-column: 4 / 6 }

.module-kaart {
  background: var(--wit);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 32px 28px;
  transition: box-shadow 0.2s, transform 0.2s;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.module-kaart:hover {
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
  transform: translateY(-2px);
}

.module-icoon {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius);
  font-family: var(--font-kop);
  font-weight: 800;
  font-size: 0.8rem;
  letter-spacing: 0.5px;
  margin-bottom: 20px;
  flex-shrink: 0;
}

.module-icoon-navy {
  background: var(--lichtblauw);
  color: var(--navy);
}

.module-icoon-goud {
  background: #FFF8E1;
  color: #8B6D00;
}

.module-icoon-groen {
  background: #E8F5E9;
  color: var(--groen);
}

.module-kaart h3 {
  margin-bottom: 10px;
  font-size: 1.1rem;
}

.module-kaart p {
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.65;
}

/* ── 22. Pakketten-grid (.pakketten-grid) ──────────────────────── */
.pakketten-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  align-items: start;
}

.pakketten-grid .pakket {
  border-top-width: 4px;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
}

.pakketten-grid .pakket:hover {
  box-shadow: 0 8px 36px rgba(0, 0, 0, 0.1);
  transform: translateY(-6px);
}

.pakketten-grid .pakket.aanbevolen {
  box-shadow: 0 12px 40px rgba(27, 58, 107, 0.15);
  transform: translateY(-6px);
  border-top-width: 4px;
}

.pakketten-grid .pakket.aanbevolen:hover {
  box-shadow: 0 16px 48px rgba(27, 58, 107, 0.2);
  transform: translateY(-10px);
}

/* ── 23. Her-meting stats ──────────────────────────────────────── */
.hermet-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
  max-width: 500px;
  margin: 0 auto;
}

.hermet-stats-3 {
  grid-template-columns: repeat(3, 1fr);
  max-width: 640px;
}

.hermet-stats .stat-getal {
  color: var(--wit);
}

.hermet-stats .stat-label {
  color: rgba(255, 255, 255, 0.65);
}

/* ── 24. Element-grid (.element-grid) ──────────────────────────── */
.element-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.element-grid-2 {
  grid-template-columns: repeat(2, 1fr);
}

.element-blok {
  background: var(--achtergrond);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 18px;
  text-align: center;
}

.element-blok-breed {
  grid-column: 1 / -1;
}

.element-blok strong {
  display: block;
  font-family: var(--font-kop);
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--navy);
  margin-bottom: 4px;
}

.element-blok p {
  margin-bottom: 0;
}

/* ── 25. Deelnemer-grid (.deelnemer-grid) ─────────────────────── */
.deelnemer-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

.deelnemer-blok {
  background: var(--wit);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 32px 24px;
  text-align: center;
}

.deelnemer-icoon {
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--lichtblauw);
  color: var(--navy);
  margin: 0 auto 16px;
}

.deelnemer-blok .stat-getal {
  margin-bottom: 4px;
}

.deelnemer-icoon-breed {
  display: inline-flex;
  width: auto;
  height: 52px;
  padding: 0 18px;
  border-radius: 26px;
  gap: 8px;
  align-items: center;
}

.deelnemer-icoon-breed svg {
  flex-shrink: 0;
  vertical-align: bottom;
}

/* Transparante secties: element-blok aanpassen */
.page-bg section:nth-of-type(odd) .element-blok {
  background: rgba(255,255,255,0.88);
}
.page-bg section:nth-of-type(odd) .element-blok strong { color: var(--navy) }
.page-bg section:nth-of-type(odd) .element-blok p { color: var(--muted) }

/* ── 25. Pagina-achtergronden (.page-bg-*) ─────────────────────── */
.page-bg {
  background-attachment: fixed;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* Lokale bestanden (gebruik zodra img/ is gevuld):
   background-image: linear-gradient(rgba(27,58,107,0.6), rgba(27,58,107,0.6)), url('../img/bg-index.jpg');
*/

.page-bg-index {
  background-image:
    linear-gradient(rgba(27,58,107,0.55), rgba(27,58,107,0.55)),
    url('https://images.unsplash.com/photo-1450101499163-c8848c66ca85?w=1920&q=80&fit=crop');
}

.page-bg-modules {
  background-image:
    linear-gradient(rgba(27,58,107,0.6), rgba(27,58,107,0.6)),
    url('https://images.unsplash.com/photo-1552664730-d307ca884978?w=1920&q=80&fit=crop');
}

.page-bg-pakketten {
  background-image:
    linear-gradient(rgba(27,58,107,0.55), rgba(27,58,107,0.55)),
    url('https://images.unsplash.com/photo-1554224155-6726b3ff858f?w=1920&q=80&fit=crop');
}

.page-bg-werkwijze {
  background-image:
    linear-gradient(rgba(27,58,107,0.6), rgba(27,58,107,0.6)),
    url('https://images.unsplash.com/photo-1517245386807-bb43f82c33c4?w=1920&q=80&fit=crop');
}

.page-bg-contact {
  background-image:
    linear-gradient(rgba(27,58,107,0.55), rgba(27,58,107,0.55)),
    url('https://images.unsplash.com/photo-1521791136064-7986c2920216?w=1920&q=80&fit=crop');
}

.page-bg-inloggen {
  background-image:
    linear-gradient(rgba(27,58,107,0.6), rgba(27,58,107,0.6)),
    url('https://images.unsplash.com/photo-1497366216548-37526070297c?w=1920&q=80&fit=crop');
}

.page-bg-methodiek {
  background-image:
    linear-gradient(rgba(27,58,107,0.55), rgba(27,58,107,0.55)),
    url('https://images.unsplash.com/photo-1532619675605-1ede6c2ed2b0?w=1920&q=80&fit=crop');
}

.page-bg-over {
  background-image:
    linear-gradient(rgba(27,58,107,0.55), rgba(27,58,107,0.55)),
    url('https://images.unsplash.com/photo-1454165804606-c3d57bc86b40?w=1920&q=80&fit=crop');
}

/* ── Even secties: opaak (witte/lichte achtergrond) ──────────── */
.page-bg section:nth-of-type(even) { background: rgba(255,255,255,0.92) }

/* ── Oneven secties: transparant, foto zichtbaar ─────────────── */
.page-bg section:nth-of-type(odd) {
  background: transparent;
  color: var(--wit);
}
.page-bg section:nth-of-type(odd) h1,
.page-bg section:nth-of-type(odd) h2,
.page-bg section:nth-of-type(odd) h3 { color: var(--wit) }
.page-bg section:nth-of-type(odd) .lead { color: rgba(255,255,255,0.8) }
.page-bg section:nth-of-type(odd) .label { color: var(--goud) }
.page-bg section:nth-of-type(odd) p { color: rgba(255,255,255,0.75) }
.page-bg section:nth-of-type(odd) .tekst-muted { color: rgba(255,255,255,0.6) }
.page-bg section:nth-of-type(odd) .stat-label { color: rgba(255,255,255,0.65) }

/* Kaarten in transparante secties: semi-transparant wit */
.page-bg section:nth-of-type(odd) .kaart,
.page-bg section:nth-of-type(odd) .probleem-kaart,
.page-bg section:nth-of-type(odd) .module-kaart,
.page-bg section:nth-of-type(odd) .inlog-kaart {
  background: rgba(255,255,255,0.92);
  color: var(--ink);
}
.page-bg section:nth-of-type(odd) .kaart h3,
.page-bg section:nth-of-type(odd) .probleem-kaart h3,
.page-bg section:nth-of-type(odd) .module-kaart h3,
.page-bg section:nth-of-type(odd) .inlog-kaart h2 { color: var(--ink) }
.page-bg section:nth-of-type(odd) .kaart p,
.page-bg section:nth-of-type(odd) .probleem-kaart p,
.page-bg section:nth-of-type(odd) .module-kaart p,
.page-bg section:nth-of-type(odd) .inlog-kaart p { color: var(--muted) }

/* Pakket-kaarten in transparante secties */
.page-bg section:nth-of-type(odd) .pakket {
  background: rgba(255,255,255,0.95);
  color: var(--ink);
}
.page-bg section:nth-of-type(odd) .pakket-naam { color: var(--ink) }
.page-bg section:nth-of-type(odd) .pakket-prijs { color: var(--navy) }
.page-bg section:nth-of-type(odd) .pakket-prijs-toelichting { color: var(--muted) }
.page-bg section:nth-of-type(odd) .pakket-features li { color: var(--ink) }
.page-bg section:nth-of-type(odd) .pakket-features li::before { color: var(--goud) }
.page-bg section:nth-of-type(odd) .pakket-features li.inactief { color: var(--muted) }
.page-bg section:nth-of-type(odd) .pakket-features li.inactief::before { color: var(--muted) }
.page-bg section:nth-of-type(odd) .pakket .divider { border-top-color: var(--border) }
.page-bg section:nth-of-type(odd) .pakket .badge { color: var(--goud) }
.page-bg section:nth-of-type(odd) .pakket .btn-secondair { color: var(--navy); border-color: var(--navy) }
.page-bg section:nth-of-type(odd) .pakket .btn-primair { color: var(--wit); background: var(--navy) }

/* Stap-nummers in transparante secties: goud voor contrast */
.page-bg section:nth-of-type(odd) .stappen-grid .stap::before {
  background: var(--goud);
  color: var(--wit);
}

/* Formulier-velden in transparante secties */
.page-bg section:nth-of-type(odd) .form-label { color: var(--wit) }
.page-bg section:nth-of-type(odd) .form-input,
.page-bg section:nth-of-type(odd) .form-textarea,
.page-bg section:nth-of-type(odd) .form-select {
  background: rgba(255,255,255,0.9);
}

/* Knoppen in transparante secties: witte rand en tekst */
.page-bg section:nth-of-type(odd) .btn-secondair { color: var(--wit); border-color: var(--wit) }
.page-bg section:nth-of-type(odd) .btn-secondair:hover { background: rgba(255,255,255,0.15) }

/* Accordeon in transparante secties */
.page-bg section:nth-of-type(odd) .accordeon-trigger { color: var(--wit) }
.page-bg section:nth-of-type(odd) .accordeon-trigger::after { color: rgba(255,255,255,0.5) }
.page-bg section:nth-of-type(odd) .accordeon-item { border-color: rgba(255,255,255,0.2) }
.page-bg section:nth-of-type(odd) .accordeon-tekst { color: rgba(255,255,255,0.7) }

/* Citaat in transparante secties */
.page-bg section:nth-of-type(odd) .citaat {
  background: rgba(255,255,255,0.1);
  border-left-color: var(--goud);
}
.page-bg section:nth-of-type(odd) .citaat-tekst { color: var(--wit) }
.page-bg section:nth-of-type(odd) .citaat-auteur { color: rgba(255,255,255,0.6) }

/* ── FAQ-sectie kleurdefinities — MOET NA de odd-regels hierboven
   staan, anders winnen die bij gelijke specificiteit en worden
   vraag + plusje wit i.p.v. navy. */
.page-bg section.faq-sectie .accordeon-trigger,
section.faq-sectie .accordeon-trigger {
  color: var(--navy);
}
.page-bg section.faq-sectie .accordeon-trigger::after,
section.faq-sectie .accordeon-trigger::after {
  color: inherit;
}
.page-bg section.faq-sectie .accordeon-tekst,
section.faq-sectie .accordeon-tekst {
  color: var(--wit);
}
.page-bg section.faq-sectie .accordeon-item,
section.faq-sectie .accordeon-item {
  border-color: rgba(0,0,0,0.08);
}

/* Divider in transparante secties */
.page-bg section:nth-of-type(odd) .divider { border-top-color: rgba(255,255,255,0.2) }

/* Tabel: altijd donkere tekst, ongeacht sectie-positie */
.page-bg section:nth-of-type(odd) .tabel { background: var(--wit); color: var(--ink) }
.page-bg section:nth-of-type(odd) .tabel th { background: var(--navy); color: var(--wit); border-color: var(--goud) }
.page-bg section:nth-of-type(odd) .tabel td { color: var(--ink); border-color: var(--border); background: var(--wit) }
.page-bg section:nth-of-type(odd) .tabel tbody tr:nth-child(even) td { background: var(--achtergrond) }
.page-bg section:nth-of-type(odd) .tabel tr:hover td { background: var(--lichtblauw); color: var(--ink) }

/* .sectie-navy behoudt altijd eigen stijl, ongeacht positie
   section.sectie-navy → specificiteit 0,2,1 ≥ section:nth-of-type(even) */
.page-bg section.sectie-navy { background: var(--navy); color: var(--wit) }
.page-bg section.sectie-navy h2,
.page-bg section.sectie-navy h3 { color: var(--wit) }
.page-bg section.sectie-navy .lead { color: rgba(255,255,255,0.7) }
.page-bg section.sectie-navy .label { color: var(--goud) }
.page-bg section.sectie-navy .stat-getal { color: var(--wit) }
.page-bg section.sectie-navy .stat-label { color: rgba(255,255,255,0.65) }

/* Vertrouwensbalk / stat-balk: altijd opaak */
.page-bg .stat-balk       { background: rgba(248,247,244,0.9) }
.page-bg .vertrouwensbalk { background: rgba(248,247,244,0.9) }

/* Footer blijft altijd solide */
.page-bg .footer { background: var(--ink) }

/* Nav op bg-pagina's: licht frosted-glass effect */
.page-bg .nav {
  background: rgba(255,255,255,0.95);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

/* Mobiel: geen fixed attachment (performance) */
@media (max-width: 640px) {
  .page-bg { background-attachment: scroll }
}

/* ── 25. Inlog-kaarten (.inlog-grid) ───────────────────────────── */
.inlog-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
  max-width: 840px;
  margin: 0 auto;
}

.inlog-kaart {
  background: var(--wit);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 40px 36px;
  text-align: center;
  transition: box-shadow 0.2s, transform 0.2s;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.inlog-kaart:hover {
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
  transform: translateY(-2px);
}

.inlog-kaart-icoon {
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-size: 1.6rem;
  margin-bottom: 24px;
}

.inlog-kaart-icoon-navy {
  background: var(--lichtblauw);
  color: var(--navy);
}

.inlog-kaart-icoon-goud {
  background: #FFF8E1;
  color: #8B6D00;
}

.inlog-kaart h2 {
  font-size: 1.35rem;
  margin-bottom: 12px;
}

.inlog-kaart p {
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.65;
  margin-bottom: 28px;
}

.inlog-kaart .form-groep {
  width: 100%;
  margin-bottom: 16px;
  text-align: left;
}

.inlog-kaart .btn-primair,
.inlog-kaart .btn-goud {
  width: 100%;
}

.inlog-scheider {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.8rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* ── Utilities ──────────────────────────────────────────────────── */
.mt-8  { margin-top: 8px }
.mt-16 { margin-top: 16px }
.mt-24 { margin-top: 24px }
.mt-32 { margin-top: 32px }
.mt-48 { margin-top: 48px }
.mt-64 { margin-top: 64px }
.mb-8  { margin-bottom: 8px }
.mb-16 { margin-bottom: 16px }
.mb-24 { margin-bottom: 24px }
.mb-32 { margin-bottom: 32px }
.mb-48 { margin-bottom: 48px }

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  border: 0;
}

/* ── Responsive ─────────────────────────────────────────────────── */
@media (max-width: 1080px) {
  .modules-grid.modules-5 {
    grid-template-columns: repeat(2, 1fr);
  }
  .modules-grid.modules-5 .module-kaart:nth-child(1),
  .modules-grid.modules-5 .module-kaart:nth-child(2),
  .modules-grid.modules-5 .module-kaart:nth-child(3),
  .modules-grid.modules-5 .module-kaart:nth-child(4) { grid-column: auto }
  .modules-grid.modules-5 .module-kaart:nth-child(5) { grid-column: 1 / -1; max-width: 400px; margin: 0 auto }
}

@media (max-width: 960px) {
  .grid-3 { grid-template-columns: repeat(2, 1fr) }
  .grid-4 { grid-template-columns: repeat(2, 1fr) }
  .footer-grid { grid-template-columns: 1fr 1fr }
  h1 { font-size: 2.4rem }
  h2 { font-size: 1.7rem }
  .hero,
  .sectie-hero { padding: 80px 24px 64px }
  .page-bg section:first-of-type {
    min-height: 300px;
    height: auto;
    padding-top: 72px;
    padding-bottom: 40px;
  }
  .page-bg::before { width: 320px; height: 320px; top: -40px; right: -80px }
  .page-bg::after { display: none }
  :root { --sectie-padding: 64px 24px }

  .stat-balk { grid-template-columns: repeat(2, 1fr) }
  .stat-balk-item:nth-child(2) { border-right: none }
  .stat-balk-item:nth-child(1),
  .stat-balk-item:nth-child(2) { border-bottom: 1px solid var(--border) }
  .probleem-grid { grid-template-columns: repeat(2, 1fr) }
  .probleem-grid .probleem-kaart:last-child { grid-column: 1 / -1; max-width: 400px; margin: 0 auto }
  .stappen-grid, .stappen-grid-4 { grid-template-columns: repeat(2, 1fr); gap: 32px }
  .stappen-grid .stap::after { display: none }
  .modules-grid { grid-template-columns: repeat(2, 1fr) }
  .modules-grid.modules-5 { grid-template-columns: repeat(2, 1fr) }
  .modules-grid.modules-5 .module-kaart { grid-column: auto }
  .modules-grid.modules-5 .module-kaart:last-child { grid-column: 1 / -1; max-width: 400px; margin: 0 auto }
  .pakketten-grid { grid-template-columns: 1fr; max-width: 440px; margin-left: auto; margin-right: auto }
  .pakketten-grid .pakket.aanbevolen { transform: none }
  /* Ster blijft binnen de card op smallere schermen (anders steekt
     hij over de pagina-rand en veroorzaakt horizontal scroll). */
  .pakket-ster { top: -14px; right: 8px; width: 42px; height: 42px; font-size: 1.2rem }
  .gap-48 { gap: 32px }
  .nav .flex.gap-8 { gap: 6px }
  .btn-klein { padding: 8px 14px; font-size: 0.78rem }
}

@media (max-width: 640px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr }
  .footer-grid { grid-template-columns: 1fr }
  h1 { font-size: 2rem }
  h2 { font-size: 1.5rem }
  .stat-getal { font-size: 2.2rem }
  .hero,
  .sectie-hero { padding: 64px 20px 48px }
  .page-bg section:first-of-type {
    min-height: 240px;
    height: auto;
    padding-top: 48px;
    padding-bottom: 36px;
  }
  .page-bg::before { width: 200px; height: 200px; opacity: 0.25 }
  :root { --sectie-padding: 48px 20px }

  .nav-links { display: none }
  .nav-links.open {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 64px;
    left: 0;
    right: 0;
    background: var(--wit);
    border-bottom: 1px solid var(--border);
    padding: 16px 24px;
    gap: 12px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
    z-index: 99;
  }
  .nav-mobiel { display: block; font-size: 1.5rem; padding: 8px 12px; }
  /* Op smalle schermen te veel knoppen naast elkaar → de hamburger
     wordt verdrongen. Verberg Inloggen (zit sowieso in de footer en
     is te bereiken via menu). Offerte-knop blijft zichtbaar als
     primaire CTA naast de hamburger. */
  .nav .flex.gap-8 .btn-secondair { display: none; }

  .vertrouwensbalk .container { gap: 24px }
  .pakket.aanbevolen { transform: none }
  .footer-bodem { flex-direction: column; gap: 8px; text-align: center }

  .stat-balk { grid-template-columns: repeat(2, 1fr) }
  .stat-balk-getal { font-size: 1.8rem }
  .stat-balk-item { padding: 24px 16px }
  .probleem-grid { grid-template-columns: 1fr }
  .deelnemer-grid { grid-template-columns: 1fr; max-width: 360px }
  .probleem-grid .probleem-kaart:last-child { max-width: none }
  .modules-grid, .modules-grid.modules-5 { grid-template-columns: 1fr }
  .modules-grid.modules-5 .module-kaart:last-child { max-width: none; margin: 0 }
  .hermet-stats { grid-template-columns: 1fr }
  .inlog-grid { grid-template-columns: 1fr; max-width: 440px }
  .element-grid { grid-template-columns: repeat(2, 1fr) }
  .footer-disclaimer { white-space: normal; font-size: 0.6rem }
  .hermet-stats-3 { grid-template-columns: 1fr }
  .tabel { overflow-x: auto; -webkit-overflow-scrolling: touch }
  .tabel table { min-width: 580px }
  .container.smal { padding-left: 16px; padding-right: 16px }
  .container.smal p { font-size: 0.9rem }
  .container.smal h2 { font-size: 1.25rem }
  .accordeon-vraag { font-size: 0.95rem }
  .gap-48 { gap: 20px }
  .sectie-hero { padding-top: 80px }
  .nav .flex.gap-8 { gap: 4px }
  .btn-klein { padding: 6px 12px; font-size: 0.75rem }
  .element-grid-2 { grid-template-columns: 1fr }
  .kaart { padding: 24px }
  .probleem-kaart { padding: 20px }
  .badge { white-space: normal }
  .form-input, .form-select, .form-textarea { padding: 12px 14px; font-size: 1rem }
  .nav-mobiel { font-size: 1.4rem }
}

/* ══════════════════════════════════════════════════════════════
   MOBIELE OPTIMALISATIE — uitbreiding op de 1080/960/640-breakpoints
   Doel: vlekkeloos op S25+ Ultra (412px), iPhone 13-15 (390px),
   iPhone SE (375px), Galaxy S20 (360px). Premium-look behouden.
   ══════════════════════════════════════════════════════════════ */

/* ── Tussenbreakpoint 768px (tablet staand / groot-mobiel) ──── */
@media (max-width: 768px) {
  /* Hamburger al vanaf 768 zichtbaar zodat er geen overvolle nav
     ontstaat op tablets in staande modus. */
  .nav-links { display: none }
  .nav-links.open {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 64px;
    left: 0;
    right: 0;
    background: var(--wit);
    border-bottom: 1px solid var(--border);
    padding: 16px 24px;
    gap: 12px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
    z-index: 99;
  }
  .nav-mobiel { display: block; font-size: 1.5rem; padding: 8px 12px; }

  /* Footer op 2 kolommen i.p.v. 1 — benut de extra ruimte. */
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px }

  /* Iets rustigere koppen */
  h1 { font-size: 2.2rem }
  h2 { font-size: 1.6rem }

  /* Alle formulier-velden vullen 100% van de container */
  .formulier,
  .formulier.gecentreerd { max-width: 100%; }

  /* Tabellen horizontaal scrollbaar ipv breken van de layout */
  .tabel { overflow-x: auto; -webkit-overflow-scrolling: touch }
  .tabel table { min-width: 560px }
}

/* ── Ondergrens 480px (smalle telefoon, zoals Galaxy S20 staand) ── */
@media (max-width: 480px) {
  /* Koppen verder schalen */
  h1 { font-size: 1.8rem; line-height: 1.25 }
  h2 { font-size: 1.35rem; line-height: 1.3 }
  h3 { font-size: 1.15rem }

  /* Body-tekst blijft op 16px (1rem), niet kleiner maken
     anders triggert iOS/Android auto-zoom bij input-focus. */

  /* Touch-targets: btn-klein mag niet klein blijven op krappe
     schermen. Minimum comfortabele tikmaat ~40px hoog. */
  .btn-klein {
    padding: 10px 14px;
    font-size: 0.85rem;
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  /* Primair + secondair: volle breedte op krappe mobiel, maar
     alleen binnen hero/sectie-kop — niet in de nav, daar blijft
     de offerte-CTA compact naast de hamburger. */
  .sectie-kop .btn-primair,
  .sectie-kop .btn-secondair,
  .sectie-kop .btn-goud,
  .hero .btn-primair,
  .hero .btn-secondair,
  .hero .btn-goud {
    width: 100%;
    text-align: center;
  }

  /* Pakket-ster: nog iets kleiner op smalle schermen */
  .pakket-ster { top: -12px; right: 10px; width: 38px; height: 38px; font-size: 1.05rem }

  /* Pakket-padding op mobiel: minder lucht = meer content zichtbaar */
  .pakket { padding: 28px 22px }

  /* Stat-balk: onder elkaar op heel smal (was 2x2 op 640px) */
  .stat-balk { grid-template-columns: 1fr }
  .stat-balk-item { border-right: none; border-bottom: 1px solid var(--border) }
  .stat-balk-item:last-child { border-bottom: none }

  /* Footer 1 kolom op echt smalle schermen */
  .footer-grid { grid-template-columns: 1fr; gap: 24px }

  /* Hero ademt krapper, labels iets kleiner */
  .sectie-kop .label { font-size: 0.7rem; letter-spacing: 1.2px }

  /* FAQ-box meer padding-inhoud op kleine schermen */
  .faq-sectie .formulier.gecentreerd { padding: 20px 20px }
  .accordeon-trigger { font-size: 0.95rem; padding: 16px 0 }
  .accordeon-tekst { font-size: 0.9rem }

  /* Vergelijking/tabellen: geen compressie, laat ze scrollen */
  .tabel table { min-width: 520px; font-size: 0.9rem }

  /* Formulier-padding en labels comfortabel tikbaar */
  .form-input,
  .form-select,
  .form-textarea {
    padding: 14px 14px;
    font-size: 1rem;  /* 16px voorkomt iOS auto-zoom */
  }
  .form-label { font-size: 0.95rem }

  /* Intake: sectiekop-lijn smaller maken */
  .intake-sectie-kop { font-size: 0.85rem; margin: 28px 0 12px }

  /* Cards padding compacter op 480px */
  .kaart,
  .probleem-kaart,
  .module-kaart { padding: 20px 18px }

  /* Laatste ademruimte: alle primair/secondair knoppen krijgen
     een zachte minimumhoogte zodat ze als button voelen */
  .btn-primair,
  .btn-secondair,
  .btn-goud {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
}

/* ── Universele image-fallback zodat afbeeldingen nooit uit
   de viewport vallen, op welke breedte dan ook ───────────── */
img { max-width: 100%; height: auto }

/* ── Print ──────────────────────────────────────────────────────── */
@media print {
  .nav, .footer { display: none }
  .sectie { padding: 32px 0; break-inside: avoid }
  .kaart, .pakket { break-inside: avoid; box-shadow: none }
  body { font-size: 12px }
}
