/* ============================================================
   ImProve websitebasis v25 — herziene opmaak
   Doel: compacter en mooier, zelfde inhoud, zelfde klassen.
   Eén schoon bestand i.p.v. gestapelde patches.

   Merkmotief "Ritme": het kleurband (magenta > amber > brons)
   keert subtiel terug als ritme-accent. Het Stuurritme is het
   visuele hart (diep bordeaux) van de homepage.
   Kleuren afgeleid uit logo + kleurband.
   ============================================================ */

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

:root {
  /* Merkkleuren uit kleurband + logo */
  --magenta:#C30066;
  --bordeaux:#7B0041;
  --bordeaux-deep:#5E0031;
  --amber:#F6A924;
  --amber-ink:#8A4B00;
  --bronze:#8A745A;
  --bronze-deep:#6F5C45;

  /* Inkt en tekst */
  --ink:#241F27;
  --muted:#67626C;
  --muted-soft:#8B8690;

  /* Vlakken (warm papier, twee duidelijk verschillende tinten) */
  --paper:#FBFAF8;
  --sand:#F3EEE8;     /* warme beige tint */
  --mist:#ECECEE;     /* koele grijze tint (alleen footer) */
  --band:#EFEFF1;     /* rustige grijze afwisselband tussen paper-secties */
  --roze:#FBF1F6;     /* lichtroze footer */
  --lichtbruin:#ECE4D8; /* heel lichtbruin: warme sectietoon en cross-sell box */
  --sectiegrijs:#E7E7EB; /* het enige grijs voor sectie-afwisseling */
  --white:#ffffff;

  /* Lijnen, schaduw, ronding */
  --line:rgba(138,116,90,.22);
  --line-soft:rgba(138,116,90,.14);
  --shadow:0 10px 30px rgba(45,33,40,.06);
  --shadow-sm:0 4px 14px rgba(45,33,40,.05);

  --r-lg:26px;
  --r-md:18px;
  --r-sm:14px;
  --max:1140px;

  --display:"Baloo 2", "Segoe UI", Arial, sans-serif;
  --body:"Nunito Sans", "Segoe UI", Arial, sans-serif;
}

* { box-sizing:border-box; }
html { scroll-behavior:smooth; }

body {
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  font-size:16px;
  line-height:1.5;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

a { color:inherit; text-decoration:none; }
img { max-width:100%; display:block; }

.wrapper { width:min(var(--max), calc(100% - 56px)); margin:0 auto; }

/* ---------- Topbar / navigatie / kleurband ---------- */
.topbar {
  position:sticky; top:0; z-index:30;
  background:rgba(251,250,248,.86);
  backdrop-filter:blur(12px);
  border-bottom:none;
}

.nav {
  min-height:74px;
  display:flex; align-items:center; justify-content:space-between;
  gap:24px;
}

.logo { width:286px; height:auto; }

.navlinks { display:flex; align-items:center; gap:4px; flex-wrap:nowrap; }

.navlinks a {
  display:inline-flex; align-items:center; min-height:34px;
  padding:0 13px;
  border-radius:999px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.07em;
  font-size:11.5px;
  font-weight:600;
  transition:.16s ease;
}
.navlinks a:hover,
.navlinks a.active { background:rgba(123,0,65,.07); color:var(--bordeaux); }

.navlinks .nav-cta {
  margin-left:6px;
  background:var(--bordeaux); color:#fff;
  padding:0 18px;
}
.navlinks .nav-cta:hover { background:var(--bordeaux-deep); color:#fff; }

.nav-toggle { display:none; flex-direction:column; justify-content:center; gap:5px; width:44px; height:44px; padding:0; background:none; border:0; cursor:pointer; }
.nav-toggle span { display:block; width:24px; height:2px; background:var(--ink); border-radius:2px; transition:transform .2s ease, opacity .2s ease; }
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.header-balk { width:100%; max-width:none; padding:14px 0 0; }
.header-balk img {
  width:100%; height:auto;
  object-fit:contain; object-position:center;
}

/* ---------- Knoppen ---------- */
.btn {
  display:inline-flex; align-items:center; justify-content:center;
  min-height:46px; padding:0 24px;
  border-radius:999px;
  font-family:var(--display);
  font-weight:700; font-size:14.5px; letter-spacing:.005em;
  border:1.5px solid transparent;
  cursor:pointer;
  transition:.18s ease;
}
.btn-primary { background:var(--bordeaux); color:#fff; }
.btn-primary:hover { background:var(--bordeaux-deep); transform:translateY(-1px); box-shadow:0 8px 20px rgba(123,0,65,.22); }

.btn-secondary { background:transparent; color:var(--bordeaux); border-color:rgba(123,0,65,.30); }
.btn-secondary:hover { border-color:var(--bordeaux); background:rgba(123,0,65,.05); }

.actions, .hero-actions { display:flex; gap:12px; flex-wrap:wrap; margin-top:24px; }

/* ---------- Secties + ritme-scheiding ---------- */
.section { padding:46px 0; }
.section-compact { padding:32px 0; }
.section-beige { background:var(--sectiegrijs); }
.section-grey  { background:var(--sectiegrijs); }

/* Dunne ritme-lijn tussen aangrenzende vlakken i.p.v. dikke witruimte */
.section + .section { position:relative; }
.section-beige + .section-grey,
.section-grey + .section-beige,
.section + .footer { box-shadow:inset 0 1px 0 var(--line-soft); }

/* ---------- Typografie ---------- */
h1,h2,h3,h4 {
  margin:0; color:var(--ink);
  font-family:var(--display);
  line-height:1.08; letter-spacing:-.01em;
}
h1 { font-size:clamp(31px, 3.8vw, 44px); font-weight:700; }
h2 { font-size:clamp(25px, 3vw, 34px); font-weight:700; }
h3 { font-size:clamp(19px, 2vw, 24px); font-weight:700; }
h4 { font-size:17px; font-weight:700; }

p { margin:0; }
p + p { margin-top:16px; }

.lead { font-size:clamp(16.5px, 1.2vw, 18.5px); color:var(--muted); line-height:1.5; }
.text { color:var(--muted); line-height:1.5; }

/* Eyebrow met "ritme"-markering (drie tikjes uit het kleurband) */
.eyebrow {
  display:inline-flex; align-items:center; gap:11px;
  color:var(--bordeaux);
  text-transform:uppercase; letter-spacing:.13em;
  font-family:var(--display);
  font-size:14px; font-weight:500;
  margin:0 0 16px;
}
.eyebrow:before {
  content:""; width:26px; height:6px; border-radius:99px;
  background:var(--bordeaux);
}

.label {
  display:inline-flex;
  color:var(--bronze-deep);
  text-transform:uppercase; letter-spacing:.09em;
  font-family:var(--display);
  font-size:12px; font-weight:700;
  margin-bottom:12px;
}

/* ---------- Hero ---------- */
.hero { padding:26px 0 0; }
.hero-shell {
  position:relative;
  width:min(var(--max), calc(100% - 56px));
  margin:0 auto;
  min-height:440px;
  border-radius:var(--r-lg);
  overflow:hidden;
}
.hero-photo { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero-shell:after {
  content:""; position:absolute; inset:0;
  background:linear-gradient(95deg, rgba(74,0,40,.72), rgba(40,20,30,.42) 48%, rgba(20,12,18,.12));
}
.hero-content {
  position:relative; z-index:2; color:#fff;
  max-width:620px;
  padding:0 0 52px 48px;
  min-height:440px;
  display:flex; flex-direction:column; justify-content:flex-end;
}
.hero-content .eyebrow { color:#fff; }
.hero-content .eyebrow:before { background:#fff; }
.hero-content h1 { color:#fff; font-size:clamp(34px, 4.4vw, 50px); max-width:560px; }
.hero-content p, .hero-content .lead { margin:16px 0 0; color:rgba(255,255,255,.92); max-width:540px; }
.hero-actions .btn-secondary {
  background:rgba(255,255,255,.12);
  color:#fff;
  border-color:rgba(255,255,255,.65);
}
.hero-actions .btn-secondary:hover { background:#fff; color:var(--bordeaux); border-color:#fff; }

/* Subpagina-hero — tekst links uitgelijnd op de wrapper, geen kader */
.page-hero { padding:34px 0 44px; }
.page-hero-box {
  width:min(var(--max), calc(100% - 56px));
  margin:0 auto;
  background:transparent;
  border-radius:0;
  padding:0;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(300px,.82fr);
  gap:44px; align-items:center;
}
.page-hero-box img {
  width:90%; aspect-ratio:4/3; object-fit:cover;
  justify-self:center;
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);
}
.page-hero-box img.is-square { aspect-ratio:1/1; }
.page-hero-box img.io-shot { aspect-ratio:auto; height:auto; object-fit:contain; background:#fff; border:1px solid var(--line-soft); }
.page-hero-box .lead { margin-top:16px; }

/* ---------- Raster-layouts ---------- */
.section-head { margin-bottom:26px; }
.section-head.grid,
.two-col {
  display:block;
}
.section-head.grid > :first-child,
.two-col > :first-child { margin-bottom:14px; }
.section-head.grid .lead,
.two-col .lead { max-width:760px; }
.section-head h2 + .lead, .section-head h1 + .lead { margin-top:16px; }

.card-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:20px; align-items:stretch; }
.card-grid.two  { grid-template-columns:repeat(2,minmax(0,1fr)); }
.card-grid.four { grid-template-columns:repeat(4,minmax(0,1fr)); }

/* ---------- Kaarten ---------- */
.card {
  background:var(--white);
  border:1px solid var(--line-soft);
  border-radius:var(--r-md);
  padding:26px 26px 28px;
  box-shadow:var(--shadow-sm);
  display:flex; flex-direction:column; height:100%;
  position:relative; overflow:hidden;
}
.card h3, .card h4 { margin-bottom:10px; }
.card p { color:var(--muted); line-height:1.48; }
.card .btn { margin-top:auto; align-self:flex-start; }
.card .label + h3 { margin-top:0; }

/* Ritme-accent: dun gekleurd streepje linksboven per kaart */
.card-grid > .card:before {
  content:""; position:absolute; left:0; top:0; width:3px; height:46px;
  border-radius:0 99px 99px 0;
}
.card-grid > .card:nth-child(3n+1):before { background:var(--magenta); }
.card-grid > .card:nth-child(3n+2):before { background:var(--amber); }
.card-grid > .card:nth-child(3n+3):before { background:var(--bronze); }
.card-grid.two > .card:nth-child(1):before { background:var(--magenta); }
.card-grid.two > .card:nth-child(2):before { background:var(--amber); }

.image-card { padding:14px 14px 22px; }
.image-card img { width:100%; aspect-ratio:16/10; object-fit:cover; border-radius:var(--r-sm); margin-bottom:18px; }
.image-card .content { display:flex; flex-direction:column; flex:1; padding:0 10px; }
.image-card .content h3 { margin-bottom:8px; }
.image-card:before { display:none; }

.feature-card { padding:16px 16px 24px; }
.feature-card .pills { margin:14px 10px; }

/* ---------- Pills ---------- */
.pills { display:flex; flex-wrap:wrap; gap:8px; margin:14px 0 18px; }
.pill {
  display:inline-flex; align-items:center; min-height:30px;
  padding:0 13px; border-radius:999px;
  font-family:var(--display);
  font-size:12.5px; font-weight:600;
}
.pill-days   { background:#FCEFD4; color:var(--amber-ink); }
.pill-price  { background:var(--mist); color:var(--muted); }
.pill-method { background:#F6E6EE; color:var(--bordeaux); }

/* ---------- De kern: StuurRitme (rustig, warm vlak) ---------- */
.heart-section { padding:58px 0; }
.heart-panel {
  background:var(--sand);
  color:var(--ink);
  border:1px solid var(--line-soft);
  border-radius:var(--r-lg);
  padding:40px 44px;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,.94fr);
  gap:40px; align-items:center;
}
.heart-copy .lead { color:var(--muted); }
.heart-copy .actions { margin-top:24px; }

.heart-visual { display:flex; justify-content:center; align-items:center; margin:0; }
.heart-visual img {
  width:100%; max-width:430px; height:auto; display:block;
  aspect-ratio:4/3; object-fit:contain;
  background:#fff;
  border:1px solid var(--line-soft);
  border-radius:18px;
  box-shadow:0 14px 34px rgba(45,33,40,.10);
  padding:12px;
}

/* ---------- Homepage: signalen + feature-blokken ---------- */
.home-split { display:grid; grid-template-columns:1.04fr .96fr; gap:52px; align-items:center; }
.home-split.reverse { grid-template-columns:.96fr 1.04fr; }
.aanbod-block, .aanbod-row { background:var(--white); border:1px solid var(--line-soft); border-radius:var(--r-md); box-shadow:var(--shadow-sm); position:relative; overflow:hidden; }
.aanbod-block:before, .aanbod-row:before { content:""; position:absolute; left:0; top:0; bottom:0; width:4px; background:var(--bronze); }
.aanbod-block { padding:30px 34px 34px; }
.belief { max-width:820px; margin:0 0 50px; }
.belief h2 { font-size:clamp(25px, 3vw, 34px); line-height:1.2; margin-bottom:16px; max-width:760px; }
.belief .lead { max-width:720px; }
.aanbodkaarten { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:22px; align-items:stretch; }
.aanbodkaarten.tweekoloms { grid-template-columns:repeat(2,minmax(0,1fr)); }
.routekaarten { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:24px; align-items:stretch; }
.routekaart { display:flex; flex-direction:column; background:var(--white); border:1px solid var(--line-soft); border-radius:var(--r-md); box-shadow:var(--shadow-sm); padding:30px 32px 32px; }
.routekaart .eyebrow { margin-bottom:14px; }
.routekaart h3 { font-size:24px; line-height:1.2; margin:0 0 12px; min-height:58px; }
.over-teaser { display:grid; grid-template-columns:1.1fr 0.9fr; gap:48px; align-items:center; }

.over-teaser-text h2 { margin: 14px 0 28px; }
.over-teaser-text .lead { margin-top: 0; }
.founder-duo { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.founder-duo figure { margin:0; }
.founder-duo img { width:100%; aspect-ratio:4/5; object-fit:cover; object-position:center top; border-radius:var(--r-md); display:block; }
.founder-duo figcaption { margin-top:10px; font-family:var(--display); font-weight:600; font-size:14px; color:var(--ink); }
.routekaart p { color:var(--muted); line-height:1.55; margin:0 0 22px; }
.routekaart .btn { align-self:flex-start; margin-top:auto; }
.belief-split { display:grid; grid-template-columns:0.85fr 1.15fr; gap:0; align-items:stretch; }
.belief-split .belief-head { padding-right:48px; display:flex; flex-direction:column; justify-content:flex-start; }
.belief-split .belief-head h2 { font-size:clamp(25px, 3vw, 34px); line-height:1.12; margin:14px 0 0; }
.belief-split .belief-body { border-left:1px solid var(--line); padding-left:48px; display:flex; flex-direction:column; justify-content:center; }
.belief-statement { font-family:var(--display); font-weight:700; color:var(--bordeaux); font-size:clamp(20px,1.8vw,24px); line-height:1.06; margin:0 0 20px; }
.belief-split .belief-body p { color:var(--muted); line-height:1.6; margin:0 0 16px; }
.belief-split .belief-body p:last-child { margin-bottom:0; }

.verschil-intro h2 { font-size:clamp(25px, 3vw, 34px); line-height:1.16; margin:14px 0 18px; max-width:920px; }
.verschil-intro .lead { max-width:780px; }
.verschil-intro.centered { text-align:center; }
.verschil-intro.centered h2, .verschil-intro.centered .lead { margin-left:auto; margin-right:auto; }
.verschillen-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:0; margin-top:36px; border-top:1px solid var(--line); }
.verschil { padding:30px 30px 6px; border-left:1px solid var(--line); }
.verschil:first-child { border-left:0; padding-left:0; }
.verschil:last-child { padding-right:0; }
.verschil .nr { display:block; font-family:var(--display); font-weight:700; color:var(--amber); font-size:14px; letter-spacing:.1em; margin-bottom:18px; }
.verschil h3 { font-size:20px; line-height:1.2; margin:0 0 12px; min-height:2.6em; }
.verschil p { color:var(--muted); line-height:1.55; margin:0; }
.ak { background:var(--white); border:1px solid var(--line-soft); border-radius:var(--r-md); box-shadow:var(--shadow-sm); overflow:hidden; display:flex; flex-direction:column; transition:transform .18s ease, box-shadow .18s ease; }
.ak:hover { transform:translateY(-3px); box-shadow:0 14px 32px rgba(45,33,40,.12); }
.ak > img { width:100%; aspect-ratio:16/10; object-fit:cover; }
.ak-body { padding:22px 24px 24px; display:flex; flex-direction:column; flex:1; }
.ak-body h3 { font-size:21px; line-height:1.2; margin:0 0 9px; display:flex; align-items:baseline; gap:10px; min-height:2.4em; }
.ak-body h3 .nr { font-size:16px; font-weight:700; color:var(--amber); letter-spacing:.08em; }
.ak-body p { color:var(--muted); line-height:1.5; margin:0 0 18px; }
.ak-link { margin-top:auto; align-self:flex-start; font-family:var(--display); font-weight:700; font-size:15px; color:var(--bordeaux); text-decoration:none; }
.ak-link:hover { text-decoration:underline; }
.aanbod-subhead { font-size:23px; margin:0 0 22px; color:var(--ink); }
.train-grid { display:grid; grid-template-columns:1fr 1fr; gap:34px; }
.train-item { display:flex; flex-direction:column; }
.train-item img { width:100%; aspect-ratio:16/10; object-fit:cover; border-radius:var(--r-sm); margin-bottom:18px; }
.train-item h4 { font-size:20px; margin:0 0 8px; }
.train-item p { color:var(--muted); line-height:1.5; margin:0 0 14px; }
.train-item .pills { margin-bottom:18px; }
.train-item .btn { align-self:flex-start; margin-top:auto; }
.aanbod-extra { margin-top:18px; display:flex; flex-direction:column; gap:18px; }
.aanbod-row { display:flex; align-items:center; justify-content:space-between; gap:36px; padding:24px 30px; }
.aanbod-row-text { max-width:680px; }
.aanbod-row h4 { margin:7px 0 8px; font-size:19px; }
.aanbod-row p { color:var(--muted); line-height:1.5; margin:0; }
.aanbod-row .btn { flex-shrink:0; }
@media (max-width:760px){ .aanbod-row { flex-direction:column; align-items:flex-start; gap:18px; } .train-grid { grid-template-columns:1fr; } }
.feature-copy .eyebrow { margin-bottom:14px; }
.feature-copy h2 { margin-bottom:16px; }
.feature-copy .btn { margin-top:24px; }

.home-signals { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; margin-top:6px; }
.signal-card {
  background:var(--white);
  border:1px solid var(--line-soft);
  border-radius:var(--r-md);
  padding:20px 20px 18px;
  border-left:3px solid var(--bronze);
}
.signal-card h3 { font-size:18px; line-height:1.14; margin:0 0 8px; }
.signal-card p { margin:0; font-size:15px; line-height:1.46; color:var(--muted); }
.home-signals .signal-card:nth-child(1) { border-left-color:var(--magenta); }
.home-signals .signal-card:nth-child(2) { border-left-color:var(--amber); }
.home-signals .signal-card:nth-child(3) { border-left-color:var(--bronze); }
.home-signals .signal-card:nth-child(4) { border-left-color:var(--bordeaux); }

.feature-points { display:grid; gap:10px; margin-top:18px; }
.feature-point {
  padding:14px 16px; border-radius:var(--r-sm);
  background:var(--white); border:1px solid var(--line-soft);
  border-left:3px solid var(--bronze);
}
.feature-point strong { display:block; margin-bottom:3px; font-family:var(--display); color:var(--ink); }
.feature-point { color:var(--muted); line-height:1.46; }

/* ---------- Detailpagina's: compacte kennisblokken ---------- */
.detail-intro { max-width:840px; }
.detail-intro p + p { margin-top:16px; }

.compact-detail-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:18px; align-items:stretch; }
.compact-detail-grid.two { grid-template-columns:repeat(2,minmax(0,1fr)); }
.compact-detail-grid.four { grid-template-columns:repeat(4,minmax(0,1fr)); gap:16px; }
.compact-detail-grid.four .compact-detail-card { padding:22px 20px 24px; }
.compact-detail-grid.four .compact-detail-card h3 { font-size:18px; line-height:1.16; min-height:3.5em; }
.compact-detail-grid.four .compact-detail-card p { font-size:15px; line-height:1.42; }
.compact-detail-card {
  background:var(--white);
  border:1px solid var(--line-soft);
  border-radius:var(--r-md);
  padding:24px 24px 26px;
  box-shadow:var(--shadow-sm);
  display:flex; flex-direction:column;
  position:relative; overflow:hidden;
}
.compact-detail-card:before {
  content:""; position:absolute; left:0; top:0; width:3px; height:40px;
  border-radius:0 99px 99px 0; background:var(--bronze);
}
/* Geen wisselende kleuren over losse kaarten: één rustige bruingoud-tint (geen kleurenfestijn) */
.compact-detail-card .label { margin-bottom:10px; }
.compact-detail-card h3 { font-size:20px; line-height:1.14; margin-bottom:8px; min-height:2.3em; }
.compact-detail-card p { color:var(--muted); line-height:1.46; }
.compact-detail-card { transition:transform .18s ease, box-shadow .18s ease; }
.compact-detail-card:hover { transform:translateY(-3px); box-shadow:0 14px 32px rgba(45,33,40,.12); }

/* Vier genummerde op een rij, de andere-orde-kaarten eronder */
.compact-detail-grid.four-two { grid-template-columns:repeat(4,minmax(0,1fr)); }
.compact-detail-grid.four-two > .compact-detail-card.meta { grid-column:span 2; }

/* "Van andere orde"-kaarten: rustig zandvlak, bronzen balk i.p.v. gekleurde tik */
.compact-detail-card.meta { background:var(--sand); border-color:rgba(138,116,90,.22); box-shadow:none; }
.compact-detail-grid > .compact-detail-card.meta::before { background:var(--bronze); height:100%; width:4px; border-radius:0; }
.compact-detail-card.meta .label { color:var(--bronze-deep); }

/* Gecentreerde modelafbeelding, groot en leesbaar */
.fig-center { display:flex; justify-content:center; margin:6px 0 6px; }
.fig-center img, .fig-center svg {
  width:100%; max-width:720px; height:auto;
  aspect-ratio:5/4; object-fit:contain;
  background:#fff; border:1px solid var(--line-soft);
  border-radius:18px; box-shadow:0 14px 34px rgba(45,33,40,.10); padding:18px;
}
.model-note { max-width:720px; margin:24px auto 0; color:var(--muted); line-height:1.6; }
.result-wrap { display:flex; justify-content:center; }
.result-card { max-width:640px; width:100%; }
.model-head { margin-bottom:30px; }
.model-split { display:grid; grid-template-columns:minmax(0,1.5fr) minmax(0,1fr); gap:48px; align-items:center; }
.model-figure { display:flex; justify-content:center; align-items:center; }
.model-figure img { width:100%; max-width:100%; height:auto; background:#fff; border:1px solid var(--line-soft); border-radius:18px; box-shadow:0 14px 34px rgba(45,33,40,.10); padding:16px; }
.model-copy { max-width:none; }
.model-note-inline { margin-top:14px; color:var(--muted); line-height:1.6; }
.model-result { margin-top:24px; max-width:none; }
@media (max-width:860px){ .model-split { grid-template-columns:1fr; } }

/* Stuurfunctie-kaarten: functiekleur alleen op het accenttikje (geen kleurvlak) */
.compact-detail-card.fn-werkoverzicht:before { background:#7B0041; }
.compact-detail-card.fn-keuzes:before        { background:#F6A924; }
.compact-detail-card.fn-eigenaarschap:before { background:#8A745A; }
.compact-detail-card.fn-voortgang:before     { background:#717074; }

/* ---------- CTA / prijsstrook ---------- */
.training-cta, .price-strip {
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
  gap:40px; align-items:start;
  border-top:1px solid var(--line-soft);
  padding:34px 2px 0;
}
.training-cta h2, .price-strip h2,
.training-cta h3, .price-strip h3 { margin-bottom:10px; }
.training-cta p, .price-strip p { color:var(--muted); line-height:1.48; }
.training-cta .pills, .price-strip .pills { margin:0 0 16px; }
.training-cta .actions, .price-strip .actions { margin-top:18px; }


.price-card {
  background:var(--white); border:1px solid var(--line-soft);
  border-radius:var(--r-lg); box-shadow:var(--shadow-sm); padding:30px;
}
.price-card h3 { margin-bottom:12px; }
.price-line { display:flex; gap:10px; flex-wrap:wrap; margin-top:16px; }

/* ---------- Profielkaarten (Over ons) ---------- */
.profile-grid { display:grid; grid-template-columns:1fr 1fr; gap:30px; align-items:stretch; }
.team-joint { margin-top:30px; max-width:980px; }
.team-joint.team-intro { margin-top:6px; margin-bottom:36px; }
.team-joint p { color:var(--muted); }
.team-joint .team-joint-lead { font-size:1.16rem; line-height:1.5; color:var(--ink); font-weight:600; margin-bottom:14px; }
.team-joint p + p { margin-top:16px; }
.profile-card {
  background:var(--white);
  border:1px solid var(--line-soft);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);
  display:block;
  padding:26px 28px 28px;
  position:relative; overflow:hidden;
}
.profile-card:before {
  content:""; position:absolute; left:0; top:0; width:3px; height:44px;
  border-radius:0 99px 99px 0; background:var(--bronze);
}
.profile-head { display:flex; gap:24px; align-items:center; margin-bottom:22px; }
.profile-head img {
  width:170px; flex:none; aspect-ratio:4/5; object-fit:cover; object-position:center top;
  border-radius:var(--r-md); margin:0; display:block;
}
.profile-name {
  display:block; font-family:var(--display); font-weight:700;
  font-size:26px; line-height:1.1; color:var(--ink); margin:0;
}
.profile-card-content { padding:0; }
.profile-card-content h3 { margin:0 0 8px; font-size:20px; line-height:1.2; color:var(--bronze-deep); }
.profile-card-content p { color:var(--muted); line-height:1.55; margin-top:0; }
.profile-card-content p + p { margin-top:16px; }

/* ---------- Testimonial ---------- */
.testimonial {
  background:var(--paper);
  border:1px solid var(--line-soft);
  border-radius:var(--r-lg);
  padding:30px 34px;
  box-shadow:var(--shadow-sm);
  max-width:720px; margin:0 auto;
  position:relative;
}
.testimonial p {
  position:relative; margin:0; font-family:var(--display);
  font-size:clamp(17px,1.4vw,20px); line-height:1.45; font-weight:600; color:var(--ink);
}
.testimonial p:before, .testimonial p:after { content:none; }
.testimonial span {
  display:block; position:relative; margin-top:16px;
  color:var(--bronze-deep); font-size:13px; font-weight:700; letter-spacing:.03em;
}
.testimonial span small { display:block; margin-top:3px; font-size:12.5px; font-weight:500; letter-spacing:0; text-transform:none; color:var(--muted); }

/* ---------- Praktijkcase ---------- */
.praktijkcase { background:var(--sand); border:1px solid var(--line-soft); border-radius:var(--r-lg); padding:34px 38px; box-shadow:var(--shadow-sm); }
.praktijkcase .case-label { font-family:var(--display); font-weight:600; font-size:12.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--bronze-deep); margin:0 0 8px; }
.praktijkcase h3 { font-size:23px; margin:0 0 22px; }
.case-blocks { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); border-top:1px solid var(--line); }
.case-block { padding:22px 26px; border-left:1px solid var(--line-soft); }
.case-block:first-child { padding-left:0; border-left:0; }
.case-block:last-child { padding-right:0; }
.case-step { display:block; font-family:var(--display); font-weight:700; font-size:13px; letter-spacing:.04em; text-transform:uppercase; color:var(--amber); margin-bottom:8px; }
.case-block p { margin:0; color:var(--muted); line-height:1.5; }
.praktijkcase-grid { display:grid; grid-template-columns:1fr; gap:22px; }
@media (max-width:760px){ .case-blocks { grid-template-columns:1fr; } .case-block { border-left:0; padding:18px 0; border-top:1px solid var(--line-soft); } .case-block:first-child { border-top:0; padding-top:0; } }

/* ---------- Artikelen ---------- */
.article-body > *, .article-summary > * { max-width:780px; }
.article-body h2, .article-summary h2 { margin-top:34px; margin-bottom:12px; }
.article-body h3 { margin-top:24px; margin-bottom:8px; }
.article-body p, .article-summary p { color:var(--muted); line-height:1.6; }

/* ---------- FAQ ---------- */
.faq-list { display:grid; gap:12px; }
.faq-item {
  background:var(--white); border:1px solid var(--line-soft);
  border-radius:var(--r-md); padding:22px 26px; box-shadow:var(--shadow-sm);
  border-left:3px solid var(--bronze);
}
.faq-item h3 { font-size:19px; margin-bottom:8px; }
.faq-item p { color:var(--muted); line-height:1.5; }

/* ---------- Contact ---------- */
.contact-list { display:grid; gap:0; }
.contact-item { padding:14px 0; border:none; background:none; border-radius:0; border-top:1px solid var(--line-soft); }
.contact-item strong { display:block; margin-bottom:4px; color:var(--ink); font-family:var(--display); }
.map-frame { overflow:hidden; border-radius:var(--r-md); min-height:100%; border:1px solid var(--line-soft); background:var(--white); }
.map-frame iframe { width:100%; height:100%; min-height:340px; border:0; display:block; }

/* ---------- Formulieren ---------- */
.form-layout { display:grid; grid-template-columns:minmax(0,45fr) minmax(0,55fr); gap:44px; align-items:start; }
.form-panel { background:var(--sand); border:1px solid var(--line-soft); border-radius:var(--r-lg); padding:32px; box-shadow:var(--shadow-sm); width:100%; }
.form-layout .form-panel { background:transparent; border:none; box-shadow:none; padding:0; }
.form-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px; }
.form-grid .full { grid-column:1 / -1; }

label { display:block; margin-bottom:7px; color:var(--ink); font-weight:600; font-size:14px; font-family:var(--display); }
input, select, textarea {
  width:100%; min-height:50px;
  border:1px solid var(--line); background:#fff;
  border-radius:var(--r-sm); padding:13px 15px;
  font:inherit; font-size:15px; line-height:1.35; color:var(--ink);
}
textarea { min-height:130px; resize:vertical; }
input::placeholder, textarea::placeholder { color:#9a958f; opacity:1; }
input:focus, select:focus, textarea:focus { outline:none; border-color:var(--bordeaux); box-shadow:0 0 0 3px rgba(123,0,65,.12); }

/* Opgeschoonde formulierpagina's */
.form-page { padding:54px 0 64px; background:var(--paper); }
.form-page-head { max-width:840px; margin:0 auto 32px; text-align:left; }
.form-page-head .lead { max-width:740px; margin-top:14px; }
.form-page-shell { width:min(940px, calc(100% - 56px)); margin:0 auto; }
.form-page-card { background:var(--sand); border:1px solid var(--line-soft); border-radius:var(--r-lg); padding:36px; box-shadow:var(--shadow-sm); }
.form-page-card .form-panel { background:transparent; border:0; box-shadow:none; padding:0; border-radius:0; }

.form-grid.compact-form { grid-template-columns:repeat(2,minmax(0,1fr)); gap:16px 20px; }
.form-grid.compact-form input,
.form-grid.compact-form textarea,
.form-grid.compact-form select { min-height:48px; }
.form-grid.compact-form textarea { min-height:104px; }

.form-section-title { margin:30px 0 16px; padding-bottom:10px; border-bottom:1px solid var(--line-soft); font-size:20px; font-family:var(--display); }
.form-section-title:first-child { margin-top:0; }
.name-trio { grid-column:1 / -1; display:grid; grid-template-columns:1fr 0.6fr 1.4fr; gap:16px 20px; }
.required { color:var(--bordeaux); }
.form-intro { margin-top:14px; color:var(--muted); line-height:1.48; }
.form-intro strong { color:var(--ink); }
.form-panel .actions { margin-top:24px; }

/* Mededelingen / akkoord / bevestiging */
.notice, .note {
  margin:22px 0 0; padding:18px 20px;
  background:#fff; border:1px solid var(--line-soft);
  border-radius:var(--r-md); color:var(--ink);
}
.note { border-style:dashed; border-color:rgba(123,0,65,.28); color:var(--muted); font-size:15px; }
.notice strong { color:var(--bordeaux); }
.small-note { margin:16px 0 0; color:var(--muted); font-size:13.5px; line-height:1.4; }

.checkbox-row {
  display:flex; align-items:flex-start; gap:12px;
  margin:20px 0 0; padding:16px 18px;
  background:#fff; border:1px solid var(--line-soft); border-radius:var(--r-sm);
}
.checkbox-row input { width:18px; height:18px; min-height:18px; margin-top:3px; accent-color:var(--bordeaux); }
.checkbox-row label { margin:0; font-weight:500; color:var(--ink); font-size:14.5px; line-height:1.4; font-family:var(--body); }

.after-submit {
  display:none; margin-top:26px; padding:32px;
  background:#fff; border:1px solid var(--line-soft);
  border-radius:var(--r-lg); box-shadow:var(--shadow);
  border-left:5px solid var(--bordeaux);
}
.after-submit h3 { margin:0 0 10px; color:var(--bordeaux); font-size:22px; line-height:1.15; }
.after-submit p { color:var(--muted); line-height:1.48; }
.after-submit p + p { margin-top:16px; }
.after-submit { } 
.platform-confirmation-text { color:var(--muted); }


/* ---------- Nieuws ---------- */
.news-page-hero { padding-bottom:10px; }
.news-hero-box { grid-template-columns:1fr; gap:20px; max-width:none; }
.news-hero-box h1, .news-hero-box .lead { max-width:720px; }
.news-hero-actions { margin-top:24px; justify-content:flex-start; }
.news-hero-aside {
  background:var(--sand); border:1px solid var(--line-soft); border-radius:var(--r-lg);
  padding:28px 30px; box-shadow:var(--shadow-sm);
}
.news-mini-label {
  margin:0 0 10px; color:var(--bordeaux); font-family:var(--display); font-size:12px;
  letter-spacing:.08em; text-transform:uppercase;
}
.news-hero-aside h2 { font-size:28px; line-height:1.15; margin:0 0 12px; }
.news-hero-aside p { color:var(--muted); margin:0 0 14px; line-height:1.58; }
.text-link {
  display:inline-flex; align-items:center; gap:8px; color:var(--bordeaux); font-weight:700;
}
.text-link:hover { color:var(--bordeaux-deep); }
.text-link:after { content:"›"; font-size:18px; line-height:1; }
.news-overview-section { padding-top:30px; }
.news-layout { display:grid; grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr); gap:20px; align-items:stretch; }
.news-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:20px; align-items:stretch; }
.news-grid .news-card h3 { font-size:22px; }
.news-grid .news-card:before { background:var(--bordeaux); }
.news-stack { display:grid; gap:20px; }
.news-card {
  display:flex; flex-direction:column; height:100%; position:relative; overflow:hidden;
  background:var(--white); border:1px solid var(--line-soft); border-radius:var(--r-lg);
  padding:28px 28px 30px; box-shadow:var(--shadow-sm); cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.news-card:hover { transform:translateY(-4px); box-shadow:0 10px 24px rgba(45,33,40,.09); border-color:rgba(123,0,65,.18); }
.news-card:active, .news-card.card-pressed { transform:translateY(2px) scale(.992); box-shadow:0 5px 12px rgba(45,33,40,.08); }
.news-card:before {
  content:""; position:absolute; left:0; top:0; width:4px; height:54px; border-radius:0 99px 99px 0; background:var(--magenta);
}
.news-stack .news-card:nth-child(2):before { background:var(--bronze); }
.news-card-featured { background:linear-gradient(180deg, #fff 0%, #fbf8f6 100%); }
.news-card-featured:before { background:var(--bordeaux); }
.news-badge {
  display:inline-flex; align-self:flex-start; min-height:28px; align-items:center; padding:0 12px;
  border-radius:999px; background:var(--sand); color:var(--bronze-deep); font-family:var(--display);
  font-size:12px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; margin-bottom:14px;
}
.news-card h3 { margin:0 0 10px; font-size:clamp(23px,2vw,31px); line-height:1.12; color:var(--ink); }
.news-stack .news-card h3 { font-size:24px; }
.news-card p { margin:0; color:var(--muted); line-height:1.58; }

/* Blogs: tekstkaarten, kop boven en tekst eronder, links uitgelijnd */
.blog-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:22px; }
.blog-card {
  display:flex; flex-direction:column; align-items:flex-start; text-align:left;
  background:var(--white); border:1px solid var(--line-soft); border-radius:var(--r-md);
  padding:24px 24px 26px; box-shadow:var(--shadow-sm); text-decoration:none; color:inherit;
  transition:transform .18s ease, box-shadow .18s ease;
}
.blog-card:hover { transform:translateY(-3px); box-shadow:0 14px 30px rgba(45,33,40,.11); }
.blog-card h3 { font-size:20px; line-height:1.18; margin:12px 0 10px; color:var(--ink); }
.blog-card > p { color:var(--muted); line-height:1.55; margin:0 0 16px; }
.blog-tag {
  display:inline-block; font-family:var(--display); font-weight:700; font-size:11.5px;
  letter-spacing:.08em; text-transform:uppercase; color:var(--bordeaux);
  background:rgba(123,0,65,.08); padding:5px 11px; border-radius:99px;
}
.blog-meta { font-size:13px; color:var(--muted-soft); margin:auto 0 12px; }
.blog-readmore { font-family:var(--display); font-weight:700; font-size:15px; color:var(--bordeaux); }
@media (max-width:900px){ .blog-grid { grid-template-columns:repeat(2,minmax(0,1fr)); } }
@media (max-width:600px){ .blog-grid { grid-template-columns:1fr; } }
.news-link {
  display:inline-flex; align-items:center; gap:8px; margin-top:auto; padding-top:18px;
  color:var(--bordeaux); font-weight:700;
}
.news-link:after { content:"›"; font-size:18px; line-height:1; }
.newsletter-panel {
  background:var(--sand); border:1px solid var(--line-soft); border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm); padding:34px 38px; display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr); gap:34px; align-items:center;
}
.newsletter-copy .lead { margin-top:14px; }
.newsletter-points { list-style:none; margin:22px 0 0; padding:0; display:grid; gap:12px; }
.newsletter-points li {
  position:relative; padding-left:22px; color:var(--muted); line-height:1.5;
}
.newsletter-points li:before {
  content:""; position:absolute; left:0; top:10px; width:10px; height:10px; border-radius:50%; background:var(--bordeaux);
}
.newsletter-form-shell {
  background:rgba(255,255,255,.72); border:1px solid rgba(138,116,90,.14); border-radius:22px; padding:24px 24px 20px;
}
.newsletter-fields { display:grid; grid-template-columns:1fr; gap:16px; }
.newsletter-form .actions { margin-top:18px; display:flex; gap:12px; flex-wrap:wrap; }
.newsletter-confirmation { margin-top:18px; }
/* Nieuwsbrief als rustig zandvlak: anker landt netjes onder de gekleurde balk,
   geen grijze strook tussen balk en paneel meer. */
/* Anker 'Meld je aan voor updates' landt netjes onder de header. Geen eigen
   achtergrond: het paneel staat als kaart op de normale sectie, net als elders. */
#nieuwsbrief { scroll-margin-top:150px; }
/* Hero-anker 'Ontdek wat bij jou past': 'Kies je route' landt netjes onder de header. */
#routes { scroll-margin-top:150px; }
@media (max-width:980px){ #routes, #nieuwsbrief, #trainingen, #trainingsdata { scroll-margin-top:128px; } }

/* ---------- Footer ---------- */
.footer.footer-v4 {
  width:100%;
  margin:0;
  padding:0;
  background:var(--sand);
  box-shadow:none;
  font-family:var(--body);
}
.footer-v4-shell {
  position:relative;
  width:100%;
  overflow:hidden;
  background:var(--sand);
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
  box-shadow:0 -5px 20px rgba(45,33,40,.04);
}
.footer-v4-accent {
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:7px;
  background:var(--bordeaux);
}
.footer-v4-main {
  display:grid;
  grid-template-columns:minmax(270px,1.15fr) minmax(320px,1.2fr) minmax(190px,.72fr) minmax(220px,.86fr);
  gap:clamp(30px,4vw,68px);
  align-items:center;
  width:100%;
  padding:38px clamp(38px,6vw,110px) 34px;
}
.footer-v4-brand {
  padding:0;
  display:flex;
  align-items:center;
}
.footer-v4-logo {
  display:block;
  width:clamp(280px,20vw,360px);
  max-width:100%;
  height:auto;
}
.footer-v4-contact {
  display:grid;
  gap:10px;
  align-self:start;
  padding-left:clamp(26px,3vw,52px);
  border-left:1px solid var(--line-soft);
}
.footer-v4-contact h4 {
  margin:0 0 4px;
  color:var(--bordeaux);
  font-family:var(--display);
  font-size:14px;
  letter-spacing:.07em;
  text-transform:uppercase;
}
.footer-v4-contact p {
  display:grid;
  grid-template-columns:20px auto;
  align-items:center;
  column-gap:10px;
  margin:0;
  color:var(--muted);
  font-size:14px;
  line-height:1.4;
}
.footer-v4-contact-line > span { color:var(--muted-soft); }
.footer-v4-contact a { color:var(--muted); }
.footer-v4-contact a:hover,
.footer-v4-links a:hover,
.footer-v4-legal a:hover { color:var(--bordeaux); }
.footer-v4-contact .footer-v4-email { color:var(--bordeaux); font-weight:700; }
.footer-v4-icon {
  position:relative;
  width:18px;
  height:18px;
  color:var(--muted-soft);
}
.footer-v4-icon:before,
.footer-v4-icon:after { content:""; position:absolute; box-sizing:border-box; }
.footer-v4-icon-location:before {
  left:4px; top:1px; width:10px; height:13px; border:1.5px solid currentColor; border-radius:8px 8px 8px 0; transform:rotate(-45deg);
}
.footer-v4-icon-location:after { left:7px; top:4px; width:4px; height:4px; border:1.4px solid currentColor; border-radius:50%; }
.footer-v4-icon-phone:before {
  left:3px; top:2px; width:12px; height:14px; border-left:2px solid currentColor; border-bottom:2px solid currentColor; border-radius:3px 0 0 8px; transform:rotate(-35deg);
}
.footer-v4-icon-mail:before {
  left:1px; top:4px; width:16px; height:11px; border:1.5px solid currentColor; border-radius:2px;
}
.footer-v4-icon-mail:after {
  left:3px; top:4px; width:12px; height:8px; border-bottom:1.5px solid currentColor; transform:rotate(35deg) skewX(-20deg);
}
.footer-v4-links {
  padding-left:clamp(24px,2.6vw,44px);
  border-left:1px solid var(--line-soft);
  align-self:stretch;
  display:flex;
  align-items:flex-start;
}
.footer-v4-links h4 {
  margin:0 0 12px;
  color:var(--bordeaux);
  font-family:var(--display);
  font-size:14px;
  letter-spacing:.07em;
  text-transform:uppercase;
}
.footer-v4-links a {
  display:block;
  margin:0 0 7px;
  color:var(--muted);
  font-size:14px;
  line-height:1.35;
}
.footer-v4-meta {
  display:grid;
  grid-template-columns:minmax(270px,1.15fr) minmax(320px,1.2fr) minmax(190px,.72fr) minmax(220px,.86fr);
  gap:clamp(30px,4vw,68px);
  align-items:center;
  width:100%;
  padding:15px clamp(38px,6vw,110px);
  background:rgba(255,255,255,.38);
  border-top:1px solid var(--line-soft);
  color:var(--muted-soft);
  font-size:12.5px;
}
.footer-v4-copyright { grid-column:1 / 3; }
.footer-v4-legal {
  grid-column:3 / 5;
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:16px 24px;
  text-align:center;
}
.footer-v4-legal a { color:var(--muted-soft); }

@media (max-width:1180px) {
  .footer-v4-main,
  .footer-v4-meta { grid-template-columns:minmax(230px,.9fr) minmax(280px,1fr) minmax(170px,.68fr) minmax(200px,.78fr); gap:28px; padding-left:34px; padding-right:34px; }
  .footer-v4-logo { width:280px; }
  .footer-v4-contact,
  .footer-v4-links { padding-left:24px; }
}

@media (max-width:960px) {
  .footer-v4-main { grid-template-columns:1fr 1fr; gap:30px 42px; align-items:start; }
  .footer-v4-brand { align-self:center; }
  .footer-v4-contact { border-left:1px solid var(--line-soft); }
  .footer-v4-links { border-left:0; padding-left:0; border-top:1px solid var(--line-soft); padding-top:24px; }
  .footer-v4-links + .footer-v4-links { border-left:1px solid var(--line-soft); border-top:1px solid var(--line-soft); padding-left:42px; }
  .footer-v4-meta { grid-template-columns:1fr 1fr; }
  .footer-v4-copyright { grid-column:1; }
  .footer-v4-legal { grid-column:2; justify-content:flex-end; }
}

@media (max-width:640px) {
  .footer-v4-accent { width:100%; height:7px; bottom:auto; }
  .footer-v4-main { grid-template-columns:1fr; padding:34px 24px 28px; gap:26px; }
  .footer-v4-logo { width:min(310px,100%); }
  .footer-v4-contact,
  .footer-v4-links,
  .footer-v4-links + .footer-v4-links { border-left:0; border-top:1px solid var(--line-soft); padding:22px 0 0; }
  .footer-v4-meta { grid-template-columns:1fr; padding:16px 24px; gap:10px; }
  .footer-v4-copyright,
  .footer-v4-legal { grid-column:1; }
  .footer-v4-legal { justify-content:flex-start; text-align:left; gap:9px 16px; }
}

/* Vaste contactafsluiter: wit, knop onder de tekst, links uitgelijnd */
.cta-band { max-width:720px; margin:0 auto; background:var(--sand); border:1px solid var(--line-soft); color:var(--ink); border-radius:var(--r-lg); padding:clamp(28px,4vw,40px) clamp(28px,4vw,48px); text-align:center; box-shadow:var(--shadow-sm); }
.cta-band .cta-text { display:flex; flex-direction:column; align-items:center; }
.cta-band .eyebrow { color:var(--bordeaux); display:inline-flex; margin-bottom:12px; }
.cta-band .eyebrow:before { background:var(--bordeaux); }
.cta-band h2 { color:var(--ink); font-size:clamp(23px,2.4vw,31px); line-height:1.16; margin:0 auto; max-width:660px; }
.cta-band .lead { color:var(--muted); max-width:600px; margin:14px auto 0; line-height:1.6; font-size:16px; }
.cta-band .actions { margin-top:24px; display:flex; gap:14px; flex-wrap:wrap; justify-content:center; }

.footer-left { display:flex; flex-direction:column; gap:20px; }
.footer-cta { background:#fff; border:1px solid var(--line-soft); border-left:3px solid var(--bronze); border-radius:var(--r-md); padding:22px 26px; display:flex; flex-direction:column; gap:16px; }
.footer-cta .cta-text { flex:1; min-width:0; }
.footer-cta .eyebrow { display:block; margin-bottom:8px; }
.footer-cta h2 { color:var(--ink); margin:0 0 5px; font-size:19px; max-width:none; }
.footer-cta .lead { color:var(--muted); margin:0; max-width:none; font-size:14px; }
.footer-cta .actions { margin:0; display:flex; gap:12px; flex-wrap:wrap; }
.footer-cta .btn-primary { background:var(--bordeaux); color:#fff; }
.footer-cta .btn-primary:hover { background:var(--bordeaux-deep); }
.footer-cta .btn-secondary { background:transparent; color:var(--bordeaux); border-color:var(--line-soft); }
.footer-cta .btn-secondary:hover { background:rgba(255,255,255,.12); }
/* lichte variant (Basiskennis, Leren sturen) */
@media (max-width:760px){ .footer-cta { flex-direction:column; align-items:flex-start; gap:16px; }
  .footer-cta .actions { width:100%; } }

/* Kolommen gelijkmatig uitgelijnd */
.footer-grid {
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(0,1.35fr);
  gap:48px; align-items:start;
  padding:22px 0 36px;
}
.footer-cols { display:grid; grid-template-columns:auto auto auto; justify-content:space-between; column-gap:28px; }
.footer-brand { background:#fff; border:1px solid var(--line-soft); border-radius:var(--r-md); padding:22px 26px; display:flex; align-items:center; justify-content:space-between; gap:24px; }
.footer-logo { order:2; width:225px; margin:0; flex:0 0 auto; }
.footer-contact-text { order:1; margin:0; }
.footer-cols h4 { font-size:13px; margin-bottom:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--bordeaux); font-family:var(--display); }
.footer-contact-text a, .footer-contact-text p, .footer-cols a { display:block; color:var(--muted); margin:0 0 4px; font-size:13.5px; line-height:1.3; }
.footer-contact-text a:hover, .footer-cols a:hover { color:var(--bordeaux); }

/* ============================================================
   Responsief
   ============================================================ */
@media (max-width:1180px) and (min-width:981px) {
  .compact-detail-grid.four { grid-template-columns:repeat(2,minmax(0,1fr)); }
}

@media (max-width:980px) {
  .wrapper, .hero-shell, .page-hero-box { width:min(var(--max), calc(100% - 36px)); }
  .nav { flex-wrap:wrap; align-items:center; padding:14px 0; gap:12px; min-height:0; }
  .logo { width:clamp(204px, 58vw, 240px); }
  .nav-toggle { display:flex; order:2; }
  .navlinks { order:3; display:none; width:100%; flex-direction:column; align-items:stretch; flex-wrap:nowrap; gap:4px; padding:6px 0 8px; }
  .navlinks.open { display:flex; }
  .navlinks a { min-height:46px; padding:0 16px; justify-content:flex-start; border-radius:12px; font-size:13px; }
  .navlinks .nav-cta { margin-left:0; margin-top:6px; justify-content:center; }

  .section-head.grid, .two-col,
  .home-split, .home-split.reverse,
  .home-signals, .heart-panel, .heart-grid,
  .card-grid, .card-grid.two, .card-grid.four,
  .aanbodkaarten, .routekaarten, .belief-split, .verschillen-grid, .over-teaser,
  .compact-detail-grid, .compact-detail-grid.two, .compact-detail-grid.four, .compact-detail-grid.four-two,
  .profile-grid, .contact-grid,
  .training-cta, .price-strip,
  .form-layout, .footer-grid,
  .page-hero-box { grid-template-columns:1fr; }
  .profile-card { gap:18px; padding:24px; }
  .belief-split .belief-head { padding-right:0; }
  .belief-split .belief-body { border-left:0; padding-left:0; margin-top:18px; }
  .verschillen-grid { border-top:0; margin-top:22px; }
  .verschil { border-left:0; padding:22px 0 6px; border-top:1px solid var(--line); }
  .verschil:first-child { padding-top:4px; border-top:0; }
  .profile-card img { max-width:280px; }
  .compact-detail-grid.four-two > .compact-detail-card.meta { grid-column:auto; }

  .section-head.grid, .two-col { gap:24px; }
  .heart-panel, .page-hero-box { padding:34px; gap:30px; }
  .hero-shell { min-height:400px; }
  .hero-content { padding:0 26px 40px; min-height:400px; }
}

@media (max-width:640px) {
  .wrapper, .hero-shell, .page-hero-box, .form-page-shell { width:min(var(--max), calc(100% - 28px)); }
  .section { padding:38px 0; }
  .heart-section { padding:46px 0; }
  h1 { font-size:32px; } h2 { font-size:27px; }
  .form-grid, .form-grid.compact-form { grid-template-columns:1fr; }
  .name-trio { grid-template-columns:1fr; }
  .card, .testimonial, .form-panel, .form-page-card { padding:22px; border-radius:var(--r-md); }
  .training-cta, .price-strip { padding:26px 0 0; }
  .heart-panel { padding:26px; }
  .hero { padding-top:18px; }
  .footer-cols { grid-template-columns:1fr 1fr; gap:24px 20px; }
  .footer-brand { flex-direction:column; align-items:flex-start; gap:16px; }
  .footer-logo { width:205px; }
}

@media (prefers-reduced-motion:reduce) {
  * { scroll-behavior:auto; }
  .btn:hover { transform:none; }
}

/* ============================================================
   Homepage-hero volgens bijlage 1 (full-bleed)
   Alles gescoped onder .home — overige pagina's blijven ongewijzigd.
   ============================================================ */

/* Kleurband staat nu full-bleed in de basis-CSS (geldt voor alle pagina's) */

/* Nav op volle breedte: logo links, menu rechts (alle pagina's, gelijk aan homepage) */
.topbar .nav {
  width:100%; max-width:none; margin:0;
  padding-left:clamp(22px,4vw,76px);
  padding-right:clamp(22px,4vw,76px);
}

/* Kleurband altijd rand-tot-rand, ook op mobiel (overschrijft de wrapper-marges) */
.topbar .header-balk {
  width:100%; max-width:none; margin:0; padding:14px 0 0;
}

/* Hero rand-tot-rand, geen kaart/ronding/marge */
.home .hero { padding:0; }
.home .hero-shell {
  width:100%; max-width:none; margin:0;
  border-radius:0;
  min-height:560px;
}

/* Warmere magenta-overlay over de hele foto */
.home .hero-shell:after {
  background:linear-gradient(100deg,
    rgba(123,0,65,.84) 0%,
    rgba(150,15,80,.60) 42%,
    rgba(190,30,110,.34) 72%,
    rgba(210,40,120,.20) 100%);
}

/* Tekstkolom op smalle paginamarge (zoals de bijlage), niet de gecentreerde 1140-kolom */
.home .hero-content {
  max-width:none;
  width:100%;
  margin:0;
  padding:0 clamp(22px,4vw,76px) 64px;
  min-height:560px;
}
.home .hero-content h1 { max-width:600px; font-size:clamp(40px, 5.4vw, 68px); line-height:1.04; }
.home .hero-content .lead,
.home .hero-content p { max-width:520px; }

/* "sturen." in warm goud */
.home .hero-content .hero-accent { color:#F3C886; }

/* Eyebrow: gouden stip + gewone schrijfwijze i.p.v. streepje + hoofdletters */
.home .hero-content .eyebrow { text-transform:none; letter-spacing:.01em; gap:9px; font-weight:600; }
.home .hero-content .eyebrow:before {
  width:9px; height:9px; border-radius:50%;
  background:var(--amber);
}

/* Primaire knop wit met bordeaux tekst */
.home .hero-actions .btn-primary { background:#fff; color:var(--bordeaux); }
.home .hero-actions .btn-primary:hover { background:#fff; color:var(--bordeaux-deep); box-shadow:0 8px 20px rgba(0,0,0,.18); }

/* ---------- Do's & don'ts blok (artikelen) ---------- */
.dodont { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin:14px 0 10px; max-width:780px; }
.dodont .col { background:#fff; border:1px solid var(--line-soft); border-radius:14px; padding:15px 18px; border-top:3px solid var(--bronze); }
.dodont .col.dont { border-top-color:var(--bordeaux); }
.dodont h4 { font-family:var(--display); font-size:13px; letter-spacing:.05em; text-transform:uppercase; margin:0 0 8px; color:var(--bronze-deep); }
.dodont .dont h4 { color:var(--bordeaux); }
.dodont ul { margin:0; padding-left:18px; }
.dodont li { margin:4px 0; color:var(--muted); font-size:14.5px; line-height:1.45; }
@media (max-width:640px){ .dodont { grid-template-columns:1fr; } }


/* ---------- Brand-componenten (stat-strip / offer-cards / trigger-chips) ---------- */
.stat-strip { display:grid; grid-template-columns:repeat(3,1fr);
  background:linear-gradient(135deg, var(--bordeaux) 0%, var(--bordeaux-deep) 100%);
  border-radius:26px; padding:36px 18px; box-shadow:0 18px 42px rgba(123,0,65,.20); overflow:hidden; }
.stat-strip .stat { padding:6px 30px; border-left:1px solid rgba(255,255,255,.16); }
.stat-strip .stat:first-child { border-left:none; }
.stat .num { display:block; font-family:var(--display); font-weight:700;
  font-size:clamp(24px,2.6vw,38px); color:var(--amber); line-height:1.05; }
.stat .lbl { display:block; margin-top:10px; color:#fff; font-size:14.5px; line-height:1.4; opacity:.92; }
@media (max-width:760px){ .stat-strip { grid-template-columns:1fr; gap:20px; }
  .stat-strip .stat { border-left:none; border-top:1px solid rgba(255,255,255,.16); padding:18px 8px 0; }
  .stat-strip .stat:first-child { border-top:none; padding-top:0; } }

.offer-grid { display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.offer-card { background:var(--white); border:1px solid var(--line-soft); border-radius:20px;
  padding:30px 30px 26px; box-shadow:var(--shadow-sm); border-top:4px solid var(--bordeaux);
  transition:transform .18s ease, box-shadow .18s ease; }
.offer-card:hover { transform:translateY(-3px); box-shadow:0 16px 34px rgba(45,33,40,.12); }
.offer-card.alt { border-top-color:var(--amber); }
.offer-ic { width:48px; height:48px; border-radius:13px; display:flex; align-items:center; justify-content:center;
  margin-bottom:16px; background:rgba(123,0,65,.08); color:var(--bordeaux); }
.offer-card.alt .offer-ic { background:rgba(246,169,36,.18); color:var(--amber-ink); }
.offer-card .label { margin-bottom:8px; }
.offer-card h3 { font-size:21px; line-height:1.2; margin-bottom:8px; min-height:2.4em; }
.offer-card p { color:var(--muted); line-height:1.5; margin:0; }
@media (max-width:700px){ .offer-grid { grid-template-columns:1fr; } }

.situaties { display:grid; grid-template-columns:1fr 1fr; gap:26px 48px; margin-top:14px; }
.situatie { border-top:1px solid var(--line-soft); padding-top:16px; }
.situatie h3 { margin:0 0 6px; font-size:18px; color:var(--bordeaux); }
.situatie p { margin:0; color:var(--muted); line-height:1.5; }
@media (max-width:760px){ .situaties { grid-template-columns:1fr; gap:22px; } }


/* ---------- Vier stuurfuncties in eigen kleur (Aanpak) ---------- */
.compact-detail-grid > .compact-detail-card.fn::before { height:100%; width:4px; border-radius:0; }


/* === Aanpak: processtrip, functielijst, oplevert-pijlers === */
.proces-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;position:relative;margin-top:6px;}
.proces-strip:before{content:"";position:absolute;top:28px;left:16.6%;right:16.6%;height:2px;
  background:linear-gradient(90deg,rgba(123,0,65,.25),var(--bordeaux),rgba(123,0,65,.25));z-index:0;}
.stap{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;height:100%;}
.stap-marker{width:56px;height:56px;border-radius:50%;background:var(--bordeaux);color:#fff;margin:0 auto;
  font-family:var(--display);font-weight:700;font-size:23px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 16px rgba(123,0,65,.20);}
.stap h3{margin:18px 0 8px;font-size:20px;}
.stap p{color:var(--muted);line-height:1.5;max-width:32ch;margin:0 auto;}
.stap-flow{display:block;margin-top:auto;padding-top:16px;color:var(--bordeaux);font-weight:700;font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;opacity:.75;}
.fn-lijst{background:var(--white);border:1px solid var(--line-soft);border-radius:var(--r-md);box-shadow:var(--shadow-sm);overflow:hidden;margin-top:6px;}
.fn-rij{display:grid;grid-template-columns:18px 210px 1fr;gap:20px;align-items:baseline;padding:22px 28px;}
.fn-rij + .fn-rij{border-top:1px solid var(--line-soft);}
.fn-dot{width:13px;height:13px;border-radius:50%;background:var(--c);align-self:start;margin-top:7px;}
.fn-rij h3{margin:0;font-size:18px;}
.fn-rij p{margin:0;color:var(--muted);line-height:1.5;}
.oplevert{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:20px;}
.oplevert .pijler{border-top:1px solid var(--line-soft);padding-top:18px;}
.oplevert .nr{display:block;font-family:var(--display);font-weight:700;font-size:14px;color:var(--bronze);letter-spacing:.08em;margin-bottom:8px;}
.oplevert h3{margin:0 0 8px;font-size:19px;color:var(--bordeaux);}
.oplevert p{margin:0;color:var(--muted);line-height:1.55;}
@media(max-width:760px){
  .proces-strip{grid-template-columns:1fr;gap:8px;}.proces-strip:before{display:none;}
  .stap{text-align:left;padding-left:74px;min-height:62px;margin-bottom:14px;}
  .stap-marker{position:absolute;left:0;top:0;margin:0;}.stap p{margin:0;max-width:none;}.stap-flow{display:none;}
  .fn-rij{grid-template-columns:18px 1fr;gap:6px 16px;}.fn-rij p{grid-column:2;}
  .oplevert{grid-template-columns:1fr;gap:24px;}
}

/* === FAQ-pagina: gegroepeerde accordions === */
.faq-group + .faq-group{margin-top:38px;}
.faq-group > .eyebrow{margin-bottom:14px;}
details.faq-q{background:var(--white);border:1px solid var(--line-soft);border-radius:var(--r-sm);box-shadow:var(--shadow-sm);margin-bottom:10px;}
details.faq-q summary{list-style:none;cursor:pointer;padding:18px 24px;font-family:var(--display);font-weight:700;font-size:17px;color:var(--ink);display:flex;align-items:center;justify-content:space-between;gap:18px;}
details.faq-q summary::-webkit-details-marker{display:none;}
details.faq-q summary::after{content:"+";color:var(--bordeaux);font-size:24px;font-weight:400;line-height:1;flex:none;}
details.faq-q[open] summary{color:var(--bordeaux);}
details.faq-q[open] summary::after{content:"\2212";}
details.faq-q p{margin:0;padding:0 24px 20px;color:var(--muted);line-height:1.55;}
.faq-wrap{max-width:880px;}

/* === Artikel-opmaak: introquote, uitgelichte zin, fase-blokken === */
.article-lead-quote{max-width:780px;margin:2px 0 10px;padding:20px 26px;background:var(--sand);border-left:3px solid var(--bordeaux);border-radius:0 var(--r-sm) var(--r-sm) 0;}
.article-lead-quote p{margin:0;font-family:var(--display);font-weight:700;font-size:22px;color:var(--bordeaux-deep);line-height:1.3;}
.pullquote{max-width:780px;margin:30px 0;padding:4px 0 4px 22px;border-left:3px solid var(--amber);}
.pullquote p{margin:0;font-family:var(--display);font-weight:700;font-size:21px;color:var(--ink);line-height:1.35;}
.fase{max-width:780px;margin:24px 0;}
.fase h3{margin:0 0 14px;}
.weldoen-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.wn{border-radius:var(--r-sm);padding:18px 20px;}
.wn h4{margin:0 0 8px;font-size:13px;letter-spacing:.05em;text-transform:uppercase;font-family:var(--display);}
.wn p{margin:0;color:var(--muted);line-height:1.55;font-size:15px;}
.wn.wel{background:var(--sand);}
.wn.wel h4{color:var(--bordeaux);}
.wn.niet{background:var(--band);}
.wn.niet h4{color:var(--grey);}
@media(max-width:680px){.weldoen-grid{grid-template-columns:1fr;}}

/* === Artikelkaarten: meer ruimte voor de knop === */
.artikel-cards .card p{margin-bottom:28px;}


.back-to-overview { border-top:1px solid var(--line-soft); }
.back-link { display:inline-flex; align-items:center; gap:9px; font-family:var(--display); font-weight:600; font-size:15px; color:var(--bordeaux); text-decoration:none; transition:gap .15s ease, color .15s ease; }
.back-link:hover { color:var(--bordeaux-deep); gap:13px; }
.back-link .back-arrow { flex:0 0 auto; }

.compact-detail-card.meta-accent { background:var(--bordeaux); border-color:var(--bordeaux); }
.compact-detail-card.meta-accent .label { color:var(--amber); }
.compact-detail-card.meta-accent h3, .compact-detail-card.meta-accent p { color:#fff; }

.form-field-full { grid-column:1 / -1; }
.form-field-full textarea { width:100%; }

.opbrengst-lijst{list-style:none;margin:6px 0 0;padding:0;display:grid;gap:14px;}
.opbrengst-lijst li{position:relative;padding-left:30px;color:var(--muted);line-height:1.5;}
.opbrengst-lijst li:before{content:"";position:absolute;left:3px;top:3px;width:7px;height:12px;border:solid var(--bordeaux);border-width:0 2.5px 2.5px 0;transform:rotate(45deg);}

.usp-band{ text-align:center; }
.usp-statement{ max-width:820px; margin:0 auto; text-align:center; font-size:clamp(21px,2.3vw,28px); font-weight:700; line-height:1.3; color:var(--bordeaux); position:relative; padding-top:22px; }
.usp-statement:before{ content:""; display:block; width:46px; height:4px; border-radius:99px; background:var(--amber); margin:0 auto 22px; }

.tel-nr { white-space:nowrap; }
.tel-naam { font-size:0.86em; color:var(--muted); }
.footer-tel { display:block; margin:0 0 4px; font-size:13px; line-height:1.3; color:var(--muted); white-space:nowrap; }
.footer-contact-text .footer-tel a { display:inline; color:var(--muted); }
.footer-contact-text .footer-tel a:hover { color:var(--bordeaux); }

.image-card img.coach-card-img { aspect-ratio:5/4; object-fit:cover; background:#fff; }

/* ImProve Online aanmeldformulier */
#online-form {
  display:grid;
  gap:22px;
}
#online-form .online-form-section {
  background:#fff;
  border:1px solid var(--line-soft);
  border-radius:var(--r-md);
  padding:24px;
  box-shadow:0 8px 24px rgba(45,33,40,.045);
}
#online-form .form-section-title {
  margin:0 0 20px;
  padding:0 0 12px;
  border-bottom:1px solid var(--line-soft);
  color:var(--ink);
  font-size:21px;
  line-height:1.2;
  position:relative;
}
#online-form .form-section-title:after {
  content:"";
  position:absolute;
  left:0;
  bottom:-1px;
  width:46px;
  height:3px;
  border-radius:99px;
  background:var(--bronze);
}
#online-form label {
  margin-bottom:8px;
}
#online-form .field-hint {
  margin:-2px 0 10px;
  color:var(--muted);
  font-size:13.5px;
  line-height:1.45;
  max-width:760px;
}
#online-form .invoice-address { min-height:96px; }
#online-form .comments-field { min-height:132px; }
#online-form input,
#online-form textarea {
  background:#fff;
  border-color:#d9d4cf;
  box-shadow:0 1px 0 rgba(45,33,40,.02);
  transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
#online-form input:hover,
#online-form textarea:hover {
  border-color:#c8c0b8;
}
#online-form input:focus,
#online-form textarea:focus {
  background:#fff;
  border-color:var(--bordeaux);
  box-shadow:0 0 0 3px rgba(123,0,65,.10);
}
#online-form .online-form-actions {
  margin-top:0;
  display:flex;
  align-items:center;
  justify-content:flex-end;
}
#online-form .online-form-actions .btn {
  min-width:180px;
}
#online-form .small-note {
  margin-top:-8px;
  text-align:right;
}

@media (max-width:640px) {
  #online-form { gap:16px; }
  #online-form .online-form-section { padding:20px; }
  #online-form .form-section-title { font-size:19px; margin-bottom:18px; }
  #online-form .field-hint { font-size:13px; }
  #online-form .online-form-actions { justify-content:stretch; }
  #online-form .online-form-actions .btn { width:100%; }
  #online-form .small-note { text-align:left; margin-top:-4px; }
}
/* v160: compactere regelafstand in kernboodschap homepage */
.belief-statement { line-height:1; }
.belief-statement span { display:block; }
.belief-statement span + span { margin-top:8px; }

/* v162: compactere en kortere kernboodschap homepage */
.belief-split .belief-head h2 { max-width:520px; line-height:1.04; }
.belief-statement { line-height:1.08; margin-bottom:18px; }
.belief-statement span + span { margin-top:4px; }


/* ============================================================
   v169: CTA's homepage, submenu's en ontwerpvoorstellen
   ============================================================ */

/* CTA's in de twee inhoudelijke homepageblokken */
.belief-actions { margin-top:24px; }
.verschil-actions { display:flex; justify-content:center; gap:14px; flex-wrap:wrap; margin-top:30px; }
.training-name { color:var(--ink); }
.training-name:before { background:var(--bordeaux); }

/* Toegankelijk submenu op desktop en mobiel */
.nav-item { position:relative; display:flex; align-items:center; }
.nav-parent-row { display:flex; align-items:center; border-radius:999px; transition:.16s ease; }
.nav-parent-row > .nav-parent { padding-right:7px; }
.submenu-toggle {
  width:29px; height:34px; padding:0 10px 0 4px; border:0; background:transparent;
  display:inline-flex; align-items:center; justify-content:center; cursor:pointer; color:var(--muted);
}
.submenu-toggle span {
  width:7px; height:7px; border-right:1.5px solid currentColor; border-bottom:1.5px solid currentColor;
  transform:translateY(-2px) rotate(45deg); transition:transform .18s ease;
}
.nav-item:hover .nav-parent-row,
.nav-item:focus-within .nav-parent-row,
.nav-item.submenu-open .nav-parent-row { background:rgba(123,0,65,.07); }
.nav-item:hover .nav-parent-row > a,
.nav-item:focus-within .nav-parent-row > a,
.nav-item.submenu-open .nav-parent-row > a,
.nav-item:hover .submenu-toggle,
.nav-item:focus-within .submenu-toggle,
.nav-item.submenu-open .submenu-toggle { color:var(--bordeaux); }
.nav-item.submenu-open .submenu-toggle span { transform:translateY(2px) rotate(225deg); }

.submenu {
  position:absolute; z-index:80; top:calc(100% + 10px); left:0; width:max-content; min-width:200px; max-width:300px;
  padding:8px; background:#fff; border:1px solid var(--line-soft); border-radius:14px;
  box-shadow:0 18px 42px rgba(45,33,40,.14); opacity:0; visibility:hidden;
  pointer-events:none; transform:translateY(-6px); transition:opacity .16s ease, transform .16s ease, visibility .16s ease;
}
.submenu:before { content:""; position:absolute; left:0; right:0; top:-11px; height:11px; }
.nav-item:hover > .submenu,
.nav-item:focus-within > .submenu,
.nav-item.submenu-open > .submenu { opacity:1; visibility:visible; pointer-events:auto; transform:translateY(0); }
.navlinks .submenu a {
  display:flex; min-height:0; padding:11px 13px; border-radius:9px; color:var(--muted);
  text-transform:none; letter-spacing:0; font-size:13px; font-weight:600; line-height:1.32; white-space:normal;
}
.navlinks .submenu a:hover,
.navlinks .submenu a.active { background:rgba(123,0,65,.07); color:var(--bordeaux); }
.navlinks .submenu a.submenu-overview { color:var(--bordeaux); border-bottom:1px solid var(--line-soft); border-radius:9px 9px 0 0; margin-bottom:3px; padding-bottom:12px; }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

@media (max-width:980px) {
  .nav-item { display:block; width:100%; }
  .nav-parent-row { width:100%; border-radius:12px; }
  .nav-parent-row > .nav-parent { flex:1; padding-right:8px; border-radius:12px 0 0 12px; }
  .submenu-toggle { width:46px; height:46px; padding:0; flex:0 0 46px; border-radius:0 12px 12px 0; }
  .submenu {
    position:static; display:none; min-width:0; margin:3px 0 7px 14px; padding:5px;
    opacity:1; visibility:visible; pointer-events:auto; transform:none; box-shadow:none;
    border:0; border-left:2px solid rgba(123,0,65,.14); border-radius:0 10px 10px 0;
    background:rgba(123,0,65,.035);
  }
  .submenu:before { display:none; }
  .nav-item:hover > .submenu,
  .nav-item:focus-within > .submenu { display:none; }
  .nav-item.submenu-open > .submenu { display:block; }
  .navlinks .submenu a { min-height:42px; padding:10px 13px; font-size:12.8px; }
}

/* Previewpagina's voor CTA- en footervoorstellen */
.design-preview { background:#f7f5f2; }
.design-preview .preview-hero { padding:54px 0 32px; }
.design-preview .preview-intro { max-width:820px; }
.design-preview .preview-set { padding:36px 0 72px; }
.design-preview .preview-item { margin-top:34px; }
.preview-label {
  display:flex; align-items:baseline; justify-content:space-between; gap:20px; margin:0 0 14px;
  color:var(--muted); font-size:13px;
}
.preview-label strong { color:var(--bordeaux); font-family:var(--display); font-size:17px; }
.preview-stage { background:#fff; border:1px solid var(--line-soft); border-radius:24px; padding:34px; box-shadow:var(--shadow-sm); }

/* CTA voorstel 1: rustige splitkaart */
.cta-proposal-one {
  display:grid; grid-template-columns:minmax(0,1.4fr) auto; gap:36px; align-items:center;
  background:var(--sand); border:1px solid var(--line-soft); border-left:5px solid var(--bordeaux);
  border-radius:22px; padding:34px 38px;
}
.cta-proposal-one .eyebrow { margin-bottom:10px; }
.cta-proposal-one h2 { font-size:clamp(25px,2.6vw,33px); }
.cta-proposal-one p { color:var(--muted); margin-top:10px; max-width:650px; }
.cta-proposal-one .actions { margin:0; justify-content:flex-end; }

/* CTA voorstel 2: sterk merkvlak */
.cta-proposal-two {
  position:relative; overflow:hidden; display:grid; grid-template-columns:minmax(0,1fr) auto; gap:34px; align-items:center;
  background:var(--bordeaux); color:#fff; border-radius:24px; padding:38px 42px;
}
.cta-proposal-two:after {
  content:""; position:absolute; width:240px; height:240px; border-radius:50%; right:-85px; top:-110px;
  border:38px solid rgba(246,169,36,.16);
}
.cta-proposal-two .cta-copy, .cta-proposal-two .actions { position:relative; z-index:1; }
.cta-proposal-two .eyebrow { color:#fff; margin-bottom:10px; }
.cta-proposal-two .eyebrow:before { background:var(--amber); }
.cta-proposal-two h2 { color:#fff; font-size:clamp(25px,2.6vw,34px); }
.cta-proposal-two p { color:rgba(255,255,255,.82); margin-top:10px; max-width:650px; }
.cta-proposal-two .actions { margin:0; }
.cta-proposal-two .btn-primary { background:#fff; color:var(--bordeaux); }
.cta-proposal-two .btn-primary:hover { background:var(--sand); color:var(--bordeaux); }
.cta-proposal-two .btn-secondary { color:#fff; border-color:rgba(255,255,255,.55); }
.cta-proposal-two .btn-secondary:hover { background:rgba(255,255,255,.10); border-color:#fff; }

/* CTA voorstel 3: twee heldere routes */
.cta-proposal-three { background:var(--band); border-radius:24px; padding:34px; }
.cta-proposal-three .cta-heading { max-width:720px; margin-bottom:24px; }
.cta-proposal-three .cta-heading h2 { font-size:clamp(25px,2.6vw,33px); }
.cta-proposal-three .cta-heading p { color:var(--muted); margin-top:10px; }
.cta-route-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.cta-route {
  display:flex; align-items:center; justify-content:space-between; gap:22px; padding:22px 24px;
  background:#fff; border:1px solid var(--line-soft); border-radius:16px; transition:.18s ease;
}
.cta-route:hover { transform:translateY(-2px); box-shadow:var(--shadow-sm); border-color:rgba(123,0,65,.25); }
.cta-route strong { display:block; font-family:var(--display); font-size:19px; color:var(--ink); }
.cta-route span { display:block; color:var(--muted); font-size:14px; margin-top:3px; }
.cta-route b { color:var(--bordeaux); font-size:24px; font-weight:500; }

/* Footer voorstel 1: compact, open en functioneel */
.footer-proposal-one { background:#fff; border-top:5px solid var(--bordeaux); padding:36px; border-radius:0 0 22px 22px; }
.footer-proposal-one .fp-top { display:grid; grid-template-columns:1.15fr 1.85fr; gap:54px; }
.footer-proposal-one .fp-brand img { width:220px; }
.footer-proposal-one .fp-brand p { color:var(--muted); margin-top:18px; font-size:14px; line-height:1.55; }
.fp-links { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.fp-links h4 { color:var(--bordeaux); text-transform:uppercase; letter-spacing:.08em; font-size:12px; margin-bottom:12px; }
.fp-links a { display:block; color:var(--muted); font-size:13.5px; margin:0 0 7px; }
.fp-links a:hover { color:var(--bordeaux); }
.footer-proposal-one .fp-bottom { display:flex; justify-content:space-between; gap:24px; margin-top:30px; padding-top:18px; border-top:1px solid var(--line-soft); color:var(--muted-soft); font-size:12.5px; }

/* Footer voorstel 2: warm donker merkvlak */
.footer-proposal-two { overflow:hidden; background:var(--bordeaux-deep); color:#fff; border-radius:22px; }
.footer-proposal-two .fp-colorbar { height:7px; background:linear-gradient(90deg,#7b0041 0 24%,#c30066 24% 46%,#bc000e 46% 62%,#f6a924 62% 78%,#874c0d 78% 100%); }
.footer-proposal-two .fp-inner { padding:38px 40px 24px; }
.footer-proposal-two .fp-top { display:grid; grid-template-columns:1.2fr 1.8fr; gap:54px; }
.footer-proposal-two .fp-brand img { width:225px; background:#fff; padding:12px; border-radius:14px; }
.footer-proposal-two .fp-contact { color:rgba(255,255,255,.75); margin-top:18px; font-size:14px; line-height:1.55; }
.footer-proposal-two .fp-links h4 { color:#fff; }
.footer-proposal-two .fp-links a { color:rgba(255,255,255,.72); }
.footer-proposal-two .fp-links a:hover { color:#fff; }
.footer-proposal-two .fp-bottom { display:flex; justify-content:space-between; gap:24px; margin-top:30px; padding-top:18px; border-top:1px solid rgba(255,255,255,.16); color:rgba(255,255,255,.55); font-size:12.5px; }

/* Footer voorstel 3: contact als duidelijke eerste laag */
.footer-proposal-three { background:var(--roze); border:1px solid var(--line-soft); border-radius:22px; overflow:hidden; }
.footer-proposal-three .fp-contactbar {
  display:grid; grid-template-columns:minmax(0,1fr) auto; align-items:center; gap:32px;
  padding:28px 34px; background:#fff; border-bottom:1px solid var(--line-soft);
}
.footer-proposal-three .fp-contactbar h3 { font-size:23px; }
.footer-proposal-three .fp-contactbar p { color:var(--muted); margin-top:5px; }
.footer-proposal-three .fp-main { display:grid; grid-template-columns:.9fr 2.1fr; gap:50px; padding:34px; }
.footer-proposal-three .fp-brand img { width:230px; }
.footer-proposal-three .fp-brand p { color:var(--muted); margin-top:16px; font-size:13.5px; line-height:1.55; }
.footer-proposal-three .fp-bottom { padding:14px 34px; background:rgba(255,255,255,.62); color:var(--muted-soft); font-size:12.5px; text-align:center; }

@media (max-width:800px) {
  .preview-stage { padding:18px; }
  .cta-proposal-one, .cta-proposal-two { grid-template-columns:1fr; padding:28px; }
  .cta-proposal-one .actions, .cta-proposal-two .actions { justify-content:flex-start; }
  .cta-route-grid { grid-template-columns:1fr; }
  .footer-proposal-one .fp-top,
  .footer-proposal-two .fp-top,
  .footer-proposal-three .fp-main,
  .footer-proposal-three .fp-contactbar { grid-template-columns:1fr; gap:28px; }
  .fp-links { grid-template-columns:1fr 1fr; gap:24px; }
  .footer-proposal-one .fp-bottom,
  .footer-proposal-two .fp-bottom { flex-direction:column; gap:8px; }
}

@media (max-width:520px) {
  .fp-links { grid-template-columns:1fr; }
  .cta-route { align-items:flex-start; }
}


@media (max-width:980px) {
  .news-hero-box, .news-layout, .news-grid, .newsletter-panel { grid-template-columns:1fr; }
  .news-hero-actions { justify-content:flex-start; }
}
@media (max-width:760px) {
  .news-card, .newsletter-panel, .news-hero-aside, .newsletter-form-shell { padding:24px; border-radius:var(--r-md); }
  .news-stack { gap:16px; }
  .news-card h3, .news-stack .news-card h3, .news-hero-aside h2 { font-size:22px; }
  .newsletter-form .actions { flex-direction:column; }
  .newsletter-form .actions .btn { width:100%; justify-content:center; }
}

.newsletter-privacy { margin-top:16px; }
.newsletter-privacy a { color:var(--bordeaux); text-decoration:underline; text-underline-offset:2px; }
.newsletter-privacy a:hover { color:var(--bordeaux-deep); }
@media (max-width:760px) {
  .verschil-actions { flex-direction:column; align-items:stretch; }
  .verschil-actions .btn { width:100%; justify-content:center; }
}

/* ============================================================
   Nieuwe CTA- en footervoorstellen v172
   Typografie exact gelijk aan de website: Baloo 2 + Nunito Sans
   ============================================================ */
.design-preview-v2,
.design-preview-v2 button,
.design-preview-v2 input,
.design-preview-v2 select,
.design-preview-v2 textarea { font-family:var(--body); }
.design-preview-v2 h1,
.design-preview-v2 h2,
.design-preview-v2 h3,
.design-preview-v2 h4,
.design-preview-v2 .eyebrow,
.design-preview-v2 .btn,
.design-preview-v2 strong { font-family:var(--display); }
.design-preview-v2 .preview-hero { background:var(--paper); }
.design-preview-v2 .preview-stage-wide { padding:28px; }
.design-preview-v2 .preview-stage-footer { padding:0; overflow:hidden; }

/* CTA 1 */
.cta-new-one {
  background:var(--sand);
  border:1px solid var(--line-soft);
  border-radius:var(--r-lg);
  padding:38px 40px;
  display:grid;
  grid-template-columns:minmax(0,.85fr) minmax(0,1.45fr);
  gap:40px;
  align-items:center;
}
.cta-new-one-copy h2 { font-size:clamp(29px,3vw,40px); line-height:1.06; max-width:470px; }
.cta-new-one-copy p:not(.eyebrow) { color:var(--muted); margin-top:13px; max-width:420px; }
.cta-new-one-routes { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.cta-choice-card {
  min-height:190px;
  background:#fff;
  border:1px solid var(--line-soft);
  border-radius:20px;
  padding:24px 24px 22px;
  display:flex;
  flex-direction:column;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.cta-choice-card:hover { transform:translateY(-3px); box-shadow:var(--shadow); border-color:rgba(123,0,65,.22); }
.cta-choice-kicker { color:var(--bordeaux); font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; }
.cta-choice-card strong { display:block; color:var(--ink); font-size:21px; line-height:1.2; margin-top:10px; }
.cta-choice-arrow { margin-top:auto; color:var(--bordeaux); font-size:14px; font-weight:700; }
.cta-choice-arrow:after { content:"  ›"; font-size:18px; }

/* CTA 2 */
.cta-new-two {
  position:relative;
  overflow:hidden;
  background:#fff;
  border:1px solid var(--line-soft);
  border-radius:var(--r-lg);
  padding:34px 38px 34px 52px;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:34px;
  align-items:center;
  box-shadow:var(--shadow-sm);
}
.cta-new-two-accent { position:absolute; left:0; top:0; bottom:0; width:10px; display:grid; grid-template-rows:repeat(4,1fr); }
.cta-new-two-accent span:nth-child(1) { background:#7b0041; }
.cta-new-two-accent span:nth-child(2) { background:#c30066; }
.cta-new-two-accent span:nth-child(3) { background:#f6a924; }
.cta-new-two-accent span:nth-child(4) { background:#874c0d; }
.cta-new-two-content h2 { font-size:clamp(28px,2.8vw,38px); line-height:1.08; max-width:720px; }
.cta-new-two-content p:not(.eyebrow) { color:var(--muted); margin-top:12px; max-width:660px; }
.cta-new-two-actions { display:flex; flex-direction:column; align-items:flex-start; gap:14px; min-width:230px; }
.cta-new-two-actions .btn { width:100%; justify-content:center; }
.cta-new-two-actions .text-link { font-size:14px; align-self:center; }

/* CTA 3 */
.cta-new-three {
  padding:28px 32px;
  background:var(--band);
  border-radius:20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:32px;
}
.cta-new-three-copy .eyebrow { margin-bottom:8px; }
.cta-new-three-copy h2 { font-size:clamp(25px,2.6vw,34px); line-height:1.1; }
.cta-new-three-actions { display:flex; gap:12px; flex-wrap:wrap; flex:none; }

/* Gedeelde footerbasis */
.footer-new-one,
.footer-new-two,
.footer-new-three {
  font-family:var(--body);
  color:var(--ink);
}
.footer-new-one h4,
.footer-new-two h4,
.footer-new-three h4,
.footer-new-two h3 { font-family:var(--display); }
.footer-new-one a,
.footer-new-two a,
.footer-new-three a { transition:color .16s ease, transform .16s ease; }
.footer-new-one a:hover,
.footer-new-two a:hover,
.footer-new-three a:hover { color:var(--bordeaux); }
.footer-new-brand img { width:236px; }
.footer-new-brand p { color:var(--muted); margin-top:14px; max-width:310px; }
.footer-new-legal {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:16px 36px;
  color:var(--muted-soft);
  font-size:12.5px;
}
.footer-new-legal > span:last-child { display:flex; gap:16px; flex-wrap:wrap; }
.footer-new-legal a { color:inherit; }

/* Footer 1 */
.footer-new-one { background:var(--sand); }
.footer-new-one-top {
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:40px;
  padding:38px 40px 26px;
  align-items:end;
}
.footer-new-contact { display:flex; flex-direction:column; align-items:flex-end; gap:4px; color:var(--muted); font-size:14px; }
.footer-new-contact a { color:var(--bordeaux); font-weight:700; }
.footer-new-one-main {
  margin:0 40px;
  padding:26px 0 28px;
  border-top:1px solid var(--line-soft);
  display:grid;
  grid-template-columns:1.2fr 1fr .75fr;
  gap:34px;
}
.footer-new-one-main h4 { color:var(--bordeaux); font-size:15px; margin:0 0 12px; }
.footer-new-one-main a { display:block; color:var(--muted); font-size:13.5px; margin:0 0 7px; }
.footer-new-one .footer-new-legal { background:rgba(255,255,255,.48); }
.footer-rhythm-bar { display:grid; grid-template-columns:1.2fr 1fr .8fr .7fr .8fr; height:6px; }
.footer-rhythm-bar i:nth-child(1) { background:#7b0041; }
.footer-rhythm-bar i:nth-child(2) { background:#c30066; }
.footer-rhythm-bar i:nth-child(3) { background:#bc000e; }
.footer-rhythm-bar i:nth-child(4) { background:#f6a924; }
.footer-rhythm-bar i:nth-child(5) { background:#874c0d; }

/* Footer 2 */
.footer-new-two { background:#fff; }
.footer-new-two-main {
  padding:42px 42px 34px;
  display:grid;
  grid-template-columns:minmax(0,.8fr) minmax(0,1.55fr);
  gap:64px;
}
.footer-new-two-intro { padding-right:34px; border-right:1px solid var(--line-soft); }
.footer-new-two-intro img { width:225px; }
.footer-new-two-intro h3 { font-size:28px; line-height:1.1; margin:24px 0 14px; max-width:330px; }
.footer-mail-link { color:var(--bordeaux); font-weight:700; }
.footer-new-two-links { display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.footer-new-two-links h4 { color:var(--bordeaux); font-size:15px; margin:0 0 13px; }
.footer-new-two-links a,
.footer-new-two-links span { display:block; color:var(--muted); font-size:13.5px; margin:0 0 7px; }
.footer-new-two-bottom {
  display:flex;
  justify-content:space-between;
  gap:24px;
  padding:16px 42px;
  background:var(--roze);
  color:var(--muted-soft);
  font-size:12.5px;
}
.footer-new-two-bottom > span:last-child { display:flex; gap:16px; flex-wrap:wrap; }

/* Footer 3 */
.footer-new-three { background:var(--paper); }
.footer-new-three-routes { display:grid; grid-template-columns:1fr 1fr; background:var(--sand); }
.footer-new-three-routes a {
  min-height:112px;
  padding:24px 34px;
  display:grid;
  grid-template-columns:1fr auto;
  align-content:center;
  column-gap:18px;
}
.footer-new-three-routes a + a { border-left:1px solid var(--line-soft); }
.footer-new-three-routes span { grid-column:1; color:var(--bordeaux); font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; }
.footer-new-three-routes strong { grid-column:1; font-family:var(--display); color:var(--ink); font-size:20px; margin-top:5px; }
.footer-new-three-routes b { grid-column:2; grid-row:1 / 3; align-self:center; color:var(--bordeaux); font-size:26px; font-weight:500; }
.footer-new-three-routes a:hover { background:rgba(255,255,255,.48); }
.footer-new-three-main {
  padding:34px 38px 28px;
  display:grid;
  grid-template-columns:1.2fr 1fr .65fr;
  gap:48px;
}
.footer-new-three-main h4 { color:var(--bordeaux); font-size:15px; margin:0 0 12px; }
.footer-new-three-contact,
.footer-new-three-links { display:flex; flex-direction:column; align-items:flex-start; }
.footer-new-three-contact a,
.footer-new-three-contact span,
.footer-new-three-links a { color:var(--muted); font-size:13.5px; margin:0 0 7px; }
.footer-new-three-contact a { color:var(--bordeaux); font-weight:700; }
.footer-new-three .footer-new-legal { border-top:1px solid var(--line-soft); }

@media (max-width:900px) {
  .cta-new-one { grid-template-columns:1fr; }
  .cta-new-two { grid-template-columns:1fr; }
  .cta-new-two-actions { width:100%; min-width:0; }
  .cta-new-two-actions .btn { width:auto; align-self:flex-start; }
  .footer-new-one-top,
  .footer-new-two-main,
  .footer-new-three-main { grid-template-columns:1fr; gap:30px; }
  .footer-new-contact { align-items:flex-start; }
  .footer-new-two-intro { padding-right:0; padding-bottom:26px; border-right:0; border-bottom:1px solid var(--line-soft); }
}

@media (max-width:700px) {
  .design-preview-v2 .preview-stage-wide { padding:16px; }
  .cta-new-one,
  .cta-new-two { padding:28px 24px; }
  .cta-new-two { padding-left:34px; }
  .cta-new-one-routes,
  .footer-new-three-routes,
  .footer-new-two-links,
  .footer-new-one-main { grid-template-columns:1fr; }
  .cta-new-three { flex-direction:column; align-items:flex-start; }
  .cta-new-three-actions { width:100%; }
  .cta-new-three-actions .btn { width:100%; justify-content:center; }
  .footer-new-one-top,
  .footer-new-two-main,
  .footer-new-three-main { padding:28px 24px; }
  .footer-new-one-main { margin:0 24px; }
  .footer-new-three-routes a + a { border-left:0; border-top:1px solid var(--line-soft); }
  .footer-new-legal,
  .footer-new-two-bottom { flex-direction:column; align-items:flex-start; padding:15px 24px; gap:8px; }
}

#trainingen { scroll-margin-top:150px; }


@media (max-width:980px) {
  .footer-v4-shell { grid-template-columns:10px 1fr; gap:0 24px; }
  .footer-v4-brand, .footer-v4-right { padding:28px 24px; }
  .footer-v4-right { padding-top:0; }
}
@media (max-width:760px) {
  .footer-v4-shell { grid-template-columns:1fr; }
  .footer-v4-accent { min-height:8px; }
  .footer-v4-brand, .footer-v4-right { padding:24px; }
  .footer-v4-right { padding-top:0; }
  .footer-v4-links { grid-template-columns:1fr; gap:24px; }
  .footer-v4-meta { align-items:flex-start; text-align:left; }
  .footer-v4-legal { justify-content:flex-start; gap:10px 14px; }
}


/* ---------- Centrale trainingsdata en inschrijving ---------- */
#trainingsdata { scroll-margin-top:150px; }

/* Alle trainingsdata: gegroepeerd overzicht op de inschrijfpagina */
.alle-data-section { scroll-margin-top:150px; padding-bottom:30px; }
.alle-data-head { max-width:760px; }
.alle-data-head .lead { margin-top:14px; }
.all-dates-group + .all-dates-group { margin-top:38px; }
.all-dates-training {
  font-family:var(--display);
  font-size:22px; font-weight:700; line-height:1.2;
  color:var(--ink);
  margin:0 0 18px;
  padding-bottom:12px;
  border-bottom:1px solid var(--line);
}
#training-registration-form { scroll-margin-top:150px; }
@media (max-width:980px){ .alle-data-section, #training-registration-form { scroll-margin-top:128px; } }
.training-dates-section { padding-top:44px; }
.training-dates-head { max-width:820px; }
.training-dates-head .lead { margin-top:14px; }
.training-dates-grid {
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
  align-items:stretch;
}
.training-date-card {
  background:var(--white);
  border:1px solid var(--line-soft);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);
  padding:26px;
  display:flex;
  flex-direction:column;
  min-height:100%;
  position:relative;
  overflow:hidden;
}
.training-date-card:before {
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:4px;
  height:54px;
  border-radius:0 99px 99px 0;
  background:var(--bordeaux);
}
.training-date-top {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:18px;
}
.training-location {
  font-family:var(--display);
  color:var(--bordeaux);
  font-weight:700;
  font-size:15px;
}
.training-status {
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:0 11px;
  border-radius:999px;
  background:#EEF5EE;
  color:#426642;
  font-size:12px;
  font-weight:700;
}
.training-date-card h3 {
  margin:0 0 12px;
  font-size:23px;
  line-height:1.18;
  color:var(--ink);
}
.training-location-note {
  margin:0;
  color:var(--muted);
  font-size:14px;
  line-height:1.5;
}
.training-date-meta {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:20px 0 22px;
}
.training-date-meta span {
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:0 12px;
  border-radius:999px;
  background:var(--sand);
  color:var(--bronze-deep);
  font-size:12.5px;
  font-weight:700;
}
.training-date-actions {
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  margin-top:auto;
}
.training-date-actions .btn { width:100%; justify-content:center; }
.training-disclaimer {
  margin:22px 0 0;
  padding:17px 20px;
  border-radius:var(--r-md);
  background:rgba(255,255,255,.68);
  border:1px solid var(--line-soft);
  color:var(--muted);
  font-size:13.5px;
  line-height:1.55;
}
.training-card-summary {
  margin:4px 0 20px;
  padding-top:16px;
  border-top:1px solid var(--line-soft);
}
.training-card-summary p {
  margin:0 0 5px;
  color:var(--muted);
  font-size:14px;
  line-height:1.45;
}
.training-card-summary strong { color:var(--ink); }

.training-card-actions {
  display:grid;
  grid-template-columns:minmax(0,.82fr) minmax(0,1.28fr);
  gap:10px;
  margin-top:auto;
}
.card .training-card-actions .btn {
  margin-top:0;
  width:100%;
  min-height:48px;
  padding:0 18px;
  justify-content:center;
  text-align:center;
  line-height:1.2;
  white-space:normal;
}

.registration-page { padding-top:48px; }
.selection-panel {
  margin:0 auto 22px;
  background:var(--bordeaux);
  color:#fff;
  border-radius:var(--r-lg);
  padding:25px 30px;
  box-shadow:var(--shadow-sm);
}
.selection-panel.selection-panel-empty { background:var(--sand); color:var(--ink); }
.selection-panel-label {
  margin:0 0 7px;
  font-family:var(--display);
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(255,255,255,.75);
}
.selection-panel-empty .selection-panel-label { color:var(--bordeaux); }
.selection-panel h2 { margin:0; color:inherit; font-size:24px; line-height:1.2; }
.selection-panel-details {
  display:flex;
  flex-wrap:wrap;
  gap:8px 18px;
  margin-top:10px;
  color:rgba(255,255,255,.82);
  font-size:14px;
}
.selection-panel-empty .selection-panel-details { color:var(--muted); }
.selection-panel-details span { position:relative; }
.selection-panel-details span + span:before {
  content:"";
  position:absolute;
  left:-10px;
  top:8px;
  width:3px;
  height:3px;
  border-radius:50%;
  background:currentColor;
}
.registration-form-card { padding:38px; }
.registration-choice-grid {
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.registration-choice {
  display:flex;
  gap:13px;
  align-items:flex-start;
  min-height:100%;
  padding:18px;
  margin:0;
  background:#fff;
  border:1px solid var(--line-soft);
  border-radius:var(--r-md);
  cursor:pointer;
  transition:border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}
.registration-choice:hover { border-color:rgba(123,0,65,.3); box-shadow:var(--shadow-sm); }
.registration-choice:has(input:checked) { border-color:var(--bordeaux); box-shadow:0 0 0 3px rgba(123,0,65,.09); }
.registration-choice input {
  flex:none;
  width:19px;
  height:19px;
  min-height:19px;
  margin-top:3px;
  accent-color:var(--bordeaux);
}
.registration-choice span { display:block; }
.registration-choice strong {
  display:block;
  margin-bottom:5px;
  color:var(--ink);
  font-family:var(--display);
  font-size:16px;
}
.registration-choice small {
  display:block;
  color:var(--muted);
  font-size:13.5px;
  line-height:1.45;
  font-weight:400;
}

.registration-location-preference-note {
  margin:0;
  padding-top:2px;
  line-height:1.5;
}

.form-disclaimer {
  margin:22px 0 4px;
  padding:18px 20px;
  background:var(--sand);
  border:1px solid var(--line-soft);
  border-radius:var(--r-md);
}
.form-disclaimer strong {
  display:block;
  color:var(--ink);
  font-family:var(--display);
  margin-bottom:6px;
}
.form-disclaimer p { margin:0; color:var(--muted); font-size:13.5px; line-height:1.55; }
.form-disclaimer p + p { margin-top:6px; }
.registration-submit-actions { margin-top:24px; }
.registration-submit-actions .btn { min-width:220px; justify-content:center; }
.checkbox-row a { color:var(--bordeaux); text-decoration:underline; text-underline-offset:2px; }
.checkbox-row[hidden] { display:none; }

@media (max-width:980px) {
  .training-dates-grid { grid-template-columns:1fr; }
}
@media (max-width:760px) {
  .training-card-actions { grid-template-columns:1fr; }
  .training-date-card, .selection-panel, .registration-form-card { padding:24px; border-radius:var(--r-md); }
  .registration-choice-grid { grid-template-columns:1fr; }
  .selection-panel-details { flex-direction:column; gap:5px; }
  .selection-panel-details span + span:before { display:none; }
  .registration-submit-actions .btn { width:100%; }
}


/* ---------- Compact overzicht bovenaan trainingspagina's ---------- */
.training-overview-section { padding-top:28px; padding-bottom:38px; }
.training-overview-panel {
  display:grid; grid-template-columns:minmax(0,.78fr) minmax(0,1.22fr); gap:34px;
  background:var(--sand); border:1px solid var(--line-soft); border-radius:var(--r-lg);
  padding:30px 32px; box-shadow:var(--shadow-sm); align-items:start;
}
.training-overview-intro h2 { margin:0 0 8px; font-size:clamp(25px,2.5vw,33px); }
.training-overview-intro > p:last-of-type { margin:0; color:var(--muted); line-height:1.55; }
.training-overview-actions { margin-top:22px; display:flex; flex-wrap:wrap; gap:10px; }
.training-overview-actions .btn { min-height:44px; padding:0 18px; font-size:14px; }
.training-overview-grid {
  display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:12px;
}
.training-overview-grid article {
  min-height:104px; background:rgba(255,255,255,.76); border:1px solid var(--line-soft);
  border-radius:var(--r-md); padding:17px 18px;
}
.training-overview-grid strong {
  display:block; margin-bottom:5px; color:var(--ink); font-family:var(--display);
  font-size:17px; line-height:1.2;
}
.training-overview-grid span { display:block; color:var(--muted); font-size:13.5px; line-height:1.4; }
@media (max-width:980px) {
  .training-overview-panel { grid-template-columns:1fr; }
}
@media (max-width:760px) {
  .training-overview-section { padding-top:18px; padding-bottom:28px; }
  .training-overview-panel { padding:24px; }
  .training-overview-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .training-overview-actions { flex-direction:column; }
  .training-overview-actions .btn { width:100%; justify-content:center; }
}
@media (max-width:520px) {
  .training-overview-grid { grid-template-columns:1fr; }
  .training-overview-grid article { min-height:0; }
}

/* ---------- Compacte aanvullingen trainingspagina's ---------- */
.training-extra-section { padding-top:48px; padding-bottom:48px; }
.training-extra-head { max-width:760px; margin-bottom:26px; }
.training-outcomes-grid {
  display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px;
}
.training-outcome {
  display:grid; grid-template-columns:38px minmax(0,1fr); gap:14px; align-items:start;
  background:var(--white); border:1px solid var(--line-soft); border-radius:var(--r-md);
  padding:20px 22px; box-shadow:var(--shadow-sm);
}
.training-outcome span {
  display:flex; align-items:center; justify-content:center; width:34px; height:34px;
  border-radius:50%; background:#F6E6EE; color:var(--bordeaux);
  font-family:var(--display); font-size:12px; font-weight:700;
}
.training-outcome p { margin:3px 0 0; color:var(--ink); line-height:1.5; }
.training-days-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px; }
.training-day-card {
  background:var(--white); border:1px solid var(--line-soft); border-radius:var(--r-md);
  padding:24px 26px; box-shadow:var(--shadow-sm);
}
.training-day-label {
  display:inline-flex; min-height:28px; align-items:center; padding:0 12px; border-radius:999px;
  background:#F6E6EE; color:var(--bordeaux); font-family:var(--display); font-size:12px;
  font-weight:700; letter-spacing:.05em; text-transform:uppercase; margin-bottom:12px;
}
.training-day-card h3 { margin:0 0 8px; font-size:22px; }
.training-day-card p { margin:0; color:var(--muted); line-height:1.55; }
.training-method-grid {
  display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px; margin-top:18px;
}
.training-method-grid article {
  background:rgba(255,255,255,.58); border:1px solid var(--line-soft); border-radius:var(--r-md);
  padding:22px 24px;
}
.training-method-grid h3 { margin:0 0 8px; font-size:20px; }
.training-method-grid p:last-child { margin:0; color:var(--muted); line-height:1.55; }
.training-practical-section { padding-top:44px; padding-bottom:44px; }
.training-facts-grid {
  display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px;
}
.training-facts-grid article {
  background:var(--white); border:1px solid var(--line-soft); border-radius:var(--r-md);
  padding:18px 20px; box-shadow:var(--shadow-sm);
}
.training-facts-grid strong { display:block; color:var(--ink); font-family:var(--display); margin-bottom:5px; }
.training-facts-grid span { color:var(--muted); font-size:14.5px; line-height:1.45; }
.training-choice-card {
  margin-top:20px; display:flex; align-items:center; justify-content:space-between; gap:24px;
  background:var(--sand); border:1px solid var(--line-soft); border-radius:var(--r-md); padding:22px 24px;
}
.training-choice-card h3 { margin:0 0 5px; font-size:20px; }
.training-choice-card p:last-child { margin:0; color:var(--muted); }
.training-choice-card .btn { flex:0 0 auto; }
.training-faq-section { padding-top:38px; padding-bottom:48px; }
.training-faq-list { display:grid; gap:10px; max-width:900px; }
.training-faq-list details {
  background:var(--white); border:1px solid var(--line-soft); border-radius:var(--r-md);
  padding:0 20px; box-shadow:var(--shadow-sm);
}
.training-faq-list summary {
  cursor:pointer; list-style:none; padding:18px 30px 18px 0; position:relative;
  font-family:var(--display); font-weight:700; color:var(--ink);
}
.training-faq-list summary::-webkit-details-marker { display:none; }
.training-faq-list summary:after {
  content:"+"; position:absolute; right:0; top:50%; transform:translateY(-50%);
  color:var(--bordeaux); font-size:22px; font-weight:500;
}
.training-faq-list details[open] summary:after { content:"−"; }
.training-faq-list details p { margin:0; padding:0 0 18px; color:var(--muted); line-height:1.55; }

@media (max-width:980px) {
  .training-facts-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width:760px) {
  .training-outcomes-grid, .training-days-grid, .training-method-grid, .training-facts-grid { grid-template-columns:1fr; }
  .training-choice-card { flex-direction:column; align-items:flex-start; }
  .training-choice-card .btn { width:100%; justify-content:center; }
}


/* Prijsaccent en opleidingsbudget op trainingspagina's */
.training-cta .pill-price {
  min-height:38px;
  padding:0 17px;
  font-size:15px;
  font-weight:800;
  color:var(--ink);
}
.training-budget-note {
  margin-top:14px;
  max-width:680px;
  padding-left:14px;
  border-left:3px solid rgba(123,0,65,.28);
  font-size:14px;
  line-height:1.5;
  color:var(--muted);
}

/* v188: compacter overzicht en minder herhaling op trainingsdetailpagina's */
.training-overview-price strong { font-size:22px; color:var(--bordeaux); }
.training-overview-budget { margin-top:18px !important; color:var(--muted); font-size:13.5px; line-height:1.48; }
.training-facts-grid.compact-three { grid-template-columns:repeat(3,minmax(0,1fr)); }
@media (max-width:760px) {
  .training-facts-grid.compact-three { grid-template-columns:1fr; }
}


.training-name-inline {
  color:var(--bordeaux);
  font-weight:700;
}

.compact-detail-grid-five {
  grid-template-columns:repeat(6,minmax(0,1fr));
}
.compact-detail-grid-five > .topic-card {
  grid-column:span 2;
  min-height:320px;
  padding:26px 26px 28px;
  background:linear-gradient(180deg,#fff 0%, #fcfaf8 100%);
}
.compact-detail-grid-five > .topic-card:nth-child(4) { grid-column:2 / span 2; }
.compact-detail-grid-five > .topic-card:nth-child(5) { grid-column:4 / span 2; }
.topic-card .label {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:36px;
  height:36px;
  padding:0 10px;
  border-radius:999px;
  background:#F4EEE8;
  color:var(--bronze-deep);
  font-family:var(--display);
  font-weight:700;
  letter-spacing:.04em;
}
.topic-card:before { width:4px; height:56px; background:var(--bronze); }
.topic-card h3 {
  min-height:auto;
  margin-bottom:14px;
  font-size:clamp(20px,2vw,22px);
}
.topic-card p {
  margin:0;
  font-size:16px;
  line-height:1.6;
}
.training-day-card {
  min-height:230px;
  display:flex;
  flex-direction:column;
}
.training-day-card p {
  margin-top:auto;
}
@media (max-width:980px) {
  .compact-detail-grid-five { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .compact-detail-grid-five > .topic-card,
  .compact-detail-grid-five > .topic-card:nth-child(4),
  .compact-detail-grid-five > .topic-card:nth-child(5) { grid-column:auto; min-height:0; }
}
@media (max-width:760px) {
  .compact-detail-grid-five { grid-template-columns:1fr; }
}


/* v190: trainingsdetail aanscherpingen */
.training-overview-budget {
  margin-top:18px !important;
  padding:16px 18px;
  border-radius:18px;
  background:#F8F1F5;
  border:1px solid rgba(123,0,65,.12);
  color:var(--ink);
  font-size:14px;
  line-height:1.55;
}
.training-overview-budget::before {
  content:'Tip!';
  display:inline-block;
  margin-right:8px;
  color:var(--bordeaux);
  font-weight:800;
}
.training-overview-grid article strong {
  line-height:1.25;
}
.compact-detail-grid-five {
  grid-template-columns:repeat(3,minmax(0,1fr));
  align-items:stretch;
}
.compact-detail-grid-five > .topic-card {
  grid-column:auto;
  min-height:300px;
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  gap:18px;
}
.compact-detail-grid-five > .topic-card:nth-child(4),
.compact-detail-grid-five > .topic-card:nth-child(5) {
  grid-column:auto;
}
@media (max-width:1100px) {
  .compact-detail-grid-five { grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width:760px) {
  .compact-detail-grid-five { grid-template-columns:1fr; }
}


/* v191 vervolg */
.compact-detail-grid-five {
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:18px;
  align-items:stretch;
}
.compact-detail-grid-five > .topic-card,
.compact-detail-grid-five > .topic-card:nth-child(4),
.compact-detail-grid-five > .topic-card:nth-child(5) {
  grid-column:auto;
  min-height:220px;
  padding:18px 18px 20px;
  border-radius:24px;
}
.compact-detail-grid-five > .topic-card .label {
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:44px;
  border-radius:999px;
  background:var(--sand);
  margin-bottom:14px;
  font-size:14px;
}
.compact-detail-grid-five > .topic-card h3 {
  font-size:22px;
  margin-bottom:10px;
}
.compact-detail-grid-five > .topic-card p {
  font-size:16px;
  line-height:1.55;
}
.selection-panel {
  margin-top:24px;
}
@media (max-width:1280px) {
  .compact-detail-grid-five { grid-template-columns:repeat(3,minmax(0,1fr)); }
}
@media (max-width:980px) {
  .compact-detail-grid-five { grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width:640px) {
  .compact-detail-grid-five { grid-template-columns:1fr; }
}


/* v192: trainingsdetail herindeling */
.training-overview-grid {
  grid-template-columns:repeat(4,minmax(0,1fr));
}
.training-overview-grid article {
  min-height:110px;
}
.training-overview-intro p strong {
  color:var(--ink);
}
#inhoud .lead p + p {
  margin-top:12px;
}
#inhoud .lead p strong {
  color:var(--ink);
}
.training-day-card {
  min-height:0;
}
.training-day-card p {
  margin-top:0;
}
.training-method-grid article:nth-child(2) {
  background:#F8F1F5;
  border-color:rgba(123,0,65,.12);
}
.training-choice-card {
  margin-top:18px;
}
@media (max-width:980px) {
  .training-overview-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width:640px) {
  .training-overview-grid { grid-template-columns:1fr; }
}


/* v193: trainingsdetail finetuning */
.training-overview-grid {
  grid-template-columns:repeat(4,minmax(0,1fr));
  align-items:stretch;
}
.training-overview-grid article {
  min-height:118px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}
.training-overview-grid article span {
  margin-top:auto;
}
.training-overview-grid article:last-child {
  justify-content:flex-start;
}
.training-overview-grid article strong {
  margin-bottom:8px;
}
.training-overview-grid article span br {
  content:"";
}

.compact-detail-grid-five {
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:20px;
  align-items:stretch;
}
.compact-detail-grid-five > .topic-card,
.compact-detail-grid-five > .topic-card:nth-child(4),
.compact-detail-grid-five > .topic-card:nth-child(5) {
  grid-column:span 2;
  min-height:255px;
  height:100%;
  padding:22px 22px 24px;
  border-radius:26px;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.compact-detail-grid-five > .topic-card:nth-child(4) { grid-column:2 / span 2; }
.compact-detail-grid-five > .topic-card:nth-child(5) { grid-column:4 / span 2; }
.compact-detail-grid-five > .topic-card .label {
  width:auto;
  min-width:68px;
  min-height:38px;
  padding:0 18px;
  margin:0 auto 4px;
  border-radius:999px;
  background:var(--sand);
  font-size:13px;
}
.compact-detail-grid-five > .topic-card h3 {
  margin:0;
  font-size:clamp(22px,2vw,24px);
  line-height:1.2;
  min-height:2.4em;
}
.compact-detail-grid-five > .topic-card p {
  margin:0;
  font-size:16px;
  line-height:1.6;
}

@media (max-width:1280px) {
  .training-overview-grid { grid-template-columns:repeat(3,minmax(0,1fr)); }
}
@media (max-width:1100px) {
  .compact-detail-grid-five {
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .compact-detail-grid-five > .topic-card,
  .compact-detail-grid-five > .topic-card:nth-child(4),
  .compact-detail-grid-five > .topic-card:nth-child(5) {
    grid-column:auto;
    min-height:0;
  }
}
@media (max-width:760px) {
  .training-overview-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width:640px) {
  .training-overview-grid,
  .compact-detail-grid-five { grid-template-columns:1fr; }
}


/* v195: rustige definitieve opmaak trainingsdetailpagina's */
.training-overview-panel {
  grid-template-columns:minmax(300px,.75fr) minmax(0,1.45fr);
  gap:32px;
  align-items:stretch;
}
.training-overview-grid {
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  align-items:stretch;
}
.training-overview-grid article {
  min-height:132px;
  height:100%;
  padding:20px 20px 18px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  border-radius:20px;
}
.training-overview-grid article strong {
  min-height:2.4em;
  margin:0 0 12px;
  font-size:18px;
  line-height:1.18;
}
.training-overview-grid article span {
  margin-top:auto;
  font-size:14px;
  line-height:1.48;
}
.training-overview-price strong {
  font-size:24px;
}

.compact-detail-grid-five {
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:16px;
  align-items:stretch;
}
.compact-detail-grid-five > .topic-card,
.compact-detail-grid-five > .topic-card:nth-child(4),
.compact-detail-grid-five > .topic-card:nth-child(5) {
  grid-column:auto;
  min-height:230px;
  height:100%;
  padding:22px 20px 24px;
  border-radius:22px;
  display:flex;
  flex-direction:column;
  gap:0;
}
.compact-detail-grid-five > .topic-card .label {
  width:44px;
  min-width:44px;
  height:30px;
  min-height:30px;
  padding:0;
  margin:0 0 24px;
  border-radius:999px;
  background:var(--sand);
  font-size:12px;
}
.compact-detail-grid-five > .topic-card h3 {
  min-height:2.45em;
  margin:0 0 14px;
  font-size:20px;
  line-height:1.18;
}
.compact-detail-grid-five > .topic-card p {
  margin:0;
  font-size:15px;
  line-height:1.55;
}
.topic-card:before {
  height:52px;
}

.incompany-tail-section {
  padding-top:46px;
  padding-bottom:54px;
}
.incompany-tail-panel {
  display:grid;
  grid-template-columns:minmax(0,1.5fr) auto;
  gap:34px;
  align-items:center;
  padding:34px 38px;
  background:var(--sand);
  border:1px solid var(--line-soft);
  border-radius:var(--r-lg);
}
.incompany-tail-panel h2 {
  margin-bottom:10px;
  font-size:clamp(26px,2.6vw,36px);
}
.incompany-tail-panel p:last-child {
  margin:0;
  max-width:780px;
  color:var(--muted);
  line-height:1.6;
}
.incompany-tail-panel .actions {
  margin:0;
  flex-direction:column;
  align-items:stretch;
}
.incompany-tail-panel .btn {
  min-width:220px;
  justify-content:center;
}
.incompany-detail-hero .page-hero-box > div {
  max-width:720px;
}

@media (max-width:1280px) {
  .compact-detail-grid-five { grid-template-columns:repeat(3,minmax(0,1fr)); }
  .compact-detail-grid-five > .topic-card { min-height:220px; }
}
@media (max-width:1040px) {
  .training-overview-panel { grid-template-columns:1fr; }
  .incompany-tail-panel { grid-template-columns:1fr; }
  .incompany-tail-panel .actions { flex-direction:row; flex-wrap:wrap; }
}
@media (max-width:800px) {
  .training-overview-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .compact-detail-grid-five { grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width:560px) {
  .training-overview-grid,
  .compact-detail-grid-five { grid-template-columns:1fr; }
  .training-overview-grid article,
  .compact-detail-grid-five > .topic-card { min-height:0; }
  .incompany-tail-panel { padding:26px 24px; }
  .incompany-tail-panel .actions { flex-direction:column; }
  .incompany-tail-panel .btn { width:100%; }
}

/* v210: sectiekleur volgt nu de klassen (wit standaard, grijs via section-beige/grey) */

.footer.footer-v4,
.footer-v4-shell {
  background:var(--sand);
}
.footer-v4-accent {
  display:none;
}
.footer-v4-shell {
  border-top:1px solid var(--line-soft);
}
.footer-v4-meta {
  background:rgba(255,255,255,.30);
}

/* ======================================================================
   Detailpagina trainingen, herziene opmaak (preview op basiskennis.html).
   Afgeschermd onder .tdetail zodat de overige pagina's ongewijzigd blijven.
   ====================================================================== */
.tdetail .section { padding:46px 0; }
.tdetail .td-head { max-width:760px; margin-bottom:26px; }

/* In het kort: rustige feitenrij, geen paneel, geen tegels, geen tip-kader */
.tdetail .td-overview-intro { max-width:760px; margin-bottom:26px; }
.tdetail .td-overview-intro h2 { margin:0 0 10px; }
.tdetail .td-overview-intro p { margin:0; color:var(--muted); line-height:1.55; }
.tdetail .td-facts {
  margin:0; display:grid; grid-template-columns:repeat(3,minmax(0,1fr));
  column-gap:40px; border-top:1px solid var(--line-soft);
}
.tdetail .td-facts > div { padding:18px 0; border-bottom:1px solid var(--line-soft); }
.tdetail .td-facts dt {
  font-family:var(--display); font-weight:700; color:var(--ink);
  font-size:17px; line-height:1.2; margin-bottom:5px;
}
.tdetail .td-facts dd { margin:0; color:var(--muted); font-size:14px; line-height:1.45; }
.tdetail .td-facts .td-fact-price dt { color:var(--bordeaux); }
.tdetail .td-budget { margin:22px 0 0; max-width:760px; color:var(--muted); font-size:14px; line-height:1.5; }

/* Onderwerpen: lichte cellen op een rij, bronzen tik als enige accent */
.tdetail .td-topic-list {
  list-style:none; margin:0; padding:0;
  display:grid; grid-template-columns:repeat(5,minmax(0,1fr)); column-gap:26px;
}
.tdetail .td-topic-list li { padding:6px 0 2px; }
.tdetail .td-topic-list .td-num {
  display:block; position:relative; padding-top:14px; margin-bottom:12px;
  font-family:var(--display); font-weight:700; color:var(--bronze-deep);
  font-size:14px; letter-spacing:.04em;
}
.tdetail .td-topic-list .td-num:before {
  content:""; position:absolute; left:0; top:0; width:26px; height:3px; background:var(--bronze);
}
.tdetail .td-topic-list h3 { font-size:17px; line-height:1.18; margin:0 0 7px; }
.tdetail .td-topic-list p { margin:0; font-size:14px; line-height:1.45; color:var(--muted); }

/* Resultaten: genummerde regels, geen doos, geen roze badge */
.tdetail .td-outcome-list {
  list-style:none; margin:0; padding:0;
  display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); column-gap:40px;
  border-top:1px solid var(--line-soft);
}
.tdetail .td-outcome-list li {
  display:grid; grid-template-columns:34px minmax(0,1fr); gap:16px; align-items:start;
  padding:20px 0; border-bottom:1px solid var(--line-soft);
}
.tdetail .td-outcome-list .td-num {
  font-family:var(--display); font-weight:700; color:var(--bordeaux); font-size:18px; line-height:1.25;
}
.tdetail .td-outcome-list p { margin:0; color:var(--ink); line-height:1.5; }

/* Opbouw: twee dagen als duidelijke twee-stappen met groot cijfer als anker.
   Werkwijze/Je neemt mee zijn duidelijk ondergeschikt (klein bronzen sublabel,
   geen sectie-eyebrow, geen eigen kop). Cross-sell is een rustige regel. */
.tdetail .td-days { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:40px; }
.tdetail .td-day { display:grid; grid-template-columns:auto minmax(0,1fr); gap:22px; align-items:start; }
.tdetail .td-day-num {
  font-family:var(--display); font-weight:700; color:var(--bordeaux);
  font-size:clamp(40px,4vw,52px); line-height:.85;
}
.tdetail .td-day-k {
  margin:0 0 5px; font-family:var(--display); font-weight:700; color:var(--bronze-deep);
  font-size:13px; letter-spacing:.06em; text-transform:uppercase;
}
.tdetail .td-day h3 { margin:0 0 8px; font-size:21px; }
.tdetail .td-day p:last-child { margin:0; color:var(--muted); line-height:1.55; }

.tdetail .td-practical {
  margin-top:38px; padding-top:30px; border-top:1px solid var(--line-soft);
  display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:22px 40px;
}
.tdetail .td-sublabel {
  margin:0 0 7px; font-family:var(--display); font-weight:700; color:var(--bronze-deep);
  font-size:13px; letter-spacing:.04em;
}
.tdetail .td-practical p:last-child { margin:0; color:var(--muted); line-height:1.55; max-width:520px; }

.tdetail .td-crosssell {
  margin:30px 0 0; padding-top:22px; border-top:1px solid var(--line-soft);
  color:var(--muted); line-height:1.55; max-width:760px;
}
.tdetail .td-crosssell a { color:var(--bordeaux); font-weight:600; }
.crosssell-box-section { padding:30px 0; }
.crosssell-box { background:var(--lichtbruin); border-radius:var(--r-md); padding:16px 22px; max-width:820px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:14px 22px; flex-wrap:wrap; }
.crosssell-box .crosssell-text { margin:0; color:var(--ink); line-height:1.5; font-size:15.5px; }
.crosssell-box .crosssell-btn { flex:none; display:inline-flex; align-items:center; gap:7px; background:var(--bordeaux); color:#fff; font-family:var(--display); font-weight:700; font-size:14px; padding:9px 13px; border-radius:999px; text-decoration:none; white-space:nowrap; transition:background .16s ease; }
.crosssell-box .crosssell-btn:hover { background:#5e0031; }
.crosssell-box .crosssell-btn:after { content:"\203A"; font-size:15px; line-height:0; }
.tdetail .td-practical.single { grid-template-columns:1fr; }
.tdetail .td-takeaway { margin:24px 0 0; color:var(--muted); line-height:1.55; max-width:760px; }

/* FAQ: hairline-regels in plaats van witte dozen */
.tdetail .td-faq-list { max-width:900px; }
.tdetail .td-faq-list details { border-top:1px solid var(--line-soft); }
.tdetail .td-faq-list details:last-child { border-bottom:1px solid var(--line-soft); }
.tdetail .td-faq-list summary {
  cursor:pointer; list-style:none; position:relative; padding:20px 36px 20px 0;
  font-family:var(--display); font-weight:700; color:var(--ink);
}
.tdetail .td-faq-list summary::-webkit-details-marker { display:none; }
.tdetail .td-faq-list summary:after {
  content:"+"; position:absolute; right:4px; top:50%; transform:translateY(-50%);
  font-family:var(--display); font-weight:700; color:var(--bordeaux); font-size:22px;
  transition:transform .2s ease;
}
.tdetail .td-faq-list details[open] summary:after { transform:translateY(-50%) rotate(45deg); }
.tdetail .td-faq-list details > p { margin:0 0 20px; color:var(--muted); line-height:1.55; max-width:760px; }

/* Trainingsdata: disclaimer plat, geen kader */
.tdetail .training-disclaimer { border:0; background:none; padding:14px 0 0; }

@media (max-width:980px) {
  .tdetail .td-facts { grid-template-columns:repeat(2,minmax(0,1fr)); column-gap:30px; }
  .tdetail .td-topic-list { grid-template-columns:repeat(3,minmax(0,1fr)); row-gap:8px; }
  .tdetail .td-outcome-list { grid-template-columns:1fr; }
  .tdetail .td-days, .tdetail .td-practical { grid-template-columns:1fr; gap:26px; }
  .tdetail .td-day-num { font-size:40px; }
}
@media (max-width:560px) {
  .tdetail .td-facts { grid-template-columns:1fr; }
  .tdetail .td-topic-list { grid-template-columns:1fr; }
}

/* Detailpagina trainingen: StuurRitme-figuur zonder losse kaart (de SVG heeft
   zijn eigen plaat), en incompany-slot zonder zanddoos. */
.tdetail .model-figure img {
  background:none; border:0; border-radius:0; box-shadow:none; padding:0;
}
.tdetail .td-incompany-inner {
  display:grid; grid-template-columns:minmax(0,1.25fr) minmax(0,.75fr); gap:40px; align-items:center;
}
.tdetail .td-incompany-inner h2 { margin:0 0 12px; }
.tdetail .td-incompany-inner > div > p { margin:0; color:var(--muted); line-height:1.6; max-width:620px; }
.tdetail .td-incompany-actions { display:flex; flex-wrap:wrap; gap:10px; }
@media (max-width:980px) {
  .tdetail .td-incompany-inner { grid-template-columns:1fr; gap:22px; }
}
@media (max-width:560px) {
  .tdetail .td-incompany-actions { flex-direction:column; }
  .tdetail .td-incompany-actions .btn { width:100%; justify-content:center; }
}

/* Incompany-traject: vier stappen met groot bronzen cijfer, eigen ritme
   (anders dan de bordeaux dag-cijfers en de genummerde resultaatregels). */
.tdetail .td-steps { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:30px 28px; }
.tdetail .td-step .td-step-num {
  display:block; font-family:var(--display); font-weight:700; color:var(--bronze);
  font-size:38px; line-height:.9; margin-bottom:12px;
}
.tdetail .td-step h3 { font-size:18px; margin:0 0 7px; }
.tdetail .td-step p { margin:0; color:var(--muted); line-height:1.5; font-size:14.5px; }
@media (max-width:980px) { .tdetail .td-steps { grid-template-columns:repeat(2,minmax(0,1fr)); gap:28px; } }
@media (max-width:560px) { .tdetail .td-steps { grid-template-columns:1fr; } }

/* Formulierverzending: honeypot (verborgen) en foutmelding */
.hp-veld { position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; }
.verzend-fout { margin-top:14px; color:var(--bordeaux); font-weight:600; }
