/*
 * Sansa Platform — Designsysteem
 * Twinq-geïnspireerde shell · Sansa Real Estate huisstijl
 * Mobiel-first · WCAG-AA-basis
 */

/* =========================================================================
   CSS-variabelen (design tokens — Sansa Real Estate huisstijl)
   ========================================================================= */
:root {
  /* Kleurpalet — Sansa-groen palet */
  --kleur-primair:       #465D53;   /* donkere salie — header, knoppen, nav */
  --kleur-primair-donker: #374a42;  /* hover/actief */
  --kleur-primair-licht: #E6F2E8;   /* kaart-accenten, highlights, hover */
  --kleur-primair-tint:  #f0f7f1;   /* subtiele achtergrond */
  --kleur-secundair:     #7E8E87;   /* groen-grijs — secondary tekst, iconen */

  /* Neutrale kleuren */
  --kleur-achtergrond:   #F7F7F8;   /* pagina-achtergrond */
  --kleur-oppervlak:     #ffffff;   /* kaarten, header */
  --kleur-rand:          #e5e7eb;
  --kleur-rand-sterk:    #d1d5db;

  /* Tekst */
  --kleur-tekst:         #1E1E1E;
  --kleur-tekst-zacht:   #6b7280;
  --kleur-tekst-zwakst:  #9ca3af;
  --kleur-tekst-op-primair: #ffffff;

  /* Betekenisvolle statuskleuren */
  --kleur-succes:           #16a34a;
  --kleur-succes-licht:     #dcfce7;
  --kleur-waarschuwing:     #d97706;
  --kleur-waarschuwing-licht: #fef3c7;
  --kleur-fout:             #dc2626;
  --kleur-fout-licht:       #fee2e2;
  --kleur-info:             #0891b2;
  --kleur-info-licht:       #cffafe;

  /* Typografie */
  --lettertype: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;
  --lettertype-mono: "JetBrains Mono", "Fira Code", monospace;
  --lettergrootte-xs:   0.75rem;
  --lettergrootte-sm:   0.875rem;
  --lettergrootte-basis: 1rem;
  --lettergrootte-lg:   1.125rem;
  --lettergrootte-xl:   1.25rem;
  --lettergrootte-2xl:  1.5rem;
  --lettergrootte-3xl:  1.875rem;

  /* Spatie-schaal */
  --ruimte-1:  0.25rem;
  --ruimte-2:  0.5rem;
  --ruimte-3:  0.75rem;
  --ruimte-4:  1rem;
  --ruimte-5:  1.25rem;
  --ruimte-6:  1.5rem;
  --ruimte-8:  2rem;
  --ruimte-10: 2.5rem;
  --ruimte-12: 3rem;
  --ruimte-16: 4rem;

  /* Randen */
  --rand-radius:        0.375rem;
  --rand-radius-lg:     0.5rem;
  --rand-radius-xl:     0.75rem;
  --rand-radius-volledig: 9999px;

  /* Schaduwen */
  --schaduw-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --schaduw:    0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
  --schaduw-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --schaduw-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);

  /* Overgangen */
  --overgang: all 0.15s ease;

  /* Layout */
  --topbalk-hoogte:       64px;
  --context-balk-hoogte:  40px;
  --inhoud-max-breedte:   1280px;
}

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

html {
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  font-family: var(--lettertype);
  font-size: var(--lettergrootte-basis);
  color: var(--kleur-tekst);
  background-color: var(--kleur-achtergrond);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

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

input, button, textarea, select {
  font: inherit;
}

p, h1, h2, h3, h4, h5, h6 {
  overflow-wrap: break-word;
}

a {
  color: var(--kleur-primair);
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

/* =========================================================================
   Twinq App-schil: topbalk + context-balk + inhoud
   ========================================================================= */

/* --- Topbalk (wit, sticky, 64px) ---------------------------------------- */
.topbalk {
  position: sticky;
  top: 0;
  z-index: 100;
  height: var(--topbalk-hoogte);
  background-color: var(--kleur-oppervlak);
  border-bottom: 1px solid var(--kleur-rand);
  display: flex;
  align-items: center;
  padding: 0 var(--ruimte-6);
  gap: var(--ruimte-4);
}

/* Logo-pill */
.topbalk-logo {
  display: flex;
  align-items: center;
  gap: var(--ruimte-2);
  text-decoration: none;
  flex-shrink: 0;
}

.topbalk-logo-naam {
  font-size: var(--lettergrootte-xl);
  font-weight: 700;
  color: var(--kleur-primair);
  letter-spacing: -0.025em;
}

.topbalk-logo-subtitel {
  font-size: var(--lettergrootte-xs);
  color: var(--kleur-tekst-zacht);
  line-height: 1;
}

/* Logo-icoon */
.topbalk-logo-icoon {
  width: 32px;
  height: 32px;
  background-color: var(--kleur-primair);
  border-radius: var(--rand-radius);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* Horizontale navigatie (desktop) */
.hoofd-nav {
  flex: 1;
  display: flex;
  align-items: center;
  gap: var(--ruimte-1);
  margin-left: var(--ruimte-6);
}

/* Nav-sectie met mega-menu */
.nav-sectie {
  position: relative;
}

.nav-sectie-knop {
  display: flex;
  align-items: center;
  gap: var(--ruimte-1);
  padding: var(--ruimte-2) var(--ruimte-3);
  border-radius: var(--rand-radius);
  font-size: var(--lettergrootte-sm);
  font-weight: 500;
  color: var(--kleur-tekst-zacht);
  background: none;
  border: none;
  cursor: pointer;
  transition: var(--overgang);
  white-space: nowrap;
}

.nav-sectie-knop:hover,
.nav-sectie:hover .nav-sectie-knop,
.nav-sectie.actief .nav-sectie-knop {
  background-color: var(--kleur-primair-licht);
  color: var(--kleur-primair);
}

.nav-sectie-knop .pijl {
  width: 14px;
  height: 14px;
  transition: transform 0.15s ease;
}

.nav-sectie:hover .nav-sectie-knop .pijl,
.nav-sectie.open .nav-sectie-knop .pijl {
  transform: rotate(180deg);
}

/* Directe nav-link (geen dropdown) */
.nav-link {
  display: flex;
  align-items: center;
  gap: var(--ruimte-1);
  padding: var(--ruimte-2) var(--ruimte-3);
  border-radius: var(--rand-radius);
  font-size: var(--lettergrootte-sm);
  font-weight: 500;
  color: var(--kleur-tekst-zacht);
  text-decoration: none;
  transition: var(--overgang);
  white-space: nowrap;
}

.nav-link:hover,
.nav-link.actief {
  background-color: var(--kleur-primair-licht);
  color: var(--kleur-primair);
  text-decoration: none;
}

/* Mega-menu dropdown */
.mega-menu {
  display: none;
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  background-color: var(--kleur-oppervlak);
  border: 1px solid var(--kleur-rand);
  border-radius: var(--rand-radius-xl);
  box-shadow: var(--schaduw-lg);
  padding: var(--ruimte-4);
  min-width: 200px;
  z-index: 200;
}

.nav-sectie:hover .mega-menu,
.nav-sectie.open .mega-menu {
  display: block;
}

.mega-menu-item {
  display: flex;
  align-items: center;
  gap: var(--ruimte-3);
  padding: var(--ruimte-2) var(--ruimte-3);
  border-radius: var(--rand-radius);
  font-size: var(--lettergrootte-sm);
  color: var(--kleur-tekst);
  text-decoration: none;
  transition: var(--overgang);
  white-space: nowrap;
}

.mega-menu-item:hover {
  background-color: var(--kleur-primair-licht);
  color: var(--kleur-primair);
  text-decoration: none;
}

.mega-menu-item .icoon {
  width: 16px;
  height: 16px;
  color: var(--kleur-tekst-zacht);
  flex-shrink: 0;
}

.mega-menu-scheidingslijn {
  height: 1px;
  background-color: var(--kleur-rand);
  margin: var(--ruimte-2) 0;
}

.mega-menu-label {
  font-size: var(--lettergrootte-xs);
  font-weight: 600;
  color: var(--kleur-tekst-zwakst);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: var(--ruimte-2) var(--ruimte-3) var(--ruimte-1);
}

/* Rechterkant topbalk: avatar + hamburger */
.topbalk-rechts {
  display: flex;
  align-items: center;
  gap: var(--ruimte-3);
  margin-left: auto;
  flex-shrink: 0;
}

/* Avatar-dropdown */
.avatar-sectie {
  position: relative;
}

.avatar-knop {
  width: 36px;
  height: 36px;
  border-radius: var(--rand-radius-volledig);
  background-color: var(--kleur-primair);
  color: var(--kleur-tekst-op-primair);
  border: none;
  cursor: pointer;
  font-size: var(--lettergrootte-sm);
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--overgang);
}

.avatar-knop:hover {
  background-color: var(--kleur-primair-donker);
}

.account-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  background-color: var(--kleur-oppervlak);
  border: 1px solid var(--kleur-rand);
  border-radius: var(--rand-radius-xl);
  box-shadow: var(--schaduw-lg);
  padding: var(--ruimte-2);
  min-width: 200px;
  z-index: 200;
}

.avatar-sectie.open .account-dropdown {
  display: block;
}

.account-dropdown-kop {
  padding: var(--ruimte-3) var(--ruimte-3) var(--ruimte-2);
  border-bottom: 1px solid var(--kleur-rand);
  margin-bottom: var(--ruimte-2);
}

.account-dropdown-naam {
  font-size: var(--lettergrootte-sm);
  font-weight: 600;
  color: var(--kleur-tekst);
}

.account-dropdown-email {
  font-size: var(--lettergrootte-xs);
  color: var(--kleur-tekst-zacht);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 176px;
}

.account-dropdown-item {
  display: flex;
  align-items: center;
  gap: var(--ruimte-3);
  padding: var(--ruimte-2) var(--ruimte-3);
  border-radius: var(--rand-radius);
  font-size: var(--lettergrootte-sm);
  color: var(--kleur-tekst);
  text-decoration: none;
  transition: var(--overgang);
  cursor: pointer;
  background: none;
  border: none;
  width: 100%;
  text-align: left;
}

.account-dropdown-item:hover {
  background-color: var(--kleur-primair-licht);
  color: var(--kleur-primair);
  text-decoration: none;
}

.account-dropdown-item.gevaar:hover {
  background-color: var(--kleur-fout-licht);
  color: var(--kleur-fout);
}

/* Hamburger-knop (mobiel) */
.hamburger-knop {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--ruimte-2);
  color: var(--kleur-tekst);
  border-radius: var(--rand-radius);
}

.hamburger-knop:hover {
  background-color: var(--kleur-achtergrond);
}

/* --- Context-balk (Sansa-groen, 40px) ----------------------------------- */
.context-balk {
  height: var(--context-balk-hoogte);
  background-color: var(--kleur-primair);
  display: flex;
  align-items: center;
  padding: 0 var(--ruimte-6);
  gap: var(--ruimte-3);
}

.context-balk-terug {
  display: flex;
  align-items: center;
  gap: var(--ruimte-2);
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
  font-size: var(--lettergrootte-sm);
  transition: var(--overgang);
  padding: var(--ruimte-1) var(--ruimte-2);
  border-radius: var(--rand-radius);
}

.context-balk-terug:hover {
  color: #ffffff;
  background-color: rgba(255, 255, 255, 0.1);
  text-decoration: none;
}

.context-balk-naam {
  font-size: var(--lettergrootte-sm);
  font-weight: 600;
  color: #ffffff;
  letter-spacing: 0.01em;
}

.context-balk-scheider {
  color: rgba(255, 255, 255, 0.4);
  font-size: var(--lettergrootte-sm);
}

/* --- Pagina-inhoud ------------------------------------------------------- */
.pagina-inhoud {
  padding: var(--ruimte-8);
  max-width: var(--inhoud-max-breedte);
  width: 100%;
  margin: 0 auto;
}

/* --- Mobiel nav-overlay -------------------------------------------------- */
.nav-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  z-index: 90;
}

.nav-overlay.open {
  display: block;
}

/* Mobiel nav-lade */
.mobiel-nav {
  display: none;
  position: fixed;
  top: var(--topbalk-hoogte);
  left: 0;
  right: 0;
  background-color: var(--kleur-oppervlak);
  border-bottom: 1px solid var(--kleur-rand);
  box-shadow: var(--schaduw-lg);
  z-index: 95;
  padding: var(--ruimte-4);
  max-height: calc(100vh - var(--topbalk-hoogte));
  overflow-y: auto;
}

.mobiel-nav.open {
  display: block;
}

.mobiel-nav-sectie {
  margin-bottom: var(--ruimte-4);
}

.mobiel-nav-label {
  font-size: var(--lettergrootte-xs);
  font-weight: 600;
  color: var(--kleur-tekst-zwakst);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: var(--ruimte-1) var(--ruimte-2);
  margin-bottom: var(--ruimte-1);
}

.mobiel-nav-link {
  display: flex;
  align-items: center;
  gap: var(--ruimte-3);
  padding: var(--ruimte-3) var(--ruimte-3);
  border-radius: var(--rand-radius);
  font-size: var(--lettergrootte-basis);
  color: var(--kleur-tekst);
  text-decoration: none;
  transition: var(--overgang);
}

.mobiel-nav-link:hover,
.mobiel-nav-link.actief {
  background-color: var(--kleur-primair-licht);
  color: var(--kleur-primair);
  text-decoration: none;
}

/* =========================================================================
   Paginakop
   ========================================================================= */
.pagina-kop {
  margin-bottom: var(--ruimte-8);
}

.pagina-kop-rij {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--ruimte-4);
  flex-wrap: wrap;
}

.pagina-titel {
  font-size: var(--lettergrootte-2xl);
  font-weight: 700;
  color: var(--kleur-tekst);
  line-height: 1.3;
}

.pagina-ondertitel {
  margin-top: var(--ruimte-1);
  color: var(--kleur-tekst-zacht);
  font-size: var(--lettergrootte-sm);
}

/* =========================================================================
   Kaart
   ========================================================================= */
.kaart {
  background-color: var(--kleur-oppervlak);
  border: 1px solid var(--kleur-rand);
  border-radius: var(--rand-radius-xl);
  box-shadow: var(--schaduw-sm);
}

.kaart-kop {
  padding: var(--ruimte-5) var(--ruimte-6);
  border-bottom: 1px solid var(--kleur-rand);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--ruimte-4);
}

.kaart-titel {
  font-size: var(--lettergrootte-basis);
  font-weight: 600;
  color: var(--kleur-tekst);
}

.kaart-lichaam {
  padding: var(--ruimte-6);
}

.kaart-voet {
  padding: var(--ruimte-4) var(--ruimte-6);
  border-top: 1px solid var(--kleur-rand);
  background-color: var(--kleur-achtergrond);
  border-radius: 0 0 var(--rand-radius-xl) var(--rand-radius-xl);
}

/* Statistiekkaart */
.stat-kaart {
  background-color: var(--kleur-oppervlak);
  border: 1px solid var(--kleur-rand);
  border-radius: var(--rand-radius-xl);
  padding: var(--ruimte-6);
  box-shadow: var(--schaduw-sm);
}

.stat-kaart-label {
  font-size: var(--lettergrootte-sm);
  font-weight: 500;
  color: var(--kleur-tekst-zacht);
  margin-bottom: var(--ruimte-2);
}

.stat-kaart-waarde {
  font-size: var(--lettergrootte-3xl);
  font-weight: 700;
  color: var(--kleur-tekst);
  line-height: 1;
}

.stat-kaart-delta {
  margin-top: var(--ruimte-2);
  font-size: var(--lettergrootte-xs);
  color: var(--kleur-tekst-zacht);
}

.stat-kaart-icoon {
  width: 40px;
  height: 40px;
  border-radius: var(--rand-radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--ruimte-4);
}

.stat-kaart-icoon.groen  { background-color: var(--kleur-primair-licht); color: var(--kleur-primair); }
.stat-kaart-icoon.blauw  { background-color: #dbeafe; color: #1e40af; }
.stat-kaart-icoon.oranje { background-color: var(--kleur-waarschuwing-licht); color: var(--kleur-waarschuwing); }
.stat-kaart-icoon.rood   { background-color: var(--kleur-fout-licht); color: var(--kleur-fout); }

/* =========================================================================
   Raster
   ========================================================================= */
.raster {
  display: grid;
  gap: var(--ruimte-6);
}

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

/* Tegel-raster (documenten) */
.tegel-raster {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--ruimte-4);
}

/* =========================================================================
   Knoppen
   ========================================================================= */
.knop {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--ruimte-2);
  padding: var(--ruimte-2) var(--ruimte-4);
  border-radius: var(--rand-radius);
  font-size: var(--lettergrootte-sm);
  font-weight: 500;
  cursor: pointer;
  border: 1px solid transparent;
  transition: var(--overgang);
  text-decoration: none;
  white-space: nowrap;
  line-height: 1.5;
  user-select: none;
}

.knop:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.knop:focus-visible {
  outline: 2px solid var(--kleur-primair);
  outline-offset: 2px;
}

/* Primair */
.knop-primair {
  background-color: var(--kleur-primair);
  color: var(--kleur-tekst-op-primair);
  border-color: var(--kleur-primair);
}

.knop-primair:hover:not(:disabled) {
  background-color: var(--kleur-primair-donker);
  border-color: var(--kleur-primair-donker);
  text-decoration: none;
  color: var(--kleur-tekst-op-primair);
}

/* Secundair */
.knop-secundair {
  background-color: var(--kleur-oppervlak);
  color: var(--kleur-tekst);
  border-color: var(--kleur-rand-sterk);
}

.knop-secundair:hover:not(:disabled) {
  background-color: var(--kleur-achtergrond);
  text-decoration: none;
  color: var(--kleur-tekst);
}

/* Gevaar */
.knop-gevaar {
  background-color: var(--kleur-fout);
  color: var(--kleur-tekst-op-primair);
  border-color: var(--kleur-fout);
}

.knop-gevaar:hover:not(:disabled) {
  background-color: #b91c1c;
  border-color: #b91c1c;
  text-decoration: none;
  color: var(--kleur-tekst-op-primair);
}

/* Spookknop */
.knop-spook {
  background-color: transparent;
  color: var(--kleur-tekst-zacht);
  border-color: transparent;
}

.knop-spook:hover:not(:disabled) {
  background-color: var(--kleur-achtergrond);
  color: var(--kleur-tekst);
  text-decoration: none;
}

/* Knopgroottes */
.knop-sm {
  padding: var(--ruimte-1) var(--ruimte-3);
  font-size: var(--lettergrootte-xs);
}

.knop-lg {
  padding: var(--ruimte-3) var(--ruimte-6);
  font-size: var(--lettergrootte-basis);
}

/* =========================================================================
   Formulieren
   ========================================================================= */
.formulier-groep {
  margin-bottom: var(--ruimte-5);
}

.formulier-label {
  display: block;
  font-size: var(--lettergrootte-sm);
  font-weight: 500;
  color: var(--kleur-tekst);
  margin-bottom: var(--ruimte-2);
}

.formulier-label.vereist::after {
  content: " *";
  color: var(--kleur-fout);
}

.formulier-invoer,
.formulier-textarea,
.formulier-select {
  width: 100%;
  padding: var(--ruimte-2) var(--ruimte-3);
  border: 1px solid var(--kleur-rand-sterk);
  border-radius: var(--rand-radius);
  font-size: var(--lettergrootte-sm);
  color: var(--kleur-tekst);
  background-color: var(--kleur-oppervlak);
  transition: var(--overgang);
  line-height: 1.5;
}

.formulier-invoer:focus,
.formulier-textarea:focus,
.formulier-select:focus {
  outline: none;
  border-color: var(--kleur-primair);
  box-shadow: 0 0 0 3px rgba(70, 93, 83, 0.12);
}

.formulier-invoer.fout,
.formulier-textarea.fout,
.formulier-select.fout {
  border-color: var(--kleur-fout);
}

.formulier-textarea {
  resize: vertical;
  min-height: 100px;
}

.formulier-hulptekst {
  margin-top: var(--ruimte-1);
  font-size: var(--lettergrootte-xs);
  color: var(--kleur-tekst-zacht);
}

.formulier-fouttekst {
  margin-top: var(--ruimte-1);
  font-size: var(--lettergrootte-xs);
  color: var(--kleur-fout);
}

.formulier-rij {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--ruimte-4);
}

.formulier-acties {
  display: flex;
  gap: var(--ruimte-3);
  margin-top: var(--ruimte-6);
  padding-top: var(--ruimte-6);
  border-top: 1px solid var(--kleur-rand);
}

/* Checkbox-groep */
.formulier-checkbox {
  display: flex;
  align-items: center;
  gap: var(--ruimte-3);
  cursor: pointer;
}

.formulier-checkbox input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--kleur-primair);
  cursor: pointer;
}

/* =========================================================================
   Tabellen
   ========================================================================= */
.tabel-wrapper {
  overflow-x: auto;
  border-radius: var(--rand-radius-xl);
  border: 1px solid var(--kleur-rand);
}

.tabel {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--lettergrootte-sm);
}

.tabel thead {
  background-color: var(--kleur-achtergrond);
}

.tabel th {
  padding: var(--ruimte-3) var(--ruimte-4);
  text-align: left;
  font-weight: 600;
  color: var(--kleur-tekst-zacht);
  font-size: var(--lettergrootte-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  white-space: nowrap;
  border-bottom: 1px solid var(--kleur-rand);
}

.tabel td {
  padding: var(--ruimte-4);
  border-bottom: 1px solid var(--kleur-rand);
  vertical-align: middle;
}

.tabel tbody tr:last-child td {
  border-bottom: none;
}

.tabel tbody tr:hover {
  background-color: var(--kleur-achtergrond);
}

.tabel tbody tr.klikbaar {
  cursor: pointer;
}

/* =========================================================================
   Statuslabels (badges)
   ========================================================================= */
.label {
  display: inline-flex;
  align-items: center;
  gap: var(--ruimte-1);
  padding: var(--ruimte-1) var(--ruimte-2);
  border-radius: var(--rand-radius-volledig);
  font-size: var(--lettergrootte-xs);
  font-weight: 500;
  white-space: nowrap;
}

.label-grijs   { background-color: #f3f4f6;                   color: #374151; }
.label-groen   { background-color: var(--kleur-primair-licht); color: var(--kleur-primair); }
.label-blauw   { background-color: #dbeafe;                   color: #1e40af; }
.label-geel    { background-color: var(--kleur-waarschuwing-licht); color: #92400e; }
.label-rood    { background-color: var(--kleur-fout-licht);   color: #991b1b; }
.label-paars   { background-color: #ede9fe;                   color: #5b21b6; }
.label-oranje  { background-color: #fff7ed;                   color: #c2410c; }

.label-stip {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: currentColor;
  opacity: 0.7;
  display: inline-block;
}

/* =========================================================================
   Flash-berichten (meldingen)
   ========================================================================= */
.melding {
  display: flex;
  align-items: flex-start;
  gap: var(--ruimte-3);
  padding: var(--ruimte-4);
  border-radius: var(--rand-radius);
  margin-bottom: var(--ruimte-4);
  border-left: 4px solid;
  font-size: var(--lettergrootte-sm);
}

.melding-succes {
  background-color: var(--kleur-succes-licht);
  border-color: var(--kleur-succes);
  color: #14532d;
}

.melding-waarschuwing {
  background-color: var(--kleur-waarschuwing-licht);
  border-color: var(--kleur-waarschuwing);
  color: #78350f;
}

.melding-fout {
  background-color: var(--kleur-fout-licht);
  border-color: var(--kleur-fout);
  color: #7f1d1d;
}

.melding-info {
  background-color: var(--kleur-info-licht);
  border-color: var(--kleur-info);
  color: #164e63;
}

/* =========================================================================
   Info-banner (ℹ)
   ========================================================================= */
.info-banner {
  display: flex;
  align-items: flex-start;
  gap: var(--ruimte-3);
  padding: var(--ruimte-4) var(--ruimte-5);
  border-radius: var(--rand-radius-xl);
  border: 1px solid;
  font-size: var(--lettergrootte-sm);
  margin-bottom: var(--ruimte-6);
}

.info-banner-info {
  background-color: var(--kleur-info-licht);
  border-color: var(--kleur-info);
  color: #164e63;
}

.info-banner-waarschuwing {
  background-color: var(--kleur-waarschuwing-licht);
  border-color: var(--kleur-waarschuwing);
  color: #78350f;
}

.info-banner-succes {
  background-color: var(--kleur-succes-licht);
  border-color: var(--kleur-succes);
  color: #14532d;
}

/* =========================================================================
   Lege staat
   ========================================================================= */
.lege-staat {
  text-align: center;
  padding: var(--ruimte-16) var(--ruimte-8);
  color: var(--kleur-tekst-zacht);
}

.lege-staat-icoon {
  width: 48px;
  height: 48px;
  margin: 0 auto var(--ruimte-4);
  opacity: 0.4;
}

.lege-staat-titel {
  font-size: var(--lettergrootte-lg);
  font-weight: 600;
  color: var(--kleur-tekst);
  margin-bottom: var(--ruimte-2);
}

.lege-staat-tekst {
  font-size: var(--lettergrootte-sm);
  margin-bottom: var(--ruimte-6);
}

/* =========================================================================
   Laadspinner
   ========================================================================= */
.spinner {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid var(--kleur-rand);
  border-top-color: var(--kleur-primair);
  border-radius: 50%;
  animation: draaien 0.6s linear infinite;
}

@keyframes draaien {
  to { transform: rotate(360deg); }
}

/* =========================================================================
   Navigatie-tabs
   ========================================================================= */
.tabs {
  display: flex;
  border-bottom: 1px solid var(--kleur-rand);
  margin-bottom: var(--ruimte-6);
  gap: var(--ruimte-1);
}

.tab {
  padding: var(--ruimte-3) var(--ruimte-4);
  font-size: var(--lettergrootte-sm);
  font-weight: 500;
  color: var(--kleur-tekst-zacht);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: var(--overgang);
  text-decoration: none;
}

.tab:hover {
  color: var(--kleur-tekst);
  text-decoration: none;
}

.tab.actief {
  color: var(--kleur-primair);
  border-bottom-color: var(--kleur-primair);
}

/* =========================================================================
   Filters-balk
   ========================================================================= */
.filter-balk {
  display: flex;
  gap: var(--ruimte-3);
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: var(--ruimte-6);
  padding: var(--ruimte-4);
  background-color: var(--kleur-oppervlak);
  border: 1px solid var(--kleur-rand);
  border-radius: var(--rand-radius-xl);
}

.filter-balk .formulier-invoer,
.filter-balk .formulier-select {
  width: auto;
  min-width: 160px;
}

.filter-zoek {
  flex: 1;
  min-width: 200px;
}

/* =========================================================================
   Paginering
   ========================================================================= */
.paginering {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--ruimte-4) 0;
  font-size: var(--lettergrootte-sm);
  color: var(--kleur-tekst-zacht);
}

.paginering-knoppen {
  display: flex;
  gap: var(--ruimte-1);
}

.paginering-knop {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 var(--ruimte-2);
  border: 1px solid var(--kleur-rand);
  border-radius: var(--rand-radius);
  font-size: var(--lettergrootte-sm);
  color: var(--kleur-tekst-zacht);
  cursor: pointer;
  background-color: var(--kleur-oppervlak);
  transition: var(--overgang);
  text-decoration: none;
}

.paginering-knop:hover {
  background-color: var(--kleur-achtergrond);
  color: var(--kleur-tekst);
  text-decoration: none;
}

.paginering-knop.actief {
  background-color: var(--kleur-primair);
  color: white;
  border-color: var(--kleur-primair);
}

/* =========================================================================
   Modal
   ========================================================================= */
.modal-overlay {
  position: fixed;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 300;
  padding: var(--ruimte-4);
}

.modal {
  background-color: var(--kleur-oppervlak);
  border-radius: var(--rand-radius-xl);
  box-shadow: var(--schaduw-lg);
  max-width: 560px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
}

.modal-kop {
  padding: var(--ruimte-6);
  border-bottom: 1px solid var(--kleur-rand);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.modal-titel {
  font-size: var(--lettergrootte-lg);
  font-weight: 600;
}

.modal-lichaam {
  padding: var(--ruimte-6);
}

.modal-voet {
  padding: var(--ruimte-4) var(--ruimte-6);
  border-top: 1px solid var(--kleur-rand);
  display: flex;
  justify-content: flex-end;
  gap: var(--ruimte-3);
}

/* =========================================================================
   Drag-and-drop upload
   ========================================================================= */
.upload-zone {
  border: 2px dashed var(--kleur-rand-sterk);
  border-radius: var(--rand-radius-xl);
  padding: var(--ruimte-12);
  text-align: center;
  cursor: pointer;
  transition: var(--overgang);
  background-color: var(--kleur-achtergrond);
}

.upload-zone:hover,
.upload-zone.sleepend {
  border-color: var(--kleur-primair);
  background-color: var(--kleur-primair-tint);
}

.upload-zone-icoon {
  width: 48px;
  height: 48px;
  margin: 0 auto var(--ruimte-4);
  color: var(--kleur-tekst-zwakst);
}

.upload-zone-tekst {
  font-size: var(--lettergrootte-sm);
  color: var(--kleur-tekst-zacht);
}

.upload-zone-link {
  color: var(--kleur-primair);
  font-weight: 500;
}

.upload-zone-bestandsnaam {
  margin-top: var(--ruimte-2);
  font-size: var(--lettergrootte-xs);
  color: var(--kleur-primair);
  font-weight: 500;
}

/* =========================================================================
   Tijdlijn
   ========================================================================= */
.tijdlijn {
  position: relative;
  padding-left: var(--ruimte-8);
}

.tijdlijn::before {
  content: "";
  position: absolute;
  left: 10px;
  top: 0;
  bottom: 0;
  width: 2px;
  background-color: var(--kleur-rand);
}

.tijdlijn-item {
  position: relative;
  margin-bottom: var(--ruimte-6);
}

.tijdlijn-stip {
  position: absolute;
  left: calc(-1 * var(--ruimte-8) + 5px);
  top: 4px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: var(--kleur-primair);
  border: 2px solid var(--kleur-oppervlak);
}

.tijdlijn-tijdstip {
  font-size: var(--lettergrootte-xs);
  color: var(--kleur-tekst-zwakst);
  margin-bottom: var(--ruimte-1);
}

.tijdlijn-inhoud {
  background-color: var(--kleur-oppervlak);
  border: 1px solid var(--kleur-rand);
  border-radius: var(--rand-radius);
  padding: var(--ruimte-3) var(--ruimte-4);
}

/* =========================================================================
   Document-tegel
   ========================================================================= */
.document-tegel {
  background-color: var(--kleur-oppervlak);
  border: 1px solid var(--kleur-rand);
  border-radius: var(--rand-radius-xl);
  padding: var(--ruimte-4);
  display: flex;
  flex-direction: column;
  gap: var(--ruimte-3);
  transition: var(--overgang);
  text-decoration: none;
  color: var(--kleur-tekst);
}

.document-tegel:hover {
  border-color: var(--kleur-primair);
  box-shadow: var(--schaduw-md);
  text-decoration: none;
  color: var(--kleur-tekst);
}

.document-tegel-icoon {
  width: 40px;
  height: 40px;
  background-color: var(--kleur-fout-licht);
  color: var(--kleur-fout);
  border-radius: var(--rand-radius);
  display: flex;
  align-items: center;
  justify-content: center;
}

.document-tegel-naam {
  font-size: var(--lettergrootte-sm);
  font-weight: 600;
  line-height: 1.4;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.document-tegel-meta {
  font-size: var(--lettergrootte-xs);
  color: var(--kleur-tekst-zacht);
}

/* =========================================================================
   Key-value detail (profiel/gegevens-pagina's — Twinq patroon 7)
   ========================================================================= */
.detail-rij {
  display: flex;
  padding: var(--ruimte-4) 0;
  border-bottom: 1px solid var(--kleur-rand);
  gap: var(--ruimte-4);
}

.detail-rij:last-child {
  border-bottom: none;
}

.detail-sleutel {
  flex: 0 0 200px;
  font-size: var(--lettergrootte-sm);
  font-weight: 500;
  color: var(--kleur-tekst-zacht);
}

.detail-waarde {
  flex: 1;
  font-size: var(--lettergrootte-sm);
  color: var(--kleur-tekst);
}

/* =========================================================================
   Twee-koloms met KPI-zijkaart (Twinq patroon 5)
   ========================================================================= */
.twee-koloms-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--ruimte-6);
  align-items: start;
}

.kpi-zijkaart {
  background-color: var(--kleur-oppervlak);
  border: 1px solid var(--kleur-rand);
  border-radius: var(--rand-radius-xl);
  padding: var(--ruimte-6);
  box-shadow: var(--schaduw-sm);
}

.kpi-getal {
  font-size: var(--lettergrootte-3xl);
  font-weight: 700;
  color: var(--kleur-primair);
  line-height: 1;
}

.kpi-label {
  font-size: var(--lettergrootte-sm);
  color: var(--kleur-tekst-zacht);
  margin-top: var(--ruimte-1);
}

/* =========================================================================
   Login-pagina (geen shell)
   ========================================================================= */
.auth-pagina {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--kleur-achtergrond);
  padding: var(--ruimte-4);
}

.auth-kaart {
  background-color: var(--kleur-oppervlak);
  border: 1px solid var(--kleur-rand);
  border-radius: var(--rand-radius-xl);
  box-shadow: var(--schaduw-lg);
  padding: var(--ruimte-10);
  width: 100%;
  max-width: 440px;
}

.auth-logo {
  text-align: center;
  margin-bottom: var(--ruimte-8);
}

.auth-logo-naam {
  font-size: var(--lettergrootte-2xl);
  font-weight: 700;
  color: var(--kleur-primair);
}

.auth-logo-beschrijving {
  font-size: var(--lettergrootte-sm);
  color: var(--kleur-tekst-zacht);
  margin-top: var(--ruimte-1);
}

.auth-titel {
  font-size: var(--lettergrootte-xl);
  font-weight: 600;
  margin-bottom: var(--ruimte-1);
}

.auth-ondertitel {
  font-size: var(--lettergrootte-sm);
  color: var(--kleur-tekst-zacht);
  margin-bottom: var(--ruimte-6);
}

.auth-voet {
  text-align: center;
  margin-top: var(--ruimte-6);
  font-size: var(--lettergrootte-sm);
  color: var(--kleur-tekst-zacht);
}

/* =========================================================================
   Hulpklassen
   ========================================================================= */
.verborgen { display: none !important; }
.visueel-verborgen {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

.tekst-rechts  { text-align: right; }
.tekst-midden  { text-align: center; }
.vet           { font-weight: 600; }
.zacht         { color: var(--kleur-tekst-zacht); }
.ruimte-boven  { margin-top: var(--ruimte-4); }
.ruimte-onder  { margin-bottom: var(--ruimte-4); }

.flex                  { display: flex; }
.flex-items-center     { align-items: center; }
.flex-justify-between  { justify-content: space-between; }
.flex-gap-2            { gap: var(--ruimte-2); }
.flex-gap-3            { gap: var(--ruimte-3); }
.flex-gap-4            { gap: var(--ruimte-4); }
.flex-1                { flex: 1; }

/* =========================================================================
   Responsief — tabletbreekpunt (< 1024px)
   ========================================================================= */
@media (max-width: 1023px) {
  .hoofd-nav {
    display: none;
  }

  .hamburger-knop {
    display: flex;
    align-items: center;
  }

  .raster-3 { grid-template-columns: 1fr 1fr; }
  .raster-4 { grid-template-columns: 1fr 1fr; }
  .twee-koloms-layout { grid-template-columns: 1fr; }

  .topbalk {
    padding: 0 var(--ruimte-4);
  }

  .context-balk {
    padding: 0 var(--ruimte-4);
  }

  .pagina-inhoud {
    padding: var(--ruimte-4);
  }

  .detail-rij {
    flex-direction: column;
    gap: var(--ruimte-1);
  }

  .detail-sleutel {
    flex: none;
  }
}

/* =========================================================================
   Responsief — mobielbreekpunt (< 640px)
   ========================================================================= */
@media (max-width: 639px) {
  .raster-2 { grid-template-columns: 1fr; }
  .raster-3 { grid-template-columns: 1fr; }
  .raster-4 { grid-template-columns: 1fr; }
  .formulier-rij { grid-template-columns: 1fr; }
  .filter-balk { flex-direction: column; align-items: stretch; }
  .filter-balk .formulier-invoer,
  .filter-balk .formulier-select { min-width: unset; width: 100%; }
  .auth-kaart { padding: var(--ruimte-6); }
  .pagina-kop-rij { flex-direction: column; }
  .tegel-raster { grid-template-columns: 1fr 1fr; }
}

/* =========================================================================
   Documenten tegel-grid (Branch 6)
   ========================================================================= */
.documenten-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--ruimte-4);
}

.document-tegel-lichaam {
  display: flex;
  flex-direction: column;
  gap: var(--ruimte-2);
  flex: 1;
}

.document-tegel-naam {
  font-size: var(--lettergrootte-sm);
  font-weight: 600;
  line-height: 1.4;
  margin: 0;
}

.document-tegel-naam a {
  color: var(--kleur-tekst);
  text-decoration: none;
}

.document-tegel-naam a:hover {
  color: var(--kleur-primair);
  text-decoration: underline;
}

.document-tegel-omschrijving {
  font-size: 0.8125rem;
  line-height: 1.5;
  margin: 0;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.document-tegel-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--ruimte-2);
  margin-top: auto;
  padding-top: var(--ruimte-2);
  border-top: 1px solid var(--kleur-rand);
}

.document-tegel-meta {
  display: flex;
  gap: var(--ruimte-1);
  flex-wrap: wrap;
}

/* PDF embed viewer */
.pdf-viewer {
  display: block;
  border: none;
  border-radius: 0 0 var(--rand-radius-xl) var(--rand-radius-xl);
}

/* =========================================================================
   HTMX — laad-indicatoren
   ========================================================================= */
.htmx-request .spinner { display: inline-block; }
.htmx-request.spinner { display: inline-block; }

[hx-target].htmx-request,
[data-hx-target].htmx-request {
  opacity: 0.7;
  pointer-events: none;
}

/* =========================================================================
   Taalwisselaar (i18n)
   ========================================================================= */
.taalwisselaar {
  position: relative;
  display: flex;
  align-items: center;
}

.taalwisselaar-knop {
  display: flex;
  align-items: center;
  gap: var(--ruimte-1);
  padding: var(--ruimte-1) var(--ruimte-2);
  border: 1px solid var(--kleur-rand);
  border-radius: var(--rand-radius);
  background: none;
  font-size: var(--lettergrootte-xs);
  font-weight: 600;
  color: var(--kleur-tekst-zacht);
  cursor: pointer;
  letter-spacing: 0.05em;
  transition: var(--overgang);
}

.taalwisselaar-knop:hover {
  background-color: var(--kleur-primair-licht);
  color: var(--kleur-primair);
  border-color: var(--kleur-primair);
}

.taalwisselaar-menu {
  display: none;
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  background-color: var(--kleur-oppervlak);
  border: 1px solid var(--kleur-rand);
  border-radius: var(--rand-radius-lg);
  box-shadow: var(--schaduw-md);
  min-width: 130px;
  z-index: 300;
  overflow: hidden;
}

.taalwisselaar:hover .taalwisselaar-menu,
.taalwisselaar.open .taalwisselaar-menu {
  display: block;
}

.taalwisselaar-optie {
  display: block;
  width: 100%;
  padding: var(--ruimte-2) var(--ruimte-3);
  background: none;
  border: none;
  text-align: left;
  font-size: var(--lettergrootte-sm);
  color: var(--kleur-tekst);
  cursor: pointer;
  transition: var(--overgang);
}

.taalwisselaar-optie:hover {
  background-color: var(--kleur-primair-licht);
  color: var(--kleur-primair);
}

.taalwisselaar-optie.actief {
  font-weight: 600;
  color: var(--kleur-primair);
  background-color: var(--kleur-primair-licht);
}

/* =========================================================================
   Financiën — KPI-kaarten en overzicht
   ========================================================================= */
.financien-kpi-rij {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--ruimte-4);
  margin-bottom: var(--ruimte-6);
}

.financien-kpi-kaart {
  min-width: 0;
}

.financien-kpi-label {
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--kleur-tekst-zacht);
  margin-bottom: var(--ruimte-2);
}

.financien-kpi-waarde {
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1;
  margin-bottom: var(--ruimte-1);
}

.financien-kpi-neutraal { color: var(--kleur-tekst); }
.financien-kpi-positief { color: #16a34a; }
.financien-kpi-negatief { color: #dc2626; }
.financien-kpi-waarschuwing { color: #d97706; }

.financien-kpi-toelichting {
  font-size: 0.75rem;
  color: var(--kleur-tekst-zacht);
}

.financien-nav-icoon {
  font-size: 1.5rem;
  width: 2.5rem;
  text-align: center;
  flex-shrink: 0;
}

.financien-coming-soon {
  border-left: 4px solid var(--kleur-waarschuwing, #f59e0b);
  background: rgba(245, 158, 11, 0.04);
}

/* Tabel-stijlen */
.tabel {
  border-collapse: collapse;
  font-size: 0.875rem;
}

.tabel th {
  padding: var(--ruimte-3) var(--ruimte-4);
  text-align: left;
  font-weight: 600;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--kleur-tekst-zacht);
  border-bottom: 2px solid var(--kleur-rand);
}

.tabel td {
  padding: var(--ruimte-3) var(--ruimte-4);
  border-bottom: 1px solid var(--kleur-rand);
  vertical-align: middle;
}

.tabel tbody tr:hover {
  background: var(--kleur-achtergrond);
}

.tabel tfoot td {
  border-bottom: none;
  padding-top: var(--ruimte-3);
}

@media (max-width: 639px) {
  .financien-kpi-rij { grid-template-columns: 1fr 1fr; }
}
