
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --blue:#4A7EC7;
  --blue-d:#2f5fa0;
  --blue-lt:#EBF2FC;
  --blue-xl:#F0F6FF;
  --dark:#3D4450;
  --navy:#1a2332;
  --off:#f7f6f4;
  --bg:#F8F9FB;
  --border:#e2e5ec;
  --text:#2c3747;
  --muted:#6b7a8d;
  --white:#ffffff;
  --green:#22c55e;
  --shadow:0 4px 24px rgba(74,126,199,0.10);
  --shadow-lg:0 8px 48px rgba(74,126,199,0.15);
}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',sans-serif;color:var(--text);background:#fff;-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.65}

/* ── SCROLL ANIMATIONS ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal.visible{opacity:1;transform:none}
.reveal-left{opacity:0;transform:translateX(-28px);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal-left.visible{opacity:1;transform:none}
.reveal-right{opacity:0;transform:translateX(28px);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal-right.visible{opacity:1;transform:none}
.delay-1{transition-delay:0.1s}
.delay-2{transition-delay:0.2s}
.delay-3{transition-delay:0.3s}
.delay-4{transition-delay:0.4s}

/* ── TOPBAR ── */
.topbar{
  background:var(--navy);
  display:flex;align-items:center;justify-content:flex-end;
  padding:0 48px;height:36px;gap:24px;
}
.topbar a,.topbar span{
  font-size:12.5px;color:rgba(255,255,255,0.6);text-decoration:none;
  display:flex;align-items:center;gap:6px;letter-spacing:0.01em;
}
.topbar a:hover{color:#fff}

/* ── NAV ── */
nav{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,0.97);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 48px;height:76px;
  transition:box-shadow 0.3s;
}
nav.scrolled{box-shadow:0 2px 20px rgba(0,0,0,0.08)}
.nav-logo img{height:52px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{
  font-size:13.5px;font-weight:500;color:var(--muted);text-decoration:none;
  padding:6px 12px;border-radius:7px;
  transition:all .18s;letter-spacing:0.01em;white-space:nowrap;
}
.nav-links a:hover{color:var(--blue);background:var(--blue-xl)}
.nav-links a.active{color:var(--blue);background:var(--blue-xl)}
.nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.nav-phone{
  font-size:13px;font-weight:600;color:var(--dark);text-decoration:none;
  display:flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:7px;
  transition:all .18s;
}
.nav-phone:hover{color:var(--blue)}
.nav-login{
  font-size:13px;font-weight:500;color:var(--muted);text-decoration:none;
  border:1px solid var(--border);padding:6px 14px;border-radius:7px;
  transition:all .18s;white-space:nowrap;
}
.nav-login:hover{border-color:var(--blue);color:var(--blue)}
.nav-cta{
  background:var(--blue);color:#fff;text-decoration:none;
  padding:8px 18px;border-radius:8px;font-size:13.5px;font-weight:600;
  white-space:nowrap;transition:background .18s;
}
.nav-cta:hover{background:var(--blue-d)}

/* ── HAMBURGER (mobile) ── */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none}
.hamburger span{width:22px;height:2px;background:var(--dark);border-radius:2px;transition:all .3s}
.mobile-menu{
  display:none;position:fixed;top:104px;left:0;right:0;bottom:0;
  background:#fff;z-index:99;padding:24px 24px;
  overflow-y:auto;
}
.mobile-menu.open{display:block}
.mobile-menu a{
  display:block;font-size:15px;font-weight:500;color:var(--dark);
  text-decoration:none;padding:12px 0;
  border-bottom:1px solid var(--border);
}
.mobile-cta{
  margin-top:24px;display:block;text-align:center;
  background:var(--blue);color:#fff!important;
  padding:16px;border-radius:10px;font-weight:600;font-size:16px;
  border:none!important;
}

/* ── PAGE ── */
.page{display:block}
.wrap{max-width:1100px;margin:0 auto;padding:0 48px}
.section{padding:80px 0}

/* ── HERO (LIGHT) ── */
.hero{
  background:linear-gradient(135deg, #F0F5FF 0%, #FAFBFF 50%, #F5F8FF 100%);
  padding:80px 48px 80px;
  position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle, rgba(74,126,199,0.08) 0%, transparent 70%);
  top:-100px;right:-100px;pointer-events:none;
}
.hero::after{
  content:'';position:absolute;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle, rgba(74,126,199,0.05) 0%, transparent 70%);
  bottom:-50px;left:10%;pointer-events:none;
}
.hero-inner{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr 420px;gap:64px;align-items:center;
  position:relative;z-index:1;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12.5px;font-weight:600;color:var(--blue);
  letter-spacing:0.08em;text-transform:uppercase;
  background:var(--blue-lt);padding:6px 14px;border-radius:20px;
  margin-bottom:20px;
}
.hero-eyebrow::before{content:'';width:20px;height:2px;background:var(--blue);flex-shrink:0}
h1{font-size:52px;font-weight:800;color:var(--navy);line-height:1.1;letter-spacing:-0.02em;margin-bottom:20px}
h1 span{color:var(--blue)}
.hero-sub{font-size:17px;color:var(--muted);line-height:1.75;margin-bottom:36px;max-width:480px;font-weight:400}
.hero-btns{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.btn-primary{
  background:var(--blue);color:#fff;text-decoration:none;
  padding:13px 26px;border-radius:9px;font-size:15px;font-weight:600;
  transition:all .2s;display:inline-flex;align-items:center;gap:8px;
  box-shadow:0 4px 16px rgba(74,126,199,0.35);
}
.btn-primary:hover{background:var(--blue-d);transform:translateY(-1px);box-shadow:0 6px 20px rgba(74,126,199,0.4)}
.btn-secondary{
  color:var(--blue);text-decoration:none;
  padding:13px 20px;border-radius:9px;font-size:15px;font-weight:600;
  border:1.5px solid var(--blue);transition:all .2s;
  display:inline-flex;align-items:center;gap:6px;
}
.btn-secondary:hover{background:var(--blue-xl)}

/* ── HERO CARD (right panel) ── */
.hero-card{
  background:#fff;border-radius:16px;
  box-shadow:var(--shadow-lg);
  border:1px solid rgba(74,126,199,0.12);
  padding:28px;
}
.hc-header{
  display:flex;align-items:center;gap:10px;
  padding-bottom:18px;border-bottom:1px solid var(--border);margin-bottom:18px;
}
.hc-dot{width:10px;height:10px;border-radius:50%;background:var(--green);flex-shrink:0}
.hc-title{font-size:13px;font-weight:600;color:var(--dark)}
.hc-sub{font-size:11.5px;color:var(--muted)}
.hc-row{
  display:flex;align-items:flex-start;gap:12px;
  padding:10px 0;border-bottom:1px solid #f0f2f5;
}
.hc-row:last-child{border-bottom:none;padding-bottom:0}
.hc-icon{
  width:32px;height:32px;border-radius:8px;
  background:var(--blue-lt);display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.hc-icon svg{width:15px;height:15px;stroke:var(--blue);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.hc-lbl{font-size:11.5px;color:var(--muted);margin-bottom:2px}
.hc-val{font-size:13.5px;font-weight:600;color:var(--dark)}
.hc-employes{
  margin-top:18px;padding:14px;border-radius:10px;
  background:var(--blue-xl);border:1px solid rgba(74,126,199,0.15);
  display:flex;align-items:center;gap:10px;
}
.hc-employes-dot{
  width:8px;height:8px;border-radius:50%;background:var(--blue);flex-shrink:0
}
.hc-employes-lbl{font-size:12.5px;font-weight:600;color:var(--blue)}
.hc-employes-sub{font-size:11.5px;color:var(--muted)}

/* ── TRUST BAR ── */
.trust{
  background:#fff;border-bottom:1px solid var(--border);
  padding:0 48px;
  display:flex;align-items:center;justify-content:center;
  gap:40px;flex-wrap:wrap;min-height:52px;
}
.trust-item{
  display:flex;align-items:center;gap:7px;
  font-size:13px;color:var(--muted);font-weight:500;
}
.trust-item svg{color:var(--blue)}

/* ── SECTION LABELS ── */
.s-lbl{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:600;color:var(--blue);
  letter-spacing:0.08em;text-transform:uppercase;margin-bottom:12px;
}
.s-lbl::before{content:'';width:20px;height:2px;background:var(--blue)}
h2{font-size:38px;font-weight:800;color:var(--navy);line-height:1.15;letter-spacing:-0.02em;margin-bottom:14px}
.s-sub{font-size:16.5px;color:var(--muted);line-height:1.7;max-width:580px;font-weight:400;margin-bottom:48px}

/* ── DIENSTEN GRID ── */
.diensten-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.dienst{
  background:#fff;border:1px solid var(--border);border-radius:14px;
  padding:28px;transition:all .2s;
}
.dienst:hover{box-shadow:var(--shadow);border-color:rgba(74,126,199,0.3);transform:translateY(-2px)}
.dienst-icon{
  width:44px;height:44px;border-radius:10px;
  background:var(--blue-lt);display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;
}
.dienst-icon svg{width:22px;height:22px;stroke:var(--blue);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.dienst-num{font-size:11px;font-weight:700;color:var(--blue);letter-spacing:0.08em;text-transform:uppercase;margin-bottom:8px}
.dienst h3{font-size:17px;font-weight:700;color:var(--navy);margin-bottom:8px}
.dienst p{font-size:14px;color:var(--muted);line-height:1.65}

/* ── PROCESS (3 STAPPEN) ── */
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;position:relative}
.process-grid::before{
  content:'';position:absolute;top:28px;left:calc(16.6% + 28px);
  right:calc(16.6% + 28px);height:2px;
  background:linear-gradient(90deg, var(--blue-lt), var(--blue), var(--blue-lt));
  z-index:0;
}
.process-step{text-align:center;position:relative;z-index:1}
.process-num{
  width:56px;height:56px;border-radius:50%;
  background:var(--blue);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;font-weight:800;
  margin:0 auto 20px;
  box-shadow:0 4px 16px rgba(74,126,199,0.35);
}
.process-step h3{font-size:17px;font-weight:700;color:var(--navy);margin-bottom:8px}
.process-step p{font-size:14px;color:var(--muted);line-height:1.65}

/* ── PRICING ── */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
.pricing-card{
  background:#fff;border:1.5px solid var(--border);border-radius:16px;
  padding:32px;transition:all .25s;position:relative;
}
.pricing-card.featured{
  border-color:var(--blue);
  box-shadow:0 8px 32px rgba(74,126,199,0.18);
}
.pricing-badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--blue);color:#fff;font-size:11.5px;font-weight:700;
  padding:4px 16px;border-radius:20px;white-space:nowrap;
  letter-spacing:0.04em;
}
.pricing-tier{font-size:12px;font-weight:700;color:var(--blue);letter-spacing:0.08em;text-transform:uppercase;margin-bottom:8px}
.pricing-name{font-size:22px;font-weight:800;color:var(--navy);margin-bottom:6px}
.pricing-desc{font-size:13.5px;color:var(--muted);margin-bottom:20px;line-height:1.55}
.pricing-price{
  display:flex;align-items:baseline;gap:4px;margin-bottom:6px;
}
.pricing-from{font-size:13px;color:var(--muted)}
.pricing-amount{font-size:36px;font-weight:800;color:var(--navy)}
.pricing-per{font-size:13.5px;color:var(--muted);font-weight:500}
.pricing-note{font-size:12px;color:var(--muted);margin-bottom:24px}
.pricing-divider{height:1px;background:var(--border);margin:20px 0}
.pricing-features{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:28px}
.pricing-features li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:13.5px;color:var(--dark);
}
.pricing-features li svg{
  width:16px;height:16px;stroke:var(--blue);fill:none;
  stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;
  flex-shrink:0;margin-top:2px;
}
.pricing-cta{
  display:block;text-align:center;text-decoration:none;
  padding:12px;border-radius:9px;font-size:14px;font-weight:600;
  transition:all .2s;
}
.pricing-cta.primary{background:var(--blue);color:#fff;box-shadow:0 4px 12px rgba(74,126,199,0.3)}
.pricing-cta.primary:hover{background:var(--blue-d)}
.pricing-cta.outline{border:1.5px solid var(--blue);color:var(--blue)}
.pricing-cta.outline:hover{background:var(--blue-xl)}
.pricing-note-bottom{
  text-align:center;margin-top:32px;font-size:13.5px;color:var(--muted);
}
.pricing-note-bottom strong{color:var(--dark)}

/* ── WAAROM / USP'S ── */
.usp-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;align-items:stretch}
.usp-card{
  background:#fff;border:1px solid var(--border);border-radius:14px;
  padding:24px;display:flex;gap:16px;align-items:flex-start;
  transition:all .2s;
}
.usp-card:hover{box-shadow:var(--shadow);border-color:rgba(74,126,199,0.25)}
.usp-num{
  width:36px;height:36px;border-radius:9px;
  background:var(--blue);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:800;flex-shrink:0;
}
.usp-card h4{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:5px}
.usp-card p{font-size:13.5px;color:var(--muted);line-height:1.6}

/* ── TEAM ── */
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.team-card{
  background:#fff;border:1px solid var(--border);border-radius:16px;
  overflow:hidden;transition:all .25s;
}
.team-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.team-avatar-wrap{
  background:linear-gradient(135deg, var(--blue-xl) 0%, #DDE9F8 100%);
  padding:40px 40px 0;display:flex;justify-content:center;
  position:relative;
}
.team-avatar-wrap.lars{
  background:linear-gradient(135deg, #EAF0FB 0%, #D4E3F6 100%);
}
/* ── SVG Avatar ── */
.avatar-svg{width:160px;height:160px;display:block}
.team-body{padding:28px}
.team-role{
  font-size:11.5px;font-weight:700;color:var(--blue);
  letter-spacing:0.07em;text-transform:uppercase;margin-bottom:6px;
}
.team-name{font-size:22px;font-weight:800;color:var(--navy);margin-bottom:10px}
.team-bio{font-size:14px;color:var(--muted);line-height:1.7}
.team-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.team-tag{
  font-size:11.5px;font-weight:600;color:var(--blue);
  background:var(--blue-lt);padding:4px 10px;border-radius:20px;
}

/* ── REVIEWS ── */
/* ── REVIEWS CAROUSEL ── */
.reviews-summary{
  display:none;align-items:center;justify-content:center;gap:10px;
  margin-top:14px;flex-wrap:wrap;
}
.reviews-score{font-size:28px;font-weight:800;color:var(--navy);line-height:1}
.reviews-stars-row{font-size:20px;line-height:1}
.reviews-count{font-size:13px;color:var(--muted)}
.reviews-carousel-wrap{overflow:hidden;margin-bottom:4px}
.reviews-track{
  display:flex;gap:24px;
  transition:transform 0.5s ease;will-change:transform;
}
.review-card{
  flex:0 0 calc(33.333% - 16px);
  background:#fff;border:1px solid var(--border);border-radius:14px;
  padding:24px;transition:box-shadow .2s,border-color .2s;
}
.review-card:hover{box-shadow:var(--shadow);border-color:rgba(74,126,199,0.25)}
.review-text{font-size:14px;color:var(--dark);line-height:1.7;margin-bottom:16px;font-style:italic}
.review-author{display:flex;align-items:center;gap:10px}
.review-av{
  width:36px;height:36px;border-radius:50%;
  background:var(--blue);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;flex-shrink:0;
}
.review-name{font-size:13.5px;font-weight:700;color:var(--dark)}
.review-role{font-size:12px;color:var(--muted)}
.reviews-dots{display:flex;justify-content:center;gap:8px;margin:16px 0 24px}
.rdot{
  width:8px;height:8px;border-radius:50%;
  background:var(--border);border:none;cursor:pointer;
  padding:0;transition:all .2s;
}
.rdot-active{background:var(--blue);transform:scale(1.3)}
.google-cta{
  display:inline-flex;align-items:center;gap:10px;
  background:#fff;border:1.5px solid var(--border);
  border-radius:10px;padding:12px 20px;
  font-size:14px;font-weight:600;color:var(--dark);
  text-decoration:none;margin-top:8px;transition:all .2s;
}
.google-cta:hover{border-color:var(--blue);box-shadow:var(--shadow)}

/* ── FAQ ── */
.faq-list{display:flex;flex-direction:column;gap:0}
.faq-item{
  border-bottom:1px solid var(--border);
}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 0;cursor:pointer;
  font-size:15.5px;font-weight:600;color:var(--navy);
  transition:color .2s;user-select:none;
}
.faq-q:hover{color:var(--blue)}
.faq-arrow{
  width:24px;height:24px;border-radius:50%;
  background:var(--blue-lt);display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:transform .25s;
}
.faq-arrow svg{width:12px;height:12px;stroke:var(--blue);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.faq-item.open .faq-arrow{transform:rotate(180deg)}
.faq-a{
  max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease;
  font-size:14.5px;color:var(--muted);line-height:1.7;padding:0;
}
.faq-item.open .faq-a{max-height:300px;padding-bottom:18px}

/* ── KENNISBANK CARDS ── */
.kennis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.kennis-card{
  background:#fff;border:1px solid var(--border);border-radius:16px;
  overflow:hidden;transition:all .25s;cursor:pointer;
  display:flex;flex-direction:column;
  text-decoration:none;color:inherit;
}
.kennis-card:hover{box-shadow:0 8px 40px rgba(74,126,199,0.14);transform:translateY(-3px);border-color:rgba(74,126,199,0.25)}
.kc-head{
  padding:26px 26px 20px;
  position:relative;overflow:hidden;
}
.kc-head::after{
  content:'';position:absolute;right:-18px;bottom:-22px;
  width:80px;height:80px;border-radius:50%;
  background:rgba(255,255,255,0.1);pointer-events:none;
}
.kc-head::before{
  content:'';position:absolute;right:18px;top:-28px;
  width:110px;height:110px;border-radius:50%;
  background:rgba(255,255,255,0.07);pointer-events:none;
}
.kc-icon{
  width:40px;height:40px;border-radius:10px;
  background:rgba(255,255,255,0.2);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;
}
.kc-icon svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.kc-cat{font-size:10.5px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:rgba(255,255,255,0.85)}
.kc-body{padding:20px 26px 0;flex:1;display:flex;flex-direction:column}
.kc-title{font-size:16px;font-weight:800;color:var(--navy);line-height:1.4;margin-bottom:10px}
.kc-excerpt{font-size:13.5px;color:var(--muted);line-height:1.65;flex:1}
.kc-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 26px 20px;margin-top:16px;
  border-top:1px solid var(--border);
}
.kc-meta{font-size:12px;color:var(--muted)}
.kc-lees{font-size:13px;font-weight:700;color:var(--blue);display:flex;align-items:center;gap:4px;transition:gap .15s}
.kennis-card:hover .kc-lees{gap:8px}
.kc-lees svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}

/* ── ARTIKEL PAGES ── */
.artikel-back{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13.5px;font-weight:600;color:var(--blue);text-decoration:none;
  margin-bottom:32px;transition:gap .2s;
}
.artikel-back:hover{gap:10px}
.artikel-header{margin-bottom:28px}
.artikel-cat{
  display:inline-flex;align-items:center;
  font-size:11px;font-weight:700;letter-spacing:0.07em;text-transform:uppercase;
  color:var(--blue);background:var(--blue-xl);
  padding:4px 12px;border-radius:20px;margin-bottom:14px;
}
.artikel-title{font-size:34px;font-weight:800;color:var(--navy);line-height:1.2;margin-bottom:16px}
.artikel-meta{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted)}
.artikel-meta span{display:flex;align-items:center;gap:5px}
.artikel-divider{height:1px;background:var(--border);margin:28px 0}
.artikel-body{max-width:740px}
.artikel-body h2{font-size:20px;font-weight:800;color:var(--navy);margin:36px 0 12px}
.artikel-body p{font-size:15px;color:var(--text);line-height:1.75;margin-bottom:18px}
.artikel-body ul{margin:0 0 18px 20px}
.artikel-body ul li{font-size:15px;color:var(--text);line-height:1.75;margin-bottom:6px}
.artikel-body table{width:100%;border-collapse:collapse;margin:24px 0;font-size:14px}
.artikel-body table th{background:var(--navy);color:#fff;padding:10px 14px;text-align:left;font-weight:600}
.artikel-body table td{padding:9px 14px;border-bottom:1px solid var(--border)}
.artikel-body table tr:nth-child(even) td{background:var(--bg)}
.artikel-cta{
  max-width:740px;margin:48px 0 0;
  background:var(--blue-xl);border:1px solid var(--blue-lt);
  border-radius:16px;padding:32px;text-align:center;
}
.artikel-cta h3{font-size:20px;font-weight:800;color:var(--navy);margin-bottom:8px}
.artikel-cta p{font-size:14.5px;color:var(--muted);margin-bottom:20px}

/* ── LEGAL PAGES ── */
.legal-back{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13.5px;font-weight:600;color:var(--blue);text-decoration:none;
  margin-bottom:32px;transition:gap .2s;
}
.legal-back:hover{gap:10px}
.legal-header{margin-bottom:8px}
.legal-header h1{font-size:34px;font-weight:800;color:var(--navy);line-height:1.2;margin-bottom:10px}
.legal-updated{font-size:13px;color:var(--muted);margin-bottom:4px}
.legal-divider{height:1px;background:var(--border);margin:24px 0 32px}
.legal-body{max-width:760px}
.legal-body h2{font-size:18px;font-weight:800;color:var(--navy);margin:36px 0 10px;padding-top:4px}
.legal-body h3{font-size:15.5px;font-weight:700;color:var(--navy);margin:20px 0 8px}
.legal-body p{font-size:14.5px;color:var(--text);line-height:1.75;margin-bottom:14px}
.legal-body ul,.legal-body ol{margin:0 0 14px 20px}
.legal-body ul li,.legal-body ol li{font-size:14.5px;color:var(--text);line-height:1.75;margin-bottom:5px}
.legal-body strong{font-weight:700;color:var(--dark)}

/* ── CTA BANNER ── */
.cta-banner{
  background:linear-gradient(135deg, var(--navy) 0%, #1e3252 100%);
  border-radius:20px;padding:56px 64px;
  display:flex;align-items:center;justify-content:space-between;gap:40px;
  position:relative;overflow:hidden;
}
.cta-banner::before{
  content:'';position:absolute;width:400px;height:400px;
  border-radius:50%;background:rgba(74,126,199,0.12);
  right:-100px;top:-100px;pointer-events:none;
}
.cta-banner h2{font-size:34px;color:#fff;margin-bottom:10px}
.cta-banner p{font-size:16px;color:rgba(255,255,255,0.6);max-width:480px}
.cta-banner .btn-primary{box-shadow:0 4px 16px rgba(0,0,0,0.25);white-space:nowrap}

/* ── PAGE HEADERS ── */
.page-header{
  background:linear-gradient(135deg, var(--navy) 0%, #1e3252 100%);
  padding:56px 0;position:relative;overflow:hidden;
}
.page-header::before{
  content:'';position:absolute;width:500px;height:500px;
  border-radius:50%;background:rgba(74,126,199,0.08);
  right:-100px;top:-150px;pointer-events:none;
}
.page-header .wrap{position:relative;z-index:1}
.ph-label{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11.5px;font-weight:700;color:rgba(100,160,220,1);
  letter-spacing:0.08em;text-transform:uppercase;margin-bottom:12px;
}
.ph-label::before{content:'';width:18px;height:2px;background:var(--blue)}
.page-header h2{font-size:42px;color:#fff}
.page-header p{font-size:17px;color:rgba(255,255,255,0.5);font-weight:300;line-height:1.7;max-width:520px;margin-top:10px}

/* ── DIENSTEN DETAIL ── */
.dienst-detail{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;
}
.dienst-detail + .dienst-detail{margin-top:64px}
.dd-content h3{font-size:26px;font-weight:800;color:var(--navy);margin-bottom:12px}
.dd-content p{font-size:15px;color:var(--muted);line-height:1.75;margin-bottom:20px}
.dd-features{list-style:none;display:flex;flex-direction:column;gap:8px}
.dd-features li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--dark)}
.dd-features li svg{
  width:16px;height:16px;stroke:var(--blue);fill:none;
  stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;margin-top:2px;
}
.dd-card{
  background:var(--bg);border:1px solid var(--border);
  border-radius:14px;padding:28px;
}
.dd-card-title{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:14px;text-transform:uppercase;letter-spacing:0.06em}
.dd-tag-list{display:flex;flex-wrap:wrap;gap:8px}
.dd-tag{
  font-size:13px;color:var(--dark);
  background:#fff;border:1px solid var(--border);
  padding:5px 12px;border-radius:7px;
}

/* ── CONTACT ── */
.c-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:64px;align-items:start}
.c-info-block{
  background:var(--bg);border:1px solid var(--border);
  border-radius:14px;padding:28px;margin-top:20px;
}
.c-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px}
.c-row:last-child{margin-bottom:0}
.c-icon{
  width:36px;height:36px;border-radius:9px;
  background:var(--blue-lt);display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.c-icon svg{width:16px;height:16px;stroke:var(--blue);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.c-lbl{font-size:11.5px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:0.06em;margin-bottom:2px}
.c-val{font-size:14.5px;font-weight:600;color:var(--dark)}
.c-val a{color:var(--blue);text-decoration:none}
.c-val a:hover{text-decoration:underline}

/* ── FORM ── */
.form-wrap{}
.form-wrap h3{font-size:20px;font-weight:700;color:var(--navy);margin-bottom:6px}
.form-wrap .f-sub{font-size:14px;color:var(--muted);margin-bottom:28px}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.fg label{font-size:13px;font-weight:600;color:var(--dark)}
.fg input,.fg select,.fg textarea{
  width:100%;border:1.5px solid var(--border);
  border-radius:8px;padding:10px 14px;
  font-family:inherit;font-size:14px;color:var(--dark);
  background:#fff;transition:border-color .2s;outline:none;
}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--blue)}
.fg textarea{height:100px;resize:vertical}
.f-submit{
  width:100%;background:var(--blue);color:#fff;
  border:none;padding:14px;border-radius:9px;
  font-family:inherit;font-size:15px;font-weight:600;
  cursor:pointer;transition:all .2s;
  box-shadow:0 4px 14px rgba(74,126,199,0.3);
}
.f-submit:hover{background:var(--blue-d);transform:translateY(-1px)}
.form-note{font-size:12px;color:var(--muted);text-align:center;margin-top:10px}

/* ── FOOTER ── */
footer{
  background:var(--navy);
  padding:48px 48px 28px;
}
.footer-grid{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;
  padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,0.1);
}
.footer-brand img{height:32px;margin-bottom:16px}
.footer-brand p{font-size:13.5px;color:rgba(255,255,255,0.4);line-height:1.7;max-width:280px}
.footer-col h4{
  font-size:12px;font-weight:700;color:rgba(255,255,255,0.5);
  letter-spacing:0.08em;text-transform:uppercase;margin-bottom:14px;
}
.footer-col a{
  display:block;font-size:13.5px;color:rgba(255,255,255,0.55);
  text-decoration:none;margin-bottom:8px;transition:color .2s;
}
.footer-col a:hover{color:#fff}
.footer-bottom{
  max-width:1100px;margin:0 auto;
  padding-top:24px;
  display:flex;align-items:center;justify-content:space-between;
  font-size:12.5px;color:rgba(255,255,255,0.35);flex-wrap:wrap;gap:12px;
}
.footer-bottom a{color:rgba(255,255,255,0.4);text-decoration:none}
.footer-bottom a:hover{color:rgba(255,255,255,0.7)}

/* ── BACKGROUNDS ── */
.bg-off{background:var(--off)}
.bg-blue-xl{background:var(--blue-xl)}
.bg-navy-section{background:var(--navy)}

/* ── INLINE GRID HELPERS ── */
.usp-intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.inbegrepen-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.kennis-nieuwsbrief{
  margin-top:56px;background:var(--blue-xl);border:1px solid var(--blue-lt);
  border-radius:16px;padding:36px 40px;
  display:flex;align-items:center;justify-content:space-between;gap:32px;
}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}

/* ── RESPONSIVE ── */
/* ═══════════════════════════════════════
   RESPONSIVE — TABLET (≤900px)
═══════════════════════════════════════ */
@media(max-width:900px){

  /* ── Layout ── */
  .wrap{padding:0 20px}
  .section{padding:52px 0}

  /* ── Topbar ── */
  .topbar{display:none}

  /* ── Nav ── */
  nav{padding:0 20px;height:68px}
  .nav-logo img{height:44px}
  .nav-links{display:none}
  .nav-phone{display:none}
  .nav-login{display:none}
  .hamburger{display:flex}
  .mobile-menu{top:68px}

  /* ── Hero ── */
  .hero{padding:44px 20px 52px}
  .hero-inner{grid-template-columns:1fr;gap:28px}
  .hero-card{display:none}
  .hero-sub{font-size:15px;margin-bottom:24px}
  .hero-actions{flex-wrap:wrap;gap:10px}
  .hero-actions .btn-primary,.hero-actions .btn-secondary{
    flex:1 1 auto;min-width:140px;text-align:center;justify-content:center;
  }

  /* ── Trust bar ── */
  .trust{padding:10px 20px;gap:14px;justify-content:flex-start}
  .trust-item{font-size:12.5px}

  /* ── Headings ── */
  h1{font-size:32px}
  h2{font-size:25px}
  .s-sub{font-size:14.5px;margin-bottom:28px}

  /* ── Page headers ── */
  .page-header{padding:36px 0}
  .page-header h2{font-size:26px}
  .page-header p{font-size:14.5px;margin-top:8px}

  /* ── Grids ── */
  .diensten-grid{grid-template-columns:1fr}
  .pricing-grid{grid-template-columns:1fr}
  .pricing-two-col{grid-template-columns:1fr!important}
  .team-grid{grid-template-columns:1fr}
  .review-card{flex:0 0 calc(50% - 12px)}
  .reviews-score{font-size:24px}
  .kennis-grid{grid-template-columns:1fr}
  .c-grid{grid-template-columns:1fr;gap:32px}
  .usp-grid{grid-template-columns:1fr}
  .usp-intro-grid{grid-template-columns:1fr;gap:36px}
  .inbegrepen-grid{grid-template-columns:1fr}
  .dienst-detail{grid-template-columns:1fr}
  .opstart-grid{grid-template-columns:1fr 1fr!important}
  .fg-row{grid-template-columns:1fr}

  /* ── CTA Banner ── */
  .cta-banner{flex-direction:column;text-align:center;padding:36px 28px;gap:24px}
  .cta-banner h2{font-size:26px}
  .cta-banner p{font-size:14.5px}
  .cta-banner .btn-primary{align-self:center}

  /* ── Process ── */
  .process-grid{grid-template-columns:1fr;gap:20px}
  .process-grid::before{display:none}

  /* ── Kennisbank nieuwsbrief ── */
  .kennis-nieuwsbrief{flex-direction:column;text-align:center;padding:32px 24px;gap:20px}
  .kennis-nieuwsbrief .btn-primary{align-self:center;white-space:normal}
  .kennis-nieuwsbrief-title{font-size:17px!important}
  .kennis-nieuwsbrief-label{font-size:11px!important}

  /* ── Artikel pages ── */
  .artikel-title{font-size:26px}
  .artikel-body{max-width:100%}
  .artikel-cta{max-width:100%;padding:24px 20px}
  .artikel-meta{flex-wrap:wrap;gap:6px;font-size:12px}

  /* ── Legal pages ── */
  .legal-body{max-width:100%}
  .legal-header h1{font-size:26px}
  .legal-body h2{margin-top:28px}

  /* ── Footer ── */
  .footer-grid{grid-template-columns:1fr!important;gap:32px}
  footer{padding:40px 20px 24px}
  .footer-bottom{flex-direction:column;gap:6px;text-align:center}
}

/* ═══════════════════════════════════════
   RESPONSIVE — MOBILE (≤480px)
═══════════════════════════════════════ */
@media(max-width:480px){

  /* ── Base ── */
  body{font-size:14px}
  .wrap{padding:0 16px}
  .section{padding:28px 0}

  /* ── Typography ladder ── */
  h1{font-size:26px;letter-spacing:-0.01em}
  h2{font-size:21px;letter-spacing:-0.01em}
  h3{font-size:18px}
  .hero-sub{font-size:14px;margin-bottom:22px}
  .s-sub{font-size:13.5px;margin-bottom:24px}
  .s-lbl{font-size:11px}
  /* ── Hero eyebrow: strip pill, flush met s-lbl ── */
  .hero-eyebrow{background:none;padding:0;font-size:11px;border-radius:0;margin-bottom:14px}

  /* ── Page headers ── */
  .page-header{padding:24px 0}
  .page-header h2{font-size:20px}
  .page-header p{font-size:13.5px;margin-top:6px}
  .page-header .wrap{padding:0 16px}

  /* ── Nav ── */
  nav{height:60px}
  .nav-logo img{height:36px}
  .mobile-menu{top:60px}
  .nav-cta{display:none}

  /* ── Trust bar ── */
  .trust{display:none}

  /* ── Hero buttons ── */
  .hero-actions{gap:8px}
  .hero-actions .btn-primary,.hero-actions .btn-secondary{
    width:100%;padding:11px 20px;font-size:14px;justify-content:center;
  }

  /* ── CTA Banner ── */
  .cta-banner{padding:24px 16px}
  .cta-banner h2{font-size:20px}
  .cta-banner p{font-size:13.5px}

  /* ── Reviews carousel ── */
  .review-card{flex:0 0 100%}
  .reviews-summary{gap:6px}
  .reviews-score{font-size:22px}

  /* ── Kennis cards ── */
  .kc-head{padding:18px 18px 14px}
  .kc-icon{width:34px;height:34px;border-radius:8px;margin-bottom:10px}
  .kc-body{padding:14px 18px 0}
  .kc-title{font-size:14.5px}
  .kc-excerpt{font-size:13px}
  .kc-footer{padding:12px 18px 16px}
  .kc-meta{font-size:11px}

  /* ── USP cards ── */
  .usp-card{padding:16px}
  .usp-card h4{font-size:14px}
  .usp-card p{font-size:13px}

  /* ── Diensten ── */
  .dienst{padding:18px}
  .dienst h3{font-size:15px}
  .dienst p{font-size:13px}
  .dd-content h3{font-size:20px}
  .dienst-num{font-size:10px}

  /* ── Artikel ── */
  .artikel-title{font-size:20px}
  .artikel-body h2{font-size:17px}
  .artikel-body p{font-size:14px}
  .artikel-cta{padding:18px 16px}
  .artikel-cta h3{font-size:16px}
  .artikel-cta p{font-size:13px}

  /* ── Legal ── */
  .legal-header h1{font-size:20px}
  .legal-body h2{font-size:16px}
  .legal-body h3{font-size:14px}
  .legal-body p,.legal-body li{font-size:13.5px}

  /* ── Pricing ── */
  .pricing-amount{font-size:30px}
  .pricing-name{font-size:19px}

  /* ── Process ── */
  .process-num{width:44px;height:44px;font-size:17px}
  .process-step h3{font-size:15px}
  .process-step p{font-size:13px}

  /* ── Team ── */
  .team-card{padding:20px}

  /* ── Footer ── */
  footer{padding:28px 16px 18px}
  .footer-bottom{font-size:11.5px}

  /* ── Misc ── */
  .opstart-grid{grid-template-columns:1fr!important}
  .kennis-nieuwsbrief{padding:24px 16px}
  /* ── Blok-CTA knoppen full-width op mobiel ── */
  .kennis-nieuwsbrief .btn-primary,
  .cta-banner .btn-primary,
  .artikel-cta .btn-primary{
    width:100%;justify-content:center;text-align:center;box-sizing:border-box;
  }
  /* ── Newsletter typografie schalen ── */
  .kennis-nieuwsbrief-title{font-size:16px!important}
  .kennis-nieuwsbrief-label{font-size:10.5px!important}
}

/* ── Formspree states ──────────────────────────────────────────── */
.field-err{display:block;font-size:12px;color:#d9534f;margin-top:4px;min-height:16px}
input[aria-invalid="true"],select[aria-invalid="true"],textarea[aria-invalid="true"]{
  border-color:#d9534f!important;background:#fff8f8}
.form-err-global{background:#fff3f3;border:1px solid #f5c6cb;border-radius:10px;
  padding:14px 18px;font-size:14px;color:#721c24;margin-bottom:16px}
.form-err-global a{color:#721c24;font-weight:600}
.form-success{display:none;text-align:center;padding:48px 24px}
.form-success-inner h4{font-size:20px;font-weight:800;color:var(--navy);margin:0 0 8px}
.form-success-inner p{font-size:14.5px;color:var(--muted)}
[data-fs-submit-btn]:disabled{opacity:.6;cursor:not-allowed}
[data-fs-success]:not([style*="display:none"]){animation:fadeIn .4s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
