/* =========================================================
   FlexHero — Randstad-style uitzendbureau site
   Brand: Deep green + Lime + Cream · Poppins + Open Sans
   ========================================================= */

:root {
  --green:        #88D932;
  --green-bright: #9CFF36;
  --green-deep:   #0C261B;
  --green-darker: #061410;
  --green-mid:    #143426;
  --green-ink:    #6FB827;
  /* A11y: WCAG-conform accent voor groen op cream (4.6:1) — gebruik in plaats
     van --green / --green-ink wanneer tekst op licht (cream/white) staat */
  --green-text:   #3F7A0E;

  --cream:        #FCF7F2;
  --cream-2:      #F4ECE1;
  --rule:         #E5DCCD;
  --paper:        #FFFFFF;

  --ink:          #1D1D1B;
  --ink-2:        #2A2A28;
  /* A11y: was #6B6B66 (4.9:1 op cream). Iets donkerder voor 5.7:1 marge. */
  --muted:        #5F5F5B;

  --f-display:    "Poppins", "Helvetica Neue", Arial, sans-serif;
  --f-sans:       "Open Sans", "Helvetica Neue", Arial, sans-serif;

  --container:    1280px;
  --gutter:       clamp(20px, 4vw, 48px);

  /* ============================================================
     DESIGN-TOKEN SYSTEM (S-tier foundation)
     Use these everywhere — geen hardcoded magic-numbers meer.
     ============================================================ */

  /* SPACING SCALE (8-point grid, fluid op key-stops) */
  --space-3xs:  2px;
  --space-2xs:  4px;
  --space-xs:   8px;
  --space-sm:   12px;
  --space-md:   16px;
  --space-lg:   20px;
  --space-xl:   24px;
  --space-2xl:  32px;
  --space-3xl:  48px;
  --space-4xl:  64px;
  --space-5xl:  96px;
  --space-6xl:  128px;
  --space-7xl:  192px;

  /* Section padding presets (fluid op viewport) */
  --pad-section-sm:  clamp(48px, 6vw, 72px);
  --pad-section-md:  clamp(72px, 9vw, 112px);
  --pad-section-lg:  clamp(96px, 12vw, 160px);
  --pad-section-xl:  clamp(120px, 16vw, 200px);

  /* RADIUS SCALE */
  --radius-xs:    4px;
  --radius-sm:    6px;
  --radius-md:    8px;
  --radius-base:  10px;
  --radius-lg:    14px;
  --radius-xl:    20px;
  --radius-2xl:   28px;
  --radius-3xl:   36px;
  --radius-pill:  999px;
  --radius:       var(--radius-sm);  /* legacy fallback */

  /* SHADOW SCALE (semantic, no random rgba) */
  --shadow-xs:    0 1px 2px rgba(8, 24, 17, 0.06);
  --shadow-sm:    0 2px 6px rgba(8, 24, 17, 0.07), 0 1px 2px rgba(8, 24, 17, 0.04);
  --shadow-md:    0 8px 22px -4px rgba(8, 24, 17, 0.10), 0 3px 8px -2px rgba(8, 24, 17, 0.06);
  --shadow-lg:    0 18px 40px -8px rgba(8, 24, 17, 0.16), 0 6px 14px -3px rgba(8, 24, 17, 0.08);
  --shadow-xl:    0 28px 60px -12px rgba(8, 24, 17, 0.22), 0 10px 22px -5px rgba(8, 24, 17, 0.12);
  --shadow-2xl:   0 40px 80px -16px rgba(8, 24, 17, 0.28), 0 14px 28px -8px rgba(8, 24, 17, 0.14);
  /* Special shadows */
  --shadow-inner-light:  inset 0 1px 0 rgba(255, 255, 255, 0.50);
  --shadow-inner-dark:   inset 0 -1px 0 rgba(12, 38, 27, 0.05);
  --shadow-glow-green:   0 8px 28px rgba(136, 217, 50, 0.32), 0 2px 8px rgba(136, 217, 50, 0.20);
  --shadow-glow-green-lg:0 16px 48px rgba(136, 217, 50, 0.42), 0 6px 16px rgba(136, 217, 50, 0.28);
  --shadow-ring-green:   0 0 0 4px rgba(136, 217, 50, 0.20);
  --shadow-ring-ink:     0 0 0 4px rgba(8, 24, 17, 0.12);

  /* EASING / TIMING (premium motion curves) */
  --ease-out:        cubic-bezier(.2, .78, .2, 1);      /* standard out — exit/landing */
  --ease-out-fast:   cubic-bezier(.34, .82, .34, 1);    /* snappier exits */
  --ease-spring:     cubic-bezier(.34, 1.56, .64, 1);   /* button-press overshoot */
  --ease-spring-soft:cubic-bezier(.16, 1.11, .34, 1);   /* subtle spring */
  --ease-in-out:     cubic-bezier(.4, 0, .2, 1);        /* reveals & transforms */
  --ease-magnetic:   cubic-bezier(.16, .84, .34, 1);    /* cursor-follow */
  --ease-decel:      cubic-bezier(0, 0, .2, 1);         /* deceleration only */

  /* DURATIONS */
  --dur-instant:  0ms;
  --dur-micro:    80ms;
  --dur-fast:     150ms;
  --dur-base:     220ms;
  --dur-slow:     360ms;
  --dur-slower:   550ms;
  --dur-cinema:   800ms;
  --dur-reveal:   1100ms;  /* hero/section reveal */

  /* Z-INDEX SCALE */
  --z-behind:    -1;
  --z-base:      0;
  --z-raised:    10;
  --z-dropdown:  100;
  --z-sticky:    200;
  --z-fixed:     300;
  --z-overlay:   400;
  --z-modal:     500;
  --z-popover:   600;
  --z-toast:     700;
  --z-tooltip:   800;
  --z-max:       9999;

  /* TYPOGRAPHY — type-scale fluid */
  --text-xs:     12px;
  --text-sm:     13.5px;
  --text-base:   15px;
  --text-md:     17px;
  --text-lg:     19px;
  --text-xl:     clamp(20px, 1.4vw, 22px);
  --text-2xl:    clamp(24px, 1.8vw, 28px);
  --text-3xl:    clamp(28px, 2.4vw, 36px);
  --text-4xl:    clamp(36px, 3.5vw, 48px);
  --text-5xl:    clamp(44px, 5vw, 64px);
  --text-6xl:    clamp(56px, 7vw, 88px);
  --text-7xl:    clamp(64px, 9vw, 112px);
  --text-8xl:    clamp(80px, 11vw, 144px);

  /* LINE-HEIGHTS (semantic) */
  --lh-tight:    0.96;
  --lh-snug:     1.05;
  --lh-base:     1.5;
  --lh-relaxed:  1.65;

  /* LETTER-SPACING optical */
  --tracking-tightest: -0.045em;
  --tracking-tighter:  -0.035em;
  --tracking-tight:    -0.025em;
  --tracking-snug:     -0.015em;
  --tracking-normal:   0;
  --tracking-wide:     0.04em;
  --tracking-wider:    0.08em;
  --tracking-widest:   0.14em;

  /* SEMANTIC COLOR ALIASES (use these in components) */
  --fg:               var(--ink);
  --fg-muted:         var(--ink-2);
  --fg-subtle:        var(--muted);
  --fg-inverse:       var(--cream);
  --bg:               var(--cream);
  --bg-elevated:      var(--paper);
  --bg-recessed:      var(--cream-2);
  --bg-inverse:       var(--green-deep);
  --border:           var(--rule);
  --border-strong:    rgba(8, 24, 17, 0.16);
  --border-on-dark:   rgba(252, 247, 242, 0.16);
  --accent:           var(--green);
  --accent-hover:     var(--green-bright);
  --accent-text:      var(--green-deep);
  --accent-soft:      rgba(136, 217, 50, 0.10);
  --accent-glow:      rgba(136, 217, 50, 0.32);
}

/* ============================================================
   ICON UTILITY — consistent sizes via .ico modifier classes
   ------------------------------------------------------------
   Use:
     <svg class="ico" aria-hidden="true"><use href="/img/icons.svg#NAME"/></svg>
     <svg class="ico ico-lg" aria-hidden="true">...</svg>
============================================================ */
.ico {
  display: inline-block;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  vertical-align: middle;
  color: currentColor;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: color var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-spring);
}
.ico-xs { width: 14px; height: 14px; }
.ico-sm { width: 16px; height: 16px; }
.ico-md { width: 22px; height: 22px; }
.ico-lg { width: 28px; height: 28px; }
.ico-xl { width: 36px; height: 36px; }
.ico-2xl { width: 48px; height: 48px; }
.ico-3xl { width: 64px; height: 64px; }
/* For inline-text icons that need to scale with font-size */
.ico-em { width: 1em; height: 1em; vertical-align: -0.15em; }

/* When icon is inside an action that hover-translates */
[class*="-link"]:hover .ico,
button:hover .ico { transition-duration: var(--dur-base); }

/* Icon-box (square gradient-bg container voor highlight-icons) */
.ico-box {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, rgba(136, 217, 50, 0.18), rgba(136, 217, 50, 0.42));
  color: var(--accent-text);
  box-shadow: var(--shadow-xs), inset 0 1px 0 rgba(255, 255, 255, 0.40);
}
.ico-box.is-lg {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-lg);
}
.ico-box.is-circle { border-radius: var(--radius-pill); }
.ico-box.is-soft {
  background: var(--accent-soft);
  box-shadow: none;
}
.ico-box.is-ink {
  background: var(--bg-inverse);
  color: var(--accent);
}
.ico-box .ico { width: 20px; height: 20px; }
.ico-box.is-lg .ico { width: 26px; height: 26px; }

/* ============================================================
   MOTION UTILITIES — pair met motion.js
   ------------------------------------------------------------
   Activeer per element met data-attribuut. CSS hieronder geeft
   start-state, JS triggert `.is-revealed` bij intersect.
============================================================ */

/* 1 · REVEALS — translate-up + fade-in */
[data-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity var(--dur-cinema, 800ms) var(--ease-out, cubic-bezier(.2,.78,.2,1)),
    transform var(--dur-cinema, 800ms) var(--ease-out, cubic-bezier(.2,.78,.2,1));
  will-change: opacity, transform;
}
[data-reveal].is-revealed {
  opacity: 1;
  transform: none;
}
/* Variants */
[data-reveal="left"]  { transform: translateX(-32px); }
[data-reveal="left"].is-revealed { transform: none; }
[data-reveal="right"] { transform: translateX(32px); }
[data-reveal="right"].is-revealed { transform: none; }
[data-reveal="up"]    { transform: translateY(40px); }
[data-reveal="up"].is-revealed { transform: none; }
[data-reveal="fade"]  { transform: none; }
/* Stagger via data-reveal-delay (in motion.js handles delay attr) */

/* Respect prefers-reduced-motion — motion.js already skipt, dit is fallback */
.motion-reduced [data-reveal],
.motion-reduced [data-reveal].is-revealed {
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}

/* 2 · MAGNETIC — transition voor het release (mouseleave) */
[data-magnetic] {
  transition: transform var(--dur-slow, 360ms) var(--ease-spring, cubic-bezier(.34,1.56,.64,1));
}

/* 4 · PARALLAX — base style */
[data-parallax] {
  will-change: transform;
  transition: transform 0s linear;  /* instant op scroll, geen jitter */
}

/* 5 · SCROLL-PROGRESS BAR */
[data-progress] {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--accent, #88D932), var(--green-bright, #9CFF36));
  transform-origin: 0 50%;
  transform: scaleX(0);
  z-index: var(--z-fixed, 300);
  pointer-events: none;
  box-shadow: 0 1px 4px rgba(136, 217, 50, 0.42);
}

/* 6 · TILT — base CSS */
[data-tilt] {
  transition: transform var(--dur-base, 220ms) var(--ease-spring-soft, cubic-bezier(.16,1.11,.34,1));
  transform-style: preserve-3d;
}

/* ============================================================
   UTILITY: HOVER-LIFT — for interactive cards
============================================================ */
.hover-lift {
  transition:
    transform var(--dur-base, 220ms) var(--ease-out, cubic-bezier(.2,.78,.2,1)),
    box-shadow var(--dur-base, 220ms) var(--ease-out, cubic-bezier(.2,.78,.2,1));
}
.hover-lift:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}
.hover-lift-sm:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.hover-lift-lg:hover { transform: translateY(-6px); box-shadow: var(--shadow-xl); }

/* ============================================================
   UTILITY: SCROLL-MARGIN voor anchor-jumps onder sticky-nav
============================================================ */
[id]:target { scroll-margin-top: 100px; }

* { box-sizing: border-box; margin: 0; padding: 0; }
/* overflow-x: clip clips the off-canvas mobile nav drawer (position:fixed) so it
   can't leak into the document scrollWidth and create a phantom horizontal scroll
   on mobile. `clip` (vs `hidden`) does NOT create a scroll container, so the sticky
   .nav keeps working. Fallback to hidden for older Safari (<16). */
html { scroll-behavior: smooth; overflow-x: hidden; overflow-x: clip; color-scheme: light; }

/* ============================================================
   POLISH: accessibility + motion + focus (Update 10)
============================================================ */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* Skip-to-content link voor toetsenbord-navigatie (verschijnt bij Tab) */
.skip-link {
  position: absolute; top: -50px; left: 16px; z-index: 99999;
  background: var(--green-deep, #0C261B); color: var(--green, #88D932);
  padding: 10px 18px; border-radius: 8px;
  font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 14px;
  text-decoration: none;
  transition: top 0.15s ease;
  box-shadow: 0 8px 22px rgba(12,38,27,0.30);
}
.skip-link:focus { top: 12px; outline: 3px solid var(--green, #88D932); outline-offset: 2px; }

/* Focus-visible: legacy block — definitive rules zijn onderaan styles.css
   in de A11Y PASS-sectie (Update 11). Hier alleen de bare minimum default. */
:focus-visible {
  outline: 3px solid var(--green-bright, #9FE94B);
  outline-offset: 2px;
  border-radius: 4px;
}
:focus:not(:focus-visible) { outline: none; }

/* Trust-badge tooltip op hover/focus (cert-banner) */
.cert-banner .cert-banner-mark[data-info] { position: relative; cursor: help; }
.cert-banner .cert-banner-mark[data-info]::after {
  content: attr(data-info);
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--green-deep, #0C261B);
  color: var(--cream, #FCF7F2);
  padding: 8px 12px;
  border-radius: 8px;
  font-size: 11px;
  line-height: 1.45;
  white-space: normal;
  width: max-content;
  max-width: 240px;
  text-align: left;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.15s, visibility 0.15s, transform 0.15s;
  pointer-events: none;
  z-index: 100;
  box-shadow: 0 8px 24px rgba(12,38,27,0.20);
}
.cert-banner .cert-banner-mark[data-info]::before {
  content: "";
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-top-color: var(--green-deep, #0C261B);
  opacity: 0;
  transition: opacity 0.15s;
  pointer-events: none;
  z-index: 101;
}
.cert-banner .cert-banner-mark[data-info]:hover::after,
.cert-banner .cert-banner-mark[data-info]:focus-within::after { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(-2px); }
.cert-banner .cert-banner-mark[data-info]:hover::before,
.cert-banner .cert-banner-mark[data-info]:focus-within::before { opacity: 1; }

body {
  background: var(--cream);
  color: var(--ink);
  font-family: var(--f-sans);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;   /* fallback oudere Safari (<16) */
  overflow-x: clip;     /* clip i.p.v. hidden: geen scroll-container, zodat de sticky .nav blijft plakken */
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }

::selection { background: var(--green); color: var(--green-deep); }

.wrap {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

h1, h2, h3, h4 {
  font-family: var(--f-display);
  font-weight: 700;
  letter-spacing: -0.025em;
  color: var(--green-deep);
  line-height: 1.1;
}

/* ============================================
   TOP UTILITY BAR
============================================ */
.utility {
  background: var(--green-deep);
  color: var(--cream);
  font-size: 13px;
  padding: 9px 0;
  position: relative;
  z-index: 60;
}
.utility .wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.utility-left {
  display: flex;
  align-items: center;
  gap: 22px;
  font-weight: 500;
}
.utility-left .live-dot {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--green);
}
.utility-left .live-dot::before {
  content: "";
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 0 0 rgba(136,217,50,.6);
  animation: dotPulse 1.8s infinite cubic-bezier(0,0,.2,1);
}
@keyframes dotPulse {
  0% { box-shadow: 0 0 0 0 rgba(136,217,50,.55); }
  70% { box-shadow: 0 0 0 10px rgba(136,217,50,0); }
  100% { box-shadow: 0 0 0 0 rgba(136,217,50,0); }
}
.utility-right { display: flex; gap: 22px; opacity: 0.85; }
.utility-right a:hover { opacity: 1; color: var(--green); }
@media (max-width: 880px) {
  .utility-right { display: none; }
}

/* ============================================
   MAIN NAV
============================================ */
.nav {
  background: var(--paper);
  border-bottom: 1px solid var(--rule);
  position: sticky;
  top: 0;
  z-index: 50;
  transition: box-shadow .2s ease;
}
.nav.scrolled { box-shadow: 0 4px 20px rgba(12,38,27,0.06); }
/* Header krijgt ruimere container (rest van site blijft 1280px) */
.nav > .wrap { max-width: 1440px; }
.nav-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 24px;
  align-items: center;
  height: 80px;
}
.logo {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  flex-shrink: 0;
  min-width: 160px;
}
.logo img {
  height: 36px;
  width: auto;
  max-width: 100%;
  display: block;
}
.nav-links {
  display: flex;
  gap: 2px;
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  font-family: var(--f-display);
  justify-content: center;
}
.nav-links > .item {
  position: relative;
}
.nav-links > .item > a {
  padding: 9px 13px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  transition: background .15s ease;
}
/* Pijltjes alleen op items met mega-menu */
.nav-links > .item.has-mega > a::after {
  content: "▾";
  font-size: 9px;
  opacity: 0.5;
  margin-top: 1px;
}
.nav-links > .item:hover > a { background: var(--cream-2); }
.nav-links > .item.active > a { color: var(--green-text); }

/* Mega menu */
.mega {
  position: absolute;
  top: calc(100% + 8px);
  left: -20px;
  width: 720px;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  padding: 28px;
  box-shadow: 0 24px 60px rgba(12,38,27,0.12);
  display: none;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  font-size: 14px;
  font-weight: 400;
}
.mega.mega-3col {
  width: 920px;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 28px;
}
.nav-links > .item:hover .mega { display: grid; }
/* Hover-brug over de 8px-gap: een onzichtbaar ::before vult de ruimte tussen
   trigger en paneel. Het is een descendant van .item, dus de muis erover houdt
   .item:hover actief → het mega-menu sluit niet bij het naar beneden bewegen. */
.mega::before {
  content: "";
  position: absolute;
  top: -10px;
  left: 0;
  right: 0;
  height: 10px;
}
.mega .col-label, .mega h3, .mega h5 {
  display: block;
  font-family: var(--f-display);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 12px;
  font-weight: 700;
}
.mega-col {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.mega-col a {
  padding: 9px 12px;
  margin: 0 -12px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--ink);
  transition: background .15s ease, color .15s ease;
  font-weight: 500;
}
.mega-col a:hover {
  background: var(--cream-2);
  color: var(--green-deep);
}
.mega-col a .arr { opacity: 0.4; transition: transform .2s ease; }
.mega-col a:hover .arr { opacity: 0.9; transform: translateX(2px); }

.nav-cta-group {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-shrink: 0;
}
/* Taalwisselaar — uitklapbare dropdown (build_langswitch.py).
   Ingeklapt: alleen de vlag (+ caret). Uitgeklapt: vlag + afkorting per taal. */
.lang-switch {
  position: relative;
  display: inline-flex;
  margin-right: 2px;
  font-family: var(--f-display);
}
.lang-switch > summary {
  list-style: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  border: 1px solid var(--rule);
  border-radius: 999px;
  padding: 5px 8px 5px 9px;
  line-height: 1;
  transition: background .15s ease, border-color .15s ease;
  -webkit-tap-highlight-color: transparent;
}
.lang-switch > summary::-webkit-details-marker,
.lang-switch > summary::marker { display: none; content: ""; }
.lang-switch > summary:hover,
.lang-switch[open] > summary { background: var(--cream-2); border-color: var(--green); }
.lang-switch .lang-flag { font-size: 15px; line-height: 1; }
.lang-switch .lang-caret { color: var(--muted); transition: transform .18s ease; flex-shrink: 0; }
.lang-switch[open] > summary .lang-caret { transform: rotate(180deg); }
.lang-menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  z-index: 60;
  margin: 0;
  padding: 4px;
  list-style: none;
  min-width: 96px;
  background: var(--paper, #fff);
  border: 1px solid var(--rule);
  border-radius: 12px;
  box-shadow: 0 10px 28px rgba(20, 30, 24, .12);
  animation: lang-menu-in .14s ease;
}
@keyframes lang-menu-in { from { opacity: 0; transform: translateY(-4px); } }
.lang-menu a {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 7px 11px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .03em;
  color: var(--ink-2, var(--muted));
  line-height: 1;
  transition: background .12s ease, color .12s ease;
}
.lang-menu a:hover { background: var(--cream-2); color: var(--green-deep); }
.lang-menu a[aria-current] { background: var(--green-deep); color: var(--cream); }
@media (max-width: 980px) {
  /* in de header verbergen op mobiel; mobile-nav.js kloont 'm in de drawer */
  .nav-cta-group > .lang-switch { display: none; }
  /* drawer-variant: menu in-flow i.p.v. absoluut (geen overflow) */
  .drawer-lang .lang-menu {
    position: static; box-shadow: none; border: 0; padding: 4px 0 0;
    min-width: 0; display: flex; flex-wrap: wrap; gap: 6px; animation: none;
  }
}
/* kloon in de mobiele drawer */
.drawer-lang { margin: 4px 0 18px; }
.drawer-lang .lang-switch { border-color: rgba(244,236,225,.22); }
.drawer-lang .lang-switch a { color: var(--cream); opacity: .8; }
.drawer-lang .lang-switch a[aria-current] { background: var(--green); color: var(--green-deep); opacity: 1; }
.nav-cta-group .icon-btn {
  width: 40px; height: 40px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--rule);
  color: var(--green-deep);
  transition: all .15s ease;
}
.nav-cta-group .icon-btn:hover {
  background: var(--green-deep);
  color: var(--cream);
  border-color: var(--green-deep);
}
.nav-cta-group .nav-cta {
  background: var(--green);
  color: var(--green-deep);
  padding: 0 20px;
  height: 40px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  font-family: var(--f-display);
  transition: all .2s ease;
  box-sizing: border-box;
}
.nav-cta-group .nav-cta:hover {
  background: var(--green-bright);
  transform: translateY(-1px);
}
@media (max-width: 980px) {
  .nav-links { display: none; }
  .nav-inner { grid-template-columns: auto 1fr; }
}

/* ============================================
   HERO
============================================ */
.hero {
  /* Donkergroen + lichte diagonale schaduw van links-onder naar rechts-boven */
  background:
    /* Lichte glow in de rechter-bovenhoek */
    radial-gradient(ellipse 900px 700px at 95% 5%, rgba(136, 217, 50, 0.14), transparent 60%),
    /* Diepere schaduw in de linker-onderhoek */
    radial-gradient(ellipse 800px 600px at 5% 95%, rgba(0, 0, 0, 0.35), transparent 65%),
    /* Diagonale lichte wash van linksonder naar rechtsboven */
    linear-gradient(45deg, #06180E 0%, var(--green-deep) 45%, #143A28 100%);
  color: var(--cream);
  position: relative;
  overflow: hidden;
}
.hero > * { position: relative; z-index: 1; }
.hero-grain {
  position: absolute;
  inset: 0;
  opacity: 0.45;
  pointer-events: none;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.05 0 0 0 0 0.13 0 0 0 0 0.09 0 0 0 0.5 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: 56px;
  align-items: center;
  padding: 64px 0 32px;
  position: relative;
}
.hero-inner > * { min-width: 0; }
@media (max-width: 980px) {
  .hero-inner { grid-template-columns: minmax(0, 1fr); padding: 44px 0 24px; }
}

.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.04em;
  margin-bottom: 28px;
  color: var(--green);
  font-family: var(--f-display);
}
.hero-eyebrow::before {
  content: "";
  width: 24px; height: 2px;
  background: var(--green);
}
.hero h1 {
  font-size: clamp(42px, 5.6vw, 80px);
  color: var(--cream);
  letter-spacing: -0.035em;
  line-height: 1.02;
  margin-bottom: 24px;
}
.hero h1 .accent {
  position: relative;
  display: inline-block;
  color: var(--green);
}
.hero p.lead {
  font-size: clamp(16px, 1.3vw, 18px);
  line-height: 1.5;
  max-width: 60ch;
  opacity: 0.88;
  color: var(--cream);
  margin-bottom: 12px;
}
.hero .lead-claims {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-size: clamp(15px, 1.2vw, 17px);
  line-height: 1.4;
  color: var(--green);
  max-width: 60ch;
  margin: 0 0 36px 0;
}
.hero .lead-claims em {
  font-style: italic;
  font-weight: 400;
}

/* Job-search box (Randstad style) */
.search-box {
  background: var(--cream);
  border-radius: var(--radius-lg);
  padding: 8px;
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 4px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.18);
  max-width: 640px;
}
.search-field {
  position: relative;
  background: var(--paper);
  border-radius: 10px;
  padding: 12px 16px 10px 48px;
  border: 1px solid transparent;
  transition: border-color .2s ease;
}
.search-field:focus-within { border-color: var(--green); }
.search-field .ic {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  width: 22px; height: 22px;
  color: var(--green-text);
}
.search-field label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
  font-family: var(--f-display);
  margin-bottom: 2px;
}
.search-field input {
  width: 100%;
  border: 0;
  outline: none;
  background: transparent;
  font: inherit;
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
  font-family: var(--f-sans);
}
.search-field input::placeholder { color: var(--muted); font-weight: 500; }
.search-submit {
  background: var(--green-deep);
  color: var(--cream);
  border-radius: 10px;
  padding: 0 28px;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 15px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  transition: background .2s ease;
}
.search-submit:hover { background: var(--green-darker); color: var(--green); }
.search-submit svg { width: 18px; height: 18px; }
@media (max-width: 660px) {
  .search-box { grid-template-columns: 1fr; }
  .search-submit { padding: 16px; justify-content: center; }
}

.search-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 24px;
  font-size: 14px;
  flex-wrap: wrap;
}
.search-meta .pop {
  opacity: 0.7;
  font-size: 13px;
  margin-right: 8px;
}
.search-meta .chip {
  background: rgba(244,236,225,0.08);
  border: 1px solid rgba(244,236,225,0.18);
  color: var(--cream);
  padding: 7px 14px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 500;
  transition: all .15s ease;
}
.search-meta .chip:hover {
  background: var(--green);
  color: var(--green-deep);
  border-color: var(--green);
}

/* Hero side card */
.hero-side {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  min-height: 480px;
  background: var(--green-mid);
}
.hero-side .img {
  position: absolute;
  inset: 0;
}
.hero-side .img img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.hero-side .img::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, rgba(12,38,27,0.2) 0%, rgba(12,38,27,0.85) 100%);
}
.hero-side .badge {
  position: absolute;
  top: 24px; left: 24px;
  background: var(--cream);
  color: var(--green-deep);
  padding: 8px 14px;
  border-radius: 999px;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.04em;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  z-index: 2;
}
.hero-side .badge::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--green-ink);
  box-shadow: 0 0 0 0 rgba(111, 184, 39, .55);
  animation: heroLivePulse 1.8s ease-out infinite;
}
@keyframes heroLivePulse {
  0%   { box-shadow: 0 0 0 0   rgba(111, 184, 39, .55); }
  70%  { box-shadow: 0 0 0 10px rgba(111, 184, 39, 0); }
  100% { box-shadow: 0 0 0 0   rgba(111, 184, 39, 0); }
}
@media (prefers-reduced-motion: reduce) {
  .hero-side .badge::before { animation: none; }
}
/* Suffix-tekst naast hero-stat getal (bv. "Google", "u") */
.hero-stats-charts .num .num-suf {
  font-family: var(--f-sans);
  font-size: 13px;
  font-weight: 600;
  opacity: .72;
  margin-left: 4px;
  letter-spacing: 0;
}
.hero-side .panel {
  position: absolute;
  bottom: 24px; left: 24px; right: 24px;
  background: var(--cream);
  border-radius: 12px;
  padding: 24px;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 16px;
  z-index: 2;
}
.hero-side .panel .stat-num {
  font-family: var(--f-display);
  font-size: 56px;
  line-height: 0.9;
  font-weight: 800;
  color: var(--green-deep);
  letter-spacing: -0.04em;
}
.hero-side .panel .stat-num em { font-style: normal; color: var(--green-text); }
.hero-side .panel .stat-lbl {
  font-size: 13px;
  font-weight: 600;
  color: var(--muted);
  margin-top: 4px;
  font-family: var(--f-display);
}
.hero-side .panel .arrow-btn {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--green);
  color: var(--green-deep);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 700;
  transition: all .2s ease;
}
.hero-side .panel .arrow-btn:hover { background: var(--green-deep); color: var(--green); }

/* Trust-strip — sociale proof boven de stats-row, voor diepte in hero */
.hero-trust {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: 22px 0 26px;
  border-top: 1px solid rgba(244, 236, 225, 0.10);
  border-bottom: 1px solid rgba(244, 236, 225, 0.10);
  margin-top: 32px;
}
.hero-trust .ht-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: rgba(252, 247, 242, 0.78);
  font-family: var(--f-display);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.hero-trust .ht-ico {
  font-size: 14px;
  line-height: 1;
}
.hero-trust .ht-sep {
  width: 3px;
  height: 3px;
  background: rgba(244, 236, 225, 0.25);
  border-radius: 50%;
  flex-shrink: 0;
}
@media (max-width: 760px) {
  .hero-trust { gap: 10px; font-size: 11px; padding: 18px 0 20px; }
  .hero-trust .ht-sep { display: none; }
}

.hero-stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  padding: 28px 0 48px;
  margin-top: 0;
  border-top: none;
}

/* ============================================================
   HERO STATS · MINI-CHARTS (chart bovenop, dan cijfer + label)
============================================================ */
.hero-stats-charts .item {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.hero-stats-charts .chart {
  height: 50px;
  display: flex;
  align-items: flex-end;
  opacity: 0.95;
}
.hero-stats-charts .chart svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* 1 · Bars: staafjes "groeien" sequentieel */
.hero-stats-charts .chart-bars rect {
  transform-origin: bottom;
  animation: bar-grow .8s cubic-bezier(.2,.7,.2,1) backwards;
}
.hero-stats-charts .chart-bars rect:nth-child(1)  { animation-delay: 0.05s; }
.hero-stats-charts .chart-bars rect:nth-child(2)  { animation-delay: 0.10s; }
.hero-stats-charts .chart-bars rect:nth-child(3)  { animation-delay: 0.15s; }
.hero-stats-charts .chart-bars rect:nth-child(4)  { animation-delay: 0.20s; }
.hero-stats-charts .chart-bars rect:nth-child(5)  { animation-delay: 0.25s; }
.hero-stats-charts .chart-bars rect:nth-child(6)  { animation-delay: 0.30s; }
.hero-stats-charts .chart-bars rect:nth-child(7)  { animation-delay: 0.35s; }
.hero-stats-charts .chart-bars rect:nth-child(8)  { animation-delay: 0.40s; }
.hero-stats-charts .chart-bars rect:nth-child(9)  { animation-delay: 0.45s; }
.hero-stats-charts .chart-bars rect:nth-child(10) { animation-delay: 0.50s; }
.hero-stats-charts .chart-bars rect:nth-child(11) { animation-delay: 0.55s; }
.hero-stats-charts .chart-bars rect:nth-child(12) { animation-delay: 0.60s; }
@keyframes bar-grow { from { transform: scaleY(0); } to { transform: scaleY(1); } }

/* 2 · Donut: 92% tekent zich */
.hero-stats-charts .chart-donut svg { width: 50px; height: 50px; }
.hero-stats-charts .chart-donut circle:last-child {
  stroke-dasharray: 163.36;
  stroke-dashoffset: 163.36;
  animation: donut-fill 1.4s cubic-bezier(.2,.7,.2,1) .2s forwards;
}
@keyframes donut-fill { to { stroke-dashoffset: 13.07; } }

/* 3 · Grid: 35 dots blijven zichtbaar, met continue golf van glow erover */
.hero-stats-charts .chart-grid svg { width: 90px; height: 40px; }
.hero-stats-charts .chart-grid circle {
  opacity: 0.35;
  animation: dot-wave 4s ease-in-out infinite;
  transform-origin: center;
}
@keyframes dot-wave {
  0%, 100% { opacity: 0.35; }
  50%      { opacity: 1; transform: scale(1.15); }
}
.hero-stats-charts .chart-grid circle:nth-child(n)  { animation-delay: calc(0.25s + (var(--i, 0) * 0.025s)); }
/* Kunnen geen var per circle in pure CSS doen — sequencing per nth-child: */
.hero-stats-charts .chart-grid circle:nth-child(1)  { animation-delay: 0.30s; }
.hero-stats-charts .chart-grid circle:nth-child(2)  { animation-delay: 0.32s; }
.hero-stats-charts .chart-grid circle:nth-child(3)  { animation-delay: 0.34s; }
.hero-stats-charts .chart-grid circle:nth-child(4)  { animation-delay: 0.36s; }
.hero-stats-charts .chart-grid circle:nth-child(5)  { animation-delay: 0.38s; }
.hero-stats-charts .chart-grid circle:nth-child(6)  { animation-delay: 0.40s; }
.hero-stats-charts .chart-grid circle:nth-child(7)  { animation-delay: 0.42s; }
.hero-stats-charts .chart-grid circle:nth-child(8)  { animation-delay: 0.44s; }
.hero-stats-charts .chart-grid circle:nth-child(9)  { animation-delay: 0.46s; }
.hero-stats-charts .chart-grid circle:nth-child(10) { animation-delay: 0.48s; }
.hero-stats-charts .chart-grid circle:nth-child(11) { animation-delay: 0.50s; }
.hero-stats-charts .chart-grid circle:nth-child(12) { animation-delay: 0.52s; }
.hero-stats-charts .chart-grid circle:nth-child(13) { animation-delay: 0.54s; }
.hero-stats-charts .chart-grid circle:nth-child(14) { animation-delay: 0.56s; }
.hero-stats-charts .chart-grid circle:nth-child(15) { animation-delay: 0.58s; }
.hero-stats-charts .chart-grid circle:nth-child(16) { animation-delay: 0.60s; }
.hero-stats-charts .chart-grid circle:nth-child(17) { animation-delay: 0.62s; }
.hero-stats-charts .chart-grid circle:nth-child(18) { animation-delay: 0.64s; }
.hero-stats-charts .chart-grid circle:nth-child(19) { animation-delay: 0.66s; }
.hero-stats-charts .chart-grid circle:nth-child(20) { animation-delay: 0.68s; }
.hero-stats-charts .chart-grid circle:nth-child(21) { animation-delay: 0.70s; }
.hero-stats-charts .chart-grid circle:nth-child(22) { animation-delay: 0.72s; }
.hero-stats-charts .chart-grid circle:nth-child(23) { animation-delay: 0.74s; }
.hero-stats-charts .chart-grid circle:nth-child(24) { animation-delay: 0.76s; }
.hero-stats-charts .chart-grid circle:nth-child(25) { animation-delay: 0.78s; }
.hero-stats-charts .chart-grid circle:nth-child(26) { animation-delay: 0.80s; }
.hero-stats-charts .chart-grid circle:nth-child(27) { animation-delay: 0.82s; }
.hero-stats-charts .chart-grid circle:nth-child(28) { animation-delay: 0.84s; }
.hero-stats-charts .chart-grid circle:nth-child(29) { animation-delay: 0.86s; }
.hero-stats-charts .chart-grid circle:nth-child(30) { animation-delay: 0.88s; }
.hero-stats-charts .chart-grid circle:nth-child(31) { animation-delay: 0.90s; }
.hero-stats-charts .chart-grid circle:nth-child(32) { animation-delay: 0.92s; }
.hero-stats-charts .chart-grid circle:nth-child(33) { animation-delay: 0.94s; }
.hero-stats-charts .chart-grid circle:nth-child(34) { animation-delay: 0.96s; }
.hero-stats-charts .chart-grid circle:nth-child(35) { animation-delay: 0.98s; }
@keyframes dot-pop { from { opacity: 0; transform: scale(0); } to { opacity: 1; transform: scale(1); } }

/* 4 · ECG-pulslijn — landelijke dekking als continu hartslagsignaal */
.hero-stats-charts .chart-pulse svg { width: 100%; height: 44px; }
.hero-stats-charts .chart-pulse .ecg-line {
  stroke-dasharray: 1000;
  stroke-dashoffset: 1000;
  animation: ecg-draw 3s ease-in-out infinite;
  filter: drop-shadow(0 0 4px rgba(136, 217, 50, 0.5));
}
.hero-stats-charts .chart-pulse .ecg-dot {
  animation: ecg-dot-move 3s ease-in-out infinite;
  filter: drop-shadow(0 0 6px rgba(136, 217, 50, 0.8));
}
@keyframes ecg-draw {
  0%   { stroke-dashoffset: 1000; }
  60%  { stroke-dashoffset: 0; }
  100% { stroke-dashoffset: -1000; }
}
@keyframes ecg-dot-move {
  0%   { cx: 0;   r: 2.4; opacity: 1; }
  20%  { cx: 30;  r: 3.5; }
  40%  { cx: 70;  r: 3.5; }
  60%  { cx: 110; r: 3.5; }
  80%  { cx: 140; r: 2.4; opacity: 0; }
  100% { cx: 0;   r: 2.4; opacity: 0; }
}

@media (max-width: 880px) {
  .hero-stats-charts .chart { height: 36px; }
  .hero-stats-charts .chart-donut svg,
  .hero-stats-charts .chart-map svg,
  .hero-stats-charts .chart-radar svg { width: 40px; height: 40px; }
}
@media (max-width: 880px) { .hero-stats-row { grid-template-columns: repeat(2, 1fr); gap: 24px; padding-top: 24px; } }
.hero-stats-row .item {
  padding: 0 24px;
  border-left: 1px solid rgba(244,236,225,0.12);
}
.hero-stats-row .item:first-child { padding-left: 0; border-left: 0; }
.hero-stats-row .num {
  font-family: var(--f-display);
  font-size: 36px;
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--cream);
}
.hero-stats-row .num em { font-style: normal; color: var(--green); }
.hero-stats-row .lbl {
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--cream);
  opacity: 0.6;
  margin-top: 8px;
  font-weight: 600;
  font-family: var(--f-display);
}

/* ============================================
   LOGO STRIP (klanten)
============================================ */
.logos {
  background: var(--paper);
  border-bottom: 1px solid var(--rule);
  padding: 32px 0;
}
.logos-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
}
.logos-label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  font-family: var(--f-display);
  white-space: nowrap;
}
.logos-list {
  display: flex;
  align-items: center;
  gap: 48px;
  flex-wrap: wrap;
}
.logos-list .l {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: 20px;
  color: var(--ink);
  opacity: 0.5;
  letter-spacing: -0.02em;
  transition: opacity .2s ease;
  font-style: italic;
}
.logos-list .l:hover { opacity: 1; color: var(--green-deep); }

/* Client logo's (PNG/SVG) — vervangt italic tekst-versie */
.logos-list .client-logo {
  display: inline-flex; align-items: center;
  padding: 0; opacity: 0.6;
  transition: opacity .2s ease, transform .2s ease, filter .2s ease;
  filter: grayscale(40%);
}
.logos-list .client-logo:hover { opacity: 1; transform: translateY(-2px); filter: grayscale(0%); }
.logos-list .client-logo img {
  height: 44px; width: auto;
  max-width: 160px; object-fit: contain;
  display: block;
}
@media (max-width: 760px) {
  .logos-list .client-logo img { height: 36px; }
}

/* ============================================
   SPECIALISATIES (4 cards)
============================================ */
.specs {
  padding: 96px 0;
  background: var(--cream);
}
.specs-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 32px;
  margin-bottom: 48px;
}
.specs-head .copy h2 {
  font-size: clamp(32px, 4vw, 48px);
  margin-bottom: 12px;
}
.specs-head .copy p {
  font-size: 17px;
  color: var(--muted);
  max-width: 50ch;
}
.specs-head .nav-arrows {
  display: flex;
  gap: 8px;
}
.specs-head .nav-arrows button {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1px solid var(--rule);
  color: var(--green-deep);
  background: var(--paper);
  transition: all .15s ease;
}
.specs-head .nav-arrows button:hover { background: var(--green-deep); color: var(--cream); border-color: var(--green-deep); }
@media (max-width: 720px) { .specs-head { flex-direction: column; align-items: flex-start; } }

.specs-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
@media (max-width: 980px) { .specs-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 580px) { .specs-grid { grid-template-columns: 1fr; } }

.spec-card {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  padding: 0;
  overflow: hidden;
  transition: all .25s ease;
  display: flex;
  flex-direction: column;
  position: relative;
}
.spec-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 48px rgba(12,38,27,0.10);
  border-color: var(--green-deep);
}
.spec-card .img {
  height: 180px;
  background: linear-gradient(135deg, var(--green-mid), var(--green-deep));
  position: relative;
  overflow: hidden;
}
.spec-card .img.maak { background: linear-gradient(135deg, #243a2c 0%, #0c261b 100%); }
.spec-card .img.log { background: linear-gradient(135deg, #1f4d35 0%, #0c261b 100%); }
.spec-card .img.tech { background: linear-gradient(135deg, #88D932 0%, #0c261b 100%); }
.spec-card .img.food { background: linear-gradient(135deg, #f4ece1 0%, #88D932 100%); }
.spec-card .img-icon {
  position: absolute;
  bottom: 18px; right: 18px;
  width: 56px; height: 56px;
  background: var(--cream);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.spec-card .img-icon svg { width: 28px; height: 28px; color: var(--green-deep); }
.spec-card .body { padding: 24px 24px 28px; flex: 1; display: flex; flex-direction: column; }
.spec-card .tag {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--green-text);
  font-family: var(--f-display);
  margin-bottom: 10px;
}
.spec-card h3 {
  font-size: 22px;
  margin-bottom: 8px;
}
.spec-card p {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.5;
  margin-bottom: 20px;
  flex: 1;
}
.spec-card .meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 16px;
  border-top: 1px solid var(--rule);
  font-size: 13px;
}
.spec-card .meta .open {
  color: var(--green-deep);
  font-weight: 700;
  font-family: var(--f-display);
}
.spec-card .meta .open em { font-style: normal; color: var(--green-text); }
.spec-card .meta .arr {
  color: var(--green-deep);
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: gap .2s ease;
  font-family: var(--f-display);
}
.spec-card:hover .meta .arr { gap: 12px; }

/* ============================================
   VACATURES FEED
============================================ */
.jobs {
  padding: 96px 0;
  background: var(--paper);
  border-top: 1px solid var(--rule);
}
.jobs-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 32px;
  margin-bottom: 32px;
  flex-wrap: wrap;
}
.jobs-head h2 {
  font-size: clamp(32px, 4vw, 48px);
}
.jobs-head .filter-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.filter-chip {
  display: inline-flex;
  align-items: center;
  min-height: 44px; /* WCAG 2.5.5 / Apple HIG touch target */
  padding: 9px 18px;
  border-radius: 999px;
  border: 1px solid var(--rule);
  background: var(--paper);
  font-size: 13px;
  font-weight: 600;
  font-family: var(--f-display);
  color: var(--ink);
  transition: all .15s ease;
}
.filter-chip:hover { border-color: var(--green-deep); }
.filter-chip.active {
  background: var(--green-deep);
  color: var(--cream);
  border-color: var(--green-deep);
}

.jobs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 40px;
}
@media (max-width: 980px) { .jobs-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .jobs-grid { grid-template-columns: 1fr; } }

.job-card {
  background: var(--cream);
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  padding: 24px;
  transition: all .2s ease;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.job-card:hover {
  background: var(--paper);
  border-color: var(--green-deep);
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(12,38,27,0.08);
}
.job-card .top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.job-card .badges {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.job-card .badge {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 999px;
  font-family: var(--f-display);
}
.job-card .badge.new { background: var(--green); color: var(--green-deep); }
.job-card .badge.urgent { background: #FFE5C2; color: #8C4A00; }
.job-card .badge.fulltime { background: rgba(12,38,27,0.08); color: var(--green-deep); }
.job-card .save-btn {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid var(--rule);
  color: var(--green-deep);
  background: var(--paper);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all .15s ease;
}
.job-card .save-btn:hover { background: var(--green); border-color: var(--green); }
.job-card .save-btn.saved { background: var(--green-deep); color: var(--green); border-color: var(--green-deep); }
.job-card .save-btn svg { width: 16px; height: 16px; }

.job-card h3 {
  font-size: 19px;
  line-height: 1.25;
}
.job-card .company {
  font-size: 14px;
  color: var(--muted);
  margin-top: -4px;
}
.job-card .meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 16px;
  font-size: 13px;
  color: var(--ink-2);
}
.job-card .meta .row {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.job-card .meta .row svg { width: 14px; height: 14px; color: var(--green-text); flex-shrink: 0; }
.job-card .foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 16px;
  border-top: 1px solid var(--rule);
  margin-top: auto;
}
.job-card .salary {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 15px;
  color: var(--green-deep);
}
.job-card .salary span { font-size: 12px; font-weight: 500; color: var(--muted); }
.job-card .apply {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 700;
  font-size: 13px;
  color: var(--green-deep);
  font-family: var(--f-display);
}
.job-card:hover .apply { color: var(--green-text); }

.jobs-foot {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
}
.btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 26px;
  border-radius: 999px;
  border: 1.5px solid var(--green-deep);
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 14px;
  color: var(--green-deep);
  transition: all .2s ease;
}
.btn-outline:hover { background: var(--green-deep); color: var(--cream); }

/* ============================================
   AUDIENCE SPLIT (werkgever / vakkracht)
============================================ */
.audience {
  padding: 96px 0;
  background: var(--cream-2);
}
.audience-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
@media (max-width: 880px) { .audience-grid { grid-template-columns: 1fr; } }
/* Single-card variant: full-width standalone (gebruikt in opgesplitste audience-secties) */
.audience-grid-single { grid-template-columns: 1fr; max-width: 880px; margin: 0 auto; }
.audience.audience-pros { background: var(--green-deep); }
.audience-pros .aud-card.dark { background: transparent; box-shadow: none; border: 1px solid rgba(244,236,225,0.12); }
.audience.audience-single .aud-card { padding: 56px 48px; }
@media (max-width: 760px) {
  .audience.audience-single .aud-card { padding: 36px 28px; }
}

.aud-card {
  background: var(--paper);
  border-radius: var(--radius-lg);
  padding: 48px;
  position: relative;
  overflow: hidden;
  transition: all .25s ease;
  border: 1px solid var(--rule);
}
.aud-card.dark {
  background: var(--green-deep);
  color: var(--cream);
  border-color: transparent;
}
.aud-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 60px rgba(12,38,27,0.14);
}

.aud-card .pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: 999px;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.04em;
  margin-bottom: 28px;
}
.aud-card.light .pill { background: var(--cream-2); color: var(--green-deep); }
.aud-card.dark .pill { background: var(--green); color: var(--green-deep); }

.aud-card h2 {
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.1;
  margin-bottom: 16px;
  max-width: 22ch;
  text-wrap: balance;
}
.aud-card.dark h2 { color: var(--cream); }
.aud-card.dark h2 .accent { color: var(--green); }
.aud-card.light h2 .accent { color: var(--green-text); }
.aud-card p.lead {
  font-size: 16px;
  line-height: 1.55;
  margin-bottom: 32px;
  max-width: 42ch;
}
.aud-card.light p.lead { color: var(--muted); }
.aud-card.dark p.lead { opacity: 0.85; }

.aud-card ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 36px;
  font-size: 14px;
}
.aud-card li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.aud-card li::before {
  content: "✓";
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--green);
  color: var(--green-deep);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 1px;
}

.aud-card .cta-row {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.aud-card .btn-primary {
  background: var(--green);
  color: var(--green-deep);
  padding: 14px 24px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 14px;
  font-family: var(--f-display);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all .2s ease;
}
.aud-card .btn-primary:hover { background: var(--green-bright); transform: translateY(-1px); }
.aud-card .btn-secondary {
  padding: 14px 24px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 14px;
  font-family: var(--f-display);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all .15s ease;
}
.aud-card.light .btn-secondary { color: var(--green-deep); border: 1.5px solid var(--green-deep); }
.aud-card.light .btn-secondary:hover { background: var(--green-deep); color: var(--cream); }
.aud-card.dark .btn-secondary { color: var(--cream); border: 1.5px solid rgba(244,236,225,0.25); }
.aud-card.dark .btn-secondary:hover { border-color: var(--cream); background: rgba(244,236,225,0.08); }

.aud-card .figure {
  position: absolute;
  top: -40px;
  right: -40px;
  width: 220px; height: 220px;
  border-radius: 50%;
  opacity: 0.7;
  pointer-events: none;
}
.aud-card.dark .figure { background: radial-gradient(circle at 30% 30%, var(--green) 0%, transparent 70%); opacity: 0.25; }
.aud-card.light .figure { background: radial-gradient(circle at 30% 30%, var(--cream-2) 0%, transparent 70%); }

/* ============================================
   WERKWIJZE
============================================ */
.process {
  padding: 96px 0;
  background: var(--paper);
}
.process-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 32px;
  margin-bottom: 56px;
  flex-wrap: wrap;
}
.process-head h2 { font-size: clamp(32px, 4vw, 48px); max-width: 14ch; }
.process-head p { color: var(--muted); max-width: 44ch; font-size: 17px; }
.process-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  border-top: 1px solid var(--rule);
}
@media (max-width: 980px) { .process-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 580px) { .process-grid { grid-template-columns: 1fr; } }
.process-step {
  padding: 32px 24px 32px 0;
  border-right: 1px solid var(--rule);
  position: relative;
}
.process-step:last-child { border-right: 0; }
.process-step .num {
  font-family: var(--f-display);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--green-text);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.process-step .num .dot {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--green);
  color: var(--green-deep);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 800;
}
.process-step h3 {
  font-size: 19px;
  margin-bottom: 12px;
  line-height: 1.2;
}
.process-step p {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.5;
}

/* ============================================
   APP / NEWSLETTER
============================================ */
.app {
  padding: 96px 0;
  background: var(--green-deep);
  color: var(--cream);
  position: relative;
  overflow: hidden;
}
.app-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
  position: relative;
}
@media (max-width: 880px) { .app-grid { grid-template-columns: 1fr; } }
.app h2 {
  color: var(--cream);
  font-size: clamp(32px, 4vw, 48px);
  margin-bottom: 20px;
  line-height: 1.05;
}
.app h2 .accent { color: var(--green); }
.app p {
  font-size: 17px;
  opacity: 0.85;
  margin-bottom: 32px;
  max-width: 44ch;
}
.app-buttons { display: flex; gap: 12px; flex-wrap: wrap; }
.store-btn {
  background: var(--cream);
  color: var(--green-deep);
  padding: 12px 22px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  transition: all .2s ease;
  font-family: var(--f-display);
}
.store-btn:hover { background: var(--green); }
.store-btn .icon { width: 28px; height: 28px; flex-shrink: 0; }
.store-btn .lbl { display: flex; flex-direction: column; line-height: 1.1; text-align: left; }
.store-btn .lbl span { font-size: 11px; font-weight: 500; opacity: 0.7; }
.store-btn .lbl strong { font-size: 16px; font-weight: 800; letter-spacing: -0.02em; }

.phone-mock {
  position: relative;
  margin: 0 auto;
  max-width: 360px;
  aspect-ratio: 9 / 18;
  background: linear-gradient(180deg, var(--green-mid), var(--green-darker));
  border-radius: 38px;
  border: 12px solid #061410;
  box-shadow: 0 40px 100px rgba(0,0,0,0.4), inset 0 0 0 1px rgba(255,255,255,0.04);
  overflow: hidden;
  padding: 18px 14px;
}
.phone-mock .notch {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 110px; height: 24px;
  background: #061410;
  border-radius: 0 0 14px 14px;
}
.phone-mock .top-bar {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  font-family: var(--f-display);
  font-weight: 700;
  margin-bottom: 22px;
  padding: 0 8px;
  color: var(--cream);
}
.phone-mock h4 {
  color: var(--cream);
  font-size: 18px;
  margin-bottom: 16px;
  padding: 0 8px;
}
.phone-mock .pjob {
  background: rgba(244,236,225,0.06);
  border: 1px solid rgba(244,236,225,0.12);
  border-radius: 12px;
  padding: 14px;
  margin-bottom: 10px;
}
.phone-mock .pjob .pj-head {
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  font-family: var(--f-display);
  margin-bottom: 8px;
  color: var(--green);
}
.phone-mock .pjob .pj-head .new { background: var(--green); color: var(--green-deep); padding: 2px 6px; border-radius: 4px; font-size: 9px; }
.phone-mock .pjob .pj-title {
  color: var(--cream);
  font-size: 13px;
  font-weight: 700;
  font-family: var(--f-display);
  margin-bottom: 4px;
}
.phone-mock .pjob .pj-meta {
  font-size: 11px;
  color: var(--cream);
  opacity: 0.6;
}

/* ============================================
   FOOTER
============================================ */
footer {
  background: var(--green-darker);
  color: var(--cream);
  padding: 72px 0 32px;
}
.foot-top {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr;
  gap: 48px;
  padding-bottom: 56px;
  border-bottom: 1px solid rgba(244,236,225,0.1);
}
@media (max-width: 980px) {
  .foot-top { grid-template-columns: 1fr 1fr; }
}
.foot-brand .big {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: 32px;
  line-height: 1;
  letter-spacing: -0.03em;
  margin-bottom: 16px;
}
.foot-brand .big .accent {
  position: relative;
  display: inline-block;
  color: var(--cream);
}
.foot-brand .big .accent::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0.05em;
  height: 0.3em; background: var(--green); z-index: -1;
}
.foot-brand p { font-size: 13px; opacity: 0.7; max-width: 30ch; line-height: 1.5; }
.foot-brand .foot-parent {
  font-size: 12px;
  opacity: 0.55;
  margin-top: 14px;
  letter-spacing: 0.02em;
}
.foot-brand .foot-parent strong { color: var(--green); font-weight: 700; opacity: 1; }

/* Social media row */
.social-row {
  display: flex; gap: 10px;
  margin-top: 22px;
}
.social-row a {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.65);
  transition: background .15s ease, color .15s ease, transform .15s ease;
}
.social-row a:hover {
  background: var(--green);
  color: var(--green-deep);
  transform: translateY(-2px);
}
.social-row svg { width: 16px; height: 16px; }

.foot-bot .foot-legal-info {
  font-size: 12px;
  letter-spacing: 0.02em;
}
.foot-col .col-label, .foot-col h3, .foot-col h5 {
  display: block;
  font-family: var(--f-display);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 18px;
  font-weight: 700;
}
.foot-col a, .foot-col p {
  display: block;
  font-size: 14px;
  margin-bottom: 10px;
  opacity: 0.8;
  transition: opacity .15s ease, color .15s ease;
}
.foot-col a:hover { opacity: 1; color: var(--green); }

.foot-bot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 32px;
  font-size: 12px;
  opacity: 0.55;
  flex-wrap: wrap;
  gap: 16px;
}
.foot-bot .certs { display: flex; gap: 18px; font-weight: 700; letter-spacing: 0.08em; font-family: var(--f-display); }

/* Cert-row uit footer verwijderd (legacy CSS, kan terug indien gewenst) */

/* Cert-banner: grote versie voor key pages */
.cert-banner {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 18px;
  padding: 32px 36px;
  display: flex; flex-wrap: wrap; gap: 18px;
  align-items: center;
  margin: 32px 0;
  box-shadow: 0 4px 18px rgba(12, 38, 27, 0.05);
}
.cert-banner .cert-banner-text {
  flex: 1; min-width: 240px;
}
.cert-banner h3 {
  font-family: var(--f-display);
  font-size: 18px;
  margin: 0 0 6px;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.cert-banner h3 em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  color: var(--green-text);
}
.cert-banner p {
  font-size: 14px;
  color: var(--ink-2);
  margin: 0;
  line-height: 1.5;
}
.cert-banner .cert-banner-marks {
  display: flex; gap: 14px; flex-wrap: wrap;
}
.cert-banner .cert-banner-mark {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 18px;
  background: var(--cream-2);
  border-radius: 12px;
}
.cert-banner .cert-banner-mark .cert-mark { width: 44px; height: 44px; }
.cert-banner .cert-banner-mark strong {
  font-family: var(--f-display);
  font-size: 13px;
  color: var(--ink);
  letter-spacing: 0.02em;
}
.cert-banner .cert-banner-mark small {
  font-size: 11px;
  color: var(--ink-2);
  display: block;
  margin-top: 2px;
}

@media (max-width: 760px) {
  .cert-badges { flex-direction: column; gap: 8px; }
  .cert-banner { padding: 24px 22px; }
}
.foot-bot a { transition: opacity .15s; }
.foot-bot a:hover { opacity: 1; color: var(--green); }
.foot-legal { display: flex; gap: 18px; }

/* ============================================
   CONTINU-STYLE: DIRECT NAAR (dual entry tiles)
============================================ */
.direct {
  padding: 56px 0 0;
  background: var(--cream);
}
.direct-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 760px) { .direct-grid { grid-template-columns: 1fr; } }
.direct-tile {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  min-height: 240px;
  display: flex;
  align-items: flex-end;
  padding: 36px;
  color: var(--cream);
  text-decoration: none;
  isolation: isolate;
  transition: transform .3s ease;
}
.direct-tile:hover { transform: translateY(-3px); }
.direct-tile img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: -2;
  transition: transform .8s cubic-bezier(.2,.7,.2,1);
}
.direct-tile:hover img { transform: scale(1.05); }
.direct-tile::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(12,38,27,0.1) 0%, rgba(12,38,27,0.85) 70%);
  z-index: -1;
}
.direct-tile h3 {
  color: var(--cream);
  font-size: 24px;
  margin-bottom: 8px;
  max-width: 22ch;
}
.direct-tile p {
  font-size: 14px;
  opacity: 0.85;
  max-width: 38ch;
  line-height: 1.5;
  margin-bottom: 16px;
}
.direct-tile .arrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--green);
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.02em;
}
.direct-tile .arrow .ic {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--green);
  color: var(--green-deep);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  transition: transform .2s ease;
}
.direct-tile:hover .arrow .ic { transform: translateX(4px); }

/* ============================================
   CONTINU-STYLE: ADVISEURS (mensen achter het bureau)
============================================ */
.advisors {
  padding: 96px 0;
  background: var(--cream);
}
.advisors-head {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 64px;
  align-items: end;
  margin-bottom: 56px;
}
@media (max-width: 880px) { .advisors-head { grid-template-columns: 1fr; gap: 24px; } }
.advisors-head .lead-copy {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--green-text);
  margin-bottom: 16px;
  font-family: var(--f-display);
}
.advisors-head h2 { font-size: clamp(32px, 4vw, 48px); max-width: 16ch; }
.advisors-head .right p { font-size: 17px; color: var(--muted); max-width: 44ch; }

.advisors-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
@media (max-width: 880px) { .advisors-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .advisors-grid { grid-template-columns: 1fr; } }

.advisor {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: all .25s ease;
}
.advisor:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 40px rgba(12,38,27,0.10);
  border-color: var(--green-deep);
}
.advisor .photo {
  aspect-ratio: 4/5;
  background: linear-gradient(135deg, var(--green-mid), var(--green-deep));
  position: relative;
  overflow: hidden;
}
.advisor .photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(0.9);
}
.advisor .photo .badge {
  position: absolute;
  top: 14px; left: 14px;
  background: var(--cream);
  color: var(--green-deep);
  padding: 5px 11px;
  border-radius: 999px;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.04em;
}
.advisor .body {
  padding: 20px 22px 24px;
}
.advisor h4 {
  font-size: 18px;
  margin-bottom: 4px;
}
.advisor .role {
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 14px;
}
.advisor .links {
  display: flex;
  gap: 12px;
  font-size: 13px;
  font-weight: 600;
  font-family: var(--f-display);
}
.advisor .links a {
  color: var(--green-deep);
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border-bottom: 1px solid transparent;
  padding-bottom: 1px;
  transition: border-color .15s ease;
}
.advisor .links a:hover { border-color: var(--green-deep); }
.advisor .links svg { width: 13px; height: 13px; }
/* Initiaal-avatar fallback (tot er echte portretten zijn) */
.advisor .photo.is-initials { display: grid; place-items: center; }
.advisor .photo .initials {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: clamp(34px, 5vw, 46px);
  letter-spacing: 0.02em;
  color: var(--cream);
  opacity: 0.96;
  text-shadow: 0 2px 12px rgba(0,0,0,0.18);
}

/* ============================================
   CONTINU-STYLE: BLADER VACATURES (alphabetic chip cloud)
============================================ */
.browse {
  padding: 80px 0 96px;
  background: var(--paper);
  border-top: 1px solid var(--rule);
}
.browse h2 {
  font-size: clamp(28px, 3vw, 36px);
  margin-bottom: 8px;
}
.browse > .wrap > p {
  font-size: 15px;
  color: var(--muted);
  margin-bottom: 32px;
  max-width: 50ch;
}
.browse-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.browse-cloud a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 16px 9px 14px;
  border-radius: 999px;
  background: var(--cream);
  border: 1px solid var(--rule);
  color: var(--ink);
  font-size: 14px;
  font-weight: 500;
  transition: all .15s ease;
}
.browse-cloud a:hover {
  background: var(--green-deep);
  border-color: var(--green-deep);
  color: var(--cream);
  transform: translateY(-1px);
}
.browse-cloud a .count {
  font-size: 11px;
  color: var(--muted);
  font-family: var(--f-display);
  font-weight: 700;
}
.browse-cloud a:hover .count { color: var(--green); }

/* ============================================
   CONTINU-STYLE: TESTIMONIALS (grote quote + portret)
============================================ */
.testimonials {
  padding: 96px 0;
  background: var(--cream);
  border-top: 1px solid var(--rule);
}
.testimonials-head {
  max-width: 56ch;
  margin-bottom: 48px;
}
.testimonials-head .eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--green-text);
  margin-bottom: 16px;
  font-family: var(--f-display);
}
.testimonials-head h2 {
  font-size: clamp(32px, 4vw, 44px);
  line-height: 1.1;
  margin-bottom: 16px;
}
.testimonials-head p {
  font-size: 17px;
  color: var(--muted);
  line-height: 1.5;
}
.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 980px) { .testimonials-grid { grid-template-columns: 1fr; } }
.testimonial {
  background: var(--paper);
  border-radius: var(--radius-lg);
  border: 1px solid var(--rule);
  padding: 36px 32px;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: all .25s ease;
}
.testimonial:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 40px rgba(12,38,27,0.08);
}
.testimonial .quote-mark {
  font-family: var(--f-display);
  font-size: 88px;
  line-height: 0.7;
  color: var(--green);
  margin-bottom: 12px;
  font-weight: 800;
  letter-spacing: -0.04em;
}
.testimonial .quote {
  font-family: var(--f-display);
  font-size: 18px;
  line-height: 1.45;
  font-weight: 500;
  color: var(--green-deep);
  margin-bottom: 28px;
  letter-spacing: -0.01em;
  flex: 1;
}
.testimonial .person {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-top: 20px;
  border-top: 1px solid var(--rule);
}
.testimonial .avatar {
  width: 52px; height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--green), var(--green-ink));
  flex-shrink: 0;
  overflow: hidden;
  border: 2px solid var(--cream);
  box-shadow: 0 0 0 1px var(--rule);
}
.testimonial .avatar img { width: 100%; height: 100%; object-fit: cover; }
.testimonial .who { display: flex; flex-direction: column; line-height: 1.3; }
.testimonial .who .name {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 15px;
  color: var(--green-deep);
}
.testimonial .who .role {
  font-size: 13px;
  color: var(--muted);
}
.testimonial .rating {
  position: absolute;
  top: 32px; right: 32px;
  display: inline-flex;
  align-items: center;
  gap: 3px;
  color: #FFC107;  /* amber-yellow voor sterren */
}
.testimonial .rating .ico {
  width: 16px;
  height: 16px;
  filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.08));
}

/* FlexHero shield-badge — gebruikt op medewerker-testimonials i.p.v. fotos */
.fh-shield {
  width: 44px;
  height: 44px;
  display: block;
  flex-shrink: 0;
  object-fit: contain;
  filter: drop-shadow(0 2px 5px rgba(12,38,27,0.18));
}
/* Maak het avatar-cirkel-frame transparant in de testimonials-pros sectie zodat alleen het schild zichtbaar is */
.testimonials-pros .avatar {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  overflow: visible !important;
  width: 44px !important;
  height: 44px !important;
  display: flex;
  align-items: center;
  justify-content: center;
}
/* In de quotes-strip (voor-professionals.html etc.) zit het schild rechtstreeks naast .who-meta */
.qs-card .who .fh-shield {
  width: 48px;
  height: 48px;
}

/* ============================================
   CONTINU-STYLE: COMMUNITY / PADEL-LIKE PARTNERSHIP
============================================ */
.community {
  padding: 96px 0;
  background: var(--cream);
}
.community h2 .academy-link {
  color: inherit;
  text-decoration: none;
  transition: opacity .15s ease;
}
.community h2 .academy-link:hover { opacity: 0.82; }
.community h2 .academy-link:focus-visible {
  outline: 2px solid var(--green);
  outline-offset: 4px;
  border-radius: 4px;
}
.community-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}
@media (max-width: 880px) { .community-grid { grid-template-columns: 1fr; gap: 32px; } }
.community .img-side {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 4/3;
  background: var(--green-deep);
}
.community .img-side img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.community .img-side .overlay {
  position: absolute;
  bottom: 24px; left: 24px;
  background: var(--cream);
  padding: 14px 20px;
  border-radius: 999px;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 13px;
  color: var(--green-deep);
  letter-spacing: 0.04em;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.community .img-side .overlay::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--green-ink);
}
.community .copy .eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--green-text);
  margin-bottom: 18px;
  font-family: var(--f-display);
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.community .copy .eyebrow::before {
  content: "";
  width: 24px; height: 2px;
  background: var(--green-ink);
}
.community .copy h2 {
  font-size: clamp(32px, 4vw, 48px);
  line-height: 1.05;
  margin-bottom: 20px;
  max-width: 18ch;
}
.community .copy h2 .accent {
  position: relative;
  display: inline-block;
}
.community .copy h2 .accent::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0.06em;
  height: 0.32em; background: var(--green); z-index: -1;
}
.community .copy p {
  font-size: 16px;
  line-height: 1.55;
  color: var(--ink-2);
  margin-bottom: 16px;
  max-width: 46ch;
}
.community .stats-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 32px;
  padding-top: 32px;
  border-top: 1px solid var(--rule);
}
.community .stats-row .num {
  font-family: var(--f-display);
  font-size: 32px;
  font-weight: 800;
  color: var(--green-deep);
  letter-spacing: -0.03em;
  line-height: 1;
}
.community .stats-row .lbl {
  font-size: 12px;
  color: var(--muted);
  font-weight: 600;
  margin-top: 6px;
}

/* ============================================
   VIND JOUW BAAN — ZOEK-CTA onder de hero
   Wit vlak (matcht het site-brede patroon: donkere hero -> licht eronder
   zoals .city-intro, .feature-grid, .story op alle andere pagina's).
   Donkergroene titel met bright green accent op het sleutelwoord.
============================================ */
.vind-baan {
  background: var(--paper);
  padding: 96px 0 104px;
  color: var(--ink);
}
.vind-baan-title {
  text-align: center;
  font-family: var(--f-display);
  font-weight: 800;
  font-size: clamp(40px, 6vw, 72px);
  letter-spacing: -0.02em;
  line-height: 1.04;
  color: var(--green-deep);
  margin: 0 0 44px;
}
.vind-baan-title em {
  color: var(--green);
  font-style: normal;
}
.vind-baan-form {
  display: grid;
  grid-template-columns: 1fr 1fr 96px;
  gap: 12px;
  max-width: 1040px;
  margin: 0 auto;
}
.vind-baan-field { display: block; position: relative; }
.vind-baan-field input {
  width: 100%;
  height: 68px;
  padding: 0 24px;
  border: 1px solid var(--rule, #ece6da);
  border-radius: 12px;
  background: #fff;
  color: var(--ink);
  font: 16px/1.2 inherit;
  outline: none;
  box-shadow: 0 2px 8px rgba(12,38,27,0.04);
  transition: border-color .15s ease, box-shadow .15s ease;
}
.vind-baan-field input::placeholder { color: var(--muted, #5F5F5B); opacity: 0.7; }
.vind-baan-field input:hover { border-color: #cdd6c6; }
.vind-baan-field input:focus-visible {
  border-color: var(--green);
  box-shadow: 0 0 0 3px rgba(136,217,50,0.25);
}
.vind-baan-submit {
  height: 68px;
  border: 0;
  border-radius: 12px;
  background: var(--green);
  color: var(--green-deep);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(136,217,50,0.30);
  transition: background .15s ease, transform .15s ease, box-shadow .15s ease;
}
.vind-baan-submit svg { width: 26px; height: 26px; }
.vind-baan-submit:hover {
  background: #9eee44;
  transform: translateY(-1px);
  box-shadow: 0 8px 22px rgba(136,217,50,0.40);
}
.vind-baan-submit:active { transform: translateY(0); }
/* Mobiel: het zoek-knopje wordt full-width — toon dan een label i.p.v. een
   kale pijl (anders oogt het als een lege groene balk). */
@media (max-width: 720px) {
  .vind-baan-submit::before {
    content: "Zoek vacatures";
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 16px;
    margin-right: 10px;
    color: var(--green-deep);
  }
}
@media (max-width: 720px) {
  .vind-baan { padding: 64px 0 72px; }
  .vind-baan-title { margin-bottom: 28px; }
  .vind-baan-form { grid-template-columns: 1fr; gap: 10px; }
  .vind-baan-field input,
  .vind-baan-submit { height: 58px; }
  .vind-baan-submit { width: 100%; }
}

/* ============================================
   CONTINU-STYLE: KLANTEN GRID (logos as cards)
============================================ */
.clients {
  padding: 80px 0;
  background: var(--green-deep);
  color: var(--cream);
}
.clients h2 {
  color: var(--cream);
  font-size: clamp(28px, 3vw, 36px);
  text-align: center;
  margin-bottom: 12px;
}
.clients > .wrap > p {
  color: var(--cream);
  opacity: 0.7;
  text-align: center;
  margin-bottom: 48px;
  font-size: 15px;
}
/* === Klanten-marquee (oneindige langzame scroll) === */
.clients-marquee {
  position: relative;
  overflow: hidden;
  margin-top: 48px;
  padding: 12px 0;
  -webkit-mask-image: linear-gradient(to right, transparent 0, black 80px, black calc(100% - 80px), transparent 100%);
          mask-image: linear-gradient(to right, transparent 0, black 80px, black calc(100% - 80px), transparent 100%);
}
.clients-marquee-track {
  display: flex;
  gap: 0;
  width: max-content;
  animation: clientsMarquee 60s linear infinite;
  will-change: transform;
}
.clients-marquee:hover .clients-marquee-track {
  animation-play-state: paused;
}
@keyframes clientsMarquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.clients-marquee .client-cell {
  flex-shrink: 0;
  font-size: 16px;            /* basis voor logo-grootte; één waarde schaalt alles op mobiel */
  width: 13em;                /* 208px — alle witte blokjes identiek breed */
  height: 6.25em;             /* 100px */
  margin: 0 .625em;           /* 10px */
  padding: 0 1.5em;           /* 0 24px */
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.14);
  opacity: 0.92;
  transition: opacity .2s ease, transform .2s ease, box-shadow .2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.clients-marquee .client-cell img {
  width: auto;
  height: 3.125em;            /* fallback ~50px */
  max-width: 10em;            /* 160px — binnen de cel-breedte minus padding */
  object-fit: contain;
  display: block;
}
/* Optische normalisatie: gelijke oppervlakte per logo (hoogte ~ 1/√verhouding,
   gemeten na het wegsnijden van witruimte) zodat alle logo's even groot ogen */
.clients-marquee img[src*="geelen-beton.png"]    { height: 2.375em; }  /* 38px */
.clients-marquee img[src*="znd.png"]             { height: 2.375em; }  /* 38px */
.clients-marquee img[src*="csb.png"]             { height: 2.6875em; } /* 43px */
.clients-marquee img[src*="van-oorschot"]        { height: 2.75em; }   /* 44px */
.clients-marquee img[src*="wilting.png"]         { height: 2.8125em; } /* 45px */
.clients-marquee img[src*="saris.png"]           { height: 2.9375em; } /* 47px */
.clients-marquee img[src*="inno-metal.png"]      { height: 3.125em; }  /* 50px */
.clients-marquee img[src*="kusters-goumans.png"] { height: 3.375em; }  /* 54px */
.clients-marquee img[src*="vdl.png"]             { height: 3.375em; }  /* 54px */
.clients-marquee img[src*="endevoets.png"]       { height: 4em; }      /* 64px */
.clients-marquee img[src*="blitta.png"]          { height: 4.125em; }  /* 66px */
.clients-marquee img[src*="luro.png"]            { height: 4.125em; }  /* 66px */
.clients-marquee img[src*="nts.jpeg"]            { height: 4.125em; }  /* 66px */
.clients-marquee .client-cell:hover {
  opacity: 1;
  transform: scale(1.05);
  box-shadow: 0 10px 26px rgba(0,0,0,0.2);
}

/* Reduced motion: stop animation */
@media (prefers-reduced-motion: reduce) {
  .clients-marquee-track { animation: none; }
}

@media (max-width: 760px) {
  .clients-marquee .client-cell { font-size: 11.5px; margin: 0 .5em; }  /* schaalt alle logo's mee naar ~72% */
  .clients-marquee-track { animation-duration: 45s; }
}

/* ============================================
   CONTINU-STYLE: CONTACT CTA (gesprek aangaan)
============================================ */
.contact-cta {
  padding: 96px 0;
  background: var(--cream);
}
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
  background: var(--paper);
  border-radius: var(--radius-lg);
  padding: 56px;
  border: 1px solid var(--rule);
  position: relative;
  overflow: hidden;
}
@media (max-width: 880px) {
  .contact-grid { grid-template-columns: 1fr; padding: 40px; gap: 32px; }
}
.contact-grid::before {
  content: "";
  position: absolute;
  bottom: -80px;
  right: -80px;
  width: 280px; height: 280px;
  background: radial-gradient(circle, var(--green) 0%, transparent 70%);
  opacity: 0.18;
  pointer-events: none;
}
.contact-grid h2 {
  font-size: clamp(32px, 4vw, 44px);
  margin-bottom: 16px;
  line-height: 1.05;
  max-width: 16ch;
}
.contact-grid h2 .accent {
  color: var(--green-text);
}
.contact-grid p {
  color: var(--muted);
  font-size: 16px;
  margin-bottom: 28px;
  max-width: 42ch;
  line-height: 1.55;
}
.contact-grid .btn-row { display: flex; gap: 12px; flex-wrap: wrap; }
.contact-grid .btn-primary {
  background: var(--green-deep);
  color: var(--cream);
  padding: 14px 26px;
  border-radius: 999px;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all .2s ease;
}
.contact-grid .btn-primary:hover { background: var(--green-darker); color: var(--green); }
.contact-grid .btn-secondary {
  border: 1.5px solid var(--green-deep);
  color: var(--green-deep);
  padding: 14px 26px;
  border-radius: 999px;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all .15s ease;
}
.contact-grid .btn-secondary:hover { background: var(--green-deep); color: var(--cream); }

.contact-grid .visual {
  position: relative;
  aspect-ratio: 4/3;
  border-radius: 12px;
  overflow: hidden;
  background: var(--green-deep);
}
.contact-grid .visual img { width: 100%; height: 100%; object-fit: cover; }

/* ============================================
   PAGE HERO (compact, used on sub-pages)
============================================ */
.page-hero {
  position: relative;
  background: var(--green-deep);
  color: var(--cream);
  padding: 140px 0 96px;
  overflow: hidden;
  isolation: isolate;
}
.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(1200px 600px at 90% 0%, rgba(140,229,90,0.18), transparent 60%),
    radial-gradient(900px 500px at 0% 100%, rgba(140,229,90,0.08), transparent 60%);
  z-index: -1;
}
/* Opt-in hero-afbeelding op subpagina's: <section class="page-hero has-media"> met
   <div class="page-hero__media"><img ...></div> als eerste kind. Donkere gradient
   eroverheen houdt de cream-tekst leesbaar. (Beeld later CMS-gestuurd — Fase 2.) */
.page-hero__media { position: absolute; inset: 0; z-index: -2; }
.page-hero__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.page-hero.has-media::before {
  background:
    linear-gradient(180deg, rgba(6,20,16,0.60), rgba(6,20,16,0.86)),
    radial-gradient(1200px 600px at 90% 0%, rgba(140,229,90,0.20), transparent 60%);
  z-index: -1;
}
.page-hero .crumbs {
  font-family: var(--f-display);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 24px;
  display: flex;
  gap: 10px;
  align-items: center;
}
.page-hero .crumbs a { color: var(--cream); opacity: 0.65; }
.page-hero .crumbs a:hover { opacity: 1; color: var(--green); }
.page-hero .crumbs .sep { opacity: 0.4; }

.page-hero h1 {
  color: var(--cream);
  font-size: clamp(48px, 7vw, 96px);
  line-height: 0.96;
  letter-spacing: -0.035em;
  margin-bottom: 28px;
  max-width: 18ch;
}
.page-hero h1 em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  color: var(--green);
}
.page-hero .lead {
  font-size: 19px;
  line-height: 1.5;
  color: var(--cream);
  opacity: 0.78;
  max-width: 56ch;
}
.page-hero .meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 32px;
  margin-top: 48px;
  padding-top: 32px;
  border-top: 1px solid rgba(244,236,225,0.18);
}
.page-hero .meta-row .item {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.page-hero .meta-row .num {
  font-family: var(--f-display);
  font-size: 32px;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--green);
  line-height: 1;
}
.page-hero .meta-row .lbl {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--cream);
  opacity: 0.65;
  font-family: var(--f-display);
  font-weight: 600;
}

/* ============================================
   VACATURES PAGE
============================================ */
.vac-search {
  padding: 24px 0;
  background: var(--paper);
  border-bottom: 1px solid var(--rule);
  position: sticky;
  top: 80px; /* strak onder de 80px-nav; was 102px -> 21px gat waar de hero/vacaturekaarten doorheen scrolden ("balk maakt vacatures niet goed zichtbaar") */
  z-index: 50;
  backdrop-filter: blur(8px);
}
@media (max-width: 760px) {
  /* nav wordt compacter (nav-inner 64/56px) -> search-balk daar ook strak onder de nav */
  .vac-search { top: 56px; }
}
.vac-search .search-box {
  margin-top: 0;
}
.vac-layout {
  padding: 56px 0 96px;
  background: var(--cream);
}
.vac-grid {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 56px;
  align-items: start;
}
@media (max-width: 980px) { .vac-grid { grid-template-columns: 1fr; } }

.vac-filters {
  position: sticky;
  top: 222px; /* net onder de sticky search-balk (nav 80 + balk ~135) i.p.v. 200 (zat deels achter de balk) */
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  padding: 28px;
}
.vac-filters h4 {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--green-text);
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--rule);
  font-family: var(--f-display);
  font-weight: 700;
}
.vac-filters .filter-group { margin-bottom: 28px; }
.vac-filters .filter-group:last-child { margin-bottom: 0; }
.vac-filters label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--ink);
  padding: 6px 0;
  cursor: pointer;
  user-select: none;
}
.vac-filters label .count {
  margin-left: auto;
  font-size: 12px;
  color: var(--muted);
  font-family: var(--f-display);
  font-weight: 600;
}
.vac-filters input[type="checkbox"] {
  width: 16px; height: 16px;
  accent-color: var(--green-deep);
}
.vac-filters .filter-clear {
  font-size: 13px;
  color: var(--green-deep);
  font-weight: 600;
  text-decoration: underline;
  margin-top: 6px;
  display: inline-block;
}

.vac-results .results-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  margin-bottom: 32px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--rule);
}
.vac-results .count-row {
  font-family: var(--f-display);
  font-size: 14px;
  color: var(--muted);
  font-weight: 600;
}
.vac-results .count-row strong { color: var(--green-deep); font-size: 22px; }
.vac-results .sort {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--muted);
}
.vac-results .sort select {
  border: 1px solid var(--rule);
  background: var(--paper);
  padding: 8px 14px;
  border-radius: 999px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  cursor: pointer;
}

.vac-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* ============================================================
   PAGINATION (continu.nl-stijl) — bottom of vacatures-list
   ============================================================ */
.vac-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 32px;
  padding: 18px 0;
  border-top: 1px solid var(--rule);
  flex-wrap: wrap;
  gap: 14px;
}
.vac-pag-info {
  font-size: 13px;
  color: var(--muted);
  font-family: var(--f-display);
}
.vac-pag-info strong {
  color: var(--ink);
  font-weight: 700;
}
.vac-pag-buttons {
  display: flex;
  align-items: center;
  gap: 6px;
}
.vac-pag-btn {
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  border: 1px solid var(--rule);
  background: var(--paper, #fff);
  color: var(--ink);
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 13px;
  border-radius: 8px;
  cursor: pointer;
  transition: all .15s ease;
}
.vac-pag-btn:hover:not(:disabled):not(.is-active) {
  border-color: var(--green-deep);
  color: var(--green-deep);
}
.vac-pag-btn.is-active {
  background: var(--green-deep);
  color: var(--cream, #f4ece1);
  border-color: var(--green-deep);
  cursor: default;
}
.vac-pag-btn:disabled {
  opacity: .35;
  cursor: not-allowed;
}
.vac-pag-dots {
  color: var(--muted);
  padding: 0 4px;
  font-family: var(--f-display);
  font-weight: 600;
}
@media (max-width: 600px) {
  .vac-pagination { flex-direction: column; align-items: stretch; }
  .vac-pag-buttons { justify-content: center; }
}
.vac-row {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  padding: 24px 28px;
  text-decoration: none;
  color: inherit;
  transition: all .2s ease;
  position: relative;
}
.vac-row:hover {
  border-color: var(--green-deep);
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(12,38,27,0.08);
}
.vac-row .left { display: flex; flex-direction: column; gap: 8px; }
.vac-row .badges-row { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.vac-row .badge {
  font-family: var(--f-display);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 999px;
}
.vac-row .badge.new { background: var(--green); color: var(--green-deep); }
.vac-row .badge.urgent { background: #fff1ee; color: #c75431; border: 1px solid #f3d3c5; }
.vac-row .badge.std { background: var(--cream-2); color: var(--green-deep); border: 1px solid var(--rule); }
.vac-row h3 {
  font-size: 22px;
  letter-spacing: -0.02em;
  font-weight: 700;
  font-family: var(--f-display);
  color: var(--green-deep);
  margin: 0;
}
.vac-row .company-row {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  font-size: 14px;
  color: var(--muted);
}
.vac-row .company-row span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.vac-row .company-row svg { width: 14px; height: 14px; opacity: 0.7; }
.vac-row .right { display: flex; flex-direction: column; align-items: flex-end; gap: 12px; }
.vac-row .salary {
  font-family: var(--f-display);
  font-size: 17px;
  font-weight: 700;
  color: var(--green-deep);
  letter-spacing: -0.01em;
}
.vac-row .salary span {
  font-size: 12px;
  color: var(--muted);
  font-weight: 500;
}
.vac-row .arrow {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--cream-2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--green-deep);
  transition: all .2s ease;
}
.vac-row:hover .arrow {
  background: var(--green);
  transform: translateX(3px);
}
@media (max-width: 600px) {
  .vac-row { grid-template-columns: 1fr; }
  .vac-row .right { align-items: flex-start; flex-direction: row; justify-content: space-between; }
}

.pagination {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 48px;
}
.pagination a, .pagination span {
  width: 40px; height: 40px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 14px;
  color: var(--ink);
  border: 1px solid var(--rule);
  background: var(--paper);
  text-decoration: none;
  transition: all .15s ease;
}
.pagination a:hover { border-color: var(--green-deep); }
.pagination .active { background: var(--green-deep); color: var(--cream); border-color: var(--green-deep); }
.pagination .ellipsis { border: none; background: transparent; }

/* ============================================
   WERKGEVERS PAGE
============================================ */
.feature-grid {
  padding: 96px 0;
  background: var(--paper);
}
.feature-grid h2 {
  font-size: clamp(32px, 4vw, 48px);
  margin-bottom: 14px;
  max-width: 18ch;
}
.feature-grid > .wrap > p {
  font-size: 17px;
  color: var(--muted);
  max-width: 56ch;
  margin-bottom: 56px;
  line-height: 1.55;
}
.fg-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 880px) { .fg-grid { grid-template-columns: 1fr; } }
.fg-card {
  background: var(--cream);
  border-radius: var(--radius-lg);
  padding: 36px;
  border: 1px solid var(--rule);
  transition: all .2s ease;
}
.fg-card:hover {
  border-color: var(--green-deep);
  transform: translateY(-3px);
  background: var(--paper);
  box-shadow: 0 12px 32px rgba(12,38,27,0.08);
}
.fg-card .num {
  font-family: var(--f-display);
  font-size: 13px;
  letter-spacing: 0.08em;
  font-weight: 700;
  color: var(--green-text);
  text-transform: uppercase;
  margin-bottom: 16px;
}
.fg-card h3 {
  font-size: 22px;
  margin-bottom: 12px;
  letter-spacing: -0.02em;
}
.fg-card p { color: var(--ink-2); line-height: 1.55; font-size: 15px; }
.fg-card .icon-square {
  width: 48px; height: 48px;
  background: var(--green-deep);
  color: var(--green);
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}
.fg-card .icon-square svg { width: 22px; height: 22px; }

/* ============================================
   PRICING / TARIEVEN
============================================ */
.pricing {
  padding: 96px 0;
  background: var(--cream);
}
.pricing-head { text-align: center; margin-bottom: 64px; }
.pricing-head .eyebrow {
  font-size: 12px;
  letter-spacing: 0.08em;
  font-family: var(--f-display);
  font-weight: 700;
  color: var(--green-text);
  text-transform: uppercase;
  margin-bottom: 14px;
  display: inline-block;
}
.pricing-head h2 {
  font-size: clamp(32px, 4vw, 48px);
  max-width: 16ch;
  margin: 0 auto 14px;
}
.pricing-head p {
  font-size: 17px;
  color: var(--muted);
  max-width: 52ch;
  margin: 0 auto;
}
.tier-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  align-items: stretch;
}
@media (max-width: 880px) { .tier-grid { grid-template-columns: 1fr; } }
/* Single-traject layout (voor-professionals) — één gecentreerde kaart */
.tier-grid--single { grid-template-columns: 1fr; max-width: 560px; margin-inline: auto; }
.tier-grid--single .tier.featured { transform: none; }

.tier {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  padding: 36px 32px;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: all .2s ease;
}
.tier.featured {
  background: var(--green-deep);
  color: var(--cream);
  border-color: var(--green-deep);
  transform: scale(1.02);
}
.tier .top-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
}
.tier h3 {
  font-size: 20px;
  letter-spacing: -0.02em;
  margin: 0;
}
.tier.featured h3 { color: var(--cream); }
.tier .pop {
  background: var(--green);
  color: var(--green-deep);
  padding: 4px 11px;
  border-radius: 999px;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.04em;
}
.tier .price {
  font-family: var(--f-display);
  font-size: 56px;
  font-weight: 800;
  letter-spacing: -0.04em;
  color: var(--green-deep);
  line-height: 1;
  margin-bottom: 4px;
}
.tier.featured .price { color: var(--green); }
.tier .price-sub {
  color: var(--muted);
  font-size: 14px;
  margin-bottom: 28px;
}
.tier.featured .price-sub { color: rgba(244,236,225,0.7); }
.tier ul {
  list-style: none;
  margin: 0 0 28px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
}
.tier li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  line-height: 1.45;
  color: var(--ink-2);
}
.tier.featured li { color: rgba(244,236,225,0.85); }
.tier li::before {
  content: "✓";
  color: var(--green-text);
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 2px;
}
.tier.featured li::before { color: var(--green); }
.tier .cta {
  background: var(--green-deep);
  color: var(--cream);
  padding: 14px 22px;
  border-radius: 999px;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 14px;
  text-align: center;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  transition: all .2s ease;
}
.tier .cta:hover { background: var(--green-darker); color: var(--green); }
.tier.featured .cta {
  background: var(--green);
  color: var(--green-deep);
}
.tier.featured .cta:hover { background: var(--cream); }

/* ============================================
   PROCESS DETAIL (werkwijze page)
============================================ */
/* ============================================================
   PROCESS-DEEP — Editorial chapter-system (S-tier)
   ------------------------------------------------------------
   Massive Fraunces italic numbers, generous breathing room,
   sticky number-side, photo-row dividers tussen chapters.
============================================================ */
.process-deep {
  padding: clamp(64px, 9vw, 120px) 0;
  background: var(--cream, #FCF7F2);
  position: relative;
}
.pd-step {
  display: grid;
  grid-template-columns: minmax(200px, 280px) minmax(0, 1fr) minmax(0, 0.85fr);
  gap: clamp(36px, 4vw, 72px);
  padding: clamp(80px, 11vw, 144px) 0;
  border-bottom: 1px solid rgba(229, 220, 205, 0.6);
  align-items: start;
  position: relative;
}
/* Flipped variant — om-en-om layout voor visuele afwisseling */
.pd-step.pd-step-flipped {
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1fr) minmax(200px, 280px);
}
.pd-step.pd-step-flipped .num-side { order: 3; align-items: flex-end; text-align: right; }
.pd-step.pd-step-flipped .pd-aside { order: 1; }
.pd-step.pd-step-flipped .body { order: 2; }
@media (max-width: 1100px) {
  .pd-step,
  .pd-step.pd-step-flipped { grid-template-columns: 1fr; gap: 28px; padding: 72px 0; }
  .pd-step.pd-step-flipped .num-side,
  .pd-step.pd-step-flipped .pd-aside,
  .pd-step.pd-step-flipped .body { order: unset; align-items: flex-start; text-align: left; }
}
.pd-step:last-child { border-bottom: none; }
.pd-step:first-child { padding-top: clamp(48px, 6vw, 72px); }

.pd-step .num-side {
  position: sticky;
  top: clamp(96px, 12vw, 144px);
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.pd-step .num-big {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 200;
  font-size: clamp(140px, 22vw, 280px);
  color: var(--green-text);
  line-height: 0.75;
  letter-spacing: -0.08em;
  margin: 0;
  background: linear-gradient(155deg,
    var(--green-ink, #6FB827) 0%,
    var(--green, #88D932) 35%,
    rgba(136, 217, 50, 0.55) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 8px 40px rgba(136, 217, 50, 0.22);
  font-feature-settings: "ss01" 1, "lnum" 1;
  display: inline-block;
}
.pd-step .stage-tag {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 700;
  color: var(--green-deep, #0C261B);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  align-self: flex-start;
}
.pd-step .stage-tag::before {
  content: "";
  width: 28px;
  height: 1px;
  background: var(--green-ink, #6FB827);
}
.pd-step h2 {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: clamp(36px, 5vw, 64px);
  letter-spacing: -0.035em;
  margin: 0 0 28px;
  max-width: 22ch;
  line-height: 1;
  color: var(--green-deep, #0C261B);
  font-weight: 700;
  text-wrap: balance;
}
.pd-step h2 em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  color: var(--green-text);
  letter-spacing: -0.025em;
}
.pd-step .body p {
  font-size: clamp(17px, 1.3vw, 19px);
  color: var(--ink-2, #2A2A28);
  line-height: 1.65;
  margin: 0 0 20px;
  max-width: 60ch;
  letter-spacing: -0.005em;
}
.pd-step .body p:first-of-type {
  font-size: clamp(18px, 1.45vw, 22px);
  color: var(--green-deep, #0C261B);
  font-weight: 500;
  line-height: 1.5;
}
.pd-step .body ul {
  list-style: none;
  padding: 0;
  margin: clamp(32px, 4vw, 48px) 0 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px 40px;
  border-top: 1px solid rgba(229, 220, 205, 0.55);
  padding-top: clamp(28px, 3vw, 40px);
}
@media (max-width: 720px) { .pd-step .body ul { grid-template-columns: 1fr; gap: 12px; } }
.pd-step .body li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 15px;
  color: var(--green-deep, #0C261B);
  font-weight: 600;
  letter-spacing: -0.005em;
  line-height: 1.4;
}
.pd-step .body li::before {
  content: "";
  flex-shrink: 0;
  width: 18px; height: 18px;
  margin-top: 2px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, var(--green-deep, #0C261B) 0%, var(--green-deep, #0C261B) 22%, transparent 24%),
    linear-gradient(135deg, var(--green, #88D932) 0%, #6FBF24 100%);
  box-shadow: 0 2px 6px rgba(136, 217, 50, 0.30);
}
.pd-step .duration-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, rgba(136, 217, 50, 0.10) 0%, rgba(136, 217, 50, 0.04) 100%);
  border: 1px solid rgba(136, 217, 50, 0.25);
  padding: 8px 16px;
  border-radius: 999px;
  font-size: 12.5px;
  font-weight: 700;
  font-family: var(--f-display, 'Poppins', sans-serif);
  color: var(--green-deep, #0C261B);
  margin-top: clamp(28px, 4vw, 40px);
  letter-spacing: 0.04em;
}
.pd-step .duration-tag::before {
  content: ""; width: 7px; height: 7px; border-radius: 50%;
  background: var(--green, #88D932);
  box-shadow: 0 0 0 2px rgba(136, 217, 50, 0.22), 0 0 8px rgba(136, 217, 50, 0.50);
  animation: pulse-dot 2.4s cubic-bezier(.4,0,.2,1) infinite;
}
@keyframes pulse-dot {
  0%, 100% { box-shadow: 0 0 0 2px rgba(136, 217, 50, 0.22), 0 0 8px rgba(136, 217, 50, 0.50); }
  50% { box-shadow: 0 0 0 5px rgba(136, 217, 50, 0.10), 0 0 14px rgba(136, 217, 50, 0.30); }
}

/* Chapter photo + quote aside */
.pd-aside {
  display: flex;
  flex-direction: column;
  gap: 24px;
  position: sticky;
  top: clamp(96px, 12vw, 144px);
}
.pd-photo {
  position: relative;
  margin: 0;
  aspect-ratio: 4 / 5;
  border-radius: 20px;
  overflow: hidden;
  background: linear-gradient(135deg, rgba(136, 217, 50, 0.06), rgba(12, 38, 27, 0.04));
  box-shadow:
    0 18px 50px -12px rgba(8, 24, 17, 0.22),
    0 4px 14px -4px rgba(8, 24, 17, 0.10);
  transition: transform .35s cubic-bezier(.2,.78,.2,1), box-shadow .35s ease;
}
.pd-step:hover .pd-photo { transform: translateY(-4px); box-shadow: 0 26px 60px -12px rgba(8, 24, 17, 0.30), 0 6px 16px -4px rgba(8, 24, 17, 0.14); }
.pd-photo picture, .pd-photo img {
  width: 100%; height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
  transition: transform .55s cubic-bezier(.2,.78,.2,1);
}
.pd-step:hover .pd-photo img { transform: scale(1.03); }
.pd-photo::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(8, 24, 17, 0.55) 100%);
  pointer-events: none;
  z-index: 1;
}
.pd-photo-caption {
  position: absolute;
  bottom: 18px; left: 20px; right: 20px;
  color: var(--cream, #FCF7F2);
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  z-index: 2;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.40);
}
.pd-photo-caption::before {
  content: "";
  display: inline-block;
  width: 22px; height: 1px;
  background: var(--green, #88D932);
  vertical-align: middle;
  margin-right: 10px;
}
.pd-quote {
  margin: 0;
  padding: 22px 24px 22px 28px;
  background: linear-gradient(135deg, rgba(136, 217, 50, 0.06), rgba(136, 217, 50, 0.02));
  border-left: 3px solid var(--green, #88D932);
  border-radius: 0 12px 12px 0;
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  font-size: clamp(16px, 1.3vw, 19px);
  line-height: 1.4;
  color: var(--green-deep, #0C261B);
  letter-spacing: -0.015em;
  position: relative;
}
.pd-quote cite {
  display: block;
  margin-top: 12px;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-style: normal;
  font-weight: 600;
  font-size: 11.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--green-text);
}
@media (max-width: 1100px) {
  .pd-aside { position: static; max-width: 480px; margin-top: 12px; }
}

/* ============================================================
   BENTO-SECTION — varying cells "Wat wij voor je regelen"
============================================================ */
.bento-section {
  padding: clamp(96px, 12vw, 160px) 0;
  background: linear-gradient(180deg, var(--cream, #FCF7F2) 0%, var(--cream-2, #F4ECE1) 100%);
}
.bento-head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto clamp(48px, 6vw, 72px);
}
.bento-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--green-text);
  margin-bottom: 22px;
}
.bento-eyebrow::before {
  content: "";
  width: 28px;
  height: 2px;
  background: var(--green, #88D932);
}
.bento-title {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: clamp(36px, 4.8vw, 64px);
  line-height: 1.02;
  letter-spacing: -0.035em;
  color: var(--green-deep, #0C261B);
  margin: 0 0 20px;
  font-weight: 700;
}
.bento-title em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  color: var(--green-text);
  letter-spacing: -0.025em;
}
.bento-lead {
  font-size: clamp(17px, 1.3vw, 19px);
  line-height: 1.55;
  color: var(--ink-2, #2A2A28);
  max-width: 60ch;
  margin: 0 auto;
}

.bento-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: minmax(220px, auto);
  gap: 18px;
}
@media (max-width: 1100px) {
  .bento-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .bento-grid { grid-template-columns: 1fr; }
}

.bento-cell {
  position: relative;
  background: var(--paper, #FFF);
  border: 1px solid var(--rule, #E5DCCD);
  border-radius: 20px;
  padding: clamp(24px, 2.5vw, 36px);
  overflow: hidden;
  transition: transform .25s cubic-bezier(.2,.78,.2,1), box-shadow .25s ease, border-color .25s ease;
  display: flex;
  flex-direction: column;
}
.bento-cell:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 50px -12px rgba(8, 24, 17, 0.16);
  border-color: rgba(136, 217, 50, 0.35);
}

/* LARGE cell: 2x2 met photo-background */
.bento-cell-large {
  grid-column: span 2;
  grid-row: span 2;
  color: var(--cream, #FCF7F2);
  border-color: transparent;
}
.bento-cell-large .bento-bg {
  position: absolute; inset: 0;
  z-index: 0;
}
.bento-cell-large .bento-bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .55s cubic-bezier(.2,.78,.2,1);
}
.bento-cell-large:hover .bento-bg img { transform: scale(1.05); }
.bento-cell-large .bento-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(160deg,
    rgba(6, 24, 14, 0.40) 0%,
    rgba(12, 38, 27, 0.62) 50%,
    rgba(8, 24, 17, 0.88) 100%);
  z-index: 1;
}
.bento-cell-large .bento-content {
  position: relative;
  z-index: 2;
  margin-top: auto;
}
.bento-cell-large h3 {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: clamp(28px, 2.6vw, 36px);
  font-weight: 700;
  letter-spacing: -0.025em;
  color: var(--cream, #FCF7F2);
  margin: 0 0 14px;
  line-height: 1.1;
  max-width: 22ch;
}
.bento-cell-large p {
  font-size: 15.5px;
  line-height: 1.55;
  color: var(--cream, #FCF7F2);
  opacity: 0.88;
  margin: 0 0 20px;
  max-width: 44ch;
}

/* WIDE dark cell: 2x1 met massive number */
.bento-cell-wide {
  grid-column: span 2;
  position: relative;
}
.bento-cell-dark {
  background: linear-gradient(135deg, #06180E 0%, var(--green-deep, #0C261B) 100%);
  color: var(--cream, #FCF7F2);
  border-color: transparent;
}
.bento-cell-dark::before {
  content: "";
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.05 0 0 0 0 0.13 0 0 0 0 0.09 0 0 0 0.5 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity: 0.30;
  mix-blend-mode: overlay;
  pointer-events: none;
}
.bento-cell-dark > * { position: relative; z-index: 1; }
.bento-cell-wide h3 { margin: 0 0 8px; }
.bento-cell-wide .bento-h-massive {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: clamp(80px, 9vw, 140px);
  font-weight: 700;
  line-height: 0.92;
  letter-spacing: -0.06em;
  color: var(--cream, #FCF7F2);
  margin: 4px 0 18px;
}
.bento-cell-wide .bento-h-massive em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 200;
  color: var(--green, #88D932);
}
.bento-cell-wide .bento-text-light {
  font-size: 16px;
  line-height: 1.5;
  color: var(--cream, #FCF7F2);
  opacity: 0.78;
  max-width: 38ch;
  margin: 0;
}
.bento-deco {
  position: absolute;
  bottom: 24px;
  right: 24px;
  width: 200px;
  height: 100px;
  z-index: 0;
  opacity: 0.7;
}

/* TALL cell: 1x2 */
.bento-cell-tall { grid-row: span 2; }
.bento-cell-tall h3 {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: clamp(22px, 1.7vw, 26px);
  font-weight: 700;
  letter-spacing: -0.020em;
  color: var(--green-deep, #0C261B);
  margin: 14px 0 12px;
  line-height: 1.2;
}
.bento-cell-tall p {
  font-size: 14.5px;
  color: var(--ink-2, #2A2A28);
  margin: 0 0 22px;
  line-height: 1.55;
}
.bento-cert-list {
  list-style: none;
  padding: 0;
  margin: auto 0 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.bento-cert-list li {
  display: flex;
  flex-direction: column;
  padding: 12px 14px;
  background: rgba(136, 217, 50, 0.08);
  border-left: 2px solid var(--green, #88D932);
  border-radius: 0 8px 8px 0;
  font-size: 12.5px;
  color: var(--ink-2, #2A2A28);
}
.bento-cert-list li span {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-weight: 700;
  font-size: 13.5px;
  color: var(--green-deep, #0C261B);
  letter-spacing: 0.02em;
}

/* MEDIUM cells (default) */
.bento-cell h3 {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--green-deep, #0C261B);
  margin: 16px 0 10px;
  line-height: 1.2;
}
.bento-cell p {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink-2, #2A2A28);
  margin: 0;
}
.bento-icon {
  width: 48px; height: 48px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--green-deep, #0C261B);
  box-shadow: 0 4px 14px rgba(136, 217, 50, 0.18);
}
.bento-icon svg { width: 24px; height: 24px; }
.bento-icon-truck { background: linear-gradient(135deg, #fef3c7, #fbbf24); color: #92400e; }
.bento-icon-doc { background: linear-gradient(135deg, #d1fae5, #88D932); }
.bento-icon-clock { background: linear-gradient(135deg, #dbeafe, #60a5fa); color: #1e3a8a; }
.bento-icon-shield { background: linear-gradient(135deg, #e6f7e6, #88D932); }

/* Tags */
.bento-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--green-deep, #0C261B);
  background: rgba(136, 217, 50, 0.12);
  padding: 5px 12px;
  border-radius: 999px;
  align-self: flex-start;
  margin-bottom: 16px;
}
.bento-tag-light {
  color: var(--green, #88D932);
  background: rgba(136, 217, 50, 0.18);
}
.bento-cell-large .bento-tag {
  background: rgba(136, 217, 50, 0.22);
  color: var(--cream, #FCF7F2);
  backdrop-filter: blur(8px);
}

/* Stats-row in large cell */
.bento-stats {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  padding-top: 14px;
  border-top: 1px solid rgba(252, 247, 242, 0.20);
  font-size: 13px;
  color: rgba(252, 247, 242, 0.78);
}
.bento-stats strong {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-weight: 700;
  color: var(--green, #88D932);
  font-size: 17px;
  display: block;
}

/* Responsive */
@media (max-width: 1100px) {
  .bento-cell-large, .bento-cell-wide { grid-column: span 2; grid-row: span 2; }
  .bento-cell-tall { grid-row: span 2; }
}
@media (max-width: 600px) {
  .bento-cell-large, .bento-cell-wide, .bento-cell-tall { grid-column: span 1; grid-row: auto; }
  .bento-cell-large { min-height: 380px; }
}

/* ============================================================
   STORY-BLOCK — immersive testimonial section
============================================================ */
.story-block {
  position: relative;
  padding: clamp(96px, 12vw, 160px) 0;
  background:
    radial-gradient(ellipse 900px 700px at 85% 15%, rgba(136,217,50,0.16), transparent 55%),
    radial-gradient(ellipse 700px 500px at 5% 85%, rgba(136,217,50,0.08), transparent 60%),
    linear-gradient(135deg, #04140A 0%, var(--green-deep, #0C261B) 50%, #143A28 100%);
  color: var(--cream, #FCF7F2);
  overflow: hidden;
  isolation: isolate;
}
.story-grain {
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 240 240' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.05 0 0 0 0 0.13 0 0 0 0 0.09 0 0 0 0.5 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity: 0.40;
  mix-blend-mode: overlay;
  pointer-events: none;
  z-index: 0;
}
.story-block .wrap { position: relative; z-index: 1; }
.story-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: clamp(40px, 6vw, 88px);
  align-items: center;
}
@media (max-width: 980px) {
  .story-grid { grid-template-columns: 1fr; gap: 48px; }
}

.story-photo {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 30px 60px -16px rgba(0, 0, 0, 0.50), 0 8px 20px -4px rgba(0, 0, 0, 0.30);
}
.story-photo picture, .story-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.story-photo::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(8, 24, 17, 0.85) 100%);
  pointer-events: none;
}
.story-photo-meta {
  position: absolute;
  bottom: 24px; left: 24px; right: 24px;
  z-index: 2;
  color: var(--cream, #FCF7F2);
  display: flex; flex-direction: column;
  gap: 4px;
}
.story-photo-tag {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--green, #88D932);
  margin-bottom: 6px;
}
.story-photo-meta strong {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--cream, #FCF7F2);
  text-shadow: 0 1px 6px rgba(0, 0, 0, 0.30);
}
.story-photo-meta small {
  font-size: 12.5px;
  opacity: 0.78;
}

.story-content {
  position: relative;
}
.story-mark {
  position: absolute;
  top: -60px; left: -20px;
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 200;
  font-size: clamp(160px, 18vw, 280px);
  color: var(--green, #88D932);
  opacity: 0.15;
  line-height: 1;
  user-select: none;
  pointer-events: none;
  z-index: 0;
}
.story-quote {
  font-family: 'Fraunces', Georgia, serif;
  font-style: normal;
  font-weight: 300;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--cream, #FCF7F2);
  margin: 0 0 28px;
  position: relative;
  z-index: 1;
}
.story-quote em {
  font-style: italic;
  color: var(--green, #88D932);
}
.story-attribution {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-bottom: 36px;
  padding-left: 18px;
  border-left: 2px solid var(--green, #88D932);
  position: relative;
  z-index: 1;
}
.story-attribution strong {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-weight: 700;
  font-size: 15px;
  color: var(--cream, #FCF7F2);
  letter-spacing: -0.01em;
}
.story-attribution span {
  font-size: 13px;
  color: rgba(252, 247, 242, 0.74);
  font-family: var(--f-sans, 'Open Sans', sans-serif);
}
.story-mini-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  padding: 28px 0;
  border-top: 1px solid rgba(252, 247, 242, 0.18);
  border-bottom: 1px solid rgba(252, 247, 242, 0.18);
  margin-bottom: 32px;
  position: relative;
  z-index: 1;
}
@media (max-width: 480px) {
  .story-mini-stats { grid-template-columns: 1fr; gap: 16px; padding: 18px 0; }
}
.story-stat-num {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: clamp(36px, 4vw, 52px);
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--cream, #FCF7F2);
}
.story-stat-num em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  color: var(--green, #88D932);
  font-size: 0.6em;
  margin-left: 2px;
}
.story-stat-lbl {
  font-size: 12.5px;
  line-height: 1.4;
  color: rgba(252, 247, 242, 0.72);
  margin-top: 6px;
}
.story-cta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 26px;
  background: var(--green, #88D932);
  color: var(--green-deep, #0C261B);
  border-radius: 999px;
  text-decoration: none;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-weight: 700;
  font-size: 14.5px;
  letter-spacing: -0.005em;
  transition: transform .18s cubic-bezier(.34,1.56,.64,1), background .2s ease, box-shadow .2s ease;
  box-shadow: 0 8px 24px rgba(136, 217, 50, 0.30);
  position: relative;
  z-index: 1;
}
.story-cta:hover {
  background: var(--green-bright, #9CFF36);
  transform: translateY(-2px);
  box-shadow: 0 12px 30px rgba(136, 217, 50, 0.40);
}
.story-cta svg { transition: transform .25s cubic-bezier(.2,.78,.2,1); }
.story-cta:hover svg { transform: translateX(4px); }

/* ============================================================
   MAG-FAQ — magazine-style 2-col FAQ
============================================================ */
.mag-faq {
  position: relative;
  padding: clamp(96px, 12vw, 160px) 0;
  background: var(--cream, #FCF7F2);
  overflow: hidden;
  isolation: isolate;
}
.mag-faq-bg {
  position: absolute;
  bottom: -120px; left: -100px;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(136, 217, 50, 0.10), transparent 70%);
  z-index: 0;
  pointer-events: none;
}
.mag-faq .wrap { position: relative; z-index: 1; }
.mag-faq-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: clamp(48px, 6vw, 96px);
  align-items: start;
}
@media (max-width: 980px) {
  .mag-faq-grid { grid-template-columns: 1fr; gap: 40px; }
}
.mag-faq-head { position: sticky; top: clamp(96px, 12vw, 144px); }
@media (max-width: 980px) { .mag-faq-head { position: static; } }

.mag-faq-eyebrow {
  display: inline-flex;
  align-items: center;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--green-text);
  margin-bottom: 24px;
}
.mag-faq-title {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: clamp(40px, 5.5vw, 80px);
  line-height: 0.95;
  letter-spacing: -0.040em;
  color: var(--green-deep, #0C261B);
  margin: 0 0 22px;
  font-weight: 700;
}
.mag-faq-title em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  color: var(--green-text);
  letter-spacing: -0.025em;
}
.mag-faq-lead {
  font-size: 17px;
  line-height: 1.55;
  color: var(--ink-2, #2A2A28);
  margin: 0 0 32px;
  max-width: 38ch;
}
.mag-faq-contact {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 360px;
}
.mag-faq-contact-card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 20px;
  background: var(--paper, #FFF);
  border: 1px solid var(--rule, #E5DCCD);
  border-radius: 14px;
  text-decoration: none;
  transition: transform .2s cubic-bezier(.2,.78,.2,1), border-color .2s ease, box-shadow .2s ease;
}
.mag-faq-contact-card:hover {
  transform: translateY(-2px);
  border-color: var(--green, #88D932);
  box-shadow: 0 10px 24px -6px rgba(8, 24, 17, 0.10);
}
.mag-faq-contact-ico {
  width: 42px; height: 42px;
  border-radius: 11px;
  background: linear-gradient(135deg, #d1fae5, #88D932);
  color: var(--green-deep, #0C261B);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(136, 217, 50, 0.22);
}
.mag-faq-contact-ico svg { width: 20px; height: 20px; }
.mag-faq-contact-card small {
  display: block;
  font-family: var(--f-sans, 'Open Sans', sans-serif);
  font-size: 11.5px;
  color: var(--muted, #5F5F5B);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
}
.mag-faq-contact-card strong {
  display: block;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 15px;
  font-weight: 700;
  color: var(--green-deep, #0C261B);
  margin-top: 2px;
  letter-spacing: -0.005em;
}

/* FAQ list */
.mag-faq-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.mag-faq-item {
  border: 1px solid var(--rule, #E5DCCD);
  border-radius: 14px;
  background: var(--paper, #FFF);
  overflow: hidden;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.mag-faq-item[open] {
  border-color: var(--green, #88D932);
  box-shadow: 0 8px 24px -8px rgba(8, 24, 17, 0.10);
}
.mag-faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 22px 26px;
  display: flex;
  align-items: center;
  gap: 16px;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: clamp(16px, 1.4vw, 19px);
  font-weight: 600;
  color: var(--green-deep, #0C261B);
  letter-spacing: -0.015em;
  line-height: 1.35;
  transition: background .15s ease;
  -webkit-tap-highlight-color: transparent;
}
.mag-faq-item summary::-webkit-details-marker { display: none; }
.mag-faq-item summary:hover { background: rgba(136, 217, 50, 0.04); }
.mag-faq-item summary span { flex: 1; min-width: 0; }
.mag-faq-chev {
  width: 22px;
  height: 22px;
  color: var(--green-text);
  flex-shrink: 0;
  padding: 4px;
  border-radius: 50%;
  background: rgba(136, 217, 50, 0.10);
  transition: transform .3s cubic-bezier(.34,1.56,.64,1), background .15s ease, color .15s ease;
}
.mag-faq-item[open] .mag-faq-chev {
  transform: rotate(180deg);
  background: var(--green, #88D932);
  color: var(--green-deep, #0C261B);
}
.mag-faq-body {
  padding: 0 26px 26px;
  font-size: 15.5px;
  line-height: 1.7;
  color: var(--ink-2, #2A2A28);
}
.mag-faq-body p { margin: 0; }

/* ============================================================
   CTA-CINEMA — cinematic final CTA
============================================================ */
.cta-cinema {
  position: relative;
  padding: clamp(112px, 14vw, 192px) 0;
  background:
    radial-gradient(ellipse 1200px 800px at 50% 50%, rgba(136, 217, 50, 0.10), transparent 60%),
    linear-gradient(135deg, #061410 0%, var(--green-deep, #0C261B) 50%, #143A28 100%);
  color: var(--cream, #FCF7F2);
  overflow: hidden;
  isolation: isolate;
}
.cta-cinema-grain {
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 240 240' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.05 0 0 0 0 0.13 0 0 0 0 0.09 0 0 0 0.5 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity: 0.40;
  mix-blend-mode: overlay;
  pointer-events: none;
  z-index: 0;
}
.cta-cinema-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  pointer-events: none;
  z-index: 0;
}
.cta-orb-1 {
  top: -100px; left: -100px;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(136, 217, 50, 0.30), transparent 60%);
}
.cta-orb-2 {
  bottom: -150px; right: -80px;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(136, 217, 50, 0.18), transparent 60%);
}
.cta-cinema .wrap { position: relative; z-index: 1; }

.cta-cinema-inner {
  max-width: 880px;
  margin: 0 auto;
  text-align: center;
}
.cta-cinema-eyebrow {
  display: inline-block;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--green, #88D932);
  margin-bottom: 28px;
}
.cta-cinema-title {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: clamp(52px, 8vw, 112px);
  line-height: 0.95;
  letter-spacing: -0.045em;
  color: var(--cream, #FCF7F2);
  margin: 0 0 32px;
  font-weight: 700;
}
.cta-cinema-title em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 200;
  color: var(--green, #88D932);
  letter-spacing: -0.035em;
}
.cta-cinema-lead {
  font-size: clamp(17px, 1.4vw, 21px);
  line-height: 1.55;
  color: var(--cream, #FCF7F2);
  opacity: 0.85;
  max-width: 60ch;
  margin: 0 auto 14px;
}
.cta-cinema-promise {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  font-size: clamp(16px, 1.2vw, 18px);
  color: var(--green, #88D932);
  margin: 0 0 44px;
}
.cta-cinema-ctas {
  display: inline-flex;
  gap: 14px;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 52px;
}
.cta-cinema-primary {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 20px 36px;
  background: var(--green, #88D932);
  color: var(--green-deep, #0C261B);
  border-radius: 999px;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-weight: 700;
  font-size: 17px;
  text-decoration: none;
  letter-spacing: -0.005em;
  box-shadow: 0 12px 40px rgba(136, 217, 50, 0.32), 0 4px 12px rgba(136, 217, 50, 0.22);
  transition: transform .2s cubic-bezier(.34,1.56,.64,1), background .2s ease, box-shadow .2s ease;
}
.cta-cinema-primary:hover {
  background: var(--green-bright, #9CFF36);
  transform: translateY(-2px);
  box-shadow: 0 16px 48px rgba(136, 217, 50, 0.45), 0 6px 16px rgba(136, 217, 50, 0.30);
}
.cta-cinema-primary svg { transition: transform .25s cubic-bezier(.2,.78,.2,1); }
.cta-cinema-primary:hover svg { transform: translateX(4px); }
.cta-cinema-secondary {
  display: inline-flex;
  align-items: center;
  padding: 20px 30px;
  color: var(--cream, #FCF7F2);
  border: 1px solid rgba(252, 247, 242, 0.30);
  border-radius: 999px;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-weight: 600;
  font-size: 17px;
  text-decoration: none;
  letter-spacing: -0.005em;
  transition: background .2s ease, border-color .2s ease;
}
.cta-cinema-secondary:hover {
  background: rgba(252, 247, 242, 0.06);
  border-color: rgba(252, 247, 242, 0.55);
}
.cta-cinema-trust {
  display: inline-flex;
  gap: 18px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  padding-top: 28px;
  border-top: 1px solid rgba(252, 247, 242, 0.18);
  font-size: 13.5px;
  color: rgba(252, 247, 242, 0.78);
}
.cta-trust-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  color: inherit;
  transition: color .15s ease;
}
a.cta-trust-item:hover { color: var(--green, #88D932); }
.cta-trust-item strong { color: var(--cream, #FCF7F2); font-weight: 700; }
.cta-trust-divider {
  width: 4px; height: 4px;
  border-radius: 50%;
  background: rgba(252, 247, 242, 0.30);
}
@media (max-width: 660px) { .cta-trust-divider { display: none; } }

/* ============================================
   ABOUT — VERHAAL / TIMELINE
============================================ */
.story {
  padding: 96px 0;
  background: var(--paper);
}
.story .story-intro { max-width: 780px; }
.story .story-intro h2 {
  font-size: clamp(36px, 4.5vw, 56px);
  line-height: 1;
  letter-spacing: -0.03em;
  margin-bottom: 24px;
}
.story .story-intro h2 em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  color: var(--green-text);
}
.story .story-intro p {
  font-size: 19px;
  line-height: 1.55;
  color: var(--ink-2);
  margin-bottom: 16px;
}
.story-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}
@media (max-width: 880px) { .story-grid { grid-template-columns: 1fr; gap: 40px; } }
.story-grid .lead-col h2 {
  font-size: clamp(36px, 4.5vw, 56px);
  line-height: 1;
  letter-spacing: -0.03em;
  margin-bottom: 28px;
  max-width: 14ch;
}
.story-grid .lead-col h2 em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  color: var(--green-text);
}
.story-grid .lead-col p {
  font-size: 19px;
  line-height: 1.55;
  color: var(--ink-2);
  margin-bottom: 16px;
}
.timeline {
  border-left: 1px solid var(--rule);
  padding-left: 28px;
  position: relative;
}
.timeline-item {
  position: relative;
  padding-bottom: 36px;
}
.timeline-item::before {
  content: "";
  position: absolute;
  left: -34px;
  top: 6px;
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--green);
  border: 2px solid var(--paper);
  box-shadow: 0 0 0 1px var(--green-deep);
}
.timeline-item .year {
  font-family: var(--f-display);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--green-text);
  margin-bottom: 6px;
}
.timeline-item h4 {
  font-size: 19px;
  margin-bottom: 6px;
  letter-spacing: -0.02em;
}
.timeline-item p {
  font-size: 14px;
  color: var(--ink-2);
  line-height: 1.5;
  max-width: 42ch;
}

.values {
  padding: 96px 0;
  background: var(--green-deep);
  color: var(--cream);
}
.values h2 {
  color: var(--cream);
  font-size: clamp(36px, 4.5vw, 56px);
  max-width: 14ch;
  margin-bottom: 56px;
  line-height: 1;
}
.values h2 em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  color: var(--green);
  font-weight: 400;
}
.values-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(244,236,225,0.12);
  border: 1px solid rgba(244,236,225,0.12);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
@media (max-width: 880px) { .values-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .values-grid { grid-template-columns: 1fr; } }
.value {
  background: var(--green-deep);
  padding: 36px 28px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.value .v-num {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-size: 32px;
  color: var(--green);
  font-weight: 400;
  margin-bottom: 8px;
}
.value h4 {
  color: var(--cream);
  font-size: 18px;
  margin: 0;
  letter-spacing: -0.01em;
}
.value p {
  color: rgba(244,236,225,0.7);
  font-size: 14px;
  line-height: 1.5;
}

/* ============================================
   CONTACT PAGE
============================================ */
.contact-wrap {
  padding: 96px 0;
  background: var(--cream);
}
.contact-2col {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 64px;
  align-items: start;
}
@media (max-width: 880px) { .contact-2col { grid-template-columns: 1fr; gap: 40px; } }

.contact-info h2 {
  font-size: clamp(32px, 4vw, 48px);
  line-height: 1;
  margin-bottom: 20px;
  letter-spacing: -0.03em;
  max-width: 14ch;
}
.contact-info h2 em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  color: var(--green-text);
  font-weight: 400;
}
.contact-info > p {
  font-size: 17px;
  color: var(--ink-2);
  line-height: 1.55;
  max-width: 42ch;
  margin-bottom: 32px;
}
.info-block {
  margin-bottom: 28px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--rule);
}
.info-block:last-child { border-bottom: none; }
.info-block h5 {
  font-family: var(--f-display);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--green-text);
  font-weight: 700;
  margin-bottom: 10px;
}
.info-block .v {
  font-family: var(--f-display);
  font-size: 22px;
  font-weight: 600;
  color: var(--green-deep);
  letter-spacing: -0.02em;
  display: block;
  margin-bottom: 4px;
}
.info-block .v a { color: inherit; }
.info-block .v a:hover { color: var(--green-text); }
.info-block p { color: var(--ink-2); font-size: 15px; line-height: 1.5; }

.contact-form {
  background: var(--paper);
  border-radius: var(--radius-lg);
  padding: 40px;
  border: 1px solid var(--rule);
}
.contact-form h3 {
  font-size: 24px;
  margin-bottom: 6px;
  letter-spacing: -0.02em;
}
.contact-form > p {
  color: var(--muted);
  font-size: 15px;
  margin-bottom: 28px;
}
.form-row {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 18px;
}
.form-row.split { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.form-row label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 700;
  font-family: var(--f-display);
  color: var(--green-deep);
}
.form-row input, .form-row select, .form-row textarea {
  border: 1px solid var(--rule);
  background: var(--cream);
  padding: 14px 16px;
  border-radius: 10px;
  font-family: inherit;
  font-size: 15px;
  color: var(--ink);
  transition: all .15s ease;
}
.form-row input:focus, .form-row select:focus, .form-row textarea:focus {
  outline: none;
  border-color: var(--green-deep);
  background: var(--paper);
  box-shadow: 0 0 0 4px rgba(140,229,90,0.15);
}
.form-row textarea { resize: vertical; min-height: 120px; }
.form-row .pill-group {
  display: flex; flex-wrap: wrap; gap: 8px;
}
.form-row .pill-group input { display: none; }
.form-row .pill-group label {
  padding: 10px 16px;
  background: var(--cream);
  border: 1px solid var(--rule);
  border-radius: 999px;
  cursor: pointer;
  text-transform: none;
  letter-spacing: normal;
  font-size: 14px;
  font-weight: 500;
  color: var(--ink);
  font-family: inherit;
  user-select: none;
  transition: all .15s ease;
}
.form-row .pill-group input:checked + label {
  background: var(--green-deep);
  color: var(--cream);
  border-color: var(--green-deep);
}
.contact-form .submit {
  width: 100%;
  background: var(--green-deep);
  color: var(--cream);
  border: none;
  padding: 16px;
  border-radius: 999px;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 15px;
  cursor: pointer;
  margin-top: 6px;
  transition: all .15s ease;
}
.contact-form .submit:hover { background: var(--green-darker); color: var(--green); }
.contact-form .privacy {
  font-size: 12px;
  color: var(--muted);
  text-align: center;
  margin-top: 14px;
  line-height: 1.5;
}
.contact-form .privacy a { color: var(--green-deep); text-decoration: underline; }

/* ============================================
   REVEAL
============================================ */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity: 1; transform: none; }


/* ============================================
   REALITEIT IN UITZENDLAND (problem statement)
============================================ */
.realiteit {
  background: var(--green-deep);
  color: var(--cream);
  padding: 110px 0;
  position: relative;
  overflow: hidden;
}
.realiteit::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 15% 20%, rgba(136,217,50,0.08), transparent 50%),
    radial-gradient(circle at 85% 80%, rgba(136,217,50,0.05), transparent 50%);
  pointer-events: none;
}
.realiteit .wrap { position: relative; }
.realiteit-head {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 64px;
  align-items: start;
  margin-bottom: 72px;
}
@media (max-width: 880px) {
  .realiteit-head { grid-template-columns: 1fr; gap: 40px; margin-bottom: 48px; }
}
.realiteit-photo {
  margin: 0;
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  aspect-ratio: 4 / 3;
  box-shadow: 0 30px 80px rgba(0,0,0,0.35), 0 0 0 1px rgba(244,236,225,0.08);
}
.realiteit-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.realiteit-photo figcaption {
  position: absolute;
  left: 18px; bottom: 16px;
  background: rgba(12, 38, 27, 0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: var(--cream);
  font-family: var(--f-display);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  padding: 6px 12px;
  border-radius: 999px;
}
.realiteit-head .lead {
  font-size: clamp(16px, 1.3vw, 18px);
  line-height: 1.55;
  max-width: 52ch;
  opacity: 0.85;
}
.realiteit-head .eyebrow {
  font-family: var(--f-display);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--green);
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 24px;
}
.realiteit-head .eyebrow::before {
  content: "";
  width: 24px; height: 2px;
  background: var(--green);
}
.realiteit-head h2 {
  font-size: clamp(40px, 4.6vw, 68px);
  color: var(--cream);
  letter-spacing: -0.035em;
  line-height: 1.02;
  margin: 0;
}
.realiteit-head h2 .accent {
  color: var(--green);
  font-style: italic;
  font-weight: 600;
}
.realiteit-head .lead {
  font-size: 19px;
  line-height: 1.55;
  color: rgba(252,247,242,0.78);
  max-width: 520px;
}
.realiteit-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.realiteit-card {
  background: rgba(252,247,242,0.04);
  border: 1px solid rgba(252,247,242,0.08);
  border-radius: var(--radius-lg);
  padding: 32px 28px 36px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  transition: all .25s ease;
}
.realiteit-card:hover {
  background: rgba(136,217,50,0.06);
  border-color: rgba(136,217,50,0.25);
  transform: translateY(-3px);
}
.realiteit-card .ico {
  width: 44px; height: 44px;
  border-radius: 10px;
  background: rgba(136,217,50,0.12);
  color: var(--green);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.realiteit-card .ico svg { width: 22px; height: 22px; }
.realiteit-card h3 {
  font-size: 19px;
  color: var(--cream);
  letter-spacing: -0.015em;
  font-weight: 700;
  line-height: 1.25;
  margin: 0;
}
.realiteit-card p {
  font-size: 14px;
  color: rgba(252,247,242,0.6);
  line-height: 1.55;
  margin: 0;
}
.realiteit-foot {
  margin-top: 64px;
  padding-top: 40px;
  border-top: 1px solid rgba(252,247,242,0.1);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
}
.realiteit-foot .pull {
  font-family: var(--f-display);
  font-size: clamp(22px, 2vw, 28px);
  font-weight: 600;
  color: var(--cream);
  letter-spacing: -0.02em;
  max-width: 720px;
  line-height: 1.3;
}
.realiteit-foot .pull em {
  font-style: italic;
  color: var(--green);
  font-weight: 500;
}
.realiteit-foot .arrow-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--green);
  color: var(--green-deep);
  padding: 14px 24px;
  border-radius: 999px;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 14px;
  transition: all .2s ease;
  white-space: nowrap;
}
.realiteit-foot .arrow-link:hover {
  background: var(--green-bright);
  transform: translateY(-1px);
}
@media (max-width: 980px) {
  .realiteit-head { grid-template-columns: 1fr; gap: 28px; }
  .realiteit-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .realiteit-grid { grid-template-columns: 1fr; }
}

/* ============================================
   WIJ REGELEN — 4 service pillars
============================================ */
.wij-regelen {
  padding: 110px 0;
  background: var(--cream);
  border-top: 1px solid var(--rule);
}
.wij-regelen-head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: end;
  margin-bottom: 56px;
}
.wij-regelen-head .eyebrow {
  font-family: var(--f-display);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--green-text);
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
}
.wij-regelen-head .eyebrow::before {
  content: "";
  width: 24px; height: 2px;
  background: var(--green-ink);
}
.wij-regelen-head h2 {
  font-size: clamp(36px, 4.2vw, 60px);
  color: var(--green-deep);
  letter-spacing: -0.035em;
  line-height: 1.05;
  margin: 0;
}
.wij-regelen-head h2 .accent {
  font-style: italic;
  font-weight: 500;
  color: var(--green-text);
}
.wij-regelen-head .right {
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink-2);
}
.wij-regelen-head .right strong {
  display: block;
  font-family: var(--f-display);
  font-weight: 700;
  color: var(--green-deep);
  margin-bottom: 8px;
  font-size: 18px;
}
.pillars {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  background: var(--paper);
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--rule);
}
.pillar {
  padding: 36px 32px 40px;
  border-right: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  gap: 18px;
  position: relative;
  transition: background .2s ease;
}
.pillar:last-child { border-right: 0; }
.pillar:hover { background: var(--cream); }
.pillar .num {
  font-family: var(--f-display);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--green-text);
  text-transform: uppercase;
}
.pillar .ico {
  width: 56px; height: 56px;
  border-radius: 14px;
  background: var(--green);
  color: var(--green-deep);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.pillar .ico svg { width: 28px; height: 28px; }
.pillar h3 {
  font-size: 24px;
  color: var(--green-deep);
  letter-spacing: -0.02em;
  margin: 4px 0 0;
}
.pillar p {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.55;
  margin: 0;
}
.pillar .check {
  margin-top: auto;
  padding-top: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  border-top: 1px dashed var(--rule);
}
.pillar .check span {
  font-size: 13px;
  color: var(--ink-2);
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 500;
}
.pillar .check span::before {
  content: "✓";
  color: var(--green-text);
  font-weight: 800;
}
.wij-regelen-tagline {
  margin-top: 48px;
  text-align: center;
  font-family: var(--f-display);
  font-size: clamp(24px, 2.4vw, 34px);
  font-weight: 600;
  color: var(--green-deep);
  letter-spacing: -0.02em;
  line-height: 1.25;
}
.wij-regelen-tagline em {
  font-style: italic;
  color: var(--green-text);
  font-weight: 500;
}
@media (max-width: 980px) {
  .wij-regelen-head { grid-template-columns: 1fr; gap: 24px; }
  .pillars { grid-template-columns: repeat(2, 1fr); }
  .pillar:nth-child(2) { border-right: 0; }
  .pillar:nth-child(1), .pillar:nth-child(2) { border-bottom: 1px solid var(--rule); }
}
@media (max-width: 560px) {
  .pillars { grid-template-columns: 1fr; }
  .pillar { border-right: 0 !important; border-bottom: 1px solid var(--rule); }
  .pillar:last-child { border-bottom: 0; }
}

/* ============================================
   QUOTE STRIP — named professionals
============================================ */
.quotes-strip { padding: 96px 0; background: var(--cream-2); border-top: 1px solid var(--rule); }
.quotes-strip .qs-head { margin-bottom: 48px; max-width: 720px; }
.quotes-strip .qs-head .eyebrow {
  font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--green-text); font-family: var(--f-display); font-weight: 700;
  margin-bottom: 16px; display: inline-block;
}
.quotes-strip .qs-head h2 {
  font-size: clamp(32px, 4vw, 48px); line-height: 1; letter-spacing: -0.025em;
}
.quotes-strip .qs-head h2 em {
  font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green-text);
}
.qs-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
@media (max-width: 980px) { .qs-grid { grid-template-columns: 1fr; } }
.qs-card {
  background: var(--paper); border: 1px solid var(--rule);
  border-radius: var(--radius-lg); padding: 32px; display: flex; flex-direction: column; gap: 24px;
  position: relative;
}
.qs-card .mark {
  font-family: 'Fraunces', Georgia, serif; font-size: 64px; line-height: 0.6;
  color: var(--green-text); font-style: italic;
}
.qs-card blockquote {
  font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 300;
  font-size: 22px; line-height: 1.35; color: var(--ink); margin: 0;
  letter-spacing: -0.01em;
}
.qs-card .who { display: flex; align-items: center; gap: 14px; padding-top: 20px; border-top: 1px solid var(--rule); margin-top: auto; }
.qs-card .who img { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; border: 2px solid var(--cream); box-shadow: 0 0 0 1px var(--rule); }
.qs-card .who .who-meta strong { display: block; font-family: var(--f-display); font-weight: 700; font-size: 15px; color: var(--ink); }
.qs-card .who .who-meta span { font-size: 13px; color: var(--muted); }

/* ============================================
   CLIENT LOGOS — "deze organisaties gingen je voor"
============================================ */
.client-logos { padding: 80px 0; background: var(--paper); border-top: 1px solid var(--rule); }
.client-logos .cl-head { margin-bottom: 40px; }
.client-logos .cl-head .eyebrow {
  font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--green-text); font-family: var(--f-display); font-weight: 700;
  margin-bottom: 14px; display: inline-block;
}
.client-logos .cl-head h2 {
  font-size: clamp(28px, 3.4vw, 40px); line-height: 1.05; letter-spacing: -0.025em; max-width: 22ch;
}
.client-logos .cl-head h2 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green-text); }
.cl-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 0; border: 1px solid var(--rule); border-radius: var(--radius-lg); overflow: hidden; }
@media (max-width: 980px) { .cl-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px) { .cl-grid { grid-template-columns: repeat(2, 1fr); } }
.cl-cell {
  display: flex; align-items: center; justify-content: center;
  padding: 32px 20px; border-right: 1px solid var(--rule); border-bottom: 1px solid var(--rule);
  font-family: var(--f-display); font-weight: 800; font-size: 17px; color: var(--ink); opacity: 0.55;
  letter-spacing: -0.01em; transition: opacity .2s ease, background .2s ease;
}
.cl-cell:hover { opacity: 1; background: var(--cream); }
.cl-cell:nth-child(6n) { border-right: 0; }
.cl-grid > .cl-cell:nth-last-child(-n+6) { border-bottom: 0; }
@media (max-width: 980px) {
  .cl-cell:nth-child(6n) { border-right: 1px solid var(--rule); }
  .cl-cell:nth-child(3n) { border-right: 0; }
  .cl-grid > .cl-cell:nth-last-child(-n+6) { border-bottom: 1px solid var(--rule); }
  .cl-grid > .cl-cell:nth-last-child(-n+3) { border-bottom: 0; }
}

/* ============================================
   FAQ — accordion
============================================ */
.faq-block { padding: 96px 0; background: var(--cream); }
.faq-grid { display: grid; grid-template-columns: 380px 1fr; gap: 80px; align-items: start; }
@media (max-width: 880px) { .faq-grid { grid-template-columns: 1fr; gap: 40px; } }
.faq-block .faq-head .eyebrow {
  font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--green-text); font-family: var(--f-display); font-weight: 700;
  margin-bottom: 16px; display: inline-block;
}
.faq-block .faq-head h2 {
  font-size: clamp(32px, 4vw, 48px); line-height: 1; letter-spacing: -0.025em; margin-bottom: 18px;
}
.faq-block .faq-head h2 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green-text); }
.faq-block .faq-head p { font-size: 16px; color: var(--muted); line-height: 1.55; margin-bottom: 22px; }
.faq-block .faq-head .helper { font-size: 14px; color: var(--ink-2); }
.faq-block .faq-head .helper a { color: var(--green-text); font-weight: 700; }
.faq-list { display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--rule); }
.faq-list details { border-bottom: 1px solid var(--rule); padding: 24px 0; }
.faq-list summary {
  list-style: none; cursor: pointer; display: flex; align-items: center; justify-content: space-between;
  font-family: var(--f-display); font-weight: 700; font-size: 19px; color: var(--ink); letter-spacing: -0.01em;
}
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list summary::after {
  content: "+"; font-weight: 400; font-size: 28px; color: var(--green-text); transition: transform .2s ease; line-height: 1;
}
.faq-list details[open] summary::after { content: "−"; }
.faq-list details p { margin: 14px 0 0; font-size: 15px; line-height: 1.6; color: var(--ink-2); max-width: 65ch; }

/* ============================================
   CSR / SPONSORING band
============================================ */
.csr-band { padding: 96px 0; background: var(--green-deep); color: var(--cream); position: relative; overflow: hidden; }
.csr-band::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 85% 30%, rgba(156,255,54,0.18), transparent 55%);
  pointer-events: none;
}
.csr-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; position: relative; z-index: 1; }
@media (max-width: 880px) { .csr-grid { grid-template-columns: 1fr; } }
.csr-band .eyebrow {
  font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--green); font-family: var(--f-display); font-weight: 700;
  margin-bottom: 18px; display: inline-block;
}
.csr-band h2 {
  color: var(--cream); font-size: clamp(36px, 4.5vw, 56px); line-height: 1.02;
  letter-spacing: -0.03em; margin-bottom: 22px;
}
.csr-band h2 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green); }
.csr-band p { font-size: 17px; line-height: 1.55; opacity: 0.85; margin-bottom: 18px; max-width: 52ch; }
.csr-band .csr-tags { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 28px; }
.csr-band .csr-tags span {
  background: rgba(244,236,225,0.08); border: 1px solid rgba(244,236,225,0.18);
  color: var(--cream); padding: 8px 14px; border-radius: 999px;
  font-size: 13px; font-family: var(--f-display); font-weight: 600;
}
.csr-band .csr-visual {
  border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 4/3;
  background: rgba(244,236,225,0.05); border: 1px solid rgba(244,236,225,0.12);
}
.csr-band .csr-visual img { width: 100%; height: 100%; object-fit: cover; }

/* ============================================
   FACTS STRIP — for over-ons / werkgevers
============================================ */
.facts-strip { padding: 80px 0; background: var(--paper); border-top: 1px solid var(--rule); }
.facts-strip h2 {
  font-size: clamp(28px, 3.4vw, 40px); line-height: 1.05; letter-spacing: -0.025em;
  margin-bottom: 40px; max-width: 22ch;
}
.facts-strip h2 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green-text); }
.facts-row { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--rule); }
@media (max-width: 880px) { .facts-row { grid-template-columns: 1fr 1fr; } }
.fact-cell { padding: 32px 28px; border-right: 1px solid var(--rule); }
.fact-cell:first-child { padding-left: 0; }
.fact-cell:last-child { border-right: 0; padding-right: 0; }
@media (max-width: 880px) { .fact-cell:nth-child(2) { border-right: 0; } .fact-cell:nth-child(-n+2) { border-bottom: 1px solid var(--rule); } }
.fact-cell .num {
  font-family: var(--f-display); font-style: normal; font-weight: 800;
  font-size: clamp(44px, 4.6vw, 64px); line-height: 1; color: var(--green-text); letter-spacing: -0.03em;
  margin-bottom: 10px;
}
.fact-cell .lbl { font-family: var(--f-display); font-weight: 700; font-size: 14px; color: var(--ink); margin-bottom: 6px; letter-spacing: -0.005em; }
.fact-cell .desc { font-size: 13px; color: var(--muted); line-height: 1.5; }

/* ============================================
   MAP / LOCATIONS panel for contact
============================================ */
.locations-panel { padding: 96px 0; background: var(--cream-2); border-top: 1px solid var(--rule); }
.locations-panel h2 {
  font-size: clamp(32px, 4vw, 48px); line-height: 1; letter-spacing: -0.025em; margin-bottom: 14px;
}
.locations-panel h2 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green-text); }
.locations-panel > .wrap > p { color: var(--muted); font-size: 16px; max-width: 50ch; margin-bottom: 48px; }
.loc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
@media (max-width: 880px) { .loc-grid { grid-template-columns: 1fr; } }
.loc-card {
  background: var(--paper); border: 1px solid var(--rule); border-radius: var(--radius-lg);
  padding: 0; overflow: hidden; display: flex; flex-direction: column;
}
.loc-card .map {
  height: 180px; background:
    linear-gradient(135deg, var(--cream) 0%, var(--cream-2) 100%);
  position: relative; border-bottom: 1px solid var(--rule);
}
.loc-card .map::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgba(108,184,39,0.08) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(108,184,39,0.08) 1px, transparent 1px);
  background-size: 24px 24px;
}
.loc-card .map .pin {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -100%);
  width: 28px; height: 28px; border-radius: 50% 50% 50% 0; transform-origin: bottom;
  background: var(--green-deep); transform: translate(-50%, -100%) rotate(-45deg);
  box-shadow: 0 4px 14px rgba(0,0,0,0.18);
}
.loc-card .map .pin::after {
  content: ""; position: absolute; top: 8px; left: 8px; width: 12px; height: 12px;
  border-radius: 50%; background: var(--green);
}
.loc-card .body { padding: 24px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.loc-card .city {
  font-family: var(--f-display); font-weight: 800; font-size: 19px; letter-spacing: -0.01em; color: var(--ink);
}
.loc-card .addr { font-size: 14px; line-height: 1.5; color: var(--ink-2); }
.loc-card .hours { font-size: 13px; color: var(--muted); padding-top: 14px; margin-top: auto; border-top: 1px solid var(--rule); }
.loc-card .hours strong { color: var(--green-text); font-weight: 700; }

/* ============================================
   SECTOR GRID — for sub-pages
============================================ */
.sector-grid-block { padding: 96px 0; background: var(--paper); border-top: 1px solid var(--rule); }
.sector-grid-block .sg-head { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: end; margin-bottom: 56px; }
@media (max-width: 880px) { .sector-grid-block .sg-head { grid-template-columns: 1fr; gap: 24px; } }
.sector-grid-block .sg-head .eyebrow { font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--green-text); font-family: var(--f-display); font-weight: 700; margin-bottom: 14px; display: inline-block; }
.sector-grid-block h2 { font-size: clamp(32px, 4vw, 52px); line-height: 1; letter-spacing: -0.025em; max-width: 14ch; }
.sector-grid-block h2 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green-text); }
.sector-grid-block .sg-head p { font-size: 17px; line-height: 1.55; color: var(--muted); }
.sg-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
@media (max-width: 980px) { .sg-cards { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .sg-cards { grid-template-columns: 1fr; } }
.sg-card { background: var(--cream); border: 1px solid var(--rule); border-radius: var(--radius-lg); padding: 28px 24px; display: flex; flex-direction: column; gap: 14px; transition: all .2s ease; text-decoration: none; color: inherit; }
.sg-card:hover { transform: translateY(-2px); border-color: var(--green-deep); }
.sg-card .ic { width: 44px; height: 44px; border-radius: 10px; background: var(--paper); border: 1px solid var(--rule); display: flex; align-items: center; justify-content: center; color: var(--green-text); }
.sg-card .ic svg { width: 22px; height: 22px; }
.sg-card h4 { font-family: var(--f-display); font-weight: 700; font-size: 19px; letter-spacing: -0.01em; color: var(--ink); }
.sg-card p { font-size: 14px; line-height: 1.5; color: var(--muted); }
.sg-card .more { font-family: var(--f-display); font-weight: 700; font-size: 13px; color: var(--green-text); margin-top: auto; padding-top: 12px; border-top: 1px solid var(--rule); display: flex; justify-content: space-between; }

/* ============================================
   BLOG STRIP
============================================ */
.blog-strip { padding: 96px 0; background: var(--cream); border-top: 1px solid var(--rule); }
.blog-strip .bs-head { display: flex; justify-content: space-between; align-items: end; margin-bottom: 40px; gap: 24px; flex-wrap: wrap; }
.blog-strip .bs-head .eyebrow { font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--green-text); font-family: var(--f-display); font-weight: 700; margin-bottom: 14px; display: inline-block; }
.blog-strip h2 { font-size: clamp(28px, 3.4vw, 42px); line-height: 1; letter-spacing: -0.025em; max-width: 18ch; }
.blog-strip h2 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green-text); }
.blog-strip .bs-head a.see-all { font-family: var(--f-display); font-weight: 700; font-size: 14px; color: var(--green-deep); border-bottom: 1.5px solid var(--green-deep); padding-bottom: 2px; }
.bs-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
@media (max-width: 880px) { .bs-grid { grid-template-columns: 1fr; } }
.bs-card { background: var(--paper); border: 1px solid var(--rule); border-radius: var(--radius-lg); overflow: hidden; text-decoration: none; color: inherit; display: flex; flex-direction: column; transition: all .2s ease; }
.bs-card:hover { transform: translateY(-2px); border-color: var(--green-deep); }
.bs-card .img { aspect-ratio: 16/10; overflow: hidden; background: var(--cream-2); }
.bs-card .img img { width: 100%; height: 100%; object-fit: cover; }
.bs-card .body { padding: 24px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.bs-card .meta-row { display: flex; gap: 10px; font-size: 12px; color: var(--muted); font-family: var(--f-display); font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; }
.bs-card .meta-row .cat { color: var(--green-text); }
.bs-card h3 { font-family: var(--f-display); font-weight: 700; font-size: 21px; line-height: 1.15; letter-spacing: -0.015em; color: var(--ink); }
.bs-card p { font-size: 14px; line-height: 1.55; color: var(--muted); }
.bs-card .read { font-family: var(--f-display); font-weight: 700; font-size: 13px; color: var(--green-text); margin-top: auto; padding-top: 14px; border-top: 1px solid var(--rule); display: flex; justify-content: space-between; }

/* ============================================
   APP / PORTAL PROMO band
============================================ */
.portal-promo { padding: 96px 0; background: var(--cream-2); }
.portal-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px; align-items: center; }
@media (max-width: 880px) { .portal-grid { grid-template-columns: 1fr; } }
.portal-promo .eyebrow { font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--green-text); font-family: var(--f-display); font-weight: 700; margin-bottom: 16px; display: inline-block; }
.portal-promo h2 { font-size: clamp(34px, 4.2vw, 56px); line-height: 1; letter-spacing: -0.03em; margin-bottom: 18px; max-width: 14ch; }
.portal-promo h2 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green-text); }
.portal-promo > .wrap > .portal-grid > div > p { font-size: 17px; line-height: 1.55; color: var(--ink-2); margin-bottom: 24px; max-width: 48ch; }
.portal-bullets { list-style: none; display: grid; grid-template-columns: 1fr 1fr; gap: 14px 24px; margin-bottom: 28px; }
@media (max-width: 560px) { .portal-bullets { grid-template-columns: 1fr; } }
.portal-bullets li { display: flex; gap: 10px; align-items: flex-start; font-size: 14px; color: var(--ink-2); line-height: 1.45; }
.portal-bullets li::before { content: ""; width: 18px; height: 18px; border-radius: 50%; background: var(--green); flex-shrink: 0; margin-top: 2px; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23061410' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>"); background-size: 12px; background-position: center; background-repeat: no-repeat; }
.portal-promo .visual { background: var(--green-deep); border-radius: var(--radius-lg); aspect-ratio: 4/5; padding: 40px; color: var(--cream); display: flex; flex-direction: column; gap: 16px; position: relative; overflow: hidden; }
.portal-promo .visual::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 80% 20%, rgba(156,255,54,0.18), transparent 55%); }
.portal-promo .visual-row { background: rgba(244,236,225,0.08); border: 1px solid rgba(244,236,225,0.14); border-radius: 12px; padding: 16px 18px; position: relative; z-index: 1; display: flex; justify-content: space-between; align-items: center; }
.portal-promo .visual-row strong { font-family: var(--f-display); font-weight: 700; font-size: 15px; color: var(--cream); }
.portal-promo .visual-row span { font-size: 13px; color: var(--green); font-family: var(--f-display); font-weight: 600; }
.portal-promo .visual h4 { color: var(--cream); font-family: var(--f-display); font-weight: 700; font-size: 17px; margin-bottom: 6px; position: relative; z-index: 1; }
.portal-promo .visual p { font-size: 13px; color: var(--cream); opacity: 0.7; position: relative; z-index: 1; margin: 0 0 16px; }

/* ============================================
   SALARY TABLE
============================================ */
.salary-block { padding: 96px 0; background: var(--paper); }
.salary-block h2 { font-size: clamp(32px, 4vw, 48px); line-height: 1; letter-spacing: -0.025em; margin-bottom: 14px; max-width: 16ch; }
.salary-block h2 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green-text); }
.salary-block > .wrap > p { font-size: 16px; color: var(--muted); max-width: 56ch; margin-bottom: 40px; }
.salary-table { width: 100%; border: 1px solid var(--rule); border-radius: var(--radius-lg); overflow: hidden; background: var(--cream); }
.salary-table .row { display: grid; grid-template-columns: 1.6fr 1fr 1fr 0.8fr; padding: 18px 24px; border-bottom: 1px solid var(--rule); align-items: center; }
.salary-table .row:last-child { border-bottom: 0; }
.salary-table .row.head { background: var(--green-deep); color: var(--cream); font-family: var(--f-display); font-weight: 700; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; padding: 16px 24px; }
.salary-table .row.head .cell { color: var(--cream); }
.salary-table .row .cell:first-child { font-family: var(--f-display); font-weight: 700; font-size: 15px; color: var(--ink); }
/* kop-rij 1e cel won anders via .cell:first-child (--ink op --green-deep -> onleesbaar) */
.salary-table .row.head .cell:first-child { color: var(--cream); }
.salary-table .row .cell { font-size: 14px; color: var(--ink-2); }
.salary-table .row .cell.range { font-family: var(--f-display); font-weight: 700; color: var(--green-deep); }
.salary-table .row .cell .sub { display: block; font-size: 12px; color: var(--muted); font-weight: 400; margin-top: 2px; }
@media (max-width: 720px) {
  .salary-table .row { grid-template-columns: 1fr 1fr; gap: 8px; }
  .salary-table .row.head { display: none; }
  .salary-table .row .cell { font-size: 13px; }
}

/* ============================================
   COMPARE TABLE — for werkgevers
============================================ */
.compare-block { padding: 96px 0; background: var(--cream); border-top: 1px solid var(--rule); }
.compare-block h2 { font-size: clamp(32px, 4vw, 48px); line-height: 1; letter-spacing: -0.025em; margin-bottom: 14px; max-width: 16ch; }
.compare-block h2 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green-text); }
.compare-block > .wrap > p { font-size: 16px; color: var(--muted); max-width: 56ch; margin-bottom: 40px; }
.compare-table { width: 100%; border: 1px solid var(--rule); border-radius: var(--radius-lg); overflow: hidden; background: var(--paper); }
.compare-row { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; border-bottom: 1px solid var(--rule); align-items: center; }
.compare-row:last-child { border-bottom: 0; }
.compare-row > div { padding: 18px 22px; border-right: 1px solid var(--rule); font-size: 14px; color: var(--ink-2); }
.compare-row > div:last-child { border-right: 0; }
.compare-row > div:first-child { font-family: var(--f-display); font-weight: 700; color: var(--ink); font-size: 15px; }
.compare-row.head { background: var(--green-deep); color: var(--cream); }
.compare-row.head > div { font-family: var(--f-display); font-weight: 700; font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--cream); border-color: rgba(244,236,225,0.18); }
.compare-row.head > div:first-child { color: var(--cream); }
.compare-row .yes { color: var(--green-text); font-weight: 700; }
.compare-row .no { color: #c54e4e; opacity: 0.75; font-weight: 600; }
@media (max-width: 720px) {
  .compare-row { grid-template-columns: 1fr; }
  .compare-row > div { border-right: 0; padding: 12px 18px; border-bottom: 1px solid var(--rule); }
  .compare-row > div:last-child { border-bottom: 0; }
  .compare-row.head { display: none; }
  .compare-row > div::before { content: attr(data-lbl) " · "; color: var(--muted); font-weight: 400; font-size: 12px; }
  .compare-row > div:first-child::before { content: ""; }
}

/* ============================================
   PROCESS-DOWNLOAD CARD
============================================ */
.dl-card-block { padding: 96px 0; background: var(--paper); border-top: 1px solid var(--rule); }
.dl-card { background: var(--cream-2); border: 1px solid var(--rule); border-radius: var(--radius-lg); padding: 48px; display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
@media (max-width: 880px) { .dl-card { grid-template-columns: 1fr; padding: 32px; } }
.dl-card .eyebrow { font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--green-text); font-family: var(--f-display); font-weight: 700; margin-bottom: 14px; display: inline-block; }
.dl-card h3 { font-size: clamp(28px, 3.2vw, 40px); line-height: 1.05; letter-spacing: -0.025em; margin-bottom: 14px; max-width: 14ch; }
.dl-card h3 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green-text); }
.dl-card p { font-size: 16px; line-height: 1.55; color: var(--ink-2); margin-bottom: 24px; }
.dl-card .specs { display: flex; gap: 18px; font-size: 13px; color: var(--muted); margin-bottom: 24px; flex-wrap: wrap; }
.dl-card .specs span { display: flex; gap: 6px; align-items: center; }
.dl-card .specs span::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--green-ink); }
.dl-card .visual { background: var(--paper); border: 1px solid var(--rule); border-radius: 12px; padding: 28px; aspect-ratio: 4/5; display: flex; flex-direction: column; gap: 12px; box-shadow: 0 8px 24px rgba(0,0,0,0.06); }
.dl-card .visual .doc-line { height: 8px; background: var(--rule); border-radius: 4px; }
.dl-card .visual .doc-line.short { width: 60%; }
.dl-card .visual .doc-line.title { height: 18px; background: var(--green-deep); width: 70%; margin-bottom: 10px; }
.dl-card .visual .doc-block { background: var(--cream); border: 1px solid var(--rule); border-radius: 8px; padding: 12px; display: flex; flex-direction: column; gap: 6px; margin-top: auto; }

/* ============================================
   FOUNDERS / TEAM SPOTLIGHT
============================================ */
.founders-block { padding: 96px 0; background: var(--paper); border-top: 1px solid var(--rule); }
.founders-block .fb-head { margin-bottom: 56px; max-width: 720px; }
.founders-block .fb-head .eyebrow { font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--green-text); font-family: var(--f-display); font-weight: 700; margin-bottom: 14px; display: inline-block; }
.founders-block h2 { font-size: clamp(32px, 4vw, 52px); line-height: 1; letter-spacing: -0.025em; margin-bottom: 14px; }
.founders-block h2 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green-text); }
.founders-block .fb-head > p { font-size: 17px; color: var(--muted); line-height: 1.55; }
.founders-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
@media (max-width: 880px) { .founders-grid { grid-template-columns: 1fr; } }
.founder-card { display: flex; flex-direction: column; gap: 18px; }
.founder-card .photo { aspect-ratio: 4/5; border-radius: var(--radius-lg); overflow: hidden; background: var(--cream-2); border: 1px solid var(--rule); position: relative; }
.founder-card .photo img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(0.15) contrast(1.05); }
.founder-card .photo .role { position: absolute; bottom: 14px; left: 14px; background: var(--cream); padding: 6px 12px; border-radius: 999px; font-family: var(--f-display); font-weight: 700; font-size: 12px; color: var(--green-deep); letter-spacing: 0.04em; text-transform: uppercase; }
.founder-card h4 { font-family: var(--f-display); font-weight: 700; font-size: 22px; letter-spacing: -0.015em; color: var(--ink); }
.founder-card .bio { font-size: 14px; line-height: 1.55; color: var(--ink-2); }
.founder-card .links { display: flex; gap: 14px; padding-top: 14px; border-top: 1px solid var(--rule); font-size: 13px; }
.founder-card .links a { color: var(--green-text); font-family: var(--f-display); font-weight: 700; }

/* ============================================
   VACATURE DETAIL
============================================ */
.vd-hero { padding: 56px 0 40px; background: var(--cream); border-bottom: 1px solid var(--rule); }
.vd-crumbs { font-size: 13px; color: var(--muted); margin-bottom: 18px; font-family: var(--f-display); font-weight: 600; }
.vd-crumbs a { color: var(--green-text); }
.vd-crumbs span { margin: 0 8px; opacity: 0.5; }
.vd-hero h1 { font-size: clamp(36px, 4.6vw, 60px); line-height: 1; letter-spacing: -0.03em; margin-bottom: 16px; max-width: 18ch; }
.vd-hero h1 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green-text); }
.vd-meta { display: flex; gap: 24px; flex-wrap: wrap; font-size: 14px; color: var(--ink-2); font-family: var(--f-display); font-weight: 600; }
.vd-meta span { display: flex; gap: 6px; align-items: center; }
.vd-meta span::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--green-ink); }
.vd-body { padding: 64px 0 96px; background: var(--paper); }
.vd-grid { display: grid; grid-template-columns: 1fr 380px; gap: 64px; align-items: start; }
@media (max-width: 980px) { .vd-grid { grid-template-columns: 1fr; } }
.vd-content { display: flex; flex-direction: column; gap: 40px; }
.vd-section h2 { font-size: clamp(22px, 2.4vw, 30px); line-height: 1.1; letter-spacing: -0.02em; margin-bottom: 14px; }
.vd-section h2 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green-text); }
.vd-section p { font-size: 16px; line-height: 1.6; color: var(--ink-2); margin-bottom: 12px; }
.vd-section ul { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 10px; margin-top: 8px; }
.vd-section ul li { padding-left: 24px; position: relative; font-size: 15px; line-height: 1.55; color: var(--ink-2); }
.vd-section ul li::before { content: ""; position: absolute; left: 0; top: 8px; width: 12px; height: 2px; background: var(--green-deep); }
.vd-section .info-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 20px; }
.vd-section .info-grid .row { padding: 14px 0; border-top: 1px solid var(--rule); }
.vd-section .info-grid .row .k { font-size: 12px; color: var(--muted); font-family: var(--f-display); font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 4px; }
.vd-section .info-grid .row .v { font-size: 15px; color: var(--ink); font-family: var(--f-display); font-weight: 700; }

/* ============================================================
   PREMIUM VACATURE-DETAIL DESIGN — Randstad-tier visuele kwaliteit
   ============================================================ */

/* Hero sector chip — kleine label boven H1 */
.vd-hero .vd-hero-sector {
  display: inline-block;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--green-deep);
  background: var(--green-soft, #dcfce7);
  padding: 6px 12px;
  border-radius: 999px;
  margin-bottom: 18px;
}

/* Premium meta-pills met SVG icoon */
.vd-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}
.vd-meta .vd-meta-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  background: var(--paper, #fff);
  border: 1px solid var(--rule, #e7e0d3);
  border-radius: 999px;
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 12.5px;
  color: var(--ink);
}
.vd-meta .vd-meta-pill svg {
  width: 14px;
  height: 14px;
  color: var(--green-deep);
  flex-shrink: 0;
}

/* Benefit-cards grid — premium iconen (SVG ipv emoji) */
.vd-benefit-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 14px;
}
@media (max-width: 760px) {
  .vd-benefit-cards { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 420px) {
  .vd-benefit-cards { grid-template-columns: 1fr; }
}
.vd-benefit-cards .vd-bc {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 18px;
  background: var(--paper, #fff);
  border: 1px solid var(--rule, #e7e0d3);
  border-radius: 14px;
  box-shadow: 0 1px 0 rgba(12,38,27,.02);
  transition: border-color .18s ease, transform .18s ease, box-shadow .18s ease;
  min-height: 76px;
}
.vd-benefit-cards .vd-bc:hover {
  border-color: var(--green-deep, #0c261b);
  transform: translateY(-2px);
  box-shadow: 0 6px 14px -8px rgba(12,38,27,.18);
}
.vd-benefit-cards .vd-bc-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: var(--green-soft, #dcfce7);
  border-radius: 10px;
  color: var(--green-deep);
  flex-shrink: 0;
}
.vd-benefit-cards .vd-bc-icon svg {
  width: 20px;
  height: 20px;
}
.vd-benefit-cards .vd-bc-text {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 14.5px;
  line-height: 1.3;
  color: var(--ink);
}

/* Pré-eisen subsectie (kleinere lijst onder hoofdeisen) */
.vd-section ul.vd-eisen-pre {
  margin-top: 4px;
  gap: 6px;
}
.vd-section ul.vd-eisen-pre li {
  font-size: 14px;
  color: var(--muted);
}
.vd-section ul.vd-eisen-pre li::before {
  background: var(--muted);
  opacity: .6;
}

/* Info-grid PREMIUM — icoon-prefixed rows ipv plain table */
.vd-info-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 22px;
}
@media (max-width: 540px) {
  .vd-info-grid { grid-template-columns: 1fr; }
}
.vd-info-grid .ig-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: var(--cream-2, #faf6f0);
  border-radius: 12px;
  border: 1px solid transparent;
  transition: border-color .15s ease;
}
.vd-info-grid .ig-row:hover {
  border-color: var(--rule);
}
.vd-info-grid .ig-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: var(--paper, #fff);
  border-radius: 8px;
  color: var(--green-deep);
  flex-shrink: 0;
}
.vd-info-grid .ig-ico svg { width: 18px; height: 18px; }
.vd-info-grid .ig-pair {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.vd-info-grid .ig-k {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 10.5px;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 3px;
}
.vd-info-grid .ig-v {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 14.5px;
  color: var(--ink);
  line-height: 1.3;
}

/* How it works — 4-step conversie-funnel */
.vd-how {
  background: linear-gradient(180deg, var(--cream-2, #faf6f0) 0%, transparent 100%);
  border-radius: 16px;
  padding: 28px;
  border: 1px solid var(--rule);
}
.vd-how-steps {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-top: 12px;
}
@media (max-width: 600px) {
  .vd-how-steps { grid-template-columns: 1fr; }
  .vd-how { padding: 22px 18px; }
}
.vd-how-step {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 16px;
  background: var(--paper, #fff);
  border-radius: 12px;
  border: 1px solid var(--rule);
}
.vd-how-step .vd-how-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: var(--green-deep);
  color: var(--cream, #f4ece1);
  font-family: var(--f-display);
  font-weight: 800;
  font-size: 14px;
  border-radius: 50%;
  flex-shrink: 0;
}
.vd-how-step strong {
  display: block;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 14.5px;
  color: var(--ink);
  margin-bottom: 4px;
}
.vd-how-step span {
  font-size: 13px;
  line-height: 1.5;
  color: var(--muted);
}

/* Back-link met icoon */
.vd-back-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--green-text);
  font-family: var(--f-display);
  font-weight: 700;
  text-decoration: none;
  font-size: 14px;
}
.vd-back-link svg { width: 16px; height: 16px; }
.vd-back-link:hover { color: var(--green-deep); }

/* ============================================================
   PREMIUM APPLY ASIDE (rechter kolom)
   ============================================================ */
.vd-aside { display: flex; flex-direction: column; gap: 18px; }

.vd-apply {
  background: var(--green-deep, #0c261b);
  color: var(--cream, #f4ece1);
  border-radius: 18px;
  padding: 28px;
  box-shadow: 0 12px 32px -16px rgba(12,38,27,.45);
}
.vd-apply h3 {
  color: var(--cream);
  font-family: var(--f-display);
  font-weight: 800;
  font-size: 22px;
  line-height: 1.15;
  letter-spacing: -.015em;
  margin: 18px 0 6px;
}
.vd-apply h3 em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  color: var(--green, #88D932);
}
.vd-apply p {
  font-size: 13.5px;
  line-height: 1.5;
  color: rgba(244,236,225,.78);
  margin-bottom: 18px;
}

/* Live-badge */
.vd-apply-live {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(136,217,50,.14);
  color: var(--green, #88D932);
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 10.5px;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 6px 12px;
  border-radius: 999px;
}
.vd-apply-live .vd-live-dot {
  width: 7px;
  height: 7px;
  background: var(--green, #88D932);
  border-radius: 50%;
  box-shadow: 0 0 0 0 rgba(136,217,50,.6);
  animation: vdLivePulse 1.8s ease-out infinite;
}
@keyframes vdLivePulse {
  0%   { box-shadow: 0 0 0 0 rgba(136,217,50,.7); }
  70%  { box-shadow: 0 0 0 10px rgba(136,217,50,0); }
  100% { box-shadow: 0 0 0 0 rgba(136,217,50,0); }
}

/* Salary hero — prominent boven H3 */
.vd-apply-salary {
  display: flex;
  flex-direction: column;
  gap: 4px;
  background: rgba(244,236,225,.06);
  border: 1px solid rgba(244,236,225,.14);
  border-radius: 12px;
  padding: 14px 16px;
  margin-top: 14px;
}
.vd-apply-sal-lbl {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 10.5px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--green, #88D932);
}
.vd-apply-sal-val {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  font-size: 28px;
  line-height: 1.05;
  color: var(--cream);
  letter-spacing: -.015em;
}
.vd-apply-sal-unit {
  font-family: var(--f-display);
  font-weight: 500;
  font-size: 12px;
  color: rgba(244,236,225,.62);
}

/* USPS */
.vd-apply-usps {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.vd-apply-usps li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  color: rgba(244,236,225,.88);
}
.vd-apply-usps li svg {
  width: 16px;
  height: 16px;
  color: var(--green, #88D932);
  flex-shrink: 0;
}

/* Primary CTA — premium 2-line button */
.vd-cta-primary {
  display: block;
  width: 100%;
  background: var(--green, #88D932);
  color: var(--green-deep, #0c261b);
  border: 0;
  border-radius: 12px;
  padding: 16px 20px;
  cursor: pointer;
  text-align: center;
  font-family: var(--f-display);
  transition: transform .15s ease, box-shadow .15s ease;
  box-shadow: 0 2px 0 rgba(12,38,27,.3);
}
.vd-cta-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 14px -6px rgba(136,217,50,.5), 0 2px 0 rgba(12,38,27,.3);
}
.vd-cta-primary .vd-cta-main {
  display: block;
  font-weight: 800;
  font-size: 15.5px;
  letter-spacing: -.01em;
  margin-bottom: 2px;
}
.vd-cta-primary .vd-cta-sub {
  display: block;
  font-weight: 500;
  font-size: 11.5px;
  opacity: .75;
}

/* Secondary CTA-row: WhatsApp + Bel */
.vd-cta-secondary-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 10px;
}
.vd-cta-wa, .vd-cta-call {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px;
  border-radius: 10px;
  border: 1px solid rgba(244,236,225,.22);
  background: rgba(244,236,225,.04);
  color: var(--cream);
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 13px;
  text-decoration: none;
  transition: background .15s ease, border-color .15s ease;
}
.vd-cta-wa:hover, .vd-cta-call:hover {
  background: rgba(244,236,225,.1);
  border-color: rgba(244,236,225,.36);
}
.vd-cta-wa svg, .vd-cta-call svg { width: 14px; height: 14px; }

.vd-apply-ref {
  margin-top: 14px;
  font-family: var(--f-mono, ui-monospace);
  font-size: 11px;
  color: rgba(244,236,225,.54);
  text-align: center;
  letter-spacing: .03em;
}

/* Recruiter mini-card */
.vd-recruiter-card {
  display: flex;
  gap: 14px;
  align-items: center;
  padding: 18px;
  background: var(--paper, #fff);
  border: 1px solid var(--rule);
  border-radius: 16px;
}
.vd-rc-photo {
  flex-shrink: 0;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--green-soft);
}
.vd-rc-photo svg { display: block; }
.vd-rc-info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.vd-rc-name {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: 14.5px;
  color: var(--ink);
  letter-spacing: -.01em;
}
.vd-rc-role {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.3;
}
.vd-rc-stars {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 3px;
}
.vd-rc-stars-row {
  color: #f59e0b;
  font-size: 11px;
  letter-spacing: .1em;
}
.vd-rc-stars-txt {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 11px;
  color: var(--ink-2);
}

/* Trust badges grid (onder recruiter-card) */
.vd-trust-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
}
.vd-tg-item {
  padding: 8px 12px;
  background: var(--paper, #fff);
  border: 1px solid var(--rule);
  border-radius: 8px;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 11.5px;
  color: var(--green-deep);
  letter-spacing: -.005em;
}

/* ============================================================
   MOBILE BOTTOM-BAR — sticky CTA-stack op mobiele schermen
   ============================================================ */
.vd-mobile-bar {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: var(--paper, #fff);
  border-top: 1px solid var(--rule);
  padding: 10px 14px calc(10px + env(safe-area-inset-bottom));
  gap: 10px;
  box-shadow: 0 -8px 24px -12px rgba(12,38,27,.18);
}
@media (max-width: 980px) {
  .vd-mobile-bar { display: flex; align-items: center; }
  body { padding-bottom: 80px; } /* prevent footer overlap */
}
.vd-mobile-bar .vd-mb-call,
.vd-mobile-bar .vd-mb-wa {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 10px;
  border: 1px solid var(--rule);
  background: var(--paper);
  color: var(--ink);
  flex-shrink: 0;
}
.vd-mobile-bar .vd-mb-wa { color: #25d366; }
.vd-mobile-bar .vd-mb-call svg,
.vd-mobile-bar .vd-mb-wa svg { width: 20px; height: 20px; }
.vd-mobile-bar .vd-mb-apply {
  flex: 1;
  height: 48px;
  border: 0;
  border-radius: 10px;
  background: var(--green-deep, #0c261b);
  color: var(--cream, #f4ece1);
  font-family: var(--f-display);
  font-weight: 800;
  font-size: 15px;
  cursor: pointer;
  letter-spacing: -.01em;
}
.vd-mobile-bar .vd-mb-apply:hover {
  background: #0a1f17;
}

/* Hide sticky-rail on mobile (mobile-bar takes over) */
@media (max-width: 980px) {
  .vd-rail-sticky { display: none !important; }
}

.vd-aside { position: sticky; top: 120px; }
.vd-apply { background: var(--green-deep); color: var(--cream); border-radius: var(--radius-lg); padding: 32px; }
.vd-apply h3 { color: var(--cream); font-size: 24px; line-height: 1.1; margin-bottom: 8px; letter-spacing: -0.015em; }
.vd-apply h3 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green); }
.vd-apply p { font-size: 14px; opacity: 0.8; margin-bottom: 22px; line-height: 1.5; }
.vd-apply .salary { background: rgba(244,236,225,0.08); border: 1px solid rgba(244,236,225,0.16); border-radius: 10px; padding: 16px; margin-bottom: 18px; }
.vd-apply .salary .lbl { font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--green); font-family: var(--f-display); font-weight: 700; margin-bottom: 4px; }
.vd-apply .salary .val { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-size: 28px; color: var(--cream); font-weight: 300; letter-spacing: -0.015em; }
.vd-apply .vd-cta { display: block; text-align: center; background: var(--green); color: var(--green-deep); padding: 16px; border-radius: 10px; font-family: var(--f-display); font-weight: 800; text-decoration: none; letter-spacing: -0.01em; margin-bottom: 10px; transition: transform .15s ease; }
.vd-apply .vd-cta:hover { transform: translateY(-1px); }
.vd-apply .vd-secondary { display: block; text-align: center; padding: 14px; border: 1px solid rgba(244,236,225,0.3); border-radius: 10px; color: var(--cream); font-family: var(--f-display); font-weight: 700; font-size: 14px; text-decoration: none; }
.vd-recruiter { display: flex; gap: 14px; align-items: center; margin-top: 24px; padding-top: 24px; border-top: 1px solid rgba(244,236,225,0.18); }
.vd-recruiter img { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; }
.vd-recruiter .who strong { display: block; font-family: var(--f-display); font-weight: 700; font-size: 14px; color: var(--cream); }
.vd-recruiter .who span { font-size: 12px; color: var(--green); }
.similar-jobs { padding: 80px 0; background: var(--cream-2); border-top: 1px solid var(--rule); }
.similar-jobs h2 { font-size: clamp(28px, 3vw, 38px); line-height: 1.05; letter-spacing: -0.02em; margin-bottom: 32px; }
.similar-jobs h2 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green-text); }

/* ============================================
   STEP-FLOW (sollicitatie / aanvraag)
============================================ */
.flow-page { padding: 56px 0 96px; background: var(--cream); min-height: calc(100vh - 200px); }
.flow-head { max-width: 720px; margin-bottom: 32px; }
.flow-head .back { font-size: 13px; color: var(--green-text); font-family: var(--f-display); font-weight: 700; margin-bottom: 16px; display: inline-block; text-decoration: none; }
.flow-head h1 { font-size: clamp(34px, 4vw, 52px); line-height: 1; letter-spacing: -0.03em; margin-bottom: 12px; }
.flow-head h1 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green-text); }
.flow-head p { font-size: 16px; color: var(--muted); line-height: 1.55; max-width: 56ch; }
.flow-progress { display: flex; gap: 10px; margin-bottom: 40px; max-width: 720px; }
.flow-progress .seg { flex: 1; height: 4px; border-radius: 2px; background: var(--rule); position: relative; }
.flow-progress .seg.done { background: var(--green-deep); }
.flow-progress .seg.active { background: var(--green-ink); }
.flow-progress-labels { display: flex; gap: 10px; max-width: 720px; margin-top: -32px; margin-bottom: 40px; }
.flow-progress-labels span { flex: 1; font-size: 12px; font-family: var(--f-display); font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--muted); }
.flow-progress-labels span.active { color: var(--green-deep); }
.flow-card { background: var(--paper); border: 1px solid var(--rule); border-radius: var(--radius-lg); padding: 40px; max-width: 720px; }
.flow-step h2 { font-size: 22px; line-height: 1.15; letter-spacing: -0.015em; margin-bottom: 24px; }
.flow-row { display: flex; flex-direction: column; gap: 8px; margin-bottom: 18px; }
.flow-row.split { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.flow-row label { font-family: var(--f-display); font-weight: 700; font-size: 13px; color: var(--ink); letter-spacing: -0.005em; }
.flow-row label .opt { color: var(--muted); font-weight: 400; }
.flow-row input[type=text], .flow-row input[type=email], .flow-row input[type=tel], .flow-row input[type=number], .flow-row select, .flow-row textarea {
  background: var(--cream); border: 1px solid var(--rule); border-radius: 10px; padding: 14px 16px;
  font: inherit; font-size: 15px; color: var(--ink); transition: border-color .15s ease;
  font-family: var(--f-text);
}
.flow-row input:focus, .flow-row select:focus, .flow-row textarea:focus { outline: none; border-color: var(--green-deep); }
.flow-row textarea { min-height: 110px; resize: vertical; line-height: 1.5; }
.flow-row .file-zone { border: 2px dashed var(--rule); border-radius: 10px; padding: 28px; text-align: center; background: var(--cream); cursor: pointer; transition: border-color .15s ease; }
.flow-row .file-zone:hover { border-color: var(--green-deep); }
.flow-row .file-zone .ic { font-size: 28px; color: var(--green-text); margin-bottom: 8px; }
.flow-row .file-zone strong { display: block; font-family: var(--f-display); font-weight: 700; font-size: 15px; margin-bottom: 4px; }
.flow-row .file-zone span { font-size: 13px; color: var(--muted); }
.flow-pills { display: flex; gap: 10px; flex-wrap: wrap; }
.flow-pills label { display: flex; align-items: center; gap: 8px; padding: 12px 18px; background: var(--cream); border: 1px solid var(--rule); border-radius: 999px; font-family: var(--f-display); font-weight: 600; font-size: 14px; color: var(--ink); cursor: pointer; transition: all .15s ease; }
.flow-pills label:hover { border-color: var(--green-deep); }
.flow-pills input[type=radio], .flow-pills input[type=checkbox] { display: none; }
.flow-pills label.has-check::before { content: ""; width: 14px; height: 14px; border-radius: 50%; border: 1.5px solid var(--rule); }
.flow-pills input:checked + label, .flow-pills label.checked { background: var(--green-deep); color: var(--cream); border-color: var(--green-deep); }
.flow-pills input:checked + label.has-check::before, .flow-pills label.checked.has-check::before { border-color: var(--green); background: var(--green); box-shadow: inset 0 0 0 3px var(--green-deep); }
.flow-options { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
@media (max-width: 720px) { .flow-options { grid-template-columns: 1fr; } .flow-row.split { grid-template-columns: 1fr; } }
.flow-option { padding: 20px; background: var(--cream); border: 1px solid var(--rule); border-radius: 12px; cursor: pointer; transition: all .15s ease; }
.flow-option:hover { border-color: var(--green-deep); }
.flow-option.checked { border-color: var(--green-deep); background: var(--paper); box-shadow: 0 0 0 3px rgba(108,184,39,0.18); }
.flow-option .num { font-family: 'Fraunces', Georgia, serif; font-style: italic; color: var(--green-text); font-size: 14px; margin-bottom: 4px; }
.flow-option strong { display: block; font-family: var(--f-display); font-weight: 700; font-size: 16px; color: var(--ink); margin-bottom: 4px; letter-spacing: -0.01em; }
.flow-option span { font-size: 13px; color: var(--muted); line-height: 1.45; }
.flow-actions { display: flex; justify-content: space-between; gap: 16px; margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--rule); }
.flow-actions .btn-prev { background: transparent; border: 1px solid var(--rule); color: var(--ink-2); padding: 14px 22px; border-radius: 10px; font-family: var(--f-display); font-weight: 700; cursor: pointer; font-size: 14px; }
.flow-actions .btn-next { background: var(--green-deep); color: var(--cream); padding: 14px 26px; border-radius: 10px; font-family: var(--f-display); font-weight: 800; cursor: pointer; border: 0; font-size: 14px; letter-spacing: -0.01em; }
.flow-actions .btn-next:hover { background: var(--green-ink); }
.flow-confirm { text-align: center; padding: 24px 0; }
.flow-confirm .ok { width: 64px; height: 64px; border-radius: 50%; background: var(--green); display: flex; align-items: center; justify-content: center; margin: 0 auto 24px; font-size: 32px; color: var(--green-deep); }
.flow-confirm h2 { font-size: clamp(28px, 3.4vw, 40px); margin-bottom: 14px; letter-spacing: -0.02em; }
.flow-confirm h2 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; color: var(--green-text); }
.flow-confirm p { color: var(--muted); font-size: 16px; max-width: 50ch; margin: 0 auto 24px; line-height: 1.55; }
.flow-confirm .next-steps { background: var(--cream); border: 1px solid var(--rule); border-radius: 12px; padding: 24px; max-width: 480px; margin: 24px auto 0; text-align: left; }
.flow-confirm .next-steps h4 { font-family: var(--f-display); font-weight: 700; font-size: 14px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--green-text); margin-bottom: 12px; }
.flow-confirm .next-steps ol { margin: 0; padding: 0 0 0 20px; font-size: 14px; line-height: 1.7; color: var(--ink-2); }
.flow-aside { background: var(--cream-2); border: 1px solid var(--rule); border-radius: 12px; padding: 20px; margin-top: 24px; max-width: 720px; display: flex; gap: 14px; align-items: center; }
.flow-aside img { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.flow-aside .txt strong { display: block; font-family: var(--f-display); font-weight: 700; font-size: 14px; }
.flow-aside .txt span { font-size: 13px; color: var(--muted); }



/* ============= LEGAL / PROSE PAGES ============= */
.legal-wrap { padding: 64px 0 96px; background: var(--paper); }
.legal-wrap .wrap { max-width: 880px; }
.legal-toc { background: var(--cream); border: 1px solid var(--rule); border-radius: 12px; padding: 24px 28px; margin: 0 0 48px; }
.legal-toc h5 { font-family: var(--f-display); font-weight: 700; font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--green-text); margin: 0 0 12px; }
.legal-toc ol { margin: 0; padding: 0 0 0 20px; columns: 2; column-gap: 32px; }
.legal-toc ol li { margin: 0 0 6px; font-size: 14px; line-height: 1.5; break-inside: avoid; }
.legal-toc ol li a { color: var(--ink-2); text-decoration: none; transition: color 0.15s ease; }
.legal-toc ol li a:hover { color: var(--green-text); }
@media (max-width: 640px) { .legal-toc ol { columns: 1; } }

.legal-prose { color: var(--ink-2); font-size: 16px; line-height: 1.7; font-family: var(--f-sans); }
.legal-prose h2 { font-family: var(--f-display); font-weight: 700; font-size: 26px; line-height: 1.2; color: var(--ink); margin: 48px 0 16px; letter-spacing: -0.01em; scroll-margin-top: 96px; }
.legal-prose h2:first-child { margin-top: 0; }
.legal-prose h2 .num { color: var(--green-text); margin-right: 8px; font-weight: 800; }
.legal-prose h3 { font-family: var(--f-display); font-weight: 700; font-size: 18px; line-height: 1.3; color: var(--ink); margin: 28px 0 10px; }
.legal-prose p { margin: 0 0 14px; }
.legal-prose ul, .legal-prose ol { margin: 0 0 16px; padding-left: 22px; }
.legal-prose li { margin: 0 0 6px; }
.legal-prose strong { color: var(--ink); font-weight: 700; }
.legal-prose a { color: var(--green-text); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
.legal-prose a:hover { color: var(--green); }
.legal-prose .updated { display: inline-block; font-size: 13px; color: var(--muted); background: var(--cream-2); padding: 6px 12px; border-radius: 999px; margin-bottom: 24px; font-family: var(--f-display); font-weight: 600; letter-spacing: 0.02em; }
.legal-prose table { width: 100%; border-collapse: collapse; margin: 16px 0 24px; font-size: 14px; }
.legal-prose table th, .legal-prose table td { text-align: left; padding: 12px 14px; border-bottom: 1px solid var(--rule); vertical-align: top; }
.legal-prose table th { font-family: var(--f-display); font-weight: 700; color: var(--ink); background: var(--cream); }
.legal-prose .callout { background: var(--cream); border-left: 3px solid var(--green); padding: 18px 22px; margin: 18px 0 24px; border-radius: 0 8px 8px 0; }
.legal-prose .callout strong { display: block; margin-bottom: 6px; color: var(--green-deep); }

/* 404 page */
.notfound { padding: 120px 0 96px; text-align: center; background: var(--cream); }
.notfound .code { font-family: var(--f-display); font-weight: 800; font-size: clamp(96px, 20vw, 220px); line-height: 0.9; color: var(--green); letter-spacing: -0.04em; margin: 0; }
.notfound .code em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 300; color: var(--green-text); }
.notfound h1 { font-family: var(--f-display); font-weight: 700; font-size: clamp(28px, 4vw, 44px); line-height: 1.15; color: var(--ink); margin: 18px 0 14px; letter-spacing: -0.015em; }
.notfound h1 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 300; color: var(--green-text); }
.notfound .lead { font-size: 17px; line-height: 1.6; color: var(--ink-2); max-width: 56ch; margin: 0 auto 32px; }
.notfound .actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-bottom: 48px; }
.notfound .quick-links { display: flex; gap: 28px; justify-content: center; flex-wrap: wrap; max-width: 720px; margin: 0 auto; padding-top: 32px; border-top: 1px solid var(--rule); }
.notfound .quick-links a { color: var(--ink-2); font-size: 14px; text-decoration: none; font-weight: 600; transition: color 0.15s ease; }
.notfound .quick-links a:hover { color: var(--green-text); }

/* ============= UITZENDBUREAU [STAD] PAGES — DESIGN UPGRADE v2 ============= */

/* --- HERO: subtiele geometric accent + betere meta-row styling --- */
.page-hero {
  background: linear-gradient(135deg, #0c261b 0%, #1a3d2e 60%, #0c261b 100%);
}
/* Decoratieve diamond-grid pattern in de hero rechtsboven */
.page-hero::after {
  content: "";
  position: absolute;
  top: 0; right: 0;
  width: 420px; height: 420px;
  background-image: radial-gradient(circle at center, rgba(140,229,90,0.12) 1.5px, transparent 1.5px);
  background-size: 24px 24px;
  mask-image: radial-gradient(ellipse at 100% 0%, black 0%, transparent 65%);
  -webkit-mask-image: radial-gradient(ellipse at 100% 0%, black 0%, transparent 65%);
  pointer-events: none;
  z-index: -1;
}
.page-hero .crumbs { color: var(--green-bright, #88D932); }
.page-hero .meta-row .item { position: relative; padding-left: 14px; }
.page-hero .meta-row .item::before {
  content: ""; position: absolute; left: 0; top: 8px;
  width: 3px; height: 28px; background: var(--green-bright, #88D932); border-radius: 2px;
}

/* --- CITY-INTRO: visueler met colored chips + dropcap --- */
.city-intro { padding: 64px 0 32px; background: var(--paper); position: relative; }
.city-intro .wrap { max-width: 880px; }
.city-intro .stad-meta {
  display: inline-flex; gap: 10px; flex-wrap: wrap; margin-bottom: 28px;
}
.city-intro .stad-meta .chip {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--f-display); font-weight: 600; font-size: 12px;
  letter-spacing: 0.04em; text-transform: uppercase;
  padding: 7px 14px;
  background: var(--paper); border: 1.5px solid var(--rule); border-radius: 999px;
  color: var(--green-deep);
  transition: border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}
.city-intro .stad-meta .chip::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--green-bright, #88D932);
  box-shadow: 0 0 0 3px rgba(140,229,90,0.18);
}
.city-intro .stad-meta .chip:hover {
  border-color: var(--green-bright, #88D932);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(12,38,27,0.06);
}
.city-intro .stad-lead {
  font-family: var(--f-sans); font-size: 19px; line-height: 1.65;
  color: var(--ink-2); max-width: 70ch;
}
.city-intro .stad-lead strong { color: var(--ink); font-weight: 700; }
/* Dropcap: eerste letter van eerste paragraaf groot + groen */
.city-intro .stad-lead::first-letter {
  font-family: var(--f-display);
  font-size: 64px; line-height: 0.85;
  color: var(--green-text);
  font-weight: 800;
  float: left;
  padding: 6px 12px 0 0;
  margin-top: 4px;
}

/* --- CITY-SECTION: visuele anchor (accent-bar) bij h2 + dot-grid bg accent --- */
.city-section { padding: 72px 0; background: var(--paper); position: relative; overflow: hidden; }
.city-section.alt { background: var(--cream); }
/* Subtiele dot-grid op .alt sections rechtsonder */
.city-section.alt::before {
  content: ""; position: absolute;
  bottom: -100px; right: -100px;
  width: 360px; height: 360px;
  background-image: radial-gradient(circle, rgba(12,38,27,0.06) 1px, transparent 1px);
  background-size: 16px 16px;
  pointer-events: none;
}
.city-section .wrap { max-width: 1080px; position: relative; z-index: 1; }

/* H2 met visuele anchor — verticale groene streep links + eyebrow accent */
.city-section h2 {
  font-family: var(--f-display); font-weight: 700;
  font-size: clamp(26px, 3.6vw, 38px);
  line-height: 1.15;
  color: var(--ink);
  margin: 0 0 18px;
  letter-spacing: -0.015em;
  position: relative;
  padding-left: 18px;
}
.city-section h2::before {
  content: ""; position: absolute; left: 0; top: 8px;
  width: 4px; height: calc(100% - 16px);
  background: linear-gradient(180deg, var(--green-bright, #88D932) 0%, var(--green-ink) 100%);
  border-radius: 2px;
}
.city-section h2 em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic; font-weight: 300;
  color: var(--green-text);
}
.city-section .section-lead {
  font-size: 16.5px; line-height: 1.7;
  color: var(--ink-2);
  max-width: 720px;
  margin: 0 0 36px;
  padding-left: 18px; /* uitlijnen met h2 */
}

/* Blockquote in city-section — testimonial-style cards die er nu uitzien als gewone tekst */
.city-section blockquote {
  position: relative;
  border-left: 4px solid var(--green-bright, #88D932) !important;
  background: var(--paper) !important;
  border-radius: 0 12px 12px 0 !important;
  box-shadow: 0 4px 16px rgba(12,38,27,0.04);
  padding: 24px 28px !important;
}
.city-section blockquote::before {
  content: "\201C";
  position: absolute;
  top: -10px; left: 18px;
  font-family: 'Fraunces', Georgia, serif;
  font-size: 60px;
  color: var(--green-bright, #88D932);
  line-height: 1;
  opacity: 0.6;
}
.city-section.alt blockquote { background: white !important; }

/* Paragraphs in city-section iets ruimer + betere kleur */
.city-section .wrap > p { font-size: 16px; line-height: 1.75; color: var(--ink-2); max-width: 75ch; }

/* Lists in city-section krijgen groene bullets */
.city-section ul:not([class]) { list-style: none; padding-left: 0; }
.city-section ul:not([class]) > li {
  position: relative; padding-left: 26px; margin-bottom: 10px;
  line-height: 1.65; color: var(--ink-2);
}
.city-section ul:not([class]) > li::before {
  content: "";
  position: absolute; left: 0; top: 9px;
  width: 14px; height: 2px;
  background: var(--green-bright, #88D932);
  border-radius: 1px;
}

.city-jobs-list { display: grid; gap: 12px; }
.city-jobs-list .job-row { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 18px 22px; background: var(--paper); border: 1px solid var(--rule); border-radius: 12px; text-decoration: none; transition: border-color 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease; }
.city-jobs-list .job-row:hover { border-color: var(--green); transform: translateY(-1px); box-shadow: 0 8px 24px rgba(12,38,27,0.06); }
.city-jobs-list .job-row .meta { flex: 1; }
.city-jobs-list .job-row .meta .title { font-family: var(--f-display); font-weight: 700; font-size: 16px; color: var(--ink); margin: 0 0 4px; }
.city-jobs-list .job-row .meta .sub { font-size: 13px; color: var(--muted); }
.city-jobs-list .job-row .salary { font-family: var(--f-display); font-weight: 700; font-size: 14px; color: var(--green-text); white-space: nowrap; }
.city-jobs-list .empty { padding: 28px; background: var(--cream); border: 1px dashed var(--rule); border-radius: 12px; color: var(--muted); font-size: 14px; line-height: 1.6; }

.sector-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; }
.sector-grid .sector-tile { background: var(--paper); border: 1px solid var(--rule); border-radius: 12px; padding: 20px 22px; }
.sector-grid .sector-tile h4 { font-family: var(--f-display); font-weight: 700; font-size: 15px; color: var(--ink); margin: 0 0 6px; }
.sector-grid .sector-tile p { font-size: 13px; line-height: 1.55; color: var(--muted); margin: 0; }

.office-block { display: grid; grid-template-columns: 1.2fr 1fr; gap: 32px; align-items: start; padding: 32px; background: var(--green-deep); color: var(--cream); border-radius: 16px; }
.office-block h3 { font-family: var(--f-display); font-weight: 700; font-size: 22px; color: var(--cream); margin: 0 0 12px; }
.office-block .addr { font-size: 14px; line-height: 1.6; opacity: 0.85; margin: 0 0 8px; }
.office-block .addr a { color: var(--green-bright); text-decoration: none; font-weight: 700; }
.office-block .addr a:hover { text-decoration: underline; }
.office-block .nearby h4 { font-family: var(--f-display); font-weight: 600; font-size: 13px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--green); margin: 0 0 10px; }
.office-block .nearby ul { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.office-block .nearby li a { display: inline-block; padding: 6px 12px; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.12); border-radius: 999px; color: var(--cream); font-size: 13px; text-decoration: none; transition: background 0.15s ease; }
.office-block .nearby li a:hover { background: var(--green); color: var(--green-deep); border-color: var(--green); }
@media (max-width: 720px) { .office-block { grid-template-columns: 1fr; padding: 24px; } }

/* --- FAQ: meer visueel met groene plus/min-iconen + accent-state --- */
.city-faq { display: grid; gap: 10px; }
.city-faq details {
  background: var(--paper); border: 1.5px solid var(--rule); border-radius: 14px;
  padding: 18px 24px;
  transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}
.city-faq details:hover { transform: translateX(2px); box-shadow: 0 4px 14px rgba(12,38,27,0.04); }
.city-faq details[open] {
  border-color: var(--green-bright, #88D932);
  background: linear-gradient(135deg, rgba(140,229,90,0.04), transparent);
  box-shadow: 0 4px 16px rgba(12,38,27,0.06);
}
.city-faq summary {
  cursor: pointer;
  font-family: var(--f-display); font-weight: 700; font-size: 16.5px;
  color: var(--ink);
  list-style: none;
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
}
.city-faq summary::-webkit-details-marker { display: none; }
.city-faq summary::after {
  content: "+";
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  width: 30px; height: 30px;
  background: var(--cream-2);
  color: var(--green-text);
  font-size: 22px; font-weight: 300; line-height: 1;
  border-radius: 50%;
  transition: background .15s ease, transform .25s ease, color .15s ease;
}
.city-faq details[open] summary::after {
  content: "−";
  background: var(--green-bright, #88D932);
  color: var(--green-deep);
  transform: rotate(180deg);
}
.city-faq details p {
  margin: 14px 0 0;
  font-size: 14.5px; line-height: 1.7; color: var(--ink-2);
  padding-top: 14px;
  border-top: 1px solid rgba(12,38,27,0.08);
}

/* --- CITY-CTA: gradient-achtergrond + decoratieve accents --- */
.city-cta {
  padding: 80px 0;
  background: linear-gradient(135deg, #0c261b 0%, #1a3d2e 100%);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.city-cta::before, .city-cta::after {
  content: ""; position: absolute;
  width: 400px; height: 400px; border-radius: 50%;
  background: radial-gradient(circle, rgba(140,229,90,0.15) 0%, transparent 60%);
  pointer-events: none;
}
.city-cta::before { top: -150px; left: -100px; }
.city-cta::after { bottom: -150px; right: -100px; }
.city-cta .wrap { position: relative; z-index: 1; }
.city-cta h2 {
  font-family: var(--f-display); font-weight: 700;
  font-size: clamp(28px, 3.8vw, 42px);
  line-height: 1.15; color: var(--cream, #fcf7f2);
  margin: 0 0 16px; letter-spacing: -0.02em;
}
.city-cta h2 em {
  font-family: 'Fraunces', Georgia, serif; font-style: italic;
  font-weight: 300; color: var(--green-bright, #88D932);
}
.city-cta p {
  font-size: 17px; line-height: 1.65;
  color: rgba(252,247,242,0.82);
  max-width: 60ch; margin: 0 auto 32px;
}
.city-cta .actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
/* Ensure buttons in CTA stay readable on dark bg */
.city-cta .btn-primary { background: var(--green-bright, #88D932); color: var(--green-deep); }
.city-cta .btn-secondary {
  background: transparent; color: var(--cream, #fcf7f2);
  border: 1.5px solid rgba(252,247,242,0.3);
}
.city-cta .btn-secondary:hover {
  background: rgba(252,247,242,0.08);
  border-color: var(--green-bright, #88D932);
}

/* === Provincie page: city grid === */
.city-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 8px; }
.city-grid a { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; background: var(--paper); border: 1px solid var(--rule); border-radius: 8px; text-decoration: none; color: var(--ink); font-family: var(--f-display); font-weight: 600; font-size: 14px; transition: border-color 0.15s ease, background 0.15s ease, transform 0.15s ease; }
.city-grid a:hover { border-color: var(--green); background: var(--cream); transform: translateY(-1px); }
.city-grid a::after { content: "→"; opacity: 0.4; font-weight: 400; transition: opacity 0.15s ease, transform 0.15s ease; }
.city-grid a:hover::after { opacity: 1; transform: translateX(2px); color: var(--green-text); }

/* === Diensten-grid (city + province cross-links to subpages) === */
.dienst-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 14px; }
.dienst-card {
  display: flex; flex-direction: column; gap: 6px; padding: 18px 20px;
  background: var(--paper); border: 1px solid var(--rule); border-radius: 10px;
  text-decoration: none; color: var(--ink);
  transition: border-color .15s, transform .15s, box-shadow .15s;
}
.dienst-card:hover { border-color: var(--green); transform: translateY(-2px); box-shadow: 0 6px 18px rgba(0,0,0,0.06); }
.dienst-card strong { font-family: var(--f-display); font-size: 15px; color: var(--green-text); }
.dienst-card span { font-size: 13px; color: var(--ink-2); line-height: 1.4; }

/* === Sitemap.html public overview === */
.sitemap-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 28px; }
.sitemap-col h3 { font-family: var(--f-display); font-size: 13px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--green-text); margin: 0 0 12px; padding-bottom: 8px; border-bottom: 2px solid var(--green); }
.sitemap-col a { display: block; padding: 6px 0; color: var(--ink-2); text-decoration: none; font-size: 14px; transition: color .12s, padding-left .12s; }
.sitemap-col a:hover { color: var(--green-text); padding-left: 4px; }

.sitemap-prov {
  margin-bottom: 12px;
  border: 1px solid var(--rule); border-radius: 10px;
  background: var(--paper);
}
.sitemap-prov summary {
  list-style: none; cursor: pointer;
  padding: 16px 20px;
  display: flex; gap: 14px; align-items: center;
  font-family: var(--f-display);
}
.sitemap-prov summary::-webkit-details-marker { display: none; }
.sitemap-prov summary::before {
  content: "▸"; color: var(--green-text); font-size: 14px;
  transition: transform .15s;
  display: inline-block;
}
.sitemap-prov[open] summary::before { transform: rotate(90deg); }
.sitemap-prov summary strong { font-size: 16px; flex: 1; color: var(--green-text); }
.sitemap-prov summary .prov-overview { font-size: 12px; color: var(--green); font-weight: 600; text-decoration: none; }
.sitemap-prov summary .prov-overview:hover { text-decoration: underline; }
.sitemap-prov summary .count { font-size: 12px; color: var(--muted); font-family: var(--f-mono); }
.sitemap-prov[open] .city-grid {
  padding: 0 20px 20px;
}

/* === Sitemap visual upgrade (SEO-first, visueel rijk) === */

/* Hero met stat-strip */
.sm-hero h1 em { color: var(--green-bright, var(--green)); font-style: normal; }
.sm-stats {
  display: flex; flex-wrap: wrap; gap: 14px;
  margin-top: 28px;
}
.sm-stat {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 12px;
  padding: 14px 22px;
  display: flex; flex-direction: column; align-items: center;
  min-width: 110px;
  transition: transform .15s, box-shadow .15s;
}
.sm-stat:hover { transform: translateY(-2px); box-shadow: 0 6px 18px rgba(0,0,0,0.06); }
.sm-stat strong {
  font-family: var(--f-display);
  font-size: 32px; font-weight: 800;
  color: var(--green-text);
  line-height: 1;
}
.sm-stat span {
  font-size: 11px; color: var(--muted);
  text-transform: uppercase; letter-spacing: 0.08em;
  margin-top: 4px; font-weight: 600;
}

/* Sticky search-toolbar */
.sm-toolbar-section { padding-top: 18px !important; padding-bottom: 0 !important; position: sticky; top: 70px; z-index: 50; background: var(--cream); border-bottom: 1px solid var(--rule); }
.sm-toolbar { padding: 4px 0 12px; }
.sm-search-label {
  display: flex; align-items: center; gap: 12px;
  background: var(--paper);
  border: 2px solid var(--rule);
  border-radius: 12px;
  padding: 12px 18px;
  transition: border-color .15s;
}
.sm-search-label:focus-within { border-color: var(--green); }
.sm-search-label svg { color: var(--green-text); flex-shrink: 0; }
.sm-search-label input {
  flex: 1; border: 0; outline: none; background: transparent;
  font-size: 15px; font-family: inherit; color: var(--ink);
}
.sm-search-count {
  font-size: 12px; color: var(--green-text);
  font-family: var(--f-mono); font-weight: 600;
  white-space: nowrap;
}

/* Spring-naar-provincie pill row */
.sm-jump {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 12px 0;
}
.sm-jump a {
  font-size: 12.5px; padding: 6px 14px;
  background: var(--paper); border: 1px solid var(--rule); border-radius: 18px;
  color: var(--ink); text-decoration: none;
  font-family: var(--f-display); font-weight: 600;
  transition: all .12s;
}
.sm-jump a:hover { background: var(--green); color: var(--green-text); border-color: var(--green); transform: translateY(-1px); }
.sm-jump a span { color: var(--muted); font-family: var(--f-mono); margin-left: 4px; font-weight: 400; }
.sm-jump a:hover span { color: var(--green-text); }

/* === Categorie-grid (FlexHero stijl) === */
.sm-cats-section { padding-top: 48px; padding-bottom: 16px; }
.sr-h2 { position: absolute; left: -9999px; }
.sm-cat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
}
.sm-cat {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 18px;
  padding: 28px 28px 24px;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  position: relative;
  overflow: hidden;
}
.sm-cat::before {
  content: ""; position: absolute; left: 0; top: 0; right: 0; height: 4px;
  background: var(--green);
  border-radius: 18px 18px 0 0;
  transition: height .2s ease;
}
.sm-cat:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 32px rgba(12, 38, 27, 0.10);
  border-color: var(--green);
}
.sm-cat:hover::before { height: 6px; }

.sm-cat header {
  display: grid;
  grid-template-columns: 48px 1fr auto;
  gap: 14px;
  align-items: center;
  padding-bottom: 18px;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--rule);
}
.sm-cat-icon {
  font-size: 24px; line-height: 1;
  width: 48px; height: 48px;
  background: var(--cream-2);
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s ease;
}
.sm-cat:hover .sm-cat-icon { background: var(--cream); }

.sm-cat header h3 {
  font-family: var(--f-display);
  font-size: 22px;
  margin: 0;
  color: var(--ink);
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 1.1;
}
.sm-cat header h3::after {
  content: ".";
  color: var(--green);
}

.sm-cat-num {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  font-size: 32px;
  color: var(--green-text);
  line-height: 1;
}

.sm-cat ul { list-style: none; padding: 0; margin: 0; }
.sm-cat li { padding: 0; }
.sm-cat li a {
  color: var(--ink);
  text-decoration: none;
  font-size: 15px;
  font-weight: 500;
  font-family: var(--f-display);
  display: flex; align-items: center;
  gap: 10px;
  padding: 9px 0;
  border-bottom: 1px solid transparent;
  transition: color .15s ease, padding-left .15s ease, border-color .15s ease;
}
.sm-cat li a::before {
  content: "→";
  color: var(--green-text);
  opacity: 0;
  transition: opacity .15s ease, transform .15s ease;
  transform: translateX(-4px);
  font-weight: 400;
}
.sm-cat li a:hover {
  color: var(--green-text);
  padding-left: 4px;
}
.sm-cat li a:hover::before {
  opacity: 1;
  transform: translateX(0);
}
.sm-flag { font-size: 18px; line-height: 1; }

/* Categorie-accenten — subtiel, FlexHero green dominant */
.sm-cat-main::before     { background: var(--green); }
.sm-cat-sectors::before  { background: linear-gradient(90deg, var(--green) 0%, #f59e0b 100%); }
.sm-cat-services::before { background: linear-gradient(90deg, var(--green) 0%, #3b82f6 100%); }
.sm-cat-conversion::before { background: linear-gradient(90deg, var(--green) 0%, #a855f7 100%); }
.sm-cat-company::before  { background: linear-gradient(90deg, var(--green) 0%, #14b8a6 100%); }
.sm-cat-langs::before    { background: linear-gradient(90deg, var(--green) 0%, #ef4444 100%); }
.sm-cat-legal::before    { background: linear-gradient(90deg, var(--green) 0%, #6b7280 100%); }
.sm-cat-xml::before      { background: linear-gradient(90deg, var(--green) 0%, #0ea5e9 100%); }

@media (max-width: 760px) {
  .sm-cat-grid { grid-template-columns: 1fr; gap: 14px; }
  .sm-cat { padding: 22px 22px 20px; }
  .sm-cat header h3 { font-size: 20px; }
  .sm-cat-num { font-size: 28px; }
}

/* Provincie-blokken met regio-color-coding */
.sm-geo-section { padding-top: 36px; }
.sm-prov {
  margin-bottom: 18px;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-left: 5px solid var(--green);
  border-radius: 12px;
  padding: 22px 26px;
  transition: box-shadow .15s, transform .15s;
}
.sm-prov:hover { box-shadow: 0 6px 18px rgba(0,0,0,0.05); }
.sm-prov.is-hidden { display: none; }
.sm-prov-randstad { border-left-color: #3b82f6; }
.sm-prov-zuid     { border-left-color: #22c55e; }
.sm-prov-oost     { border-left-color: #f59e0b; }
.sm-prov-noord    { border-left-color: #a855f7; }

.sm-prov-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  padding-bottom: 14px; margin-bottom: 16px;
  border-bottom: 1px dashed var(--rule);
  gap: 14px; flex-wrap: wrap;
}
.sm-region-tag {
  display: inline-block;
  font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.08em;
  font-family: var(--f-display); font-weight: 700;
  padding: 3px 10px; border-radius: 10px;
  background: var(--cream); color: var(--ink-2);
  margin-bottom: 6px;
}
.sm-prov-randstad .sm-region-tag { background: #dbeafe; color: #1e40af; }
.sm-prov-zuid     .sm-region-tag { background: #d1fae5; color: #065f46; }
.sm-prov-oost     .sm-region-tag { background: #fef3c7; color: #92400e; }
.sm-prov-noord    .sm-region-tag { background: #f3e8ff; color: #6b21a8; }

.sm-prov-head h3 {
  font-family: var(--f-display); font-size: 22px;
  color: var(--ink); margin: 0; font-weight: 700;
}
.sm-prov-head h3 a { color: var(--green-text); text-decoration: none; }
.sm-prov-head h3 a:hover { text-decoration: underline; }
.sm-prov-cta {
  font-size: 13px; color: var(--green-text); text-decoration: none;
  font-family: var(--f-display); font-weight: 700;
  padding: 8px 14px; border: 1px solid var(--green-ink); border-radius: 8px;
  transition: all .12s;
  white-space: nowrap;
}
.sm-prov-cta:hover { background: var(--green-ink); color: var(--cream); }
.sm-prov .city-grid a.is-hidden { display: none; }

/* Mobile */
@media (max-width: 760px) {
  .sm-stat { min-width: calc(50% - 10px); flex: 1 1 calc(50% - 10px); }
  .sm-toolbar-section { position: static; }
  .sm-prov { padding: 18px 16px; }
  .sm-prov-head { flex-direction: column; align-items: flex-start; }
}

/* === Sitemap FAQ block (AI-cite friendly) === */
.sm-faq-section { padding-top: 36px; }
.sm-faq { display: flex; flex-direction: column; gap: 8px; max-width: 880px; margin: 0 auto; }
.sm-faq-item {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-left: 4px solid var(--green);
  border-radius: 10px;
  padding: 0;
  transition: box-shadow .15s, border-color .15s;
}
.sm-faq-item:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.04); }
.sm-faq-item summary {
  list-style: none; cursor: pointer;
  padding: 18px 22px;
  display: flex; gap: 14px; align-items: center;
}
.sm-faq-item summary::-webkit-details-marker { display: none; }
.sm-faq-item summary::before {
  content: "+"; color: var(--green-text);
  font-family: var(--f-display); font-weight: 800; font-size: 22px;
  flex-shrink: 0; line-height: 1;
  transition: transform .2s;
}
.sm-faq-item[open] summary::before { transform: rotate(45deg); }
.sm-faq-item summary h3 {
  font-family: var(--f-display); font-size: 16px;
  margin: 0; color: var(--ink);
  font-weight: 700;
}
.sm-faq-item p {
  padding: 0 22px 20px 56px;
  margin: 0;
  font-size: 14.5px; color: var(--ink-2);
  line-height: 1.6;
}

/* === Sitemap SEO-optimized layout (legacy classes — bewaard) === */
.sm-jump {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 14px 18px;
  background: var(--cream);
  border: 1px solid var(--rule);
  border-radius: 10px;
  margin-bottom: 28px;
}
.sm-jump a {
  font-size: 12.5px;
  padding: 6px 12px;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 16px;
  color: var(--ink);
  text-decoration: none;
  font-family: var(--f-display);
  font-weight: 600;
  transition: all .12s;
}
.sm-jump a:hover { background: var(--green); color: var(--green-text); border-color: var(--green); }
.sm-jump a span { color: var(--muted); font-family: var(--f-mono); margin-left: 4px; font-weight: 400; }

.sitemap-grid.sm-services .sitemap-col ul { list-style: none; padding: 0; margin: 0; }
.sitemap-grid.sm-services .sitemap-col li { padding: 0; }
.sitemap-grid.sm-services .sitemap-col h2 {
  font-family: var(--f-display); font-size: 13px;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--green-text); margin: 0 0 12px;
  padding-bottom: 8px; border-bottom: 2px solid var(--green);
}

.sm-prov {
  margin-bottom: 28px;
  padding: 18px 22px;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 10px;
}
.sm-prov-head {
  display: flex; justify-content: space-between; align-items: baseline;
  padding-bottom: 12px;
  margin-bottom: 14px;
  border-bottom: 1px dashed var(--rule);
}
.sm-prov-head h3 {
  font-family: var(--f-display); font-size: 18px;
  color: var(--ink); margin: 0;
  font-weight: 700;
}
.sm-prov-head h3 a { color: var(--green-text); text-decoration: none; }
.sm-prov-head h3 a:hover { text-decoration: underline; }
.sm-prov .sm-count { font-size: 12px; color: var(--muted); font-family: var(--f-mono); }

/* === Legacy sitemap visual tree (kept for compat — niet meer gebruikt) === */
.sitemap-tree {
  margin: 32px 0;
  padding: 36px 28px;
  background: linear-gradient(180deg, var(--paper) 0%, var(--cream) 100%);
  border-radius: 16px;
  border: 1px solid var(--rule);
}
.sitemap-tree .st-root { display: flex; justify-content: center; margin-bottom: 24px; position: relative; }
.sitemap-tree .st-root::after {
  content: "";
  position: absolute;
  bottom: -24px;
  left: 50%;
  width: 2px;
  height: 24px;
  background: var(--green);
}
.sitemap-tree .st-node.st-home {
  background: var(--green-ink);
  color: var(--cream);
  padding: 16px 32px;
  border-radius: 12px;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.08);
}
.sitemap-tree .st-home .st-icon { font-size: 24px; }
.sitemap-tree .st-home a { color: var(--cream); text-decoration: none; font-family: var(--f-display); font-size: 18px; }
.sitemap-tree .st-home .st-sub { font-size: 11px; opacity: 0.7; font-family: var(--f-mono); }

.sitemap-tree .st-trunk {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
  margin-bottom: 28px;
  position: relative;
}
.sitemap-tree .st-trunk::before {
  content: "";
  position: absolute;
  top: -16px;
  left: 8%;
  right: 8%;
  height: 2px;
  background: var(--green);
}

.sitemap-tree .st-branch {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 10px;
  padding: 18px 16px;
  position: relative;
}
.sitemap-tree .st-branch::before {
  content: "";
  position: absolute;
  top: -16px;
  left: 50%;
  width: 2px;
  height: 16px;
  background: var(--green);
}
.sitemap-tree .st-branch-head {
  border-bottom: 1px dashed var(--rule);
  padding-bottom: 10px;
  margin-bottom: 10px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.sitemap-tree .st-branch-head .st-icon { font-size: 20px; line-height: 1; }
.sitemap-tree .st-branch-head strong { font-family: var(--f-display); font-size: 14px; color: var(--green-text); margin-top: 4px; }
.sitemap-tree .st-branch-head .st-sub { font-size: 11px; color: var(--muted); font-family: var(--f-mono); }
.sitemap-tree .st-branch ul { list-style: none; padding: 0; margin: 0; }
.sitemap-tree .st-branch li {
  font-size: 13px;
  padding: 5px 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.sitemap-tree .st-branch li a { color: var(--ink); text-decoration: none; font-weight: 600; transition: color .12s; }
.sitemap-tree .st-branch li a:hover { color: var(--green-text); }
.sitemap-tree .st-branch li .st-sub { font-size: 10.5px; color: var(--muted); }
.sitemap-tree .st-branch li .st-flow {
  font-size: 11px;
  color: var(--green-text);
  font-style: italic;
}

.sitemap-tree .st-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 12px;
  padding: 18px;
  background: var(--cream);
  border-radius: 10px;
}
.sitemap-tree .st-stat {
  text-align: center;
}
.sitemap-tree .st-stat strong {
  display: block;
  font-family: var(--f-display);
  font-size: 28px;
  font-weight: 800;
  color: var(--green-text);
  line-height: 1;
}
.sitemap-tree .st-stat span {
  display: block;
  font-size: 11px;
  color: var(--muted);
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

@media (max-width: 760px) {
  .sitemap-tree { padding: 22px 16px; }
  .sitemap-tree .st-trunk::before { display: none; }
  .sitemap-tree .st-branch::before { display: none; }
}

/* ============= LANGUAGE DROPDOWN (in header nav-cta-group) ============= */
.lang-dropdown { position: relative; font-family: var(--f-display); font-weight: 600; font-size: 13px; letter-spacing: 0.04em; display: inline-block; }
.lang-dropdown summary { list-style: none; cursor: pointer; padding: 0 14px; height: 40px; display: inline-flex; align-items: center; gap: 7px; color: var(--ink); user-select: none; border-radius: 999px; border: 1px solid var(--rule); background: var(--paper); transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease; line-height: 1; box-sizing: border-box; }
.lang-dropdown summary::-webkit-details-marker { display: none; }
.lang-dropdown summary::after { content: "▾"; font-size: 9px; margin-left: 2px; opacity: 0.55; transition: transform 0.18s ease; display: inline-block; }
.lang-dropdown[open] summary::after { transform: rotate(180deg); }
.lang-dropdown summary:hover { background: var(--cream); border-color: var(--green); color: var(--green-deep); }
.lang-dropdown[open] summary { background: var(--cream); border-color: var(--green); color: var(--green-deep); }
/* Menu sluit direct aan op summary zonder transparante gap (top:100% i.p.v. calc(100% + 6px)) */
.lang-dropdown .lang-menu { position: absolute; top: 100%; right: 0; margin-top: 4px; background: #fff; border: 1px solid var(--rule); border-radius: 12px; box-shadow: 0 16px 36px rgba(12,38,27,0.18); padding: 8px; min-width: 240px; z-index: 1000; display: flex; flex-direction: column; gap: 2px; animation: langMenuIn .14s ease-out; }
/* Bridge tussen summary en menu zodat cursor niet 'valt' — onder menu, geen interactie blokkering */
.lang-dropdown[open]::before { content: ""; position: absolute; top: 100%; left: 0; right: 0; height: 6px; pointer-events: none; }
@keyframes langMenuIn { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }
.lang-dropdown .lang-menu a { display: flex; align-items: center; gap: 12px; padding: 12px 14px; text-decoration: none; color: var(--ink-2); border-radius: 8px; font-weight: 500; font-size: 14px; letter-spacing: 0.02em; transition: background 0.12s ease, color 0.12s ease; min-height: 44px; box-sizing: border-box; }
.lang-dropdown .lang-menu a:hover { background: var(--cream); color: var(--green-text); }
.lang-dropdown .lang-menu a.current { background: var(--cream); color: var(--green-deep); font-weight: 700; }
.lang-dropdown .lang-menu a .code { font-family: var(--f-display); font-weight: 700; font-size: 12px; letter-spacing: 0.06em; color: var(--green-text); margin-left: auto; }
.lang-dropdown .lang-menu a.current .code { color: var(--green-deep); }
.lang-dropdown .flag { font-size: 16px; line-height: 1; flex-shrink: 0; }
@media (max-width: 480px) { .lang-dropdown .lang-menu { min-width: 170px; } }

/* ============= SISTER NETWORK (HR-groep zusterbedrijven) ============= */
.sister-network { padding: 64px 0 80px; background: var(--cream); }
.sister-network .wrap { max-width: 1080px; }
.sister-network h2 { font-family: var(--f-display); font-weight: 700; font-size: clamp(26px, 3.4vw, 38px); line-height: 1.15; color: var(--ink); margin: 0 0 14px; letter-spacing: -0.015em; }
.sister-network h2 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 300; color: var(--green-text); }
.sister-network .lead { font-size: 17px; line-height: 1.6; color: var(--ink-2); max-width: 720px; margin: 0 0 40px; }
.sister-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 18px; }
.sister-card { display: flex; flex-direction: column; padding: 28px 24px; background: var(--paper); border: 1px solid var(--rule); border-radius: 14px; text-decoration: none; color: var(--ink); position: relative; transition: border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease; }
.sister-card:hover { border-color: var(--green); transform: translateY(-3px); box-shadow: 0 16px 40px rgba(12,38,27,0.10); }
.sister-card .logo { display: flex; align-items: center; justify-content: center; height: 64px; margin-bottom: 18px; }
.sister-card .logo img { max-height: 100%; max-width: 80%; width: auto; height: auto; object-fit: contain; }
.sister-card h3 { font-family: var(--f-display); font-weight: 700; font-size: 17px; color: var(--ink); margin: 0 0 6px; letter-spacing: -0.01em; }
.sister-card .role { font-family: var(--f-display); font-weight: 600; font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--green-text); margin: 0 0 10px; }
.sister-card p { font-size: 13px; line-height: 1.55; color: var(--muted); margin: 0; flex: 1; }
.sister-card .badge-current { position: absolute; top: 14px; right: 14px; font-family: var(--f-display); font-weight: 700; font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; padding: 4px 8px; background: var(--green); color: var(--green-deep); border-radius: 4px; }
.sister-card.is-current { border-color: var(--green); background: var(--cream); }
.sister-card.sister-card-link { cursor: pointer; }
.sister-card .sister-link {
  display: inline-block;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px dashed var(--rule);
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 12px;
  color: var(--green-text);
  letter-spacing: 0.02em;
  transition: color 0.15s ease, padding-left 0.15s ease;
}
.sister-card.sister-card-link:hover .sister-link {
  color: var(--green-deep);
  padding-left: 4px;
}

/* ============= SEARCH AUTOSUGGEST DROPDOWN ============= */
.search-field { position: relative; }
.search-suggest { position: absolute; top: calc(100% + 6px); left: 0; right: 0; background: #fff; border: 1px solid var(--rule); border-radius: 12px; box-shadow: 0 12px 32px rgba(12,38,27,0.14); padding: 6px; max-height: 320px; overflow-y: auto; z-index: 200; display: none; }
.search-suggest[data-open="1"] { display: block; }
.search-suggest .item { display: block; width: 100%; text-align: left; padding: 10px 14px; background: transparent; border: none; border-radius: 8px; cursor: pointer; font-family: inherit; text-decoration: none; color: var(--ink); transition: background 0.12s ease; }
.search-suggest .item:hover, .search-suggest .item:focus-visible { background: var(--cream); outline: none; }
.search-suggest .item strong { display: block; font-family: var(--f-display); font-size: 14px; font-weight: 700; color: var(--ink); }
.search-suggest .item .sub { display: block; font-size: 12px; color: var(--muted); margin-top: 2px; letter-spacing: 0.01em; }
.search-suggest .empty { padding: 14px; color: var(--muted); font-size: 13px; text-align: center; }

/* Vacatures page: zoek-resultaat-banner */
.search-active-banner { background: var(--cream); border: 1px solid var(--rule); border-radius: 10px; padding: 14px 18px; margin-bottom: 20px; display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.search-active-banner .info { font-family: var(--f-display); font-weight: 600; font-size: 14px; color: var(--ink); }
.search-active-banner .info strong { color: var(--green-deep); }
.search-active-banner .clear { font-family: var(--f-display); font-weight: 600; font-size: 13px; color: var(--green-text); text-decoration: none; padding: 6px 12px; border-radius: 999px; border: 1px solid var(--rule); background: var(--paper); transition: background 0.15s ease, border-color 0.15s ease; cursor: pointer; }
.search-active-banner .clear:hover { background: var(--cream-2); border-color: var(--green); }
.vac-row.is-hidden { display: none !important; }

/* ============================================
   VACATURES — UPGRADED FILTER/SORT/CARD UX (S-tier)
============================================ */

/* Filter sidebar header */
.vac-filter-header {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 14px; margin-bottom: 18px;
  border-bottom: 1px solid var(--rule);
}
.vac-filter-title {
  font-family: var(--f-display); font-weight: 700; font-size: 15px;
  color: var(--green-deep); letter-spacing: -0.01em;
}
.vac-filter-clear-all {
  background: transparent; border: 0; cursor: pointer;
  font-family: var(--f-display); font-size: 12px; font-weight: 600;
  color: var(--green-deep); text-decoration: underline; padding: 0;
}
.vac-filter-clear-all:hover { color: var(--green-text); }
.vac-filter-group { margin-bottom: 22px; }
.vac-filter-group:last-child { margin-bottom: 0; }
.vac-filter-h4 {
  font-size: 12px; font-family: var(--f-display); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.07em;
  color: var(--green-text); margin: 0 0 10px;
}
.vac-filter-opts { display: flex; flex-direction: column; gap: 2px; }
.vac-filter-opt {
  display: flex; align-items: center; gap: 10px;
  font-size: 14px; color: var(--ink);
  padding: 6px 8px; cursor: pointer; user-select: none;
  border-radius: 8px; transition: background 0.12s ease;
}
.vac-filter-opt:hover { background: var(--cream); }
.vac-filter-opt.is-empty { opacity: 0.45; }
.vac-filter-opt-text { flex: 1; }
.vac-filter-opt-count {
  font-size: 11px; color: var(--muted);
  font-family: var(--f-display); font-weight: 600;
  background: var(--cream-2); padding: 2px 7px; border-radius: 999px;
  min-width: 22px; text-align: center;
}
.vac-filter-opt input[type="checkbox"] {
  width: 16px; height: 16px; accent-color: var(--green-deep);
  margin: 0; flex-shrink: 0;
}

/* Salary range slider (dual handle) */
.vac-salary-slider { position: relative; padding: 18px 4px 0; }
.vac-salary-track {
  position: relative; height: 4px; background: var(--cream-2);
  border-radius: 2px;
}
.vac-salary-fill {
  position: absolute; top: 0; bottom: 0;
  background: var(--green-deep); border-radius: 2px;
}
.vac-salary-range {
  position: absolute; left: 0; right: 0; top: 12px;
  width: 100%; height: 30px; margin: 0;
  -webkit-appearance: none; appearance: none;
  background: transparent; pointer-events: none;
}
.vac-salary-range::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--paper); border: 2px solid var(--green-deep);
  cursor: pointer; pointer-events: auto;
  box-shadow: 0 2px 6px rgba(12,38,27,0.18);
  transition: transform 0.12s ease;
}
.vac-salary-range::-webkit-slider-thumb:hover { transform: scale(1.15); }
.vac-salary-range::-moz-range-thumb {
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--paper); border: 2px solid var(--green-deep);
  cursor: pointer; pointer-events: auto;
  box-shadow: 0 2px 6px rgba(12,38,27,0.18);
}
.vac-salary-range--min { z-index: 1; }
.vac-salary-range--max { z-index: 2; }
.vac-salary-values {
  display: flex; justify-content: space-between;
  margin-top: 30px;
  font-family: var(--f-display); font-size: 12px; font-weight: 600;
  color: var(--green-deep);
}

/* Saved searches block */
.vac-saved-searches { border-top: 1px solid var(--rule); padding-top: 18px; }
.vac-saved-empty {
  font-size: 12px; color: var(--muted); margin: 0 0 10px;
}
.vac-saved-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 6px 0; gap: 8px;
}
.vac-saved-link {
  flex: 1; font-size: 13px; color: var(--ink); text-decoration: none;
  font-family: var(--f-display); font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.vac-saved-link:hover { color: var(--green-deep); }
.vac-saved-del {
  width: 22px; height: 22px; border: 0; border-radius: 50%;
  background: var(--cream-2); cursor: pointer; color: var(--muted);
  font-size: 16px; line-height: 1; padding: 0;
}
.vac-saved-del:hover { background: #fde2e2; color: #c33; }
.vac-saved-add {
  width: 100%; margin-top: 12px;
  background: var(--cream); border: 1px dashed var(--rule);
  border-radius: 10px; padding: 10px;
  font-family: var(--f-display); font-weight: 600; font-size: 13px;
  color: var(--green-deep); cursor: pointer;
  transition: all 0.15s ease;
}
.vac-saved-add:hover { border-color: var(--green-deep); background: var(--paper); }

/* Active filter chips */
.vac-active-chips {
  display: none; flex-wrap: wrap; gap: 8px; align-items: center;
  margin: -12px 0 24px;
}
.vac-active-chips.has-chips { display: flex; }
.vac-chips-label {
  font-family: var(--f-display); font-weight: 600; font-size: 12px;
  text-transform: uppercase; letter-spacing: 0.05em; color: var(--muted);
  margin-right: 4px;
}
.vac-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--green); color: var(--green-deep);
  border: 1px solid var(--green-deep);
  padding: 5px 12px; border-radius: 999px;
  font-family: var(--f-display); font-weight: 600; font-size: 12px;
  cursor: pointer; transition: all 0.12s ease;
}
.vac-chip:hover { background: var(--green-deep); color: var(--cream); }
.vac-chip-x { font-size: 14px; line-height: 1; }
.vac-chip-clear {
  background: transparent; color: var(--muted);
  border: 1px solid var(--rule); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.05em;
}
.vac-chip-clear:hover { background: var(--cream-2); color: var(--ink); border-color: var(--ink); }

/* Results header tools (sort + map + share + save-search) */
.vac-results .results-head {
  flex-wrap: wrap; gap: 14px; align-items: center;
}
.vac-results-tools {
  display: flex; gap: 8px; flex-wrap: wrap; align-items: center;
  flex: 1 1 100%; padding-top: 14px;
  border-top: 1px dashed var(--rule);
}
.vac-tool {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--paper); border: 1px solid var(--rule);
  padding: 7px 12px; border-radius: 999px;
  font-family: var(--f-display); font-weight: 600; font-size: 12px;
  color: var(--ink); cursor: pointer;
  transition: all 0.15s ease;
}
.vac-tool:hover { border-color: var(--green-deep); color: var(--green-deep); }
.vac-tool-primary {
  margin-left: auto;
  background: var(--green-deep); color: var(--cream); border-color: var(--green-deep);
}
.vac-tool-primary:hover { background: var(--green-ink); border-color: var(--green-text); color: var(--cream); }
.vac-tool svg { flex-shrink: 0; }
.vac-tool-mobile { display: none; }
.vac-mobile-count {
  background: var(--green-deep); color: var(--cream);
  font-size: 10px; min-width: 18px; height: 18px;
  padding: 0 5px; border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
}

/* Saved-jobs toggle in sort row */
.vac-saved-toggle {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--paper); border: 1px solid var(--rule);
  padding: 7px 12px; border-radius: 999px;
  font-family: var(--f-display); font-weight: 600; font-size: 12px;
  color: var(--ink); cursor: pointer;
  transition: all 0.15s ease;
  margin-right: 10px;
}
.vac-saved-toggle:hover { border-color: var(--green-deep); }
.vac-saved-toggle.is-active {
  background: var(--green); border-color: var(--green-deep); color: var(--green-deep);
}
.vac-saved-count {
  font-size: 10px; background: var(--cream-2); padding: 1px 6px;
  border-radius: 999px; min-width: 18px; text-align: center;
}
.vac-saved-toggle.is-active .vac-saved-count {
  background: var(--green-deep); color: var(--cream);
}

/* Upgraded vacancy cards */
.vac-list { display: flex; flex-direction: column; gap: 12px; }
.vac-list .vac-row {
  display: grid; grid-template-columns: 1fr;
  background: var(--paper); border: 1px solid var(--rule);
  border-radius: var(--radius); padding: 0;
  position: relative;
  transition: all 0.2s ease;
  animation: vacFadeIn 0.3s ease;
}
.vac-list .vac-row:hover {
  border-color: var(--green-deep);
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(12,38,27,0.08);
}
@keyframes vacFadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } }
.vac-row-main {
  display: grid; grid-template-columns: 1fr auto;
  gap: 24px; padding: 22px 26px 16px;
  text-decoration: none; color: inherit;
}
.vac-row-left { display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.vac-badges-row {
  display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
  margin-bottom: 2px;
}
.vac-badge {
  font-family: var(--f-display); font-size: 10px; font-weight: 700;
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 3px 9px; border-radius: 999px;
  display: inline-flex; align-items: center;
}
.vac-badge-new { background: var(--green); color: var(--green-deep); }
.vac-badge-urgent {
  background: #fff1ee; color: #c75431; border: 1px solid #f3d3c5;
  animation: urgentPulse 2s ease-in-out infinite;
}
@keyframes urgentPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(199, 84, 49, 0); }
  50% { box-shadow: 0 0 0 4px rgba(199, 84, 49, 0.12); }
}
.vac-badge-sector { background: var(--green); color: var(--green-deep); }
.vac-badge-std {
  background: var(--cream-2); color: var(--green-deep); border: 1px solid var(--rule);
}
.vac-row-title {
  font-size: 21px; line-height: 1.2; letter-spacing: -0.02em;
  font-weight: 700; font-family: var(--f-display);
  color: var(--green-deep); margin: 0;
}
.vac-row-meta {
  display: flex; flex-wrap: wrap; gap: 14px;
  font-size: 13px; color: var(--muted); margin-top: 4px;
}
.vac-row-meta-item {
  display: inline-flex; align-items: center; gap: 5px;
}
.vac-row-meta-item svg { opacity: 0.7; flex-shrink: 0; }
.vac-row-right {
  display: flex; flex-direction: column; align-items: flex-end;
  gap: 8px; text-align: right; min-width: 160px;
}
.vac-row-salary {
  font-family: var(--f-display); font-size: 17px; font-weight: 700;
  color: var(--green-deep); letter-spacing: -0.01em;
  white-space: nowrap;
}
.vac-row-salary-unit {
  display: block; font-size: 11px; color: var(--muted);
  font-weight: 500; letter-spacing: 0;
}

/* Mini salary bar */
.vac-salbar { width: 130px; max-width: 100%; padding-top: 2px; }
.vac-salbar-track {
  position: relative; height: 4px;
  background: linear-gradient(to right, #f0eee8, #d8d3c5);
  border-radius: 2px; overflow: hidden;
}
.vac-salbar-fill {
  position: absolute; top: 0; bottom: 0;
  background: linear-gradient(to right, var(--green-deep), var(--green-ink));
  border-radius: 2px;
}

.vac-row-actions { display: flex; align-items: center; gap: 8px; margin-top: 4px; }
.vac-row-arrow {
  width: 34px; height: 34px; border-radius: 50%;
  background: var(--cream-2); display: inline-flex;
  align-items: center; justify-content: center;
  color: var(--green-deep); transition: all 0.2s ease;
  font-size: 16px;
}
.vac-row:hover .vac-row-arrow {
  background: var(--green); transform: translateX(3px);
}

/* Quick-action buttons (save + whatsapp) */
.vac-row-quick {
  display: flex; gap: 6px;
  position: absolute; top: 14px; right: 14px;
  z-index: 2;
}
.vac-quick-btn {
  width: 34px; height: 34px; border-radius: 50%;
  border: 1px solid var(--rule); background: var(--paper);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all 0.15s ease;
  color: var(--muted); text-decoration: none;
}
.vac-quick-btn:hover { border-color: var(--green-deep); color: var(--green-deep); background: var(--cream); }
.vac-quick-save.is-saved { color: var(--green-deep); border-color: var(--green-deep); background: var(--green); }
.vac-quick-wa {
  color: #25d366; border-color: #c5ecd1; background: #f0faf2;
}
.vac-quick-wa:hover { color: #fff; background: #25d366; border-color: #25d366; }

/* Empty state */
.vac-empty-state {
  padding: 56px 32px; text-align: center;
  background: var(--paper);
  border: 1px dashed var(--rule); border-radius: 16px;
  color: var(--muted);
}
.vac-empty-icon {
  width: 72px; height: 72px; border-radius: 50%;
  background: var(--cream); color: var(--green-deep);
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 18px;
}
.vac-empty-title {
  display: block; color: var(--green-deep);
  font-family: var(--f-display); font-size: 22px; font-weight: 700;
  margin-bottom: 10px; letter-spacing: -0.01em;
}
.vac-empty-hint { font-size: 15px; max-width: 36ch; margin: 0 auto 24px; }
.vac-empty-suggestions {
  text-align: left; max-width: 480px; margin: 0 auto 28px;
  background: var(--cream); border-radius: 12px; padding: 18px;
}
.vac-empty-suggestions-label {
  font-family: var(--f-display); font-weight: 700; font-size: 13px;
  color: var(--green-deep); margin: 0 0 12px;
  text-transform: uppercase; letter-spacing: 0.04em;
}
.vac-empty-card {
  display: flex; justify-content: space-between; align-items: center;
  gap: 12px; padding: 12px 14px; background: var(--paper);
  border-radius: 8px; margin-bottom: 6px;
  text-decoration: none; color: inherit;
  transition: all 0.15s ease;
}
.vac-empty-card:last-child { margin-bottom: 0; }
.vac-empty-card:hover { background: var(--green); transform: translateX(3px); }
.vac-empty-card strong {
  display: block; color: var(--green-deep); font-family: var(--f-display);
  font-size: 14px; font-weight: 700;
}
.vac-empty-card span { font-size: 12px; color: var(--muted); white-space: nowrap; }
.vac-empty-cta {
  display: inline-block; padding: 12px 24px;
  background: var(--green-deep); color: var(--cream);
  border-radius: 999px; text-decoration: none;
  font-family: var(--f-display); font-weight: 600; font-size: 14px;
  transition: all 0.15s ease;
}
.vac-empty-cta:hover { background: var(--green-ink); transform: translateY(-1px); }

/* Save-search modal */
.vac-modal-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(12,38,27,0.6); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  animation: vacModalIn 0.18s ease;
}
@keyframes vacModalIn { from { opacity: 0; } to { opacity: 1; } }
.vac-modal {
  background: var(--paper); border-radius: 16px;
  padding: 32px; width: 100%; max-width: 440px;
  position: relative;
  box-shadow: 0 24px 64px rgba(0,0,0,0.25);
  animation: vacModalSlide 0.22s ease;
}
@keyframes vacModalSlide { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.vac-modal-close {
  position: absolute; top: 14px; right: 14px;
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--cream-2); border: 0; cursor: pointer;
  font-size: 20px; line-height: 1; color: var(--ink);
}
.vac-modal-close:hover { background: var(--cream); }
.vac-modal-title {
  font-family: var(--f-display); font-size: 20px; font-weight: 700;
  color: var(--green-deep); margin: 0 0 18px; letter-spacing: -0.01em;
}
.vac-modal-label {
  display: block; font-family: var(--f-display); font-weight: 600;
  font-size: 13px; color: var(--ink); margin-bottom: 14px;
}
.vac-modal-label input[type="text"], .vac-modal-label input[type="email"] {
  display: block; width: 100%; margin-top: 6px;
  padding: 10px 14px; border: 1px solid var(--rule);
  border-radius: 8px; font-family: inherit; font-size: 14px;
  background: var(--paper);
}
.vac-modal-label input:focus { outline: 2px solid var(--green-deep); outline-offset: 1px; }
.vac-modal-check {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--ink); cursor: pointer;
  margin-bottom: 16px; padding: 10px; background: var(--cream);
  border-radius: 8px;
}
.vac-modal-actions {
  display: flex; gap: 8px; justify-content: flex-end; margin-top: 20px;
}
.vac-modal-btn {
  padding: 10px 20px; border-radius: 999px; cursor: pointer;
  font-family: var(--f-display); font-weight: 600; font-size: 13px;
  border: 1px solid transparent; transition: all 0.15s ease;
}
.vac-modal-btn-secondary {
  background: transparent; color: var(--ink); border-color: var(--rule);
}
.vac-modal-btn-secondary:hover { background: var(--cream-2); }
.vac-modal-btn-primary {
  background: var(--green-deep); color: var(--cream);
}
.vac-modal-btn-primary:hover { background: var(--green-ink); }

/* Toast */
.vac-toast {
  position: fixed; bottom: 32px; left: 50%; transform: translateX(-50%) translateY(20px);
  background: var(--green-deep); color: var(--cream);
  padding: 12px 22px; border-radius: 999px;
  font-family: var(--f-display); font-weight: 600; font-size: 13px;
  box-shadow: 0 12px 32px rgba(12,38,27,0.25);
  opacity: 0; pointer-events: none; z-index: 9998;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.vac-toast.is-visible { opacity: 1; transform: translateX(-50%) translateY(0); }

/* Mobile drawer */
.vac-drawer-overlay {
  position: fixed; inset: 0; z-index: 998;
  background: rgba(12,38,27,0.5); backdrop-filter: blur(2px);
  opacity: 0; pointer-events: none;
  transition: opacity 0.2s ease;
}
.vac-drawer-overlay.is-visible { opacity: 1; pointer-events: auto; }

@media (max-width: 980px) {
  .vac-filters {
    position: fixed; top: 0; left: 0; bottom: 0;
    width: min(360px, 92vw); max-width: 92vw;
    z-index: 999;
    border-radius: 0; border: 0; border-right: 1px solid var(--rule);
    transform: translateX(-100%); transition: transform 0.25s ease;
    overflow-y: auto;
    padding: 22px;
  }
  .vac-filters.vac-filters-open { transform: translateX(0); }
  .vac-tool-mobile { display: inline-flex; }
}

/* Vacancies legacy compatibility (existing CSS uses .filter-group) */
.vac-filters .filter-group { margin-bottom: 22px; }
.vac-filters .filter-group:last-child { margin-bottom: 0; }

@media (max-width: 720px) {
  .vac-row-main { grid-template-columns: 1fr; padding: 18px 20px 14px; }
  .vac-row-right { align-items: flex-start; min-width: 0; text-align: left; flex-direction: row; justify-content: space-between; width: 100%; }
  .vac-row-quick { top: 12px; right: 12px; }
  .vac-row-title { font-size: 18px; padding-right: 90px; }
  .vac-salbar { width: 100px; }
  .vac-results .results-head { flex-direction: column; align-items: stretch; gap: 12px; }
  .vac-results-tools { padding-top: 0; border-top: 0; }
  .vac-saved-toggle, .vac-tool { font-size: 11px; padding: 6px 10px; }
  .vac-tool-primary { margin-left: 0; flex: 1; justify-content: center; }
}

/* ============================================
   MOBIEL HAMBURGER-MENU
============================================ */
.nav-burger {
  display: none;
  background: transparent;
  border: 1.5px solid var(--rule);
  border-radius: 8px;
  width: 42px; height: 42px;
  padding: 0;
  cursor: pointer;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  transition: border-color .15s, background .15s;
  margin-left: 8px;
}
.nav-burger:hover { border-color: var(--green-deep); background: var(--cream-2); }
.nav-burger span {
  display: block;
  width: 18px; height: 2px;
  background: var(--ink);
  border-radius: 2px;
  transition: transform .25s ease, opacity .15s ease;
  transform-origin: center;
}
.nav.nav-open .nav-burger span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.nav.nav-open .nav-burger span:nth-child(2) {
  opacity: 0;
}
.nav.nav-open .nav-burger span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* body.nav-locked rules → zie premium drawer-polish sectie verderop
   (position:fixed + scroll-position preserve via JS, voorkomt scroll-jump). */

@media (max-width: 980px) {
  .nav-burger { display: inline-flex; }

  .nav-links {
    position: fixed;
    top: var(--header-h, 72px);
    left: 0; right: 0; bottom: 0;
    background: var(--paper);
    flex-direction: column !important;
    align-items: stretch !important;
    padding: 24px 22px 80px;
    gap: 4px !important;
    overflow-y: auto;
    transform: translateX(100%);
    transition: transform .28s ease;
    border-top: 1px solid var(--rule);
    z-index: 90;
    box-shadow: -8px 0 32px rgba(0,0,0,0.08);
  }
  .nav.nav-open .nav-links {
    transform: translateX(0);
  }
  .nav-links .item {
    width: 100%;
    border-bottom: 1px solid var(--rule);
  }
  .nav-links .item > a {
    display: block;
    padding: 16px 4px;
    font-size: 16px;
    font-family: var(--f-display);
    font-weight: 700;
    color: var(--ink);
  }
  .nav-links .item .mega {
    position: static !important;
    box-shadow: none !important;
    background: transparent !important;
    padding: 0 0 14px 8px !important;
    grid-template-columns: 1fr !important;
    border-radius: 0 !important;
    border: 0 !important;
    transform: none !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    visibility: visible !important;
    display: block !important;
  }
  .nav-links .item .mega-col h3, .nav-links .item .mega-col h5 {
    font-size: 11px;
    color: var(--green-text);
    margin: 8px 0 4px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
  }
  .nav-links .item .mega a {
    padding: 8px 0;
    font-size: 14px;
    font-weight: 500;
    border: 0;
    display: block;
    color: var(--ink-2);
  }

  /* CTA-group: hide niet-essentiële items op mobiel */
  .nav-cta-group .icon-btn { display: none; }
  .nav-cta-group .lang-dropdown { display: none; }
  .nav-cta-group .nav-cta {
    font-size: 12px;
    padding: 8px 14px;
  }
  .nav-cta-group .nav-cta span { display: none; }
}

@media (max-width: 480px) {
  .nav-cta-group .nav-cta { display: none; }  /* op heel kleine schermen alleen logo + hamburger */
}

/* ============================================================
   MOBILE-FRIENDLY: iOS + Android UX upgrades
============================================================ */

/* iOS: voorkom auto-zoom bij input-focus (font-size moet >= 16px zijn) */
@media (max-width: 980px) {
  input[type="text"],
  input[type="email"],
  input[type="tel"],
  input[type="search"],
  input[type="number"],
  input[type="password"],
  input[type="date"],
  input[type="time"],
  input[type="url"],
  textarea,
  select {
    font-size: 16px !important;
  }
  /* Touch: tekstvelden minstens 48px hoog (geen checkboxes/radios) */
  input[type="text"],
  input[type="email"],
  input[type="tel"],
  input[type="search"],
  input[type="number"],
  input[type="password"],
  input[type="date"],
  input[type="time"],
  input[type="url"],
  select {
    min-height: 48px;
  }
}

/* iOS: tap-highlight smoother */
* {
  -webkit-tap-highlight-color: rgba(136, 217, 50, 0.18);
}
a, button, .btn-primary, .btn-secondary, .btn-outline,
.nav-burger, .icon-btn, .nav-cta, .lang-dropdown summary {
  -webkit-tap-highlight-color: rgba(136, 217, 50, 0.25);
  touch-action: manipulation;  /* schakelt 300ms-tap-delay uit */
}

/* iPhone notch / home-indicator: safe-area-insets respecteren */
@supports (padding: env(safe-area-inset-top)) {
  body {
    padding-top: env(safe-area-inset-top);
    padding-bottom: env(safe-area-inset-bottom);
  }
  .nav, header.nav {
    padding-top: env(safe-area-inset-top);
  }
}

/* iOS: smooth scrolling overal */
html { -webkit-overflow-scrolling: touch; scroll-behavior: smooth; }

/* Android/iOS: minimale 48x48 touch-target voor klikbare elementen */
@media (max-width: 980px) {
  .nav-burger { width: 48px; height: 48px; }
  .icon-btn { min-width: 44px; min-height: 44px; padding: 10px; }
  .btn-primary, .btn-secondary, .btn-outline { min-height: 48px; padding: 14px 22px; }
  .nav-cta { min-height: 44px; }
  .footer a, .foot-col a { padding: 11px 0; min-height: 44px; display: inline-flex; align-items: center; }
  .nav-links .item > a { min-height: 52px; display: flex !important; align-items: center; }

  /* Alle vacaturekaarten / job-row klikbaar gebied vergroten */
  .job-row, .vac-row, .job-card { padding: 18px 16px !important; }

  /* Filter-pills makkelijker te tappen */
  .pill, .lang-btn { min-height: 44px; padding: 11px 16px; display: inline-flex; align-items: center; }

  /* Social-icons + legal fine-print volwaardig tap-target (STAP 8.3) */
  .social-row a { width: 44px; height: 44px; }
  .foot-legal a { min-height: 44px; padding: 11px 0; display: inline-flex; align-items: center; }
}

/* Hamburger menu: full-screen overlay + grotere typografie */
@media (max-width: 980px) {
  .nav-links {
    top: 0 !important;
    padding-top: calc(72px + env(safe-area-inset-top, 0px)) !important;
    padding-bottom: 100px !important;
    gap: 0 !important;
    background: var(--cream) !important;
  }
  .nav-links .item {
    border-bottom: 1px solid var(--rule);
    padding: 0;
  }
  .nav-links .item > a {
    font-size: 18px !important;
    padding: 18px 8px !important;
    color: var(--ink);
  }
  .nav-links .item.has-mega > a::after {
    content: "▾";
    margin-left: auto;
    color: var(--green-text);
    font-size: 14px;
  }
}

/* Selectable text zonder iOS callout (voor decoratieve elementen) */
.nav, .nav-burger {
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
}

/* iOS Safari: zoek-input cursor-bug fix */
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}


/* ============================================================
   CONTACT V3 · editorial, single-accent, premium-minimalist
   Inspiratie: Continu · Jex · Apple
============================================================ */

/* ROUTE-ROW · editorial rij met nummer, body, action */
.route-row {
  display: grid;
  grid-template-columns: 80px 1fr auto;
  gap: 48px;
  align-items: start;
  padding: 56px 0;
  border-bottom: 1px solid var(--rule, #E5DCCD);
  transition: background .25s ease;
}
.route-row:last-child { border-bottom: none; }
.route-row:hover { background: var(--cream, #FCF7F2); margin: 0 -32px; padding-left: 32px; padding-right: 32px; }

.route-row .rr-num {
  font-family: 'Poppins', sans-serif;
  font-size: 48px;
  font-weight: 300;
  color: var(--green-text);
  line-height: 1;
  letter-spacing: -0.02em;
  font-feature-settings: "tnum";
  opacity: 0.5;
  transition: opacity .25s, color .25s;
}
.route-row:hover .rr-num { opacity: 1; }

.route-row .rr-body { max-width: 580px; }
.route-row .rr-tag {
  font-family: 'Poppins', sans-serif;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--green-text);
  margin-bottom: 12px;
}
.route-row .rr-title {
  font-family: 'Poppins', sans-serif;
  font-size: clamp(28px, 3.2vw, 40px);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--green-deep, #0C261B);
  margin: 0 0 14px;
  line-height: 1.05;
}
.route-row .rr-desc {
  font-size: 17px;
  line-height: 1.55;
  color: var(--ink-2, #2A332C);
  margin: 0 0 20px;
}
.route-row .rr-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  color: var(--ink-2, #2A332C);
  font-family: 'Poppins', sans-serif;
  font-weight: 500;
  flex-wrap: wrap;
}
.route-row .rr-meta a {
  color: var(--green-deep, #0C261B);
  text-decoration: none;
  border-bottom: 1px solid var(--rule, #E5DCCD);
  padding-bottom: 1px;
  transition: border-color .15s;
}
.route-row .rr-meta a:hover { border-color: var(--green-text); }
.route-row .rr-meta .rr-dot { color: var(--muted, #8A8478); }

.route-row .rr-actions {
  align-self: center;
  flex-shrink: 0;
}
.route-row .rr-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 24px;
  background: var(--green-deep, #0C261B);
  color: var(--cream, #FCF7F2);
  text-decoration: none;
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  font-size: 14px;
  border-radius: 999px;
  transition: background .15s, transform .15s;
  white-space: nowrap;
}
.route-row .rr-cta:hover {
  background: var(--green-ink, #6FB827);
  transform: translateX(2px);
}
.route-row .rr-cta span { transition: transform .15s; }
.route-row .rr-cta:hover span { transform: translateX(3px); }

@media (max-width: 880px) {
  .route-row { grid-template-columns: 56px 1fr; gap: 24px; padding: 40px 0; }
  .route-row .rr-num { font-size: 32px; }
  .route-row .rr-actions { grid-column: 1 / -1; margin-top: 8px; }
  .route-row:hover { margin: 0; padding-left: 0; padding-right: 0; background: transparent; }
}

/* CONTACT-FORM V3 · minimalistisch */
.contact-form-v3 {
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.contact-form-v3 .cf-row { display: flex; flex-direction: column; gap: 10px; }
.contact-form-v3 .cf-split { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
@media (max-width: 600px) { .contact-form-v3 .cf-split { grid-template-columns: 1fr; gap: 20px; } }

.contact-form-v3 .cf-label {
  font-family: 'Poppins', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-2, #2A332C);
}
.contact-form-v3 .cf-opt {
  font-family: 'Open Sans', sans-serif;
  font-size: 11px;
  text-transform: lowercase;
  letter-spacing: 0;
  color: var(--muted, #8A8478);
  font-weight: 400;
}

.contact-form-v3 input[type="text"],
.contact-form-v3 input[type="email"],
.contact-form-v3 input[type="tel"],
.contact-form-v3 textarea {
  width: 100%;
  padding: 16px 0;
  border: 0;
  border-bottom: 1.5px solid var(--rule, #E5DCCD);
  background: transparent;
  font-family: 'Open Sans', system-ui, sans-serif;
  font-size: 17px;
  color: var(--green-deep, #0C261B);
  outline: none;
  transition: border-color .15s;
  border-radius: 0;
}
.contact-form-v3 input:focus,
.contact-form-v3 textarea:focus {
  border-bottom-color: var(--green-text);
}
.contact-form-v3 textarea {
  resize: vertical;
  min-height: 100px;
  padding-top: 12px;
}
.contact-form-v3 .cf-row.error input,
.contact-form-v3 .cf-row.error textarea,
.contact-form-v3 .cf-row > div.error input,
.contact-form-v3 .cf-row > div.error textarea {
  border-bottom-color: #dc2626;
}

.contact-form-v3 .cf-pills {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.contact-form-v3 .cf-pills label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 18px;
  border: 1.5px solid var(--rule, #E5DCCD);
  border-radius: 999px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all .15s ease;
  color: var(--ink-2, #2A332C);
  font-family: 'Poppins', sans-serif;
}
.contact-form-v3 .cf-pills input { display: none; }
.contact-form-v3 .cf-pills label:has(input:checked) {
  background: var(--green-deep, #0C261B);
  color: var(--cream, #FCF7F2);
  border-color: var(--green-deep, #0C261B);
}

/* contact.html gebruikt losse <label class="cf-pill"> (zonder .contact-form-v3-wrapper),
   die had GEEN kleurregel -> erfde crème -> onzichtbaar op witte form. Eigen leesbare styling: */
.cf-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 18px;
  border: 1.5px solid var(--rule);
  border-radius: 999px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all .15s ease;
  color: var(--ink-2);
  background: var(--paper);
  font-family: var(--f-display);
}
.cf-pill input { display: none; }
.cf-pill:has(input:checked) {
  background: var(--green-deep);
  color: var(--cream);
  border-color: var(--green-deep);
}

.contact-form-v3 .cf-consent {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 13px;
  color: var(--ink-2, #2A332C);
  line-height: 1.5;
  margin-top: 4px;
}
.contact-form-v3 .cf-consent input {
  margin-top: 3px;
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  accent-color: var(--green-deep, #0C261B);
}
.contact-form-v3 .cf-consent a {
  color: var(--green-deep, #0C261B);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.contact-form-v3 .cf-submit {
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 32px;
  background: var(--green-deep, #0C261B);
  color: var(--cream, #FCF7F2);
  border: 0;
  border-radius: 999px;
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  font-size: 15px;
  cursor: pointer;
  transition: background .15s, transform .15s;
  margin-top: 8px;
}
.contact-form-v3 .cf-submit:hover {
  background: var(--green-ink, #6FB827);
}
.contact-form-v3 .cf-submit span { transition: transform .15s; }
.contact-form-v3 .cf-submit:hover span { transform: translateX(3px); }

/* OFFICE BLOCK · editorial text, no card */
.office-block .ob-label {
  font-family: 'Poppins', sans-serif;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--green-text);
  margin-bottom: 16px;
}
.office-block .ob-city {
  font-family: 'Poppins', sans-serif;
  font-size: clamp(32px, 4vw, 44px);
  line-height: 1;
  letter-spacing: -0.025em;
  color: var(--green-deep, #0C261B);
  margin: 0 0 24px;
  font-weight: 700;
}
.office-block .ob-addr {
  font-style: normal;
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink-2, #2A332C);
  margin: 0 0 24px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--rule, #E5DCCD);
}
.office-block .ob-meta {
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-size: 15px;
  color: var(--ink-2, #2A332C);
}
.office-block .ob-meta a {
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  color: var(--green-deep, #0C261B);
  text-decoration: none;
  border-bottom: 1.5px solid var(--green-deep, #0C261B);
  padding-bottom: 1px;
  display: inline-block;
  width: fit-content;
  transition: color .15s, border-color .15s;
}
.office-block .ob-meta a:hover { color: var(--green-text); border-color: var(--green-text); }
.office-block .ob-meta span { color: var(--muted, #8A8478); font-size: 14px; }

@media (max-width: 760px) {
  /* Office cols stacken op mobiel */
  section[style*="grid-template-columns:1fr 1fr"] { grid-template-columns: 1fr !important; gap: 48px !important; }
}

/* Legacy CONTACT V2 (deprecated, niet meer gebruikt) */
.mail-card, .office-card-dark, .route-card { /* kept for compat, gegoten in nieuwe stijl indien nog gebruikt */ }
.route-card {
  background: var(--paper, #FFFFFF);
  border: 1px solid var(--rule, #E5DCCD);
  border-radius: 16px;
  padding: 28px 28px 24px;
  display: flex;
  flex-direction: column;
  transition: all .15s ease;
}
.route-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(12, 38, 27, 0.10);
}
.route-card .rc-top {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 16px;
}
.route-card .rc-ico {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 30px;
  flex-shrink: 0;
}
.route-card.route-sales      .rc-ico { background: linear-gradient(135deg, #d1fae5, #88D932); }
.route-card.route-backoffice .rc-ico { background: linear-gradient(135deg, #fef3c7, #fbbf24); }
.route-card.route-recruitment .rc-ico { background: linear-gradient(135deg, #dbeafe, #60a5fa); }

.route-card .rc-tag {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--green-text);
}
.route-card h3 {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--green-deep, #0C261B);
  margin: 0 0 8px;
}
.route-card p {
  font-size: 14px;
  line-height: 1.55;
  color: var(--ink-2, #2A332C);
  margin: 0 0 14px;
  min-height: 64px;
}
.route-card .rc-email {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 13px;
  font-weight: 600;
  color: var(--green-text);
  text-decoration: none;
  word-break: break-all;
  margin-bottom: 22px;
  display: block;
}
.route-card .rc-email:hover { color: var(--green-deep, #0C261B); text-decoration: underline; }

.route-card .rc-actions {
  display: flex;
  gap: 8px;
  margin-top: auto;
  align-items: stretch;
}
.route-card .rc-actions .btn-primary {
  flex: 1;
  font-size: 13px;
  padding: 12px 16px;
}
.route-card .rc-wa {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  background: #25D366;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  text-decoration: none;
  flex-shrink: 0;
  transition: transform .12s;
}
.route-card .rc-wa:hover { transform: scale(1.05); }

/* Office cards op dark bg */
.office-card-dark {
  display: flex;
  gap: 18px;
  padding: 24px 26px;
  background: rgba(244, 236, 225, 0.05);
  border: 1px solid rgba(244, 236, 225, 0.15);
  border-radius: 14px;
  align-items: flex-start;
}
.office-card-dark .ocd-flag {
  font-size: 40px;
  line-height: 1;
  flex-shrink: 0;
}
.office-card-dark .ocd-tag {
  display: inline-block;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--green, #88D932);
  margin-bottom: 6px;
}
.office-card-dark h3 {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 22px;
  font-weight: 700;
  color: var(--cream, #FCF7F2);
  margin: 0 0 8px;
  letter-spacing: -0.01em;
}
.office-card-dark p {
  font-size: 13px;
  color: var(--cream, #FCF7F2);
  opacity: 0.78;
  margin: 0 0 8px;
  line-height: 1.5;
}
.office-card-dark a {
  display: block;
  color: var(--green, #88D932);
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  margin-bottom: 6px;
}
.office-card-dark a:hover { text-decoration: underline; }
.office-card-dark .ocd-hours {
  display: block;
  font-size: 12px;
  color: var(--cream, #FCF7F2);
  opacity: 0.55;
}

/* Pill-radio */
.pill-radio {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border: 1px solid var(--rule, #E5DCCD);
  border-radius: 999px;
  font-size: 13px;
  cursor: pointer;
  transition: all .15s ease;
  background: var(--cream, #FCF7F2);
}
.pill-radio input { accent-color: var(--green-deep, #0C261B); }
.pill-radio:has(input:checked) {
  background: var(--green-deep, #0C261B);
  color: var(--green, #88D932);
  border-color: var(--green-deep, #0C261B);
}

@media (max-width: 760px) {
  .route-card { padding: 22px; }
  .route-card p { min-height: 0; }
  .office-card-dark { padding: 18px; flex-direction: column; gap: 10px; }
}

/* ============================================================
   CONTACT V3 · premium polish (mei 2026)
   - Hero met trust-strip
   - Featured route-card met pin-badge + SVG-icons
   - Form 2-col met "wat gebeurt er na verzending" sidebar
============================================================ */
/* ============================================================
   ED-HERO — EDITORIAL hero (S-tier voor werkwijze/over-ons/contact)
   ------------------------------------------------------------
   Zwaardere visuele aanwezigheid dan ct-hero. Two-column layout
   met massive editorial typography + animated process-visual.
============================================================ */
.ed-hero {
  background:
    radial-gradient(ellipse 1200px 800px at 92% 8%, rgba(136,217,50,0.18), transparent 55%),
    radial-gradient(ellipse 900px 600px at 5% 100%, rgba(136,217,50,0.10), transparent 60%),
    radial-gradient(ellipse 1100px 700px at 50% 50%, rgba(0,0,0,0.25), transparent 70%),
    linear-gradient(135deg, #04140A 0%, var(--green-deep, #0C261B) 50%, #143A28 100%);
  color: var(--cream, #FCF7F2);
  padding: clamp(120px, 16vw, 200px) 0 clamp(60px, 8vw, 96px);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.ed-hero-grain {
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 240 240' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.05 0 0 0 0 0.13 0 0 0 0 0.09 0 0 0 0.5 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity: 0.45;
  pointer-events: none;
  mix-blend-mode: overlay;
  z-index: 0;
}
.ed-hero-glow {
  position: absolute;
  top: -120px; right: -200px;
  width: 800px; height: 800px;
  background: radial-gradient(circle at center, rgba(136,217,50,0.22), transparent 60%);
  pointer-events: none;
  z-index: 0;
  filter: blur(40px);
}
.ed-hero > .wrap { position: relative; z-index: 1; }
.ed-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  gap: clamp(40px, 6vw, 96px);
  align-items: center;
  margin-bottom: clamp(56px, 8vw, 88px);
}
@media (max-width: 980px) {
  .ed-hero-inner { grid-template-columns: 1fr; gap: 48px; }
}
.ed-hero-copy { min-width: 0; }
.ed-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--green, #88D932);
  margin-bottom: 32px;
}
.ed-eyebrow-line {
  width: 32px;
  height: 2px;
  background: var(--green, #88D932);
  display: inline-block;
}
.ed-hero-title {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: clamp(52px, 9vw, 128px);
  line-height: 0.92;
  letter-spacing: -0.045em;
  color: var(--cream, #FCF7F2);
  margin: 0 0 32px;
  font-weight: 700;
  text-wrap: balance;
}
.ed-hero-title em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  color: var(--green, #88D932);
  letter-spacing: -0.035em;
}
.ed-hero-lead {
  font-size: clamp(18px, 1.5vw, 22px);
  line-height: 1.5;
  max-width: 56ch;
  color: var(--cream, #FCF7F2);
  opacity: 0.88;
  margin: 0 0 14px;
  font-weight: 400;
}
.ed-hero-claims {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  font-size: clamp(16px, 1.3vw, 19px);
  line-height: 1.45;
  color: var(--green, #88D932);
  margin: 0 0 40px;
  max-width: 50ch;
}
.ed-hero-ctas {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.ed-cta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 16px 26px;
  border-radius: 999px;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-weight: 600;
  font-size: 15px;
  text-decoration: none;
  transition: transform .18s cubic-bezier(.34,1.56,.64,1), box-shadow .2s ease, background .2s ease;
  letter-spacing: -0.005em;
  border: 1px solid transparent;
}
.ed-cta:hover { transform: translateY(-2px); }
.ed-cta-primary {
  background: var(--green, #88D932);
  color: var(--green-deep, #0C261B);
  box-shadow: 0 8px 24px rgba(136, 217, 50, 0.28), 0 2px 6px rgba(136, 217, 50, 0.18);
}
.ed-cta-primary:hover {
  background: var(--green-bright, #9CFF36);
  box-shadow: 0 12px 32px rgba(136, 217, 50, 0.40), 0 4px 12px rgba(136, 217, 50, 0.22);
}
.ed-cta-ghost {
  color: var(--cream, #FCF7F2);
  border-color: rgba(252, 247, 242, 0.32);
}
.ed-cta-ghost:hover { background: rgba(252, 247, 242, 0.08); border-color: rgba(252, 247, 242, 0.55); }

/* Visual side: process pipeline (vertical timeline) */
.ed-hero-visual {
  position: relative;
  min-width: 0;
}
.ed-pipeline {
  position: relative;
  padding: 24px 0;
  background: rgba(252, 247, 242, 0.04);
  border: 1px solid rgba(252, 247, 242, 0.10);
  border-radius: 20px;
  backdrop-filter: blur(20px) saturate(1.5);
  -webkit-backdrop-filter: blur(20px) saturate(1.5);
  box-shadow: 0 24px 60px rgba(0,0,0,0.30);
}
.ed-pipeline-line {
  position: absolute;
  left: 39px; top: 36px; bottom: 36px;
  width: 2px;
  background: linear-gradient(to bottom,
    rgba(136, 217, 50, 0.50) 0%,
    rgba(136, 217, 50, 0.30) 50%,
    rgba(136, 217, 50, 0.50) 100%);
}
.ed-pipeline-step {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 14px 28px 14px 24px;
  position: relative;
  z-index: 1;
}
.ed-pipeline-dot {
  width: 32px; height: 32px;
  border-radius: 50%;
  background:
    radial-gradient(circle, var(--green-deep, #0C261B) 0%, var(--green-deep, #0C261B) 32%, transparent 36%),
    linear-gradient(135deg, var(--green, #88D932) 0%, #6FBF24 100%);
  flex-shrink: 0;
  position: relative;
  box-shadow: 0 2px 8px rgba(136, 217, 50, 0.30);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.ed-pipeline-step::before {
  content: attr(data-step);
  position: absolute;
  left: 24px; top: 50%;
  transform: translateY(-50%);
  width: 32px;
  text-align: center;
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-size: 13px;
  font-weight: 500;
  color: var(--green-deep, #0C261B);
  z-index: 2;
  pointer-events: none;
}
.ed-pipeline-label {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.ed-pipeline-label strong {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 16px;
  font-weight: 700;
  color: var(--cream, #FCF7F2);
  letter-spacing: -0.01em;
}
.ed-pipeline-label small {
  font-size: 12.5px;
  color: rgba(252, 247, 242, 0.62);
  font-weight: 500;
}

/* Stats-row onder hero */
.ed-stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(24px, 3vw, 56px);
  padding: clamp(32px, 4vw, 48px) 0 0;
  border-top: 1px solid rgba(252, 247, 242, 0.14);
}
@media (max-width: 880px) { .ed-stats-row { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .ed-stats-row { grid-template-columns: 1fr; } }
.ed-stat-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
}
.ed-stat-chart {
  width: 60px; height: 60px;
}
.ed-stat-chart svg { width: 100%; height: 100%; display: block; }
.ed-stat-num {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: clamp(40px, 5vw, 64px);
  font-weight: 700;
  line-height: 1;
  color: var(--cream, #FCF7F2);
  letter-spacing: -0.04em;
}
.ed-stat-num em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  color: var(--green, #88D932);
}
.ed-stat-lbl {
  font-size: 13.5px;
  line-height: 1.4;
  color: rgba(252, 247, 242, 0.74);
  font-weight: 500;
}

/* ============================================================
   ED-INTRO — Editorial intro met dropcap
============================================================ */
.ed-intro {
  background: var(--cream, #FCF7F2);
  padding: clamp(80px, 10vw, 128px) 0;
}
.ed-intro-inner {
  max-width: 760px;
  margin: 0 auto;
  text-align: left;
}
.ed-intro-label {
  display: inline-block;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--green-text);
  margin-bottom: 24px;
}
.ed-intro-body {
  font-size: clamp(20px, 1.7vw, 26px);
  line-height: 1.45;
  color: var(--green-deep, #0C261B);
  font-weight: 400;
  letter-spacing: -0.015em;
  margin: 0 0 32px;
  text-wrap: pretty;
}
/* Semantic dropcap via ::first-letter — D blijft semantically deel van "De" */
.ed-has-dropcap::first-letter {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  font-size: 4.5em;
  line-height: 0.85;
  float: left;
  padding: 8px 14px 0 0;
  margin-left: -2px;
  color: var(--green-text);
  letter-spacing: -0.08em;
}
/* Backward-compat voor oude .ed-dropcap span (mocht nog ergens staan) */
.ed-dropcap {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  font-size: 4.5em;
  line-height: 0.85;
  float: left;
  margin: 8px 14px 0 -2px;
  color: var(--green-text);
  letter-spacing: -0.08em;
}
.ed-intro-meta {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 12px 20px;
  background: rgba(136, 217, 50, 0.08);
  border-radius: 999px;
  font-size: 13px;
  color: var(--ink-2, #2A2A28);
  font-weight: 500;
}
.ed-intro-meta strong { color: var(--green-deep, #0C261B); font-weight: 700; }
.ed-intro-meta a { color: var(--green-deep, #0C261B); font-weight: 700; text-decoration: underline; text-decoration-color: rgba(136, 217, 50, 0.5); text-underline-offset: 3px; }
.ed-intro-dot {
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--green-ink, #6FB827);
  opacity: 0.5;
}

/* ============================================================
   CT-HERO — premium page-hero (zelfde caliber als homepage .hero)
   ------------------------------------------------------------
   Gebruikt op werkwijze.html, over-ons.html, contact.html.
   Match met homepage:
     - Larger padding (140px top → ademende ruimte)
     - 3-stop background gradient + radial glows
     - Subtle grain texture (mix-blend-mode overlay)
     - Bigger display-type clamp (matchet hero h1)
============================================================ */
.ct-hero {
  background:
    radial-gradient(ellipse 900px 700px at 95% 5%, rgba(136,217,50,0.14), transparent 60%),
    radial-gradient(ellipse 800px 600px at 5% 95%, rgba(0,0,0,0.35), transparent 65%),
    linear-gradient(45deg, #06180E 0%, var(--green-deep, #0C261B) 45%, #143A28 100%);
  color: var(--cream, #FCF7F2);
  padding: clamp(96px, 14vw, 160px) 0 clamp(72px, 10vw, 112px);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
/* Subtle film-grain texture overlay (zoals homepage .hero-grain) */
.ct-hero::before {
  content: "";
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.05 0 0 0 0 0.13 0 0 0 0 0.09 0 0 0 0.5 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity: 0.40;
  pointer-events: none;
  mix-blend-mode: overlay;
  z-index: 0;
}
.ct-hero > * { position: relative; z-index: 1; }
.ct-hero-glow {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 1100px 700px at 88% 12%, rgba(136,217,50,.20), transparent 60%),
    radial-gradient(ellipse 700px 500px at 8% 92%, rgba(136,217,50,.10), transparent 60%);
  pointer-events: none;
  z-index: 0;
}
.ct-hero-inner { position: relative; }
.ct-hero-crumb {
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--cream, #FCF7F2);
  opacity: .65;
  margin-bottom: 22px;
}
.ct-hero-crumb a { color: inherit; text-decoration: none; }
.ct-hero-crumb a:hover { opacity: .85; }
.ct-hero-title {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: clamp(48px, 7vw, 96px);
  line-height: 0.96;
  letter-spacing: -.035em;
  color: var(--cream, #FCF7F2);
  margin: 0 0 28px;
  max-width: 18ch;
  font-weight: 700;
}
.ct-hero-title em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  color: var(--green, #88D932);
}
.ct-hero-lead {
  font-size: clamp(17px, 1.4vw, 20px);
  line-height: 1.55;
  max-width: 60ch;
  color: var(--cream, #FCF7F2);
  opacity: .85;
  margin: 0 0 36px;
}
.ct-hero-ctas {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}
.ct-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 22px;
  border-radius: 999px;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-weight: 600;
  font-size: 15px;
  text-decoration: none;
  border: 1px solid transparent;
  transition: transform .12s ease, box-shadow .15s ease, background .15s ease;
}
.ct-cta:hover { transform: translateY(-1px); }
.ct-cta-wa {
  background: #25D366;
  color: #fff;
  box-shadow: 0 4px 18px rgba(37, 211, 102, .25);
}
.ct-cta-wa:hover { background: #1eb455; box-shadow: 0 6px 22px rgba(37, 211, 102, .35); }
.ct-cta-call {
  background: var(--green, #88D932);
  color: var(--green-deep, #0C261B);
  box-shadow: 0 4px 18px rgba(136, 217, 50, .25);
}
.ct-cta-call:hover { background: #95e23d; box-shadow: 0 6px 22px rgba(136, 217, 50, .35); }
.ct-trust {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
  padding-top: 6px;
  font-family: var(--f-sans, 'Open Sans', sans-serif);
  font-size: 13px;
  color: var(--cream, #FCF7F2);
  opacity: .82;
}
.ct-trust-item {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: inherit;
}
.ct-trust-item strong { font-weight: 700; color: var(--green, #88D932); }
.ct-trust-dot {
  width: 3px; height: 3px;
  border-radius: 50%;
  background: rgba(252, 247, 242, .35);
}

/* Featured route-card */
.route-card { position: relative; }
.route-card.is-featured {
  border-color: var(--green, #88D932);
  box-shadow: 0 8px 28px rgba(136, 217, 50, .18);
}
.route-card .rc-pin {
  position: absolute;
  top: -10px; right: 18px;
  background: var(--green-deep, #0C261B);
  color: var(--green, #88D932);
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 5px 12px;
  border-radius: 999px;
  box-shadow: 0 4px 14px rgba(12, 38, 27, .18);
}
.route-card .rc-ico {
  color: var(--green-deep, #0C261B);
  font-size: 0;
}
.route-card.route-sales      .rc-ico { background: linear-gradient(135deg, #e6f7e6, #88D932); }
.route-card.route-backoffice .rc-ico { background: linear-gradient(135deg, #fef3c7, #fbbf24); }
.route-card.route-recruitment .rc-ico { background: linear-gradient(135deg, #d1fae5, #88D932); }

/* Form 2-col layout met sidebar */
.ct-form-section {
  background: var(--cream-2, #F5EFE5);
  padding: 80px 0;
}
.ct-form-wrap { max-width: 1100px; }
.ct-form-head {
  text-align: center;
  margin-bottom: 44px;
}
.ct-form-head h2 {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: clamp(26px, 3.2vw, 38px);
  letter-spacing: -.02em;
  line-height: 1.1;
  margin: 0 0 10px;
}
.ct-form-head h2 em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  color: var(--green-text);
}
.ct-form-head p {
  color: var(--ink-2, #2A332C);
  font-size: 15px;
  margin: 0;
}
.ct-form-grid {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 36px;
  align-items: start;
}
.ct-form-side {
  position: sticky;
  top: 100px;
  padding: 28px 24px;
  background: var(--paper, #FFF);
  border: 1px solid var(--rule, #E5DCCD);
  border-radius: 14px;
}
.ct-steps-eyebrow {
  display: block;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--green-text);
  margin-bottom: 14px;
}
.ct-steps {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.ct-steps li {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
.ct-step-num {
  flex-shrink: 0;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--green-deep, #0C261B);
  color: var(--green, #88D932);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 13px;
  font-weight: 700;
}
.ct-steps li > div { display: flex; flex-direction: column; gap: 2px; }
.ct-steps strong {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 14px;
  color: var(--green-deep, #0C261B);
  font-weight: 700;
}
.ct-steps span {
  font-size: 13px;
  color: var(--ink-2, #2A332C);
  line-height: 1.5;
}
.ct-side-note {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 14px;
  background: var(--cream, #FCF7F2);
  border-radius: 10px;
  font-size: 12.5px;
  color: var(--ink-2, #2A332C);
  line-height: 1.5;
}
.ct-side-note a { color: var(--green-text); font-weight: 600; text-decoration: none; }
.ct-side-note a:hover { text-decoration: underline; }

.ct-form-card {
  background: var(--paper, #FFF);
  border: 1px solid var(--rule, #E5DCCD);
  border-radius: 16px;
  padding: 36px;
  box-shadow: 0 4px 24px rgba(12, 38, 27, .04);
}

/* Office-card SVG flag styling */
.office-card-dark .ocd-flag {
  display: inline-flex;
  font-size: 0;
  line-height: 0;
  flex-shrink: 0;
  border-radius: 50%;
  overflow: hidden;
}
.office-card-dark .ocd-flag svg { display: block; }

@media (max-width: 900px) {
  .ct-form-grid { grid-template-columns: 1fr; gap: 24px; }
  .ct-form-side { position: static; }
}
@media (max-width: 760px) {
  .ct-form-card { padding: 24px; }
  .ct-trust { gap: 10px; font-size: 12.5px; }
  .ct-trust-dot { display: none; }
  .route-card .rc-pin { right: 12px; }
}

/* ============================================================
   CT-BAND · premium section pattern voor werkwijze/over-ons/contact
   ------------------------------------------------------------
   Bestaande inline-style sections waren onderstyled. Deze utility
   maakt sections die matchen met homepage-kwaliteit:
     - .ct-band            → standaard section met juiste padding + radial accent
     - .ct-band-cream      → cream-2 background (alternating sections)
     - .ct-band-dark       → green-deep background met grain
     - .ct-band-narrow     → kleinere wrap voor focus-content
     - .ct-band > .eyebrow → kleine label boven titel
     - .ct-band > h2 + em  → display titel met italic accent
============================================================ */
.ct-band {
  padding: clamp(72px, 9vw, 112px) 0;
  background: var(--paper, #FFF);
  position: relative;
  isolation: isolate;
}
.ct-band-cream { background: var(--cream-2, #F4ECE1); }
.ct-band.ct-band-soft {
  background:
    radial-gradient(ellipse 1000px 500px at 50% 0%, rgba(136,217,50,0.06), transparent 70%),
    var(--cream, #FCF7F2);
}
.ct-band-dark {
  background:
    radial-gradient(ellipse 1100px 700px at 88% 12%, rgba(136,217,50,.18), transparent 60%),
    radial-gradient(ellipse 700px 500px at 8% 92%, rgba(136,217,50,.10), transparent 60%),
    linear-gradient(45deg, #06180E 0%, var(--green-deep, #0C261B) 50%, #143A28 100%);
  color: var(--cream, #FCF7F2);
}
.ct-band-dark::before {
  content: "";
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.05 0 0 0 0 0.13 0 0 0 0 0.09 0 0 0 0.5 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity: 0.35;
  pointer-events: none;
  mix-blend-mode: overlay;
  z-index: 0;
}
.ct-band-dark > * { position: relative; z-index: 1; }

.ct-band-head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto clamp(40px, 5vw, 64px);
}
.ct-band-head.is-left { text-align: left; margin: 0 0 clamp(32px, 4vw, 48px); }
.ct-band-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 12px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--green-text);
  margin-bottom: 18px;
}
.ct-band-eyebrow::before {
  content: "";
  width: 28px;
  height: 2px;
  background: var(--green, #88D932);
}
.ct-band-title {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: clamp(32px, 4.4vw, 56px);
  line-height: 1.05;
  letter-spacing: -0.030em;
  color: var(--green-deep, #0C261B);
  margin: 0 0 18px;
  font-weight: 700;
}
.ct-band-dark .ct-band-title { color: var(--cream, #FCF7F2); }
.ct-band-title em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  color: var(--green-text);
}
.ct-band-dark .ct-band-title em { color: var(--green, #88D932); }
.ct-band-lead {
  font-size: clamp(15px, 1.3vw, 18px);
  line-height: 1.6;
  color: var(--ink-2, #2A2A28);
  max-width: 62ch;
  margin: 0 auto;
}
.ct-band-head.is-left .ct-band-lead { margin: 0; }
.ct-band-dark .ct-band-lead { color: var(--cream, #FCF7F2); opacity: 0.85; }

/* Premium card pattern voor content-blocks binnen ct-band */
.ct-card {
  background: var(--paper, #FFF);
  border: 1px solid var(--rule, #E5DCCD);
  border-radius: 18px;
  padding: clamp(20px, 2.6vw, 32px);
  transition: transform .22s cubic-bezier(.2,.78,.2,1), box-shadow .22s ease, border-color .22s ease;
  position: relative;
}
.ct-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 40px -10px rgba(8, 24, 17, 0.10);
  border-color: rgba(136, 217, 50, 0.32);
}
.ct-card-icon {
  width: 48px; height: 48px;
  border-radius: 12px;
  background: linear-gradient(135deg, #d1fae5 0%, #88D932 100%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--green-deep, #0C261B);
  margin-bottom: 16px;
  box-shadow: 0 4px 14px rgba(136, 217, 50, 0.22);
}
.ct-card-icon svg { width: 24px; height: 24px; }
.ct-card-title {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 18px;
  font-weight: 700;
  color: var(--green-deep, #0C261B);
  margin: 0 0 8px;
  line-height: 1.25;
}
.ct-card-body {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ink-2, #2A2A28);
  margin: 0;
}

/* Stat-strip — voor "200+ vakkrachten" type triple/quad */
.ct-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: clamp(16px, 2vw, 28px);
}
.ct-stat {
  text-align: center;
  padding: 24px 18px;
  border-right: 1px solid var(--rule, #E5DCCD);
}
.ct-stat:last-child { border-right: 0; }
@media (max-width: 720px) { .ct-stat { border-right: 0; border-bottom: 1px solid var(--rule); } .ct-stat:last-child { border-bottom: 0; } }
.ct-band-dark .ct-stat { border-right-color: rgba(244, 236, 225, 0.16); }
.ct-band-dark .ct-stat { border-bottom-color: rgba(244, 236, 225, 0.16); }
.ct-stat-num {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: clamp(36px, 4.5vw, 56px);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1;
  background: linear-gradient(135deg, var(--green-ink, #6FB827) 0%, var(--green, #88D932) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 6px;
}
.ct-band-dark .ct-stat-num {
  background: linear-gradient(135deg, var(--green, #88D932) 0%, #B5F168 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.ct-stat-lbl {
  font-size: 13px;
  color: var(--muted, #5F5F5B);
  line-height: 1.4;
}
.ct-band-dark .ct-stat-lbl { color: rgba(252, 247, 242, 0.78); }

/* ============================================================
   CONTACT-PAGINA · mail-cards en kantoor-cards (oude, ongebruikt)
============================================================ */
.mail-card {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 16px;
  padding: 18px 20px;
  background: var(--paper, #FFFFFF);
  border: 1px solid var(--rule, #E5DCCD);
  border-radius: 12px;
  text-decoration: none;
  color: var(--ink);
  transition: all .15s ease;
}
.mail-card:hover {
  border-color: var(--green-deep, #0C261B);
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(12, 38, 27, 0.08);
}
.mail-card .mc-ico {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  flex-shrink: 0;
}
.mail-card .mc-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.mail-card .mc-body strong {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 15px;
  font-weight: 700;
  color: var(--green-deep, #0C261B);
}
.mail-card .mc-desc {
  font-size: 12px;
  color: var(--ink-2, #2A332C);
  line-height: 1.4;
}
.mail-card .mc-email {
  font-size: 12px;
  color: var(--green-text);
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-weight: 600;
  margin-top: 2px;
  word-break: break-all;
}
.mail-card .mc-arrow {
  font-size: 22px;
  color: var(--green-deep, #0C261B);
  font-weight: 700;
  transition: transform .15s;
}
.mail-card:hover .mc-arrow { transform: translateX(4px); }

/* Office-card */
.office-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 20px;
  padding: 28px;
  background: var(--paper, #FFFFFF);
  border: 1px solid var(--rule, #E5DCCD);
  border-radius: 14px;
  transition: all .15s ease;
}
.office-card:hover {
  border-color: var(--green-deep, #0C261B);
  box-shadow: 0 8px 22px rgba(12, 38, 27, 0.08);
}
.office-card .oc-flag {
  font-size: 48px;
  line-height: 1;
  flex-shrink: 0;
}
.office-card .oc-tag {
  display: inline-block;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--green-text);
  margin-bottom: 4px;
}
.office-card h3 {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--green-deep, #0C261B);
  margin: 0 0 12px;
}
.office-card p {
  color: var(--ink-2, #2A332C);
  font-size: 14px;
  line-height: 1.55;
  margin: 0 0 16px;
}
.office-card .oc-meta {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 13px;
  color: var(--ink-2, #2A332C);
}
.office-card .oc-meta a {
  color: var(--green-deep, #0C261B);
  font-weight: 600;
  text-decoration: none;
}
.office-card .oc-meta a:hover { color: var(--green-text); }

/* Pill-radio voor "Ik ben…" */
.pill-radio {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border: 1px solid var(--rule, #E5DCCD);
  border-radius: 999px;
  font-size: 13px;
  cursor: pointer;
  transition: all .15s ease;
  background: var(--cream, #FCF7F2);
}
.pill-radio input { accent-color: var(--green-deep, #0C261B); }
.pill-radio:has(input:checked) {
  background: var(--green-deep, #0C261B);
  color: var(--green, #88D932);
  border-color: var(--green-deep, #0C261B);
}

@media (max-width: 760px) {
  .mail-card { grid-template-columns: auto 1fr; padding: 14px 16px; }
  .mail-card .mc-arrow { display: none; }
  .office-card { grid-template-columns: 1fr; gap: 14px; padding: 22px; }
  .office-card .oc-flag { font-size: 36px; }
  /* 2-col contact form/info wordt 1-col op smal */
  .city-section > .wrap > div[style*="grid-template-columns:1fr 1.2fr"] { grid-template-columns: 1fr !important; gap: 32px !important; }
}

/* ============================================================
   JOB-CARD-WIDE · interne vacatures op werken-bij pagina
============================================================ */
.job-card-wide {
  background: var(--paper, #FFFFFF);
  border: 1px solid var(--rule, #E5DCCD);
  border-radius: 14px;
  padding: 24px 26px;
  transition: all .15s ease;
}
.job-card-wide:hover {
  border-color: var(--green-deep, #0C261B);
  box-shadow: 0 6px 22px rgba(12, 38, 27, 0.08);
}
.job-card-wide .jcw-head {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  margin-bottom: 16px;
}
.job-card-wide .jcw-tag {
  display: inline-block;
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--green-deep, #0C261B);
  background: var(--cream-2, #F4ECE1);
  padding: 4px 10px;
  border-radius: 999px;
  margin-bottom: 8px;
}
.job-card-wide h3 {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--green-deep, #0C261B);
  margin: 4px 0 8px;
}
.job-card-wide .jcw-head p {
  font-size: 14px;
  line-height: 1.55;
  color: var(--ink-2, #2A332C);
  max-width: 600px;
  margin: 0;
}
.job-card-wide .jcw-meta {
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: flex-end;
  flex-shrink: 0;
}
.job-card-wide .jcw-badge {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 12px;
  font-weight: 600;
  padding: 6px 10px;
  background: var(--green-deep, #0C261B);
  color: var(--green, #88D932);
  border-radius: 8px;
  white-space: nowrap;
}
.job-card-wide .jcw-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  padding-top: 14px;
  border-top: 1px solid var(--rule, #E5DCCD);
}
.job-card-wide .jcw-skills {
  font-size: 12px;
  color: var(--muted, #8A8478);
  font-style: italic;
  flex: 1;
  min-width: 240px;
}
.job-card-wide .jcw-cta {
  font-size: 13px !important;
  padding: 10px 18px !important;
  flex-shrink: 0;
}
@media (max-width: 760px) {
  .job-card-wide { padding: 20px; }
  .job-card-wide .jcw-head { grid-template-columns: 1fr; }
  .job-card-wide .jcw-meta { flex-direction: row; flex-wrap: wrap; align-items: flex-start; }
  .job-card-wide h3 { font-size: 18px; }
}

/* ============================================================
   DOWNLOADS PAGINA · brochure-cards in grid
============================================================ */
.downloads-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 14px;
}
.download-card {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 16px;
  padding: 18px 20px;
  background: var(--paper, #FFFFFF);
  border: 1px solid var(--rule, #E5DCCD);
  border-radius: 12px;
  text-decoration: none;
  color: var(--ink);
  transition: all .15s ease;
}
.download-card:hover {
  border-color: var(--green-deep, #0C261B);
  transform: translateY(-1px);
  box-shadow: 0 8px 22px rgba(12, 38, 27, 0.08);
}
.download-card .dl-icon {
  font-size: 32px;
  line-height: 1;
  flex-shrink: 0;
}
.download-card .dl-meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.download-card .dl-meta strong {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.005em;
  color: var(--green-deep, #0C261B);
}
.download-card .dl-desc {
  font-size: 12px;
  color: var(--ink-2, #2A332C);
  line-height: 1.4;
}
.download-card .dl-type {
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted, #8A8478);
  font-weight: 600;
  margin-top: 2px;
}
.download-card .dl-cta {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 13px;
  font-weight: 700;
  color: var(--green-deep, #0C261B);
  white-space: nowrap;
  flex-shrink: 0;
}
.download-card:hover .dl-cta {
  color: var(--green-text);
}
@media (max-width: 600px) {
  .download-card { grid-template-columns: auto 1fr; padding: 14px 16px; }
  .download-card .dl-cta { grid-column: 2; justify-self: end; margin-top: 4px; }
}

/* ============================================================
   APPLY-CTA op vacature-detailpagina · premium light-card v4
   (Stripe / Airbnb stijl — wit, bold, recruiter-portret +
    verified badge, social-proof ticker, calendar-slot,
    stagger entrance, micro-interacties)
============================================================ */
.vd-apply {
  position: relative;
  background: #fff;
  border: 1px solid #ECE3D5;
  border-radius: 26px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  color: #0c261b;
  overflow: hidden;
  isolation: isolate;
  box-shadow:
    0 1px 0 rgba(12,38,27,0.04),
    0 8px 16px -4px rgba(12,38,27,0.06),
    0 24px 56px -16px rgba(12,38,27,0.14);
  transition: box-shadow .25s ease, transform .25s ease;
}
.vd-apply:hover {
  box-shadow:
    0 1px 0 rgba(12,38,27,0.04),
    0 14px 26px -4px rgba(12,38,27,0.10),
    0 36px 80px -20px rgba(12,38,27,0.22);
}
/* Subtiele highlight onder de top-rand (premium kaart-effect) */
.vd-apply::before {
  content: ""; position: absolute; inset: 0 0 auto 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(140,229,90,0.7), transparent);
  z-index: 5; pointer-events: none;
}

/* Stagger entrance — elementen schuiven omhoog wanneer card in view komt */
.vd-apply > * {
  opacity: 0;
  transform: translateY(8px);
  animation: vdFadeUp .45s cubic-bezier(.2,.8,.2,1) forwards;
}
.vd-apply > *:nth-child(1) { animation-delay: .05s; }
.vd-apply > *:nth-child(2) { animation-delay: .12s; }
.vd-apply > *:nth-child(3) { animation-delay: .19s; }
.vd-apply > *:nth-child(4) { animation-delay: .26s; }
.vd-apply > *:nth-child(5) { animation-delay: .33s; }
.vd-apply > *:nth-child(6) { animation-delay: .40s; }
.vd-apply > *:nth-child(7) { animation-delay: .47s; }
.vd-apply > *:nth-child(8) { animation-delay: .54s; }
.vd-apply > *:nth-child(9) { animation-delay: .61s; }
.vd-apply > *:nth-child(10) { animation-delay: .68s; }
@keyframes vdFadeUp {
  to { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
  .vd-apply > * { animation: none; opacity: 1; transform: none; }
}

/* TOP: live banner met groene rand-glow */
.vd-apply-top {
  position: relative;
  padding: 16px 22px 14px;
  background: linear-gradient(135deg, #F4FBE5 0%, #FCFEF7 50%, #F4FBE5 100%);
  border-bottom: 1px solid #E9F5D0;
  display: flex; align-items: center; gap: 8px;
  font-family: 'Poppins', sans-serif;
  font-size: 11px; font-weight: 800;
  color: #4a7c0f; letter-spacing: .08em; text-transform: uppercase;
}
.vd-apply-top::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: #88D932; box-shadow: 0 0 0 0 rgba(140,229,90,0.6);
  animation: vdLivePulse 1.6s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes vdLivePulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(140,229,90,0.65); }
  50% { box-shadow: 0 0 0 6px rgba(140,229,90,0); }
}

/* Recruiter-block (avatar + naam + verified + rating + reply-time) */
.vd-recruiter-card {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 14px;
  align-items: center;
  padding: 18px 22px;
  border-bottom: 1px solid #F4ECDA;
  position: relative;
}
.vd-recruiter-avatar {
  width: 72px; height: 72px; border-radius: 50%;
  background: #fff;
  display: flex; align-items: center; justify-content: center;
  position: relative;
  box-shadow:
    0 8px 18px rgba(12,38,27,0.10),
    0 0 0 1px rgba(12,38,27,0.06),
    0 0 0 4px rgba(140,229,90,0.16);
}
.vd-recruiter-avatar svg,
.vd-recruiter-avatar img { width: 56px; height: 56px; position: relative; z-index: 2; object-fit: contain; }
/* Sparkle particles rondom de avatar (AI-feel) */
.vd-recruiter-avatar .vd-sparkle {
  position: absolute; width: 10px; height: 10px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23FBBF24'><path d='M12 0 L14 10 L24 12 L14 14 L12 24 L10 14 L0 12 L10 10 Z'/></svg>") center / contain no-repeat;
  pointer-events: none;
  opacity: 0;
  filter: drop-shadow(0 0 4px rgba(251,191,36,0.6));
}
.vd-recruiter-avatar .vd-sparkle.s1 { top: -2px; left: -4px; animation: vdSparkle 3s ease-in-out 0s infinite; }
.vd-recruiter-avatar .vd-sparkle.s2 { top: -4px; right: 6px; width: 8px; height: 8px; animation: vdSparkle 3s ease-in-out 1s infinite; }
.vd-recruiter-avatar .vd-sparkle.s3 { bottom: 6px; left: -4px; width: 7px; height: 7px; animation: vdSparkle 3s ease-in-out 2s infinite; }
@keyframes vdSparkle {
  0%, 100% { opacity: 0; transform: scale(0.4) rotate(0deg); }
  20%, 80% { opacity: 1; transform: scale(1.1) rotate(180deg); }
}
/* Online-dot met pulse */
.vd-recruiter-avatar::after {
  content: ""; position: absolute; bottom: 2px; right: 2px;
  width: 18px; height: 18px; border-radius: 50%;
  background: #4ade80; border: 3px solid #fff;
  box-shadow: 0 0 0 0 rgba(74,222,128,0.55);
  animation: vdAvatarPulse 1.7s ease-in-out infinite;
}
@keyframes vdAvatarPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(74,222,128,0.55); }
  50% { box-shadow: 0 0 0 6px rgba(74,222,128,0); }
}
.vd-recruiter-info { min-width: 0; }
.vd-recruiter-name {
  font-family: 'Poppins', sans-serif; font-weight: 800; font-size: 17px;
  color: #0c261b; line-height: 1.1; margin: 0 0 4px;
  display: flex; align-items: center; gap: 6px;
}
/* Verified blue checkmark */
.vd-recruiter-name::after {
  content: ""; width: 16px; height: 16px; flex-shrink: 0;
  background: #1d9bf0 url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center / 11px no-repeat;
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(29,155,240,0.40);
}
.vd-recruiter-role {
  font-size: 12px; color: #6E6655; font-weight: 600; margin-bottom: 4px;
}
.vd-recruiter-meta {
  display: flex; align-items: center; gap: 10px;
  font-size: 12px; color: #6E6655; font-weight: 600;
  flex-wrap: wrap;
}
.vd-recruiter-meta .vd-rating {
  display: inline-flex; align-items: center; gap: 5px;
  color: #6E6655; text-decoration: none;
  transition: color .15s ease;
}
.vd-recruiter-meta .vd-rating:hover { color: #0c261b; }
.vd-recruiter-meta .vd-rating:hover span:last-child { text-decoration: underline; }
.vd-recruiter-meta .vd-rating strong { color: #0c261b; font-weight: 800; }
.vd-recruiter-meta .vd-rating .stars { color: #f59e0b; letter-spacing: -1px; }
.vd-recruiter-meta .vd-reply {
  display: inline-flex; align-items: center; gap: 4px;
  color: #4a7c0f; font-weight: 700;
}
.vd-recruiter-meta .vd-reply::before {
  content: ""; width: 12px; height: 12px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234a7c0f' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='10'/><polyline points='12 6 12 12 16 14'/></svg>") center / 12px no-repeat;
}
.vd-recruiter-meta .vd-sep { color: #C9BFAF; }

/* Urgency-badge — boven headline */
.vd-urgency {
  margin: 18px 22px 0;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px 6px 8px;
  border-radius: 999px;
  background: linear-gradient(135deg, #FEF3C7 0%, #FDE68A 100%);
  border: 1px solid #F59E0B;
  font-family: 'Poppins', sans-serif;
  font-size: 11px; font-weight: 800;
  color: #92400e;
  letter-spacing: .02em;
  align-self: flex-start;
  box-shadow: 0 4px 12px rgba(245,158,11,0.20);
}
.vd-urgency::before {
  content: ""; width: 18px; height: 18px;
  background: #F59E0B url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='10'/><polyline points='12 6 12 12 16 14'/></svg>") center / 11px no-repeat;
  border-radius: 50%;
  flex-shrink: 0;
}
.vd-urgency strong { color: #78350f; }

/* Headline */
.vd-apply-headline {
  padding: 14px 22px 8px;
  font-family: 'Poppins', sans-serif;
  font-weight: 800; font-size: 22px; line-height: 1.15;
  color: #0c261b; letter-spacing: -.02em;
}
.vd-apply-headline em {
  font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400;
  color: #6BB91A;
}

/* WhatsApp chat-preview */
.vd-chat-preview {
  margin: 0 22px 16px;
  padding: 12px;
  background: #ECE5DD;
  border-radius: 14px;
  display: flex; flex-direction: column; gap: 8px;
  position: relative;
}
.vd-chat-bubble {
  background: #fff;
  padding: 10px 12px;
  border-radius: 12px 12px 12px 4px;
  font-size: 12.5px; line-height: 1.4;
  color: #1F2937;
  max-width: 88%;
  align-self: flex-start;
  box-shadow: 0 1px 1px rgba(0,0,0,0.06);
  position: relative;
}
.vd-chat-bubble.from-user {
  background: #DCF8C6;
  border-radius: 12px 12px 4px 12px;
  align-self: flex-end;
  color: #0f172a;
}
.vd-chat-bubble .vd-chat-meta {
  display: block;
  font-size: 9.5px; color: #65798a; margin-top: 3px; font-weight: 600;
  text-align: right;
}
.vd-chat-bubble.from-user .vd-chat-meta { color: #4d7c0f; }
.vd-chat-bubble.from-user .vd-chat-meta::after {
  content: " ✓✓"; color: #25D366; font-weight: 800;
}
.vd-chat-typing {
  background: #fff;
  padding: 12px;
  border-radius: 12px 12px 12px 4px;
  display: inline-flex; gap: 4px;
  align-self: flex-start;
  box-shadow: 0 1px 1px rgba(0,0,0,0.06);
}
.vd-chat-typing span {
  width: 6px; height: 6px; border-radius: 50%;
  background: #98a3b8;
  animation: vdTyping 1.2s infinite;
}
.vd-chat-typing span:nth-child(2) { animation-delay: 0.15s; }
.vd-chat-typing span:nth-child(3) { animation-delay: 0.3s; }
@keyframes vdTyping {
  0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
  30% { transform: translateY(-4px); opacity: 1; }
}
.vd-chat-hidden { display: none !important; }
.vd-apply-sub {
  padding: 0 22px 16px;
  font-size: 13.5px; color: #6E6655; line-height: 1.5;
  font-weight: 500;
}

/* Value bullets — bigger, with numbers + colored icons */
.vd-apply-bullets {
  list-style: none; padding: 0 22px 18px; margin: 0;
  display: flex; flex-direction: column; gap: 10px;
}
.vd-apply-bullets li {
  display: flex; align-items: center; gap: 12px;
  font-size: 13px; font-weight: 600; color: #2A332C;
  line-height: 1.35;
  transition: transform .15s ease;
}
.vd-apply-bullets li:hover { transform: translateX(2px); }
.vd-apply-bullets li::before {
  content: ""; width: 22px; height: 22px; flex-shrink: 0;
  border-radius: 50%;
  background: linear-gradient(135deg, #d6f4a8 0%, #b8e672 100%);
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23295c0a' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>"),
    linear-gradient(135deg, #d6f4a8 0%, #b8e672 100%);
  background-repeat: no-repeat, no-repeat;
  background-position: center, center;
  background-size: 13px, cover;
  box-shadow: 0 2px 6px rgba(140,229,90,0.30), inset 0 1px 0 rgba(255,255,255,0.5);
}
.vd-apply-bullets li strong { color: #0c261b; font-weight: 800; }

/* Social-proof ticker */
.vd-social-proof {
  margin: 0 22px 16px;
  padding: 12px 14px;
  background: linear-gradient(135deg, #FAF6EE 0%, #F4ECDA 100%);
  border: 1px solid #ECE3D5;
  border-radius: 12px;
  display: flex; align-items: center; gap: 10px;
  overflow: hidden;
  position: relative;
}
.vd-social-proof-icon {
  width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, #B5F062 0%, #6BB91A 100%);
  color: #0c261b;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Poppins', sans-serif; font-weight: 800; font-size: 13px;
  box-shadow: 0 4px 10px rgba(140,229,90,0.30), inset 0 1px 0 rgba(255,255,255,0.4);
  transition: background .3s ease;
}
.vd-social-proof-text {
  flex: 1; min-width: 0;
  font-size: 12px; color: #2A332C; line-height: 1.35; font-weight: 500;
}
.vd-social-proof-text strong { color: #0c261b; font-weight: 800; }
.vd-social-proof-text small {
  display: block; font-size: 10.5px; color: #8A8478; margin-top: 2px;
  font-weight: 600;
}

/* Calendar-slot mini */
.vd-calendar {
  margin: 0 22px 16px;
  padding: 12px 14px;
  background: #fff;
  border: 1px dashed rgba(140,229,90,0.40);
  border-radius: 12px;
  display: flex; align-items: center; gap: 10px;
}
.vd-calendar-ico {
  width: 32px; height: 32px; border-radius: 8px; flex-shrink: 0;
  background: rgba(140,229,90,0.16);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236BB91A' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='4' width='18' height='18' rx='2' ry='2'/><line x1='16' y1='2' x2='16' y2='6'/><line x1='8' y1='2' x2='8' y2='6'/><line x1='3' y1='10' x2='21' y2='10'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 16px;
}
.vd-calendar-text {
  flex: 1; font-size: 11.5px; color: #2A332C; line-height: 1.4;
  font-weight: 600;
}
.vd-calendar-text strong { display: block; color: #0c261b; font-weight: 800; font-size: 12px; margin-bottom: 1px; }
.vd-calendar-text small { color: #6BB91A; font-weight: 700; }

/* CTA wrapper */
.vd-apply-cta-wrap {
  padding: 4px 16px 14px;
}

/* Secondary actions */
.vd-apply-actions {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
  padding: 0 16px 14px;
}
.vd-apply-actions a {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  padding: 11px 12px; border-radius: 12px;
  font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 13px;
  text-decoration: none; transition: background .15s, transform .12s;
}
.vd-apply-actions a:active { transform: scale(0.97); }
.vd-apply-actions .wa {
  background: rgba(37,211,102,0.08); color: #128C7E;
  border: 1px solid rgba(37,211,102,0.20);
}
.vd-apply-actions .wa:hover { background: rgba(37,211,102,0.14); }
.vd-apply-actions .call {
  background: #FAF6EE; color: #0c261b;
  border: 1px solid #ECE3D5;
}
.vd-apply-actions .call:hover { background: #F4ECDA; }
.vd-apply-actions svg { width: 14px; height: 14px; }
.vd-apply-actions .wa svg { fill: currentColor; }
.vd-apply-actions .call svg { stroke: currentColor; fill: none; stroke-width: 2.2; }

/* Trust strip — shield-style cert badges */
.vd-apply-trust {
  display: flex; justify-content: space-around; gap: 6px;
  padding: 14px 16px;
  background: linear-gradient(180deg, #FAF6EE 0%, #F4ECDA 100%);
  border-top: 1px solid #ECE3D5;
}
.vd-apply-trust-item {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  font-size: 9.5px; color: #6E6655; font-weight: 800;
  letter-spacing: .04em; text-transform: uppercase;
  text-align: center;
}
.vd-apply-trust-item::before {
  content: ""; width: 22px; height: 26px; flex-shrink: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 28' fill='none'><path d='M3 3 L21 3 Q23 3 23 5 L23 17 Q23 21 12 27 Q1 21 1 17 L1 5 Q1 3 3 3 Z' fill='%2388D932' stroke='%230c261b' stroke-width='1.4'/><polyline points='8 14 11 17 17 11' fill='none' stroke='%230c261b' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 22px 26px;
  filter: drop-shadow(0 1px 2px rgba(12,38,27,0.15));
}

/* Stats-rij onder de trust-badges (sociale bewijslaag) */
.vd-apply-stats {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  padding: 14px 16px;
  background: #fff;
  border-top: 1px solid #ECE3D5;
}
.vd-apply-stat {
  text-align: center;
  padding: 4px 8px;
}
.vd-apply-stat + .vd-apply-stat {
  border-left: 1px solid #ECE3D5;
}
.vd-apply-stat .val {
  font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400;
  font-size: 24px; line-height: 1; color: #0c261b;
  display: block; margin-bottom: 4px;
  transition: color .4s ease;
}
.vd-apply-stat.counting .val { color: #6BB91A; }
.vd-apply-stat .lbl {
  font-size: 9.5px; letter-spacing: .08em; text-transform: uppercase;
  color: #6E6655; font-weight: 700;
}

/* Bottom referentie */
.vd-apply-foot {
  padding: 10px 22px 14px;
  font-size: 10.5px; letter-spacing: .12em;
  color: #B8AE9B; font-family: 'Poppins', sans-serif;
  font-weight: 700; text-transform: uppercase; text-align: center;
  border-top: 1px solid #F4ECDA;
}

/* WhatsApp-link wordt vervangen door .vd-apply-actions, dus oude regels uitschakelen */
.vd-apply .apply-wa-link, .vd-apply .apply-ref-mini { display: none !important; }

/* ============================================================
   APPLY-CARD — premium refinement (v2)
   Belangrijkste conversie-element van de site. Hoogste-prioriteit
   overrides, gescoped op .vd-apply zodat ze de oudere/dubbele
   .vd-cta-primary-regels winnen op specificiteit (niet op volgorde).
   Lost op: (1) onleesbare subtekst, (2) krappe 2-koloms CTA-knop,
   (3) gimmick-sparkles -> rustiger, premium uitstraling.
   ============================================================ */

/* 1. Subtekst — was #6E6655 (te licht, las als "onzichtbaar") -> solide, leesbaar */
.vd-apply .vd-apply-sub {
  color: #3E4A40;
  font-size: 14px;
  line-height: 1.55;
  font-weight: 500;
  padding: 0 22px 18px;
}

/* 2. Recruiter-rol iets donkerder voor nette leesbaarheid */
.vd-apply .vd-recruiter-role { color: #5A5346; }

/* 3. Geen gimmick-sparkles rond de avatar -> rustiger / premium (online-dot blijft) */
.vd-apply .vd-recruiter-avatar .vd-sparkle { display: none !important; }

/* 4. Bullets — tekst iets steviger */
.vd-apply .vd-apply-bullets li { color: #283129; font-size: 13.5px; }

/* 5. Hoofd-CTA — UNIFICEREN op één premium knop.
   Build-vacatures gebruiken .vd-cta-primary, statische pagina's .apply-cta-big.
   Die toonden 2 verschillende knoppen (krappe donkere 2-koloms vs. bright-green
   pill met arrow). Hier krijgt .vd-cta-primary exact hetzelfde bright-green
   design als .apply-cta-big -> één consistente, on-brand CTA overal.
   !important wint van de losse oudere .vd-cta-primary-regels (5995/13205). */
.vd-apply .vd-apply-cta-wrap { padding: 10px 16px 14px; }
.vd-apply .vd-cta-primary {
  position: relative;
  display: flex !important;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 3px;
  width: 100% !important;
  margin: 0;
  padding: 20px 64px 20px 22px !important;
  border-radius: 16px !important;
  border: none !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.22) 0%, transparent 50%),
    linear-gradient(135deg, #B5F062 0%, #88D932 45%, #6BB91A 100%) !important;
  color: #0c261b !important;
  font-family: 'Poppins', system-ui, sans-serif !important;
  letter-spacing: -0.01em;
  cursor: pointer;
  text-align: left;
  text-decoration: none !important;
  min-height: 76px;
  overflow: hidden;
  isolation: isolate;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.55) inset,
    0 -3px 0 rgba(8,24,17,0.18) inset,
    0 14px 32px -6px rgba(140,229,90,0.55),
    0 4px 10px rgba(8,24,17,0.20);
  transition: transform .22s cubic-bezier(.2,.8,.2,1), box-shadow .22s ease, filter .2s;
}
.vd-apply .vd-cta-primary::after {
  content: "\2192";
  position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
  width: 40px; height: 40px; border-radius: 50%;
  background: #0c261b; color: #88D932;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; font-weight: 900;
  box-shadow: 0 6px 16px rgba(8,24,17,0.35), inset 0 1px 0 rgba(140,229,90,0.25);
  z-index: 2;
}
.vd-apply .vd-cta-primary:hover {
  transform: translateY(-3px);
  filter: brightness(1.04);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 -3px 0 rgba(8,24,17,0.18) inset,
    0 22px 44px -8px rgba(140,229,90,0.65),
    0 6px 14px rgba(8,24,17,0.22);
}
.vd-apply .vd-cta-primary:hover::after { transform: translateY(-50%) translateX(3px) scale(1.06); }
.vd-apply .vd-cta-primary:active { transform: translateY(-1px); }
.vd-apply .vd-cta-primary .vd-cta-main {
  position: relative; z-index: 2;
  font-size: 18px; font-weight: 800; color: #0c261b;
  line-height: 1.15; letter-spacing: -.015em;
}
.vd-apply .vd-cta-primary .vd-cta-sub,
.vd-apply .apply-cta-big .apply-cta-sub {
  position: relative; z-index: 2;
  display: block;
  font-size: 11px; font-weight: 700; color: rgba(12,38,27,0.82);
  letter-spacing: 0; line-height: 1.3;
}
/* Orphan-dot van .apply-cta-sub weg + block i.p.v. inline-flex ->
   subtitel past op één nette regel (geen lelijke mid-zin-wrap). */
.vd-apply .apply-cta-big .apply-cta-sub::before { display: none !important; }

/* Mobiel: zelfde knop-verkleining als .apply-cta-big al had (kleinere padding +
   arrow + subtitel) zodat de subtitel ook bij .vd-cta-primary op één regel past. */
@media (max-width: 480px) {
  .vd-apply .vd-cta-primary {
    padding: 18px 56px 18px 18px !important;
    min-height: 70px;
    border-radius: 14px !important;
  }
  .vd-apply .vd-cta-primary::after { width: 36px; height: 36px; right: 10px; font-size: 18px; }
  .vd-apply .vd-cta-primary .vd-cta-main { font-size: 16.5px; }
  .vd-apply .vd-cta-primary .vd-cta-sub,
  .vd-apply .apply-cta-big .apply-cta-sub { font-size: 10.5px; letter-spacing: 0; }
}

/* ============================================================
   STICKY MOBILE APPLY-BAR
   Verschijnt onderaan op mobiel zodra de hoofd-applycard uit
   beeld is gescrolld. Maakt sollicitatie altijd 1-tap-bereik.
============================================================ */
.vd-mobile-cta {
  position: fixed; left: 0; right: 0; bottom: -100%;
  z-index: 999;
  padding: 12px 14px calc(12px + env(safe-area-inset-bottom));
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border-top: 1px solid #ECE3D5;
  box-shadow: 0 -8px 24px rgba(12,38,27,0.10);
  display: none;
  transition: bottom .35s cubic-bezier(.16,.84,.34,1);
}
.vd-mobile-cta.visible { bottom: 0; }
.vd-mobile-cta-inner {
  display: grid; grid-template-columns: auto 1fr auto;
  gap: 12px; align-items: center;
}
.vd-mobile-cta-ava {
  width: 40px; height: 40px; border-radius: 50%;
  background: linear-gradient(135deg, #0C261B 0%, #1B4B33 100%);
  display: flex; align-items: center; justify-content: center;
  position: relative; flex-shrink: 0;
  box-shadow: 0 4px 10px rgba(12,38,27,0.20);
}
.vd-mobile-cta-ava svg { width: 26px; height: 26px; }
.vd-mobile-cta-ava::after {
  content: ""; position: absolute; bottom: 1px; right: 1px;
  width: 10px; height: 10px; border-radius: 50%;
  background: #4ade80; border: 2px solid #fff;
}
.vd-mobile-cta-text {
  min-width: 0;
  font-family: 'Poppins', sans-serif;
  font-size: 13px; font-weight: 700; color: #0c261b; line-height: 1.2;
}
.vd-mobile-cta-text small {
  display: block; font-size: 10.5px; color: #6E6655; font-weight: 600;
  margin-top: 2px;
}
.vd-mobile-cta-btn {
  padding: 12px 18px; border-radius: 12px; border: none;
  background: linear-gradient(135deg, #B5F062 0%, #88D932 45%, #6BB91A 100%);
  color: #0c261b;
  font-family: 'Poppins', sans-serif; font-weight: 800; font-size: 13px;
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 6px;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.55) inset,
    0 -2px 0 rgba(8,24,17,0.16) inset,
    0 8px 18px rgba(140,229,90,0.42);
  cursor: pointer;
}
.vd-mobile-cta-btn::after { content: "→"; font-size: 15px; font-weight: 900; }
@media (max-width: 720px) {
  .vd-mobile-cta { display: block; }
}
/* Recruiter-blok onder de knop wordt via CSS toegevoegd */
.vd-apply .apply-cta-big {
  margin: 14px 16px 6px;
  width: auto !important;
}
.vd-apply .apply-wa-link {
  padding: 10px 22px;
  color: rgba(252,247,242,0.78);
  font-size: 13px;
  font-weight: 600;
}
.vd-apply .apply-wa-link:hover { color: #fff; }
.vd-apply .apply-wa-link svg { color: #25D366; }
.vd-apply .apply-ref-mini {
  border-top: 1px solid rgba(140,229,90,0.18);
  margin: 6px 22px 0;
  padding: 12px 0 16px;
  font-size: 10.5px;
  letter-spacing: .14em;
  text-align: center;
  color: rgba(252,247,242,0.42);
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
  text-transform: uppercase;
}
/* Premium apply-CTA — BRIGHT green pill, glasshouse-bevel, krachtig binnen
   donkere kaart-context. CSS-only, geen HTML-change. */
.apply-cta-big {
  position: relative;
  display: flex !important;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 3px;
  width: 100%;
  padding: 20px 64px 20px 22px !important;
  border-radius: 16px !important;
  border: none !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.22) 0%, transparent 50%),
    linear-gradient(135deg, #B5F062 0%, #88D932 45%, #6BB91A 100%) !important;
  color: #0c261b !important;
  font-family: 'Poppins', system-ui, sans-serif !important;
  letter-spacing: -0.01em;
  cursor: pointer;
  text-align: left;
  text-decoration: none !important;
  min-height: 76px;
  overflow: hidden;
  isolation: isolate;
  transition: transform .22s cubic-bezier(.2,.8,.2,1), box-shadow .22s ease, filter .2s;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.55) inset,
    0 -3px 0 rgba(8,24,17,0.18) inset,
    0 14px 32px -6px rgba(140,229,90,0.55),
    0 4px 10px rgba(8,24,17,0.20);
}
/* Sheen die over de knop schuift */
.apply-cta-big::before {
  content: "";
  position: absolute;
  top: 0; left: -75%; width: 50%; height: 100%;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.5) 50%, transparent 100%);
  transform: skewX(-20deg);
  pointer-events: none;
  z-index: 1;
  animation: applyShine 3.8s ease-in-out 1.2s infinite;
}
@keyframes applyShine {
  0%, 100% { left: -75%; }
  40%, 60% { left: 125%; }
}
/* Arrow-pill rechts (donker tegen lichte knop voor contrast) */
.apply-cta-big::after {
  content: "→";
  position: absolute;
  right: 12px; top: 50%; transform: translateY(-50%);
  width: 40px; height: 40px; border-radius: 50%;
  background: #0c261b;
  color: #88D932;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; font-weight: 900;
  box-shadow:
    0 6px 16px rgba(8,24,17,0.35),
    inset 0 1px 0 rgba(140,229,90,0.25);
  transition: transform .28s cubic-bezier(.2,.8,.2,1), box-shadow .2s ease;
  z-index: 2;
}
.apply-cta-big:hover {
  transform: translateY(-3px);
  filter: brightness(1.04);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 -3px 0 rgba(8,24,17,0.18) inset,
    0 22px 44px -8px rgba(140,229,90,0.65),
    0 6px 14px rgba(8,24,17,0.22);
}
.apply-cta-big:hover::after {
  transform: translateY(-50%) translateX(3px) scale(1.06);
  background: #0c261b;
  box-shadow: 0 8px 20px rgba(8,24,17,0.45), inset 0 1px 0 rgba(140,229,90,0.4);
}
.apply-cta-big:active { transform: translateY(-1px); }

.apply-cta-big .apply-cta-main {
  position: relative;
  z-index: 2;
  font-size: 18px;
  font-weight: 800;
  color: #0c261b;
  line-height: 1.15;
  letter-spacing: -.015em;
}
.apply-cta-big .apply-cta-main::before,
.apply-cta-big .apply-cta-main::after { content: none; }

.apply-cta-big .apply-cta-sub {
  position: relative;
  z-index: 2;
  font-size: 11.5px;
  font-weight: 700;
  color: rgba(12,38,27,0.78);
  letter-spacing: 0.02em;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  line-height: 1.35;
}
.apply-cta-big .apply-cta-sub::before {
  content: "";
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #0c261b;
  box-shadow: 0 0 0 0 rgba(8,24,17,0.4);
  animation: applyLive 1.8s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes applyLive {
  0%, 100% { box-shadow: 0 0 0 0 rgba(8,24,17,0.4); }
  50% { box-shadow: 0 0 0 5px rgba(8,24,17,0); }
}

@media (max-width: 480px) {
  .apply-cta-big { padding: 18px 58px 18px 18px !important; min-height: 70px; border-radius: 14px !important; }
  .apply-cta-big::after { width: 36px; height: 36px; right: 10px; font-size: 18px; }
  .apply-cta-big .apply-cta-main { font-size: 16.5px; }
  .apply-cta-big .apply-cta-sub { font-size: 11px; }
}
@media (prefers-reduced-motion: reduce) {
  .apply-cta-big::before, .apply-cta-big .apply-cta-sub::before { animation: none; }
}
.apply-wa-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-decoration: none;
  color: var(--ink-2, #2A332C);
  font-size: 13px;
  font-weight: 500;
  padding: 8px 0;
  transition: color .15s ease;
}
.apply-wa-link:hover {
  color: #25D366;
}
.apply-wa-link svg {
  flex-shrink: 0;
  color: #25D366;
}
.apply-ref-mini {
  font-size: 11px;
  color: var(--muted, #8A8478);
  text-align: center;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-family: 'Poppins', system-ui, sans-serif;
  font-weight: 600;
  border-top: 1px solid var(--rule, #E8DFD2);
  padding-top: 10px;
  margin-top: 4px;
}
@media (max-width: 600px) {
  .vd-apply { padding: 18px; }
  .apply-cta-big { font-size: 16px !important; padding: 16px 18px !important; min-height: 58px; }
}

/* ============================================================
   VAKGEBIEDEN GRID (vacatures.html · 10 sectoren tegelweergave)
============================================================ */
.vakgebieden-grid {
  padding: 64px 0 32px;
  background: var(--paper);
  border-top: 1px solid var(--rule);
}
.vakgebieden-grid h2 {
  font-family: var(--f-display);
  font-size: clamp(28px, 3.4vw, 44px);
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin-bottom: 6px;
}
.vakgebieden-grid h2 em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  color: var(--green-text);
}
.vakgebieden-grid .lead-sm {
  color: var(--ink-2);
  margin-bottom: 32px;
  font-size: 15px;
}
.vakgebieden-grid .vg-tiles {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
}
.vakgebieden-grid .vg-tile {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 18px 18px 16px;
  border: 1px solid var(--rule);
  border-radius: 12px;
  background: var(--cream);
  text-decoration: none;
  color: var(--ink);
  transition: all .15s ease;
  position: relative;
  overflow: hidden;
}
.vakgebieden-grid .vg-tile:hover {
  border-color: var(--green-deep);
  background: white;
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(12,38,27,0.08);
}
.vakgebieden-grid .vg-tile .vg-num {
  font-family: var(--f-display);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--green-deep);
  opacity: 0.6;
  margin-bottom: 4px;
}
.vakgebieden-grid .vg-tile strong {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.vakgebieden-grid .vg-tile span:not(.vg-num) {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.4;
}
@media (max-width: 760px) {
  .vakgebieden-grid { padding: 40px 0 16px; }
  .vakgebieden-grid .vg-tiles { grid-template-columns: 1fr 1fr; gap: 8px; }
  .vakgebieden-grid .vg-tile { padding: 14px; }
  .vakgebieden-grid .vg-tile strong { font-size: 14px; }
  .vakgebieden-grid .vg-tile span:not(.vg-num) { font-size: 11px; }
}

/* ============================================================
   FLEXHERO ACADEMY — curriculum-categorieën
============================================================ */
.academy-cat {
  margin-bottom: 56px;
}
.academy-cat:last-child {
  margin-bottom: 0;
}
.academy-cat h3 {
  font-family: var(--f-display);
  font-size: clamp(20px, 2.4vw, 26px);
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--green-deep);
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 2px solid var(--green);
  display: flex;
  align-items: center;
  gap: 10px;
}
.academy-cat .sector-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
}
.academy-cat .sector-tile h4 {
  font-family: var(--f-display);
  font-size: 15px;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 6px;
}
.academy-cat .sector-tile p {
  font-size: 13px;
  line-height: 1.5;
  color: var(--ink-2);
  margin: 0;
}
@media (max-width: 760px) {
  .academy-cat { margin-bottom: 36px; }
  .academy-cat h3 { font-size: 18px; }
  .academy-cat .sector-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   MOBILE QUICK-WINS · upgrade van 6 → 8/10
   1. Sticky compact header met backdrop-blur
   2. Sticky bottom-CTA-bar
   3. Hero strakker (chips weg, padding tight)
   4. Stats-charts groter (1-kolom layout)
   5. Tap-feedback op alle buttons (0.96 scale)
   6. Founder-foto vertical mobile-crop (face focus)
============================================================ */

/* 1 · STICKY COMPACT HEADER · mobile-first refinement */
@media (max-width: 760px) {
  .nav {
    background: rgba(252, 247, 242, 0.85);
    -webkit-backdrop-filter: saturate(1.4) blur(12px);
    backdrop-filter: saturate(1.4) blur(12px);
    border-bottom: 1px solid rgba(229, 220, 205, 0.6);
  }
  .nav-inner { height: 64px !important; gap: 12px !important; }
  .logo { min-width: 0 !important; }
  .logo img { height: 28px !important; }
  /* CTA-knop in nav verkleinen op mobiel */
  .nav-cta-group .nav-cta { font-size: 12px; padding: 8px 14px; }
  .nav-burger { width: 44px; height: 44px; }
}

/* Scrolled state: nog compacter + sterker blur */
.nav.scrolled {
  background: rgba(252, 247, 242, 0.92);
  -webkit-backdrop-filter: saturate(1.6) blur(20px);
  backdrop-filter: saturate(1.6) blur(20px);
  box-shadow: 0 1px 0 rgba(12,38,27,0.06);
}
@media (max-width: 760px) {
  .nav.scrolled .nav-inner { height: 56px !important; }
  .nav.scrolled .logo img { height: 24px !important; transition: height .15s ease; }
}

/* 2 · STICKY BOTTOM-CTA BAR · mobile only */
.mobile-cta-bar {
  display: none;
}
@media (max-width: 760px) {
  .mobile-cta-bar {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 8px;
    position: fixed;
    left: 12px; right: 12px;
    bottom: calc(12px + env(safe-area-inset-bottom, 0px));
    z-index: 80;
    background: rgba(12, 38, 27, 0.96);
    -webkit-backdrop-filter: saturate(1.4) blur(16px);
    backdrop-filter: saturate(1.4) blur(16px);
    padding: 10px 12px;
    border-radius: 999px;
    box-shadow: 0 8px 28px rgba(12,38,27,0.32), 0 0 0 1px rgba(244,236,225,0.08);
    transform: translateY(120%);
    transition: transform .3s cubic-bezier(.2,.7,.2,1);
  }
  .mobile-cta-bar.is-visible { transform: translateY(0); }
  .mobile-cta-bar .mcb-primary {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: var(--green);
    color: var(--green-deep);
    border-radius: 999px;
    padding: 12px 18px;
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
    font-size: 14px;
    text-decoration: none;
    letter-spacing: -0.005em;
  }
  .mobile-cta-bar .mcb-wa {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: #25D366;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    flex-shrink: 0;
  }
  .mobile-cta-bar .mcb-wa svg { width: 20px; height: 20px; }
  /* Extra bottom-padding op body zodat content niet onder de bar valt */
  body { padding-bottom: 84px; }
}

/* 3 · HERO STRAKKER op mobiel */
@media (max-width: 760px) {
  .hero-inner { padding: 28px 0 24px !important; gap: 28px !important; }
  .hero h1 { font-size: clamp(36px, 9vw, 48px) !important; margin-bottom: 16px !important; }
  .hero p.lead { font-size: 15px !important; line-height: 1.5 !important; margin-bottom: 8px !important; }
  .hero .lead-claims { font-size: 14px !important; margin-bottom: 24px !important; }
  /* Veelgezocht-chips: 1 rij scrollend ipv wrap-rommel — moet binnen parent blijven */
  .search-meta {
    flex-wrap: nowrap !important;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 8px;
    max-width: 100%;
    min-width: 0;
  }
  .search-meta::-webkit-scrollbar { display: none; }
  .search-meta .chip {
    scroll-snap-align: start;
    flex-shrink: 0;
  }
  .search-meta .pop { flex-shrink: 0; }
}

/* 4 · STATS-CHARTS GROTER op mobiel · 1-kolom layout, charts pop */
@media (max-width: 880px) {
  .hero-stats-charts {
    grid-template-columns: 1fr 1fr !important;
    gap: 28px 20px !important;
    padding: 32px 0 40px !important;
  }
  .hero-stats-charts .item {
    padding: 0 !important;
    border-left: 0 !important;
    gap: 10px !important;
  }
  .hero-stats-charts .chart { height: 44px !important; }
  .hero-stats-charts .num { font-size: 32px !important; }
  .hero-stats-charts .lbl { font-size: 11px !important; opacity: 0.7 !important; }
}
@media (max-width: 480px) {
  .hero-stats-charts {
    grid-template-columns: 1fr 1fr !important;
    gap: 24px 16px !important;
  }
  .hero-stats-charts .chart { height: 38px !important; }
  .hero-stats-charts .chart-donut svg,
  .hero-stats-charts .chart-radar svg { width: 38px !important; height: 38px !important; }
  .hero-stats-charts .chart-grid svg { width: 72px !important; height: 32px !important; }
  .hero-stats-charts .num { font-size: 28px !important; }
}

/* 5 · TAP-FEEDBACK op alle CTA's · 0.96 scale 80ms */
.btn-primary, .btn-secondary, .btn-outline,
.search-submit, .nav-cta, .arrow-btn,
.apply-cta-big, .cf-submit, .mcb-primary, .mcb-wa {
  transition: transform .08s ease, background-color .15s, color .15s, box-shadow .15s;
}
.btn-primary:active, .btn-secondary:active, .btn-outline:active,
.search-submit:active, .nav-cta:active, .arrow-btn:active,
.apply-cta-big:active, .cf-submit:active, .mcb-primary:active, .mcb-wa:active {
  transform: scale(0.96);
}
/* Tap-targets pijl-pulse op cards */
.spec-card:active, .job-card:active, .aud-card:active, .route-card:active,
.download-card:active, .mail-card:active, .vg-tile:active {
  transform: scale(0.985);
  transition: transform .12s ease;
}

/* 6 · FOUNDER-FOTO VERTICAL MOBILE-CROP (face focus) */
.hero-side .hero-img-portrait img {
  object-fit: cover;
  object-position: center 22%; /* Gezicht in beeld, niet jas */
}

/* Cutout-variant: transparante PNG zonder achtergrond
   — geen overlay, geen border, jas mag bleeden tot rand */
.hero-side .hero-img-cutout {
  background: transparent !important;
  overflow: visible;
}
.hero-side .hero-img-cutout img {
  object-fit: contain;
  object-position: bottom center;
  filter: drop-shadow(0 20px 40px rgba(0, 0, 0, 0.35));
}
.hero-side .hero-img-cutout::after { display: none; }
.hero-side:has(.hero-img-cutout) { background: transparent; }
.hero-side:has(.hero-img-cutout) .img::after { display: none; }

/* hero-side-editorial CSS verwijderd op user-request — origineel behouden */

@media (max-width: 980px) {
  .hero-side { min-height: 360px !important; }
  .hero-side .hero-img-portrait img {
    object-position: center 18%; /* iets hoger op mobiel */
  }
}
@media (max-width: 480px) {
  .hero-side { min-height: 320px !important; }
  .hero-side .img::after {
    /* Donkere overlay onderaan zodat de badge leesbaar blijft */
    background: linear-gradient(180deg, rgba(12,38,27,0.05) 0%, rgba(12,38,27,0.4) 100%) !important;
  }
}

/* Disable reveal-animaties op tap-pages voor snelle paint op mobiel */
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1 !important; transform: none !important; }
  .hero-stats-charts .chart * { animation: none !important; }
}

/* === Vacature detail · Soortgelijke vacatures === */
.vd-similar { padding: 56px 0 24px; background: var(--paper); }
.vd-similar .vd-similar-head { max-width: 720px; margin-bottom: 28px; }
.vd-similar .vd-similar-head h2 {
  font-size: clamp(26px, 3vw, 36px);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin-bottom: 8px;
}
.vd-similar .vd-similar-head h2 em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  color: var(--green-text);
}
.vd-similar .vd-similar-head p { font-size: 15px; color: var(--muted); }
.vd-similar .vd-similar-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.vd-similar .job-card { text-decoration: none; color: inherit; }
.vd-similar-foot { margin-top: 28px; display: flex; justify-content: center; }
@media (max-width: 900px) {
  .vd-similar .vd-similar-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .vd-similar .vd-similar-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   VACATURE-DETAIL · S-TIER PREMIUM (overnight agent #5)
   ------------------------------------------------------------
   .vd-trust-strip   · 5-pill social proof onder hero
   .vd-salary-bar    · SVG min/max/median visual
   .vd-rail-sticky   · Desktop ≥1024px fixed-position apply card
   .vd-similar-card  · Mini-card variant van .job-card (icon + meta)
   .vd-print         · @media print overrides
   ============================================================ */

/* TRUST STRIP ─ onder vd-hero, conversion-anker */
.vd-trust-strip {
  background: var(--cream);
  border-top: 1px solid rgba(12, 38, 27, 0.06);
  border-bottom: 1px solid var(--rule);
}
.vd-trust-strip .vts-wrap {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 16px 0 18px;
}
.vd-trust-strip .vts-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--ink-2);
  font-family: var(--f-display);
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: 0.01em;
  white-space: nowrap;
}
.vd-trust-strip .vts-item svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  color: var(--green-text);
}
.vd-trust-strip .vts-item.is-star { color: #B45309; }
.vd-trust-strip .vts-item.is-star svg { color: #F59E0B; }
.vd-trust-strip .vts-sep {
  width: 3px;
  height: 3px;
  background: rgba(12, 38, 27, 0.25);
  border-radius: 50%;
  flex-shrink: 0;
}
@media (max-width: 760px) {
  .vd-trust-strip .vts-wrap { gap: 10px; padding: 14px 0 16px; }
  .vd-trust-strip .vts-item { font-size: 11.5px; }
  .vd-trust-strip .vts-sep { display: none; }
}

/* SALARY BAR ─ SVG min/median/max range in info-grid */
.vd-salary-bar {
  margin-top: 10px;
  padding: 14px 4px 6px;
}
.vd-salary-bar .vsb-svg {
  width: 100%;
  height: 28px;
  display: block;
  overflow: visible;
}
.vd-salary-bar .vsb-track { fill: rgba(12, 38, 27, 0.08); }
.vd-salary-bar .vsb-range { fill: var(--green-deep); }
.vd-salary-bar .vsb-mid   { fill: var(--green); stroke: var(--green-deep); stroke-width: 2; }
.vd-salary-bar .vsb-label {
  display: flex;
  justify-content: space-between;
  margin-top: 6px;
  font-family: var(--f-display);
  font-size: 11px;
  font-weight: 700;
  color: var(--muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.vd-salary-bar .vsb-label .vsb-mid-lbl {
  color: var(--green-text);
}

/* STICKY RIGHT-RAIL APPLY CARD ─ desktop only */
.vd-rail-sticky {
  display: none;
}
@media (min-width: 1280px) {
  .vd-rail-sticky {
    position: fixed;
    right: 24px;
    bottom: 24px;
    width: 280px;
    background: var(--green-deep);
    color: var(--cream);
    border-radius: 18px;
    padding: 18px 18px 16px;
    box-shadow: 0 18px 50px rgba(12, 38, 27, 0.28), 0 0 0 1px rgba(244, 236, 225, 0.06);
    z-index: 60;
    opacity: 0;
    transform: translateY(20px);
    pointer-events: none;
    transition: opacity .25s ease, transform .25s cubic-bezier(.2,.7,.2,1);
  }
  .vd-rail-sticky.is-visible {
    display: block;
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }
  .vd-rail-sticky.is-hidden { opacity: 0; transform: translateY(20px); pointer-events: none; }
  .vd-rail-sticky .vrs-title {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 14px;
    line-height: 1.25;
    color: var(--cream);
    margin-bottom: 4px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .vd-rail-sticky .vrs-salary {
    font-family: 'Fraunces', Georgia, serif;
    font-style: italic;
    font-size: 18px;
    font-weight: 300;
    color: var(--green);
    margin-bottom: 12px;
  }
  .vd-rail-sticky .vrs-cta {
    display: block;
    background: var(--green);
    color: var(--green-deep);
    text-align: center;
    padding: 11px 14px;
    border-radius: 999px;
    font-family: var(--f-display);
    font-weight: 800;
    font-size: 13.5px;
    text-decoration: none;
    border: 0;
    width: 100%;
    cursor: pointer;
    margin-bottom: 8px;
    transition: transform .12s ease;
  }
  .vd-rail-sticky .vrs-cta:hover { transform: translateY(-1px); }
  .vd-rail-sticky .vrs-wa {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    color: rgba(244, 236, 225, 0.82);
    font-family: var(--f-display);
    font-size: 12px;
    font-weight: 600;
    text-decoration: none;
  }
  .vd-rail-sticky .vrs-wa svg { width: 12px; height: 12px; color: #25D366; }
  .vd-rail-sticky .vrs-close {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: transparent;
    border: 0;
    color: rgba(244, 236, 225, 0.5);
    cursor: pointer;
    font-size: 16px;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .vd-rail-sticky .vrs-close:hover { color: var(--cream); background: rgba(244, 236, 225, 0.08); }
}

/* SIMILAR CARDS ─ enhanced .job-card variant met sector-tag/meta-icons */
.vd-similar-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 16px;
  padding: 20px;
  text-decoration: none;
  color: inherit;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.vd-similar-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(12, 38, 27, 0.08);
  border-color: var(--green-text);
}
.vd-similar-card .vsc-tag {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(12, 38, 27, 0.06);
  color: var(--green-text);
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.vd-similar-card .vsc-title {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 18px;
  line-height: 1.2;
  color: var(--ink);
  letter-spacing: -0.01em;
  margin: 2px 0 0;
}
.vd-similar-card .vsc-meta {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  color: var(--muted);
  font-family: var(--f-display);
  font-size: 12.5px;
  font-weight: 600;
}
.vd-similar-card .vsc-meta span {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.vd-similar-card .vsc-meta svg { width: 12px; height: 12px; color: var(--green-text); }
.vd-similar-card .vsc-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px solid var(--rule);
}
.vd-similar-card .vsc-salary {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-size: 17px;
  font-weight: 300;
  color: var(--green-text);
  letter-spacing: -0.01em;
}
.vd-similar-card .vsc-cta {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 13px;
  color: var(--green-text);
}

/* PRINT STYLESHEET ─ recruiters print vacancies */
@media print {
  /* Hide all chrome */
  header.nav, .nav,
  footer, .contact-cta,
  .cookie-bar, .cookie-banner,
  .mobile-cta-bar,
  .vd-rail-sticky,
  .vd-similar, .vd-similar-foot,
  .apply-cta-big, .apply-wa-link,
  .vd-aside,
  .trengo-floating-button,
  #trengo-web-widget, .trengo-widget-button,
  .live-edit-toolbar { display: none !important; }

  body {
    background: #fff !important;
    color: #000 !important;
    font-size: 11pt;
    line-height: 1.45;
    padding: 0 !important;
    margin: 0 !important;
  }
  .wrap { max-width: none !important; padding: 0 16mm !important; }
  main { padding-top: 0 !important; }

  .vd-hero {
    background: #fff !important;
    border: 0 !important;
    padding: 0 0 8mm 0 !important;
  }
  .vd-hero h1 {
    font-size: 22pt !important;
    color: #000 !important;
    margin: 4mm 0 3mm !important;
    page-break-after: avoid;
  }
  .vd-hero h1 em { color: #0c261b !important; font-style: italic !important; }
  .vd-crumbs { display: none !important; }
  .vd-meta {
    font-size: 10pt !important;
    color: #333 !important;
    gap: 12px !important;
  }
  .vd-meta span::before { background: #0c261b !important; }

  .vd-trust-strip {
    background: #fff !important;
    border-color: #ccc !important;
    page-break-inside: avoid;
  }
  .vd-trust-strip .vts-item { color: #333 !important; font-size: 9pt !important; }

  .vd-body { padding: 4mm 0 0 0 !important; background: #fff !important; }
  .vd-grid { grid-template-columns: 1fr !important; gap: 0 !important; }
  .vd-content { gap: 6mm !important; }
  .vd-section h2 {
    font-size: 14pt !important;
    color: #000 !important;
    page-break-after: avoid;
    margin-bottom: 3mm !important;
  }
  .vd-section h2 em { color: #0c261b !important; }
  .vd-section p, .vd-section li { font-size: 10.5pt !important; color: #111 !important; }
  .vd-section ul li::before { background: #0c261b !important; }

  .info-grid {
    page-break-inside: avoid;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 4mm !important;
  }
  .info-grid .row .v { color: #000 !important; font-size: 10.5pt !important; }
  .vd-salary-bar .vsb-track { fill: #e5e7eb !important; }
  .vd-salary-bar .vsb-range { fill: #0c261b !important; }
  .vd-salary-bar .vsb-mid   { fill: #88D932 !important; stroke: #0c261b !important; }

  /* Add print-only footer with canonical URL */
  .vd-print-footer {
    display: block !important;
    margin-top: 8mm;
    padding-top: 4mm;
    border-top: 1px solid #ccc;
    font-size: 8.5pt;
    color: #444;
  }

  a[href]::after { content: ""; } /* no link decorations */
  @page { margin: 14mm; size: A4; }
}
.vd-print-footer { display: none; }
/* =========================================================
   A11Y PASS — WCAG 2.1 AA (Update 11)
   Verzameld op één plek, overschrijft eerdere regels waar nodig.
   ========================================================= */

/* Screen-reader-only utility: visueel verborgen maar wel voorgelezen.
   Pair met focus-not-sr-only voor zichtbaarheid bij keyboard-navigatie. */
.sr-only {
  position: absolute !important;
  width: 1px !important; height: 1px !important;
  padding: 0 !important; margin: -1px !important;
  overflow: hidden !important; clip: rect(0,0,0,0) !important;
  white-space: nowrap !important; border: 0 !important;
}
.sr-only-focusable:not(:focus):not(:focus-within) {
  position: absolute !important;
  width: 1px !important; height: 1px !important;
  padding: 0 !important; margin: -1px !important;
  overflow: hidden !important; clip: rect(0,0,0,0) !important;
  white-space: nowrap !important; border: 0 !important;
}

/* Focus-visible: consistente, goed zichtbare ring voor alle interactieve
   elementen. 3px outline + 2-3px offset voor zichtbaarheid op alle
   achtergronden. Lichte achtergrond → groen-deep ring; donkere achtergrond
   (header/hero/footer) → felgroene ring. */
:focus-visible {
  outline: 3px solid var(--green-deep, #0C261B);
  outline-offset: 2px;
  border-radius: 4px;
  box-shadow: 0 0 0 5px rgba(140, 229, 90, 0.35);
}
/* Op donkere achtergronden de inverse: felgroen voor maximale zichtbaarheid */
.utility *:focus-visible,
header.nav *:focus-visible,
.nav *:focus-visible,
.hero *:focus-visible,
.aud-card.dark *:focus-visible,
.app *:focus-visible,
footer *:focus-visible,
.foot-top *:focus-visible,
.foot-bot *:focus-visible {
  outline: 3px solid var(--green-bright, #9CFF36);
  outline-offset: 2px;
  box-shadow: 0 0 0 5px rgba(12, 38, 27, 0.45);
}
/* Inputs / textareas / selects: ring binnen border + tonen */
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 3px solid var(--green-deep, #0C261B);
  outline-offset: 1px;
  border-color: var(--green-deep, #0C261B);
  box-shadow: 0 0 0 4px rgba(140, 229, 90, 0.30);
}
/* Voorkom dat we de outline weer uitzetten bij muis */
:focus:not(:focus-visible) { outline: none; box-shadow: none; }

/* Skip-link: zichtbaar bij focus, ook bij :focus-within voor toets-paden */
.skip-link:focus, .skip-link:focus-visible {
  top: 12px !important;
  outline: 3px solid var(--green-bright, #9CFF36);
  outline-offset: 2px;
}

/* Heading hierarchie hint — voorkom dat h4/h5 in mockups e.d. door
   screen-readers fout begrepen worden: phone-mock h4 als rol="text". */

/* Color-contrast fixes voor groen-op-cream text-only */
.accent-text { color: var(--green-text); }
/* Specifieke fixes voor de gevallen waar groen op licht stond */
.contact-grid h2 .accent { color: var(--green-text); }
.vd-similar .vd-similar-head h2 em { color: var(--green-text); }
.hero-side .panel .stat-num em { color: var(--green-text); }
.search-suggest .item .meta { color: var(--muted); }

/* Cookie-banner: link contrast omhoog (was #6FB827 → 2.06:1 op cream) */
.fh-cc-bar .fh-cc-text a { color: #2E6A0A !important; }
.fh-cc-cat-always { color: #2E6A0A !important; }

/* Touch-targets: zorg dat ALLE interactieve elementen ≥44×44 zijn op mobile */
@media (max-width: 980px) {
  .lang-dropdown summary {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    padding: 8px 14px;
  }
  .lang-dropdown .lang-menu a {
    min-height: 44px;
    display: flex;
    align-items: center;
  }
  .vac-save, .save-btn {
    min-width: 44px;
    min-height: 44px;
  }
  .af-close-btn,
  .af-cv-remove,
  button[aria-label*="lose"],
  button[aria-label*="luiten"] {
    min-width: 44px;
    min-height: 44px;
  }
  /* Filter-checkboxes/labels in filter-panel: vergroot tap-zone */
  .filter-panel label,
  .vac-filters label {
    min-height: 40px;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 0;
  }
}

/* Sterker prefers-reduced-motion respect:
   - geen pulse/dot-animaties
   - geen confetti
   - geen marquee-loop */
@media (prefers-reduced-motion: reduce) {
  .utility-left .live-dot::before,
  .badge-pulse,
  .pulse-dot,
  .af-confetti,
  .clients-marquee .track,
  .marquee .track {
    animation: none !important;
  }
  .af-drawer { transition: none !important; }
  .af-overlay { transition: none !important; }
}

/* ARIA-busy: visueel feedback op submitting buttons */
button[aria-busy="true"],
[aria-busy="true"] button[type="submit"] {
  position: relative;
  cursor: progress;
  opacity: 0.7;
}
button[aria-busy="true"]::after {
  content: "";
  position: absolute;
  right: 12px; top: 50%;
  width: 14px; height: 14px;
  margin-top: -7px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: a11ySpin 0.7s linear infinite;
}
@keyframes a11ySpin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) {
  button[aria-busy="true"]::after { animation: none !important; opacity: 0.6; }
}

/* Error-states: stuur screen-readers via aria-invalid */
input[aria-invalid="true"],
textarea[aria-invalid="true"],
select[aria-invalid="true"] {
  border-color: #C8270B !important;
  box-shadow: 0 0 0 2px rgba(200, 39, 11, 0.18);
}

/* Forced-colors (Windows hoog-contrast) ondersteuning */
@media (forced-colors: active) {
  :focus-visible {
    outline: 3px solid CanvasText !important;
    box-shadow: none !important;
  }
  .skip-link:focus { outline: 3px solid Highlight !important; }
  .btn-primary, .btn-secondary, .btn-outline {
    border: 1px solid CanvasText;
  }
}

/* ============================================================
   VERHALEN / STORIES — index grid + detail pages
   ============================================================ */

/* Index filter chips */
.stories-filter { display: flex; gap: 8px; flex-wrap: wrap; margin: 0 0 28px; padding: 0; list-style: none; }
.stories-filter .chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-radius: 999px;
  border: 1px solid var(--rule); background: var(--paper); color: var(--ink);
  font-family: var(--f-display); font-weight: 600; font-size: 13px;
  cursor: pointer; transition: all .18s ease; text-decoration: none;
}
.stories-filter .chip:hover { border-color: var(--green-text); color: var(--green-text); }
.stories-filter .chip.is-active { background: var(--green-deep); color: var(--cream); border-color: var(--green-deep); }
.stories-filter .chip .count { opacity: .55; font-size: 12px; }

/* Stories grid */
.stories-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
@media (max-width: 980px) { .stories-grid { grid-template-columns: repeat(2, 1fr); gap: 22px; } }
@media (max-width: 640px) { .stories-grid { grid-template-columns: 1fr; gap: 18px; } }

.story-card {
  display: flex; flex-direction: column;
  background: var(--paper); border: 1px solid var(--rule); border-radius: 14px;
  overflow: hidden; text-decoration: none; color: inherit;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  position: relative;
}
.story-card:hover { transform: translateY(-3px); border-color: var(--green-text); box-shadow: 0 14px 34px rgba(12,38,27,.10); }
.story-card .sc-photo { position: relative; aspect-ratio: 16 / 9; overflow: hidden; background: var(--cream); }
.story-card .sc-photo img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .6s ease; }
.story-card:hover .sc-photo img { transform: scale(1.04); }
.story-card .sc-tag {
  position: absolute; top: 12px; left: 12px;
  display: inline-flex; align-items: center; gap: 4px;
  padding: 5px 10px; border-radius: 999px; font-size: 11px;
  font-family: var(--f-display); font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
  background: rgba(12,38,27,.92); color: var(--cream); backdrop-filter: blur(8px);
}
.story-card .sc-tag.tag-klant { background: rgba(12,38,27,.92); }
.story-card .sc-tag.tag-vakkracht { background: rgba(136,217,50,.95); color: var(--green-deep); }
.story-card .sc-body { padding: 22px 22px 24px; display: flex; flex-direction: column; flex: 1; }
.story-card .sc-name { font-family: var(--f-display); font-weight: 700; font-size: 19px; line-height: 1.2; color: var(--ink); margin: 0 0 4px; letter-spacing: -.01em; }
.story-card .sc-role { font-size: 13px; color: var(--muted); margin: 0 0 14px; }
.story-card .sc-teaser { font-size: 14.5px; line-height: 1.55; color: var(--ink); margin: 0 0 18px; flex: 1; }
.story-card .sc-link { display: inline-flex; align-items: center; gap: 6px; font-family: var(--f-display); font-weight: 700; font-size: 14px; color: var(--green-text); margin-top: auto; }
.story-card:hover .sc-link { gap: 10px; }

/* Index "share your story" CTA */
.story-share-cta {
  background: var(--cream); border: 1px dashed var(--rule); border-radius: 16px;
  padding: 40px 36px; display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: center;
  margin-top: 56px;
}
.story-share-cta h3 { font-family: var(--f-display); font-weight: 700; font-size: 22px; margin: 0 0 6px; color: var(--ink); }
.story-share-cta p { margin: 0; color: var(--muted); font-size: 15px; line-height: 1.55; }
@media (max-width: 720px) { .story-share-cta { grid-template-columns: 1fr; padding: 28px 24px; } }

/* ============= STORY DETAIL PAGE ============= */

/* Hero with photo */
.story-hero { position: relative; background: var(--green-deep); color: var(--cream); padding: 72px 0 88px; overflow: hidden; }
.story-hero::before {
  content: ""; position: absolute; inset: 0;
  background-image: radial-gradient(circle at 80% 20%, rgba(136,217,50,.10), transparent 50%);
  pointer-events: none;
}
.story-hero .wrap { max-width: 1180px; position: relative; z-index: 1; }
.story-hero .crumbs { font-size: 13px; color: rgba(247,243,232,.65); margin-bottom: 28px; }
.story-hero .crumbs a { color: rgba(247,243,232,.65); text-decoration: none; }
.story-hero .crumbs a:hover { color: var(--green-bright, #88D932); }
.story-hero .crumbs .sep { margin: 0 8px; opacity: .4; }
.story-hero .sh-grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: 56px; align-items: center; }
@media (max-width: 900px) { .story-hero .sh-grid { grid-template-columns: 1fr; gap: 32px; } }
.story-hero .sh-eyebrow { display: inline-block; font-family: var(--f-display); font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--green-bright, #88D932); margin-bottom: 18px; }
.story-hero h1 { font-family: var(--f-display); font-weight: 700; font-size: clamp(36px, 5vw, 64px); line-height: 1.02; letter-spacing: -.025em; margin: 0 0 18px; color: var(--cream); }
.story-hero h1 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 300; color: var(--green-bright, #88D932); }
.story-hero .sh-role { font-size: 17px; color: rgba(247,243,232,.8); margin: 0 0 24px; line-height: 1.5; }
.story-hero .sh-meta { display: flex; gap: 28px; flex-wrap: wrap; font-size: 13px; color: rgba(247,243,232,.6); }
.story-hero .sh-meta .item { display: flex; flex-direction: column; gap: 2px; }
.story-hero .sh-meta .item .lbl { font-size: 11px; text-transform: uppercase; letter-spacing: .08em; opacity: .7; }
.story-hero .sh-meta .item .val { font-family: var(--f-display); font-weight: 600; color: var(--cream); font-size: 15px; }
.story-hero .sh-photo { position: relative; border-radius: 18px; overflow: hidden; aspect-ratio: 4 / 5; box-shadow: 0 24px 60px rgba(0,0,0,.35); }
.story-hero .sh-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Pull-quote */
.story-pullquote {
  background: var(--cream); padding: 64px 0;
  position: relative;
}
.story-pullquote .wrap { max-width: 880px; }
.story-pullquote blockquote {
  margin: 0; padding: 0;
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic; font-weight: 300;
  font-size: clamp(26px, 3.4vw, 40px);
  line-height: 1.25; letter-spacing: -.015em;
  color: var(--ink);
  text-align: center;
  position: relative;
}
.story-pullquote blockquote::before {
  content: "\201C"; position: absolute; top: -36px; left: 50%; transform: translateX(-50%);
  font-size: 96px; color: var(--green-text); opacity: .25; line-height: 1;
}
.story-pullquote cite { display: block; margin-top: 24px; font-style: normal; font-family: var(--f-display); font-size: 13px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--muted); }

/* Body + sidebar layout */
.story-body-section { padding: 72px 0 96px; background: var(--paper); }
.story-body-section .wrap { max-width: 1180px; }
.story-body-grid { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 64px; align-items: start; }
@media (max-width: 980px) { .story-body-grid { grid-template-columns: 1fr; gap: 40px; } }

.story-body { font-size: 17px; line-height: 1.7; color: var(--ink); }
.story-body h3 {
  font-family: var(--f-display); font-weight: 700;
  font-size: 21px; letter-spacing: -.01em;
  margin: 36px 0 12px; color: var(--green-deep);
}
.story-body h3:first-child { margin-top: 0; }
.story-body h3::before { content: "Q. "; color: var(--green-text); font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 400; }
.story-body p { margin: 0 0 18px; }
.story-body p strong { color: var(--green-deep); }

/* Sidebar */
.story-sidebar { display: flex; flex-direction: column; gap: 24px; position: sticky; top: 100px; }
.story-sidebar .ss-card {
  background: var(--cream); border: 1px solid var(--rule); border-radius: 14px; padding: 26px 24px;
}
.story-sidebar .ss-card.dark { background: var(--green-deep); color: var(--cream); border-color: var(--green-deep); }
.story-sidebar .ss-card h4 {
  font-family: var(--f-display); font-weight: 700;
  font-size: 13px; letter-spacing: .08em; text-transform: uppercase;
  margin: 0 0 16px; color: var(--green-text);
}
.story-sidebar .ss-card.dark h4 { color: var(--green-bright, #88D932); }
.story-sidebar .ss-card ul { margin: 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 12px; }
.story-sidebar .ss-card li {
  font-size: 14.5px; line-height: 1.5; color: var(--ink);
  padding-left: 22px; position: relative;
}
.story-sidebar .ss-card.dark li { color: rgba(247,243,232,.88); }
.story-sidebar .ss-card li::before {
  content: ""; position: absolute; left: 0; top: 8px;
  width: 12px; height: 2px; background: var(--green-ink); border-radius: 2px;
}
.story-sidebar .ss-card.dark li::before { background: var(--green-bright, #88D932); }
.story-sidebar .ss-card p { font-size: 14.5px; line-height: 1.55; margin: 0 0 16px; }
.story-sidebar .ss-card .btn-primary,
.story-sidebar .ss-card .btn-secondary { display: inline-flex; width: 100%; justify-content: center; }

@media (max-width: 980px) { .story-sidebar { position: static; } }

/* Photo gallery */
.story-gallery { padding: 0 0 80px; background: var(--paper); }
.story-gallery .wrap { max-width: 1180px; }
.story-gallery h3 {
  font-family: var(--f-display); font-weight: 700;
  font-size: 13px; letter-spacing: .08em; text-transform: uppercase;
  color: var(--green-text); margin: 0 0 20px;
}
.story-gallery .sg-grid {
  display: grid; gap: 16px;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: 240px 240px;
}
.story-gallery .sg-grid figure { margin: 0; border-radius: 14px; overflow: hidden; background: var(--cream); }
.story-gallery .sg-grid figure:nth-child(1) { grid-row: 1 / span 2; }
.story-gallery .sg-grid figure img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .6s ease; }
.story-gallery .sg-grid figure:hover img { transform: scale(1.03); }
@media (max-width: 720px) {
  .story-gallery .sg-grid { grid-template-columns: 1fr 1fr; grid-template-rows: 200px 200px 200px; }
  .story-gallery .sg-grid figure:nth-child(1) { grid-row: 1; grid-column: 1 / span 2; }
}

/* Read also */
.story-readalso { padding: 80px 0; background: var(--cream); border-top: 1px solid var(--rule); }
.story-readalso .wrap { max-width: 1180px; }
.story-readalso .ra-head {
  display: flex; justify-content: space-between; align-items: end; gap: 24px; margin-bottom: 32px; flex-wrap: wrap;
}
.story-readalso .ra-head h2 { font-family: var(--f-display); font-weight: 700; font-size: clamp(28px, 3.5vw, 40px); line-height: 1; letter-spacing: -.02em; margin: 0; }
.story-readalso .ra-head h2 em { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-weight: 300; color: var(--green-text); }
.story-readalso .ra-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
@media (max-width: 720px) { .story-readalso .ra-grid { grid-template-columns: 1fr; } }

/* ============================================================
   MOBILE-UX POLISH — bottom-nav, drawer-enhance, swipe, suggest
   night-agent-8 · S-tier touch-feedback + safe-area
============================================================ */

/* -------- 1 · MOBILE BOTTOM-NAV (Liquid Glass — iOS 26 stijl) ----- */
/* Floating glass-island met heavy backdrop-blur, specular highlight,
   inner refraction-glow, en lichte hue-shift via content erachter.   */
.mb-nav {
  display: none;
  position: fixed;
  /* Floating island: marge van de schermrand voor liquid-glass feel */
  left: 14px; right: 14px;
  bottom: calc(14px + env(safe-area-inset-bottom, 0px));
  z-index: 75;
  /* Multi-layer liquid background: subtle gradient + tint */
  background:
    linear-gradient(135deg,
      rgba(255, 255, 255, 0.62) 0%,
      rgba(252, 247, 242, 0.48) 50%,
      rgba(248, 244, 238, 0.56) 100%);
  /* Heavy blur + saturatie boost + lichte brightness voor refraction-feel */
  -webkit-backdrop-filter: saturate(1.9) blur(40px) brightness(1.04);
  backdrop-filter: saturate(1.9) blur(40px) brightness(1.04);
  /* Pill-shape voor het hele eiland — liquid glass voelt rond */
  border-radius: 28px;
  padding: 10px 12px;
  /* Border + outer shadow + edge lighting */
  border: 1px solid rgba(255, 255, 255, 0.45);
  box-shadow:
    /* outer soft drop */
    0 18px 40px -8px rgba(8, 24, 17, 0.22),
    0 6px 18px -4px rgba(8, 24, 17, 0.12),
    /* edge specular highlights — als licht dat door glas weerkaatst */
    inset 0 1px 0 rgba(255, 255, 255, 0.65),
    inset 0 -1px 0 rgba(12, 38, 27, 0.04),
    inset 1px 0 0 rgba(255, 255, 255, 0.20),
    inset -1px 0 0 rgba(255, 255, 255, 0.20);
  transition:
    transform .32s cubic-bezier(.2,.78,.2,1),
    opacity .25s ease,
    bottom .25s cubic-bezier(.2,.78,.2,1);
  isolation: isolate;
}
/* Specular highlight aan top — moet een "licht-weerkaatsing" suggereren */
.mb-nav::before {
  content: '';
  position: absolute;
  top: 1px; left: 12%; right: 12%;
  height: 1px;
  background: linear-gradient(to right,
    transparent 0%,
    rgba(255, 255, 255, 0.85) 30%,
    rgba(255, 255, 255, 0.95) 50%,
    rgba(255, 255, 255, 0.85) 70%,
    transparent 100%);
  pointer-events: none;
  z-index: 2;
  border-radius: 999px;
}
/* Soft inner glow — voor extra "liquid" diepte */
.mb-nav::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 28px;
  pointer-events: none;
  background:
    radial-gradient(80% 60% at 50% -10%, rgba(255, 255, 255, 0.35) 0%, transparent 60%),
    radial-gradient(60% 80% at 50% 110%, rgba(140, 217, 50, 0.06) 0%, transparent 70%);
  z-index: 1;
}
.mb-nav.is-hidden { transform: translateY(calc(100% + 20px)); }
.mb-nav.is-keyboard { transform: translateY(calc(100% + 20px)) !important; }
.mb-nav > * { display: contents; }
.mb-nav nav, .mb-nav { display: flex; }
@media (max-width: 760px) {
  .mb-nav { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px; }
  body.has-mb-nav { padding-bottom: calc(100px + env(safe-area-inset-bottom, 0px)) !important; }
  body.has-mb-nav .mobile-cta-bar {
    bottom: calc(98px + env(safe-area-inset-bottom, 0px)) !important;
  }
}
.mb-nav-item {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 4px;
  padding: 6px 4px 4px;
  min-height: 56px;
  text-decoration: none;
  color: #5A6760;
  border-radius: 18px;
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  font-size: 10.5px;
  letter-spacing: 0.015em;
  transition:
    color .22s cubic-bezier(.2,.7,.2,1),
    transform .14s cubic-bezier(.4,1.5,.5,1);
  position: relative;
  z-index: 3;  /* boven ::before en ::after pseudo-elementen van .mb-nav */
  -webkit-tap-highlight-color: transparent;
  isolation: isolate;
}
/* Icoon-container: krijgt bij active een groene pill als achtergrond */
.mb-nav-ico {
  position: relative;
  display: flex; align-items: center; justify-content: center;
  width: 44px; height: 30px;
  border-radius: 999px;
  transition:
    background-color .25s cubic-bezier(.2,.7,.2,1),
    transform .14s cubic-bezier(.4,1.5,.5,1),
    box-shadow .25s ease;
  z-index: 1;
}
.mb-nav-ico svg {
  width: 22px; height: 22px;
  display: block;
  transition: transform .2s cubic-bezier(.4,1.5,.5,1), stroke-width .2s ease;
}
.mb-nav-lbl {
  display: block;
  line-height: 1;
  transition: color .22s ease, font-weight .22s ease;
}

/* Touch feedback — kleine "haptic-spring" bij press */
.mb-nav-item:active .mb-nav-ico { transform: scale(0.88); }
.mb-nav-item:active .mb-nav-lbl { transform: scale(0.97); }
.mb-nav-item:hover:not(.is-active) { color: #0c261b; }
.mb-nav-item:hover:not(.is-active) .mb-nav-ico { background: rgba(140, 217, 50, 0.10); }

/* ===== ACTIVE STATE: liquid green pill met inner refraction ===== */
.mb-nav-item.is-active { color: #0c261b; }
.mb-nav-item.is-active .mb-nav-ico {
  background:
    /* Multi-stop gradient voor liquid-feel diepte */
    radial-gradient(120% 90% at 30% 20%, rgba(255, 255, 255, 0.40) 0%, transparent 50%),
    linear-gradient(135deg, #A6E847 0%, #88D932 55%, #6FBF24 100%);
  box-shadow:
    /* Outer halo voor "glowing through glass" effect */
    0 4px 12px rgba(140, 217, 50, 0.32),
    0 1px 3px rgba(111, 191, 36, 0.45),
    /* Edge specular */
    0 0 0 1px rgba(111, 191, 36, 0.25),
    inset 0 1px 0 rgba(255, 255, 255, 0.55),
    inset 0 -1px 1px rgba(74, 125, 29, 0.20);
}
.mb-nav-item.is-active .mb-nav-ico svg {
  color: #0c261b;
  stroke-width: 2.2;
  filter: drop-shadow(0 0.5px 0 rgba(255, 255, 255, 0.45));
}
.mb-nav-item.is-active .mb-nav-lbl {
  font-weight: 700;
  color: #0c261b;
}

/* -------- 2 · DRAWER POLISH — Premium slide-in met stagger ----- */
/* iOS-stijl spring-curve, liquid-glass backdrop met diepere blur,
   items staggeren in via fade+translate voor "in stappen" feel. */
.nav-backdrop {
  position: fixed; inset: 0;
  background: linear-gradient(135deg, rgba(8, 24, 17, 0.38) 0%, rgba(12, 38, 27, 0.50) 100%);
  -webkit-backdrop-filter: blur(14px) saturate(1.4);
  backdrop-filter: blur(14px) saturate(1.4);
  z-index: 88;
  opacity: 0;
  pointer-events: none;
  /* Backdrop iets vertraagd zodat drawer eerst start te bewegen */
  transition: opacity .42s cubic-bezier(.2,.78,.2,1) .04s;
  will-change: opacity;
  /* Stop scroll-bubble naar body */
  overscroll-behavior: contain;
  touch-action: none;  /* backdrop is niet scrollbaar */
}
.nav-backdrop.is-visible { opacity: 1; pointer-events: auto; }
@media (min-width: 981px) { .nav-backdrop { display: none !important; } }

@media (max-width: 980px) {
  /* DRAWER: premium spring slide + liquid glass background */
  /* `display: flex` is hier nodig om line 357 (`display:none`) te overrulen —
     drawer wordt zichtbaar gemaakt via transform i.p.v. display-toggle. */
  .nav-links {
    display: flex !important;
    width: min(86vw, 360px) !important;
    left: auto !important;
    right: 0 !important;
    /* Explicit height — top:0 + bottom:0 wordt soms in flex-context als
       content-height berekend; expliciet 100dvh (dynamic viewport) maakt
       de drawer altijd full-height op mobiele browsers met chrome-bars. */
    height: 100dvh !important;
    top: 0 !important;
    /* CRITISCH: voorkom scroll-chain naar body als je in de drawer scrollt
       en het einde raakt. Zonder dit "springt" de body en raak je positie kwijt. */
    overscroll-behavior: contain !important;
    overscroll-behavior-y: contain !important;
    -webkit-overflow-scrolling: touch !important; /* iOS momentum-scroll */
    overflow-y: auto !important;
    overflow-x: hidden !important;
    touch-action: pan-y !important;  /* alleen verticaal scrollen toegestaan */
    /* Liquid glass background — laat hero-content subtiel door */
    background: linear-gradient(180deg, rgba(252, 247, 242, 0.97) 0%, rgba(248, 244, 238, 0.95) 100%) !important;
    -webkit-backdrop-filter: blur(30px) saturate(1.6) !important;
    backdrop-filter: blur(30px) saturate(1.6) !important;
    /* Soft outer shadow + edge highlights voor depth */
    box-shadow:
      -24px 0 60px -8px rgba(8, 24, 17, 0.28),
      -2px 0 12px -2px rgba(8, 24, 17, 0.12),
      inset 1px 0 0 rgba(255, 255, 255, 0.40) !important;
    border-top: 0 !important;
    /* iOS-style spring curve — natuurlijke acceleratie + zachte landing */
    transition: transform .45s cubic-bezier(.32, .72, .24, 1) !important;
    padding-top: calc(80px + env(safe-area-inset-top, 0px)) !important;
    padding-bottom: calc(120px + env(safe-area-inset-bottom, 0px)) !important;
    will-change: transform;
  }

  /* ITEMS staggeren in als drawer opent — voor "in lagen" gevoel */
  .nav-links .item {
    opacity: 0;
    transform: translateX(20px);
    transition:
      opacity .35s cubic-bezier(.2,.78,.2,1),
      transform .42s cubic-bezier(.2,.78,.2,1);
  }
  .nav.nav-open .nav-links .item {
    opacity: 1;
    transform: translateX(0);
  }
  /* Stagger delays — elk item komt 50ms later binnen */
  .nav.nav-open .nav-links .item:nth-child(1) { transition-delay: .12s; }
  .nav.nav-open .nav-links .item:nth-child(2) { transition-delay: .17s; }
  .nav.nav-open .nav-links .item:nth-child(3) { transition-delay: .22s; }
  .nav.nav-open .nav-links .item:nth-child(4) { transition-delay: .27s; }
  .nav.nav-open .nav-links .item:nth-child(5) { transition-delay: .32s; }
  .nav.nav-open .nav-links .item:nth-child(6) { transition-delay: .37s; }
  .nav.nav-open .nav-links .item:nth-child(7) { transition-delay: .42s; }
  /* Footer (lang + contact) komt als laatste binnen */
  .nav-links .mb-drawer-foot {
    opacity: 0;
    transform: translateX(20px);
    transition:
      opacity .4s cubic-bezier(.2,.78,.2,1),
      transform .45s cubic-bezier(.2,.78,.2,1);
  }
  .nav.nav-open .nav-links .mb-drawer-foot {
    opacity: 1;
    transform: translateX(0);
    transition-delay: .42s;
  }

  /* Chevron-collapse: sub-menus default verborgen op mobiel */
  .nav-links .item.has-mega > .mega {
    max-height: 0 !important;
    overflow: hidden !important;
    padding: 0 0 0 8px !important;
    transition: max-height .35s cubic-bezier(.2,.78,.2,1) !important;
  }
  .nav-links .item.has-mega.mb-open > .mega {
    max-height: 800px !important;
    padding: 0 0 14px 8px !important;
  }
  /* Hide existing ▾ injected via ::after — we now use a real chevron button */
  .nav-links .item.has-mega > a::after { display: none !important; }
  .mb-chevron {
    position: absolute;
    right: 8px;
    top: 8px;
    width: 44px; height: 44px;
    display: flex; align-items: center; justify-content: center;
    background: transparent;
    border: 0;
    color: var(--green-text);
    cursor: pointer;
    border-radius: 10px;
    transition:
      background .18s ease,
      transform .35s cubic-bezier(.34, 1.56, .64, 1);
    -webkit-tap-highlight-color: transparent;
  }
  .mb-chevron svg { width: 18px; height: 18px; transition: transform .35s cubic-bezier(.34,1.56,.64,1); }
  .mb-chevron:hover { background: rgba(140, 217, 50, 0.12); }
  .mb-chevron:active { background: rgba(140, 217, 50, 0.22); transform: scale(0.92); }
  .item.mb-open > .mb-chevron { color: #0c261b; }
  .item.mb-open > .mb-chevron svg { transform: rotate(180deg); }
  .nav-links .item.has-mega { position: relative; }
  .nav-links .item.has-mega > a { padding-right: 56px !important; }
}

/* ===== Burger button: bouncier spring-anim ===== */
.nav-burger span {
  transition:
    transform .38s cubic-bezier(.34, 1.56, .64, 1),
    opacity .2s cubic-bezier(.2,.78,.2,1) !important;
  transform-origin: center !important;
}
.nav-burger:active { transform: scale(0.92); }
.nav-burger {
  transition: border-color .15s, background .15s, transform .14s cubic-bezier(.4,1.5,.5,1) !important;
}

/* Body-lock: gebruik position:fixed ipv overflow:hidden om scroll-jump te
   voorkomen wanneer je drawer sluit. JS moet scroll-Y opslaan/restoren. */
body.nav-locked {
  position: fixed;
  width: 100%;
  overflow-y: scroll; /* houdt scrollbar zichtbaar zodat content niet shift */
}

/* Drawer footer (lang + contact) — alleen zichtbaar in mobile-drawer (≤900px) */
.mb-drawer-foot {
  margin-top: 24px;
  padding: 20px 8px 0;
  border-top: 1px solid rgba(12, 38, 27, 0.08);
  display: none; /* default verborgen op desktop */
}
@media (max-width: 900px) {
  .mb-drawer-foot { display: block; }
}
.mb-drawer-lang { margin-bottom: 18px; }
.mb-foot-label {
  display: block;
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 700;
  color: #8A8478;
  margin-bottom: 8px;
}
.mb-lang-buttons {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
}
.mb-lang-btn {
  display: flex; align-items: center; justify-content: center;
  min-height: 44px;
  border: 1px solid rgba(12, 38, 27, 0.12);
  border-radius: 8px;
  background: #fff;
  text-decoration: none;
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
  font-size: 12px;
  color: #0c261b;
  letter-spacing: 0.04em;
  transition: background .15s, border-color .15s, color .15s, transform .08s;
}
.mb-lang-btn:active { transform: scale(0.96); }
.mb-lang-btn:hover { border-color: var(--green, #88D932); background: rgba(140, 217, 50, 0.08); }
.mb-lang-btn.is-active {
  background: var(--green-deep, #0c261b);
  color: #fff;
  border-color: var(--green-deep, #0c261b);
}
.mb-drawer-contact { display: flex; flex-direction: column; gap: 10px; }
.mb-drawer-tel, .mb-drawer-addr {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px;
  background: rgba(252, 247, 242, 0.6);
  border: 1px solid rgba(12, 38, 27, 0.08);
  border-radius: 12px;
  text-decoration: none;
  color: #0c261b;
  min-height: 56px;
  transition: background .15s, border-color .15s;
}
.mb-drawer-tel:hover { background: rgba(140, 217, 50, 0.08); border-color: var(--green, #88D932); }
.mb-drawer-tel svg, .mb-drawer-addr svg { width: 22px; height: 22px; color: var(--green-text); flex-shrink: 0; }
.mb-drawer-tel small, .mb-drawer-addr small {
  display: block; font-size: 10px; letter-spacing: .1em; text-transform: uppercase;
  font-weight: 700; color: #8A8478;
}
.mb-drawer-tel strong, .mb-drawer-addr strong {
  display: block; font-family: 'Poppins', sans-serif; font-weight: 700;
  font-size: 14px; color: #0c261b; margin-top: 1px;
}

/* -------- 3 · SEARCH-SUGGEST DROPDOWN ----------------------- */
/* search-suggest.js mounts a .search-suggest dropdown — override the
   existing legacy rule so it shows when not [hidden] (no data-open needed). */
.search-suggest:not([hidden]) { display: block; }
.search-suggest {
  position: absolute;
  top: calc(100% + 4px);
  left: 0; right: 0;
  background: #fff;
  border: 1px solid rgba(12, 38, 27, 0.10);
  border-radius: 12px;
  box-shadow: 0 16px 32px rgba(8, 24, 17, 0.12);
  z-index: 60;
  overflow: hidden;
  max-height: 320px;
  overflow-y: auto;
  padding: 4px;
}
.ssg-item {
  display: block;
  width: 100%;
  text-align: left;
  padding: 12px 14px;
  background: transparent;
  border: 0;
  border-radius: 8px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 500;
  color: #0c261b;
  cursor: pointer;
  min-height: 44px;
  transition: background .12s;
}
.ssg-item:hover, .ssg-item.is-active {
  background: rgba(140, 217, 50, 0.12);
  color: var(--green-deep, #0c261b);
}
.ssg-item mark {
  background: transparent;
  color: var(--green-deep, #4a7d1d);
  font-weight: 700;
}
@media (max-width: 760px) {
  .search-suggest {
    position: fixed;
    left: 12px; right: 12px;
    top: auto;
    bottom: calc(env(safe-area-inset-bottom, 0px) + 12px);
    max-height: 40vh;
    border-radius: 14px;
    box-shadow: 0 -10px 30px rgba(8, 24, 17, 0.18);
  }
}

/* -------- 4 · VACATURE STACK SWIPE -------------------------- */
.vac-view-toggle {
  display: inline-flex;
  align-items: center; gap: 8px;
  padding: 10px 14px;
  background: #fff;
  border: 1.5px solid rgba(12, 38, 27, 0.12);
  border-radius: 999px;
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
  font-size: 12px;
  color: #0c261b;
  cursor: pointer;
  min-height: 44px;
  margin-bottom: 14px;
  transition: border-color .15s, background .15s, transform .08s;
}
.vac-view-toggle:active { transform: scale(0.97); }
.vac-view-toggle:hover { border-color: var(--green, #88D932); background: rgba(140, 217, 50, 0.06); }
.vac-view-toggle[aria-pressed="true"] {
  background: var(--green-deep, #0c261b);
  color: #fff; border-color: var(--green-deep, #0c261b);
}
.vac-view-toggle svg { width: 16px; height: 16px; }

.vac-stack {
  margin: 16px 0 32px;
}
.vac-stack-cards {
  position: relative;
  height: 460px;
  max-width: 360px;
  margin: 0 auto;
}
.vac-swipe-card {
  position: absolute;
  inset: 0;
  background: #fff;
  border-radius: 20px;
  box-shadow: 0 12px 28px rgba(8, 24, 17, 0.14), 0 1px 0 rgba(12,38,27,0.04);
  padding: 22px 22px 60px;
  overflow: hidden;
  transition: transform .26s ease, opacity .26s ease;
  cursor: grab;
  display: flex;
  flex-direction: column;
  transform: scale(calc(1 - var(--stack-idx, 0) * 0.04)) translateY(calc(var(--stack-idx, 0) * 8px));
  z-index: calc(100 - var(--stack-idx, 0));
  opacity: calc(1 - var(--stack-idx, 0) * 0.18);
}
.vac-swipe-card.is-dragging { cursor: grabbing; transition: none; }
.vsc-link { display: flex; flex-direction: column; gap: 10px; text-decoration: none; color: inherit; flex: 1; min-width: 0; }
.vsc-head { display: flex; align-items: center; gap: 8px; }
.vsc-sector {
  display: inline-block;
  padding: 4px 10px;
  background: rgba(140, 217, 50, 0.14);
  color: var(--green-deep, #4a7d1d);
  border-radius: 999px;
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.vsc-title {
  font-family: 'Poppins', sans-serif;
  font-weight: 800;
  font-size: 22px;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: #0c261b;
  margin: 0;
}
.vsc-meta {
  display: flex; flex-wrap: wrap; gap: 8px 16px;
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  font-size: 13px;
  color: #5a6961;
}
.vsc-loc { display: inline-flex; align-items: center; gap: 4px; }
.vsc-salary { font-weight: 700; color: var(--green-deep, #4a7d1d); }
.vsc-hint {
  position: absolute;
  bottom: 14px; left: 22px; right: 22px;
  font-size: 11px;
  font-weight: 600;
  color: #8A8478;
  text-align: center;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.vsc-stamp {
  position: absolute;
  top: 28px;
  font-family: 'Poppins', sans-serif;
  font-weight: 800;
  font-size: 18px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 8px 18px;
  border-radius: 8px;
  border: 3px solid currentColor;
  opacity: 0;
  transition: opacity .15s;
  pointer-events: none;
}
.vsc-stamp-save {
  right: 22px;
  color: #16A34A;
  transform: rotate(15deg);
}
.vsc-stamp-skip {
  left: 22px;
  color: #ef4444;
  transform: rotate(-15deg);
}
.vac-swipe-card.show-save .vsc-stamp-save { opacity: 1; }
.vac-swipe-card.show-skip .vsc-stamp-skip { opacity: 1; }
.vac-stack-actions {
  display: flex; justify-content: center; gap: 24px;
  margin-top: 24px;
}
.vac-stack-btn {
  width: 60px; height: 60px;
  border-radius: 50%;
  border: none;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  box-shadow: 0 8px 22px rgba(8, 24, 17, 0.16);
  transition: transform .12s, box-shadow .15s;
}
.vac-stack-btn:active { transform: scale(0.92); }
.vac-stack-btn svg { width: 24px; height: 24px; }
.vac-stack-skip {
  background: #fff;
  color: #ef4444;
  border: 2px solid #fef2f2;
}
.vac-stack-save {
  background: linear-gradient(135deg, #88D932 0%, #6BB91A 100%);
  color: #fff;
}
.vac-stack-empty {
  text-align: center;
  padding: 60px 24px;
  background: #fff;
  border-radius: 20px;
  box-shadow: 0 12px 28px rgba(8, 24, 17, 0.10);
}
.vac-stack-empty strong { display: block; font-family: 'Poppins', sans-serif; font-size: 16px; color: #0c261b; margin-bottom: 16px; }
.vac-stack-reset {
  padding: 12px 22px;
  background: var(--green-deep, #0c261b);
  color: #fff;
  border: 0;
  border-radius: 999px;
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
  font-size: 13px;
  cursor: pointer;
  min-height: 44px;
}
.vac-stack-reset:active { transform: scale(0.96); }

@media (min-width: 761px) {
  /* Stack only for mobile */
  .vac-view-toggle { display: none; }
  .vac-stack { display: none; }
}

/* -------- 5 · PULL-TO-REFRESH ------------------------------- */
.ptr-indicator {
  position: fixed;
  top: 0; left: 50%;
  transform: translate(-50%, -60px);
  width: 44px; height: 44px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 6px 18px rgba(8, 24, 17, 0.18);
  display: flex; align-items: center; justify-content: center;
  z-index: 70;
  transition: transform .2s ease;
  pointer-events: none;
}
.ptr-indicator svg { width: 22px; height: 22px; color: var(--green-text); }
.ptr-indicator.is-pulling { transform: translate(-50%, calc(var(--ptr-y, 0px) - 60px)); }
.ptr-indicator.is-ready { transform: translate(-50%, 12px); }
.ptr-indicator.is-refreshing svg { animation: ptr-spin .8s linear infinite; }
@keyframes ptr-spin { to { transform: rotate(360deg); } }

/* -------- 6 · TOUCH-FEEDBACK :active state ------------------ */
/* Subtiel scale(0.97) op alle interactieve elementen op mobiel */
@media (hover: none) and (pointer: coarse) {
  a, button, .btn-primary, .btn-secondary, .btn-outline,
  .nav-cta, .icon-btn, .pill, .lang-btn,
  .job-row, .vac-row, .job-card, .spec-card, .aud-card, .route-card,
  .download-card, .mail-card, .vg-tile, .chip, .pop,
  .mb-nav-item, .mb-lang-btn, .mb-chevron,
  .vac-view-toggle, .vac-stack-btn, .vac-stack-reset,
  .ssg-item,
  .af-quick a, .af-next, .af-back, .af-submit, .af-cv-cam-btn {
    transition: transform .08s ease, background-color .15s, color .15s, box-shadow .15s, border-color .15s;
  }
  a:active, button:active,
  .btn-primary:active, .btn-secondary:active, .btn-outline:active,
  .nav-cta:active, .icon-btn:active, .pill:active, .lang-btn:active,
  .mb-nav-item:active, .mb-lang-btn:active,
  .vac-view-toggle:active, .vac-stack-btn:active, .vac-stack-reset:active,
  .ssg-item:active,
  .af-cv-cam-btn:active {
    transform: scale(0.97);
  }
}

/* -------- 7 · SAFE-AREA ENHANCEMENTS ------------------------ */
@supports (padding: env(safe-area-inset-bottom)) {
  /* Body padding now only for pages that don't use bottom-nav (haves get larger pad via .has-mb-nav) */
  body:not(.has-mb-nav) {
    /* Existing rule already adds env(safe-area-inset-bottom) — keep it */
  }
  body.has-mb-nav .mobile-cta-bar {
    bottom: calc(74px + env(safe-area-inset-bottom, 0px)) !important;
  }
  /* Apply-flow drawer respects safe-area on iOS via @media inside apply-flow.js */
}

/* -------- 8 · MINOR PERFORMANCE ----------------------------- */
/* Make below-fold images skip layout calc */
img[loading="lazy"] { content-visibility: auto; contain-intrinsic-size: auto 400px; }

/* Save-data: reduce image cost on slow connections */
@media (prefers-reduced-data: reduce) {
  .hero-side img, .visual img, .story-gallery img { image-rendering: optimizeSpeed; }
}

/* ==========================================================================
   SEO — FAQ & HowTo (visible blocks gekoppeld aan FAQPage / HowTo schema)
   ========================================================================== */
.faq-section { border-top: 1px solid var(--rule, #ece6da); }
.faq-list .faq-item {
  background: #fff; border: 1px solid var(--rule, #ece6da); border-radius: 12px;
  padding: 0; transition: box-shadow .2s ease, border-color .2s ease;
}
.faq-list .faq-item:hover { box-shadow: 0 4px 14px rgba(12,38,27,.06); border-color: var(--green, #5fd697); }
.faq-list .faq-item summary {
  list-style: none; cursor: pointer; padding: 18px 22px;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  font-family: 'Poppins', sans-serif; font-weight: 600; font-size: 16px; color: var(--green-deep, #0C261B);
}
.faq-list .faq-item summary::-webkit-details-marker { display: none; }
.faq-list .faq-item .faq-icon {
  flex-shrink: 0; width: 26px; height: 26px; border-radius: 50%;
  background: var(--green, #5fd697); color: var(--green-deep, #0C261B);
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 18px; line-height: 1; transition: transform .25s ease;
}
.faq-list .faq-item[open] .faq-icon { transform: rotate(45deg); }
.faq-list .faq-item .faq-answer {
  padding: 0 22px 20px; color: var(--ink-2, #3a3a3a); font-size: 15px; line-height: 1.6;
}

.howto-section { border-top: 1px solid var(--rule, #ece6da); }
.howto-list .howto-step {
  display: flex; gap: 16px; align-items: flex-start;
  padding: 18px 20px; background: #fff;
  border: 1px solid var(--rule, #ece6da); border-radius: 12px;
  transition: box-shadow .2s ease;
}
.howto-list .howto-step:hover { box-shadow: 0 4px 14px rgba(12,38,27,.06); }
.howto-list .howto-num {
  flex-shrink: 0; width: 36px; height: 36px; border-radius: 50%;
  background: var(--green, #5fd697); color: var(--green-deep, #0C261B);
  font-family: 'Poppins', sans-serif; font-weight: 800; font-size: 16px;
  display: flex; align-items: center; justify-content: center;
}
.howto-list .howto-step-name {
  font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 16px;
  display: block; margin-bottom: 4px; color: var(--green-deep, #0C261B);
}
.howto-list .howto-step-text {
  color: var(--ink-2, #3a3a3a); font-size: 14.5px; line-height: 1.55;
}

/* =========================================================
   Universal Search · /zoeken /es/buscar /pt/pesquisar /it/cerca
   Cmd+K command-palette modal
   ========================================================= */

/* ---- Hero search ---- */
.srch-main { background: var(--cream, #FCF7F2); }
.srch-hero {
  padding: 56px 0 28px;
  background: linear-gradient(180deg, var(--cream-2, #F4ECE1) 0%, var(--cream, #FCF7F2) 100%);
  border-bottom: 1px solid var(--rule, #E5DCCD);
}
.srch-crumb { margin-bottom: 14px; }
.srch-title {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: clamp(32px, 4vw, 52px);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 0 0 12px;
  color: var(--green-deep, #0C261B);
}
.srch-title em {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 300;
  color: var(--green-text, #3F7A0E);
}
.srch-lead {
  font-size: 17px; line-height: 1.55; color: var(--ink-2, #3a3a3a);
  max-width: 720px; margin: 0 0 28px;
}
.srch-lead kbd {
  display: inline-block; padding: 1px 7px; margin: 0 1px;
  background: #fff; border: 1px solid var(--rule, #E5DCCD);
  border-radius: 6px; font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 13px; box-shadow: 0 1px 0 rgba(12,38,27,0.08);
}

.srch-form { max-width: 880px; margin: 0; }
.srch-field {
  position: relative; display: flex; align-items: center;
  background: #fff;
  border: 2px solid var(--rule, #E5DCCD);
  border-radius: 16px;
  box-shadow: 0 6px 24px rgba(12,38,27,0.06);
  transition: border-color 0.16s ease, box-shadow 0.16s ease;
}
.srch-field:focus-within {
  border-color: var(--green-text, #3F7A0E);
  box-shadow: 0 8px 32px rgba(12,38,27,0.12);
}
.srch-field-icon {
  flex-shrink: 0; margin-left: 18px; color: var(--ink-3, #6b6b6b);
}
.srch-field input {
  flex: 1; padding: 18px 16px; font-size: 18px;
  border: none; outline: none; background: transparent;
  font-family: inherit; color: var(--ink, #1a1a1a);
}
.srch-field input::placeholder { color: var(--ink-3, #9b9b9b); }
.srch-clear {
  flex-shrink: 0; margin-right: 14px;
  width: 28px; height: 28px; border-radius: 14px;
  background: var(--cream-2, #F4ECE1); border: none;
  font-size: 18px; line-height: 1; cursor: pointer;
  color: var(--ink-2, #3a3a3a);
  display: flex; align-items: center; justify-content: center;
}
.srch-clear:hover { background: var(--rule, #E5DCCD); }
.srch-meta {
  margin-top: 12px; font-size: 13px; color: var(--ink-3, #6b6b6b);
  display: flex; align-items: center; gap: 8px;
}
.srch-meta-status:not(:empty) { color: var(--ink-3, #9b9b9b); }

.srch-popular, .srch-recent {
  margin-top: 14px; display: flex; align-items: center; gap: 10px;
  flex-wrap: wrap;
}
.srch-popular-label {
  font-size: 13px; color: var(--ink-3, #6b6b6b);
  font-weight: 600; letter-spacing: 0.02em; text-transform: uppercase;
}
.srch-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.srch-chip {
  padding: 6px 12px; border-radius: 999px;
  background: #fff; border: 1px solid var(--rule, #E5DCCD);
  font-size: 13px; cursor: pointer; font-family: inherit;
  color: var(--ink, #1a1a1a);
  transition: background 0.12s ease, border-color 0.12s ease;
}
.srch-chip:hover {
  background: var(--green-text, #3F7A0E); color: #fff;
  border-color: var(--green-text, #3F7A0E);
}

/* ---- Body layout ---- */
.srch-body { padding: 28px 0 80px; }
.srch-grid {
  display: grid; grid-template-columns: 240px 1fr; gap: 32px;
}
@media (max-width: 880px) {
  .srch-grid { grid-template-columns: 1fr; gap: 16px; }
}

/* ---- Facets sidebar ---- */
.srch-facets {
  position: sticky; top: 84px; align-self: start;
  max-height: calc(100vh - 100px); overflow-y: auto;
  padding-right: 4px;
}
@media (max-width: 880px) {
  .srch-facets { position: static; max-height: none; overflow: visible; }
}
.srch-facet { margin-bottom: 22px; }
.srch-facet-h {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 13px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--green-deep, #0C261B);
  margin: 0 0 8px;
}
.srch-facet-list { list-style: none; margin: 0; padding: 0; }
.srch-facet-list li { margin: 0; }
.srch-facet-btn {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; padding: 7px 10px; border-radius: 8px;
  background: transparent; border: none; cursor: pointer;
  font-family: inherit; font-size: 14px; text-align: left;
  color: var(--ink, #1a1a1a);
  transition: background 0.1s ease;
}
.srch-facet-btn:hover { background: rgba(12,38,27,0.05); }
.srch-facet-btn.is-active {
  background: var(--green-deep, #0C261B); color: #fff; font-weight: 600;
}
.srch-facet-count {
  font-size: 12px; color: var(--ink-3, #6b6b6b);
  font-variant-numeric: tabular-nums;
}
.srch-facet-btn.is-active .srch-facet-count { color: rgba(255,255,255,0.7); }
.srch-facet-reset {
  width: 100%; padding: 10px; margin-top: 8px;
  border-radius: 8px; background: var(--cream-2, #F4ECE1);
  border: 1px solid var(--rule, #E5DCCD);
  font-family: inherit; font-size: 13px; cursor: pointer;
  color: var(--ink-2, #3a3a3a);
}
.srch-facet-reset:hover { background: var(--rule, #E5DCCD); }

/* ---- Results column ---- */
.srch-results-meta {
  font-size: 14px; color: var(--ink-3, #6b6b6b);
  margin-bottom: 16px; padding-bottom: 12px;
  border-bottom: 1px solid var(--rule, #E5DCCD);
}
.srch-group { margin-bottom: 28px; }
.srch-group-h {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 13px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--green-text, #3F7A0E);
  margin: 0 0 10px;
}
.srch-group-n { color: var(--ink-3, #9b9b9b); font-weight: 500; }

.srch-hit {
  display: block; padding: 16px 18px; margin-bottom: 8px;
  background: #fff; border: 1px solid var(--rule, #E5DCCD);
  border-radius: 12px; text-decoration: none; color: inherit;
  transition: transform 0.12s ease, box-shadow 0.12s ease, border-color 0.12s ease;
}
.srch-hit:hover,
.srch-hit:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 12px 24px rgba(12,38,27,0.08);
  border-color: var(--green-text, #3F7A0E);
  outline: none;
}
.srch-hit-head {
  display: flex; align-items: center; gap: 10px; margin-bottom: 6px;
  flex-wrap: wrap;
}
.srch-hit-pill {
  display: inline-block; padding: 2px 8px; border-radius: 6px;
  font-size: 11px; font-weight: 700; letter-spacing: 0.04em;
  text-transform: uppercase;
  background: var(--cream-2, #F4ECE1); color: var(--ink-2, #3a3a3a);
  flex-shrink: 0;
}
.srch-pill-vacature { background: #E8F5E0; color: #2F5B11; }
.srch-pill-verhaal { background: #FBE7C7; color: #6B3A00; }
.srch-pill-dienst { background: #DDEAFE; color: #1E3A8A; }
.srch-pill-stad { background: #FEE2E2; color: #7F1D1D; }
.srch-pill-regio { background: #FFE4B5; color: #7C2D12; }
.srch-pill-static { background: #E5E7EB; color: #374151; }
.srch-pill-vacature-overview { background: #C7EBA9; color: #2F5B11; }
.srch-pill-verhaal-overview { background: #FBD594; color: #6B3A00; }

.srch-hit-lang { font-size: 14px; }
.srch-hit-title {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 16px; font-weight: 700;
  color: var(--green-deep, #0C261B);
  flex: 1; min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.srch-hit-snip {
  font-size: 14px; line-height: 1.5; color: var(--ink-2, #3a3a3a);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.srch-hit-snip mark, .srch-hit-title mark {
  background: #FFF3B0; color: inherit; padding: 0 2px; border-radius: 2px;
  font-weight: 700;
}
.srch-hit-foot {
  margin-top: 8px; display: flex; flex-wrap: wrap; gap: 6px 12px;
  font-size: 12px; color: var(--ink-3, #6b6b6b);
}
.srch-hit-url {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  color: var(--ink-3, #9b9b9b); white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis; max-width: 320px;
}
.srch-hit-tag {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 1px 7px; background: var(--cream-2, #F4ECE1);
  border-radius: 4px; font-size: 11px;
}

/* ---- Pagination ---- */
.srch-pagination {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; margin-top: 24px; padding: 16px 0;
  border-top: 1px solid var(--rule, #E5DCCD);
}
.srch-page-btn {
  padding: 8px 16px; border-radius: 8px;
  background: var(--green-deep, #0C261B); color: #fff;
  border: none; cursor: pointer; font-family: inherit; font-size: 14px;
  text-decoration: none;
}
.srch-page-btn:hover { background: var(--green-mid, #143426); }
.srch-page-btn.is-disabled {
  background: var(--cream-2, #F4ECE1); color: var(--ink-3, #9b9b9b);
  cursor: default; padding: 8px 16px; border-radius: 8px; font-size: 14px;
}
.srch-page-info { font-size: 13px; color: var(--ink-3, #6b6b6b); }

/* ---- Empty state ---- */
.srch-empty {
  padding: 40px 20px; text-align: center;
  background: #fff; border: 1px dashed var(--rule, #E5DCCD);
  border-radius: 12px;
}
.srch-empty-icon { font-size: 32px; margin-bottom: 8px; }
.srch-empty-title {
  font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 18px; font-weight: 700; margin-bottom: 4px;
  color: var(--green-deep, #0C261B);
}
.srch-empty-sub { font-size: 13px; color: var(--ink-3, #6b6b6b); margin-bottom: 14px; }
.srch-chips-empty { justify-content: center; }

/* ---- Skeleton loader ---- */
.srch-skel {
  height: 96px; margin-bottom: 8px; border-radius: 12px;
  background: linear-gradient(90deg, var(--cream-2, #F4ECE1) 0%, #FFF 50%, var(--cream-2, #F4ECE1) 100%);
  background-size: 200% 100%;
  animation: srchSkelShimmer 1.4s linear infinite;
}
@keyframes srchSkelShimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Active state for search icon in header */
.icon-btn-active {
  background: var(--green-deep, #0C261B) !important;
  color: #fff !important;
}

/* =========================================================
   Cmd+K modal (global, lazy-injected on first open)
   ========================================================= */
.cmdk-modal {
  position: fixed; inset: 0; z-index: 9999;
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 12vh;
  opacity: 0; transition: opacity 0.16s ease;
  pointer-events: none;
}
.cmdk-modal.is-open { opacity: 1; pointer-events: auto; }
.cmdk-backdrop {
  position: absolute; inset: 0;
  background: rgba(12, 38, 27, 0.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.cmdk-panel {
  position: relative; width: 92%; max-width: 640px;
  background: #fff; border-radius: 16px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.35);
  overflow: hidden;
  transform: translateY(-8px); transition: transform 0.18s ease;
}
.cmdk-modal.is-open .cmdk-panel { transform: translateY(0); }
.cmdk-input-row {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 16px; border-bottom: 1px solid var(--rule, #E5DCCD);
}
.cmdk-icon { color: var(--ink-3, #6b6b6b); flex-shrink: 0; }
.cmdk-input {
  flex: 1; border: none; outline: none; background: transparent;
  font-size: 17px; font-family: inherit; color: var(--ink, #1a1a1a);
  padding: 4px 0;
}
.cmdk-input::placeholder { color: var(--ink-3, #9b9b9b); }
.cmdk-close {
  font-size: 11px; padding: 4px 8px;
  background: var(--cream-2, #F4ECE1); border: 1px solid var(--rule, #E5DCCD);
  border-radius: 6px; cursor: pointer; font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  color: var(--ink-3, #6b6b6b);
}
.cmdk-close:hover { background: var(--rule, #E5DCCD); }

.cmdk-results { max-height: 56vh; overflow-y: auto; padding: 8px; }
.cmdk-loading, .cmdk-noresults {
  padding: 32px 16px; text-align: center; color: var(--ink-3, #6b6b6b);
  font-size: 14px;
}
.cmdk-popular { padding: 16px; }
.cmdk-label {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--ink-3, #6b6b6b);
  margin-bottom: 8px;
}
.cmdk-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.cmdk-chip {
  padding: 5px 10px; border-radius: 999px;
  background: var(--cream-2, #F4ECE1); border: 1px solid var(--rule, #E5DCCD);
  font-size: 13px; cursor: pointer; font-family: inherit;
  color: var(--ink, #1a1a1a);
}
.cmdk-chip:hover { background: var(--green-text, #3F7A0E); color: #fff; }

.cmdk-hit {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; border-radius: 8px;
  text-decoration: none; color: inherit;
  transition: background 0.1s ease;
}
.cmdk-hit:hover, .cmdk-hit.is-active {
  background: var(--cream-2, #F4ECE1);
}
.cmdk-hit-pill {
  display: inline-block; padding: 2px 6px; border-radius: 4px;
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.04em;
  background: var(--cream-2, #F4ECE1); color: var(--ink-2, #3a3a3a);
  flex-shrink: 0;
}
.cmdk-pill-vacature { background: #E8F5E0; color: #2F5B11; }
.cmdk-pill-verhaal { background: #FBE7C7; color: #6B3A00; }
.cmdk-pill-dienst { background: #DDEAFE; color: #1E3A8A; }
.cmdk-pill-stad { background: #FEE2E2; color: #7F1D1D; }
.cmdk-pill-static { background: #E5E7EB; color: #374151; }
.cmdk-hit-body { flex: 1; min-width: 0; }
.cmdk-hit-title {
  display: block; font-family: var(--f-display, 'Poppins', sans-serif);
  font-size: 14px; font-weight: 600; color: var(--green-deep, #0C261B);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cmdk-hit-snip {
  display: block; font-size: 12px; color: var(--ink-3, #6b6b6b);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cmdk-hit-title mark, .cmdk-hit-snip mark {
  background: #FFF3B0; color: inherit; padding: 0 1px; font-weight: 700;
}
.cmdk-hit-arrow {
  color: var(--ink-3, #9b9b9b); font-size: 14px; flex-shrink: 0;
  opacity: 0; transition: opacity 0.1s ease;
}
.cmdk-hit:hover .cmdk-hit-arrow,
.cmdk-hit.is-active .cmdk-hit-arrow { opacity: 1; }
.cmdk-more { padding: 8px 12px; border-top: 1px solid var(--rule, #E5DCCD); margin-top: 4px; }
.cmdk-seeall {
  display: block; padding: 8px 12px; border-radius: 6px;
  font-size: 13px; font-weight: 600; color: var(--green-text, #3F7A0E);
  text-decoration: none; text-align: center;
}
.cmdk-seeall:hover { background: var(--cream-2, #F4ECE1); }
.cmdk-footer {
  padding: 10px 16px; border-top: 1px solid var(--rule, #E5DCCD);
  font-size: 12px; color: var(--ink-3, #9b9b9b);
  display: flex; justify-content: space-between; align-items: center;
}
.cmdk-hint { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }

@media (max-width: 600px) {
  .cmdk-modal { padding-top: 6vh; }
  .cmdk-panel { width: 96%; }
}

/* ============================================================
   HELP HUB — Documentation Hub styling (Stripe/Linear-grade)
============================================================ */

/* ---- Help layout (sidebar + main + TOC) ---- */
.help-shell {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr) 220px;
  gap: 48px;
  max-width: var(--container);
  margin: 0 auto;
  padding: 40px var(--gutter) 80px;
}
@media (max-width: 1100px) {
  .help-shell { grid-template-columns: 240px minmax(0,1fr); }
  .help-toc { display: none; }
}
@media (max-width: 820px) {
  .help-shell { grid-template-columns: 1fr; gap: 24px; padding: 24px var(--gutter) 60px; }
  .help-sidebar { position: static; max-height: none; }
}

/* ---- Sidebar ---- */
.help-sidebar {
  position: sticky;
  top: 96px;
  align-self: start;
  max-height: calc(100vh - 120px);
  overflow-y: auto;
  padding-right: 8px;
  font-family: var(--f-sans);
  font-size: 14px;
}
.help-sidebar .help-sb-group { margin-bottom: 22px; }
.help-sidebar .help-sb-label {
  display: block;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 700;
  font-size: 11px;
  color: var(--muted);
  margin-bottom: 8px;
  padding-left: 10px;
}
.help-sidebar a {
  display: block;
  padding: 7px 10px;
  margin-bottom: 1px;
  border-radius: 6px;
  color: var(--ink-2);
  text-decoration: none;
  font-weight: 500;
  line-height: 1.4;
  border-left: 2px solid transparent;
}
.help-sidebar a:hover {
  background: var(--cream-2);
  color: var(--ink);
}
.help-sidebar a.is-active {
  color: var(--green-text);
  background: rgba(111,184,39,.08);
  border-left-color: var(--green-text);
  font-weight: 600;
}

/* ---- Article main ---- */
.help-main {
  min-width: 0;
  font-family: var(--f-sans);
  color: var(--ink-2);
  font-size: 16px;
  line-height: 1.7;
}
.help-crumb {
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 16px;
}
.help-crumb a { color: var(--muted); text-decoration: none; }
.help-crumb a:hover { color: var(--green-text); }
.help-crumb .sep { margin: 0 6px; opacity: .5; }

.help-main h1 {
  font-family: var(--f-display);
  font-size: clamp(28px, 3.4vw, 40px);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -.02em;
  color: var(--ink);
  margin: 0 0 14px;
}
.help-main .help-lead {
  font-size: 18px;
  color: var(--muted);
  line-height: 1.6;
  margin-bottom: 32px;
  border-bottom: 1px solid var(--rule);
  padding-bottom: 24px;
}
.help-main h2 {
  font-family: var(--f-display);
  font-size: 24px;
  font-weight: 700;
  color: var(--ink);
  margin: 40px 0 14px;
  scroll-margin-top: 100px;
  letter-spacing: -.01em;
}
.help-main h3 {
  font-family: var(--f-display);
  font-size: 18px;
  font-weight: 600;
  color: var(--ink);
  margin: 28px 0 10px;
  scroll-margin-top: 100px;
}
.help-main p { margin: 0 0 16px; }
.help-main ul, .help-main ol { margin: 0 0 20px 22px; }
.help-main li { margin-bottom: 6px; }
.help-main a {
  color: var(--green-text);
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
}
.help-main a:hover { color: var(--green-deep); }
.help-main strong { color: var(--ink); font-weight: 700; }
.help-main code {
  background: var(--cream-2);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 14px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}

/* ---- Article meta (reading time, updated) ---- */
.help-meta {
  display: flex;
  gap: 14px;
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 18px;
  align-items: center;
}
.help-meta .dot { width: 3px; height: 3px; border-radius: 50%; background: currentColor; opacity: .5; }

/* ---- Callouts ---- */
.help-callout {
  display: flex;
  gap: 12px;
  padding: 16px 18px;
  margin: 24px 0;
  border-radius: 8px;
  border-left: 3px solid var(--green-text);
  background: rgba(111,184,39,.07);
  font-size: 15px;
}
.help-callout .help-callout-ico { flex-shrink: 0; width: 20px; height: 20px; color: var(--green-text); margin-top: 2px; }
.help-callout p:last-child { margin-bottom: 0; }
.help-callout strong { color: var(--green-deep); }
.help-callout.is-warn { border-left-color: #D97706; background: rgba(217,119,6,.07); }
.help-callout.is-warn .help-callout-ico { color: #D97706; }
.help-callout.is-warn strong { color: #92400E; }
.help-callout.is-info { border-left-color: #2563EB; background: rgba(37,99,235,.06); }
.help-callout.is-info .help-callout-ico { color: #2563EB; }
.help-callout.is-info strong { color: #1E40AF; }

/* ---- Screenshot placeholder ---- */
.help-screenshot {
  margin: 28px 0;
  border: 1px dashed var(--rule);
  border-radius: 8px;
  padding: 48px 24px;
  text-align: center;
  background: var(--cream);
  color: var(--muted);
  font-size: 13px;
  font-style: italic;
}
.help-screenshot::before {
  content: "";
  display: block;
  font-size: 28px;
  margin-bottom: 6px;
  font-style: normal;
}

/* ---- Video embed ---- */
.help-video {
  position: relative;
  margin: 28px 0;
  border-radius: 10px;
  overflow: hidden;
  background: var(--green-darker);
  padding-bottom: 56.25%;
  height: 0;
}
.help-video iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
.help-video-placeholder {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  color: var(--cream);
}
.help-video-placeholder svg { width: 60px; height: 60px; margin-bottom: 10px; opacity: .9; }
.help-video-placeholder span { font-size: 13px; opacity: .7; }

/* ---- TOC (right rail) ---- */
.help-toc {
  position: sticky;
  top: 96px;
  align-self: start;
  font-family: var(--f-sans);
  font-size: 13px;
}
.help-toc-label {
  display: block;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 700;
  font-size: 11px;
  color: var(--muted);
  margin-bottom: 10px;
}
.help-toc a {
  display: block;
  padding: 4px 0;
  color: var(--muted);
  text-decoration: none;
  border-left: 2px solid var(--rule);
  padding-left: 12px;
  line-height: 1.4;
}
.help-toc a:hover { color: var(--green-text); border-left-color: var(--green-text); }
.help-toc a.toc-h3 { padding-left: 22px; font-size: 12px; }

/* ---- Feedback (was dit nuttig) ---- */
.help-feedback {
  margin: 56px 0 32px;
  padding: 24px;
  border: 1px solid var(--rule);
  border-radius: 10px;
  background: var(--cream);
}
.help-feedback h3 {
  font-size: 16px;
  margin: 0 0 12px;
  color: var(--ink);
}
.help-feedback-buttons { display: flex; gap: 10px; }
.help-feedback-btn {
  flex: 0 0 auto;
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: 8px 14px;
  border-radius: 999px;
  cursor: pointer;
  font-family: var(--f-sans);
  font-size: 13px;
  font-weight: 600;
  color: var(--ink-2);
  transition: all .15s;
}
.help-feedback-btn:hover { border-color: var(--green-text); color: var(--green-text); transform: translateY(-1px); }
.help-feedback-btn.is-selected { background: var(--green-text); color: var(--cream); border-color: var(--green-text); }
.help-feedback-thanks { font-size: 13px; color: var(--muted); margin-top: 10px; }
.help-feedback-text {
  margin-top: 12px;
  width: 100%;
  border: 1px solid var(--rule);
  border-radius: 8px;
  padding: 10px 12px;
  font-family: var(--f-sans);
  font-size: 14px;
  min-height: 70px;
  resize: vertical;
}

/* ---- Related articles ---- */
.help-related {
  margin-top: 40px;
  padding-top: 28px;
  border-top: 1px solid var(--rule);
}
.help-related h3 {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 700;
  color: var(--muted);
  margin-bottom: 14px;
}
.help-related-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px,1fr));
  gap: 10px;
}
.help-related-card {
  display: block;
  padding: 14px 16px;
  border: 1px solid var(--rule);
  border-radius: 8px;
  text-decoration: none;
  background: var(--paper);
  color: var(--ink);
  font-weight: 600;
  font-size: 14px;
  transition: all .15s;
}
.help-related-card:hover { border-color: var(--green-text); transform: translateY(-2px); box-shadow: 0 4px 14px rgba(12,38,27,.06); }
.help-related-card .arr { color: var(--green-text); margin-left: 6px; }

/* ---- Help index hero ---- */
.help-hero {
  background: linear-gradient(180deg, var(--green-deep) 0%, var(--green-mid) 100%);
  color: var(--cream);
  padding: 80px var(--gutter) 60px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.help-hero::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(136,217,50,.15), transparent 60%);
  pointer-events: none;
}
.help-hero-inner { max-width: 760px; margin: 0 auto; position: relative; z-index: 1; }
.help-hero h1 {
  font-family: var(--f-display);
  font-size: clamp(32px, 4.4vw, 52px);
  font-weight: 700;
  letter-spacing: -.02em;
  line-height: 1.1;
  margin: 0 0 14px;
  color: var(--cream);
}
.help-hero h1 em {
  font-family: var(--f-display);
  font-style: normal;
  font-weight: 700;
  color: var(--cream);
}
.help-hero p {
  font-size: 17px;
  color: rgba(252,247,242,.78);
  margin-bottom: 32px;
}

.help-search {
  position: relative;
  max-width: 580px;
  margin: 0 auto;
}
.help-search input {
  width: 100%;
  padding: 18px 22px 18px 56px;
  font-size: 16px;
  font-family: var(--f-sans);
  border-radius: 12px;
  border: 0;
  background: var(--cream);
  color: var(--ink);
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
}
.help-search input:focus { outline: 3px solid var(--green); outline-offset: 2px; }
.help-search .help-search-ico {
  position: absolute;
  left: 20px; top: 50%; transform: translateY(-50%);
  width: 22px; height: 22px; color: var(--muted);
}
.help-search-results {
  position: absolute;
  top: calc(100% + 8px);
  left: 0; right: 0;
  background: var(--paper);
  border-radius: 12px;
  box-shadow: 0 18px 50px rgba(0,0,0,.25);
  max-height: 380px;
  overflow-y: auto;
  text-align: left;
  display: none;
  z-index: 50;
}
.help-search-results.is-open { display: block; }
.help-search-results a {
  display: block;
  padding: 12px 18px;
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid var(--rule);
  font-size: 14px;
}
.help-search-results a:hover { background: var(--cream-2); }
.help-search-results a:last-child { border-bottom: 0; }
.help-search-results .help-sr-cat {
  font-size: 11px; color: var(--muted); text-transform: uppercase;
  letter-spacing: .06em; font-weight: 700; margin-bottom: 2px; display: block;
}
.help-search-empty { padding: 24px 18px; color: var(--muted); font-size: 13px; text-align: center; }

/* ---- Category cards (index) ---- */
.help-cats {
  max-width: var(--container);
  margin: -40px auto 0;
  padding: 0 var(--gutter);
  position: relative; z-index: 2;
}
.help-cats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
}
.help-cat-card {
  display: block;
  padding: 28px 24px;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 14px;
  text-decoration: none;
  color: var(--ink);
  box-shadow: 0 8px 24px rgba(12,38,27,.06);
  transition: all .2s;
}
.help-cat-card:hover {
  transform: translateY(-4px);
  border-color: var(--green-text);
  box-shadow: 0 18px 36px rgba(12,38,27,.10);
}
.help-cat-icon {
  width: 44px; height: 44px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(111,184,39,.12);
  color: var(--green-text);
  margin-bottom: 16px;
}
.help-cat-card h3 {
  font-family: var(--f-display);
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 6px;
}
.help-cat-card p { font-size: 14px; color: var(--muted); margin: 0; line-height: 1.5; }
.help-cat-card .help-cat-count {
  display: inline-block;
  margin-top: 12px;
  font-size: 12px;
  color: var(--green-text);
  font-weight: 600;
}

/* ---- Popular articles list ---- */
.help-section { padding: 64px 0; }
.help-section .wrap-narrow { max-width: 880px; margin: 0 auto; padding: 0 var(--gutter); }
.help-section h2 {
  font-family: var(--f-display);
  font-size: 24px;
  font-weight: 700;
  margin: 0 0 22px;
  color: var(--ink);
}
.help-popular-list { display: grid; gap: 8px; }
.help-popular-item {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 20px;
  border: 1px solid var(--rule);
  border-radius: 10px;
  background: var(--paper);
  text-decoration: none;
  color: var(--ink);
  transition: all .15s;
}
.help-popular-item:hover {
  border-color: var(--green-text);
  background: var(--cream);
}
.help-popular-item .help-pop-title { font-weight: 600; font-size: 15px; }
.help-popular-item .help-pop-cat {
  font-size: 11px; color: var(--muted);
  text-transform: uppercase; letter-spacing: .06em;
  margin-top: 2px; display: block;
}
.help-popular-item .arr { color: var(--green-text); font-weight: 700; }

/* ---- Video grid ---- */
.help-video-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px,1fr));
  gap: 18px;
}
.help-video-card {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 10px;
  overflow: hidden;
  text-decoration: none;
  color: var(--ink);
  transition: all .2s;
}
.help-video-card:hover { transform: translateY(-3px); border-color: var(--green-text); box-shadow: 0 10px 24px rgba(12,38,27,.08); }
.help-video-thumb {
  height: 150px;
  background: linear-gradient(135deg, var(--green-deep), var(--green-mid));
  display: flex; align-items: center; justify-content: center;
  color: var(--green);
}
.help-video-thumb svg { width: 48px; height: 48px; }
.help-video-card-body { padding: 14px 16px; }
.help-video-card h4 { font-size: 14px; font-weight: 700; margin: 0 0 4px; color: var(--ink); }
.help-video-card p { font-size: 12px; color: var(--muted); margin: 0; }

/* ---- Contact CTA strip ---- */
.help-contact-strip {
  background: var(--green-deep);
  color: var(--cream);
  padding: 48px var(--gutter);
  text-align: center;
}
.help-contact-strip h2 {
  font-family: var(--f-display);
  font-size: clamp(22px, 2.6vw, 30px);
  color: var(--cream);
  margin: 0 0 8px;
}
.help-contact-strip p { color: rgba(252,247,242,.75); margin-bottom: 22px; font-size: 15px; }
.help-contact-strip .help-cta-row { display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
.help-contact-strip .help-cta-row a {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--green);
  color: var(--green-deep);
  padding: 12px 22px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 700;
  font-size: 14px;
  transition: all .15s;
}
.help-contact-strip .help-cta-row a:hover { background: var(--green-bright); transform: translateY(-1px); }
.help-contact-strip .help-cta-row a.is-ghost {
  background: transparent;
  color: var(--cream);
  border: 1px solid rgba(252,247,242,.3);
}
.help-contact-strip .help-cta-row a.is-ghost:hover { background: rgba(252,247,242,.08); border-color: var(--green); color: var(--green); }

/* ---- FAQ accordion (used on faq/index) ---- */
.help-faq-list { display: grid; gap: 8px; }
.help-faq-item {
  border: 1px solid var(--rule);
  border-radius: 10px;
  background: var(--paper);
  overflow: hidden;
}
.help-faq-item summary {
  padding: 18px 22px;
  font-weight: 600;
  font-size: 15px;
  color: var(--ink);
  cursor: pointer;
  list-style: none;
  display: flex; justify-content: space-between; align-items: center;
  gap: 12px;
}
.help-faq-item summary::-webkit-details-marker { display: none; }
.help-faq-item summary::after {
  content: "+"; flex-shrink: 0;
  font-size: 22px; font-weight: 300; color: var(--green-text);
  transition: transform .2s;
}
.help-faq-item[open] summary::after { content: "−"; }
.help-faq-item summary:hover { background: var(--cream); }
.help-faq-item .help-faq-answer {
  padding: 0 22px 18px;
  font-size: 15px;
  color: var(--ink-2);
  line-height: 1.65;
}
.help-faq-item .help-faq-answer p { margin: 0 0 12px; }

/* ---- Glossary list ---- */
.help-glossary-alpha {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-bottom: 28px;
  padding: 14px;
  background: var(--cream);
  border-radius: 10px;
  border: 1px solid var(--rule);
}
.help-glossary-alpha a {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px;
  border-radius: 6px;
  font-weight: 700; font-size: 13px;
  color: var(--ink);
  text-decoration: none;
  background: var(--paper);
  border: 1px solid var(--rule);
}
.help-glossary-alpha a:hover { background: var(--green-text); color: var(--cream); border-color: var(--green-text); }
.help-glossary-alpha a.is-disabled { color: var(--rule); pointer-events: none; background: transparent; }

.help-glossary-list { display: grid; gap: 16px; }
.help-glossary-item {
  padding: 18px 22px;
  border: 1px solid var(--rule);
  border-radius: 10px;
  background: var(--paper);
  scroll-margin-top: 100px;
}
.help-glossary-item h3 {
  font-family: var(--f-display);
  font-size: 17px; font-weight: 700;
  margin: 0 0 6px; color: var(--ink);
}
.help-glossary-item .help-gl-tag {
  display: inline-block;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--green-text);
  background: rgba(111,184,39,.10);
  padding: 2px 8px;
  border-radius: 999px;
  margin-left: 8px;
  font-weight: 700;
  vertical-align: middle;
}
.help-glossary-item p { font-size: 14px; color: var(--ink-2); margin: 0; line-height: 1.65; }
.help-glossary-item p a { color: var(--green-text); }

/* ============================================================
   HOMEPAGE CUTS — compact varianten van realiteit + advisors
   ============================================================ */
.realiteit.realiteit-compact .realiteit-head {
  align-items: start;
}
.realiteit-bullets {
  list-style: none;
  padding: 0;
  margin: 28px 0 0;
  display: grid;
  gap: 14px;
}
.realiteit-bullets li {
  position: relative;
  padding-left: 28px;
  font-size: 17px;
  color: rgba(252,247,242,0.82);
  line-height: 1.55;
}
.realiteit-bullets li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 14px;
  height: 2px;
  background: var(--green);
  border-radius: 2px;
}
.realiteit-bullets li strong {
  color: var(--paper);
  font-weight: 700;
}

/* ADVISORS COMPACT */
.advisors-compact {
  background: var(--paper);
  padding: clamp(72px, 9vw, 120px) 0;
}
.advisors-compact-inner {
  display: block;
}
.advisors-copy {
  max-width: 720px;
  margin-bottom: clamp(36px, 5vw, 56px);
}
.advisors-copy .eyebrow {
  display: inline-block;
  font-family: var(--f-display);
  font-size: 13px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--green-text);
  margin-bottom: 18px;
}
.advisors-copy h2 {
  font-family: var(--f-display);
  font-size: clamp(34px, 4.4vw, 56px);
  line-height: 1.05;
  letter-spacing: -.02em;
  color: var(--green-deep);
  margin: 0 0 22px;
  max-width: 22ch;
}
.advisors-copy p {
  font-size: 18px;
  line-height: 1.65;
  color: var(--ink-2);
  max-width: 56ch;
  margin: 0 0 32px;
}
.advisors-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 24px;
}
.advisors-actions .arrow-link {
  color: var(--green-text);
  font-weight: 600;
  text-decoration: none;
}
.advisors-actions .arrow-link:hover { text-decoration: underline; }

.advisors-stack {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  position: relative;
  min-height: 200px;
}
.advisors-stack picture {
  width: 120px;
  height: 120px;
  display: block;
  border-radius: 50%;
  overflow: hidden;
  border: 4px solid var(--paper);
  box-shadow: 0 8px 24px rgba(12,38,27,0.12);
  flex-shrink: 0;
}
.advisors-stack picture:not(:first-child) {
  margin-left: -32px;
}
.advisors-stack picture img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* 4 adviseur-kaartjes (homepage) — hergebruikt de .advisor-kaart, compacter */
.advisors-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(16px, 2vw, 24px);
}
.advisors-cards .advisor .body { padding: 14px 16px 15px; }
.advisors-cards .advisor h4 { font-size: 16px; margin-bottom: 2px; }
.advisors-cards .advisor .role { font-size: 12.5px; margin-bottom: 0; }

@media (max-width: 900px) {
  .advisors-compact-inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .advisors-cards { grid-template-columns: repeat(2, 1fr); }
  .advisors-stack {
    justify-content: flex-start;
    min-height: auto;
  }
  .advisors-stack picture { width: 88px; height: 88px; }
  .advisors-stack picture:not(:first-child) { margin-left: -22px; }
}

/* ============================================================
 * VACATURE DETAIL PAGE — 10-section spec
 * ============================================================ */
.vd-quickbar {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
  margin: 28px 0 24px;
}
.vd-qi {
  display: flex;
  gap: 12px;
  align-items: center;
  background: var(--paper);
  padding: 14px 16px;
  border-radius: 10px;
  border: 1px solid var(--rule);
}
.vd-qi svg { color: var(--green-text); flex-shrink: 0; }
.vd-qi .lbl {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  font-weight: 700;
  margin-bottom: 2px;
}
.vd-qi strong {
  font-family: var(--f-display);
  font-size: 14px;
  color: var(--ink);
  font-weight: 700;
  line-height: 1.2;
  display: block;
}
.vd-hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.vd-cta-primary {
  background: var(--green-deep);
  color: var(--cream);
  padding: 14px 28px;
  border-radius: 999px;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 15px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  transition: background .15s ease, transform .15s ease;
}
.vd-cta-primary:hover { background: #0a1f17; transform: translateY(-1px); }
.vd-cta-primary span { font-size: 18px; line-height: 1; }
.vd-cta-large { padding: 18px 36px; font-size: 17px; }
.vd-cta-save {
  background: var(--paper);
  border: 1px solid var(--rule);
  color: var(--ink-2);
  padding: 12px 18px;
  border-radius: 999px;
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  transition: background .15s ease;
}
.vd-cta-save:hover { background: var(--cream-2); }

.vd-benefits-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 10px;
  margin-top: 14px;
}
.vd-benefit {
  background: var(--cream-2);
  padding: 14px 16px;
  border-radius: 10px;
  font-size: 14px;
  line-height: 1.5;
  display: flex;
  gap: 12px;
  align-items: flex-start;
}
.vd-benefit .ico {
  width: 28px;
  height: 28px;
  background: var(--green-deep);
  color: var(--green);
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-weight: 800;
  font-size: 14px;
}

.vd-section-cta {
  background: linear-gradient(135deg, var(--cream-2) 0%, #eef6dd 100%);
  border-radius: 16px;
  padding: 36px 32px;
  text-align: center;
  margin-top: 18px;
}
.vd-section-cta h2 { margin-bottom: 12px; }
.vd-section-cta > p { max-width: 56ch; margin: 0 auto 22px; }
.vd-section-cta .vd-cta-primary { margin: 0 auto; }
.vd-cta-secondary-text { font-size: 12.5px; color: var(--muted); margin-top: 14px; }

.vd-contact-card {
  display: flex;
  gap: 18px;
  align-items: center;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 14px;
  padding: 18px 22px;
  margin-top: 14px;
}
.vd-contact-photo {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
}
.vd-contact-photo img { width: 100%; height: 100%; object-fit: cover; }
.vd-contact-name {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 17px;
  color: var(--ink);
}
.vd-contact-role { font-size: 12.5px; color: var(--muted); margin-top: 2px; }
.vd-contact-links { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 10px; }
.vd-contact-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--green-deep);
  font-weight: 600;
  text-decoration: none;
  font-family: var(--f-display);
}
.vd-contact-link:hover { color: var(--green-text); }

.vd-process .vd-steps {
  list-style: none;
  padding: 0;
  margin: 18px 0 0;
  position: relative;
}
.vd-process .vd-steps::before {
  content: "";
  position: absolute;
  left: 22px;
  top: 22px;
  bottom: 22px;
  width: 2px;
  background: #d6e8b8;
}
.vd-step { display: flex; gap: 18px; padding: 12px 0; position: relative; }
.vd-step-num {
  width: 44px;
  height: 44px;
  background: var(--green-deep);
  color: var(--green);
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--f-display);
  font-weight: 800;
  font-size: 18px;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}
.vd-step strong {
  font-family: var(--f-display);
  font-size: 16px;
  color: var(--ink);
  display: block;
  margin-bottom: 2px;
}
.vd-step p { margin: 0; font-size: 14px; color: var(--ink-2); line-height: 1.55; }

.vd-share { background: var(--cream-2); border-radius: 10px; padding: 14px 18px; }
.vd-share-row { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.vd-share-label { font-size: 13px; color: var(--ink-2); font-weight: 600; margin-right: 6px; }
.vd-share-btn {
  width: 36px;
  height: 36px;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-2);
  cursor: pointer;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
  text-decoration: none;
}
.vd-share-btn:hover {
  background: var(--green-deep);
  color: var(--green);
  border-color: var(--green-deep);
}

.vd-aside .salary .lbl-sub { font-size: 11px; color: var(--muted); margin-top: 2px; }

@media (max-width: 880px) {
  .vd-quickbar { grid-template-columns: 1fr 1fr; }
  .vd-contact-card { flex-direction: column; align-items: flex-start; text-align: left; }
  .vd-section-cta { padding: 24px 18px; }
  .vd-process .vd-steps::before { left: 18px; }
  .vd-step-num { width: 36px; height: 36px; font-size: 15px; }
}
@media (max-width: 560px) {
  .vd-quickbar { grid-template-columns: 1fr; }
}

@media print {
  header.nav, footer, .vd-share, .vd-aside, .similar-jobs, .vd-similar, .contact-cta { display: none !important; }
  .vd-body { padding: 0; }
}

/* ════════════════════════════════════════════════════════════════════════
   REDESIGN · EDITORIAL INDUSTRIAL — ELEVATION LAYER v1
   ────────────────────────────────────────────────────────────────────────
   Site-wide craft layer. Purely ADDITIVE (shadows, motion, text-rendering,
   scroll-margin) — no layout restructuring. Lower/equal specificity than the
   per-section rules above, so existing component styling keeps winning on
   colour & layout; this only adds finish. Fully reversible: delete this block.
   Aesthetic: warm cream paper · deep-forest ink · single acid-green accent ·
   Fraunces editorial italics — pushed to a confident magazine-grade finish.
   ════════════════════════════════════════════════════════════════════════ */

/* 1 · Typographic craft (every page) ----------------------------------- */
body {
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "kern" 1, "liga" 1, "calt" 1;
}
/* Balanced headlines, no orphan body lines */
h1, h2, h3, .hero h1, .page-hero h1 { text-wrap: balance; }
p, li, .lead, blockquote { text-wrap: pretty; }
/* Anchor jumps clear the sticky nav so headings aren't hidden under the bar */
:where(h2, h3, h4, section, article)[id] { scroll-margin-top: 104px; }

/* 2 · CTA micro-interactions — refined lift + layered shadow + acid edge.
   Additive only; per-context colour rules retain higher specificity.       */
.btn-primary, .nav-cta, .nav-cta-group .nav-cta, .search-submit,
.apply-cta-big, .cf-submit, .mcb-primary {
  box-shadow: 0 1px 0 rgba(255,255,255,0.18) inset,
              0 6px 18px -8px rgba(12,38,27,0.45);
}
.btn-primary:hover, .nav-cta:hover, .nav-cta-group .nav-cta:hover,
.search-submit:hover, .apply-cta-big:hover, .cf-submit:hover, .mcb-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 1px 0 rgba(255,255,255,0.28) inset,
              0 14px 30px -10px rgba(12,38,27,0.55),
              0 0 0 1px rgba(136,217,50,0.20);
}
.btn-primary:focus-visible, .nav-cta:focus-visible,
.search-submit:focus-visible, .apply-cta-big:focus-visible {
  outline: 3px solid var(--green-bright); outline-offset: 3px;
}

/* 3 · Card craft — unified tactile lift + warm shadow ------------------- */
.job-card, .advisor, .spec-card, .route-card, .download-card, .mail-card {
  transition: transform .28s cubic-bezier(.2,.7,.2,1),
              box-shadow .28s cubic-bezier(.2,.7,.2,1),
              border-color .28s ease;
}
.job-card:hover, .advisor:hover, .spec-card:hover, .route-card:hover,
.download-card:hover, .mail-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 22px 48px -20px rgba(12,38,27,0.40),
              0 4px 12px -8px rgba(12,38,27,0.28);
}

/* 4 · Signature link affordance — acid underline grows from the left ---- */
.arrow-link {
  background-image: linear-gradient(var(--green), var(--green));
  background-repeat: no-repeat;
  background-position: 0 100%;
  background-size: 0% 2px;
  transition: background-size .3s cubic-bezier(.2,.7,.2,1);
  padding-bottom: 1px;
}
.arrow-link:hover { background-size: 100% 2px; text-decoration: none; }

/* 5 · Depth — tactile paper grain across the canvas (barely-there) ------ */
body::after {
  content: ""; position: fixed; inset: 0; z-index: 1;
  pointer-events: none; opacity: 0.03; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");
}

/* 6 · Custom scrollbar — brand chrome instead of OS default ------------- */
* { scrollbar-width: thin; scrollbar-color: var(--green-deep) var(--cream-2); }
::-webkit-scrollbar { width: 12px; height: 12px; }
::-webkit-scrollbar-track { background: var(--cream-2); }
::-webkit-scrollbar-thumb {
  background: var(--green-deep); border: 3px solid var(--cream-2); border-radius: 999px;
}
::-webkit-scrollbar-thumb:hover { background: var(--green-darker); }

/* 7 · Honour reduced-motion for every addition above ------------------- */
@media (prefers-reduced-motion: reduce) {
  .btn-primary, .nav-cta, .search-submit, .apply-cta-big,
  .job-card, .advisor, .spec-card, .route-card, .download-card, .mail-card,
  .arrow-link { transition: none !important; }
  .btn-primary:hover, .nav-cta:hover, .search-submit:hover, .apply-cta-big:hover,
  .job-card:hover, .advisor:hover, .spec-card:hover, .route-card:hover { transform: none !important; }
  body::after { display: none; }
}

/* ════════════════════════════════════════════════════════════════════════
   REDESIGN · ITERATION 2 — BOLD EDITORIAL HOMEPAGE HERO
   ────────────────────────────────────────────────────────────────────────
   Scoped to .hero only. CSS-only, reversible. Pushes the first-3-seconds
   moment: bigger confident display type, an editorial kicker, and the
   differentiation anchor — a hand-drawn acid "marker" swash under the accent
   word "uitzenden." (the thing you remember 24h later). Mobile-safe via clamp.
   ════════════════════════════════════════════════════════════════════════ */
/* NB: selectors below intentionally carry extra specificity (.hero .hero-copy …)
   so they beat the INLINE critical-CSS in <head>, which otherwise wins on
   source order for equal-specificity rules. */
.hero .hero-copy h1 {
  font-size: clamp(44px, 6.0vw, 92px);
  letter-spacing: -0.045em;
  line-height: 0.98;
}

/* Lead claims (Fraunces italic) get a touch more editorial presence */
.hero .hero-copy .lead-claims { font-size: clamp(16px, 1.35vw, 19px); opacity: 1; }

/* Search box: deeper, warmer lift + clearer focus glow */
.hero .hero-inner .search-box {
  box-shadow: 0 32px 70px -28px rgba(0,0,0,0.50), 0 2px 8px -4px rgba(0,0,0,0.30);
}
.hero .hero-inner .search-field:focus-within {
  border-color: var(--green);
  box-shadow: 0 0 0 4px rgba(136,217,50,0.16);
}

/* Stat numbers: tighter, more confident editorial figures */
.hero .hero-stats-row .num { letter-spacing: -0.03em; font-feature-settings: "tnum" 1; }

/* ════════════════════════════════════════════════════════════════════════
   REDESIGN · ITERATION 3 — HOMEPAGE SECTIONS (EDITORIAL NUMBERING + RHYTHM)
   ────────────────────────────────────────────────────────────────────────
   Scoped to body.page-home only — other ~590 pages untouched. The signature
   move: a magazine-style oversized section index (01 02 03 …) rendered as a
   CSS counter on each section heading. Pseudo-element ⇒ survives the CMS
   textContent overrides on the data-content-key headings.
   ════════════════════════════════════════════════════════════════════════ */
.page-home main { counter-reset: fhsec; }

.page-home main h2[data-reveal] { position: relative; }
.page-home main h2[data-reveal]::before {
  /* Section-nummering uitgeschakeld op verzoek (haal de cijfers weg op de homepagina) */
  content: none;
  display: none;
}
.page-home .audience-dual .aud-card h2[data-reveal]::before {
  content: none;
  display: none;
}
/* Reduced-motion / no-reveal fallback: data-reveal is set in markup, so the
   numbering shows regardless of JS. Nothing to guard here. */

/* ════════════════════════════════════════════════════════════════════════
   POLISH · S-TIER HERO (bestaand design, homepage-scoped)
   Hogere specificity dan de inline critical-CSS → wint. Premium zoekbalk,
   meer ademruimte, premium live-badge, gestaffelde entrance.
   ════════════════════════════════════════════════════════════════════════ */
.page-home .hero .hero-inner{ gap:clamp(40px,5vw,76px); padding-top:clamp(76px,9vw,116px); padding-bottom:clamp(40px,5vw,60px); }
.page-home .hero .lead-claims{ margin-bottom:40px; }

/* Premium glass search box */
.page-home .hero .search-box{
  padding:10px; border-radius:16px; gap:6px;
  background:rgba(252,247,242,.97); -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);
  box-shadow:0 40px 80px -34px rgba(0,0,0,.55), 0 2px 8px -3px rgba(0,0,0,.3);
}
.page-home .hero .search-field{ border-radius:13px; padding:15px 16px 13px 50px; border:1px solid transparent; transition:border-color .2s,background .2s,box-shadow .2s; }
.page-home .hero .search-field:focus-within{ background:var(--paper); border-color:var(--green); box-shadow:0 0 0 4px rgba(136,217,50,.18); }
.page-home .hero .search-submit{ border-radius:13px; padding:0 30px; }

/* Premium "live" badge on the founder photo */
.page-home .hero .hero-side .badge{
  border-radius:100px; padding:11px 18px;
  box-shadow:0 18px 40px -16px rgba(0,0,0,.55);
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
}

/* Confident staggered entrance for the hero copy + figure (premium feel) */
@media (prefers-reduced-motion:no-preference){
  .page-home .hero .hero-copy > *{ opacity:0; animation:fhHeroIn .85s cubic-bezier(.2,.7,.2,1) forwards; }
  .page-home .hero .hero-copy > *:nth-child(1){ animation-delay:.05s }
  .page-home .hero .hero-copy > *:nth-child(2){ animation-delay:.13s }
  .page-home .hero .hero-copy > *:nth-child(3){ animation-delay:.21s }
  .page-home .hero .hero-copy > *:nth-child(4){ animation-delay:.29s }
  .page-home .hero .hero-copy > *:nth-child(5){ animation-delay:.37s }
  .page-home .hero .hero-side{ opacity:0; animation:fhHeroIn 1s .22s cubic-bezier(.2,.7,.2,1) forwards; }
  @keyframes fhHeroIn{ from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:none} }
}

/* ─────────── Hero-koppen uniform (site-breed) ───────────
   Geen los Fraunces-groen accent meer in hero-titels: alle hero-koppen
   uniform crème Poppins op de donkere hero. Eén bron van waarheid. */
.hero h1 em, .page-hero h1 em, .ct-hero-title em, .ed-hero-title em,
.vd-hero h1 em, .srch-title em, .sm-hero h1 em, .notfound h1 em,
.flow-head h1 em, .story-hero h1 em, .help-hero h1 em {
  font-family: var(--f-display) !important;
  font-style: normal !important;
  font-weight: inherit !important;
  color: inherit !important;
}

/* ─────────── Hero-koppen: één identieke typografie (site-breed) ───────────
   Alle hero-titels exact gelijk: Poppins 700, zelfde grootte/tracking/kleur.
   Voorkomt 'verspringen' van gewicht/grootte tussen paginatypes. */
.hero h1,
.page-hero h1,
.ct-hero-title,
.ed-hero-title,
.vd-hero h1,
.srch-title,
.help-hero h1,
.notfound h1,
.flow-head h1,
.story-hero h1,
body[data-page="businesspartner"] .bp-hero h1 {
  font-family: var(--f-display) !important;
  font-weight: 700 !important;
  font-size: clamp(40px, 5.2vw, 74px) !important;
  line-height: 1.04 !important;
  letter-spacing: -0.03em !important;
  color: var(--cream) !important;
}
/* .vd-hero is een LICHTE (cream) hero -> titel mag GEEN cream zijn (cream-op-cream = onzichtbaar).
   Stond per ongeluk in de donkere-hero-groep hierboven. */
.vd-hero h1 { color: var(--green-deep) !important; }
.vd-hero h1 em { color: var(--green-text) !important; }   /* plaatsnaam als groen accent */


/* ============================================================
   S-TIER SECTION TRANSITIONS — rounded card overlap
   ------------------------------------------------------------
   Iedere sectie die volgt op een ander kleur-mode krijgt
   afgeronde top-hoeken en steekt ~48px omhoog onder de vorige
   sectie. De ronde hoeken onthullen de vorige sectie eronder,
   wat een gestackt 'kaart'-effect geeft (Stripe / Linear / Vercel).
   Geen kleurmenging, geen gimmicks.
============================================================ */
.audience.audience-dual,
.realiteit.realiteit-compact,
.testimonials.testimonials-pros,
.clients,
.advisors-compact {
  position: relative;
  z-index: 1;
  border-top: 0;
  border-top-left-radius: clamp(32px, 3vw, 56px);
  border-top-right-radius: clamp(32px, 3vw, 56px);
  margin-top: calc(clamp(32px, 3vw, 56px) * -1);
}

/* ============================================================
 * PREMIUM HERO — v=2026060102
 * ------------------------------------------------------------
 * Dark-green brand hero (geen grain, refined gradient), editorial
 * team-foto met asymmetrische rounded corner. De foto's bright-
 * green wand voegt visueel ritme toe tegen het donkergroen.
 * ============================================================ */

.hero {
  background:
    radial-gradient(1200px 800px at 92% 8%, rgba(136, 217, 50, 0.18), transparent 65%),
    radial-gradient(800px 600px at 8% 100%, rgba(0, 0, 0, 0.32), transparent 60%),
    linear-gradient(135deg, #06180E 0%, var(--green-deep) 55%, #11341F 100%) !important;
  color: var(--cream) !important;
  padding-bottom: clamp(48px, 7vw, 96px);
}
.hero-grain { display: none !important; }

.hero-inner {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr) !important;
  gap: clamp(40px, 5.5vw, 72px) !important;
  padding: clamp(56px, 8vw, 104px) 0 clamp(28px, 4vw, 48px) !important;
  align-items: center !important;
}

.hero-eyebrow {
  color: var(--green) !important;
  margin-bottom: 24px !important;
}
.hero-eyebrow::before { background: var(--green) !important; }
/* .hero-eyebrow is fel groen (voor donkere hero's). Op LICHTE secties die 'm hergebruiken
   (contact-cta, faq, howto) zou dat onleesbaar zijn -> daar green-text. */
.contact-cta .hero-eyebrow,
.faq-section .hero-eyebrow,
.howto-section .hero-eyebrow { color: var(--green-text) !important; }
.contact-cta .hero-eyebrow::before,
.faq-section .hero-eyebrow::before,
.howto-section .hero-eyebrow::before { background: var(--green-text) !important; }

.hero h1 {
  color: var(--cream) !important;
  font-size: clamp(42px, 5.4vw, 78px) !important;
  line-height: 1.04 !important;
  letter-spacing: -0.035em !important;
  margin-bottom: 22px !important;
  text-wrap: balance;
}
.hero h1 .accent { color: var(--green) !important; }

.hero p.lead {
  color: var(--cream) !important;
  opacity: 0.86 !important;
  font-size: 18px !important;
  line-height: 1.65 !important;
  max-width: 56ch !important;
  margin-bottom: 12px !important;
}
.hero .lead-claims {
  color: var(--green) !important;
  opacity: 0.95 !important;
  margin-bottom: 34px !important;
}

/* Search box — cream floating card op donker */
.hero .search-box {
  background: var(--cream) !important;
  border: 1px solid rgba(252, 247, 242, 0.18);
  box-shadow:
    0 24px 60px -20px rgba(0, 0, 0, 0.45),
    0 2px 8px rgba(0, 0, 0, 0.12) !important;
}
.hero .search-field label { color: var(--muted) !important; }
.hero .search-field input { color: var(--green-deep) !important; }
.hero .search-submit {
  background: var(--green-deep) !important;
  color: var(--green) !important;
  transition: transform 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
}
.hero .search-submit:hover {
  background: var(--green-darker) !important;
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.35);
}

.hero .search-meta { color: rgba(252, 247, 242, 0.7) !important; margin-top: 18px; }
.hero .search-meta .pop { color: rgba(252, 247, 242, 0.5) !important; }
.hero .search-meta .chip {
  background: rgba(252, 247, 242, 0.08) !important;
  border: 1px solid rgba(252, 247, 242, 0.14) !important;
  color: var(--cream) !important;
  transition: background 0.18s ease, transform 0.15s ease;
}
.hero .search-meta .chip:hover {
  background: rgba(136, 217, 50, 0.22) !important;
  border-color: rgba(136, 217, 50, 0.4) !important;
  transform: translateY(-1px);
}

/* === Team-foto rechts === */
.hero-side--team {
  display: block;
  padding: 0;
  margin: 0;
  background: none !important;
  position: relative;
}
.hero-side--team .hero-photo {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 2;
  border-radius: 28px 110px 28px 28px;
  overflow: hidden;
  background: var(--green-darker);
  box-shadow:
    0 50px 100px -30px rgba(0, 0, 0, 0.6),
    0 18px 40px rgba(0, 0, 0, 0.28),
    inset 0 0 0 1px rgba(252, 247, 242, 0.08);
  opacity: 0;
  transform: translateY(28px);
  animation: heroPhotoIn 1s cubic-bezier(0.16, 0.84, 0.34, 1) 0.15s forwards;
}
.hero-side--team .hero-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}

.hero-side--team .hero-photo-badge {
  position: absolute;
  bottom: 20px; left: 20px;
  display: inline-block; white-space: nowrap;
  background: var(--paper);
  color: var(--green-deep);
  padding: 9px 16px 9px 14px;
  border-radius: 999px;
  font-family: var(--f-display);
  font-weight: 700; font-size: 12.5px;
  letter-spacing: 0.02em;
  box-shadow:
    0 8px 28px rgba(12, 38, 27, 0.18),
    0 2px 6px rgba(12, 38, 27, 0.06);
}
.hero-side--team .hero-photo-badge::before {
  content: '';
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #4ade80;
  vertical-align: middle;
  margin-right: 9px;
  box-shadow: none;
  animation: none;
}

@keyframes heroPhotoIn {
  to { opacity: 1; transform: translateY(0); }
}
@keyframes heroPulseDot {
  0%, 100% { box-shadow: 0 0 0 0 rgba(74, 222, 128, 0.55); }
  50%      { box-shadow: 0 0 0 9px rgba(74, 222, 128, 0); }
}

/* Hero copy — gestapelde fade-in */
.hero-copy > * {
  opacity: 0;
  transform: translateY(14px);
  animation: heroCopyIn 0.7s cubic-bezier(0.16, 0.84, 0.34, 1) forwards;
}
.hero-copy > *:nth-child(1) { animation-delay: 0.05s; }
.hero-copy > *:nth-child(2) { animation-delay: 0.13s; }
.hero-copy > *:nth-child(3) { animation-delay: 0.21s; }
.hero-copy > *:nth-child(4) { animation-delay: 0.29s; }
.hero-copy > *:nth-child(5) { animation-delay: 0.37s; }
@keyframes heroCopyIn {
  to { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .hero-side--team .hero-photo,
  .hero-copy > * {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
}

/* Stats row in hero — subtle cards op donker hero */
.hero .hero-stats-row,
.hero .hero-stats-charts {
  background: transparent !important;
  margin-top: clamp(48px, 6vw, 80px);
  padding-top: clamp(36px, 4vw, 56px);
  border-top: 1px solid rgba(252, 247, 242, 0.12);
}
.hero .hero-stats-row .item {
  background: rgba(252, 247, 242, 0.04);
  border: 1px solid rgba(252, 247, 242, 0.10);
  border-radius: 16px;
  padding: 24px 22px;
  box-shadow: inset 0 0 0 1px rgba(252, 247, 242, 0.02);
  transition: transform 0.22s ease, background 0.22s ease, border-color 0.22s ease;
}
.hero .hero-stats-row .item:hover {
  transform: translateY(-3px);
  background: rgba(252, 247, 242, 0.07);
  border-color: rgba(136, 217, 50, 0.32);
}
.hero .hero-stats-row .num,
.hero .hero-stats-charts .num { color: var(--cream) !important; }
.hero .hero-stats-row .num em,
.hero .hero-stats-charts .num em { color: var(--green) !important; }
.hero .hero-stats-row .lbl,
.hero .hero-stats-charts .lbl { color: rgba(252, 247, 242, 0.68) !important; }

.hero .hero-trust { color: rgba(252, 247, 242, 0.7) !important; }

/* Mobile aanpassingen */
@media (max-width: 980px) {
  .hero-inner {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 36px !important;
  }
  .hero-side--team { order: -1; }
  .hero-side--team .hero-photo {
    aspect-ratio: 4 / 3;
    border-radius: 18px 56px 18px 18px;
  }
}

/* ============================================================
 * CALM HOMEPAGE — meer whitespace, zachtere kleuren site-wide
 * ============================================================ */

/* Standaard section-padding +40% voor rust */
.audience.audience-dual,
.vind-baan,
.realiteit.realiteit-compact,
.testimonials.testimonials-pros,
.clients,
.advisors-compact,
.process,
.community,
.specs,
.jobs {
  padding-top: clamp(64px, 9vw, 112px) !important;
  padding-bottom: clamp(64px, 9vw, 112px) !important;
}

/* Section rhythm — afwisselend cream / paper i.p.v. heavy green blocks.
   .clients is BEWUST donker-groen gelaten (logos pop visueel op donkere bg + cream tekst is leesbaar).
   .community blijft op haar oorspronkelijke bg om text-color conflicts te vermijden. */
.audience.audience-dual { background: var(--paper) !important; }
.vind-baan { background: var(--cream) !important; }
.realiteit.realiteit-compact { background: var(--green-deep) !important; }
.testimonials.testimonials-pros { background: var(--cream) !important; }
.advisors-compact { background: var(--cream) !important; }

/* Cards: zachte schaduw i.p.v. harde border */
.aud-card,
.testimonials-pros .tp-card,
.process .step,
.specs .spec-card,
.jobs .job-card,
.community .com-card {
  border: 1px solid var(--rule) !important;
  box-shadow: 0 2px 20px rgba(12, 38, 27, 0.05) !important;
  transition: transform 0.22s ease, box-shadow 0.22s ease !important;
}
.aud-card:hover,
.testimonials-pros .tp-card:hover,
.process .step:hover,
.specs .spec-card:hover,
.jobs .job-card:hover,
.community .com-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 14px 36px rgba(12, 38, 27, 0.10) !important;
}

/* Typography: betere body line-height (1.65) waar nog niet gezet */
section p { line-height: 1.65; }
section h2 { line-height: 1.12; letter-spacing: -0.025em; }
section h3 { line-height: 1.18; }

/* Premium buttons site-wide — micro-interactions */
.btn-primary,
.btn-secondary,
.aanv-qbtn,
.cta {
  transition: transform 0.18s cubic-bezier(0.2, 0.8, 0.2, 1),
              box-shadow 0.18s ease,
              background-color 0.18s ease !important;
}
.btn-primary:hover,
.aanv-qbtn:hover,
.cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(12, 38, 27, 0.18);
}
.btn-secondary:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(12, 38, 27, 0.08);
}

/* Reduce aggressive green: testimonials achtergrond was donker — nu cream */
.testimonials.testimonials-pros { color: var(--green-deep) !important; }
.testimonials.testimonials-pros h2 { color: var(--green-deep) !important; }
.testimonials.testimonials-pros .tp-card { background: var(--paper) !important; }

/* ============================================================
 * UNIFIED HERO — alle subpagina-heros gelijk aan homepage
 * ------------------------------------------------------------
 * Zelfde gradient + zelfde min-height + zelfde padding zodat
 * pagina's visueel echt consistent zijn (niet alleen kleur).
 * ============================================================ */
.page-hero,
.ct-hero,
.ed-hero,
.aanv-hero {
  background:
    radial-gradient(ellipse 900px 700px at 95% 5%, rgba(136, 217, 50, 0.14), transparent 60%),
    radial-gradient(ellipse 800px 600px at 5% 95%, rgba(0, 0, 0, 0.35), transparent 65%),
    linear-gradient(45deg, #06180E 0%, var(--green-deep) 45%, #143A28 100%) !important;
  color: var(--cream) !important;
  min-height: clamp(820px, 100vh, 1220px) !important;
  display: flex !important;
  align-items: center !important;
  padding-top: clamp(110px, 14vh, 160px) !important;
  padding-bottom: clamp(64px, 9vh, 110px) !important;
}
.page-hero > .wrap,
.ct-hero > .wrap,
.ed-hero > .wrap,
.aanv-hero > .wrap {
  width: 100%;
}
/* Homepage hero óók dezelfde min-height — voor 100% pariteit */
.hero {
  min-height: clamp(820px, 100vh, 1220px);
}
/* Verwijder secundaire gradient-overlays van bestaande hero-rules
   (sommige hadden eigen ::before/::after radial overlays of DOM-elementen).
   Inclusief: .ct-hero-glow div (voor-werkgevers/contact), .aanv-hero ::before
   met groene radials, en page-hero ::before overlay. */
.page-hero::before,
.ct-hero::before,
.ed-hero::before,
.aanv-hero::before {
  background: none !important;
}
.ct-hero-glow,
.aanv-hero .aanv-hero__art,
.aanv-hero::after,
.page-hero::after {
  display: none !important;
  background: none !important;
}

/* ============================================================
 * SEARCH PAGE — premium herontwerp
 *   1. Donker-groene hero (gelijk aan andere pagina's)
 *   2. Witte zoekbalk met prominente focus-glow
 *   3. Filter-chips lime-green wanneer actief
 *   4. Result-cards met groene border-accent links
 * ============================================================ */

/* Hero — donker, matched met homepage */
.srch-main { background: var(--cream) !important; }
.srch-hero {
  padding: clamp(80px, 12vw, 140px) 0 clamp(56px, 7vw, 80px) !important;
  background:
    radial-gradient(ellipse 900px 700px at 95% 5%, rgba(136, 217, 50, 0.18), transparent 60%),
    radial-gradient(ellipse 800px 600px at 5% 95%, rgba(0, 0, 0, 0.35), transparent 65%),
    linear-gradient(45deg, #06180E 0%, var(--green-deep) 45%, #143A28 100%) !important;
  border-bottom: 0 !important;
  color: var(--cream) !important;
}
.srch-hero .srch-crumb,
.srch-hero .srch-crumb a {
  color: var(--green) !important;
  opacity: 0.9;
}
.srch-title {
  color: var(--cream) !important;
  font-size: clamp(40px, 5.5vw, 72px) !important;
  font-weight: 800 !important;
}
.srch-title em {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 300;
  color: var(--green) !important;
}
.srch-lead {
  color: rgba(252, 247, 242, 0.82) !important;
  font-size: 18px !important;
}
.srch-lead kbd {
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: rgba(255, 255, 255, 0.22) !important;
  color: var(--cream) !important;
}

/* Zoekbalk — wit floating card met groene focus-ring */
.srch-form { max-width: 920px; }
.srch-field {
  background: #FFFFFF !important;
  border: 2px solid transparent !important;
  border-radius: 100px !important;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.18), 0 2px 6px rgba(0, 0, 0, 0.05) !important;
  transition: border-color 0.18s, box-shadow 0.18s, transform 0.18s !important;
}
.srch-field:focus-within {
  border-color: var(--green) !important;
  box-shadow: 0 0 0 6px rgba(136, 217, 50, 0.22), 0 12px 40px rgba(0, 0, 0, 0.22) !important;
  transform: translateY(-1px);
}
.srch-field-icon {
  color: var(--green-deep) !important;
  margin-left: 22px !important;
}
.srch-field input {
  padding: 20px 18px !important;
  font-size: 17px !important;
  color: var(--green-deep) !important;
  font-weight: 500;
}
.srch-field input::placeholder { color: #9b9b9b !important; }
.srch-clear {
  background: var(--cream-2) !important;
  color: var(--green-deep) !important;
  margin-right: 14px !important;
}

.srch-meta,
.srch-meta-status { color: rgba(252, 247, 242, 0.65) !important; }

/* Populair-chips — wit op donker */
.srch-popular-label { color: rgba(252, 247, 242, 0.55) !important; }
.srch-chip {
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.18) !important;
  color: var(--cream) !important;
  padding: 8px 16px !important;
  font-size: 13.5px !important;
  font-weight: 500;
  transition: all 0.15s !important;
}
.srch-chip:hover {
  background: var(--green) !important;
  color: var(--green-deep) !important;
  border-color: var(--green) !important;
  transform: translateY(-1px);
}

/* Body sectie op cream */
.srch-body {
  padding: clamp(48px, 6vw, 72px) 0 clamp(64px, 8vw, 96px) !important;
  background: var(--cream) !important;
}

/* Facets — duidelijker filter UI */
.srch-facet-h {
  font-size: 11px !important;
  letter-spacing: 0.14em !important;
  color: var(--green-text) !important;
  margin-bottom: 10px !important;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--rule);
}
.srch-facet-btn {
  padding: 9px 12px !important;
  font-size: 14px !important;
  border-radius: 10px !important;
  color: var(--ink-2) !important;
  transition: all 0.15s !important;
}
.srch-facet-btn:hover {
  background: rgba(136, 217, 50, 0.12) !important;
  color: var(--green-deep) !important;
}
.srch-facet-btn.is-active {
  background: var(--green-deep) !important;
  color: var(--green) !important;
  font-weight: 700 !important;
  box-shadow: 0 4px 12px rgba(12, 38, 27, 0.18);
}
.srch-facet-btn.is-active .srch-facet-count {
  color: var(--green) !important;
  opacity: 0.85;
}
.srch-facet-count {
  font-weight: 600;
  padding-left: 8px;
}

/* Result cards — duidelijker hierarchie */
.srch-results-meta {
  font-size: 14px !important;
  color: var(--muted) !important;
  font-weight: 600;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--rule);
}
.srch-group-h {
  color: var(--green-text) !important;
  font-size: 12px !important;
  letter-spacing: 0.14em !important;
  margin-bottom: 12px !important;
}
.srch-result {
  background: var(--paper) !important;
  border: 1px solid var(--rule) !important;
  border-left: 3px solid var(--green) !important;
  border-radius: 14px !important;
  padding: 20px 24px !important;
  margin-bottom: 12px !important;
  transition: all 0.18s !important;
}
.srch-result:hover {
  border-left-color: var(--green-deep) !important;
  box-shadow: 0 8px 28px rgba(12, 38, 27, 0.08) !important;
  transform: translateX(4px);
}
.srch-result a,
.srch-result h3,
.srch-result .srch-result-title {
  color: var(--green-deep) !important;
  font-weight: 700;
}
.srch-result p,
.srch-result .srch-result-snippet {
  color: var(--ink-2) !important;
  font-size: 14.5px;
  line-height: 1.6;
}
.srch-result .badge,
.srch-result .srch-result-type {
  display: inline-block;
  background: rgba(136, 217, 50, 0.18) !important;
  color: var(--green-text) !important;
  padding: 3px 10px !important;
  border-radius: 100px !important;
  font-size: 10.5px !important;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.srch-result code,
.srch-result .srch-result-path {
  background: var(--cream-2) !important;
  color: var(--muted) !important;
  padding: 2px 8px !important;
  border-radius: 4px !important;
  font-size: 12px !important;
}

/* ============================================================
 * REALITEIT — portrait photo presentatie
 * ============================================================ */
.realiteit.realiteit-compact { color: var(--cream) !important; }
.realiteit.realiteit-compact .eyebrow { color: var(--green) !important; }
.realiteit.realiteit-compact h2 { color: var(--cream) !important; }
.realiteit.realiteit-compact h2 .accent { color: var(--green) !important; }
.realiteit.realiteit-compact .lead,
.realiteit.realiteit-compact .realiteit-bullets li { color: var(--cream) !important; opacity: 0.92 !important; }
.realiteit.realiteit-compact .realiteit-bullets li strong { color: var(--green) !important; }
.realiteit.realiteit-compact .pull { color: var(--cream) !important; }
.realiteit.realiteit-compact .pull em { color: var(--green) !important; }
.realiteit.realiteit-compact .arrow-link { color: var(--green) !important; }
.realiteit.realiteit-compact .arrow-link:hover { color: var(--green-bright) !important; }
/* uitzondering: de .realiteit-foot is een GROENE pill → tekst moet donker (anders
   tekstkleur = pill-achtergrond = onzichtbaar). Hogere specificiteit wint van bovenstaande. */
.realiteit.realiteit-compact .realiteit-foot .arrow-link,
.realiteit.realiteit-compact .realiteit-foot .arrow-link:hover { color: var(--green-deep) !important; }

.realiteit-head {
  grid-template-columns: 1.15fr 0.85fr !important;
  gap: clamp(40px, 5vw, 72px) !important;
  align-items: center !important;
}
@media (max-width: 880px) {
  .realiteit-head { grid-template-columns: 1fr !important; }
}

.realiteit-photo--portrait {
  aspect-ratio: 2 / 3 !important;
  border-radius: 24px 100px 24px 24px !important;
  box-shadow:
    0 40px 80px -28px rgba(12, 38, 27, 0.28),
    0 14px 28px rgba(12, 38, 27, 0.08),
    inset 0 0 0 1px rgba(12, 38, 27, 0.04) !important;
  max-width: 420px;
  margin-left: auto !important;
  margin-right: 0 !important;
}
@media (max-width: 880px) {
  .realiteit-photo--portrait {
    max-width: 100%;
    aspect-ratio: 3 / 4 !important;
    margin: 0 auto !important;
    border-radius: 20px 64px 20px 20px !important;
  }
}

/* ============================================================
 * HOME PROMO VIDEO — onderaan de homepage
 * ============================================================ */
.home-promo-video {
  padding: 64px 0 24px;
  background: var(--cream);
}
.home-promo-video .hpv-player {
  max-width: 980px;
  margin: 0 auto;
  border-radius: 48px;
  overflow: hidden;
  background: var(--green-deep);
  box-shadow: 0 24px 60px rgba(12, 38, 27, 0.18);
  aspect-ratio: 16 / 9;
  isolation: isolate;
  transform: translateZ(0);
  -webkit-mask-image: -webkit-radial-gradient(white, black);
}
.home-promo-video .hpv-player video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: 48px;
}
@media (max-width: 720px) {
  .home-promo-video { padding: 40px 0 16px; }
  .home-promo-video .hpv-player {
    border-radius: 28px;
    box-shadow: 0 12px 30px rgba(12, 38, 27, 0.14);
  }
  .home-promo-video .hpv-player video {
    border-radius: 28px;
  }
}

/* ============================================================
 * PREMIUM TYPOGRAPHY — Inter site-wide (overschrijft Poppins/Open Sans)
 * Inter is de digitale standaard van Stripe / Linear / Vercel.
 * Toegepast op alle pagina's + subpagina's via :root vars.
 * ============================================================ */
:root {
  --f-display: 'Plus Jakarta Sans', 'Poppins', 'Helvetica Neue', Arial, sans-serif !important;
  --f-sans:    'Plus Jakarta Sans', 'Open Sans', 'Helvetica Neue', Arial, sans-serif !important;
}
body, main, section, p, span, a, button, input, textarea, select, label, h1, h2, h3, h4, h5, h6 {
  font-family: 'Plus Jakarta Sans', 'Poppins', 'Helvetica Neue', Arial, sans-serif;
}
/* Stem heading-tracking + weight op Inter zodat 'ie spannend uitziet */
h1, h2, h3, h4 {
  font-family: 'Plus Jakarta Sans', 'Poppins', 'Helvetica Neue', Arial, sans-serif;
  font-feature-settings: "ss01" 1, "cv11" 1; /* Inter stylistic alternates */
  letter-spacing: -0.025em;
}

/* === Grote stat-getallen NIET meer in Fraunces-italic — Inter bold === */
.aanv-trust .ti b,
.aanv-trust .ti strong,
.hero-stats-row .num,
.hero-stats-charts .num,
.hero-stats-row .num em,
.hero-stats-charts .num em,
.hero-stats-row .num strong,
.hero-stats-charts .num strong,
.ph-trust .ti b,
.ed-stat-num,
.ed-stat-num em,
.ed-stat-num strong,
.ed-stats .num,
.ed-stats .num em,
section .stat-num,
section .stat-num em,
.page-hero .meta-row .item b,
.page-hero .meta-row .item strong,
[class*="-stats"] .num,
[class*="-stats"] .num em,
[class*="-stats"] em.num,
[class*="-stat-num"],
[class*="-stat-num"] em,
.num-big,
.fg-stat,
.spec-num,
.kc-num {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif !important;
  font-style: normal !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
}

/* Drop-cap (eerste letter in editorial paragraphs) blijft Fraunces — dat is bewust */
.aanv-bigp::first-letter,
.kc-bigp::first-letter,
.bigp::first-letter,
section p.bigp::first-letter {
  font-family: 'Fraunces', Georgia, serif;
}

/* ============================================================
 * WERKWIJZE — totale make-over
 *   Schone hero, compacte stats-strip, verticale timeline
 * ============================================================ */

/* Hero — donker, simpel, statement-only */
.wkw-hero {
  background:
    radial-gradient(ellipse 900px 700px at 95% 5%, rgba(136, 217, 50, 0.14), transparent 60%),
    radial-gradient(ellipse 800px 600px at 5% 95%, rgba(0, 0, 0, 0.35), transparent 65%),
    linear-gradient(45deg, #06180E 0%, var(--green-deep) 45%, #143A28 100%);
  color: var(--cream);
  padding: clamp(110px, 14vh, 160px) 0 clamp(80px, 10vh, 120px);
  min-height: clamp(620px, 70vh, 820px);
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.wkw-hero-inner {
  max-width: 880px;
}
.wkw-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: var(--f-display);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 24px;
}
.wkw-eyebrow-line {
  width: 32px;
  height: 2px;
  background: var(--green);
  display: inline-block;
}
.wkw-hero-title {
  font-family: var(--f-display);
  font-size: clamp(44px, 6vw, 84px);
  font-weight: 800;
  line-height: 1.0;
  letter-spacing: -0.035em;
  color: var(--cream);
  margin: 0 0 24px;
  max-width: 18ch;
  text-wrap: balance;
}
.wkw-hero-lead {
  font-size: clamp(17px, 1.4vw, 20px);
  line-height: 1.6;
  color: rgba(252, 247, 242, 0.82);
  max-width: 56ch;
  margin: 0 0 36px;
}
.wkw-hero-ctas {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  align-items: center;
}
.wkw-cta-primary {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--green);
  color: var(--green-deep);
  font-family: var(--f-display);
  font-size: 15.5px;
  font-weight: 700;
  padding: 16px 30px;
  border-radius: 100px;
  text-decoration: none;
  transition: transform 0.18s, box-shadow 0.18s, background 0.18s;
  box-shadow: 0 10px 28px rgba(136, 217, 50, 0.30);
}
.wkw-cta-primary:hover {
  background: var(--green-bright);
  transform: translateY(-2px);
  box-shadow: 0 16px 36px rgba(136, 217, 50, 0.40);
}
.wkw-cta-ghost {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 26px;
  border-radius: 100px;
  border: 1.5px solid rgba(252, 247, 242, 0.30);
  color: var(--cream);
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 14.5px;
  text-decoration: none;
  transition: border-color 0.18s, background 0.18s, transform 0.18s;
}
.wkw-cta-ghost:hover {
  border-color: var(--green);
  background: rgba(136, 217, 50, 0.08);
  transform: translateY(-2px);
}

/* Stats-strip — compact, witte band onder hero */
.wkw-stats {
  background: var(--paper);
  padding: clamp(36px, 4vw, 56px) 0;
  border-bottom: 1px solid var(--rule);
}
.wkw-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.wkw-stat {
  text-align: center;
  padding: 8px 24px;
  border-right: 1px solid var(--rule);
}
.wkw-stat:last-child { border-right: none; }
.wkw-stat-num {
  font-family: var(--f-display);
  font-size: clamp(32px, 3.8vw, 48px);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--green-deep);
  line-height: 1;
  margin-bottom: 8px;
}
.wkw-stat-lbl {
  font-size: 13px;
  line-height: 1.4;
  color: var(--muted);
  font-weight: 500;
}
@media (max-width: 720px) {
  .wkw-stats-grid { grid-template-columns: repeat(2, 1fr); gap: 32px 0; }
  .wkw-stat:nth-child(2) { border-right: none; }
}

/* Timeline — verticale flow, schoon */
.wkw-timeline {
  background: var(--cream);
  padding: clamp(72px, 10vw, 120px) 0;
}
.wkw-timeline-head {
  max-width: 720px;
  margin: 0 0 clamp(48px, 6vw, 80px);
}
.wkw-section-title {
  font-family: var(--f-display);
  font-size: clamp(36px, 4.8vw, 64px);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: var(--green-deep);
  margin: 0;
}
.wkw-section-title em {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  color: var(--green-text);
}
.wkw-timeline .wkw-eyebrow { color: var(--green-text); margin-bottom: 18px; }
.wkw-timeline .wkw-eyebrow-line { background: var(--green-text); }

.wkw-steps {
  list-style: none;
  margin: 0;
  padding: 0;
  max-width: 880px;
  margin-left: auto;
  margin-right: auto;
  position: relative;
}
.wkw-step {
  position: relative;
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 32px;
  padding-bottom: clamp(40px, 4vw, 56px);
}
.wkw-step:last-child { padding-bottom: 0; }

/* Verbindings-lijn (verticaal tussen markers) */
.wkw-step:not(:last-child)::before {
  content: '';
  position: absolute;
  left: 39px;
  top: 60px;
  bottom: 0;
  width: 2px;
  background: linear-gradient(180deg, var(--green) 0%, rgba(136, 217, 50, 0.2) 100%);
}

.wkw-step-marker {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: var(--paper);
  border: 2px solid var(--green);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--f-display);
  font-size: 17px;
  font-weight: 800;
  color: var(--green-deep);
  flex-shrink: 0;
  position: relative;
  z-index: 1;
  box-shadow: 0 4px 16px rgba(136, 217, 50, 0.18);
  transition: transform 0.22s ease, box-shadow 0.22s ease, background 0.22s ease;
}
.wkw-step:hover .wkw-step-marker {
  background: var(--green);
  color: var(--green-deep);
  transform: scale(1.08);
  box-shadow: 0 8px 28px rgba(136, 217, 50, 0.36);
}

.wkw-step-body {
  padding-top: 4px;
  min-width: 0;
}
.wkw-step-head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 14px;
  margin-bottom: 14px;
}
.wkw-step-head h3 {
  font-family: var(--f-display);
  font-size: clamp(22px, 2.4vw, 30px);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--green-deep);
  margin: 0;
  flex: 1;
  min-width: 220px;
}
.wkw-step-time {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  border-radius: 100px;
  background: rgba(136, 217, 50, 0.16);
  color: var(--green-text);
  font-family: var(--f-display);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
}
.wkw-step-body p {
  font-size: 16px;
  line-height: 1.65;
  color: var(--ink-2);
  margin: 0 0 18px;
  max-width: 60ch;
}
.wkw-step-bullets {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px 24px;
}
.wkw-step-bullets li {
  position: relative;
  padding-left: 26px;
  font-size: 14.5px;
  line-height: 1.5;
  color: var(--ink-2);
}
.wkw-step-bullets li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 7px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--green) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230C261B' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/10px no-repeat;
}

@media (max-width: 720px) {
  .wkw-step { grid-template-columns: 48px 1fr; gap: 18px; }
  .wkw-step-marker { width: 48px; height: 48px; font-size: 14px; }
  .wkw-step:not(:last-child)::before { left: 31px; top: 50px; }
  .wkw-step-bullets { grid-template-columns: 1fr; }
}

/* ============================================================
   HERO STATS · EDITORIAL KEYLINES  (vervangt de oude mini-charts)
   Puur typografisch: cijfers + dunne keylines. Geen iconen/grafieken.
   Scoped op .hero-stats-keylines — botst niet met oude
   .hero-stats-row / .hero-stats-charts regels (die zijn nu dood).
   Count-up loopt via [data-counter] (motion.js observeert per element).
============================================================ */
.hero-stats-keylines {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  align-items: start;
  gap: 0;
  margin-top: clamp(40px, 5vw, 64px);
  padding: clamp(32px, 4vw, 48px) 0 clamp(36px, 4vw, 52px);
  border-top: 1px solid rgba(244, 236, 225, 0.12);
}

.hero-stats-keylines .hsk-item {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 4px 32px;
  border-left: 1px solid rgba(244, 236, 225, 0.12);
  opacity: 1;
  transform: none;
  animation: none;
}
.hero-stats-keylines .hsk-item:first-child {
  padding-left: 0;
  border-left: 0;
}
.hero-stats-keylines .hsk-item:nth-child(1) { animation-delay: 0.05s; }
.hero-stats-keylines .hsk-item:nth-child(2) { animation-delay: 0.12s; }
.hero-stats-keylines .hsk-item:nth-child(3) { animation-delay: 0.19s; }
.hero-stats-keylines .hsk-item:nth-child(4) { animation-delay: 0.26s; }

.hero-stats-keylines .hsk-num {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: clamp(34px, 4.4vw, 44px);
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--cream);
  font-feature-settings: "tnum" 1, "lnum" 1;
  font-variant-numeric: tabular-nums lining-nums;
}
.hero-stats-keylines .hsk-num em {
  font-style: normal;
  color: var(--green);
}
/* Soepele count-up: pin de cijferbox op de exacte eindbreedte (tabular-nums,
   letter-spacing 0) zodat de box tijdens het tellen NIET van breedte verandert
   — geen reflow per frame en geen verspringende +/%. contain:layout houdt een
   reflow binnen het element. Volgorde vast: 1=250 (3 cijfers), 2=92 & 3=35 (2). */
.hero-stats-keylines .hsk-num { contain: layout; }
.hero-stats-keylines .hsk-num em[data-counter] {
  display: inline-block;
  text-align: right;
  letter-spacing: 0;
  font-variant-numeric: tabular-nums;
}
.hero-stats-keylines .hsk-item:nth-child(1) .hsk-num em[data-counter] { min-width: 3ch; }
.hero-stats-keylines .hsk-item:nth-child(2) .hsk-num em[data-counter],
.hero-stats-keylines .hsk-item:nth-child(3) .hsk-num em[data-counter] { min-width: 2ch; }

.hero-stats-keylines .hsk-lbl {
  font-family: var(--f-sans);
  font-size: 12px;
  font-weight: 500;
  line-height: 1.35;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(252, 247, 242, 0.68);
  max-width: 14ch;
}

@keyframes hsk-rise {
  to { opacity: 1; transform: translateY(0); }
}

/* Tablet -> 2x2 raster, keyline tussen kolommen blijft */
@media (max-width: 880px) {
  .hero-stats-keylines {
    grid-template-columns: repeat(2, 1fr);
    row-gap: 32px;
  }
  .hero-stats-keylines .hsk-item {
    padding: 4px 0 4px 28px;
  }
  .hero-stats-keylines .hsk-item:nth-child(odd) {
    padding-left: 0;
    border-left: 0;
  }
  .hero-stats-keylines .hsk-item:nth-child(3) { padding-top: 24px; }
  .hero-stats-keylines .hsk-item:nth-child(4) { padding-top: 24px; }
}

/* Mobiel -> 2x2 blijft, iets compacter; cijfer leidend */
@media (max-width: 480px) {
  .hero-stats-keylines {
    padding-top: 32px;
    margin-top: 36px;
  }
  .hero-stats-keylines .hsk-item { padding-left: 20px; gap: 8px; }
  .hero-stats-keylines .hsk-item:nth-child(odd) { padding-left: 0; }
  .hero-stats-keylines .hsk-num { font-size: clamp(30px, 9vw, 36px); }
  .hero-stats-keylines .hsk-lbl { font-size: 11px; letter-spacing: 0.06em; }
}

/* Toegankelijkheid: geen beweging */
@media (prefers-reduced-motion: reduce) {
  .hero-stats-keylines .hsk-item {
    opacity: 1;
    transform: none;
    animation: none;
  }
}

/* ============================================================================
   RESPONSIVE CONSOLIDATIE — STAP 1-7  (responsive-audit, 2026-06)
   Additieve overrides bovenop de bestaande stijlen; desktop blijft intact.
   Nieuwe regels gebruiken 3 gestandaardiseerde breakpoints: 1024 / 768 / 480px
   (desktop-first, grootste eerst). De vacatures-filter-fix hieronder gebruikt
   bewust 980px, omdat hij een bestaande, kapotte 980px-regel neutraliseert.
   N.B.: CSS custom properties kunnen niet in @media-condities (vanilla CSS),
   vandaar 3 vaste px-waarden i.p.v. variabelen.
   ============================================================================ */

/* ---------- STAP5: vloeiende clamp() voor KALE koppen (zonder class) ----------
   Section-koppen met een eigen class (.hero h1, .page-hero h1, .city-section h2, …)
   houden hun grootte via hogere specificiteit; alleen kale h1/h2/h3 schalen mee. */
h1 { font-size: clamp(2rem, 5vw + 1rem, 4rem); }
h2 { font-size: clamp(1.5rem, 3.5vw + 0.75rem, 2.75rem); }
h3 { font-size: clamp(1.125rem, 2vw + 0.5rem, 1.75rem); }

/* ========================= md: <= 1024px (tablet landscape) ================= */
@media (max-width: 1024px) {
  /* STAP4: vacaturekaarten 2 per rij op tablet (3 per rij blijft >= 1025px) */
  .jobs-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ========================= sm: <= 768px (telefoon / kleine tablet) ========== */
@media (max-width: 768px) {
  /* STAP4: vacaturekaarten 1 per rij */
  .jobs-grid { grid-template-columns: 1fr; }

  /* STAP4: stappen-/werkwijze-sectie verticaal gestapeld */
  .process-grid { grid-template-columns: 1fr; }
  .process-step { border-right: 0; }

  /* STAP6/STAP4: brede <table>'s (tarieven-modellen + salaris-tabel op de
     vakkracht-pagina's) horizontaal scrollbaar i.p.v. afgeknipt of geperst */
  .city-section table {
    display: block; width: 100%; max-width: 100%;
    overflow-x: auto; -webkit-overflow-scrolling: touch;
  }
  .city-section table thead,
  .city-section table tbody { display: table; width: 100%; min-width: 480px; }
  .city-section table th,
  .city-section table td { padding: 10px 12px; font-size: 14px; vertical-align: top; }
  .city-section table th { font-family: var(--f-display); font-weight: 700; text-align: left; }

  /* STAP7: Trengo chat-launcher boven de sticky CTA-balk tillen (balk ~64px) */
  #trengo-web-widget,
  .trengo-floating-button,
  .trengo-widget-button,
  .trengo-vue-widget { bottom: 92px !important; }
}

/* STAP6: de vacatures-filter was een off-canvas drawer ZONDER werkende toggle
   (vacancy-filters.js wordt nergens geladen) -> filters onbereikbaar op mobiel.
   Terug naar een normaal, in-flow gestapeld paneel boven de resultaten.
   Zelfde breakpoint (<=980px) als de kapotte regel zodat 769-980px ook gedekt is. */
@media (max-width: 980px) {
  .vac-filters {
    position: static; transform: none;
    width: auto; max-width: none; z-index: auto; height: auto;
    border: 1px solid var(--rule);
    border-radius: var(--radius-lg);
    margin-bottom: 20px;
  }
  .vac-drawer-overlay { display: none !important; }
  .vac-tool-mobile { display: none !important; }
}

/* ========================= xs: <= 480px (kleine telefoon) ================== */
@media (max-width: 480px) {
  /* STAP4: CTA-knopgroepen gestapeld + volledige breedte */
  .aud-card .cta-row,
  .contact-cta .btn-row,
  .contact-grid .btn-row { display: flex; flex-direction: column; align-items: stretch; }
  .aud-card .cta-row > a,
  .aud-card .cta-row > .btn-primary,
  .aud-card .cta-row > .btn-secondary,
  .contact-cta .btn-row > a,
  .contact-cta .btn-row > .btn-primary,
  .contact-cta .btn-row > .btn-secondary,
  .contact-grid .btn-row > a,
  .contact-grid .btn-row > .btn-primary,
  .contact-grid .btn-row > .btn-secondary { width: 100%; justify-content: center; }

  /* STAP1: smalle telefoons — flex-items met min-width laten krimpen i.p.v.
     net buiten beeld te duwen */
  .cert-banner .cert-banner-text { min-width: 0; flex-basis: 100%; }
  .job-card-wide .jcw-skills { min-width: 0; flex-basis: 100%; }
  .wkw-step-head h3 { min-width: 0; flex-basis: 100%; }

  /* STAP5: te krappe horizontale padding op de single-traject kaart */
  .audience.audience-single .aud-card { padding: 28px 20px; }
}

/* ============================================================================
   STAP8 — TOEGANKELIJKHEID (axe/WCAG 2 AA, mobiel geverifieerd)
   ============================================================================ */

/* Mobiel drawer mag niet focusbaar zijn wanneer gesloten. mobile-nav.js houdt
   aria-hidden synchroon (true=dicht / false=open); visibility:hidden haalt de
   links uit de tab-volgorde -> lost axe 'aria-hidden-focus' op. */
@media (max-width: 980px) {
  #navLinksMenu[aria-hidden="true"]  { visibility: hidden; }
  /* ook de interactieve descendants expliciet (sommige reveal-regels heffen de
     geerfde visibility op) — id-specificiteit wint van class-regels */
  #navLinksMenu[aria-hidden="true"] a,
  #navLinksMenu[aria-hidden="true"] button,
  #navLinksMenu[aria-hidden="true"] input,
  #navLinksMenu[aria-hidden="true"] [tabindex] { visibility: hidden; }
  #navLinksMenu[aria-hidden="false"] { visibility: visible; }
}

/* Contrast: groene accent-tekst op lichte achtergrond moet --green-text
   (#3F7A0E, AA-conform) gebruiken i.p.v. de neon --green/--green-ink — exact
   wat de design-token-comment al voorschrijft. Alleen licht-bg accenten. */
.testimonials-head .eyebrow,
.vac-filters h4,
.city-section h2 em,
.vind-baan-title em { color: var(--green-text); }

/* ============================================================================
   MOBIELE NAV — REDESIGN (header-balk + drawer)  ·  <= 980px
   Autoritatief met !important: de inline critical-css laadt NA styles.css en
   her-toont de CTA-groep zonder mobiele hide-regels (CTA's liepen buiten beeld
   + hamburger wikkelde onder de balk). Dit blok zet de mobiele nav definitief.
   ============================================================================ */
@media (max-width: 980px) {
  /* ---------- HEADER-BALK: logo links · compacte CTA + hamburger rechts ------ */
  .nav .wrap { max-width: 100%; }
  .nav-inner {
    display: flex !important;
    grid-template-columns: none !important;
    align-items: center !important;
    gap: 10px !important;
    height: 64px !important;
  }
  .nav-inner > .logo { margin-right: auto; flex-shrink: 0; min-width: 0; }
  .nav-inner > .logo img { height: 28px !important; }

  /* CTA-groep: alleen een compacte 'Solliciteren'-pill blijft in de balk */
  .nav-cta-group { gap: 8px !important; flex-shrink: 0; }
  .nav-cta-group .icon-btn,
  .nav-cta-group .lang-dropdown,
  .nav-cta-group a.nav-cta[href*="aanvraag"] { display: none !important; }
  .nav-cta-group a.nav-cta[href*="solliciteren"] {
    display: inline-flex !important;
    height: 40px !important;
    padding: 0 16px !important;
    font-size: 13px !important;
    border-radius: 999px !important;
    white-space: nowrap;
  }
  .nav-cta-group a.nav-cta[href*="solliciteren"] span { display: none !important; }

  /* Hamburger: verfijnd, 44px, altijd inline als laatste element (geen wrap) */
  .nav-burger {
    display: inline-flex !important;
    width: 44px !important; height: 44px !important;
    border: 1px solid var(--rule) !important;
    border-radius: 12px !important;
    background: var(--paper) !important;
    flex-shrink: 0;
    margin-left: 0 !important;
    transition: border-color .15s ease, background .15s ease;
  }
  .nav.nav-open .nav-burger { border-color: var(--green-deep) !important; background: var(--cream-2) !important; }
  /* Header BOVEN de backdrop tillen wanneer open, zodat de ✕-hamburger direct
     tikbaar blijft om te sluiten (anders dekt de backdrop hem af). */
  .nav.nav-open { z-index: 101 !important; }

  /* ---------- DRAWER: opaak, vol-hoog, hoog contrast, premium spacing -------- */
  /* backdrop: simpele donkere dim ZONDER blur — de blur "bloedde" over de
     opake drawer heen (backdrop-filter stacking-artefact) en maakte alles flets */
  .nav-backdrop {
    z-index: 90 !important;
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
    background: rgba(8, 24, 17, 0.48) !important;
  }
  .nav-links {
    top: 64px !important;
    left: auto !important; right: 0 !important; bottom: 0 !important;
    width: min(90vw, 380px) !important;
    /* expliciete hoogte: in flex-context rekt top+bottom niet uit (anders 54px) */
    height: calc(100dvh - 64px) !important;
    background: var(--paper) !important;
    /* glassmorphism-blur weg: gaf een fletse frosted look met laag contrast */
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
    border-top: 0 !important;
    border-left: 1px solid var(--rule) !important;
    box-shadow: -22px 0 60px rgba(12, 38, 27, 0.22) !important;
    padding: 20px 22px calc(40px + env(safe-area-inset-bottom, 0px)) !important;
    gap: 0 !important;
    justify-content: flex-start !important;  /* inhoud bovenaan i.p.v. gecentreerd */
    z-index: 95 !important;
  }
  .nav-links .mb-drawer-foot { margin-top: auto !important; }  /* contact onderaan duwen */
  .nav-links .item { border-bottom: 1px solid var(--rule) !important; }
  .nav-links .item > a {
    font-size: 17px !important;
    padding: 16px 2px !important;
    color: var(--green-deep) !important;
    font-weight: 700 !important;
    font-family: var(--f-display) !important;
  }
  .nav-links .item.active > a { color: var(--green-text) !important; }
  /* Accordion-kop (mega) labels + links */
  .nav-links .item .mega { padding: 0 0 14px 6px !important; }
  .nav-links .item .mega .col-label,
  .nav-links .item .mega h3,
  .nav-links .item .mega h5 {
    color: var(--green-text) !important;
    font-weight: 700 !important;
    margin: 10px 0 6px !important;
  }
  .nav-links .item .mega a {
    color: var(--ink-2) !important;
    font-size: 15px !important;
    /* reset de desktop mega-menu negatieve marge (-12px) die de sublinks naar
       links trok en tegen de drawer-rand duwde — nu netjes uitgelijnd.
       padding 12px -> ~44px touch-target (zonder de pijl-layout te wijzigen). */
    margin: 0 !important;
    padding: 12px 2px !important;
  }
  /* Accordion-chevron */
  .mb-chevron { color: var(--green-deep) !important; opacity: .8; }

  /* Drawer-footer: contact, net afgescheiden. Taalwisselaar (NL/ES/PT/IT) is
     stale — de site is NL-only — dus verbergen. */
  .mb-drawer-lang { display: none !important; }
  .mb-drawer-foot {
    margin-top: 20px !important;
    padding-top: 20px !important;
    border-top: 1px solid var(--rule) !important;
  }
  .mb-drawer-tel {
    display: inline-flex; align-items: center; gap: 8px;
    color: var(--green-deep) !important; font-weight: 700 !important;
    font-family: var(--f-display); font-size: 16px !important;
  }
  .mb-drawer-addr { color: var(--muted) !important; font-size: 13px !important; line-height: 1.5; }
}

/* Op heel kleine telefoons (<=360px): laat de balk-CTA weg, alleen logo + burger */
@media (max-width: 360px) {
  .nav-cta-group a.nav-cta[href*="solliciteren"] { display: none !important; }
}

/* ============================================================================
   MOBIELE NAV — PREMIUM DARK DRAWER + verfijnde hamburger  (<= 980px)
   Donkergroen menu in dezelfde sfeer als de hero; zachtere hamburger.
   Overruled de eerdere licht-thema-regels (zelfde specificiteit, later in bron).
   ============================================================================ */
@media (max-width: 980px) {
  /* ---- Hamburger: zacht vlak i.p.v. harde box-border ---- */
  .nav-burger {
    border: 0 !important;
    background: var(--cream-2) !important;
    border-radius: 13px !important;
  }
  .nav-burger span {
    background: var(--green-deep) !important;
    width: 20px !important; height: 2px !important; border-radius: 2px;
  }
  .nav.nav-open .nav-burger { background: var(--green-deep) !important; }
  .nav.nav-open .nav-burger span { background: var(--cream) !important; }

  /* ---- Drawer: donkergroen verloop, opaak ---- */
  .nav-links {
    background: linear-gradient(168deg, #0e2c1b 0%, var(--green-deep) 52%, #06170d 100%) !important;
    border-left: 1px solid rgba(252, 247, 242, 0.10) !important;
    box-shadow: -24px 0 64px rgba(0, 0, 0, 0.45) !important;
  }
  /* Hoofd-links: cream, ruim */
  .nav-links .item { border-bottom: 1px solid rgba(252, 247, 242, 0.10) !important; }
  .nav-links .item > a { color: var(--cream) !important; }
  .nav-links .item.active > a { color: var(--green) !important; }
  /* Accordion: groene labels, lichte sublinks */
  .nav-links .item .mega .col-label,
  .nav-links .item .mega h3,
  .nav-links .item .mega h5 { color: var(--green) !important; }
  .nav-links .item .mega a { color: rgba(252, 247, 242, 0.72) !important; }
  .nav-links .item .mega a:hover { color: var(--cream) !important; }
  /* Chevron */
  .mb-chevron { color: var(--cream) !important; opacity: .9; }
  .item.mb-open > .mb-chevron { color: var(--green) !important; }

  /* ---- Footer + contact-kaarten op donker ---- */
  .mb-drawer-foot { border-top: 1px solid rgba(252, 247, 242, 0.12) !important; }
  .mb-drawer-tel,
  .mb-drawer-addr {
    background: rgba(252, 247, 242, 0.06) !important;
    border: 1px solid rgba(252, 247, 242, 0.14) !important;
    color: var(--cream) !important;
  }
  .mb-drawer-tel:hover { background: rgba(136, 217, 50, 0.14) !important; border-color: var(--green) !important; }
  .mb-drawer-tel svg,
  .mb-drawer-addr svg { color: var(--green) !important; }
  .mb-drawer-tel small,
  .mb-drawer-addr small { color: rgba(252, 247, 242, 0.55) !important; }
  .mb-drawer-tel strong,
  .mb-drawer-addr strong { color: var(--cream) !important; }
}

/* ============================================================================
   Emoji-iconen verwijderd -> lege icon-containers netjes laten inklappen
   (downloads/sitemap/zoeken). SVG line-iconen kunnen later worden toegevoegd.
   ============================================================================ */
.dl-icon:empty,
.sm-cat-icon:empty,
.srch-empty-icon:empty { display: none; }


/* ===== EDITORIAL ROWS — vacaturekaart-herontwerp (overruled oudere .vac-list/.vac-row blokken via volgorde) ===== */
/* ============================================================
   VACANCY LIST — "Editorial Rows"
   One continuous paper panel, hairline dividers, sector accent,
   full-row hover-fill. Styles BOTH renderers:
   - static SSG  : .vac-row > .left/.right (.badges-row/.company-row/h3/.salary/.arrow)
   - client-side : .vac-row > .vac-row-main > .vac-row-left/.vac-row-right (.vac-row-*)
   Requires data-sector="<raw lowercase sector>" on each .vac-row (see markupNotes).
   ============================================================ */

/* ---- The list becomes ONE surface, not 50 floating boxes ---- */
.vac-list{
  display:flex; flex-direction:column; gap:0;
  background:var(--paper);
  border:1px solid var(--rule);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:0 1px 2px rgba(12,38,27,.04), 0 18px 40px -28px rgba(12,38,27,.18);
}

/* ---- Row reset (kills the old per-card box look) ---- */
.vac-list .vac-row,
.vac-row{
  display:block;
  background:transparent;
  border:0;
  border-top:1px solid var(--rule);
  border-radius:0;
  padding:0;
  margin:0;
  position:relative;
  isolation:isolate;
  text-decoration:none;
  color:inherit;
  transition:background .18s ease;
  animation:none;
}
.vac-list .vac-row:first-child,
.vac-list .vac-row:first-child{ border-top:0; }

/* Left sector accent rail (depth + colour + scannability) */
.vac-row::before{
  content:""; position:absolute; left:0; top:0; bottom:0;
  width:3px; background:var(--vac-accent,var(--green-text));
  transform:scaleX(.5); transform-origin:left;
  opacity:.5; transition:transform .18s ease, opacity .18s ease;
  z-index:1;
}

/* Per-sector accent colour (raw lowercase sector slug). Default = green-ink. */
.vac-row{ --vac-accent:var(--green-text); --vac-dot:var(--green-text); }
.vac-row[data-sector="metaaltechniek"]    { --vac-accent:#3F7A0E; --vac-dot:#3F7A0E; }
.vac-row[data-sector="productie"]         { --vac-accent:var(--green-text); --vac-dot:var(--green-text); }
.vac-row[data-sector="installatietechniek"]{ --vac-accent:#1C7C5B; --vac-dot:#1C7C5B; }
.vac-row[data-sector="bouw"]              { --vac-accent:#8A6A1E; --vac-dot:#8A6A1E; }
.vac-row[data-sector="logistiek"]         { --vac-accent:#2F5DA8; --vac-dot:#2F5DA8; }

/* ---- HOVER: full-row warm fill + accent grows ---- */
.vac-list .vac-row:hover,
.vac-row:hover{
  background:
    linear-gradient(90deg, rgba(136,217,50,.08), rgba(252,247,242,0) 38%),
    var(--cream);
  transform:none; box-shadow:none;
}
.vac-row:hover::before{ transform:scaleX(1.6); opacity:1; }
.vac-row:focus-within{ background:var(--cream-2); }
.vac-row:has(.vac-row-main:focus-visible) .vac-row-arrow,
.vac-row:has(.left):focus-within .arrow{ background:var(--green); }

/* ---- Inner grid (both renderers) ---- */
.vac-row .left,
.vac-row .vac-row-left{ display:flex; flex-direction:column; gap:7px; min-width:0; }

/* The clickable inner area */
.vac-row > .left,
.vac-row > .right{ /* static: row is the <a>; give it the grid */ }
.vac-row:not(:has(.vac-row-main)){
  display:grid; grid-template-columns:1fr auto;
  align-items:center; gap:24px;
  padding:22px 28px 22px 30px;
}
.vac-row-main{
  display:grid; grid-template-columns:1fr auto;
  align-items:center; gap:24px;
  padding:22px 28px 22px 30px;
  text-decoration:none; color:inherit;
}

/* ---- Badges row → quieter, with a coloured sector dot ---- */
.vac-row .badges-row,
.vac-row .vac-badges-row{
  display:flex; gap:8px; align-items:center; flex-wrap:wrap; margin-bottom:1px;
}
/* Sector becomes a calm label with a leading colour dot, not a loud green pill */
.vac-row .badge,
.vac-row .vac-badge{
  font-family:var(--f-display); font-size:10px; font-weight:700;
  letter-spacing:.07em; text-transform:uppercase;
  padding:3px 9px; border-radius:999px; line-height:1.5;
  display:inline-flex; align-items:center; gap:6px;
}
.vac-row .badge.new,
.vac-row .vac-badge-sector{
  background:transparent; color:var(--green-deep);
  padding-left:0; letter-spacing:.09em;
}
.vac-row .badge.new::before,
.vac-row .vac-badge-sector::before{
  content:""; width:7px; height:7px; border-radius:50%;
  background:var(--vac-dot); flex:0 0 7px;
  box-shadow:0 0 0 3px color-mix(in srgb,var(--vac-dot) 18%, transparent);
}
.vac-row .badge.std,
.vac-row .vac-badge-std{
  background:var(--cream-2); color:var(--muted);
  border:1px solid var(--rule); font-weight:600; letter-spacing:.04em;
}
/* keep "nieuw" as the only solid green accent → real signal */
.vac-row .vac-badge-new{ background:var(--green); color:var(--green-deep); }
.vac-row .vac-badge-urgent{
  background:#fff1ee; color:#c75431; border:1px solid #f3d3c5;
}

/* ---- Title: bigger, confident ---- */
.vac-row h3,
.vac-row .vac-row-title{
  font-size:23px; line-height:1.15; letter-spacing:-.025em;
  font-weight:700; font-family:var(--f-display);
  color:var(--green-deep); margin:0;
  transition:color .15s ease;
}
.vac-row:hover h3,
.vac-row:hover .vac-row-title{ color:#06180E; }

/* ---- Meta: quiet, hairline-separated ---- */
.vac-row .company-row,
.vac-row .vac-row-meta{
  display:flex; flex-wrap:wrap; align-items:center;
  gap:6px 16px; font-size:13.5px; color:var(--muted); margin-top:2px;
}
.vac-row .company-row span,
.vac-row .vac-row-meta-item{ display:inline-flex; align-items:center; gap:6px; }
.vac-row .company-row svg,
.vac-row .vac-row-meta-item svg{ width:14px; height:14px; opacity:.55; flex-shrink:0; color:var(--green-text); }

/* ---- Right column: salary anchor + arrow ---- */
.vac-row .right,
.vac-row .vac-row-right{
  display:flex; flex-direction:column; align-items:flex-end;
  gap:10px; text-align:right; min-width:170px;
}
.vac-row .salary,
.vac-row .vac-row-salary{
  font-family:var(--f-display); font-size:17px; font-weight:700;
  color:var(--green-deep); letter-spacing:-.01em; line-height:1.25;
}
.vac-row .salary span,
.vac-row .vac-row-salary-unit{
  display:block; font-size:11px; color:var(--muted);
  font-weight:500; letter-spacing:0; margin-top:1px;
}

/* Inline arrow (no heavy circle) that slides on hover */
.vac-row .arrow,
.vac-row .vac-row-arrow{
  width:34px; height:34px; border-radius:50%;
  background:var(--cream-2); color:var(--green-deep);
  display:inline-flex; align-items:center; justify-content:center;
  font-size:15px; transition:background .18s ease, transform .18s ease;
}
.vac-row:hover .arrow,
.vac-row:hover .vac-row-arrow{
  background:var(--green); transform:translateX(4px);
}
.vac-row-actions{ display:flex; align-items:center; gap:8px; margin-top:2px; }

/* ---- Save / quick buttons stay top-right, lighter on the new surface ---- */
.vac-save,
.vac-row-quick{ position:absolute; top:16px; right:18px; z-index:3; display:flex; gap:6px; }
.vac-save{ width:32px; height:32px; }
.vac-quick-btn,
.vac-save{
  width:32px; height:32px; border-radius:50%;
  border:1px solid var(--rule); background:var(--paper);
  color:var(--muted); display:inline-flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all .15s ease; text-decoration:none;
}
.vac-quick-btn:hover,
.vac-save:hover{ border-color:var(--green-deep); color:var(--green-deep); background:var(--cream); }
.vac-quick-save.is-saved,
.vac-save.is-saved{ color:var(--green-deep); border-color:var(--green-deep); background:var(--green); }
.vac-quick-wa{ color:#1f9e4d; border-color:#cdeeda; background:#f2fbf5; }
.vac-quick-wa:hover{ color:#fff; background:#25d366; border-color:#25d366; }

/* keep mini salary-bar but tint it to the sector accent */
.vac-salbar-fill{ background:linear-gradient(to right,var(--vac-accent),var(--green)); }

/* ---- Mobile ---- */
@media (max-width:600px){
  .vac-row:not(:has(.vac-row-main)),
  .vac-row-main{
    grid-template-columns:1fr; gap:14px; padding:18px 18px 18px 22px;
  }
  .vac-row .right,
  .vac-row .vac-row-right{
    align-items:center; text-align:left;
    flex-direction:row; justify-content:space-between;
    min-width:0; width:100%;
  }
  .vac-row h3,
  .vac-row .vac-row-title{ font-size:19px; padding-right:84px; }
  .vac-save,
  .vac-row-quick{ top:14px; right:14px; }
  /* on touch, surface the accent + arrow a touch since there's no hover */
  .vac-row::before{ transform:scaleX(1); opacity:.8; }
}

/* ---- Reduced motion ---- */
@media (prefers-reduced-motion:reduce){
  .vac-row, .vac-row::before, .vac-row .arrow, .vac-row .vac-row-arrow,
  .vac-row h3, .vac-row .vac-row-title{ transition:none; animation:none; }
  .vac-row:hover .arrow, .vac-row:hover .vac-row-arrow{ transform:none; }
  .vac-row:hover::before{ transform:scaleX(1); }
}
