/* ============================================================
   Business & Wellbeing - huisstijl-stylesheet
   Bron: Brandbook V1.2 (Leading Lean / Meerwaarde Makers)
   Navy #222C3F + goud #CDA46F + warm #f5f0e8 + Montserrat
   ============================================================ */

:root {
  --donkerblauw: #222C3F; --donkerblauw-soft: #2d3a52;
  --goud: #CDA46F; --goud-soft: #ebd9b9; --goud-lite: #faf3e3;
  --bruin: #8E5F36; --warm-bg: #f5f0e8;
  --ink: #1a1a1a; --ink-soft: #4a4a4a; --ink-faded: #777;
  --pijn: #b8553a; --pijn-bg: #fde8e3;
  --oplossing: #2d8b6b; --oplossing-bg: #e0f1ea;
  --business: #3a5a87; --business-bg: #e7ecf3;
  --welbeing: #5a8b6b; --welbeing-bg: #e3ede5;
  --indigo: #5b5fa6; --indigo-bg: #e8e9f4;
  --card: #ffffff; --border: rgba(34,44,63,.10);
  --shadow-sm: 0 1px 3px rgba(34,44,63,.05);
  --shadow-md: 0 4px 16px rgba(34,44,63,.06), 0 1px 3px rgba(34,44,63,.04);
  --shadow-lg: 0 12px 32px rgba(34,44,63,.09), 0 4px 12px rgba(34,44,63,.05);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0; padding: 0; background: var(--warm-bg); color: var(--ink);
  font-family: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 16px; line-height: 1.65;
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
}
a { color: var(--bruin); }
img { max-width: 100%; display: block; }
.wrap { max-width: 1080px; margin: 0 auto; padding: 0 24px; }
.narrow { max-width: 920px; margin: 0 auto; padding: 0 24px; }

/* ===== TOP NAV ===== */
.nav {
  position: sticky; top: 0; z-index: 100;
  background: rgba(245,240,232,.92); backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--border);
}
.nav-inner { max-width: 1080px; margin: 0 auto; padding: 12px 24px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.brand { display: flex; align-items: center; gap: 10px; text-decoration: none; }
.brand .mark { width: 30px; height: 30px; border-radius: 8px; background: var(--donkerblauw); color: var(--goud); font-weight: 800; display: flex; align-items: center; justify-content: center; font-size: 17px; }
.brand .bn { font-weight: 800; color: var(--donkerblauw); font-size: 16px; letter-spacing: -.01em; line-height: 1; }
.brand .bn small { display: block; font-size: 10px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--bruin); margin-top: 3px; }
.brand-logo { height: 47px; width: auto; display: block; }
.site-footer .brand-logo { height: 55px; opacity: .96; }
.nav-links { display: flex; align-items: center; gap: 4px; flex-wrap: wrap; }
.nav-links a { color: var(--donkerblauw); font-weight: 600; font-size: 14px; text-decoration: none; padding: 8px 12px; border-radius: 8px; }
.nav-links a:hover { background: var(--goud-lite); }
.nav-links a.cur { color: var(--goud); }
.nav-links a.btn-nav { background: var(--donkerblauw); color: #fff; padding: 9px 16px; }
.nav-links a.btn-nav:hover { background: var(--donkerblauw-soft); }
.nav-toggle { display: none; background: none; border: 1px solid var(--border); border-radius: 8px; padding: 7px 10px; font-size: 18px; cursor: pointer; color: var(--donkerblauw); }

/* ===== BUTTONS ===== */
.btn { display: inline-block; border-radius: 999px; font-weight: 700; font-size: 15px; text-decoration: none; letter-spacing: .02em; padding: 14px 30px; transition: transform .15s ease, background .15s ease, box-shadow .15s ease; cursor: pointer; border: none; }
.btn-primary { background: var(--donkerblauw); color: #fff; }
.btn-primary:hover { background: var(--donkerblauw-soft); transform: translateY(-2px); }
.btn-gold { background: var(--goud); color: var(--donkerblauw); font-weight: 800; }
.btn-gold:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(205,164,111,.35); }
.btn-ghost { background: transparent; color: var(--donkerblauw); border: 1.5px solid var(--donkerblauw); }
.btn-ghost:hover { background: var(--donkerblauw); color: #fff; }
.btn-light { background: rgba(255,255,255,.14); color: #fff; border: 1.5px solid rgba(255,255,255,.4); }
.btn-light:hover { background: rgba(255,255,255,.22); }

/* ===== SITE HERO (met foto) ===== */
.site-hero { position: relative; overflow: hidden; }
.site-hero-media { position: absolute; inset: 0; background-size: cover; background-position: 70% center; }
.site-hero-overlay { position: absolute; inset: 0; background:
  linear-gradient(100deg, rgba(28,36,52,.94) 0%, rgba(28,36,52,.82) 38%, rgba(28,36,52,.42) 66%, rgba(28,36,52,.12) 100%); }
.site-hero-inner { position: relative; max-width: 1080px; margin: 0 auto; padding: 86px 24px 92px; }
.site-hero .col { max-width: 620px; }
.site-hero .eyebrow { display: inline-block; text-transform: uppercase; letter-spacing: .16em; font-size: 11.5px; color: var(--goud); font-weight: 700; margin-bottom: 20px; padding: 6px 14px; border-radius: 999px; background: rgba(205,164,111,.14); border: 1px solid rgba(205,164,111,.4); }
.site-hero h1 { font-size: clamp(30px, 5vw, 52px); line-height: 1.06; margin: 0 0 18px; letter-spacing: -.02em; font-weight: 800; color: #fff; }
.site-hero h1 .goud { color: var(--goud); }
.site-hero .sub { font-size: 18px; color: rgba(255,255,255,.9); line-height: 1.6; margin: 0 0 28px; max-width: 560px; }
.site-hero .hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 30px; }
.hero-trust { display: flex; gap: 26px; flex-wrap: wrap; border-top: 1px solid rgba(255,255,255,.18); padding-top: 20px; }
.hero-trust .t .n { font-size: 24px; font-weight: 800; color: var(--goud); line-height: 1; }
.hero-trust .t .l { font-size: 12.5px; color: rgba(255,255,255,.72); margin-top: 4px; max-width: 150px; }

/* ===== PAGE BANNER (kortere hero met foto, sub-paginas) ===== */
.page-banner { position: relative; overflow: hidden; }
.page-banner-media { position: absolute; inset: 0; background-size: cover; background-position: 72% center; }
.page-banner-overlay { position: absolute; inset: 0; background:
  linear-gradient(100deg, rgba(28,36,52,.93) 0%, rgba(28,36,52,.8) 40%, rgba(28,36,52,.4) 70%, rgba(28,36,52,.1) 100%); }
.page-banner-inner { position: relative; max-width: 1080px; margin: 0 auto; padding: 56px 24px 58px; }
.page-banner .col { max-width: 600px; }
.page-banner .eyebrow { display: inline-block; text-transform: uppercase; letter-spacing: .16em; font-size: 11px; color: var(--goud); font-weight: 700; margin-bottom: 16px; padding: 6px 14px; border-radius: 999px; background: rgba(205,164,111,.14); border: 1px solid rgba(205,164,111,.4); }
.page-banner h1 { font-size: clamp(27px, 4.2vw, 40px); line-height: 1.08; margin: 0 0 14px; letter-spacing: -.02em; font-weight: 800; color: #fff; }
.page-banner h1 .goud { color: var(--goud); }
.page-banner .sub { font-size: 16.5px; color: rgba(255,255,255,.9); line-height: 1.55; margin: 0 0 24px; max-width: 540px; }

/* ===== SLIMMER MODEL (visueel, pill-rows) ===== */
.slimmer-model { background: var(--donkerblauw); border-radius: 18px; padding: 34px 36px; box-shadow: var(--shadow-lg); }
.slimmer-model .smh { text-align: center; margin-bottom: 22px; }
.slimmer-model .smh .label { text-transform: uppercase; letter-spacing: .16em; font-size: 11px; color: var(--goud); font-weight: 700; margin-bottom: 8px; }
.slimmer-model .smh h3 { color: #fff; font-size: 23px; margin: 0 0 8px; }
.slimmer-model .smh p { color: rgba(255,255,255,.78); font-size: 14.5px; margin: 0 auto; max-width: 620px; line-height: 1.55; }
.sm-row { display: grid; grid-template-columns: 290px 1fr; gap: 20px; align-items: center; padding: 7px 0; }
.sm-pill { display: flex; align-items: center; gap: 13px; background: var(--goud-lite); border-radius: 999px; padding: 8px 18px 8px 8px; }
.sm-pill .lc { width: 34px; min-width: 34px; height: 34px; border-radius: 50%; background: var(--donkerblauw); color: var(--goud-lite); font-weight: 800; font-size: 16px; display: flex; align-items: center; justify-content: center; }
.sm-pill .ll { font-weight: 700; color: var(--donkerblauw); font-size: 14px; }
.sm-desc { color: rgba(255,255,255,.82); font-size: 13.5px; line-height: 1.5; }
.sm-row.vit { margin-top: 6px; }
.sm-row.vit .sm-pill { background: var(--goud); }
.sm-row.vit .sm-pill .lc { background: var(--oplossing); color: #fff; }
.sm-row.vit .sm-pill .ll { color: var(--donkerblauw); font-weight: 800; }
.sm-row.vit .sm-desc { color: #fff; }

/* ===== ROUTE-ICONEN (inline svg, geen emoji) ===== */
.route .ico svg { width: 26px; height: 26px; display: block; }
.route .ico svg [stroke] { stroke: var(--bruin); }
.route .ico svg [fill]:not([fill="none"]) { fill: var(--bruin); }

/* ===== SECTION SCAFFOLD ===== */
.section { padding: 60px 0; }
.section.tight { padding: 44px 0; }
.section-eyebrow { text-transform: uppercase; letter-spacing: .16em; font-size: 11px; font-weight: 700; color: var(--bruin); margin-bottom: 8px; }
h2 { font-size: clamp(24px, 3.4vw, 31px); font-weight: 800; color: var(--donkerblauw); letter-spacing: -.01em; margin: 0 0 10px; line-height: 1.18; }
h2 .goud { color: var(--goud); }
h3 { font-size: 19px; font-weight: 700; color: var(--donkerblauw); margin: 0 0 10px; }
.section-lead { color: var(--ink-soft); margin: 0 0 28px; font-size: 16.5px; max-width: 720px; line-height: 1.6; }
.center { text-align: center; }
.center .section-lead { margin-left: auto; margin-right: auto; }

/* ===== CARDS / TEGELS ===== */
.card { background: var(--card); border: 1px solid var(--border); border-radius: 16px; padding: 26px 28px; box-shadow: var(--shadow-md); }
.grid { display: grid; gap: 18px; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.badge { display: inline-block; padding: 4px 12px; border-radius: 999px; font-size: 11.5px; font-weight: 700; letter-spacing: .02em; }
.badge.business { color: var(--business); background: var(--business-bg); }
.badge.welbeing { color: var(--welbeing); background: var(--welbeing-bg); }
.badge.goud { color: var(--bruin); background: var(--goud-lite); border: 1px solid var(--goud-soft); }
.badge.pijn { color: var(--pijn); background: var(--pijn-bg); }
.badge.indigo { color: var(--indigo); background: var(--indigo-bg); }
.badge.oplossing { color: var(--oplossing); background: var(--oplossing-bg); }

/* ===== ROUTE CARDS (wat we doen) ===== */
.route { display: flex; flex-direction: column; background: var(--card); border: 1px solid var(--border); border-radius: 18px; padding: 0; box-shadow: var(--shadow-md); position: relative; overflow: hidden; transition: transform .18s ease, box-shadow .18s ease; }
.route:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.route::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 5px; background: var(--goud); z-index: 3; }
.route-img { height: 162px; background-size: cover; background-position: center; border-bottom: 1px solid var(--border); }
.route-body { padding: 24px 26px 26px; display: flex; flex-direction: column; flex: 1; }
.route .ico { font-size: 26px; width: 52px; height: 52px; border-radius: 13px; background: var(--goud-lite); border: 1px solid var(--goud-soft); display: flex; align-items: center; justify-content: center; margin-bottom: 16px; }
.route h3 { font-size: 20px; margin-bottom: 8px; }
.route p { font-size: 14.5px; color: var(--ink-soft); margin: 0 0 18px; line-height: 1.55; flex: 1; }
.route .go { font-weight: 700; color: var(--bruin); text-decoration: none; font-size: 14.5px; }
.route .go:hover { color: var(--donkerblauw); }

/* ===== PERSONA CARDS (voor wie) ===== */
.persona { background: var(--card); border: 1px solid var(--border); border-radius: 16px; padding: 24px; box-shadow: var(--shadow-sm); }
.persona .rol { font-weight: 800; color: var(--donkerblauw); font-size: 16px; margin-bottom: 4px; }
.persona .pijn { font-size: 13.5px; color: var(--pijn); font-weight: 600; margin-bottom: 10px; }
.persona p { font-size: 14px; color: var(--ink-soft); margin: 0 0 14px; line-height: 1.55; }
.persona .cta { font-size: 13.5px; font-weight: 700; color: var(--bruin); text-decoration: none; }

/* ===== CIJFER-TEGELS (uit flyer) ===== */
.cijfer-rij { margin-bottom: 20px; }
.cijfer-rij-label { display: inline-block; text-transform: uppercase; letter-spacing: .14em; font-size: 11px; font-weight: 700; padding: 5px 13px; border-radius: 999px; margin-bottom: 13px; }
.cijfer-rij-label.business { color: var(--business); background: var(--business-bg); }
.cijfer-rij-label.welbeing { color: var(--welbeing); background: var(--welbeing-bg); }
.cijfer-rij-label.fomo { color: var(--bruin); background: var(--goud-lite); }
.cijfer-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.cijfer-tegel { background: var(--card); border: 1px solid var(--border); border-radius: 12px; padding: 18px; box-shadow: var(--shadow-sm); display: flex; flex-direction: column; justify-content: space-between; min-height: 158px; }
.cijfer-tegel .groot { font-size: 29px; line-height: 1.05; font-weight: 800; letter-spacing: -.02em; margin-bottom: 8px; color: var(--donkerblauw); }
.cijfer-tegel.business-tegel .groot { color: var(--business); }
.cijfer-tegel.welbeing-tegel .groot { color: var(--welbeing); }
.cijfer-tegel.fomo-tegel .groot { color: var(--bruin); }
.cijfer-tegel .uitleg { font-size: 13.5px; color: var(--ink-soft); line-height: 1.45; }
.cijfer-tegel .bron { font-size: 11px; color: var(--ink-faded); margin-top: 12px; border-top: 1px solid var(--border); padding-top: 8px; }

/* ===== DONKER BLOK (crisis / visie / cta) ===== */
.dark { background: var(--donkerblauw); color: #fff; border-radius: 18px; padding: 40px; box-shadow: var(--shadow-lg); }
.dark .label { text-transform: uppercase; letter-spacing: .16em; font-size: 11px; color: var(--goud); font-weight: 700; margin-bottom: 14px; }
.dark h2, .dark h3 { color: #fff; }
.dark p { color: rgba(255,255,255,.9); }
.dark .quote-tekst { font-size: 17.5px; line-height: 1.6; font-style: italic; margin: 0; }
.dark .big { color: var(--goud); font-weight: 700; }

/* ===== TABEL ===== */
table.std { width: 100%; border-collapse: collapse; background: var(--card); border-radius: 12px; overflow: hidden; box-shadow: var(--shadow-sm); font-size: 14px; }
table.std thead th { background: var(--donkerblauw); color: #fff; text-align: left; padding: 11px 13px; font-weight: 600; font-size: 13px; }
table.std tbody td { padding: 10px 13px; border-top: 1px solid var(--border); vertical-align: top; }
table.std tbody tr:nth-child(even) { background: #faf8f3; }
.center-cell { text-align: center; }

/* ===== SLIMMER-TABEL (uit flyer) ===== */
.slimmer-frame { background: linear-gradient(135deg, var(--goud-lite) 0%, var(--goud-soft) 100%); border: 1px solid rgba(205,164,111,.4); border-radius: 18px; padding: 36px; }
.slimmer-frame .intro { color: #4d3f24; margin: 0 0 20px; font-size: 15.5px; line-height: 1.6; max-width: 720px; }
.slimmer-table { width: 100%; border-collapse: collapse; background: var(--card); border-radius: 10px; overflow: hidden; margin-bottom: 18px; }
.slimmer-table th { background: var(--donkerblauw); color: #fff; text-align: left; padding: 12px 14px; font-size: 12px; text-transform: uppercase; letter-spacing: .08em; font-weight: 700; }
.slimmer-table td { padding: 12px 14px; border-top: 1px solid var(--border); font-size: 14px; line-height: 1.45; color: var(--ink-soft); vertical-align: top; }
.slimmer-table td.letter-cel { font-weight: 800; font-size: 20px; color: var(--bruin); width: 56px; text-align: center; }
.slimmer-table td.letter-cel.vinkje { color: var(--goud); font-size: 22px; }
.slimmer-table tr.vinkje-row { background: var(--goud-lite); }
.slimmer-table td strong { color: var(--donkerblauw); }

/* ===== FUNNEL / PRODUCT-TRAP (uit aanpak-doc) ===== */
.funnel { display: flex; flex-direction: column; gap: 0; margin: 18px 0; }
.funnel-step { display: flex; align-items: stretch; }
.funnel-step + .funnel-step { margin-top: 6px; }
.funnel-num { width: 44px; min-width: 44px; background: var(--donkerblauw); color: #fff; font-weight: 800; font-size: 18px; display: flex; align-items: center; justify-content: center; border-radius: 12px 0 0 12px; }
.funnel-body { flex: 1; border: 1px solid var(--border); border-left: none; border-radius: 0 12px 12px 0; background: var(--card); padding: 14px 18px; box-shadow: var(--shadow-sm); }
.funnel-body.highlight { background: var(--goud-lite); border-color: var(--goud-soft); }
.funnel-step.active .funnel-num { background: var(--goud); color: var(--donkerblauw); }
.funnel-body h4 { margin: 0 0 4px; font-size: 15px; font-weight: 700; color: var(--donkerblauw); }
.funnel-body p { margin: 0; font-size: 13.5px; color: var(--ink-soft); }
.funnel-body .price { display: inline-block; margin-top: 6px; font-weight: 800; color: var(--bruin); font-size: 14px; }
.funnel-arrow { text-align: center; color: var(--goud); font-size: 20px; line-height: 1; margin: 2px 0; padding-left: 22px; }

/* ===== STAP-KAARTEN (drietrapsraket) ===== */
.trap { background: var(--card); border-radius: 14px; padding: 20px 22px; box-shadow: var(--shadow-sm); margin-bottom: 12px; }
.trap.b { border-left: 4px solid var(--business); }
.trap.i { border-left: 4px solid var(--indigo); }
.trap.d { border-left: 4px solid var(--donkerblauw); }
.trap.w { border-left: 4px solid var(--welbeing); }
.trap .tg { display: inline-block; font-size: 11.5px; font-weight: 700; border-radius: 999px; padding: 4px 12px; color: #fff; margin-bottom: 10px; }
.trap.b .tg { background: var(--business); } .trap.i .tg { background: var(--indigo); }
.trap.d .tg { background: var(--donkerblauw); } .trap.w .tg { background: var(--welbeing); }
.trap h4 { margin: 0 0 6px; font-size: 16px; color: var(--donkerblauw); }
.trap p { margin: 0; font-size: 14px; color: var(--ink-soft); line-height: 1.5; }
.trap-arrow { text-align: center; color: var(--goud); font-size: 22px; line-height: 1; margin: -2px 0 10px; }

/* ===== TEAM ===== */
.team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.tm { display: block; background: var(--card); border: 1px solid var(--border); border-radius: 16px; padding: 24px; box-shadow: var(--shadow-sm); text-align: center; text-decoration: none; color: inherit; transition: transform .16s ease, box-shadow .16s ease; }
a.tm:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.tm .av { width: 108px; height: 108px; border-radius: 50%; margin: 0 auto 16px; background: var(--donkerblauw); color: var(--goud); font-weight: 800; font-size: 34px; display: flex; align-items: center; justify-content: center; }
.tm-link { display: inline-block; margin-top: 12px; font-size: 13px; font-weight: 700; color: var(--bruin); }
a.tm:hover .tm-link { color: var(--donkerblauw); }

/* ===== PROFIELPAGINA ===== */
.profile-hero { display: grid; grid-template-columns: 340px 1fr; gap: 40px; align-items: start; }
.profile-photo { width: 100%; border-radius: 20px; box-shadow: var(--shadow-lg); display: block; }
.profile-eyebrow { text-transform: uppercase; letter-spacing: .16em; font-size: 11px; font-weight: 700; color: var(--bruin); margin-bottom: 8px; }
.profile-name { font-size: clamp(28px, 4vw, 38px); font-weight: 800; color: var(--donkerblauw); letter-spacing: -.02em; margin: 0 0 4px; }
.profile-role { font-size: 16px; font-weight: 700; color: var(--bruin); margin-bottom: 18px; }
.profile-statement { font-size: 18px; line-height: 1.55; color: var(--donkerblauw); font-style: italic; border-left: 4px solid var(--goud); background: var(--goud-lite); padding: 16px 20px; border-radius: 0 12px 12px 0; margin: 0 0 22px; }
.profile-bio p { font-size: 15.5px; color: var(--ink-soft); line-height: 1.7; margin: 0 0 14px; }
.profile-contact { margin-top: 22px; display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.back-link { display: inline-block; font-size: 13.5px; font-weight: 700; color: var(--bruin); text-decoration: none; margin-bottom: 22px; }
.back-link:hover { color: var(--donkerblauw); }
@media (max-width: 760px) { .profile-hero { grid-template-columns: 1fr; gap: 24px; } .profile-photo { max-width: 320px; margin: 0 auto; } }
.tm .nm { font-weight: 800; color: var(--donkerblauw); font-size: 16px; }
.tm .rl { font-size: 12.5px; color: var(--bruin); font-weight: 600; text-transform: uppercase; letter-spacing: .04em; margin: 4px 0 10px; }
.tm .co { display: inline-block; font-size: 11px; font-weight: 700; color: var(--ink-soft); background: var(--goud-lite); border: 1px solid var(--goud-soft); border-radius: 999px; padding: 2px 10px; margin-bottom: 10px; }
.tm p { font-size: 13px; color: var(--ink-soft); margin: 0; line-height: 1.5; }
.tm .av.photo { padding: 0; overflow: hidden; background: none; }
.tm .av.photo img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 20%; }
.team-photo { width: 100%; max-width: 760px; margin: 30px auto 0; border-radius: 18px; box-shadow: var(--shadow-lg); display: block; border: 5px solid #fff; }
.team-photo-cap { text-align: center; font-size: 13px; color: var(--ink-faded); margin: 12px auto 0; }

/* ===== WHITEPAPER BAND (terugkerende sectie) ===== */
.whitepaper { background: var(--goud-lite); border-top: 1px solid var(--goud-soft); border-bottom: 1px solid var(--goud-soft); }
.whitepaper .wp-inner { max-width: 1080px; margin: 0 auto; padding: 48px 24px; display: grid; grid-template-columns: 1.3fr 1fr; gap: 36px; align-items: center; }
.whitepaper .wp-label { text-transform: uppercase; letter-spacing: .16em; font-size: 11px; font-weight: 700; color: var(--bruin); margin-bottom: 10px; }
.whitepaper h2 { margin-bottom: 10px; }
.whitepaper p { font-size: 15.5px; color: var(--ink-soft); margin: 0 0 16px; line-height: 1.6; }
.whitepaper ul { margin: 0; padding: 0; list-style: none; }
.whitepaper ul li { font-size: 14px; color: var(--ink-soft); padding: 5px 0 5px 26px; position: relative; }
.whitepaper ul li::before { content: "\2713"; position: absolute; left: 0; color: var(--goud); font-weight: 800; }
.wp-form { background: var(--card); border: 1px solid var(--goud-soft); border-radius: 16px; padding: 26px; box-shadow: var(--shadow-md); }
.wp-form h3 { font-size: 17px; margin-bottom: 6px; }
.wp-form .sub { font-size: 13px; color: var(--ink-faded); margin: 0 0 16px; }
.wp-form input { width: 100%; padding: 12px 14px; border: 1px solid var(--border); border-radius: 10px; font-family: inherit; font-size: 14px; margin-bottom: 10px; background: #fff; }
.wp-form input:focus { outline: none; border-color: var(--goud); }
.wp-form .btn { width: 100%; text-align: center; }
.wp-form .privacy { font-size: 11px; color: var(--ink-faded); margin: 10px 0 0; text-align: center; }

/* ===== CTA-BAND ===== */
.cta-band { background: linear-gradient(135deg, var(--donkerblauw) 0%, var(--donkerblauw-soft) 100%); color: #fff; border-radius: 18px; padding: 48px; text-align: center; box-shadow: var(--shadow-lg); }
.cta-band .label { text-transform: uppercase; letter-spacing: .18em; font-size: 12px; font-weight: 700; color: var(--goud); margin-bottom: 14px; }
.cta-band h2 { color: #fff; margin-bottom: 12px; }
.cta-band p { color: rgba(255,255,255,.85); max-width: 600px; margin: 0 auto 26px; font-size: 16px; }
.cta-feiten { display: flex; justify-content: center; gap: 28px; flex-wrap: wrap; margin-bottom: 26px; }
.cta-feit .num { font-size: 24px; font-weight: 800; color: var(--goud); display: block; line-height: 1; margin-bottom: 4px; }
.cta-feit .lab { font-size: 12px; color: rgba(255,255,255,.7); }

/* ===== FOOTER ===== */
.site-footer { background: var(--donkerblauw); color: rgba(255,255,255,.78); margin-top: 0; }
.site-footer .ft-inner { max-width: 1080px; margin: 0 auto; padding: 52px 24px 28px; display: grid; grid-template-columns: 1.6fr 1fr 1fr; gap: 32px; }
.site-footer .brand .bn { color: #fff; } .site-footer .brand .bn small { color: var(--goud); }
.site-footer .ft-about { font-size: 13.5px; line-height: 1.6; margin: 14px 0 0; max-width: 320px; }
.site-footer h4 { color: #fff; font-size: 13px; text-transform: uppercase; letter-spacing: .1em; margin: 0 0 14px; }
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer ul li { margin-bottom: 9px; }
.site-footer ul li a { color: rgba(255,255,255,.78); text-decoration: none; font-size: 14px; }
.site-footer ul li a:hover { color: var(--goud); }
.site-footer .ft-bottom { border-top: 1px solid rgba(255,255,255,.12); padding: 18px 24px; max-width: 1080px; margin: 0 auto; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; font-size: 12px; color: rgba(255,255,255,.5); }
.site-footer .ft-bottom a { color: rgba(255,255,255,.6); }
.site-footer .ft-legal { font-size: 12.5px; color: rgba(255,255,255,.55); margin: 14px 0 0; line-height: 1.6; }

/* ===== UTILS ===== */
.mt0{margin-top:0}.mb0{margin-bottom:0}
.soft-divider{height:1px;background:var(--border);margin:0}
.bron-line { font-size: 12px; color: var(--ink-faded); margin-top: 14px; line-height: 1.5; }

/* ===== STAPPEN (4-staps aanpak) ===== */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin: 18px 0 0; }
.step { background: var(--goud-lite); border: 1px solid var(--goud-soft); border-radius: 13px; padding: 18px 16px; font-size: 13px; color: var(--ink-soft); line-height: 1.5; position: relative; }
.step .n { font-weight: 800; color: #fff; background: var(--bruin); width: 30px; height: 30px; border-radius: 9px; font-size: 16px; display: flex; align-items: center; justify-content: center; margin-bottom: 12px; }
.step b { color: var(--donkerblauw); display: block; margin-bottom: 5px; font-size: 14.5px; }

/* ===== PRODUCT-LADDER (sterke trap-visual) ===== */
.ladder { display: flex; flex-direction: column; gap: 12px; margin: 20px 0 0; position: relative; }
.ladder-step { display: flex; gap: 16px; align-items: center; background: var(--card); border: 1px solid var(--border); border-radius: 16px; padding: 18px 22px; box-shadow: var(--shadow-sm); position: relative; transition: transform .15s ease, box-shadow .15s ease; }
.ladder-step:hover { transform: translateX(4px); box-shadow: var(--shadow-md); }
.ladder-step.free { background: var(--goud-lite); border-color: var(--goud-soft); }
.ladder-step.peak { background: linear-gradient(135deg, #222C3F, #2d3a52); border-color: transparent; }
.ladder-step.peak h4 { color: #fff; } .ladder-step.peak p { color: rgba(255,255,255,.82); }
.ladder-num { width: 42px; min-width: 42px; height: 42px; border-radius: 13px; background: var(--donkerblauw); color: #fff; font-weight: 800; font-size: 18px; display: flex; align-items: center; justify-content: center; }
.ladder-step.free .ladder-num { background: var(--goud); color: var(--donkerblauw); }
.ladder-step.peak .ladder-num { background: var(--goud); color: var(--donkerblauw); }
.ladder-body { flex: 1; }
.ladder-body h4 { margin: 0 0 4px; font-size: 15.5px; color: var(--donkerblauw); }
.ladder-body p { margin: 0; font-size: 13.5px; color: var(--ink-soft); line-height: 1.5; }
.ladder-price { white-space: nowrap; font-weight: 800; font-size: 13.5px; color: var(--bruin); background: #fff; border: 1px solid var(--border); border-radius: 999px; padding: 6px 14px; }
.ladder-step.free .ladder-price { color: var(--oplossing); background: var(--oplossing-bg); border-color: transparent; }
.ladder-step.peak .ladder-price { color: var(--donkerblauw); background: var(--goud); border-color: transparent; }
@media (max-width: 620px) { .ladder-step { flex-wrap: wrap; } .ladder-price { order: 3; } }

/* ===== PROCES-FLOW (adaptieve scan, 3 niveaus) ===== */
.flow { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr; gap: 0; align-items: stretch; margin: 8px 0 4px; }
.flow-node { background: var(--card); border: 1px solid var(--border); border-radius: 16px; padding: 22px 20px; box-shadow: var(--shadow-sm); position: relative; overflow: hidden; }
.flow-node::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px; }
.flow-node.d::before { background: var(--business); }
.flow-node.m::before { background: var(--indigo); }
.flow-node.w::before { background: var(--welbeing); }
.flow-node .tag { display: inline-block; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; padding: 3px 10px; border-radius: 999px; margin-bottom: 10px; }
.flow-node.d .tag { color: var(--business); background: var(--business-bg); }
.flow-node.m .tag { color: var(--indigo); background: var(--indigo-bg); }
.flow-node.w .tag { color: var(--welbeing); background: var(--welbeing-bg); }
.flow-node h4 { margin: 0 0 6px; font-size: 16px; color: var(--donkerblauw); }
.flow-node p { margin: 0; font-size: 13px; color: var(--ink-soft); line-height: 1.5; }
.flow-arrow { display: flex; align-items: center; justify-content: center; color: var(--goud); font-size: 24px; padding: 0 8px; font-weight: 800; }

/* ===== RAPPORT-SNIPPET (radar legend + staafjes met gouden benchmark) ===== */
.legend { display: flex; gap: 16px; flex-wrap: wrap; font-size: 12.5px; color: var(--ink-soft); margin-top: 10px; justify-content: center; }
.legend span { display: inline-flex; align-items: center; gap: 7px; }
.lg-line { width: 20px; border-top: 3px solid var(--donkerblauw); }
.lg-dash { width: 20px; border-top: 3px dashed var(--goud); }
.lg-b { width: 11px; height: 11px; border-radius: 3px; background: var(--business); }
.lg-w { width: 11px; height: 11px; border-radius: 3px; background: var(--welbeing); }
.ghead { font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; margin: 16px 0 4px; }
.ghead:first-child { margin-top: 0; }
.brow { display: grid; grid-template-columns: 170px 1fr 92px; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--border); }
.blabel { font-size: 12.5px; font-weight: 600; color: var(--donkerblauw); }
.btrack { position: relative; height: 20px; background: #efe9df; border-radius: 7px; }
.bfill { position: absolute; top: 0; left: 0; height: 100%; border-radius: 7px; background: linear-gradient(90deg,#2d3a52,#222C3F); }
.bbench { position: absolute; top: -3px; height: 26px; width: 3px; background: var(--goud); border-radius: 2px; }
.bvals { display: flex; align-items: center; gap: 6px; justify-content: flex-end; font-size: 12px; }
.bnow { font-weight: 800; color: var(--donkerblauw); font-size: 14px; }
.bgap { font-weight: 700; font-size: 10.5px; width: 28px; text-align: right; }
.bgap.warn { color: var(--bruin); } .bgap.low { color: var(--pijn); } .bgap.ok { color: var(--oplossing); }
.align-bar { display: flex; align-items: center; gap: 8px; margin-bottom: 5px; }
.align-bar .who { width: 124px; font-size: 11.5px; color: var(--ink-faded); }
.align-bar .track { flex: 1; height: 14px; background: #efe9df; border-radius: 5px; }
.align-bar .track > div { height: 100%; border-radius: 5px; }
.align-bar .val { width: 28px; font-weight: 700; font-size: 12px; text-align: right; }

/* ===== RESPONSIVE ===== */
@media (max-width: 860px) {
  .grid-3, .cijfer-grid, .team-grid { grid-template-columns: 1fr 1fr; }
  .flow { grid-template-columns: 1fr; }
  .flow-arrow { padding: 8px 0; transform: rotate(90deg); }
  .brow { grid-template-columns: 116px 1fr 84px; }
  .steps { grid-template-columns: 1fr 1fr; }
  .whitepaper .wp-inner { grid-template-columns: 1fr; gap: 24px; }
  .site-footer .ft-inner { grid-template-columns: 1fr 1fr; }
  .site-hero-media { background-position: 78% center; }
  .site-hero-overlay { background: linear-gradient(180deg, rgba(28,36,52,.82) 0%, rgba(28,36,52,.9) 100%); }
}
@media (max-width: 620px) {
  .brand-logo { height: 42px; }
  .site-footer .brand-logo { height: 50px; }
  .nav-links { display: none; position: absolute; top: 100%; left: 0; right: 0; background: var(--warm-bg); border-bottom: 1px solid var(--border); flex-direction: column; align-items: stretch; padding: 8px 16px 16px; }
  .nav-links.open { display: flex; }
  .nav-links a { padding: 12px; }
  .nav-toggle { display: block; }
  .grid-2, .grid-3, .cijfer-grid, .team-grid, .steps { grid-template-columns: 1fr; }
  .site-hero-inner { padding: 56px 24px 60px; }
  .hero-trust { gap: 18px; }
  .dark, .cta-band, .slimmer-frame { padding: 28px 22px; }
  .section { padding: 44px 0; }
  .cta-feiten { gap: 18px; }
}
