/* ============================================================
   Beroepen Portaal — portaal.css v4.0
   Syne + DM Sans | navbar | footer | home | theme-agnostic
   ============================================================ */
:root {
  scroll-behavior: smooth;
  /* Huisstijl Beroepen-portaal.nl — Apple-inspired */
  --kb-blue:    #007AFF;
  --kb-mid:     #0066d6;
  --kb-orange:  #FF9500;
  --kb-purple:  #AF52DE;
  --kb-bg:      #f5f5f7;
  --kb-border:  rgba(0,0,0,.08);
  --kb-text:    #1d1d1f;
  --kb-muted:   #86868b;
}
.kb-wrap *, .kb-login-wrap *, .kb-nav *, .kb-footer *, .kb-home * { box-sizing: border-box; }
.kb-wrap {
  font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'SF Pro Display', 'Helvetica Neue', Arial, sans-serif;
  color: var(--kb-text); line-height: 1.5;
  max-width: 1240px; margin: 0 auto; padding: 12px 20px 24px;
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
}
.kb-wrap a { text-decoration: none; color: var(--kb-link, var(--kb-blue)); }
.kb-wrap p { margin: 0 0 8px; }
.kb-wrap h1,.kb-wrap h2,.kb-wrap h3 { line-height: 1.2; margin: 0 0 8px; font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'Helvetica Neue', Arial, sans-serif; font-weight: 600; letter-spacing: -.02em; }

/* ─── NAVBAR ──────────────────────────────────────────── */
.kb-nav {
  font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'Helvetica Neue', Arial, sans-serif;
  background: rgba(255,255,255,.72); backdrop-filter: saturate(180%) blur(20px); -webkit-backdrop-filter: saturate(180%) blur(20px);
  border-bottom: 1px solid rgba(0,0,0,.1);
  position: sticky; top: 0; z-index: 1000; width: 100%;
}
.kb-nav-inner {
  max-width: 1200px; margin: 0 auto; padding: 0 20px;
  height: 62px; display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.kb-nav-logo { display: flex; align-items: center; gap: 10px; text-decoration: none; flex-shrink: 0; }
.kb-nav-logo-img { max-height: 38px; width: auto; }
.kb-nav-logo-text { font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'Helvetica Neue', Arial, sans-serif; font-size: 17px; font-weight: 700; color: var(--kb-text); letter-spacing: -.02em; line-height: 1.1; }
.kb-nav-logo-sub { font-size: 10px; color: var(--kb-muted); font-weight: 500; }
.kb-nav-links { display: flex; align-items: center; gap: 4px; flex: 1; }
.kb-nav-link { padding: 7px 13px; border-radius: 10px; font-size: 13px; font-weight: 600; color: var(--kb-muted); text-decoration: none; transition: all .15s; white-space: nowrap; }
.kb-nav-link:hover { background: #f1f5f9; color: var(--kb-blue); }
.kb-nav-link.active { background: #eff6ff; color: var(--kb-blue); }
.kb-nav-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.kb-nav-user { font-size: 12px; color: var(--kb-muted); background: #f8fafc; padding: 5px 12px; border-radius: 20px; border: 1px solid var(--kb-border); white-space: nowrap; }
.kb-nav-burger { display: none; background: none; border: none; cursor: pointer; padding: 6px; color: var(--kb-blue); font-size: 22px; line-height: 1; }
.kb-nav-mobile { display: none; border-top: 1px solid var(--kb-border); padding: 10px 16px; background: white; flex-direction: column; gap: 4px; }
.kb-nav-mobile .kb-nav-link { padding: 10px 14px; }
@media (max-width:768px) {
  .kb-nav-links { display: none; }
  .kb-nav-burger { display: flex; align-items: center; justify-content: center; }
  .kb-nav-user { display: none; }
}

/* ─── FOOTER ──────────────────────────────────────────── */
.kb-footer {
  font-family: 'Inter', system-ui, sans-serif;
  background: var(--kb-blue); color: rgba(255,255,255,.7); margin-top: 60px;
}
.kb-footer-inner {
  max-width: 1200px; margin: 0 auto; padding: 44px 24px 0;
  display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 32px;
}
.kb-footer-logo-text { font-family: 'Inter', system-ui, sans-serif; font-size: 20px; font-weight: 800; color: white; letter-spacing: -.3px; display: block; margin-bottom: 10px; }
.kb-footer-brand p { font-size: 13px; line-height: 1.65; }
.kb-footer-col h4 { font-family: 'Inter', system-ui, sans-serif; color: white; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 14px; }
.kb-footer-col a, .kb-footer-col span { display: block; color: rgba(255,255,255,.62); font-size: 13px; margin-bottom: 9px; text-decoration: none; transition: color .15s; }
.kb-footer-col a:hover { color: white; }
.kb-footer-bottom { max-width: 1200px; margin: 0 auto; padding: 18px 24px; border-top: 1px solid rgba(255,255,255,.1); display: flex; justify-content: space-between; align-items: center; font-size: 12px; opacity: .5; flex-wrap: wrap; gap: 6px; }
@media (max-width:768px) { .kb-footer-inner { grid-template-columns: 1fr 1fr; gap: 24px; } }
@media (max-width:480px) { .kb-footer-inner { grid-template-columns: 1fr; } }

/* ─── HOME / STARTPAGINA ──────────────────────────────── */

/* De homepage secties breken uit de WordPress content container.
   Doorbreekt de theme-container via width:100vw + negatieve margin-left.
   Werkt ook als de parent overflow:hidden heeft. */

.kb-home {
  font-family: 'Inter', system-ui, sans-serif;
  width: 100vw;
  max-width: none;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  overflow-x: clip;
  overflow-y: visible;
  position: relative;
}
.kb-home * { box-sizing: border-box; }

/* Block themes (zoals SaasLauncher) zetten vaak een "constrained" max-width op kinderen.
   Forceer hier full-bleed zodat de home niet boxed wordt. */
.wp-site-blocks .kb-home,
.wp-block-group.is-layout-constrained > .kb-home,
.is-layout-constrained > .kb-home {
  width: 100vw !important;
  max-width: none !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
}

/* Sticky topbar van de home over de volle breedte houden en scroll-jitter voorkomen. */
.kb-home .kb-nav {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  z-index: 1100;
}

body.admin-bar .kb-home .kb-nav { top: 32px; }
@media (max-width: 782px) {
  body.admin-bar .kb-home .kb-nav { top: 46px; }
}

/* ── HERO ─────────────────────────────────────────────── */
.kbh-hero {
  position: relative;
  background: #001233;
  width: 100%;
  overflow: hidden;
}
.kbh-hero-bg { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.kbh-orb {
  position:absolute; border-radius:50%; filter:blur(80px); opacity:.5;
  pointer-events:none;
}
.kbh-orb-1 { width:600px; height:600px; background:#1a3fb0; top:-150px; left:-100px; }
.kbh-orb-2 { width:400px; height:400px; background:#7c3aed; bottom:-100px; right:5%; opacity:.35; }
.kbh-orb-3 { width:300px; height:300px; background:#e85d00; top:25%; left:40%; opacity:.25; }
.kbh-grid-overlay {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 48px 48px;
}
.kbh-hero-inner {
  position: relative; z-index: 1;
  max-width: 1240px; margin: 0 auto; width: 100%;
  padding: 56px 40px 48px;
  display: grid; grid-template-columns: 55% 1fr; gap: 40px; align-items: center;
}
.kbh-hero-content { min-width: 0; }
.kbh-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.09); border: 1px solid rgba(255,255,255,.18);
  border-radius: 100px; padding: 6px 16px; margin-bottom: 24px;
  font-size: 12px; font-weight: 600; color: rgba(255,255,255,.88); letter-spacing: .04em;
}
.kbh-badge-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #4ade80; box-shadow: 0 0 8px #4ade80; flex-shrink: 0;
  animation: kbhPulse 2s ease-in-out infinite;
}
@keyframes kbhPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.8)} }
.kbh-hero-title {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: clamp(28px, 3.5vw, 44px); font-weight: 800;
  color: white; line-height: 1.08; letter-spacing: -.6px; margin-bottom: 20px;
}
.kbh-hero-accent {
  background: linear-gradient(90deg, #f59e0b, #e85d00);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.kbh-hero-sub {
  font-size: 17px; color: rgba(255,255,255,.72);
  line-height: 1.65; margin-bottom: 36px;
}
.kbh-hero-btns { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 28px; }
.kbh-btn-primary {
  display: inline-flex; align-items: center; gap: 8px;
  background: linear-gradient(135deg, #e85d00, #f59e0b);
  color: white !important; padding: 14px 26px; border-radius: 14px;
  font-size: 15px; font-weight: 700; text-decoration: none;
  box-shadow: 0 4px 24px rgba(232,93,0,.4); transition: all .2s; white-space: nowrap;
}
.kbh-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 8px 32px rgba(232,93,0,.55); }
.kbh-btn-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.1); color: white !important;
  border: 1px solid rgba(255,255,255,.28); padding: 14px 22px; border-radius: 14px;
  font-size: 15px; font-weight: 600; text-decoration: none; transition: all .2s;
  white-space: nowrap; backdrop-filter: blur(8px);
}
.kbh-btn-ghost:hover { background: rgba(255,255,255,.18); }
.kbh-hero-trust {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.kbh-hero-trust span { font-size: 13px; color: rgba(255,255,255,.5); font-weight: 500; }
.kbh-trust-check { color: #4ade80; font-weight: 700; margin-right: 3px; }
.kbh-trust-dot { color: rgba(255,255,255,.2) !important; }

/* Hero visual (drijvende kaartjes) */
.kbh-hero-visual { position: relative; height: 380px; min-width: 0; overflow: hidden; border-radius: 4px; }
.kbh-card {
  background: rgba(255,255,255,.09); backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,.18); border-radius: 20px;
  color: white; position: absolute;
}
.kbh-card-main {
  left: 0; top: 30px; width: min(280px, 60%); padding: 18px;
  animation: kbhFloat 4s ease-in-out infinite;
}
.kbh-card-top { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.kbh-card-avi { font-size: 26px; flex-shrink: 0; }
.kbh-card-name { font-size: 14px; font-weight: 700; line-height: 1.3; }
.kbh-card-meta { font-size: 11px; color: rgba(255,255,255,.5); margin-top: 2px; }
.kbh-pill-green {
  margin-left: auto; flex-shrink: 0; font-size: 10px; font-weight: 700;
  background: rgba(74,222,128,.15); color: #4ade80;
  border: 1px solid rgba(74,222,128,.35); padding: 3px 10px; border-radius: 20px;
}
.kbh-card-stars-row { font-size: 13px; color: #fbbf24; margin-bottom: 12px; }
.kbh-card-stars-row span { color: rgba(255,255,255,.5); font-size: 12px; margin-left: 6px; }
.kbh-progress-row { display: flex; justify-content: space-between; font-size: 11px; color: rgba(255,255,255,.5); margin-bottom: 6px; }
.kbh-progress-track { height: 6px; background: rgba(255,255,255,.1); border-radius: 3px; overflow: hidden; }
.kbh-progress-fill { height: 100%; background: linear-gradient(90deg, #4ade80, #22d3ee); border-radius: 3px; }
.kbh-card-sm {
  padding: 12px 14px; display: flex; align-items: center; gap: 10px; width: min(180px, 38%);
}
.kbh-float-1 { right: 0; top: 10px; animation: kbhFloat 3.5s ease-in-out .6s infinite; }
.kbh-float-2 { right: 10px; bottom: 70px; animation: kbhFloat 4.5s ease-in-out 1.2s infinite; }
.kbh-card-avi-sm { font-size: 22px; flex-shrink: 0; }
.kbh-card-name-sm { font-size: 12px; font-weight: 700; }
.kbh-card-stars-sm { font-size: 11px; color: #fbbf24; margin-top: 2px; }
.kbh-card-counter {
  right: 0; bottom: 10px; padding: 14px 18px; text-align: center;
  animation: kbhFloat 5s ease-in-out .3s infinite;
}
.kbh-counter-num { font-family: 'Inter',system-ui,sans-serif; font-size: 36px; font-weight: 800; color: #4ade80; line-height: 1; }
.kbh-counter-label { font-size: 11px; color: rgba(255,255,255,.5); margin-top: 4px; line-height: 1.3; }
@keyframes kbhFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }

/* ── STATS BAR ─────────────────────────────────────────── */
.kbh-stats {
  background: linear-gradient(135deg, #003082, #0055b3);
  width: 100%;
  overflow: hidden;
}
.kbh-stats-inner {
  max-width: 1240px; margin: 0 auto; padding: 28px 40px; width: 100%;
  display: grid; grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr;
  align-items: center;
}
.kbh-stat { text-align: center; padding: 0 24px; }
.kbh-stat-num {
  font-family: 'Inter',system-ui,sans-serif; font-size: 36px; font-weight: 800; color: white; line-height: 1;
}
.kbh-stat-num sup { font-size: 22px; vertical-align: super; }
.kbh-stat-num small { font-size: 22px; font-weight: 600; }
.kbh-stat-label { font-size: 14px; color: rgba(255,255,255,.65); margin-top: 8px; }
.kbh-stat-sep { width: 1px; height: 56px; background: rgba(255,255,255,.18); }

/* ── SECTIES ────────────────────────────────────────────── */
.kbh-section { padding: 44px 0; }
.kbh-section-alt { background: #f8fafc; }
.kbh-section-inner { max-width: 1240px; margin: 0 auto; padding: 0 40px; width: 100%; }
.kbh-eyebrow {
  display: inline-block; font-size: 11px; font-weight: 800; letter-spacing: .12em;
  text-transform: uppercase; color: var(--kb-blue); background: #eff6ff;
  padding: 4px 14px; border-radius: 100px; margin-bottom: 16px;
}
.kbh-eyebrow-light { color: #93c5fd; background: rgba(255,255,255,.12); }
.kbh-title {
  font-family: 'Inter',system-ui,sans-serif; font-size: clamp(24px,3vw,36px); font-weight: 800;
  color: var(--kb-blue); text-align: center; margin-bottom: 10px; letter-spacing: -.3px;
}
.kbh-title-light { color: white; }
.kbh-subtitle {
  text-align: center; color: var(--kb-muted); font-size: 15px; line-height: 1.65;
  margin-bottom: 36px; max-width: 560px; margin-left: auto; margin-right: auto;
}
.kbh-subtitle-light { color: rgba(255,255,255,.65); }

/* ── FEATURES ──────────────────────────────────────────── */
.kbh-features {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 20px;
}
.kbh-feat {
  padding: 30px 26px; border-radius: 20px;
  border: 1px solid var(--kb-border); background: white;
  transition: all .25s; position: relative; overflow: hidden;
}
.kbh-feat::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 3px;
  opacity: 0; transition: opacity .25s; border-radius: 0 0 20px 20px;
}
.kbh-feat-blue::after   { background: linear-gradient(90deg,#003082,#3b82f6); }
.kbh-feat-orange::after { background: linear-gradient(90deg,#e85d00,#f59e0b); }
.kbh-feat-purple::after { background: linear-gradient(90deg,#7c3aed,#a78bfa); }
.kbh-feat-green::after  { background: linear-gradient(90deg,#16a34a,#4ade80); }
.kbh-feat:hover { transform: translateY(-4px); box-shadow: 0 14px 36px rgba(0,48,130,.09); border-color: transparent; }
.kbh-feat:hover::after { opacity: 1; }
.kbh-feat-icon {
  font-size: 28px; width: 58px; height: 58px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 14px; margin-bottom: 18px;
}
.kbh-feat-blue   .kbh-feat-icon { background: #eff6ff; }
.kbh-feat-orange .kbh-feat-icon { background: #fff7ed; }
.kbh-feat-purple .kbh-feat-icon { background: #f5f3ff; }
.kbh-feat-green  .kbh-feat-icon { background: #f0fdf4; }
.kbh-feat h3 { font-family: 'Inter',system-ui,sans-serif; font-size: 16px; font-weight: 700; color: var(--kb-blue); margin-bottom: 8px; }
.kbh-feat p  { font-size: 13px; color: var(--kb-muted); line-height: 1.65; margin: 0; }

/* ── STAPPEN ───────────────────────────────────────────── */
.kbh-steps-section {
  background: linear-gradient(135deg,#001233 0%,#003082 60%,#1a3fb0 100%);
  width: 100%;
  padding-top: 44px; padding-bottom: 44px;
  overflow: hidden;
}
.kbh-steps { display: flex; align-items: flex-start; gap: 0; }
.kbh-step  { flex: 1; text-align: center; padding: 0 12px; min-width: 0; }
.kbh-step-arrow { font-size: 22px; color: rgba(255,255,255,.2); padding-top: 16px; flex-shrink: 0; }
.kbh-step-n {
  width: 54px; height: 54px; border-radius: 50%; margin: 0 auto 16px;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Inter',system-ui,sans-serif; font-size: 17px; font-weight: 800; color: white;
  background: rgba(255,255,255,.14); border: 2px solid rgba(255,255,255,.22);
}
.kbh-step-n-orange { background: rgba(232,93,0,.28); border-color: rgba(232,93,0,.5); }
.kbh-step-n-purple { background: rgba(124,58,237,.28); border-color: rgba(124,58,237,.5); }
.kbh-step-n-green  { background: rgba(74,222,128,.2); border-color: rgba(74,222,128,.4); }
.kbh-step h4 { font-family: 'Inter',system-ui,sans-serif; font-size: 15px; font-weight: 700; color: white; margin-bottom: 8px; }
.kbh-step p  { font-size: 13px; color: rgba(255,255,255,.58); line-height: 1.6; margin: 0; }

/* ── VOOR WIE ──────────────────────────────────────────── */
.kbh-voor-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.kbh-voor { padding: 32px; border-radius: 24px; color: white; }
.kbh-voor-blue   { background: linear-gradient(135deg,#001233,#003082); }
.kbh-voor-purple { background: linear-gradient(135deg,#3b0764,#7c3aed); }
.kbh-voor-emoji  { font-size: 44px; margin-bottom: 20px; display: block; }
.kbh-voor h3 { font-family: 'Inter',system-ui,sans-serif; font-size: 22px; font-weight: 800; color: white; margin-bottom: 12px; }
.kbh-voor p  { color: rgba(255,255,255,.7); font-size: 14px; line-height: 1.7; margin-bottom: 20px; }
.kbh-voor ul { list-style: none; padding: 0; margin: 0 0 28px; display: flex; flex-direction: column; gap: 9px; }
.kbh-voor ul li { font-size: 14px; color: rgba(255,255,255,.85); padding-left: 22px; position: relative; }
.kbh-voor ul li::before { content: '✓'; position: absolute; left: 0; color: #4ade80; font-weight: 700; }
.kbh-voor-link {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.25);
  color: white !important; padding: 11px 20px; border-radius: 12px;
  font-size: 14px; font-weight: 600; text-decoration: none; transition: all .2s;
}
.kbh-voor-link:hover { background: rgba(255,255,255,.24); }

/* ── CTA ───────────────────────────────────────────────── */
.kbh-cta {
  background: radial-gradient(ellipse at 50% 0%,#1a3fb0 0%,#001233 70%);
  width: 100%;
  padding-top: 44px; padding-bottom: 44px;
  position: relative; overflow: hidden;
}
.kbh-cta-inner { position: relative; z-index: 1; text-align: center; max-width: 520px; margin: 0 auto; }
.kbh-cta-glow {
  position: absolute; top: -60%; left: 50%; transform: translateX(-50%);
  width: 500px; height: 300px;
  background: radial-gradient(ellipse,rgba(232,93,0,.35) 0%,transparent 70%);
  pointer-events: none;
}
.kbh-cta-emoji  { font-size: 52px; display: block; margin-bottom: 20px; }
.kbh-cta h2 {
  font-family: 'Inter',system-ui,sans-serif; font-size: clamp(24px,3vw,36px);
  font-weight: 800; color: white; margin-bottom: 12px; letter-spacing: -.3px;
}
.kbh-cta p  { font-size: 16px; color: rgba(255,255,255,.65); margin-bottom: 32px; line-height: 1.6; }
.kbh-btn-lg { font-size: 16px !important; padding: 16px 36px !important; border-radius: 16px !important; }

/* ── RESPONSIVE ────────────────────────────────────────── */
@media (max-width: 1280px) {
  .kbh-hero-inner { grid-template-columns: 1fr; padding: 56px 40px 48px; text-align: center; }
  .kbh-hero-visual { display: none; }
  .kbh-hero-sub { max-width: 600px; margin-left: auto; margin-right: auto; }
  .kbh-hero-btns  { justify-content: center; }
  .kbh-hero-trust { justify-content: center; }
}
@media (max-width: 900px) {
  .kbh-features { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .kbh-hero-inner  { padding: 56px 20px 48px; }
  .kbh-hero-title  { font-size: 34px; }
  .kbh-hero-btns   { flex-direction: column; align-items: stretch; gap: 10px; }
  .kbh-btn-primary,.kbh-btn-ghost { justify-content: center; text-align: center; }
  .kbh-stats-inner {
    grid-template-columns: 1fr 1fr; padding: 36px 20px;
  }
  .kbh-stat-sep { display: none; }
  .kbh-stat { padding: 16px 12px; border-bottom: 1px solid rgba(255,255,255,.1); }
  .kbh-stat:nth-child(odd) { border-right: 1px solid rgba(255,255,255,.1); }
  .kbh-stat-num { font-size: 32px; }
  .kbh-section { padding: 36px 0; }
  .kbh-section-inner { padding: 0 20px; }
  .kbh-features { grid-template-columns: 1fr; gap: 14px; }
  .kbh-steps-section { padding-top: 36px; padding-bottom: 36px; }
  .kbh-steps { flex-direction: column; gap: 0; }
  .kbh-step-arrow { display: none; }
  .kbh-step {
    text-align: left; padding: 20px;
    display: flex; align-items: flex-start; gap: 16px;
    border-bottom: 1px solid rgba(255,255,255,.08);
  }
  .kbh-step:last-child { border-bottom: none; }
  .kbh-step-n { margin: 0; flex-shrink: 0; width: 44px; height: 44px; font-size: 14px; }
  .kbh-step > div:not(.kbh-step-n) { flex: 1; min-width: 0; }
  .kbh-voor-grid { grid-template-columns: 1fr; gap: 16px; }
  .kbh-voor { padding: 22px 18px; }
  .kbh-hero-sub { font-size: 15px; margin-bottom: 24px; }
  .kbh-cta { padding-top: 36px; padding-bottom: 36px; }
  .kbh-cta-inner { padding: 0 20px; }
}
@media (max-width: 480px) {
  .kbh-hero-title { font-size: 28px; }
  .kbh-features   { grid-template-columns: 1fr; }
}


/* ── MOBILE FORM FIXES (alle pagina's) ── */

/* Inline grid overrides via attribute selector — werkt op elk element met inline grid */
@media (max-width: 768px) {
  /* Universeel: elk element met inline grid-template-columns → 1 kolom */
  .kb-wrap [style*="grid-template-columns"],
  .kb-home [style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
  }

  /* Uitzonderingen: stats mogen 2 kolommen houden */
  #kb-logboek-stats,
  .kbh-stats-inner {
    grid-template-columns: 1fr 1fr !important;
  }

  /* Uitzonderingen: begeleider sidebar layout */
  #kb-begel-grid {
    grid-template-columns: 1fr !important;
  }

  /* Inputs en selects: altijd full-width + geen iOS auto-zoom (font-size >= 16px) */
  .kb-login-input,
  .kb-notitie,
  .kb-field-textarea,
  .kb-field-number,
  .kb-select,
  .kb-search,
  input[type="text"],
  input[type="email"],
  input[type="password"],
  input[type="date"],
  input[type="number"],
  select,
  textarea {
    width: 100% !important;
    box-sizing: border-box !important;
    font-size: 16px !important; /* voorkomt auto-zoom op iOS Safari */
  }

  /* Filters stapelen verticaal */
  .kb-filters {
    flex-direction: column;
    align-items: stretch;
  }
  .kb-teller { margin-left: 0; }

  /* Knoppen in topbar full-width */
  .kb-topbar { flex-direction: column; align-items: stretch; gap: 10px; }
  .kb-topbar .kb-btn,
  .kb-topbar button { width: 100%; justify-content: center; }

  /* Logboek entries wrappen netjes */
  .kb-log-entry { flex-wrap: wrap; }

  /* CV sectie knoppen */
  .kb-wrap div[style*="justify-content:flex-end"] { flex-wrap: wrap; gap: 8px; }

  /* Admin modal smaller scherm */
  #kb-modal-overlay > div { width: 95vw !important; padding: 20px !important; }
  #kb-modal-overlay .form-table td,
  #kb-modal-overlay .form-table th { display: block; width: 100% !important; padding: 4px 0 !important; }
  #kb-modal-overlay .form-table select,
  #kb-modal-overlay .form-table input { width: 100% !important; }
}

@media (max-width: 480px) {
  /* Logboek stats: 2 kolommen ipv 1 */
  #kb-logboek-stats { grid-template-columns: 1fr 1fr !important; }
  .kb-card { padding: 14px; }
  .kb-log-entry { padding: 10px 12px; }
  .kb-wrap { padding: 10px; }
}

@media (max-width: 768px) {
  /* Logboek formulier */
  #kb-nieuw-form > div { grid-template-columns:1fr !important; }
  #kb-logboek-stats   { grid-template-columns:1fr 1fr !important; }

  /* Dashboard grid */
  .kb-wrap div[style*="grid-template-columns:1fr 1fr"] { grid-template-columns:1fr !important; }
  .kb-wrap div[style*="grid-template-columns: 1fr 1fr"] { grid-template-columns:1fr !important; }

  /* Begeleider aant-grid */
  .kb-aant-grid { grid-template-columns:1fr !important; }

  /* Inputs en selects altijd full-width */
  .kb-login-input, .kb-notitie, .kb-field-textarea,
  .kb-select, .kb-search { width:100% !important; box-sizing:border-box; font-size:16px !important; }
  /* font-size 16px voorkomt auto-zoom op iOS */

  /* Filters wrappen */
  .kb-filters { flex-direction:column; align-items:stretch; }
  .kb-filters .kb-select, .kb-filters .kb-search { width:100% !important; }
  .kb-teller { margin-left:0; }

  /* Logboek entry layout op mobiel */
  .kb-log-entry { flex-wrap:wrap; gap:10px; }
  .kb-log-datum { min-width:auto; }

  /* Admin gebruikers modal */
  #kb-modal-overlay > div { width:95vw !important; padding:20px !important; }
  #kb-modal-overlay .form-table td,
  #kb-modal-overlay .form-table th { display:block; width:100% !important; padding:4px 0 !important; }

  /* Buttons full-width op mobiel in forms */
  .kb-btn { width:100%; justify-content:center; }

  /* Topbar wraps */
  .kb-topbar { flex-direction:column; align-items:stretch; gap:10px; }
  .kb-topbar .kb-btn, .kb-topbar button { width:100%; }
}
@media (max-width:480px) {
  #kb-logboek-stats { grid-template-columns:1fr 1fr !important; }
  .kb-log-entry { padding:10px 12px; }
  .kb-card { padding:14px; }
  .kb-login-box { padding: 16px 12px; }
  .kbh-hero-inner { padding: 40px 16px 36px; }
  .kb-btn { width:100%; justify-content:center; }
}

/* ── MOBILE NAV ── */
@media (max-width:768px) {
  .kb-nav-inner { padding:0 16px; }
  .kb-nav-logo-text { font-size:15px; }
}


/* ─── PORTAAL INSIDE PAGES ───────────────────────────── */
.kb-topbar { display:flex; justify-content:space-between; align-items:center; padding:12px 0; margin-bottom:18px; border-bottom:none; flex-wrap:wrap; gap:10px; }
.kb-login-wrap { font-family:'Inter',system-ui,sans-serif; min-height:70vh; display:flex; align-items:center; justify-content:center; padding:20px; }
.kb-login-box  { background:rgba(255,255,255,.82); border-radius:24px; padding:36px; width:100%; max-width:420px; box-shadow:0 8px 40px rgba(0,0,0,.08); border:1px solid rgba(255,255,255,.6); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); }
.kb-login-input { width:100%; padding:12px 14px; border:1px solid rgba(0,0,0,.1); border-radius:12px; font-size:14px; font-family:inherit; outline:none; transition:border-color .2s,box-shadow .2s; background:rgba(255,255,255,.9); color:var(--kb-text); }
.kb-login-input:focus { border-color:var(--kb-blue); box-shadow:0 0 0 4px rgba(0,122,255,.12); }
.kb-notice { padding:14px 18px; border-radius:14px; margin-bottom:18px; font-size:14px; }
.kb-notice-info    { background:#eff6ff; border:1px solid #bfdbfe; color:#1d4ed8; }
.kb-notice-error   { background:#fef2f2; border:1px solid #fca5a5; color:#dc2626; }
.kb-notice-success { background:#f0fdf4; border:1px solid #86efac; color:#166534; }
.kb-btn { display:inline-flex; align-items:center; justify-content:center; gap:6px; padding:10px 20px; border-radius:980px; font-size:14px; font-weight:500; cursor:pointer; border:none; text-decoration:none; transition:all .2s ease; font-family:inherit; line-height:1.2; color:var(--kb-btn-text,#ffffff); letter-spacing:-.01em; }
.kb-btn:hover { transform:scale(1.02); filter:brightness(1.05); }
.kb-btn:active { transform:scale(.98); }
.kb-btn-primary { background:var(--kb-btn-bg,var(--kb-blue)) !important; color:var(--kb-btn-text,#ffffff) !important; }
.kb-btn-primary:hover { background:var(--kb-btn-hover,var(--kb-mid)) !important; }
.kb-btn-orange  { background:var(--kb-orange); color:#fff !important; }
.kb-btn-purple  { background:var(--kb-purple); color:#fff !important; }
.kb-btn-ghost   { background:rgba(0,0,0,.04); color:var(--kb-text) !important; border:none; }
.kb-btn-ghost:hover { background:rgba(0,0,0,.07); }
.kb-btn-sm      { padding:6px 14px; font-size:13px; }
.bp-btn { border-radius:var(--kb-btn-radius,10px); }
.bp-btn-primary { background:var(--kb-btn-bg,var(--kb-blue)) !important; border-color:var(--kb-btn-bg,var(--kb-blue)) !important; color:var(--kb-btn-text,#ffffff) !important; }
.bp-btn-primary:hover { background:var(--kb-btn-hover,var(--kb-mid)) !important; border-color:var(--kb-btn-hover,var(--kb-mid)) !important; }
.kb-hero { background:linear-gradient(135deg,#007AFF 0%,#0055d4 100%); border-radius:24px; padding:28px 32px; color:white; margin-bottom:24px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px; box-shadow:0 8px 30px rgba(0,122,255,.18); }
.kb-hero-title { font-family:-apple-system,BlinkMacSystemFont,'SF Pro Display','Helvetica Neue',Arial,sans-serif; font-size:22px; font-weight:700; letter-spacing:-.02em; }
.kb-hero-sub   { font-size:14px; opacity:.78; margin-top:4px; }
.kb-filters { display:flex; gap:8px; margin-bottom:16px; flex-wrap:wrap; align-items:center; }
.kb-select,.kb-search { padding:10px 14px; border-radius:12px; border:1px solid rgba(0,0,0,.1); font-size:14px; font-family:inherit; outline:none; background:rgba(255,255,255,.9); color:var(--kb-text); transition:border-color .2s,box-shadow .2s; }
.kb-select:focus,.kb-search:focus { border-color:var(--kb-blue); box-shadow:0 0 0 4px rgba(0,122,255,.12); }
.kb-search { width:200px; }
.kb-teller { margin-left:auto; font-size:13px; color:var(--kb-muted); }
.kb-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:12px; }
.kb-beroep-card { background:rgba(255,255,255,.85); border-radius:18px; border:1px solid rgba(255,255,255,.6); box-shadow:0 2px 12px rgba(0,0,0,.05),0 0 0 1px rgba(0,0,0,.04); overflow:hidden; transition:box-shadow .25s ease,transform .25s ease; backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); }
.kb-beroep-card:hover { box-shadow:0 8px 28px rgba(0,0,0,.1); transform:translateY(-2px); }
.kb-beroep-header { padding:12px 14px 10px; background:#fafbff; border-bottom:1px solid #f1f5f9; }
.kb-beroep-naam   { font-family:'Inter',system-ui,sans-serif; font-weight:700; color:var(--kb-blue); font-size:14px; line-height:1.3; }
.kb-beroep-sector { font-size:11px; text-transform:uppercase; letter-spacing:.06em; color:var(--kb-muted); margin-top:2px; }
.kb-beroep-body   { padding:10px 14px; }
.kb-beroep-footer { padding:8px 14px 14px; }
.kb-lvl { display:inline-block; padding:2px 8px; border-radius:20px; font-size:10px; font-weight:700; flex-shrink:0; }
.kb-lvl-basis { background:#fef3c7; color:#92400e; }
.kb-lvl-mbo   { background:#dcfce7; color:#166534; }
.kb-lvl-hoger { background:#dbeafe; color:#1e40af; }
.kb-badge-dg  { background:#ede9fe; color:#6d28d9; padding:2px 8px; border-radius:20px; font-size:10px; font-weight:700; }
.kb-check-label { display:flex; align-items:center; gap:7px; cursor:pointer; font-size:13px; font-weight:600; color:#374151; margin-bottom:5px; }
.kb-check-label input[type=checkbox] { width:15px; height:15px; cursor:pointer; accent-color:var(--kb-orange); }
.kb-notitie { width:100%; padding:10px 12px; border:1px solid rgba(0,0,0,.1); border-radius:12px; font-size:13px; font-family:inherit; resize:none; min-height:56px; outline:none; transition:border-color .2s,box-shadow .2s; background:rgba(255,255,255,.9); color:var(--kb-text); }
.kb-notitie:focus { border-color:var(--kb-blue); box-shadow:0 0 0 4px rgba(0,122,255,.12); }
.kb-card { background:rgba(255,255,255,.82); border-radius:20px; border:1px solid rgba(255,255,255,.6); box-shadow:0 2px 12px rgba(0,0,0,.06),0 0 0 1px rgba(0,0,0,.04); padding:22px; backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); }
.kb-client-btn { width:100%; padding:14px 16px; background:rgba(255,255,255,.82); border:1px solid rgba(0,0,0,.06); border-radius:14px; cursor:pointer; text-align:left; transition:all .2s ease; margin-bottom:8px; font-family:inherit; box-shadow:0 1px 4px rgba(0,0,0,.03); }
.kb-client-btn:hover { border-color:rgba(0,0,0,.1); background:rgba(255,255,255,.95); box-shadow:0 4px 16px rgba(0,0,0,.07); transform:translateY(-1px); }
.kb-aant-card  { background:rgba(255,255,255,.82); border-radius:16px; border:1px solid rgba(255,255,255,.6); margin-bottom:10px; overflow:hidden; box-shadow:0 2px 8px rgba(0,0,0,.04),0 0 0 1px rgba(0,0,0,.03); transition:box-shadow .2s ease; backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); }
.kb-aant-card:hover { box-shadow:0 4px 16px rgba(0,0,0,.08); }
.kb-aant-kop   { padding:14px 16px; background:transparent; cursor:pointer; user-select:none; transition:background .15s; }
.kb-aant-kop:hover { background:rgba(0,0,0,.02); }
.kb-aant-body  { padding:16px; border-top:1px solid rgba(0,0,0,.05); background:rgba(0,0,0,.01); }
.kb-aant-grid  { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.kb-inklap-pijl { font-size:11px; color:#94a3b8; transition:transform .2s; display:inline-block; }
.kb-sterren-preview { color:#f59e0b; font-size:13px; letter-spacing:-1px; }
.kb-client-notitie-preview { margin-top:6px; font-size:11px; background:#fff7ed; border:1px solid #fed7aa; border-radius:6px; padding:4px 8px; color:#92400e; }
.kb-sector-groep { margin-bottom:8px; }
.kb-sector-titel { font-family:'Inter',system-ui,sans-serif; font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:var(--kb-purple); margin:16px 0 8px 2px; border-bottom:2px solid #ede9fe; padding-bottom:6px; }
.kb-doelgroep-toggle { display:flex; align-items:flex-start; gap:10px; padding:10px 14px; border-radius:12px; border:2px solid var(--kb-border); margin-bottom:14px; transition:border-color .15s,background .15s; }
.kb-doelgroep-toggle.actief { border-color:var(--kb-purple); background:#f5f3ff; }
.kb-dg-cb { width:18px; height:18px; flex-shrink:0; accent-color:var(--kb-purple); cursor:pointer; margin-top:2px; }
.kb-sterren-rij { display:flex; align-items:center; gap:2px; }
.kb-ster { font-size:24px; cursor:pointer; background:none; border:none; padding:0; line-height:1; color:#e2e8f0; transition:color .1s,transform .1s; }
.kb-ster.actief { color:#f59e0b; }
.kb-ster:hover  { transform:scale(1.2); }
.kb-ster-label  { font-size:12px; color:var(--kb-muted); margin-left:8px; }
.kb-field-label { font-size:12px; font-weight:500; text-transform:none; letter-spacing:-.01em; color:var(--kb-muted); display:block; margin-bottom:6px; }
.kb-field-textarea { width:100%; padding:10px 12px; border:1.5px solid #ede9fe; background:#faf5ff; border-radius:10px; font-size:13px; font-family:inherit; resize:vertical; min-height:76px; outline:none; color:var(--kb-text); }
.kb-field-textarea:focus { border-color:var(--kb-purple); }
.kb-field-number { width:80px; padding:8px 12px; border:1.5px solid #ede9fe; background:#faf5ff; border-radius:10px; font-size:14px; font-weight:700; text-align:center; outline:none; color:var(--kb-text); }
.kb-save-status { font-size:12px; color:var(--kb-muted); min-height:18px; }
.kb-tab-btn { padding:8px 18px; border-radius:980px; border:none; background:transparent; font-size:13px; font-weight:500; color:var(--kb-muted); cursor:pointer; transition:all .2s ease; font-family:inherit; }
.kb-tab-btn.active { background:rgba(255,255,255,.9); color:var(--kb-text); box-shadow:0 1px 6px rgba(0,0,0,.08),0 0 0 1px rgba(0,0,0,.04); }
.kb-begel-tabs { display:flex; gap:2px; background:rgba(0,0,0,.04); padding:3px; border-radius:980px; width:fit-content; margin-bottom:22px; flex-wrap:wrap; }
.kb-begel-tab { padding:9px 20px; border-radius:980px; border:none; background:transparent; font-size:13px; font-weight:500; color:var(--kb-muted); cursor:pointer; transition:all .2s ease; font-family:inherit; }
.kb-begel-tab.active { background:rgba(255,255,255,.95); color:var(--kb-text); box-shadow:0 1px 6px rgba(0,0,0,.08),0 0 0 1px rgba(0,0,0,.04); }
.kb-client-tbl { width:100%; border-collapse:collapse; font-size:14px; }
.kb-client-tbl th { text-align:left; padding:10px 14px; color:var(--kb-muted); font-size:12px; text-transform:none; font-weight:500; border-bottom:1px solid rgba(0,0,0,.06); letter-spacing:-.01em; }
.kb-client-tbl td { padding:12px 14px; border-bottom:1px solid rgba(0,0,0,.04); vertical-align:middle; }
.kb-client-tbl tr:hover td { background:rgba(0,0,0,.02); }
.kb-begel-print-header { display:none; }
.kb-log-maand-header { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:#94a3b8; margin:20px 0 8px; padding-bottom:4px; border-bottom:1px solid #f1f5f9; }
.kb-log-entry  { display:flex; gap:14px; align-items:flex-start; background:rgba(255,255,255,.82); border:1px solid rgba(255,255,255,.6); border-radius:16px; padding:16px 18px; margin-bottom:10px; transition:box-shadow .25s ease,transform .25s ease; box-shadow:0 1px 6px rgba(0,0,0,.04); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); }
.kb-log-entry:hover { box-shadow:0 6px 20px rgba(0,0,0,.08); transform:translateY(-1px); }
.kb-log-datum  { flex-shrink:0; text-align:center; min-width:48px; }
.kb-log-acties { flex-shrink:0; }
.kb-print-header { display:none; }

/* Admin beheer (front-end) */
.bp-admin-block input[type="text"],
.bp-admin-block input[type="email"],
.bp-admin-block input[type="password"],
.bp-admin-block select {
  width: 100% !important;
  min-height: 44px !important;
  padding: 10px 12px !important;
  font-size: 14px !important;
  border-radius: 10px !important;
  box-sizing: border-box !important;
}

.bp-admin-block .bp-form-row { margin-bottom: 12px; }

.bp-tabs { display:flex; gap:10px; flex-wrap:wrap; margin-top:14px; margin-bottom:14px; }
.bp-tab-button {
  background:#f1f5f9;
  border:1px solid #e2e8f0;
  padding:10px 14px;
  border-radius:12px;
  cursor:pointer;
  font-weight:800;
  font-size:13px;
}
.bp-tab-button.active { background: #003082; border-color:#003082; color:#fff; }
.bp-tab-content { display:none; }
.bp-tab-content.active { display:block; }

.bp-admin-card { background:#fafafa; border:1px solid #e5e7eb; border-radius:14px; padding:16px; }
.bp-admin-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media (max-width:900px) { .bp-admin-grid { grid-template-columns:1fr; } }

.bp-bulk-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
@media (max-width:900px) { .bp-bulk-grid { grid-template-columns:1fr; } }

/* Fallback styling for auteur-tag in oudere begeleider-logboek renderer. */
#kb-ws-begel-logboek .kb-begel-log-entry > div:first-child > div:first-child > span:nth-child(3) {
  display: inline-flex !important;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 999px;
  background: #eef2ff;
  color: #3730a3 !important;
  border: 1px solid #c7d2fe;
  font-weight: 600;
}

@media (max-width:768px) {
  .kb-hero { flex-direction:column; }
  .kb-grid { grid-template-columns:1fr; }
  .kb-aant-grid { grid-template-columns:1fr !important; }
  .kb-search { width:100%; }
  .kb-wrap { padding: 4px 10px 16px; }
  .kb-begel-tabs { width:100%; }
  /* Login box: minder padding op mobiel */
  .kb-login-box { padding: 20px 16px; }
  /* Dashboard hero: naast-elkaar → onder-elkaar */
  .kb-dash-hero-flex { flex-direction: column !important; gap: 12px !important; }
}
@media print {
  .kb-no-print,.kb-topbar,.kb-filters,nav,header,footer,
  .kb-hero > div:last-child,#wpadminbar,.site-header,
  .kb-client-btn,#kb-client-list,#kb-logboek-stats,
  #kb-nieuw-form,.kb-sterren-rij,.kb-doelgroep-toggle,
  .kb-log-acties,.kb-nav,.kb-footer,.kb-begel-tabs,
  #begel-tab-clients,#begel-tab-archief { display:none !important; }
  .kb-begel-print-header { display:block !important; }
  .kb-print-header { display:block !important; }
  #kb-logboek-entries { display:none !important; }
  #kb-print-entries   { display:block !important; }
  .kb-aant-card { box-shadow:none !important; border:1px solid #e2e8f0 !important; margin-bottom:6px !important; break-inside:avoid; }
  .kb-aant-body { display:block !important; padding:8px 12px !important; }
  .kb-aant-kop  { display:block !important; }
  .kb-aant-grid { grid-template-columns:1fr 1fr !important; gap:8px !important; }
  .kb-field-textarea,.kb-field-number { border:none !important; background:transparent !important; padding:2px 0 !important; font-size:11px !important; min-height:auto !important; }
  .kb-sector-titel { margin:10px 0 4px !important; font-size:10px !important; }
  .kb-beroep-card { box-shadow:none !important; border:1px solid #e2e8f0 !important; break-inside:avoid; margin-bottom:6px !important; }
  .kb-notitie,.kb-field-textarea { border:none !important; background:transparent !important; }
  .kb-hero { border-radius:10px !important; padding:14px !important; break-after:avoid; }
  .kb-log-entry { break-inside:avoid; border:1px solid #e2e8f0 !important; margin-bottom:4px !important; }
  .kb-wrap { max-width:100%; padding:0; }
  body { font-size:11px; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
  @page { size:A4 portrait; margin:14mm; }
}
