/**
 * Vloeren Kameraad — Utilities
 * Minimale helper-klassen. Semantisch benoemd, geen utility-soup.
 * Importeer als laatste in je WordPress theme style.css.
 */

/* ─────────────────────────────────────────────────────────────────────────────
 * LAYOUT HELPERS
 * ─────────────────────────────────────────────────────────────────────────── */

/* Twee-koloms grid (gelijk) */
.grid-2 {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-16);
}

@media (min-width: 1024px) {
  .grid-2 {
    grid-template-columns: 1fr 1fr;
    align-items: stretch;
  }
}

/* Drie-koloms grid */
.grid-3 {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}

@media (min-width: 768px) {
  .grid-3 {
    grid-template-columns: repeat(2, 1fr);
  }
}

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

/* Vier-koloms grid */
.grid-4 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
}

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

/* Formulier + sidebar (2/3 + 1/3) */
.grid-form-sidebar {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
}

@media (min-width: 1024px) {
  .grid-form-sidebar {
    grid-template-columns: 2fr 1fr;
  }
}

/* Content + sidebar (3/4 + 1/4) */
.grid-content-sidebar {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
}

@media (min-width: 1024px) {
  .grid-content-sidebar {
    grid-template-columns: 3fr 1fr;
  }
}

/* ─────────────────────────────────────────────────────────────────────────────
 * GEEN HORIZONTALE SCROLL (site-breed)
 * Stray overflow rekt de layout-viewport (ICB) op waardoor fixed bars
 * (header, announcement, sticky, cookie) breder dan het scherm worden en
 * de pagina horizontaal scrollt. `clip` clipt dit weg zonder een
 * scroll-container te maken -> position:sticky blijft werken (i.t.t. hidden).
 * ─────────────────────────────────────────────────────────────────────────── */
html, body {
  overflow-x: clip;
  max-width: 100%;
}

/* Lange koppen / lange woorden mogen nooit buiten hun container lopen. */
h1, h2, h3, h4, h5, h6,
.hero-title, .section-title, .section-header-title {
  overflow-wrap: break-word;
  word-break: break-word;
}

/* ─────────────────────────────────────────────────────────────────────────────
 * FAQ-ACCORDION — nette stacking + symmetrische uitlijning
 * (.faq-* classes hadden geen styling -> items liepen "kris kras" in elkaar)
 * ─────────────────────────────────────────────────────────────────────────── */
.faq-list {
  display: flex;
  flex-direction: column;
}
.faq-item {
  border-bottom: 1px solid var(--color-cream-mid, oklch(0.90 0.01 75));
}
.faq-question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  width: 100%;
  padding: 1.1rem 0;
  font-family: var(--font-body);
  font-size: var(--text-base, 1rem);
  font-weight: 600;
  color: var(--color-charcoal, oklch(0.22 0.005 65));
  background: none;          /* reset default button-achtergrond (grijs) */
  border: none;             /* reset default button-rand */
  text-align: left;
  cursor: pointer;
  list-style: none;
}
.faq-question::-webkit-details-marker { display: none; }
.faq-question::marker { content: ''; }
.faq-question svg,
.faq-icon { flex-shrink: 0; }
/* CSS-chevron (markup bevat geen svg) — roteert via aria-expanded dat de JS zet.
   :not(:has(svg)) voorkomt dubbele chevron op pagina's die wel een svg hebben. */
.faq-question:not(:has(svg))::after {
  content: '';
  flex-shrink: 0;
  width: 0.5rem;
  height: 0.5rem;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  transition: transform 0.2s ease;
  opacity: 0.5;
}
.faq-question[aria-expanded="true"]:not(:has(svg))::after {
  transform: rotate(-135deg);
}
.faq-answer {
  display: none;            /* accordion: dicht by default, JS opent via inline display */
  padding: 0 0 1.1rem;
  color: var(--color-charcoal-light, oklch(0.42 0.008 65));
  line-height: 1.7;
}

/* ─────────────────────────────────────────────────────────────────────────────
 * MOBIEL — FAQ + analyse-kaarten + reviews netjes over de volle breedte
 * ─────────────────────────────────────────────────────────────────────────── */
@media (max-width: 767px) {
  /* De brede flex-wrap-regel (zie MOBILE GRID OVERRIDE) zette ook flex-wrap op
     de FAQ-knop -> bij een lange vraag wrapte het plusje/chevron naar de regel
     eronder. De knop mag NOOIT wrappen: vraag links, icoon rechts ernaast. */
  .faq-question {
    flex-wrap: nowrap !important;
    gap: 0.75rem;
    align-items: flex-start;
  }
  .faq-question > span,
  .faq-question > :first-child:not(svg) {
    min-width: 0;          /* laat de vraagtekst krimpen/intern afbreken */
    flex: 1 1 auto;
  }
  .faq-question svg,
  .faq-chevron,
  .faq-icon {
    flex-shrink: 0;
    margin-top: 0.15rem;   /* lijn het icoon uit met de eerste tekstregel */
  }

  /* Analyse-kaarten (offerte-check "Wat controleren wij") + reviews staan op
     mobiel in 2 kolommen naast elkaar = te smal/onleesbaar. Volle breedte.
     [style] erbij -> hogere specificiteit dan de generieke repeat(4)->2-kol-regel
     verderop, ongeacht bronvolgorde. */
  .grid-cards-fullwidth-mobile[style] {
    grid-template-columns: 1fr !important;
  }
  /* Review-grids site-breed naar 1 kolom op mobiel (volle breedte per kaart). */
  [style*="grid"]:has(> .review-card),
  [style*="grid"]:has(> article.review-card) {
    grid-template-columns: 1fr !important;
  }
}

/* ─────────────────────────────────────────────────────────────────────────────
 * MOBILE GRID OVERRIDE
 * Inline grid-template-columns in page-templates werken niet responsive.
 * Forceer 1-kolom op mobile; desktop behoudt de inline waarde.
 * ─────────────────────────────────────────────────────────────────────────── */

@media (max-width: 767px) {
  /* TWEE-TRAPS responsive grid-aanpak voor inline-styled grids.

     TRAP 1 — Veel-koloms KAART/STAT/GALERIJ-grids -> 2 KOLOMS:
       stats-balk (4 cijfers = 2x2), avatar-galerijen (Bekende Nederlanders),
       voordelen (5-kol), showroom-foto's, collectie-kaarten met afbeelding.
       Twee naast elkaar leest prettig op een telefoon. */
  [style*="repeat(4"],
  [style*="repeat(5"],
  [style*="repeat(6"],
  [style*="repeat(7"] {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;  /* minmax(0,..) -> kolommen kunnen krimpen, geen blow-out */
  }

  /* GRID-kinderen mogen binnen hun (expliciete) track krimpen -> voorkomt dat
     een lang woord de track uit het scherm duwt. Alleen grid (geen !important),
     zodat flex-rijen NIET worden dichtgeknepen (dat gaf 1-woord-per-regel). */
  .container [style*="display:grid"] > * {
    min-width: 0;
  }

  /* Content-KAARTEN met dikke padding (padding:2rem) in een meerkoloms-grid
     worden op mobiel te smal (2 kol van ~150px - 64px padding = ~87px tekst ->
     1 woord per regel). Zulke grids naar 1 kolom. Stats-kaarten gebruiken
     "padding:1.5rem 2rem" en matchen deze selector NIET -> die blijven 2x2. */
  .container [style*="display:grid"]:has(> [style*="padding:2rem"]),
  .container [style*="display:grid"]:has(> [style*="padding:2.5rem"]),
  .container [style*="display:grid"]:has(> [style*="padding:3rem"]) {
    grid-template-columns: 1fr !important;
  }

  /* Expliciete grote px-min-widths (bv. min-width:400px) neutraliseren op mobiel. */
  .container [style*="min-width:300px"],
  .container [style*="min-width:320px"],
  .container [style*="min-width:360px"],
  .container [style*="min-width:400px"],
  .container [style*="min-width:480px"],
  .container [style*="min-width:500px"],
  .container [style*="min-width:600px"] {
    min-width: 0 !important;
  }
  .container img,
  .container svg {
    max-width: 100%;
  }

  /* TRAP 2 — 3-koloms grote kaarten + STRUCTURELE layouts -> 1 KOLOM:
       grote product-kaarten (collectie 3-kol), afbeelding-naast-tekst
       (1fr 2fr / 2fr 1fr), content+sidebar, en 2-koloms met grote gap
       (=afbeelding+tekst). Kleine 2-koloms (1fr 1fr met kleine gap =
       feature-/stats-paren) blijft bewust 2-koloms. */
  [style*="repeat(3"],
  [style*="1fr 2fr"],
  [style*="2fr 1fr"],
  [style*="1fr 1fr 1fr"],
  [style*="1fr 1fr;gap:4rem"],
  [style*="1fr 1fr;gap:3rem"],
  [style*="1fr 1fr;gap:2.5rem"],
  [style*="1fr 1fr;gap:2rem"],
  [style*="1fr 1fr;gap:1.5rem"],
  [style*="1fr 1fr;gap:1.25rem"],
  [style*="1fr 1fr;gap:1rem"],
  [style*="grid-template-columns:1fr 1fr;max-width"],
  .collectie-grid,
  .grid-content-sidebar {
    grid-template-columns: 1fr !important;
  }

  /* Compactere container-padding op mobiel = meer ruimte voor content. */
  .container {
    padding-left: 0.9375rem !important;   /* 15px */
    padding-right: 0.9375rem !important;
  }

  /* Reset child-spans: inline grid-column/grid-row span 2/3 (desktop featured
     cards) maken op een 1-koloms grid impliciete kolommen -> scheve layout.
     Op mobiel is elk item toch volle breedte, dus span -> auto. */
  [style*="grid-column"] {
    grid-column: auto !important;
  }
  [style*="grid-row"] {
    grid-row: auto !important;
  }
  /* Vaste grid-auto-rows (mozaïek-galerijen, bv. showroom) maken items op een
     1-koloms grid onnodig laag/vervormd -> laat hoogte meegroeien met content. */
  [style*="grid-auto-rows"] {
    grid-auto-rows: auto !important;
  }

  /* Inline flex-rijen (icoon + tekst + knop callouts e.d.) passen op mobiel
     vaak niet -> nowrap duwt content buiten het scherm = horizontale scroll.
     Laat ze wrappen; korte rijen blijven vanzelf op 1 regel. */
  [style*="display:flex"]:not([style*="flex-direction:column"]) {
    flex-wrap: wrap;
  }

  /* VERTICAAL RITME — desktop gebruikt 6rem (96px) sectie-padding; op een
     telefoon is dat veel te ruim (secties voelen los, eindeloos scrollen).
     Comprimeer naar een strak, consistent mobiel ritme. */
  [style*="padding:8rem 0"] { padding-top: 3.5rem !important; padding-bottom: 3.5rem !important; }
  [style*="padding:6rem 0"] { padding-top: 3rem !important;   padding-bottom: 3rem !important; }
  [style*="padding:5rem 0"] { padding-top: 2.75rem !important; padding-bottom: 2.75rem !important; }
  [style*="padding:4rem 0"] { padding-top: 2.5rem !important; padding-bottom: 2.5rem !important; }
  .section-light, .section-white, .section-dark {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }

  /* Reviews-float (oms-reviews badge) net boven de compacte zwarte sticky-bar
     (~53px hoog) zetten met een kleine marge, zodat ze niet botsen.
     + Compacter ontwerp op mobiel: G-logo LINKS, tekst ernaast (gestapeld). */
  .oms-rev-badge {
    bottom: 62px !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 9px !important;
    padding: 7px 13px !important;
    min-width: 0 !important;
    border-radius: 10px !important;
  }
  .oms-rev-badge-g svg { width: 26px !important; height: 26px !important; }
  .oms-rev-badge-body {
    align-items: flex-start !important;
    text-align: left !important;
    gap: 0 !important;
  }
  .oms-rev-badge-label { font-size: 0.78rem !important; }
  .oms-rev-badge-rating { font-size: 0.82rem !important; gap: 4px !important; }
  .oms-rev-badge-rating strong { font-size: 0.88rem !important; }
  .oms-rev-badge-count { font-size: 0.66rem !important; margin-top: 0 !important; }

  /* ── TAP-TARGETS >= 44px (WCAG/Apple) ── */
  .nav-toggle { min-width: 44px; min-height: 44px; }
  .mobile-menu-link { min-height: 44px; display: flex; align-items: center; }
  .mobile-submenu-link { min-height: 42px; display: flex; align-items: center; }
  .stad-pill, .regio-pill { min-height: 44px; display: inline-flex; align-items: center; justify-content: center; }
  .cookie-banner-accept, .cookie-banner-decline { min-height: 44px; }
  .btn, .btn-cta, .btn-secondary, .btn-outline-gold { min-height: 44px; }
  .breadcrumbs, .breadcrumb { gap: 0.75rem; }

  /* ── TYPOGRAFIE-SCHALING: clamp-minima zijn te hoog voor 390px (koppen
     wrappen lelijk / overschieten). Verlaag de mobiele ondergrens; desktop
     (de max-waarde) blijft gelijk. ── */
  [style*="font-size:clamp(2.5rem,5vw"]  { font-size: clamp(1.875rem, 7vw, 4.5rem) !important; }
  [style*="font-size:clamp(2.25rem,5vw"] { font-size: clamp(1.875rem, 7vw, 3.75rem) !important; }
  [style*="font-size:clamp(1.875rem,3vw"] { font-size: clamp(1.5rem, 5.5vw, 2.25rem) !important; }
  [style*="font-size:clamp(10rem,12vw"]  { font-size: clamp(4rem, 17vw, 12rem) !important; }
  /* Te strakke line-heights op grote display-koppen iets ruimer. */
  [style*="line-height:0.9"] { line-height: 1.15 !important; }

  /* Stats-balk onder de hero: de goud/tan border-left verdeelt op desktop de
     4 kolommen, maar wordt in de 2x2 mobiel-layout een lelijk verticaal
     streepje naast de cijfers. Weg ermee -> egale achtergrond. */
  [style*="border-left:1px solid oklch(0.60 0.08 75)"] {
    border-left: none !important;
  }
}

/* ─────────────────────────────────────────────────────────────────────────────
 * VERGELIJKING — DESKTOP = 3-koloms tabel, MOBIEL = twee losse tabellen
 * (bv. Plak-PVC eerst, dan Klik-PVC eronder). De desktop-tabel (.cmp-desktop)
 * wordt op mobiel verborgen; de losse kaart-tabellen (.cmp-card) getoond.
 * ─────────────────────────────────────────────────────────────────────────── */
.cmp-card { display: none; }

@media (max-width: 767px) {
  .cmp-desktop { display: none !important; }
  .cmp-card {
    display: block;
    border: 1px solid oklch(0.42 0.010 65);
    border-radius: 0.75rem;
    overflow: hidden;
    margin-bottom: 1rem;
  }
  .cmp-card-head {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    background: oklch(0.22 0.012 65);
    color: #fff;
    padding: 0.8rem 1rem;
    font-family: var(--font-body);
    font-weight: 700;
    font-size: 1rem;
  }
  .cmp-card-badge {
    font-size: 0.65rem;
    font-weight: 700;
    background: oklch(0.68 0.08 75);
    color: oklch(0.12 0.005 65);
    padding: 0.1rem 0.5rem;
    border-radius: 9999px;
    text-transform: none;
  }
  .cmp-card-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.7rem 1rem;
    border-top: 1px solid oklch(0.42 0.010 65);
    background: oklch(0.16 0.008 65);
  }
  .cmp-card-prop {
    flex-shrink: 0;
    max-width: 42%;
    color: oklch(0.62 0.015 65);
    font-family: var(--font-body);
    font-size: 0.8rem;
  }
  .cmp-card-val {
    color: #fff;
    font-weight: 500;
    text-align: right;
    font-family: var(--font-body);
    font-size: 0.8rem;
  }
}

/* ─────────────────────────────────────────────────────────────────────────────
 * VERGELIJKINGSTABELLEN OP MOBIEL (Plak-PVC vs Klik-PVC e.d.)
 * Deze 3-koloms grids (1fr 1fr 1fr) mogen NIET naar 1 kolom collapsen — dan is
 * onduidelijk welke waarde bij klik of plak hoort. Houd 3 koloms maar compact
 * zodat de tabel binnen het scherm past. Komt NA de collapse-regel hierboven,
 * dus wint bij gelijke specificiteit. (Andere 1fr 1fr 1fr grids zoals
 * ;gap:3rem collapsen wel, want die matchen deze selectors niet.)
 * ─────────────────────────────────────────────────────────────────────────── */
@media (max-width: 767px) {
  /* Naar 2 koloms (Klik | Plak); de eerste cel (eigenschap/kop) wordt een
     volle-breedte kopje erboven. Geeft per rij een net mini-kaartje i.p.v.
     3 cramped kolommen met ongelijke rijhoogtes. */
  [style*="1fr 1fr 1fr;text-align:center"],
  [style*="1fr 1fr 1fr;background"] {
    grid-template-columns: 1fr 1fr !important;
    align-items: stretch !important;
  }
  [style*="1fr 1fr 1fr;text-align:center"] > :first-child,
  [style*="1fr 1fr 1fr;background"] > :first-child {
    grid-column: 1 / -1 !important;
    border-left: none !important;
    background: rgba(255, 255, 255, 0.04) !important;
    text-align: left !important;
  }
  [style*="1fr 1fr 1fr;text-align:center"] > div,
  [style*="1fr 1fr 1fr;background"] > div {
    padding: 0.625rem 0.75rem !important;
  }
  [style*="1fr 1fr 1fr;text-align:center"] span,
  [style*="1fr 1fr 1fr;background"] span {
    font-size: 0.8125rem !important;
    line-height: 1.35 !important;
  }
  /* "Aanbevolen"-badge naast Plak-PVC-kop mag onder de kop wrappen */
  [style*="1fr 1fr 1fr;text-align:center"] [style*="display:flex"] {
    flex-wrap: wrap;
    gap: 0.25rem !important;
  }
}

/* ─────────────────────────────────────────────────────────────────────────────
 * SECTIE ACHTERGRONDEN
 * ─────────────────────────────────────────────────────────────────────────── */

.section-light {
  background-color: var(--color-cream);
  padding: var(--section-pad-y) 0;
}

.section-white {
  background-color: var(--color-white);
  padding: var(--section-pad-y) 0;
}

.section-dark {
  background-color: var(--color-charcoal);
  padding: var(--section-pad-y) 0;
}

.section-sm {
  padding: var(--section-pad-y-sm) 0;
}

/* ─────────────────────────────────────────────────────────────────────────────
 * TEKST UITLIJNING
 * ─────────────────────────────────────────────────────────────────────────── */

.text-center { text-align: center; }
.text-left   { text-align: left; }
.text-right  { text-align: right; }

/* ─────────────────────────────────────────────────────────────────────────────
 * AFBEELDINGEN
 * ─────────────────────────────────────────────────────────────────────────── */

/* Volledige hoogte afbeelding (voor split-layouts) */
.img-cover {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Afbeelding wrapper met vaste hoogte */
.img-wrapper {
  position: relative;
  overflow: hidden;
  border-radius: var(--card-radius);
}

.img-wrapper-hero {
  min-height: 480px;
}

.img-wrapper-card {
  height: 13rem;   /* 208px */
}

.img-wrapper-card-lg {
  height: 15rem;   /* 240px */
}

/* Gradient overlay op afbeelding */
.img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(26, 26, 24, 0.7) 0%,
    transparent 60%
  );
}

/* Zoom-effect bij hover (op parent) */
.img-zoom img {
  transition: transform var(--transition-slower);
}

.img-zoom:hover img {
  transform: scale(1.05);
}

/* ─────────────────────────────────────────────────────────────────────────────
 * ZICHTBAARHEID
 * ─────────────────────────────────────────────────────────────────────────── */

.hidden { display: none; }

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

/* Verberg op mobiel, toon op desktop */
.hide-mobile {
  display: none;
}

@media (min-width: 768px) {
  .hide-mobile {
    display: block;
  }
}

/* Toon op mobiel, verberg op desktop */
.hide-desktop {
  display: block;
}

@media (min-width: 768px) {
  .hide-desktop {
    display: none;
  }
}

/* ─────────────────────────────────────────────────────────────────────────────
 * ANIMATIES (CSS-only, vervangt Framer Motion)
 * ─────────────────────────────────────────────────────────────────────────── */

/* Fade in van onderen (voor cards, secties) */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(24px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Fade in */
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* Scale in (voor popup) */
@keyframes scaleIn {
  from {
    opacity: 0;
    transform: scale(0.92) translateY(16px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

/* Slide in van links (voor mobiel menu) */
@keyframes slideInLeft {
  from { transform: translateX(-100%); }
  to   { transform: translateX(0); }
}

/* Slide in van rechts */
@keyframes slideInRight {
  from { transform: translateX(100%); }
  to   { transform: translateX(0); }
}

/* Klassen om animaties toe te passen */
.animate-fade-in-up {
  animation: fadeInUp 0.5s ease forwards;
}

.animate-fade-in {
  animation: fadeIn 0.4s ease forwards;
}

.animate-scale-in {
  animation: scaleIn 0.35s ease forwards;
}

/* Intersection Observer: elementen beginnen onzichtbaar */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Vertraagde reveal voor staggered effecten */
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
.reveal-delay-4 { transition-delay: 0.4s; }
.reveal-delay-5 { transition-delay: 0.5s; }

/* ─────────────────────────────────────────────────────────────────────────────
 * BREADCRUMBS
 * ─────────────────────────────────────────────────────────────────────────── */

.breadcrumbs {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  margin-bottom: var(--space-6);
}

.breadcrumb-item {
  color: rgba(240, 237, 230, 0.6);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.breadcrumb-item:hover {
  color: var(--color-gold);
}

.breadcrumb-separator {
  color: rgba(240, 237, 230, 0.4);
  font-size: 0.625rem;
}

.breadcrumb-current {
  color: var(--color-cream-dark);
}

/* ─────────────────────────────────────────────────────────────────────────────
 * LEVENSDUUR BALK
 * ─────────────────────────────────────────────────────────────────────────── */

.levensduur-bar {
  height: 0.5rem;
  border-radius: var(--radius-full);
  overflow: hidden;
  background-color: var(--color-cream-mid);
}

.levensduur-bar-fill {
  height: 100%;
  border-radius: var(--radius-full);
  background-color: var(--color-gold);
  transition: width 0.8s ease;
}

.levensduur-bar-fill-green {
  background-color: var(--color-green);
}

.levensduur-bar-fill-gray {
  background-color: #aaa;
}

/* ─────────────────────────────────────────────────────────────────────────────
 * FLOATING WHATSAPP KNOP
 * ─────────────────────────────────────────────────────────────────────────── */

/* Bel-knop boven WhatsApp, gestapeld linksonder (desktop) */
.float-contact {
  position: fixed;
  bottom: 1.5rem;
  left: 1.5rem;
  z-index: 60;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.float-contact-btn {
  width: 3.5rem;
  height: 3.5rem;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-xl);
  text-decoration: none;
  transition: transform var(--transition-normal), box-shadow var(--transition-normal);
}

.float-contact-btn:hover {
  transform: scale(1.1);
  box-shadow: var(--shadow-2xl);
}

.float-call {
  background-color: oklch(0.68 0.08 75); /* warm-goud, site-accent */
  color: oklch(0.12 0.005 65);
}

.float-whatsapp {
  background-color: #25D366;
  color: #fff;
}

/* Op mobiel neemt de sticky-bar het over → float verbergen */
@media (max-width: 767px) {
  .float-contact {
    display: none;
  }
}

/* TABLET (768–1023px): floating elementen compacter + strak in de hoek, zodat
   ze stat-balken, formuliervelden en kaarten niet meer afdekken. De review-badge
   krijgt dezelfde compacte rij-variant als op mobiel; op desktop (≥1024) is er
   ruimte zat en blijft alles zoals ontworpen. */
@media (min-width: 768px) and (max-width: 1023px) {
  .oms-rev-badge {
    flex-direction: row !important;
    align-items: center !important;
    gap: 9px !important;
    padding: 7px 13px !important;
    min-width: 0 !important;
    border-radius: 10px !important;
  }
  .oms-rev-badge-g svg { width: 26px !important; height: 26px !important; }
  .oms-rev-badge-body { align-items: flex-start !important; text-align: left !important; gap: 0 !important; }
  .oms-rev-badge-label  { font-size: 0.78rem !important; }
  .oms-rev-badge-rating { font-size: 0.82rem !important; gap: 4px !important; }
  .oms-rev-badge-rating strong { font-size: 0.88rem !important; }
  .oms-rev-badge-count  { font-size: 0.66rem !important; margin-top: 0 !important; }

  .float-contact { bottom: 1rem; left: 1rem; gap: 0.5rem; }
  .float-contact-btn { width: 3rem; height: 3rem; }
}

/* ─────────────────────────────────────────────────────────────────────────────
 * STICKY MOBIELE BALK (onderaan op mobiel)
 * ─────────────────────────────────────────────────────────────────────────── */

.mobile-sticky-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 40;
  background-color: var(--color-charcoal);
  border-top: 1px solid var(--color-charcoal-light);
  padding: var(--space-3) var(--space-4);
  display: flex;
  gap: var(--space-3);
}

@media (min-width: 768px) {
  .mobile-sticky-bar {
    display: none;
  }
}

.mobile-sticky-bar .btn {
  flex: 1;
  font-size: var(--text-sm);
}

/* ─────────────────────────────────────────────────────────────────────────────
 * DIVIDERS
 * ─────────────────────────────────────────────────────────────────────────── */

.divider {
  border: none;
  border-top: 1px solid var(--color-cream-mid);
  margin: var(--space-8) 0;
}

.divider-dark {
  border-top-color: var(--color-charcoal-light);
}

/* ─────────────────────────────────────────────────────────────────────────────
 * SECTIE HEADER (gecentreerd)
 * ─────────────────────────────────────────────────────────────────────────── */

.section-header {
  text-align: center;
  margin-bottom: var(--space-14);
}

.section-header-title {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-3);
}

@media (min-width: 768px) {
  .section-header-title {
    font-size: var(--text-4xl);
  }
}

.section-header-subtitle {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-text-muted);
  max-width: 36rem;
  margin: 0 auto;
  line-height: var(--leading-relaxed);
}

/* Dark variant */
.section-header-dark .section-header-title {
  color: var(--color-white);
}

.section-header-dark .section-header-subtitle {
  color: var(--color-cream-dark);
}

/* ─────────────────────────────────────────────────────────────────────────────
 * DONKERE INLINE-SECTIES — body-tekst licht houden
 * Inline-styled secties (background:oklch(0.12 ...)) zetten hun kleur via een
 * geërfde inline-style, maar globale li/p-kleurregels overschrijven die erfenis
 * → donkere tekst op donkere achtergrond. Hogere-specificiteit-regel dwingt licht
 * af; elementen met een eigen inline color (gold koppen, badges) winnen alsnog.
 * ─────────────────────────────────────────────────────────────────────────── */
[style*="background:oklch(0.12"] p,
[style*="background:oklch(0.12"] li,
[style*="background:oklch(0.12"] ul,
[style*="background:oklch(0.12"] span,
[style*="background:oklch(0.12"] strong,
[style*="background:oklch(0.12"] b,
[style*="background:oklch(0.12"] h1,
[style*="background:oklch(0.12"] h2,
[style*="background:oklch(0.12"] h3,
[style*="background:oklch(0.12"] h4,
[style*="background:oklch(0.18"] p,
[style*="background:oklch(0.18"] li,
[style*="background:oklch(0.18"] span,
[style*="background:oklch(0.18"] strong,
[style*="background:oklch(0.18"] b,
[style*="background:oklch(0.18"] h1,
[style*="background:oklch(0.18"] h2,
[style*="background:oklch(0.18"] h3,
[style*="background:oklch(0.18"] h4 {
  color: var(--color-cream, oklch(0.96 0.008 75));
}

/* ─────────────────────────────────────────────────────────────────────────────
 * FOOTER — secundaire tekst leesbaar op (bijna-zwarte) footer-achtergrond.
 * --color-text-secondary/-muted zijn agency-breed donkerder gezet voor leesbaar-
 * heid op LICHTE achtergronden; in de donkere footer gaf dat 2.7:1 (onleesbaar).
 * We herdefiniëren de vars binnen de footer-scope → de inline var()-referenties
 * in footer.php lossen hier op naar lichte waarden (geen !important nodig).
 * ─────────────────────────────────────────────────────────────────────────── */
.site-footer {
  --color-text-secondary: oklch(0.74 0.008 75); /* ~9:1 op footer-bg */
  --color-text-muted:     oklch(0.68 0.010 75); /* ~7:1 op footer-bg */
}

/* ─────────────────────────────────────────────────────────────────────────────
 * SECUNDAIR GRIJS — leesbaarheid op LICHTE achtergrond (WCAG AA).
 * Templates gebruiken inline color:oklch(0.60 0.015 65) als subtekst; op
 * wit/crème geeft dat ~3.9:1 (onder de 4.5-norm). We donkeren het naar 0.48
 * (~4.6:1) op lichte secties, maar lichten het juist op binnen DONKERE secties
 * (hogere specificiteit wint) zodat daar geen donker-op-donker ontstaat.
 * ─────────────────────────────────────────────────────────────────────────── */
[style*="color:oklch(0.60 0.015 65)"] {
  color: oklch(0.48 0.015 65) !important;
}
[style*="background:oklch(0.12"] [style*="color:oklch(0.60 0.015 65)"],
[style*="background:oklch(0.18"] [style*="color:oklch(0.60 0.015 65)"] {
  color: oklch(0.78 0.015 65) !important;
}

/* ─────────────────────────────────────────────────────────────────────────────
 * SECONDARY-KNOP OP DONKERE SECTIE — .btn-secondary heeft donkere tekst (bedoeld
 * voor lichte bg). Zonder inline color:white-override werd hij donker-op-donker
 * (onzichtbaar) op donkere CTA-secties. Forceer licht + lichte rand daar.
 * ─────────────────────────────────────────────────────────────────────────── */
[style*="background:oklch(0.12"] a.btn-secondary,
[style*="background:oklch(0.18"] a.btn-secondary {
  color: #fff !important;
  border-color: rgba(255, 255, 255, 0.3) !important;
}

/* ─────────────────────────────────────────────────────────────────────────────
 * MOBIEL — inline 2/3-koloms grids + min-width-flexitems responsive
 * (page-pvc-vloeren e.d. gebruiken inline repeat(2/3,1fr) + min-width:300/400px
 *  die de override voor repeat(4-7) niet ving → gepropt / horizontale overflow)
 * ─────────────────────────────────────────────────────────────────────────── */
@media (max-width: 767px) {
  [style*="grid-template-columns:repeat(3,1fr)"],
  [style*="grid-template-columns:repeat(2,1fr)"] {
    grid-template-columns: 1fr !important;
  }
  [style*="min-width:400px"],
  [style*="min-width:300px"] {
    min-width: 0 !important;
  }
}

/* Inline 2-koloms flex-secties op mobiel stapelen (flex:1/flex:2 + min-width-kind)
   zodat kolommen volle breedte krijgen i.p.v. te krimpen (page-pvc-vloeren e.d.). */
@media (max-width: 767px) {
  [style*="display:flex"]:has(> [style*="min-width:400px"]),
  [style*="display:flex"]:has(> [style*="min-width:300px"]) {
    flex-direction: column !important;
  }
}
