/* ═══════════════════════════════════════════
   Zuiver in Zorg - Het Personeelslek
   Design tokens, layout, components
   ═══════════════════════════════════════════ */

/* ─── @font-face: Public Sans Variable (self-hosted WOFF2) ─── */
@font-face {
  font-family: "Public Sans";
  font-style: normal;
  font-display: swap;
  font-weight: 100 900;
  src: url("/assets/fonts/PublicSans-Variable-LatinExt.woff2") format("woff2-variations");
  unicode-range: U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face {
  font-family: "Public Sans";
  font-style: normal;
  font-display: swap;
  font-weight: 100 900;
  src: url("/assets/fonts/PublicSans-Variable-Latin.woff2") format("woff2-variations");
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}

:root {
  /* ─── Color tokens - Rijksoverheid-grade clarity & trust ─── */
  --bg: #F6F4F0;
  --surface: #FFFFFF;
  --surface-muted: #EDEBE7;
  --text: #1A1A1A;
  --text-secondary: #4D4D4D;
  --accent: #8A2735;
  --accent-hover: #6B1D28;
  --accent-soft: #F0E3E6;
  --line: #D6D1CB;
  --line-soft: #E5E2DD;
  --link: #154273;
  --link-hover: #0D2B4D;
  --shadow: 0 1px 2px rgba(0, 0, 0, 0.03);
  --shadow-lg: 0 1px 4px rgba(0, 0, 0, 0.04);
  --radius: 8px;
  --radius-sm: 6px;
  --container: 1140px;
  --narrow: 740px;
  --side-pad: 24px;

  /* ─── Spacing scale - generous Rijksoverheid-style whitespace ─── */
  --space-xs: 8px;
  --space-sm: 16px;
  --space-md: 24px;
  --space-lg: 48px;
  --space-xl: 72px;
  --space-2xl: 96px;

  /* ─── Typography tokens - optimised for Dutch government readability ─── */
  --ff-sans: "Public Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;

  --fs-overline: clamp(0.75rem, 0.72rem + 0.10vw, 0.8125rem);
  --fs-ui:       clamp(0.9rem, 0.86rem + 0.14vw, 0.9625rem);
  --fs-small:    clamp(0.8125rem, 0.79rem + 0.10vw, 0.875rem);
  --fs-body:     clamp(1.0625rem, 1.02rem + 0.18vw, 1.15rem);
  --fs-lead:     clamp(1.1875rem, 1.08rem + 0.45vw, 1.375rem);
  --fs-h3:       clamp(1.375rem, 1.20rem + 0.55vw, 1.75rem);
  --fs-h2:       clamp(1.75rem, 1.45rem + 0.85vw, 2.375rem);
  --fs-h1:       clamp(2.25rem, 1.80rem + 1.50vw, 3.25rem);
  --fs-metric:   clamp(2rem, 1.70rem + 1.00vw, 2.625rem);

  --lh-tight:      1.12;
  --lh-ui:         1.3;
  --lh-short:      1.38;
  --lh-lead:       1.55;
  --lh-body:       1.7;
  --lh-body-wide:  1.75;

  --ls-tight: -0.01em;
  --ls-h:     -0.005em;
  --ls-ui:    0;
  --ls-label: 0.01em;
  --ls-overline: 0.06em;

  --measure-body: 66ch;
  --measure-lead: 52ch;
  --measure-card: 36ch;
  --measure-faq:  62ch;

  --space-paragraph: 1.1em;
  --space-list-item: 0.5em;
  --space-heading-below-sm: 0.85rem;
  --space-heading-below-md: 1.1rem;
  --space-heading-above-sm: 1.25rem;
  --space-heading-above-md: 1.5rem;
  --space-heading-above-lg: 2rem;
  --space-section-y-mobile: 4.5rem;
  --space-section-y-desktop: 6.5rem;

  /* ─── Focus - WCAG 2.2 enhanced visible focus ─── */
  --focus-ring: 0 0 0 3px rgba(21, 66, 115, 0.35);
}

/* ─── Reset / Base ─── */
*, *::before, *::after { box-sizing: border-box; }
html { font-size: 100%; scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--ff-sans);
  font-synthesis: none;
  color: var(--text);
  background: var(--bg);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  font-feature-settings: "kern" 1, "liga" 1;
}
img { max-width: 100%; display: block; height: auto; }
a { color: var(--link); text-decoration-thickness: .08em; text-underline-offset: .18em; transition: color .15s ease; }
a:hover { color: var(--link-hover); }
a:focus-visible { outline: 3px solid rgba(21, 66, 115, .35); outline-offset: 3px; border-radius: 4px; }
strong { font-weight: 700; }
.hidden { display: none !important; }
.hidden-field { position: absolute; left: -9999px; opacity: 0; }
.skip-link {
  position: absolute; left: -9999px; top: 0;
  background: var(--accent); color: #fff; padding: 1rem 1.25rem; z-index: 100;
}
.skip-link:focus { left: 1rem; top: 1rem; }

/* ─── Layout ─── */
.container {
  width: min(calc(100% - var(--side-pad) * 2), var(--container));
  margin: 0 auto;
}
.content-narrow,
.narrow { max-width: var(--narrow); }
.section { padding: var(--space-xl) 0; }
.section-muted,
.section-soft { background: var(--surface-muted); }

/* ─── Header ─── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 60;
  background: rgba(255, 255, 255, 0.98);
  border-bottom: 1px solid var(--line);
}
.site-header.simple { position: relative; }
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  min-height: 76px;
  padding: 0 12px;
}
.brand-group {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.brand {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  color: var(--text);
  text-decoration: none;
  min-width: 0;
  margin-right: auto;
}
.brand-logo {
  display: block;
  height: auto;
  max-height: 46px;
  width: auto;
  max-width: 100%;
  object-fit: contain;
  object-position: left center;
}
.site-nav {
  display: none;
  flex-direction: column;
  align-items: start;
  position: absolute;
  top: calc(100% + 1px);
  right: var(--side-pad);
  left: var(--side-pad);
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.98);
  box-shadow: var(--shadow-lg);
  z-index: 50;
}
.site-nav.open { display: flex; }
.site-nav a {
  color: var(--text);
  text-decoration: none;
  font-size: var(--fs-ui);
  font-weight: 600;
  line-height: var(--lh-ui);
  padding: .5rem 0;
  min-height: 44px;
  display: flex;
  align-items: center;
}
.site-nav a:hover { color: var(--accent); }
.site-nav a.is-active { color: var(--accent); }
.nav-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  min-width: 44px;
  padding: .5rem 1rem;
  appearance: none;
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: 8px;
  font: inherit;
  font-size: 16px;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
  flex-shrink: 0;
}
.nav-toggle-label {
  pointer-events: none;
}
.header-cta { display: none; white-space: nowrap; }

/* ─── Buttons - Rijksoverheid-grade: clear, generous, accessible ─── */
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: 52px;
  padding: 0.9rem 1.85rem;
  border-radius: 6px;
  border: 2px solid transparent;
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.2;
  letter-spacing: var(--ls-ui);
  text-decoration: none;
  cursor: pointer;
  transition: background-color .15s ease, border-color .15s ease;
}
.button:hover { text-decoration: none; }
.button:focus-visible { outline: 3px solid rgba(138, 39, 53, .35); outline-offset: 3px; }
.button-primary {
  background: var(--accent);
  color: #fff;
}
.button-primary:hover { background: var(--accent-hover); color: #fff; }
.button-secondary {
  background: transparent;
  color: var(--text);
  border-color: var(--line);
}
.button-secondary:hover { border-color: var(--text-secondary); color: var(--text); background: var(--surface-muted); }
.button-xl {
  min-height: 58px;
  padding-inline: 2.25rem;
  font-size: 1.0625rem;
}

/* ─── Tertiary link ─── */
.tertiary-link {
  display: inline-flex;
  align-items: center;
  gap: 0.3em;
  font-weight: 600;
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  text-decoration: underline;
  text-decoration-thickness: .08em;
  text-underline-offset: .18em;
  margin-top: 16px;
}
.tertiary-link:hover { color: var(--accent); }
.tertiary-link.text-link { color: var(--link); }
.tertiary-link.text-link:hover { color: var(--link-hover); }

.mini-scan-link {
  color: var(--link);
  text-decoration: underline;
  text-decoration-color: var(--link);
  text-underline-offset: .18em;
  text-decoration-thickness: .08em;
  font-weight: 600;
}

.mini-scan-link:hover {
  color: var(--link-hover);
}

.cta-mini-scan-wrap,
.session-mini-scan-wrap,
.sticky-mini-scan-wrap,
.hero-scan-link-wrap {
  margin-top: 10px;
  margin-bottom: 0;
}

/* ─── Labels / Microcopy - clean government hierarchy ─── */
.eyebrow,
.section-label,
.price-label {
  margin: 0 0 var(--space-sm);
  text-transform: uppercase;
  letter-spacing: var(--ls-overline);
  font-size: var(--fs-overline);
  color: var(--text-secondary);
  font-weight: 700;
  line-height: var(--lh-ui);
}
.section-intro,
.price-sub,
.microcopy {
  color: var(--text-secondary);
  font-size: var(--fs-ui);
  line-height: var(--lh-body);
}

/* ─── Typography - government-grade readability ─── */
h1 {
  margin: 0 0 var(--space-heading-below-md);
  font-size: var(--fs-h1);
  font-weight: 800;
  line-height: 0.98;
  letter-spacing: var(--ls-tight);
  text-wrap: balance;
}
h2 {
  margin: 0 0 var(--space-heading-below-md);
  font-size: var(--fs-h2);
  font-weight: 800;
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-h);
  text-wrap: balance;
}
h3 {
  margin: 0 0 var(--space-heading-below-sm);
  font-size: var(--fs-h3);
  font-weight: 700;
  line-height: 1.18;
  letter-spacing: var(--ls-h);
}
p { margin: 0 0 var(--space-paragraph); max-inline-size: var(--measure-body); text-wrap: pretty; }
.section-head { margin-bottom: var(--space-lg); }

/* ─── Hero ─── */
.hero { padding: 36px 0 var(--space-lg); }
.hero-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-lg);
  align-items: start;
}
.hero-copy { align-self: center; }

/* Hero offer eyebrow */
.hero-offer-eyebrow {
  margin: 0 0 12px;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent);
  line-height: 1.2;
}

/* Hero doelgroep */
.hero-doelgroep {
  margin: 0 0 20px;
  font-size: 15px;
  font-weight: 500;
  color: var(--text-secondary);
  line-height: 1.3;
}

/* Hero H1 */
.hero h1 {
  font-size: clamp(1.65rem, 1.3rem + 1.2vw, 2.6rem);
  line-height: 1.15;
  margin: 0 0 24px;
}

.hero-lead {
  margin: 0 0 var(--space-md);
  font-size: 18px;
  font-weight: 400;
  color: var(--text);
  max-inline-size: var(--measure-lead);
  line-height: 1.55;
}

/* Hero proof line */
.hero-proof-line {
  margin: 0 0 var(--space-md);
  font-size: var(--fs-ui);
  font-weight: 600;
  color: var(--text-secondary);
  max-inline-size: var(--measure-lead);
  line-height: var(--lh-body);
}
.hero-proof-line a {
  color: var(--link);
  text-decoration: underline;
  text-underline-offset: .18em;
  text-decoration-thickness: .08em;
}
.hero-proof-line a:hover {
  color: var(--link-hover);
}

/* Hero USPs */
.hero-usps {
  list-style: none;
  margin: var(--space-sm) 0 var(--space-lg);
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.hero-usps li {
  font-size: 16px;
  line-height: 1.45;
  color: var(--text);
  padding-left: 1.6em;
  position: relative;
}
.hero-usps li::before {
  content: "→";
  position: absolute;
  left: 0;
  color: #27ae60;
  font-weight: 700;
}
.hero-usps li strong {
  font-weight: 700;
}

.hero-actions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 1rem;
  margin-top: var(--space-xs);
}
.hero .microcopy {
  margin-top: 14px;
}

/* Hero secondary CTA */
.hero-secondary-cta {
  margin: 12px 0 0;
  text-align: center;
}
.hero-actions .hero-secondary-cta {
  width: 100%;
  text-align: center;
}

/* Hero tertiary CTA */
.hero-tertiary-cta {
  margin: 12px 0 0;
  text-align: center;
}
.hero-tertiary-cta a {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-secondary);
  text-decoration: underline;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.18em;
}
.hero-tertiary-cta a:hover {
  color: var(--text);
}

/* Hero info strip */
.hero-info-strip {
  margin: 24px 0 0;
  font-size: 15px;
  font-weight: 600;
  color: var(--text-secondary);
  letter-spacing: 0.005em;
  line-height: 1.4;
  max-inline-size: none;
  white-space: nowrap;
}

/* Hero proof intro (replaces proofchips) */
.hero-proof-intro {
  margin: 14px 0 0;
  font-size: var(--fs-small);
  color: var(--text-secondary);
  max-inline-size: var(--measure-lead);
  line-height: var(--lh-body);
}
.hero-proof-intro strong {
  color: var(--accent);
  font-weight: 700;
}
.hero-proof-intro a {
  font-weight: 600;
}

/* Hero micropull (deprecated - now hero-info-strip) */
.hero-micropull {
  margin: 10px 0 0;
  font-size: var(--fs-small);
  font-weight: 600;
  color: var(--text-secondary);
  letter-spacing: var(--ls-label);
}

/* Hero support line (visible on all sizes, not just desktop) */
.hero-support {
  color: var(--text-secondary);
  font-size: var(--fs-ui);
  max-inline-size: var(--measure-lead);
  line-height: var(--lh-body);
  margin: 0 0 var(--space-sm);
}

/* Hero visual column */
.hero-visual-col {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

/* ─── Micro Praktisch Strip ─── */
.micro-praktisch {
  padding: 16px 0;
  background: var(--surface);
  border-bottom: 1px solid var(--line);
}
.micro-praktisch-inner {
  text-align: center;
}
.micro-praktisch-label {
  margin: 0 0 10px;
  font-size: var(--fs-overline);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--ls-overline);
  color: var(--text-secondary);
}
.micro-praktisch-chips {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
}
.micro-praktisch-chip {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 10px 10px;
  background: var(--bg);
  border-radius: var(--radius-sm);
  font-size: var(--fs-overline);
  color: var(--text-secondary);
  line-height: 1.3;
}
.mp-icon {
  width: 18px;
  height: 18px;
  color: var(--accent);
  margin-bottom: 2px;
  flex-shrink: 0;
}
.mp-chip-label {
  font-size: var(--fs-overline);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--ls-overline);
  color: var(--text-secondary);
  opacity: 0.7;
}
.mp-chip-sub {
  font-size: var(--fs-overline);
  color: var(--text-secondary);
}
.micro-praktisch-chip strong {
  font-size: var(--fs-ui);
  font-weight: 800;
  color: var(--text);
  letter-spacing: var(--ls-h);
  font-variant-numeric: tabular-nums lining-nums;
}

/* ─── Proofbar ─── */
.proofbar {
  background: var(--surface-muted);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.proofbar-inner {
  padding: 18px 0;
}
.proofbar-eyebrow {
  margin: 0 0 12px;
  text-align: center;
  font-size: var(--fs-overline);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--ls-overline);
  color: var(--text-secondary);
}
.proofbar-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--surface) 92%, var(--bg) 8%);
}
.proofbar-item {
  padding: 14px 14px 12px;
  margin: 0;
}
.proofbar-item:nth-child(odd) {
  border-right: 1px solid var(--line-soft);
}
.proofbar-item:nth-child(-n+2) {
  border-bottom: 1px solid var(--line-soft);
}
.proofbar-item-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
.proofbar-value {
  margin: 0;
  font-size: var(--fs-ui);
  font-weight: 700;
  line-height: 1.2;
  max-inline-size: none;
  color: var(--text);
}
.proofbar-label {
  margin: 0;
  font-size: var(--fs-overline);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--ls-overline);
  color: var(--text-secondary);
}
.proofbar-subcopy {
  margin: 5px 0 0;
  max-inline-size: none;
  font-size: var(--fs-small);
  line-height: var(--lh-body);
  color: var(--text-secondary);
}
.proofbar-source {
  margin: 4px 0 0;
  max-inline-size: none;
  font-size: var(--fs-overline);
  color: var(--text-muted);
}
.proofbar-item-link {
  color: inherit;
  text-decoration: none;
}
.proofbar-item-link:hover .proofbar-value {
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

/* ─── NEW Proof Section (replaces proofbar) ─── */
.proof-section {
  padding: var(--space-xl) 0;
  background: var(--surface-muted);
}
.proof-accent-label {
  margin: 0 0 10px;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent);
  line-height: 1.2;
}
.proof-heading {
  margin: 0 0 14px;
  font-size: var(--fs-h2);
  font-weight: 800;
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-h);
}
.proof-intro {
  margin: 0 0 36px;
  font-size: 1.05rem;
  line-height: 1.65;
  color: var(--text-secondary);
  max-width: 640px;
}
.proof-cards-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-bottom: 36px;
}
.proof-card {
  background: var(--surface);
  border-radius: var(--radius);
  padding: 26px;
  border: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.proof-card-icon {
  width: 36px;
  height: 36px;
  margin-bottom: 14px;
}
.proof-card-icon .icon {
  width: 26px;
  height: 26px;
  stroke: #888;
  stroke-width: 1.8;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.proof-card-metric {
  margin: 0 0 6px;
  font-size: 18px;
  font-weight: 800;
  color: var(--text);
  line-height: 1.25;
  max-inline-size: none;
}
.proof-card-label {
  margin: 0 0 10px;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent);
  line-height: 1.2;
  max-inline-size: none;
}
.proof-card-body {
  margin: 0;
  font-size: 16px;
  color: var(--text-secondary);
  line-height: 1.55;
  max-inline-size: none;
}
.proof-card-logo {
  position: absolute;
  bottom: 12px;
  right: 12px;
  width: 52px;
  height: auto;
  margin: 0;
  opacity: 0.3;
  filter: grayscale(1);
}
.proof-cta-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  margin-top: 8px;
}
.proof-cta-secondary {
  margin: 0;
}

/* ─── Pain / Herkenning list (legacy) ─── */
.pain-list {
  display: grid;
  gap: 1.15rem;
  margin-top: var(--space-lg);
}
.pain-list p {
  margin: 0;
  max-inline-size: var(--measure-body);
  padding-left: 20px;
  border-left: 3px solid var(--accent-soft);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
}
.section-closing {
  margin-top: var(--space-lg);
  font-weight: 800;
  font-size: var(--fs-h3);
  line-height: var(--lh-short);
  max-inline-size: var(--measure-body);
}

/* ─── NEW Herkenning Section - clean scannable cards ─── */
.herkenning-section {
  padding: var(--space-2xl) 0;
}
.herkenning-heading {
  margin: 0 0 14px;
  font-size: var(--fs-h2);
  font-weight: 800;
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-h);
}
.herkenning-intro {
  margin: 0 0 36px;
  font-size: 18px;
  color: var(--text-secondary);
  line-height: 1.5;
  max-inline-size: 56ch;
}
.herkenning-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-bottom: 36px;
}
.herkenning-card {
  position: relative;
  padding: 22px 22px 22px 58px;
  background: var(--surface);
  border-radius: var(--radius);
  border: 1px solid var(--line);
}
.herkenning-number {
  position: absolute;
  left: 18px;
  top: 22px;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #888;
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  border-radius: 50%;
  line-height: 1;
}
.herkenning-card-title {
  margin: 0 0 8px;
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.35;
}
.herkenning-card-body {
  margin: 0;
  font-size: 16px;
  color: var(--text-secondary);
  line-height: 1.55;
  max-inline-size: none;
}
.herkenning-punchline {
  margin: 0 0 28px;
  font-size: var(--fs-h3);
  line-height: var(--lh-short);
  max-inline-size: var(--measure-body);
}
.herkenning-punchline strong {
  font-weight: 800;
}
.herkenning-cta-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}
.herkenning-cta-secondary {
  margin: 0;
}
.herkenning-cta-tertiary {
  margin: 0;
}
.herkenning-cta-tertiary a {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-secondary);
  text-decoration: underline;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.18em;
}
.herkenning-cta-tertiary a:hover {
  color: var(--text);
}

/* ─── Contrast / False solutions grid ─── */
.contrast-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}
.contrast-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: var(--space-md);
}
.contrast-card h3 {
  font-size: var(--fs-body);
  font-weight: 700;
  margin-bottom: 8px;
}
.contrast-card p {
  margin: 0;
  max-inline-size: var(--measure-card);
  font-size: var(--fs-body);
  color: var(--text-secondary);
  line-height: var(--lh-body);
}
.contrast-card--highlight {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.contrast-card--highlight h3 { color: #fff; }
.contrast-card--highlight p { color: rgba(255,255,255,.85); }

/* ─── Bedrijfsritme bold line & dashboard line ─── */
.bedrijfsritme-bold {
  margin-top: var(--space-md);
  max-inline-size: var(--measure-body);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
}
.pillars-dashboard-line {
  margin-top: var(--space-md);
  text-align: center;
  font-size: var(--fs-small);
  color: var(--text-secondary);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* ─── Proof extra line ─── */
.proof-extra-line {
  margin-top: var(--space-md);
  max-inline-size: var(--measure-body);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
}

/* ─── Mini-case card (testimonials) ─── */
.mini-case-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: var(--space-md);
}
.mini-case-title {
  font-size: var(--fs-body);
  font-weight: 700;
  margin-bottom: var(--space-sm);
}
.mini-case-before,
.mini-case-after,
.mini-case-week1 {
  padding: var(--space-xs) 0;
  border-top: 1px solid var(--line);
}
.mini-case-label {
  font-size: var(--fs-overline);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent);
  margin-bottom: 4px;
}
.mini-case-before p:last-child,
.mini-case-after p:last-child,
.mini-case-week1 p:last-child {
  margin: 0;
  max-inline-size: var(--measure-card);
  font-size: var(--fs-body);
  color: var(--text-secondary);
  line-height: var(--lh-body);
}

/* ─── Split grid ─── */
.split-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-lg);
}
.split-grid.align-center { align-items: center; }
.split-head {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  align-items: end;
}
.split-head .section-intro { max-inline-size: var(--measure-body); }

/* ─── Portrait / Trainer ─── */
.portrait-card {
  margin: 0;
  overflow: hidden;
  border-radius: var(--radius);
  background: var(--surface);
}
.portrait-card img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  object-position: center 30%;
  aspect-ratio: 4 / 3;
}

/* ─── CMS image slots (hide when empty) ─── */
.cms-image-slot { display: none; }
.cms-image-slot.is-visible { display: block; }
.image-caption {
  font-size: 16px;
  color: var(--text);
  padding: 12px 4px 0;
  margin: 0;
  font-weight: 500;
  line-height: 1.45;
}
.image-caption:empty { display: none; }

/* ─── Hero image slot ─── */
.hero-image-slot {
  margin: 0;
  overflow: hidden;
  border-radius: var(--radius);
  background: var(--surface);
}
.hero-image-slot img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  object-position: center 20%;
  aspect-ratio: 3 / 4;
}

/* ─── Samir images wrapper ─── */
.samir-images {
  display: grid;
  gap: 16px;
}
.portrait-card-secondary {
  /* Hidden by default via .cms-image-slot */
}
.portrait-card-secondary img {
  aspect-ratio: 4 / 5;
  object-position: center center;
}

/* ─── Context image (group / session) ─── */
.context-image-section {
  padding: 0;
}
.context-image-card {
  margin: 0;
  overflow: hidden;
  border-radius: var(--radius);
  background: var(--surface);
}
.context-image-card img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  object-position: center center;
  aspect-ratio: 3 / 2;
}
/* ─── Authority section (Over Samir) - credible, clean ─── */
.authority-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 36px;
}
.authority-text-col {
  max-width: 34em;
}
.authority-headline {
  font-size: var(--fs-h3);
  line-height: 1.25;
  letter-spacing: var(--ls-h);
  margin-bottom: 0.6em;
}
.authority-lead {
  font-size: var(--fs-body);
  font-weight: 600;
  color: var(--text);
  margin-bottom: 1.5em;
  line-height: 1.6;
}
.authority-body {
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  margin-bottom: 1.4em;
  color: var(--text);
  max-inline-size: var(--measure-card);
}
.authority-litany {
  font-size: var(--fs-ui);
  line-height: 1.85;
  margin: 1.6em 0;
  padding-left: 18px;
  border-left: 3px solid var(--accent);
  color: var(--text);
  max-inline-size: var(--measure-card);
}
.authority-quote {
  margin: 1.4em 0 1em;
  padding: 20px 22px;
  background: var(--accent);
  color: #fff;
  border-left: none;
  border-radius: var(--radius-sm);
  font-size: var(--fs-body);
  font-weight: 700;
  font-style: italic;
  line-height: 1.55;
  position: relative;
}
.authority-quote p {
  margin: 0;
}
.authority-cta-block {
  margin-top: 1em;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}
.authority-microcopy {
  margin-top: 10px;
  font-size: var(--fs-small);
  color: var(--text-secondary);
  font-weight: 600;
}

/* Facts strip */
.samir-facts-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}
.samir-facts-desktop { display: none; }
.samir-facts-mobile { display: flex; margin-top: 0.8em; margin-bottom: 0.3em; }
.samir-fact {
  flex: 1;
  min-width: 90px;
  background: var(--surface);
  border-radius: var(--radius-sm);
  padding: 8px 10px;
  display: grid;
  gap: 2px;
}
.samir-fact-metric {
  font-size: var(--fs-small);
  font-weight: 900;
  letter-spacing: -0.02em;
  color: var(--accent);
  line-height: 1.2;
  font-variant-numeric: tabular-nums lining-nums;
}
.samir-fact-label {
  font-size: var(--fs-overline);
  font-weight: 600;
  color: var(--text-secondary);
}

/* Secondary portrait compact on mobile */
.portrait-card-secondary img {
  aspect-ratio: 16 / 9;
  max-height: 220px;
}

/* ─── Bullet card ─── */
.bullet-card {
  background: var(--surface);
  border-radius: var(--radius);
  padding: var(--space-md);
}
.feature-list,
.checklist {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 1rem;
}
.feature-list li,
.checklist li {
  position: relative;
  padding-left: 26px;
  max-inline-size: var(--measure-body);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
}
.feature-list li::before,
.checklist li::before {
  content: "•";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--accent);
  font-weight: 900;
}
.strong-line {
  margin-top: 20px;
  font-weight: 800;
  max-inline-size: var(--measure-body);
}

/* ─── Static cards (no hover, no pointer) ─── */
.static-card {
  cursor: default;
  user-select: auto;
}
.static-card:hover {
  transform: none;
}

/* ─── Metric grid / Proof grid ─── */
.metric-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-sm);
}
.metric-card {
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 20px;
}
.metric-card p { max-inline-size: var(--measure-card); font-size: var(--fs-small); color: var(--text-secondary); line-height: 1.55; }
.metric-bron {
  font-size: var(--fs-overline);
  color: var(--text-secondary);
  opacity: 0.7;
  margin-top: 8px;
  margin-bottom: 0;
  font-style: italic;
}
.metric {
  display: inline-block;
  margin-bottom: 8px;
  font-size: var(--fs-metric);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--accent);
  font-variant-numeric: tabular-nums lining-nums;
  line-height: 0.95;
}
.proof-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-sm);
  margin-top: var(--space-sm);
}
.proof-card {
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 20px;
  border-left: 3px solid var(--accent);
}
.proof-card .section-label { font-size: var(--fs-overline); }
.proof-hard {
  font-weight: 800;
  font-size: var(--fs-body);
  line-height: var(--lh-short);
}
.proof-card p:last-child {
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  margin-bottom: 0;
}
.proof-bron {
  font-size: var(--fs-overline);
  color: var(--text-secondary);
  opacity: 0.7;
  margin-top: 6px;
  margin-bottom: 0 !important;
  font-style: italic;
}

/* ─── Proof Compact (Audit/Trend/Mensen combined) ─── */
.proof-compact {
  margin-top: var(--space-md);
  background: var(--surface);
  border-radius: var(--radius);
  padding: 20px;
  border-left: 3px solid var(--accent);
}
.proof-compact-title {
  font-size: 1rem;
  font-weight: 800;
  margin: 0 0 14px;
  color: var(--text);
}
.proof-compact-items {
  display: grid;
  gap: 12px;
}
.proof-compact-item {
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line);
}
.proof-compact-item:last-child {
  padding-bottom: 0;
  border-bottom: none;
}
.proof-compact-label {
  font-size: var(--fs-overline);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--ls-overline);
  color: var(--accent);
  margin: 0 0 2px;
}
.proof-compact-text {
  font-size: var(--fs-ui);
  line-height: 1.55;
  color: var(--text-secondary);
  margin: 0;
  max-inline-size: var(--measure-body);
}
.proof-compact-text strong {
  color: var(--text);
}

/* ─── Proof Quotes (audit / MTO) ─── */
.proof-quotes {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}
.proof-quote-card {
  background: var(--surface);
  border-radius: var(--radius-sm);
  padding: 16px 18px;
  border-left: 3px solid var(--accent);
  margin: 0;
}
.proof-quote-card p {
  font-size: var(--fs-ui);
  line-height: 1.5;
  font-style: italic;
  margin: 0 0 6px;
  color: var(--text);
}
.proof-quote-bron {
  display: block;
  font-size: var(--fs-overline);
  color: var(--text-secondary);
  font-style: normal;
}

/* ─── Testimonials ─── */
.testimonial-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 32px;
}
.testimonial-card {
  background: var(--surface);
  border-radius: var(--radius);
  padding: 24px;
  border: 1px solid var(--line);
  margin: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.testimonial-card p {
  font-size: var(--fs-body);
  line-height: 1.55;
  margin: 0 0 16px;
  font-style: italic;
  max-width: none;
}
.testimonial-footer {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: var(--fs-small);
  color: var(--text-secondary);
}
.testimonial-footer strong { color: var(--text); }
.testimonial-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.testimonial-avatar[src=""],
.testimonial-avatar:not([src]) {
  display: none;
}
.testimonial-hide-mobile { display: none; }

/* ─── Testimonials v2 (twijfel → inzicht → resultaat) ─── */
.testimonial-grid-v2 {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
  margin-top: var(--space-lg);
}
.testimonial-card-v2 {
  background: var(--surface);
  border-radius: var(--radius);
  padding: var(--space-md);
  border: 1px solid var(--line);
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.testimonial-phase {
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
}
.testimonial-phase:last-of-type {
  border-bottom: none;
}
.testimonial-phase-label {
  font-size: var(--fs-overline);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--ls-overline);
  color: var(--accent);
  margin: 0 0 4px;
}
.testimonial-phase-text {
  font-size: var(--fs-ui);
  line-height: 1.5;
  margin: 0;
  color: var(--text);
}
/* Hide phases with empty text from CMS */
.testimonial-phase-text:empty { display: none; }
.testimonial-phase:has(.testimonial-phase-text:empty) { display: none; }

/* "De maandag erna" highlight */
.testimonial-phase--highlight {
  background: rgba(138, 39, 53, 0.06);
  border-radius: var(--radius-sm);
  padding: 14px 16px;
  margin-top: 4px;
  border-bottom: none;
  border-left: 3px solid var(--accent);
}
.testimonial-phase--highlight .testimonial-phase-label {
  color: var(--accent);
  font-size: var(--fs-overline);
}
.testimonial-phase--highlight .testimonial-phase-text {
  font-weight: 600;
  color: var(--text);
}

.testimonial-footer-v2 {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-top: 12px;
  margin-top: 4px;
  border-top: 1px solid var(--line);
  font-size: var(--fs-small);
  color: var(--text-secondary);
}
.testimonial-footer-v2 strong { color: var(--text); }
.testimonial-name:not(:empty) {
  display: block;
  font-weight: 700;
  color: var(--text);
  font-size: var(--fs-ui);
}
.testimonial-role {
  font-size: var(--fs-small);
  color: var(--text-secondary);
}
.testimonial-sep { margin: 0 2px; }

/* Featured testimonial (above pricing) */
.testimonial-featured {
  max-width: 720px;
  margin: 0 auto;
  border-left: 3px solid var(--accent);
  border-color: var(--accent);
}

.method-strip {
  margin-top: var(--space-md);
  padding: 18px 20px;
  background: var(--surface);
  border-radius: var(--radius-sm);
}
.method-strip h3 {
  margin-bottom: 10px;
}
.method-pillars {
  gap: 10px;
}

/* Empty state: if all phase texts are empty, show a placeholder */
.testimonial-card-v2:not(:has(.testimonial-phase-text:not(:empty))) {
  display: none;
}

/* ─── Audience cards - clear, contrasting, government-grade ─── */
.two-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-sm);
}
.audience-card {
  background: var(--surface);
  border-radius: var(--radius);
  border: 1px solid var(--line);
  padding: 24px;
}
.audience-card h3 { font-size: var(--fs-body); margin-bottom: 14px; }
.audience-card .checklist { gap: 0.75rem; }
.audience-card-neg {
  background: var(--accent-soft);
  border-color: transparent;
}
.audience-card-neg h3 { font-size: var(--fs-ui); }
.audience-card-neg .checklist li {
  font-size: var(--fs-ui);
  line-height: 1.55;
  color: var(--text-secondary);
}

/* ─── Pricing card ─── */
.pricing-card {
  padding: 28px 24px;
  background: var(--surface);
  box-shadow: var(--shadow-lg);
  border-radius: var(--radius);
  border: 1px solid rgba(138, 39, 53, 0.08);
}
.pricing-card p { max-inline-size: var(--measure-body); }
.pricing-top {
  margin-bottom: 20px;
}
.price {
  margin: 0;
  font-size: clamp(2.4rem, 6vw, 3.6rem);
  font-weight: 900;
  letter-spacing: -0.05em;
  line-height: 1;
  color: var(--text);
  font-variant-numeric: tabular-nums lining-nums;
}
.price-unit {
  font-size: var(--fs-body);
  color: var(--text-secondary);
  font-weight: 700;
  letter-spacing: 0;
}
.price-sub {
  margin: 4px 0 0;
  font-size: var(--fs-ui);
}
.price-tiers {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 16px;
  margin-bottom: 24px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--line);
}
.price-tier {
  margin: 0;
  font-size: var(--fs-small);
  color: var(--text-secondary);
  font-weight: 600;
  max-width: none;
}
.practical-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  margin: 16px 0;
}
.practical-list div {
  padding: 10px 0;
  border-top: 1px solid var(--line);
}
.practical-list dt {
  font-weight: 800;
  font-size: var(--fs-overline);
  text-transform: uppercase;
  letter-spacing: var(--ls-overline);
  color: var(--accent);
}
.practical-list dd {
  margin: 2px 0 0;
  color: var(--text);
  font-size: var(--fs-ui);
  font-weight: 600;
}
.pricing-extra {
  margin-top: var(--space-md);
  padding: var(--space-md);
  background: var(--surface-muted);
  border-radius: var(--radius-sm);
  font-weight: 600;
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  font-style: italic;
  max-inline-size: var(--measure-body);
}

/* ─── Private directiesessie link (below pricing) ─── */
.private-session-link {
  margin-top: var(--space-md);
  font-size: var(--fs-ui);
  color: var(--text-secondary);
}
.private-session-link a {
  color: var(--link);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}
.private-session-link a:hover {
  color: var(--link-hover);
}

/* ─── Private session card (thank-you page) ─── */
.private-session-card {
  margin-top: var(--space-lg);
  padding: var(--space-md);
  background: var(--surface-muted);
  border-radius: var(--radius-sm);
  border-left: 3px solid var(--accent);
  font-size: var(--fs-ui);
  color: var(--text-secondary);
}
.private-session-card-title {
  font-weight: 700;
  color: var(--text);
  margin-bottom: 4px;
}
.private-session-card .tertiary-link {
  margin-top: 8px;
  font-size: var(--fs-ui);
}

/* ─── FAQ - clean, spacious, Rijksoverheid-level ─── */
.faq-list {
  display: grid;
  gap: 12px;
}
details {
  background: var(--surface);
  border-radius: var(--radius-sm);
  border: 1px solid var(--line);
  overflow: hidden;
}
details[open] {
  border-color: var(--line);
}
summary {
  cursor: pointer;
  font-weight: 700;
  font-size: clamp(1.0625rem, 1.02rem + 0.18vw, 1.1875rem);
  line-height: 1.35;
  list-style: none;
  padding: 18px 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-height: 54px;
  -webkit-tap-highlight-color: transparent;
  transition: background-color .15s ease;
}
summary:hover { background: rgba(0,0,0,.015); }
summary:focus-visible { outline: 3px solid rgba(138, 39, 53, .2); outline-offset: -3px; }
summary::-webkit-details-marker { display: none; }
summary::after {
  content: "+";
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--surface-muted);
  color: var(--accent);
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1;
}
details[open] summary::after { content: "\2212"; }
details[open] summary { padding-bottom: 12px; }
details p {
  margin: 0;
  padding: 0 22px 20px;
  color: var(--text-secondary);
  max-inline-size: var(--measure-faq);
  font-size: clamp(1rem, 0.97rem + 0.10vw, 1.0625rem);
  line-height: var(--lh-body);
}

/* ─── Final CTA - clean dark trust block ─── */
.final-cta {
  background: #1a1614;
  color: #fff;
}
.final-cta .section-label { color: rgba(255,255,255,.55); }
.final-cta p { color: rgba(255,255,255,.78); }
.final-cta h2 { color: #fff; }
.final-cta .microcopy { color: rgba(255,255,255,.55); }
.final-cta-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-lg);
}
.trust-card {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: var(--radius);
  padding: 28px;
}
.trust-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 14px;
}
.trust-list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: var(--fs-ui);
  font-weight: 600;
  color: rgba(255,255,255,.82);
  line-height: 1.45;
}
.trust-list .icon {
  width: 18px;
  height: 18px;
  color: rgba(255,255,255,.65);
  opacity: 1;
}
@media (min-width: 768px) {
  .trust-list .icon {
    width: 20px;
    height: 20px;
  }
}
.trust-list li::before {
  content: none;
}

/* ─── Newsletter section - trustworthy, clean ─── */
.newsletter-section {
  background: var(--surface);
  color: var(--text-secondary);
}
.newsletter-section h2 {
  color: var(--text);
  font-size: var(--fs-h2);
}
.newsletter-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
}
.newsletter-teasers {
  margin: 0 0 18px;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}
.newsletter-teasers li {
  position: relative;
  padding-left: 16px;
  font-size: var(--fs-small);
  color: var(--text-secondary);
  line-height: 1.55;
}
.newsletter-teasers li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.5em;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--line);
}
.newsletter-form {
  padding: 28px;
  background: #fff;
  border: 1px solid var(--line-soft);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.newsletter-form label {
  display: grid;
  gap: 8px;
  margin-bottom: 14px;
}
.newsletter-form span {
  font-weight: 700;
  font-size: var(--fs-ui);
}
.newsletter-submit {
  width: 100%;
  background: transparent;
  color: var(--text-secondary);
  border: 1px solid var(--line);
  min-height: 52px;
  font-size: 1rem;
}
.newsletter-submit:hover {
  background: var(--surface-muted);
  color: var(--text);
  border-color: var(--text-secondary);
}
.newsletter-microcopy {
  color: var(--text-secondary);
  font-size: var(--fs-small);
  margin-top: 12px;
  margin-bottom: 0;
  max-width: none;
  line-height: 1.55;
}

/* ─── Inputs - WCAG accessible, clear focus states ─── */
input,
select,
textarea {
  width: 100%;
  min-height: 50px;
  padding: 0.8rem 1rem;
  border-radius: var(--radius-sm);
  border: 2px solid var(--line);
  background: #fff;
  font: inherit;
  color: var(--text);
  font-size: 1rem;
  transition: border-color .15s ease, box-shadow .15s ease;
}
input:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(138, 39, 53, .12);
}
.newsletter-form input {
  background: #fff;
  border-color: var(--line);
  color: var(--text);
}
.newsletter-form input::placeholder { color: #8e857d; }
.newsletter-form input:focus {
  background: #fff;
  border-color: var(--accent);
  outline-color: rgba(138, 39, 53, .15);
}

/* ─── Footer - clean, government-level ─── */
.site-footer {
  padding: 36px 0;
  background: #1B1B1B;
  color: rgba(255,255,255,.65);
}
.footer-bottom {
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
  font-size: var(--fs-ui);
  font-weight: 400;
  line-height: 1.55;
}
.footer-bottom p { max-width: none; margin: 0; }
.footer-bottom a { color: rgba(255,255,255,.78); }
.footer-bottom a:hover { color: #fff; }
.footer-bottom nav { display: flex; flex-wrap: wrap; gap: 0.8rem 1rem; }
.cookie-settings-trigger {
  appearance: none;
  border: 0;
  background: transparent;
  padding: 0;
  font: inherit;
  cursor: pointer;
}
.site-footer .cookie-settings-trigger {
  color: rgba(255,255,255,.8);
}
.site-footer .cookie-settings-trigger:hover {
  color: #fff;
}
.cookie-settings-trigger:focus-visible {
  outline: 3px solid rgba(138, 39, 53, .25);
  outline-offset: 2px;
  border-radius: 4px;
}

/* ─── Cookie consent ─── */
#zi-cookie-root {
  position: relative;
  z-index: 9999;
}
.zi-cookie-banner {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 0 var(--side-pad) calc(env(safe-area-inset-bottom, 0px) + 12px);
  pointer-events: none;
}
.zi-cookie-sheet {
  pointer-events: auto;
  width: min(100%, 560px);
  margin: 0 auto;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--surface);
  box-shadow: var(--shadow-lg);
  padding: 1rem;
  position: relative;
}
.zi-cookie-title {
  margin: 0 2.5rem .5rem 0;
  font-size: 1.0625rem;
}
.zi-cookie-body {
  margin: 0 0 .65rem;
  color: var(--text-secondary);
  font-size: .95rem;
}
.zi-cookie-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}
.zi-cookie-btn {
  min-height: 44px;
  padding: .65rem 1rem;
  flex: 1 1 180px;
}
.zi-cookie-banner-close {
  position: absolute;
  top: .65rem;
  right: .65rem;
}
.zi-cookie-policy-link {
  display: inline-block;
  margin-top: .55rem;
  font-size: .9rem;
}
.zi-cookie-banner[hidden],
.zi-cookie-modal-overlay[hidden] {
  display: none !important;
}
.zi-cookie-modal-overlay {
  position: fixed;
  inset: 0;
  padding: 1rem;
  background: rgba(0, 0, 0, .35);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  z-index: 9999;
}
.zi-cookie-modal {
  width: min(100%, 560px);
  max-height: min(82vh, 700px);
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--surface);
  box-shadow: var(--shadow-lg);
  padding: 1rem;
}
.zi-cookie-modal-head {
  display: flex;
  justify-content: space-between;
  gap: .75rem;
}
.zi-cookie-modal-title {
  margin: 0;
  font-size: 1.125rem;
}
.zi-cookie-close {
  appearance: none;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--text);
  min-height: 36px;
  min-width: 36px;
  border-radius: 999px;
  cursor: pointer;
  font: inherit;
  font-size: 1.3rem;
  line-height: 1;
}
.zi-cookie-modal-intro {
  margin: .75rem 0 1rem;
  color: var(--text-secondary);
  font-size: .95rem;
}
.zi-cookie-categories {
  display: grid;
  gap: .6rem;
}
.zi-cookie-category {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  padding: .8rem;
  display: flex;
  justify-content: space-between;
  gap: .8rem;
}
.zi-cookie-category-disabled {
  opacity: .68;
}
.zi-cookie-category-title {
  margin: 0;
  font-size: .98rem;
}
.zi-cookie-category-body {
  margin: .35rem 0 0;
  color: var(--text-secondary);
  font-size: .9rem;
}
.zi-cookie-toggle-wrap {
  align-self: center;
}
.zi-cookie-always-on {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: .25rem .6rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--text-secondary);
  font-size: .8rem;
  font-weight: 600;
}
.zi-cookie-switch {
  position: relative;
  display: inline-flex;
  width: 48px;
  height: 28px;
}
.zi-cookie-switch input {
  opacity: 0;
  width: 0;
  height: 0;
}
.zi-cookie-slider {
  position: absolute;
  inset: 0;
  background: var(--surface-muted);
  border: 1px solid var(--line);
  border-radius: 999px;
  transition: background-color .2s ease;
}
.zi-cookie-slider::before {
  content: "";
  position: absolute;
  height: 20px;
  width: 20px;
  left: 3px;
  top: 3px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .25);
  transition: transform .2s ease;
}
.zi-cookie-switch input:checked + .zi-cookie-slider {
  background: var(--accent-soft);
}
.zi-cookie-switch input:checked + .zi-cookie-slider::before {
  transform: translateX(20px);
}
.zi-cookie-switch input:focus-visible + .zi-cookie-slider,
.zi-cookie-close:focus-visible {
  outline: 3px solid rgba(138, 39, 53, .25);
  outline-offset: 2px;
}
.zi-cookie-withdraw-note {
  margin: .9rem 0 0;
  padding: .75rem;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  color: var(--text-secondary);
  font-size: .9rem;
}
.zi-cookie-actions-modal {
  margin-top: .9rem;
}
.zi-cookie-footer-note {
  margin: .75rem 0 0;
  color: var(--text-secondary);
  font-size: .85rem;
}
@media (max-width: 640px) {
  .zi-cookie-btn {
    flex-basis: 100%;
  }
}
body.zi-cookie-modal-open {
  overflow: hidden;
}
/* ─── Sticky CTA ─── */
.sticky-cta-bar {
  display: none;
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 70;
  padding: 14px var(--side-pad) calc(env(safe-area-inset-bottom, 0px) + 14px);
  background: rgba(255, 255, 255, 0.98);
  border-top: 1px solid var(--line);
  text-align: center;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .3s ease, transform .3s ease;
  pointer-events: none;
}
.sticky-cta-bar.is-visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.sticky-cta-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 50px;
  border-radius: 6px;
  background: var(--accent);
  color: #fff;
  font-weight: 700;
  font-size: var(--fs-body);
  line-height: 1.2;
  text-decoration: none;
}
.sticky-cta-btn:hover {
  background: var(--accent-hover);
  color: #fff;
  text-decoration: none;
}
.sticky-cta-btn:focus-visible {
  outline: 3px solid rgba(138, 39, 53, .35);
  outline-offset: 3px;
}
.sticky-cta-link {
  display: block;
  margin-top: 6px;
  font-size: var(--fs-overline);
  color: var(--text-secondary);
  text-decoration: underline;
  text-underline-offset: .15em;
}
.sticky-cta-link:hover {
  color: var(--text);
}
body.keyboard-open .sticky-cta-bar {
  opacity: 0 !important;
  pointer-events: none !important;
}

/* ─── Form pages shared ─── */
.form-card {
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 24px;
}
.form-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
.form-grid .span-2 { grid-column: 1 / -1; }
.checkbox-row {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: 12px;
  margin: 16px 0 24px;
}
.checkbox-row input {
  width: 20px;
  min-height: auto;
  margin-top: 4px;
}
.form-card .button { width: fit-content; }
.form-microcopy {
  margin-top: 12px;
  font-size: var(--fs-small);
  color: var(--text-secondary);
}

/* ─── Thank you pages ─── */
.thankyou-page {
  padding: 48px 0 64px;
  min-height: 60vh;
}
.thankyou-card {
  max-width: 600px;
  text-align: left;
  padding: 0 20px;
}

/* Success icon */
.thankyou-success-icon {
  color: #16a34a;
  margin-bottom: 16px;
}
.thankyou-lead {
  font-size: var(--fs-body);
  color: var(--text-secondary);
  margin-bottom: 28px;
  line-height: 1.6;
}

/* Summary card */
.thankyou-summary {
  background: var(--surface-muted);
  border-radius: var(--radius);
  padding: 20px 24px;
  margin-bottom: 28px;
}
.thankyou-summary-title {
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 14px;
  font-size: var(--fs-overline);
}
.thankyou-summary-list {
  display: grid;
  gap: 10px;
  margin: 0;
}
.thankyou-summary-list div {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 8px;
}
.thankyou-summary-list dt {
  font-size: var(--fs-small);
  font-weight: 600;
  color: var(--text-secondary);
}
.thankyou-summary-list dd {
  margin: 0;
  font-size: var(--fs-ui);
  color: var(--text);
}

/* Timeline */
.thankyou-timeline {
  margin-bottom: 28px;
}
.thankyou-timeline-title {
  font-size: var(--fs-body);
  font-weight: 700;
  margin: 0 0 14px;
}
.thankyou-steps {
  margin: 0;
  padding-left: 0;
  list-style: none;
  counter-reset: step;
}
.thankyou-steps li {
  counter-increment: step;
  display: grid;
  grid-template-columns: 1fr;
  gap: 2px;
  padding: 12px 0 12px 36px;
  position: relative;
  border-left: 2px solid var(--line);
  margin-left: 12px;
  font-size: var(--fs-ui);
  line-height: 1.5;
}
.thankyou-steps li::before {
  content: counter(step);
  position: absolute;
  left: -13px;
  top: 10px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}
.thankyou-steps li strong {
  font-size: var(--fs-ui);
  font-weight: 700;
  color: var(--text);
}
.thankyou-steps li span {
  color: var(--text-secondary);
  font-size: var(--fs-small);
}

/* Notes */
.thankyou-notes {
  margin-bottom: 24px;
}
.thankyou-notes-title {
  font-size: var(--fs-ui);
  font-weight: 700;
  margin: 0 0 10px;
}
.thankyou-notes-list {
  margin: 0;
  padding-left: 1.2rem;
  font-size: var(--fs-small);
  color: var(--text-secondary);
  line-height: 1.7;
}

/* Contact */
.thankyou-contact {
  margin-bottom: 28px;
  font-size: var(--fs-ui);
  color: var(--text-secondary);
}
.thankyou-contact a {
  color: var(--link);
  font-weight: 600;
}

/* Actions */
.thankyou-actions {
  margin-bottom: 32px;
}
.thankyou-secondary {
  border-top: 1px solid var(--line);
  padding-top: 24px;
}
.thankyou-card p { margin-inline: 0; }
.page-main .section,
.page-hero { padding: 60px 0; }

/* ─── Legal page ─── */
.legal-page {
  padding: 36px 0 60px;
}
.legal-card {
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 28px 22px;
  max-width: 900px;
}
.legal-card--wide {
  width: min(100%, 900px);
}
.legal-card h1 {
  margin-top: 0;
  margin-bottom: 14px;
}
.legal-intro {
  margin: 0 0 24px;
  color: var(--text-secondary);
  line-height: 1.6;
}
.legal-toc {
  margin: 0 0 30px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: #fff;
}
.legal-toc-title {
  margin: 0 0 8px;
  font-size: 1.05rem;
}
.legal-toc ol {
  margin: 0;
  padding-left: 1.2rem;
  columns: 1;
}
.legal-toc li {
  margin: 4px 0;
}
.legal-section {
  margin-bottom: 24px;
}
.legal-section h2 {
  margin: 0 0 10px;
  font-size: clamp(1.02rem, 2.4vw, 1.24rem);
}
.legal-richtext p {
  margin: 0 0 10px;
  line-height: 1.62;
}
.legal-richtext ul {
  margin: 8px 0 12px;
  padding-left: 1.2rem;
}
.legal-richtext li {
  margin-bottom: 6px;
  line-height: 1.55;
}
.legal-updated {
  margin: 26px 0 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  font-size: var(--fs-ui);
}
.legal-cta-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
}

/* ─── Quiz / Quickscan - Stepper ─── */
.quiz-stepper {
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 28px 24px;
}
.quiz-progress {
  height: 6px;
  background: var(--surface-muted, #eee);
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 8px;
}
.quiz-progress-bar {
  height: 100%;
  background: var(--accent);
  border-radius: 3px;
  transition: width .3s ease;
}
.quiz-progress-label {
  font-size: var(--fs-small, .85rem);
  color: var(--text-secondary);
  margin-bottom: 24px;
}
.quiz-step {
  display: none;
}
.quiz-step.active {
  display: block;
  animation: quizFadeIn .25s ease;
}
@keyframes quizFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
.quiz-form-stepper fieldset {
  margin: 0;
  padding: 0;
  border: none;
}
.quiz-form-stepper legend {
  font-weight: 800;
  font-size: clamp(1rem, 2.5vw, 1.15rem);
  line-height: 1.4;
  margin-bottom: 20px;
}
.quiz-form-stepper fieldset label {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: .8rem;
  margin-top: 8px;
  padding: 12px 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm, 10px);
  cursor: pointer;
  transition: background-color .15s ease, border-color .15s ease;
}
.quiz-form-stepper fieldset label:hover {
  background: var(--surface-muted);
  border-color: rgba(138, 39, 53, 0.15);
}
.quiz-form-stepper fieldset input {
  width: 20px;
  height: 20px;
  min-height: auto;
  accent-color: var(--accent);
}
.quiz-form-stepper fieldset input:checked + span { font-weight: 700; }
.quiz-form-stepper fieldset label:has(input:checked) {
  background: var(--accent-soft);
  border-color: var(--accent);
}
.quiz-field-error {
  animation: quizShake .4s ease;
}
.quiz-field-error label {
  border-color: #c0392b !important;
}
@keyframes quizShake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-4px); }
  75% { transform: translateX(4px); }
}
.quiz-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 24px;
  gap: 12px;
}
.quiz-stepper.hidden { display: none; }

/* ─── Result card ─── */
.result-card {
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  margin-top: 28px;
  padding: 28px 24px;
  text-align: center;
}
.result-card h2 { color: var(--accent); }
.result-score-badge {
  display: inline-block;
  background: var(--accent-soft);
  color: var(--accent);
  font-size: 1.6rem;
  font-weight: 800;
  padding: 12px 24px;
  border-radius: var(--radius-sm, 10px);
  margin-bottom: 16px;
}
.result-cta-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
  margin-top: 20px;
}
@media (min-width: 480px) {
  .result-cta-list {
    flex-direction: row;
    justify-content: center;
  }
}

/* ─── Follow-up form card ─── */
.followup-form-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 28px 24px;
  margin-top: 24px;
}
.followup-form-card h3 {
  margin: 0 0 4px;
}
.followup-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin: 20px 0;
}
@media (min-width: 600px) {
  .followup-grid {
    grid-template-columns: 1fr 1fr;
  }
  .followup-grid .span-full { grid-column: 1 / -1; }
}
.followup-label span {
  display: block;
  font-size: var(--fs-small, .85rem);
  font-weight: 600;
  margin-bottom: 4px;
}
.followup-label input,
.followup-label select {
  width: 100%;
}
.followup-thankyou { margin-top: 24px; }
.followup-thankyou-inner {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 32px 24px;
  text-align: center;
}
.followup-thankyou-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--accent-soft);
  color: var(--accent);
  font-size: 1.4rem;
  font-weight: 700;
  margin: 0 auto 16px;
}

/* ─── Blue text links ─── */
.text-link {
  color: var(--link);
  text-decoration: underline;
  text-decoration-thickness: .08em;
  text-underline-offset: .16em;
}
.text-link:hover { color: var(--link-hover); }

/* Footer text links */
.footer-bottom nav a,
.footer-bottom nav .cookie-settings-trigger { text-decoration: underline; }
.site-footer .text-link { color: rgba(255,255,255,.8); }
.site-footer .text-link:hover { color: #fff; }

/* Inline content links */
.pricing-extra a,
.newsletter-microcopy a,
.microcopy a { color: var(--link); }
.pricing-extra a:hover,
.newsletter-microcopy a:hover,
.microcopy a:hover { color: var(--link-hover); }

/* ─── CMS Rich Text Style Variants ─── */
/* Quote variant - styled blockquote from rich text fields */
blockquote, .cms-quote {
  border-left: 3px solid var(--accent, #8A2735);
  margin: 1.25em 0;
  padding: .75em 1.25em;
  font-style: italic;
  color: var(--text-secondary, #555);
  background: rgba(138,39,53,.03);
  border-radius: 0 var(--radius, 6px) var(--radius, 6px) 0;
}
blockquote p:last-child, .cms-quote p:last-child { margin-bottom: 0; }

/* Meta variant - small muted text for dates, sources, labels */
.cms-meta, small, .text-meta {
  font-size: .8125rem;
  color: var(--text-muted, #888);
  letter-spacing: .01em;
}

/* Accent variant - highlighted words/phrases in brand color */
.cms-accent, mark.cms-accent {
  color: var(--accent, #8A2735);
  background: transparent;
  font-weight: 600;
}

/* Muted variant - dimmed text for disclaimers and footnotes */
.cms-muted {
  color: var(--text-muted, #888);
  font-size: .875rem;
}

/* Highlight variant - soft background highlight for key phrases */
mark, .cms-highlight {
  background: rgba(138,39,53,.08);
  color: inherit;
  padding: .1em .3em;
  border-radius: 3px;
}

/* Rich text inline styles */
[data-cms] ul, [data-cms] ol { margin: .75em 0; padding-left: 1.5em; }
[data-cms] li { margin-bottom: .35em; }
[data-cms] a { color: var(--link, #8A2735); text-decoration: underline; }
[data-cms] a:hover { color: var(--link-hover, #6b1f2a); }

/* ─── Session cards ─── */
.session-card {
  background: var(--surface);
  border-radius: var(--radius);
}
.session-card--featured {
  padding: 30px 26px;
  box-shadow: var(--shadow-lg);
  border: 2px solid rgba(138, 39, 53, 0.10);
  background: var(--surface);
  border-radius: var(--radius);
}
.session-card--featured .pricing-top { margin-bottom: 16px; }
.session-card--featured .practical-list { margin: 16px 0; }
.session-card--featured .session-availability-row { margin-bottom: 20px; }
.session-card--featured .button { width: 100%; }
.session-card--featured p { max-inline-size: var(--measure-card); }

.price-tier-line {
  margin: 0 0 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--line);
  font-size: var(--fs-small);
  color: var(--text-secondary);
  font-weight: 600;
  max-width: none;
}

.session-card--next {
  padding: 24px;
}
.session-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.session-card-header h4 {
  margin: 0;
  font-size: var(--fs-body);
  font-weight: 700;
}
.session-card-details {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 16px;
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  margin-bottom: 16px;
}
.session-card--next .button {
  width: 100%;
}

/* Availability badges */
.session-availability {
  font-size: var(--fs-ui);
  font-weight: 600;
  color: var(--text-secondary);
}
.session-availability--warning {
  font-size: var(--fs-ui);
  font-weight: 700;
  color: #B45309;
}
.session-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  border-radius: 999px;
  font-size: var(--fs-overline);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.session-badge--soldout {
  background: var(--accent-soft);
  color: var(--accent);
}
.session-badge--completed {
  background: var(--surface-muted);
  color: var(--text-secondary);
}

/* Next sessions section */
.next-sessions-wrapper { margin-top: 24px; }
.next-sessions-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  gap: 0.4em;
  padding: 14px 20px;
  background: transparent;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  font: inherit;
  font-weight: 700;
  font-size: var(--fs-ui);
  color: var(--link);
  cursor: pointer;
  transition: border-color .15s ease, background .15s ease;
  text-decoration: none;
}
.next-sessions-toggle:hover {
  border-color: var(--link);
  background: rgba(29, 78, 216, 0.04);
}
.next-sessions-toggle::after {
  content: "↓";
  font-size: 0.9em;
  transition: transform .2s ease;
}
.next-sessions-toggle[aria-expanded="true"]::after {
  transform: rotate(180deg);
}
.next-sessions-list {
  display: none;
  gap: 12px;
  margin-top: 12px;
}

/* Past sessions section */
.past-sessions-wrapper { margin-top: 48px; }
.past-sessions-title {
  font-size: var(--fs-ui);
  font-weight: 700;
  margin: 0 0 12px;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.past-sessions-list {
  display: grid;
  gap: 8px;
}
.session-card--past {
  padding: 14px 20px;
  background: transparent;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
}
.session-card--past .session-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 0;
}
.past-session-date {
  font-size: var(--fs-ui);
  font-weight: 600;
  color: var(--text-secondary);
}
.session-card--past .session-card-details {
  margin-top: 4px;
  margin-bottom: 0;
  font-size: var(--fs-small);
  color: var(--text-secondary);
  opacity: 0.8;
}
.past-session-capacity {
  font-variant-numeric: tabular-nums;
}
.session-card--past .session-badge {
  font-size: var(--fs-overline);
  padding: 2px 8px;
}

/* Testimonial context line */
.testimonial-context {
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  font-style: italic;
  margin: -8px 0 24px;
  max-width: 38em;
}

/* Waitlist block */
.waitlist-block {
  text-align: center;
  margin-top: 12px;
}
.waitlist-block--compact {
  margin-top: 8px;
}
.waitlist-subtitle {
  font-size: var(--fs-small);
  color: var(--text-secondary);
  margin: 8px 0 0;
  font-style: italic;
}

/* ═══════════════════════════════════════════
   DESKTOP (min-width: 860px)
   ═══════════════════════════════════════════ */
@media (min-width: 860px) {
  :root {
    --side-pad: 40px;
    --space-2xl: 120px;
  }

  /* Desktop body line-height */
  body { line-height: var(--lh-body-wide); }

  .section { padding: var(--space-section-y-desktop) 0; }
  .hero { padding: 3.5rem 0 var(--space-section-y-desktop); }

  /* Header */
  .header-inner { min-height: 88px; gap: 1rem; padding: 0; }
  .brand { max-width: 340px; margin-right: auto; }
  .brand-logo { max-height: 56px; }

  /* Proofbar (legacy) */
  .proofbar-inner { padding: 20px 0; }
  .proofbar-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .proofbar-item {
    padding: 16px 16px 14px;
    border-bottom: 0;
    border-right: 1px solid var(--line-soft);
  }
  .proofbar-item:nth-child(odd) {
    border-right: 1px solid var(--line-soft);
  }
  .proofbar-item:nth-child(-n+2) {
    border-bottom: 0;
  }
  .proofbar-item:last-child {
    border-right: 0;
  }

  /* NEW Proof section desktop */
  .proof-cards-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 22px;
  }
  .proof-card {
    padding: 30px;
  }
  .proof-card-metric {
    font-size: 19px;
  }
  .proof-cta-row {
    flex-direction: row;
    gap: 24px;
    justify-content: flex-start;
  }

  /* Micro praktisch strip: horizontal on desktop */
  .micro-praktisch { padding: 18px 0; }
  .micro-praktisch-inner { display: flex; align-items: center; gap: 16px; }
  .micro-praktisch-label { margin: 0; white-space: nowrap; }
  .micro-praktisch-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    grid-template-columns: none;
  }
  .micro-praktisch-chip {
    flex-direction: row;
    gap: 6px;
    padding: 8px 16px;
    border-radius: 999px;
    font-size: var(--fs-small);
  }
  .mp-icon { width: 16px; height: 16px; margin-bottom: 0; }
  .mp-chip-label { display: none; }
  .mp-chip-sub { font-size: var(--fs-overline); }
  .micro-praktisch-chip strong { font-size: var(--fs-ui); }
  .nav-toggle { display: none; }
  .site-nav {
    display: flex;
    flex-direction: row;
    position: static;
    padding: 0;
    border: none;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    gap: 1.35rem;
  }
  .header-cta { display: inline-flex; }

  /* Hero */
  .hero { padding: 3.5rem 0 var(--space-section-y-desktop); }
  .hero-grid {
    grid-template-columns: minmax(0, 1.1fr) minmax(260px, 0.55fr);
    gap: 60px;
  }
  .hero h1 { font-size: clamp(2.2rem, 1.8rem + 0.8vw, 2.6rem); margin-bottom: 28px; }
  .hero-offer-eyebrow { font-size: 14px; }
  .hero-doelgroep { font-size: 16px; }
  .hero-lead { font-size: var(--fs-lead); max-inline-size: 58ch; margin-bottom: var(--space-md); }
  .hero-actions {
    flex-direction: column;
    align-items: flex-start;
    margin-top: var(--space-xs);
    width: fit-content;
  }
  .hero-actions .button-xl { width: 100%; }
  .hero-secondary-cta { text-align: left; margin: 0; }
  .hero-tertiary-cta { text-align: left; }
  .hero-info-strip { font-size: 15px; }

  /* Herkenning desktop */
  .herkenning-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
  .herkenning-cta-row {
    flex-direction: row;
    gap: 24px;
    justify-content: flex-start;
    align-items: center;
  }
  .herkenning-cta-tertiary {
    margin: 0;
  }

  /* Hero visual col */
  .hero-visual-col {
    flex-direction: column;
    gap: 16px;
    padding-top: 0;
  }

  /* Micro praktisch: horizontal on desktop */

  /* Buttons */
  .button { min-height: 56px; }
  .button-xl { min-height: 64px; font-size: 1.0625rem; padding-inline: 2.5rem; }

  /* Split grid */
  .split-grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, .9fr);
    gap: 48px;
  }
  .split-head {
    grid-template-columns: minmax(0, 1fr) minmax(0, .86fr);
    gap: 28px;
  }

  /* Trainer / Authority */
  .portrait-card img { aspect-ratio: 3 / 4; }
  .portrait-card-secondary img { aspect-ratio: 3 / 2; max-height: none; }
  .hero-image-slot img { aspect-ratio: 3 / 4; }
  .context-image-card img { aspect-ratio: 16 / 9; }
  .authority-grid {
    grid-template-columns: minmax(0, .85fr) minmax(0, 1.15fr);
    gap: 60px;
    align-items: start;
  }
  .authority-text-col { max-width: 33em; }
  .authority-headline { font-size: var(--fs-h3); }
  .authority-lead { font-size: var(--fs-body); }
  .authority-body { font-size: var(--fs-body); margin-bottom: 1.3em; }
  .authority-litany { font-size: var(--fs-ui); margin: 1.5em 0; }
  .authority-quote { font-size: var(--fs-lead); padding: 26px 30px; margin: 1.5em 0 1em; }
  .samir-facts-desktop { display: flex; }
  .samir-facts-mobile { display: none; }

  /* Bullet card */
  .bullet-card { padding: 36px; }

  /* Contrast grid */
  .contrast-grid { grid-template-columns: repeat(4, 1fr); gap: 20px; }

  /* Value blocks */
  .value-blocks { grid-template-columns: repeat(3, 1fr); gap: 20px; }

  /* Pillars grid */
  .pillars-grid { grid-template-columns: repeat(5, 1fr); gap: 16px; }

  /* Testimonials flow */
  .testimonials-flow { grid-template-columns: 1fr 1fr; gap: 24px; }
  .case-card-featured { grid-column: 1 / -1; }

  /* Mini-case card */
  .mini-case-card { grid-column: 1 / -1; display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--space-sm); }
  .mini-case-title { grid-column: 1 / -1; }
  .mini-case-card > .case-card-footer { grid-column: 1 / -1; }

  /* Metric grid */
  .metric-grid { grid-template-columns: repeat(4, 1fr); gap: 20px; }
  .metric-card { padding: 24px; }
  .metric { font-size: var(--fs-metric); }
  .proof-grid { grid-template-columns: repeat(3, 1fr); gap: 20px; }
  .proof-card { padding: 28px; }

  /* Testimonials */
  .testimonial-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .testimonial-card { padding: 32px; }
  .testimonial-hide-mobile { display: flex; }
  .testimonial-grid-v2 { grid-template-columns: repeat(3, 1fr); gap: 18px; }
  .testimonial-card-v2 { padding: 32px 28px; }
  .proof-quotes { grid-template-columns: repeat(2, 1fr); gap: 20px; }

  /* Audience cards */
  .two-cards { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .audience-card { padding: 38px; }

  /* Pricing / Sessions */
  .pricing-card { padding: 42px 38px; }
  .session-card--featured { padding: 42px 38px; }
  .session-card--next { padding: 28px 32px; }
  .session-card--next .button { width: fit-content; }
  .practical-list { grid-template-columns: repeat(2, 1fr); gap: 14px 28px; }

  /* FAQ */
  .faq-list { gap: 14px; }
  summary { padding: 22px 28px; min-height: 58px; }
  details p { padding: 0 28px 24px; }

  /* Final CTA */
  .final-cta-grid {
    grid-template-columns: 1fr minmax(260px, 0.45fr);
    gap: 48px;
    align-items: center;
  }

  /* Newsletter */
  .newsletter-grid {
    grid-template-columns: minmax(0, 1fr) minmax(340px, .9fr);
    gap: 52px;
  }
  .newsletter-form { padding: 34px; }
  .newsletter-submit { width: fit-content; }

  /* Footer */
  .footer-bottom {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
  }

  /* Forms */
  .form-card { padding: 36px; }
  .form-grid { grid-template-columns: repeat(2, 1fr); gap: 18px 20px; }
  .thankyou-card { padding: 0 32px; }
  .legal-card { padding: 44px; }
  .result-card { padding: 36px; }

  /* Sticky CTA is mobile only */
  .sticky-cta-bar { display: none !important; }
}

/* ═══════════════════════════════════════════
   MOBILE / DESKTOP VISIBILITY UTILITIES
   ═══════════════════════════════════════════ */
.desktop-only { display: none; }
.mobile-only { display: block; }

@media (min-width: 860px) {
  .desktop-only { display: block; }
  .mobile-only { display: none; }
  .desktop-only-flex { display: flex; }
  .desktop-only-grid { display: grid; }
}
@media (max-width: 859px) {
  .desktop-only, .desktop-only-flex, .desktop-only-grid { display: none !important; }
  .mobile-only-flex { display: flex; }
}

/* ─── Small screens (sticky CTA visible) ─── */
@media (max-width: 859px) {
  body { padding-bottom: 0; }

  .site-footer { padding-bottom: calc(88px + 36px); }

  .sticky-cta-bar {
    display: block;
  }

  .hero .button,
  .pricing-card .button,
  .final-cta .button { width: 100%; }

  .hero-actions .button-xl { width: 100%; }

  .site-footer { padding-bottom: 12px; }

  /* ─── A. HEADER: compact mobile layout ─── */
  .header-inner {
    min-height: 76px;
    gap: 0.5rem;
    padding: 0 12px 0 4px;
  }
  .brand {
    flex: 1;
    min-width: 0;
    max-width: 280px;
    margin-right: auto;
  }
  .brand-logo { max-height: 50px; }
  /* Hide the header CTA on mobile - use bottom sticky instead */
  .header-cta { display: none !important; }
  .nav-toggle {
    flex-shrink: 0;
    order: 1;
    min-height: 48px;
    min-width: 48px;
    padding: 0.4rem 1rem;
    font-size: 16px;
    font-weight: 600;
  }

  /* ─── B. HERO: spacious mobile ─── */
  .hero { padding: 36px 0 var(--space-lg); }
  .hero-grid { gap: var(--space-lg); }

  /* Hide on mobile: secondary body (now hero-support is always visible) */
  .hero-visual-col { display: block; }
  .hero-image-slot img {
    aspect-ratio: 2 / 3;
    object-fit: cover;
    object-position: center 20%;
    max-height: 50vh;
  }

  /* Hero order on mobile */
  .hero-copy { display: flex; flex-direction: column; }
  .hero-offer-eyebrow { order: 1; }
  .hero-doelgroep { order: 2; }
  .hero-copy h1 { order: 3; margin-bottom: var(--space-md); }
  .hero-visual-col { order: 4; margin-top: var(--space-sm); }
  .hero-lead { order: 5; font-size: 18px; line-height: 1.55; margin-bottom: var(--space-sm); }
  .hero-usps { order: 6; }
  .hero-actions { order: 7; margin-top: var(--space-xs); }
  .hero-tertiary-cta { order: 8; margin-top: 12px; }
  .hero-info-strip { order: 9; margin-top: 20px; font-size: 13px; white-space: normal; }

  /* ─── C. PROOFBAR: stacked cards on mobile ─── */
  .proofbar { border-top: 0; border-bottom: 0; }
  .proofbar-inner { padding: 20px 0; }
  .proofbar-grid {
    grid-template-columns: 1fr;
    gap: 12px;
    border: 0;
    background: transparent;
    border-radius: 0;
  }
  .proofbar-item {
    padding: 18px 20px 16px;
    background: var(--surface);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow);
  }
  .proofbar-item:nth-child(odd) {
    border-right: 0;
  }
  .proofbar-item:nth-child(-n+2) {
    border-bottom: 0;
  }
  .proofbar-item-head {
    align-items: center;
    gap: 8px;
  }
  .proofbar-value { font-size: var(--fs-ui); }
  .proofbar-subcopy { font-size: var(--fs-small); color: var(--text-secondary); }

  /* NEW Proof section mobile */
  .proof-section { padding: var(--space-section-y-mobile) 0; }

  /* ─── D. HERKENNING: scannable cards on mobile ─── */
  .herkenning-section { padding: var(--space-section-y-mobile) 0; }

  /* ─── D. Section spacing on mobile: more breathing room ─── */
  .section { padding: var(--space-section-y-mobile) 0; }

  /* ─── E. OVER SAMIR: show all content on mobile ─── */
  .authority-grid { gap: 24px; }
  /* Hide secondary portrait on mobile */
  .portrait-card-secondary { display: none !important; }
  /* Show all Samir content - no toggle needed */
  .authority-litany {
    font-size: var(--fs-ui);
    margin: 1.2em 0;
    padding-left: 14px;
  }
  .samir-expand-btn { display: none; }
  .authority-body {
    font-size: var(--fs-body);
    line-height: var(--lh-body);
  }
  .authority-lead {
    font-size: var(--fs-body);
    line-height: var(--lh-body);
  }
  /* Samir CTA: visible on all viewports (compact on mobile) */

  /* ─── F. WAT JE ZIET: show all bullets on mobile ─── */

  /* ─── G. BEWIJS: show all on mobile, better hierarchy ─── */
  .proof-grid { display: grid; }
  .metric-card p { font-size: var(--fs-small); line-height: var(--lh-body); }
  .metric-card { padding: 18px; }
  .metric { font-size: var(--fs-metric); margin-bottom: 6px; }
  .metric-bron { font-size: var(--fs-overline); margin-top: 4px; }
  .metric-card h3 { font-size: var(--fs-body); }
  /* Proof compact on mobile */
  .proof-compact { padding: 18px; }
  .proof-compact-title { font-size: var(--fs-ui); margin-bottom: 12px; }

  /* ─── H. TESTIMONIALS: progressive disclosure on mobile ─── */
  .testimonial-card-v2 { padding: 18px; gap: 0; border: none; box-shadow: var(--shadow); }
  .testimonial-phase { padding: 10px 0; }
  .testimonial-phase-text { font-size: var(--fs-ui); line-height: var(--lh-body); }
  .testimonial-phase--highlight {
    padding: 14px;
    margin: 6px -4px 0;
  }
  .testimonial-footer-v2 { padding-top: 10px; gap: 8px; }
  .testimonial-avatar { width: 36px; height: 36px; }
  /* Featured testimonial before pricing: show on mobile but compact */
  .testimonial-featured { padding: 16px; }
  /* Third testimonial hidden on mobile by default */
  .testimonial-third { display: none; }
  .testimonial-third.testimonial-third--visible { display: flex; }

  /* ─── I. PRAKTISCH: trustworthy mobile ─── */
  .past-sessions-wrapper .past-sessions-list { display: none; }
  .past-sessions-wrapper .past-sessions-list.past-sessions--visible { display: grid; }
  .session-card--featured {
    padding: 24px 20px;
    border-width: 2px;
    margin-left: calc(var(--side-pad) * -1);
    margin-right: calc(var(--side-pad) * -1);
    border-radius: 0;
    border-left: none;
    border-right: none;
  }
  .price {
    font-size: clamp(2rem, 9vw, 2.5rem);
  }
  .price-tier-line {
    margin-bottom: 14px;
    padding-bottom: 14px;
    font-size: var(--fs-small);
  }
  .practical-list div {
    padding: 10px 0;
  }
  .practical-list dt {
    font-size: var(--fs-overline);
  }
  .practical-list dd {
    font-size: var(--fs-ui);
  }
  .session-card--featured .button {
    margin-top: 12px;
  }
  .private-session-link {
    font-size: var(--fs-small);
    margin-top: var(--space-sm);
    padding-top: var(--space-sm);
    border-top: 1px solid var(--line);
  }

  /* ─── J. FAQ: compact mobile, all shown ─── */
  summary {
    padding: 12px 14px;
    min-height: 46px;
    font-size: 1.125rem;
  }
  summary::after {
    width: 22px;
    height: 22px;
    font-size: 0.95rem;
  }
  details p {
    padding: 0 14px 12px;
    font-size: 1rem;
  }

  /* ─── K. FINAL CTA: compact mobile ─── */
  .final-cta-grid { gap: var(--space-md); }
  .trust-card { padding: 16px; }
  .trust-list { gap: 8px; }
  .trust-list li { font-size: var(--fs-ui); }

  /* ─── K. WEGGEVER / PDF: compact mobile ─── */
  .weggever-signup-card { padding: 20px 16px; }
  .weggever-bullets li:nth-child(n+4) { display: none; }

  /* ─── K. NEWSLETTER: compact mobile ─── */
  .newsletter-section { padding: var(--space-lg) 0; }
  .newsletter-teasers { display: none; }
  .newsletter-form { padding: 16px; }
  .newsletter-microcopy { font-size: var(--fs-overline); }

  /* ─── M. GENERAL POLISH: spacing, whitespace, typography ─── */
  h2 { margin-bottom: var(--space-sm); }
  .section-head { margin-bottom: var(--space-md); }
  .section-closing { margin-top: var(--space-md); }

  /* Better body text readability */
  p { line-height: var(--lh-body); }
  .eyebrow, .section-label { font-size: var(--fs-overline); margin-bottom: var(--space-md); }
  .section-intro { font-size: var(--fs-ui); line-height: var(--lh-body); }

  /* More space between section groups */
  .opbrengst-list li { font-size: var(--fs-body); line-height: var(--lh-body); }
  .feature-list li, .checklist li { font-size: var(--fs-body); line-height: var(--lh-body); }

  /* Mobile density: increased vertical rest between sections */
  .section + .section { margin-top: 8px; }
  .section-muted + .section,
  .section + .section-muted { margin-top: 0; }

  /* Mobile density: reduce card overflow in viewport */
  .pain-list { gap: 1rem; }
  .metric-grid { gap: 10px; }

  /* Voor wie compact on mobile */
  .audience-card { padding: 16px; }
  .audience-card h3 { font-size: var(--fs-body); margin-bottom: 10px; }
  .audience-card .checklist li { font-size: var(--fs-ui); line-height: var(--lh-body); }
  .audience-card-neg .checklist li { font-size: var(--fs-small); }

  /* Over Samir: show CTA on mobile too (compact) */
  .authority-cta-block { display: block; margin-top: 0.6em; }
  .authority-cta-block .button { font-size: var(--fs-ui); min-height: 48px; padding: 0.75rem 1.5rem; }

  /* Toggle buttons shared styling */
  .show-more-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.3em;
    margin-top: var(--space-sm);
    padding: 10px 18px;
    background: transparent;
    border: 1px solid var(--link);
    border-radius: 999px;
    font: inherit;
    font-size: var(--fs-ui);
    font-weight: 600;
    color: var(--link);
    cursor: pointer;
    transition: border-color .15s ease, color .15s ease;
  }
  .show-more-btn:hover { border-color: var(--link); color: var(--link-hover); }
  .show-more-btn:focus-visible { outline: 3px solid rgba(138, 39, 53, .25); outline-offset: 2px; }
}

/* ─── Desktop: show weggever-banner ─── */
@media (min-width: 860px) {
  .weggever-banner { display: block; }
  .pain-toggle-btn { display: none; }
  .samir-expand-btn { display: none; }
  .authority-cta-block { display: block; }
  .show-more-btn { display: none; }
  .brand-logo { max-height: 56px; }
  /* Desktop proof-compact */
  .proof-compact {
    padding: 28px;
  }
  .proof-compact-items {
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
  .proof-compact-item {
    border-bottom: none;
    padding-bottom: 0;
    border-right: 1px solid var(--line);
    padding-right: 20px;
  }
  .proof-compact-item:last-child {
    border-right: none;
    padding-right: 0;
  }
}

/* ─── Very small screens ─── */
@media (max-width: 420px) {
  :root { --side-pad: 16px; }
  .brand { max-width: 250px; }
  .brand-logo { max-height: 42px; }
  h1 { font-size: clamp(1.5rem, 5vw, 2rem); }
  .hero-lead { font-size: var(--fs-body); }
  .testimonial-card-v2 { padding: 14px; }
  .metric-card { padding: 14px; }
  .proofbar-item { padding: 16px; }
  .proofbar-value { font-size: var(--fs-small); }
}

/* ─── Tablet (metric grid 2-col) ─── */
@media (min-width: 480px) and (max-width: 859px) {
  .metric-grid { grid-template-columns: repeat(2, 1fr); }
  .testimonial-grid-v2 { grid-template-columns: 1fr; gap: 16px; }
  .proofbar-grid { grid-template-columns: repeat(2, 1fr); }
  .contrast-grid { grid-template-columns: repeat(2, 1fr); }
  .value-blocks { grid-template-columns: repeat(3, 1fr); }
  .pillars-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ═══════════════════════════════════════════
   REGISTER PAGE - /inschrijven/
   Premium, mobile-first, single-action
   ═══════════════════════════════════════════ */

/* Hide sticky CTA on /inschrijven/ */
.page-inschrijven .sticky-cta-bar { display: none !important; }
.page-inschrijven { padding-bottom: 0 !important; }

.register-narrow { max-width: 620px; }
.register-main { padding-bottom: 0; }

/* ─── Hero ─── */
.register-hero {
  padding: 48px 0 32px;
}
.register-hero h1 {
  margin-bottom: 14px;
  font-size: clamp(1.8rem, 4.5vw, 2.75rem);
  line-height: 1.08;
  letter-spacing: -0.03em;
}
.register-lead {
  font-size: var(--fs-body);
  color: var(--text-secondary);
  max-width: 34em;
  margin-bottom: 10px;
  line-height: 1.6;
}
.register-trust-line {
  font-size: var(--fs-small);
  font-weight: 600;
  color: var(--text-secondary);
  margin: 0;
  opacity: 0.8;
}

/* ─── Register sections ─── */
.register-section {
  padding: 32px 0;
}

/* ─── Session date picker ─── */
.register-datepicker {
  border: none;
  padding: 0;
  margin: 0 0 32px;
}
.register-fieldset-title {
  font-size: var(--fs-body);
  font-weight: 700;
  color: var(--text);
  margin: 0 0 6px;
}
.register-fieldset-desc {
  font-size: var(--fs-small);
  color: var(--text-secondary);
  margin: 0 0 16px;
  line-height: 1.5;
}
.register-fieldset-subtitle {
  font-size: var(--fs-ui);
  font-weight: 600;
  color: var(--text-secondary);
  margin: 20px 0 12px;
}
.label-optional {
  font-weight: 400;
  color: var(--text-secondary);
  opacity: 0.7;
}
.session-cards {
  display: grid;
  gap: 10px;
}
.session-card {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: 14px;
  padding: 16px 18px;
  border: 2px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  cursor: pointer;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
  position: relative;
}
.session-card:hover:not(.session-card--soldout) {
  border-color: rgba(138, 39, 53, 0.25);
}
.session-card--selected {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 1px var(--accent), 0 2px 8px rgba(138, 39, 53, 0.08);
}
.session-card--soldout {
  opacity: 0.55;
  cursor: not-allowed;
  background: var(--surface-muted);
}
.session-card--limited {
  border-color: #D97706;
}
.session-card-input {
  width: 20px;
  height: 20px;
  margin-top: 2px;
  accent-color: var(--accent);
  min-height: auto !important;
}
.session-card-content {
  display: grid;
  gap: 2px;
}
.session-card-date {
  font-size: var(--fs-ui);
  font-weight: 700;
  color: var(--text);
  line-height: 1.3;
}
.session-card-meta {
  font-size: var(--fs-small);
  color: var(--text-secondary);
  line-height: 1.4;
}
.session-card-price {
  font-size: var(--fs-small);
  color: var(--text);
  font-weight: 600;
}
.session-card-avail {
  font-size: var(--fs-overline);
  font-weight: 700;
  color: var(--accent);
  margin-top: 2px;
}
.session-card-avail--limited {
  color: #B45309;
}
.session-card-avail--soldout {
  color: var(--text-secondary);
  font-weight: 600;
}
.register-datepicker.has-error .session-cards {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--radius);
}
.register-alt-dates {
  margin-top: 8px;
}
.session-cards--alt .session-card {
  padding: 12px 16px;
}
.session-cards--alt .session-card-date {
  font-size: var(--fs-small);
}
.register-no-sessions {
  padding: 24px;
  background: var(--surface-muted);
  border-radius: var(--radius);
  margin-bottom: 24px;
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  line-height: 1.6;
}

/* ─── Form fields ─── */
.register-form-fields {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  margin-bottom: 24px;
}

/* ─── Register form ─── */
.register-form-section {
  padding-top: 0;
}
.register-form {
  display: grid;
  gap: 0;
}

/* Form field */
.form-field label {
  display: block;
  font-size: var(--fs-ui);
  font-weight: 700;
  color: var(--text);
  margin-bottom: 6px;
}
.form-field input,
.form-field select,
.form-field textarea {
  width: 100%;
  min-height: 50px;
  padding: 0.8rem 1rem;
  border-radius: var(--radius-sm);
  border: 1.5px solid rgba(20, 17, 15, .12);
  background: #fff;
  font: inherit;
  color: var(--text);
  font-size: 1rem;
  transition: border-color 0.15s ease;
}
.form-field textarea {
  min-height: 80px;
  resize: vertical;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  outline: 3px solid rgba(138, 39, 53, .12);
  border-color: var(--accent);
}
.form-field--full { grid-column: 1 / -1; }
.field-hint {
  display: block;
  margin-top: 6px;
  font-size: var(--fs-small);
  color: var(--text-secondary);
  line-height: 1.4;
}
.field-error {
  display: none;
  margin-top: 6px;
  font-size: var(--fs-small);
  color: var(--accent);
  font-weight: 600;
}
.field-error.is-visible { display: block; }
.form-field.has-error input,
.form-field.has-error select,
.form-field.has-error textarea {
  border-color: var(--accent);
  outline: 3px solid rgba(138, 39, 53, .08);
}

/* Checkbox */
.register-checkbox {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: 12px;
  margin: 0;
  cursor: pointer;
}
.register-checkbox input {
  width: 20px;
  height: 20px;
  min-height: auto;
  margin-top: 3px;
  accent-color: var(--accent);
}
.register-checkbox span {
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  line-height: 1.5;
}
.register-checkbox span a {
  color: var(--link);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}
.register-checkbox.has-error span {
  color: var(--accent);
}
.register-checkbox-error {
  margin: 4px 0 0 32px;
}
.register-checkbox--secondary {
  margin-top: 14px;
  opacity: 0.75;
}
.register-checkbox--secondary span {
  font-size: var(--fs-small);
}
.register-legal-block {
  margin: 0 0 24px;
  padding: 16px 18px 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface-muted);
}
.register-legal-block .register-checkbox--required {
  margin-top: 0;
}

/* ─── Review / Testimonial card (Google-style) ─── */
.register-review-card {
  margin: 28px 0;
  padding: 20px 22px;
  background: #fff;
  border-radius: var(--radius);
  border: 1px solid #e0e0e0;
  box-shadow: 0 1px 3px rgba(0,0,0,0.08);
}
.review-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}
.review-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--accent, #8A2735);
  color: #fff;
  font-weight: 700;
  font-size: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  text-transform: uppercase;
}
.review-author-info {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.review-author-name {
  font-weight: 700;
  font-size: var(--fs-ui);
  color: var(--text);
}
.review-author-role {
  font-size: var(--fs-small);
  color: var(--text-secondary);
}
.review-stars {
  display: flex;
  gap: 2px;
  margin-bottom: 10px;
}
.review-stars svg {
  width: 18px;
  height: 18px;
  fill: #fbbc04;
}
.review-body {
  margin: 0;
  font-size: var(--fs-ui);
  line-height: 1.6;
  color: var(--text);
}

/* Mobile: review below CTA. Desktop: review stays below CTA (natural order) */
@media (min-width: 768px) {
  .register-review-card {
    max-width: 480px;
  }
}

/* Submit block */
.register-submit-block {
  margin: 0 0 8px;
}
.register-submit {
  width: 100%;
}
.register-microcopy {
  margin: 12px 0 6px;
  font-size: var(--fs-small);
  color: var(--text-secondary);
  text-align: center;
}
.register-after-submit {
  margin: 16px 0 20px;
  padding: 16px 18px;
  background: var(--surface-muted);
  border-radius: var(--radius-sm);
}
.register-after-title {
  font-size: var(--fs-ui);
  font-weight: 700;
  color: var(--text);
  margin: 0 0 8px;
}
.register-after-list {
  margin: 0;
  padding-left: 1.2rem;
  font-size: var(--fs-small);
  color: var(--text-secondary);
  line-height: 1.7;
}
.register-privacy-note {
  margin: 0;
  font-size: var(--fs-overline);
  color: var(--text-secondary);
  opacity: 0.65;
  text-align: center;
  max-width: 38em;
  margin-inline: auto;
  line-height: 1.5;
}

/* ─── Error summary ─── */
.form-error-summary {
  padding: 16px 20px;
  background: #FEF2F2;
  border: 1px solid rgba(138, 39, 53, .15);
  border-radius: var(--radius-sm);
  margin-bottom: 20px;
}
.form-error-summary h3 {
  font-size: var(--fs-ui);
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--accent);
}
.form-error-summary ul {
  margin: 0;
  padding-left: 1.2rem;
}
.form-error-summary li {
  font-size: var(--fs-small);
  margin-bottom: 4px;
}
.form-error-summary a {
  color: var(--accent);
  text-decoration: underline;
  font-weight: 600;
}

/* ─── Sold-out state ─── */
.register-soldout-msg {
  font-size: var(--fs-lead);
  font-weight: 800;
  color: var(--accent);
  margin-bottom: 20px;
}

/* ─── Extra / incompany block ─── */
.register-extra {
  padding: 28px 0 48px;
}
.register-incompany-card {
  padding: 24px;
  background: var(--surface-muted);
  border-radius: var(--radius);
}
.register-extra-title {
  font-size: clamp(1.1rem, 2.5vw, 1.4rem);
  font-weight: 700;
  margin: 0 0 8px;
  line-height: 1.3;
}
.register-extra-body {
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  margin-bottom: 8px;
  max-width: 34em;
  line-height: 1.6;
}
.register-extra .text-link {
  color: var(--link);
  font-weight: 600;
  font-size: var(--fs-ui);
}
.register-extra .text-link:hover {
  color: var(--link-hover);
}

/* ─── Text links on register page ─── */
.page-inschrijven .text-link {
  color: var(--link);
}
.page-inschrijven .text-link:hover {
  color: var(--link-hover);
}
.page-inschrijven .footer-bottom a {
  color: var(--link);
}
.page-inschrijven .footer-bottom a:hover {
  color: var(--link-hover);
}

/* ─── Desktop: 2-col form grid ─── */
@media (min-width: 860px) {
  .register-hero { padding: 56px 0 36px; }
  .register-narrow { max-width: 640px; }
  .register-form-fields {
    grid-template-columns: 1fr;
    gap: 22px;
  }
  .register-submit {
    width: fit-content;
    min-width: 260px;
  }
  .register-submit-block { text-align: left; }
  .register-microcopy,
  .register-privacy-note { text-align: left; margin-inline: 0; }
  .session-cards {
    gap: 12px;
  }
  .session-card {
    padding: 18px 22px;
  }
  .register-prepflow .session-summary {
    padding: 30px 34px;
  }
  .legal-card {
    padding: 40px;
  }
  .legal-toc ol {
    columns: 2;
    column-gap: 24px;
  }
}

/* ─── Deelnemersvoorbereiding portal ─── */
.prep-flow {
  margin-top: 20px;
  display: grid;
  gap: 14px;
}
.prep-step-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 20px;
}
.prep-step-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}
.prep-step-time {
  margin: 0;
  font-size: var(--fs-small);
  font-weight: 700;
  color: var(--text-secondary);
}
.prep-step-card h2 {
  font-size: 1.2rem;
  margin: 0 0 8px;
}
.prep-step-card p {
  margin: 0 0 8px;
  color: var(--text-secondary);
  line-height: 1.5;
}
.prep-step-card ul {
  margin: 0;
  padding-left: 1.05rem;
}
.prep-step-card li {
  margin-bottom: 6px;
}
.prep-checklist {
  margin: 0;
  padding-left: 1rem;
}
.prep-checklist-compact li {
  margin-bottom: 4px;
}
.prep-topic-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
}
.prep-topic-list li {
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: #fff;
  margin: 0;
}
.prep-topic-list strong {
  display: block;
  margin: 0 0 2px;
  color: var(--text);
}
.prep-topic-list span {
  color: var(--text-secondary);
  font-size: var(--fs-ui);
}
.prep-action-row {
  margin-top: 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  align-items: center;
}
.prep-inline-note {
  margin: 0;
  font-size: var(--fs-small);
  color: var(--text-secondary);
}
.prep-upload-box {
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--line);
  background: #fff;
}
.prep-upload-title {
  margin: 0 0 4px;
  font-weight: 700;
  color: var(--text);
}
.prep-upload-body {
  margin: 0;
  color: var(--text-secondary);
  font-size: var(--fs-ui);
}
.prep-step-card-followup {
  border-color: var(--accent-soft);
}
.prepflow-list li strong {
  color: var(--text);
}
.prepflow-list li span {
  color: var(--text-secondary);
  font-size: var(--fs-small);
}

/* ═══════════════════════════════════════════
   Weggever - Lead Magnet Blocks
   Calm, scannable, visually subordinate
   ═══════════════════════════════════════════ */

/* ─── Inline CTA (under hero) ─── */
.weggever-inline {
  margin-top: 20px;
  padding: 16px 20px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.weggever-inline-text {
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  margin: 0;
  line-height: 1.5;
}
.weggever-inline-link {
  font-size: var(--fs-ui);
  font-weight: 600;
  color: var(--text-secondary);
  text-decoration: underline;
  text-decoration-thickness: .08em;
  text-underline-offset: .18em;
}
.weggever-inline-link:hover {
  color: var(--text);
}

/* ─── Banner CTA (after herkenning) ─── */
.weggever-banner {
  padding: 28px 0;
  background: var(--surface);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.weggever-banner-inner {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.weggever-banner-label {
  font-size: var(--fs-overline);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-secondary);
  margin: 0;
}
.weggever-banner-title {
  font-size: var(--fs-ui);
  color: var(--text);
  margin: 0;
  line-height: 1.5;
  font-weight: 500;
}
.weggever-banner-link {
  font-size: var(--fs-ui);
  font-weight: 600;
  color: var(--text-secondary);
  text-decoration: underline;
  text-decoration-thickness: .08em;
  text-underline-offset: .18em;
}
.weggever-banner-link:hover {
  color: var(--text);
}

/* ─── Signup section (above newsletter) ─── */
.weggever-signup-section {
  padding: var(--space-lg) 0;
  background: var(--surface);
}
.weggever-signup-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 32px 24px;
}
.weggever-signup-label {
  font-size: var(--fs-overline);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-secondary);
  margin: 0 0 8px;
}
.weggever-signup-title {
  font-size: var(--fs-h3);
  line-height: 1.3;
  margin: 0 0 8px;
  color: var(--text);
}
.weggever-signup-subtitle {
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  margin: 0 0 20px;
}
.weggever-bullets {
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
  display: grid;
  gap: 8px;
}
.weggever-bullets li {
  position: relative;
  padding-left: 20px;
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  line-height: 1.5;
}
.weggever-bullets li::before {
  content: '-';
  position: absolute;
  left: 0;
  color: var(--accent);
  font-weight: 600;
}

/* ─── Weggever form (shared) ─── */
.weggever-form {
  margin: 0;
}
.weggever-form-row {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.weggever-form-row input[type="email"] {
  padding: 12px 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  font-size: 1rem;
  font-family: inherit;
  background: #fff;
  color: var(--text);
  width: 100%;
}
.weggever-form-row input[type="email"]:focus {
  outline: 2px solid var(--accent);
  outline-offset: -1px;
  border-color: var(--accent);
}
.weggever-form-row .button {
  width: 100%;
  text-align: center;
}
.weggever-form .microcopy {
  margin-top: 8px;
}

/* ─── Opt-in block (quickscan page) ─── */
.weggever-optin {
  margin-top: 24px;
}
.weggever-optin-inner {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 28px 24px;
}
.weggever-optin-label {
  font-size: var(--fs-overline);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-secondary);
  margin: 0 0 8px;
}
.weggever-optin-title {
  font-size: var(--fs-body);
  line-height: 1.35;
  margin: 0 0 6px;
  color: var(--text);
}
.weggever-optin-subtitle {
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  margin: 0 0 20px;
}

/* ─── Thank-you state ─── */
.weggever-thankyou {
  margin-top: 24px;
}
.weggever-thankyou-inner,
.weggever-signup-thankyou {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 32px 24px;
  text-align: center;
}
.weggever-thankyou-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--accent-soft);
  color: var(--accent);
  font-size: 1.4rem;
  font-weight: 700;
  margin: 0 auto 16px;
}
.weggever-thankyou-inner h3,
.weggever-signup-thankyou h3 {
  font-size: 1.2rem;
  margin: 0 0 8px;
}
.weggever-thankyou-inner p,
.weggever-signup-thankyou p {
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  margin: 0 0 16px;
}
.weggever-thankyou-inner .button,
.weggever-signup-thankyou .button {
  margin-bottom: 12px;
}

/* ─── Desktop overrides for weggever ─── */
@media (min-width: 860px) {
  .weggever-inline {
    flex-direction: row;
    align-items: center;
    gap: 16px;
  }
  .weggever-banner-inner {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
  }
  .weggever-banner-copy {
    flex: 1;
    min-width: 0;
  }
  .weggever-banner-link {
    white-space: nowrap;
    flex-shrink: 0;
  }
  .weggever-signup-card {
    padding: 40px 40px;
  }
  .weggever-form-row {
    flex-direction: row;
    gap: 12px;
  }
  .weggever-form-row input[type="email"] {
    flex: 1;
  }
  .weggever-form-row .button {
    width: auto;
    white-space: nowrap;
  }
  .weggever-bullets {
    grid-template-columns: 1fr 1fr;
    gap: 6px 24px;
  }
  .weggever-optin-inner {
    padding: 32px 36px;
  }
}

/* ═══════════════════════════════════════════
   Icon System - functional, minimal
   ═══════════════════════════════════════════ */

/* Base icon: inline SVG or img, muted color, outline style */
.icon {
  display: inline-block;
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  vertical-align: middle;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  color: var(--text-secondary);
  opacity: 0.7;
}
.icon-ui {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.icon img,
.icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* Desktop sizing */
@media (min-width: 768px) {
  .icon { width: 18px; height: 18px; }
}

/* ── Proofbar icons ── */
.proofbar-icon {
  width: 16px;
  height: 16px;
  opacity: 0.85;
}
@media (min-width: 768px) {
  .proofbar-icon {
    width: 18px;
    height: 18px;
  }
}

/* ── Practical list icons ── */
.practical-list dt {
  display: flex;
  align-items: center;
  gap: 8px;
}
@media (min-width: 768px) {
  .practical-list dt {
    gap: 10px;
  }
}
.practical-list .icon {
  width: 18px;
  height: 18px;
  color: var(--text-muted);
}
@media (min-width: 768px) {
  .practical-list .icon {
    width: 20px;
    height: 20px;
  }
}

/* ── Newsletter teaser icons ── */
.newsletter-teasers li {
  display: block;
}
.newsletter-teasers li::before {
  content: "";
}
@media (min-width: 768px) {
  .newsletter-teasers li {
    padding-left: 16px;
  }
}

/* ═══════════════════════════════════════════
   OPBRENGSTEN - Value takeaways block
   ═══════════════════════════════════════════ */
.opbrengst-list {
  margin: var(--space-md) 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 14px;
}
.opbrengst-list li {
  position: relative;
  padding: 14px 16px 14px 20px;
  background: var(--surface);
  border-radius: var(--radius-sm);
  border-left: 3px solid var(--accent);
  font-size: var(--fs-ui);
  line-height: 1.55;
}
.opbrengst-list li strong {
  display: block;
  font-size: var(--fs-ui);
  color: var(--accent);
  margin-bottom: 2px;
}
@media (min-width: 860px) {
  .opbrengst-list {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
  .opbrengst-list li {
    padding: 18px 20px 18px 22px;
  }
}

/* ═══════════════════════════════════════════
   RITME-STAPPEN - Van visie naar werkvloer
   ═══════════════════════════════════════════ */
.ritme-stappen {
  margin: var(--space-md) 0 0;
  padding: 0 0 0 1.4em;
  display: flex;
  flex-direction: column;
  gap: 12px;
  counter-reset: ritme;
}
.ritme-stappen li {
  position: relative;
  padding: 10px 14px;
  background: var(--surface);
  border-radius: var(--radius);
  border-left: 3px solid var(--accent);
  font-size: var(--fs-ui);
  line-height: 1.55;
  list-style: none;
  counter-increment: ritme;
}
.ritme-stappen li::before {
  content: counter(ritme);
  position: absolute;
  left: -1.6em;
  top: 10px;
  width: 1.4em;
  height: 1.4em;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent);
  color: #fff;
  font-size: var(--fs-overline);
  font-weight: 700;
  border-radius: 50%;
}

/* ═══════════════════════════════════════════
   SCARCITY LINE
   ═══════════════════════════════════════════ */
.scarcity-line {
  font-size: var(--fs-small);
  font-weight: 700;
  color: var(--accent);
  margin: 0 0 var(--space-md);
  letter-spacing: 0.01em;
}

/* ═══════════════════════════════════════════
   REGISTER - After submit reassurance
   ═══════════════════════════════════════════ */
.register-after-submit {
  margin: 16px 0;
  padding: 14px 16px;
  background: var(--surface);
  border-radius: var(--radius-sm);
  border-left: 3px solid var(--accent);
}
.register-after-title {
  font-size: var(--fs-overline);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-secondary);
  margin: 0 0 4px;
}
.register-after-body {
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  margin: 0;
  line-height: 1.5;
}

/* ═══════════════════════════════════════════
   REGISTER - Better mobile spacing
   ═══════════════════════════════════════════ */
@media (max-width: 859px) {
  .register-hero { padding: 36px 0 28px; }
  .register-section { padding: 24px 0; }
  .register-form-section { padding-top: 0; }
  .session-summary { padding: 18px 16px; }
  .session-summary-list { gap: 10px; }
  .register-form-grid { gap: 16px; }
  .register-submit-block { margin-top: 24px; }
}

/* ═══════════════════════════════════════════
   QUICKSCAN - Mobile refinements
   ═══════════════════════════════════════════ */
@media (max-width: 859px) {
  .quiz-stepper {
    padding: 20px 16px;
  }
  .quiz-form-stepper fieldset label {
    padding: 10px 12px;
  }
  .result-card {
    padding: 20px 16px;
    margin-top: 20px;
  }
  .result-card h2 {
    font-size: clamp(1.4rem, 4vw, 1.8rem);
  }
}

/* Quickscan intro */
.quickscan-intro {
  font-size: var(--fs-body);
  line-height: 1.65;
  max-inline-size: var(--measure-body);
  color: var(--text);
  margin-bottom: var(--space-sm);
}

/* Result card copy */
.result-copy {
  font-size: var(--fs-ui);
  line-height: 1.65;
  color: var(--text);
  max-inline-size: var(--measure-body);
  margin: 0 auto var(--space-md);
}

@media (min-width: 860px) {
  .quiz-stepper {
    padding: 36px;
  }
  .followup-form-card {
    padding: 36px;
  }
}

/* ═══════════════════════════════════════════
   BINKADVIES - Extern trendbewijs subsectie
   ═══════════════════════════════════════════ */
.binkadvies-section {
  margin-top: var(--space-lg, 3rem);
  margin-bottom: var(--space-lg, 3rem);
  padding-top: var(--space-md, 2rem);
  border-top: 1px solid var(--line);
  display: none;
}
.binkadvies-section.is-visible {
  display: block;
}
.binkadvies-head {
  text-align: center;
  max-width: 42em;
  margin: 0 auto var(--space-md, 2rem);
}
.binkadvies-title {
  font-size: var(--fs-h3);
  line-height: 1.25;
  margin: 0.3em 0 0.6em;
}
.binkadvies-intro {
  font-size: var(--fs-body);
  line-height: 1.65;
  color: var(--text-secondary);
}
.binkadvies-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md, 2rem);
}
@media (min-width: 640px) {
  .binkadvies-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (min-width: 960px) {
  .binkadvies-grid {
    grid-template-columns: 1fr 1fr 1fr;
  }
}
.binkadvies-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: var(--space-sm, 1.25rem) var(--space-sm, 1.25rem) 1rem;
  display: flex;
  flex-direction: column;
  margin: 0;
}
.binkadvies-card h4 {
  font-size: 1.1rem;
  margin: 0 0 0.35em;
  color: var(--text);
}
.binkadvies-summary {
  font-size: var(--fs-ui);
  line-height: 1.55;
  color: var(--text-secondary);
  margin: 0 0 0.75em;
}
.binkadvies-chart-wrap {
  position: relative;
  aspect-ratio: 3 / 2;
  overflow: hidden;
  border-radius: 8px;
  background: #fff;
  margin-bottom: 0.6em;
}
.binkadvies-chart {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.binkadvies-enlarge-btn {
  display: none;
}
@media (max-width: 639px) {
  .binkadvies-enlarge-btn {
    display: inline-block;
    position: absolute;
    bottom: 8px;
    right: 8px;
    background: var(--accent);
    color: #fff;
    border: none;
    border-radius: 6px;
    padding: 6px 12px;
    font-size: 0.8rem;
    cursor: pointer;
    opacity: 0.9;
    transition: opacity 0.2s;
  }
  .binkadvies-enlarge-btn:hover,
  .binkadvies-enlarge-btn:focus-visible {
    opacity: 1;
  }
}
.binkadvies-footnote {
  font-size: var(--fs-overline);
  color: var(--text-secondary);
  line-height: 1.4;
  margin: auto 0 0;
  padding-top: 0.4em;
}
.binkadvies-section-footnote {
  font-size: var(--fs-small);
  color: var(--text-secondary);
  text-align: center;
  margin-top: var(--space-sm, 1.25rem);
}
.binkadvies-section-footnote:empty {
  display: none;
}

/* Binkadvies lightbox modal */
.binkadvies-modal {
  border: none;
  background: transparent;
  max-width: 96vw;
  max-height: 96vh;
  padding: 0;
}
.binkadvies-modal::backdrop {
  background: rgba(0, 0, 0, 0.75);
}
.binkadvies-modal-inner {
  position: relative;
  background: #fff;
  border-radius: 12px;
  padding: 1rem;
  max-width: 92vw;
  max-height: 90vh;
}
.binkadvies-modal-img {
  display: block;
  max-width: 100%;
  max-height: 82vh;
  object-fit: contain;
  margin: 0 auto;
}
.binkadvies-modal-close {
  position: absolute;
  top: 4px;
  right: 8px;
  background: none;
  border: none;
  font-size: 1.8rem;
  cursor: pointer;
  color: var(--text-secondary);
  line-height: 1;
  min-width: 44px;
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4px;
  z-index: 1;
}
.binkadvies-modal-close:focus-visible {
  outline: 3px solid rgba(138, 39, 53, .25);
  outline-offset: 2px;
  border-radius: 4px;
}

/* ═══════════════════════════════════════════
   WARNING BAR - sticky, collapsible, gold
   ═══════════════════════════════════════════ */
/* ─── Announcement Bar ─── */
.announcement-bar {
  background: #FFF9E6;
  border-bottom: 1px solid #F0E4B0;
  height: 36px;
  display: flex;
  align-items: center;
}
.announcement-bar-inner {
  text-align: center;
}
.announcement-bar-text {
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  letter-spacing: 0.005em;
  line-height: 1;
}

/* ═══════════════════════════════════════════
   RESULTATEN BLOK
   ═══════════════════════════════════════════ */
.resultaten-blok {
  padding: var(--space-lg) 0 var(--space-xl);
  background: var(--surface);
}
.resultaten-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: var(--space-md);
}
.resultaat-card {
  background: var(--bg);
  border-radius: var(--radius-sm);
  padding: 20px;
  border-left: 4px solid var(--accent);
}
.resultaat-metric {
  display: block;
  font-size: var(--fs-metric);
  font-weight: 800;
  color: var(--accent);
  letter-spacing: -0.02em;
  line-height: 0.95;
  margin-bottom: 4px;
  font-variant-numeric: tabular-nums lining-nums;
}
.resultaat-card h3 {
  margin: 4px 0 8px;
  font-size: var(--fs-ui);
  font-weight: 700;
  color: var(--text);
}
.resultaat-toelichting {
  font-size: var(--fs-small);
  color: var(--text-secondary);
  line-height: 1.55;
  margin: 0 0 6px;
  max-inline-size: var(--measure-card);
}
.resultaat-bron {
  font-size: var(--fs-overline);
  color: var(--text-secondary);
  opacity: 0.7;
  margin: 0;
  font-style: italic;
}

/* Samir facts reference link */
.samir-facts-reference {
  margin: 0;
  font-size: var(--fs-small);
}
.samir-facts-reference a {
  color: var(--accent);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.14em;
}

/* ─── Resultaten desktop ─── */
@media (min-width: 860px) {
  .resultaten-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
  .resultaten-grid .resultaat-card:nth-child(4),
  .resultaten-grid .resultaat-card:nth-child(5) {
    grid-column: span 1;
  }
  .resultaat-metric {
    font-size: var(--fs-metric);
  }
  .resultaten-blok {
    padding: var(--space-xl) 0;
  }
}
/* 5-col layout for wide screens */
@media (min-width: 1100px) {
  .resultaten-grid {
    grid-template-columns: repeat(5, 1fr);
  }
}

/* ─── Announcement bar desktop ─── */
@media (min-width: 860px) {
  .announcement-bar {
    height: 40px;
  }
  .announcement-bar-text {
    font-weight: 600;
  }
}

/* ═══════════════════════════════════════════
   PROOF INTRO BRIDGE
   ═══════════════════════════════════════════ */
.proof-intro-bridge {
  padding: var(--space-lg) 0 var(--space-md);
}
.proof-intro-bridge-text {
  font-size: var(--fs-lead);
  line-height: 1.6;
  color: var(--text-secondary);
  max-width: 640px;
  margin: 0;
  font-style: italic;
}

/* ═══════════════════════════════════════════
   CASE CARDS (premium testimonials)
   ═══════════════════════════════════════════ */
.testimonial-subcopy {
  font-size: var(--fs-body);
  line-height: 1.6;
  color: var(--text-secondary);
  max-width: 640px;
  margin: 8px 0 0;
}
.case-card-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
  margin-top: var(--space-lg);
}
.case-card {
  background: var(--surface);
  border-radius: var(--radius);
  padding: 28px 24px 24px;
  margin: 0;
  border: none;
  box-shadow: 0 1px 3px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.04);
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
}
.case-card::before {
  content: "\201C";
  position: absolute;
  top: 16px;
  right: 20px;
  font-size: 3rem;
  line-height: 1;
  color: var(--accent);
  opacity: 0.12;
  font-family: Georgia, serif;
}
.case-card-headline {
  font-size: var(--fs-body);
  font-weight: 700;
  line-height: 1.35;
  color: var(--text);
  margin: 0 0 12px;
}
.case-card-body {
  font-size: var(--fs-ui);
  line-height: 1.6;
  color: var(--text-secondary);
  margin: 0 0 16px;
}
.case-card-outcome {
  font-size: var(--fs-ui);
  font-weight: 600;
  line-height: 1.5;
  color: var(--accent);
  margin: 0 0 20px;
  padding: 12px 14px;
  background: rgba(138, 39, 53, 0.05);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius-sm);
}
.case-card-footer {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}
.case-card-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.case-card-avatar[src=""],
.case-card-avatar:not([src]) { display: none; }
.case-card-meta {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.case-card-name:not(:empty) {
  font-size: var(--fs-small);
  font-weight: 600;
  color: var(--text);
}
.case-card-role {
  font-size: var(--fs-small);
  color: var(--text-secondary);
}
.case-card-org {
  font-size: var(--fs-overline);
  color: var(--text-secondary);
  opacity: 0.8;
}
.case-card-edition:not(:empty) {
  font-size: var(--fs-overline);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent);
  margin-top: 2px;
}
.case-card-edition:empty { display: none; }

@media (min-width: 860px) {
  .case-card-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
  .case-card {
    padding: 32px 28px 28px;
  }
}
@media (max-width: 859px) {
  .testimonial-third { display: none; }
  .testimonial-third.testimonial-third--visible { display: flex; }
}

/* ═══════════════════════════════════════════
   LOGO WALL
   ═══════════════════════════════════════════ */
.logo-wall-section {
  padding: var(--space-md) 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.logo-wall-label {
  font-size: var(--fs-overline);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-secondary);
  margin: 0 0 12px;
  text-align: center;
}
.logo-wall-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 24px 32px;
}
.logo-wall-strip img {
  height: 28px;
  width: auto;
  opacity: 0.5;
  filter: grayscale(1);
  transition: opacity 0.2s;
}
.logo-wall-strip img:hover { opacity: 0.8; }
.logo-wall-demo {
  font-size: var(--fs-overline);
  color: var(--text-secondary);
  opacity: 0.6;
  background: var(--surface);
  border: 1px dashed var(--line);
  border-radius: var(--radius-sm);
  padding: 6px 14px;
  white-space: nowrap;
}

/* ═══════════════════════════════════════════
   EDITION HISTORY STRIP
   ═══════════════════════════════════════════ */
.edition-history-section {
  padding: var(--space-sm) 0;
}
.edition-history-label {
  font-size: var(--fs-overline);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-secondary);
  margin: 0 0 10px;
  text-align: center;
}
.edition-history-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}
.edition-chip {
  font-size: var(--fs-small);
  color: var(--text-secondary);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 100px;
  padding: 5px 16px;
}
.edition-chip--demo {
  border-style: dashed;
  opacity: 0.6;
  font-size: var(--fs-overline);
}

/* ═══════════════════════════════════════════
   ORG TAKEAWAY CARDS
   ═══════════════════════════════════════════ */
.org-takeaway-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
  margin-top: var(--space-lg);
}
.org-takeaway-card {
  background: var(--surface);
  border-radius: var(--radius);
  padding: 24px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}
.org-takeaway-card--demo {
  border: 1px dashed var(--line);
  opacity: 0.6;
}
.org-takeaway-text {
  font-size: var(--fs-ui);
  line-height: 1.55;
  color: var(--text);
  margin: 0 0 8px;
}
.org-takeaway-org {
  font-size: var(--fs-overline);
  color: var(--text-secondary);
  margin: 0;
}
@media (min-width: 860px) {
  .org-takeaway-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
}

/* ═══════════════════════════════════════════
   ARTEFACT PROOF
   ═══════════════════════════════════════════ */
.artefact-proof-strip {
  display: none;
  margin-top: var(--space-xl);
  padding-top: var(--space-md);
  border-top: 1px solid var(--line);
}
.artefact-proof-strip.is-visible {
  display: block;
}
.artefact-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
  margin-top: var(--space-lg);
}
.artefact-card {
  background: var(--surface);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}
.artefact-card--demo {
  border: 1px dashed var(--line);
}
.artefact-preview {
  width: 100%;
  aspect-ratio: 280 / 180;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f0ebe8;
}
.artefact-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: blur(3px);
  opacity: 0.7;
}
.artefact-placeholder-svg {
  width: 100%;
  height: auto;
}
.artefact-caption {
  font-size: var(--fs-ui);
  font-weight: 600;
  color: var(--text);
  padding: 16px 20px 4px;
  margin: 0;
}
.artefact-source {
  font-size: var(--fs-overline);
  color: var(--text-secondary);
  padding: 0 20px;
  margin: 0;
}
.artefact-demo-label {
  display: block;
  font-size: var(--fs-overline);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent);
  padding: 8px 20px 16px;
  opacity: 0.7;
}
@media (min-width: 860px) {
  .artefact-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
}

/* ═══════════════════════════════════════════
   SESSION GALLERY
   ═══════════════════════════════════════════ */
.session-gallery {
  padding: var(--space-lg) 0;
}
.session-gallery-label {
  font-size: var(--fs-overline);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-secondary);
  margin: 0 0 16px;
}
.session-gallery-strip {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
.gallery-tile {
  border-radius: var(--radius);
  overflow: hidden;
  aspect-ratio: 4/3;
}
.gallery-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.gallery-tile--demo {
  border: 1px dashed var(--line);
  background: var(--surface);
}
.gallery-tile-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-small);
  color: var(--text-secondary);
  opacity: 0.6;
  text-align: center;
  padding: 12px;
}
@media (min-width: 860px) {
  .session-gallery-strip {
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
  }
}

/* ═══════════════════════════════════════════
   Trust / Confidentiality notices
   ═══════════════════════════════════════════ */
.trust-notice {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  background: var(--surface);
  border: 1px solid var(--line);
  border-left: 4px solid var(--accent);
  border-radius: var(--radius-sm);
  padding: 16px 20px;
  margin-top: 20px;
}
.trust-notice svg {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  color: var(--text-muted);
  stroke-width: 1.75;
  margin-top: 2px;
}
.trust-notice p {
  margin: 0;
  font-size: var(--fs-small, .85rem);
  line-height: 1.5;
  color: var(--text-secondary);
}
.trust-notice p strong {
  color: var(--text);
}
.trust-notice--small {
  padding: 12px 16px;
  margin-top: 16px;
}
.trust-notice--small p {
  font-size: 13px;
}
.trust-notice--small svg {
  width: 18px;
  height: 18px;
}
.trust-notice--prominent {
  margin-bottom: 32px;
  padding: 24px;
  border-left-width: 5px;
}
.trust-notice--prominent div p {
  margin: 0 0 8px;
}
.trust-notice--prominent div p:last-child {
  margin-bottom: 0;
}

/* ═══════════════════════════════════════════
   Dimension bars (result breakdown)
   ═══════════════════════════════════════════ */
.dimension-bars {
  margin: 24px 0;
  text-align: left;
}
.dimension-bars-title {
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 16px;
  color: var(--text);
}
.dim-bar-row {
  display: grid;
  grid-template-columns: 140px 1fr 50px;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.dim-bar-label {
  font-size: var(--fs-small, .85rem);
  font-weight: 600;
  color: var(--text);
}
.dim-bar-track {
  height: 20px;
  background: var(--surface-muted);
  border-radius: 999px;
  overflow: hidden;
}
.dim-bar-fill {
  height: 100%;
  border-radius: 999px;
  min-width: 16px;
  transition: width 0.6s ease;
}
.dim-bar--low { background: var(--accent); }
.dim-bar--mid { background: #C4873B; }
.dim-bar--high { background: #3A7D5C; }
.dim-bar-score {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  text-align: right;
}

@media (max-width: 480px) {
  .dim-bar-row {
    grid-template-columns: 1fr 50px;
  }
  .dim-bar-label {
    grid-column: 1 / -1;
    margin-bottom: -4px;
  }
}

/* ═══════════════════════════════════════════
   Email / PDF modal
   ═══════════════════════════════════════════ */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(20, 17, 15, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 24px;
  backdrop-filter: blur(4px);
}
.modal-overlay.hidden { display: none; }
.modal-card {
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  max-width: 520px;
  width: 100%;
  padding: 36px 32px;
  position: relative;
  max-height: 90vh;
  overflow-y: auto;
}
.modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  background: none;
  border: none;
  font-size: 24px;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 4px 8px;
  line-height: 1;
}
.modal-close:hover { color: var(--text); }
.modal-card h3 {
  margin: 0 0 8px;
  font-size: 1.25rem;
  color: var(--text);
}
.modal-desc {
  color: var(--text-secondary);
  font-size: var(--fs-small, .85rem);
  margin: 0 0 24px;
  line-height: 1.5;
}
.email-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.email-form .followup-label {
  display: block;
}
.email-form .consent-copy {
  margin: 0;
}
.email-form .consent-copy-note {
  margin: -6px 0 0;
}
.email-success {
  text-align: center;
}
.email-success h3 {
  margin-top: 16px;
}
.email-success .button {
  margin-top: 12px;
}

/* ═══════════════════════════════════════════
   Barometer gate & info card
   ═══════════════════════════════════════════ */
.barometer-info-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 28px 24px;
  margin-top: 28px;
}
.barometer-info-card h3 {
  margin: 0 0 12px;
  color: var(--accent);
}
.barometer-info-card p {
  margin: 0 0 16px;
  line-height: 1.6;
}
.barometer-benefits {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
}
.barometer-benefits li {
  padding: 8px 0 8px 28px;
  position: relative;
  line-height: 1.5;
  border-bottom: 1px solid var(--line);
}
.barometer-benefits li:last-child { border-bottom: none; }
.barometer-benefits li::before {
  content: "\2713";
  position: absolute;
  left: 0;
  color: #3A7D5C;
  font-weight: 700;
}
.barometer-gate-note {
  font-size: var(--fs-small, .85rem);
  color: var(--text-secondary);
}
.barometer-gate-note a {
  color: var(--accent);
  text-decoration: underline;
}

.barometer-public-block {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  padding: 18px 20px;
  margin-top: 14px;
}
.barometer-public-block h2 {
  font-size: 1.05rem;
  margin: 0 0 8px;
}
.barometer-public-block p {
  margin: 0;
  color: var(--text-secondary);
  line-height: 1.55;
}

.barometer-domains-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 20px;
}
.barometer-domain-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  padding: 16px;
}
.barometer-domain-code {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent);
  font-weight: 700;
  margin: 0 0 6px;
}
.barometer-domain-card h3 {
  margin: 0 0 6px;
  font-size: 1.02rem;
}
.barometer-domain-card p {
  margin: 0;
  color: var(--text-secondary);
  line-height: 1.45;
}

@media (min-width: 860px) {
  .barometer-domains-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ─── Code entry ─── */
.code-entry-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 28px 24px;
  margin-top: 20px;
}
.code-entry-card h3 {
  margin: 0 0 8px;
}
.code-entry-card p {
  color: var(--text-secondary);
  margin: 0 0 16px;
}
.code-input-row {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}
.code-input-row input {
  flex: 1;
  font-size: 1.1rem;
  letter-spacing: 2px;
  font-weight: 700;
  text-align: center;
  max-width: 220px;
}
.code-error {
  color: var(--accent);
  font-size: var(--fs-small, .85rem);
  margin-top: 8px;
  font-weight: 600;
}
.code-error.hidden { display: none; }

@media (max-width: 480px) {
  .code-input-row {
    flex-direction: column;
  }
  .code-input-row input {
    max-width: 100%;
  }
}

/* ═══════════════════════════════════════════
   Barometer teaser (after quickscan results)
   ═══════════════════════════════════════════ */
.barometer-teaser {
  margin-top: 28px;
}
.barometer-teaser-inner {
  background: var(--surface);
  border: 2px solid var(--accent-soft);
  border-radius: var(--radius);
  padding: 32px 28px;
  text-align: center;
}
.barometer-teaser-inner .section-label {
  color: #3A7D5C;
}
.barometer-teaser-inner h3 {
  margin: 8px 0 12px;
  color: var(--accent);
}
.barometer-teaser-inner p {
  max-width: 560px;
  margin: 0 auto 20px;
  line-height: 1.6;
}
.result-cta-list--followup {
  margin-top: 10px;
}
.barometer-teaser-ctas {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
}
@media (min-width: 480px) {
  .barometer-teaser-ctas {
    flex-direction: row;
    justify-content: center;
  }
}

/* ═══════════════════════════════════════════
   Dimension headers (barometer)
   ═══════════════════════════════════════════ */
.dimension-header {
  display: none;
  text-align: center;
  padding: 20px 0 8px;
}
.dimension-header.active {
  display: block;
}
.dimension-tag {
  display: inline-block;
  font-size: 12px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--accent);
  background: var(--accent-soft);
  padding: 4px 16px;
  border-radius: 999px;
  margin-bottom: 12px;
}
.domain-step-tag {
  margin-bottom: 10px;
}
.dimension-header h2 {
  font-size: 1.25rem;
  margin: 0 0 4px;
}
.dimension-header p {
  color: var(--text-secondary);
  font-size: var(--fs-small, .85rem);
  margin: 0;
}

/* ─── Homepage rebuild: funnel blocks ─── */
.section-bridge {
  background: var(--surface);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.value-blocks {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
}
.value-block {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: var(--space-md);
}
.value-block h3 {
  font-size: var(--fs-body);
  margin-bottom: 10px;
}
.value-bullets-card {
  margin-top: var(--space-sm);
}

.pillars-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}
.pillar-item {
  background: var(--surface);
  border-radius: var(--radius-sm);
  border: 1px solid var(--line-soft);
  padding: 18px;
}
.pillar-item h3 {
  font-size: var(--fs-ui);
  margin-bottom: 8px;
}
.pillar-item p {
  margin: 0;
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  line-height: 1.55;
}

.three-phase-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}
.phase-card {
  background: var(--surface);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius);
  padding: var(--space-md);
}
.phase-card h3 {
  font-size: var(--fs-body);
  margin-bottom: 10px;
}
.phase-card p {
  margin: 0;
  color: var(--text-secondary);
  line-height: 1.6;
}

.testimonials-flow {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}
.case-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: var(--space-md);
  margin: 0;
}
.case-card-featured {
  border-left: 3px solid var(--accent);
}
.case-card-headline {
  font-size: var(--fs-body);
  font-weight: 700;
  margin-bottom: 8px;
}
.case-card-body,
.case-card-outcome {
  font-size: var(--fs-ui);
  color: var(--text-secondary);
}
.case-card-outcome {
  margin-bottom: 0;
  color: var(--text);
  font-weight: 600;
}
.case-card-footer {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
  display: flex;
  align-items: center;
  gap: 10px;
}
.case-card-avatar {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  object-fit: cover;
  flex-shrink: 0;
}
.case-card-avatar[src=""],
.case-card-avatar:not([src]) {
  display: none;
}
.case-card-meta {
  display: grid;
  gap: 2px;
}
.case-card-name {
  font-weight: 700;
  font-size: var(--fs-ui);
}
.case-card-role,
.case-card-org,
.case-card-edition {
  font-size: var(--fs-overline);
  color: var(--text-secondary);
}

@media (min-width: 860px) {
  .value-blocks {
    grid-template-columns: repeat(3, 1fr);
  }
  .pillars-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .pillars-grid .pillar-item:last-child {
    grid-column: 1 / -1;
  }
  .three-phase-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .testimonials-flow {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
    grid-auto-rows: 1fr;
  }
  .testimonials-flow .case-card-featured {
    grid-row: span 2;
  }
}

/* ═══════════════════════════════════════════════════════════════
   PREMIUM UX UPGRADE - Animations, polish, refined spacing
   ═══════════════════════════════════════════════════════════════ */

/* ─── Scroll-triggered reveal animations ─── */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes scaleIn {
  from { opacity: 0; transform: scale(0.92); }
  to   { opacity: 1; transform: scale(1); }
}
@keyframes slideInLeft {
  from { opacity: 0; transform: translateX(-24px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes slideInRight {
  from { opacity: 0; transform: translateX(24px); }
  to   { opacity: 1; transform: translateX(0); }
}

.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: none;
}
.reveal.is-revealed {
  animation: fadeInUp 0.7s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.reveal-scale {
  opacity: 0;
  transform: scale(0.92);
}
.reveal-scale.is-revealed {
  animation: scaleIn 0.6s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

/* Staggered card reveals */
.reveal-stagger > .is-revealed:nth-child(1) { animation-delay: 0s; }
.reveal-stagger > .is-revealed:nth-child(2) { animation-delay: 0.08s; }
.reveal-stagger > .is-revealed:nth-child(3) { animation-delay: 0.16s; }
.reveal-stagger > .is-revealed:nth-child(4) { animation-delay: 0.24s; }
.reveal-stagger > .is-revealed:nth-child(5) { animation-delay: 0.30s; }
.reveal-stagger > .is-revealed:nth-child(6) { animation-delay: 0.36s; }

/* ═══════════════════════════════════════════
   Sober overrides - government-grade clarity
   Replaces all premium/gradient/glass effects
   ═══════════════════════════════════════════ */

/* Remove decorative top accent line */
body::before { display: none; }

/* Clean header - no glass */
.site-header {
  background: rgba(255, 255, 255, 0.98);
  border-bottom: 1px solid var(--line);
}

/* Hero - no decorative pseudo-elements, no gradient text */
.hero { position: relative; }
.hero::before { display: none; }
.hero-offer-eyebrow {
  display: inline-block;
  padding: 0;
  background: none;
  border-radius: 0;
  border: none;
}
.hero h1 {
  color: var(--text);
  -webkit-text-fill-color: var(--text);
  background: none;
  -webkit-background-clip: unset;
  background-clip: unset;
}
.hero-lead {
  font-size: clamp(1rem, 0.95rem + 0.2vw, 1.2rem);
  line-height: 1.7;
  color: var(--text-secondary);
}
.hero-info-strip {
  padding: 14px 22px;
  background: var(--surface);
  border-radius: var(--radius-sm);
  border: 1px solid var(--line);
  display: inline-block;
  white-space: nowrap;
  font-size: 15px;
}

/* Hero image - subtle, no heavy shadow */
.hero-image-slot {
  position: relative;
  border: 1px solid var(--line);
}
.image-caption {
  font-size: 14px;
  font-style: italic;
  color: var(--text-secondary);
  padding: 12px 14px 0;
}

/* Proof section - flat, no gradient background */
.proof-section {
  background: var(--surface-muted);
  position: relative;
}
.proof-section::before { display: none; }
.proof-card {
  border-radius: var(--radius);
  padding: 28px;
  border: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.proof-card::after { display: none; }
.proof-card:hover {
  transform: none;
  box-shadow: none;
}
.proof-card-icon {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
}
.proof-card-metric {
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -0.01em;
}

/* Herkenning cards - flat, no hover transform */
.herkenning-card {
  background: var(--surface);
  border-radius: var(--radius);
  border: 1px solid var(--line);
  padding: 22px 22px 22px 58px;
}
.herkenning-card:hover {
  transform: none;
  box-shadow: none;
  border-color: var(--line);
}
.herkenning-number {
  width: 28px;
  height: 28px;
  font-size: 13px;
  left: 18px;
  top: 22px;
}
.herkenning-punchline {
  font-size: var(--fs-h3);
  padding: 20px 0;
  border-top: 2px solid #888;
  border-bottom: none;
  text-align: left;
  max-inline-size: var(--measure-body);
}

/* Contrast cards - sober */
.contrast-card {
  border-radius: var(--radius);
  padding: 24px;
  border: 1px solid var(--line);
}
.contrast-card:hover {
  box-shadow: none;
}
.contrast-card--highlight {
  background: var(--accent);
  border-color: var(--accent);
  border-radius: var(--radius);
  position: relative;
  overflow: hidden;
  grid-column: 1 / -1;
  padding: 28px 24px;
  border-left: none;
}
.contrast-card--highlight::before { display: none; }
.contrast-card--highlight h3 {
  font-size: 1.1rem;
  font-weight: 800;
  margin-bottom: 8px;
  color: #fff;
}
.contrast-card--highlight p {
  color: rgba(255,255,255,.88);
  font-size: 1rem;
  line-height: 1.65;
  max-inline-size: 56ch;
}

/* Value blocks - sober */
.value-block {
  padding: 24px;
  background: var(--surface);
  border-radius: var(--radius);
  border: 1px solid var(--line);
  position: relative;
}
.value-block::before { display: none; }
.value-block:hover {
  transform: none;
  box-shadow: none;
}
.value-block .section-label {
  color: var(--accent);
  font-size: 12px;
  letter-spacing: 0.08em;
}

/* Pillar items - sober */
.pillar-item {
  padding: 24px 20px;
  background: var(--surface);
  border-radius: var(--radius);
  border: 1px solid var(--line);
}
.pillar-item:hover {
  border-color: var(--line);
  box-shadow: none;
}
.pillar-item h3 {
  color: var(--accent);
}

/* Authority / Trainer - sober */
.portrait-card {
  border: 1px solid var(--line);
}
.authority-quote {
  border-radius: var(--radius-sm);
  padding: 24px;
  background: var(--accent);
  font-size: var(--fs-body);
  line-height: 1.55;
}

/* Phase cards - sober */
.phase-card {
  padding: 24px 20px;
  background: var(--surface);
  border-radius: var(--radius);
  border: 1px solid var(--line);
  position: relative;
}
.phase-card::before {
  content: "";
  position: absolute;
  top: 16px;
  left: 20px;
  width: 6px;
  height: 6px;
  background: var(--accent);
  border-radius: 50%;
}
.phase-card h3 {
  padding-left: 18px;
}
.phase-card:hover {
  transform: none;
  box-shadow: none;
}

/* Audience cards - sober */
.audience-card {
  border-radius: var(--radius);
  border: 1px solid var(--line);
}
.audience-card:hover {
  box-shadow: none;
}
.audience-card-neg {
  background: var(--surface-muted);
  border: 1px solid var(--line);
}

/* Metric cards - sober, no gradient numbers */
.metric-card {
  border-radius: var(--radius);
  border: 1px solid var(--line);
}
.metric-card:hover {
  transform: none;
  box-shadow: none;
}
.metric {
  color: var(--accent);
  -webkit-text-fill-color: var(--accent);
  background: none;
  -webkit-background-clip: unset;
  background-clip: unset;
}

/* Quote cards - sober */
.proof-quote-card {
  padding: 24px;
  background: var(--surface);
  border-radius: var(--radius-sm);
  border: 1px solid var(--line);
  border-left: 3px solid var(--accent);
  position: relative;
}
.proof-quote-card::before { display: none; }

/* Binkadvies charts - sober */
.binkadvies-card {
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--line);
}
.binkadvies-card:hover {
  transform: none;
  box-shadow: none;
}

/* FAQ - sober */
details {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  overflow: hidden;
}
details:hover {
  border-color: var(--line);
  box-shadow: none;
}
details[open] {
  border-color: var(--line);
}
summary::after {
  content: "+";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--surface-muted);
  color: var(--accent);
  font-size: 1.1rem;
  font-weight: 700;
  flex-shrink: 0;
}
details[open] summary::after {
  content: "\2212";
  background: var(--accent);
  color: #fff;
}
summary:hover { color: var(--text); }

/* Final CTA - flat dark, no gradient */
.final-cta {
  background: #1a1614;
  position: relative;
}
.final-cta::before { display: none; }
.trust-card {
  border-radius: var(--radius);
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
}

/* Newsletter - clean, no gradient */
.newsletter-section {
  background: var(--surface);
}
.newsletter-form {
  border-radius: var(--radius);
  border: 1px solid var(--line);
}

/* Footer - solid dark */
.site-footer {
  background: #1B1B1B;
}

/* Sticky CTA - clean */
.sticky-cta-bar {
  background: rgba(255, 255, 255, 0.98);
  border-top: 1px solid var(--line);
}

/* Button - clean, no gradient overlay */
.button-primary {
  position: relative;
  overflow: visible;
}
.button-primary::after { display: none; }
.button-primary:hover {
  transform: none;
  box-shadow: none;
}
.button-primary:active {
  transform: none;
}

/* Section dividers - subtle, no gradient */
.section + .section-muted::before,
.section-muted + .section::before { display: none; }

/* Section labels - clean, no decorative dot */
.section-label::before { display: none; }

/* Selection color - accent */
::selection {
  background: rgba(138, 39, 53, 0.15);
  color: var(--text);
}

/* Desktop sober overrides */
@media (min-width: 860px) {
  .proof-cards-grid { gap: 22px; }
  .herkenning-card { padding: 24px 24px 24px 60px; }
  .herkenning-number { left: 20px; top: 24px; }
  .herkenning-grid { gap: 20px; }
  .phase-card { padding: 28px 24px; }
  .phase-card::before { top: 18px; left: 24px; }
  .value-block { padding: 28px 24px; }
  .audience-card { padding: 36px; }
  .proof-quote-card { padding: 28px; }
  .authority-quote { padding: 26px 30px; font-size: var(--fs-lead); }
  .hero-grid { align-items: center; }
}

/* Tablet sober */
@media (min-width: 480px) and (max-width: 859px) {
  .herkenning-grid { gap: 14px; }
  .proof-cards-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .phase-card { padding: 24px 20px; }
}

/* Mobile sober */
@media (max-width: 859px) {
  .proof-card { padding: 20px; }
  .pillar-item { padding: 20px 16px; }
  .phase-card { padding: 20px 16px; }
  .phase-card::before { top: 12px; left: 16px; width: 5px; height: 5px; }
  .phase-card h3 { padding-left: 16px; }
  .value-block { padding: 20px 16px; }
  .proof-quote-card { padding: 20px; }
  details { border-radius: var(--radius-sm); }
}

/* ═══════════════════════════════════════════
   MOBILE UX - Rijksoverheid/Gemeente principles
   Focus: breathing room, hierarchy, readability,
   touch targets, visual separation, scanability
   ═══════════════════════════════════════════ */
@media (max-width: 859px) {

  /* ── A. HERO: Generous vertical rhythm & readability ── */
  .hero {
    padding: 28px 0 32px;
  }
  .hero-grid {
    gap: 28px;
  }
  .hero-offer-eyebrow {
    margin-bottom: 10px;
    font-size: 12px;
    letter-spacing: 0.08em;
  }
  .hero-doelgroep {
    margin-bottom: 16px;
    font-size: 14px;
    line-height: 1.4;
  }
  .hero-copy h1 {
    font-size: clamp(1.5rem, 5.5vw, 2rem);
    line-height: 1.18;
    margin-bottom: 20px;
    letter-spacing: -0.02em;
  }
  .hero-lead {
    font-size: 1rem;
    line-height: 1.65;
    margin-bottom: 14px;
    color: var(--text-secondary);
  }
  .hero-lead:last-of-type {
    margin-bottom: 20px;
  }
  .hero-lead strong {
    color: var(--text);
  }

  /* Hero USPs: card-like feel, more air */
  .hero-usps {
    margin: 8px 0 24px;
    gap: 8px;
    padding: 16px;
    background: var(--surface);
    border-radius: var(--radius-sm);
    border: 1px solid var(--line);
  }
  .hero-usps li {
    font-size: 15px;
    line-height: 1.5;
    padding-left: 1.5em;
    padding-top: 2px;
    padding-bottom: 2px;
  }
  .hero-usps li::before {
    left: 0;
    top: 2px;
  }

  /* Hero CTA: centered, full-width, prominent */
  .hero-actions {
    margin-top: 4px;
    gap: 10px;
  }
  .hero-actions .button-xl {
    min-height: 56px;
    font-size: 1rem;
    font-weight: 800;
    border-radius: 6px;
  }
  .hero-secondary-cta {
    margin-top: 4px;
    font-size: 14px;
  }
  .hero-info-strip {
    margin-top: 16px;
    font-size: 13px;
    text-align: center;
    padding: 10px 14px;
    background: var(--surface);
    border-radius: var(--radius-sm);
    border: 1px solid var(--line);
    white-space: normal;
    line-height: 1.4;
  }

  /* Hero image: constrained height, better crop */
  .hero-image-slot img {
    border-radius: var(--radius-sm);
    max-height: 50vh;
    object-position: center 20%;
  }
  .hero-image-slot .image-caption {
    font-size: 13px;
    margin-top: 8px;
    text-align: center;
    color: var(--text-secondary);
  }

  /* ── B. PROOF SECTION: stacked cards with clear separation ── */
  .proof-section {
    padding: 40px 0;
  }
  .proof-accent-label {
    font-size: 12px;
    letter-spacing: 0.08em;
    margin-bottom: 6px;
  }
  .proof-heading {
    font-size: clamp(1.4rem, 5vw, 1.8rem);
    margin-bottom: 10px;
    line-height: 1.15;
  }
  .proof-intro {
    font-size: 15px;
    line-height: 1.6;
    margin-bottom: 24px;
  }
  .proof-cards-grid {
    gap: 12px;
    margin-bottom: 24px;
  }
  .proof-card {
    padding: 20px;
    position: relative;
    border: 1px solid rgba(0,0,0,0.04);
  }
  .proof-card-icon {
    width: 28px;
    height: 28px;
    margin-bottom: 10px;
  }
  .proof-card-icon .icon {
    width: 20px;
    height: 20px;
  }
  .proof-card-metric {
    font-size: 16px;
    margin-bottom: 3px;
  }
  .proof-card-label {
    font-size: 11px;
    letter-spacing: 0.08em;
    margin-bottom: 6px;
  }
  .proof-card-body {
    font-size: 14px;
    line-height: 1.55;
  }
  .proof-card-logo {
    width: 44px;
    bottom: 10px;
    right: 10px;
  }
  .proof-cta-row {
    margin-top: 4px;
    gap: 10px;
    align-items: center;
  }
  .proof-cta-row .button {
    width: 100%;
    min-height: 52px;
  }

  /* ── C. HERKENNING: cards scannable on small screens ── */
  .herkenning-section {
    padding: 40px 0;
  }
  .herkenning-heading {
    font-size: clamp(1.4rem, 5vw, 1.8rem);
    line-height: 1.15;
    margin-bottom: 8px;
  }
  .herkenning-intro {
    font-size: 15px;
    line-height: 1.6;
    margin-bottom: 24px;
  }
  .herkenning-grid {
    gap: 10px;
    margin-bottom: 24px;
  }
  .herkenning-card {
    padding: 16px 16px 16px 50px;
    border-radius: 12px;
  }
  .herkenning-number {
    left: 14px;
    top: 16px;
    width: 26px;
    height: 26px;
    font-size: 13px;
  }
  .herkenning-card-title {
    font-size: 15px;
    margin-bottom: 4px;
    line-height: 1.3;
  }
  .herkenning-card-body {
    font-size: 14px;
    line-height: 1.55;
  }
  .herkenning-punchline {
    font-size: clamp(1.1rem, 4vw, 1.35rem);
    line-height: 1.3;
    padding: 16px 0 8px;
  }
  .herkenning-cta-row {
    gap: 10px;
    align-items: center;
  }
  .herkenning-cta-row .button {
    width: 100%;
    min-height: 52px;
  }
  .herkenning-cta-tertiary {
    text-align: center;
  }
  .herkenning-cta-tertiary a {
    font-size: 13px;
  }

  /* ── D. CONTRAST SECTION: compact but readable ── */
  .contrast-grid {
    gap: 10px;
    margin-top: 20px;
  }
  .contrast-card {
    padding: 18px;
    border-radius: 12px;
  }
  .contrast-card h3 {
    font-size: 15px;
    margin-bottom: 4px;
  }
  .contrast-card p {
    font-size: 14px;
    line-height: 1.55;
  }
  .contrast-card--highlight {
    padding: 24px 20px;
    border-left-width: 4px;
  }
  .contrast-card--highlight h3 {
    font-size: 1rem;
  }
  .contrast-card--highlight p {
    font-size: 14px;
    line-height: 1.6;
  }

  /* ── E. VALUE BLOCKS (Wat je koopt) ── */
  .value-blocks {
    gap: 10px;
  }
  .value-block {
    padding: 20px 18px;
    border-radius: 12px;
  }
  .value-block .section-label {
    font-size: 11px;
    margin-bottom: 6px;
  }
  .value-block h3 {
    font-size: 17px;
    margin-bottom: 6px;
  }
  .value-block p {
    font-size: 14px;
    line-height: 1.6;
  }

  /* ── F. PILLARS (Bedrijfsritme) ── */
  .pillars-grid {
    gap: 10px;
  }
  .pillar-item {
    padding: 18px 16px;
    border-radius: 12px;
  }
  .pillar-item h3 {
    font-size: 15px;
    margin-bottom: 4px;
  }
  .pillar-item p {
    font-size: 14px;
    line-height: 1.55;
  }
  .pillars-dashboard-line {
    margin-top: 16px;
    font-size: 12px;
    letter-spacing: 0.1em;
  }
  .bedrijfsritme-bold {
    font-size: 15px;
    line-height: 1.6;
    margin-top: 16px;
  }

  /* ── G. SECTION LABELS & HEADINGS: Gemeente-style clear hierarchy ── */
  .section-label,
  .eyebrow {
    font-size: 11px;
    letter-spacing: 0.08em;
    margin-bottom: 8px;
    line-height: 1.3;
  }
  h2 {
    font-size: clamp(1.4rem, 5vw, 1.8rem);
    line-height: 1.15;
    margin-bottom: 12px;
  }
  .section-intro {
    font-size: 15px;
    line-height: 1.6;
    margin-bottom: 20px;
  }
  .split-head {
    margin-bottom: 24px;
  }
  .section-head {
    margin-bottom: 20px;
  }

  /* ── H. BEWIJS SECTION: metrics scannable on mobile ── */
  .metric-grid {
    gap: 10px;
  }
  .metric-card {
    padding: 16px;
    border-radius: 12px;
  }
  .metric {
    font-size: clamp(1.5rem, 5vw, 2rem);
    margin-bottom: 4px;
  }
  .metric-card h3 {
    font-size: 14px;
    margin-bottom: 4px;
  }
  .metric-card p {
    font-size: 13px;
    line-height: 1.5;
  }
  .metric-bron {
    font-size: 11px;
    margin-top: 4px;
  }
  .proof-extra-line {
    font-size: 15px;
    line-height: 1.6;
    margin-top: 20px;
  }
  .proof-quotes {
    gap: 10px;
    margin-top: 24px;
  }
  .proof-quote-card {
    padding: 18px;
    border-radius: 12px;
  }
  .proof-quote-card p {
    font-size: 15px;
    line-height: 1.5;
  }
  .proof-quote-bron {
    font-size: 13px;
  }

  /* ── I. OVER SAMIR: portrait + readable story ── */
  .authority-grid {
    gap: 20px;
  }
  .portrait-card img {
    border-radius: var(--radius-sm);
    max-height: 50vh;
    object-fit: cover;
  }
  .authority-headline {
    font-size: clamp(1.2rem, 4.5vw, 1.5rem);
    line-height: 1.25;
    margin-bottom: 10px;
  }
  .authority-lead {
    font-size: 15px;
    line-height: 1.6;
    margin-bottom: 12px;
  }
  .authority-body {
    font-size: 15px;
    line-height: 1.65;
    margin-bottom: 12px;
  }
  .authority-quote {
    font-size: 16px;
    line-height: 1.5;
    padding: 16px 18px;
    margin: 16px 0 12px;
    border-radius: 12px;
  }
  .authority-cta-block {
    margin-top: 16px;
  }
  .authority-cta-block .button {
    width: 100%;
    min-height: 52px;
  }

  /* ── J. THREE PHASES (Beslistraject) ── */
  .three-phase-grid {
    gap: 10px;
  }
  .phase-card {
    padding: 20px 18px;
    border-radius: 12px;
  }
  .phase-card h3 {
    font-size: 15px;
    margin-bottom: 4px;
  }
  .phase-card p {
    font-size: 14px;
    line-height: 1.55;
  }

  /* ── K. VOOR WIE: audience cards, checklist readable ── */
  .two-cards {
    gap: 12px;
  }
  .audience-card {
    padding: 20px;
    border-radius: 12px;
  }
  .audience-card h3 {
    font-size: 16px;
    line-height: 1.3;
    margin-bottom: 12px;
  }
  .checklist {
    gap: 8px;
  }
  .checklist li {
    font-size: 14px;
    line-height: 1.55;
    padding-left: 24px;
    position: relative;
  }

  /* ── L. PRAKTISCH / SESSIONS ── */
  .session-card--featured {
    border-radius: var(--radius-sm);
    margin-left: 0;
    margin-right: 0;
    border: 2px solid var(--accent);
    padding: 20px;
  }
  .price {
    font-size: clamp(1.8rem, 8vw, 2.25rem);
  }
  .practical-list div {
    padding: 8px 0;
  }
  .practical-list dt {
    font-size: 11px;
  }
  .practical-list dd {
    font-size: 14px;
  }
  .private-session-link {
    font-size: 13px;
    margin-top: 16px;
    padding-top: 16px;
    text-align: center;
  }

  /* ── M. FAQ: generous touch targets, comfortable reading ── */
  .faq-list {
    gap: 8px;
  }
  summary {
    padding: 14px 16px;
    min-height: 48px;
    font-size: 1rem;
    line-height: 1.35;
    font-weight: 700;
    border-radius: 12px;
  }
  summary::after {
    flex-shrink: 0;
    margin-left: 12px;
  }
  details p {
    padding: 0 16px 14px;
    font-size: 15px;
    line-height: 1.65;
  }

  /* ── N. FINAL CTA: clear and prominent ── */
  .final-cta-grid {
    gap: 20px;
  }
  .final-cta-copy h2 {
    font-size: clamp(1.3rem, 5vw, 1.7rem);
    line-height: 1.2;
  }
  .final-cta-copy p {
    font-size: 15px;
    line-height: 1.6;
  }
  .final-cta-copy .button-xl {
    width: 100%;
    min-height: 56px;
    font-size: 1rem;
  }
  .trust-card {
    padding: 18px;
    border-radius: 12px;
  }
  .trust-list {
    gap: 10px;
  }
  .trust-list li {
    font-size: 14px;
    line-height: 1.45;
    min-height: 28px;
    display: flex;
    align-items: center;
    gap: 10px;
  }

  /* ── O. NEWSLETTER: compact but accessible ── */
  .newsletter-section {
    padding: 32px 0;
  }
  .newsletter-section h2 {
    font-size: clamp(1.3rem, 5vw, 1.7rem);
    margin-bottom: 8px;
  }
  .newsletter-section p {
    font-size: 15px;
    line-height: 1.6;
  }
  .newsletter-form {
    padding: 20px;
    border-radius: 12px;
  }
  .newsletter-form label span {
    font-size: 14px;
  }
  .newsletter-form input {
    min-height: 48px;
    font-size: 16px; /* prevents iOS zoom */
  }
  .newsletter-submit {
    min-height: 48px;
    font-size: 15px;
  }

  /* ── P. FOOTER: legible, tappable links ── */
  .site-footer {
    padding: 24px 0 16px;
  }
  .footer-bottom {
    gap: 12px;
    font-size: 13px;
  }
  .footer-bottom nav {
    flex-wrap: wrap;
    gap: 8px 16px;
  }
  .footer-bottom nav a,
  .footer-bottom nav button {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    font-size: 14px;
  }

  /* ── Q. NAVIGATION: mobile menu usability ── */
  .site-nav {
    padding: 16px 20px;
    border-radius: 14px;
    gap: 0;
  }
  .site-nav a {
    padding: 12px 0;
    min-height: 48px;
    font-size: 16px;
    font-weight: 600;
    border-bottom: 1px solid var(--line);
  }
  .site-nav a:last-child {
    border-bottom: none;
  }

  /* ── R. STICKY CTA BAR: refined ── */
  .sticky-cta-bar {
    padding: 10px var(--side-pad) calc(env(safe-area-inset-bottom, 0px) + 10px);
  }
  .sticky-cta-btn {
    min-height: 48px;
    font-size: 15px;
    border-radius: 999px;
  }
  .sticky-cta-link {
    display: none;
  }
  .sticky-mini-scan-wrap {
    margin-top: 4px;
  }
  .sticky-mini-scan-wrap .mini-scan-link {
    font-size: 12px;
  }

  /* ── S. BINKADVIES: charts still usable ── */
  .binkadvies-card {
    padding: 16px;
    border-radius: 12px;
  }
  .binkadvies-card h4 {
    font-size: 15px;
    margin-bottom: 4px;
  }
  .binkadvies-summary {
    font-size: 13px;
    line-height: 1.5;
  }
  .binkadvies-footnote {
    font-size: 11px;
  }

  /* ── T. TESTIMONIALS: compact cards ── */
  .case-card {
    padding: 20px;
    border-radius: 12px;
  }
  .case-card-headline {
    font-size: 15px;
    line-height: 1.4;
    margin-bottom: 8px;
  }
  .case-card-body {
    font-size: 14px;
    line-height: 1.6;
    margin-bottom: 12px;
  }
  .case-card-outcome {
    font-size: 14px;
    line-height: 1.5;
    padding: 10px 12px;
    margin-bottom: 14px;
    border-radius: 10px;
  }
  .case-card-footer {
    padding-top: 12px;
    gap: 10px;
  }
  .case-card-name:not(:empty) {
    font-size: 13px;
  }
  .case-card-role {
    font-size: 12px;
  }

  /* ── U. RESULTATEN BLOK ── */
  .resultaten-blok {
    padding: 32px 0 40px;
  }
  .resultaten-grid {
    gap: 10px;
  }
  .resultaat-card {
    padding: 16px;
    border-radius: 12px;
  }
  .resultaat-metric {
    font-size: clamp(1.4rem, 5vw, 1.8rem);
  }
  .resultaat-card h3 {
    font-size: 14px;
  }
  .resultaat-toelichting {
    font-size: 13px;
    line-height: 1.5;
  }

  /* ── V. GENERAL: vertical rhythm & whitespace ── */
  /* Consistent section spacing following gemeente style */
  :root {
    --space-section-y-mobile: 40px;
  }
  .section {
    padding: 40px 0;
  }
  .section + .section {
    margin-top: 0;
  }

  /* Prevent orphans in headings */
  h1, h2, h3 {
    text-wrap: balance;
  }

  /* All buttons: min 48px touch target (WCAG) */
  .button {
    min-height: 48px;
    padding: 0.75rem 1.5rem;
  }

  /* Card border-radius consistency */
  .proof-card,
  .herkenning-card,
  .contrast-card,
  .value-block,
  .pillar-item,
  .phase-card,
  .audience-card,
  .metric-card,
  .case-card,
  .resultaat-card,
  .proof-quote-card,
  .trust-card,
  .binkadvies-card {
    border-radius: 12px;
  }

  /* Images: consistent rounded corners */
  .hero-image-slot img,
  .portrait-card img {
    border-radius: 12px;
  }
}

/* ─── Very small screens: extra refinements ─── */
@media (max-width: 420px) {
  .hero-copy h1 {
    font-size: clamp(1.3rem, 6vw, 1.65rem);
    line-height: 1.2;
  }
  .hero-lead {
    font-size: 15px;
  }
  .hero-usps {
    padding: 14px;
  }
  .hero-usps li {
    font-size: 14px;
  }
  .herkenning-card {
    padding: 14px 14px 14px 46px;
  }
  .herkenning-number {
    left: 12px;
    top: 14px;
    width: 24px;
    height: 24px;
    font-size: 12px;
  }
  .proof-card {
    padding: 16px;
  }
  .proof-card-metric {
    font-size: 15px;
  }
  .metric-card {
    padding: 14px;
  }
  .audience-card {
    padding: 16px;
  }
  .case-card {
    padding: 16px;
  }
  .value-block {
    padding: 16px;
  }
  .pillar-item {
    padding: 16px 14px;
  }
}

/* ─── Reduced motion: disable animations ─── */
@media (prefers-reduced-motion: reduce) {
  .reveal,
  .reveal-scale {
    opacity: 1;
    transform: none;
    transition: none;
    animation: none;
  }
  .reveal.is-revealed,
  .reveal-scale.is-revealed {
    animation: none;
    opacity: 1;
    transform: none;
  }
  .hero-usps li:hover { transform: none; }
  .proof-card:hover,
  .herkenning-card:hover,
  .contrast-card:hover,
  .value-block:hover,
  .pillar-item:hover,
  .metric-card:hover,
  .phase-card:hover,
  .binkadvies-card:hover {
    transform: none;
  }
  .button-primary:hover {
    transform: none;
  }
}

/* UX/IA a11y pass overrides */
.breadcrumb {
  margin: 20px 0 8px;
  font-size: var(--fs-ui);
}
.breadcrumb ol {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.breadcrumb li {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.breadcrumb li + li::before {
  content: "/";
  color: var(--text-secondary);
  margin-right: 8px;
}
.breadcrumb a {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}

.hero-offer-eyebrow {
  margin-bottom: 8px;
}
.hero-doelgroep {
  margin-bottom: 12px;
  font-size: 14px;
  line-height: 1.45;
}
.hero-doelgroep u {
  text-decoration: none;
}
.hero-lead--verified {
  margin-bottom: 14px;
}
.hero-info-strip {
  margin-top: 16px;
  font-size: 14px;
  font-weight: 500;
}

.form-error-summary {
  background: #fff;
  border: 2px solid var(--accent);
  border-radius: var(--radius-sm);
  padding: 14px 16px;
  margin: 0 0 18px;
}
.form-error-summary h3 {
  margin: 0 0 8px;
  font-size: 1rem;
}
.form-error-summary ul {
  margin: 0;
  padding-left: 18px;
}
.form-error-summary li {
  margin: 0;
}
.form-error-summary a {
  font-weight: 600;
}

.register-form input,
.register-form select,
.register-form textarea,
.register-form button,
.footer-bottom nav a,
.footer-bottom nav button,
.text-link,
.cookie-settings-trigger {
  min-height: 44px;
}

.register-form input[aria-invalid="true"],
.register-form select[aria-invalid="true"],
.register-form textarea[aria-invalid="true"],
.register-form input[type="checkbox"][aria-invalid="true"] {
  border-color: #a32132;
}

.site-footer .footer-bottom {
  gap: 16px;
}
.site-footer .footer-bottom nav {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
}

@media (max-width: 768px) {
  .breadcrumb {
    margin-top: 14px;
  }
  .breadcrumb ol {
    gap: 6px;
  }
  .site-footer .footer-bottom nav {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* SEA LP utility: keep focus on the primary conversion path */
body[data-page-type="ads_lp"] .site-header.simple .header-inner {
  align-items: center;
}

body[data-page-type="ads_lp"] .hero {
  padding-top: clamp(2.5rem, 5vw, 4rem);
}

/* ═══════════════════════════════════════════
   Organisatie-lekt section - Rijksoverheid-style
   ═══════════════════════════════════════════ */
.organisatie-lekt-section {
  padding-top: var(--space-xl);
  padding-bottom: var(--space-xl);
}
.organisatie-lekt-heading {
  font-size: clamp(1.5rem, 3vw, 2.15rem);
  line-height: 1.3;
  font-weight: 700;
  max-width: 38ch;
  margin-bottom: var(--space-sm);
  color: var(--text);
}
.organisatie-lekt-intro {
  font-size: clamp(1rem, 1.15vw, 1.125rem);
  line-height: 1.75;
  color: var(--text-secondary);
  max-width: 60ch;
  margin-bottom: var(--space-lg);
}
.organisatie-lekt-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}
@media (min-width: 768px) {
  .organisatie-lekt-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
  }
}
.organisatie-lekt-card {
  background: var(--surface);
  border-radius: var(--radius);
  padding: var(--space-md) var(--space-md) var(--space-md);
  border: 1px solid var(--line);
  border-left: 4px solid var(--accent);
}
.organisatie-lekt-icon {
  width: 40px;
  height: 40px;
  margin-bottom: var(--space-sm);
  color: var(--accent);
}
.organisatie-lekt-icon svg {
  width: 100%;
  height: 100%;
}
.organisatie-lekt-card h3 {
  font-size: 1.05rem;
  font-weight: 700;
  margin-bottom: 10px;
  color: var(--text);
  line-height: 1.38;
}
.organisatie-lekt-card p {
  font-size: 0.95rem;
  line-height: 1.7;
  color: var(--text-secondary);
  margin: 0;
}
.organisatie-lekt-divider {
  border-top: 2px solid #888;
  padding-top: var(--space-md);
  margin-top: var(--space-md);
}
.organisatie-lekt-werkzin {
  font-size: clamp(1rem, 1.15vw, 1.125rem);
  line-height: 1.75;
  color: var(--text);
  text-align: center;
  max-width: 56ch;
  margin: 0 auto;
}

/* ═══════════════════════════════════════════
   Bedrijfsritme systeemregel + slotregel
   ═══════════════════════════════════════════ */
.bedrijfsritme-systeemregel {
  margin: var(--space-lg) 0 0;
  font-size: var(--fs-body);
  font-weight: 600;
  color: var(--text);
  line-height: 1.55;
  max-inline-size: var(--measure-body);
  font-style: italic;
}
.bedrijfsritme-slotregel {
  margin-top: var(--space-lg);
  padding: 28px var(--space-md);
  background: #f0f8f2;
  border-left: 4px solid #27ae60;
  border-radius: var(--radius);
  text-align: left;
  color: var(--text);
}
.bedrijfsritme-slotregel-label {
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 8px;
  opacity: 0.7;
  color: #1e7a45;
}
.bedrijfsritme-slotregel-body {
  font-size: clamp(1rem, 1.15vw, 1.1rem);
  line-height: 1.65;
  margin: 0;
  color: var(--text);
}

/* ═══════════════════════════════════════════
   Bewezen Resultaten section
   ═══════════════════════════════════════════ */
.bewezen-resultaten-section .section-head {
  margin-bottom: var(--space-md);
}
.bewezen-resultaten-body {
  font-size: clamp(1rem, 1.15vw, 1.1rem);
  line-height: 1.75;
  color: var(--text-secondary);
  max-width: 60ch;
  margin-bottom: var(--space-lg);
}
.bewezen-quotes {
  margin-bottom: var(--space-lg);
}
.bewezen-quote-card {
  position: relative;
}
.bewezen-quote-logo-row {
  margin-bottom: var(--space-sm);
}
.bewezen-quote-logo {
  height: 36px;
  width: auto;
  object-fit: contain;
  filter: grayscale(0.15);
  opacity: 0.92;
}
.zo-landt-dit {
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-xs);
  border-bottom: 2px solid var(--accent);
}
.zo-landt-dit .section-label {
  margin-bottom: 0;
}

/* Bewijs link in Samir section */
.bewijs-link {
  border-color: var(--accent);
  color: var(--accent);
}
.bewijs-link:hover {
  background: var(--accent);
  color: #fff;
}

/* ═══════════════════════════════════════════
   ZO LANDT DIT - Bridge heading
   ═══════════════════════════════════════════ */
.zo-landt-dit-bridge {
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 2px solid var(--accent);
}
.zo-landt-dit-bridge .section-label {
  margin-bottom: var(--space-xs);
}
.zo-landt-dit-intro {
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--text-secondary);
  margin: 0;
  max-width: 56ch;
}

/* ═══════════════════════════════════════════
   Authority checklist (Wat daaruit ontstond)
   ═══════════════════════════════════════════ */
.authority-checklist {
  list-style: none;
  padding: 0;
  margin: 0.85em 0 1.5em;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.authority-checklist li {
  display: flex;
  align-items: flex-start;
  gap: 0.7rem;
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--text);
}
.authority-checklist .icon-check {
  width: 22px;
  height: 22px;
  flex-shrink: 0;
  margin-top: 3px;
}

/* ═══════════════════════════════════════════
   VOOR WIE - Wel / Niet cards (Rijksoverheid)
   ═══════════════════════════════════════════ */
.voor-wie-cards {
  gap: var(--space-md);
}
.audience-card-wel,
.audience-card-niet {
  border-radius: var(--radius);
  padding: 30px 26px;
  border: 1px solid var(--line-soft);
}
.audience-card-wel {
  background: var(--surface);
  border-left: 4px solid #27ae60;
}
.audience-card-niet {
  background: var(--accent-soft);
  border-left: 4px solid #8c8c8c;
  border-color: transparent;
  border-left-color: #8c8c8c;
}
.audience-card-header {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  margin-bottom: 1.15rem;
}
.audience-card-icon {
  width: 30px;
  height: 30px;
  flex-shrink: 0;
}
.audience-card-header h3 {
  font-size: var(--fs-body);
  font-weight: 700;
  margin: 0;
  line-height: var(--lh-short);
}
.checklist--wel li::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 6L9 17l-5-5' stroke='%2327ae60' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
  flex-shrink: 0;
  margin-top: 2px;
}
.checklist--niet li::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M18 6L6 18M6 6l12 12' stroke='%238c8c8c' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
  flex-shrink: 0;
  margin-top: 2px;
}
.checklist--wel li,
.checklist--niet li {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  line-height: 1.55;
}
.checklist--niet li {
  color: var(--text-secondary);
  font-size: var(--fs-ui);
}
@media (min-width: 768px) {
  .voor-wie-cards {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
  }
  .audience-card-wel,
  .audience-card-niet {
    padding: 38px 34px;
  }
}

/* ═══════════════════════════════════════════
   Quote highlight box (proefballon)
   ═══════════════════════════════════════════ */
.quote-highlight-box {
  margin: var(--space-lg) 0;
}
.quote-highlight {
  position: relative;
  background: var(--accent-soft);
  border: 1px solid rgba(138,39,53,0.10);
  border-left: 4px solid var(--accent);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 30px 34px;
  margin: 0;
  font-style: normal;
}
.quote-highlight p {
  font-size: var(--fs-lead);
  line-height: var(--lh-lead);
  color: var(--text);
  font-weight: 600;
  margin: 0;
  max-width: 52ch;
}
@media (min-width: 768px) {
  .quote-highlight {
    padding: 38px 48px;
  }
}

/* ═══════════════════════════════════════════
   Doorlinks (arrow links)
   ═══════════════════════════════════════════ */
.text-link--arrow {
  font-size: var(--fs-body);
  font-weight: 600;
  color: var(--link);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.text-link--arrow:hover {
  color: var(--link-hover);
}
.bedrijfsritme-doorlink,
.authority-doorlink {
  margin-top: var(--space-sm);
}

/* ═══════════════════════════════════════════
   Bedrijfsritme-systeem page
   ═══════════════════════════════════════════ */
.page-intro-lead {
  font-size: var(--fs-lead);
  line-height: var(--lh-lead);
  color: var(--text);
  font-weight: 600;
  margin-bottom: 0.85em;
  max-width: var(--measure-lead);
}
.page-intro-body {
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--text-secondary);
  margin-bottom: 1.1em;
  max-width: var(--measure-body);
}
.page-body-text {
  font-size: var(--fs-body);
  line-height: var(--lh-body-wide);
  color: var(--text);
  max-width: var(--measure-body);
}
.intro-questions {
  list-style: none;
  padding: 0;
  margin: 0.85em 0 1.4em;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.intro-questions li {
  position: relative;
  padding-left: 1.6rem;
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--text);
}
.intro-questions li::before {
  content: "\2014";
  position: absolute;
  left: 0;
  color: var(--accent);
  font-weight: 700;
}

/* Bouwstenen grid */
.bouwstenen-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}
.bouwsteen-card {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius);
  padding: 26px 22px;
  padding-left: 60px;
  transition: box-shadow 0.2s ease;
}
.bouwsteen-card:hover {
  box-shadow: var(--shadow);
}
.bouwsteen-nummer {
  position: absolute;
  left: 20px;
  top: 24px;
  width: 28px;
  height: 28px;
  background: #888;
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  font-weight: 700;
  line-height: 1;
}
.bouwsteen-card h3 {
  font-size: var(--fs-body);
  font-weight: 700;
  margin: 0 0 8px;
}
.bouwsteen-card p {
  font-size: var(--fs-ui);
  line-height: 1.6;
  color: var(--text-secondary);
  margin: 0;
}
@media (min-width: 768px) {
  .bouwstenen-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
  }
  .bouwsteen-card {
    padding: 28px 24px 28px 60px;
  }
  .bouwsteen-nummer {
    left: 24px;
    top: 28px;
  }
}

/* Systeem contrast grid (niet/wel) */
.systeem-contrast-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
}
.systeem-contrast-card {
  border-radius: var(--radius);
  padding: 26px 22px;
}
.systeem-contrast-niet {
  background: var(--accent-soft);
  border-left: 4px solid #8c8c8c;
}
.systeem-contrast-wel {
  background: var(--surface);
  border-left: 4px solid #27ae60;
}
.systeem-contrast-card h3 {
  font-size: var(--fs-h3);
  font-weight: 700;
  margin: 0 0 var(--space-sm);
}
.systeem-contrast-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}
.systeem-contrast-list li {
  position: relative;
  padding-left: 1.6rem;
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--text-secondary);
}
.systeem-contrast-list li::before {
  content: "\2715";
  position: absolute;
  left: 0;
  color: #8c8c8c;
  font-weight: 700;
}
.systeem-contrast-wel p {
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--text);
  margin: 0;
  font-weight: 500;
}
@media (min-width: 768px) {
  .systeem-contrast-grid {
    grid-template-columns: 1fr 1fr;
  }
  .systeem-contrast-card {
    padding: 34px 30px;
  }
}

/* Systeem CTA */
.systeem-cta-section {
  text-align: center;
}
.systeem-cta-block {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  align-items: center;
}
@media (min-width: 480px) {
  .systeem-cta-block {
    flex-direction: row;
    justify-content: center;
  }
}

/* ═══════════════════════════════════════════
   Samir Khayar page
   ═══════════════════════════════════════════ */
.samir-verhaal-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-lg);
  align-items: start;
}
.samir-portret-figure {
  margin: 0;
}
.samir-portret-figure img {
  width: 100%;
  height: auto;
  border-radius: var(--radius);
  object-fit: cover;
  aspect-ratio: 3 / 2;
}
.samir-alinea {
  font-size: var(--fs-body);
  line-height: var(--lh-body-wide);
  color: var(--text);
  margin-bottom: 1.5em;
  max-width: var(--measure-body);
}
.samir-alinea:last-child {
  margin-bottom: 0;
}
@media (min-width: 768px) {
  .samir-verhaal-grid {
    grid-template-columns: 1fr 1.5fr;
    gap: var(--space-xl);
  }
}

/* Samir featured quote */
.samir-featured-quote {
  position: relative;
  background: var(--accent-soft);
  border: 1px solid rgba(138,39,53,0.10);
  border-left: 4px solid var(--accent);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 34px 38px;
  margin: 0;
  font-style: normal;
  text-align: center;
}
.samir-featured-quote p {
  font-size: var(--fs-lead);
  line-height: var(--lh-lead);
  color: var(--text);
  font-weight: 600;
  margin: 0;
}

/* Samir proof strip */
.samir-proof-strip {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  padding: var(--space-md) 0;
}
.samir-proof-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 6px;
}
.samir-proof-metric {
  font-size: var(--fs-h3);
  font-weight: 800;
  color: var(--accent);
  line-height: 1.15;
}
.samir-proof-label {
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  line-height: var(--lh-ui);
}
.samir-proof-divider {
  width: 40px;
  height: 2px;
  background: var(--line-soft);
  margin: 0 auto;
}
@media (min-width: 600px) {
  .samir-proof-strip {
    flex-direction: row;
    justify-content: center;
    align-items: center;
    gap: var(--space-lg);
  }
  .samir-proof-divider {
    width: 2px;
    height: 40px;
    margin: 0;
  }
}

/* Samir CTA */
.samir-cta-section {
  text-align: center;
}
.samir-cta-block {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  align-items: center;
}
@media (min-width: 480px) {
  .samir-cta-block {
    flex-direction: row;
    justify-content: center;
  }
}

/* ═══════════════════════════════════════════
   DRIE FASEN - enhanced UX
   ═══════════════════════════════════════════ */
.three-phase-grid .phase-card {
  position: relative;
  padding: 28px 24px;
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border: 1px solid rgba(0,0,0,0.04);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.three-phase-grid .phase-card::before {
  display: none;
}
.three-phase-grid .phase-card::after {
  display: none;
}
.three-phase-grid .phase-card h3 {
  font-size: var(--fs-body);
  font-weight: 700;
  margin: 0 0 8px;
}
.three-phase-grid .phase-card p {
  font-size: var(--fs-ui);
  line-height: var(--lh-body);
  color: var(--text-secondary);
  margin: 0;
}
@media (min-width: 768px) {
  .three-phase-grid {
    grid-template-columns: 1fr 1fr 1fr;
    gap: var(--space-md);
  }
  .three-phase-grid .phase-card {
    padding: 32px 28px;
  }
  .three-phase-grid .phase-card::before {
    display: none;
  }
  .three-phase-grid .phase-card::after {
    display: none;
  }
}

/* ═══════════════════════════════════════════
   UX-POLISH - Rijksoverheid-grade overrides
   Sober, flat, accessible, no decoration
   ═══════════════════════════════════════════ */

/* ─── Organisatie-lekt section ─── */
.organisatie-lekt-section { padding: var(--space-xl) 0; }
.organisatie-lekt-heading {
  font-size: var(--fs-h2);
  font-weight: 800;
  line-height: var(--lh-tight);
  margin: 0 0 var(--space-heading-below-md);
}
.organisatie-lekt-intro {
  font-size: var(--fs-body);
  color: var(--text-secondary);
  line-height: var(--lh-body);
  margin: 0 0 var(--space-lg);
  max-inline-size: var(--measure-body);
}
.organisatie-lekt-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-bottom: var(--space-md);
}
.organisatie-lekt-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 22px;
}
.organisatie-lekt-icon {
  width: 28px;
  height: 28px;
  margin-bottom: 10px;
  color: var(--accent);
}
.organisatie-lekt-icon svg {
  width: 100%;
  height: 100%;
}
.organisatie-lekt-card h3 {
  font-size: var(--fs-body);
  font-weight: 700;
  margin: 0 0 8px;
}
.organisatie-lekt-card p {
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  line-height: var(--lh-body);
  margin: 0;
  max-inline-size: var(--measure-card);
}
.organisatie-lekt-divider {
  margin-top: var(--space-md);
  padding: 18px 22px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  border-left: 3px solid var(--accent);
}
.organisatie-lekt-werkzin {
  margin: 0;
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  max-inline-size: var(--measure-body);
}
@media (min-width: 860px) {
  .organisatie-lekt-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
}

/* ─── Announcement bar - ultra sober ─── */
.announcement-bar {
  background: #FFF9E6;
  border-bottom: 1px solid #F0E4B0;
  padding: 10px 0;
  font-size: var(--fs-small);
  font-weight: 600;
  color: #7a6b2a;
  text-align: center;
}
.announcement-bar-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.announcement-bar-text {
  max-inline-size: none;
}

/* ─── Proofbar items: no hover transform, no gradient ─── */
.proof-card {
  transition: none;
}
.proof-card:hover {
  transform: none;
  box-shadow: var(--shadow);
}
.proof-card-logo {
  opacity: 0.25;
  filter: grayscale(1);
  transition: none;
}
.proof-card-logo:hover {
  opacity: 0.25;
  filter: grayscale(1);
}

/* ─── Herkenning: flat cards, no hover effect ─── */
.herkenning-card {
  transition: none;
}
.herkenning-card:hover {
  transform: none;
  box-shadow: none;
}

/* ─── Bedrijfsritme system rule ─── */
.bedrijfsritme-systeemregel {
  margin: var(--space-md) 0;
  padding: 16px 22px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius);
  font-size: var(--fs-body);
  font-weight: 600;
  color: var(--text);
  line-height: var(--lh-body);
}

/* ─── Bedrijfsritme slotregel ─── */
.bedrijfsritme-slotregel {
  margin-top: var(--space-md);
  padding: 18px 22px;
  background: #f0f8f2;
  border-left: 4px solid #27ae60;
  border-radius: var(--radius);
}
.bedrijfsritme-slotregel-label {
  margin: 0 0 6px;
  font-size: var(--fs-overline);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--ls-overline);
  color: #1e7a45;
}
.bedrijfsritme-slotregel-body {
  margin: 0 0 8px;
  font-size: var(--fs-body);
  color: var(--text);
  line-height: var(--lh-body);
}
.bedrijfsritme-doorlink {
  margin: 0;
}

/* ─── Pillars: sober grid ─── */
.pillars-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin: var(--space-md) 0;
}
.pillar-item {
  padding: 18px 20px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}
.pillar-item h3 {
  font-size: var(--fs-body);
  font-weight: 700;
  margin: 0 0 6px;
}
.pillar-item p {
  margin: 0;
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  line-height: var(--lh-body);
  max-inline-size: var(--measure-card);
}

/* ─── Bewezen resultaten section ─── */
.bewezen-resultaten-section { padding: var(--space-xl) 0; }
.bewezen-resultaten-body {
  margin: 0 0 var(--space-lg);
  font-size: var(--fs-body);
  color: var(--text-secondary);
  line-height: var(--lh-body);
  max-inline-size: var(--measure-body);
}
.bewezen-quotes {
  margin-top: var(--space-md);
}
.bewezen-quote-card {
  border-left: none;
  background: #f9faf9;
  border: 1px solid #e6e9e6;
  padding: 28px 32px;
  text-align: left;
}
.bewezen-quote-logo-row {
  margin-bottom: 14px;
}
.bewezen-quote-logo {
  height: 28px;
  width: auto;
  opacity: 0.45;
  filter: grayscale(0.4);
}
.zo-landt-dit-bridge {
  margin: var(--space-lg) 0 var(--space-md);
  padding: var(--space-md) 0;
  border-top: 1px solid var(--line);
}
.zo-landt-dit-intro {
  margin: 0;
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  line-height: var(--lh-body);
}

/* ─── Binkadvies charts - consistent borders ─── */
.binkadvies-section { margin-top: var(--space-md); }
.binkadvies-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
.binkadvies-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 22px;
  margin: 0;
}
.binkadvies-card h4 {
  font-size: var(--fs-body);
  font-weight: 700;
  margin: 0 0 8px;
}
.binkadvies-summary {
  font-size: var(--fs-ui);
  color: var(--text-secondary);
  margin: 0 0 14px;
  line-height: var(--lh-body);
}
.binkadvies-chart-wrap {
  position: relative;
}
.binkadvies-chart {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius-sm);
}
.binkadvies-enlarge-btn {
  margin-top: 10px;
  appearance: none;
  border: 1px solid var(--line);
  background: var(--surface);
  padding: 6px 14px;
  border-radius: var(--radius-sm);
  font: inherit;
  font-size: var(--fs-small);
  font-weight: 600;
  color: var(--link);
  cursor: pointer;
}
.binkadvies-enlarge-btn:hover {
  border-color: var(--link);
  background: rgba(21, 66, 115, 0.04);
}
.binkadvies-enlarge-btn:focus-visible {
  outline: 3px solid rgba(21, 66, 115, 0.35);
  outline-offset: 2px;
}
.binkadvies-footnote {
  margin: 10px 0 0;
  font-size: var(--fs-overline);
  color: var(--text-secondary);
  font-style: italic;
}
.binkadvies-section-footnote {
  margin: var(--space-sm) 0 0;
  font-size: var(--fs-overline);
  color: var(--text-secondary);
}
@media (min-width: 860px) {
  .binkadvies-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
  .binkadvies-card { padding: 26px; }
}

/* ─── Binkadvies modal ─── */
.binkadvies-modal {
  border: none;
  border-radius: var(--radius);
  padding: 0;
  max-width: 90vw;
  max-height: 90vh;
  background: var(--surface);
  box-shadow: var(--shadow-lg);
}
.binkadvies-modal::backdrop {
  background: rgba(0, 0, 0, 0.5);
}
.binkadvies-modal-inner {
  position: relative;
  padding: 16px;
}
.binkadvies-modal-close {
  position: absolute;
  top: 8px;
  right: 8px;
  appearance: none;
  border: 1px solid var(--line);
  background: var(--surface);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  font-size: 1.2rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text);
}
.binkadvies-modal-img {
  width: 100%;
  height: auto;
  display: block;
}

/* ─── Artefact proof strip ─── */
.artefact-proof-strip {
  margin-top: var(--space-lg);
  padding-top: var(--space-md);
  border-top: 1px solid var(--line);
}
.artefact-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: var(--space-md);
}
.artefact-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
}
.artefact-preview {
  background: var(--surface-muted);
  min-height: 120px;
}
.artefact-preview img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}
.artefact-caption {
  padding: 14px 16px 4px;
  font-size: var(--fs-ui);
  font-weight: 700;
  color: var(--text);
  margin: 0;
}
.artefact-source {
  padding: 0 16px 14px;
  font-size: var(--fs-small);
  color: var(--text-secondary);
  margin: 0;
}
@media (min-width: 860px) {
  .artefact-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
}

/* ─── Authority: sober quote block ─── */
.authority-quote {
  background: var(--accent);
  color: #fff;
  border-radius: var(--radius-sm);
  padding: 20px 22px;
  font-size: var(--fs-body);
  font-weight: 700;
  font-style: italic;
  line-height: 1.55;
  margin: 1.4em 0 1em;
  border-left: none;
  position: relative;
}
.authority-quote p { margin: 0; color: #fff; }

/* ─── Authority checklist: compact ─── */
.authority-checklist {
  list-style: none;
  margin: 1em 0;
  padding: 0;
  display: grid;
  gap: 10px;
}
.authority-checklist li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: var(--fs-ui);
  line-height: var(--lh-body);
}
.authority-checklist .icon-check {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  margin-top: 2px;
}
.authority-doorlink {
  margin-top: var(--space-sm);
}

/* ─── Quote highlight box (praktisch section) ─── */
.quote-highlight-box {
  margin: var(--space-md) 0;
  padding: 18px 22px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius);
}
.quote-highlight {
  margin: 0;
  font-size: var(--fs-body);
  font-style: italic;
  color: var(--text);
  line-height: var(--lh-body);
}
.quote-highlight p {
  margin: 0;
}

/* ─── Audience card headers ─── */
.audience-card-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}
.audience-card-icon {
  width: 28px;
  height: 28px;
  flex-shrink: 0;
}

/* ─── Audience card: functional contrast ─── */
.audience-card-wel {
  background: var(--surface);
  border: 1px solid var(--line);
}
.audience-card-niet {
  background: var(--accent-soft);
  border: 1px solid transparent;
}

/* ─── Session availability row ─── */
.session-availability-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 10px 0;
}

/* ─── Text link arrow variant ─── */
.text-link--arrow {
  font-weight: 600;
}

/* ─── Bewijs link in authority ─── */
.bewijs-link {
  margin-right: 12px;
}

/* ═══════════════════════════════════════════
   Pillar icons
   ═══════════════════════════════════════════ */
.pillar-icon {
  width: 32px;
  height: 32px;
  margin-bottom: 10px;
  color: #888;
}
.pillar-icon svg {
  width: 100%;
  height: 100%;
}

/* ═══════════════════════════════════════════
   Phase icons (Drie fasen)
   ═══════════════════════════════════════════ */
.phase-icon {
  width: 36px;
  height: 36px;
  margin-bottom: 14px;
  color: #888;
  flex-shrink: 0;
  padding: 6px;
  background: #f4f4f4;
  border-radius: 8px;
}
.phase-icon svg {
  width: 100%;
  height: 100%;
}
.three-phase-grid .phase-card {
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.three-phase-grid .phase-card::before,
.three-phase-grid .phase-card::after {
  display: none;
}

/* ═══════════════════════════════════════════
   Section divider
   ═══════════════════════════════════════════ */
.section-divider {
  border: none;
  border-top: 2px solid var(--line);
  margin: 0;
}
.section-divider--subtle {
  border-top: 1px solid var(--line-soft);
  margin: var(--space-lg) 0;
}

/* ═══════════════════════════════════════════
   Auditor quote premium block
   ═══════════════════════════════════════════ */
.auditor-quote-premium {
  max-width: 640px;
  margin: var(--space-lg) auto;
  padding: 36px 40px;
  background: #f9faf9;
  border: 1px solid #e6e9e6;
  border-radius: var(--radius);
  text-align: center;
}
.auditor-quote-inner {
  margin: 0;
  padding: 0;
}
.auditor-quote-logo {
  display: block;
  width: 80px;
  height: auto;
  opacity: 0.45;
  filter: grayscale(0.4);
  margin: 0 auto 20px;
}
.auditor-quote-text {
  font-size: clamp(1.02rem, 1.15vw, 1.12rem);
  line-height: 1.75;
  color: var(--text);
  font-style: italic;
  margin: 0 0 16px;
  letter-spacing: -0.01em;
}
.auditor-quote-cite {
  display: block;
  font-style: normal;
  font-size: var(--fs-small);
  color: var(--text-secondary);
  font-weight: 600;
  letter-spacing: 0.02em;
}
@media (max-width: 600px) {
  .auditor-quote-premium {
    padding: 28px 24px;
  }
  .auditor-quote-logo {
    width: 68px;
  }
}

/* ═══════════════════════════════════════════
   Zo landt dit - Title styling
   ═══════════════════════════════════════════ */
.zo-landt-dit-bridge {
  border-bottom: none;
  padding-bottom: 0;
}
.zo-landt-dit-title {
  font-size: var(--fs-h3);
  font-weight: 700;
  color: var(--text);
  margin: 0 0 var(--space-xs);
  line-height: var(--lh-short);
}

/* ═══════════════════════════════════════════
   Bedrijfsritme doorlink (outside block)
   ═══════════════════════════════════════════ */
.bedrijfsritme-doorlink {
  margin-top: var(--space-sm);
  text-align: center;
}

/* ═══════════════════════════════════════════
   Authority quote premium variant
   ═══════════════════════════════════════════ */
.authority-quote--premium {
  background: var(--accent);
  color: #fff;
  border-radius: var(--radius);
  padding: 28px 30px;
  text-align: left;
}
.authority-quote-dim {
  opacity: 0.7;
  font-weight: 400;
  font-style: italic;
}
.authority-quote-highlight {
  font-weight: 700;
  font-size: 1.1em;
  display: block;
  margin-top: 0.3em;
}
.authority-quote-bridge {
  margin-top: 1em;
  padding-top: 1em;
  border-top: 1px solid rgba(255,255,255,0.2);
  font-size: var(--fs-body);
  font-weight: 500;
  font-style: normal;
  color: rgba(255,255,255,0.9);
}

/* ─── Unified section spacing - calm, consistent rhythm ─── */
:root {
  --space-section-y: var(--space-xl);        /* 72px base */
}
@media (min-width: 860px) {
  :root {
    --space-section-y: var(--space-section-y-desktop);  /* 6.5rem desktop */
  }
}
@media (max-width: 859px) {
  :root {
    --space-section-y: var(--space-section-y-mobile);   /* 4.5rem mobile */
  }
}

.hero,
.proof-section,
.section.herkenning-section,
.section,
.bewezen-resultaten-section,
.final-cta,
.newsletter-section {
  padding-top: var(--space-section-y) !important;
  padding-bottom: var(--space-section-y) !important;
}

/* Hero gets slightly less top padding for visual balance */
.hero {
  padding-top: calc(var(--space-section-y) * 0.5) !important;
}

/* ═══════════════════════════════════════════
   Final polish - remove red accent lines,
   lighter grey crosses, section separation
   ═══════════════════════════════════════════ */

/* Remove ALL thin red/accent decorative lines */
.herkenning-punchline {
  border-top: 2px solid var(--line) !important;
}
.organisatie-lekt-divider {
  border-top: 2px solid var(--line) !important;
}
.zo-landt-dit {
  border-bottom: none !important;
}
.zo-landt-dit-bridge {
  border-bottom: none !important;
}
.section-divider,
.section-divider--subtle {
  display: none;
}

/* Make "niet voor" cross icons lighter grey */
.checklist--niet li::before {
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M18 6L6 18M6 6l12 12' stroke='%23c0c0c0' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat !important;
}
.audience-card-niet {
  border-left-color: #c0c0c0 !important;
}
.audience-card-header--niet .audience-card-icon circle {
  fill: #c0c0c0;
}

/* Hide the doelgroep line via CSS as fallback */
.hero-doelgroep { display: none; }

/* Herkenning CTA row - flex wrap for quickscan button */
.herkenning-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}
.herkenning-cta-row .button-secondary {
  background: transparent;
  border: 2px solid var(--accent);
  color: var(--accent);
  font-weight: 600;
}
.herkenning-cta-row .button-secondary:hover {
  background: var(--accent);
  color: #fff;
}
.herkenning-cta-row .herkenning-cta-tertiary {
  flex-basis: 100%;
}

/* Newsletter section muted background */
.newsletter-section.section-muted {
  background: var(--surface-muted);
}

/* Mobile polish */
@media (max-width: 640px) {
  .herkenning-cta-row {
    flex-direction: column;
    align-items: stretch;
    text-align: center;
  }
  .herkenning-cta-row .button {
    width: 100%;
  }
}
