/* ─────────── ANIMATIONS ─────────── */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes scaleIn {
  from { opacity: 0; transform: scale(0.96); }
  to   { opacity: 1; transform: scale(1); }
}

/* Hero entree (laadt direct bij page load) */
.hero-bg               { animation: fadeIn 1.6s ease-out both; }
.hero .eyebrow         { animation: fadeUp 0.9s ease-out 0.25s both; }
.hero h1               { animation: fadeUp 0.9s ease-out 0.4s both; }
.hero-content .lead    { animation: fadeUp 0.9s ease-out 0.55s both; }
.hero-content .actions { animation: fadeUp 0.9s ease-out 0.7s both; }

/* Subhero entree */
.subhero .crumbs       { animation: fadeIn 0.6s ease-out 0.1s both; }
.subhero .eyebrow      { animation: fadeUp 0.8s ease-out 0.2s both; }
.subhero h1            { animation: fadeUp 0.8s ease-out 0.3s both; }
.subhero p             { animation: fadeUp 0.8s ease-out 0.45s both; }
.subhero .actions      { animation: fadeUp 0.8s ease-out 0.6s both; }
.subhero-photo         { animation: scaleIn 1.2s cubic-bezier(.2,.7,.2,1) 0.5s both; }

/* Reveal-on-scroll (klassen worden door JS toegevoegd) */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.8s cubic-bezier(.2,.7,.2,1), transform 0.8s cubic-bezier(.2,.7,.2,1);
  will-change: opacity, transform;
}
.reveal.in-view {
  opacity: 1;
  transform: translateY(0);
}
/* Stagger voor grid-items binnen een sectie */
.in-view .stagger > *:nth-child(1) { transition-delay: 0.05s; }
.in-view .stagger > *:nth-child(2) { transition-delay: 0.15s; }
.in-view .stagger > *:nth-child(3) { transition-delay: 0.25s; }
.in-view .stagger > *:nth-child(4) { transition-delay: 0.35s; }
.in-view .stagger > *:nth-child(5) { transition-delay: 0.45s; }
.in-view .stagger > *:nth-child(6) { transition-delay: 0.55s; }

/* Foto-zoom op hover */
.path-photo, .post-photo, .product .cover, .subhero-photo, .about-photo {
  overflow: hidden;
  position: relative;
}
.path-photo, .post-photo, .product .cover {
  transition: transform 0.6s cubic-bezier(.2,.7,.2,1);
}
.path:hover .path-photo,
.post:hover .post-photo,
.product:hover .cover {
  transform: scale(1.03);
}

/* Subtiele inset-glow op insta-grid hover */
.insta-grid > * { transition: transform 0.4s ease, opacity 0.3s ease; cursor: pointer; }
.insta-grid > *:hover { transform: scale(1.04); opacity: 0.92; }

/* Smooth focus voor accessibility */
a, button { transition: opacity 0.2s ease; }
a:focus-visible, button:focus-visible {
  outline: 2px solid var(--terracotta);
  outline-offset: 3px;
  border-radius: 2px;
}

/* Respect voor users die animaties uit hebben staan */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ─────────── DESIGN TOKENS ─────────── */
:root {
  --cream: #fbf7ef;
  --cream-light: #fefcf7;
  --cream-dark: #f0e8d6;
  --ink: #1f2a25;
  --ink-soft: #5a6760;
  --forest: #2d4a3e;
  --forest-dark: #1f352c;
  --sage: #a8b5a0;
  --terracotta: #c97b5a;
  --terracotta-dark: #b3654a;
  --sand: #e8d9c0;
  --line: #d8cbb5;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Public Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  color: var(--ink);
  background: var(--cream);
  line-height: 1.65;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4 {
  font-family: 'Oswald', 'Fraunces', Georgia, serif;
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.015em;
}
/* em binnen titels: kleur-accent maar geen cursief */
h1 em, h2 em, h3 em, h4 em, h5 em, h6 em {
  font-style: normal;
}
a { color: var(--forest); text-decoration: none; }
img { max-width: 100%; display: block; }

.container {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 28px;
}
.container-wide {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 28px;
}
.container-narrow {
  max-width: 820px;
  margin: 0 auto;
  padding: 0 28px;
}

/* ─────────── TOP BANNER ─────────── */
.topbar {
  background: var(--forest);
  color: #ffffff;
  padding: 12px 20px;
  font-size: 14px;
  font-family: 'Public Sans', sans-serif;
  letter-spacing: 0.01em;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px;
  line-height: 1.4;
}
.topbar .icon {
  color: #9b9a84;
  font-size: 14px;
  line-height: 1;
}
.topbar em {
  font-family: 'Public Sans', sans-serif;
  font-style: italic;
  color: #ffffff;
  font-weight: 500;
  line-height: 1.4;
}
.topbar a {
  color: #ffffff;
  font-weight: 600;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
  text-decoration-color: rgba(255,255,255,0.4);
  transition: color .2s, text-decoration-color .2s;
  line-height: 1.4;
}
.topbar a:hover {
  color: #9b9a84;
  text-decoration-color: #9b9a84;
}
.topbar a .arrow {
  display: inline-block;
  margin-left: 6px;
  transition: transform .2s;
}
.topbar a:hover .arrow { transform: translateX(3px); }

/* ─────────── NAV ─────────── */
nav.top {
  position: sticky; top: 0; z-index: 50;
  background: rgba(251,247,239,0.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
  transition: background 0.35s ease, border-color 0.35s ease, backdrop-filter 0.35s ease;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 30px 32px;
  gap: 24px;
}
nav.top > .logo { justify-self: start; }
nav.top > ul { justify-self: center; }
nav.top > .nav-cta { justify-self: end; }
nav.top .nav-cta {
  font-family: 'Public Sans', sans-serif;
  font-weight: 600;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--forest);
  transition: color 0.2s;
}
nav.top .nav-cta:hover { color: #9b9a84; }

/* Hamburger-knop (zichtbaar op mobiel) */
.nav-hamburger {
  display: none;
  width: 36px;
  height: 36px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  justify-self: end;
}
.nav-hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--forest);
  border-radius: 1px;
  transition: all 0.3s ease;
}
.nav-hamburger span { transform-origin: center; }
.nav-hamburger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-hamburger.is-open span:nth-child(2) { opacity: 0; transform: scale(0); }
.nav-hamburger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobiel volledig-scherm menu */
.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--cream);
  z-index: 200;
  padding: 120px 28px 40px;
  display: flex;
  flex-direction: column;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-12px);
  transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s;
  overflow-y: auto;
}
/* Verberg de aankondigingsbalk zodra het mobile-menu open is — anders pusht hij
   de sticky nav omlaag en valt het eerste menu-item daarachter weg */
body:has(.mobile-menu.is-open) .site-announcement {
  display: none;
}
.mobile-menu.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.mobile-menu ul {
  list-style: none;
  margin: 0 0 24px;
  padding: 0;
}
.mobile-menu ul li { margin: 0; }
.mobile-menu ul a {
  display: block;
  padding: 18px 0;
  font-family: 'Public Sans', sans-serif;
  font-size: 15px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--forest);
  text-decoration: none;
  border-bottom: 1px solid var(--line);
  transition: color 0.2s ease;
}
.mobile-menu ul a:hover,
.mobile-menu ul a:focus { color: #9b9a84; }

/* Collapsible-groep in mobiel menu (bv. Over Ferry) */
.mobile-menu .has-submenu .submenu-toggle {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: space-between;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 18px 0;
  border-bottom: 1px solid var(--line);
  font-family: 'Public Sans', sans-serif;
  font-size: 15px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--forest);
  text-align: left;
}
.mobile-menu .has-submenu .submenu-toggle .caret {
  transition: transform 0.3s ease;
  margin-left: 12px;
}
.mobile-menu .has-submenu.is-expanded .submenu-toggle .caret {
  transform: rotate(180deg);
}
.mobile-menu .mobile-submenu {
  list-style: none;
  margin: 0 !important;
  padding: 0 !important;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
}
.mobile-menu .has-submenu.is-expanded .mobile-submenu {
  max-height: 400px;
}
.mobile-menu .mobile-submenu a {
  padding: 14px 0 14px 22px !important;
  font-size: 13px !important;
  letter-spacing: 0.12em !important;
  color: var(--ink-soft) !important;
}
.mobile-menu .mobile-submenu a:hover { color: var(--forest) !important; }
.mobile-menu .mobile-cta {
  display: inline-block;
  margin-top: auto;
  padding: 16px 24px;
  background: #9b9a84;
  color: #ffffff;
  border-radius: 10px;
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  text-align: center;
  text-decoration: none;
  transition: background 0.2s ease;
}
.mobile-menu .mobile-cta:hover { background: #87866f; }

@media (min-width: 861px) {
  .nav-hamburger { display: none !important; }
  .mobile-menu { display: none !important; }
}

/* Overlay variant - transparent over hero photo */
nav.top.nav-overlay {
  background: transparent;
  backdrop-filter: none;
  border-bottom: 1px solid rgba(255,255,255,0.18);
}
nav.top.nav-overlay .logo,
nav.top.nav-overlay ul a,
nav.top.nav-overlay .nav-cta {
  color: #ffffff;
}
nav.top.nav-overlay .logo span { color: #9b9a84; }
nav.top.nav-overlay .logo small { color: rgba(255,255,255,0.75); }
nav.top.nav-overlay ul a:hover,
nav.top.nav-overlay .nav-cta:hover { color: #9b9a84; }

/* Overlay scrolled - returns to solid */
nav.top.nav-overlay.scrolled {
  background: rgba(251,247,239,0.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
nav.top.nav-overlay.scrolled .logo,
nav.top.nav-overlay.scrolled .nav-cta {
  color: var(--forest);
}
nav.top.nav-overlay.scrolled ul a {
  color: var(--forest);
}
nav.top.nav-overlay.scrolled .logo small {
  color: var(--ink-soft);
}
.logo {
  font-family: 'Oswald', sans-serif;
  font-weight: 600;
  font-size: 24px;
  color: var(--forest);
  letter-spacing: 0.02em;
  font-style: normal;
  line-height: 1;
  text-transform: uppercase;
}
.logo span { color: #9b9a84; }
.logo small { display: none; }
nav.top ul {
  display: flex; gap: 32px; list-style: none;
  font-family: 'Public Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}
nav.top ul a { color: var(--forest); transition: color .2s; padding-bottom: 4px; }
nav.top ul a:hover { color: #9b9a84; }
nav.top ul a.current { color: var(--forest); border-bottom: 2px solid var(--terracotta); }

/* Dropdown menu (Over Ferry) */
.has-dropdown {
  position: relative;
}
.has-dropdown > a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.has-dropdown .caret {
  transition: transform 0.25s ease;
  margin-top: 1px;
}
.has-dropdown:hover .caret,
.has-dropdown:focus-within .caret {
  transform: rotate(180deg);
}
/* onzichtbare bridge-zone zodat hover niet verloren gaat tussen menu-item en dropdown */
.has-dropdown::after {
  content: "";
  position: absolute;
  top: 100%;
  left: -20px;
  right: -20px;
  height: 24px;
}
nav.top ul.dropdown {
  position: absolute;
  top: calc(100% + 18px);
  left: 50%;
  transform: translateX(-50%) translateY(-8px);
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 4px 0;
  min-width: 200px;
  list-style: none;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.22s ease, transform 0.22s ease, visibility 0.22s;
  box-shadow: 0 14px 36px rgba(31,42,37,0.12);
  z-index: 100;
}
.has-dropdown:hover > .dropdown,
.has-dropdown:focus-within > .dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}
.dropdown li { width: 100%; }
.dropdown a {
  display: block;
  padding: 7px 22px;
  color: var(--forest);
  white-space: nowrap;
  border-bottom: none !important;
  transition: background 0.15s, color 0.15s;
}
.dropdown a:hover {
  background: var(--cream-dark);
  color: #9b9a84;
}

/* ─────────── BUTTONS ─────────── */
.btn {
  display: inline-block;
  padding: 13px 26px;
  border-radius: 10px;
  font-weight: 800;
  font-size: 15px;
  transition: all .2s ease;
  cursor: pointer;
  border: none;
  font-family: inherit;
  letter-spacing: 0.01em;
}
.btn-primary {
  background: #9b9a84;
  color: #ffffff;
}
.btn-primary:hover { background: #87866f; transform: translateY(-1px); }
.btn-accent {
  background: var(--terracotta);
  color: white;
}
.btn-accent:hover { background: var(--terracotta-dark); }
.btn-outline {
  background: transparent;
  color: var(--forest);
  border: 1.5px solid var(--forest);
}
.btn-outline:hover { background: var(--forest); color: #ffffff; }

.eyebrow {
  font-size: 22px;
  letter-spacing: 0.02em;
  font-weight: 500;
  color: var(--ink-soft);
  margin-bottom: 24px;
  font-family: 'Oswald', 'Public Sans', sans-serif;
  line-height: 1.4;
}
.eyebrow::before { content: ""; }

/* ─────────── HERO (paginabreed met overlay-tekst) ─────────── */
.hero {
  position: relative;
  padding: 0;
  overflow: hidden;
}
.hero-bg {
  position: relative;
  width: 100%;
  min-height: 640px;
  height: 100vh; /* schermvullend */
  display: flex;
  align-items: center;
  background:
    /* donkere overlay voor leesbaarheid van de tekst */
    linear-gradient(100deg, rgba(15,30,24,0.65) 0%, rgba(15,30,24,0.35) 45%, rgba(15,30,24,0.15) 100%),
    /* de echte foto */
    url('hero-foto.jpg') center/cover no-repeat,
    /* fallback gradient als foto nog niet aanwezig is */
    linear-gradient(135deg, var(--sand) 0%, var(--terracotta) 60%, var(--forest) 110%);
}
.hero-bg::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 78% 38%, rgba(255,255,255,0.18), transparent 55%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cpath d='M50 22c-10 0-18 8-18 18s8 18 18 18 18-8 18-18-8-18-18-18zm0 42c-15 0-30 8-30 22v6h60v-6c0-14-15-22-30-22z' fill='%231f352c' opacity='.16'/%3E%3C/svg%3E") no-repeat 80% center / 28%;
  pointer-events: none;
}
.hero-content {
  position: relative;
  max-width: 1320px;
  margin: 0 auto;
  padding: 60px;
  width: 100%;
  z-index: 2;
}
.hero-content .text {
  max-width: 640px;
  color: #ffffff;
}
.hero-content .eyebrow {
  color: #ffffff;
  margin-bottom: 22px;
}
.hero-content h1 {
  font-family: 'Oswald', 'Fraunces', Georgia, sans-serif;
  font-size: clamp(40px, 5.6vw, 76px);
  font-weight: 300;
  color: #ffffff;
  margin-top: 0;
  margin-bottom: 26px;
  letter-spacing: -0.02em;
  line-height: 1.1;
  text-shadow: 0 2px 30px rgba(0,0,0,0.15);
}
.hero-content h1 em {
  color: #ffffff;
  font-weight: 400;
}
.hero-content .lead {
  font-size: 19px;
  color: rgba(255,255,255,0.88);
  max-width: 540px;
  margin-bottom: 36px;
  text-shadow: 0 1px 20px rgba(0,0,0,0.15);
}
.hero-content .actions {
  display: flex; gap: 18px; flex-wrap: wrap; align-items: center;
}

/* Social proof naast de CTA in de hero */
.social-proof {
  display: flex;
  align-items: center;
  gap: 14px;
}
.avatar-stack {
  display: flex;
  align-items: center;
}
.avatar-stack > .avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 2px solid #ffffff;
  margin-left: -12px;
  background: linear-gradient(135deg, var(--sand), var(--terracotta));
  background-size: cover;
  background-position: center;
  box-shadow: 0 2px 10px rgba(0,0,0,0.2);
  flex-shrink: 0;
}
.avatar-stack > .avatar:nth-child(1) {
  margin-left: 0;
  background: linear-gradient(135deg, #c4b59a, var(--sand));
}
.avatar-stack > .avatar:nth-child(2) {
  background: linear-gradient(135deg, var(--sage), var(--forest));
}
.avatar-stack > .badge {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 2px solid #ffffff;
  margin-left: -12px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--cream);
  color: var(--forest);
  font-family: 'Oswald', 'Fraunces', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.02em;
  box-shadow: 0 2px 10px rgba(0,0,0,0.2);
  flex-shrink: 0;
}
.social-proof .text {
  color: #ffffff;
  font-size: 14px;
  line-height: 1.35;
  font-weight: 800;
  text-decoration: none;
  white-space: nowrap;
  transition: opacity 0.2s ease;
}
.social-proof .text:hover {
  opacity: 0.75;
}
.hero-content .actions .btn-outline {
  color: #ffffff;
  border-color: rgba(251,247,239,0.55);
}
.hero-content .actions .btn-outline:hover {
  background: var(--cream);
  color: var(--forest);
  border-color: #ffffff;
}
.hero-photo-note {
  position: absolute;
  bottom: 80px; right: 26px;
  background: rgba(251,247,239,0.92);
  padding: 10px 16px;
  border-radius: 4px;
  font-size: 11px;
  color: var(--ink-soft);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  z-index: 3;
}

/* Service-strip onder hero-foto */
.hero-services {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 22px 60px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 18px 50px;
  background: linear-gradient(180deg, transparent, rgba(31,53,44,0.55));
  border-top: 1px solid rgba(251,247,239,0.12);
  z-index: 2;
}
.hero-services .item {
  color: #ffffff;
  font-size: 16px;
  font-weight: 800;
  display: flex;
  align-items: center;
  gap: 10px;
  letter-spacing: 0.01em;
}
.hero-services .check {
  width: 22px; height: 22px;
  border-radius: 50%;
  border: 1.5px solid var(--cream);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  font-size: 11px;
  font-weight: 700;
  flex-shrink: 0;
}

/* Bewegende pijl achter CTA-knop (algemeen — bv. de bottom CTA) */
.btn .arrow {
  display: inline-block;
  margin-left: 9px;
  font-style: normal;
  animation: arrowNudge 2.2s ease-in-out infinite;
  will-change: transform;
}
@keyframes arrowNudge {
  0%, 100% { transform: translateX(0); }
  50%      { transform: translateX(5px); }
}
.btn:hover .arrow {
  animation: none;
  transform: translateX(8px);
  transition: transform 0.25s ease;
}

/* Nav-CTA: hele tekst + pijl beweegt samen, rustig en opvallend */
nav.top .nav-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  animation: btnNudge 2.4s ease-in-out infinite;
  will-change: transform;
}
nav.top .nav-cta .arrow {
  display: inline-block;
  font-style: normal;
  animation: none; /* niet dubbel laten bewegen */
}
nav.top .nav-cta:hover {
  animation: none;
  transform: translateX(6px);
  transition: transform 0.25s ease;
}
@keyframes btnNudge {
  0%, 100% { transform: translateX(0); }
  50%      { transform: translateX(5px); }
}

/* Typewriter-effect in hero-headline */
.word-cycle {
  display: inline-block;
  min-width: 5.5em;
  text-align: left;
  vertical-align: bottom;
}
.word-cycle-text {
  color: #ffffff;
  font-weight: 400;
  white-space: nowrap;
}
.word-cycle-cursor {
  display: inline-block;
  width: 0.05em;
  min-width: 2px;
  height: 0.85em;
  background: currentColor;
  vertical-align: -0.05em;
  margin-left: 0.06em;
  animation: cursorBlink 0.85s step-end infinite;
}
@keyframes cursorBlink {
  0%, 50% { opacity: 1; }
  50.01%, 100% { opacity: 0; }
}

/* Cursor-volger — open oranje ringetje dat de muis subtiel volgt */
.cursor-ring {
  position: fixed;
  top: 0; left: 0;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid var(--orange);
  background: transparent;
  pointer-events: none;
  z-index: 9999;
  opacity: 0;
  transition: opacity 0.35s ease;
  will-change: transform;
}
@media (hover: none), (pointer: coarse) {
  .cursor-ring { display: none !important; }
}

/* ─────────── SUBHERO (sub-pages) ─────────── */
.subhero {
  padding: 70px 0 90px;
  background: var(--cream-light);
  border-bottom: 1px solid var(--line);
}
.subhero .grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 60px;
  align-items: center;
}
.subhero h1 {
  font-size: clamp(36px, 4.6vw, 58px);
  font-weight: 300;
  color: var(--forest);
  margin-bottom: 22px;
  letter-spacing: -0.02em;
}
.subhero h1 em { color: #9b9a84; font-weight: 400; }
.subhero p {
  font-size: 19px;
  color: var(--ink-soft);
  max-width: 540px;
  margin-bottom: 30px;
}
.subhero .actions { display: flex; gap: 12px; flex-wrap: wrap; }
.subhero-photo {
  aspect-ratio: 4/5;
  border-radius: 4px;
  background: linear-gradient(135deg, var(--sage), var(--forest));
  position: relative;
  box-shadow: 0 30px 60px -25px rgba(31,42,37,0.25);
}
.subhero-photo.warm { background: linear-gradient(135deg, var(--sand), var(--terracotta)); }
.subhero-photo::after {
  content: attr(data-note);
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.7);
  font-family: 'Fraunces', serif; font-style: italic;
  font-size: 14px; padding: 20px; text-align: center;
}

/* breadcrumb */
.crumbs {
  font-size: 13px;
  color: var(--ink-soft);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.crumbs a { color: var(--ink-soft); }
.crumbs a:hover { color: #9b9a84; }
.crumbs span { color: #9b9a84; margin: 0 8px; }

/* ─────────── STATS STRIP ─────────── */
.stats {
  background: var(--cream-dark);
  padding: 60px 0;
  margin-top: 80px;
}
.stats .row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  text-align: center;
}
.stat .num {
  font-family: 'Oswald', 'Fraunces', sans-serif;
  font-size: clamp(48px, 6vw, 72px);
  font-weight: 300;
  color: var(--forest);
  line-height: 1;
  margin-bottom: 8px;
  letter-spacing: -0.02em;
}
.stat .label {
  font-size: 13px;
  color: var(--ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 500;
}

/* ─────────── TWO PATHS ─────────── */
.paths {
  padding: 110px 0;
}
.section-head { text-align: center; max-width: 720px; margin: 0 auto 80px; }
.section-head h2 {
  font-size: clamp(42px, 5.4vw, 68px);
  font-weight: 300;
  color: var(--forest);
  margin-bottom: 45px;
  letter-spacing: -0.025em;
  line-height: 1.05;
}
.section-head h2 em { color: #9b9a84; font-weight: 400; }
.section-head p {
  color: var(--ink-soft);
  font-size: 20px;
  line-height: 1.7;
  max-width: 580px;
  margin: 0 auto;
}
.paths-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}
.path {
  background: white;
  border-radius: 4px;
  overflow: hidden;
  transition: all .3s ease;
  display: flex; flex-direction: column;
}
.path:hover { transform: translateY(-4px); box-shadow: 0 30px 60px -25px rgba(31,42,37,0.2); }
.path-photo {
  aspect-ratio: 16/10;
  background: linear-gradient(135deg, var(--sage), var(--forest));
  position: relative;
}
.path.parents .path-photo {
  background:
    url('foto-opvoeding.jpg') center/cover no-repeat,
    linear-gradient(135deg, var(--sage), var(--forest));
}
.path.couples .path-photo {
  background:
    url('foto-relatiecoaching.jpg') center/cover no-repeat,
    linear-gradient(135deg, var(--sand), var(--terracotta));
}
.path-photo .photo-tag {
  position: absolute; top: 18px; left: 18px;
  background: rgba(244,237,225,0.95);
  padding: 6px 12px; border-radius: 999px;
  font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.15em;
  color: var(--forest);
}
.path-body { padding: 38px; display: flex; flex-direction: column; flex: 1; }
.path h3 {
  font-size: 30px;
  color: var(--forest);
  margin-bottom: 16px;
  font-weight: 400;
}
.path h3 em { color: #9b9a84; font-weight: 400; }
.path > .path-body > p {
  color: var(--ink-soft);
  margin-bottom: 24px;
  font-size: 16px;
  min-height: 5em; /* zorgt dat de bullets in beide kaarten op dezelfde lijn starten */
}
.path h3 {
  min-height: 1.2em; /* zelfde voor de h3 kop */
}
.path ul { list-style: none; margin-bottom: 32px; }
.path ul li {
  padding: 12px 0 12px 28px;
  position: relative;
  font-size: 15px;
  border-bottom: 1px solid var(--cream-dark);
}
.path ul li:last-child { border-bottom: none; }
.path ul li::before {
  content: "→"; position: absolute; left: 0; color: #9b9a84; font-weight: 500;
}
.path-cta { margin-top: auto; }

/* ─────────── PAIN POINTS (sub-page) ─────────── */
.painpoints {
  padding: 110px 0;
  background: var(--cream-light);
}
.painpoints-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-top: 50px;
}
.pain {
  background: white;
  padding: 32px 30px;
  border-radius: 4px;
  border-left: 3px solid var(--terracotta);
}
.pain h4 {
  font-size: 20px;
  color: var(--forest);
  margin-bottom: 8px;
  font-weight: 500;
}
.pain p {
  color: var(--ink-soft);
  font-size: 15px;
}

/* ─────────── BENEFITS / WHAT YOU GET ─────────── */
.benefits {
  padding: 110px 0;
}
.benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin-top: 50px;
}
.benefit {
  text-align: left;
}
.benefit .ico {
  width: 48px; height: 48px;
  border-radius: 12px;
  background: var(--sand);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 18px;
  font-size: 22px;
}
.benefit h4 {
  font-size: 21px;
  color: var(--forest);
  margin-bottom: 8px;
  font-weight: 500;
}
.benefit p { color: var(--ink-soft); font-size: 15px; }

/* ─────────── PRICING CARD ─────────── */
.pricing {
  padding: 110px 0;
  background: var(--cream-dark);
}
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 24px;
  margin-top: 50px;
  max-width: 1080px;
  margin-left: auto;
  margin-right: auto;
}
.price-card {
  background: var(--cream);
  padding: 40px 36px;
  border-radius: 4px;
  border: 1px solid var(--line);
}
.price-card.featured {
  background: var(--forest);
  color: #ffffff;
  border-color: var(--forest);
}
.price-card .tier {
  font-size: 12px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #9b9a84;
  margin-bottom: 14px;
  font-weight: 500;
}
.price-card h3 {
  font-size: 28px;
  color: var(--forest);
  margin-bottom: 6px;
  font-weight: 400;
}
.price-card.featured h3 { color: #ffffff; }
.price-card .pric {
  font-family: 'Oswald', 'Fraunces', sans-serif;
  font-size: 42px;
  font-weight: 300;
  color: var(--forest);
  margin: 16px 0 8px;
  letter-spacing: -0.02em;
}
.price-card.featured .pric { color: #ffffff; }
.price-card .freq {
  font-size: 13px;
  color: var(--ink-soft);
  margin-bottom: 24px;
}
.price-card.featured .freq { color: rgba(255,255,255,0.7); }
.price-card ul {
  list-style: none;
  margin-bottom: 28px;
}
.price-card ul li {
  padding: 10px 0 10px 26px;
  position: relative;
  font-size: 15px;
  border-bottom: 1px solid var(--cream-dark);
}
.price-card.featured ul li {
  border-color: rgba(244,237,225,0.15);
}
.price-card ul li:last-child { border-bottom: none; }
.price-card ul li::before {
  content: "✓";
  position: absolute; left: 0;
  color: #9b9a84;
  font-weight: 600;
}

/* ─────────── FAQ ─────────── */
.faq {
  padding: 110px 0;
}
.faq-list {
  max-width: 760px;
  margin: 50px auto 0;
}
.faq-item {
  border-bottom: 1px solid var(--line);
  padding: 24px 0;
}
.faq-item h4 {
  font-size: 20px;
  color: var(--forest);
  margin-bottom: 10px;
  font-weight: 500;
  cursor: pointer;
  display: flex; justify-content: space-between; align-items: start;
  gap: 16px;
}
.faq-item h4::after {
  content: "+";
  color: #9b9a84;
  font-weight: 300;
  font-size: 28px;
  line-height: 0.6;
}
.faq-item p {
  color: var(--ink-soft);
  font-size: 16px;
  padding-right: 36px;
}

/* ─────────── OVER (asymmetrische magazine-layout) ─────────── */
.about {
  padding: 110px 0;
  background: var(--cream-light);
}
.about .grid {
  display: grid;
  grid-template-columns: 5fr 6fr;
  gap: 0;
  align-items: stretch;
  position: relative;
}
.about-text-block {
  background: var(--cream);
  padding: 60px 56px;
  z-index: 2;
  align-self: center;
  margin-right: -50px;
  border-radius: 2px;
  box-shadow: 0 30px 60px -30px rgba(31,42,37,0.15);
}
.about-photo {
  aspect-ratio: 4/5;
  background:
    url('ferry-profiel.jpg') center/cover no-repeat,
    linear-gradient(135deg, var(--sage) 0%, var(--forest) 100%);
  position: relative;
  border-radius: 2px;
}

/* Speels effect: tekst en foto schuiven scroll-gedreven naar elkaar toe (desktop) */
@media (min-width: 861px) {
  .about-text-block,
  .about-photo {
    will-change: transform;
  }
}
.about h2 {
  font-size: clamp(30px, 3.4vw, 42px);
  color: var(--forest);
  margin-bottom: 20px;
  font-weight: 300;
  letter-spacing: -0.02em;
}
.about h2 em { color: #9b9a84; font-weight: 400; }
.about p { font-size: 17px; color: var(--ink-soft); margin-bottom: 16px; }
.about .signature {
  font-family: 'Fraunces', serif; font-style: italic; font-size: 22px;
  margin-top: 26px; color: var(--forest);
}
.about .signature::before { content: "— "; }

/* ─────────── WERKWIJZE ─────────── */
.approach {
  padding: 110px 0;
  position: relative;
  overflow: hidden;
}
/* zachte sage-blobs als decoratieve achtergrond */
.approach::before {
  content: "";
  position: absolute;
  top: -120px;
  right: -160px;
  width: 460px;
  height: 460px;
  background: radial-gradient(circle, rgba(155,154,132,0.16), transparent 65%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
}
.approach::after {
  content: "";
  position: absolute;
  bottom: -140px;
  left: -180px;
  width: 420px;
  height: 420px;
  background: radial-gradient(circle, rgba(168,181,160,0.18), transparent 65%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
}
.approach > .container { position: relative; z-index: 1; }
/* oude 3-staps grid (gebruikt op subpagina's) */
.steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 36px;
}
.step {
  padding: 0;
}
.step .num {
  font-family: 'Oswald', 'Fraunces', sans-serif;
  font-size: 64px;
  font-weight: 300;
  color: #9b9a84;
  line-height: 1;
  margin-bottom: 18px;
  letter-spacing: -0.03em;
}
.step h4 { font-size: 24px; color: var(--forest); margin-bottom: 12px; font-weight: 400; }
.step p { color: var(--ink-soft); font-size: 16px; }

/* nieuwe verticale tijdlijn (homepage) */
.timeline {
  position: relative;
  max-width: 940px;
  margin: 0 auto;
  padding: 10px 0 20px;
}
.timeline::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 30px;
  bottom: 30px;
  width: 2px;
  background: var(--line);
  transform: translateX(-1px);
}
/* fill-lijn die meeloopt met scrollpositie */
.timeline-fill {
  position: absolute;
  left: 50%;
  top: 30px;
  width: 2px;
  height: 0;
  background: linear-gradient(180deg, var(--forest) 0%, var(--forest) calc(100% - 30px), transparent 100%);
  transform: translateX(-1px);
  z-index: 2;
  pointer-events: none;
}
.timeline-row {
  display: flex;
  position: relative;
  margin-bottom: 50px;
  z-index: 3; /* zorgt dat marker en kaart over de fill-lijn vallen */
}
.timeline-row:last-child { margin-bottom: 0; }
.timeline-row--left  { justify-content: flex-start; padding-right: 50%; }
.timeline-row--right { justify-content: flex-end;   padding-left: 50%; }
.timeline-row--left  .step-card { margin-right: 36px; }
.timeline-row--right .step-card { margin-left: 36px; }

/* grote markers op de centrale lijn met het stap-nummer */
.step-marker {
  position: absolute;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--forest);
  color: var(--cream);
  font-family: 'Oswald', 'Fraunces', sans-serif;
  font-weight: 400;
  font-size: 22px;
  letter-spacing: -0.02em;
  display: flex;
  align-items: center;
  justify-content: center;
  left: 50%;
  top: 22px;
  transform: translateX(-50%);
  z-index: 3;
  border: 5px solid var(--cream);
  box-shadow: 0 8px 22px rgba(31,42,37,0.18);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
/* de actieve rij (in beeld) krijgt een sage-glow rondom de marker */
.timeline-row.in-view .step-marker {
  box-shadow: 0 8px 22px rgba(31,42,37,0.18), 0 0 0 6px rgba(155,154,132,0.18);
}
.step-card {
  background-color: #fefcf7;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.42 0 0 0 0 0.4 0 0 0 0 0.32 0 0 0 0.18 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  padding: 30px 32px;
  border-radius: 8px;
  width: 100%;
  max-width: 400px;
  box-shadow: 0 8px 28px rgba(31,42,37,0.06);
  border: 1px solid var(--line);
  position: relative;
  transition: transform 0.3s ease, box-shadow 0.6s ease, border-color 0.6s ease;
}
/* kaart "ontvangt" de tijdlijn: rand kleurt mee zodra de fill-lijn de marker bereikt */
.timeline-row.is-reached .step-card {
  border-color: var(--forest);
  box-shadow: 0 12px 32px rgba(45,74,62,0.12);
}
.step-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 40px rgba(31,42,37,0.10);
}
/* horizontale verbindingslijn tussen kaart en marker — uitgelijnd op marker-midden */
.timeline-row--left .step-card::after,
.timeline-row--right .step-card::after {
  content: "";
  position: absolute;
  top: 54px; /* marker top (22) + halve marker-hoogte (32) */
  width: 24px;
  height: 1px;
  background: var(--line);
  transition: background 0.6s ease;
}
.timeline-row--left .step-card::after  { right: -24px; }
.timeline-row--right .step-card::after { left: -24px; }
.timeline-row.is-reached .step-card::after {
  background: var(--forest);
}
.step-card h4 {
  font-size: 22px;
  color: var(--forest);
  margin-bottom: 10px;
  font-weight: 400;
}
.step-card p {
  color: var(--ink-soft);
  font-size: 15px;
  margin-bottom: 0;
}
.step-card .step-btn {
  margin-top: 20px;
  padding: 11px 22px;
  font-size: 14px;
}

@media (max-width: 860px) {
  .timeline::before { left: 32px; }
  .timeline-fill { left: 32px; }
  .timeline-row,
  .timeline-row--left,
  .timeline-row--right { padding-left: 0; padding-right: 0; justify-content: flex-start; }
  .timeline-row--left  .step-card,
  .timeline-row--right .step-card {
    margin-left: 80px;
    margin-right: 0;
    width: auto;
    flex: 1 1 0;
    min-width: 0;
    max-width: none;
  }
  .timeline-row--left  .step-card::after,
  .timeline-row--right .step-card::after { display: none; }
  .step-marker { left: 32px; width: 50px; height: 50px; font-size: 18px; border-width: 4px; }
}

/* ─────────── DOWNLOADS ─────────── */
.downloads {
  padding: 110px 0;
  background: var(--forest);
  color: #ffffff;
}
.downloads .section-head h2 { color: #ffffff; }
.downloads .section-head p { color: rgba(255,255,255,0.75); }
.downloads .eyebrow { color: #9b9a84; }
.downloads-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.product {
  background: var(--cream);
  color: var(--ink);
  border-radius: 4px;
  overflow: hidden;
  display: flex; flex-direction: column;
}
.product .cover {
  aspect-ratio: 4/3;
  background: linear-gradient(135deg, var(--sand), var(--terracotta));
  position: relative;
  display: flex; align-items: flex-end;
  padding: 24px;
}
.product:nth-child(2) .cover { background: linear-gradient(135deg, var(--sage), var(--forest)); }
.product:nth-child(3) .cover { background: linear-gradient(135deg, #c4b59a, var(--sand)); }
.product .cover h4 {
  color: white; font-size: 26px; line-height: 1.05;
  text-shadow: 0 2px 12px rgba(0,0,0,0.2);
  font-weight: 400;
}
.product .body { padding: 24px 26px 28px; flex: 1; display: flex; flex-direction: column; }
.product .tag {
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.15em;
  color: #9b9a84; font-weight: 500; margin-bottom: 10px;
}
.product p { color: var(--ink-soft); font-size: 15px; flex: 1; margin-bottom: 18px; }
.product .price-row { display: flex; justify-content: space-between; align-items: center; }
.product .price { font-family: 'Oswald', 'Fraunces', sans-serif; font-size: 24px; color: var(--forest); font-weight: 400; }

/* Leesbalk: voortgangsindicator bovenin de pagina */
.reading-progress {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: rgba(45,74,62,0.08);
  z-index: 100;
  pointer-events: none;
}
.reading-progress-fill {
  height: 100%;
  background: var(--forest);
  width: 0;
  transition: width 0.12s linear;
}

/* ─────────── CONTACT-PAGINA ─────────── */
.subhero--contact .grid {
  grid-template-columns: 1.6fr 1fr;
  gap: 60px;
}
.subhero-photo--contact {
  background:
    url('ferry-contact.png') center/cover no-repeat,
    linear-gradient(135deg, var(--sage), var(--forest));
  aspect-ratio: 4/5;
  border-radius: 10px;
  box-shadow: 0 16px 40px rgba(31,42,37,0.15);
  width: 100%;
}
.subhero-photo--contact::after {
  display: none;
}
@media (max-width: 860px) {
  .subhero--contact .grid {
    grid-template-columns: 1fr;
  }
  .subhero-photo--contact {
    max-width: 280px;
    margin: 0 auto;
  }
}


.contact-section {
  padding: 60px 0 90px;
}
.contact-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 60px;
  align-items: stretch;
}
.contact-form-block {
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 40px 44px;
  box-shadow: 0 8px 28px rgba(31,42,37,0.06);
}
.contact-form .field {
  margin-bottom: 20px;
}
.contact-form label {
  display: block;
  font-family: 'Public Sans', sans-serif;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ink-soft);
  margin-bottom: 8px;
}
.contact-form input,
.contact-form select,
.contact-form textarea {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--cream-light);
  font-family: 'Public Sans', sans-serif;
  font-size: 15px;
  color: var(--ink);
  transition: border-color 0.2s ease, background 0.2s ease;
}
.contact-form input::placeholder,
.contact-form textarea::placeholder {
  color: var(--ink-soft);
  opacity: 0.7;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
  outline: none;
  border-color: var(--forest);
  background: #ffffff;
}
.contact-form textarea {
  resize: vertical;
  min-height: 130px;
  font-family: 'Public Sans', sans-serif;
}
.contact-form select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%232d4a3e' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  padding-right: 40px;
  cursor: pointer;
}
.contact-form .btn {
  margin-top: 8px;
}
.contact-form .form-note {
  margin-top: 16px;
  font-size: 13px;
  color: var(--ink-soft);
  font-style: italic;
}

.contact-info {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 16px;
}
.info-block {
  background: var(--cream-light);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 24px 26px;
  transition: background 0.2s ease, border-color 0.2s ease;
}
.info-block:hover {
  background: #ffffff;
  border-color: var(--forest);
}
.info-block--accent {
  background: var(--forest);
  border-color: var(--forest);
}
.info-block--accent:hover {
  background: var(--forest-dark);
  border-color: var(--forest-dark);
}
.info-block--accent .eyebrow,
.info-block--accent .info-note { color: rgba(255,255,255,0.75); }
.info-block--accent .info-link { color: #ffffff; }
.info-block--accent .info-icon { color: rgba(255,255,255,0.85); }
.info-icon {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: rgba(45,74,62,0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
  color: var(--forest);
}
.info-block--accent .info-icon {
  background: rgba(255,255,255,0.12);
}
.info-block .eyebrow {
  margin-bottom: 4px;
  color: var(--ink-soft);
}
.info-link {
  display: inline-block;
  font-family: 'Oswald', 'Fraunces', Georgia, sans-serif;
  font-size: 22px;
  font-weight: 400;
  color: var(--forest);
  text-decoration: none;
  letter-spacing: -0.01em;
  margin-bottom: 8px;
  transition: color 0.2s ease;
}
.info-link:hover {
  color: #9b9a84;
}
.info-note {
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 1.55;
}

/* Reviews */
.reviews-section {
  padding: 80px 0 100px;
  background: var(--cream-dark);
}
.reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-top: 50px;
}
.review {
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 32px 30px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.review:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 40px rgba(31,42,37,0.08);
}
.review-quote {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 18px;
  line-height: 1.5;
  color: var(--forest);
  font-weight: 400;
  font-style: italic;
  flex: 1;
}
.reviewer {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}
.reviewer-portrait {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--terracotta), var(--sand));
  flex-shrink: 0;
}
.reviewer-portrait--2 { background: linear-gradient(135deg, var(--sage), var(--forest)); }
.reviewer-portrait--3 { background: linear-gradient(135deg, var(--sand), #c4b59a); }
.reviewer-info strong {
  display: block;
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--forest);
}
.reviewer-info span {
  font-family: 'Public Sans', sans-serif;
  font-size: 12px;
  color: var(--ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

@media (max-width: 860px) {
  .contact-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .contact-form-block {
    padding: 30px 26px;
  }
  .reviews-grid {
    grid-template-columns: 1fr;
  }
}

/* ─────────── ARTIKEL-PAGINA (single post, één kolom, rustig leesplezier) ─────────── */
.single-article { background: var(--cream); }

.article-header {
  position: relative;
  min-height: 70vh;
  display: flex;
  align-items: flex-end;
  padding: 120px 0 120px;
  background:
    linear-gradient(180deg, rgba(15,30,24,0.35) 0%, rgba(15,30,24,0.7) 100%),
    url('gamen-met-pap.jpg') center/cover no-repeat;
  margin-bottom: 0;
}
.article-header .container {
  width: 100%;
  text-align: left;
  position: relative;
  z-index: 2;
}
.article-cat-tag {
  display: inline-block;
  margin-bottom: 28px;
  padding: 6px 14px;
  background: rgba(255,255,255,0.15);
  border: 1px solid rgba(255,255,255,0.3);
  backdrop-filter: blur(6px);
  color: #ffffff;
  border-radius: 10px;
  font-family: 'Public Sans', sans-serif;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  text-decoration: none;
  transition: background 0.2s ease;
}
.article-cat-tag:hover { background: rgba(255,255,255,0.25); color: #ffffff; }
.article-header h1 {
  font-family: 'Oswald', 'Fraunces', Georgia, sans-serif;
  font-size: clamp(40px, 5.5vw, 80px);
  font-weight: 500;
  color: #ffffff;
  line-height: 1.05;
  letter-spacing: -0.01em;
  margin-bottom: 28px;
  max-width: 1000px;
  text-shadow: 0 2px 30px rgba(0,0,0,0.25);
}
.article-meta {
  font-family: 'Public Sans', sans-serif;
  font-size: 13px;
  color: rgba(255,255,255,0.88);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  font-weight: 600;
}
.article-meta .dot { margin: 0 10px; opacity: 0.6; }

.article-content {
  margin-top: -60px;
  position: relative;
  z-index: 2;
  background: transparent;
  padding: 0;
}
.article-content > .container-narrow {
  max-width: 1180px;
  background: var(--cream);
  padding: 90px 100px 80px;
  border-radius: 4px;
}
/* Tekst-elementen blijven op leesbreedte gecentreerd in de bredere kaart */
.article-content > .container-narrow > .lead,
.article-content > .container-narrow > p,
.article-content > .container-narrow > h2,
.article-content > .container-narrow > h3,
.article-content > .container-narrow > ul,
.article-content > .container-narrow > ol,
.article-content > .container-narrow > blockquote,
.article-content > .container-narrow > .toc {
  max-width: 880px;
  margin-left: auto;
  margin-right: auto;
}

/* Share + tags blok — gedeelde cream-dark achtergrond */
.article-share {
  background: var(--cream-dark);
  padding: 50px 0 28px;
}
.article-share .container-narrow {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}
.article-share .label {
  font-family: 'Public Sans', sans-serif;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ink-soft);
  font-weight: 600;
}
.share-buttons {
  display: flex;
  gap: 8px;
}
.share-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: var(--cream-light);
  border: 1px solid var(--line);
  border-radius: 10px;
  color: var(--forest);
  text-decoration: none;
  transition: all 0.2s ease;
}
.share-btn svg { display: block; }
.share-btn:hover {
  background: var(--forest);
  border-color: var(--forest);
  color: #ffffff;
  transform: translateY(-1px);
}

.article-content .lead {
  font-family: 'Public Sans', sans-serif;
  font-size: clamp(20px, 2.1vw, 23px);
  line-height: 1.55;
  color: var(--forest);
  font-weight: 400;
  margin-bottom: 36px;
  padding-bottom: 30px;
  border-bottom: 1px solid var(--line);
}
.article-content p {
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  line-height: 1.78;
  color: var(--ink);
  margin-bottom: 24px;
}
.article-content h2 {
  font-family: 'Oswald', 'Fraunces', Georgia, sans-serif;
  font-size: clamp(26px, 2.8vw, 32px);
  color: var(--forest);
  margin: 56px 0 20px;
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: -0.01em;
  scroll-margin-top: 112px;
}

/* Inhoudsopgave als reading-progress timeline */
.article-content .toc {
  background: var(--cream-dark);
  border-radius: 12px;
  padding: 32px 32px;
  margin: 0 0 50px;
}
.article-content .toc-label {
  font-family: 'Public Sans', sans-serif;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ink-soft);
  margin-bottom: 24px;
}
.article-content .toc > ol {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  position: relative;
}
/* leeg lijntje van boven tot onder */
.article-content .toc > ol::before {
  content: "";
  position: absolute;
  left: 6px;
  top: 8px;
  bottom: 8px;
  width: 2px;
  background: rgba(45,74,62,0.18);
  border-radius: 1px;
}
/* gevulde lijn die meegroeit met scroll-positie (height via CSS-var) */
.article-content .toc > ol::after {
  content: "";
  position: absolute;
  left: 6px;
  top: 8px;
  width: 2px;
  height: var(--toc-fill-height, 0px);
  background: var(--forest);
  border-radius: 1px;
  z-index: 1;
  transition: height 0.55s cubic-bezier(.2,.7,.2,1);
}
.article-content .toc > ol > li {
  font-family: 'Oswald', 'Fraunces', Georgia, sans-serif;
  font-size: 24px;
  line-height: 1.35;
  margin-bottom: 22px !important;
  padding-left: 30px !important;
  position: relative;
  font-weight: 400;
  color: var(--ink-soft);
  transition: color 0.3s ease;
}
.article-content .toc > ol > li:last-child { margin-bottom: 0 !important; }
/* cirkel-marker op de lijn */
.article-content .toc > ol > li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--cream-dark);
  border: 2px solid rgba(45,74,62,0.3);
  box-sizing: border-box;
  z-index: 2;
  transition: all 0.4s ease;
}
.article-content .toc > ol > li:hover::before {
  background: var(--forest);
  border-color: var(--forest);
}
.article-content .toc > ol > li.is-active::before {
  background: var(--forest);
  border-color: var(--forest);
  box-shadow: 0 0 0 5px rgba(45,74,62,0.14);
}
.article-content .toc > ol > li.is-active > a {
  color: var(--forest);
  font-weight: 500;
}
.article-content .toc a {
  color: inherit;
  text-decoration: none !important;
  transition: color 0.2s ease;
}
.article-content .toc a:hover { color: var(--forest); }

/* H3 sub-items — ingesprongen, geen marker op de lijn */
.article-content .toc-sub {
  list-style: none !important;
  margin: 12px 0 0 !important;
  padding: 0 !important;
}
.article-content .toc-sub li {
  font-family: 'Oswald', 'Fraunces', Georgia, sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.4;
  color: var(--ink-soft);
  padding-left: 18px !important;
  margin-bottom: 8px !important;
  position: relative;
  transition: color 0.3s ease;
}
.article-content .toc-sub li:last-child { margin-bottom: 0 !important; }
.article-content .toc-sub li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 12px;
  width: 10px;
  height: 1px;
  background: rgba(45,74,62,0.3);
  transition: all 0.3s ease;
}
.article-content .toc-sub li:hover::before {
  background: var(--forest);
}
.article-content .toc-sub li.is-active::before {
  background: var(--forest);
  width: 14px;
}
.article-content .toc-sub li.is-active > a {
  color: var(--forest);
  font-weight: 500;
}
.article-content .toc-sub a {
  color: var(--ink-soft);
}
.article-content .toc-sub a:hover { color: var(--forest); }

.article-content h3[id] { scroll-margin-top: 112px; }

/* Compacte TOC-rail aan de rechter zijkant tijdens lezen */
.toc-rail {
  position: fixed;
  right: 28px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 50;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 18px;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s;
}
.toc-rail.is-visible {
  opacity: 1;
  visibility: visible;
}
.toc-rail-item {
  display: flex;
  align-items: center;
  gap: 14px;
  cursor: pointer;
  text-decoration: none;
  font-family: 'Public Sans', sans-serif;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--forest);
}
.toc-rail-item .label {
  background: var(--cream);
  padding: 6px 12px;
  border-radius: 8px;
  border: 1px solid var(--line);
  box-shadow: 0 6px 18px rgba(31,42,37,0.10);
  white-space: nowrap;
  opacity: 0;
  transform: translateX(8px);
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
}
.toc-rail-item:hover .label,
.toc-rail-item.is-active .label {
  opacity: 1;
  transform: translateX(0);
}
.toc-rail-item .dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: rgba(45,74,62,0.28);
  transition: all 0.35s ease;
  flex-shrink: 0;
}
.toc-rail-item:hover .dot {
  background: var(--forest);
}
.toc-rail-item.is-active .dot {
  background: var(--forest);
  box-shadow: 0 0 0 4px rgba(45,74,62,0.15);
}

@media (max-width: 1100px) {
  .toc-rail { display: none !important; }
}
.article-content h3 {
  font-family: 'Oswald', 'Fraunces', Georgia, sans-serif;
  font-size: 22px;
  color: var(--forest);
  margin: 40px 0 14px;
  font-weight: 500;
  line-height: 1.3;
}
.article-content ul,
.article-content ol {
  margin: 0 0 24px 0;
  padding-left: 24px;
}
.article-content ul li,
.article-content ol li {
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  line-height: 1.7;
  color: var(--ink);
  margin-bottom: 10px;
  padding-left: 8px;
}
.article-content blockquote {
  background: var(--cream-dark);
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-size: clamp(20px, 2.2vw, 25px);
  line-height: 1.45;
  color: var(--forest);
  margin: 50px 0;
  padding: 32px 36px 32px 38px;
  border-left: 4px solid var(--terracotta);
  border-radius: 0 10px 10px 0;
  position: relative;
}
.article-content blockquote cite {
  display: block;
  margin-top: 18px;
  text-align: right;
  font-family: 'Public Sans', sans-serif;
  font-style: normal;
  font-size: 12px;
  font-weight: 600;
  color: var(--ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.12em;
}
.article-content a {
  color: var(--forest);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  transition: color 0.2s ease;
}
.article-content a:hover { color: #9b9a84; }
.article-content strong {
  color: var(--forest);
  font-weight: 700;
}
.article-content em {
  font-style: italic;
}

/* Foto's en galerijen in het artikel */
.article-content figure {
  margin: 44px 0;
}
.article-content figure img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 8px;
  aspect-ratio: 16/9;
  object-fit: cover;
}
.article-content figure figcaption {
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  color: var(--ink-soft);
  font-style: italic;
  margin-top: 14px;
  text-align: center;
  line-height: 1.5;
}
/* Galerij — 3 thumbnails boven + 1 brede featured eronder */
.article-content .gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin: 44px 0;
}
.article-content .gallery figure {
  margin: 0;
}
.article-content .gallery img {
  width: 100%;
  height: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: 8px;
  cursor: zoom-in;
  transition: opacity 0.25s ease;
}
.article-content .gallery img:hover { opacity: 0.92; }
.article-content .gallery .gallery-feature {
  grid-column: 1 / -1;
}
.article-content .gallery .gallery-feature img {
  aspect-ratio: 16/9;
}

/* Klikbare inline-foto's openen ook in de lightbox */
.article-content figure img { cursor: zoom-in; }

@media (max-width: 600px) {
  .article-content .gallery {
    grid-template-columns: 1fr;
  }
  .article-content .gallery .gallery-feature img {
    aspect-ratio: 4/3;
  }
}

/* Lightbox: vergrootte weergave bij klik op artikel-foto */
.lightbox {
  position: fixed;
  inset: 0;
  background: rgba(15,30,24,0.93);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s;
  padding: 40px;
}
.lightbox.is-open {
  opacity: 1;
  visibility: visible;
}
.lightbox-img {
  max-width: 92vw;
  max-height: 88vh;
  width: auto;
  height: auto;
  border-radius: 8px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.5);
  display: block;
}
.lightbox-close {
  position: absolute;
  top: 24px;
  right: 24px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.2);
  color: #ffffff;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  font-family: inherit;
  transition: background 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.lightbox-close:hover {
  background: rgba(255,255,255,0.2);
}
.lightbox-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.2);
  color: #ffffff;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  font-family: inherit;
  transition: background 0.2s ease, transform 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.lightbox-nav:hover {
  background: rgba(255,255,255,0.22);
}
.lightbox-prev { left: 24px; }
.lightbox-next { right: 24px; }
.lightbox-prev:hover { transform: translateY(-50%) translateX(-2px); }
.lightbox-next:hover { transform: translateY(-50%) translateX(2px); }
@media (max-width: 600px) {
  .lightbox-nav { width: 42px; height: 42px; font-size: 18px; }
  .lightbox-prev { left: 12px; }
  .lightbox-next { right: 12px; }
}

/* Tags onderaan artikel — sluit visueel aan op de share-balk erboven */
.article-footer {
  padding: 28px 0 60px;
  background: var(--cream-dark);
}
.article-footer .tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.article-footer .tags .label {
  font-family: 'Public Sans', sans-serif;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ink-soft);
  font-weight: 600;
  margin-right: 6px;
}
.article-footer .tags a {
  display: inline-block;
  padding: 6px 12px;
  background: var(--cream-light);
  border: 1px solid var(--line);
  border-radius: 10px;
  font-family: 'Public Sans', sans-serif;
  font-size: 12px;
  font-weight: 600;
  color: var(--forest);
  text-decoration: none;
  text-transform: lowercase;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
.article-footer .tags a:hover {
  background: var(--forest);
  border-color: var(--forest);
  color: #ffffff;
}

/* Auteur-bio — donker blok met persoonlijke noot */
.author-bio {
  padding: 80px 0;
  background: var(--forest-dark);
}
.author-bio-inner {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 36px;
  align-items: center;
  background: transparent;
  padding: 0;
  border: none;
  box-shadow: none;
}
.author-photo {
  width: 140px;
  height: 140px;
  border-radius: 10px;
  background:
    url('ferry-profiel.jpg') center/cover no-repeat,
    linear-gradient(135deg, var(--sage), var(--forest));
  box-shadow: 0 8px 24px rgba(0,0,0,0.25);
}
.author-text .eyebrow {
  margin-bottom: 8px;
  color: rgba(255,255,255,0.6);
}
.author-text h3 {
  font-family: 'Oswald', 'Fraunces', Georgia, sans-serif;
  font-size: 26px;
  color: #ffffff;
  margin-bottom: 10px;
  font-weight: 400;
}
.author-text p {
  font-family: 'Public Sans', sans-serif;
  font-size: 15px;
  color: rgba(255,255,255,0.82);
  line-height: 1.65;
  margin-bottom: 20px;
}

/* Gerelateerde artikelen */
.related-articles {
  padding: 80px 0;
  background: var(--cream-light);
}
.related-articles .blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin-top: 30px;
}

@media (max-width: 860px) {
  .article-header { min-height: 50vh; padding: 90px 0 70px; }
  .article-content { margin-top: -36px; }
  .article-content > .container-narrow {
    padding: 40px 24px 50px;
    border-radius: 4px;
  }
  .article-content .lead { font-size: 19px; }
  .article-content p { font-size: 17px; }
  .article-content ul li, .article-content ol li { font-size: 17px; }
  .article-content h2 { margin-top: 44px; }
  .author-bio-inner {
    grid-template-columns: 1fr;
    text-align: center;
    padding: 32px 28px;
  }
  .author-photo { margin: 0 auto; }
  .related-articles .blog-grid { grid-template-columns: 1fr; }
}

/* ─────────── BLOG INDEX-PAGINA: toolbar, featured, paginering ─────────── */
.blog-toolbar {
  padding: 50px 0 20px;
}
.blog-toolbar .container {
  display: flex;
  flex-wrap: wrap;
  gap: 24px 32px;
  align-items: center;
  justify-content: space-between;
}
.blog-search {
  position: relative;
  flex: 0 0 320px;
  max-width: 100%;
}
.blog-search input {
  width: 100%;
  padding: 12px 16px 12px 44px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--cream-light);
  font-family: inherit;
  font-size: 15px;
  color: var(--ink);
  transition: border-color 0.2s ease, background 0.2s ease;
}
.blog-search input::placeholder {
  color: var(--ink-soft);
}
.blog-search input:focus {
  outline: none;
  border-color: var(--forest);
  background: white;
}
.blog-search .search-icon {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--ink-soft);
  pointer-events: none;
  display: inline-flex;
  align-items: center;
}

.blog-categories {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.cat-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: 10px;
  background: transparent;
  border: 1px solid var(--line);
  font-family: 'Public Sans', sans-serif;
  font-size: 12px;
  font-weight: 600;
  color: var(--forest);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  transition: all 0.2s ease;
  white-space: nowrap;
}
.cat-pill span {
  font-size: 11px;
  color: var(--ink-soft);
  font-weight: 500;
}
.cat-pill:hover {
  background: var(--cream-dark);
  border-color: var(--cream-dark);
}
.cat-pill.is-active {
  background: var(--forest);
  border-color: var(--forest);
  color: #ffffff;
}
.cat-pill.is-active span {
  color: rgba(255,255,255,0.7);
}

/* Uitgelicht artikel — twee kolommen, foto links, content rechts */
.blog-featured {
  padding: 30px 0 70px;
}
.featured-post {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 0;
  background: white;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: 0 8px 28px rgba(31,42,37,0.06);
}
.featured-photo {
  display: block;
  background:
    url('gamen-met-pap.jpg') center/cover no-repeat,
    linear-gradient(135deg, var(--sand), var(--sage));
  position: relative;
  overflow: hidden;
  min-height: 360px;
  transition: transform 0.6s cubic-bezier(.2,.7,.2,1);
}
.featured-photo::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(100deg, rgba(15,30,24,0.45) 0%, rgba(15,30,24,0.15) 70%, transparent 100%);
  opacity: 0;
  transition: opacity 0.45s ease;
  pointer-events: none;
}
.featured-post:hover .featured-photo::before { opacity: 1; }
.featured-post:hover .featured-photo { transform: scale(1.02); }
.featured-body {
  padding: 50px 50px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.featured-tag {
  display: inline-block;
  align-self: flex-start;
  padding: 4px 12px;
  background: var(--cream-dark);
  border-radius: 10px;
  font-size: 11px;
  font-weight: 700;
  color: var(--forest);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin-bottom: 18px;
}
.featured-body .meta {
  font-size: 12px;
  color: var(--ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin-bottom: 14px;
}
.featured-body .meta .cat { color: #9b9a84; font-weight: 600; }
.featured-body h2 {
  font-family: 'Oswald', 'Fraunces', Georgia, sans-serif;
  font-size: clamp(28px, 3.2vw, 40px);
  color: var(--forest);
  line-height: 1.15;
  margin-bottom: 18px;
  font-weight: 400;
}
.featured-body h2 a {
  color: inherit;
  text-decoration: none;
  transition: color 0.2s ease;
}
.featured-body h2 a:hover { color: #9b9a84; }
.featured-body p {
  color: var(--ink-soft);
  font-size: 17px;
  line-height: 1.6;
  margin-bottom: 22px;
}
.featured-body .read {
  font-size: 14px;
  font-weight: 500;
  color: var(--forest);
  border-bottom: 1px solid var(--forest);
  padding-bottom: 1px;
  align-self: flex-start;
}
.featured-body .read:hover { color: #9b9a84; border-color: #9b9a84; }

/* Artikel-lijst onder featured */
.blog-list {
  padding: 20px 0 80px;
}

/* Paginering */
.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  margin-top: 70px;
}
.pagination a, .pagination span {
  min-width: 40px;
  height: 40px;
  padding: 0 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--forest);
  text-decoration: none;
  transition: all 0.2s ease;
  border: 1px solid transparent;
}
.pagination a:hover {
  background: var(--cream-dark);
  border-color: var(--cream-dark);
}
.pagination a.active,
.pagination a[aria-current="page"] {
  background: var(--forest);
  border-color: var(--forest);
  color: #ffffff;
}
.pagination .prev, .pagination .next {
  font-size: 18px;
  font-weight: 400;
}
.pagination span.dots {
  color: var(--ink-soft);
  cursor: default;
}

@media (max-width: 860px) {
  .blog-toolbar .container {
    flex-direction: column;
    align-items: stretch;
  }
  .blog-search { flex: 1 1 auto; }
  .featured-post {
    grid-template-columns: 1fr;
  }
  .featured-photo { min-height: 240px; }
  .featured-body { padding: 32px; }
  .pagination a, .pagination span { min-width: 36px; height: 36px; }
}

/* ─────────── BLOG ─────────── */
section.blog {
  padding: 110px 0;
}
.blog-head { display: flex; justify-content: space-between; align-items: end; margin-bottom: 60px; }
.blog-head h2 { font-size: clamp(34px, 4vw, 50px); color: var(--forest); font-weight: 300; letter-spacing: -0.02em; }
.blog-head h2 em { color: #9b9a84; font-weight: 400; }
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}

/* Full-width spotlight-slider voor blog-artikelen op de homepage */
.blog-slider {
  position: relative;
  margin-top: 60px;
}
.blog-track {
  display: flex;
  gap: 24px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 8px 0 32px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.blog-track::-webkit-scrollbar { display: none; }
/* zorgt dat eerste 3 kaarten netjes gecentreerd starten — pad = (viewport - 3 cards - 2 gaps) / 2 */
.blog-track::before,
.blog-track::after {
  content: "";
  flex: 0 0 calc((100% - 3 * 330px - 2 * 24px) / 2);
  min-width: 12px;
}
.blog-track .post {
  flex: 0 0 330px;
  scroll-snap-align: center;
  transition: opacity 0.5s ease;
}
.slider-btn {
  position: absolute;
  top: 38%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: white;
  border: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(0,0,0,0.08);
  color: var(--forest);
  font-size: 20px;
  z-index: 5;
  transition: all .2s ease;
  font-family: inherit;
}
.slider-btn:hover {
  background: var(--forest);
  color: var(--cream);
  border-color: var(--forest);
}
.slider-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
.slider-prev { left: 24px; }
.slider-next { right: 24px; }
.post-photo {
  aspect-ratio: 4/3;
  background:
    url('gamen-met-pap.jpg') center/cover no-repeat,
    linear-gradient(135deg, var(--sand), var(--sage));
  border-radius: 4px;
  margin-bottom: 18px;
  position: relative;
  overflow: hidden;
}
.post-photo::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(100deg, rgba(15,30,24,0.65) 0%, rgba(15,30,24,0.35) 45%, rgba(15,30,24,0.15) 100%);
  opacity: 0;
  transition: opacity 0.45s ease;
  pointer-events: none;
}
.post:hover .post-photo::before {
  opacity: 1;
}
.post .meta {
  font-size: 12px; color: var(--ink-soft); text-transform: uppercase;
  letter-spacing: 0.15em; margin-bottom: 12px;
}
.post .meta .cat { color: #9b9a84; font-weight: 600; }
.meta a.cat,
.featured-body .meta a.cat {
  text-decoration: none;
  transition: color 0.2s ease;
}
.meta a.cat:hover,
.featured-body .meta a.cat:hover {
  color: var(--forest);
}
.post h4 {
  font-size: 24px; color: var(--ink); margin-bottom: 10px;
  line-height: 1.2; font-weight: 400;
}
.post h4 a {
  color: inherit;
  text-decoration: none;
  transition: color 0.2s ease;
}
.post h4 a:hover { color: #9b9a84; }
a.post-photo { display: block; cursor: pointer; }
.post p { color: var(--ink-soft); font-size: 15px; margin-bottom: 14px; }
.post a.read { font-size: 14px; font-weight: 500; color: var(--forest); border-bottom: 1px solid var(--forest); padding-bottom: 1px; }
.post a.read:hover { color: #9b9a84; border-color: #9b9a84; }

/* ─────────── TESTIMONIAL ─────────── */
.testimonial {
  background: var(--cream-dark);
  padding: 110px 0;
}
.testimonial .row {
  max-width: 920px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 36px;
  align-items: center;
}
.test-portrait {
  width: 110px; height: 110px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--terracotta), var(--sand));
}
.testimonial blockquote {
  font-family: 'Fraunces', serif;
  font-size: clamp(20px, 2.2vw, 26px);
  color: var(--forest);
  line-height: 1.45;
  font-style: italic;
  font-weight: 300;
  margin-bottom: 16px;
}
.testimonial .who {
  font-size: 13px; color: var(--ink-soft);
  text-transform: uppercase; letter-spacing: 0.15em;
}

/* ─────────── CTA BANNER (sage met portretfoto) ─────────── */
.cta-banner {
  padding: 80px 0;
  background: var(--cream);
}
.cta-banner-inner {
  background: #9b9a84;
  border-radius: 24px;
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  align-items: center;
  position: relative;
  overflow: hidden;
  min-height: 360px;
}
.cta-banner-photo {
  align-self: end;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  height: 100%;
  padding-top: 30px;
}
.cta-banner-photo img {
  display: block;
  max-width: 100%;
  max-height: 480px;
  object-fit: contain;
  object-position: bottom center;
}
.cta-banner-content {
  padding: 60px 70px 60px 30px;
  color: #ffffff;
}
.cta-banner-content .eyebrow {
  color: rgba(255,255,255,0.85);
  margin-bottom: 18px;
}
.cta-banner-content h2 .move-word {
  display: inline-block;
  animation: wordSlide 5s ease-in-out infinite;
  will-change: transform;
}
/* CTA-banner button: wit op sage achtergrond, geen pijl-animatie */
.cta-banner-content .banner-btn {
  background: #ffffff;
  color: var(--forest);
}
.cta-banner-content .banner-btn:hover {
  background: var(--cream-light);
  transform: translateY(-1px);
}
.cta-banner-content .banner-btn .arrow { animation: none; }
@keyframes wordSlide {
  0%   { transform: translateX(-5px); }
  50%  { transform: translateX(5px); }
  100% { transform: translateX(-5px); }
}
.cta-banner-content h2 {
  font-family: 'Oswald', 'Marcellus', Georgia, sans-serif;
  font-size: clamp(30px, 3.6vw, 48px);
  color: #ffffff;
  line-height: 1.1;
  margin-bottom: 22px;
  font-weight: 400;
  letter-spacing: -0.01em;
}
.cta-banner-content p {
  color: rgba(255,255,255,0.92);
  font-size: 17px;
  margin-bottom: 32px;
  max-width: 480px;
}

/* Flippende button: één kant 'Plan een afspraak', andere kant 'Wacht niet langer' */
.flip-btn {
  display: inline-block;
  perspective: 1000px;
  text-decoration: none;
  cursor: pointer;
}
.flip-inner {
  display: block;
  position: relative;
  width: 240px;
  height: 52px;
  transform-style: preserve-3d;
  animation: btnFlip 7s infinite;
}
.flip-btn:hover .flip-inner {
  animation-play-state: paused;
}
.flip-face {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #ffffff;
  color: var(--forest);
  border-radius: 10px;
  font-weight: 800;
  font-size: 16px;
  letter-spacing: 0.01em;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transition: background 0.2s ease, color 0.2s ease;
}
.flip-back { transform: rotateY(180deg); }
.flip-btn:hover .flip-face {
  background: var(--cream-light);
}
@keyframes btnFlip {
  0%, 42%   { transform: rotateY(0deg); }
  50%, 92%  { transform: rotateY(180deg); }
  100%      { transform: rotateY(360deg); }
}
@media (prefers-reduced-motion: reduce) {
  .flip-inner { animation: none; }
}

@media (max-width: 860px) {
  .cta-banner-inner {
    grid-template-columns: 1fr;
    min-height: 0;
  }
  .cta-banner-photo {
    max-height: 300px;
    overflow: hidden;
    padding-top: 20px;
  }
  .cta-banner-photo img {
    max-height: 300px;
  }
  .cta-banner-content {
    padding: 40px 32px 50px;
    text-align: center;
  }
  .cta-banner-content p {
    margin-left: auto;
    margin-right: auto;
  }
}

/* ─────────── NEWSLETTER ─────────── */
.newsletter {
  padding: 100px 0;
  text-align: center;
  background-color: var(--cream-dark);
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='nn'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.42 0 0 0 0 0.4 0 0 0 0 0.32 0 0 0 0.14 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23nn)'/%3E%3C/svg%3E");
}
.newsletter h2 {
  font-size: clamp(28px, 3vw, 38px);
  color: var(--forest);
  font-weight: 300;
  margin-bottom: 14px;
  letter-spacing: -0.02em;
}
.newsletter h2 em { color: #9b9a84; font-weight: 400; }
.newsletter p {
  color: var(--ink-soft);
  max-width: 480px; margin: 0 auto 36px;
  font-size: 17px;
}
.newsletter form {
  display: flex; gap: 10px; max-width: 460px; margin: 0 auto;
  flex-wrap: wrap; justify-content: center;
}
.newsletter input {
  flex: 1; min-width: 220px;
  padding: 14px 20px;
  border: 1px solid var(--line);
  background: var(--cream-light);
  border-radius: 10px;
  font-family: inherit; font-size: 15px;
  color: var(--ink);
}
.newsletter input:focus { outline: none; border-color: var(--forest); }

/* ─────────── CTA ─────────── */
.cta-final {
  padding: 110px 0 130px;
  text-align: center;
  background: var(--cream-light);
}
.cta-final h2 {
  font-size: clamp(36px, 4.8vw, 60px);
  color: var(--forest);
  margin-bottom: 22px;
  max-width: 760px; margin-left: auto; margin-right: auto;
  font-weight: 300; letter-spacing: -0.02em;
}
.cta-final h2 em { color: #9b9a84; font-weight: 400; }
.cta-final p { font-size: 19px; color: var(--ink-soft); max-width: 560px; margin: 0 auto 36px; }

/* ─────────── INSTAGRAM GRID ─────────── */
.insta {
  padding: 70px 0 40px;
  background: var(--forest-dark);
  color: #ffffff;
}
.insta .head {
  text-align: center; margin-bottom: 40px;
}
.insta .head h3 {
  font-family: 'Oswald', 'Fraunces', sans-serif;
  font-size: 26px;
  font-weight: 400;
  color: #ffffff;
  margin-bottom: 6px;
}
.insta .head h3 em { color: #9b9a84; }
.insta .head a {
  font-size: 13px; color: rgba(255,255,255,0.7); letter-spacing: 0.15em;
  text-transform: uppercase;
}
.insta-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 8px;
  max-width: 1100px;
  margin: 0 auto;
}
.insta-grid > * {
  aspect-ratio: 4/5; /* Instagram-portret-formaat */
  background:
    url('placeholder-insta.png') center/cover no-repeat,
    linear-gradient(135deg, var(--sand), var(--terracotta));
  border-radius: 2px;
  display: block;
}

/* ─────────── FOOTER ─────────── */
footer {
  background: var(--forest-dark);
  color: rgba(255,255,255,0.7);
  padding: 70px 0 30px;
}
footer .grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 50px;
}
footer h5 {
  color: #ffffff;
  font-family: 'Fraunces', serif;
  font-size: 18px;
  margin-bottom: 18px;
  font-weight: 500;
}
footer ul { list-style: none; }
footer ul li { margin-bottom: 10px; font-size: 14px; }
footer ul li a { color: rgba(255,255,255,0.7); }
footer ul li a:hover { color: #9b9a84; }
footer .bottom {
  border-top: 1px solid rgba(244,237,225,0.15);
  padding-top: 24px;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 14px;
  font-size: 13px;
}

/* ─────────── RESPONSIVE ─────────── */
@media (max-width: 860px) {
  body { overflow-x: hidden; }
  nav.top {
    grid-template-columns: 1fr auto;
    padding: 20px 22px;
    z-index: 210; /* boven het mobile-menu zodat de hamburger zichtbaar blijft */
  }
  nav.top ul { display: none; }
  nav.top > .nav-cta { display: none; }
  .nav-hamburger { display: flex; }

  /* Hero: minder padding, kleinere headline, social-proof mag wrap */
  .hero-content { padding: 40px 24px 50px; }
  .hero-content .text { max-width: 100%; }
  .hero-content h1 {
    font-size: clamp(32px, 8.5vw, 48px);
    margin-bottom: 18px;
    line-height: 1.12;
  }
  .hero-content .lead {
    font-size: 16px;
    margin-bottom: 28px;
  }
  .hero-content .actions {
    gap: 16px;
  }
  /* Social proof: laat tekst wrappen, kleinere avatars */
  .social-proof {
    flex-wrap: wrap;
    gap: 12px;
  }
  .social-proof .text {
    white-space: normal;
    font-size: 13px;
    line-height: 1.35;
    max-width: 200px;
  }
  .avatar-stack > .avatar,
  .avatar-stack > .badge {
    width: 38px;
    height: 38px;
    margin-left: -10px;
  }
  .avatar-stack > .avatar:nth-child(1) { margin-left: 0; }
  .avatar-stack > .badge { font-size: 12px; }

  /* Werkwijze + andere oude blokken */
  .blog-track .post { flex-basis: 280px; }
  .blog-track::before,
  .blog-track::after { flex: 0 0 calc((100% - 280px) / 2); }
  .slider-btn { display: none; }
  .stats { padding: 40px 0; margin-top: 50px; }
  .stats .row { grid-template-columns: 1fr; gap: 30px; }
  .paths-grid, .steps, .downloads-grid, .blog-grid,
  .painpoints-grid, .benefits-grid, .pricing-grid { grid-template-columns: 1fr; }
  .about .grid { grid-template-columns: 1fr; }
  .about-text-block { margin-right: 0; padding: 40px 30px; }
  .about-photo {
    width: 100%;
    max-width: 480px;
    margin: 0 auto;
  }
  .subhero .grid { grid-template-columns: 1fr; gap: 40px; }
  .subhero-photo { aspect-ratio: 4/3; max-width: 360px; margin: 0 auto; }
  .testimonial .row { grid-template-columns: 1fr; text-align: center; gap: 24px; }
  .test-portrait { margin: 0 auto; }
  .insta-grid { grid-template-columns: repeat(3, 1fr); }
  footer .grid { grid-template-columns: 1fr 1fr; }
  .blog-head { flex-direction: column; align-items: start; gap: 16px; }

  /* Bottom CTA: niet te groot */
  .cta-final h2 { font-size: clamp(28px, 7vw, 38px); }
  .cta-final p { font-size: 16px; }

  /* Newsletter: padding minder */
  .newsletter { padding: 70px 0; }
  .newsletter h2 { font-size: clamp(24px, 6vw, 32px); }
}

/* Extra finetuning voor smal mobiel */
@media (max-width: 480px) {
  .hero-content { padding: 32px 20px 44px; }
  .hero-content h1 { font-size: clamp(28px, 9vw, 36px); }
  .hero-content .lead { font-size: 15px; }
  .hero-content .actions { flex-direction: column; align-items: stretch; }
  .hero-content .actions .btn-primary { width: 100%; text-align: center; }
  .social-proof { width: 100%; justify-content: flex-start; }
  .insta-grid { grid-template-columns: repeat(2, 1fr); }
  footer .grid { grid-template-columns: 1fr; gap: 30px; }
  .cta-banner-content { padding: 32px 24px 44px; }
  .cta-banner-content h2 { font-size: clamp(24px, 6.5vw, 32px); }
}

/* ─────────── THEME-NAVY OVERRIDE — geldig op alle pagina's met body.theme-navy ─────────── */
  /* TIJDELIJKE NAVY-PALETTE OVERRIDE — alleen homepage */
  body.theme-navy {
    --cream: #ffffff;
    --cream-light: #ffffff;
    --cream-dark: #f5f7f7;
    --forest: #063231;
    --forest-dark: #042322;
    --sage: #98a2b5;
    --line: #e6e3dc;
    --ink: #4a4a4a;
    /* Nieuw accent: fel oranje */
    --orange: #f75709;
    --orange-dark: #d44708;
    /* Terracotta-aliases voor compatibiliteit met de base-CSS die nog var(--orange) gebruikt */
    --terracotta: var(--orange);
    --terracotta-dark: var(--orange-dark);
    /* Tweede accent: lime — voor specifieke decoratieve momenten */
    --lime: #c3df94;
    --lime-dark: #a3c772;
  }
  /* Eyebrows — klein label-stijl, fel oranje uppercase met ruime letter-spacing */
  body.theme-navy .eyebrow {
    font-size: 16px;
    letter-spacing: 0.18em;
    font-weight: 600;
    color: #f75709;
    text-transform: uppercase;
    margin-bottom: 28px;
    font-family: 'Oswald', 'Public Sans', sans-serif;
    line-height: 1.4;
  }
  /* Alle grote section-titels: massief uppercase, weight 700, navy */
  body.theme-navy .section-head { max-width: 1200px; }
  body.theme-navy .section-head p { max-width: 580px; margin: 0 auto; }
  body.theme-navy .section-head h2,
  body.theme-navy .about h2,
  body.theme-navy .blog-head h2,
  body.theme-navy .newsletter h2,
  body.theme-navy .cta-final h2 {
    font-family: 'Oswald', sans-serif;
    font-size: 60px;
    font-weight: 700;
    color: var(--forest);
    text-transform: uppercase;
    letter-spacing: -0.02em;
    line-height: 0.98;
    margin-bottom: 40px;
  }
  /* Downloads-sectie heeft donker petrol bg — title moet wit zijn */
  body.theme-navy .downloads .section-head h2 {
    color: #ffffff;
  }

  /* CTA-banner heeft een donker blok — zelfde stijl maar wit, kleiner */
  body.theme-navy .cta-banner-content h2 {
    font-family: 'Oswald', sans-serif;
    font-size: clamp(40px, 5.6vw, 72px);
    font-weight: 700;
    color: #ffffff;
    text-transform: uppercase;
    letter-spacing: -0.02em;
    line-height: 0.98;
    margin-bottom: 24px;
  }
  /* Em-woorden in deze grote titels: blijven in dezelfde regelhoogte, geen italic */
  body.theme-navy .section-head h2 em,
  body.theme-navy .about h2 em,
  body.theme-navy .blog-head h2 em,
  body.theme-navy .newsletter h2 em,
  body.theme-navy .cta-final h2 em,
  body.theme-navy .cta-banner-content h2 em {
    font-style: normal;
    font-weight: 700;
  }
  /* Eyebrows op donkere ondergrond blijven licht (hero, downloads, author, cta-banner) */
  body.theme-navy .hero-content .eyebrow { color: #ffffff; }
  body.theme-navy .downloads .eyebrow { color: rgba(255,255,255,0.85); }
  body.theme-navy .author-text .eyebrow { color: rgba(255,255,255,0.6); }
  body.theme-navy .cta-banner-content .eyebrow { color: rgba(255,255,255,0.85); }
  /* Hardcoded olive-accent (#9b9a84) vervangen door warm-tan dat naast navy werkt */
  body.theme-navy .subhero h1 em,
  body.theme-navy .section-head h2 em,
  body.theme-navy .path h3 em,
  body.theme-navy .about h2 em,
  body.theme-navy .blog-head h2 em,
  body.theme-navy .newsletter h2 em,
  body.theme-navy .cta-final h2 em,
  body.theme-navy .insta .head h3 em { color: var(--orange); }
  body.theme-navy .logo span { color: var(--orange); }
  body.theme-navy nav.top ul a:hover,
  body.theme-navy footer ul li a:hover { color: var(--orange); }

  /* Menu-items in Oswald */
  body.theme-navy nav.top ul {
    font-family: 'Oswald', sans-serif;
    font-size: 14px;
    letter-spacing: 0.14em;
  }

  /* Plan kennismaking → lime button stijl, consistent in beide nav-states */
  body.theme-navy nav.top .nav-cta,
  body.theme-navy nav.top.nav-overlay .nav-cta,
  body.theme-navy nav.top.nav-overlay.scrolled .nav-cta {
    background: var(--lime);
    color: #000000;
    padding: 20px 30px;
    font-family: 'Oswald', sans-serif;
    font-size: 16px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0;
    border: none;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    position: relative;
    overflow: hidden;
    isolation: isolate;
    /* Base-CSS heeft een btnNudge-animatie en translateX op hover — uit */
    animation: none;
    transform: none;
    transition: color 0.25s ease;
  }
  /* Battery-fill effect: oranje vlak schuift bij hover van links naar rechts */
  body.theme-navy nav.top .nav-cta::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 0;
    background: var(--orange);
    transition: width 0.45s ease;
    z-index: -1;
  }
  body.theme-navy nav.top .nav-cta:hover::before {
    width: 100%;
  }
  body.theme-navy nav.top .nav-cta:hover,
  body.theme-navy nav.top.nav-overlay .nav-cta:hover,
  body.theme-navy nav.top.nav-overlay.scrolled .nav-cta:hover {
    animation: none;
    transform: none;
    color: #ffffff;
  }

  /* BUTTONS — uniform style: padding 20x30, radius 12px, Oswald 16px,
     battery-fill animatie van links naar rechts bij hover */
  body.theme-navy .btn {
    padding: 20px 30px;
    border-radius: 12px;
    font-family: 'Oswald', sans-serif;
    font-weight: 600;
    font-size: 16px;
    letter-spacing: 0;
    text-transform: uppercase;
    position: relative;
    overflow: hidden;
    isolation: isolate;
    border: none;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    box-shadow: none;
    transition: color 0.25s ease, border-color 0.25s ease;
  }
  /* Battery-fill pseudo: vult van links naar rechts bij hover */
  body.theme-navy .btn::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 0;
    transition: width 0.45s ease;
    z-index: -1;
  }
  body.theme-navy .btn:hover::before {
    width: 100%;
  }

  /* PRIMARY = oranje basis, vult bij hover met donker petrol (tekst wit) */
  body.theme-navy .btn-primary {
    background: var(--orange);
    color: #ffffff;
  }
  body.theme-navy .btn-primary::before {
    background: var(--forest);
  }
  body.theme-navy .btn-primary:hover {
    color: #ffffff;
  }
  /* Uitzondering: hero primary button vult met lime ipv petrol (lichter tegen donkere hero) */
  body.theme-navy .hero-content .btn-primary::before {
    background: var(--lime);
  }
  body.theme-navy .hero-content .btn-primary:hover {
    color: #000000;
  }
  /* Insta-button op donkere bg krijgt zelfde behandeling: vult met lime ipv petrol */
  body.theme-navy .insta .btn-primary::before {
    background: var(--lime);
  }
  body.theme-navy .insta .btn-primary:hover {
    color: #000000;
  }
  /* Featured pricing-kaart heeft donkere bg — vul de knop bij hover met lime zodat ie contrasteert */
  body.theme-navy .price-card--featured .btn-primary::before {
    background: var(--lime);
  }
  body.theme-navy .price-card--featured .btn-primary:hover {
    color: var(--forest);
  }

  /* ACCENT = donker petrol basis, vult bij hover met oranje (tekst wit) */
  body.theme-navy .btn-accent {
    background: var(--forest);
    color: #ffffff;
  }
  body.theme-navy .btn-accent::before {
    background: var(--orange);
  }
  body.theme-navy .btn-accent:hover {
    color: #ffffff;
  }

  /* OUTLINE = transparant met oranje rand+tekst, vult zich bij hover met oranje */
  body.theme-navy .btn-outline {
    background: transparent;
    color: var(--orange);
    border: 2px solid var(--orange);
  }
  body.theme-navy .btn-outline::before {
    background: var(--orange);
  }
  body.theme-navy .btn-outline:hover {
    color: #ffffff;
    border-color: var(--orange);
  }

  /* Hero: outline-knoppen liggen op donkere foto — witte rand+tekst, vult met lime */
  body.theme-navy .hero-content .actions .btn-outline {
    color: #ffffff;
    border-color: rgba(255,255,255,0.55);
  }
  body.theme-navy .hero-content .actions .btn-outline::before {
    background: var(--lime);
  }
  body.theme-navy .hero-content .actions .btn-outline:hover {
    color: #000000;
    border-color: var(--lime);
  }

  /* Géén translateY-lift bij button-hover (werd uit oude basis-CSS overgenomen) */
  body.theme-navy .btn:hover {
    transform: none;
  }

  /* Pijltje binnen button: zelfde rotatie als op homepage path-link
     (continue nudge-animatie uit basis-CSS uitschakelen, alleen rotate op hover) */
  body.theme-navy .btn .arrow {
    display: inline-block;
    flex-shrink: 0;
    animation: none;
    transition: transform 0.3s ease;
  }
  body.theme-navy .btn:hover .arrow {
    transform: rotate(45deg);
  }

  /* NAV-BALK — transparant + blur bij open, wit + navy bij scroll */
  body.theme-navy nav.top.nav-overlay {
    position: fixed;
    top: 0; left: 0; right: 0;
    background: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border-bottom: none;
  }
  /* Pseudo-laag MET de blur, gemaskeerd met een verloop zodat de blur naar onderen
     toe uitfade-t en mooi overloopt in de hero-foto */
  body.theme-navy nav.top.nav-overlay::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    bottom: -50px; /* steekt 50px onder de nav uit voor zachte feathered edge */
    background: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    -webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 55%, rgba(0,0,0,0.6) 80%, transparent 100%);
            mask-image: linear-gradient(to bottom, #000 0%, #000 55%, rgba(0,0,0,0.6) 80%, transparent 100%);
    pointer-events: none;
    z-index: -1;
  }
  /* Bij scrollen verdwijnt de fade-blur, vervangen door de solide witte balk */
  body.theme-navy nav.top.nav-overlay.scrolled::before {
    display: none;
  }
  body.theme-navy nav.top.nav-overlay .logo,
  body.theme-navy nav.top.nav-overlay .logo span,
  body.theme-navy nav.top.nav-overlay ul a {
    color: #ffffff;
    transition: color 0.35s ease;
  }
  body.theme-navy nav.top.nav-overlay ul a:hover {
    color: var(--lime);
  }
  /* Dropdown: meer ademruimte boven en onder */
  body.theme-navy nav.top ul.dropdown {
    padding: 16px 0;
  }
  /* Dropdown-links staan op witte achtergrond — donkere tekst forceren ongeacht nav-state */
  body.theme-navy nav.top.nav-overlay ul.dropdown a {
    color: var(--forest);
  }
  body.theme-navy nav.top.nav-overlay ul.dropdown a:hover {
    color: var(--orange);
  }
  /* Em-words op donkere secties → lime accent ipv orange (lime pop op navy) */
  body.theme-navy .downloads .section-head h2 em,
  body.theme-navy .insta .head h3 em,
  body.theme-navy .author-text h3 em,
  body.theme-navy .cta-banner-content h2 em {
    color: var(--lime);
  }
  /* Scrolled state — puur wit, navy tekst */
  body.theme-navy nav.top.nav-overlay.scrolled {
    background: #ffffff;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border-bottom: 1px solid var(--line);
  }
  body.theme-navy nav.top.nav-overlay.scrolled .logo,
  body.theme-navy nav.top.nav-overlay.scrolled ul a {
    color: var(--forest);
  }
  body.theme-navy nav.top.nav-overlay.scrolled .logo span {
    color: var(--orange);
  }
  body.theme-navy nav.top.nav-overlay.scrolled ul a:hover {
    color: var(--orange);
  }

  /* HERO — bold uppercase headline-stijl met sterk donker overlay */
  body.theme-navy .hero-bg {
    background:
      linear-gradient(rgba(6,50,49,0.78), rgba(6,50,49,0.78)),
      url('hero-foto.jpg') center 15%/cover no-repeat;
    align-items: center;
    height: calc(100vh - 100px);
    min-height: 540px;
  }
  /* Witte radial-glow + SVG-silhouet uitzetten — was bedoeld voor het oude palet */
  body.theme-navy .hero-bg::before { display: none; }
  body.theme-navy .hero-content {
    padding: 100px 60px;
  }
  body.theme-navy .hero-content .text {
    max-width: 1000px;
  }
  body.theme-navy .hero-content h1 {
    font-family: 'Oswald', sans-serif;
    font-size: 86px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: -0.02em;
    line-height: 0.95;
    margin-top: 0;
    margin-bottom: 36px;
    color: #ffffff;
    text-shadow: none;
  }
  body.theme-navy .hero-content h1 em {
    font-style: normal;
    font-weight: 700;
    color: var(--lime);
  }
  /* Word-cycle (typemachine-effect): zelfde gewicht als de h1, autobreedte */
  body.theme-navy .hero-content h1 .word-cycle {
    min-width: 0;
  }
  body.theme-navy .hero-content h1 .word-cycle-text {
    font-weight: 700;
    color: #ffffff;
  }
  body.theme-navy .hero-content h1 .word-cycle-cursor {
    background: var(--lime);
  }
  body.theme-navy .hero-content .lead {
    font-size: 20px;
    font-weight: 400;
    max-width: 520px;
    margin-bottom: 44px;
    line-height: 1.55;
    color: rgba(255,255,255,0.92);
  }
  body.theme-navy .hero-content .actions {
    flex-direction: row;
    align-items: center;
    gap: 0;
  }

  /* TWO PATHS — moderne kaart-stijl: witte sectie, grijze kaarten, bold uppercase titels */
  body.theme-navy .paths {
    background: #ffffff;
  }
  body.theme-navy .path {
    background: #f5f7f7;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: none;
    border: none;
    display: flex;
    flex-direction: column;
    transition: transform 0.35s ease, box-shadow 0.35s ease;
    position: relative;
    cursor: pointer;
  }
  /* Stretched-link patroon: hele kaart wordt klikbaar via de path-link href */
  body.theme-navy .path-link::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
  }
  body.theme-navy .path:hover {
    transform: none;
    box-shadow: none;
  }
  body.theme-navy .path-photo {
    aspect-ratio: 16/9;
    border-radius: 12px 12px 0 0;
  }
  body.theme-navy .path-body {
    padding: 44px 44px 40px;
  }
  /* Kaart-titel: bold uppercase, geen italic em — uniform donker */
  body.theme-navy .path h3 {
    font-family: 'Oswald', sans-serif;
    font-size: clamp(28px, 3.2vw, 38px);
    font-weight: 700;
    text-transform: uppercase;
    color: var(--forest);
    letter-spacing: -0.01em;
    line-height: 1;
    margin-bottom: 22px;
  }
  body.theme-navy .path h3 em {
    font-style: normal;
    font-weight: 700;
    color: var(--orange);
  }
  /* Beschrijving: 18px Public Sans */
  body.theme-navy .path > .path-body > p {
    font-family: 'Public Sans', sans-serif;
    font-size: 18px;
    color: var(--ink);
    line-height: 1.6;
    margin-bottom: 28px;
    min-height: 0;
  }
  /* Lijst: oranje pijltjes ipv bullets, 18px tekst, perfect uitgelijnd */
  body.theme-navy .path-body ul {
    list-style: none;
    padding: 0;
    margin: 0 0 32px 0;
  }
  body.theme-navy .path-body ul li {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 0;
    border-bottom: none;
    font-family: 'Public Sans', sans-serif;
    font-size: 18px;
    color: var(--ink);
    margin-bottom: 14px;
    line-height: 1.5;
  }
  body.theme-navy .path-body ul li::before {
    content: "";
    position: static;
    width: 24px;
    height: 24px;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c3df94' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><line x1='5' y1='12' x2='19' y2='12'/><polyline points='13 6 19 12 13 18'/></svg>");
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    flex-shrink: 0;
  }
  body.theme-navy .path-body ul li:last-child {
    margin-bottom: 0;
  }
  /* "Meer weten ↗" link in oranje uppercase met geanimeerde diagonale pijl */
  body.theme-navy .path-cta {
    margin-top: auto;
    padding-top: 24px;
  }
  body.theme-navy .path-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: 'Oswald', sans-serif;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: 0;
    text-transform: uppercase;
    color: var(--orange);
    text-decoration: none;
    transition: color 0.2s ease;
  }
  body.theme-navy .path-link:hover {
    color: var(--orange-dark);
  }
  body.theme-navy .path-link .arrow {
    display: inline-block;
    transition: transform 0.3s ease;
    flex-shrink: 0;
  }
  /* Bij hover draait de SVG-pijl naar horizontaal rechts */
  body.theme-navy .path-link:hover .arrow {
    transform: rotate(45deg);
  }
  /* Photo-tag — bold magazine label, kleurgecodeerd per pad */
  body.theme-navy .path-photo .photo-tag {
    position: absolute;
    top: 0;
    left: 0;
    padding: 12px 20px;
    background: var(--orange);
    color: #ffffff;
    font-family: 'Oswald', sans-serif;
    font-weight: 700;
    font-size: 15px;
    letter-spacing: 0;
    text-transform: uppercase;
    border-radius: 0;
  }
  /* Voor koppels-kaart krijgt lime ipv oranje voor visuele differentiatie */
  body.theme-navy .path.couples .path-photo .photo-tag {
    background: var(--lime);
    color: #000000;
  }

  /* OVER FERRY — extra spacing voor de CTA-button */
  body.theme-navy .about-cta {
    margin-top: 36px;
  }
  /* Over Ferry — afgeronde hoeken op tekst-blok en foto */
  body.theme-navy .about-text-block {
    border-radius: 12px;
  }
  body.theme-navy .about-photo {
    border-radius: 12px;
  }

  /* WERKBOEKEN (downloads/products) — refresh: solid covers, bold typografie */
  body.theme-navy .downloads .eyebrow {
    color: var(--lime-dark);
  }
  body.theme-navy .product {
    border-radius: 12px;
    background: #ffffff;
    overflow: hidden;
  }
  /* Drie cover-kleuren: oranje, lime, navy — alle in palette, alle solide */
  body.theme-navy .product .cover {
    border-radius: 12px 12px 0 0;
    aspect-ratio: 4/3;
    background: var(--orange);
    display: flex;
    align-items: flex-end;
    padding: 32px;
  }
  body.theme-navy .product:nth-child(2) .cover {
    background: var(--lime);
  }
  body.theme-navy .product:nth-child(3) .cover {
    background: var(--forest);
  }
  body.theme-navy .product .cover h4 {
    font-family: 'Oswald', sans-serif;
    font-size: clamp(28px, 2.6vw, 34px);
    font-weight: 700;
    text-transform: uppercase;
    text-shadow: none;
    color: #ffffff;
    line-height: 0.95;
    letter-spacing: -0.01em;
  }
  body.theme-navy .product:nth-child(2) .cover h4 {
    color: #000000;
  }
  /* Body styling: tag in Oswald, prijs bold, button compact */
  body.theme-navy .product .body {
    padding: 28px 32px 32px;
    flex: 1;
    display: flex;
    flex-direction: column;
  }
  body.theme-navy .product .tag {
    font-family: 'Oswald', sans-serif;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--ink-soft);
    margin-bottom: 14px;
  }
  body.theme-navy .product .body p {
    font-family: 'Public Sans', sans-serif;
    font-size: 16px;
    line-height: 1.55;
    color: var(--ink);
    margin-bottom: 24px;
    flex: 1;
  }
  body.theme-navy .product .price-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
  }
  body.theme-navy .product .price {
    font-family: 'Oswald', sans-serif;
    font-size: 30px;
    font-weight: 700;
    color: var(--forest);
    letter-spacing: -0.01em;
  }
  /* "Bekijken"-button compacter dan default btn-padding (20x30 is te groot voor kaart) */
  body.theme-navy .product .btn-accent {
    padding: 14px 22px;
    font-size: 14px;
  }

  /* FOOTER — strakke single-row met email links + utility */
  body.theme-navy footer {
    padding: 28px 0;
  }
  body.theme-navy .footer-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 40px;
    flex-wrap: wrap;
  }
  body.theme-navy .footer-email {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    color: #ffffff;
    font-family: 'Public Sans', sans-serif;
    font-size: 16px;
    transition: color 0.2s ease;
  }
  body.theme-navy .footer-email:hover {
    color: var(--lime);
  }
  body.theme-navy .footer-utility {
    display: flex;
    gap: 50px;
    list-style: none;
    margin: 0;
    padding: 0;
    flex-wrap: wrap;
  }
  body.theme-navy .footer-utility li { margin: 0; }
  body.theme-navy .footer-utility a,
  body.theme-navy .footer-utility span {
    color: #ffffff;
    font-family: 'Oswald', sans-serif;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: 600;
    transition: color 0.2s ease;
  }
  body.theme-navy .footer-utility a:hover {
    color: var(--lime);
  }
  /* Mobiel: stack onder elkaar */
  @media (max-width: 860px) {
    body.theme-navy .footer-row {
      flex-direction: column;
      align-items: flex-start;
      gap: 24px;
    }
    body.theme-navy .footer-utility {
      gap: 20px 32px;
    }
  }

  /* INSTAGRAM — bold statement, geen foto's, oranje CTA */
  body.theme-navy .insta {
    background: var(--forest-dark);
    padding: 110px 0;
    text-align: center;
  }
  body.theme-navy .insta-statement {
    max-width: 760px;
    margin: 0 auto;
  }
  body.theme-navy .insta-statement .eyebrow {
    color: var(--lime-dark);
    margin-bottom: 24px;
    line-height: 1;
  }
  body.theme-navy .insta-statement h2 {
    font-family: 'Oswald', sans-serif;
    font-size: 60px;
    font-weight: 700;
    color: #ffffff;
    text-transform: uppercase;
    letter-spacing: -0.02em;
    line-height: 0.98;
    margin-bottom: 28px;
  }
  body.theme-navy .insta-statement h2 em {
    font-style: normal;
    font-weight: 700;
    color: var(--lime);
  }
  body.theme-navy .insta-statement p {
    font-family: 'Public Sans', sans-serif;
    font-size: 18px;
    line-height: 1.6;
    color: rgba(255,255,255,0.85);
    margin-bottom: 40px;
    max-width: 560px;
    margin-left: auto;
    margin-right: auto;
  }
  body.theme-navy .insta-statement strong {
    color: #ffffff;
    font-weight: 700;
  }
  /* Mobiel: kleinere titel */
  @media (max-width: 860px) {
    body.theme-navy .insta { padding: 70px 0; }
    body.theme-navy .insta-statement h2 { font-size: 36px; }
    body.theme-navy .insta-statement p { font-size: 16px; }
  }

  /* TESTIMONIALS — boxed layout met slider, geen foto's */
  body.theme-navy .testimonial {
    background: #ffffff;
  }
  body.theme-navy .testimonial-box {
    background: #f5f7f7;
    border-radius: 28px;
    padding: 80px 90px;
  }
  body.theme-navy .testimonial-grid {
    display: grid;
    grid-template-columns: 1.1fr 1.3fr;
    gap: 80px;
    align-items: stretch;
  }
  body.theme-navy .testimonial-intro {
    display: flex;
    flex-direction: column;
  }
  body.theme-navy .testimonial-intro .eyebrow {
    margin-bottom: 24px;
    line-height: 1;
    color: var(--lime-dark);
  }
  body.theme-navy .testimonial-intro h2 {
    font-family: 'Oswald', sans-serif;
    font-size: 60px;
    font-weight: 700;
    color: var(--forest);
    text-transform: uppercase;
    letter-spacing: -0.02em;
    line-height: 0.98;
    margin: 0;
  }
  body.theme-navy .testimonial-intro h2 em {
    font-style: normal;
    font-weight: 700;
    color: var(--orange);
  }
  /* Slider-knoppen onderaan de intro-kolom */
  body.theme-navy .testimonial-nav {
    display: flex;
    gap: 12px;
    margin-top: auto;
    padding-top: 60px;
  }
  body.theme-navy .testimonial-nav button {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.25s ease, color 0.25s ease, transform 0.25s ease;
    padding: 0;
  }
  body.theme-navy .t-prev {
    background: #ffffff;
    color: var(--forest);
  }
  body.theme-navy .t-prev:hover {
    background: var(--forest);
    color: #ffffff;
  }
  body.theme-navy .t-next {
    background: var(--orange);
    color: #ffffff;
  }
  body.theme-navy .t-next:hover {
    background: var(--orange-dark);
  }

  /* Quote-kolom met verticale lijn als scheiding */
  body.theme-navy .testimonial-content {
    border-left: 1px solid rgba(6,50,49,0.18);
    padding-left: 80px;
    position: relative;
    min-height: 320px;
  }
  body.theme-navy .testimonial-item {
    opacity: 0;
    visibility: hidden;
    position: absolute;
    inset: 0 0 0 80px;
    transition: opacity 0.4s ease;
  }
  body.theme-navy .testimonial-item.active {
    opacity: 1;
    visibility: visible;
    position: relative;
    inset: auto;
  }
  body.theme-navy .stars {
    color: var(--lime-dark);
    font-size: 22px;
    letter-spacing: 4px;
    margin-bottom: 28px;
    line-height: 1;
  }
  body.theme-navy .testimonial-content blockquote {
    font-family: 'Public Sans', sans-serif;
    font-size: 24px;
    font-weight: 700;
    color: var(--forest);
    line-height: 1.25;
    letter-spacing: -0.005em;
    margin: 0 0 36px 0;
  }
  body.theme-navy .testimonial-author strong {
    display: block;
    font-family: 'Oswald', sans-serif;
    font-size: 18px;
    font-weight: 700;
    color: var(--forest);
    text-transform: uppercase;
    letter-spacing: 0;
    margin-bottom: 6px;
  }
  body.theme-navy .testimonial-author span {
    font-family: 'Public Sans', sans-serif;
    font-size: 16px;
    color: var(--ink);
  }

  /* Mobiel: stack alles, geen verticale lijn */
  @media (max-width: 860px) {
    body.theme-navy .testimonial-box { padding: 50px 30px; }
    body.theme-navy .testimonial-grid {
      grid-template-columns: 1fr;
      gap: 40px;
    }
    body.theme-navy .testimonial-intro h2 { font-size: 38px; }
    body.theme-navy .testimonial-content {
      border-left: none;
      border-top: 1px solid rgba(6,50,49,0.18);
      padding-left: 0;
      padding-top: 40px;
    }
    body.theme-navy .testimonial-item {
      inset: 40px 0 0 0;
    }
    body.theme-navy .testimonial-item.active {
      inset: auto;
    }
  }

  /* CTA-FINAL — "in beweging" beweegt zelf zachtjes mee */
  body.theme-navy .cta-final h2 .move-word {
    display: inline-block;
    animation: wordSlide 3.5s ease-in-out infinite;
    will-change: transform;
  }

  /* BLOG — twee-koloms layout: intro links, drie horizontale kaarten rechts */
  body.theme-navy .blog {
    background: var(--cream-dark);
  }
  body.theme-navy .blog .container {
    max-width: 1320px;
  }
  body.theme-navy .blog-layout {
    display: grid;
    grid-template-columns: 0.85fr 1.4fr;
    gap: 80px;
    align-items: start;
  }
  /* Eyebrow visueel uitlijnen met de top van de eerste kaart */
  body.theme-navy .blog-intro .eyebrow {
    margin-top: 0;
    margin-bottom: 24px;
    line-height: 1;
  }
  body.theme-navy .blog-intro h2 {
    font-family: 'Oswald', sans-serif;
    font-size: 60px;
    font-weight: 700;
    color: var(--forest);
    text-transform: uppercase;
    letter-spacing: -0.02em;
    line-height: 0.98;
    margin-bottom: 28px;
  }
  body.theme-navy .blog-intro h2 em {
    font-style: normal;
    font-weight: 700;
    color: var(--orange);
  }
  body.theme-navy .blog-intro p {
    font-family: 'Public Sans', sans-serif;
    font-size: 18px;
    line-height: 1.6;
    color: var(--ink);
    margin-bottom: 36px;
    max-width: 460px;
  }
  /* Stack van 3 horizontale post-kaarten */
  body.theme-navy .blog-list {
    display: flex;
    flex-direction: column;
    gap: 24px;
    padding: 0;
  }
  body.theme-navy .blog-card {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 0;
    background: #ffffff;
    border-radius: 12px;
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
  }
  body.theme-navy .blog-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 40px -20px rgba(6,50,49,0.18);
  }
  body.theme-navy .blog-card-photo {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 180px;
    background-image: url('gamen-met-pap.jpg');
    background-size: cover;
    background-position: center;
  }
  body.theme-navy .blog-card-photo--2 { background-image: url('foto-relatiecoaching.jpg'); }
  body.theme-navy .blog-card-photo--3 { background-image: url('foto-opvoeding.jpg'); }
  body.theme-navy .blog-card-body {
    padding: 28px 32px;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  body.theme-navy .blog-card-meta {
    font-family: 'Public Sans', sans-serif;
    font-size: 14px;
    color: var(--ink-soft);
    margin-bottom: 12px;
  }
  body.theme-navy .blog-card-meta .sep {
    margin: 0 8px;
    opacity: 0.5;
  }
  body.theme-navy .blog-card-meta a {
    color: var(--lime-dark);
    font-weight: 600;
    transition: color 0.2s ease;
  }
  body.theme-navy .blog-card-meta a:hover {
    color: var(--orange);
  }
  body.theme-navy .blog-card h4 {
    font-family: 'Oswald', sans-serif;
    font-size: 28px;
    font-weight: 700;
    color: var(--forest);
    text-transform: uppercase;
    letter-spacing: -0.005em;
    line-height: 1.15;
    margin-bottom: 16px;
  }
  body.theme-navy .blog-card h4 a {
    color: inherit;
  }
  body.theme-navy .blog-card h4 a:hover {
    color: var(--orange);
  }
  body.theme-navy .blog-card-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: 'Oswald', sans-serif;
    font-size: 16px;
    font-weight: 600;
    color: var(--orange);
    text-transform: uppercase;
    letter-spacing: 0;
    transition: color 0.2s ease;
  }
  body.theme-navy .blog-card-link:hover {
    color: var(--orange-dark);
  }
  body.theme-navy .blog-card-link .arrow {
    display: inline-block;
    transition: transform 0.3s ease;
    flex-shrink: 0;
  }
  body.theme-navy .blog-card-link:hover .arrow,
  body.theme-navy .blog-card:hover .blog-card-link .arrow {
    transform: rotate(45deg);
  }
  body.theme-navy .blog-card:hover .blog-card-link {
    color: var(--orange-dark);
  }
  /* Mobiel: stack alles, photo bovenaan elke kaart */
  @media (max-width: 860px) {
    body.theme-navy .blog-layout {
      grid-template-columns: 1fr;
      gap: 50px;
    }
    body.theme-navy .blog-card {
      grid-template-columns: 1fr;
    }
    body.theme-navy .blog-card-photo {
      min-height: 200px;
      aspect-ratio: 16/9;
    }
    body.theme-navy .blog-intro h2 {
      font-size: 42px;
    }
  }

  /* WERKWIJZE — drie horizontale ronde stappen met genummerde badges en gestreepte pijlen */
  body.theme-navy .approach {
    background: var(--cream-dark);
  }
  body.theme-navy .approach .container {
    max-width: 1320px;
  }
  body.theme-navy .steps-row {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: 20px;
    margin-top: 60px;
  }
  body.theme-navy .step {
    flex: 1 1 0;
    max-width: 340px;
    text-align: center;
  }
  body.theme-navy .step-circle {
    position: relative;
    width: 220px;
    height: 220px;
    margin: 0 auto 56px;
  }
  body.theme-navy .step-photo {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background-size: cover;
    background-position: center;
    background-color: var(--cream-dark);
  }
  /* Oude ::after dashed border uitzetten — vervangen door SVG ring die roteert */
  body.theme-navy .step-circle::after { display: none; }
  /* Roterende dashed ring rond de foto, met grote gaps tussen streepjes */
  body.theme-navy .step-ring {
    position: absolute;
    inset: -10px;
    width: calc(100% + 20px);
    height: calc(100% + 20px);
    color: var(--forest);
    opacity: 0.45;
    pointer-events: none;
    animation: stepRingRotate 40s linear infinite;
  }
  @keyframes stepRingRotate {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
  }
  /* Genummerde badge rechtsboven op de cirkel — hover wisselt naar oranje */
  body.theme-navy .step-number {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--forest);
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Oswald', sans-serif;
    font-weight: 600;
    font-size: 15px;
    letter-spacing: 0.04em;
    z-index: 2;
    transition: background 0.25s ease, color 0.25s ease;
  }
  body.theme-navy .step:hover .step-number {
    background: var(--orange);
    color: #ffffff;
  }
  /* Achtergrond-stippen verbergen op werkwijze */
  body.theme-navy .approach-dots { display: none; }
  /* Step-titel: bold uppercase, donker petrol */
  body.theme-navy .step h4 {
    font-family: 'Oswald', sans-serif;
    font-size: 24px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--forest);
    margin-bottom: 14px;
    letter-spacing: -0.005em;
    line-height: 1.05;
  }
  body.theme-navy .step p {
    font-family: 'Public Sans', sans-serif;
    font-size: 16px;
    line-height: 1.6;
    color: var(--ink);
    max-width: 280px;
    margin: 0 auto;
  }
  /* Pijl-SVG tussen de cirkels: gecentreerd op de fotomidden (110px in 220px-cirkel) */
  body.theme-navy .step-arrow {
    flex: 0 0 auto;
    width: 153px;
    height: 153px;
    margin-top: 34px;
    color: #a0a8a4;
  }
  /* Eerste pijl in spiegelbeeld — boog aan bovenkant */
  body.theme-navy .steps-row .step-arrow:first-of-type {
    transform: scaleY(-1);
  }
  /* Mobiel: stappen onder elkaar, pijlen verstoppen (zou rechtop moeten staan) */
  @media (max-width: 860px) {
    body.theme-navy .steps-row {
      flex-direction: column;
      align-items: center;
      gap: 50px;
    }
    body.theme-navy .step {
      max-width: 360px;
    }
    body.theme-navy .step-arrow {
      display: none;
    }
    body.theme-navy .step-circle {
      width: 200px;
      height: 200px;
    }
    body.theme-navy .step-number {
      width: 42px;
      height: 42px;
      font-size: 14px;
    }
  }

  /* MOBIELE HEADER — fixes voor onder 860px viewport */
  @media (max-width: 860px) {
    /* nav-cta button verbergen op mobiel — hamburger neemt het over */
    body.theme-navy nav.top > .nav-cta { display: none !important; }

    /* Hamburger-spans wit op transparante nav, navy bij scrolled state */
    body.theme-navy nav.top.nav-overlay .nav-hamburger span {
      background: #ffffff;
    }
    body.theme-navy nav.top.nav-overlay.scrolled .nav-hamburger span {
      background: var(--forest);
    }
    /* Wanneer het mobiele menu open is, sluit-X moet zichtbaar zijn tegen witte menu-bg */
    body.theme-navy nav.top.nav-overlay .nav-hamburger.is-open span {
      background: var(--forest);
    }
    /* Logo moet ook donker zijn als het mobiele menu open is */
    body.theme-navy nav.top.nav-overlay:has(.nav-hamburger.is-open) .logo {
      color: var(--forest);
    }
    body.theme-navy nav.top.nav-overlay:has(.nav-hamburger.is-open) .logo span {
      color: var(--orange);
    }

    /* Mobile menu items in Oswald (zelfde stijl als desktop nav) */
    body.theme-navy .mobile-menu ul a,
    body.theme-navy .mobile-menu .has-submenu .submenu-toggle,
    body.theme-navy .mobile-menu .mobile-submenu a {
      font-family: 'Oswald', sans-serif;
      letter-spacing: 0.14em;
    }

    /* Mobile menu CTA gebruikt de nieuwe lime button-stijl */
    body.theme-navy .mobile-menu .mobile-cta {
      background: var(--lime);
      color: #000000;
      font-family: 'Oswald', sans-serif;
      font-weight: 600;
      font-size: 16px;
      text-transform: uppercase;
      letter-spacing: 0;
      border-radius: 12px;
      padding: 18px 28px;
    }
    body.theme-navy .mobile-menu .mobile-cta:hover {
      background: var(--lime-dark);
      color: #000000;
    }

    /* Hero op mobiel: kleinere typografie en padding */
    body.theme-navy .hero-content { padding: 80px 24px; }
    body.theme-navy .hero-content h1 {
      font-size: clamp(36px, 9vw, 56px);
      margin-bottom: 24px;
    }
    body.theme-navy .hero-content .lead {
      font-size: 16px;
      margin-bottom: 28px;
      max-width: 100%;
    }

    /* Section titels kleiner op mobiel */
    body.theme-navy .section-head h2,
    body.theme-navy .about h2,
    body.theme-navy .blog-head h2,
    body.theme-navy .newsletter h2,
    body.theme-navy .cta-final h2 {
      font-size: 36px;
      margin-bottom: 28px;
    }
    body.theme-navy .cta-banner-content h2 {
      font-size: clamp(28px, 6.5vw, 40px);
    }

    /* Path-body padding kleiner zodat content past op mobiel */
    body.theme-navy .path-body { padding: 32px 28px; }
  }

  /* SCROLL-TO-TOP — verschijnt bij scrollen, oranje circle met witte pijl */
  body.theme-navy .scroll-top {
    position: fixed;
    bottom: 30px;
    right: 30px;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--orange);
    color: #ffffff;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: opacity 0.3s ease, transform 0.3s ease, background 0.25s ease, visibility 0.3s;
    z-index: 70;
    box-shadow: none;
    padding: 0;
  }
  body.theme-navy .scroll-top.visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }
  body.theme-navy .scroll-top:hover {
    background: var(--orange-dark);
  }

  /* WERKWIJZE — losse stippen die elk een eigen kant op drijven tijdens scroll */
  body.theme-navy .approach::before,
  body.theme-navy .approach::after { display: none; }
  body.theme-navy .approach { overflow: hidden; }
  body.theme-navy .approach-dots {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
  }
  body.theme-navy .approach-dots .dot {
    position: absolute;
    border-radius: 50%;
    background: #f75709;
    opacity: 0.4;
    will-change: transform;
  }
  body.theme-navy .approach > .container { position: relative; z-index: 1; }

  /* Nav: smooth transitions tussen transparant en scrolled state, lagere balk */
  body.theme-navy nav.top {
    padding: 18px 32px;
  }
  body.theme-navy nav.top.nav-overlay {
    top: 0;
    transition: background 0.35s ease, border-color 0.35s ease, backdrop-filter 0.35s ease;
  }

/* Niet-homepage nav: witte achtergrond ipv cream-tinted (geldt voor alle pagina's behalve homepage met .nav-overlay) */
body.theme-navy nav.top {
  background: #ffffff;
  border-bottom: 1px solid var(--line);
}

/* BLOG SUBHERO — centered section-head stijl (zelfde als homepage section-heads) */
body.theme-navy .blog-subhero {
  padding: 110px 0;
  background: #ffffff;
}
body.theme-navy .blog-subhero .section-head {
  text-align: center;
  max-width: 1200px;
  margin: 0 auto;
}
body.theme-navy .blog-subhero .section-head h1 {
  font-family: 'Oswald', sans-serif;
  font-size: 72px;
  font-weight: 700;
  color: var(--forest);
  text-transform: uppercase;
  letter-spacing: -0.02em;
  line-height: 0.98;
  margin-bottom: 28px;
}
body.theme-navy .blog-subhero .section-head h1 em {
  font-style: normal;
  font-weight: 700;
  color: var(--orange);
}
body.theme-navy .blog-subhero .section-head p {
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  line-height: 1.65;
  color: var(--ink);
  max-width: 580px;
  margin: 0 auto;
}
@media (max-width: 860px) {
  body.theme-navy .blog-subhero { padding: 70px 0; }
  body.theme-navy .blog-subhero .section-head h1 { font-size: 44px; }
}

/* BLOG TOOLBAR — search + categorie-pills in battery-fill stijl */
body.theme-navy .blog-toolbar {
  padding: 30px 0 60px;
  background: #ffffff;
}
body.theme-navy .blog-toolbar {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}

/* SEARCH — line-style input met cycling placeholder, gecentreerd */
body.theme-navy .blog-search {
  position: relative;
  flex: 0 0 auto;
  width: 100%;
  max-width: 520px;
}
body.theme-navy .blog-search input {
  width: 100%;
  padding: 18px 18px 18px 48px;
  border: none;
  border-bottom: 2px solid var(--line);
  border-radius: 0;
  background: transparent;
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  color: var(--ink);
  transition: border-color 0.25s ease;
}
body.theme-navy .blog-search input::placeholder {
  color: var(--ink-soft);
  font-style: italic;
  transition: opacity 0.4s ease;
}
body.theme-navy .blog-search input:focus {
  outline: none;
  border-bottom-color: var(--orange);
}
body.theme-navy .blog-search input:focus::placeholder {
  opacity: 0.4;
}
body.theme-navy .blog-search .search-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--orange);
  pointer-events: none;
  display: flex;
  transition: transform 0.25s ease;
}
body.theme-navy .blog-search:focus-within .search-icon {
  transform: translateY(-50%) scale(1.1);
}

/* CATEGORIE PILLS — battery-fill stijl */
body.theme-navy .blog-categories {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  max-width: 900px;
  margin: 0 auto;
}
/* Forceer max 5 items per rij, met centering: grid override met line-break na 5e item */
body.theme-navy .blog-categories::after {
  content: "";
  flex-basis: 100%;
  height: 0;
  order: 5;
}
body.theme-navy .blog-categories > a:nth-child(n+6) {
  order: 6;
}
body.theme-navy .cat-pill {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  padding: 12px 22px;
  background: var(--cream-dark);
  color: var(--forest);
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border-radius: 12px;
  border: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  transition: color 0.25s ease, background 0.25s ease;
}
body.theme-navy .cat-pill::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 0;
  background: var(--orange);
  transition: width 0.4s ease;
  z-index: -1;
}
body.theme-navy .cat-pill:hover::before {
  width: 100%;
}
body.theme-navy .cat-pill:hover {
  color: #ffffff;
}
/* Active state: gevuld oranje permanent */
body.theme-navy .cat-pill.is-active {
  color: #ffffff;
  background: var(--orange);
}
body.theme-navy .cat-pill.is-active::before {
  width: 100%;
}
/* Aantal-badge: subtieler */
body.theme-navy .cat-pill span {
  font-size: 11px;
  opacity: 0.7;
  font-weight: 400;
  letter-spacing: 0;
}
body.theme-navy .cat-pill.is-active span,
body.theme-navy .cat-pill:hover span {
  opacity: 0.9;
}

@media (max-width: 860px) {
  body.theme-navy .blog-toolbar .container {
    align-items: stretch;
  }
  body.theme-navy .blog-categories {
    justify-content: center;
  }
  body.theme-navy .blog-categories::after {
    display: none;
  }
  body.theme-navy .blog-categories > a:nth-child(n+6) {
    order: initial;
  }
}

/* DISCOVER BLOCK — search + categorieën + featured artikel in één blok */
body.theme-navy .blog-discover {
  background: var(--cream-dark);
  padding: 60px 0 80px;
}
/* Blog-list krijgt zelfde grijze bg als discover-blok zodat de witte kaarten poppen */
body.theme-navy .blog-list {
  background: var(--cream-dark);
  padding-top: 0;
  padding-bottom: 80px;
}
/* Discover en list lopen visueel in elkaar over (één grote grijze artikel-area) */
body.theme-navy .blog-discover {
  padding-bottom: 80px;
}
body.theme-navy .blog-discover .blog-toolbar {
  padding: 0;
  background: transparent;
  margin-bottom: 60px;
}
body.theme-navy .blog-discover .blog-featured {
  padding: 0;
  background: transparent;
}
/* Featured artikel binnen het blok krijgt witte achtergrond zodat het pop op de grijze container */
body.theme-navy .blog-discover .featured-post {
  background: #ffffff;
  border-radius: 16px;
  overflow: hidden;
}


/* Category pills binnen het grijze blog-discover blok: witte bg ipv cream-dark */
body.theme-navy .blog-discover .cat-pill {
  background: #ffffff;
}
body.theme-navy .blog-discover .cat-pill.is-active {
  background: var(--orange);
}
/* Search-input binnen het grijze blok: witte onderlijn-achtergrond niet nodig, transparant blijft */

/* FEATURED POST — uitgelicht artikel in moderne stijl, twee-koloms */
body.theme-navy .blog-discover .featured-post {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  align-items: stretch;
  background: #ffffff;
  border-radius: 16px;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
body.theme-navy .blog-discover .featured-post:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 50px -22px rgba(6,50,49,0.18);
}
body.theme-navy .blog-discover .featured-photo {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 360px;
  background-image: url('foto-relatiecoaching.jpg');
  background-size: cover;
  background-position: center;
}
body.theme-navy .blog-discover .featured-body {
  padding: 50px 56px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
}
body.theme-navy .blog-discover .featured-tag {
  font-family: 'Oswald', sans-serif;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--orange);
  margin-bottom: 18px;
  border: none;
  background: transparent;
  padding: 0;
}
body.theme-navy .blog-discover .featured-body .meta {
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  color: var(--ink-soft);
  margin-bottom: 18px;
}
body.theme-navy .blog-discover .featured-body .meta .sep {
  margin: 0 8px;
  opacity: 0.5;
}
body.theme-navy .blog-discover .featured-body .meta .cat {
  color: var(--lime-dark);
  font-weight: 600;
}
body.theme-navy .blog-discover .featured-body .meta .cat:hover {
  color: var(--orange);
}
body.theme-navy .blog-discover .featured-body h2 {
  font-family: 'Oswald', sans-serif;
  font-size: 36px;
  font-weight: 700;
  color: var(--forest);
  text-transform: uppercase;
  letter-spacing: -0.005em;
  line-height: 1.1;
  margin-bottom: 22px;
}
body.theme-navy .blog-discover .featured-body h2 a {
  color: inherit;
  transition: color 0.2s ease;
}
body.theme-navy .blog-discover .featured-body h2 a:hover {
  color: var(--orange);
}
body.theme-navy .blog-discover .featured-body p {
  font-family: 'Public Sans', sans-serif;
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink);
  margin-bottom: 28px;
}
body.theme-navy .blog-discover .featured-body .read {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: var(--orange);
  text-transform: uppercase;
  letter-spacing: 0;
  text-decoration: none;
  border: none;
  padding: 0;
  transition: color 0.2s ease;
}
body.theme-navy .blog-discover .featured-body .read:hover {
  color: var(--orange-dark);
}
body.theme-navy .blog-discover .featured-body .read .arrow {
  display: inline-block;
  transition: transform 0.3s ease;
  flex-shrink: 0;
}
body.theme-navy .blog-discover .featured-body .read:hover .arrow,
body.theme-navy .blog-discover .featured-post:hover .read .arrow {
  transform: rotate(45deg);
}
body.theme-navy .blog-discover .featured-post:hover .read {
  color: var(--orange-dark);
}

@media (max-width: 860px) {
  body.theme-navy .blog-discover .featured-post {
    grid-template-columns: 1fr;
  }
  body.theme-navy .blog-discover .featured-photo {
    min-height: 240px;
    aspect-ratio: 16/9;
  }
  body.theme-navy .blog-discover .featured-body {
    padding: 32px 28px;
  }
  body.theme-navy .blog-discover .featured-body h2 {
    font-size: 28px;
  }
}

/* ARTIKEL GRID — 9 posts in nieuwe stijl: vertikale kaart met foto-top */
body.theme-navy .blog-list .blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
body.theme-navy .blog-list .post {
  background: #ffffff;
  border-radius: 16px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  /* Reset oude post-styling */
  padding: 0;
  border: none;
}
body.theme-navy .blog-list .post:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 40px -20px rgba(6,50,49,0.18);
}
body.theme-navy .blog-list .post-photo {
  display: block;
  width: 100%;
  aspect-ratio: 16/10;
  background-image: url('gamen-met-pap.jpg');
  background-size: cover;
  background-position: center;
}
body.theme-navy .blog-list .post .meta {
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  color: var(--ink-soft);
  margin: 24px 28px 12px;
}
body.theme-navy .blog-list .post .meta .sep {
  margin: 0 8px;
  opacity: 0.5;
}
body.theme-navy .blog-list .post .meta .cat {
  color: var(--lime-dark);
  font-weight: 600;
}
body.theme-navy .blog-list .post .meta .cat:hover {
  color: var(--orange);
}
body.theme-navy .blog-list .post h4 {
  font-family: 'Oswald', sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--forest);
  text-transform: uppercase;
  letter-spacing: -0.005em;
  line-height: 1.2;
  margin: 0 28px 14px;
}
body.theme-navy .blog-list .post h4 a {
  color: inherit;
  transition: color 0.2s ease;
}
body.theme-navy .blog-list .post h4 a:hover,
body.theme-navy .blog-list .post:hover h4 a {
  color: var(--orange);
}
body.theme-navy .blog-list .post p {
  font-family: 'Public Sans', sans-serif;
  font-size: 15px;
  line-height: 1.6;
  color: var(--ink);
  margin: 0 28px 22px;
  flex: 1;
}
body.theme-navy .blog-list .post .read {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'Oswald', sans-serif;
  font-size: 15px;
  font-weight: 600;
  color: var(--orange);
  text-transform: uppercase;
  letter-spacing: 0;
  text-decoration: none;
  border: none;
  padding: 0;
  margin: 0 28px 28px;
  align-self: flex-start;
  transition: color 0.2s ease;
}
body.theme-navy .blog-list .post .read:hover,
body.theme-navy .blog-list .post:hover .read {
  color: var(--orange-dark);
}
body.theme-navy .blog-list .post .read .arrow {
  display: inline-block;
  transition: transform 0.3s ease;
  flex-shrink: 0;
  width: 20px;
  height: 20px;
}
body.theme-navy .blog-list .post .read:hover .arrow,
body.theme-navy .blog-list .post:hover .read .arrow {
  transform: rotate(45deg);
}

@media (max-width: 1100px) {
  body.theme-navy .blog-list .blog-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 700px) {
  body.theme-navy .blog-list .blog-grid {
    grid-template-columns: 1fr;
  }
}

/* PAGINATION — modern, in lijn met overige stijl */
body.theme-navy .blog-list .pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  margin-top: 80px;
  flex-wrap: wrap;
}
body.theme-navy .blog-list .pagination a,
body.theme-navy .blog-list .pagination .dots {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 48px;
  height: 48px;
  padding: 0 6px;
  background: #ffffff;
  color: var(--forest);
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 600;
  border: none;
  border-radius: 12px;
  text-decoration: none;
  transition: background 0.2s ease, color 0.2s ease;
}
body.theme-navy .blog-list .pagination a:hover {
  background: var(--lime);
  color: #000000;
}
body.theme-navy .blog-list .pagination a.active {
  background: var(--orange);
  color: #ffffff;
  cursor: default;
}
body.theme-navy .blog-list .pagination a.active:hover {
  background: var(--orange);
}
body.theme-navy .blog-list .pagination .dots {
  background: transparent;
  color: var(--ink-soft);
  font-weight: 400;
  letter-spacing: 0.1em;
}
body.theme-navy .blog-list .pagination .prev,
body.theme-navy .blog-list .pagination .next {
  border-radius: 50%;
  width: 48px;
  min-width: 48px;
}
body.theme-navy .blog-list .pagination .next {
  background: var(--orange);
  color: #ffffff;
  margin-left: 8px;
}
body.theme-navy .blog-list .pagination .next:hover {
  background: var(--orange-dark);
  color: #ffffff;
}
body.theme-navy .blog-list .pagination .prev {
  margin-right: 8px;
}
body.theme-navy .blog-list .pagination .prev:hover {
  background: var(--forest);
  color: #ffffff;
}

/* OVER FERRY — beide kaarten top-aligned, maar verschillende hoogtes */
body.theme-navy .about .grid {
  grid-template-columns: 1fr 1.2fr;
  align-items: start;
}
/* Foto wordt extra vertikaal (taller) zodat hij duidelijk hoger is dan tekstblok */
body.theme-navy .about-photo {
  aspect-ratio: 3/4;
}
/* Tekstblok houdt natuurlijke content-hoogte aan */
body.theme-navy .about-text-block {
  align-self: center;
  padding: 48px 50px;
}
/* Op mobiel terug naar verticale stack */
@media (max-width: 860px) {
  body.theme-navy .about .grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  body.theme-navy .about-text-block {
    padding: 32px 28px;
  }
  body.theme-navy .about-photo {
    aspect-ratio: 4/5;
    max-width: 100%;
    margin: 0 auto;
    background-position: center top;
  }
}

/* OVER FERRY — eigen background-kleur, warmer dan het grijze blok eronder */
body.theme-navy .about {
  background: #f5ede0;
}

/* SCHEDULE MODAL — fullscreen overlay voor "Plan een gesprek"-flow */
body.theme-navy .schedule-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s;
}
/* Tijdens de boekingsmodule: nav volledig verbergen (zit anders bovenop) */
body:has(.schedule-modal.is-open) nav.top {
  display: none;
}
body.theme-navy .schedule-modal.is-open {
  opacity: 1;
  visibility: visible;
}
body.theme-navy .schedule-modal-bg {
  position: absolute;
  inset: 0;
  background: var(--forest);
}
body.theme-navy .schedule-close {
  position: absolute;
  top: 24px;
  right: 24px;
  width: 56px;
  height: 56px;
  background: var(--orange);
  color: #ffffff;
  border: none;
  border-radius: 0;
  cursor: pointer;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s ease;
}
body.theme-navy .schedule-close:hover {
  background: var(--orange-dark);
}
body.theme-navy .schedule-modal-content {
  position: relative;
  z-index: 2;
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-columns: auto auto;
  align-items: center;
  justify-content: center;
  padding: 60px 80px;
  gap: 80px;
  overflow-y: auto;
}

/* LEFT — branding & contact */
body.theme-navy .schedule-left {
  color: #ffffff;
  display: flex;
  flex-direction: column;
  gap: 30px;
  max-width: 540px;
}
body.theme-navy .schedule-logo {
  font-family: 'Oswald', sans-serif;
  font-weight: 600;
  font-size: 22px;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: #ffffff;
}
body.theme-navy .schedule-logo span {
  color: var(--orange);
}
body.theme-navy .schedule-title {
  font-family: 'Oswald', sans-serif;
  font-size: 86px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.02em;
  line-height: 0.95;
  color: #ffffff;
  margin: 0;
}
body.theme-navy .schedule-title em {
  font-style: normal;
  font-weight: 700;
  color: var(--lime);
}
body.theme-navy .schedule-contact {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-family: 'Public Sans', sans-serif;
  font-size: 17px;
}
body.theme-navy .schedule-contact a {
  color: rgba(255,255,255,0.85);
  transition: color 0.2s ease;
}
body.theme-navy .schedule-contact a:hover {
  color: var(--lime);
}
body.theme-navy .schedule-social {
  display: flex;
  gap: 14px;
}
body.theme-navy .schedule-social a {
  color: rgba(255,255,255,0.7);
  transition: color 0.2s ease;
}
body.theme-navy .schedule-social a:hover {
  color: var(--lime);
}

/* RIGHT — form card */
body.theme-navy .schedule-right {
  display: flex;
  align-items: center;
}
body.theme-navy .schedule-form {
  background: #ffffff;
  border-radius: 16px;
  padding: 50px 50px 40px;
  width: 100%;
  max-width: 480px;
  box-shadow: 0 30px 80px -30px rgba(0,0,0,0.4);
  transition: max-width 0.3s ease;
}

/* Step 2 (cal.com agenda) actief: het linker info-paneel verbergen en het form
   over de volle modaal-breedte tonen — anders is er geen ruimte voor de week-view */
body.theme-navy .schedule-modal:has(.schedule-step[data-step="2"].is-active) .schedule-left {
  display: none;
}
body.theme-navy .schedule-modal:has(.schedule-step[data-step="2"].is-active) .schedule-modal-content {
  grid-template-columns: 1fr;
  padding: 60px 40px;
  gap: 0;
}
body.theme-navy .schedule-modal:has(.schedule-step[data-step="2"].is-active) .schedule-right {
  justify-content: center;
}
body.theme-navy .schedule-form:has(.schedule-step[data-step="2"].is-active) {
  max-width: 1100px;
}
body.theme-navy .schedule-form:has(.schedule-step[data-step="2"].is-active) .schedule-cal {
  min-height: 650px;
}
body.theme-navy .schedule-step {
  display: none;
}
body.theme-navy .schedule-step.is-active {
  display: block;
}
body.theme-navy .schedule-question {
  font-family: 'Oswald', sans-serif;
  font-size: 18px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--forest);
  margin: 0 0 14px;
}
body.theme-navy .schedule-options + .schedule-question {
  margin-top: 36px;
}
body.theme-navy .schedule-options {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 8px;
}
body.theme-navy .schedule-option {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  padding: 16px 18px;
  background: var(--cream-dark);
  color: var(--forest);
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0;
  border: 2px solid transparent;
  border-radius: 12px;
  cursor: pointer;
  transition: color 0.25s ease, border-color 0.25s ease;
}
body.theme-navy .schedule-option::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  height: 100%; width: 0;
  background: var(--orange);
  transition: width 0.4s ease;
  z-index: -1;
}
body.theme-navy .schedule-option:hover::before {
  width: 100%;
}
body.theme-navy .schedule-option:hover {
  color: #ffffff;
}
body.theme-navy .schedule-option.is-selected {
  background: var(--orange);
  color: #ffffff;
  border-color: var(--orange);
}
body.theme-navy .schedule-option.is-selected::before {
  width: 100%;
}
body.theme-navy .schedule-next {
  width: 100%;
  margin-top: 24px;
  justify-content: center;
}
body.theme-navy .schedule-next:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

/* Step 2 */
body.theme-navy .schedule-summary {
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  color: var(--ink-soft);
  margin: 0 0 20px;
}
body.theme-navy .schedule-cal {
  background: var(--cream-dark);
  border-radius: 12px;
  margin-bottom: 16px;
  width: 100%;
  position: relative;
}
body.theme-navy .schedule-cal iframe {
  width: 100%;
  border: none;
  display: block;
}
body.theme-navy .schedule-cal #schedule-cal-container {
  width: 100%;
  min-height: 580px;
}
body.theme-navy .schedule-note {
  font-size: 13px !important;
  color: var(--ink-soft) !important;
}
body.theme-navy .schedule-back {
  background: none;
  border: none;
  color: var(--orange);
  font-family: 'Oswald', sans-serif;
  font-size: 15px;
  font-weight: 600;
  text-transform: uppercase;
  cursor: pointer;
  padding: 0;
}
body.theme-navy .schedule-back:hover {
  color: var(--orange-dark);
}

/* Mobiel: één kolom */
@media (max-width: 860px) {
  body.theme-navy .schedule-modal-content {
    grid-template-columns: 1fr;
    padding: 90px 24px 40px;
    overflow-y: auto;
    align-items: start;
  }
  body.theme-navy .schedule-left {
    margin-left: 0;
    gap: 20px;
  }
  body.theme-navy .schedule-title { font-size: 52px; }
  body.theme-navy .schedule-form { padding: 32px 28px; }
}

/* HOMEPAGE BLOG-blok: minder margin onderaan */
body.theme-navy .blog {
  padding-bottom: 60px;
}

/* ════════════════════════════════════════════════════════════════════════
   CTA-INVITE — Ferry "staat" op de onderbalk, content links ernaast
   ════════════════════════════════════════════════════════════════════════ */
body.theme-navy .cta-invite {
  padding: 80px 0 0;
  background: var(--cream-dark);
  overflow: hidden;
}
/* Variant: witte achtergrond — voor pagina's waar cream te warm is */
body.theme-navy .cta-invite.cta-invite--white {
  background: #ffffff;
}
body.theme-navy .cta-invite-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 60px;
  align-items: end;
}
body.theme-navy .cta-invite-content {
  text-align: left;
  padding-bottom: 80px;
}
body.theme-navy .cta-invite-eyebrow {
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--orange);
  margin-bottom: 18px;
}
body.theme-navy .cta-invite-title {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(34px, 4.4vw, 56px);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--forest);
  margin: 0 0 22px;
}
body.theme-navy .cta-invite-title em {
  font-style: normal;
  color: var(--orange);
}
body.theme-navy .cta-invite-text {
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  line-height: 1.6;
  color: var(--ink);
  margin: 0 0 32px;
  max-width: 520px;
}
body.theme-navy .cta-invite-buttons {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}
body.theme-navy .cta-invite-signature {
  font-family: 'Reenie Beanie', cursive;
  font-size: 32px;
  line-height: 1;
  color: var(--forest);
  transform: rotate(-3deg);
  display: inline-block;
}
/* RECHTERKANT: Ferry-foto staat tegen de onderbalk aan */
body.theme-navy .cta-invite-figure {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: flex-end;
}
body.theme-navy .cta-invite-img {
  width: 100%;
  max-width: 420px;
  height: auto;
  display: block;
}
body.theme-navy .cta-invite-note {
  position: absolute;
  top: 10px;
  left: 0;
  font-family: 'Reenie Beanie', cursive;
  font-size: 30px;
  line-height: 1.05;
  color: var(--orange);
  transform: rotate(-6deg);
  text-align: left;
  z-index: 2;
  max-width: 180px;
}
@media (max-width: 860px) {
  body.theme-navy .cta-invite {
    padding: 70px 0 0;
  }
  body.theme-navy .cta-invite-grid {
    grid-template-columns: 1fr;
    gap: 30px;
    text-align: center;
  }
  body.theme-navy .cta-invite-content {
    text-align: center;
    padding-bottom: 0;
    order: 1;
  }
  body.theme-navy .cta-invite-figure {
    order: 2;
    justify-content: center;
  }
  body.theme-navy .cta-invite-text {
    margin-left: auto;
    margin-right: auto;
    font-size: 16px;
  }
  body.theme-navy .cta-invite-buttons {
    justify-content: center;
  }
  body.theme-navy .cta-invite-img {
    max-width: 280px;
  }
  body.theme-navy .cta-invite-note {
    top: 10px;
    left: 50%;
    transform: translateX(-90%) rotate(-6deg);
    max-width: 160px;
    text-align: center;
  }
}

/* OUDERS-FAQ THREAD — vraag als clickable bubble, antwoord als reply met avatar */
body.theme-navy .ouders-faq--slim {
  padding: 80px 0;
  background: var(--cream-dark);
}
body.theme-navy .ouders-faq--slim .section-head {
  margin-bottom: 50px;
}
body.theme-navy .ouders-faq--slim .faq-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 760px;
  margin: 0 auto;
}
body.theme-navy .ouders-faq--slim .faq-item {
  display: flex;
  flex-direction: column;
  background: #ffffff;
  border: none;
  border-radius: 10px;
  padding: 0;
  box-shadow: 0 2px 8px -4px rgba(6,50,49,0.10);
  transition: box-shadow 0.25s ease, transform 0.25s ease;
}
body.theme-navy .ouders-faq--slim .faq-item:hover {
  box-shadow: 0 10px 22px -14px rgba(6,50,49,0.22);
}
body.theme-navy .ouders-faq--slim .faq-item[open] {
  box-shadow: 0 12px 26px -16px rgba(247,87,9,0.25);
}
/* Vraag: witte kaart met oranje accent-streep links en chevron rechts */
body.theme-navy .ouders-faq--slim .faq-item summary {
  background: transparent;
  color: var(--forest);
  padding: 20px 22px 20px 30px;
  border: none;
  border-radius: 10px;
  list-style: none;
  cursor: pointer;
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0;
  transition: color 0.25s ease;
  display: flex;
  align-items: center;
  gap: 16px;
  position: relative;
}
/* Oranje accent-streep links, met kleine inset boven/onder */
body.theme-navy .ouders-faq--slim .faq-item summary::before {
  content: "";
  position: absolute;
  left: 10px;
  top: 12px;
  bottom: 12px;
  width: 4px;
  border-radius: 3px;
  background: var(--orange);
  transition: background 0.25s ease;
}
/* Push het chevron-icoontje naar rechts */
body.theme-navy .ouders-faq--slim .faq-icon {
  margin-left: auto;
}
body.theme-navy .ouders-faq--slim .faq-item summary::-webkit-details-marker {
  display: none;
}
body.theme-navy .ouders-faq--slim .faq-item summary:hover {
  color: var(--orange);
}
body.theme-navy .ouders-faq--slim .faq-item[open] summary {
  color: var(--orange);
}
/* SVG-pijltje rechts: standaard naar rechts (↗ geroteerd), bij open soepel naar beneden.
   Rotatie via individual `rotate` property zodat 'm soepel transitioneert. */
body.theme-navy .ouders-faq--slim .faq-icon {
  display: block;
  width: 22px;
  height: 22px;
  flex-shrink: 0;
  color: var(--forest);
  rotate: 45deg;
  transition: rotate 0.5s cubic-bezier(0.4, 0, 0.2, 1), color 0.25s ease;
}
body.theme-navy .ouders-faq--slim .faq-item summary:hover .faq-icon {
  color: var(--orange);
}
body.theme-navy .ouders-faq--slim .faq-item[open] .faq-icon {
  color: var(--orange);
  rotate: 135deg;
}
/* Ferry's antwoord: thread-reply met avatar links + donker petrol bubbel */
body.theme-navy .ouders-faq--slim .faq-answer {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin: 4px 22px 22px 30px;
  padding: 0;
  overflow: hidden;
  transition: height 0.42s cubic-bezier(0.4, 0, 0.2, 1),
              opacity 0.32s ease,
              margin-top 0.42s cubic-bezier(0.4, 0, 0.2, 1),
              margin-bottom 0.42s cubic-bezier(0.4, 0, 0.2, 1);
}
body.theme-navy .ouders-faq--slim .faq-answer::before {
  content: "";
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background:
    url('ferry-profiel.jpg') center/cover no-repeat,
    linear-gradient(135deg, var(--lime), var(--forest));
  flex-shrink: 0;
  margin-top: 5px;
}
body.theme-navy .ouders-faq--slim .faq-answer p {
  background: var(--forest);
  color: #ffffff;
  padding: 14px 20px;
  border-radius: 6px 18px 18px 18px;
  margin: 0;
  font-family: 'Public Sans', sans-serif;
  font-size: 16px;
  line-height: 1.55;
  box-shadow: 0 8px 20px -12px rgba(6,50,49,0.25);
  flex: 1;
}
@media (max-width: 860px) {
  body.theme-navy .ouders-faq--slim {
    padding: 60px 0;
  }
  body.theme-navy .ouders-faq--slim .faq-item summary {
    font-size: 17px;
    padding: 16px 18px 16px 26px;
    gap: 12px;
  }
  body.theme-navy .ouders-faq--slim .faq-answer {
    margin: 4px 16px 18px 22px;
    gap: 10px;
  }
  body.theme-navy .ouders-faq--slim .faq-answer::before {
    width: 36px;
    height: 36px;
  }
  body.theme-navy .ouders-faq--slim .faq-answer p {
    font-size: 15px;
  }
}

/* DOWNLOADS-LINK TOAST — verschijnt bovenin bij klik op downloads-menu-link */
body.theme-navy .soon-toast {
  position: fixed;
  top: 28px;
  left: 50%;
  transform: translateX(-50%) translateY(-140%);
  background: var(--forest);
  color: #ffffff;
  padding: 16px 28px;
  border-radius: 12px;
  font-family: 'Public Sans', sans-serif;
  font-size: 16px;
  font-weight: 500;
  opacity: 0;
  transition: opacity 0.4s ease, transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  z-index: 9999;
  pointer-events: none;
  box-shadow: 0 20px 50px -20px rgba(6,50,49,0.45),
              0 8px 16px -10px rgba(6,50,49,0.3);
  border-left: 4px solid var(--orange);
  max-width: calc(100vw - 40px);
}
body.theme-navy .soon-toast.is-visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
body.theme-navy .soon-toast-content {
  display: flex;
  align-items: center;
  gap: 12px;
  white-space: nowrap;
}
body.theme-navy .soon-toast-icon {
  color: var(--orange);
  flex-shrink: 0;
}
@media (max-width: 600px) {
  body.theme-navy .soon-toast {
    font-size: 14px;
    padding: 14px 20px;
  }
  body.theme-navy .soon-toast-content {
    white-space: normal;
  }
}

/* DOWNLOADS — "coming soon" overlay bij hover */
body.theme-navy .downloads-wrap {
  position: relative;
}
body.theme-navy .downloads-wrap .downloads-grid {
  transition: filter 0.45s ease, opacity 0.45s ease;
}
body.theme-navy .downloads-wrap:hover .downloads-grid {
  filter: blur(4px);
  opacity: 0.45;
  pointer-events: none;
}
body.theme-navy .downloads-soon {
  position: absolute;
  inset: -20px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.55);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.45s ease;
  z-index: 5;
  border-radius: 24px;
}
body.theme-navy .downloads-wrap:hover .downloads-soon {
  opacity: 1;
}
body.theme-navy .downloads-soon-card {
  background: var(--forest);
  color: #ffffff;
  padding: 44px 60px 36px;
  border-radius: 18px;
  text-align: center;
  border: none;
  box-shadow:
    0 30px 80px -25px rgba(6,50,49,0.5),
    0 12px 24px -12px rgba(6,50,49,0.3);
  transform: rotate(-1.5deg) scale(0.92);
  transition: transform 0.45s cubic-bezier(0.34, 1.56, 0.64, 1);
  position: relative;
  max-width: 440px;
}
body.theme-navy .downloads-wrap:hover .downloads-soon-card {
  transform: rotate(-1.5deg) scale(1);
}
/* Punaise van schuin bovenaf — alsof-ie schuin in de kaart is geprikt */
body.theme-navy .downloads-soon-card::before {
  content: "";
  position: absolute;
  top: -18px;
  left: 50%;
  transform: translateX(-50%) rotate(-12deg);
  transform-origin: 50% 100%;
  width: 32px;
  height: 40px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 40'><rect x='14' y='18' width='4' height='20' rx='1' fill='%23a0a0a0'/><rect x='14' y='18' width='1.5' height='20' fill='%23d8d8d8'/><ellipse cx='16' cy='14' rx='11' ry='9' fill='%23c43d05'/><ellipse cx='16' cy='12' rx='11' ry='9' fill='%23f75709'/><ellipse cx='12' cy='8' rx='3.5' ry='2.2' fill='rgba(255,255,255,0.5)'/></svg>");
  background-size: contain;
  background-repeat: no-repeat;
  filter: drop-shadow(0 4px 6px rgba(0,0,0,0.4));
}
body.theme-navy .downloads-soon-icon {
  width: 64px;
  height: 64px;
  margin: 6px auto 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(247, 87, 9, 0.15);
  border-radius: 50%;
  color: var(--orange);
  animation: downloadsHourglass 3.5s ease-in-out infinite;
}
@keyframes downloadsHourglass {
  0%, 45%   { transform: rotate(0deg); }
  50%, 95%  { transform: rotate(180deg); }
  100%      { transform: rotate(360deg); }
}
body.theme-navy .downloads-soon-text {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(26px, 3vw, 36px);
  font-weight: 700;
  text-transform: uppercase;
  color: #ffffff;
  letter-spacing: -0.01em;
  line-height: 1.05;
  margin-bottom: 14px;
}
body.theme-navy .downloads-soon-tag {
  font-family: 'Reenie Beanie', cursive;
  font-size: 26px;
  color: var(--lime);
  line-height: 1;
}
@media (prefers-reduced-motion: reduce) {
  body.theme-navy .downloads-soon-icon {
    animation: none;
  }
}
@media (max-width: 860px) {
  body.theme-navy .downloads-soon-card {
    padding: 36px 32px 28px;
  }
  body.theme-navy .downloads-soon-icon {
    width: 52px;
    height: 52px;
    margin-bottom: 18px;
  }
  body.theme-navy .downloads-soon-text {
    font-size: 22px;
  }
}

/* ALLE BLOKKEN: uniforme 100px padding boven en onder (uitgezonderd hero, fullscreen modal) */
body.theme-navy .paths,
body.theme-navy .about,
body.theme-navy .approach,
body.theme-navy .downloads,
body.theme-navy .testimonial,
body.theme-navy .cta-final,
body.theme-navy .blog,
body.theme-navy .blog-discover,
body.theme-navy .blog-list,
body.theme-navy .newsletter,
body.theme-navy .insta,
body.theme-navy .blog-subhero,
body.theme-navy .subhero,
body.theme-navy .painpoints,
body.theme-navy .benefits,
body.theme-navy .pricing,
body.theme-navy .reviews-section,
body.theme-navy .contact-section {
  padding-top: 100px;
  padding-bottom: 100px;
}

/* Homepage .blog-list zit binnen .blog-layout en heeft géén eigen padding nodig
   (de wrappende .blog-section heeft al 100px) */
body.theme-navy .blog-layout .blog-list {
  padding-top: 0;
  padding-bottom: 0;
}



/* CTA-final & Testimonial: tussen deze twee blokken slechts 100px totaal (50 + 50) */
body.theme-navy .cta-final {
  padding-bottom: 50px;
}
body.theme-navy .testimonial {
  padding-top: 50px;
}

/* ════════════════════════════════════════════════════════════════════════
   ARTICLE PAGE — editorial magazine stijl
   ════════════════════════════════════════════════════════════════════════ */

/* HEADER — full-width photo met donker petrol overlay */
body.theme-navy .article-header {
  position: relative;
  min-height: 100vh;
  padding: 150px 0 100px;
  display: flex;
  align-items: center;
  background:
    linear-gradient(rgba(6,50,49,0.78), rgba(6,50,49,0.82)),
    url('gamen-met-pap.jpg') center/cover no-repeat;
  margin: 0;
  color: #ffffff;
}
body.theme-navy .article-header .container {
  position: relative;
  z-index: 2;
}
body.theme-navy .article-cat-tag {
  display: inline-block;
  background: var(--orange);
  color: #ffffff;
  padding: 8px 18px;
  font-family: 'Oswald', sans-serif;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  border: none;
  border-radius: 12px;
  margin-bottom: 28px;
  text-decoration: none;
  transition: background 0.2s ease;
}
body.theme-navy .article-cat-tag:hover {
  background: var(--orange-dark);
}
body.theme-navy .article-header h1 {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(40px, 6vw, 80px);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.02em;
  line-height: 0.98;
  color: #ffffff;
  margin: 0 0 28px;
  max-width: 1100px;
}
body.theme-navy .article-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0;
  font-family: 'Public Sans', sans-serif;
  font-size: 15px;
  color: rgba(255,255,255,0.85);
}
body.theme-navy .article-meta .dot {
  margin: 0 12px;
  opacity: 0.5;
}

/* BODY content — Public Sans op grijze achtergrond */
body.theme-navy .single-article {
  background: #ffffff;
}
body.theme-navy .article-content {
  margin-top: 0;
  padding-top: 80px;
  background: transparent;
}
body.theme-navy .article-content > .container-narrow {
  max-width: 920px;
  background: transparent;
  padding: 0 28px;
}
body.theme-navy .article-content > .container-narrow > * {
  max-width: 880px;
  margin-left: auto;
  margin-right: auto;
}
body.theme-navy .article-content .lead {
  font-family: 'Public Sans', sans-serif;
  font-size: 22px;
  font-weight: 400;
  line-height: 1.55;
  color: var(--forest);
  margin-top: 0;
  margin-bottom: 50px;
  padding-bottom: 0;
  border-bottom: none;
}
body.theme-navy .article-content p {
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  line-height: 1.75;
  color: var(--ink);
  margin-bottom: 26px;
}
body.theme-navy .article-content h2 {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(32px, 4vw, 42px);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  line-height: 1.1;
  color: var(--forest);
  margin: 70px 0 22px;
}
body.theme-navy .article-content h3 {
  font-family: 'Oswald', sans-serif;
  font-size: 26px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.005em;
  line-height: 1.2;
  color: var(--forest);
  margin: 50px 0 16px;
}
body.theme-navy .article-content em {
  color: var(--orange);
  font-style: italic;
}
body.theme-navy .article-content strong {
  color: var(--forest);
  font-weight: 700;
}
/* Lists with orange arrow markers */
body.theme-navy .article-content ul,
body.theme-navy .article-content ol {
  padding-left: 0;
  margin: 0 auto 30px;
  list-style: none;
  max-width: 720px;
}
body.theme-navy .article-content ul li {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 0;
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  line-height: 1.6;
  color: var(--ink);
  margin-bottom: 14px;
  border-bottom: none;
}
body.theme-navy .article-content ul li::before {
  content: "";
  position: static;
  width: 24px;
  height: 24px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c3df94' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><line x1='5' y1='12' x2='19' y2='12'/><polyline points='13 6 19 12 13 18'/></svg>");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  flex-shrink: 0;
}
body.theme-navy .article-content ol {
  counter-reset: ol-counter;
}
body.theme-navy .article-content ol li {
  position: relative;
  padding-left: 36px;
  counter-increment: ol-counter;
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  line-height: 1.7;
  color: var(--ink);
  margin-bottom: 14px;
}
body.theme-navy .article-content ol li::before {
  content: counter(ol-counter) ".";
  position: absolute;
  left: 0;
  color: var(--orange);
  font-weight: 700;
  font-family: 'Oswald', sans-serif;
}
/* Blockquote — bold uppercase pull-quote in donker petrol kaart met witte tekst */
body.theme-navy .article-content blockquote {
  position: relative;
  background: var(--forest);
  color: #ffffff;
  margin: 70px auto;
  padding: 80px 70px;
  border: none;
  border-radius: 20px;
  font-family: 'Oswald', sans-serif;
  font-size: 36px;
  font-weight: 700;
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  line-height: 1.1;
  text-align: center;
}
/* Oranje lijntje boven */
body.theme-navy .article-content blockquote::before {
  content: "";
  display: block;
  width: 70px;
  height: 4px;
  background: var(--orange);
  margin: 0 auto 36px;
}
/* Oranje lijntje onder */
body.theme-navy .article-content blockquote::after {
  content: "";
  display: block;
  width: 70px;
  height: 4px;
  background: var(--orange);
  margin: 36px auto 0;
}
/* Figure: rounded corners */
body.theme-navy .article-content figure {
  margin: 40px 0;
  max-width: 100% !important;
}
body.theme-navy .article-content figure img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 12px;
}
/* Gallery: full-width horizontale slider met 3 foto's tegelijk zichtbaar */
body.theme-navy .article-content .gallery {
  position: relative;
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  margin-top: 50px;
  margin-bottom: 50px;
  display: flex;
  gap: 20px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 4px 50px;
  scroll-padding: 0 50px;
  scrollbar-width: none;
}
body.theme-navy .article-content .gallery::-webkit-scrollbar {
  display: none;
}
body.theme-navy .article-content .gallery figure {
  flex: 0 0 calc((100% - 100px - 40px) / 3);
  margin: 0 !important;
  scroll-snap-align: start;
  max-width: none !important;
}
body.theme-navy .article-content .gallery figure img {
  width: 100%;
  height: 460px;
  object-fit: cover;
  border-radius: 16px;
  display: block;
}
/* Override de oude gallery-feature die met grid-column werkte */
body.theme-navy .article-content .gallery .gallery-feature {
  grid-column: auto !important;
  flex: 0 0 calc((100% - 100px - 40px) / 3);
}
/* Voorkom dat body horizontaal kan scrollen door de breakout */
body.theme-navy {
  overflow-x: hidden;
}

/* INLINE TOC — grijze card met genummerde items, sub-items stacken eronder */
body.theme-navy .article-content .toc {
  background: var(--cream-dark);
  border-radius: 16px;
  padding: 36px 40px;
  margin: 50px auto 60px;
  max-width: 880px;
  list-style: none;
}
body.theme-navy .article-content .toc-label {
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--orange);
  margin-bottom: 22px;
}
/* Reset alle ol/li styling uit base CSS + uitschakeling van timeline-lijnen */
body.theme-navy .article-content .toc ol {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  max-width: none !important;
  counter-reset: toc-counter;
}
body.theme-navy .article-content .toc > ol::before,
body.theme-navy .article-content .toc > ol::after {
  display: none !important;
}
body.theme-navy .article-content .toc > ol > li {
  display: block !important;
  position: relative;
  padding: 6px 0 6px 56px !important;
  margin-bottom: 16px !important;
  min-height: 36px;
  font-family: 'Oswald', sans-serif !important;
  font-size: 20px !important;
  font-weight: 600 !important;
  color: var(--forest) !important;
  line-height: 1.35 !important;
  text-transform: none;
  counter-increment: toc-counter;
  border: none !important;
  background: none !important;
}
body.theme-navy .article-content .toc > ol > li:last-child {
  margin-bottom: 0 !important;
}
body.theme-navy .article-content .toc > ol > li::before {
  content: counter(toc-counter, decimal-leading-zero);
  position: absolute !important;
  left: 0;
  top: 0;
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  background: var(--orange) !important;
  color: #ffffff !important;
  font-family: 'Oswald', sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em;
  display: flex !important;
  align-items: center;
  justify-content: center;
  border: none !important;
  box-shadow: none !important;
  transform: none !important;
}
body.theme-navy .article-content .toc a {
  color: inherit;
  transition: color 0.2s ease;
}
body.theme-navy .article-content .toc a:hover {
  color: var(--orange);
}
/* Sub-items: doorgenummerd in {parent}.{sub} format (bijv. 3.1, 3.2, 3.3) */
body.theme-navy .article-content .toc .toc-sub {
  list-style: none !important;
  margin-top: 12px !important;
  padding: 0 !important;
  counter-reset: toc-sub;
}
body.theme-navy .article-content .toc .toc-sub li {
  display: block !important;
  position: relative;
  padding: 0 0 0 44px !important;
  margin-bottom: 8px !important;
  font-family: 'Public Sans', sans-serif !important;
  font-size: 18px !important;
  font-weight: 400 !important;
  color: var(--ink-soft) !important;
  line-height: 1.5 !important;
  border: none !important;
  background: none !important;
  counter-increment: toc-sub;
}
body.theme-navy .article-content .toc .toc-sub li::before {
  content: counter(toc-counter) "." counter(toc-sub);
  position: absolute !important;
  left: 0;
  top: 0;
  color: var(--orange) !important;
  font-family: 'Oswald', sans-serif !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  letter-spacing: 0.02em;
  background: none !important;
  border: none !important;
  width: auto !important;
  height: auto !important;
  box-shadow: none !important;
  transform: none !important;
}

/* ARTICLE SHARE */
body.theme-navy .article-share {
  background: transparent;
  padding: 60px 0 30px;
}
body.theme-navy .article-share .container-narrow {
  max-width: 920px;
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
  padding: 0 28px;
}
body.theme-navy .article-share .label {
  font-family: 'Oswald', sans-serif;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ink-soft);
}
body.theme-navy .share-buttons {
  display: flex;
  gap: 10px;
}
body.theme-navy .share-btn {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--cream-dark);
  color: var(--forest);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: color 0.25s ease, background 0.25s ease;
}
body.theme-navy .share-btn::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 0;
  background: var(--orange);
  transition: width 0.4s ease;
  z-index: -1;
}
body.theme-navy .share-btn:hover::before {
  width: 100%;
}
body.theme-navy .share-btn:hover {
  color: #ffffff;
  transform: none;
  border-color: transparent;
}
body.theme-navy .share-btn svg {
  position: relative;
  z-index: 1;
}

/* TAGS */
body.theme-navy .article-footer {
  padding: 30px 0 60px;
  background: transparent;
}
body.theme-navy .article-footer .container-narrow {
  max-width: 920px;
  padding: 0 28px;
}
body.theme-navy .article-footer .tags {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
body.theme-navy .article-footer .tags .label {
  font-family: 'Oswald', sans-serif;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ink-soft);
}
body.theme-navy .article-footer .tags a {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  display: inline-flex;
  align-items: center;
  padding: 8px 16px;
  background: var(--cream-dark);
  color: var(--forest);
  font-family: 'Oswald', sans-serif;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-radius: 12px;
  text-decoration: none;
  transition: color 0.25s ease, background 0.25s ease;
}
body.theme-navy .article-footer .tags a::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 0;
  background: var(--orange);
  transition: width 0.4s ease;
  z-index: -1;
}
body.theme-navy .article-footer .tags a:hover::before {
  width: 100%;
}
body.theme-navy .article-footer .tags a:hover {
  color: #ffffff;
}

/* AUTHOR BIO — donker petrol kaart */
body.theme-navy .author-bio {
  padding: 50px 0 100px;
  background: transparent;
}
body.theme-navy .author-bio .container-narrow {
  max-width: 920px;
  padding: 0 28px;
}
body.theme-navy .author-bio-inner {
  background: var(--forest);
  color: #ffffff;
  border-radius: 16px;
  padding: 44px 48px;
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 36px;
  align-items: center;
}
body.theme-navy .author-photo {
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background: url('ferry-profiel.jpg') center/cover no-repeat,
              linear-gradient(135deg, var(--lime), var(--orange));
  border: 3px solid var(--lime);
}
body.theme-navy .author-text .eyebrow {
  color: var(--lime-dark) !important;
  margin-bottom: 8px;
}
body.theme-navy .author-text h3 {
  font-family: 'Oswald', sans-serif;
  font-size: 32px;
  font-weight: 700;
  text-transform: uppercase;
  color: #ffffff;
  margin: 0 0 12px;
}
body.theme-navy .author-text h3 em {
  font-style: normal;
  color: var(--lime);
}
body.theme-navy .author-text p {
  font-family: 'Public Sans', sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: rgba(255,255,255,0.85);
  margin-bottom: 22px;
}

/* RELATED ARTICLES */
body.theme-navy .related-articles {
  background: var(--cream-dark);
}
body.theme-navy .related-articles .blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin-top: 50px;
}
body.theme-navy .related-articles .post {
  background: #ffffff;
  border-radius: 16px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  padding: 0;
  border: none;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
body.theme-navy .related-articles .post:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 40px -20px rgba(6,50,49,0.18);
}
body.theme-navy .related-articles .post-photo {
  display: block;
  width: 100%;
  aspect-ratio: 16/10;
  background-image: url('gamen-met-pap.jpg');
  background-size: cover;
  background-position: center;
}
body.theme-navy .related-articles .post .meta {
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  color: var(--ink-soft);
  margin: 24px 28px 12px;
}
body.theme-navy .related-articles .post .meta .cat {
  color: var(--lime-dark);
  font-weight: 600;
}
body.theme-navy .related-articles .post h4 {
  font-family: 'Oswald', sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--forest);
  text-transform: uppercase;
  letter-spacing: -0.005em;
  line-height: 1.2;
  margin: 0 28px 14px;
}
body.theme-navy .related-articles .post h4 a {
  color: inherit;
}
body.theme-navy .related-articles .post:hover h4 a {
  color: var(--orange);
}
body.theme-navy .related-articles .post p {
  font-family: 'Public Sans', sans-serif;
  font-size: 15px;
  line-height: 1.6;
  color: var(--ink);
  margin: 0 28px 22px;
  flex: 1;
}
body.theme-navy .related-articles .post .read {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: var(--orange);
  text-transform: uppercase;
  letter-spacing: 0;
  text-decoration: none;
  margin: 0 28px 28px;
  align-self: flex-start;
  border: none;
  padding: 0;
  transition: color 0.2s ease;
}
body.theme-navy .related-articles .post .read:hover {
  color: var(--orange-dark);
}
body.theme-navy .related-articles .post .read .arrow {
  display: inline-block;
  transition: transform 0.3s ease;
  flex-shrink: 0;
}
body.theme-navy .related-articles .post .read:hover .arrow,
body.theme-navy .related-articles .post:hover .read .arrow {
  transform: rotate(45deg);
}
body.theme-navy .related-articles .post:hover .read {
  color: var(--orange-dark);
}

/* Mobiel */
@media (max-width: 860px) {
  body.theme-navy .article-header {
    padding: 90px 0 60px;
    margin-bottom: 50px;
  }
  body.theme-navy .article-content > .container-narrow > * {
    max-width: 100%;
  }
  body.theme-navy .author-bio-inner {
    grid-template-columns: 1fr;
    text-align: center;
    padding: 36px 28px;
  }
  body.theme-navy .author-photo {
    margin: 0 auto;
  }
  body.theme-navy .related-articles .blog-grid {
    grid-template-columns: 1fr;
  }
}

/* READING PROGRESS — onder de menubalk, 5px hoog, oranje fill */
body.theme-navy .reading-progress {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 5px;
  background: rgba(6,50,49,0.12);
  z-index: 100;
}
body.theme-navy .reading-progress-fill {
  height: 100%;
  background: var(--orange);
  width: 0;
  transition: width 0.12s linear;
}
/* Op mobiel zit de nav op andere hoogte (compacter) */
@media (max-width: 860px) {
  body.theme-navy .reading-progress {
    top: 0;
  }
}

/* ════════════════════════════════════════════════════════════════════════
   CONTACT PAGE — gespreks-georiënteerd, geen formulier-eerst
   ════════════════════════════════════════════════════════════════════════ */

/* HERO ----------------------------------------------------------------- */
body.theme-navy .contact-hero {
  padding: 160px 0 100px;
  background: var(--cream-dark);
  position: relative;
}
body.theme-navy .contact-hero-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 80px;
  align-items: center;
  position: relative;
}
body.theme-navy .contact-hero-text .eyebrow {
  margin-bottom: 22px;
}
body.theme-navy .contact-hero-text h1 {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(44px, 5.4vw, 72px);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--forest);
  margin: 0 0 28px;
}
body.theme-navy .contact-hero-text h1 em {
  font-style: normal;
  color: var(--orange);
}
body.theme-navy .contact-hero-text p {
  font-family: 'Public Sans', sans-serif;
  font-size: 19px;
  line-height: 1.55;
  color: var(--ink);
  max-width: 540px;
  margin: 0 0 40px;
}
body.theme-navy .contact-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 28px;
}
body.theme-navy .contact-hero-meta-item {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--forest);
  background: #ffffff;
  padding: 10px 18px;
  border-radius: 100px;
}
body.theme-navy .contact-hero-meta-item svg {
  color: var(--orange);
  flex-shrink: 0;
}

body.theme-navy .contact-hero-photo {
  position: relative;
  aspect-ratio: 4/5;
  perspective: 1400px;
}
body.theme-navy .contact-hero-photo::after {
  content: "";
  position: absolute;
  inset: -8px;
  border: 2px dashed var(--orange);
  border-radius: 24px;
  pointer-events: none;
  z-index: -1;
}
body.theme-navy .contact-hero-photo-inner {
  position: relative;
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
  animation: contactPhotoFlip 8s cubic-bezier(0.4, 0.0, 0.2, 1) infinite;
}
@keyframes contactPhotoFlip {
  /* flip om de 4 seconden — voorkant, flip, achterkant, flip terug */
  0%, 44%   { transform: rotateY(0deg); }
  50%, 94%  { transform: rotateY(180deg); }
  100%      { transform: rotateY(360deg); }
}
body.theme-navy .contact-hero-photo-face {
  position: absolute;
  inset: 0;
  border-radius: 20px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  box-shadow: 0 30px 70px -25px rgba(6,50,49,0.4);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
body.theme-navy .contact-hero-photo-front {
  background-image:
    url('ferry-profiel.jpg'),
    linear-gradient(135deg, var(--lime), var(--forest));
}
body.theme-navy .contact-hero-photo-back {
  background-image: url('papa-ferry.png');
  background-color: #ffffff;
  transform: rotateY(180deg);
}
/* Bij reduced-motion: geen flip, toon alleen de tekening (achterkant) */
@media (prefers-reduced-motion: reduce) {
  body.theme-navy .contact-hero-photo-inner {
    animation: none !important;
    transform: rotateY(180deg) !important;
  }
}
/* Handgeschreven notitie linksboven naast de foto, pijl wijst van tekst naar foto */
body.theme-navy .contact-hero-photo-note {
  position: absolute;
  top: -110px;
  left: -240px;
  width: 380px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  color: var(--forest);
  pointer-events: none;
  z-index: 2;
}
body.theme-navy .contact-hero-photo-note .note-text {
  font-family: 'Reenie Beanie', cursive;
  font-size: 34px;
  line-height: 1.05;
  white-space: nowrap;
  color: var(--forest);
  transform: rotate(-3deg);
  transform-origin: left top;
  margin-left: 0;
}
body.theme-navy .contact-hero-photo-note .note-arrow {
  width: 110px;
  height: 110px;
  margin-top: -10px;
  margin-left: 110px;
  transform: rotate(45deg);
}

/* DRIE PADEN ---------------------------------------------------------- */
body.theme-navy .contact-paths {
  padding: 100px 0;
  background: #ffffff;
}
body.theme-navy .contact-paths .section-head {
  text-align: center;
  margin-bottom: 60px;
}
body.theme-navy .contact-paths-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
body.theme-navy .contact-path {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--cream-dark);
  border-radius: 20px;
  padding: 40px 36px 36px;
  text-decoration: none;
  color: var(--forest);
  overflow: hidden;
  isolation: isolate;
  transition: transform 0.3s ease;
}
body.theme-navy .contact-path::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--forest);
  transform: translateY(101%);
  transition: transform 0.45s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: -1;
}
body.theme-navy .contact-path:hover::before {
  transform: translateY(0);
}
body.theme-navy .contact-path:hover {
  color: #ffffff;
}
body.theme-navy .contact-path-icon {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--orange);
  margin-bottom: 28px;
  transition: background 0.3s ease, color 0.3s ease;
}
body.theme-navy .contact-path:hover .contact-path-icon {
  background: var(--orange);
  color: #ffffff;
}
body.theme-navy .contact-path-label {
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0;
  color: var(--orange);
  margin-bottom: 14px;
  transition: color 0.3s ease;
}
body.theme-navy .contact-path:hover .contact-path-label {
  color: var(--lime);
}
body.theme-navy .contact-path h3 {
  font-family: 'Oswald', sans-serif;
  font-size: 28px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin: 0 0 14px;
  line-height: 1.1;
}
body.theme-navy .contact-path p {
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  line-height: 1.55;
  color: var(--ink);
  margin: 0 0 32px;
  flex: 1;
  transition: color 0.3s ease;
}
body.theme-navy .contact-path:hover p {
  color: rgba(255,255,255,0.85);
}
body.theme-navy .contact-path-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'Oswald', sans-serif;
  font-size: 15px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--orange);
  transition: color 0.3s ease;
}
body.theme-navy .contact-path:hover .contact-path-cta {
  color: var(--lime);
}
body.theme-navy .contact-path-cta .arrow {
  transition: transform 0.3s ease;
  flex-shrink: 0;
}
body.theme-navy .contact-path:hover .contact-path-cta .arrow {
  transform: rotate(45deg);
}

/* BERICHT FORMULIER --------------------------------------------------- */
body.theme-navy .contact-form-section {
  padding: 100px 0;
  background: var(--cream-dark);
}
body.theme-navy .contact-form-section .container-narrow {
  max-width: 720px;
  padding: 0 28px;
}
body.theme-navy .contact-form-section .section-head {
  text-align: center;
  margin-bottom: 50px;
}
body.theme-navy .contact-form-section .section-head p {
  max-width: 540px;
  margin-left: auto;
  margin-right: auto;
}
body.theme-navy .contact-form-section .contact-form {
  background: #ffffff;
  border-radius: 20px;
  padding: 50px 50px 44px;
  box-shadow: 0 24px 60px -28px rgba(6,50,49,0.25);
}
body.theme-navy .contact-form-section .contact-form .field {
  margin-bottom: 24px;
}
body.theme-navy .contact-form-section .contact-form label {
  display: block;
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--forest);
  margin-bottom: 10px;
}
body.theme-navy .contact-form-section .contact-form input,
body.theme-navy .contact-form-section .contact-form select,
body.theme-navy .contact-form-section .contact-form textarea {
  width: 100%;
  padding: 16px 18px;
  border: 1.5px solid rgba(6,50,49,0.12);
  border-radius: 12px;
  background: var(--cream-dark);
  font-family: 'Public Sans', sans-serif;
  font-size: 16px;
  color: var(--ink);
  transition: border-color 0.2s ease, background 0.2s ease;
}
body.theme-navy .contact-form-section .contact-form input::placeholder,
body.theme-navy .contact-form-section .contact-form textarea::placeholder {
  color: rgba(6,50,49,0.4);
}
body.theme-navy .contact-form-section .contact-form input:focus,
body.theme-navy .contact-form-section .contact-form select:focus,
body.theme-navy .contact-form-section .contact-form textarea:focus {
  outline: none;
  border-color: var(--orange);
  background: #ffffff;
}
body.theme-navy .contact-form-section .contact-form textarea {
  resize: vertical;
  min-height: 140px;
}
body.theme-navy .contact-form-section .contact-form select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23063231' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 18px center;
  padding-right: 44px;
  cursor: pointer;
}
body.theme-navy .contact-form-section .contact-form .btn {
  margin-top: 12px;
  width: 100%;
  justify-content: center;
}
body.theme-navy .contact-form-section .contact-form .form-note {
  margin-top: 20px;
  font-family: 'Public Sans', sans-serif;
  font-size: 13px;
  color: rgba(6,50,49,0.6);
  text-align: center;
  font-style: italic;
}

/* PROCESS STAPPEN ----------------------------------------------------- */
body.theme-navy .contact-process {
  padding: 100px 0;
  background: var(--forest);
  color: #ffffff;
}
body.theme-navy .contact-process .section-head {
  text-align: center;
  margin-bottom: 70px;
}
body.theme-navy .contact-process .section-head .eyebrow {
  color: var(--lime-dark) !important;
}
body.theme-navy .contact-process .section-head h2 {
  color: #ffffff;
}
body.theme-navy .contact-process .section-head h2 em {
  color: var(--lime);
}
body.theme-navy .contact-process .section-head p {
  color: rgba(255,255,255,0.8);
  max-width: 560px;
  margin: 16px auto 0;
}
body.theme-navy .contact-process-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 36px;
  position: relative;
}
body.theme-navy .contact-process-steps::before {
  content: "";
  position: absolute;
  top: 78px;
  /* loopt precies van het midden van cirkel 1 tot het midden van cirkel 3,
     onafhankelijk van schermbreedte: 3 gelijke kolommen met 36px gap,
     dus de zijmarges = (totaal - 2*gap) / 6 */
  left: calc((100% - 72px) / 6);
  right: calc((100% - 72px) / 6);
  height: 2px;
  background: repeating-linear-gradient(
    to right,
    rgba(195,223,148,0.4) 0 6px,
    transparent 6px 12px
  );
  z-index: 0;
}
body.theme-navy .contact-process-step {
  position: relative;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 1;
}
body.theme-navy .contact-process-step h3 {
  font-family: 'Oswald', sans-serif;
  font-size: 22px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.005em;
  line-height: 1.1;
  margin: 0 0 24px;
  color: #ffffff;
}
body.theme-navy .contact-process-step .step-number {
  position: relative;
  top: auto;
  right: auto;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: var(--orange);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Oswald', sans-serif;
  font-size: 18px;
  font-weight: 700;
  margin: 0 auto 24px;
  z-index: 2;
}
body.theme-navy .contact-process-step p {
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  line-height: 1.55;
  color: rgba(255,255,255,0.78);
  margin: 0 auto;
  max-width: 280px;
}

/* FAQ ----------------------------------------------------------------- */
body.theme-navy .contact-faq {
  padding: 100px 0;
  background: #ffffff;
}
body.theme-navy .contact-faq .container-narrow {
  max-width: 820px;
  padding: 0 28px;
}
body.theme-navy .contact-faq .section-head {
  text-align: center;
  margin-bottom: 50px;
}
body.theme-navy .faq-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
body.theme-navy .faq-item {
  background: var(--cream-dark);
  border-radius: 16px;
  overflow: hidden;
  transition: background 0.25s ease;
}
body.theme-navy .faq-item[open] {
  background: var(--forest);
  color: #ffffff;
}
body.theme-navy .faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 24px 30px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  font-family: 'Oswald', sans-serif;
  font-size: 19px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: -0.005em;
  color: var(--forest);
  transition: color 0.25s ease;
}
body.theme-navy .faq-item[open] summary {
  color: #ffffff;
}
body.theme-navy .faq-item summary::-webkit-details-marker {
  display: none;
}
body.theme-navy .faq-icon {
  position: relative;
  width: 22px;
  height: 22px;
  flex-shrink: 0;
}
body.theme-navy .faq-icon::before,
body.theme-navy .faq-icon::after {
  content: "";
  position: absolute;
  background: var(--orange);
  border-radius: 2px;
  transition: transform 0.3s ease, background 0.25s ease;
}
body.theme-navy .faq-icon::before {
  top: 50%;
  left: 0;
  width: 100%;
  height: 3px;
  transform: translateY(-50%);
}
body.theme-navy .faq-icon::after {
  top: 0;
  left: 50%;
  width: 3px;
  height: 100%;
  transform: translateX(-50%);
}
body.theme-navy .faq-item[open] .faq-icon::after {
  transform: translateX(-50%) rotate(90deg);
}
body.theme-navy .faq-item[open] .faq-icon::before,
body.theme-navy .faq-item[open] .faq-icon::after {
  background: var(--lime);
}
body.theme-navy .faq-answer {
  padding: 0 30px 28px;
}
body.theme-navy .faq-answer p {
  font-family: 'Public Sans', sans-serif;
  font-size: 16px;
  line-height: 1.65;
  color: rgba(255,255,255,0.85);
  margin: 0;
}
body.theme-navy .faq-item:not([open]) .faq-answer {
  /* niet zichtbaar als gesloten — details element handelt dit af */
}

/* TABLET — onder 1024px */
@media (max-width: 1024px) {
  body.theme-navy .contact-hero-grid {
    grid-template-columns: 1.2fr 1fr;
    gap: 50px;
  }
  body.theme-navy .contact-hero-text h1 {
    font-size: clamp(40px, 5.5vw, 60px);
  }
  body.theme-navy .contact-hero-photo-note {
    left: -180px;
    width: 320px;
  }
  body.theme-navy .contact-hero-photo-note .note-text {
    font-size: 30px;
  }
  body.theme-navy .contact-hero-photo-note .note-arrow {
    width: 90px;
    height: 90px;
    margin-left: 90px;
  }
  body.theme-navy .contact-paths-grid {
    gap: 18px;
  }
  body.theme-navy .contact-path {
    padding: 32px 28px 28px;
  }
  body.theme-navy .contact-path h3 {
    font-size: 24px;
  }
}

/* MOBIEL — onder 860px */
@media (max-width: 860px) {
  /* HERO ---------------------------------------------------- */
  body.theme-navy .contact-hero {
    padding: 130px 0 70px;
  }
  body.theme-navy .contact-hero-grid {
    grid-template-columns: 1fr;
    gap: 150px;
  }
  body.theme-navy .contact-hero-text h1 {
    font-size: 42px;
  }
  body.theme-navy .contact-hero-text p {
    font-size: 17px;
    margin-bottom: 28px;
  }
  body.theme-navy .contact-hero-meta {
    gap: 10px 16px;
  }
  body.theme-navy .contact-hero-meta-item {
    font-size: 13px;
    padding: 8px 14px;
  }
  body.theme-navy .contact-hero-photo {
    width: 100%;
    max-width: 280px;
    margin: 0 auto;
  }
  /* Notitie boven de foto, gecentreerd, pijl wijst naar beneden */
  body.theme-navy .contact-hero-photo-note {
    top: -130px;
    left: 50%;
    width: 240px;
    transform: translateX(-50%);
    align-items: center;
    text-align: center;
  }
  body.theme-navy .contact-hero-photo-note .note-text {
    font-size: 26px;
    line-height: 1;
    transform: rotate(-2deg);
    transform-origin: center top;
    margin-left: 0;
    white-space: normal;
  }
  body.theme-navy .contact-hero-photo-note .note-arrow {
    width: 55px;
    height: 55px;
    margin-top: -4px;
    margin-left: 30px;
    transform: rotate(80deg);
  }

  /* PADEN --------------------------------------------------- */
  body.theme-navy .contact-paths {
    padding: 70px 0;
  }
  body.theme-navy .contact-paths .section-head {
    margin-bottom: 40px;
  }
  body.theme-navy .contact-paths-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  body.theme-navy .contact-path {
    padding: 32px 28px 28px;
  }
  body.theme-navy .contact-path h3 {
    font-size: 24px;
  }
  body.theme-navy .contact-path p {
    font-size: 17px;
  }

  /* FORMULIER ----------------------------------------------- */
  body.theme-navy .contact-form-section {
    padding: 70px 0;
  }
  body.theme-navy .contact-form-section .contact-form {
    padding: 32px 24px 28px;
  }
  body.theme-navy .contact-form-section .contact-form input,
  body.theme-navy .contact-form-section .contact-form select,
  body.theme-navy .contact-form-section .contact-form textarea {
    font-size: 15px;
    padding: 14px 16px;
  }
  body.theme-navy .contact-form-section .contact-form label {
    font-size: 14px;
  }

  /* PROCESS ------------------------------------------------- */
  body.theme-navy .contact-process {
    padding: 70px 0;
  }
  body.theme-navy .contact-process .section-head {
    margin-bottom: 50px;
  }
  body.theme-navy .contact-process-steps {
    grid-template-columns: 1fr;
    gap: 50px;
  }
  body.theme-navy .contact-process-steps::before {
    display: none;
  }
  body.theme-navy .contact-process-step h3 {
    font-size: 20px;
  }
  body.theme-navy .contact-process-step p {
    font-size: 17px;
  }

  /* FAQ ----------------------------------------------------- */
  body.theme-navy .contact-faq {
    padding: 70px 0;
  }
  body.theme-navy .contact-faq .section-head {
    margin-bottom: 36px;
  }
  body.theme-navy .faq-item summary {
    padding: 20px 22px;
    font-size: 17px;
    gap: 14px;
  }
  body.theme-navy .faq-answer {
    padding: 0 22px 22px;
  }
  body.theme-navy .faq-answer p {
    font-size: 15px;
  }
}

/* REVIEWS-KAARTEN — overschrijven Fraunces met de site-typografie */
body.theme-navy .reviews-grid {
  margin-top: 50px;
}
body.theme-navy .review {
  background: #ffffff;
  border: none;
  border-radius: 16px;
  padding: 36px 32px;
  box-shadow: 0 18px 40px -25px rgba(6,50,49,0.18);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
body.theme-navy .review:hover {
  transform: translateY(-3px);
  box-shadow: 0 24px 50px -25px rgba(6,50,49,0.22);
}
body.theme-navy .review-quote {
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  line-height: 1.55;
  font-weight: 500;
  font-style: normal;
  color: var(--forest);
}
body.theme-navy .reviewer {
  border-top: 1px solid rgba(6,50,49,0.1);
  padding-top: 18px;
}
body.theme-navy .reviewer-info strong {
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0;
  color: var(--forest);
}
body.theme-navy .reviewer-info span {
  font-family: 'Public Sans', sans-serif;
  font-size: 13px;
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
  color: var(--ink);
}

/* KLEINE MOBIEL — onder 480px */
@media (max-width: 480px) {
  body.theme-navy .contact-hero {
    padding: 110px 0 50px;
  }
  body.theme-navy .contact-hero-text h1 {
    font-size: 34px;
  }
  body.theme-navy .contact-hero-text p {
    font-size: 16px;
  }
  body.theme-navy .contact-hero-photo {
    width: 100%;
    max-width: 240px;
  }
  body.theme-navy .contact-hero-photo-note {
    top: -115px;
    width: 200px;
  }
  body.theme-navy .contact-hero-photo-note .note-text {
    font-size: 22px;
    line-height: 1;
  }
  body.theme-navy .contact-hero-photo-note .note-arrow {
    width: 48px;
    height: 48px;
    margin-left: 24px;
  }
  body.theme-navy .contact-path {
    padding: 28px 22px 24px;
  }
  body.theme-navy .contact-path h3 {
    font-size: 22px;
  }
  body.theme-navy .contact-path p {
    font-size: 16px;
    margin-bottom: 24px;
  }
  body.theme-navy .contact-form-section .section-head h2,
  body.theme-navy .contact-process .section-head h2,
  body.theme-navy .contact-faq .section-head h2,
  body.theme-navy .contact-paths .section-head h2 {
    font-size: 32px;
  }
  body.theme-navy .faq-item summary {
    font-size: 16px;
    padding: 18px 18px;
  }
}

/* ════════════════════════════════════════════════════════════════════════
   SAMENWERKEN PAGE — Instagram partner & brand inquiries
   ════════════════════════════════════════════════════════════════════════ */

/* HERO ----------------------------------------------------------------- */
body.theme-navy .partner-hero {
  padding: 80px 0;
  background: var(--cream-dark);
  position: relative;
}
body.theme-navy .partner-hero-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 80px;
  align-items: center;
}
body.theme-navy .partner-hero-text .eyebrow {
  margin-bottom: 22px;
}
body.theme-navy .partner-hero-text h1 {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(44px, 5.4vw, 72px);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--forest);
  margin: 0 0 28px;
}
body.theme-navy .partner-hero-text h1 em {
  font-style: normal;
  color: var(--orange);
}
body.theme-navy .partner-hero-text p {
  font-family: 'Public Sans', sans-serif;
  font-size: 19px;
  line-height: 1.55;
  color: var(--ink);
  max-width: 540px;
  margin: 0 0 30px;
}
body.theme-navy .partner-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 18px;
  margin-bottom: 36px;
}
body.theme-navy .partner-hero-meta-item {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--forest);
  background: #ffffff;
  padding: 10px 18px;
  border-radius: 100px;
}
body.theme-navy .partner-hero-meta-item svg {
  color: var(--orange);
  flex-shrink: 0;
}

/* HERO INSTAGRAM-POST MOCKUP ------------------------------------------- */
body.theme-navy .partner-hero-visual {
  display: flex;
  justify-content: center;
  align-items: center;
}
body.theme-navy .ig-post {
  background: #ffffff;
  border-radius: 16px;
  width: 100%;
  max-width: 320px;
  overflow: hidden;
  box-shadow: 0 30px 80px -30px rgba(6,50,49,0.4);
  transform: rotate(-2deg);
  position: relative;
}
body.theme-navy .ig-post::before {
  /* tweede polaroid eronder voor diepte */
  content: "";
  position: absolute;
  inset: 0;
  background: #ffffff;
  border-radius: 16px;
  z-index: -1;
  transform: rotate(4deg) translate(8px, 8px);
  box-shadow: 0 20px 60px -25px rgba(6,50,49,0.25);
}
body.theme-navy .ig-post-head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
}
body.theme-navy .ig-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background:
    url('ferry-profiel.jpg') center/cover no-repeat,
    linear-gradient(135deg, var(--lime), var(--orange));
  flex-shrink: 0;
  border: 2px solid var(--orange);
}
body.theme-navy .ig-meta {
  flex: 1;
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}
body.theme-navy .ig-meta strong {
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: var(--forest);
}
body.theme-navy .ig-meta span {
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  color: var(--ink-soft);
  margin-top: 2px;
}
body.theme-navy .ig-more {
  background: none;
  border: none;
  display: flex;
  flex-direction: column;
  gap: 3px;
  cursor: default;
  padding: 8px;
}
body.theme-navy .ig-more span {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--forest);
}
body.theme-navy .ig-post-image {
  width: 100%;
  aspect-ratio: 4/5;
  background:
    url('partner-video-poster.jpg') center/cover no-repeat,
    linear-gradient(135deg, var(--lime), var(--forest));
  position: relative;
  overflow: hidden;
}
body.theme-navy .ig-post-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
body.theme-navy .ig-post-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 16px 6px;
  color: var(--forest);
}
body.theme-navy .ig-post-actions svg {
  cursor: default;
}
body.theme-navy .ig-post-actions .ig-heart {
  color: #ed4956;
}
body.theme-navy .ig-bookmark {
  margin-left: auto;
}
body.theme-navy .ig-post-body {
  padding: 0 16px 18px;
}
body.theme-navy .ig-likes {
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--forest);
  margin-bottom: 6px;
}
body.theme-navy .ig-caption {
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  line-height: 1.45;
  color: var(--forest);
}
body.theme-navy .ig-caption strong {
  font-weight: 700;
  margin-right: 6px;
}

/* LOGO BAR ------------------------------------------------------------- */
body.theme-navy .partner-logos {
  padding: 80px 0 80px;
  background: #ffffff;
  border-bottom: 1px solid rgba(6,50,49,0.08);
}
body.theme-navy .partner-logos-head {
  text-align: center;
  margin-bottom: 36px;
}
body.theme-navy .partner-logos-head .eyebrow {
  margin: 0;
}
body.theme-navy .logo-bar {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 28px 56px;
  align-items: center;
}
body.theme-navy .logo-mark {
  font-family: 'Oswald', sans-serif;
  font-size: 22px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--forest);
  opacity: 0.55;
  transition: opacity 0.25s ease;
}
body.theme-navy .logo-mark:hover {
  opacity: 1;
}

/* CIJFERS ------------------------------------------------------------- */
body.theme-navy .partner-stats {
  padding: 100px 0;
  background: var(--cream-dark);
}
body.theme-navy .partner-stats .section-head {
  text-align: center;
  margin-bottom: 70px;
}
body.theme-navy .partner-stats .section-head p {
  max-width: 540px;
  margin: 16px auto 0;
}
body.theme-navy .stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
body.theme-navy .stat-card {
  background: #ffffff;
  border-radius: 20px;
  padding: 50px 36px 40px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
body.theme-navy .stat-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 5px;
  background: var(--orange);
}
body.theme-navy .stat-number {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(64px, 6vw, 96px);
  font-weight: 700;
  line-height: 1;
  color: var(--forest);
  letter-spacing: -0.02em;
  margin-bottom: 14px;
  display: block;
}
body.theme-navy .stat-label {
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--orange);
  margin-bottom: 18px;
}
body.theme-navy .stat-note {
  font-family: 'Public Sans', sans-serif;
  font-size: 15px;
  line-height: 1.55;
  color: var(--ink);
  margin: 0;
  max-width: 280px;
  margin-left: auto;
  margin-right: auto;
}

/* DRIE INSTAGRAM-FORMATS — hergebruikt contact-paths-grid styling ----- */
body.theme-navy .partner-formats {
  padding: 100px 0;
  background: #ffffff;
}
body.theme-navy .partner-formats .section-head {
  text-align: center;
  margin-bottom: 60px;
}
body.theme-navy .partner-formats .section-head p {
  max-width: 540px;
  margin: 16px auto 0;
}

/* WEL / NIET ---------------------------------------------------------- */
body.theme-navy .partner-vs {
  padding: 100px 0;
  background: var(--cream-dark);
}
body.theme-navy .partner-vs .section-head {
  text-align: center;
  margin-bottom: 60px;
}
body.theme-navy .partner-vs .section-head p {
  max-width: 540px;
  margin: 16px auto 0;
}
body.theme-navy .vs-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
body.theme-navy .vs-col {
  border-radius: 20px;
  padding: 48px 44px 44px;
  position: relative;
}
body.theme-navy .vs-yes {
  background: var(--lime);
  color: var(--forest);
}
body.theme-navy .vs-no {
  background: var(--forest);
  color: #ffffff;
}
body.theme-navy .vs-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 28px;
}
body.theme-navy .vs-yes .vs-icon {
  color: var(--forest);
}
body.theme-navy .vs-no .vs-icon {
  color: var(--orange);
}
body.theme-navy .vs-col h3 {
  font-family: 'Oswald', sans-serif;
  font-size: 36px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin: 0 0 24px;
  line-height: 1;
}
body.theme-navy .vs-col ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
body.theme-navy .vs-col li {
  font-family: 'Public Sans', sans-serif;
  font-size: 17px;
  line-height: 1.5;
  padding: 12px 0 12px 28px;
  position: relative;
  border-top: 1px solid rgba(6,50,49,0.12);
}
body.theme-navy .vs-no li {
  border-top-color: rgba(255,255,255,0.12);
}
body.theme-navy .vs-col li:first-child {
  border-top: none;
}
body.theme-navy .vs-col li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 19px;
  width: 14px;
  height: 14px;
  background-size: contain;
  background-repeat: no-repeat;
}
body.theme-navy .vs-yes li::before {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23063231' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
}
body.theme-navy .vs-no li::before {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f75709' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><line x1='18' y1='6' x2='6' y2='18'/><line x1='6' y1='6' x2='18' y2='18'/></svg>");
}

/* PARTNER PROCESS — 4 stappen, hergebruikt contact-process structuur -- */
body.theme-navy .partner-process .contact-process-steps {
  grid-template-columns: repeat(4, 1fr);
}
body.theme-navy .partner-process .contact-process-steps::before {
  /* lijn loopt nu over 4 cirkels: zijmarges = (totaal - 3*gap) / 8 */
  left: calc((100% - 108px) / 8);
  right: calc((100% - 108px) / 8);
}

/* PARTNER FORM — meer velden, twee-koloms voor bedrijfsdetails -------- */
body.theme-navy .partner-form-section {
  background: #ffffff;
}
body.theme-navy .partner-form-section .container-narrow {
  max-width: 760px;
}
body.theme-navy .partner-form-section .contact-form .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-bottom: 0;
}
body.theme-navy .partner-form-section .contact-form .form-row .field {
  margin-bottom: 24px;
}

/* RESPONSIVE ---------------------------------------------------------- */
@media (max-width: 1024px) {
  body.theme-navy .partner-hero-grid {
    grid-template-columns: 1.1fr 1fr;
    gap: 50px;
  }
  body.theme-navy .partner-process .contact-process-steps {
    grid-template-columns: repeat(2, 1fr);
    gap: 60px 36px;
  }
  body.theme-navy .partner-process .contact-process-steps::before {
    display: none;
  }
}

@media (max-width: 860px) {
  body.theme-navy .partner-hero {
    padding: 100px 0 60px;
  }
  body.theme-navy .partner-hero-grid {
    grid-template-columns: 1fr;
    gap: 60px;
  }
  body.theme-navy .partner-hero-text h1 {
    font-size: 42px;
  }
  body.theme-navy .partner-hero-text p {
    font-size: 17px;
  }
  body.theme-navy .ig-post {
    max-width: 280px;
    margin: 0 auto;
  }
  body.theme-navy .partner-logos {
    padding: 60px 0;
  }
  body.theme-navy .logo-bar {
    gap: 20px 36px;
  }
  body.theme-navy .logo-mark {
    font-size: 18px;
  }
  body.theme-navy .partner-stats {
    padding: 70px 0;
  }
  body.theme-navy .partner-stats .section-head {
    margin-bottom: 50px;
  }
  body.theme-navy .stats-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  body.theme-navy .stat-card {
    padding: 40px 32px 36px;
  }
  body.theme-navy .partner-formats {
    padding: 70px 0;
  }
  body.theme-navy .partner-vs {
    padding: 70px 0;
  }
  body.theme-navy .vs-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  body.theme-navy .vs-col {
    padding: 36px 28px 32px;
  }
  body.theme-navy .vs-col h3 {
    font-size: 30px;
  }
  body.theme-navy .vs-col li {
    font-size: 16px;
  }
  body.theme-navy .partner-form-section .contact-form .form-row {
    grid-template-columns: 1fr;
    gap: 0;
  }
}

@media (max-width: 480px) {
  body.theme-navy .partner-hero-text h1 {
    font-size: 34px;
  }
  body.theme-navy .ig-post {
    max-width: 240px;
  }
  body.theme-navy .stat-number {
    font-size: 56px;
  }
}

/* ════════════════════════════════════════════════════════════════════════
   OVER FERRY PAGE — persoonlijk verhaal, manifest, tijdlijn, boek
   ════════════════════════════════════════════════════════════════════════ */

/* HERO ----------------------------------------------------------------- */
body.theme-navy .over-hero {
  padding: 80px 0;
  background: var(--cream-dark);
  position: relative;
}
body.theme-navy .over-hero-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 80px;
  align-items: center;
}
body.theme-navy .over-hero-text .eyebrow {
  margin-bottom: 22px;
}
body.theme-navy .over-hero-text h1 {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(40px, 4.6vw, 60px);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--forest);
  margin: 0 0 28px;
}
body.theme-navy .over-hero-text h1 em {
  font-style: normal;
  color: var(--orange);
}
body.theme-navy .over-hero-lead {
  font-family: 'Public Sans', sans-serif;
  font-size: 19px;
  line-height: 1.55;
  color: var(--ink);
  max-width: 540px;
  margin: 0 0 36px;
}
body.theme-navy .over-hero-meta {
  display: flex;
  flex-direction: column;
  max-width: 540px;
}
body.theme-navy .over-hero-meta-item {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 24px;
  align-items: center;
  padding: 18px 0;
  border-top: 1px solid rgba(6,50,49,0.14);
  position: relative;
  transition: padding-left 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}
body.theme-navy .over-hero-meta-item:last-child {
  border-bottom: 1px solid rgba(6,50,49,0.14);
}
/* Oranje accent-balkje dat van links inschuift bij hover */
body.theme-navy .over-hero-meta-item::before {
  content: "";
  position: absolute;
  left: 0;
  top: -1px;
  bottom: -1px;
  width: 0;
  background: var(--orange);
  transition: width 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}
body.theme-navy .over-hero-meta-item:hover::before {
  width: 4px;
}
body.theme-navy .over-hero-meta-item:hover {
  padding-left: 16px;
}
body.theme-navy .over-hero-meta-item .meta-value {
  font-family: 'Oswald', sans-serif;
  font-size: 44px;
  font-weight: 700;
  color: var(--forest);
  line-height: 1;
  letter-spacing: -0.02em;
  transition: color 0.3s ease;
}
body.theme-navy .over-hero-meta-item:hover .meta-value {
  color: var(--orange);
}
body.theme-navy .over-hero-meta-item .meta-label {
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
  line-height: 1.25;
  transition: color 0.3s ease;
}
body.theme-navy .over-hero-meta-item:hover .meta-label {
  color: var(--forest);
}
body.theme-navy .over-hero-photo {
  aspect-ratio: 4/5;
  border-radius: 20px;
  background:
    url('ferry-profiel.jpg') center/cover no-repeat,
    linear-gradient(135deg, var(--lime), var(--forest));
  box-shadow: 0 30px 70px -25px rgba(6,50,49,0.4);
  position: relative;
}
body.theme-navy .over-hero-photo::after {
  content: "";
  position: absolute;
  inset: -8px;
  border: 2px dashed var(--orange);
  border-radius: 24px;
  pointer-events: none;
  z-index: -1;
}

/* VERHAAL ------------------------------------------------------------- */
body.theme-navy .over-story {
  padding: 100px 0;
  background: #ffffff;
}
body.theme-navy .over-story .container-narrow {
  max-width: 920px;
  padding: 0 28px;
}
body.theme-navy .over-story .section-head,
body.theme-navy .over-story-content {
  max-width: 880px;
  margin-left: auto;
  margin-right: auto;
}
body.theme-navy .over-story .section-head {
  text-align: center;
  margin-bottom: 50px;
}
body.theme-navy .over-story-content p {
  font-family: 'Public Sans', sans-serif;
  font-size: 19px;
  line-height: 1.65;
  color: var(--ink);
  margin: 0 0 22px;
}
body.theme-navy .over-story-content p:last-child {
  margin-bottom: 0;
}

/* FOTO SLIDER — zelfde stijl als artikel-gallery, full-width met scroll-snap */
body.theme-navy .over-mosaic {
  padding: 0 0 100px;
  background: #ffffff;
}
body.theme-navy .mosaic-slider {
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  display: flex;
  gap: 20px;
  overflow-x: auto;
  padding: 4px 50px;
  scrollbar-width: none;
}
body.theme-navy .mosaic-slider::-webkit-scrollbar {
  display: none;
}
body.theme-navy .mosaic-slider figure {
  flex: 0 0 calc((100% - 100px - 40px) / 3);
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
  max-width: none;
}
body.theme-navy .mosaic-slider figure img {
  width: 100%;
  height: 460px;
  object-fit: cover;
  border-radius: 16px;
  display: block;
}
body.theme-navy .mosaic-slider figcaption {
  font-family: 'Reenie Beanie', cursive;
  font-size: 24px;
  line-height: 1.05;
  color: var(--forest);
  text-align: center;
  padding: 0 8px;
}

/* MANIFEST ------------------------------------------------------------ */
body.theme-navy .over-manifest {
  padding: 100px 0;
  background: var(--forest);
  color: #ffffff;
}
body.theme-navy .over-manifest .section-head {
  text-align: center;
  margin-bottom: 70px;
}
body.theme-navy .over-manifest .section-head .eyebrow {
  color: var(--lime-dark) !important;
}
body.theme-navy .over-manifest .section-head h2 {
  color: #ffffff;
}
body.theme-navy .over-manifest .section-head h2 em {
  color: var(--lime);
}
body.theme-navy .over-manifest .section-head p {
  color: rgba(255,255,255,0.78);
  max-width: 540px;
  margin: 16px auto 0;
}
body.theme-navy .manifest-list {
  max-width: 920px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}
body.theme-navy .manifest-item {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 28px;
  align-items: baseline;
  padding: 28px 0;
  border-top: 1px solid rgba(255,255,255,0.12);
}
body.theme-navy .manifest-item:first-child {
  border-top: none;
}
body.theme-navy .manifest-num {
  font-family: 'Oswald', sans-serif;
  font-size: 18px;
  font-weight: 600;
  color: var(--orange);
  letter-spacing: 0.04em;
}
body.theme-navy .manifest-item p {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(22px, 2.2vw, 32px);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  color: #ffffff;
  margin: 0;
}
body.theme-navy .manifest-item p em {
  font-style: normal;
  color: var(--lime);
}

/* EEN DAG IN MIJN LEVEN — als digitale agenda met urenraster ----------- */
body.theme-navy .over-day {
  padding: 100px 0;
  background: var(--cream-dark);
}
body.theme-navy .over-day .section-head {
  text-align: center;
  margin-bottom: 60px;
}
/* Container = window-mockup */
body.theme-navy .agenda {
  --hour-height: 50px;
  background: #ffffff;
  border-radius: 16px;
  box-shadow: 0 30px 80px -30px rgba(6,50,49,0.3);
  overflow: hidden;
  max-width: 760px;
  margin: 0 auto;
  position: relative;
}
/* Window-bar bovenaan (titlebar met traffic lights) */
body.theme-navy .agenda-bar {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  background: #f5f6f6;
  border-bottom: 1px solid rgba(6,50,49,0.08);
}
body.theme-navy .agenda-bar-dots {
  display: flex;
  gap: 7px;
}
body.theme-navy .agenda-bar-dots span {
  width: 12px;
  height: 12px;
  border-radius: 50%;
}
body.theme-navy .agenda-bar-dots span:nth-child(1) { background: #ff5f57; }
body.theme-navy .agenda-bar-dots span:nth-child(2) { background: #ffbd2e; }
body.theme-navy .agenda-bar-dots span:nth-child(3) { background: #28c840; }
body.theme-navy .agenda-bar-title {
  flex: 1;
  text-align: center;
  font-family: 'Public Sans', sans-serif;
  font-size: 17px;
  font-weight: 600;
  color: var(--forest);
  letter-spacing: 0.01em;
}
body.theme-navy .agenda-bar-spacer {
  width: 60px; /* gelijk aan dots-zone, zodat title gecentreerd blijft */
}

/* Body: links uren, rechts events */
body.theme-navy .agenda-body {
  display: grid;
  grid-template-columns: 80px 1fr;
}
/* Uren-kolom */
body.theme-navy .agenda-hours {
  display: flex;
  flex-direction: column;
  border-right: 1px solid rgba(6,50,49,0.06);
  background: #fafbfb;
}
body.theme-navy .agenda-hours span {
  height: var(--hour-height);
  padding: 4px 14px 0 0;
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 500;
  color: rgba(6,50,49,0.5);
  text-align: right;
  letter-spacing: 0.04em;
  border-bottom: 1px solid rgba(6,50,49,0.04);
}
body.theme-navy .agenda-hours span:last-child {
  border-bottom: none;
}
/* Events-area: gridraster doorgetekend met dunne lijntjes */
body.theme-navy .agenda-events {
  position: relative;
  background-image: linear-gradient(
    to bottom,
    transparent 0,
    transparent calc(var(--hour-height) - 1px),
    rgba(6,50,49,0.04) calc(var(--hour-height) - 1px),
    rgba(6,50,49,0.04) var(--hour-height)
  );
  background-size: 100% var(--hour-height);
}
/* Forceer hoogte op basis van 19 uur-rijen (05:00-23:00 = 18 uur) */
body.theme-navy .agenda-events::before {
  content: "";
  display: block;
  height: calc(var(--hour-height) * 18);
}
/* Event blok */
body.theme-navy .agenda-event {
  position: absolute;
  left: 8px;
  right: 8px;
  top: calc(var(--start) * var(--hour-height));
  height: calc(var(--duration) * var(--hour-height));
  border-radius: 8px;
  padding: 6px 12px;
  cursor: default;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  box-shadow: 0 2px 6px -2px rgba(6,50,49,0.15);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  border-left: 3px solid;
}
body.theme-navy .agenda-event:hover {
  transform: translateX(2px);
  box-shadow: 0 8px 20px -8px rgba(6,50,49,0.3);
  z-index: 2;
}
body.theme-navy .agenda-event-time {
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  margin-bottom: 3px;
  opacity: 0.85;
}
body.theme-navy .agenda-event-title {
  font-family: 'Public Sans', sans-serif;
  font-size: 15px;
  line-height: 1.35;
  font-weight: 500;
}
/* Categorie-kleuren */
body.theme-navy .agenda-event[data-cat="family"] {
  background: #e0f0c8;
  color: var(--forest);
  border-left-color: #87a85a;
}
body.theme-navy .agenda-event[data-cat="work"] {
  background: #fde2cd;
  color: #6e2902;
  border-left-color: var(--orange);
}
body.theme-navy .agenda-event[data-cat="personal"] {
  background: #d4dfde;
  color: var(--forest);
  border-left-color: var(--forest);
}
/* Korte events (duration < 1) krijgen compactere stijl */
body.theme-navy .agenda-event[style*="--duration: 0.5"] .agenda-event-title,
body.theme-navy .agenda-event[style*="--duration:0.5"] .agenda-event-title {
  font-size: 12px;
}

/* WAT IK NIET BEN — 2x2 grid met afgrenzende statements ---------------- */
body.theme-navy .over-not {
  padding: 100px 0;
  background: #ffffff;
}
body.theme-navy .over-not .section-head {
  text-align: center;
  margin-bottom: 60px;
}
body.theme-navy .not-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
body.theme-navy .not-card {
  background: var(--cream-dark);
  border-radius: 20px;
  padding: 40px 36px 36px;
  position: relative;
  text-align: left;
  transition: background 0.3s ease, transform 0.3s ease;
}
body.theme-navy .not-card:hover {
  background: #ffffff;
  box-shadow: 0 24px 50px -25px rgba(6,50,49,0.18);
  transform: translateY(-3px);
}
body.theme-navy .not-mark {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--orange);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 24px;
}
body.theme-navy .not-card h3 {
  font-family: 'Oswald', sans-serif;
  font-size: 30px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  color: var(--forest);
  margin: 0 0 14px;
  line-height: 1.05;
}
body.theme-navy .not-card p {
  font-family: 'Public Sans', sans-serif;
  font-size: 17px;
  line-height: 1.55;
  color: var(--ink);
  margin: 0;
}

/* BOEK ---------------------------------------------------------------- */
body.theme-navy .over-book {
  padding: 100px 0;
  background: #f5ede0;
}
body.theme-navy .book-grid {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: 80px;
  align-items: center;
}
body.theme-navy .book-cover {
  aspect-ratio: 5/7;
  max-width: 340px;
  border-radius: 4px 12px 12px 4px;
  background:
    linear-gradient(135deg, #073937 0%, var(--forest) 50%, #042322 100%);
  position: relative;
  box-shadow:
    0 30px 70px -25px rgba(6,50,49,0.55),
    0 12px 30px -12px rgba(6,50,49,0.35),
    inset 0 1px 0 rgba(255,255,255,0.08);
  transform: rotate(-2deg);
  margin-left: auto;
  margin-right: 12px;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1),
              box-shadow 0.5s ease;
}
body.theme-navy .book-cover:hover {
  transform: rotate(-1deg) translateY(-8px);
  box-shadow:
    0 40px 80px -25px rgba(6,50,49,0.6),
    0 16px 35px -12px rgba(6,50,49,0.4),
    inset 0 1px 0 rgba(255,255,255,0.1);
}
/* Subtiele paper-texture via radial gradients */
body.theme-navy .book-cover::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 25% 15%, rgba(255,255,255,0.06) 0%, transparent 45%),
    radial-gradient(ellipse at 75% 85%, rgba(195,223,148,0.05) 0%, transparent 50%);
  pointer-events: none;
  border-radius: inherit;
}
/* Spine links — bredere, diepere shadow-gradient */
body.theme-navy .book-cover-spine {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 22px;
  background: linear-gradient(to right,
    rgba(0,0,0,0.5) 0%,
    rgba(0,0,0,0.25) 40%,
    rgba(0,0,0,0.05) 80%,
    rgba(0,0,0,0) 100%);
  pointer-events: none;
  z-index: 2;
  border-radius: 4px 0 0 4px;
}
body.theme-navy .book-cover-inner {
  padding: 54px 36px 42px 52px;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}
/* Auteursnaam met klein oranje lijntje eronder */
body.theme-navy .book-cover-eyebrow {
  font-family: 'Oswald', sans-serif;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--lime);
  padding-bottom: 14px;
  position: relative;
}
body.theme-navy .book-cover-eyebrow::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 28px;
  height: 1px;
  background: var(--orange);
}
/* Titel met letterpress-effect via text-shadow */
body.theme-navy .book-cover-title {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(38px, 4vw, 52px);
  font-weight: 700;
  text-transform: uppercase;
  line-height: 0.95;
  color: #ffffff;
  letter-spacing: -0.01em;
  text-shadow:
    0 1px 0 rgba(0,0,0,0.3),
    0 2px 6px rgba(0,0,0,0.15);
}
body.theme-navy .book-cover-title em {
  font-style: normal;
  color: var(--orange);
}
/* Ondertitel met decoratief lime lijntje erboven */
body.theme-navy .book-cover-sub {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 16px;
  font-style: normal;
  color: rgba(255,255,255,0.85);
  line-height: 1.35;
  padding-top: 18px;
  position: relative;
}
body.theme-navy .book-cover-sub::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 32px;
  height: 1px;
  background: linear-gradient(to right, var(--lime) 0%, transparent 100%);
}
body.theme-navy .book-cover-sub em {
  color: var(--lime);
  font-style: italic;
}
body.theme-navy .book-text .eyebrow {
  margin-bottom: 22px;
}
body.theme-navy .book-text h2 {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(38px, 3.4vw, 48px);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--forest);
  margin: 0 0 24px;
}
body.theme-navy .book-text h2 em {
  font-style: normal;
  color: var(--orange);
}
body.theme-navy .book-text p {
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  line-height: 1.6;
  color: var(--ink);
  margin: 0 0 18px;
}
body.theme-navy .book-eta {
  font-family: 'Oswald', sans-serif;
  font-size: 16px !important;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--orange) !important;
  margin-bottom: 28px !important;
}
body.theme-navy .book-eta strong {
  color: var(--orange);
}
body.theme-navy .book-signup {
  display: flex;
  gap: 12px;
  max-width: 480px;
  margin-bottom: 14px;
}
body.theme-navy .book-signup input {
  flex: 1;
  padding: 16px 20px;
  border: 1.5px solid rgba(6,50,49,0.12);
  border-radius: 12px;
  background: #ffffff;
  font-family: 'Public Sans', sans-serif;
  font-size: 16px;
  color: var(--ink);
  transition: border-color 0.2s ease;
}
body.theme-navy .book-signup input:focus {
  outline: none;
  border-color: var(--orange);
}
body.theme-navy .book-signup .btn {
  flex-shrink: 0;
}
body.theme-navy .book-note {
  font-family: 'Public Sans', sans-serif;
  font-size: 14px !important;
  color: rgba(6,50,49,0.6) !important;
  font-style: italic;
  margin: 0 !important;
}

/* CTA ----------------------------------------------------------------- */
body.theme-navy .over-cta {
  padding: 100px 0;
  background: #ffffff;
  text-align: center;
}
body.theme-navy .over-cta .container-narrow {
  max-width: 720px;
  padding: 0 28px;
}
body.theme-navy .over-cta h2 {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(40px, 4.4vw, 60px);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--forest);
  margin: 0 0 20px;
}
body.theme-navy .over-cta h2 em {
  font-style: normal;
  color: var(--orange);
}
body.theme-navy .over-cta p {
  font-family: 'Public Sans', sans-serif;
  font-size: 19px;
  line-height: 1.55;
  color: var(--ink);
  margin: 0 0 36px;
}
body.theme-navy .over-cta-buttons {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
}

/* RESPONSIVE ---------------------------------------------------------- */
@media (max-width: 1024px) {
  body.theme-navy .over-hero-grid {
    gap: 50px;
  }
  body.theme-navy .mosaic-slider figure {
    flex: 0 0 calc((100% - 80px - 30px) / 2.5);
  }
  body.theme-navy .mosaic-slider figure img {
    height: 380px;
  }
  body.theme-navy .book-grid {
    gap: 50px;
  }
}

@media (max-width: 860px) {
  body.theme-navy .over-hero {
    padding: 60px 0;
  }
  body.theme-navy .over-hero-grid {
    grid-template-columns: 1fr;
    gap: 50px;
  }
  body.theme-navy .over-hero-text h1 {
    font-size: 36px;
  }
  body.theme-navy .over-hero-photo {
    max-width: 320px;
    width: 100%;
    margin: 0 auto;
  }
  body.theme-navy .over-hero-meta {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  body.theme-navy .over-hero-meta-item .meta-value {
    font-size: 30px;
  }
  body.theme-navy .over-story,
  body.theme-navy .over-manifest,
  body.theme-navy .over-day,
  body.theme-navy .over-not,
  body.theme-navy .over-book,
  body.theme-navy .over-cta {
    padding: 70px 0;
  }
  /* Agenda compacter op mobiel */
  body.theme-navy .agenda {
    --hour-height: 44px;
  }
  body.theme-navy .agenda-body {
    grid-template-columns: 56px 1fr;
  }
  body.theme-navy .agenda-hours span {
    font-size: 10px;
    padding: 4px 8px 0 0;
  }
  body.theme-navy .agenda-event {
    left: 5px;
    right: 5px;
    padding: 5px 10px;
  }
  body.theme-navy .agenda-event-time {
    font-size: 10px;
  }
  body.theme-navy .agenda-event-title {
    font-size: 14px;
  }
  body.theme-navy .agenda-bar-title {
    font-size: 15px;
  }
  body.theme-navy .over-mosaic {
    padding: 0 0 70px;
  }
  body.theme-navy .over-story-content p {
    font-size: 17px;
  }
  body.theme-navy .mosaic-slider {
    padding: 4px 28px;
    scroll-padding: 0 28px;
  }
  body.theme-navy .mosaic-slider figure {
    flex: 0 0 calc(100% - 56px - 40px);
    max-width: 320px;
  }
  body.theme-navy .mosaic-slider figure img {
    height: 360px;
  }
  body.theme-navy .mosaic-slider figcaption {
    font-size: 22px;
  }
  body.theme-navy .manifest-item {
    grid-template-columns: 1fr;
    gap: 8px;
  }
  body.theme-navy .manifest-item p {
    font-size: 22px;
  }
  body.theme-navy .not-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  body.theme-navy .not-card {
    padding: 32px 28px 28px;
  }
  body.theme-navy .not-card h3 {
    font-size: 26px;
  }
  body.theme-navy .book-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  body.theme-navy .book-cover {
    margin: 0 auto;
    max-width: 260px;
  }
  body.theme-navy .book-signup {
    flex-direction: column;
  }
  body.theme-navy .book-signup .btn {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 480px) {
  body.theme-navy .over-hero-text h1 {
    font-size: 30px;
  }
  body.theme-navy .mosaic-slider figure img {
    height: 320px;
  }
  body.theme-navy .manifest-item p {
    font-size: 20px;
  }
  body.theme-navy .agenda {
    --hour-height: 40px;
  }
  body.theme-navy .agenda-body {
    grid-template-columns: 48px 1fr;
  }
  body.theme-navy .agenda-event-title {
    font-size: 13px;
  }
}

/* ════════════════════════════════════════════════════════════════════════
   ONDER CONSTRUCTIE — placeholder pagina's (juridische teksten etc)
   ════════════════════════════════════════════════════════════════════════ */
body.theme-navy .under-construction {
  padding: 160px 0 120px;
  background: var(--cream-dark);
  min-height: calc(100vh - 200px);
  display: flex;
  align-items: center;
}
body.theme-navy .under-construction .container-narrow {
  max-width: 640px;
  padding: 0 28px;
}
body.theme-navy .construction-content {
  text-align: center;
}
body.theme-navy .construction-dots {
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-bottom: 36px;
}
body.theme-navy .construction-dots span {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--orange);
  animation: constructionPulse 1.4s ease-in-out infinite;
}
body.theme-navy .construction-dots span:nth-child(2) { animation-delay: 0.2s; }
body.theme-navy .construction-dots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes constructionPulse {
  0%, 60%, 100% { opacity: 0.25; transform: scale(0.8); }
  30%           { opacity: 1; transform: scale(1); }
}
body.theme-navy .construction-content .eyebrow {
  margin-bottom: 22px;
}
body.theme-navy .construction-content h1 {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(40px, 5vw, 60px);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--forest);
  margin: 0 0 28px;
}
body.theme-navy .construction-content p {
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  line-height: 1.6;
  color: var(--ink);
  margin: 0 auto 18px;
  max-width: 520px;
}
body.theme-navy .construction-content p:last-of-type {
  margin-bottom: 36px;
}
body.theme-navy .construction-actions {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
}
@media (max-width: 860px) {
  body.theme-navy .under-construction {
    padding: 120px 0 80px;
  }
  body.theme-navy .construction-content h1 {
    font-size: 36px;
  }
  body.theme-navy .construction-content p {
    font-size: 16px;
  }
}

/* ════════════════════════════════════════════════════════════════════════
   VOOR OUDERS PAGE — service page voor opvoedcoaching
   ════════════════════════════════════════════════════════════════════════ */

/* HERO ----------------------------------------------------------------- */
body.theme-navy .ouders-hero {
  padding: 80px 0;
  background: #ffffff;
  position: relative;
}
body.theme-navy .ouders-hero-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 80px;
  align-items: center;
}
body.theme-navy .ouders-hero-text .eyebrow {
  margin-bottom: 22px;
}
body.theme-navy .ouders-hero-text h1 {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(40px, 5vw, 64px);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--forest);
  margin: 0 0 28px;
}
body.theme-navy .ouders-hero-text h1 em {
  font-style: normal;
  color: var(--orange);
}
body.theme-navy .ouders-hero-text p {
  font-family: 'Public Sans', sans-serif;
  font-size: 19px;
  line-height: 1.55;
  color: var(--ink);
  max-width: 540px;
  margin: 0 0 32px;
}
body.theme-navy .ouders-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 16px;
  margin-bottom: 36px;
}
body.theme-navy .ouders-hero-meta-item {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--forest);
  background: var(--cream-dark);
  padding: 10px 18px;
  border-radius: 100px;
}
body.theme-navy .ouders-hero-meta-item svg {
  color: var(--orange);
  flex-shrink: 0;
}
body.theme-navy .ouders-hero-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}
body.theme-navy .ouders-hero-photo {
  aspect-ratio: 4/5;
  border-radius: 20px;
  background:
    url('ouders-1.jpg') center/cover no-repeat,
    linear-gradient(135deg, var(--lime), var(--forest));
  box-shadow: 0 30px 70px -25px rgba(6,50,49,0.4);
}

/* HERKEN JE DIT? — paper-card met staggered checklist en hover-effect -- */
body.theme-navy .ouders-pain {
  padding: 100px 0;
  background: var(--cream-dark);
}
body.theme-navy .pain-block {
  max-width: 720px;
  margin: 0 auto;
  background: #ffffff;
  border-radius: 24px;
  padding: 72px 64px 64px;
  box-shadow:
    0 30px 70px -30px rgba(6,50,49,0.25),
    0 10px 30px -15px rgba(6,50,49,0.1);
  position: relative;
  text-align: center;
}
/* Klein oranje accent-streepje bovenin de kaart */
body.theme-navy .pain-block::before {
  content: "";
  position: absolute;
  top: 32px;
  left: 50%;
  transform: translateX(-50%);
  width: 48px;
  height: 3px;
  border-radius: 2px;
  background: var(--orange);
}
body.theme-navy .pain-block .eyebrow {
  margin-bottom: 22px;
}
body.theme-navy .pain-block h2 {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(34px, 4.4vw, 52px);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--forest);
  margin: 0 0 32px;
}
body.theme-navy .pain-block h2 em {
  font-style: normal;
  color: var(--orange);
}
body.theme-navy .pain-lead {
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  line-height: 1.55;
  color: var(--ink);
  margin: 0 0 24px;
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}
body.theme-navy .pain-intro {
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0 0 28px;
  font-weight: 500;
}
body.theme-navy .pain-list {
  list-style: none;
  padding: 0;
  margin: 0 auto 36px;
  text-align: left;
  max-width: 520px;
}
body.theme-navy .pain-list li {
  font-family: 'Public Sans', sans-serif;
  font-size: 17px;
  line-height: 1.5;
  color: var(--forest);
  padding: 14px 18px 14px 60px;
  position: relative;
  border-radius: 12px;
  cursor: default;
  transition: background 0.3s ease, transform 0.3s ease;
  font-weight: 500;
}
body.theme-navy .pain-list li {
  cursor: pointer;
  user-select: none;
}
body.theme-navy .pain-list li:hover {
  background: var(--cream-dark);
}
/* Lege oranje cirkel als startpunt */
body.theme-navy .pain-list li::before {
  content: "";
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: transparent;
  border: 2.5px solid var(--orange);
  transition: background 0.25s cubic-bezier(0.4, 0, 0.2, 1),
              transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  box-sizing: border-box;
}
/* SVG potlood-scribble: zigzag binnen de cirkel die zich "inkrast" bij is-checked */
body.theme-navy .pain-check-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 30px;
  height: 30px;
  pointer-events: none;
  z-index: 1;
}
body.theme-navy .pain-scribble {
  stroke-dasharray: 100;
  stroke-dashoffset: 100;
  stroke-opacity: 0;
  stroke-linecap: butt;
  transition: stroke-dashoffset 0.8s cubic-bezier(0.4, 0, 0.2, 1),
              stroke-opacity 0.15s ease;
}
body.theme-navy .pain-list li.is-checked .pain-scribble {
  stroke-opacity: 1;
  stroke-linecap: round;
}
/* Bij hover: cirkel pulst lichtjes */
body.theme-navy .pain-list li:hover::before {
  transform: translateY(-50%) scale(1.08);
}
/* AANGEVINKT: cirkel blijft outline, scribble krast zich erin */
body.theme-navy .pain-list li.is-checked::before {
  background: rgba(247, 87, 9, 0.06);
  border-color: var(--orange);
  animation: painCheckPop 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}
body.theme-navy .pain-list li.is-checked .pain-scribble {
  stroke-dashoffset: 0;
}
@keyframes painCheckPop {
  0%   { transform: translateY(-50%) scale(1); }
  40%  { transform: translateY(-50%) scale(1.18); }
  100% { transform: translateY(-50%) scale(1); }
}
/* Tally en complete-message */
body.theme-navy .pain-tally {
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ink-soft);
  margin-bottom: 24px;
}
body.theme-navy .pain-tally-count {
  display: inline-block;
  min-width: 1.2em;
  font-size: 20px;
  color: var(--orange);
  font-weight: 700;
  letter-spacing: 0;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}
body.theme-navy .pain-tally.has-bumped .pain-tally-count {
  animation: tallyBump 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}
@keyframes tallyBump {
  0%   { transform: scale(1); }
  40%  { transform: scale(1.4); }
  100% { transform: scale(1); }
}
body.theme-navy .pain-complete {
  font-family: 'Reenie Beanie', cursive;
  line-height: 1.15;
  color: var(--orange);
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transform: translateY(8px);
  transition: opacity 0.4s ease, transform 0.4s ease, max-height 0.4s ease,
              margin 0.4s ease, font-size 0.3s ease, color 0.3s ease;
  margin: 0;
  font-size: 26px;
}
body.theme-navy .pain-complete.is-visible {
  opacity: 1;
  max-height: 120px;
  transform: translateY(0);
  margin: 0 0 24px;
}
/* CTA-knop onder de wisselende boodschap */
body.theme-navy .pain-cta {
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transform: translateY(8px);
  transition: opacity 0.4s ease, transform 0.4s ease, max-height 0.4s ease, margin 0.4s ease;
  margin: 0;
}
body.theme-navy .pain-cta.is-visible {
  opacity: 1;
  max-height: 80px;
  transform: translateY(0);
  margin: 0 0 24px;
}
body.theme-navy .pain-cta .btn {
  font-size: 15px;
}
body.theme-navy .pain-cta .btn svg {
  flex-shrink: 0;
}

/* Lettertype is overal 30px; alleen de kleur verschuift mee met de intensiteit */
body.theme-navy .pain-complete { font-size: 30px; }
body.theme-navy .pain-complete[data-intensity="1"] { color: var(--orange); }
body.theme-navy .pain-complete[data-intensity="2"] { color: var(--orange); }
body.theme-navy .pain-complete[data-intensity="3"] { color: var(--orange); }
body.theme-navy .pain-complete[data-intensity="4"] { color: var(--orange-dark); }
body.theme-navy .pain-complete[data-intensity="5"] { color: var(--orange-dark); }
body.theme-navy .pain-complete[data-intensity="6"] { color: #c43d05; }
/* Stagger reveal voor list items */
body.theme-navy .pain-list li {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.6s cubic-bezier(.2,.7,.2,1),
              transform 0.6s cubic-bezier(.2,.7,.2,1),
              background 0.3s ease;
}
body.theme-navy .pain-block.is-revealed .pain-list li {
  opacity: 1;
  transform: translateY(0);
}
body.theme-navy .pain-block.is-revealed .pain-list li:hover {
  transform: translateX(4px);
}
body.theme-navy .pain-block.is-revealed .pain-list li:nth-child(1) { transition-delay: 0.10s, 0.10s, 0s; }
body.theme-navy .pain-block.is-revealed .pain-list li:nth-child(2) { transition-delay: 0.20s, 0.20s, 0s; }
body.theme-navy .pain-block.is-revealed .pain-list li:nth-child(3) { transition-delay: 0.30s, 0.30s, 0s; }
body.theme-navy .pain-block.is-revealed .pain-list li:nth-child(4) { transition-delay: 0.40s, 0.40s, 0s; }
body.theme-navy .pain-block.is-revealed .pain-list li:nth-child(5) { transition-delay: 0.50s, 0.50s, 0s; }
body.theme-navy .pain-block.is-revealed .pain-list li:nth-child(6) { transition-delay: 0.60s, 0.60s, 0s; }
body.theme-navy .pain-outro {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 18px;
  font-style: italic;
  line-height: 1.5;
  color: var(--ink-soft);
  margin: 0 auto;
  max-width: 480px;
}
@media (prefers-reduced-motion: reduce) {
  body.theme-navy .pain-list li {
    opacity: 1;
    transform: none;
  }
}
@media (max-width: 860px) {
  body.theme-navy .pain-block {
    padding: 56px 32px 48px;
  }
  body.theme-navy .pain-list li {
    padding: 12px 14px 12px 54px;
    font-size: 16px;
  }
  body.theme-navy .pain-list li::before {
    left: 12px;
    width: 26px;
    height: 26px;
    background-size: 14px;
  }
}

/* BENEFITS — hergebruik contact-paths styling met kleine tweak --------- */
body.theme-navy .ouders-benefits {
  padding: 100px 0;
  background: #ffffff;
}
/* Icoon-animaties: oog knipoogt, kompasnaald slingert, theedamp stijgt op */
@keyframes oudersBenefitBlink {
  0%, 85%, 100% { transform: scaleY(1); }
  92%, 96%      { transform: scaleY(0.05); }
}
body.theme-navy .icon-eye {
  animation: oudersBenefitBlink 2s infinite;
  transform-origin: 12px 12px;
  transform-box: view-box;
}
@keyframes oudersBenefitSwing {
  0%, 100% { transform: rotate(-30deg); }
  50%      { transform: rotate(30deg); }
}
body.theme-navy .icon-compass polygon {
  animation: oudersBenefitSwing 4s ease-in-out infinite;
  transform-origin: 12px 12px;
  transform-box: view-box;
}
@keyframes oudersBenefitSteam {
  0%   { transform: translateY(0); opacity: 0.4; }
  30%  { opacity: 1; }
  100% { transform: translateY(-2px); opacity: 0; }
}
body.theme-navy .icon-tea .steam {
  animation: oudersBenefitSteam 2.4s ease-out infinite;
  transform-box: view-box;
  transform-origin: bottom;
}
body.theme-navy .icon-tea .steam:nth-of-type(2) { animation-delay: 0.8s; }
body.theme-navy .icon-tea .steam:nth-of-type(3) { animation-delay: 1.6s; }
@media (prefers-reduced-motion: reduce) {
  body.theme-navy .icon-eye,
  body.theme-navy .icon-compass polygon,
  body.theme-navy .icon-tea .steam {
    animation: none;
  }
}
body.theme-navy .ouders-benefits .section-head {
  text-align: center;
  margin-bottom: 60px;
}
body.theme-navy .ouders-benefits .section-head p {
  max-width: 580px;
  margin: 16px auto 0;
}

/* PRICING — drie tier-kaarten ---------------------------------------- */
body.theme-navy .ouders-pricing {
  padding: 100px 0;
  background: #ffffff;
}
body.theme-navy .ouders-pricing .section-head {
  text-align: center;
  margin-bottom: 60px;
}
body.theme-navy .ouders-pricing .section-head p {
  max-width: 580px;
  margin: 16px auto 0;
}
body.theme-navy .pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  align-items: stretch;
}
body.theme-navy .price-card {
  background: var(--cream-dark);
  border-radius: 20px;
  padding: 40px 32px 36px;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: transform 0.3s ease;
}
body.theme-navy .price-card:hover {
  transform: translateY(-4px);
}
body.theme-navy .price-card--featured {
  background: var(--forest);
  color: #ffffff;
  box-shadow: 0 30px 60px -25px rgba(6,50,49,0.35);
  animation: priceCardFloat 2.6s ease-in-out infinite;
}
body.theme-navy .price-card--featured:hover {
  animation-play-state: paused;
  transform: translateY(-8px);
}
@keyframes priceCardFloat {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-10px); }
}
@media (prefers-reduced-motion: reduce) {
  body.theme-navy .price-card--featured {
    animation: none;
  }
}
body.theme-navy .price-tag {
  font-family: 'Oswald', sans-serif;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--orange);
  margin-bottom: 18px;
}
body.theme-navy .price-card--featured .price-tag {
  color: var(--lime);
}
body.theme-navy .price-card h3 {
  font-family: 'Oswald', sans-serif;
  font-size: 26px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  color: var(--forest);
  margin: 0 0 18px;
  line-height: 1.1;
}
body.theme-navy .price-card--featured h3 {
  color: #ffffff;
}
body.theme-navy .price-amount {
  font-family: 'Oswald', sans-serif;
  font-size: 48px;
  font-weight: 700;
  color: var(--forest);
  line-height: 1;
  letter-spacing: -0.02em;
  margin-bottom: 8px;
}
body.theme-navy .price-card--featured .price-amount {
  color: var(--lime);
}
body.theme-navy .price-meta {
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  color: var(--ink-soft);
  margin-bottom: 28px;
}
body.theme-navy .price-card--featured .price-meta {
  color: rgba(255,255,255,0.7);
}
body.theme-navy .price-card ul {
  list-style: none;
  padding: 0;
  margin: 0 0 32px;
  flex: 1;
}
body.theme-navy .price-card li {
  font-family: 'Public Sans', sans-serif;
  font-size: 15px;
  line-height: 1.5;
  color: var(--ink);
  padding: 10px 0 10px 26px;
  position: relative;
  border-top: 1px solid rgba(6,50,49,0.08);
}
body.theme-navy .price-card--featured li {
  color: rgba(255,255,255,0.85);
  border-top-color: rgba(255,255,255,0.1);
}
body.theme-navy .price-card li:first-child {
  border-top: none;
}
body.theme-navy .price-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 16px;
  width: 14px;
  height: 14px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f75709' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-size: contain;
  background-repeat: no-repeat;
}
body.theme-navy .price-card--featured li::before {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c3df94' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
}
body.theme-navy .price-card .btn {
  width: 100%;
  justify-content: center;
}

/* RESPONSIVE ---------------------------------------------------------- */
@media (max-width: 1024px) {
  body.theme-navy .ouders-hero-grid {
    grid-template-columns: 1.1fr 1fr;
    gap: 50px;
  }
  body.theme-navy .pain-list li {
    font-size: 17px;
  }
}
@media (max-width: 860px) {
  body.theme-navy .ouders-hero {
    padding: 60px 0;
  }
  body.theme-navy .ouders-hero-grid {
    grid-template-columns: 1fr;
    gap: 50px;
  }
  body.theme-navy .ouders-hero-text h1 {
    font-size: 38px;
  }
  body.theme-navy .ouders-hero-photo {
    max-width: 320px;
    width: 100%;
    margin: 0 auto;
  }
  body.theme-navy .ouders-pain,
  body.theme-navy .ouders-benefits,
  body.theme-navy .ouders-pricing {
    padding: 70px 0;
  }
  body.theme-navy .pain-list li {
    font-size: 16px;
    padding-left: 30px;
  }
  body.theme-navy .pain-outro {
    font-size: 16px;
  }
  body.theme-navy .pricing-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }
}
@media (max-width: 480px) {
  body.theme-navy .ouders-hero-text h1 {
    font-size: 32px;
  }
  body.theme-navy .price-amount {
    font-size: 40px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   VOOR-KOPPELS pagina — eigen identiteit binnen het brand-palet
   ═══════════════════════════════════════════════════════════════ */

/* ─── HERO: dubbel-portret met spark in het midden ─── */
body.theme-navy .koppels-hero {
  padding: 100px 0 90px;
  background: #ffffff;
  position: relative;
  overflow: hidden;
}
body.theme-navy .koppels-hero::before {
  content: "";
  position: absolute;
  inset: auto -10% -40% auto;
  width: 60%;
  aspect-ratio: 1;
  background: radial-gradient(circle, rgba(247,87,9,0.06), transparent 60%);
  pointer-events: none;
}
body.theme-navy .koppels-hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 80px;
  align-items: center;
  position: relative;
}
body.theme-navy .koppels-hero-text .eyebrow {
  margin-bottom: 22px;
}
body.theme-navy .koppels-hero-text h1 {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(40px, 5vw, 64px);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--forest);
  margin: 0 0 28px;
}
body.theme-navy .koppels-hero-text h1 em {
  font-style: normal;
  color: var(--orange);
}
body.theme-navy .koppels-hero-lead {
  font-family: 'Public Sans', sans-serif;
  font-size: 19px;
  line-height: 1.55;
  color: var(--ink, var(--forest));
  max-width: 540px;
  margin: 0 0 32px;
}
body.theme-navy .koppels-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 16px;
  margin-bottom: 36px;
}
body.theme-navy .koppels-hero-meta-item {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--forest);
  background: var(--cream-dark);
  padding: 10px 18px;
  border-radius: 100px;
}
body.theme-navy .koppels-hero-meta-item svg {
  color: var(--orange);
  flex-shrink: 0;
}
body.theme-navy .koppels-hero-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}
/* Dubbel-portret compositie */
body.theme-navy .koppels-hero-visual {
  position: relative;
  aspect-ratio: 1;
  min-height: 460px;
}
body.theme-navy .koppels-hero-portrait {
  position: absolute;
  width: 62%;
  aspect-ratio: 1;
  border-radius: 28px;
  background-size: cover;
  background-position: center;
  box-shadow: 0 30px 70px -25px rgba(6,50,49,0.35);
}
body.theme-navy .koppels-hero-portrait--a {
  top: 0;
  left: 0;
  background:
    url('koppels-1.jpg') center/cover no-repeat,
    linear-gradient(135deg, var(--lime) 0%, #5b9080 100%);
  z-index: 1;
  transform: rotate(-3deg);
}
body.theme-navy .koppels-hero-portrait--b {
  bottom: 0;
  right: 0;
  background:
    url('koppels-2.jpg') center/cover no-repeat,
    linear-gradient(135deg, var(--forest) 0%, #2a605d 100%);
  z-index: 2;
  transform: rotate(3deg);
}
body.theme-navy .koppels-hero-spark {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 86px;
  height: 86px;
  border-radius: 50%;
  background: var(--orange);
  color: #ffffff;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 18px 36px -12px rgba(247,87,9,0.55);
  z-index: 3;
}
body.theme-navy .koppels-hero-spark svg {
  width: 50px;
  height: 50px;
}
/* Cumulatieve dots: eerst stip 1, dan +2, dan +3, daarna reset en opnieuw */
body.theme-navy .koppels-hero-spark svg circle:nth-of-type(1) {
  animation: koppelsDot1 1.9s ease-in-out infinite;
}
body.theme-navy .koppels-hero-spark svg circle:nth-of-type(2) {
  animation: koppelsDot2 1.9s ease-in-out infinite;
}
body.theme-navy .koppels-hero-spark svg circle:nth-of-type(3) {
  animation: koppelsDot3 1.9s ease-in-out infinite;
}
@keyframes koppelsDot1 {
  0%, 6%       { opacity: 0; }
  14%, 90%     { opacity: 1; }
  100%         { opacity: 0; }
}
@keyframes koppelsDot2 {
  0%, 28%      { opacity: 0; }
  36%, 90%     { opacity: 1; }
  100%         { opacity: 0; }
}
@keyframes koppelsDot3 {
  0%, 50%      { opacity: 0; }
  58%, 90%     { opacity: 1; }
  100%         { opacity: 0; }
}

/* ─── DIALOOG-SECTIE: paren van uitspraken (hij/zij) ─── */
body.theme-navy .koppels-dialog {
  padding: 100px 0 90px;
  background: var(--cream-dark);
  position: relative;
}
body.theme-navy .koppels-dialog .section-head {
  text-align: center;
  max-width: 680px;
  margin: 0 auto 60px;
}
body.theme-navy .koppels-dialog .section-head h2 {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(30px, 3.4vw, 44px);
  font-weight: 700;
  line-height: 1.1;
  text-transform: uppercase;
  color: var(--forest);
  letter-spacing: -0.01em;
  margin: 12px 0 18px;
}
body.theme-navy .koppels-dialog .section-head h2 em {
  font-style: normal;
  color: var(--orange);
}
body.theme-navy .koppels-dialog .section-head p {
  font-family: 'Public Sans', sans-serif;
  font-size: 17px;
  line-height: 1.55;
  color: var(--forest);
  margin: 0;
}
body.theme-navy .koppels-dialog-list {
  max-width: 900px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 44px;
}
body.theme-navy .koppels-dialog-pair {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
body.theme-navy .koppels-dialog-topic {
  font-family: 'Reenie Beanie', cursive;
  font-size: 30px;
  color: var(--orange);
  transform: rotate(-2deg);
  padding: 0 14px;
}
body.theme-navy .koppels-dialog-bubbles {
  display: grid;
  grid-template-columns: 1fr 50px 1fr;
  gap: 0;
  align-items: center;
  width: 100%;
}
body.theme-navy .koppels-dialog-quote {
  padding: 22px 26px;
  border-radius: 18px;
  position: relative;
  background: #ffffff;
  box-shadow: 0 10px 28px -16px rgba(6,50,49,0.25);
}
body.theme-navy .koppels-dialog-quote--a {
  border-bottom-left-radius: 4px;
  border-left: 4px solid var(--lime);
  justify-self: end;
  max-width: 360px;
  width: 100%;
}
body.theme-navy .koppels-dialog-quote--b {
  background: var(--forest);
  color: #ffffff;
  border-bottom-right-radius: 4px;
  border-right: 4px solid var(--orange);
  justify-self: start;
  max-width: 360px;
  width: 100%;
}
body.theme-navy .koppels-dialog-who {
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 11px;
  font-weight: 700;
  margin-bottom: 8px;
  color: var(--forest);
  opacity: 0.6;
}
body.theme-navy .koppels-dialog-quote--b .koppels-dialog-who {
  color: var(--lime);
  opacity: 0.9;
}
body.theme-navy .koppels-dialog-quote p {
  margin: 0;
  font-family: 'Public Sans', sans-serif;
  font-size: 17px;
  line-height: 1.5;
  font-weight: 500;
}
/* Verbindings-streep tussen de twee bubbels */
body.theme-navy .koppels-dialog-link {
  height: 2px;
  background: linear-gradient(90deg, var(--lime), var(--orange));
  width: 100%;
  position: relative;
  align-self: center;
}
body.theme-navy .koppels-dialog-link::before,
body.theme-navy .koppels-dialog-link::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  transform: translateY(-50%);
}
body.theme-navy .koppels-dialog-link::before {
  left: 0;
  background: var(--lime);
}
body.theme-navy .koppels-dialog-link::after {
  right: 0;
  background: var(--orange);
}
body.theme-navy .koppels-dialog-note {
  max-width: 620px;
  margin: 70px auto 0;
  text-align: center;
  font-family: 'Public Sans', sans-serif;
  font-size: 17px;
  line-height: 1.55;
  color: var(--forest);
  font-style: italic;
}
body.theme-navy .koppels-dialog-note em {
  font-style: normal;
  color: var(--orange);
  font-weight: 600;
}

/* ─── HOE WIJ ER MEE WERKEN: tekst + quote-callout ─── */
body.theme-navy .koppels-howit {
  padding: 100px 0;
  background: #ffffff;
}
body.theme-navy .koppels-howit-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 70px;
  align-items: center;
  max-width: 1100px;
  margin: 0 auto;
}
body.theme-navy .koppels-howit-text .eyebrow {
  margin-bottom: 18px;
}
body.theme-navy .koppels-howit-text h2 {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(28px, 3.2vw, 40px);
  font-weight: 700;
  line-height: 1.1;
  text-transform: uppercase;
  color: var(--forest);
  letter-spacing: -0.01em;
  margin: 0 0 22px;
}
body.theme-navy .koppels-howit-text h2 em {
  font-style: normal;
  color: var(--orange);
}
body.theme-navy .koppels-howit-text p {
  font-family: 'Public Sans', sans-serif;
  font-size: 17px;
  line-height: 1.6;
  color: var(--forest);
  margin: 0 0 24px;
}
body.theme-navy .koppels-howit-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
body.theme-navy .koppels-howit-list li {
  display: flex;
  align-items: center;
  gap: 14px;
  font-family: 'Public Sans', sans-serif;
  font-size: 16px;
  color: var(--forest);
}
body.theme-navy .koppels-howit-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--orange);
  flex-shrink: 0;
}
/* Quote-callout */
body.theme-navy .koppels-howit-quote {
  background: var(--forest);
  color: #ffffff;
  padding: 50px 44px 44px;
  border-radius: 28px;
  position: relative;
  box-shadow: 0 30px 60px -25px rgba(6,50,49,0.35);
}
body.theme-navy .koppels-howit-mark {
  position: absolute;
  top: -28px;
  left: 36px;
  width: 56px;
  height: 56px;
  padding: 12px;
  background: var(--orange);
  color: #ffffff;
  border-radius: 50%;
  box-shadow: 0 10px 24px -8px rgba(247,87,9,0.5);
}
body.theme-navy .koppels-howit-quote p {
  font-family: 'Fraunces', serif;
  font-size: 22px;
  line-height: 1.4;
  font-weight: 400;
  margin: 0 0 22px;
  font-style: italic;
}
body.theme-navy .koppels-howit-attrib {
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 13px;
  color: var(--lime);
}

/* ─── REVIEWS: twee stemmen per koppel naast elkaar ─── */
body.theme-navy .koppels-reviews {
  padding: 100px 0;
  background: var(--cream-dark);
}
body.theme-navy .koppels-reviews .section-head {
  text-align: center;
  max-width: 680px;
  margin: 0 auto 50px;
}
body.theme-navy .koppels-reviews .section-head h2 {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(30px, 3.4vw, 44px);
  font-weight: 700;
  line-height: 1.1;
  text-transform: uppercase;
  color: var(--forest);
  letter-spacing: -0.01em;
  margin: 12px 0 18px;
}
body.theme-navy .koppels-reviews .section-head h2 em {
  font-style: normal;
  color: var(--orange);
}
body.theme-navy .koppels-reviews .section-head p {
  font-family: 'Public Sans', sans-serif;
  font-size: 17px;
  line-height: 1.55;
  color: var(--forest);
  margin: 0;
}
body.theme-navy .koppels-reviews-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
  max-width: 920px;
  margin: 0 auto;
}
body.theme-navy .koppels-review {
  background: #ffffff;
  border-radius: 22px;
  padding: 36px 40px 30px;
  box-shadow: 0 16px 40px -22px rgba(6,50,49,0.22);
}
body.theme-navy .koppels-review-pair {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 28px;
  align-items: stretch;
}
body.theme-navy .koppels-review-half {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
body.theme-navy .koppels-review-name {
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 16px;
  font-weight: 700;
  color: var(--orange);
}
body.theme-navy .koppels-review-half p {
  margin: 0;
  font-family: 'Fraunces', serif;
  font-size: 18px;
  line-height: 1.5;
  color: var(--forest);
  font-style: italic;
}
body.theme-navy .koppels-review-divider {
  width: 1px;
  background: linear-gradient(180deg, transparent, var(--forest), transparent);
  opacity: 0.25;
}
body.theme-navy .koppels-review-meta {
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px dashed rgba(6,50,49,0.15);
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 16px;
  color: var(--forest);
  opacity: 0.6;
  text-align: center;
}

/* ─── RESPONSIVE: tablet ─── */
@media (max-width: 980px) {
  body.theme-navy .koppels-hero-grid,
  body.theme-navy .koppels-howit-grid {
    grid-template-columns: 1fr;
    gap: 50px;
  }
  body.theme-navy .koppels-hero-visual {
    min-height: 380px;
    max-width: 460px;
    margin: 0 auto;
  }
  body.theme-navy .koppels-howit-quote {
    padding: 44px 32px 32px;
  }
}

/* ─── RESPONSIVE: mobiel ─── */
@media (max-width: 700px) {
  body.theme-navy .koppels-hero {
    padding: 70px 0 60px;
  }
  body.theme-navy .koppels-hero-visual {
    min-height: 340px;
  }
  body.theme-navy .koppels-dialog {
    padding: 70px 0 60px;
  }
  body.theme-navy .koppels-dialog-bubbles {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  body.theme-navy .koppels-dialog-quote--a,
  body.theme-navy .koppels-dialog-quote--b {
    justify-self: stretch;
    max-width: 100%;
  }
  body.theme-navy .koppels-dialog-link {
    width: 60%;
    margin: 0 auto;
    transform: rotate(90deg);
  }
  body.theme-navy .koppels-dialog-topic {
    font-size: 22px;
  }
  body.theme-navy .koppels-reviews {
    padding: 70px 0 60px;
  }
  body.theme-navy .koppels-review {
    padding: 28px 26px 22px;
  }
  body.theme-navy .koppels-review-pair {
    grid-template-columns: 1fr;
    gap: 22px;
  }
  body.theme-navy .koppels-review-divider {
    height: 1px;
    width: 60%;
    margin: 0 auto;
    background: linear-gradient(90deg, transparent, var(--forest), transparent);
  }
  body.theme-navy .koppels-howit {
    padding: 70px 0;
  }
  body.theme-navy .koppels-howit-mark {
    width: 44px;
    height: 44px;
    padding: 9px;
    top: -22px;
    left: 24px;
  }
  body.theme-navy .koppels-howit-quote p {
    font-size: 19px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   EASY TABLE OF CONTENTS — exact in demo-stijl (oranje cirkels)
   ═══════════════════════════════════════════════════════════════ */

/* Container */
#ez-toc-container,
[id^="ez-toc-container"] {
  background: var(--cream-dark, #f5f7f7) !important;
  border: none !important;
  border-radius: 14px !important;
  padding: 36px 40px !important;
  margin: 36px 0 !important;
  box-shadow: 0 6px 18px -10px rgba(6,50,49,0.1) !important;
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  float: none !important;
}

/* Titel: oranje, klein uppercase, geen toggle */
#ez-toc-container .ez-toc-title-container {
  border-bottom: none !important;
  padding: 0 !important;
  margin: 0 0 24px !important;
}
#ez-toc-container .ez-toc-title {
  font-family: 'Oswald', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.14em !important;
  color: var(--orange, #f75709) !important;
  margin: 0 !important;
  padding: 0 !important;
  background: none !important;
  text-shadow: none !important;
}
#ez-toc-container .ez-toc-title-toggle,
#ez-toc-container .ez-toc-pull-right,
#ez-toc-container .ez-toc-toggle {
  display: none !important;
}

/* Lijsten resetten */
#ez-toc-container nav { margin: 0 !important; padding: 0 !important; }
#ez-toc-container ul,
#ez-toc-container ol {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  counter-reset: ez-toc-main;
}
/* Verberg ingebakken cijfers/pijltjes van de plugin */
#ez-toc-container ul li::before,
#ez-toc-container ul li::after,
#ez-toc-container ol li::before,
#ez-toc-container ol li::after,
#ez-toc-container .ez-toc-list-level-1 > li > a::before,
#ez-toc-container .ez-toc-icon-toggle-span { content: none !important; display: none !important; }

/* Hoofd-items: flex met oranje cirkel + bold dark text */
#ez-toc-container > nav > ul > li,
#ez-toc-container > ul > li {
  display: flex !important;
  align-items: center !important;
  gap: 18px !important;
  margin: 14px 0 !important;
  padding: 0 !important;
  counter-increment: ez-toc-main !important;
  counter-reset: ez-toc-sub !important;
  background: none !important;
  border: none !important;
  list-style: none !important;
  position: relative;
  flex-wrap: wrap;
}

/* Oranje cirkel met nummer als ::before van het li-element */
#ez-toc-container > nav > ul > li::before,
#ez-toc-container > ul > li::before {
  content: counter(ez-toc-main, decimal-leading-zero) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  background: var(--orange, #f75709) !important;
  color: #ffffff !important;
  font-family: 'Oswald', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  flex-shrink: 0 !important;
}

/* Hoofd-link: bold dark petrol */
#ez-toc-container > nav > ul > li > a,
#ez-toc-container > ul > li > a {
  color: var(--forest, #063231) !important;
  font-family: 'Public Sans', sans-serif !important;
  font-size: 17px !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
  text-decoration: none !important;
  background: none !important;
  padding: 0 !important;
  transition: color 0.2s ease !important;
  flex: 1 1 auto;
  min-width: 0;
}
#ez-toc-container > nav > ul > li > a:hover {
  color: var(--orange, #f75709) !important;
}

/* Sub-lijst: ingesprongen onder het hoofd-item, full-width op nieuwe regel */
#ez-toc-container > nav > ul > li > ul,
#ez-toc-container > nav > ul > li > ol,
#ez-toc-container > ul > li > ul,
#ez-toc-container > ul > li > ol {
  flex-basis: 100% !important;
  margin: 8px 0 8px 54px !important;
  padding: 0 !important;
  display: block !important;
}

/* Sub-items: oranje "x.y" nummer + grijze tekst */
#ez-toc-container > nav > ul > li > ul > li,
#ez-toc-container > nav > ul > li > ol > li,
#ez-toc-container > ul > li > ul > li,
#ez-toc-container > ul > li > ol > li {
  display: flex !important;
  align-items: baseline !important;
  gap: 14px !important;
  margin: 6px 0 !important;
  padding: 0 !important;
  counter-increment: ez-toc-sub !important;
  background: none !important;
  border: none !important;
  list-style: none !important;
}
#ez-toc-container > nav > ul > li > ul > li::before,
#ez-toc-container > nav > ul > li > ol > li::before,
#ez-toc-container > ul > li > ul > li::before,
#ez-toc-container > ul > li > ol > li::before {
  content: counter(ez-toc-main) "." counter(ez-toc-sub) !important;
  display: inline-block !important;
  color: var(--orange, #f75709) !important;
  font-family: 'Public Sans', sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  background: none !important;
  width: auto !important;
  height: auto !important;
  border-radius: 0 !important;
  flex-shrink: 0 !important;
  min-width: 28px;
}
#ez-toc-container > nav > ul > li > ul > li > a,
#ez-toc-container > nav > ul > li > ol > li > a,
#ez-toc-container > ul > li > ul > li > a,
#ez-toc-container > ul > li > ol > li > a {
  color: rgba(6,50,49,0.7) !important;
  font-family: 'Public Sans', sans-serif !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  line-height: 1.4 !important;
  text-decoration: none !important;
  background: none !important;
  padding: 0 !important;
  transition: color 0.2s ease !important;
}
#ez-toc-container > nav > ul > li > ul > li > a:hover,
#ez-toc-container > nav > ul > li > ol > li > a:hover,
#ez-toc-container > ul > li > ul > li > a:hover,
#ez-toc-container > ul > li > ol > li > a:hover {
  color: var(--orange, #f75709) !important;
}

/* ═══════════════════════════════════════════════════════════════
   AANKONDIGINGSBALK — oranje balk bovenaan, scrolt weg bij sticky-nav
   ═══════════════════════════════════════════════════════════════ */
.site-announcement {
  background: var(--orange, #f75709);
  color: #ffffff;
  text-align: center;
  padding: 12px 24px;
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.55;
  position: relative;
  z-index: 1;
}
.site-announcement-inner {
  max-width: 980px;
  margin: 0 auto;
}
.site-announcement strong {
  font-weight: 700;
}
@media (max-width: 700px) {
  .site-announcement {
    padding: 10px 16px;
    font-size: 13px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   CONTACT FORM 7 — submit-button styling laten matchen met mockup
   ═══════════════════════════════════════════════════════════════ */

/* Override CF7-default styling op submit-knoppen die onze .btn-class hebben */
.wpcf7-form input[type="submit"].btn,
.wpcf7-form button[type="submit"].btn {
  display: inline-block;
  padding: 13px 26px;
  border-radius: 10px;
  font-weight: 800;
  font-size: 15px;
  border: none;
  cursor: pointer;
  font-family: inherit;
  letter-spacing: 0.01em;
  transition: all 0.2s ease;
  line-height: 1.4;
  -webkit-appearance: none;
  appearance: none;
}
.wpcf7-form input[type="submit"].btn-primary,
.wpcf7-form button[type="submit"].btn-primary {
  background: var(--orange, #f75709);
  color: #ffffff;
}
.wpcf7-form input[type="submit"].btn-primary:hover,
.wpcf7-form button[type="submit"].btn-primary:hover {
  background: var(--orange-dark, #d44708);
  transform: translateY(-1px);
}

/* CF7 spinner naast knop niet midden in layout duwen */
.wpcf7-form .wpcf7-spinner {
  margin-left: 10px;
  vertical-align: middle;
}

/* CF7 form-control wrappers (geen verkeerde defaults overerven) */
.wpcf7-form .wpcf7-form-control-wrap {
  display: block;
}
.wpcf7-form-control:not([type="submit"]):not([type="button"]) {
  font-family: inherit;
  font-size: inherit;
}

/* Validatie- en succes-meldingen passend bij de site-look */
.wpcf7-form .wpcf7-response-output {
  border-radius: 8px;
  padding: 14px 18px;
  margin: 20px 0 0;
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
}
.wpcf7-form.sent .wpcf7-response-output {
  background: var(--lime, #c3df94);
  border-color: var(--lime, #c3df94);
  color: var(--forest, #063231);
}
.wpcf7-form.invalid .wpcf7-response-output,
.wpcf7-form.failed .wpcf7-response-output {
  background: rgba(247, 87, 9, 0.08);
  border-color: var(--orange, #f75709);
  color: var(--forest, #063231);
}
.wpcf7-not-valid-tip {
  color: var(--orange-dark, #d44708);
  font-size: 13px;
  margin-top: 4px;
}
