/* =============================================================
   MeneerOnline — main.css
   Gebaseerd op prototype index-v4.html
   ============================================================= */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --color-primary:#17C69C;
  --color-primary-dark:#12A882;
  --color-primary-light:#E8FAF5;
  --color-black:#1A1A1A;
  --color-white:#FFFFFF;
  --color-bg-alt:#EEF2F7;
  --color-bg-dark:#0E1117;
  --color-bg-dark-alt:#161B27;
  --color-text-muted:#64748B;
  --color-border:#E2E8F0;
  --radius-card:12px;
  --radius-lg:20px;
  --radius-pill:100px;
  --shadow:0 4px 24px rgba(0,0,0,0.07);
  --shadow-dark:0 8px 40px rgba(0,0,0,0.4);
}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;line-height:1.6;color:var(--color-black);background:var(--color-white);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 20px}
@media(min-width:768px){.container{padding:0 32px}}
@media(min-width:1024px){.container{padding:0 40px}}

/* SECTION LABELS */
.section-label{display:inline-flex;flex-direction:column;gap:10px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--color-primary);margin-bottom:16px}
.section-label::before{content:'';width:40px;height:3px;background:var(--color-primary);border-radius:2px}
.diensten-header .section-label,.section-groeiscan .section-label{align-items:center}

/* ===================== NAV ===================== */
#siteNav{position:fixed;top:0;left:0;right:0;z-index:100;padding:0;pointer-events:none}
.nav-pill{width:100%;background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 1px 0 rgba(0,0,0,0.07);border-radius:0;height:96px;display:flex;align-items:center;pointer-events:auto;transition:box-shadow 0.4s ease,height 0.4s ease}
#siteNav.scrolled .nav-pill{box-shadow:0 2px 20px rgba(0,0,0,0.09)}
.nav-inner{width:100%;max-width:1200px;margin:0 auto;padding:0 20px;display:flex;align-items:center;gap:16px}
@media(min-width:768px){.nav-inner{padding:0 32px}}
@media(min-width:1024px){.nav-inner{padding:0 40px}}
.nav-logo img{display:block;height:84px;width:auto;max-width:none;transition:height 0.4s ease}
/* Krimp bij scrollen alleen op desktop; mobiel houdt altijd het grote logo */
@media(min-width:768px){#siteNav.scrolled .nav-pill{height:64px}#siteNav.scrolled .nav-logo img{height:28px}}
.nav-links{display:none;gap:32px;list-style:none;margin-left:auto}
@media(min-width:1024px){.nav-links{display:flex;align-items:center}}
.nav-links a{font-size:16px;font-weight:600;color:var(--color-black);transition:color 0.3s}
.nav-links a:hover{color:var(--color-primary)}
.nav-right{display:flex;align-items:center;gap:8px}
/* Mobiel/tablet: hoofdmenu is verborgen, dus pin de hamburger vast rechts */
@media(max-width:1023px){.nav-right{margin-left:auto}}
.nav-cta{display:none;background:var(--color-primary);color:white;border:none;font-weight:700;font-size:14px;border-radius:8px;padding:10px 22px;transition:background 0.2s,transform 0.15s;white-space:nowrap}
.nav-cta:hover{background:var(--color-primary-dark);transform:translateY(-1px)}
@media(min-width:768px){.nav-cta{display:inline-flex;align-items:center}}
#navToggle{display:flex;flex-direction:column;justify-content:center;background:none;border:none;width:44px;height:44px;align-items:center;gap:0;padding:0}
@media(min-width:1024px){#navToggle{display:none}}
.hamburger-bar{display:block;width:22px;height:2px;background:var(--color-black);border-radius:2px;transition:transform 0.25s,opacity 0.25s;transform-origin:center}
.hamburger-bar+.hamburger-bar{margin-top:5px}
#navToggle.is-open .hamburger-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
#navToggle.is-open .hamburger-bar:nth-child(2){opacity:0}
#navToggle.is-open .hamburger-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* NAV MOBILE */
.nav-mobile{display:none;position:fixed;inset:0;background:white;z-index:99;padding:80px 24px 40px;flex-direction:column;gap:8px;overflow-y:auto}
.nav-mobile.open{display:flex}
.nav-mobile a{font-size:22px;font-weight:700;color:var(--color-black);padding:14px 0;border-bottom:1px solid var(--color-bg-alt)}
.nav-mobile .mob-cta{margin-top:auto;display:block;background:var(--color-primary);color:white;text-align:center;border-radius:10px;padding:16px;font-weight:700;font-size:18px;border:none}

/* ===================== HERO SPLIT ===================== */
.hero-split{background:#ffffff;background-image:linear-gradient(rgba(23,198,156,0.05) 1px,transparent 1px),linear-gradient(to right,rgba(23,198,156,0.05) 1px,transparent 1px);background-size:48px 48px;display:flex;align-items:center;padding:128px 0 64px}
@media(min-width:1024px){.hero-split{padding:140px 0 80px}}
.hero-split-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:1024px){.hero-split-grid{grid-template-columns:1fr 1fr;gap:64px}}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(23,198,156,0.1);border:1px solid rgba(23,198,156,0.25);border-radius:100px;padding:7px 16px;font-size:12px;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:24px}
.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--color-primary);flex-shrink:0}
.hero-h1{font-size:clamp(36px,5.5vw,72px);font-weight:800;color:var(--color-black);line-height:1.07;letter-spacing:-2px;margin-bottom:24px;max-width:580px}
.hero-green{color:var(--color-primary);display:block}
.hero-sub{font-size:17px;color:var(--color-text-muted);line-height:1.7;max-width:480px;margin-bottom:36px}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px}
.hero-btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--color-primary);color:white;border-radius:10px;padding:15px 28px;font-size:15px;font-weight:700;transition:background 0.2s,transform 0.15s;white-space:nowrap}
.hero-btn-primary:hover{background:var(--color-primary-dark);transform:translateY(-1px)}
.hero-btn-outline{display:inline-flex;align-items:center;background:transparent;color:var(--color-black);border:1.5px solid var(--color-border);border-radius:10px;padding:15px 28px;font-size:15px;font-weight:700;transition:border-color 0.2s,transform 0.15s;white-space:nowrap}
.hero-btn-outline:hover{border-color:#94a3b8;transform:translateY(-1px)}
.hero-right{position:relative}
.hero-img-wrap{position:relative;border-radius:20px;overflow:visible}
.hero-img{width:100%;height:480px;object-fit:cover;object-position:center top;border-radius:20px;display:block;box-shadow:0 24px 80px rgba(0,0,0,0.14)}
@media(min-width:1024px){.hero-img{height:560px}}
.hero-location{position:absolute;top:16px;right:16px;background:white;border-radius:100px;padding:7px 14px;font-size:12px;font-weight:700;color:var(--color-black);display:flex;align-items:center;gap:5px;box-shadow:0 4px 16px rgba(0,0,0,0.12);z-index:2}
.hero-card{position:absolute;background:white;border-radius:14px;padding:14px 18px;box-shadow:0 8px 32px rgba(0,0,0,0.11),0 2px 8px rgba(0,0,0,0.05);max-width:210px;z-index:2}
.hero-card-icon{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:0.08em;color:var(--color-primary);margin-bottom:6px}
.hero-card p{font-size:13px;font-weight:600;color:var(--color-black);line-height:1.5;margin:0}
.hero-card-left{left:-28px;top:28%}
.hero-card-right{right:-20px;bottom:18%}
@media(max-width:1023px){.hero-card-left{left:12px;top:auto;bottom:120px}.hero-card-right{right:12px;bottom:12px}}

/* ===================== SECTION: PROBLEEM ===================== */
.section-probleem{background:white;padding:80px 0}
.section-probleem h2{font-size:clamp(26px,4vw,42px);font-weight:800;color:var(--color-black);margin-bottom:32px}
.pain-grid{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:640px){.pain-grid{grid-template-columns:1fr 1fr}}
.pain-card{background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-card);padding:20px 20px 20px 52px;position:relative}
.pain-dot{position:absolute;width:10px;height:10px;border-radius:50%;top:24px;left:20px;background:linear-gradient(135deg,#FF6B6B,#FF9F43)}
.pain-card p{font-size:15px;font-weight:600;color:var(--color-black);line-height:1.5}
.probleem-callout{border-left:4px solid var(--color-primary);background:white;padding:24px 28px;margin-top:24px;border-radius:0 var(--radius-card) var(--radius-card) 0;box-shadow:0 2px 12px rgba(23,198,156,0.08)}
.probleem-callout p{font-size:16px;font-style:italic;color:var(--color-black);font-weight:600;line-height:1.6;margin-bottom:16px}
.btn-green-pill{background:var(--color-primary);color:white;border:none;border-radius:10px;padding:12px 24px;font-size:14px;font-weight:700;transition:background 0.2s,transform 0.15s;display:inline-flex;align-items:center;min-height:44px;white-space:nowrap}
.btn-green-pill:hover{background:var(--color-primary-dark);transform:translateY(-1px)}

/* ===================== SECTION: DIENSTEN ===================== */
.section-diensten{background:#F0FAF6;padding:80px 0}
.section-diensten h2{font-size:clamp(26px,4vw,42px);font-weight:800;color:var(--color-black);margin-bottom:12px}
.section-diensten .section-sub{font-size:16px;color:var(--color-text-muted);max-width:560px;margin:0 auto 40px;text-align:center;line-height:1.7}
.diensten-header{text-align:center}
.diensten-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:640px){.diensten-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.diensten-grid{grid-template-columns:repeat(3,1fr)}}
.dienst-card{background:white;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;position:relative;overflow:hidden;transition:border-color 0.2s,box-shadow 0.2s,transform 0.2s}
.dienst-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-primary);transform:scaleX(0);transition:transform 0.25s;transform-origin:left}
.dienst-card:hover{border-color:transparent;box-shadow:var(--shadow);transform:translateY(-2px)}
.dienst-card:hover::before{transform:scaleX(1)}
.dienst-card.featured{background:var(--color-black);color:white}
.dienst-card.featured::before{transform:scaleX(1)}
.dienst-icon{width:40px;height:40px;background:var(--color-primary-light);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.dienst-card.featured .dienst-icon{background:rgba(23,198,156,0.15)}
.dienst-name{font-weight:700;font-size:16px;margin-bottom:6px}
.dienst-card.featured .dienst-name{color:white}
.dienst-desc{font-size:14px;color:var(--color-text-muted);line-height:1.5;margin-bottom:16px}
.dienst-card.featured .dienst-desc{color:rgba(255,255,255,0.6)}
.dienst-link{font-size:14px;font-weight:600;color:var(--color-primary)}

/* ===================== SECTION: RESULTATEN (GREEN) ===================== */
.section-resultaten{background:var(--color-primary);padding:80px 0}
.section-resultaten-label{display:inline-block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:rgba(255,255,255,0.65);margin-bottom:12px}
.section-resultaten h2{font-size:clamp(26px,4vw,42px);font-weight:800;color:white;margin-bottom:48px}
.stats-green-row{display:grid;grid-template-columns:1fr 1fr;gap:0}
@media(min-width:768px){.stats-green-row{grid-template-columns:repeat(4,1fr)}}
.stat-green-item{text-align:center;padding:32px 20px;border-right:1px solid rgba(255,255,255,0.15)}
.stat-green-item:last-child{border-right:none}
@media(max-width:767px){.stat-green-item:nth-child(2){border-right:none}.stat-green-item:nth-child(3){border-right:1px solid rgba(255,255,255,0.15)}}
.stat-green-number{font-size:clamp(56px,8vw,96px);font-weight:800;color:white;line-height:1;letter-spacing:-3px}
.stat-green-label{color:rgba(255,255,255,0.75);font-size:14px;margin-top:8px;line-height:1.4}
.cases-green-sep{margin-top:56px}
.cases-green-sep h3{font-size:clamp(20px,3vw,28px);font-weight:800;color:white;margin-bottom:24px;text-align:center}
.cases-green-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:768px){.cases-green-grid{grid-template-columns:repeat(3,1fr)}}
.case-green-card{background:rgba(0,0,0,0.15);border-radius:var(--radius-card);padding:24px;transition:background 0.2s}
.case-green-card:hover{background:rgba(0,0,0,0.22)}
.case-green-sector{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:rgba(255,255,255,0.6);margin-bottom:6px}
.case-green-company{color:white;font-weight:700;font-size:18px;margin-bottom:12px}
.case-green-stat{color:rgba(255,255,255,0.95);font-size:24px;font-weight:800;line-height:1.1;margin-bottom:4px}
.case-green-result{color:rgba(255,255,255,0.65);font-size:14px;line-height:1.5}
.cases-green-cta{display:block;text-align:center;margin-top:40px}
.btn-white-pill{display:inline-flex;align-items:center;background:white;color:var(--color-primary);border-radius:10px;padding:14px 32px;font-size:15px;font-weight:700;transition:background 0.2s,transform 0.15s}
.btn-white-pill:hover{background:rgba(255,255,255,0.9);transform:translateY(-1px)}

/* ===================== SECTION: TEAM ===================== */
.section-team{background:white;padding:80px 0}
.team-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:1024px){.team-grid{grid-template-columns:1fr 1fr;gap:64px}}
.section-team h2{font-size:clamp(26px,4vw,40px);font-weight:800;color:var(--color-black);margin-bottom:16px}
.section-team p{font-size:16px;color:var(--color-text-muted);line-height:1.75;margin-bottom:24px}
.pull-quote{border-left:3px solid var(--color-primary);padding-left:20px;margin:24px 0;font-size:18px;font-style:italic;color:var(--color-black);font-weight:600;line-height:1.5}
.team-member{display:flex;align-items:center;gap:14px;padding:16px;border:1px solid var(--color-border);border-radius:var(--radius-card);margin-bottom:12px}
.team-avatar{width:52px;height:52px;border-radius:50%;object-fit:cover;border:2px solid var(--color-primary-light);flex-shrink:0}
.team-name{font-weight:700;font-size:15px;color:var(--color-black)}
.team-role{font-size:13px;color:var(--color-text-muted);margin-top:2px}
.team-photo-wrap{position:relative;border-radius:var(--radius-lg);overflow:hidden;min-height:360px}
.team-photo-wrap img{width:100%;height:100%;object-fit:cover;min-height:360px}
.rotterdam-badge{position:absolute;bottom:20px;left:20px;background:white;border-radius:100px;padding:8px 16px;display:flex;align-items:center;gap:8px;box-shadow:0 4px 16px rgba(0,0,0,0.15);font-weight:700;font-size:14px;color:var(--color-black)}

/* ===================== SECTION: VOOR WIE ===================== */
.section-voorwie{background:white;padding:80px 0}
.section-voorwie h2{font-size:clamp(26px,4vw,42px);font-weight:800;color:var(--color-black);margin-bottom:32px}
.voorwie-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:640px){.voorwie-grid{grid-template-columns:1fr 1fr}}
.voorwie-card{border-radius:var(--radius-lg);overflow:hidden;position:relative;height:280px;cursor:pointer;transition:transform 0.25s;display:block}
.voorwie-card:hover{transform:scale(1.02)}
.voorwie-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.voorwie-img-placeholder{position:absolute;inset:0;background:linear-gradient(135deg,var(--color-primary-dark),var(--color-bg-dark))}
.voorwie-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(14,17,23,0.85) 0%,rgba(14,17,23,0.2) 60%,transparent 100%)}
.voorwie-content{position:absolute;bottom:0;left:0;right:0;padding:24px}
.voorwie-title{color:white;font-weight:800;font-size:20px;margin-bottom:6px}
.voorwie-desc{color:rgba(255,255,255,0.75);font-size:13px;line-height:1.5;margin-bottom:12px}
.voorwie-link{display:inline-flex;align-items:center;gap:6px;color:var(--color-primary);font-weight:700;font-size:13px}

/* ===================== SECTION: LOGO SLIDER ===================== */
:root{
  --bs-primary:#17C69C;
  --bs-surface:#ffffff;
  --bs-bg:#F0FAF6;
  --bs-border:#E2E8F0;
  --bs-text:#1A1A1A;
  --bs-text-muted:#64748B;
  --bs-cta:#17C69C;
  --bs-radius:12px;
  --bs-gap:20px;
  --bs-speed:32s;
}
.brand-slider-section{background:white;padding:64px 0}
.brand-slider-section__header{text-align:center;margin-bottom:40px}
.brand-slider-section__header .section-label{display:inline-flex;align-items:center;margin-bottom:16px}
.brand-slider-section__header h2{font-size:clamp(1.25rem,2.5vw,1.75rem);font-weight:800;color:var(--bs-text);letter-spacing:-0.02em;margin:0}
@keyframes brand-scroll{
  from{transform:translateX(0)}
  to{transform:translateX(calc(-100% / var(--set-count, 2)))}
}
.brand-slider{
  overflow:hidden;
  -webkit-mask-image:linear-gradient(to right,transparent 0%,black 6%,black 94%,transparent 100%);
          mask-image:linear-gradient(to right,transparent 0%,black 6%,black 94%,transparent 100%);
}
.brand-slider:hover .brand-track{animation-play-state:paused}
.brand-track{display:flex;width:max-content;animation:brand-scroll var(--bs-speed) linear infinite}
.brand-set{display:flex;gap:var(--bs-gap);padding-inline-end:var(--bs-gap)}
.brand-logo{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 18px;
  background:var(--bs-surface);
  border:1.5px solid var(--bs-border);
  border-radius:var(--bs-radius);
  min-height:104px;min-width:200px;
  transition:border-color .2s ease,box-shadow .2s ease;
  flex-shrink:0;
}
.brand-logo img{
  max-width:220px;max-height:84px;width:auto;height:auto;
  object-fit:contain;
  filter:grayscale(100%);opacity:.5;
  transition:filter .2s ease,opacity .2s ease;
}
.brand-slider .brand-logo:hover{border-color:var(--bs-primary);box-shadow:0 2px 12px rgba(23,198,156,0.12)}
.brand-slider .brand-logo:hover img{filter:grayscale(0%);opacity:1}
@media(prefers-reduced-motion:reduce){
  .brand-track{animation:none}
  .brand-slider{overflow-x:auto;-webkit-mask-image:none;mask-image:none;scrollbar-width:none}
  .brand-slider::-webkit-scrollbar{display:none}
}

/* ===================== SECTION: LOKALE MARKETING ===================== */
.section-lokaal{background:#F0FAF6;padding:88px 0}
.lokaal-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:1024px){.lokaal-grid{grid-template-columns:1fr 1fr;gap:64px}}
.lokaal-badge{display:inline-flex;align-items:center;border:1px solid rgba(23,198,156,0.4);border-radius:100px;padding:7px 16px;font-size:11px;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:24px}
.lokaal-h2{font-size:clamp(32px,5vw,52px);font-weight:800;color:var(--color-black);line-height:1.08;letter-spacing:-1.5px;margin-bottom:20px}
.lokaal-h2 span{color:var(--color-primary)}
.lokaal-sub{font-size:17px;color:var(--color-text-muted);line-height:1.75;max-width:480px;margin-bottom:36px}
.lokaal-cta{display:inline-flex;align-items:center;gap:8px;background:var(--color-primary);color:white;border-radius:10px;padding:15px 28px;font-size:15px;font-weight:700;transition:background 0.2s,transform 0.15s}
.lokaal-cta:hover{background:var(--color-primary-dark);transform:translateY(-1px)}
.lokaal-card{background:white;border:1px solid rgba(23,198,156,0.25);border-radius:16px;padding:32px;box-shadow:0 2px 16px rgba(23,198,156,0.08)}
.lokaal-card-label{display:flex;align-items:center;gap:7px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:0.1em;color:var(--color-primary);margin-bottom:20px}
.lokaal-stat{font-size:clamp(36px,5vw,52px);font-weight:800;color:var(--color-black);letter-spacing:-1.5px;line-height:1;margin-bottom:8px}
.lokaal-stat-sub{font-size:14px;color:var(--color-text-muted);line-height:1.5}

/* ===================== SECTION: GEO ===================== */
.section-geo{background:var(--color-bg-dark);padding:88px 0}
.geo-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:1024px){.geo-grid{grid-template-columns:1fr 1fr;gap:64px}}
.geo-badge{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(23,198,156,0.4);border-radius:100px;padding:7px 16px;font-size:11px;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:24px}
.geo-h2{font-size:clamp(32px,5vw,56px);font-weight:800;color:white;line-height:1.08;letter-spacing:-1.5px;margin-bottom:20px}
.geo-h2 span{color:var(--color-primary)}
.geo-sub{font-size:17px;color:rgba(255,255,255,0.6);line-height:1.75;max-width:480px;margin-bottom:36px}
.geo-cta{display:inline-flex;align-items:center;gap:8px;background:var(--color-primary);color:white;border-radius:10px;padding:15px 28px;font-size:15px;font-weight:700;transition:background 0.2s,transform 0.15s}
.geo-cta:hover{background:var(--color-primary-dark);transform:translateY(-1px)}
.geo-answer-card{background:#161B27;border:1px solid rgba(255,255,255,0.08);border-radius:16px;padding:28px;position:relative}
.geo-answer-label{display:flex;align-items:center;gap:7px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:0.1em;color:var(--color-primary);margin-bottom:16px}
.geo-answer-label svg{flex-shrink:0}
.geo-answer-text{font-size:15px;color:rgba(255,255,255,0.85);line-height:1.75;font-style:italic;margin-bottom:20px}
.geo-answer-text mark{background:rgba(23,198,156,0.2);color:var(--color-primary);border-radius:3px;padding:1px 4px;font-style:normal;font-weight:700}
.geo-sources{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.geo-source{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.1);border-radius:100px;padding:5px 12px;font-size:12px;font-weight:600;color:rgba(255,255,255,0.6)}
.geo-source svg{flex-shrink:0;opacity:0.5}

/* ===================== SECTION: GROEISCAN ===================== */
.section-groeiscan{background:#F0FAF6;padding:80px 0;text-align:center}
.section-groeiscan h2{font-size:clamp(26px,4vw,42px);font-weight:800;color:var(--color-black);margin-bottom:12px}
.section-groeiscan .scan-sub{color:var(--color-text-muted);font-size:clamp(15px,2vw,18px);max-width:600px;margin:0 auto;line-height:1.7}
.form-card{background:white;border-radius:var(--radius-lg);padding:36px;max-width:720px;margin:40px auto 0;box-shadow:0 8px 40px rgba(0,0,0,0.08);text-align:left}
.form-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:768px){.form-grid{grid-template-columns:1fr 1fr}}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group.full{grid-column:1 / -1}
.form-group label{font-size:14px;font-weight:600;color:var(--color-black)}
.form-group input,.form-group textarea{width:100%;border:1px solid var(--color-border);border-radius:8px;padding:11px 14px;font-family:inherit;font-size:15px;color:var(--color-black);transition:border-color 0.2s;background:white}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary)}
.form-group textarea{resize:vertical;min-height:88px}
.checkbox-group{grid-column:1 / -1}
.checkbox-group-label{font-size:14px;font-weight:600;color:var(--color-black);display:block;margin-bottom:10px}
.pill-checks{display:flex;flex-wrap:wrap;gap:0}
.pill-check{display:none}
.pill-check-label{border:1px solid var(--color-border);border-radius:var(--radius-pill);padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:all 0.15s;display:inline-block;margin:4px;color:var(--color-black)}
.pill-check:checked+.pill-check-label{background:var(--color-primary);border-color:var(--color-primary);color:white}
.btn-submit{width:100%;background:var(--color-primary);color:white;border:none;border-radius:10px;padding:16px 32px;font-size:16px;font-weight:700;cursor:pointer;transition:background 0.2s,transform 0.15s;margin-top:8px;min-height:52px}
.btn-submit:hover{background:var(--color-primary-dark);transform:translateY(-1px)}
.form-privacy{font-size:12px;color:var(--color-text-muted);text-align:center;margin-top:12px}

/* ===================== SECTION: TESTIMONIALS ===================== */
.section-testimonials{background:var(--color-bg-alt);padding:80px 0}
.section-testimonials h2{font-size:clamp(26px,4vw,42px);font-weight:800;color:var(--color-black);margin-bottom:40px}
.testimonials-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:768px){.testimonials-grid{grid-template-columns:repeat(3,1fr)}}
.testimonial-card{background:white;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow);display:flex;flex-direction:column}
.testimonial-stars{color:#F59E0B;font-size:15px;letter-spacing:2px;margin-bottom:16px}
.testimonial-quote{font-size:15px;line-height:1.75;color:var(--color-black);font-style:italic;margin-bottom:24px;flex:1}
.testimonial-author{display:flex;align-items:center;gap:12px;padding-top:20px;border-top:1px solid var(--color-border)}
.testimonial-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0}
.testimonial-name{font-weight:700;font-size:14px;color:var(--color-black)}
.testimonial-company{font-size:13px;color:var(--color-text-muted)}

/* ===================== SECTION: INTERNATIONAAL ===================== */
.section-intl{background:#F0FAF6;padding:88px 0}
.intl-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:1024px){.intl-grid{grid-template-columns:1fr 1fr;gap:64px}}
.intl-h2{font-size:clamp(32px,5vw,56px);font-weight:800;color:var(--color-black);line-height:1.08;letter-spacing:-1.5px;margin-bottom:20px}
.intl-h2 span{color:var(--color-primary)}
.intl-body{font-size:16px;color:var(--color-text-muted);line-height:1.75;margin-bottom:32px;max-width:480px}
.intl-cta{display:inline-flex;align-items:center;gap:8px;background:var(--color-primary);color:white;border-radius:10px;padding:14px 24px;font-size:15px;font-weight:700;transition:background 0.2s,transform 0.15s}
.intl-cta:hover{background:var(--color-primary-dark);transform:translateY(-1px)}
.intl-card{background:white;border:1px solid rgba(23,198,156,0.25);border-radius:16px;padding:32px;box-shadow:0 2px 16px rgba(23,198,156,0.08)}
.intl-card-label{display:flex;align-items:center;gap:7px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:0.1em;color:var(--color-primary);margin-bottom:20px}
.intl-stat{font-size:clamp(32px,4vw,48px);font-weight:800;color:var(--color-black);letter-spacing:-1.5px;line-height:1;margin-bottom:10px}
.intl-stat-sub{font-size:14px;color:var(--color-text-muted);line-height:1.6}

/* ===================== SECTION: FINAL CTA ===================== */
.section-final-cta{background:white;padding:80px 0}
.final-cta-card{background:white;border-radius:20px;padding:48px;box-shadow:0 4px 32px rgba(0,0,0,0.06);display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:1024px){.final-cta-card{grid-template-columns:1fr 1fr;gap:64px}}
.final-cta-badge{display:inline-flex;align-items:center;background:var(--color-primary-light);border:1px solid rgba(23,198,156,0.25);border-radius:100px;padding:6px 14px;font-size:11px;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:20px}
.final-cta-card h2{font-size:clamp(28px,4vw,44px);font-weight:800;color:var(--color-black);letter-spacing:-1.5px;line-height:1.1;margin-bottom:16px}
.final-cta-card .cta-sub{color:var(--color-text-muted);font-size:16px;line-height:1.7;margin-bottom:32px;max-width:420px}
.cta-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-primary-lg{background:var(--color-primary);color:white;border:none;border-radius:10px;padding:15px 28px;font-size:15px;font-weight:700;transition:background 0.2s,transform 0.15s;display:inline-flex;align-items:center;gap:8px}
.btn-primary-lg:hover{background:var(--color-primary-dark);transform:translateY(-1px)}
.btn-dark-outline-lg{background:transparent;color:var(--color-black);border:1.5px solid var(--color-border);border-radius:10px;padding:15px 28px;font-size:15px;font-weight:700;transition:border-color 0.2s,transform 0.15s;display:inline-flex;align-items:center;gap:8px}
.btn-dark-outline-lg:hover{border-color:var(--color-black);transform:translateY(-1px)}
.final-cta-info{background:var(--color-primary-light);border:1px solid rgba(23,198,156,0.25);border-radius:16px;padding:28px}
.final-cta-info-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:0.1em;color:var(--color-text-muted);margin-bottom:8px}
.final-cta-info-stat{font-size:clamp(32px,4vw,48px);font-weight:800;color:var(--color-black);letter-spacing:-1.5px;line-height:1;margin-bottom:10px}
.final-cta-info-desc{font-size:14px;color:var(--color-text-muted);line-height:1.6;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid rgba(23,198,156,0.2)}
.final-cta-meta{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.final-cta-meta-item{}
.final-cta-meta-key{font-size:11px;color:var(--color-text-muted);margin-bottom:3px}
.final-cta-meta-val{font-size:14px;font-weight:700;color:var(--color-black)}

/* ===================== FOOTER ===================== */
footer{background:var(--color-bg-dark);position:relative;overflow:hidden}
.footer-erasmus{position:absolute;bottom:0;left:0;right:0;width:100%;opacity:0.15;pointer-events:none;user-select:none}
.footer-erasmus svg{width:100%;height:auto;display:block}
.footer-accent{height:3px;background:var(--color-primary)}
.footer-inner{padding:64px 0 0}
.footer-main{display:grid;grid-template-columns:1fr;gap:48px}
@media(min-width:640px){.footer-main{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.footer-main{grid-template-columns:2.2fr 1fr 1fr 1fr}}
.footer-brand-desc{font-size:14px;line-height:1.8;color:rgba(255,255,255,0.5);max-width:248px;margin-bottom:32px}
.footer-contact-list{display:flex;flex-direction:column;gap:10px;margin-bottom:28px}
.footer-contact-link{display:flex;align-items:center;gap:10px;font-size:14px;color:rgba(255,255,255,0.5);font-weight:500;transition:color 0.2s}
.footer-contact-link:hover{color:white}
.footer-contact-icon{width:30px;height:30px;border-radius:8px;border:1px solid rgba(23,198,156,0.3);background:rgba(23,198,156,0.1);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.footer-socials{display:flex;gap:8px}
.footer-social-btn{width:36px;height:36px;border-radius:10px;border:1px solid rgba(23,198,156,0.25);background:rgba(23,198,156,0.08);display:inline-flex;align-items:center;justify-content:center;transition:border-color 0.2s,background 0.2s}
.footer-social-btn:hover{border-color:var(--color-primary);background:rgba(23,198,156,0.18)}
.footer-col h4{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--color-primary);margin-bottom:20px}
.footer-col a{display:block;font-size:14px;color:rgba(255,255,255,0.5);margin-bottom:12px;transition:color 0.2s;font-weight:500}
.footer-col a:hover{color:white}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{margin:0}
/* Scheidingslijn: geef een menu-item de CSS-class "footer-sep" voor een streep erboven */
.footer-col li.footer-sep{border-top:1px solid rgba(255,255,255,0.08);margin-top:20px;padding-top:20px}
.footer-col .footer-col-sep{height:1px;background:rgba(255,255,255,0.08);margin:20px 0}
.footer-divider{height:1px;background:rgba(255,255,255,0.08);margin-top:56px}
.footer-bottom{padding:24px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer-copy{font-size:13px;color:rgba(255,255,255,0.4)}
.footer-badges{display:flex;align-items:center;gap:20px}
.footer-badge{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:rgba(255,255,255,0.4)}
.footer-badge-dot{width:5px;height:5px;border-radius:50%;background:var(--color-primary);flex-shrink:0}

/* ===================== WORDPRESS CORE ===================== */
.wp-caption { max-width: 100%; }
.wp-caption-text { font-size: 13px; color: var(--color-text-muted); margin-top: 6px; }
img.alignleft { float: left; margin: 0 20px 16px 0; }
img.alignright { float: right; margin: 0 0 16px 20px; }
img.aligncenter { display: block; margin: 0 auto 16px; }
.screen-reader-text { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.entry-content { line-height: 1.8; }
.entry-content p { margin-bottom: 1.25em; }
.entry-content h1,.entry-content h2,.entry-content h3,.entry-content h4 { font-weight: 800; margin-bottom: 0.75em; margin-top: 1.5em; letter-spacing: -0.5px; }
.entry-content ul,.entry-content ol { padding-left: 1.5em; margin-bottom: 1.25em; }
.entry-content li { margin-bottom: 0.4em; }

/* ===================== DIENSTEN: OVERZICHT (archive) ===================== */
.page-hero{background:#ffffff;background-image:linear-gradient(rgba(23,198,156,0.05) 1px,transparent 1px),linear-gradient(to right,rgba(23,198,156,0.05) 1px,transparent 1px);background-size:48px 48px;padding:140px 0 56px;border-bottom:1px solid var(--color-border)}
.page-hero-title{font-size:clamp(32px,5vw,56px);font-weight:800;color:var(--color-black);letter-spacing:-2px;line-height:1.08;margin:4px 0 16px;max-width:760px}
.page-hero-sub{font-size:17px;color:var(--color-text-muted);line-height:1.7;max-width:620px}
.dienst-cta{background:var(--color-bg-dark);padding:72px 0}
.dienst-cta-inner{text-align:center;max-width:620px;margin:0 auto}
.dienst-cta-inner h2{font-size:clamp(26px,4vw,40px);font-weight:800;color:white;letter-spacing:-1px;line-height:1.15;margin-bottom:14px}
.dienst-cta-inner p{font-size:16px;color:rgba(255,255,255,0.7);line-height:1.7;margin-bottom:28px}

/* ===================== DIENST DETAIL (single) ===================== */
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-muted);margin-bottom:24px;flex-wrap:wrap}
.breadcrumb a{color:var(--color-text-muted);transition:color 0.2s}
.breadcrumb a:hover{color:var(--color-primary)}
.breadcrumb-sep{color:var(--color-border);user-select:none}
.breadcrumb-current{color:var(--color-black);font-weight:600}

.dienst-hero{padding:140px 0 80px;background:white}
.dienst-hero-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:1024px){.dienst-hero-grid{grid-template-columns:1.1fr 0.9fr;gap:64px}.dienst-hero-grid.is-single{grid-template-columns:1fr;max-width:760px}}
.dienst-hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--color-primary-light);border:1px solid rgba(23,198,156,0.25);border-radius:var(--radius-pill);padding:6px 14px;font-size:11px;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:20px}
.dienst-hero h1{font-size:clamp(36px,5vw,60px);font-weight:800;line-height:1.07;letter-spacing:-2px;margin-bottom:20px;color:var(--color-black)}
.dienst-hero-sub{font-size:17px;color:var(--color-text-muted);max-width:520px;line-height:1.75;margin-bottom:36px}
.hero-btns{display:flex;flex-wrap:wrap;gap:12px}
.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--color-primary);color:white;font-weight:700;font-size:15px;border-radius:10px;padding:14px 28px;border:none;transition:background 0.2s,transform 0.15s}
.btn-primary:hover{background:var(--color-primary-dark);transform:translateY(-1px)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--color-black);font-weight:700;font-size:15px;border-radius:10px;padding:13px 28px;border:1.5px solid var(--color-border);transition:border-color 0.2s,transform 0.15s}
.btn-outline:hover{border-color:var(--color-black);transform:translateY(-1px)}
.hero-proof-card{background:var(--color-bg-alt);border:1px solid rgba(23,198,156,0.2);border-radius:var(--radius-lg);padding:32px;display:flex;flex-direction:column;gap:24px}
.proof-stat{border-bottom:1px solid rgba(23,198,156,0.15);padding-bottom:20px}
.proof-stat:last-child{border-bottom:none;padding-bottom:0}
.proof-stat-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--color-primary);margin-bottom:6px}
.proof-stat-value{font-size:clamp(28px,3.5vw,40px);font-weight:800;color:var(--color-black);letter-spacing:-1.5px;line-height:1;margin-bottom:4px}
.proof-stat-desc{font-size:13px;color:var(--color-text-muted);line-height:1.5}

.dienst-body{background:white;padding:0 0 64px}
.dienst-body .container{max-width:760px}

.section-inbegrepen{background:var(--color-bg-alt);padding:80px 0}
.inbegrepen-header{max-width:640px;margin-bottom:48px}
.inbegrepen-header h2{font-size:clamp(28px,4vw,44px);font-weight:800;letter-spacing:-1.5px;line-height:1.1;margin-bottom:12px}
.inbegrepen-header p{font-size:16px;color:var(--color-text-muted);line-height:1.7}
.inbegrepen-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:640px){.inbegrepen-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.inbegrepen-grid{grid-template-columns:1fr 1fr 1fr}}
.inbegrepen-card{background:white;border:1px solid var(--color-border);border-radius:var(--radius-card);padding:24px;transition:box-shadow 0.2s,transform 0.2s}
.inbegrepen-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.inbegrepen-icon{width:40px;height:40px;background:var(--color-primary-light);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.inbegrepen-name{font-size:16px;font-weight:700;margin-bottom:6px}
.inbegrepen-desc{font-size:14px;color:var(--color-text-muted);line-height:1.6}

.section-aanpak{background:white;padding:80px 0;border-top:1px solid var(--color-border)}
.aanpak-header{max-width:600px;margin-bottom:56px}
.aanpak-header h2{font-size:clamp(28px,4vw,44px);font-weight:800;letter-spacing:-1.5px;line-height:1.1;margin-bottom:12px}
.aanpak-header p{font-size:16px;color:var(--color-text-muted);line-height:1.7}
.aanpak-steps{display:grid;grid-template-columns:1fr;gap:0}
@media(min-width:768px){.aanpak-steps{grid-template-columns:1fr 1fr 1fr 1fr}}
.aanpak-step{position:relative;padding:32px 24px 32px 0}
@media(min-width:768px){.aanpak-step{border-right:1px solid var(--color-border);padding:0 32px 0 0}.aanpak-step:last-child{border-right:none;padding-right:0}}
.aanpak-num{font-size:42px;font-weight:800;color:var(--color-primary);opacity:0.25;line-height:1;margin-bottom:12px}
.aanpak-title{font-size:17px;font-weight:700;margin-bottom:8px}
.aanpak-desc{font-size:14px;color:var(--color-text-muted);line-height:1.6}

.section-resultaten{background:var(--color-bg-dark);padding:80px 0}
.resultaten-header{max-width:560px;margin-bottom:48px}
.resultaten-header .section-label{color:var(--color-primary)}
.resultaten-header h2{font-size:clamp(28px,4vw,44px);font-weight:800;letter-spacing:-1.5px;line-height:1.1;color:white}
.resultaten-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.08);border-radius:var(--radius-lg);overflow:hidden}
@media(min-width:768px){.resultaten-grid{grid-template-columns:1fr 1fr 1fr 1fr}}
.resultaat-item{padding:32px 28px;background:var(--color-bg-dark)}
.resultaat-value{font-size:clamp(32px,4vw,48px);font-weight:800;color:white;letter-spacing:-2px;line-height:1;margin-bottom:6px}
.resultaat-value span{color:var(--color-primary)}
.resultaat-label{font-size:13px;color:rgba(255,255,255,0.5);line-height:1.4}

.section-voorwie{background:var(--color-bg-alt);padding:80px 0}
.voorwie-header{max-width:560px;margin-bottom:48px}
.voorwie-header h2{font-size:clamp(28px,4vw,44px);font-weight:800;letter-spacing:-1.5px;line-height:1.1;margin-bottom:12px}
.voorwie-header p{font-size:16px;color:var(--color-text-muted);line-height:1.7}
.voorwie-list{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:640px){.voorwie-list{grid-template-columns:1fr 1fr}}
.voorwie-item{background:white;border:1px solid var(--color-border);border-radius:var(--radius-card);padding:20px 20px 20px 52px;position:relative}
.voorwie-dot{position:absolute;top:24px;left:20px;width:10px;height:10px;border-radius:50%;background:var(--color-primary)}
.voorwie-name{font-size:15px;font-weight:700;margin-bottom:4px}
.voorwie-desc{font-size:13px;color:var(--color-text-muted);line-height:1.5}

.section-cta{background:white;padding:96px 0;border-top:1px solid var(--color-border)}
.cta-inner{max-width:640px;margin:0 auto;text-align:center}
.cta-inner h2{font-size:clamp(28px,4vw,48px);font-weight:800;letter-spacing:-2px;line-height:1.08;margin-bottom:16px}
.cta-inner p{font-size:17px;color:var(--color-text-muted);line-height:1.7;margin-bottom:36px;max-width:480px;margin-left:auto;margin-right:auto}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:20px}
.cta-note{font-size:13px;color:var(--color-text-muted)}
.cta-note a{color:var(--color-black);font-weight:600;transition:color 0.2s}
.cta-note a:hover{color:var(--color-primary)}

/* ===================== PAGE-HERO TYPOGRAFIE (over ons / contact) ===================== */
.page-hero .section-label{display:inline-flex}
.page-hero h1{font-size:clamp(2rem,5vw,3.25rem);font-weight:800;letter-spacing:-0.04em;line-height:1.1;margin:4px 0 20px;color:var(--color-black)}
.page-hero p{font-size:18px;color:var(--color-text-muted);max-width:580px;line-height:1.65}
.page-hero .subtitle{font-size:18px;color:var(--color-text-muted);max-width:520px;line-height:1.7}

/* ===================== OVER ONS ===================== */
.verhaal-section{padding:80px 0;background:var(--color-white)}
.verhaal-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:1024px){.verhaal-grid{grid-template-columns:1fr 1fr;gap:80px}}
.verhaal-text .section-label{display:inline-flex}
.verhaal-text h2{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;letter-spacing:-0.03em;line-height:1.2;margin-bottom:24px;color:var(--color-black)}
.verhaal-text p{font-size:15px;color:var(--color-text-muted);line-height:1.75;margin-bottom:16px}
.verhaal-text p:last-of-type{margin-bottom:24px}
.verhaal-quote{border-left:3px solid var(--color-primary);padding:16px 20px;background:var(--color-primary-light);border-radius:0 var(--radius-card) var(--radius-card) 0}
.verhaal-quote p{font-size:15px;font-weight:600;color:var(--color-black);font-style:italic;margin-bottom:0;line-height:1.6}
.verhaal-image-wrap{position:relative}
.verhaal-image-wrap img{width:100%;height:440px;object-fit:cover;object-position:center;border-radius:var(--radius-lg)}
.verhaal-badge{position:absolute;bottom:20px;left:20px;background:white;border-radius:var(--radius-pill);padding:8px 16px;font-size:13px;font-weight:700;color:var(--color-black);box-shadow:var(--shadow);display:flex;align-items:center;gap:6px}
.verhaal-badge-dot{width:8px;height:8px;background:var(--color-primary);border-radius:50%;flex-shrink:0}

.values-section{padding:80px 0;background:var(--color-bg-alt)}
.values-section .section-label{display:inline-flex}
.values-section h2{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;letter-spacing:-0.03em;line-height:1.2;margin-bottom:48px;color:var(--color-black)}
.values-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:640px){.values-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.values-grid{grid-template-columns:repeat(3,1fr)}}
.value-card{background:var(--color-white);border:1px solid var(--color-border);border-radius:16px;padding:24px;transition:box-shadow 0.25s,transform 0.25s}
.value-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.value-icon{width:44px;height:44px;background:var(--color-primary-light);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;flex-shrink:0}
.value-icon svg{width:22px;height:22px;color:var(--color-primary)}
.value-card h3{font-size:15px;font-weight:700;color:var(--color-black);margin-bottom:8px}
.value-card p{font-size:14px;color:var(--color-text-muted);line-height:1.65}

.team-section{padding:80px 0;background:var(--color-white)}
.team-header{margin-bottom:48px}
.team-header .section-label{display:inline-flex}
.team-header h2{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;letter-spacing:-0.03em;line-height:1.2;margin-bottom:8px;color:var(--color-black)}
.team-header p{font-size:16px;color:var(--color-text-muted)}
.team-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:640px){.team-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.team-grid{grid-template-columns:repeat(4,1fr)}}
.team-card{border:1px solid var(--color-border);border-radius:20px;overflow:hidden;transition:box-shadow 0.25s,transform 0.25s}
.team-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.team-card img{width:100%;height:220px;object-fit:cover;object-position:center top}
.team-card-body{padding:20px}
.team-card-body h3{font-size:17px;font-weight:700;color:var(--color-black);margin-bottom:4px}
.team-card-role{font-size:13px;font-weight:600;color:var(--color-primary);margin-bottom:10px;display:block}
.team-card-bio{font-size:13px;color:var(--color-text-muted);line-height:1.6;margin-bottom:14px}
.team-card-linkedin{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--color-text-muted);transition:color 0.2s}
.team-card-linkedin:hover{color:var(--color-primary)}
.team-card-linkedin svg{width:16px;height:16px}

.rotterdam-section{padding:64px 0;background:var(--color-primary)}
.rotterdam-inner{display:flex;flex-direction:column;gap:32px}
@media(min-width:768px){.rotterdam-inner{flex-direction:row;align-items:center;justify-content:space-between;gap:48px}}
.rotterdam-text h2{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;letter-spacing:-0.03em;line-height:1.2;color:white;margin-bottom:16px}
.rotterdam-text p{font-size:15px;color:rgba(255,255,255,0.8);line-height:1.7;max-width:520px}
.rotterdam-stats{display:flex;gap:40px;flex-shrink:0}
.rotterdam-stat{text-align:center}
.rotterdam-stat-number{font-size:2.5rem;font-weight:800;color:white;line-height:1;display:block}
.rotterdam-stat-label{font-size:13px;color:rgba(255,255,255,0.75);margin-top:4px;display:block}

.testimonial-section{padding:80px 0;background:var(--color-white)}
.testimonial-inner{max-width:720px;margin:0 auto;text-align:center}
.testimonial-quote-mark{display:block;font-size:80px;line-height:0.8;color:var(--color-primary);font-weight:800;margin-bottom:24px;font-family:Georgia,serif}
.testimonial-text{font-size:clamp(1.05rem,2.5vw,1.3rem);font-weight:600;color:var(--color-black);line-height:1.6;margin-bottom:32px;font-style:italic}
.testimonial-stars{display:flex;justify-content:center;gap:4px;margin-bottom:16px}
.testimonial-stars svg{width:20px;height:20px}
.testimonial-author{font-size:14px;color:var(--color-text-muted);font-weight:500}

.cta-section{padding:80px 0;background:var(--color-bg-alt);text-align:center}
.cta-section h2{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;letter-spacing:-0.03em;color:var(--color-black);margin-bottom:16px}
.cta-section p{font-size:16px;color:var(--color-text-muted);max-width:480px;margin:0 auto 40px;line-height:1.65}
.cta-buttons{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.btn-outline-white{display:inline-flex;align-items:center;background:transparent;color:var(--color-black);font-weight:700;font-size:15px;padding:14px 28px;border-radius:10px;border:1.5px solid var(--color-border);transition:border-color 0.25s,color 0.25s,transform 0.15s}
.btn-outline-white:hover{border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-2px)}

/* ===================== CONTACT ===================== */
.contact-section{padding:80px 0;background:var(--color-white)}
.contact-layout{display:grid;grid-template-columns:1fr;gap:32px}
@media(min-width:1024px){.contact-layout{grid-template-columns:3fr 2fr;align-items:start}}
.contact-section .form-card{max-width:none;margin:0;border:1px solid var(--color-border)}
.contact-section .form-card h2{font-size:22px;font-weight:700;margin-bottom:28px}
.cf7-notice{font-size:14px;color:var(--color-text-muted);background:var(--color-bg-alt);border:1px dashed var(--color-border);border-radius:var(--radius-card);padding:16px 18px;line-height:1.6}
/* Formulier-elementen (Contact Form 7 met prototype-markup) */
.form-row{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:16px}
@media(min-width:768px){.form-row.two-col{grid-template-columns:1fr 1fr}}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:14px;font-weight:600;color:var(--color-black)}
.form-group input,.form-group textarea,.contact-section .wpcf7-form input[type="text"],.contact-section .wpcf7-form input[type="email"],.contact-section .wpcf7-form input[type="tel"],.contact-section .wpcf7-form textarea{font-family:inherit;font-size:15px;color:var(--color-black);background:var(--color-bg-alt);border:1.5px solid var(--color-border);border-radius:var(--radius-card);padding:12px 16px;transition:border-color 0.2s,box-shadow 0.2s;outline:none;width:100%}
.form-group textarea,.contact-section .wpcf7-form textarea{min-height:120px;resize:vertical;line-height:1.6}
.form-group input:focus,.form-group textarea:focus,.contact-section .wpcf7-form input:focus,.contact-section .wpcf7-form textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(23,198,156,0.12)}
.services-label{font-size:14px;font-weight:600;margin-bottom:12px;display:block}
.services-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.service-pill{position:relative}
.service-pill input[type="checkbox"]{position:absolute;opacity:0;width:0;height:0}
.service-pill label{display:inline-block;font-size:13px;font-weight:600;padding:7px 16px;border-radius:var(--radius-pill);border:1.5px solid var(--color-border);background:var(--color-white);color:var(--color-text-muted);cursor:pointer;transition:border-color 0.2s,background 0.2s,color 0.2s;user-select:none}
.service-pill input[type="checkbox"]:checked+label{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary)}
.service-pill label:hover{border-color:var(--color-primary)}
.btn-submit,.contact-section .wpcf7-form input.wpcf7-submit{width:100%;background:var(--color-primary);color:white;font-weight:700;font-size:16px;border:none;border-radius:10px;padding:16px 28px;transition:background 0.2s,transform 0.15s;margin-bottom:12px;cursor:pointer}
.btn-submit:hover,.contact-section .wpcf7-form input.wpcf7-submit:hover{background:var(--color-primary-dark);transform:translateY(-1px)}
.privacy-note{font-size:13px;color:var(--color-text-muted);display:flex;align-items:center;gap:6px}
.privacy-note svg{flex-shrink:0}
.contact-section .wpcf7-form p{margin:0}
.contact-section .wpcf7 .wpcf7-response-output{border-radius:var(--radius-card);margin:16px 0 0;font-size:14px}

.details-card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:28px}
.details-card h3{font-size:18px;font-weight:700;margin-bottom:20px}
.detail-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:18px}
.detail-icon{width:36px;height:36px;background:var(--color-primary-light);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.detail-text{font-size:15px;font-weight:600;color:var(--color-black);display:block}
.detail-sub{font-size:13px;color:var(--color-text-muted);display:block;margin-top:1px}
.detail-divider{border:none;border-top:1px solid var(--color-border);margin:20px 0}
.map-placeholder{background:var(--color-bg-alt);border-radius:var(--radius-card);height:200px;display:flex;align-items:center;justify-content:center;margin-top:20px;border:1px solid var(--color-border);font-size:14px;font-weight:600;color:var(--color-text-muted)}
.map-image{width:100%;height:auto;border-radius:var(--radius-card);margin-top:20px;display:block;border:1px solid var(--color-border)}
.response-note{font-size:13px;color:var(--color-text-muted);margin-top:16px;text-align:center}

.faq-section{padding:80px 0;background:var(--color-bg-alt)}
.faq-header{max-width:560px;margin-bottom:48px}
.faq-header h2{font-size:clamp(28px,4vw,44px);font-weight:800;letter-spacing:-0.02em;margin-bottom:12px}
.faq-header p{font-size:17px;color:var(--color-text-muted)}
.faq-list{display:flex;flex-direction:column;gap:0;max-width:760px}
.faq-item{border-bottom:1px solid var(--color-border)}
.faq-item:first-child{border-top:1px solid var(--color-border)}
.faq-trigger{width:100%;background:none;border:none;text-align:left;padding:20px 0;display:flex;align-items:center;justify-content:space-between;gap:16px;cursor:pointer}
.faq-trigger-text{font-size:16px;font-weight:700;color:var(--color-black)}
.faq-chevron{flex-shrink:0;transition:transform 0.3s ease;color:var(--color-text-muted)}
.faq-item.open .faq-chevron{transform:rotate(180deg)}
.faq-body{max-height:0;overflow:hidden;transition:max-height 0.35s ease}
.faq-body-inner{padding:0 0 20px;font-size:15px;color:var(--color-text-muted);line-height:1.7}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ===================== TOEGANKELIJKHEID ===================== */
.skip-link{position:absolute;left:-9999px;top:0;z-index:1000}
.skip-link:focus{left:0;background:var(--color-primary-dark);color:#fff;padding:12px 20px;border-radius:0 0 8px 0;font-weight:700;font-size:14px;box-shadow:0 4px 16px rgba(0,0,0,0.2)}
#content{display:block;height:0}
a:focus-visible,button:focus-visible,[tabindex]:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,.faq-trigger:focus-visible{outline:2px solid var(--color-primary-dark);outline-offset:3px;border-radius:4px}

/* ===================== AFBEELDING-PLACEHOLDER (zonder externe foto) ===================== */
.mo-img-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;min-height:360px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--color-primary-light),#D4F3EA)}
.mo-img-placeholder span{font-size:13px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:var(--color-primary)}
.team-photo-img{width:100%;height:100%;object-fit:cover;min-height:360px}

/* ===================== WERKWIJZE ===================== */
.methode-section{padding:80px 0;background:var(--color-white)}
.methode-header{max-width:620px;margin-bottom:56px}
.methode-header h2{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;letter-spacing:-0.03em;line-height:1.2;margin-bottom:12px}
.methode-header p{font-size:16px;color:var(--color-text-muted);line-height:1.7}
.methode-timeline{display:grid;gap:0;max-width:820px}
.methode-step{display:grid;grid-template-columns:auto 1fr;gap:24px;position:relative;padding-bottom:40px}
.methode-step:last-child{padding-bottom:0}
.methode-num-wrap{display:flex;flex-direction:column;align-items:center}
.methode-num{width:52px;height:52px;border-radius:50%;background:var(--color-primary-light);color:var(--color-primary);font-weight:800;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:2px solid rgba(23,198,156,0.3)}
.methode-line{flex:1;width:2px;background:linear-gradient(var(--color-primary),rgba(23,198,156,0.15));margin:8px 0;border-radius:2px}
.methode-step:last-child .methode-line{display:none}
.methode-step-content{padding-top:8px}
.methode-step-title{font-size:19px;font-weight:700;margin-bottom:8px}
.methode-step-desc{font-size:15px;color:var(--color-text-muted);line-height:1.7;max-width:560px}

.ritme-section{padding:80px 0;background:var(--color-white)}
.ritme-header{max-width:560px;margin-bottom:40px}
.ritme-header h2{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;letter-spacing:-0.03em;line-height:1.2;margin-bottom:12px}
.ritme-header p{font-size:16px;color:var(--color-text-muted);line-height:1.7}
.ritme-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:640px){.ritme-grid{grid-template-columns:1fr 1fr}}
.ritme-item{display:flex;align-items:flex-start;gap:12px;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-card);padding:18px 20px}
.ritme-check{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--color-primary-light);display:flex;align-items:center;justify-content:center;margin-top:1px}
.ritme-item-text{font-size:15px;font-weight:700}
.ritme-item-sub{font-size:13px;color:var(--color-text-muted);font-weight:500;margin-top:2px}
