/* ==========================================================================
   Tempro — style.css
   --------------------------------------------------------------------------
   1. VARIABLES   — scaling system + brand + nav state
   2. BASE        — reset, typography, container
   3. NAV         — fixed header, dropdowns, mobile menu
   4. SECTIONS    — hero, usp, problem/oplossing, audiences, werkwijze, signup, footer
   5. BUTTONS     — .btn, bubble arrow + variants
   6. RESPONSIVE  — alle media queries gebundeld
   ========================================================================== */


/* ==========================================================================
   1. VARIABLES
   ========================================================================== */

/* --- Osmo Scaling System ---
   Variable breakpoints staan hier (niet onderaan bij Responsive)
   omdat ze variabelen definiëren, geen style-overrides. */
:root {
  --size-unit: 16;
  --size-container-ideal: 1440;
  --size-container-min: 992px;
  --size-container-max: 1440px;
  --size-container: clamp(var(--size-container-min), 100vw, var(--size-container-max));
  --size-font: calc(var(--size-container) / (var(--size-container-ideal) / var(--size-unit)));
}
@media screen and (max-width: 991px) {
  :root { --size-container-ideal: 834; --size-container-min: 768px; --size-container-max: 991px; }
}
@media screen and (max-width: 767px) {
  :root { --size-container-ideal: 550; --size-container-min: 480px; --size-container-max: 767px; }
}
@media screen and (max-width: 479px) {
  :root { --size-container-ideal: 390; --size-container-min: 320px; --size-container-max: 479px; }
}

/* --- Tempro brand --- */
:root {
  --green:   #0D917D;
  --mint:    #0DFFC6;
  --black:   #1A2421;
  --grey:    #F5F6F5;
  --grey-2:  #E8E9E7;
  --text:    #1F2A28;
  --muted:   #5C6663;
}

/* --- Nav state --- */
:root {
  --nav-bg-height:   calc(18em + 10em);
  --cubic-default:   cubic-bezier(0.525, 0, 0, 1);
  --duration-fast:   0.2s;
  --duration-normal: 0.45s;
}

/* --- Editorial design tokens (voor Claude-Design secties: hero, audience-split, stats, etc.) --- */
:root {
  /* Easing */
  --ease:      cubic-bezier(0.625, 0.05, 0, 1);
  --ease-out:  cubic-bezier(0.16, 1, 0.3, 1);

  /* Duration */
  --dur-fast:  200ms;
  --dur:       450ms;
  --dur-slow:  800ms;

  /* Vertical section spacing */
  --space-section: clamp(5rem, 9vw, 8rem);

  /* Radius scale (3 stops) */
  --r-sm:   12px;
  --r-md:   20px;
  --r-pill: 999px;

  /* Editorial type sizes */
  --fs-eyebrow: 0.72rem;
  --fs-mega:    clamp(3rem, 9vw, 8rem);
  --fs-display: clamp(2.5rem, 5.5vw, 4.5rem);
  --fs-h2:      clamp(1.75rem, 3.5vw, 2.75rem);
  --fs-lead:    clamp(1.05rem, 1.2vw, 1.2rem);

  /* Side rail — afstand viewport-rand tot container-content begin.
     Gebruikt voor full-bleed secties die uitgelijnd moeten zijn met .container. */
  --rail: max(1.5rem, calc((100vw - var(--size-container)) / 2 + 1.5rem));
}


/* ==========================================================================
   2. BASE
   ========================================================================== */

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Avenir Next', 'Avenir', 'Nunito Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  font-weight: 400;
  color: var(--text);
  line-height: 1.6;
  background: #fff;
  font-size: var(--size-font);
}

h1, h2, h3, h4 { font-weight: 700; letter-spacing: -0.01em; line-height: 1.15; color: var(--black); }
h1 { font-size: clamp(1.8rem, 4vw, 3rem); }
h2 { font-size: clamp(1.4rem, 2.8vw, 2rem); margin-bottom: 1rem; }
h3 { font-size: 1.05rem; margin-bottom: .5rem; }
p  { margin-bottom: 1rem; }
a  { color: var(--green); text-decoration: none; }

.container        { max-width: var(--size-container); margin: 0 auto; padding: 0 1.5rem; }
.container.medium { max-width: calc(var(--size-container) * 0.85); }
.container.small  { max-width: calc(var(--size-container) * 0.7); }


/* ==========================================================================
   3. NAV
   ========================================================================== */

.nav {
  z-index: 100;
  position: fixed;
  top: 0; left: 0; right: 0;
  padding: 1rem 1rem 0;
  color: #fff;
  pointer-events: none;
  transition: color var(--duration-normal) var(--cubic-default);
}

/* Pill = .nav-container. Bij scroll wordt 'ie glassy. */
.nav-container {
  pointer-events: auto;
  z-index: 1;
  width: 100%;
  max-width: var(--size-container);
  margin: 0 auto;
  padding: 0 2em;
  position: relative;
  border-radius: 999px;
  background-color: transparent;
  border: 1px solid transparent;
  transition:
    background-color var(--duration-normal) var(--cubic-default),
    border-color var(--duration-normal) var(--cubic-default),
    border-radius var(--duration-normal) var(--cubic-default),
    backdrop-filter var(--duration-normal) var(--cubic-default);
}

/* Scrolled: glassy pill (light variant default).
   :not([data-menu-status="open"]) zorgt dat menu-open state niet ge-overruled wordt.
   > .nav-container zorgt dat de geneste .nav-container binnen .nav-dropdown
   geen pill-styles krijgt. */
.nav.is-scrolled:not([data-menu-status="open"]) > .nav-container {
  background-color: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(16px) saturate(160%);
  -webkit-backdrop-filter: blur(16px) saturate(160%);
  border-color: rgba(26, 36, 33, 0.08);
}

/* Osmo theme — kleur adapteert per sectie achter de nav */
body[data-theme-nav="dark"]  .nav { color: var(--mint); }
body[data-theme-nav="light"] .nav { color: var(--green); }

/* Glassy pill — donkere variant wanneer over een donkere sectie gescrold */
body[data-theme-nav="dark"] .nav.is-scrolled:not([data-menu-status="open"]) > .nav-container {
  background-color: rgba(26, 36, 33, 0.45);
  border-color: rgba(255, 255, 255, 0.08);
}

/* Dropdown open: pill morpht naar card-top, witte achtergrond, groene tekst.
   > .nav-container target alleen de OUTER pill, niet de geneste .nav-container
   binnen .nav-dropdown.
   Alleen desktop (≥768px): op mobiel is de dropdown uit, en sticky :hover/:focus
   op touch zou anders het witte vlak laten plakken op de hub-pagina. */
@media (min-width: 768px) {
  body:has([data-dropdown-toggle]:hover) .nav > .nav-container,
  body:has([data-dropdown-toggle]:focus-visible) .nav > .nav-container,
  body:has(.nav-dropdown:hover) .nav > .nav-container,
  body:has(.nav-dropdown:focus-within) .nav > .nav-container {
    border-radius: 1em 1em 0 0;
    background-color: #fff;
    border-color: rgba(26, 36, 33, 0.06);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
}

body:has([data-dropdown-toggle]:hover) .nav,
body:has([data-dropdown-toggle]:focus-visible) .nav,
body:has(.nav-dropdown:hover) .nav,
body:has(.nav-dropdown:focus-within) .nav,
.nav[data-menu-status="open"] {
  color: var(--green);
}
.nav-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 1.25em 0;
  position: relative;
}

.nav-logo {
  display: flex;
  align-items: center;
  gap: .5em;
  font-weight: 700;
  font-size: 1.15em;
  letter-spacing: .02em;
  color: inherit;
  text-decoration: none;
  z-index: 2;
}
.nav-logo svg   { width: 3.2em; height: auto; }
.nav-logo small { font-weight: 400; opacity: .7; font-size: .75em; }

.nav-center        { position: relative; }
.nav-center__list  {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0; padding: 0;
  list-style: none;
  gap: .25em;
}

.nav-link {
  display: flex;
  gap: .375em;
  align-items: center;
  justify-content: center;
  padding: .65em 1em;
  background: transparent;
  border: none;
  border-radius: .35em;
  color: inherit;
  font: inherit;
  font-size: 1em;
  cursor: pointer;
  text-decoration: none;
}
.nav-link__label         { font-size: 1em; line-height: 1; position: relative; }
.nav-link__dropdown-icon { width: .75em; transition: transform var(--duration-normal) var(--cubic-default); }

/* CTA buttons — show/hide per breakpoint (mobile-show rules staan in Responsive) */
.nav-cta-mobile { display: none; }

.nav-end {
  display: flex;
  gap: .5em;
  align-items: stretch;
  z-index: 2;
}
.nav-button {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 2.75em;
  padding: 0 1em;
  font-size: .95em;
  font-weight: 700;
  border: 1px solid;
  border-radius: 999px;
  color: inherit;
  text-decoration: none;
  transition: all var(--duration-fast) var(--cubic-default);
}
.nav-button.is--primary       { color: #fff; background-color: var(--green); border-color: var(--green); }
.nav-button.is--primary:hover { background-color: #0a7a68; border-color: #0a7a68; }

/* Dropdown */
.nav-dropdown {
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  padding: 2em 1rem 2.5em;   /* 1rem zij-padding = zelfde kader als .nav (pill) → uitlijning klopt */
  position: fixed;
  left: 0; right: 0;
  transition: all var(--duration-fast) ease;
}
.nav-bg {
  background-color: #fff;
  border-radius: 1em;
  box-shadow: 0 12px 32px rgba(0,0,0,.06);
  width: 100%;
  height: 0;
  position: absolute;
  inset: 0 0 auto;
  transition: height var(--duration-normal) var(--cubic-default);
}
.nav-dropdown__content {
  display: flex;
  gap: 1em;
  width: 100%;
  margin: 0; padding: 0;
  list-style: none;
}
.nav-dropdown__content-li { flex: 1; }

.nav-dropdown__link {
  color: #fff;
  background-color: var(--grey-2);
  border-radius: .6em;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  height: 18em;
  padding: 1.25em;
  position: relative;
  overflow: hidden;
  text-decoration: none;
}
.nav-dropdown__link-bg { position: absolute; inset: 0; }
.nav-dropdown__img {
  object-fit: cover;
  width: 100%; height: 100%;
  transition: transform .4s var(--cubic-default);
}
.nav-dropdown__img-overlay {
  z-index: 1;
  opacity: .45;
  background: linear-gradient(transparent 35%, rgba(26,36,33,.85));
  position: absolute;
  inset: 0;
  transition: opacity .2s var(--cubic-default);
}
.nav-dropdown__link-meta {
  z-index: 1;
  position: relative;
  color: rgba(255,255,255,.8);
  font-size: .8em;
  margin-bottom: .25em;
  font-weight: 400;
}
.nav-dropdown__link-inner {
  z-index: 1;
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.nav-dropdown__link-label {
  font-size: 1.35em;
  font-weight: 700;
  transition: transform .2s var(--cubic-default);
}
.nav-dropdown__link-bubble {
  color: var(--green);
  background-color: var(--mint);
  border-radius: 100em;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 1.6em; height: 1.6em;
  padding: .35em;
}
.nav-dropdown__link-bubble svg { width: 100%; height: 100%; }

.page-bg {
  z-index: 0;
  opacity: 0;
  pointer-events: none;
  background-color: rgba(26,36,33,.45);
  width: 100%;
  height: 100vh;
  position: absolute;
  top: 0;
  transition: opacity var(--duration-fast) var(--cubic-default);
}

/* Tijdens een Barba-paginatransitie: forceer dropdown + dim dicht,
   ook als de muis nog boven de dropdown hangt (overruled CSS :hover). */
body.is-transitioning .page-bg { opacity: 0 !important; }
body.is-transitioning .nav-dropdown {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}
body.is-transitioning .nav-bg { height: 0 !important; }

/* Footer verbergen tijdens transitie: de nieuwe container is position:fixed
   (uit de flow), waardoor de donkere footer omhoog schuift en als zwarte flits
   doorheen de fade verschijnt. Scroll reset naar top, dus footer staat onder
   de vouw — geen zichtbare "pop" bij terugkeer. */
body.is-transitioning footer { visibility: hidden !important; }

.menu-button {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: .25em;
  background: transparent;
  border: 1px solid currentColor;
  border-radius: .35em;
  width: 2.75em; height: 2.75em;
  padding: .75em;
  cursor: pointer;
  color: inherit;
}
.menu-button__line { background: currentColor; width: 100%; height: 1px; }

/* Show dropdown on hover/focus */
[data-dropdown-toggle]:hover + .nav-dropdown,
[data-dropdown-toggle]:focus-visible + .nav-dropdown,
.nav-dropdown:hover,
.nav-dropdown:focus-within {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* Body state when dropdown open */
body:has([data-dropdown-toggle]:hover) .nav-bg,
body:has([data-dropdown-toggle]:focus-visible) .nav-bg,
body:has(.nav-dropdown:hover) .nav-bg,
body:has(.nav-dropdown:focus-within) .nav-bg {
  height: var(--nav-bg-height);
}
/* Geen donkere dim achter de desktop-dropdown (alleen de witte dropdown zelf).
   De .page-bg blijft wél actief voor het mobiele menu (zie [data-menu-status="open"]). */

[data-dropdown-toggle] { transition: background-color var(--duration-fast) var(--cubic-default); }

/* Dropdown items animation */
.nav-dropdown__content-li {
  transition: all var(--duration-normal) var(--cubic-default);
  transition-delay: .15s;
  opacity: 0;
  transform: translate(3em, 0);
}
.nav-dropdown__content-li:nth-child(2) { transition-delay: .22s; }
.nav-dropdown__content-li:nth-child(3) { transition-delay: .29s; }

body:has([data-dropdown-toggle]:hover) .nav-dropdown__content-li,
body:has([data-dropdown-toggle]:focus-within) .nav-dropdown__content-li,
body:has(.nav-dropdown:hover) .nav-dropdown__content-li,
body:has(.nav-dropdown:focus-within) .nav-dropdown__content-li {
  opacity: 1;
  transform: translate(0, 0);
}

.nav-dropdown__link:hover .nav-dropdown__img-overlay { opacity: .15; }
.nav-dropdown__link:hover .nav-dropdown__img         { transform: scale(1.05); }

/* Underline on simple nav-links */
a.nav-link .nav-link__label::after {
  content: '';
  position: absolute;
  left: 0; bottom: -3px;
  width: 100%; height: 1px;
  background: currentColor;
  transition: transform var(--duration-normal) var(--cubic-default);
  transform: scale(0, 1);
  transform-origin: right center;
}
a.nav-link:hover .nav-link__label::after,
a.nav-link:focus-visible .nav-link__label::after,
a.nav-link.is-active .nav-link__label::after {
  transform: scale(1, 1);
  transform-origin: left center;
}


/* ==========================================================================
   4. SECTIONS
   ========================================================================== */

/* --- REUSABLE: section--dark modifier (zet sectie op zwart met witte tekst) --- */
.section--dark { background: var(--black); color: #fff; }
.section--dark h1,
.section--dark h2,
.section--dark h3,
.section--dark h4 { color: #fff; }

/* --- REUSABLE: accent word (italic, kleur context-afhankelijk) --- */
.accent                  { color: var(--green); font-style: italic; font-weight: 700; }
.accent-light           { color: var(--grey); font-style: italic; font-weight: 700; }
.accent-mint           { color: var(--mint); font-style: italic; font-weight: 700; }
.section--dark .accent   { color: var(--mint); }

/* --- REUSABLE: Eyebrow label (gebruikt in hero + andere editorial secties) --- */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.55em;
  color: var(--green);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  line-height: 1;
}
.eyebrow::before {
  content: "";
  width: 1.5em;
  height: 1px;
  background: currentColor;
  display: inline-block;
}
.eyebrow--mint { color: var(--mint); }
.eyebrow--dark { color: var(--black); }
.eyebrow--light { color: var(--grey); }

/* --- HERO (editorial, licht/grey, geen achtergrondfoto) --- */
.hero {
  position: relative;
  min-height: 100vh;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  align-items: end;
  overflow: hidden;
  color: var(--text);
  background:
    radial-gradient(at 80% 5%,  rgba(13,255,198,0.18) 0%, transparent 45%),
    radial-gradient(at 15% 95%, rgba(13,145,125,0.08) 0%, transparent 45%),
    var(--grey);
}

/* Background image */
.hero-media { position: absolute; inset: 0; z-index: 0; }
.hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.85) contrast(1.05);
}
.hero-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(26,36,33,0.55) 0%, rgba(26,36,33,0.25) 35%, rgba(26,36,33,0.80) 95%),
    radial-gradient(80% 60% at 50% 100%, rgba(13,255,198,0.10), transparent 70%);
}

/* Content layer */
.hero-inner {
  position: relative;
  z-index: 2;
  max-width: var(--size-container);
  width: 100%;
  margin: 0 auto;
  padding: clamp(7rem, 12vw, 10rem) clamp(1.25rem, 3vw, 2.5rem) clamp(3rem, 6vw, 5rem);
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 4vw, 3rem);
}

/* On-load entrance — gestaggerde fade-in van de hero-elementen.
   Pure CSS, draait op first load én bij navigatie (geen scroll-trigger nodig). */
.hero-eyebrow-row,
.hero-title,
.hero-foot,
.hero-scroll {
  animation: heroEntrance 0.9s var(--ease) both;
}
.hero-eyebrow-row { animation-delay: 0.15s; }
.hero-title       { animation-delay: 0.30s; }
.hero-foot        { animation-delay: 0.45s; }
.hero-scroll      { animation-delay: 0.70s; }

@keyframes heroEntrance {
  from { opacity: 0; transform: translateY(1.5rem); }
  to   { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .hero-eyebrow-row,
  .hero-title,
  .hero-foot,
  .hero-scroll { animation: none; }
}

/* Top row: eyebrow links, meta rechts */
.hero-eyebrow-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  padding-top: clamp(2rem, 6vw, 4rem);
}
.hero-eyebrow-row .eyebrow { color: var(--green); }
.hero-meta {
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  color: var(--muted);
  font-size: 0.85rem;
  font-weight: 500;
}
.hero-meta::before {
  content: "";
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 0 4px rgba(13,145,125,0.18);
  animation: heroPulse 2.4s cubic-bezier(0.625, 0.05, 0, 1) infinite;
}
@keyframes heroPulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(13,145,125,0.18); }
  50%      { box-shadow: 0 0 0 8px rgba(13,145,125,0.05); }
}

/* Mega title */
.hero-title {
  font-size: clamp(2.2rem, 6vw, 5.5rem);
  line-height: 1.1;
  letter-spacing: -0.035em;
  font-weight: 700;
  color: var(--black);
  max-width: 22ch;
}
.hero-title .line { display: block; }
.hero-title em {
  font-style: italic;
  font-weight: 700;
  color: var(--green);
  letter-spacing: -0.045em;
}

/* Bottom: lead links, CTAs rechts */
.hero-foot {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  align-items: end;
  gap: clamp(2rem, 5vw, 4rem);
  padding-top: clamp(1rem, 3vw, 2rem);
  border-top: 1px solid rgba(26,36,33,0.15);
}
.hero-lead {
  font-size: clamp(1.05rem, 1.2vw, 1.2rem);
  color: var(--muted);
  max-width: 44ch;
  line-height: 1.5;
  margin: 0;
}
.hero-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  justify-content: flex-end;
}

/* Scroll indicator rechtsonder */
.hero-scroll {
  position: absolute;
  right: clamp(1.25rem, 3vw, 2.5rem);
  bottom: clamp(1.25rem, 3vw, 2rem);
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.hero-scroll .line-v {
  width: 1px; height: 38px;
  background: linear-gradient(180deg, transparent, var(--green));
  animation: heroDrop 2s cubic-bezier(0.625, 0.05, 0, 1) infinite;
  transform-origin: top;
}
@keyframes heroDrop {
  0%   { transform: scaleY(0); }
  50%  { transform: scaleY(1); }
  100% { transform: scaleY(0); transform-origin: bottom; }
}

/* Hero tag — behouden voor backward compat */
.hero-tag {
  display: inline-block;
  background: rgba(13,145,125,.1);
  color: var(--green);
  padding: .4rem 1rem;
  border-radius: 999px;
  font-size: .85rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
  border: 1px solid rgba(13,145,125,.25);
}

/* --- USP STRIP --- */
.usp-strip       { padding: 2.5rem 0; background: var(--black); color: #fff; }
.usp-items       { display: grid; grid-template-columns: repeat(4,1fr); gap: 2rem; text-align: center; }
.usp-items strong{ color: var(--mint); font-size: 1.1rem; display: block; margin-bottom: .25rem; }
.usp-items span  { color: #BFC9C6; font-size: .9rem; }

/* --- PROBLEM / SOLUTION (basic — behouden voor backward compat) --- */
.problem               { padding: 5rem 0; background: #fff; }
.problem-header        { text-align: center; max-width: 680px; margin: 0 auto 3rem; }
.problem-header p      { color: var(--muted); font-size: 1.1rem; }
.ps-grid               { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.ps-card               { padding: 2rem; border-radius: 16px; }
.ps-card.problem-card  { background: var(--grey); }
.ps-card.solution-card { background: var(--black); color: #fff; }
.ps-card.solution-card h3 { color: #fff; }
.ps-card h3            { margin-bottom: 1.25rem; font-size: 1.35rem; }
.ps-list               { list-style: none; }
.ps-list li {
  padding: .75rem 0; padding-left: 2rem;
  position: relative;
  border-bottom: 1px solid rgba(0,0,0,.08);
}
.solution-card .ps-list li { border-color: rgba(255,255,255,.1); }
.ps-list li::before {
  content: ""; position: absolute; left: 0; top: 1.1rem;
  width: 1.25rem; height: 1.25rem; border-radius: 50%;
}
.problem-card .ps-list li::before  { background: #E8453C; opacity: .8; }
.solution-card .ps-list li::before { background: var(--mint); }

/* --- PROBLEM / OPLOSSING (light variant — cream achtergrond met mint accent) --- */
.ps {
  padding: 5rem 0;
  background: var(--grey);
  position: relative;
  overflow: hidden;
}

/* Subtiele mint glow rechtsboven voor brand-presence */
.ps::before {
  content: "";
  position: absolute;
  inset: -20% -10% auto auto;
  width: 60%;
  height: 70%;
  background: radial-gradient(circle, rgba(13,255,198,0.18), transparent 60%);
  pointer-events: none;
  z-index: 0;
}

.ps__layout {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1.85fr;
  gap: 3rem;
  align-items: center;
}
.ps__left      { display: flex; flex-direction: column; gap: 1.5rem; }
.ps__text h2   { color: var(--black); margin-bottom: 0.75rem; }
.ps__text p    { color: var(--muted); margin: 0; }

.ps__tabs {
  display: flex;
  border-radius: 10em;
  overflow: hidden;
  border: 1px solid rgba(26,36,33,0.10);
  width: fit-content;
  background: rgba(26,36,33,0.04);
}
.ps__tab {
  display: flex; align-items: center; gap: 0.5em;
  padding: 0.75em 1.5em;
  font-family: inherit; font-size: 0.95rem; font-weight: 700;
  cursor: pointer; border: none;
  background: transparent;
  color: var(--muted);
  transition: background 0.3s ease, color 0.3s ease;
}
[data-ps-status="problem"]  .ps__tab--problem  { background: var(--black); color: #fff; }
[data-ps-status="solution"] .ps__tab--solution { background: var(--green); color: #fff; }

.ps__hint      { display: flex; align-items: flex-end; gap: 0.5rem; }
.ps__hint span { color: var(--muted); font-style: italic; font-size: 1.05em; }
.ps__hint svg  { color: var(--black); }

/* Tabs: show/hide */
.ps__text--solution,
.ps__card-grid.ps__card-grid--solution { display: none; }

[data-ps-status="solution"] .ps__text--problem,
[data-ps-status="solution"] .ps__card-grid--problem,
[data-ps-status="solution"] .ps__hint { display: none; }

[data-ps-status="solution"] .ps__text--solution      { display: block; animation: psSlideIn 0.4s ease; }
[data-ps-status="solution"] .ps__card-grid--solution { display: grid;  animation: psSlideIn 0.4s ease; }

@keyframes psSlideIn {
  from { opacity: 0; transform: translateY(0.75em); }
  to   { opacity: 1; transform: translateY(0); }
}

.ps__card-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.ps__card {
  background: #fff;
  border: 1px solid rgba(26,36,33,0.06);
  border-radius: 16px;
  padding: 1.5rem;
  box-shadow: 0 4px 24px rgba(26,36,33,0.06);
}
.ps__card h5 { font-size: 1rem; font-weight: 700; color: var(--black); margin-bottom: 0.4rem; }
.ps__card p  { color: var(--muted); font-size: 0.875rem; margin: 0; line-height: 1.5; }

.ps__icon {
  width: 2.75rem; height: 2.75rem;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1rem;
}
.ps__icon--problem  { background: rgba(232,69,60,0.10);  color: #E8453C; }
.ps__icon--solution { background: rgba(13,145,125,0.12); color: var(--green); }

/* --- AUDIENCE BLOCKS --- */
.audiences {
  padding: 5rem 0;
  background:
    radial-gradient(at 80% 5%,  rgba(13,255,198,0.20) 0%, transparent 45%),
    radial-gradient(at 15% 85%, rgba(13,145,125,0.08) 0%, transparent 45%),
    linear-gradient(180deg, #fff 0%, var(--grey) 100%);
}
.audiences h2 { text-align: center; margin-bottom: 3rem; }
.audience-card {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin-bottom: 2rem;
  box-shadow: 0 4px 20px rgba(0,0,0,.04);
}
.audience-card:nth-child(even)       { grid-template-columns: 1fr 1fr; direction: rtl; }
.audience-card:nth-child(even) > *   { direction: ltr; }
.audience-body                       { padding: 3rem; }
.audience-tag {
  display: inline-block;
  background: var(--mint);
  color: var(--black);
  padding: .3rem .75rem;
  border-radius: 999px;
  font-size: .8rem;
  font-weight: 700;
  margin-bottom: 1rem;
}
.audience-body p { color: var(--muted); margin-bottom: 1.5rem; }
.audience-visual img {
  display: block;
  width: 100%;
  min-height: 280px;
  height: 100%;
  object-fit: cover;
}
.audience-visual:has(img) { display: block; padding: 0; }
.audience-card:nth-child(even) .audience-visual { background: var(--black); color: var(--mint); }

/* --- AUDIENCE SPLIT (interactieve 2-pane, LIGHT, full-bleed) --- */
.audience-split { padding: 0; background: var(--grey); position: relative; color: var(--text); }

.audience-split__head {
  padding: var(--space-section) var(--rail) clamp(2rem, 5vw, 4rem);
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: end;
  gap: 2rem;
  color: var(--text);
}
.audience-split__head h2 {
  color: var(--black);
  font-size: clamp(1.85rem, 4vw, 3.25rem);
  letter-spacing: -0.03em;
  max-width: 22ch;
}
.audience-split__head p {
  color: var(--muted);
  max-width: 40ch;
  font-size: var(--fs-lead);
  margin: 0;
}

.audience-split__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 72vh;
  position: relative;
}

/* Vertical mint thread tussen panes */
.audience-split__grid::before {
  content: "";
  position: absolute;
  left: 50%; top: 12%; bottom: 12%;
  width: 1px;
  background: linear-gradient(180deg, transparent, var(--mint), transparent);
  opacity: 0.4;
  z-index: 3;
  pointer-events: none;
}

.audience-pane {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  padding: clamp(2rem, 5vw, 4rem);
  color: #fff;
  text-decoration: none;
  cursor: pointer;
  transition: flex var(--dur-slow) var(--ease);
  flex: 1;
  isolation: isolate;
  border-top: 1px solid rgba(26,36,33,0.08);
}
.audience-pane + .audience-pane { border-left: 1px solid rgba(26,36,33,0.08); }

/* Outer rails: content uitlijnen met .container van andere secties.
   max() zorgt dat op smalle viewports de standaard pane-padding wint. */
.audience-pane:first-child { padding-left:  max(clamp(2rem, 5vw, 4rem), var(--rail)); }
.audience-pane:last-child  { padding-right: max(clamp(2rem, 5vw, 4rem), var(--rail)); }

.audience-pane__media { position: absolute; inset: 0; z-index: -2; }
.audience-pane__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: grayscale(0.2) brightness(0.78) contrast(1.05);
  transition: filter var(--dur-slow) var(--ease), transform 1.2s var(--ease);
}
.audience-pane__media::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(180deg, transparent 40%, rgba(26,36,33,0.80));
  transition: opacity var(--dur) var(--ease);
}

/* Hover/focus: pane wordt actief */
.audience-pane:hover .audience-pane__media img,
.audience-pane:focus-visible .audience-pane__media img {
  filter: grayscale(0) brightness(0.7) contrast(1.05);
  transform: scale(1.04);
}
.audience-split__grid:has(.audience-pane:hover) .audience-pane:not(:hover),
.audience-split__grid:has(.audience-pane:focus-visible) .audience-pane:not(:focus-visible) {
  flex: 0.55;
}
.audience-split__grid:has(.audience-pane:hover) .audience-pane:hover,
.audience-split__grid:has(.audience-pane:focus-visible) .audience-pane:focus-visible {
  flex: 1.45;
}

.audience-pane__body {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  max-width: 42rem;
}
.audience-pane__index {
  font-size: 0.78rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--mint);
  font-weight: 700;
}
.audience-pane h3 {
  color: #fff;
  font-size: clamp(1.75rem, 3.2vw, 2.75rem);
  letter-spacing: -0.025em;
  line-height: 1.02;
  font-weight: 700;
}
.audience-pane__copy {
  color: rgba(255,255,255,0.95);
  font-size: var(--fs-lead);
  line-height: 1.55;
  margin: 0;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
.audience-pane:hover .audience-pane__copy,
.audience-pane:focus-visible .audience-pane__copy {
  max-height: 30rem;
  opacity: 1;
}
.audience-pane__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  font-weight: 700;
  color: var(--mint);
  transform: translateY(8px);
  opacity: 0;
  transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
.audience-pane:hover .audience-pane__cta,
.audience-pane:focus-visible .audience-pane__cta {
  transform: translateY(0);
  opacity: 1;
}
.audience-pane__cta svg { width: 1em; height: 1em; transition: transform var(--dur) var(--ease); }
.audience-pane:hover .audience-pane__cta svg { transform: translateX(4px); }

/* Touch tap: zelfde reveal als hover, getriggerd door JS via .is-active */
.audience-pane.is-active .audience-pane__media img {
  filter: grayscale(0) brightness(0.7) contrast(1.05);
  transform: scale(1.04);
}
.audience-pane.is-active .audience-pane__copy { max-height: 30rem; opacity: 1; }
.audience-pane.is-active .audience-pane__cta  { transform: translateY(0); opacity: 1; }

/* --- STEPS --- */
.steps-inline { display: flex; gap: 1rem; margin-top: 1.5rem; flex-wrap: wrap; }
.step-pill {
  background: var(--grey);
  padding: .6rem 1.1rem;
  border-radius: 999px;
  font-size: .9rem;
  font-weight: 700;
  color: var(--black);
}
.step-pill span { color: var(--green); margin-right: .4rem; }

/* --- WERKWIJZE (asymmetrische 2-koloms layout met offset images) — licht --- */
.werkwijze {
  padding: 6rem 0;
  background:
    radial-gradient(at 15% 95%, rgba(13,255,198,0.18) 0%, transparent 45%),
    radial-gradient(at 85% 10%, rgba(13,145,125,0.08) 0%, transparent 45%),
    var(--grey);
}

.werkwijze-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 5rem;
  align-items: start;
}

/* Row 1 — titel links, intro rechts */
.werkwijze-title { grid-column: 1; grid-row: 1; }
.werkwijze-title h2 {
  font-size: clamp(2.25rem, 4.5vw, 3.75rem);
  color: var(--black);
  margin: 0;
  line-height: 1.05;
}

.werkwijze-intro { grid-column: 2; grid-row: 1; }
.werkwijze-label {
  display: inline-block;
  color: var(--green);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom: 1.25rem;
}
.werkwijze-intro p {
  color: var(--muted);
  font-size: 1.1rem;
  margin: 0;
}

/* Row 2 — afbeeldingen (rechter offset down voor staggered look) */
.werkwijze-img {
  margin: 0;
  overflow: hidden;
  border-radius: 12px;
  background: var(--grey-2);
}
.werkwijze-img img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.werkwijze-img--1 {
  grid-column: 1;
  grid-row: 2;
  aspect-ratio: 4 / 5;
  margin-top: 2.5rem;
}
.werkwijze-img--2 {
  grid-column: 2;
  grid-row: 2;
  aspect-ratio: 5 / 4;
  margin-top: 7rem;
}

/* Row 3 — Langdurige samenwerking */
.werkwijze-block {
  grid-column: 2;
  grid-row: 3;
  margin-top: 2.5rem;
}
.werkwijze-block h3 { color: var(--green); margin-bottom: 1rem; }
.werkwijze-block p  { color: var(--muted); margin: 0; }

/* Tagline behouden voor backward compat (oude chunk) */
.werkwijze-tagline {
  grid-column: 1 / -1;
  text-align: center;
  color: var(--mint);
  font-size: 1.1rem;
  font-weight: 700;
  margin-bottom: 0;
  padding-top: 2.5rem;
  border-top: 1px solid rgba(255,255,255,.1);
}

/* --- SIGNUP --- */
.signup           { padding: 5rem 0; background: #fff; }
.signup-grid      { display: grid; grid-template-columns: 1fr 1.3fr; gap: 4rem; align-items: start; }
.signup-left h2   { margin-bottom: 1rem; }
.signup-left p    { color: var(--muted); margin-bottom: 2rem; }
.signup-usps      { list-style: none; margin-bottom: 2rem; }
.signup-usps li   { padding: .5rem 0; padding-left: 2rem; position: relative; font-weight: 700; }
.signup-usps li::before {
  content: "✓"; position: absolute; left: 0; top: .5rem;
  width: 1.5rem; height: 1.5rem; border-radius: 50%;
  background: var(--green); color: #fff; font-size: .85rem;
  display: flex; align-items: center; justify-content: center;
}
.signup-steps {
  background: var(--black);
  color: #fff;
  padding: 2rem;
  border-radius: 16px;
  margin-top: 2rem;
}
.signup-steps h3 { color: #fff; margin-bottom: 1rem; }
.signup-steps ol { padding-left: 1.25rem; }
.signup-steps li { margin-bottom: .5rem; color: #E8E9E7; }
.signup-steps li::marker { color: var(--mint); font-weight: 700; }

form              { background: var(--grey); padding: 2.5rem; border-radius: 20px; }
.form-row         { display: grid; gap: 1rem; margin-bottom: 1rem; }
.form-row.row-2   { grid-template-columns: 1fr 1fr; }
.form-row.row-3   { grid-template-columns: 2fr 1fr 1.5fr; }
label             { display: block; font-size: .85rem; font-weight: 700; margin-bottom: .3rem; color: var(--black); }
input[type=text], input[type=email], input[type=tel], input[type=date], select, textarea {
  width: 100%;
  padding: .75rem 1rem;
  border: 1px solid var(--grey-2);
  border-radius: 10px;
  font-family: inherit;
  font-size: 1rem;
  background: #fff;
}
textarea { resize: vertical; min-height: 7rem; }
input:focus, select:focus, textarea:focus { outline: 2px solid var(--green); outline-offset: 1px; border-color: var(--green); }

/* Custom chevron met ruimte aan de rechterkant (vervangt native arrow) */
select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235C6663' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1.1rem center;
  background-size: 1.1em;
  padding-right: 3rem;
}
.checkbox-row             { display: flex; gap: .5rem; align-items: flex-start; margin-bottom: .75rem; font-size: .9rem; color: var(--muted); }
.checkbox-row input       { margin-top: .25rem; }
.form-submit              { margin-top: 1.5rem; width: 100%; }

/* --- HUB INTRO (B2C huurders — links tekst, rechts USP's) --- */
.hub-intro {
  padding: clamp(7rem, 12vw, 9rem) 0 var(--space-section);
  background:
    radial-gradient(at 80% 5%,  rgba(13,255,198,0.18) 0%, transparent 45%),
    radial-gradient(at 15% 95%, rgba(13,145,125,0.08) 0%, transparent 45%),
    var(--grey);
}
.hub-intro__grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: start;
}
.hub-intro__main h2 {
  font-size: var(--fs-display);
  letter-spacing: -0.03em;
  margin: 1rem 0 1.5rem;
  max-width: 16ch;
}
.hub-intro__body p {
  color: var(--muted);
  font-size: var(--fs-lead);
  margin-bottom: 1rem;
}
.hub-intro__body p:last-child { margin-bottom: 0; }

/* USP's in de rechterkolom als rijtjes, verticaal gecentreerd t.o.v. de tekst */
.hub-intro__usps { display: flex; flex-direction: column; gap: 1rem; align-self: center; }

/* Pandeigenaren-intro: hergebruikt .hub-intro layout, ruimere top voor de nav */
.hub-intro.is--page { padding-top: clamp(7rem, 12vw, 9rem); }
.hub-intro__cta { margin-top: 2rem; }

/* --- STAPPENPLAN (3 genummerde stappen, donker) --- */
.stappen { padding: var(--space-section) 0; background: var(--black); }
.stappen__head { margin-bottom: clamp(2.5rem, 5vw, 4rem); max-width: 40ch; }
.stappen__head h2 { color: #fff; margin-top: 1rem; }
.stappen__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1.5rem, 3vw, 2.5rem);
  position: relative;
}
/* gestippelde verbindingslijn achter de nummers */
.stappen__grid::before {
  content: "";
  position: absolute;
  left: 8%; right: 8%; top: 1.75rem;
  height: 1px;
  background-image: linear-gradient(90deg, var(--mint) 50%, transparent 50%);
  background-size: 10px 1px;
  opacity: 0.35;
  z-index: 0;
}
.stap { position: relative; z-index: 1; display: flex; flex-direction: column; gap: 1rem; }
.stap__num {
  width: 3.5rem; height: 3.5rem;
  border-radius: var(--r-pill);
  border: 1px solid rgba(255,255,255,0.2);
  background: var(--black);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; font-weight: 700;
  color: var(--mint);
}
.stap h3 { color: #fff; font-size: 1.2rem; }
.stap p  { color: rgba(255,255,255,0.65); margin: 0; }

/* --- USP CHECK (rij: icoon links, tekst rechts) --- */
.usp-check {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  background: var(--grey);
  border: 1px solid rgba(26,36,33,0.06);
  border-radius: var(--r-md);
}
.usp-check__icon {
  width: 2.5rem; height: 2.5rem;
  border-radius: var(--r-pill);
  background: var(--green);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  flex: none;
}
.usp-check__icon svg { width: 1.1rem; height: 1.1rem; }
.usp-check__text strong { display: block; font-size: 1.05rem; font-weight: 700; color: var(--black); margin-bottom: 0.15rem; }
.usp-check__text span   { color: var(--muted); font-size: 0.9rem; }

/* --- CTA BAND (mint, gecentreerd, met bubble button) --- */
.cta-band { padding: var(--space-section) 0; background: var(--green); }
.cta-band__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 1.5rem;
}
.cta-band h2 { color: var(--grey); max-width: 18ch; }
.cta-band p  { color: var(--grey); max-width: 50ch; margin: 0; font-size: var(--fs-lead); }
.cta-band__actions { margin-top: 0.5rem; }

/* --- WERKRUIMTE CARDS (dynamisch via getResources) --- */
.wr-section { padding: var(--space-section) 0; background: #fff; }
.wr-section__head { margin-bottom: clamp(2rem, 4vw, 3rem); }
.wr-section__head h2 { margin-top: 1rem; }

.wr-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: clamp(1rem, 2vw, 1.5rem);
}
.wr-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid rgba(26,36,33,0.08);
  border-radius: var(--r-md);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.wr-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(26,36,33,0.10); }

.wr-card__media { position: relative; aspect-ratio: 4/3; overflow: hidden; background: var(--grey); }
.wr-card__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--dur-slow) var(--ease);
}
.wr-card:hover .wr-card__media img { transform: scale(1.05); }

.wr-card__status {
  position: absolute; top: 1rem; left: 1rem;
  font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 0.4em 0.8em; border-radius: var(--r-pill);
  background: var(--mint); color: var(--black);
}
.wr-card__status--binnenkort { background: #F5C24B; color: var(--black); }
.wr-card__status--verhuurd   { background: var(--grey-2); color: var(--muted); }

.wr-card__body { padding: 1.5rem; display: flex; flex-direction: column; gap: 0.5rem; flex: 1; }
.wr-card__stad {
  font-size: 0.75rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--green);
}
.wr-card__title { font-size: 1.2rem; font-weight: 700; color: var(--black); }
.wr-card__specs {
  display: flex; flex-wrap: wrap; gap: 0.75rem;
  color: var(--muted); font-size: 0.88rem; margin-top: 0.25rem;
}
.wr-card__price {
  margin-top: auto; padding-top: 1rem;
  font-size: 1.05rem; font-weight: 700; color: var(--black);
  border-top: 1px solid rgba(26,36,33,0.08);
}
.wr-empty { color: var(--muted); padding: 2rem 0; }

/* --- WERKRUIMTE DETAIL (detailpagina van één werkruimte) --- */
.wr-detail { padding: clamp(7rem, 12vw, 9rem) 0 var(--space-section); background: #fff; }
.wr-detail__back {
  display: inline-flex; align-items: center; gap: 0.5em;
  color: var(--muted); font-weight: 700; font-size: 0.9rem;
  margin-bottom: 2rem;
  transition: color var(--dur-fast) var(--ease);
}
.wr-detail__back:hover { color: var(--green); }
.wr-detail__back svg { width: 1em; height: 1em; }

.wr-detail__top {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: clamp(2rem, 4vw, 3.5rem);
  align-items: start;
}
.wr-detail__media {
  border-radius: var(--r-md);
  overflow: hidden;
  aspect-ratio: 4/3;
  background: var(--grey);
}
.wr-detail__media img { width: 100%; height: 100%; object-fit: cover; }

.wr-detail__panel { display: flex; flex-direction: column; gap: 1.1rem; }
.wr-detail__badge {
  align-self: flex-start;
  font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 0.4em 0.8em; border-radius: var(--r-pill);
  background: var(--mint); color: var(--black);
}
.wr-detail__badge--binnenkort { background: #F5C24B; }
.wr-detail__badge--verhuurd   { background: var(--grey-2); color: var(--muted); }
.wr-detail__eyebrow {
  font-size: 0.75rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--green);
}
.wr-detail__title { font-size: var(--fs-h2); margin: 0; }

.wr-detail__specs { list-style: none; display: flex; flex-direction: column; gap: 0; margin: 0.5rem 0; }
.wr-detail__specs li {
  display: flex; justify-content: space-between; gap: 1rem;
  padding: 0.75rem 0;
  border-bottom: 1px solid rgba(26,36,33,0.08);
  font-size: 0.95rem;
}
.wr-detail__specs li span:first-child  {
  color: var(--muted);
  display: inline-flex; align-items: center; gap: 0.6em;
}
.wr-detail__specs li span:first-child svg { width: 1.15em; height: 1.15em; color: var(--green); flex: none; }
.wr-detail__specs li span:last-child   { font-weight: 700; color: var(--black); text-align: right; }
.wr-detail__price { font-size: 1.4rem; font-weight: 700; color: var(--black); }
.wr-detail__panel .btn-bubble-arrow { align-self: flex-start; }

.wr-detail__desc { max-width: 120ch; margin-top: clamp(2.5rem, 5vw, 4rem); }
.wr-detail__desc h2 { margin-bottom: 1rem; }
.wr-detail__desc p  { color: var(--muted); font-size: var(--fs-lead); }

/* --- STAD INTRO (landingspagina-kop met nav-clearing top-padding) --- */
.stad-intro { padding: clamp(7rem, 12vw, 9rem) 0 var(--space-section); background: #fff; }
.stad-intro h1 {
  font-size: var(--fs-display);
  letter-spacing: -0.03em;
  margin: 1rem 0 1.25rem;
  max-width: 18ch;
}
.stad-intro__lead { color: var(--muted); font-size: var(--fs-lead); max-width: 60ch; margin: 0; }
.stad-intro__grid { margin-top: clamp(2.5rem, 5vw, 4rem); }

/* --- FAQ ACCORDION --- */
.faq { padding: var(--space-section) 0; background: var(--grey); }
.faq__head { margin-bottom: clamp(2rem, 4vw, 3rem); }
.faq__head h3 {
  margin-top: 1rem;
  font-size: clamp(1.75rem, 3.5vw, 2.75rem);
  letter-spacing: -0.025em;
  line-height: 1.1;
}
.faq__list { display: flex; flex-direction: column; gap: 0.75rem; max-width: 820px; }
.faq__item {
  background: #fff;
  border: 1px solid rgba(26,36,33,0.08);
  border-radius: var(--r-md);
  overflow: hidden;
}
.faq__q {
  width: 100%;
  display: flex; justify-content: space-between; align-items: center; gap: 1rem;
  padding: 1.25rem 1.5rem;
  background: none; border: none; cursor: pointer;
  font: inherit; font-weight: 700; font-size: 1.05rem; color: var(--black);
  text-align: left;
}
.faq__q svg {
  flex: none; width: 1.25rem; height: 1.25rem; color: var(--green);
  transition: transform var(--dur) var(--ease);
}
.faq__item.is-open .faq__q svg { transform: rotate(45deg); }
.faq__a {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--dur) var(--ease);
}
.faq__item.is-open .faq__a { grid-template-rows: 1fr; }
.faq__a-inner { overflow: hidden; }
.faq__a-inner p { color: var(--muted); margin: 0; padding: 0 1.5rem 1.25rem; }

/* --- ANDERE STEDEN (cross-link grid) --- */
.andere-steden { padding: var(--space-section) 0; background: #fff; }
.andere-steden__head { margin-bottom: clamp(2rem, 4vw, 3rem); }
.andere-steden__head h2 { margin-top: 1rem; }
.steden-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: clamp(1rem, 2vw, 1.5rem);
}
.stad-card {
  position: relative;
  display: block;
  aspect-ratio: 4/3;
  border-radius: var(--r-md);
  overflow: hidden;
  text-decoration: none;
  background: var(--grey);
}
.stad-card img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--dur-slow) var(--ease);
}
.stad-card:hover img { transform: scale(1.05); }
.stad-card::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(26,36,33,0.8));
}
.stad-card__label {
  position: absolute; left: 1.25rem; right: 1.25rem; bottom: 1.25rem;
  z-index: 1;
  display: flex; justify-content: space-between; align-items: center;
  color: #fff; font-size: 1.2rem; font-weight: 700;
}
.stad-card__label svg { width: 1.25rem; height: 1.25rem; transition: transform var(--dur) var(--ease); }
.stad-card:hover .stad-card__label svg { transform: translateX(4px); }

/* --- STACKING STICKY CARDS (Osmo, Tempro-branded) --- */
.cards-stack {
  padding: clamp(4rem, 9vw, 7rem) 0 12dvh;
  background:
    radial-gradient(at 80% 5%,  rgba(13,255,198,0.18) 0%, transparent 45%),
    radial-gradient(at 15% 95%, rgba(13,145,125,0.08) 0%, transparent 45%),
    var(--grey);
}
.cards-stack__head { text-align: center; margin-bottom: clamp(2rem, 5vw, 4rem); }
.cards-stack__head h2 { margin-top: 1rem; }

.cards-stack__list {
  grid-row-gap: 5em;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  display: flex;
}
.cards-stack__item {
  flex: none;
  width: 100%;
  max-width: 26em;
  position: sticky;
  top: 9em;   /* meer ruimte boven de gestapelde kaarten (was 6em) */
}
.cards-stack__item.is--wide { max-width: 60em; }

.cards-stack-card {
  aspect-ratio: 2 / 3;
  background-color: #fff;
  border: 1px solid rgba(26,36,33,0.08);
  border-radius: var(--r-md);
  flex-flow: column;
  justify-content: space-between;
  width: 100%;
  padding: 2.5em;
  display: flex;
  box-shadow: 0 16px 50px rgba(26,36,33,0.10);
}
.cards-stack-card.is--green { background-color: var(--green); color: #fff; border-color: transparent; }
.cards-stack-card.is--dark  { background-color: var(--black); color: #fff; border-color: transparent; }
.cards-stack-card.is--mint  { background-color: var(--mint);  color: var(--black); border-color: transparent; }
.cards-stack-card.is--wide  { aspect-ratio: 5 / 3; }

.cards-stack-card__number { font-size: 5em; font-weight: 700; line-height: .95; letter-spacing: -0.04em; }
.cards-stack-card.is--green .cards-stack-card__number,
.cards-stack-card.is--dark  .cards-stack-card__number { color: var(--mint); }

.cards-stack-card__h {
  letter-spacing: -.03em;
  margin: 0 0 0.5em;
  font-size: 2.25em;
  font-weight: 700;
  line-height: 1;
}
.cards-stack-card.is--green .cards-stack-card__h,
.cards-stack-card.is--dark  .cards-stack-card__h,
.cards-stack-card.is--mint  .cards-stack-card__h { color: inherit; }

.cards-stack-card__services { flex-flow: column; justify-content: flex-end; display: flex; gap: 0; }
.cards-stack-card__services-p {
  letter-spacing: -.01em;
  margin: 0;
  font-size: 1.05em;
  font-weight: 500;
  line-height: 1.4;
  padding: 0.6em 0;
  border-bottom: 1px solid rgba(26,36,33,0.10);
}
.cards-stack-card__services-p:last-child { border-bottom: none; }
.cards-stack-card.is--green .cards-stack-card__services-p,
.cards-stack-card.is--dark  .cards-stack-card__services-p { border-color: rgba(255,255,255,0.18); }
.cards-stack-card.is--mint  .cards-stack-card__services-p { border-color: rgba(26,36,33,0.15); }

@media screen and (max-width: 767px) {
  .cards-stack__item.is--wide { max-width: 26em; }
  .cards-stack-card { font-size: .85em; }
}

/* --- WERKRUIMTE GALLERY (Osmo parallax slider, aangepast voor detail-media) --- */
.img-slider {
  gap: 1rem;
  border-radius: var(--r-md);
  justify-content: center;
  align-items: flex-end;
  width: 100%;
  aspect-ratio: 4 / 3;
  display: flex;
  position: relative;
  overflow: hidden;
  background: var(--grey);
}
.img-slider__list {
  grid-template-rows: 100%;
  grid-template-columns: 100%;
  place-items: center;
  width: 100%; height: 100%;
  display: grid;
  overflow: hidden;
}
.img-slide {
  opacity: 0; pointer-events: none;
  will-change: transform, opacity;
  grid-area: 1 / 1 / -1 / -1;
  place-items: center;
  width: 100%; height: 100%;
  display: grid; position: relative; overflow: hidden;
}
.img-slide.is--current { opacity: 1; pointer-events: auto; }
.img-slide__inner { object-fit: cover; will-change: transform; width: 100%; height: 100%; position: absolute; }
.img-slider__nav {
  z-index: 2; gap: .5rem; pointer-events: none;
  flex-flow: wrap; justify-content: center; align-items: center;
  max-width: 92%; display: flex; position: absolute; bottom: 1rem;
}
.img-slider__thumb {
  aspect-ratio: 1.5; pointer-events: auto; cursor: pointer;
  border: 2px solid rgba(255,255,255,.4);
  border-radius: .35rem; width: 4.5rem;
  transition: border-color .2s; position: relative; overflow: hidden;
}
.img-slider__thumb:hover { border-color: rgba(255,255,255,.7); }
.img-slider__thumb.is--current { border-color: #fff; }
.slider-thumb__img { object-fit: cover; width: 100%; height: 100%; }
/* Eén afbeelding → geen thumbnail-balk */
.img-slider__nav:has(.img-slider__thumb:only-child) { display: none; }
@media (max-width: 479px) { .img-slider__thumb { width: 3.5rem; } }

/* --- CONTACT (intro links, toggle + formulieren rechts) --- */
.contact { padding: clamp(7rem, 12vw, 9rem) 0 var(--space-section); background:
    radial-gradient(at 80% 5%,  rgba(13,255,198,0.18) 0%, transparent 45%),
    radial-gradient(at 15% 95%, rgba(13,145,125,0.08) 0%, transparent 45%),
    var(--grey);
}
.contact__grid {
  display: grid;
  grid-template-columns: 1fr 1.15fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: start;
}
.contact__intro h1 { font-size: var(--fs-display); letter-spacing: -0.03em; margin: 1rem 0 1.25rem; max-width: 14ch; }
.contact__intro > p { color: var(--muted); font-size: var(--fs-lead); max-width: 44ch; }
.contact__info { margin-top: 2.5rem; display: flex; flex-direction: column; gap: 1.25rem; }
.contact__info-item strong {
  display: block; font-size: 0.75rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--muted); font-weight: 700; margin-bottom: 0.3rem;
}
.contact__info-item a, .contact__info-item span { color: var(--black); font-weight: 700; font-size: 1.05rem; }

/* Toggle */
.contact-toggle {
  display: flex;
  background: rgba(26,36,33,0.05);
  border: 1px solid rgba(26,36,33,0.10);
  border-radius: var(--r-pill);
  padding: 0.3em;
  margin-bottom: 1.5rem;
}
.contact-toggle__btn {
  flex: 1;
  padding: 0.75em 1em;
  border: none; background: transparent; cursor: pointer;
  font: inherit; font-weight: 700; font-size: 0.95rem; color: var(--muted);
  border-radius: var(--r-pill);
  transition: background 0.3s var(--ease), color 0.3s var(--ease);
}
[data-contact-status="huurder"]    .contact-toggle__btn[data-contact-control="huurder"],
[data-contact-status="verhuurder"] .contact-toggle__btn[data-contact-control="verhuurder"] {
  background: var(--green); color: #fff;
}

/* Form show/hide */
.contact-form--verhuurder { display: none; }
[data-contact-status="verhuurder"] .contact-form--huurder    { display: none; }
[data-contact-status="verhuurder"] .contact-form--verhuurder { display: block; }

/* FormIt fouten + success */
.fi-error  { color: #E8453C; font-size: 0.8rem; font-weight: 700; display: block; margin-top: 0.3rem; }
.fi-message {
  padding: 1rem 1.25rem; border-radius: var(--r-sm); margin-bottom: 1.25rem;
  background: rgba(13,145,125,0.12); color: var(--green); font-weight: 700;
}
.fi-message.fi-error-message { background: rgba(232,69,60,0.10); color: #E8453C; }

/* --- CIJFERS (stats-strip met odometer) --- */
.cijfers { padding: clamp(2.5rem, 5vw, 4rem) 0; background: var(--black); }
.cijfers__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  text-align: center;
}
.cijfers__item { display: flex; flex-direction: column; align-items: center; gap: 0.35rem; }
.cijfers__num {
  color: var(--mint);
  font-size: clamp(2.25rem, 4.5vw, 3.25rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.02em;
}
.cijfers__label { color: #BFC9C6; font-size: 0.9rem; }

/* Odometer-onderdelen (Osmo) — structureel; kleur/grootte komt van .cijfers__num */
[data-odometer-element] {
  display: inline-flex;
  align-items: center;
  font-variant-numeric: tabular-nums;
}
[data-odometer-part="mask"],
[data-odometer-part="static"] {
  display: inline-block;
  overflow: clip;
  padding: 0.05em;
  margin: -0.05em;
}
[data-odometer-part="roller"] {
  display: block;
  white-space: pre;
  text-align: center;
  will-change: transform;
}
[data-odometer-part="static"] { display: inline-block; }

/* --- LEGAL / PROSE (algemene voorwaarden, privacy, etc.) --- */
.legal { padding: clamp(8rem, 13vw, 10rem) 0 var(--space-section); background: #fff; }
.legal__prose { max-width: 75ch; margin: 0 auto; }
.legal__prose h1 { font-size: var(--fs-display); letter-spacing: -0.03em; margin: 1rem 0 0.5rem; }
.legal__meta { color: var(--muted); font-size: 0.9rem; margin-bottom: 2.5rem; }
.legal__prose h2 { font-size: 1.4rem; margin: 2.5rem 0 0.75rem; }
.legal__prose h3 { font-size: 1.1rem; margin: 1.75rem 0 0.5rem; }
.legal__prose p  { color: var(--text); margin-bottom: 1rem; line-height: 1.7; }
.legal__prose ul { margin: 0 0 1rem 1.25rem; }
.legal__prose li { margin-bottom: 0.4rem; line-height: 1.6; }
.legal__prose a  { color: var(--green); text-decoration: underline; }
.legal__disclaimer {
  background: var(--grey); border-left: 3px solid var(--green);
  padding: 1rem 1.25rem; border-radius: var(--r-sm);
  color: var(--muted); font-size: 0.9rem; margin-bottom: 2.5rem;
}

/* --- BEDANKT (bevestigingspagina) --- */
.bedankt {
  min-height: 75vh;
  padding: clamp(8rem, 14vw, 11rem) 0 var(--space-section);
  display: flex; align-items: center;
  background:
    radial-gradient(at 80% 5%,  rgba(13,255,198,0.18) 0%, transparent 45%),
    radial-gradient(at 15% 95%, rgba(13,145,125,0.08) 0%, transparent 45%),
    var(--grey);
}
.bedankt__inner {
  max-width: 620px; margin: 0 auto; text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 1.25rem;
}
.bedankt__icon {
  width: 4.5rem; height: 4.5rem; border-radius: var(--r-pill);
  background: var(--green); color: #fff;
  display: flex; align-items: center; justify-content: center;
}
.bedankt__icon svg { width: 2rem; height: 2rem; }
.bedankt h1 { font-size: var(--fs-display); letter-spacing: -0.03em; margin: 0; max-width: 16ch; }
.bedankt p  { color: var(--muted); font-size: var(--fs-lead); max-width: 50ch; margin: 0; }
.bedankt__actions { margin-top: 0.75rem; }

/* --- FOOTER --- */
footer         { background: var(--black); color: #fff; padding: 3rem 0 2rem; }
.footer-grid   { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem; margin-bottom: 2rem; }
footer h4      { color: var(--mint); font-size: .9rem; text-transform: uppercase; letter-spacing: .1em; margin-bottom: 1rem; }
footer ul      { list-style: none; }
footer a       { color: #BFC9C6; }
footer a:hover { color: var(--mint); }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.1);
  padding-top: 1.5rem;
  color: #7A8583;
  font-size: .85rem;
  text-align: center;
}


/* ==========================================================================
   5. BUTTONS
   ========================================================================== */

/* --- Basic buttons --- */
.btn {
  display: inline-block;
  padding: .9rem 1.75rem;
  border-radius: 999px;
  font-weight: 700;
  font-size: .95rem;
  transition: all .2s;
  border: none;
  cursor: pointer;
}
.btn-primary       { background: var(--green); color: #fff; }
.btn-primary:hover { background: #0A7A68; transform: translateY(-1px); }
.btn-outline       { background: transparent; color: var(--black); border: 2px solid var(--black); }
.btn-outline:hover { background: var(--black); color: #fff; }
.btn-mint          { background: var(--mint); color: var(--black); }
.btn-mint:hover    { background: #00E6B0; }

/* --- Bubble Arrow Button --- */
.btn-bubble-arrow {
  border-radius: 10em;
  justify-content: center;
  align-items: center;
  font-size: 1rem;
  text-decoration: none;
  display: inline-flex;
  position: relative;
  overflow: hidden;
}
.btn-bubble-arrow__arrow {
  color: #fff;
  background-color: var(--green, #0D917D);
  border-radius: 10em;
  flex-flow: row;
  justify-content: center;
  align-items: center;
  width: 3.75em;
  height: 3.75em;
  display: flex;
  position: relative;
  transition: transform 0.735s cubic-bezier(0.625, 0.05, 0, 1);
  transform: scale(0) rotate(0.001deg);
  transform-origin: left;
}
.btn-bubble-arrow__arrow.is--duplicate {
  color: var(--green, #0D917D);
  background-color: #fff;
  z-index: 2;
  position: absolute;
  right: 0;
  transform: scale(1) rotate(0.001deg);
  transform-origin: right;
}
.btn-bubble-arrow__arrow-svg {
  width: 40%;
  transition: transform 0.735s cubic-bezier(0.625, 0.05, 0, 1);
  transform: rotate(0.001deg);
}
.btn-bubble-arrow__content {
  color: #fff;
  background-color: var(--green, #0D917D);
  border-radius: 10em;
  justify-content: center;
  align-items: center;
  height: 3.75em;
  padding-left: 2em;
  padding-right: 2em;
  display: flex;
  position: relative;
  white-space: nowrap;
  transition: transform 0.735s cubic-bezier(0.625, 0.05, 0, 1);
  transform: translateX(-3.75em) rotate(0.001deg);
}
.btn-bubble-arrow__content-text { line-height: 1; }

/* Hover */
.btn-bubble-arrow:hover .btn-bubble-arrow__content             { transform: translateX(0em) rotate(0.001deg); }
.btn-bubble-arrow:hover .btn-bubble-arrow__arrow-svg           { transform: rotate(-45deg); }
.btn-bubble-arrow:hover .btn-bubble-arrow__arrow               { transform: scale(1) rotate(0.001deg); }
.btn-bubble-arrow:hover .btn-bubble-arrow__arrow.is--duplicate { transform: scale(0) rotate(0.001deg); }

/* Variant: dark */
.btn-bubble-arrow--dark .btn-bubble-arrow__arrow {
  color: #F5F6F5;
  background-color: var(--black, #0A0A0A);
}
.btn-bubble-arrow--dark .btn-bubble-arrow__arrow.is--duplicate {
  color: #5C6663;
  background-color: var(--mint, #F5F6F5);
}
.btn-bubble-arrow--dark .btn-bubble-arrow__content {
  color: #F5F6F5;
  background-color: var(--black, #0A0A0A);
}


/* ==========================================================================
   6. RESPONSIVE
   ========================================================================== */

/* --- Desktop hover effects (≥768px) --- */
@media (min-width: 768px) {
  [data-dropdown-toggle]:hover .nav-link__dropdown-icon,
  [data-dropdown-toggle]:focus .nav-link__dropdown-icon,
  [data-dropdown-toggle]:has(+ .nav-dropdown:hover) .nav-link__dropdown-icon {
    transform: rotate(180deg);
  }
  [data-dropdown-toggle]:hover,
  [data-dropdown-toggle]:focus,
  [data-dropdown-toggle]:has(+ .nav-dropdown:hover) {
    background-color: var(--grey);
  }
}

/* --- Tablet (≤991px) --- */
@media (max-width: 991px) {
  .nav-container        { padding: 0 1.25em; }
  .nav-button.md--hide  { display: none; }

  /* Audience Split: kop in 1 kolom, panes onder elkaar, geen flex-expand */
  .audience-split__head { grid-template-columns: 1fr; }
  .audience-split__grid { grid-template-columns: 1fr; min-height: auto; }
  .audience-split__grid::before { display: none; }
  .audience-pane                                  { min-height: 60vh; }
  .audience-pane + .audience-pane                 { border-left: 0; border-top: 1px solid rgba(255,255,255,0.08); }
  .audience-split__grid:has(.audience-pane:hover) .audience-pane:not(:hover),
  .audience-split__grid:has(.audience-pane:hover) .audience-pane:hover { flex: 1; }

  /* Mobiel: CTA altijd zichtbaar, copy nooit tonen */
  .audience-pane__copy { display: none; }
  .audience-pane__cta  { opacity: 1; transform: none; }
}

/* --- Mobile main breakpoint (≤900px) --- */
@media (max-width: 900px) {
  /* Layout: alle multi-koloms grids naar 1 kolom */
  .ps-grid,
  .signup-grid,
  .audience-card,
  .audience-card:nth-child(even),
  .werkwijze-grid,
  .hub-intro__grid,
  .contact__grid,
  .ps__layout { grid-template-columns: 1fr !important; }

  /* Hub: stappen 3→1 kolom (verberg connector) */
  .stappen__grid { grid-template-columns: 1fr; }
  .stappen__grid::before { display: none; }

  /* Werkruimte detail: top naar 1 kolom */
  .wr-detail__top { grid-template-columns: 1fr; }

  /* ProbleemOplossing: mint glow herpositioneren naar boven-gecentreerd
     (anders rechter-helft mint = verticale split op smal scherm) */
  .ps::before {
    inset: -8% auto auto 50%;
    transform: translateX(-50%);
    width: 130%;
    height: 35%;
  }

  /* Werkwijze: stack onder elkaar, reset grid posities, verberg 2e foto */
  .werkwijze-grid { gap: 1.5rem; }
  .werkwijze-title,
  .werkwijze-intro,
  .werkwijze-img--1,
  .werkwijze-block {
    grid-column: 1;
    grid-row: auto;
    margin-top: 0;
  }
  .werkwijze-img--2 { display: none; }
  .werkwijze-block  { margin-top: 1.5rem; }

  /* Hero kleiner op tablet (padding wordt door .hero-inner geregeld) */
  .hero { min-height: 80vh; }

  /* USP: 4 → 2 kolommen */
  .usp-items { grid-template-columns: repeat(2,1fr); gap: 1.5rem; }
  .cijfers__grid { grid-template-columns: repeat(2,1fr); gap: 1.5rem; }

  /* Audience: rtl-flip reset + minder padding + min-width:0 (fix overflow door BtnBubble nowrap) */
  .audience-card:nth-child(even) { direction: ltr; }
  .audience-body                 { padding: 1.75rem; min-width: 0; }
  .audience-visual               { min-height: 200px; }

  /* Form grids → 1 kolom */
  .form-row.row-2,
  .form-row.row-3 { grid-template-columns: 1fr; }

  /* Footer 4 → 2 kolommen */
  .footer-grid { grid-template-columns: 1fr 1fr; }
}

/* --- Mobile landscape (≤767px) --- */
@media (max-width: 767px) {
  /* Nav CTAs: desktop verbergen, mobile tonen */
  .nav-cta-desktop { display: none !important; }
  .nav-cta-mobile {
    display: block;
    padding: 1.5em 1.5em 1em;
    margin-top: auto;
  }
  .nav-cta-mobile .nav-button {
    width: 100%;
    height: 3.25em;
    font-size: 1.1em;
  }

  /* Nav mobile layout */
  .nav-logo      { z-index: 2; font-size: 1em; }
  .nav-logo svg  { width: 2.6em; }
  .nav-center {
    z-index: 0;
    opacity: 0;
    visibility: hidden;
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    transform: translate(0, 1em);
    transition: all var(--duration-normal) var(--cubic-default), opacity var(--duration-fast) var(--cubic-default);
  }

  /* Mobile menu open: nav-container wordt een volledig floating card,
     inset 1rem van alle viewport-randen. Geen seam meer met .nav-center__list.
     > .nav-container targets alleen de OUTER pill, niet de geneste .nav-container
     binnen .nav-dropdown (anders krijgt die ook height: 100dvh wat de cards breekt).
     !important op bg + filter om donker glassy scroll-state te overrulen. */
  .nav[data-menu-status="open"] > .nav-container {
    border-radius: 1em;
    background-color: #fff !important;
    border-color: rgba(26, 36, 33, 0.06) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    height: calc(100dvh - 2rem);
    overflow: hidden;
  }

  /* .nav-inner moet meegroeien met de card zodat .nav-center (abs positioned
     binnen .nav-inner) de volledige hoogte krijgt. align-items: flex-start
     houdt logo + X bovenaan ipv vertical center. */
  .nav[data-menu-status="open"] .nav-inner {
    height: 100%;
    align-items: flex-start;
  }

  /* Force groen wanneer menu open is (overschrijft data-theme-nav mint) */
  body[data-theme-nav] .nav[data-menu-status="open"] {
    color: var(--green);
  }

  .nav-center__list {
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
    height: 100%;
    padding-top: 6em;
    overflow-y: auto;
    background: transparent;
  }
  .nav-link        { justify-content: space-between; width: 100%; padding: 1em 1.5em; }
  .nav-link__label { font-size: 1.4em; }

  /* Dropdown uit op mobiel: "Kantoorruimte huren" is een gewone link naar de hub.
     Geen chevron, geen uitklap — voorkomt dat je navigeert vóór het uitklappen. */
  .nav-dropdown          { display: none; }
  .nav-link__dropdown-icon { display: none; }

  .nav-bg { display: none; }
  .nav-dropdown__overflow {
    grid-template-rows: 0fr;
    width: 100%;
    display: grid;
    overflow: hidden;
    transition: grid-template-rows var(--duration-normal) var(--cubic-default);
  }
  .nav-dropdown__overflow-inner { min-height: 0; overflow: hidden; }
  .nav-dropdown__content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .75em;
    padding: 0 1.5em 1em;
  }
  .nav-dropdown__link       { aspect-ratio: 1; height: auto; padding: 1em; }
  .nav-dropdown__link-label { font-size: 1em; }
  .menu-button              { display: flex; }
  .menu-button__line        { transition: all var(--duration-normal) var(--cubic-default); }

  :root { --nav-bg-height: 100dvh; }

  [data-menu-status="open"] .menu-button__line:nth-of-type(1) { transform: translate(0, .125em) rotate(135deg); }
  [data-menu-status="open"] .menu-button__line:nth-of-type(2) { transform: translate(0, -.175em) rotate(-135deg); }
  [data-menu-status="open"] .nav-center  { opacity: 1; visibility: visible; transform: translate(0, 0); transition-delay: .1s; }

  [data-dropdown-toggle="open"] + .nav-dropdown .nav-dropdown__overflow   { grid-template-rows: 1fr; }
  [data-dropdown-toggle="open"] + .nav-dropdown .nav-dropdown__content-li { opacity: 1; transform: translate(0, 0); }
  [data-dropdown-toggle="open"] .nav-link__dropdown-icon                  { transform: rotate(180deg); }
}

/* --- Mobile portrait (≤479px) --- */
@media (max-width: 479px) {
  .ps__card-grid { grid-template-columns: 1fr; }
  .ps__tabs      { width: 100%; }
  .ps__tab       { flex: 1; justify-content: center; }


  /* Hero compacter op telefoon — foot stacken, CTAs links */
  .hero          { min-height: 70vh; }
  .hero-foot     { grid-template-columns: 1fr; align-items: stretch; }
  .hero-ctas     { justify-content: flex-start; }
  .hero-eyebrow-row { padding-top: 1rem; }
  .hero-lead     { font-size: 1.05rem; }
}