/* ============================================
   SOMA — Styles
   Warm palette: terracotta / amber / cream
   ============================================ */

/* ---------- Custom Properties ---------- */
:root {
  /* Core warm palette */
  --terracotta: #C75B3A;        /* primary brand — warm clay */
  --terracotta-deep: #8E3A21;   /* deep burnt — headings on cream */
  --amber: #E89A3C;             /* golden accent */
  --amber-soft: #F4B860;        /* lighter amber for hovers */
  --cream: #FBF4E6;             /* page background */
  --cream-deep: #F3E8CF;        /* card / alternating section bg */
  --sand: #E9D8B4;              /* subtle divider / border tint */
  --ember: #B23A1E;             /* darkest accent — CTA hover */

  /* Text */
  --ink: #2B1810;               /* deep brown-black, primary text */
  --ink-soft: #5A3E2E;          /* secondary text, warm brown */
  --ink-muted: #8B6F5C;         /* tertiary / muted */
  --cream-muted: rgba(251, 244, 230, 0.72); /* muted text on dark */

  /* Utility */
  --success: #6B8E4E;
  --warning: #D9A441;
  --danger: #B23A1E;
  --border: #E5D4B4;
  --border-warm: rgba(139, 111, 92, 0.18);

  --font-body: 'Inter', system-ui, -apple-system, sans-serif;
  --font-display: 'Fraunces', Georgia, serif;
  --font-mono: 'JetBrains Mono', 'Fira Code', monospace;

  --radius-sm: 6px;
  --radius-md: 14px;
  --radius-lg: 20px;

  --shadow-sm: 0 1px 3px rgba(69, 30, 10, 0.08);
  --shadow-md: 0 6px 18px rgba(69, 30, 10, 0.10);
  --shadow-lg: 0 14px 32px rgba(69, 30, 10, 0.14);
  --shadow-warm: 0 8px 24px rgba(199, 91, 58, 0.22);

  --transition: 0.2s ease;
}

/* ---------- Reset ---------- */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
}

body {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink);
  background: var(--cream);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

img, svg {
  max-width: 100%;
  display: block;
}

/* Fixed background canvas — thermal particle swarm */
#thermal-bg {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none;
}

/* All content floats above the canvas */
nav, header, main, footer {
  position: relative;
  z-index: 2;
}

a {
  color: inherit;
  text-decoration: none;
}

ul, ol {
  list-style: none;
}

/* ---------- Typography ---------- */
h1, h2 {
  font-family: var(--font-display);
  font-weight: 500;           /* Fraunces reads heavy at 600+ */
  letter-spacing: -0.015em;
}

h1 {
  font-size: clamp(2.25rem, 6vw, 3.75rem);
  line-height: 1.08;
  letter-spacing: -0.025em;
}

h2 {
  font-size: clamp(1.75rem, 4.2vw, 2.75rem);
  line-height: 1.15;
}

h3 {
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: 0.75rem;
  color: var(--terracotta-deep);
}

h4 {
  font-size: 1.05rem;
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: 0.5rem;
}

.mono {
  font-family: var(--font-mono);
  font-size: 0.9em;
}

.nb {
  white-space: nowrap;
}

.eyebrow {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.78rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--terracotta);
  margin-bottom: 1.1rem;
}

/* ---------- Layout ---------- */
.container {
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 clamp(16px, 4vw, 48px);
}

.section {
  padding: clamp(56px, 9vw, 112px) 0;
  scroll-margin-top: 70px;
  position: relative;
}

/* Opake sections delen nu &eacute;&eacute;n warme tint &mdash; het midden
   tussen de oude cr&egrave;me (probleem) en zand (hoe het werkt / impact)
   kleuren. Zo krijgen alle vaste-achtergrond secties dezelfde kleur en
   contrasteren ze tegelijk duidelijk met de cr&egrave;me canvas. */
.section--cream,
.section--sand {
  background: rgba(242, 224, 195, 0.96);
  border-top: 1px solid rgba(199, 91, 58, 0.1);
  border-bottom: 1px solid rgba(199, 91, 58, 0.1);
}

/* Transparent sections (hero, CTA) now show cream canvas behind, so text
   must be dark — not cream. */
.section--dark {
  background: transparent;
  color: var(--ink);
}

.section--dark h2 {
  color: var(--terracotta-deep);
}

.section--dark .eyebrow {
  color: var(--terracotta);
}

.section--dark .section__subtitle {
  color: var(--ink-soft);
}

.section__header {
  text-align: center;
  max-width: 820px;
  margin: 0 auto clamp(40px, 6vw, 64px);
}

/* Default header color — voor transparante sections (hero, CTA, solution,
   service, team) zichtbaar tegen de cr&egrave;me canvas. */
.section__header h2 {
  color: var(--terracotta-deep);
}

/* Op de lichte cr&egrave;me-zand sections is terracotta-deep nog altijd
   donker, maar we gebruiken de fellere terracotta voor meer hierarchie. */
.section--cream .section__header h2 {
  color: var(--terracotta);
}

/* Op de warmere zand sections is de achtergrond dichter bij terracotta;
   daarom gebruiken we hier juist de diepste tint voor contrast. */
.section--sand .section__header h2 {
  color: var(--terracotta-deep);
}

/* De probleem-header is een langere zin; geef hem meer breedte zodat
   hij in minder regels past en gecentreerd blijft. */
#problem .section__header,
#solution .section__header {
  max-width: 1040px;
}

/* Minder loze ruimte onder de vier probleem-kaarten. */
#problem {
  padding-bottom: clamp(32px, 5vw, 64px);
}

.section--dark .section__header h2 {
  color: var(--cream);
}

/* Sub-headers (feature items etc.) volgen dezelfde logica: op cr&egrave;me
   fellere tint voor lucht, op zand de diepe tint voor grondigheid. */
.section--cream .feature-item h4,
.section--cream .impact-card h3,
.section--cream .team-member h3,
.section--cream .process__step h4 {
  color: var(--terracotta);
}

.section__subtitle {
  color: var(--ink-soft);
  font-size: 1.1rem;
  margin-top: 1rem;
  line-height: 1.7;
}

/* CTA boven de comfort-chart: stack button en chart verticaal in dezelfde kolom
   van de .how-it-works__grid, en laat de kolom haar breedte houden. */
.comfort-chart-column {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3rem;
}
.comfort-chart-column .comfort-chart {
  width: 100%;
}

/* Grotere variant voor de comfort-chart CTA: ruimer padding en grotere tekst
   dan de default .btn. Selector is extra specifiek (.btn.comfort-chart__cta)
   omdat .btn verderop in het bestand gedefinieerd is en anders wint. */
.btn.comfort-chart__cta {
  padding: 20px 48px;
  font-size: 1.2rem;
}

/* Losstaande tagline die op een eigen regel komt, iets losser van de
   section subtitle zodat de tweede zin visueel apart leest. */
.section__tagline {
  color: var(--terracotta);
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1rem, 1.8vw, 1.2rem);
  line-height: 1.5;
  margin-top: 1.5rem;
  font-weight: 500;
}

.grid-2-col {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(24px, 4vw, 56px);
  align-items: center;
}

.grid-3-col {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(16px, 3vw, 32px);
}

.grid-4-col {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(16px, 2.5vw, 24px);
}

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

  .grid-3-col {
    grid-template-columns: repeat(3, 1fr);
  }

  .grid-4-col {
    grid-template-columns: repeat(2, 1fr);
  }
}

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

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 13px 28px;
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 600;
  border-radius: 999px;
  border: 2px solid transparent;
  cursor: pointer;
  transition: all var(--transition);
  white-space: nowrap;
  letter-spacing: 0.01em;
}

.btn--primary {
  background: var(--terracotta);
  color: var(--cream);
  border-color: var(--terracotta);
}

.btn--primary:hover {
  background: var(--ember);
  border-color: var(--ember);
  transform: translateY(-1px);
  box-shadow: var(--shadow-warm);
}

.btn--secondary {
  background: transparent;
  color: var(--terracotta);
  border-color: var(--terracotta);
}

.btn--secondary:hover {
  background: rgba(199, 91, 58, 0.08);
  transform: translateY(-1px);
}

.section--dark .btn--secondary {
  color: var(--amber);
  border-color: var(--amber);
}

.section--dark .btn--secondary:hover {
  background: rgba(232, 154, 60, 0.12);
}

/* ---------- Navigation ---------- */
/* De nav verandert van kleur afhankelijk van de sectie die eronder ligt.
   Drie varianten:
     - default                  : lichtgetinte crème (over transparante sections / canvas)
     - .nav--on-cream           : iets feller crème met terracotta-tint (over .section--cream)
     - .nav--on-sand            : warme zand-tint (over .section--sand)
   De switch wordt met een transition gesoepeld. */
.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 120;
  padding: 20px 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  backdrop-filter: blur(10px);
  /* Default: terracotta-deep &mdash; warm donkerrood, contrasteert met de
     cr&egrave;me canvas. De .nav--on-sand variant wisselt naar diepe ink
     (donkerbruin) voor een zichtbaar ander gevoel boven de zand sections. */
  background: rgba(142, 58, 33, 0.9);
  border-bottom: 1px solid rgba(43, 24, 16, 0.24);
  transition: background 0.35s ease, border-color 0.35s ease, color 0.35s ease;
}

/* Default tekst/logo op donkere nav: cr&egrave;me */
.nav .nav__logo-text {
  color: var(--cream);
}

.nav .nav__logo-dot {
  color: var(--amber);
}

.nav .nav__links a {
  color: rgba(251, 244, 230, 0.88);
}

.nav .nav__links a:hover {
  color: var(--amber);
}

.nav .nav__links a::after {
  background: var(--amber);
}

.nav .nav__hamburger span {
  background: var(--cream);
}

/* Boven een opake sectie: schakel naar dezelfde cr&egrave;me-tint als de
   stat-cards in de probleem-sectie, voor visuele samenhang. */
.nav.nav--on-opaque {
  background: rgba(251, 244, 230, 0.9);
  border-bottom-color: rgba(199, 91, 58, 0.18);
}

/* Op de lichte variant heeft de donkere cr&egrave;me tekst niet genoeg
   contrast &mdash; laat logo, links en hamburger switchen naar donkere tinten. */
.nav.nav--on-opaque .nav__logo-text {
  color: var(--terracotta-deep);
}

.nav.nav--on-opaque .nav__logo-dot {
  color: var(--terracotta);
}

.nav.nav--on-opaque .nav__links a {
  color: var(--ink);
}

.nav.nav--on-opaque .nav__links a:hover {
  color: var(--terracotta);
}

.nav.nav--on-opaque .nav__links a::after {
  background: var(--terracotta);
}

.nav.nav--on-opaque .nav__hamburger span {
  background: var(--ink);
}

/* Kleuren voor logo/tekst/hamburger staan op de base .nav regels hierboven
   en gelden voor alle varianten (default, --on-sand). Beide varianten zijn
   donker genoeg dat cr&egrave;me tekst in alle gevallen leesbaar is. */

/* Logo- en link-structuur (kleuren staan hierboven op .nav .nav__* regels) */
.nav__logo-text {
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 1.6vw, 1.55rem);
  font-weight: 500;
  font-style: italic;
  letter-spacing: -0.01em;
}

.nav__links {
  list-style: none;
  display: none;
  gap: 36px;
}

.nav__links a {
  text-decoration: none;
  font-size: 13px;
  font-family: var(--font-body);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 500;
  position: relative;
  padding-bottom: 3px;
  transition: color 0.3s ease;
}

.nav__links a::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  height: 1px;
  transition: width 0.3s ease;
}

.nav__links a:hover::after {
  width: 100%;
}

@media (min-width: 768px) {
  .nav__links {
    display: flex;
  }
}

/* -- Hamburger (mobile) -- */
.nav__hamburger {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  width: 28px;
  height: 20px;
  position: relative;
}

.nav__hamburger span {
  display: block;
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  border-radius: 2px;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.nav__hamburger span:nth-child(1) { top: 0; }
.nav__hamburger span:nth-child(2) { top: 9px; }
.nav__hamburger span:nth-child(3) { top: 18px; }

.nav__hamburger.is-open span:nth-child(1) {
  transform: translateY(9px) rotate(45deg);
}
.nav__hamburger.is-open span:nth-child(2) {
  opacity: 0;
}
.nav__hamburger.is-open span:nth-child(3) {
  transform: translateY(-9px) rotate(-45deg);
}

/* Hamburger stays cream when the mobile overlay is open (dark bg behind) */
.nav__hamburger.is-open span {
  background: var(--cream);
}

.nav.nav--open {
  background: transparent;
  border-bottom-color: transparent;
  backdrop-filter: none;
}

.nav.nav--open .nav__logo-text {
  color: var(--cream);
}

.nav.nav--open .nav__links a {
  color: rgba(251, 244, 230, 0.88);
}

/* ---------- Mobile overlay ---------- */
.mobile-overlay {
  display: none;
}

@media (max-width: 767px) {
  .nav {
    padding: 16px 24px;
  }

  .nav__hamburger {
    display: block;
  }

  .nav__links {
    display: none !important;
  }

  .mobile-overlay {
    display: block;
    position: fixed;
    inset: 0;
    background: var(--ink);
    z-index: 110;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
  }

  .mobile-overlay.is-open {
    opacity: 0.97;
    pointer-events: auto;
  }

  .mobile-overlay__links {
    list-style: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    gap: 0;
  }

  .mobile-overlay__links a {
    font-family: var(--font-body);
    font-size: 1.15rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 500;
    color: rgba(251, 244, 230, 0.92);
    padding: 14px 32px;
    display: block;
    transition: color 0.3s ease;
  }

  .mobile-overlay__links a:hover {
    color: var(--amber);
  }

  .nb { white-space: normal; }
  .btn { white-space: normal; }

  .cta__buttons {
    flex-direction: column;
    align-items: center;
  }

  .cta__buttons .btn {
    width: 100%;
    max-width: 300px;
  }
}

/* ---------- Hero ---------- */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  overflow: hidden;
  /* De vaste nav-balk (~76px) dekt het bovenste deel van de hero af. Zonder
     compensatie lijkt de content daardoor boven het optische midden te zweven
     — deze padding-top duwt de centrering naar het échte visuele midden. */
  padding-top: 76px;
}

/* Op mobiel is de eyebrow-tekst boven de hero-titel te druk — verberg hem
   daar zodat de h1 direct in beeld staat. Daarnaast extra top-padding op
   de hero zodat de titel losstaat van de vaste nav-balk. */
@media (max-width: 639px) {
  .hero__content > .eyebrow {
    display: none;
  }

  .hero {
    padding-top: 96px;
    align-items: flex-start;
  }
}

.hero__content {
  position: relative;
  text-align: center;
  max-width: 1080px;
  /* Symmetrische verticale padding laat de flex-centrering van .hero
     daadwerkelijk zichtbaar zijn; de extra top-padding was cosmetisch
     dus oud maar zorgde ervoor dat de content bovenin plakte. */
  padding: clamp(48px, 6vw, 80px) clamp(16px, 4vw, 48px);
}

.hero h1 {
  color: var(--terracotta-deep);
  margin-bottom: 1.25rem;
}

.hero h1 em {
  font-style: italic;
  color: var(--terracotta);
  font-weight: 400;
}

.hero__subtitle {
  color: var(--ink-soft);
  font-size: clamp(1rem, 2vw, 1.2rem);
  line-height: 1.7;
  margin-bottom: 2.5rem;
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
}

/* Losstaande tagline onder de subtitle — duidelijk gescheiden door ruimte */
.hero__tagline {
  color: var(--terracotta);
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.05rem, 2.1vw, 1.3rem);
  line-height: 1.5;
  max-width: 720px;
  margin: 2.5rem auto 2.5rem;
  font-weight: 500;
}

.hero__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  justify-content: center;
  align-items: center;
  margin-bottom: 2.5rem;
}

/* Centrale CTA in de hero: iets groter, meer padding en een zachte warme glow
   zodat-ie duidelijk het zwaartepunt is tussen de andere twee secundaire knoppen. */
.hero__cta-primary {
  font-size: 1.05rem;
  padding: 16px 34px;
  box-shadow: var(--shadow-warm);
}

.hero__cta-primary:hover {
  box-shadow: 0 12px 30px rgba(199, 91, 58, 0.35);
}

.hero__trust {
  font-size: 0.85rem;
  color: var(--ink-muted);
}

.hero__trust a {
  color: var(--terracotta);
  font-weight: 600;
  transition: color var(--transition);
}

.hero__trust a:hover {
  color: var(--terracotta-deep);
}

/* ---------- Problem ---------- */
.problem__stats {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  margin-bottom: clamp(32px, 4vw, 48px);
}

@media (min-width: 640px) {
  .problem__stats {
    grid-template-columns: 1fr 1fr;
  }
}

.stat-card {
  background: rgba(251, 244, 230, 0.7);
  border: 1px solid var(--border);
  border-left: 4px solid var(--terracotta);
  border-radius: var(--radius-md);
  padding: 28px 32px;
  box-shadow: var(--shadow-sm);
}

.stat-card__number {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 3.5rem);
  font-weight: 500;
  line-height: 1;
  color: var(--terracotta);
  letter-spacing: -0.02em;
  margin-bottom: 0.5rem;
}

/* Icon in plaats van percentage &mdash; zelfde optische hoogte als
   .stat-card__number zodat alle vier de kaarten uitlijnen. */
.stat-card__icon {
  width: clamp(42px, 5vw, 56px);
  height: clamp(42px, 5vw, 56px);
  color: var(--terracotta);
  margin-bottom: 0.9rem;
  display: block;
}

.stat-card__label {
  color: var(--ink-soft);
  font-size: 0.95rem;
  line-height: 1.5;
}

/* Bold stukken binnen een stat-card-label oplichten in terracotta voor accent. */
.stat-card__label strong {
  color: var(--terracotta);
  font-weight: 600;
}

.problem__body {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
}

.problem__body p {
  color: var(--ink-soft);
  font-size: 1.1rem;
  line-height: 1.75;
  margin-top: 1rem;
}

.problem__body p strong {
  color: var(--terracotta-deep);
  font-weight: 600;
}

/* ---------- Solution cards ---------- */
.card {
  background: rgba(251, 244, 230, 0.85);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 32px;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition), transform var(--transition);
}

.card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}

.card__number {
  font-family: var(--font-display);
  font-size: 2.25rem;
  font-weight: 400;
  font-style: italic;
  color: var(--amber);
  line-height: 1;
  margin-bottom: 16px;
}

.card__icon {
  width: 44px;
  height: 44px;
  margin-bottom: 18px;
  color: var(--terracotta);
}

.card p {
  color: var(--ink-soft);
  font-size: 0.97rem;
  line-height: 1.65;
}

.card p strong {
  color: var(--terracotta-deep);
  font-weight: 600;
}

/* ---------- How it works — side-by-side layout ---------- */
.how-it-works__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(32px, 5vw, 56px);
  align-items: center;
}

@media (min-width: 900px) {
  .how-it-works__grid {
    grid-template-columns: 1fr 1fr;
  }
}

.feature-list {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.feature-item {
  padding: 20px 24px;
  background: rgba(251, 244, 230, 0.6);
  border-left: 3px solid var(--amber);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

.feature-item h4 {
  color: var(--terracotta-deep);
  margin-bottom: 6px;
  font-size: 1.05rem;
}

.feature-item p {
  color: var(--ink-soft);
  font-size: 0.95rem;
  line-height: 1.6;
}

/* Comfort chart container */
.comfort-chart {
  background: rgba(251, 244, 230, 0.88);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 28px;
  box-shadow: var(--shadow-sm);
}

.comfort-chart__caption {
  font-size: 0.85rem;
  color: var(--ink-muted);
  text-align: center;
  margin-top: 12px;
  font-style: italic;
}

/* ---------- Service process / timeline ---------- */
.process {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}

@media (min-width: 768px) {
  .process {
    grid-template-columns: repeat(5, 1fr);
    gap: 12px;
  }
}

.process__step {
  background: rgba(251, 244, 230, 0.82);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 24px 20px;
  box-shadow: var(--shadow-sm);
  position: relative;
  transition: transform var(--transition), box-shadow var(--transition);
}

.process__step:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}

.process__dot {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--terracotta);
  color: var(--cream);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 500;
  margin-bottom: 16px;
  box-shadow: var(--shadow-warm);
}

.process__step:nth-child(2) .process__dot { background: #D4712C; }
.process__step:nth-child(3) .process__dot { background: var(--amber); }
.process__step:nth-child(4) .process__dot { background: #C79545; }
.process__step:nth-child(5) .process__dot { background: #B28555; }

.process__step h4 {
  color: var(--terracotta-deep);
  font-size: 1rem;
  margin-bottom: 8px;
}

.process__step p {
  color: var(--ink-soft);
  font-size: 0.88rem;
  line-height: 1.55;
}

/* ---------- Impact section ---------- */
.impact__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}

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

.impact-card {
  background: rgba(251, 244, 230, 0.88);
  border: 1px solid var(--border);
  border-top: 4px solid var(--terracotta);
  border-radius: var(--radius-md);
  padding: 32px;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition), box-shadow var(--transition);
}

.impact-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}

.impact-card:nth-child(2) { border-top-color: var(--amber); }
.impact-card:nth-child(3) { border-top-color: #8E6B3C; }

.impact-card__icon {
  width: 44px;
  height: 44px;
  color: var(--terracotta);
  margin-bottom: 18px;
}

.impact-card:nth-child(2) .impact-card__icon { color: var(--amber); }
.impact-card:nth-child(3) .impact-card__icon { color: #8E6B3C; }

.impact-card h3 {
  margin-bottom: 12px;
}

.impact-card__metric {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 500;
  color: var(--terracotta);
  line-height: 1.1;
  margin: 8px 0 6px;
  letter-spacing: -0.02em;
}

.impact-card:nth-child(2) .impact-card__metric { color: var(--amber); }
.impact-card:nth-child(3) .impact-card__metric { color: #8E6B3C; }

.impact-card p {
  color: var(--ink-soft);
  font-size: 0.95rem;
  line-height: 1.65;
}

/* Headline stats banner */
.impact__banner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  margin-top: clamp(32px, 5vw, 48px);
  padding: clamp(28px, 4vw, 40px);
  background: rgba(142, 58, 33, 0.92);
  border-radius: var(--radius-lg);
  color: var(--cream);
  text-align: center;
}

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

.impact__banner-stat {
  border-right: 1px solid rgba(251, 244, 230, 0.18);
  padding: 8px 16px;
}

.impact__banner-stat:last-child {
  border-right: none;
}

@media (max-width: 639px) {
  .impact__banner-stat {
    border-right: none;
    border-bottom: 1px solid rgba(251, 244, 230, 0.18);
    padding-bottom: 16px;
  }
  .impact__banner-stat:last-child { border-bottom: none; }
}

.impact__banner-number {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 500;
  color: var(--amber);
  line-height: 1;
  margin-bottom: 6px;
}

.impact__banner-label {
  font-size: 0.85rem;
  color: var(--cream-muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

/* ---------- Team ---------- */
.team {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
}

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

.team-member {
  background: rgba(251, 244, 230, 0.85);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 28px;
  text-align: center;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition), box-shadow var(--transition);
}

.team-member:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}

.team-member__avatar {
  width: 96px;
  height: 96px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--amber), var(--terracotta));
  margin: 0 auto 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 500;
  color: var(--cream);
}

.team-member h3 {
  margin-bottom: 4px;
  color: var(--terracotta-deep);
}

.team-member__role {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 14px;
}

.team-member p {
  color: var(--ink-soft);
  font-size: 0.92rem;
  line-height: 1.6;
  text-align: left;
}

/* ---------- CTA ---------- */
.cta {
  position: relative;
  background: transparent;
  text-align: center;
  padding: clamp(72px, 10vw, 128px) 0;
  overflow: hidden;
}

.cta h2 {
  color: var(--terracotta-deep);
  margin-bottom: 1rem;
}

.cta h2 em {
  font-style: italic;
  color: var(--terracotta);
  font-weight: 400;
}

.cta__subtitle {
  color: var(--ink-soft);
  font-size: 1.1rem;
  margin-bottom: 2.5rem;
  max-width: 860px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.7;
}

.cta__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  justify-content: center;
  margin-bottom: 2rem;
}

.cta__contact {
  font-size: 0.9rem;
  color: var(--ink-muted);
}

/* Extra lucht tussen de quickscan-card en het fallback-contactregeltje eronder. */
.quickscan + .cta__contact,
.quickscan__result + .cta__contact,
.quickscan__error + .cta__contact {
  margin-top: 2.5rem;
}

.cta__contact a {
  color: var(--terracotta);
  font-weight: 600;
  transition: color var(--transition);
}

.cta__contact a:hover {
  color: var(--terracotta-deep);
}

/* ---------- Footer ---------- */
.footer {
  background: rgba(142, 58, 33, 0.95);
  padding: 32px 48px;
  border-top: 1px solid rgba(251, 244, 230, 0.1);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-body);
  font-size: 11px;
  color: rgba(251, 244, 230, 0.55);
  letter-spacing: 0.05em;
}

.footer a {
  color: rgba(251, 244, 230, 0.55);
  transition: color 0.3s ease;
}

.footer a:hover {
  color: var(--amber);
}

@media (max-width: 767px) {
  .footer {
    flex-direction: column;
    gap: 12px;
    text-align: center;
    padding: 24px;
  }
}

/* ---------- Scroll Animations ---------- */
.animate-on-scroll {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.animate-on-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Stagger grid children */
.grid-3-col .animate-on-scroll:nth-child(2),
.impact__grid .animate-on-scroll:nth-child(2),
.team .animate-on-scroll:nth-child(2) {
  transition-delay: 0.1s;
}

.grid-3-col .animate-on-scroll:nth-child(3),
.impact__grid .animate-on-scroll:nth-child(3),
.team .animate-on-scroll:nth-child(3) {
  transition-delay: 0.2s;
}

.process .animate-on-scroll:nth-child(2) { transition-delay: 0.08s; }
.process .animate-on-scroll:nth-child(3) { transition-delay: 0.16s; }
.process .animate-on-scroll:nth-child(4) { transition-delay: 0.24s; }
.process .animate-on-scroll:nth-child(5) { transition-delay: 0.32s; }

/* ---------- Reduced Motion ---------- */
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  .animate-on-scroll {
    opacity: 1;
    transform: none;
    transition: none;
  }

  #thermal-bg {
    display: none;
  }

  .hero,
  .cta {
    background: var(--cream);
  }

  .footer {
    background: var(--terracotta-deep);
  }
}

/* ============================================
   QUICK SCAN WIZARD (#contact)
   Stapsgewijs formulier met progressie-dots, radio-kaarten
   en een resultaatscherm. Hergebruikt de warme palette en
   .btn varianten uit de rest van de site.
   ============================================ */

.quickscan {
  max-width: 640px;
  margin: 0 auto;
  background: rgba(251, 244, 230, 0.92);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: clamp(24px, 4vw, 44px);
  box-shadow: var(--shadow-md);
  text-align: left;
  position: relative;
}

/* Honeypot: volledig onzichtbaar voor echte gebruikers, wel in de DOM
   zodat Formspree hem kan checken. */
.quickscan__honeypot {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

/* ---------- Progress dots ---------- */
.quickscan__progress {
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-bottom: 28px;
}

.quickscan__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: transparent;
  border: 1.5px solid var(--border);
  transition: background-color var(--transition), border-color var(--transition), transform var(--transition);
}

.quickscan__dot.is-done {
  background: var(--amber-soft);
  border-color: var(--amber-soft);
}

.quickscan__dot.is-active {
  background: var(--terracotta);
  border-color: var(--terracotta);
  transform: scale(1.25);
}

/* ---------- Steps ---------- */
.quickscan__step {
  display: none;
  animation: quickscanFadeIn 0.25s ease;
}

.quickscan__step.is-active {
  display: block;
}

@keyframes quickscanFadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.quickscan__step-label {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 10px;
}

.quickscan__question {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2.4vw, 1.6rem);
  font-weight: 500;
  color: var(--terracotta-deep);
  line-height: 1.25;
  margin-bottom: 6px;
}

.quickscan__help {
  color: var(--ink-muted);
  font-size: 0.92rem;
  margin-bottom: 18px;
}

/* ---------- Radio-kaart opties ---------- */
.quickscan__options {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 18px;
}

.quickscan__option {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: var(--cream);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: border-color var(--transition), background-color var(--transition), transform var(--transition);
}

.quickscan__option:hover {
  border-color: var(--amber-soft);
  background: var(--cream-deep);
}

/* Verberg de native radio, we gebruiken de kaart zelf als hit-target. */
.quickscan__option input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.quickscan__option::before {
  content: "";
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid var(--border);
  flex: 0 0 auto;
  transition: border-color var(--transition), background-color var(--transition);
}

.quickscan__option:has(input[type="radio"]:checked),
.quickscan__option.is-selected {
  border-color: var(--terracotta);
  background: rgba(199, 91, 58, 0.06);
}

.quickscan__option:has(input[type="radio"]:checked)::before,
.quickscan__option.is-selected::before {
  border-color: var(--terracotta);
  background: radial-gradient(circle, var(--terracotta) 0 45%, var(--cream) 50% 100%);
}

/* Focusring voor keyboard-gebruikers: verschijnt op de label wanneer
   de verborgen radio focus heeft. */
.quickscan__option:has(input[type="radio"]:focus-visible) {
  outline: 2px solid var(--amber);
  outline-offset: 2px;
}

.quickscan__option-text {
  font-size: 0.98rem;
  color: var(--ink);
  font-weight: 500;
}

.quickscan__option-hint {
  display: block;
  font-size: 0.82rem;
  color: var(--ink-muted);
  font-weight: 400;
  margin-top: 2px;
}

/* Conditioneel zichtbaar invulveld (bijv. "Anders, namelijk..."). JS zet
   het hidden-attribuut; de globale [hidden]-regel handelt verbergen af. */
.quickscan__reveal {
  margin-top: 6px;
  padding-left: 4px;
}

/* ---------- Tekst-inputs ---------- */
.quickscan__input-wrap {
  position: relative;
  margin-top: 18px;
  max-width: 320px;
}

.quickscan__input {
  width: 100%;
  padding: 14px 16px;
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--ink);
  background: var(--cream);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  transition: border-color var(--transition), box-shadow var(--transition);
}

.quickscan__input:focus {
  outline: none;
  border-color: var(--terracotta);
  box-shadow: 0 0 0 3px rgba(199, 91, 58, 0.15);
}

.quickscan__input::placeholder {
  color: var(--ink-muted);
}

.quickscan__input-wrap .quickscan__input {
  padding-right: 48px;
}

.quickscan__input-suffix {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--font-mono);
  font-size: 0.9rem;
  color: var(--ink-muted);
  pointer-events: none;
}

.quickscan__textarea {
  resize: vertical;
  min-height: 72px;
  font-family: var(--font-body);
}

/* ---------- Contactgegevens-grid ---------- */
.quickscan__fields {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-top: 18px;
}

.quickscan__field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.quickscan__field--full {
  grid-column: 1 / -1;
}

.quickscan__field-label {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--ink-soft);
}

.quickscan__field-optional {
  font-weight: 400;
  color: var(--ink-muted);
}

/* Foutstaat — JS zet .is-invalid op een veld bij ongeldige input. */
.quickscan__input.is-invalid {
  border-color: var(--danger);
  box-shadow: 0 0 0 3px rgba(178, 58, 30, 0.12);
}

.quickscan__privacy {
  margin-top: 16px;
  font-size: 0.82rem;
  color: var(--ink-muted);
  line-height: 1.55;
}

/* ---------- Navigatie-knoppen ---------- */
.quickscan__nav {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-top: 32px;
}

/* .btn heeft display: inline-flex, wat het HTML hidden-attribuut
   overschrijft. Deze regel herstelt dat voor de wizard-knoppen. */
.quickscan__nav .btn[hidden] {
  display: none;
}

/* Diverse wizard-containers hebben een eigen display-waarde (flex/grid) die
   het hidden-attribuut overschrijft. Forceer `none` wanneer hidden gezet is. */
.quickscan [hidden],
.quickscan__result[hidden],
.quickscan__result-metric[hidden],
.quickscan__error[hidden],
.quickscan__followup[hidden] {
  display: none !important;
}

/* Primary-knoppen rechts uitlijnen als "Vorige" disabled is. */
.quickscan__back {
  min-width: 110px;
}

.quickscan__next,
.quickscan__submit {
  min-width: 140px;
  margin-left: auto;
}

.quickscan__next:disabled,
.quickscan__submit:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.quickscan__submit.is-loading {
  opacity: 0.7;
  cursor: progress;
}

/* ---------- Resultaatscherm ---------- */
.quickscan__result {
  max-width: 640px;
  margin: 0 auto;
  background: var(--cream-deep);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: clamp(28px, 5vw, 52px);
  text-align: center;
  box-shadow: var(--shadow-md);
}

.quickscan__result-eyebrow {
  color: var(--terracotta);
}

.quickscan__result-title {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 3vw, 1.9rem);
  color: var(--terracotta-deep);
  margin: 10px 0 20px;
  line-height: 1.25;
}

.quickscan__result-metric {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin: 8px 0 24px;
  padding: 22px 16px;
  background: rgba(251, 244, 230, 0.85);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
}

.quickscan__result-metric-label {
  font-size: 0.85rem;
  font-family: var(--font-mono);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

.quickscan__result-metric-value {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  font-weight: 500;
  color: var(--terracotta);
  line-height: 1.15;
}

.quickscan__result-metric-note {
  font-size: 0.8rem;
  color: var(--ink-muted);
  font-style: italic;
}

.quickscan__result-text {
  color: var(--ink-soft);
  line-height: 1.6;
  font-size: 1rem;
}

.quickscan__result-actions {
  display: flex;
  justify-content: center;
  margin-top: 28px;
}

/* ---------- Early-exit follow-up ---------- */
.quickscan__early-exit .quickscan__result-text {
  max-width: 520px;
  margin: 0 auto 24px;
}

.quickscan__followup-form {
  max-width: 520px;
  margin: 8px auto 0;
  text-align: left;
}

.quickscan__followup-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 32px;
}

.quickscan__followup-actions .btn {
  min-width: 140px;
}

@media (max-width: 559px) {
  .quickscan__followup-actions {
    flex-direction: column-reverse;
  }
  .quickscan__followup-actions .btn {
    width: 100%;
  }
}

.quickscan__followup-thanks {
  margin-top: 20px;
  color: var(--success);
  font-weight: 600;
}

/* ---------- Foutscherm ---------- */
.quickscan__error {
  max-width: 640px;
  margin: 20px auto 0;
  padding: 16px 20px;
  background: rgba(178, 58, 30, 0.08);
  border: 1px solid rgba(178, 58, 30, 0.3);
  border-radius: var(--radius-md);
  color: var(--terracotta-deep);
  font-size: 0.95rem;
  text-align: center;
}

.quickscan__error a {
  color: var(--terracotta);
  font-weight: 600;
  text-decoration: underline;
}

/* ---------- Responsive ---------- */
@media (min-width: 640px) {
  .quickscan__fields {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 559px) {
  .quickscan__nav {
    flex-direction: column-reverse;
  }

  .quickscan__back,
  .quickscan__next,
  .quickscan__submit {
    width: 100%;
    margin-left: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .quickscan__step {
    animation: none;
  }

  .quickscan__dot {
    transition: none;
  }
}
