/* Self-hosted fonts — latin + latin-ext subsets only */

/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('/fonts/geist-latin-ext.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}

/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('/fonts/geist-latin.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/geist-latin-ext.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}

/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/geist-latin.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('/fonts/geist-latin-ext.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}

/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('/fonts/geist-latin.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('/fonts/geist-latin-ext.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}

/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('/fonts/geist-latin.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/fonts/geist-latin-ext.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}

/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/fonts/geist-latin.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/jetbrains-mono-latin-ext.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}

/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/jetbrains-mono-latin.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('/fonts/jetbrains-mono-latin-ext.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}

/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('/fonts/jetbrains-mono-latin.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* ==========================================================================
   shared.css — Salenza design system
   Shared tokens, nav, footer, and buttons used across all pages.
   Last updated: 2025
   ========================================================================== */

/* --------------------------------------------------------------------------
   DESIGN TOKENS
   -------------------------------------------------------------------------- */
:root {
  color-scheme: light only;
  --ink: #0A0A0A;
  --ink-soft: rgba(10, 10, 10, 0.62);
  --ink-faded: rgba(10, 10, 10, 0.42);
  --ink-line: rgba(10, 10, 10, 0.08);
  --ink-stroke: rgba(10, 10, 10, 0.12);
  --bg: #FAFAFA;
  --bg-warm: #F4F4F2;
  --surface: #FFFFFF;
  --dark: #0B0B0B;
  --dark-warm: #0E0E0C;
  --dark-line: rgba(255, 255, 255, 0.08);
  --dark-stroke: rgba(255, 255, 255, 0.14);
  --emerald: #047857;
  --emerald-light: #10B981;
  --emerald-deep: #035E45;
  --emerald-soft: rgba(4, 120, 87, 0.08);
  --emerald-glow: rgba(16, 185, 129, 0.18);
  --sans: 'Geist', system-ui, sans-serif;
  --mono: 'JetBrains Mono', monospace;
  /* Spacing scale — base-4, 10 tokens */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;
  --space-9: 96px;
  --space-10: 120px;
  /* Motion tokens */
  --duration-fast: 150ms;
  --duration-base: 200ms;
  --duration-slow: 300ms;
  --duration-deliberate: 600ms;
  --ease-default: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-out: cubic-bezier(0, 0, 0.2, 1);
  --ease-spring: cubic-bezier(0.16, 1, 0.3, 1);
  --radius-sm: 12px;
  --radius-md: 18px;
  --radius-lg: 24px;
  --radius-pill: 999px;
}

/* --------------------------------------------------------------------------
   RESET + BASE
   -------------------------------------------------------------------------- */
* { margin: 0; padding: 0; box-sizing: border-box; }
html, body { overflow-x: clip; }
em { font-style: normal; color: var(--emerald); }
body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  font-feature-settings: 'tnum' 0;
}
.tnum { font-variant-numeric: tabular-nums; }

/* --------------------------------------------------------------------------
   DARK SECTION TONAL OVERRIDE
   Same hue (160°), lifted lightness for visibility on dark bg.
   #047857 (light) → #10B981 (dark). One brand, two contexts.
   -------------------------------------------------------------------------- */
.proof-dark, .cta-dark, .footer-dark {
  --emerald: #10B981;
  --emerald-deep: #047857;
  --emerald-soft: rgba(16, 185, 129, 0.12);
}
.proof-dark .btn-emerald,
.cta-dark .btn-emerald,
.footer-dark .btn-emerald {
  color: #0A0A0A;
}
.proof-dark .btn-emerald:hover,
.cta-dark .btn-emerald:hover,
.footer-dark .btn-emerald:hover {
  background: #34D399;
}

/* --------------------------------------------------------------------------
   NAV
   -------------------------------------------------------------------------- */
.nav-wrap {
  background: rgba(250,250,250,0.85);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--ink-line);
  position: sticky;
  top: 0;
  z-index: 50;
}
.nav {
  max-width: 1280px;
  margin: 0 auto;
  padding: var(--space-4) var(--space-6);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
}

/* LOGO */
.logo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.02em;
  text-decoration: none;
  color: inherit;
}

/* Logo-mark: green rounded square with 3 animated dots */
.logo-mark {
  position: relative;
  width: 28px; height: 28px;
  background: var(--emerald);
  color: transparent;
  display: flex; align-items: center; justify-content: center;
  font-size: 0; font-weight: 600;
  border-radius: 8px;
  overflow: hidden;
}

/* Shared dot styles for all logo-mark variants */
.logo-mark::before,
.logo-mark::after,
.logo-mark > span,
.dash-logo-mark::before,
.dash-logo-mark::after,
.dash-logo-mark > span,
.footer-logo-mark::before,
.footer-logo-mark::after,
.footer-logo-mark > span {
  content: "";
  position: absolute;
  top: 50%;
  width: 13%;
  height: 13%;
  background: #fff;
  border-radius: 50%;
  transform: translateY(-50%);
}
.logo-mark::before,
.dash-logo-mark::before,
.footer-logo-mark::before {
  left: 22%;
  opacity: 0.5;
}
.logo-mark > span,
.dash-logo-mark > span,
.footer-logo-mark > span {
  left: 50%;
  transform: translate(-50%, -50%);
  opacity: 0.75;
}
.logo-mark::after,
.dash-logo-mark::after,
.footer-logo-mark::after {
  right: 22%;
}

/* Typing animation */
@keyframes salenza-typing {
  0%, 100% { opacity: 0.3; }
  50% { opacity: 1; }
}
.logo-mark::before,
.logo-mark > span,
.logo-mark::after,
.footer-logo-mark::before,
.footer-logo-mark > span,
.footer-logo-mark::after {
  animation: salenza-typing 2.4s infinite ease-in-out;
}
.logo-mark::before,
.footer-logo-mark::before { animation-delay: 0s; }
.logo-mark > span,
.footer-logo-mark > span { animation-delay: 0.3s; }
.logo-mark::after,
.footer-logo-mark::after { animation-delay: 0.6s; }

@media (prefers-reduced-motion: reduce) {
  .logo-mark::before,
  .logo-mark > span,
  .logo-mark::after,
  .footer-logo-mark::before,
  .footer-logo-mark > span,
  .footer-logo-mark::after {
    animation: none;
  }
}

/* Nav logo variant: transparent bg, emerald dots */
.logo .logo-mark {
  width: 24px;
  height: 24px;
  background: transparent;
  border-radius: 0;
  overflow: visible;
}
.logo .logo-mark::before,
.logo .logo-mark::after,
.logo .logo-mark > span {
  width: 28%;
  height: 28%;
  background: var(--emerald);
}
.logo .logo-mark::before { left: 0; }
.logo .logo-mark::after { right: 0; }

/* Footer logo variant: transparent bg, emerald-light dots */
.footer-logo .footer-logo-mark {
  width: 24px;
  height: 24px;
  background: transparent;
  border-radius: 0;
  overflow: visible;
}
.footer-logo .footer-logo-mark::before,
.footer-logo .footer-logo-mark::after,
.footer-logo .footer-logo-mark > span {
  width: 28%;
  height: 28%;
  background: var(--emerald-light);
}
.footer-logo .footer-logo-mark::before { left: 0; }
.footer-logo .footer-logo-mark::after { right: 0; }

/* Nav links */
.nav-links { display: flex; gap: 28px; }
.nav-link {
  font-size: 14px;
  color: var(--ink-soft);
  text-decoration: none;
  transition: color var(--duration-base);
}
.nav-link:hover { color: var(--ink); }
.nav-link.active { color: var(--ink); font-weight: 500; }

.nav-cta-row { display: flex; align-items: center; gap: var(--space-4); }
.nav-login {
  font-size: 14px;
  color: var(--ink-soft);
  text-decoration: none;
  transition: color var(--duration-base);
}
.nav-login:hover { color: var(--ink); }

/* Hamburger */
.nav-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 36px;
  height: 36px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  border-radius: var(--radius-sm);
}
.nav-hamburger-bar {
  display: block;
  width: 20px;
  height: 1.5px;
  background: var(--ink);
  border-radius: 2px;
  transition: all 0.25s var(--ease-default);
  transform-origin: center;
}
.nav-hamburger.is-open .nav-hamburger-bar:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-hamburger.is-open .nav-hamburger-bar:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-hamburger.is-open .nav-hamburger-bar:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* Mobile menu */
.mobile-menu {
  display: none;
  flex-direction: column;
  gap: 2px;
  padding: 12px 20px 20px;
  border-top: 1px solid var(--ink-line);
  background: rgba(250,250,250,0.97);
  backdrop-filter: blur(12px);
}
.mobile-menu.is-open { display: flex; }
.mobile-menu-link {
  font-size: 16px;
  font-weight: 500;
  color: var(--ink);
  text-decoration: none;
  padding: 12px 4px;
  border-bottom: 1px solid var(--ink-line);
  transition: color var(--duration-base);
}
.mobile-menu-link:last-of-type { border-bottom: none; }
.mobile-menu-link:hover { color: var(--emerald); }

/* --------------------------------------------------------------------------
   BUTTONS
   -------------------------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--sans);
  border: none;
  cursor: pointer;
  transition: all var(--duration-base) var(--ease-default);
  text-decoration: none;
  font-weight: 500;
  border-radius: var(--radius-pill);
}
.btn-sm { padding: 9px 18px; font-size: 13px; }
.btn-lg { padding: var(--space-4) 28px; font-size: 15px; }
.btn-emerald { background: var(--emerald); color: white; }
.btn-emerald:hover { background: var(--emerald-deep); transform: translateY(-1px); }
.btn-secondary { background: var(--surface); color: var(--ink); border: 1px solid var(--ink-stroke); }
.btn-secondary:hover { background: var(--bg-warm); border-color: var(--ink); }

/* --------------------------------------------------------------------------
   FOOTER
   -------------------------------------------------------------------------- */
.footer-dark {
  background: #0A0A0A;
  color: rgba(255,255,255,0.65);
  padding: 80px 0 40px;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.footer-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--space-6);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: var(--space-8);
  padding-bottom: 56px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  margin-bottom: 28px;
}

.footer-brand { display: flex; flex-direction: column; gap: 20px; }
.footer-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 17px;
  font-weight: 600;
  color: white;
  letter-spacing: -0.02em;
  text-decoration: none;
}
.footer-logo-mark {
  position: relative;
  width: 28px; height: 28px;
  background: var(--emerald);
  color: transparent;
  display: flex; align-items: center; justify-content: center;
  font-size: 0; font-weight: 600;
  border-radius: 8px;
  overflow: hidden;
}
.footer-tagline {
  font-size: 14px;
  line-height: 1.55;
  color: rgba(255,255,255,0.5);
  max-width: 300px;
}
.footer-social {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-2);
}
.footer-social a {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.55);
  transition: all var(--duration-base);
  text-decoration: none;
}
.footer-social a:hover {
  background: var(--emerald);
  color: white;
  border-color: var(--emerald);
}
.footer-social svg { width: 14px; height: 14px; }

.footer-col h5 {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.42);
  margin-bottom: 22px;
  font-weight: 400;
}
.footer-col ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.footer-col li a {
  font-size: 14px;
  color: rgba(255,255,255,0.7);
  text-decoration: none;
  transition: color var(--duration-base);
}
.footer-col li a:hover { color: white; }

.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: var(--space-5);
  font-size: 11px;
  color: rgba(255,255,255,0.38);
  font-family: var(--mono);
  letter-spacing: 0.06em;
}
.footer-bottom-left { display: flex; gap: var(--space-5); flex-wrap: wrap; }
.footer-language { display: flex; gap: var(--space-1); }
.footer-language a {
  color: rgba(255,255,255,0.4);
  text-decoration: none;
  padding: var(--space-1) 10px;
  border-radius: 6px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: all var(--duration-base);
}
.footer-language a.active {
  color: white;
  background: rgba(255,255,255,0.08);
}
.footer-language a:hover:not(.active) { color: rgba(255,255,255,0.75); }

/* --------------------------------------------------------------------------
   RESPONSIVE — nav + footer only
   (Page-specific breakpoints live in each page's own <style> block)
   -------------------------------------------------------------------------- */
@media (max-width: 980px) {
  .nav-links { display: none; }
  .nav-hamburger { display: flex; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
  .footer-bottom { flex-direction: column; gap: var(--space-4); align-items: flex-start; }
}

@media (max-width: 640px) {
  .footer-inner { padding: 0 var(--space-5); }
}

/* --------------------------------------------------------------------------
   KLARO — Salenza-stijl cookie banner
   -------------------------------------------------------------------------- */

/* Logo binnen Klaro banner — kleur via CSS zodat dark mode mee schakelt */
.klaro .kl-brand .logo-mark {
  background: var(--emerald) !important;
}
.klaro .kl-logo-text {
  color: #09090b !important;
}

/* Banner container — volledige breedte balk onderaan */
.klaro .cookie-notice,
.klaro .cookie-notice:not(.cookie-modal-notice) {
  font-family: var(--sans) !important;
  background: #ffffff !important;
  border-top: 1px solid #e4e4e7 !important;
  border-radius: 0 !important;
  box-shadow: 0 -2px 20px rgba(0,0,0,0.07) !important;
  padding: 0 !important;
  margin: 0 !important;
  position: fixed !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  top: auto !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  height: auto !important;
  z-index: 9000 !important;
  transform: none !important;
}

/* Binnenste rij: logo | tekst | knoppen */
.klaro .cn-body {
  display: flex !important;
  align-items: center !important;
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 14px 32px !important;
  gap: 0 !important;
}

/* Logo links */
.klaro .kl-brand {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-shrink: 0 !important;
  padding-right: 24px !important;
  margin-right: 24px !important;
  border-right: 1px solid #e4e4e7 !important;
}
.klaro .kl-logo-text {
  font-size: 15px !important;
  font-weight: 600 !important;
  letter-spacing: -0.02em !important;
  color: #09090b !important;
}

/* Beschrijving tekst — neemt beschikbare ruimte */
.klaro .cn-body > p {
  flex: 1 !important;
  margin: 0 24px 0 0 !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
  color: #52525b !important;
}
.klaro .cn-body > p span { color: #52525b !important; }

/* Rechts: meer info + knoppen */
.klaro .cn-ok {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-shrink: 0 !important;
}

/* Meer info link */
.klaro .cn-learn-more {
  font-size: 13px !important;
  color: #a1a1aa !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  margin-right: 8px !important;
  transition: color 0.15s !important;
}
.klaro .cn-learn-more:hover { color: #09090b !important; }

/* Knoppen */
.klaro .cn-buttons {
  display: flex !important;
  gap: 8px !important;
  align-items: center !important;
}
.klaro .cm-btn-danger {
  background: #27272a !important;
  border: 1px solid #27272a !important;
  color: #ffffff !important;
  font-family: var(--sans) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  padding: 8px 16px !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  transition: all 0.15s !important;
}
.klaro .cm-btn-danger:hover {
  background: #09090b !important;
  border-color: #09090b !important;
}
.klaro .cm-btn-success {
  background: #10B981 !important;
  color: #fff !important;
  border: none !important;
  font-family: var(--sans) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  padding: 8px 16px !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  transition: background 0.15s !important;
}
.klaro .cm-btn-success:hover { background: #059669 !important; }

/* Details tonen link — prominenter */
.klaro .cn-learn-more {
  font-size: 13px !important;
  color: #10B981 !important;
  text-decoration: underline !important;
  text-underline-offset: 2px !important;
  white-space: nowrap !important;
  margin-right: 16px !important;
  transition: color 0.15s !important;
  font-weight: 500 !important;
}
.klaro .cn-learn-more:hover { color: #059669 !important; }

/* Modal container — flexbox parent voor perfecte centering */
.klaro .cookie-modal {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 9100 !important;
  padding: 20px !important;
  box-sizing: border-box !important;
}

/* Overlay achtergrond — absoluut binnen container */
.klaro .cm-bg {
  background: rgba(0,0,0,0.4) !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  height: 100% !important;
  z-index: 0 !important;
}

/* Modal venster — gecentreerd via flexbox parent, geen transforms */
.klaro .cm-modal {
  font-family: var(--sans) !important;
  background: #ffffff !important;
  border-radius: 12px !important;
  box-shadow: 0 24px 64px rgba(0,0,0,0.14) !important;
  border: 1px solid #e4e4e7 !important;
  max-width: 600px !important;
  width: calc(100% - 40px) !important;
  max-height: calc(100vh - 40px) !important;
  padding: 0 !important;
  overflow: hidden !important;
  color: #09090b !important;
  position: relative !important;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
  margin: 0 !important;
  transform: none !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Modal header */
.klaro .cm-modal .cm-header {
  background: #ffffff !important;
  padding: 24px 28px 20px !important;
  border-bottom: 1px solid #e4e4e7 !important;
}
.klaro .cm-modal .cm-header .title {
  font-size: 18px !important;
  font-weight: 600 !important;
  letter-spacing: -0.02em !important;
  color: #09090b !important;
  margin: 0 0 8px !important;
}
.klaro .cm-modal .cm-header p {
  font-size: 13px !important;
  color: #71717a !important;
  line-height: 1.6 !important;
  margin: 0 !important;
}
.klaro .cm-modal .cm-header p a {
  color: #10B981 !important;
}

/* Sluit-knop */
.klaro .cm-modal .hide {
  color: #71717a !important;
  background: transparent !important;
  font-size: 20px !important;
}

/* Modal body */
.klaro .cm-modal .cm-body {
  background: #ffffff !important;
  padding: 0 !important;
  max-height: 55vh !important;
  overflow-y: auto !important;
}

/* Cookie categorie items */
.klaro .cm-modal .cm-purpose {
  background: #ffffff !important;
  padding: 20px 28px !important;
  border-bottom: 1px solid #f4f4f5 !important;
  list-style: none !important;
}
.klaro .cm-modal .cm-purpose:last-child {
  border-bottom: none !important;
}

/* Verberg de echte checkbox maar behoud pointer-events zodat label-click werkt */
.klaro .cm-modal .cm-list-input {
  position: absolute !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
}

/* Label-rij: titel links, toggle rechts */
.klaro .cm-modal .cm-list-label {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  cursor: pointer !important;
  margin-bottom: 8px !important;
}
.klaro .cm-modal .cm-list-title {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #09090b !important;
  flex: 1 !important;
}

/* Toggle switch — uit absolute halen zodat flex-layout werkt */
.klaro .cm-modal .cm-switch {
  position: relative !important;
  flex-shrink: 0 !important;
  width: 44px !important;
  height: 24px !important;
  display: inline-block !important;
}

/* Slider pill — vul de switch container */
.klaro .cm-modal .cm-switch .slider {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 44px !important;
  height: 24px !important;
  background: #d4d4d8 !important;
  border-radius: 999px !important;
  cursor: pointer !important;
  transition: background 0.2s ease !important;
  box-shadow: none !important;
}

/* Witte knop binnen de slider */
.klaro .cm-modal .cm-switch .slider::before {
  content: '' !important;
  position: absolute !important;
  height: 18px !important;
  width: 18px !important;
  left: 3px !important;
  bottom: 3px !important;
  top: auto !important;
  background: #ffffff !important;
  border-radius: 50% !important;
  transition: transform 0.2s ease !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2) !important;
  transform: none !important;
}

/* AAN-stand: groen + knop naar rechts */
.klaro .cm-modal .cm-list-input:checked + .cm-list-label .slider {
  background: #10B981 !important;
}
.klaro .cm-modal .cm-list-input:checked + .cm-list-label .slider::before {
  transform: translateX(20px) !important;
}

/* Verplicht (altijd aan, niet uitschakelbaar) */
.klaro .cm-modal .cm-list-input.required + .cm-list-label .slider,
.klaro .cm-modal .cm-list-input[disabled] + .cm-list-label .slider {
  background: #10B981 !important;
  opacity: 1 !important;
  cursor: not-allowed !important;
}
.klaro .cm-modal .cm-list-input.required + .cm-list-label .slider::before,
.klaro .cm-modal .cm-list-input[disabled] + .cm-list-label .slider::before {
  transform: translateX(20px) !important;
}

/* Beschrijving */
.klaro .cm-modal .cm-list-description {
  font-size: 13px !important;
  color: #71717a !important;
  line-height: 1.55 !important;
  margin: 0 !important;
}
.klaro .cm-modal .cm-list-description span {
  color: #71717a !important;
}

/* Sub-services (bijv. Google Analytics) */
.klaro .cm-modal .cm-services {
  background: #f9f9fb !important;
  border: 1px solid #e4e4e7 !important;
  border-radius: 10px !important;
  margin-top: 14px !important;
  padding: 0 !important;
  overflow: hidden !important;
}
.klaro .cm-modal .cm-caret {
  padding: 10px 14px !important;
  border-bottom: 1px solid transparent !important;
  transition: border-color 0.15s !important;
}
.klaro .cm-modal .cm-services:has(.cm-content.expanded) .cm-caret {
  border-bottom-color: #e4e4e7 !important;
}
.klaro .cm-modal .cm-caret a {
  font-size: 12px !important;
  color: #71717a !important;
  text-decoration: none !important;
  font-weight: 500 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
}
.klaro .cm-modal .cm-caret a:hover { color: #09090b !important; }

/* Lijst van services */
.klaro .cm-modal .cm-content {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.klaro .cm-modal .cm-service {
  padding: 12px 14px !important;
  list-style: none !important;
  border-top: 1px solid #efeff2 !important;
}
.klaro .cm-modal .cm-service:first-child { border-top: none !important; }

/* Service header: titel + (altijd nodig) + toggle */
.klaro .cm-modal .cm-service .cm-list-label {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 6px !important;
}
.klaro .cm-modal .cm-service .cm-list-title {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #27272a !important;
  flex: 1 !important;
}
.klaro .cm-modal .cm-required {
  font-size: 11px !important;
  color: #a1a1aa !important;
  font-weight: 400 !important;
  white-space: nowrap !important;
}

/* Beschrijving + verwerkingsdoel */
.klaro .cm-modal .cm-service .cm-list-description {
  font-size: 12px !important;
  color: #71717a !important;
  line-height: 1.55 !important;
  margin: 0 0 6px 0 !important;
}
.klaro .cm-modal .cm-service .cm-list-description span {
  color: #71717a !important;
}
.klaro .cm-modal .cm-service .purposes {
  font-size: 11px !important;
  color: #a1a1aa !important;
  margin: 0 !important;
  font-family: var(--mono) !important;
  letter-spacing: 0.02em !important;
}

.klaro .cm-modal .cm-purposes {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Modal footer */
.klaro .cm-modal .cm-footer {
  background: #fafafa !important;
  border-top: 1px solid #e4e4e7 !important;
  padding: 14px 28px !important;
}
.klaro .cm-modal .cm-footer-buttons {
  display: flex !important;
  gap: 8px !important;
  justify-content: flex-end !important;
  flex-wrap: wrap !important;
}
.klaro .cm-modal .cm-footer .cm-btn {
  font-family: var(--sans) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  padding: 8px 16px !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  border: none !important;
}
/* Weigeren — solid grey (gelijkwaardig aan accepteren qua weight) */
.klaro .cm-modal .cm-btn-decline {
  background: #27272a !important;
  border: 1px solid #27272a !important;
  color: #ffffff !important;
}
.klaro .cm-modal .cm-btn-decline:hover {
  background: #09090b !important;
  border-color: #09090b !important;
}

/* Selectie opslaan — outline (secundair) */
.klaro .cm-modal .cm-btn-accept {
  background: transparent !important;
  border: 1px solid #e4e4e7 !important;
  color: #27272a !important;
}
.klaro .cm-modal .cm-btn-accept:hover {
  border-color: #a1a1aa !important;
  background: #fafafa !important;
}

/* Alle cookies accepteren — solid groen (primaire CTA) */
.klaro .cm-modal .cm-btn-accept-all {
  background: #10B981 !important;
  border: 1px solid #10B981 !important;
  color: #ffffff !important;
}
.klaro .cm-modal .cm-btn-accept-all:hover {
  background: #059669 !important;
  border-color: #059669 !important;
}

/* "Gerealiseerd met Klaro!" verbergen */
.klaro .cm-powered-by {
  display: none !important;
}

/* --------------------------------------------------------------------------
   DARK MODE — echte donkere variant van Klaro & FAB
   Activeert automatisch op basis van system preference.
   Palette afgestemd op site dark sections (.footer-dark, .proof-dark).
   -------------------------------------------------------------------------- */
@media (prefers-color-scheme: dark) {
  /* === BANNER === */
  .klaro .cookie-notice,
  .klaro .cookie-notice:not(.cookie-modal-notice) {
    background: #0E0E0C !important;
    border-top-color: rgba(255, 255, 255, 0.08) !important;
    color: #fafafa !important;
    box-shadow: 0 -2px 24px rgba(0, 0, 0, 0.4) !important;
  }

  /* Logo */
  .klaro .kl-brand {
    border-right-color: rgba(255, 255, 255, 0.1) !important;
    border-bottom-color: rgba(255, 255, 255, 0.1) !important;
  }
  .klaro .kl-brand .logo-mark { background: #10B981 !important; }
  .klaro .kl-logo-text { color: #fafafa !important; }

  /* Beschrijvingstekst */
  .klaro .cn-body > p,
  .klaro .cn-body > p span {
    color: rgba(255, 255, 255, 0.62) !important;
  }

  /* Details tonen link */
  .klaro .cn-learn-more { color: #10B981 !important; }
  .klaro .cn-learn-more:hover { color: #34D399 !important; }

  /* Banner buttons — Weigeren = donker grijs, Accept = groen */
  .klaro .cm-btn-danger {
    background: rgba(255, 255, 255, 0.08) !important;
    border-color: rgba(255, 255, 255, 0.14) !important;
    color: #fafafa !important;
  }
  .klaro .cm-btn-danger:hover {
    background: rgba(255, 255, 255, 0.14) !important;
    border-color: rgba(255, 255, 255, 0.24) !important;
    color: #ffffff !important;
  }
  .klaro .cm-btn-success {
    background: #10B981 !important;
    color: #0A0A0A !important;
  }
  .klaro .cm-btn-success:hover { background: #34D399 !important; }

  /* === MODAL === */
  .klaro .cm-bg { background: rgba(0, 0, 0, 0.65) !important; }
  .klaro .cm-modal {
    background: #0E0E0C !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
    color: #fafafa !important;
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5) !important;
  }

  /* Modal header */
  .klaro .cm-modal .cm-header {
    background: #0E0E0C !important;
    border-bottom-color: rgba(255, 255, 255, 0.08) !important;
  }
  .klaro .cm-modal .cm-header .title { color: #fafafa !important; }
  .klaro .cm-modal .cm-header p { color: rgba(255, 255, 255, 0.55) !important; }
  .klaro .cm-modal .cm-header p a { color: #10B981 !important; }
  .klaro .cm-modal .hide { color: rgba(255, 255, 255, 0.55) !important; }
  .klaro .cm-modal .hide:hover { color: #fafafa !important; }

  /* Modal body + purpose items */
  .klaro .cm-modal .cm-body { background: #0E0E0C !important; }
  .klaro .cm-modal .cm-purpose {
    background: #0E0E0C !important;
    border-bottom-color: rgba(255, 255, 255, 0.06) !important;
  }
  .klaro .cm-modal .cm-list-title { color: #fafafa !important; }
  .klaro .cm-modal .cm-list-description,
  .klaro .cm-modal .cm-list-description span {
    color: rgba(255, 255, 255, 0.55) !important;
  }
  .klaro .cm-modal .cm-required { color: rgba(255, 255, 255, 0.4) !important; }

  /* Services dropdown — iets lichter dan modal bg voor diepte */
  .klaro .cm-modal .cm-services {
    background: #18181b !important;
    border-color: rgba(255, 255, 255, 0.06) !important;
  }
  .klaro .cm-modal .cm-services:has(.cm-content.expanded) .cm-caret {
    border-bottom-color: rgba(255, 255, 255, 0.06) !important;
  }
  .klaro .cm-modal .cm-caret a { color: rgba(255, 255, 255, 0.55) !important; }
  .klaro .cm-modal .cm-caret a:hover { color: #fafafa !important; }
  .klaro .cm-modal .cm-service {
    border-top-color: rgba(255, 255, 255, 0.06) !important;
  }
  .klaro .cm-modal .cm-service .cm-list-title { color: #fafafa !important; }
  .klaro .cm-modal .cm-service .cm-list-description,
  .klaro .cm-modal .cm-service .cm-list-description span {
    color: rgba(255, 255, 255, 0.5) !important;
  }
  .klaro .cm-modal .cm-service .purposes {
    color: rgba(255, 255, 255, 0.35) !important;
  }

  /* Toggle — donker uit-staat, helder groen aan */
  .klaro .cm-modal .cm-switch .slider {
    background: rgba(255, 255, 255, 0.15) !important;
  }
  .klaro .cm-modal .cm-switch .slider::before {
    background: #fafafa !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.4) !important;
  }
  .klaro .cm-modal .cm-list-input:checked + .cm-list-label .slider,
  .klaro .cm-modal .cm-list-input.required + .cm-list-label .slider {
    background: #10B981 !important;
  }

  /* Modal footer */
  .klaro .cm-modal .cm-footer {
    background: #18181b !important;
    border-top-color: rgba(255, 255, 255, 0.08) !important;
  }
  .klaro .cm-modal .cm-btn-decline {
    background: rgba(255, 255, 255, 0.08) !important;
    border: 1px solid rgba(255, 255, 255, 0.14) !important;
    color: #fafafa !important;
  }
  .klaro .cm-modal .cm-btn-decline:hover {
    background: rgba(255, 255, 255, 0.14) !important;
    border-color: rgba(255, 255, 255, 0.24) !important;
    color: #ffffff !important;
  }
  .klaro .cm-modal .cm-btn-accept {
    background: transparent !important;
    border: 1px solid rgba(255, 255, 255, 0.14) !important;
    color: rgba(255, 255, 255, 0.85) !important;
  }
  .klaro .cm-modal .cm-btn-accept:hover {
    border-color: rgba(255, 255, 255, 0.32) !important;
    background: rgba(255, 255, 255, 0.04) !important;
    color: #ffffff !important;
  }
  .klaro .cm-modal .cm-btn-accept-all {
    background: #10B981 !important;
    border-color: #10B981 !important;
    color: #0A0A0A !important;
  }
  .klaro .cm-modal .cm-btn-accept-all:hover {
    background: #34D399 !important;
    border-color: #34D399 !important;
  }

  /* === FAB === */
  .sln-cookie-fab {
    background: #18181b !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
    color: #10B981 !important;
    box-shadow: 0 2px 16px rgba(0, 0, 0, 0.4) !important;
  }
  .sln-cookie-fab:hover {
    border-color: #10B981 !important;
    box-shadow: 0 8px 28px rgba(16, 185, 129, 0.25) !important;
  }
  .sln-cookie-fab:focus-visible {
    outline-color: #10B981 !important;
  }
}

/* Mobiel */
@media (max-width: 768px) {
  /* Banner */
  .klaro .cn-body {
    flex-wrap: wrap !important;
    padding: 14px 20px !important;
    gap: 10px !important;
  }
  .klaro .kl-brand {
    border-right: none !important;
    padding-right: 0 !important;
    margin-right: 0 !important;
    padding-bottom: 10px !important;
    border-bottom: 1px solid #e4e4e7 !important;
    width: 100% !important;
  }
  .klaro .cn-body > p {
    flex: none !important;
    width: 100% !important;
    margin: 0 !important;
  }
  .klaro .cn-ok {
    width: 100% !important;
    justify-content: space-between !important;
    align-items: center !important;
  }
  .klaro .cn-learn-more {
    margin-right: 0 !important;
    flex-shrink: 0 !important;
  }
  .klaro .cn-buttons {
    flex-shrink: 0 !important;
  }

  /* Modal — laat flexbox parent centreren, alleen padding aanpassen */
  .klaro .cookie-modal {
    padding: 16px !important;
  }
  .klaro .cm-modal {
    width: 100% !important;
    max-width: none !important;
    left: auto !important;
    right: auto !important;
  }

  /* Modal padding verkleinen op mobiel */
  .klaro .cm-modal .cm-header {
    padding: 20px 20px 16px !important;
  }
  .klaro .cm-modal .cm-purpose {
    padding: 16px 20px !important;
  }
  .klaro .cm-modal .cm-footer {
    padding: 12px 20px !important;
  }
  .klaro .cm-modal .cm-footer-buttons {
    flex-direction: column !important;
    gap: 8px !important;
  }
  .klaro .cm-modal .cm-footer .cm-btn {
    width: 100% !important;
    text-align: center !important;
    justify-content: center !important;
  }
}

/* --------------------------------------------------------------------------
   COOKIE FAB — persistent cookie-instellingen knop (linksonder)
   -------------------------------------------------------------------------- */
.sln-cookie-fab {
  position: fixed;
  bottom: 20px;
  left: 20px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #ffffff;
  border: 1px solid #e4e4e7;
  color: var(--emerald);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
  transition: transform 0.2s var(--ease-default),
              box-shadow 0.2s var(--ease-default),
              border-color 0.2s var(--ease-default),
              opacity 0.25s var(--ease-default);
  z-index: 8000;
}
.sln-cookie-fab svg {
  width: 20px;
  height: 20px;
  display: block;
}
.sln-cookie-fab:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  border-color: var(--emerald);
}
.sln-cookie-fab:focus-visible {
  outline: 2px solid var(--emerald);
  outline-offset: 2px;
}
.sln-cookie-fab--hidden {
  opacity: 0;
  transform: translateY(16px);
  pointer-events: none;
}

@media (max-width: 768px) {
  .sln-cookie-fab {
    bottom: 16px;
    left: 16px;
    width: 40px;
    height: 40px;
  }
  .sln-cookie-fab svg { width: 18px; height: 18px; }
}

@media (prefers-reduced-motion: reduce) {
  .sln-cookie-fab { transition: opacity 0.2s; }
  .sln-cookie-fab:hover { transform: none; }
}

/* --------------------------------------------------------------------------
   BACK LINK — shared across all subpages
   -------------------------------------------------------------------------- */
.back-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-faded);
  text-decoration: none;
  margin-bottom: 28px;
  transition: color var(--duration-base);
}
.back-link:hover { color: var(--ink); }
.back-link svg { width: 14px; height: 14px; flex-shrink: 0; }
