/* ═══════════════════════════════════════════════════════════
   WEBGROEIERS — LICHT & CLEAN (all-green)
   Manrope · Wit/off-white · Groen #059669 accent
   ═══════════════════════════════════════════════════════════ */

/* ── DESIGN TOKENS ──────────────────────────────────────── */
:root {
  /* Colours */
  --white:       #FFFFFF;
  --off-white:   #F2FBF6;
  --surface:     #E8F7EF;
  --amber:       #059669;
  --accent:      #FBB024;
  --accent-soft: #FEF0D0;
  --accent-dark: #C77E00;
  --amber-dark:  #047857;
  --amber-light: #D1FAE5;
  --text:        #0F1A17;
  --text-soft:   #3C534A;
  --text-muted:  #7C9389;
  --border:      #DBEDE4;
  --navy:        #07291F;
  --navy-mid:    #0E3D2C;

  /* Typography */
  --font:        'Manrope', system-ui, -apple-system, sans-serif;

  /* Spacing */
  --section-y:   clamp(4rem, 8vw, 7rem);
  --container:   1200px;
  --radius:      12px;
  --radius-lg:   20px;
  --radius-xl:   28px;

  /* Shadows */
  --shadow-sm:   0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --shadow-md:   0 4px 16px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);
  --shadow-lg:   0 12px 40px rgba(0,0,0,.10), 0 4px 8px rgba(0,0,0,.05);

  /* Transitions */
  --ease:        cubic-bezier(0.22, 1, 0.36, 1);
  --dur-fast:    150ms;
  --dur-med:     300ms;
  --dur-slow:    500ms;
}

/* ── RESET & BASE ───────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font);
  font-size: 16px;
  line-height: 1.7;
  color: var(--text);
  background: var(--white);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { font: inherit; cursor: pointer; border: none; background: none; }
address { font-style: normal; }

/* ── ACCESSIBILITY ──────────────────────────────────────── */
.skip-link {
  position: absolute;
  top: -100px;
  left: 1rem;
  padding: .5rem 1rem;
  background: var(--amber);
  color: #fff;
  font-weight: 700;
  border-radius: var(--radius);
  z-index: 9999;
  transition: top var(--dur-fast);
}
.skip-link:focus { top: 1rem; }

.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border-width: 0;
}

:focus-visible {
  outline: 2px solid var(--amber);
  outline-offset: 3px;
  border-radius: 4px;
}

/* ── LAYOUT ─────────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: clamp(1.25rem, 5vw, 2.5rem);
}

/* ── COLOUR UTILS ───────────────────────────────────────── */
.amber { color: var(--amber); }
em.amber { font-style: normal; color: var(--amber); }

/* ── TYPOGRAPHY HELPERS ─────────────────────────────────── */
.section-eyebrow {
  display: inline-block;
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--amber);
  margin-bottom: .75rem;
}

.section-heading {
  font-size: clamp(1.75rem, 3.5vw, 2.75rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -.02em;
  color: var(--text);
  margin-bottom: 1rem;
}

.section-sub {
  font-size: 1.0625rem;
  color: var(--text-soft);
  max-width: 600px;
  line-height: 1.7;
}

.section-header {
  margin-bottom: clamp(2.5rem, 5vw, 4rem);
}

/* ── BUTTONS ────────────────────────────────────────────── */
.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .875rem 1.75rem;
  background: var(--amber);
  color: #fff;
  font-weight: 700;
  font-size: .9375rem;
  border-radius: 50px;
  transition: background var(--dur-fast), transform var(--dur-fast), box-shadow var(--dur-fast);
  box-shadow: 0 2px 8px rgba(16,185,129,.35);
  white-space: nowrap;
}
.btn-primary:hover {
  background: var(--amber-dark);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(16,185,129,.45);
}
.btn-primary:active { transform: translateY(0); }

.btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: .375rem;
  padding: .875rem 1.5rem;
  color: var(--text);
  font-weight: 600;
  font-size: .9375rem;
  border: 1.5px solid var(--border);
  border-radius: 50px;
  transition: border-color var(--dur-fast), background var(--dur-fast);
}
.btn-ghost:hover {
  border-color: var(--text);
  background: rgba(26,29,33,.04);
}

.btn-amber {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .875rem 1.75rem;
  background: var(--amber);
  color: #fff;
  font-weight: 700;
  font-size: .9375rem;
  border-radius: 50px;
  transition: background var(--dur-fast), transform var(--dur-fast);
  box-shadow: 0 2px 12px rgba(16,185,129,.4);
}
.btn-amber:hover {
  background: var(--amber-dark);
  transform: translateY(-1px);
}

.btn-ghost-light {
  display: inline-flex;
  align-items: center;
  gap: .375rem;
  padding: .875rem 1.5rem;
  color: rgba(255,255,255,.8);
  font-weight: 600;
  font-size: .9375rem;
  border: 1.5px solid rgba(255,255,255,.2);
  border-radius: 50px;
  transition: border-color var(--dur-fast), color var(--dur-fast);
}
.btn-ghost-light:hover {
  color: #fff;
  border-color: rgba(255,255,255,.5);
}

.btn-full { width: 100%; justify-content: center; }

.btn-google {
  display: inline-flex;
  align-items: center;
  gap: .625rem;
  padding: .75rem 1.5rem;
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: 50px;
  font-weight: 600;
  font-size: .9375rem;
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
}
.btn-google:hover {
  border-color: #4285F4;
  box-shadow: 0 2px 8px rgba(66,133,244,.2);
}

/* ── GLASS CARD ─────────────────────────────────────────── */
.glass-card {
  background: rgba(255,255,255,0.7);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.8);
  box-shadow: var(--shadow-md);
  position: relative;
  overflow: hidden;
}
.glass-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.5) 0%, rgba(255,255,255,0) 60%);
  pointer-events: none;
}

/* ── ANIMATION ──────────────────────────────────────────── */
/* Start hidden; JS adds .is-visible; CSS animation reveals after 800ms as fallback */
@keyframes reveal-fallback {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: none; }
}

[data-animate] {
  animation: reveal-fallback 600ms 800ms var(--ease) both;
}
[data-animate].is-visible {
  animation: reveal-fallback 500ms 0ms var(--ease) both;
}

@media (prefers-reduced-motion: reduce) {
  [data-animate] {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
  html { scroll-behavior: auto; }
}

/* ══════════════════════════════════════════════════════════
   NAVIGATIE
   ══════════════════════════════════════════════════════════ */

.site-header {
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  z-index: 100;
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-bottom: 1px solid transparent;
  transition: box-shadow var(--dur-fast);
}

/* Scrolled: witte achtergrond + donkere tekst */
.site-header.scrolled {
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  box-shadow: 0 2px 16px rgba(0,0,0,.06);
}

.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  height: 68px;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: clamp(1.25rem, 5vw, 2.5rem);
}

.nav-logo {
  display: flex;
  align-items: center;
  gap: .625rem;
  font-weight: 800;
  font-size: 1.0625rem;
  letter-spacing: -.01em;
  color: var(--text);
  text-shadow: none;
  flex-shrink: 0;
  text-decoration: none;
  transition: color var(--dur-fast), text-shadow var(--dur-fast);
}
.logo-mark {
  width: 36px;
  height: 36px;
  background: var(--amber);
  color: #fff;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.125rem;
  font-weight: 800;
  flex-shrink: 0;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 2rem;
  list-style: none;
}
.nav-links a {
  font-size: .9375rem;
  font-weight: 500;
  color: var(--text-soft);
  text-shadow: none;
  transition: color var(--dur-fast), text-shadow var(--dur-fast);
}
.nav-links a:hover { color: var(--text); }

.nav-cta {
  padding: .625rem 1.25rem;
  background: var(--amber) !important;
  color: #fff !important;
  font-weight: 700 !important;
  border-radius: 50px;
  transition: background var(--dur-fast) !important;
}
.nav-cta:hover { background: var(--amber-dark) !important; }

/* ── Scrolled state: donkere nav-tekst ── */
.site-header.scrolled .nav-logo {
  color: var(--text);
  text-shadow: none;
}
.site-header.scrolled .nav-links a {
  color: var(--text-soft);
  text-shadow: none;
}
.site-header.scrolled .nav-links a:hover {
  color: var(--text);
}
.site-header.scrolled .hamburger span {
  background: var(--text);
}

/* ── Mobile trigger ─ */
.mobile-menu__trigger {
  display: none;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius);
  color: var(--text);
  transition: background var(--dur-fast);
  flex-shrink: 0;
}
.mobile-menu__trigger:hover { background: var(--off-white); }

.hamburger {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--text);
  border-radius: 2px;
  transition: transform var(--dur-med) var(--ease), opacity var(--dur-fast);
}

/* Open state */
.mobile-menu__trigger[aria-expanded="true"] .hamburger span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.mobile-menu__trigger[aria-expanded="true"] .hamburger span:nth-child(2) {
  opacity: 0;
}
.mobile-menu__trigger[aria-expanded="true"] .hamburger span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* ── Mobile overlay (fullscreen kit) ── */
.mobile-menu__overlay {
  position: fixed;
  inset: 0;
  height: 100dvh;
  width: 100%;
  background: var(--white);
  z-index: 200;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  padding: 1.5rem clamp(1.25rem, 5vw, 2.5rem) 2.5rem;

  opacity: 0;
  pointer-events: none;
  transform: translateY(-8px);
  transition: opacity var(--dur-med) var(--ease), transform var(--dur-med) var(--ease);
}
.mobile-menu__overlay[aria-hidden="false"] {
  opacity: 1;
  pointer-events: auto;
  transform: none;
}

.mobile-menu__close {
  align-self: flex-end;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius);
  color: var(--text);
  margin-bottom: 1rem;
  transition: background var(--dur-fast);
}
.mobile-menu__close:hover { background: var(--off-white); }

.mobile-menu__panel { flex: 1; }

.mobile-menu__list {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}

.mobile-menu__item {
  display: block;
  padding: 1rem 1.25rem;
  font-size: 1.375rem;
  font-weight: 700;
  color: var(--text);
  border-radius: var(--radius);
  letter-spacing: -.02em;
  transition: background var(--dur-fast), color var(--dur-fast);
}
.mobile-menu__item:hover { background: var(--off-white); }
.mobile-menu__item--cta {
  background: var(--amber);
  color: #fff;
  margin-top: .5rem;
}
.mobile-menu__item--cta:hover {
  background: var(--amber-dark);
}

.mobile-menu__footer {
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
}
.mobile-menu__footer p {
  font-size: .875rem;
  color: var(--text-muted);
  margin-bottom: .5rem;
}
.mobile-menu__phone {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -.01em;
}

@media (max-width: 768px) {
  .nav-links { display: none; }
  .mobile-menu__trigger { display: flex; }
}

/* ══════════════════════════════════════════════════════════
   HERO
   ══════════════════════════════════════════════════════════ */

.hero {
  background: var(--white);
  padding-block: clamp(4rem, 8vw, 6rem) clamp(3rem, 6vw, 5rem);
}

.hero-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2.5rem, 5vw, 4rem);
  align-items: center;
}

/* Left: text */
.hero-text { display: flex; flex-direction: column; gap: 1.5rem; }

.hero-eyebrow {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .8125rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.eyebrow-dot {
  width: 8px;
  height: 8px;
  background: var(--amber);
  border-radius: 50%;
  flex-shrink: 0;
}

.hero-headline {
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -.03em;
  color: var(--text);
  margin: 0;
}

.hero-sub {
  font-size: clamp(.9375rem, 1.5vw, 1.0625rem);
  color: var(--text-soft);
  line-height: 1.7;
  max-width: 480px;
  margin: 0;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  align-items: center;
}

.hero-trust {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding-top: .5rem;
}
.stars { color: #F5B400; font-size: 1rem; letter-spacing: 2px; }
.trust-text { font-size: .875rem; color: var(--text-muted); }
.trust-text strong { color: var(--text); }

/* Right: video frame (jkc-stijl) */
.hero-media { display: flex; justify-content: center; }

.hero-video-frame {
  width: 100%;
  max-width: 580px;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  position: relative;
  background: var(--off-white);
  aspect-ratio: 16/10;
}

.hero-video-slot {
  width: 100%;
  height: 100%;
  position: relative;
  display: block;
}

.hero-poster-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.hero-video-frame video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.video-play-hint {
  position: absolute;
  bottom: 4rem;
  right: 1.25rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  pointer-events: none;
}
.video-play-hint span {
  font-size: .6875rem;
  font-weight: 600;
  color: rgba(255,255,255,.8);
  background: rgba(0,0,0,.4);
  padding: .25rem .625rem;
  border-radius: 50px;
  white-space: nowrap;
}

.video-badge {
  position: absolute;
  bottom: 1.25rem;
  left: 1.25rem;
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .5rem .875rem;
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(8px);
  border-radius: 50px;
  font-size: .75rem;
  font-weight: 600;
  color: var(--text);
  box-shadow: var(--shadow-sm);
}
.badge-dot {
  width: 7px; height: 7px;
  background: #22c55e;
  border-radius: 50%;
  animation: pulse-dot 2s infinite;
}

@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: .6; transform: scale(.85); }
}

@media (max-width: 900px) {
  .hero-layout {
    grid-template-columns: 1fr;
  }
  .hero-media { order: -1; }
  .hero-video-frame { max-width: 100%; }
}

/* ══════════════════════════════════════════════════════════
   HERO — FULL-BLEED VIDEO (jkc-stijl)
   ══════════════════════════════════════════════════════════ */

.hero--video {
  position: relative;
  width: 100%;
  /* Inset/padded frame — clearly visible white margin all around video */
  padding: clamp(20px, 3vw, 40px);
  background: var(--white);
  display: block;
  margin-top: 0;
}

/* Inner container: clipped + rounded video area */
.hero-video-inner {
  position: relative;
  width: 100%;
  height: min(80vh, 740px);
  min-height: 480px;
  border-radius: 28px;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  background: #0d0e10;
  box-shadow: 0 8px 40px rgba(0,0,0,.18), 0 2px 8px rgba(0,0,0,.10);
}

/* Background video */
.hero-bg-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
  pointer-events: none;
}

/* ── Hero slideshow: AI-stills MKB-bedrijven, Ken Burns crossfade ── */
.hero-slideshow {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}
.hero-slide {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0;
  will-change: opacity, transform;
  animation: heroFade 30s infinite, heroZoom 30s infinite;
}
.hero-slide:nth-child(1) { animation-delay: 0s,  0s;  }
.hero-slide:nth-child(2) { animation-delay: 6s,  6s;  }
.hero-slide:nth-child(3) { animation-delay: 12s, 12s; }
.hero-slide:nth-child(4) { animation-delay: 18s, 18s; }
.hero-slide:nth-child(5) { animation-delay: 24s, 24s; }
@keyframes heroFade {
  0%   { opacity: 0; }
  3%   { opacity: 1; }
  18%  { opacity: 1; }
  22%  { opacity: 0; }
  100% { opacity: 0; }
}
@keyframes heroZoom {
  0%   { transform: scale(1.03); }
  22%  { transform: scale(1.12); }
  100% { transform: scale(1.12); }
}

/* Gradient scrim — subtle top, strong bottom */
.hero-scrim {
  position: absolute;
  inset: 0;
  z-index: 1;
  /* Full-width dark overlay for nav legibility + bottom text readability */
  background:
    linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0.18) 0%,
      rgba(0, 0, 0, 0.18) 15%,
      rgba(0, 0, 0, 0.20) 40%,
      rgba(0, 0, 0, 0.68) 75%,
      rgba(0, 0, 0, 0.82) 100%
    );
}

/* Content wrapper — sits above scrim */
.hero-video-content {
  position: relative;
  z-index: 2;
  width: 100%;
  padding-bottom: clamp(2.5rem, 5vw, 4rem);
}

.hero-video-text {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  max-width: 640px;
}

/* Light variants of existing hero text classes */
.hero-eyebrow--light {
  color: rgba(255, 255, 255, 0.75);
}
.hero-eyebrow--light .eyebrow-dot {
  background: var(--amber, #059669);
}

.hero-headline--light {
  color: #ffffff;
  font-size: clamp(2.4rem, 5.5vw, 4.25rem);
  font-weight: 800;
  line-height: 1.07;
  letter-spacing: -0.03em;
  text-shadow: 0 2px 16px rgba(0,0,0,.35);
}

.hero-sub--light {
  color: rgba(255, 255, 255, 0.85);
  max-width: 480px;
  text-shadow: 0 1px 6px rgba(0,0,0,.3);
}

/* Ghost white CTA */
.btn-ghost--white {
  color: #ffffff;
  border-color: rgba(255, 255, 255, 0.65);
  background: transparent;
}
.btn-ghost--white:hover,
.btn-ghost--white:focus-visible {
  background: rgba(255, 255, 255, 0.12);
  border-color: #ffffff;
  color: #ffffff;
}

/* Trust / rating badge on dark background */
.hero-trust--light .stars {
  color: #F5B400;
}
.trust-text--light {
  color: rgba(255, 255, 255, 0.8);
}
.trust-text--light strong {
  color: #ffffff;
}


/* ── Explicit amber on primary CTA inside video hero ── */
.hero--video .btn-primary {
  background: #059669 !important;
  color: #ffffff !important;
  box-shadow: 0 6px 22px rgba(5, 150, 105, 0.45) !important;
}
.hero--video .btn-primary:hover {
  background: #047857 !important;
}
/* ── Reduced-motion: pause video, show poster ── */
@media (prefers-reduced-motion: reduce) {
  /* Pauzeer de hero-video; poster blijft zichtbaar */
  .hero-bg-video { animation-play-state: paused; }
}

/* ── Mobile: stronger scrim, stacked CTAs ── */
@media (max-width: 640px) {
  .hero--video {
    padding: 16px;
  }
  .hero-video-inner {
    height: min(86vh, 640px);
    min-height: 440px;
    border-radius: 20px;
  }
  .hero-scrim {
    background: linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0.08) 0%,
      rgba(0, 0, 0, 0.30) 35%,
      rgba(0, 0, 0, 0.78) 72%,
      rgba(0, 0, 0, 0.88) 100%
    );
  }
  .hero-video-text {
    gap: 1rem;
  }
  .hero-headline--light {
    font-size: clamp(2rem, 9vw, 2.8rem);
  }
  .hero-actions {
    flex-direction: column;
    align-items: flex-start;
  }
  .hero-actions .btn-primary,
  .hero-actions .btn-ghost--white {
    width: 100%;
    text-align: center;
    justify-content: center;
  }
}

/* ══════════════════════════════════════════════════════════
   TRUST STRIP
   ══════════════════════════════════════════════════════════ */

.trust-strip .container { display: block; }

.trust-logos {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  align-items: center;
}

.logo-pill {
  display: inline-block;
  padding: .375rem 1rem;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 50px;
  font-size: .8125rem;
  font-weight: 600;
  color: var(--text-soft);
  white-space: nowrap;
}

/* ══════════════════════════════════════════════════════════
   STORYTELLING
   ══════════════════════════════════════════════════════════ */

.storytelling {
  padding-block: var(--section-y);
  background: var(--white);
}

.story-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1.25rem;
  margin-bottom: clamp(3rem, 5vw, 4rem);
}

.story-card {
  padding: 2rem;
  border-radius: var(--radius-lg);
  transition: transform var(--dur-med) var(--ease), box-shadow var(--dur-med);
}
.story-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.story-icon {
  font-size: 2rem;
  margin-bottom: 1rem;
  display: block;
}

.story-card h3 {
  font-size: 1.125rem;
  font-weight: 700;
  margin-bottom: .5rem;
  color: var(--text);
  letter-spacing: -.01em;
}

.story-card p {
  font-size: .9375rem;
  color: var(--text-soft);
  line-height: 1.6;
}

/* Stats row */
.stats-row {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: space-between;
  background: var(--off-white);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 2.5rem clamp(1.5rem, 4vw, 3rem);
}

.stat-item {
  display: flex;
  flex-direction: column;
  gap: .25rem;
  flex: 1;
  min-width: 140px;
}

.stat-number {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 800;
  letter-spacing: -.04em;
  line-height: 1;
}
.stat-plus { font-size: .6em; }

.stat-label {
  font-size: .875rem;
  color: var(--text-muted);
  font-weight: 500;
}

.stat-divider {
  width: 1px;
  background: var(--border);
  align-self: stretch;
  flex-shrink: 0;
}

@media (max-width: 640px) {
  .stat-divider { display: none; }
  .stats-row { gap: 2rem; }
  .stat-item { min-width: 45%; }
}

/* ══════════════════════════════════════════════════════════
   GOOGLE REVIEWS
   ══════════════════════════════════════════════════════════ */

.reviews-section {
  padding-block: var(--section-y);
  background: var(--off-white);
}

.google-badge {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .375rem .875rem;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 50px;
  font-size: .875rem;
  font-weight: 600;
  color: var(--text);
  margin-left: .75rem;
  vertical-align: middle;
}

.reviews-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1.25rem;
  margin-bottom: 2.5rem;
}

.review-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  box-shadow: var(--shadow-sm);
  transition: transform var(--dur-med) var(--ease), box-shadow var(--dur-med);
}
.review-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}

.review-stars {
  color: var(--amber);
  font-size: 1.125rem;
  letter-spacing: 2px;
}

.review-quote {
  font-size: .9375rem;
  color: var(--text-soft);
  line-height: 1.65;
  flex: 1;
  quotes: '"' '"';
}
.review-quote::before { content: open-quote; }
.review-quote::after { content: close-quote; }

.review-footer {
  display: flex;
  align-items: center;
  gap: .875rem;
}

.review-avatar {
  width: 40px;
  height: 40px;
  background: var(--amber-light);
  color: var(--amber-dark);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 1rem;
  flex-shrink: 0;
  border: 2px solid var(--amber);
}

.review-name {
  display: block;
  font-size: .9375rem;
  color: var(--text);
  font-weight: 700;
}

.review-biz {
  font-size: .8125rem;
  color: var(--text-muted);
  display: block;
}
.review-biz em { font-style: italic; }

.reviews-cta { text-align: center; }

/* ══════════════════════════════════════════════════════════
   WERK / CASES
   ══════════════════════════════════════════════════════════ */

.work-section {
  padding-block: var(--section-y);
  background: var(--white);
}

.cases-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 1.5rem;
  align-items: stretch;
}

.case-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--white);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
  transition: transform var(--dur-med) var(--ease), box-shadow var(--dur-med);
}
.case-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

/* Browser frame mockup */
.browser-frame {
  background: var(--off-white);
  border-bottom: 1px solid var(--border);
}

.browser-bar {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .625rem 1rem;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}

.browser-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--border);
  flex-shrink: 0;
}
.browser-dot:nth-child(1) { background: #ff5f57; }
.browser-dot:nth-child(2) { background: #febc2e; }
.browser-dot:nth-child(3) { background: #28c840; }

.browser-url {
  flex: 1;
  text-align: center;
  font-size: .75rem;
  font-weight: 500;
  color: var(--text-muted);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 50px;
  padding: .25rem .875rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.browser-screen {
  aspect-ratio: 16/10;
  overflow: hidden;
}
.browser-screen img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
  transition: transform .6s var(--ease);
}
.case-card:hover .browser-screen img {
  transform: scale(1.03);
}

.case-info {
  padding: 1.25rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.case-name {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -.01em;
}

.case-tag {
  font-size: .75rem;
  font-weight: 600;
  color: var(--text-muted);
  background: var(--off-white);
  padding: .25rem .75rem;
  border-radius: 50px;
  border: 1px solid var(--border);
  white-space: nowrap;
}

/* ══════════════════════════════════════════════════════════
   PRICING
   ══════════════════════════════════════════════════════════ */

.pricing-section {
  padding-block: var(--section-y);
  background: var(--off-white);
}

.pricing-category {
  margin-bottom: 3rem;
}

.pricing-cat-label {
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 1.25rem;
  padding-bottom: .75rem;
  border-bottom: 1px solid var(--border);
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.25rem;
  max-width: 780px;
}

.price-card {
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 2rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  position: relative;
  box-shadow: var(--shadow-sm);
  transition: transform var(--dur-med), box-shadow var(--dur-med);
}
.price-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}

.price-card--featured {
  border-color: var(--amber);
  box-shadow: 0 0 0 1px var(--amber), var(--shadow-md);
}

.price-label-popular {
  position: absolute;
  top: -1px;
  right: 1.5rem;
  background: var(--amber);
  color: #fff;
  font-size: .6875rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: .25rem .75rem;
  border-radius: 0 0 var(--radius) var(--radius);
}

.price-card-header {
  display: flex;
  flex-direction: column;
  gap: .75rem;
}

.price-badge {
  font-size: .8125rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--text-soft);
}

.price-setup {
  font-size: .875rem;
  color: var(--text-muted);
  display: block;
}

.price-monthly {
  display: flex;
  align-items: baseline;
  gap: .25rem;
}

.price-big {
  font-size: 2.75rem;
  font-weight: 800;
  letter-spacing: -.04em;
  color: var(--text);
  line-height: 1;
}

.price-period {
  font-size: 1rem;
  color: var(--text-muted);
  font-weight: 500;
}

.price-features {
  display: flex;
  flex-direction: column;
  gap: .625rem;
  flex: 1;
}
.price-features li {
  font-size: .9375rem;
  color: var(--text-soft);
  padding-left: 1.375rem;
  position: relative;
}
.price-features li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--amber);
  font-weight: 700;
}

.price-note {
  font-size: .8125rem;
  color: var(--amber-dark);
  font-weight: 600;
}

.price-disclaimer {
  font-size: .875rem;
  color: var(--text-muted);
  margin-top: .5rem;
  font-style: italic;
}

/* ══════════════════════════════════════════════════════════
   MARKETING
   ══════════════════════════════════════════════════════════ */

.marketing-section {
  padding-block: var(--section-y);
  background: var(--white);
}

.marketing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.25rem;
}

.marketing-card {
  padding: 2rem;
  border-radius: var(--radius-lg);
  transition: transform var(--dur-med), box-shadow var(--dur-med);
}
.marketing-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.marketing-icon {
  font-size: 2.25rem;
  margin-bottom: 1rem;
  display: block;
}

.marketing-card h3 {
  font-size: 1.375rem;
  font-weight: 800;
  letter-spacing: -.02em;
  color: var(--text);
  margin-bottom: .25rem;
}

.marketing-sub {
  font-size: .8125rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--amber-dark);
  margin-bottom: .875rem;
}

.marketing-card p:not(.marketing-sub) {
  font-size: .9375rem;
  color: var(--text-soft);
  line-height: 1.65;
  margin-bottom: 1rem;
}

.marketing-points {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.marketing-points li {
  font-size: .875rem;
  color: var(--text-soft);
  padding-left: 1.25rem;
  position: relative;
}
.marketing-points li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--amber);
  font-size: .8em;
}

/* ══════════════════════════════════════════════════════════
   AUTORANQ CALLOUT — enige donkere sectie
   ══════════════════════════════════════════════════════════ */

/* ══════════════════════════════════════════════════════════
   AUTORANQ SHOWCASE (ingelijste gradient-card + product-mock)
   ══════════════════════════════════════════════════════════ */
.autoranq-section {
  padding-block: var(--section-y);
  background: var(--off-white);
}

.autoranq-card {
  position: relative;
  overflow: hidden;
  border-radius: clamp(20px, 3vw, 32px);
  padding: clamp(1.75rem, 4vw, 3.5rem);
  background: linear-gradient(140deg, #0A1410 0%, #0E2A20 52%, #064E3B 100%);
  box-shadow: 0 30px 80px -30px rgba(4,120,87,.45), 0 2px 0 rgba(255,255,255,.04) inset;
}
/* glossy sheen */
.autoranq-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.08) 0%, transparent 42%);
  pointer-events: none;
}
/* groene radial glow */
.autoranq-card::after {
  content: '';
  position: absolute;
  top: -30%;
  right: -10%;
  width: 55%;
  height: 150%;
  background: radial-gradient(ellipse at center, rgba(16,185,129,.22) 0%, transparent 70%);
  pointer-events: none;
}

.autoranq-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1.05fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}

.autoranq-eyebrow {
  display: inline-block;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #34d399;
  margin-bottom: .875rem;
}
.autoranq-heading {
  font-size: clamp(1.75rem, 4vw, 3rem);
  font-weight: 800;
  line-height: 1.12;
  letter-spacing: -.03em;
  color: var(--white);
  margin-bottom: 1rem;
}
.autoranq-heading em.amber { color: #34d399; }
.autoranq-sub {
  font-size: 1.0625rem;
  color: rgba(255,255,255,.7);
  line-height: 1.7;
  max-width: 520px;
  margin-bottom: 1.75rem;
}
.autoranq-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .875rem;
  align-items: center;
  margin-bottom: 1.5rem;
}
.autoranq-chips {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}
.aq-chip {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  font-size: .8125rem;
  font-weight: 600;
  color: rgba(255,255,255,.85);
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  padding: .4rem .8rem;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.aq-dot { width: 7px; height: 7px; border-radius: 50%; background: #34d399; box-shadow: 0 0 8px rgba(52,211,153,.8); }

/* ── Autoranq browser frame (echte product-preview) ── */
.autoranq-browser {
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 30px 70px -28px rgba(0,0,0,.75);
}
.autoranq-browser-bar {
  display: flex; align-items: center; gap: .4rem;
  padding: .6rem .9rem;
  background: rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.autoranq-browser-bar .bdot { width: 9px; height: 9px; border-radius: 50%; background: rgba(255,255,255,.3); }
.autoranq-browser-bar .bdot:nth-child(1){ background:#ff5f57; }
.autoranq-browser-bar .bdot:nth-child(2){ background:#febc2e; }
.autoranq-browser-bar .bdot:nth-child(3){ background:#28c840; }
.autoranq-browser-url {
  margin-left: .6rem; font-size: .75rem; color: rgba(255,255,255,.6);
  background: rgba(0,0,0,.25); border-radius: 6px; padding: .2rem .7rem;
}
.autoranq-browser-screen {
  aspect-ratio: 16 / 11;
  overflow: hidden;
  background: #fff;
}
.autoranq-browser-screen img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: top center;
  display: block;
}

@media (max-width: 860px) {
  .autoranq-inner { grid-template-columns: 1fr; }
  .autoranq-visual { order: 2; }
}

/* ══════════════════════════════════════════════════════════
   CONTACT
   ══════════════════════════════════════════════════════════ */

.contact-section {
  padding-block: var(--section-y);
  background: var(--off-white);
}

.contact-inner {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(2.5rem, 6vw, 5rem);
  align-items: start;
}

@media (max-width: 900px) {
  .contact-inner { grid-template-columns: 1fr; }
}

.contact-methods {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  margin-top: 1.5rem;
}

.contact-method {
  display: flex;
  align-items: center;
  gap: .875rem;
  padding: 1rem 1.25rem;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-weight: 600;
  color: var(--text);
  font-size: .9375rem;
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
}
.contact-method:hover {
  border-color: var(--amber);
  box-shadow: 0 0 0 1px var(--amber);
}

.contact-icon { font-size: 1.25rem; }

/* Contact form */
.contact-form-wrap {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: clamp(1.5rem, 4vw, 2.5rem);
  box-shadow: var(--shadow-md);
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

@media (max-width: 560px) {
  .form-row { grid-template-columns: 1fr; }
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: .375rem;
}

.form-group label {
  font-size: .875rem;
  font-weight: 600;
  color: var(--text);
}

.form-group input,
.form-group textarea {
  font-family: var(--font);
  font-size: .9375rem;
  line-height: 1.5;
  color: var(--text);
  background: var(--off-white);
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  padding: .75rem 1rem;
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
  resize: vertical;
}

.form-group input:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--amber);
  box-shadow: 0 0 0 3px rgba(16,185,129,.15);
  background: var(--white);
}

.form-group input::placeholder,
.form-group textarea::placeholder {
  color: var(--text-muted);
}

.form-privacy {
  font-size: .8125rem;
  color: var(--text-muted);
  text-align: center;
}
.form-privacy a { color: var(--amber-dark); text-decoration: underline; }

/* ══════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════ */

.site-footer-outer {
  padding: clamp(20px, 3vw, 40px);
  background: var(--white);
}

.site-footer {
  background: linear-gradient(135deg, #1A1D21 0%, #232B38 60%, #2A3040 100%);
  color: rgba(255,255,255,.75);
  padding-block: clamp(3rem, 6vw, 5rem) 2rem;
  border-radius: 24px;
  overflow: hidden;
  position: relative;
  box-shadow: 0 8px 40px rgba(0,0,0,.15);
}

/* Subtle gloss sheen at top */
.site-footer::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 180px;
  background: linear-gradient(to bottom,
    rgba(255,255,255,.07) 0%,
    rgba(255,255,255,0) 100%);
  pointer-events: none;
  border-radius: 24px 24px 0 0;
  z-index: 0;
}

/* Amber radial glow accent */
.site-footer::after {
  content: '';
  position: absolute;
  top: -20%;
  right: -5%;
  width: 50%;
  height: 120%;
  background: radial-gradient(ellipse at center, rgba(16,185,129,.07) 0%, transparent 65%);
  pointer-events: none;
  z-index: 0;
}

.site-footer .container {
  position: relative;
  z-index: 1;
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 2.5rem;
  margin-bottom: 3rem;
}

@media (max-width: 900px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: 1 / -1; }
}

@media (max-width: 560px) {
  .footer-grid { grid-template-columns: 1fr; }
  .site-footer-outer { padding: 16px; }
  .site-footer { border-radius: 16px; }
}

.footer-brand .nav-logo {
  color: var(--white);
  margin-bottom: 1rem;
  display: inline-flex;
}
.footer-brand .logo-mark {
  background: var(--amber);
}
.footer-brand .logo-text {
  color: var(--white);
}

.footer-tagline {
  font-size: .9375rem;
  color: rgba(255,255,255,.5);
  line-height: 1.6;
  max-width: 300px;
  margin-bottom: 1.5rem;
}

.footer-social {
  display: flex;
  gap: .875rem;
}
.footer-social a {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.08);
  border-radius: 10px;
  color: rgba(255,255,255,.7);
  transition: background var(--dur-fast), color var(--dur-fast);
}
.footer-social a:hover {
  background: var(--amber);
  color: #fff;
}

.footer-nav-heading {
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.4);
  margin-bottom: 1rem;
}

.footer-nav ul {
  display: flex;
  flex-direction: column;
  gap: .625rem;
}

.footer-nav a {
  font-size: .9375rem;
  color: rgba(255,255,255,.6);
  transition: color var(--dur-fast);
}
.footer-nav a:hover { color: var(--white); }

.footer-nav address p {
  margin-bottom: .375rem;
}

.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: 1.5rem;
  font-size: .875rem;
  color: rgba(255,255,255,.35);
}
.footer-bottom a {
  color: rgba(255,255,255,.5);
  transition: color var(--dur-fast);
}
.footer-bottom a:hover { color: var(--white); }

/* ══════════════════════════════════════════════════════════
   RESPONSIVE UTILITIES
   ══════════════════════════════════════════════════════════ */

@media (max-width: 1024px) {
  .cases-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  .cases-grid { grid-template-columns: 1fr; }
  .reviews-grid { grid-template-columns: 1fr; }
  .marketing-grid { grid-template-columns: 1fr; }
  .pricing-grid { grid-template-columns: 1fr; }
}

/* ── Fixed-nav body offset + hero underlay ── */
body {
  padding-top: 68px; /* compensate for fixed header */
}
/* Nav is now over a light background — no negative margin needed */
/* .hero--video margin-top reset intentionally removed */

/* ── Pricing: single-column on very narrow screens ── */
@media (max-width: 420px) {
  .pricing-grid {
    grid-template-columns: 1fr !important;
  }
}

/* ══════════════════════════════════════════════════════════
   SERVICES GRID (Webtify-stijl productkaarten) + SVG-iconen
   ══════════════════════════════════════════════════════════ */
.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
  margin-bottom: clamp(3rem, 5vw, 4rem);
}
.service-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: .85rem;
  padding: 2rem 1.9rem 1.9rem;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: 0 1px 2px rgba(7,41,31,.04);
  text-decoration: none;
  color: var(--text);
  transition: transform .35s var(--ease), box-shadow .35s, border-color .35s;
  overflow: hidden;
}
.service-card::before {
  content: '';
  position: absolute; inset: 0 0 auto 0; height: 3px;
  background: linear-gradient(90deg, #059669, #34d399);
  opacity: 0; transition: opacity .35s;
}
.service-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 44px -22px rgba(7,41,31,.35);
  border-color: #BFE6D2;
}
.service-card:hover::before { opacity: 1; }
.service-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 52px; height: 52px; border-radius: 14px;
  background: var(--amber-light); color: #047857;
}
.service-icon svg { width: 26px; height: 26px; }
.service-card h3 { font-size: 1.18rem; font-weight: 800; letter-spacing: -.02em; }
.service-card p { color: var(--text-soft); line-height: 1.6; font-size: .95rem; flex-grow: 1; }
.service-link { font-weight: 700; color: #059669; font-size: .9rem; display: inline-flex; gap: .35rem; align-items: center; transition: gap .3s; }
.service-card:hover .service-link { gap: .6rem; }
.service-card--featured { border-color: #BFE6D2; box-shadow: 0 12px 36px -20px rgba(5,150,105,.4); }
.service-badge {
  position: absolute; top: 1.1rem; right: 1.1rem;
  font-size: .7rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
  color: #047857; background: var(--amber-light);
  padding: .25rem .6rem; border-radius: 999px;
}
@media (max-width: 860px) { .services-grid { grid-template-columns: 1fr; } }

/* Emoji -> SVG iconen */
.marketing-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 54px; height: 54px; border-radius: 14px;
  background: var(--amber-light); color: #047857; margin-bottom: 1rem;
}
.marketing-icon svg { width: 28px; height: 28px; }
.contact-icon { display: inline-flex; align-items: center; justify-content: center; color: #059669; }
.contact-icon svg { width: 22px; height: 22px; }

/* ══════════════════════════════════════════════════════════
   COMPONENT-CONSISTENTIE (clean, uniforme cards + AI-logo-strip)
   ══════════════════════════════════════════════════════════ */
/* Eén clean card-stijl voor alle content-cards */
.glass-card {
  background: var(--white);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border: 1px solid var(--border);
  box-shadow: 0 1px 3px rgba(7,41,31,.05);
}
.service-card,
.marketing-card,
.case-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: 0 1px 3px rgba(7,41,31,.05);
  transition: transform .35s var(--ease), box-shadow .35s, border-color .35s;
}
.service-card:hover,
.marketing-card:hover,
.case-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 44px -22px rgba(7,41,31,.30);
  border-color: #BFE6D2;
}
/* groene top-accentbalk weg voor uniforme, rustige look */
.service-card::before { display: none; }

/* AI-vindbaarheid logo-strip */
.ai-visibility {
  text-align: center;
  margin: 0 auto clamp(2.5rem, 5vw, 3.5rem);
}
.ai-visibility-label {
  display: block;
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 1.25rem;
}
.ai-logos {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: clamp(1.4rem, 4vw, 3rem);
}
.ai-logo {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  color: #9AA8A0;
  opacity: .9;
  transition: color .3s, opacity .3s;
}
.ai-logo svg { width: 21px; height: 21px; flex-shrink: 0; }
.ai-logo span { font-size: .95rem; font-weight: 600; letter-spacing: -.01em; }
.ai-logo:hover { color: var(--text); opacity: 1; }

/* ══════════════════════════════════════════════════════════
   SHOWCASE IMAGE-CARDS · REVIEW-AVATARS · AUTORANQ LICHT · KENNISBANK
   ══════════════════════════════════════════════════════════ */
/* Showcase: FULL-IMAGE-BACKGROUND cards (echte foto vult de kaart) */
.cases-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; align-items: stretch; }
.case-card {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: 0 2px 10px rgba(7,41,31,.08);
  transition: transform .35s var(--ease), box-shadow .35s;
  isolation: isolate;
}
.case-card:hover { transform: translateY(-5px); box-shadow: 0 26px 56px -22px rgba(7,41,31,.45); }
.case-bg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  z-index: 0;
  transition: transform .7s var(--ease);
}
.case-card:hover .case-bg { transform: scale(1.06); }
.case-overlay {
  position: absolute; inset: 0;
  z-index: 1;
  display: flex; flex-direction: column; justify-content: flex-end;
  gap: .5rem;
  padding: 1.6rem 1.5rem 1.5rem;
  background: linear-gradient(to top, rgba(8,20,15,.88) 0%, rgba(8,20,15,.55) 32%, rgba(8,20,15,.12) 58%, rgba(8,20,15,0) 78%);
}
.case-name { font-size: 1.3rem; font-weight: 800; letter-spacing: -.02em; color: #fff; text-shadow: 0 1px 8px rgba(0,0,0,.4); }
.case-desc { font-size: .9rem; color: rgba(255,255,255,.88); line-height: 1.5; text-shadow: 0 1px 6px rgba(0,0,0,.4); }
.case-services { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: .35rem; }
.case-service {
  font-size: .72rem; font-weight: 700; letter-spacing: .02em;
  color: #fff;
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.28);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  padding: .28rem .7rem; border-radius: 999px;
}
@media (max-width: 900px) { .cases-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 600px) { .cases-grid { grid-template-columns: 1fr; } }

/* Review portret-avatars + gouden sterren */
img.review-avatar { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; display: block; border: 2px solid var(--white); box-shadow: 0 2px 8px rgba(7,41,31,.15); }
.review-stars { color: #F5B400; }

/* Autoranq LICHT & clean (override donkere gradient) */
.autoranq-section { background: var(--off-white); }
.autoranq-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-xl); box-shadow: 0 1px 3px rgba(7,41,31,.05); }
.autoranq-card::before, .autoranq-card::after { display: none !important; }
.autoranq-eyebrow { color: #059669; }
.autoranq-heading { color: var(--text); }
.autoranq-heading em.amber { color: #059669; }
.autoranq-sub { color: var(--text-soft); }
.aq-chip { color: #047857; background: var(--amber-light); border: 1px solid #CDEBDC; backdrop-filter: none; -webkit-backdrop-filter: none; }
.aq-dot { background: #059669; box-shadow: none; }
.autoranq-browser { background: var(--white); border: 1px solid var(--border); box-shadow: 0 18px 44px -22px rgba(7,41,31,.25); }
.autoranq-browser-bar { background: var(--surface); border-bottom: 1px solid var(--border); }
.autoranq-browser-url { color: var(--text-muted); background: var(--off-white); }

/* Kennisbank */
.kb-section { background: var(--white); }
.kb-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
.kb-card { display: flex; flex-direction: column; gap: .55rem; padding: 1.6rem 1.5rem; background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: 0 1px 3px rgba(7,41,31,.05); text-decoration: none; color: var(--text); transition: transform .35s var(--ease), box-shadow .35s, border-color .35s; }
.kb-card:hover { transform: translateY(-4px); box-shadow: 0 18px 44px -22px rgba(7,41,31,.30); border-color: #BFE6D2; }
.kb-cat { font-size: .72rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; color: #059669; }
.kb-title { font-size: 1.1rem; font-weight: 800; letter-spacing: -.02em; line-height: 1.25; }
.kb-desc { font-size: .92rem; color: var(--text-soft); line-height: 1.55; flex-grow: 1; }
.kb-meta { display: flex; justify-content: space-between; align-items: center; margin-top: .5rem; }
.kb-read { font-weight: 700; color: #059669; font-size: .88rem; }
.kb-time { font-size: .8rem; color: var(--text-muted); }
@media (max-width: 900px) { .kb-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 600px) { .kb-grid { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════════════════════════
   PRICING (Webtify-stijl, 3 clean tiers) + KENNISBANK featured images
   ══════════════════════════════════════════════════════════ */
.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; align-items: stretch; max-width: 1120px; margin: 0 auto; }
.price-card { position: relative; display: flex; flex-direction: column; background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 2.1rem 1.85rem; box-shadow: 0 1px 3px rgba(7,41,31,.05); transition: transform .35s var(--ease), box-shadow .35s, border-color .35s; }
.price-card:hover { transform: translateY(-4px); box-shadow: 0 22px 50px -24px rgba(7,41,31,.30); border-color: #BFE6D2; }
.price-card--featured { border-color: #059669; box-shadow: 0 18px 50px -22px rgba(5,150,105,.45); }
.price-popular { position: absolute; top: -.85rem; left: 50%; transform: translateX(-50%); background: #059669; color: #fff; font-size: .72rem; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; padding: .3rem .9rem; border-radius: 999px; box-shadow: 0 4px 12px rgba(5,150,105,.4); }
.price-badge { font-size: 1.05rem; font-weight: 800; letter-spacing: -.02em; color: var(--text); background: none; padding: 0; }
.price-amount { display: flex; align-items: baseline; gap: .25rem; margin: .9rem 0 .3rem; }
.price-from { font-size: .85rem; color: var(--text-muted); font-weight: 600; margin-right: .1rem; }
.price-big { font-size: 2.6rem; font-weight: 800; letter-spacing: -.04em; color: var(--text); line-height: 1; }
.price-period { font-size: 1rem; color: var(--text-soft); font-weight: 600; }
.price-tagline { font-size: .92rem; color: var(--text-soft); line-height: 1.5; margin-bottom: 1.3rem; min-height: 2.7em; }
.price-features { list-style: none; display: flex; flex-direction: column; gap: .6rem; margin: 0 0 1.6rem; padding: 0; flex-grow: 1; }
.price-features li { position: relative; padding-left: 1.55rem; font-size: .92rem; color: var(--text-soft); line-height: 1.4; }
.price-features li::before { content: '✓'; position: absolute; left: 0; top: 0; color: #059669; font-weight: 800; }
.btn-full { width: 100%; justify-content: center; }
.pricing-foot { text-align: center; margin-top: 2.2rem; color: var(--text-soft); font-size: .95rem; }
.pricing-foot a { color: #059669; font-weight: 700; text-decoration: none; }
.pricing-foot a:hover { text-decoration: underline; }
.price-note { font-size: .8rem; color: var(--text-muted); font-weight: 500; }
@media (max-width: 900px) { .pricing-grid { grid-template-columns: 1fr; max-width: 460px; } }

/* Kennisbank: featured image + nette spacing */
.kb-section { background: var(--white); padding-block: var(--section-y); }
.kb-card { padding: 0; gap: 0; overflow: hidden; }
.kb-image { aspect-ratio: 16 / 9; overflow: hidden; background: var(--surface); }
.kb-image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .6s var(--ease); }
.kb-card:hover .kb-image img { transform: scale(1.05); }
.kb-body { display: flex; flex-direction: column; gap: .55rem; padding: 1.4rem 1.4rem 1.5rem; }

/* ══════════════════════════════════════════════════════════
   SPEELSE HAMBURGER + CLOSE (eigen stijl)
   ══════════════════════════════════════════════════════════ */
.hamburger { gap: 5px; }
.hamburger span {
  height: 2.5px;
  width: 24px;
  border-radius: 99px;
  background: var(--text);
  transition: width .3s var(--ease), transform .35s var(--ease), opacity .25s, background .3s;
}
.hamburger span:nth-child(1) { width: 24px; }
.hamburger span:nth-child(2) { width: 14px; background: var(--amber); }   /* korte groene middenlijn */
.hamburger span:nth-child(3) { width: 19px; }
/* speelse hover: lijnen lijnen netjes uit */
.mobile-menu__trigger:hover .hamburger span { width: 24px; }
.mobile-menu__trigger:hover .hamburger span:nth-child(2) { background: var(--amber-dark); }
/* expanded -> nette X (alle lijnen gelijk) */
.mobile-menu__trigger[aria-expanded="true"] .hamburger span { width: 24px; }
.mobile-menu__trigger[aria-expanded="true"] .hamburger span:nth-child(2) { opacity: 0; }

/* Playful close: rond knopje, X draait + kleurt groen op hover */
.mobile-menu__close {
  width: 46px; height: 46px;
  border-radius: 50%;
  border: 1.5px solid var(--border);
  background: var(--white);
  color: var(--text);
  transition: transform .4s var(--ease), border-color .3s, color .3s, background .3s;
}
.mobile-menu__close svg { transition: transform .4s var(--ease); }
.mobile-menu__close:hover {
  background: var(--amber-light);
  border-color: var(--amber);
  color: var(--amber-dark);
  transform: rotate(90deg);
}
.mobile-menu__close:hover svg { transform: scale(1.1); }

/* ══════════════════════════════════════════════════════════
   PRICING — SIMPELE CARDS met speelse pijl (override)
   ══════════════════════════════════════════════════════════ */
.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; max-width: 1040px; margin: 0 auto; align-items: stretch; }
.price-card {
  position: relative; display: flex; flex-direction: column;
  padding: 1.85rem 1.8rem 1.7rem;
  background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-xl);
  box-shadow: 0 1px 3px rgba(7,41,31,.05);
  text-decoration: none; color: var(--text); min-height: 210px;
  transition: transform .35s var(--ease), box-shadow .35s, border-color .35s; overflow: hidden;
}
.price-card:hover { transform: translateY(-5px); box-shadow: 0 24px 52px -24px rgba(7,41,31,.35); border-color: #BFE6D2; }
.price-card--featured { border-color: #059669; box-shadow: 0 18px 50px -22px rgba(5,150,105,.4); }
.price-popular { position: absolute; top: 1.5rem; right: 1.6rem; left: auto; transform: none; background: var(--amber-light); color: #047857; font-size: .7rem; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; padding: .25rem .65rem; border-radius: 999px; box-shadow: none; }
.price-name { font-size: 1.15rem; font-weight: 800; letter-spacing: -.02em; color: var(--text); }
.price-amount { display: flex; align-items: baseline; gap: .25rem; margin: .7rem 0 .5rem; }
.price-from { font-size: .82rem; color: var(--text-muted); font-weight: 600; }
.price-big { font-size: 2.3rem; font-weight: 800; letter-spacing: -.04em; color: var(--text); line-height: 1; }
.price-period { font-size: .95rem; color: var(--text-soft); font-weight: 600; }
.price-tagline { font-size: .92rem; color: var(--text-soft); line-height: 1.5; flex-grow: 1; padding-right: 3.2rem; margin-bottom: 1.2rem; }
.price-arrow {
  position: absolute; right: 1.6rem; bottom: 1.5rem;
  width: 44px; height: 44px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--amber-light); color: #047857;
  transition: background .35s var(--ease), color .35s, transform .35s;
}
.price-arrow svg { width: 20px; height: 20px; transition: transform .4s var(--ease); }
.price-card:hover .price-arrow { background: #059669; color: #fff; transform: scale(1.08); }
.price-card:hover .price-arrow svg { transform: translateX(3px); }
@media (max-width: 900px) { .pricing-grid { grid-template-columns: 1fr; max-width: 460px; } }

/* ══════════════════════════════════════════════════════════
   CASE-PAGINA'S (klantverhalen) + showcase cta-arrow
   ══════════════════════════════════════════════════════════ */
.site-header--solid { background: rgba(255,255,255,.97); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid var(--border); }
.site-header--solid .nav-logo, .site-header--solid .nav-links a { color: var(--text); }
.case-hero { position: relative; min-height: 60vh; display: flex; align-items: flex-end; overflow: hidden; }
.case-hero-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.case-hero-scrim { position: absolute; inset: 0; z-index: 1; background: linear-gradient(to top, rgba(8,20,15,.92) 0%, rgba(8,20,15,.55) 42%, rgba(8,20,15,.25) 100%); }
.case-hero-inner { position: relative; z-index: 2; padding-block: clamp(2.5rem,6vw,5rem); color: #fff; }
.case-back { color: rgba(255,255,255,.85); font-weight: 600; font-size: .9rem; text-decoration: none; display: inline-block; margin-bottom: 1.25rem; transition: color .25s; }
.case-back:hover { color: #fff; }
.case-hero-eyebrow { display: block; font-size: .8rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: #34d399; margin-bottom: .6rem; }
.case-hero-title { font-size: clamp(2.2rem,5vw,3.6rem); font-weight: 800; letter-spacing: -.03em; color: #fff; margin-bottom: .6rem; }
.case-hero-tag { font-size: 1.15rem; color: rgba(255,255,255,.9); max-width: 540px; margin-bottom: 1.1rem; }
.case-services { display: flex; flex-wrap: wrap; gap: .4rem; }
.case-services--hero .case-service { color: #fff; background: rgba(255,255,255,.16); border: 1px solid rgba(255,255,255,.28); backdrop-filter: blur(6px); padding: .28rem .7rem; border-radius: 999px; font-size: .72rem; font-weight: 700; }
.case-story { padding-block: var(--section-y); }
.case-story > .container { text-align: center; }
.case-intro { font-size: clamp(1.2rem,2.5vw,1.55rem); font-weight: 600; letter-spacing: -.01em; color: var(--text); line-height: 1.45; max-width: 760px; margin: 0 auto 3rem; }
.case-blocks { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; margin-bottom: 2.5rem; text-align: left; }
.case-block { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.8rem; box-shadow: 0 1px 3px rgba(7,41,31,.05); }
.case-block-num { font-size: .85rem; font-weight: 800; color: #059669; }
.case-block h3 { font-size: 1.15rem; font-weight: 800; margin: .5rem 0 .6rem; letter-spacing: -.02em; }
.case-block p { color: var(--text-soft); line-height: 1.6; font-size: .95rem; }
.case-next { background: var(--off-white); padding-block: var(--section-y); text-align: center; }
.case-next h2 { font-size: clamp(1.6rem,3.5vw,2.4rem); font-weight: 800; letter-spacing: -.02em; margin-bottom: .75rem; }
.case-next p { color: var(--text-soft); margin-bottom: 1.5rem; }
.btn-lg { padding: 1.05rem 2.2rem; font-size: 1.05rem; }
@media (max-width:800px){ .case-blocks{ grid-template-columns:1fr; } }
/* showcase card "Bekijk case" arrow */
.case-cta-row { display: inline-flex; align-items: center; gap: .4rem; margin-top: .7rem; font-size: .85rem; font-weight: 700; color: #fff; }
.case-cta-arrow { display: inline-block; transition: transform .35s var(--ease); }
.case-card:hover .case-cta-arrow { transform: translateX(5px); }

/* ══════════════════════════════════════════════════════════
   SLIDE-IN PIJL (Webtify/Divi-stijl) — verborgen in rust, schuift in bij hover
   ══════════════════════════════════════════════════════════ */
.arrow-cta { display: inline-flex; align-items: center; font-weight: 700; color: #059669; white-space: nowrap; font-size: .9rem; }
.ac-arrow {
  display: inline-block; overflow: hidden;
  max-width: 0; opacity: 0; margin-left: 0;
  transform: translateX(-5px);
  transition: max-width .38s var(--ease), opacity .3s, transform .38s, margin-left .38s;
}
.arrow-cta:hover .ac-arrow,
.price-card:hover .ac-arrow,
.service-card:hover .ac-arrow,
.case-card:hover .ac-arrow,
.kb-card:hover .ac-arrow {
  max-width: 1.4em; opacity: 1; transform: translateX(0); margin-left: .4em;
}
/* pricing: link onderaan, geen los cirkeltje meer */
.price-link { margin-top: auto; }
/* showcase-cards zijn donker: pijl-CTA wit */
.case-card .arrow-cta { color: rgba(255,255,255,.95); }

/* ══════════════════════════════════════════════════════════
   CASE-PAGINA'S v2 — split-intro + echte screenshot + highlights
   ══════════════════════════════════════════════════════════ */
.case-split { padding-block: var(--section-y); }
.case-split-grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: clamp(2rem,5vw,4rem); align-items: center; }
.case-split-text .case-intro { font-size: clamp(1.15rem,2vw,1.4rem); font-weight: 600; color: var(--text); line-height: 1.5; margin: .9rem 0 1.5rem; max-width: none; text-align: left; }
.case-highlights { list-style: none; padding: 0; margin: 0 0 2rem; display: flex; flex-direction: column; gap: .8rem; }
.case-highlights li { display: flex; align-items: center; gap: .7rem; font-weight: 600; color: var(--text); }
.case-hl-icon { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; border-radius: 50%; background: var(--amber-light); color: #047857; flex-shrink: 0; }
.case-hl-icon svg { width: 15px; height: 15px; }
.case-browser { border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--border); box-shadow: 0 30px 70px -28px rgba(7,41,31,.4); background: var(--white); }
.case-browser-bar { display: flex; align-items: center; gap: .4rem; padding: .6rem .9rem; background: var(--surface); border-bottom: 1px solid var(--border); }
.case-browser-bar .bdot { width: 9px; height: 9px; border-radius: 50%; background: rgba(7,41,31,.18); }
.case-browser-bar .bdot:nth-child(1){background:#ff5f57}.case-browser-bar .bdot:nth-child(2){background:#febc2e}.case-browser-bar .bdot:nth-child(3){background:#28c840}
.case-browser-url { margin-left: .5rem; font-size: .75rem; color: var(--text-muted); background: var(--off-white); border-radius: 6px; padding: .2rem .7rem; }
.case-browser-screen { aspect-ratio: 16/11; overflow: hidden; background: #fff; }
.case-browser-screen img { width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; }
.case-story { background: var(--off-white); padding-block: var(--section-y); }
.case-story > .container { text-align: left; }
.case-story .section-header { margin-bottom: 2.5rem; }
@media (max-width:860px){ .case-split-grid{ grid-template-columns:1fr; } .case-split-visual{ order:-1; } }

/* ══════════════════════════════════════════════════════════
   DIENST-DETAILPAGINA'S + services-grid 4-koloms
   ══════════════════════════════════════════════════════════ */
.services-grid { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1000px) { .services-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px) { .services-grid { grid-template-columns: 1fr; } }

.dienst-hero { padding: clamp(2.5rem,5vw,4.5rem) 0 clamp(2rem,4vw,3.5rem); background: var(--off-white); }
.dienst-hero .case-back { color: var(--text-soft); margin-bottom: 1.25rem; display: inline-block; text-decoration: none; font-weight: 600; font-size: .9rem; }
.dienst-hero .case-back:hover { color: var(--text); }
.dienst-h1 { font-size: clamp(2.4rem,5.5vw,4rem); font-weight: 800; letter-spacing: -.03em; line-height: 1.07; margin: .5rem 0 1rem; max-width: 16ch; }
.dienst-sub { font-size: clamp(1.05rem,2vw,1.25rem); color: var(--text-soft); line-height: 1.6; max-width: 640px; margin-bottom: 1.75rem; }
.dienst-hero-cta { display: flex; flex-wrap: wrap; gap: .9rem; }

.benefits-section { padding-block: var(--section-y); }
.benefits-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; }
.benefit-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.85rem; box-shadow: 0 1px 3px rgba(7,41,31,.05); transition: transform .35s var(--ease), box-shadow .35s; }
.benefit-card:hover { transform: translateY(-4px); box-shadow: 0 18px 44px -22px rgba(7,41,31,.3); }
.benefit-card h3 { font-size: 1.15rem; font-weight: 800; letter-spacing: -.02em; margin-bottom: .5rem; }
.benefit-card p { color: var(--text-soft); line-height: 1.6; font-size: .95rem; }
.benefit-card--dark { background: linear-gradient(150deg,#07291F,#0E3D2C); border-color: transparent; }
.benefit-card--dark h3 { color: #fff; }
.benefit-card--dark p { color: rgba(255,255,255,.8); }
@media (max-width: 860px) { .benefits-grid { grid-template-columns: 1fr; } }

.aanpak-section { background: var(--off-white); padding-block: var(--section-y); }
.steps-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.25rem; }
.step-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.8rem 1.5rem; }
.step-num { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border-radius: 50%; background: var(--amber-light); color: #047857; font-weight: 800; font-size: 1.05rem; margin-bottom: 1rem; }
.step-card h3 { font-size: 1.1rem; font-weight: 800; letter-spacing: -.02em; margin-bottom: .5rem; }
.step-card p { color: var(--text-soft); line-height: 1.55; font-size: .92rem; }
@media (max-width: 900px) { .steps-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 520px) { .steps-grid { grid-template-columns: 1fr; } }

.dienst-showcase { padding-block: var(--section-y); }
.dsc-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; }
.dsc-card { position: relative; display: block; aspect-ratio: 4/3; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--border); box-shadow: 0 2px 10px rgba(7,41,31,.08); transition: transform .35s var(--ease), box-shadow .35s; }
.dsc-card:hover { transform: translateY(-4px); box-shadow: 0 22px 50px -24px rgba(7,41,31,.4); }
.dsc-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.dsc-card:hover img { transform: scale(1.06); }
.dsc-overlay { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: flex-end; gap: .3rem; padding: 1.2rem; background: linear-gradient(to top, rgba(8,20,15,.85), rgba(8,20,15,0) 65%); color: #fff; }
.dsc-overlay strong { font-size: 1.1rem; font-weight: 800; }
.dsc-overlay .arrow-cta { color: rgba(255,255,255,.95); font-size: .85rem; }
.dsc-card:hover .ac-arrow { max-width: 1.4em; opacity: 1; transform: translateX(0); margin-left: .4em; }
@media (max-width: 760px) { .dsc-grid { grid-template-columns: 1fr; } }

.dienst-price { padding-bottom: var(--section-y); }
.dienst-price-card { display: flex; align-items: center; justify-content: space-between; gap: 2rem; flex-wrap: wrap; background: linear-gradient(135deg, var(--amber-light), #F2FBF6); border: 1px solid #CDEBDC; border-radius: var(--radius-xl); padding: clamp(2rem,4vw,3rem); }
.dienst-price-text h2 { font-size: clamp(1.6rem,3vw,2.2rem); font-weight: 800; letter-spacing: -.02em; margin: .4rem 0 .6rem; }
.dienst-price-text p { color: var(--text-soft); max-width: 540px; }

/* ══════════════════════════════════════════════════════════
   MEGA-MENU (Ontdekken) + LANGUAGE SWITCHER + OVER-ONS
   ══════════════════════════════════════════════════════════ */
.nav-mega-item, .nav-lang { position: relative; display: flex; align-items: center; }
.nav-mega-trigger, .lang-btn { display: inline-flex; align-items: center; gap: .35rem; background: none; border: none; cursor: pointer; font: inherit; font-weight: 600; color: var(--text); padding: .25rem 0; }
.nav-caret { transition: transform .3s var(--ease); }
.nav-mega-item:hover .nav-caret, .nav-lang:hover .nav-caret { transform: rotate(180deg); }
.nav-mega-trigger:hover, .lang-btn:hover { color: #059669; }

.mega-menu { position: absolute; top: calc(100% + 14px); left: 50%; transform: translateX(-50%) translateY(8px); display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; min-width: 460px; background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: 0 24px 60px -24px rgba(7,41,31,.35); padding: 1.5rem 1.75rem; opacity: 0; visibility: hidden; transition: opacity .25s, transform .25s; z-index: 200; }
.nav-mega-item:hover .mega-menu, .nav-mega-item:focus-within .mega-menu { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.mega-menu::before { content:''; position:absolute; top:-14px; left:0; right:0; height:14px; }
.mega-heading { display: block; font-size: .72rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; color: #059669; margin-bottom: .9rem; }
.mega-col a { display: block; padding: .4rem 0; color: var(--text-soft); text-decoration: none; font-weight: 600; transition: color .2s, padding-left .2s; }
.mega-col a:hover { color: #059669; padding-left: 4px; }

.lang-menu { position: absolute; top: calc(100% + 14px); right: 0; transform: translateY(8px); background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: 0 18px 44px -22px rgba(7,41,31,.3); padding: .6rem; min-width: 170px; opacity: 0; visibility: hidden; transition: opacity .25s, transform .25s; z-index: 200; }
.lang-menu::before { content:''; position:absolute; top:-14px; left:0; right:0; height:14px; }
.nav-lang:hover .lang-menu, .nav-lang:focus-within .lang-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.lang-menu .lang-current { display: block; padding: .45rem .6rem; border-radius: 8px; font-weight: 700; color: #047857; background: var(--amber-light); }
.lang-menu .lang-soon { display: flex; justify-content: space-between; align-items: center; gap:.5rem; padding: .45rem .6rem; color: var(--text-muted); text-decoration: none; font-weight: 600; }
.lang-menu .lang-soon em { font-style: normal; font-size: .66rem; background: var(--surface); color: var(--text-muted); padding: .1rem .45rem; border-radius: 999px; }

@media (max-width: 880px) { .nav-mega-item, .nav-lang { display: none; } }
.mobile-menu__label { display:block; font-size:.72rem; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:#059669; margin: 1.1rem 0 .15rem; }
.mobile-menu__item--sub { font-size: 1.15rem; opacity: .85; }

.over-story { max-width: 760px; }
.over-story p { font-size: clamp(1.05rem,2vw,1.25rem); color: var(--text-soft); line-height: 1.7; margin-bottom: 1.25rem; }
.pillars-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.25rem; }
.pillar-card { display: flex; flex-direction: column; gap: .4rem; padding: 1.6rem 1.5rem; background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: 0 1px 3px rgba(7,41,31,.05); text-decoration: none; color: var(--text); transition: transform .35s var(--ease), box-shadow .35s, border-color .35s; }
.pillar-card:hover { transform: translateY(-4px); box-shadow: 0 18px 44px -22px rgba(7,41,31,.3); border-color: #BFE6D2; }
.pillar-card strong { font-size: 1.1rem; font-weight: 800; letter-spacing: -.02em; }
.pillar-card span:not(.arrow-cta) { color: var(--text-soft); font-size: .92rem; line-height: 1.5; flex-grow: 1; }
.pillar-card .arrow-cta { margin-top: .3rem; font-size:.85rem; }
.pillar-card:hover .ac-arrow { max-width: 1.4em; opacity: 1; transform: translateX(0); margin-left: .4em; }
@media (max-width: 900px) { .pillars-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 540px) { .pillars-grid { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════════════════════════
   FULL-WIDTH MEGA-MENU (Websites/Webshops/Marketing/Ontdekken)
   ══════════════════════════════════════════════════════════ */
.nav-mega-item { position: static; }
.mega-panel {
  position: absolute; top: 68px; left: 0; right: 0; width: 100%;
  background: var(--white);
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
  box-shadow: 0 26px 50px -20px rgba(7,41,31,.25);
  opacity: 0; visibility: hidden; transform: translateY(8px);
  transition: opacity .25s var(--ease), transform .25s var(--ease), visibility .25s;
  z-index: 150;
}
.nav-mega-item:hover .mega-panel, .nav-mega-item:focus-within .mega-panel { opacity: 1; visibility: visible; transform: translateY(0); }
.mega-panel-inner { max-width: var(--container); margin-inline: auto; padding: clamp(2rem,3vw,2.75rem) clamp(1.25rem,5vw,2.5rem); display: grid; grid-template-columns: 1fr auto; gap: clamp(2rem,5vw,5rem); align-items: stretch; }
.mega-cols { display: grid; grid-template-columns: repeat(2, minmax(190px,240px)); gap: clamp(2rem,4vw,4rem); }
.mega-heading { display: block; font-size: .72rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; color: #059669; margin-bottom: 1rem; }
.mega-col a { display: block; padding: .45rem 0; color: var(--text-soft); text-decoration: none; font-weight: 600; transition: color .2s, padding-left .2s; }
.mega-col a:hover { color: #059669; padding-left: 5px; }
.mega-feature { display: flex; flex-direction: column; justify-content: center; gap: .4rem; min-width: 280px; max-width: 340px; padding: 1.75rem; border-radius: var(--radius-lg); background: linear-gradient(150deg,#07291F,#0E3D2C); color: #fff; text-decoration: none; transition: transform .35s var(--ease); }
.mega-feature:hover { transform: translateY(-3px); }
.mega-feature-eyebrow { font-size: .72rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; color: #34d399; }
.mega-feature-price { font-size: 1.5rem; font-weight: 800; letter-spacing: -.02em; color: #fff; }
.mega-feature-desc { color: rgba(255,255,255,.8); font-size: .92rem; line-height: 1.5; margin-bottom: .5rem; }
.mega-feature .arrow-cta { color: #fff; font-size: .9rem; }
.mega-feature:hover .ac-arrow { max-width: 1.4em; opacity: 1; transform: translateX(0); margin-left: .4em; }
@media (max-width: 980px) { .nav-mega-item, .nav-lang { display: none; } }

/* ══════════════════════════════════════════════════════════
   WERK-SLIDER (Raak geïnspireerd) — autoslide + fade-randen + pijlen
   ══════════════════════════════════════════════════════════ */
.work-header { display: flex; justify-content: space-between; align-items: flex-end; gap: 1.5rem; flex-wrap: wrap; max-width: none; }
.work-header-text { text-align: left; max-width: 640px; }
.work-nav { display: flex; gap: .6rem; flex-shrink: 0; }
.work-arrow { width: 50px; height: 50px; border-radius: 50%; border: 1px solid var(--border); background: var(--white); color: var(--text); display: inline-flex; align-items: center; justify-content: center; cursor: pointer; box-shadow: 0 1px 3px rgba(7,41,31,.06); transition: background .25s var(--ease), color .25s, border-color .25s, transform .25s; }
.work-arrow:hover { background: #059669; color: #fff; border-color: #059669; transform: scale(1.07); }
.work-arrow:active { transform: scale(.96); }
.work-arrow svg { width: 22px; height: 22px; }
/* full-bleed slider: loopt door tot de schermranden */
.work-slider { position: relative; width: 100vw; margin-left: calc(50% - 50vw); margin-top: clamp(2rem,4vw,3rem); overflow: hidden; -webkit-mask-image: linear-gradient(to right, transparent 0, #000 3%, #000 97%, transparent 100%); mask-image: linear-gradient(to right, transparent 0, #000 3%, #000 97%, transparent 100%); }
.work-track { display: flex; gap: 1.5rem; padding: .5rem clamp(1rem,4vw,2.5rem); will-change: transform; }
.work-track .case-card { flex: 0 0 clamp(220px, 20vw, 300px); }
@media (max-width: 900px) { .work-track .case-card { flex: 0 0 46vw; } }
@media (max-width: 600px) { .work-track .case-card { flex: 0 0 78vw; } }

/* ══════════════════════════════════════════════════════════
   MEGA-MENU v2: card-vormige items + branche-grid
   ══════════════════════════════════════════════════════════ */
.mega-panel-inner { display: flex !important; grid-template-columns: none !important; gap: clamp(2rem,4vw,3.5rem); align-items: stretch; }
.mega-section { min-width: 0; }
.mega-section--branches { flex: 1; min-width: 280px; }
.mega-cards { display: flex; flex-direction: column; gap: .35rem; }
.mega-cards--2col { display: grid; grid-template-columns: 1fr 1fr; gap: .35rem .6rem; }
.mega-card { display: flex; align-items: center; gap: .85rem; padding: .7rem .8rem; border-radius: var(--radius); text-decoration: none; transition: background .2s, transform .2s; }
.mega-card:hover { background: var(--off-white); transform: translateX(2px); }
.mega-card-icon { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: 11px; background: var(--amber-light); color: #047857; flex-shrink: 0; }
.mega-card-icon svg { width: 20px; height: 20px; }
.mega-card-text { display: flex; flex-direction: column; line-height: 1.25; }
.mega-card-text strong { font-size: .95rem; font-weight: 700; color: var(--text); }
.mega-card-text span { font-size: .8rem; color: var(--text-muted); }
.mega-branch-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 .6rem; }
.mega-branch-grid a { display: block; padding: .45rem .25rem; color: var(--text-soft); text-decoration: none; font-weight: 600; font-size: .92rem; border-radius: 6px; transition: color .2s, padding-left .2s; }
.mega-branch-grid a:hover { color: #059669; padding-left: 5px; }
.mega-feature { flex: 0 0 290px; }

/* ══════════════════════════════════════════════════════════
   AMBER ACCENT (#FBB024) + INFINITE LOGO-MARQUEE
   ══════════════════════════════════════════════════════════ */
/* warme accent op 'populair'/featured-badges + stat-tekens */
.price-popular, .service-badge { background: var(--accent); color: #3D2B00; }
.stat-plus { color: var(--accent); }
.google-badge { box-shadow: inset 0 0 0 1px var(--accent-soft); }
.dienst-price-card { background: linear-gradient(135deg, var(--accent-soft), #F2FBF6); border-color: #F4DCA0; }
/* subtiele amber-onderstreping mogelijk via .accent-underline (optioneel) */

/* Logo-marquee: oneindig scrollend, grayscale, fade-randen */

/* ══════════════════════════════════════════════════════════
   NIEUW LOGO (oplopende W-icoon + wordmark-W)
   ══════════════════════════════════════════════════════════ */
.logo-mark { width: 36px; height: 36px; background: none; border-radius: 0; padding: 0; font-size: 0; }
.logo-mark svg { width: 100%; height: 100%; display: block; }
.logo-text { display: inline-flex; align-items: flex-end; line-height: 1; }
.logo-wm-w { height: 1.04em; width: auto; flex-shrink: 0; }

/* Logo zonder icoon-tegeltje: grotere wordmark, groene W */
.nav-logo { gap: 0; }
.logo-text { font-size: 1.42rem; font-weight: 800; letter-spacing: -.03em; }
.logo-wm-w { height: 1.0em; }
.logo-wm-w path { stroke: #059669; }
.site-footer .logo-wm-w path, .site-footer-outer .logo-wm-w path { stroke: #34d399; }
.site-header--solid .logo-text, .site-header .logo-text { color: var(--text); }

.site-footer .logo-text, .site-footer-outer .logo-text { color: #fff; }


/* ══════════════════════════════════════════════════════════
   LOGO-STRIP v2 (Webtify): vaste tekst links + slider rechts, gelijke logo's
   ══════════════════════════════════════════════════════════ */
.trust-strip { background: var(--white); padding-block: clamp(1.7rem,3vw,2.5rem); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.trust-row { display: flex; align-items: center; gap: clamp(1.5rem,4vw,3rem); }
.trust-label { flex: 0 0 auto; max-width: 30%; margin: 0; text-align: left; text-transform: none; white-space: normal; font-size: clamp(1.05rem,1.5vw,1.3rem); font-weight: 800; line-height: 1.18; letter-spacing: -.02em; color: var(--text); }
.trust-label .g { color: #059669; }
.logo-slider { flex: 1 1 auto; min-width: 0; overflow: hidden; -webkit-mask-image: linear-gradient(to right, transparent 0, #fff 10%, #fff 90%, transparent 100%); mask-image: linear-gradient(to right, transparent 0, #fff 10%, #fff 90%, transparent 100%); }
.logo-track { display: flex; align-items: center; gap: clamp(3rem,7vw,5.5rem); width: max-content; animation: logoScroll 40s linear infinite; }
.logo-slider:hover .logo-track { animation-play-state: paused; }
.logo-slot { flex: 0 0 auto; display: flex; align-items: center; justify-content: center; }
.marquee-logo { height: 40px; width: auto; max-width: 150px; object-fit: contain; opacity: .8; transition: opacity .3s; flex-shrink: 0; }
.logo-slot:hover .marquee-logo { opacity: 1; }
@keyframes logoScroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce){ .logo-track { animation: none; } }
@media (max-width: 760px){ .trust-row { flex-direction: column; align-items: flex-start; gap: 1.1rem; } .trust-label { max-width: none; } .logo-slider { width: 100%; } }

/* ══════════════════════════════════════════════════════════
   KENNISBANK: hub + artikelpagina's
   ══════════════════════════════════════════════════════════ */
.kb-image { aspect-ratio: 16/9; overflow: hidden; border-radius: var(--radius); margin: -0.2rem -0.2rem 0.4rem; }
.kb-image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s var(--ease); }
.kb-card:hover .kb-image img { transform: scale(1.04); }
.kb-time { font-size: .78rem; color: var(--text-muted); font-weight: 600; }

/* Breadcrumb */
.breadcrumb { font-size: .82rem; color: var(--text-muted); display: flex; flex-wrap: wrap; gap: .4rem; align-items: center; }
.breadcrumb a { color: var(--text-muted); text-decoration: none; }
.breadcrumb a:hover { color: #059669; }
.breadcrumb span[aria-current] { color: var(--text-soft); font-weight: 600; }
.breadcrumb .sep { opacity: .5; }

/* Hub hero */
.kb-hub-hero { background: var(--off-white); border-bottom: 1px solid var(--border); padding-block: clamp(2.5rem,5vw,4rem); }
.kb-hub-hero .breadcrumb { margin-bottom: 1.2rem; }
.kb-hub-h1 { font-size: clamp(2rem,4.5vw,3.2rem); font-weight: 800; letter-spacing: -.03em; line-height: 1.08; margin: 0 0 1rem; }
.kb-hub-intro { font-size: clamp(1.02rem,1.4vw,1.18rem); color: var(--text-soft); line-height: 1.6; max-width: 60ch; }
.kb-pillars { display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; margin-top: 2rem; }
.kb-pillar { display: block; padding: 1.3rem 1.4rem; border: 1px solid var(--border); border-radius: var(--radius-lg); background: var(--white); text-decoration: none; color: var(--text); transition: transform .3s var(--ease), box-shadow .3s, border-color .3s; }
.kb-pillar:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: #BFE6D2; }
.kb-pillar strong { display: block; font-size: 1.05rem; font-weight: 800; letter-spacing: -.02em; margin-bottom: .2rem; }
.kb-pillar > span { display: block; font-size: .9rem; color: var(--text-soft); line-height: 1.5; }
.kb-pillar .arrow-cta { display: inline-flex; }
.kb-pillar .arrow-cta { margin-top: .6rem; font-size: .85rem; }
.kb-list-section { padding-block: var(--section-y); }
@media (max-width: 820px){ .kb-pillars { grid-template-columns: 1fr; } }

/* Artikelpagina */
.article-page { background: var(--white); }
.article-hero { background: var(--off-white); border-bottom: 1px solid var(--border); padding-block: clamp(2.2rem,4vw,3.4rem); }
.article-hero .container { max-width: 820px; }
.article-hero .breadcrumb { margin-bottom: 1.3rem; }
.article-cat { font-size: .74rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: #059669; }
.article-h1 { font-size: clamp(1.9rem,4vw,2.9rem); font-weight: 800; letter-spacing: -.03em; line-height: 1.1; margin: .6rem 0 .8rem; }
.article-dek { font-size: clamp(1.05rem,1.5vw,1.25rem); color: var(--text-soft); line-height: 1.55; max-width: 60ch; }
.article-meta { display: flex; flex-wrap: wrap; gap: 1.2rem; align-items: center; margin-top: 1.4rem; font-size: .85rem; color: var(--text-muted); }
.article-meta .am-author { display: flex; align-items: center; gap: .5rem; font-weight: 600; color: var(--text-soft); }
.article-meta .am-dot { width: 26px; height: 26px; border-radius: 50%; background: linear-gradient(135deg,#059669,#34d399); display: inline-flex; align-items: center; justify-content: center; color: #fff; font-weight: 800; font-size: .8rem; }

.article-figure { max-width: 960px; margin: clamp(1.6rem,3vw,2.4rem) auto 0; padding: 0 clamp(1rem,4vw,1.5rem); }
.article-figure img { width: 100%; aspect-ratio: 16/9; object-fit: cover; border-radius: var(--radius-lg); display: block; }

.article-wrap { max-width: 760px; margin: 0 auto; padding: clamp(2.2rem,4vw,3.4rem) clamp(1rem,4vw,1.5rem) 0; }

/* TOC */
.article-toc { background: var(--off-white); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.3rem 1.5rem; margin-bottom: 2.4rem; }
.article-toc strong { display: block; font-size: .8rem; text-transform: uppercase; letter-spacing: .06em; color: var(--text-muted); margin-bottom: .7rem; }
.article-toc ol { margin: 0; padding-left: 1.1rem; display: grid; gap: .4rem; }
.article-toc a { color: var(--text-soft); text-decoration: none; font-size: .95rem; }
.article-toc a:hover { color: #059669; }

/* Prose */
.article-body { font-size: 1.06rem; line-height: 1.75; color: var(--text-soft); }
.article-body > p { margin: 0 0 1.3rem; }
.article-body h2 { font-size: clamp(1.4rem,2.4vw,1.8rem); font-weight: 800; letter-spacing: -.02em; line-height: 1.2; color: var(--text); margin: 2.6rem 0 1rem; scroll-margin-top: 90px; }
.article-body h3 { font-size: 1.18rem; font-weight: 700; color: var(--text); margin: 1.8rem 0 .7rem; }
.article-body strong { color: var(--text); font-weight: 700; }
.article-body a { color: #047857; font-weight: 600; text-decoration: underline; text-underline-offset: 2px; text-decoration-thickness: 1px; }
.article-body a:hover { color: #059669; }
.article-body ul, .article-body ol { margin: 0 0 1.3rem; padding-left: 1.3rem; display: grid; gap: .5rem; }
.article-body li { padding-left: .2rem; }
.article-body li::marker { color: #34d399; }
.article-body blockquote { margin: 1.8rem 0; padding: 1.1rem 1.5rem; border-left: 3px solid #059669; background: var(--off-white); border-radius: 0 var(--radius) var(--radius) 0; font-size: 1.12rem; font-style: italic; color: var(--text); }
.article-callout { margin: 1.8rem 0; padding: 1.1rem 1.4rem; background: var(--accent-soft); border: 1px solid #F4DCA0; border-radius: var(--radius-lg); font-size: .98rem; color: #5b4300; }
.article-callout strong { color: #3D2B00; }

/* Takeaways */
.article-takeaways { margin: 2.6rem 0; padding: 1.6rem 1.8rem; background: var(--navy); color: #fff; border-radius: var(--radius-lg); }
.article-takeaways h2 { color: #fff; font-size: 1.2rem; margin: 0 0 1rem; }
.article-takeaways ul { list-style: none; margin: 0; padding: 0; display: grid; gap: .8rem; }
.article-takeaways li { position: relative; padding-left: 1.8rem; line-height: 1.5; color: #D1FAE5; }
.article-takeaways li::before { content: "✓"; position: absolute; left: 0; top: 0; color: #34d399; font-weight: 800; }

/* FAQ */
.article-faq { max-width: 760px; margin: clamp(2.4rem,4vw,3.4rem) auto 0; padding: 0 clamp(1rem,4vw,1.5rem); }
.article-faq h2 { font-size: clamp(1.5rem,2.6vw,2rem); font-weight: 800; letter-spacing: -.02em; margin: 0 0 1.3rem; }
.faq-item { border: 1px solid var(--border); border-radius: var(--radius-lg); margin-bottom: .8rem; overflow: hidden; background: var(--white); }
.faq-item summary { cursor: pointer; padding: 1.1rem 1.4rem; font-weight: 700; color: var(--text); list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 1rem; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; font-size: 1.4rem; color: #059669; font-weight: 400; flex-shrink: 0; transition: transform .3s; }
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item .faq-a { padding: 0 1.4rem 1.2rem; color: var(--text-soft); line-height: 1.65; }

/* Related */
.article-related { padding: clamp(3rem,6vw,5rem) 0 0; }
.article-related .section-header { margin-bottom: 1.6rem; }

/* Pillar CTA band */
.article-cta-band { margin-top: clamp(3rem,6vw,5rem); }
.article-cta-inner { background: linear-gradient(135deg, var(--navy), var(--navy-mid)); border-radius: var(--radius-xl); padding: clamp(2rem,4vw,3rem); text-align: center; color: #fff; }
.article-cta-inner h2 { font-size: clamp(1.5rem,3vw,2.1rem); font-weight: 800; letter-spacing: -.02em; margin: 0 0 .7rem; color: #fff; }
.article-cta-inner p { color: #B9D9CC; max-width: 48ch; margin: 0 auto 1.6rem; line-height: 1.6; }

.kb-allcta { text-align: center; margin-top: 2rem; }

/* E-E-A-T auteursblok onder FAQ */
.author-box { margin-top: 2.4rem; padding: 1.6rem 1.8rem; background: var(--off-white); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.author-box-title { font-size: .8rem; text-transform: uppercase; letter-spacing: .06em; color: var(--text-muted); margin: 0 0 1.1rem; }
.author-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.4rem; }
.author-card { display: flex; gap: .9rem; align-items: flex-start; }
.author-avatar { flex-shrink: 0; width: 44px; height: 44px; border-radius: 50%; background: linear-gradient(135deg,#059669,#34d399); color: #fff; font-weight: 800; font-size: .9rem; display: inline-flex; align-items: center; justify-content: center; }
.author-info strong { display: block; font-size: 1rem; color: var(--text); }
.author-info .author-role { display: block; font-size: .82rem; color: #059669; font-weight: 600; margin-bottom: .35rem; }
.author-info p { margin: 0; font-size: .9rem; color: var(--text-soft); line-height: 1.55; }
@media (max-width: 640px){ .author-grid { grid-template-columns: 1fr; } }
