/* ============================================================
   Woningopname — visueel ontwerp (Toevast v2)
   Brand-trouw aan de Toevast brandguide (Ifthen, april 2022):
   - Blinker als hoofdfont (lokaal, geen CDN)
   - Exacte palet-waarden uit het brandboek
   - Beeldmerk als markering in de topbalk
   - Donker thema (default) via brandguide's "diapositief"-treatment
   - Licht thema (auto via prefers-color-scheme) = canonieke
     Toevast-look: Lichtgrijs canvas, wit verheven, Donkergrijs tekst
   Klassennamen en HTML-structuur ongewijzigd; app.js werkt zonder
   aanpassingen.
   ============================================================ */

/* ============================================================
   0. Fonts — Blinker, lokaal
   ============================================================ */
@font-face {
  font-family: "Blinker";
  src: url("fonts/Blinker-ExtraLight.ttf") format("truetype");
  font-weight: 200;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Blinker";
  src: url("fonts/Blinker-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Blinker";
  src: url("fonts/Blinker-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
/* SemiBold zit niet in het brandpack — synthetisch met font-synthesis
   uit Bold halen is niet betrouwbaar; we vallen op 700 terug. */

/* ============================================================
   1. Tokens
   ============================================================ */
:root {
  /* ---------- Toevast hoofdkleuren (brandguide p.10) ---------- */
  --t-donkergrijs:     #414956;
  --t-donkergrijs-900: #131f2b;
  --t-donkergrijs-800: #283441;
  --t-donkergrijs-700: #3d4552;
  --t-donkergrijs-600: #404a57;
  --t-donkergrijs-500: #414956;
  --t-donkergrijs-400: #464e5b;
  --t-donkergrijs-300: #6f7a88;

  --t-blauw:           #85a5d3;
  --t-blauw-900:       #4d729e;
  --t-blauw-800:       #678cb9;
  --t-blauw-700:       #7fa0cf;
  --t-blauw-600:       #85a5d3;
  --t-blauw-500:       #89abda;
  --t-blauw-400:       #9dc1f1;
  --t-blauw-300:       #b8ddff;

  --t-lichtgrijs:      #f2f7f9;
  --t-lichtgrijs-900:  #b8bfc1;
  --t-lichtgrijs-800:  #d4dadd;
  --t-lichtgrijs-700:  #eaf1f3;
  --t-lichtgrijs-600:  #f2f7f9;
  --t-lichtgrijs-500:  #f3f9fc;
  --t-lichtgrijs-400:  #f6fcff;
  --t-lichtgrijs-300:  #ffffff;

  --t-groen:           #46be64;
  --t-groen-900:       #00a155;
  --t-groen-800:       #00bc6e;
  --t-rood:            #d23737;
  --t-rood-900:        #bb0022;

  /* ---------- Typografie ---------- */
  --font-sans: "Blinker", Tahoma, "Segoe UI", "Helvetica Neue", Arial,
               "Liberation Sans", system-ui, sans-serif;
  --font-mono: ui-monospace, "SF Mono", "Cascadia Mono",
               "Roboto Mono", Menlo, Consolas, monospace;

  --fs-caption:  12px;
  --fs-small:    13px;
  --fs-body:     clamp(14px, 0.45vw + 12.5px, 15.5px);
  --fs-input:    clamp(15px, 0.35vw + 13.8px, 16px);
  --fs-h3:       clamp(15px, 0.4vw + 13.5px, 17px);
  --fs-h2:       clamp(22px, 1.1vw + 17px, 30px);
  --fs-h2-num:   clamp(28px, 1.6vw + 20px, 40px);
  --fs-h1:       18px;

  --lh-tight:    1.15;
  --lh-snug:     1.30;
  --lh-normal:   1.55;

  --fw-extralight: 200;
  --fw-regular:    400;
  --fw-semibold:   700; /* Blinker SemiBold niet in pack → Bold */
  --fw-bold:       700;

  /* ---------- Ruimte (4px raster, brandguide-conform) ---------- */
  --sp-1:  4px;
  --sp-2:  8px;
  --sp-3:  12px;
  --sp-4:  16px;
  --sp-5:  20px;
  --sp-6:  24px;
  --sp-8:  32px;
  --sp-10: 40px;
  --sp-12: 48px;
  --sp-16: 64px;

  /* ---------- Radii — brandguide: cards 18px, buttons 12px ---------- */
  --r-xs:  4px;
  --r-sm:  8px;
  --r-md: 12px;       /* buttons, inputs */
  --r-lg: 18px;       /* cards */
  --r-xl: 24px;
  --r-pill: 999px;

  /* ---------- Donker thema (default — "diapositief") ---------- */
  --bg:             var(--t-donkergrijs-900);   /* #131f2b — diepste */
  --bg-elev:        var(--t-donkergrijs);       /* #414956 — card */
  --bg-elev-2:      #4b5462;                    /* sub-card binnen card */
  --bg-input:       #2a323f;                    /* inputs zakken in */
  --bg-input-hover: #323b48;
  --border:         #555f6d;
  --border-strong:  var(--t-donkergrijs-300);

  --text:           var(--t-lichtgrijs);
  --text-strong:    #ffffff;
  --text-muted:     #b3bbc7;
  --text-faint:     #8993a2;

  --accent:         var(--t-blauw);             /* #85a5d3 */
  --accent-strong:  var(--t-blauw-300);         /* #b8ddff voor donker */
  --accent-soft:    rgba(133, 165, 211, 0.16);
  --accent-fg:      var(--t-donkergrijs-900);
  --success:        var(--t-groen);
  --success-fg:     #0a1e10;
  --danger:         #f06b6b;                    /* opgehelderd Rood voor donker */
  --danger-strong:  var(--t-rood);
  --danger-bg:      rgba(210, 55, 55, 0.14);
  --danger-fg:      #ffd2cf;

  --shadow-1: 0 1px 2px rgba(0,0,0,0.30);
  --shadow-2: 0 8px 24px rgba(0,0,0,0.30), 0 1px 2px rgba(0,0,0,0.25);
  --focus-ring: 0 0 0 3px rgba(133, 165, 211, 0.45);

  /* ---------- Logo's voor topbalk ---------- */
  --logo-url:      url("assets/logo_toevast_diapositief.png");
  --beeldmerk-url: url("assets/beeldmerk_toevast_diapositief.png");

  /* Compat met oude tokens */
  --bg-elev-compat: var(--bg-elev);
  --radius: var(--r-md);
  --gap:    var(--sp-3);
  --gap-lg: var(--sp-5);

  color-scheme: dark light;
}

/* Licht thema — Toevast canonieke look. */
@media (prefers-color-scheme: light) {
  :root {
    --bg:             var(--t-lichtgrijs);          /* #f2f7f9 */
    --bg-elev:        #ffffff;
    --bg-elev-2:      var(--t-lichtgrijs-700);      /* #eaf1f3 */
    --bg-input:       #ffffff;
    --bg-input-hover: var(--t-lichtgrijs-500);
    --border:         var(--t-lichtgrijs-800);      /* #d4dadd */
    --border-strong:  var(--t-lichtgrijs-900);      /* #b8bfc1 */

    --text:           var(--t-donkergrijs);
    --text-strong:    var(--t-donkergrijs-900);
    --text-muted:     var(--t-donkergrijs-300);
    --text-faint:     #9098a3;

    --accent:         var(--t-blauw);
    --accent-strong:  var(--t-blauw-900);
    --accent-soft:    rgba(77, 114, 158, 0.10);
    --accent-fg:      #ffffff;
    --success:        var(--t-groen);
    --success-fg:     #ffffff;
    --danger:         var(--t-rood);
    --danger-strong:  var(--t-rood-900);
    --danger-bg:      #fbeaea;
    --danger-fg:      #88151a;

    --shadow-1: 0 1px 2px rgba(65, 73, 86, 0.06);
    --shadow-2: 0 6px 20px rgba(65, 73, 86, 0.10), 0 1px 2px rgba(65, 73, 86, 0.04);
    --focus-ring: 0 0 0 3px rgba(133, 165, 211, 0.50);

    --logo-url:      url("assets/logo_toevast.png");
    --beeldmerk-url: url("assets/beeldmerk_toevast.png");
  }
}

/* ============================================================
   2. Reset / basis
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  background: var(--bg);
  color: var(--text);
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

::selection { background: var(--accent); color: var(--accent-fg); }

h1 {
  font-size: var(--fs-h1);
  font-weight: var(--fw-bold);
  letter-spacing: 0.005em;
  margin: 0;
  color: var(--text-strong);
  line-height: var(--lh-tight);
}
/* Sectie-titel: nummer dik en groot, naam ernaast. We splitsen
   "1. Algemeen" pseudo-visueel — first-letter pakt het cijfer.
   first-line zou ook werken maar is fragieler. */
h2 {
  font-size: var(--fs-h2);
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  letter-spacing: -0.012em;
  margin: 0 0 var(--sp-5);
  color: var(--text-strong);
  padding: 0 0 var(--sp-3);
  border-bottom: 1px solid var(--border);
  position: relative;
}
h2::first-letter {
  font-weight: var(--fw-bold);
  font-size: var(--fs-h2-num);
  color: var(--accent);
  margin-right: 6px;
  line-height: 1;
}
h2::after {
  content: "";
  position: absolute;
  left: 0; bottom: -1px;
  width: var(--sp-12);
  height: 2px;
  background: var(--accent);
  border-radius: 1px;
}
h3 {
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  letter-spacing: -0.005em;
  margin: var(--sp-6) 0 var(--sp-3);
  color: var(--text-strong);
}

p { margin: 0 0 var(--sp-3); }
.hint {
  color: var(--text-muted);
  font-size: var(--fs-small);
  line-height: var(--lh-normal);
  max-width: 70ch;
}

/* ============================================================
   3. Topbar — logo, autosave, acties
   ============================================================ */
.topbar {
  position: sticky;
  top: 0;
  z-index: 100;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  padding: var(--sp-3) var(--sp-5);
  background: color-mix(in srgb, var(--bg-elev) 94%, transparent);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
          backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid var(--border);
}
.topbar-left {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  min-width: 0;
  flex: 1 1 auto;
}
/* Echt Toevast beeldmerk, exact gepositioneerd voor de H1 */
.topbar-left::before {
  content: "";
  width: 36px;
  height: 36px;
  flex: 0 0 36px;
  background-image: var(--beeldmerk-url);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
/* "Toevast" wordmark als prefix bij H1 — uppercase + sperring */
.topbar h1::before {
  content: "Toevast";
  display: inline-block;
  color: var(--accent);
  font-weight: var(--fw-bold);
  font-family: var(--font-sans);
  letter-spacing: 0.20em;
  font-size: 12px;
  margin-right: var(--sp-3);
  padding-right: var(--sp-3);
  border-right: 1px solid var(--border);
  text-transform: uppercase;
}
.topbar h1 {
  font-weight: var(--fw-bold);
  letter-spacing: 0;
}

.autosave {
  font-size: var(--fs-small);
  color: var(--text-muted);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  padding-left: var(--sp-2);
}
.autosave::before {
  content: "";
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--text-faint);
  flex: 0 0 8px;
  transition: background 160ms;
}
.autosave:not(:empty)::before { background: var(--success); }
.autosave.saving::before {
  background: var(--danger);
  animation: pulse 1.4s ease-in-out infinite;
}
@keyframes pulse { 50% { opacity: 0.35; } }

.topbar-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2);
  flex: 0 0 auto;
}

/* Verticale scheiding tussen primaire acties en JSON-acties */
.topbar-sep {
  width: 1px;
  align-self: stretch;
  min-height: 28px;
  background: var(--border);
  margin: 0 4px;
}

/* JSON-knoppen: bewust minder opvallend (gedempt) */
.btn-json {
  color: var(--text-muted);
  font-weight: var(--fw-medium, 500);
  opacity: 0.85;
}
.btn-json:hover {
  opacity: 1;
}

/* "Leeg formulier" subtiel waarschuwend bij hover */
.btn-leeg:hover {
  border-color: var(--danger);
  color: var(--danger);
  background: var(--danger-bg);
}

/* Uitlegregel onder de topbar */
.topbar-uitleg {
  margin: 0;
  padding: 8px 16px;
  font-size: var(--fs-small);
  color: var(--text-muted);
  background: var(--bg-elev-1, rgba(0,0,0,0.02));
  border-bottom: 1px solid var(--border);
  line-height: 1.5;
}
.topbar-uitleg strong { color: var(--text); }

/* ============================================================
   4. Layout: zijbalk + main
   ============================================================ */
.layout {
  display: block;
  max-width: 1320px;
  margin: 0 auto;
  padding: var(--sp-5) var(--sp-4) var(--sp-12);
}
main { min-width: 0; }
.sidenav { display: none; }

@media (min-width: 960px) {
  .layout {
    display: grid;
    grid-template-columns: 252px minmax(0, 1fr);
    gap: var(--sp-8);
    padding: var(--sp-6) var(--sp-6) var(--sp-16);
  }
  .sidenav {
    display: block;
    position: sticky;
    top: 88px;
    align-self: start;
    max-height: calc(100vh - 110px);
    overflow-y: auto;
    padding: var(--sp-4) var(--sp-2) var(--sp-4) 0;
    scrollbar-width: thin;
  }
}

/* Groepskoppen in de zijbalk (boven de woningenlijst en boven de paginalijst) */
.sidenav-groepkop {
  font-size: 11px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-faint);
  padding: 0 var(--sp-3) var(--sp-2);
}
.secties-kop { margin-top: var(--sp-2); }

/* 0. Woningen — lijst van opnames */
.woningen-blok {
  margin: 0 0 var(--sp-3);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--border);
}
.woningen-kop {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--sp-2) var(--sp-2) var(--sp-3);
  font-size: var(--fs-small);
  font-weight: var(--fw-bold);
  color: var(--text);
}
.woningen-kop .btn-icon {
  width: 26px; height: 26px; min-height: 26px;
  font-size: 18px; line-height: 1;
  border: 1px solid var(--border);
  color: var(--accent-strong);
}
.woningen-kop .btn-icon:hover {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--accent-strong);
}
.woningen-lijst { list-style: none; margin: 0; padding: 0; }
.woning-leeg {
  padding: 4px var(--sp-3);
  font-size: var(--fs-small);
  color: var(--text-faint);
  font-style: italic;
}
.woning-item {
  display: flex;
  align-items: center;
  gap: 2px;
  border-radius: var(--r-sm);
  margin: 1px 0;
}
.woning-item.is-actief {
  background: var(--accent-soft);
  position: relative;
}
.woning-item.is-actief::before {
  content: "";
  position: absolute;
  left: -3px; top: 15%; bottom: 15%;
  width: 3px; border-radius: 2px;
  background: var(--accent);
}
.woning-naam {
  flex: 1 1 auto;
  text-align: left;
  background: none;
  border: none;
  cursor: pointer;
  padding: 6px var(--sp-3);
  font: inherit;
  font-size: var(--fs-small);
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  border-radius: var(--r-sm);
}
.woning-item.is-actief .woning-naam { color: var(--accent-strong); font-weight: var(--fw-bold); }
.woning-naam:hover { color: var(--text-strong); }
.woning-del {
  flex: 0 0 auto;
  width: 24px; height: 24px; min-height: 24px;
  font-size: 15px; line-height: 1;
  opacity: 0;
  transition: opacity 120ms;
}
.woning-item:hover .woning-del { opacity: 1; }

.sidenav ol {
  list-style: none;
  padding: 0;
  margin: 0;
}
.sidenav > ol > li { margin: 2px 0; }
.sidenav ol ol {
  padding-left: var(--sp-4);
  margin: 4px 0 var(--sp-2);
  border-left: 1px solid var(--border);
}
.sidenav a {
  display: block;
  position: relative;
  color: var(--text-muted);
  text-decoration: none;
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-sm);
  font-size: var(--fs-small);
  line-height: 1.3;
  font-weight: var(--fw-bold);
  letter-spacing: 0.005em;
  transition: color 120ms, background 120ms;
}
.sidenav > ol > li > a { color: var(--text); }
.sidenav ol ol a { font-weight: var(--fw-regular); }
.sidenav a:hover {
  color: var(--text-strong);
  background: var(--accent-soft);
}
.sidenav a:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}

/* Actieve sectie — door de scrollspy (wireScrollspy in app.js) gezet tijdens scrollen */
.sidenav a.is-actief {
  color: var(--accent-strong);
  background: var(--accent-soft);
}
.sidenav a.is-actief::before {
  content: "";
  position: absolute;
  left: -3px; top: 18%; bottom: 18%;
  width: 3px;
  border-radius: 2px;
  background: var(--accent);
}

/* ============================================================
   5. Cards (sectie-container)
   ============================================================ */
.card {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);          /* 18px — brandguide */
  padding: var(--sp-5) var(--sp-5) var(--sp-6);
  margin: 0 0 var(--sp-5);
  box-shadow: var(--shadow-1);
  scroll-margin-top: 88px;
  position: relative;
  overflow: hidden;
}
@media (min-width: 640px) {
  .card { padding: var(--sp-6) var(--sp-8) var(--sp-8); }
}

/* Brandguide p.13: het beeldmerk als hoekdecoratie. Alleen op de
   eerste card om bescheiden te blijven, maar groot genoeg om
   meteen herkenbaar Toevast te zijn. */
#sectie-algemeen::before {
  content: "";
  position: absolute;
  top: -90px; right: -90px;
  width: 420px; height: 420px;
  background-image: var(--beeldmerk-url);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  opacity: 0.10;
  pointer-events: none;
  transform: rotate(10deg);
  z-index: 0;
}
@media (prefers-color-scheme: light) {
  #sectie-algemeen::before { opacity: 0.14; }
}
@media (min-width: 640px) {
  #sectie-algemeen::before {
    top: -110px; right: -110px;
    width: 520px; height: 520px;
  }
}
/* Zorg dat de form-inhoud boven het beeldmerk blijft staan */
#sectie-algemeen > * { position: relative; z-index: 1; }

/* ============================================================
   6. Grid voor velden
   ============================================================ */
.grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
  margin-bottom: var(--sp-4);
}
@media (min-width: 640px) {
  .grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 960px) {
  .grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
.grid-adres { grid-template-columns: 1fr; }
@media (min-width: 640px) {
  .grid-adres {
    grid-template-columns: 2fr 0.6fr 0.6fr 1fr 1.4fr;
  }
}

/* ============================================================
   7. Form fields
   ============================================================ */
.field {
  display: flex;
  flex-direction: column;
  min-width: 0;
  gap: 6px;
}
.field label,
.field > legend {
  font-size: var(--fs-caption);
  font-weight: var(--fw-bold);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: 0;
  line-height: 1.3;
}
.req {
  color: var(--accent);
  margin-left: 2px;
  font-weight: var(--fw-bold);
}

.field-group {
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-4) var(--sp-5) var(--sp-5);
  margin: var(--sp-4) 0 var(--sp-5);
  background: var(--bg-elev-2);
}
.field-group > legend {
  padding: 4px 12px;
  margin-left: -4px;
  color: var(--text-strong);
  font-size: var(--fs-small);
  font-weight: var(--fw-bold);
  text-transform: none;
  letter-spacing: 0;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
}

input[type="text"],
input[type="number"],
input[type="date"],
input[type="file"],
select,
textarea {
  font: inherit;
  font-family: var(--font-sans);
  font-size: var(--fs-input);
  color: var(--text);
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 10px 14px;
  width: 100%;
  min-height: 44px;
  line-height: 1.3;
  transition: border-color 120ms, background 120ms, box-shadow 120ms;
  -webkit-appearance: none;
  appearance: none;
  font-variant-numeric: tabular-nums;
}
textarea {
  min-height: 92px;
  resize: vertical;
  line-height: 1.45;
}

/* Custom select-pijl (inline SVG in --accent kleur per thema) */
select {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none' stroke='%2385a5d3' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><path d='M1.5 1.5 6 6 10.5 1.5'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 11px 7px;
  padding-right: 38px;
  cursor: pointer;
}
@media (prefers-color-scheme: light) {
  select {
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none' stroke='%234d729e' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><path d='M1.5 1.5 6 6 10.5 1.5'/></svg>");
  }
}

input[type="date"]::-webkit-calendar-picker-indicator {
  filter: invert(0.85) sepia(0.2) hue-rotate(180deg);
  opacity: 0.75;
  cursor: pointer;
}
@media (prefers-color-scheme: light) {
  input[type="date"]::-webkit-calendar-picker-indicator { filter: none; opacity: 0.7; }
}

input[type="file"] {
  padding: 7px 10px;
  font-size: var(--fs-small);
  color: var(--text-muted);
  cursor: pointer;
}
input[type="file"]::-webkit-file-upload-button,
input[type="file"]::file-selector-button {
  font: inherit;
  font-family: var(--font-sans);
  font-size: var(--fs-small);
  font-weight: var(--fw-bold);
  color: var(--text);
  background: var(--bg-elev-2);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-sm);
  padding: 6px 14px;
  margin-right: 10px;
  cursor: pointer;
  transition: background 120ms, border-color 120ms;
}
input[type="file"]:hover::-webkit-file-upload-button,
input[type="file"]:hover::file-selector-button {
  background: var(--bg-input-hover);
  border-color: var(--accent);
}

input::placeholder, textarea::placeholder { color: var(--text-faint); }

input:hover, select:hover, textarea:hover {
  border-color: var(--border-strong);
}

/* Focus-state — verzorgd:
   - Border kleurt mee in Toevast-Blauw
   - Achtergrond licht lichter op
   - Dubbele ring (binnen-hairline + buiten-glow) voor visuele diepte
   - Hele .field-container kleurt mee via :has — label wordt accent
     en links verschijnt een kleine accent-streep als visueel anker.
   Alles binnen 120ms zoals brandguide voorschrijft ("no bounces"). */
input:focus, select:focus, textarea:focus,
input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: none;
  border-color: var(--accent);
  background: var(--bg-input-hover);
  box-shadow:
    inset 0 0 0 1px var(--accent),
    var(--focus-ring);
}

.field {
  position: relative;
  border-radius: var(--r-md);
  transition: background 160ms ease;
}
.field::before {
  content: "";
  position: absolute;
  left: -10px; top: 22px; bottom: 4px;
  width: 3px;
  border-radius: 2px;
  background: var(--accent);
  opacity: 0;
  transform: scaleY(0.4);
  transform-origin: center;
  transition: opacity 160ms ease, transform 160ms ease;
  pointer-events: none;
}
.field:has(input:focus-visible),
.field:has(select:focus-visible),
.field:has(textarea:focus-visible),
.field:has(input:focus),
.field:has(select:focus),
.field:has(textarea:focus) {
  /* geen achtergrond op de hele field — de input zelf is al duidelijk
     gemarkeerd; het label en de linker-accentstreep volstaan. */
}
.field:has(input:focus)::before,
.field:has(select:focus)::before,
.field:has(textarea:focus)::before,
.field:has(input:focus-visible)::before,
.field:has(select:focus-visible)::before,
.field:has(textarea:focus-visible)::before {
  opacity: 1;
  transform: scaleY(1);
}
.field:has(input:focus) > label,
.field:has(select:focus) > label,
.field:has(textarea:focus) > label,
.field:has(input:focus-visible) > label,
.field:has(select:focus-visible) > label,
.field:has(textarea:focus-visible) > label {
  color: var(--accent-strong);
}

input:disabled, select:disabled, textarea:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  background: var(--bg-elev);
}

/* Error-state via .has-error of :invalid.touched */
input:invalid.touched,
select:invalid.touched,
.field.has-error input,
.field.has-error select,
.field.has-error textarea {
  border-color: var(--danger);
  background: var(--danger-bg);
}
.field.has-error label,
.field.has-error label .req { color: var(--danger); }

/* ============================================================
   8. Radio's en checkboxes als touch-cards
   ============================================================ */
.radio-row,
.checkbox-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: stretch;
  padding: 0;
  min-height: 44px;
}
.radio-row label,
.checkbox-row label {
  flex: 0 0 auto;
  color: var(--text);
  font-family: var(--font-sans);
  font-size: var(--fs-small);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  min-height: 44px;
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  cursor: pointer;
  transition: border-color 120ms, background 120ms, color 120ms;
  user-select: none;
  text-transform: none;
  letter-spacing: 0;
  font-weight: var(--fw-regular);
}
.radio-row label:hover,
.checkbox-row label:hover {
  border-color: var(--border-strong);
  background: var(--bg-input-hover);
}
.radio-row input,
.checkbox-row input {
  width: 16px;
  height: 16px;
  min-height: 0;
  margin: 0;
  flex: 0 0 16px;
  cursor: pointer;
  accent-color: var(--accent);
}
.radio-row label:has(input:checked),
.checkbox-row label:has(input:checked) {
  border-color: var(--accent);
  background: var(--accent-soft);
  color: var(--text-strong);
  font-weight: var(--fw-bold);
}
.radio-row label:focus-within,
.checkbox-row label:focus-within {
  box-shadow: var(--focus-ring);
  border-color: var(--accent);
}

/* ============================================================
   9. Buttons — brandguide: primair = Groen, radius 12
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font: inherit;
  font-family: var(--font-sans);
  font-size: var(--fs-small);
  font-weight: var(--fw-bold);
  letter-spacing: 0.005em;
  padding: 0 18px;
  min-height: 44px;
  border-radius: var(--r-md);
  border: 1px solid var(--border-strong);
  background: var(--bg-elev-2);
  color: var(--text);
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition: background 120ms, border-color 120ms, color 120ms,
              transform 80ms, box-shadow 120ms;
}
.btn:hover {
  background: var(--bg-input-hover);
  color: var(--text-strong);
}
.btn:active { transform: scale(0.98); box-shadow: none; }
.btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }

.btn-primary {
  background: var(--success);
  color: var(--success-fg);
  border-color: var(--success);
}
.btn-primary:hover {
  background: var(--t-groen-900);
  border-color: var(--t-groen-900);
  color: #fff;
}

.btn-ghost {
  background: transparent;
  border-color: var(--border);
  color: var(--text);
}
.btn-ghost:hover {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--text-strong);
}

.btn-icon {
  background: transparent;
  border: 1px solid transparent;
  color: var(--text-muted);
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  width: 36px;
  height: 36px;
  min-height: 36px;
  border-radius: var(--r-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: background 120ms, color 120ms, border-color 120ms;
}
.btn-icon:hover {
  color: var(--danger);
  border-color: var(--danger);
  background: var(--danger-bg);
}
.btn-icon:focus-visible { outline: none; box-shadow: var(--focus-ring); }

.footer-actions {
  margin: var(--sp-6) 0 var(--sp-4);
  display: flex;
  justify-content: flex-end;
}
.footer-actions .btn-primary { min-width: 220px; }

/* ============================================================
   10. Constructies (herhaalde compacte rijen)
   ============================================================ */
.constructies-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  margin: 0 0 var(--sp-4);
}
.constructie {
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-4);
  transition: border-color 160ms;
}
.constructie:hover { border-color: var(--accent); }

.constructie-head {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--border);
}
.constructie-code {
  font-family: var(--font-mono);
  font-weight: var(--fw-bold);
  font-size: 13px;
  letter-spacing: 0.06em;
  background: var(--accent);
  color: var(--accent-fg);
  border: none;
  border-radius: var(--r-sm);
  padding: 8px 12px;
  min-width: 58px;
  text-align: center;
  flex: 0 0 auto;
  font-variant-numeric: tabular-nums;
}
@media (prefers-color-scheme: light) {
  .constructie-code {
    background: var(--t-blauw-900);
    color: #fff;
  }
}
.constructie-head select {
  flex: 1 1 auto;
  max-width: 320px;
  min-height: 40px;
  font-weight: var(--fw-bold);
}
.constructie-head .btn-icon { margin-left: auto; }

.constructie .grid {
  grid-template-columns: 1fr;
  gap: var(--sp-3);
  margin-bottom: var(--sp-3);
}
@media (min-width: 640px) {
  .constructie .grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 960px) {
  .constructie .grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
.constructie .field label { font-size: 11px; }
.constructie textarea { min-height: 64px; }

.constructie-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-4);
  background: transparent;
  border: 1px dashed var(--border-strong);
  border-radius: var(--r-lg);
}
.constructie-toolbar .btn {
  min-height: 40px;
  padding: 0 16px;
  font-weight: var(--fw-bold);
}

/* ============================================================
   11. Subsections
   ============================================================ */
.subsection {
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-4) var(--sp-5) var(--sp-5);
  margin: var(--sp-4) 0 0;
  background: var(--bg-elev-2);
  scroll-margin-top: 88px;
}
.subsection + .subsection { margin-top: var(--sp-4); }
.subsection > legend {
  padding: 4px 12px;
  margin-left: -6px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  color: var(--text-strong);
  font-size: var(--fs-small);
  font-weight: var(--fw-bold);
  text-transform: none;
  letter-spacing: 0;
}

/* ============================================================
   12. Plattegronden & schetsen
   ============================================================ */
.plattegronden {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
  margin-bottom: var(--sp-4);
}
@media (min-width: 640px) {
  .plattegronden { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 960px) {
  .plattegronden { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

.plattegrond-slot,
.schets {
  background: var(--bg-elev-2);
  border: 1px dashed var(--border-strong);
  border-radius: var(--r-lg);
  padding: var(--sp-4);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: border-style 120ms, border-color 120ms, background 120ms;
}
.plattegrond-slot:has(.foto-preview img),
.schets:has(.foto-preview img) {
  border-style: solid;
  border-color: var(--border);
}

.slot-label {
  font-weight: var(--fw-bold);
  font-size: var(--fs-small);
  color: var(--text-strong);
  letter-spacing: 0.005em;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 8px;
}
.slot-label::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 1px;
  background: var(--accent);
  flex: 0 0 6px;
}

.foto-preview {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-height: 36px;
  border: 1px dashed transparent;
  border-radius: var(--r-sm);
  padding: 2px;
  transition: background 120ms ease, border-color 120ms ease;
}
.foto-preview.is-dropzone:empty {
  border-color: var(--border);
}
.foto-preview.is-dropzone:empty::before {
  content: "sleep foto's hierheen, of gebruik de knop hierboven";
  color: var(--text-muted, #888);
  font-size: 12px;
  font-style: italic;
  padding: 6px 8px;
}
.is-dragover {
  background: rgba(70, 190, 100, 0.08);
  border-color: #46be64 !important;
}

/* "Via foto" checkbox onder verwarming-velden */
.via-foto {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 4px;
  font-size: 12px;
  color: var(--text-muted, #666);
  cursor: pointer;
}
.via-foto input { transform: scale(0.9); }

/* Onderdeel-type als label (i.p.v. dropdown) in de header */
.onderdeel-type-label {
  display: inline-flex;
  align-items: center;
  padding: 0 12px;
  min-height: 36px;
  font-weight: var(--fw-bold);
  color: var(--accent-strong);
  background: var(--accent-soft);
  border-radius: var(--r-sm);
  white-space: nowrap;
}

/* Veld dat nog aandacht nodig heeft (bv. oriëntatie na kopiëren zonne-systeem) */
.needs-attention {
  border-color: var(--t-groen, #46be64) !important;
  box-shadow: 0 0 0 2px rgba(70,190,100,0.25) !important;
}

/* GBO per woonlaag */
.woonlaag-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 8px 0;
}
.woonlaag-rij {
  display: flex;
  align-items: center;
  gap: 10px;
}
.woonlaag-label {
  flex: 0 0 150px;
  font-size: var(--fs-small);
  font-weight: var(--fw-medium, 500);
}
.woonlaag-rij .input-with-action { flex: 1 1 auto; max-width: 200px; }
.woonlaag-totaal {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 10px;
  padding: 8px 12px;
  background: var(--accent-soft);
  border-radius: var(--r-sm);
  font-weight: var(--fw-bold);
}
.woonlaag-totaal strong { color: var(--accent-strong); }

/* Waarschuwing in maten-blok (bv. openingen groter dan vlak) */
.maten-blok-totaal.maten-blok-waarschuwing {
  color: var(--danger);
  background: var(--danger-bg);
  border-radius: var(--r-sm);
  padding: 4px 8px;
}

/* Compacte belemmering-checkbox-rij (zonne-energie) */
.belemmering-rij {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 18px;
  align-items: center;
  padding: 6px 0;
}
.belemmering-rij .koeling-aanwezig-label { margin: 0; }

/* Aannames-blok in het indicatieve label */
.label-aannames {
  margin: 10px 0;
  padding: 10px 12px;
  background: rgba(240, 200, 0, 0.10);
  border-left: 3px solid #f0c800;
  border-radius: var(--r-sm);
  font-size: var(--fs-small);
}
.label-aannames.is-compleet {
  background: rgba(70, 190, 100, 0.10);
  border-left-color: var(--t-groen, #46be64);
  color: var(--text);
}
.lbl-aannames-titel {
  font-weight: var(--fw-bold);
  margin-bottom: 6px;
}
.label-aannames ul {
  margin: 0 0 6px;
  padding-left: 18px;
}
.label-aannames li { margin: 2px 0; }
.lbl-aannames-tip {
  font-style: italic;
  color: var(--text-muted);
}

/* Aanpas- + verwijder-knop naast elkaar in een maten-rij */
.maten-blok-acties {
  display: inline-flex;
  gap: 2px;
  align-items: center;
}
.maten-blok-acties .btn-icon[data-stroke-edit]:hover {
  color: var(--accent-strong);
  border-color: var(--accent);
  background: var(--accent-soft);
}

/* Subgroepen binnen een installatie-fieldset (bv. Verwarming) */
.subgroep {
  margin: 0 0 var(--sp-3);
  padding: var(--sp-3);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--bg-elev-1, rgba(0,0,0,0.015));
}
.subgroep-titel {
  margin: 0 0 var(--sp-2);
  font-size: var(--fs-small);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent-strong);
}

/* Dakvlak rekenhulp blok */
.dak-rekenhulp {
  margin: 8px 0 4px;
  padding: 10px 12px;
  background: rgba(77, 114, 158, 0.06);
  border-left: 3px solid #4d729e;
  border-radius: var(--r-sm);
}
.dak-rekenhulp > strong {
  display: block;
  font-size: 13px;
  margin-bottom: 6px;
  color: #4d729e;
}
.dak-rekenhulp [data-role="dak-resultaat"] {
  margin-top: 6px;
  font-weight: 500;
}
.foto-preview img {
  max-width: 100%;
  max-height: 140px;
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
  cursor: pointer;
  transition: transform 120ms, box-shadow 120ms;
}
.foto-preview img:hover { transform: scale(1.02); box-shadow: var(--shadow-2); }

.schets {
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
}
.schets > input[type="file"]    { flex: 1 1 240px; }
.schets > input[type="text"]    { flex: 2 1 320px; }
.schets > .foto-preview         { flex: 1 0 100%; order: 3; }
.schets > .btn-icon             { order: 2; align-self: center; }

.extra-schetsen-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  margin: var(--sp-3) 0 var(--sp-4);
}
#btn-add-schets { margin-top: var(--sp-2); }

/* ============================================================
   13. Dialog (concept-restore)
   ============================================================ */
.dialog {
  position: fixed;
  inset: 0;
  background: color-mix(in srgb, var(--t-donkergrijs-900) 65%, transparent);
  -webkit-backdrop-filter: blur(6px);
          backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-5);
  z-index: 1000;
  animation: dialog-fade 180ms ease-out;
}
@keyframes dialog-fade { from { opacity: 0; } to { opacity: 1; } }
.dialog[hidden] { display: none; }
.dialog-content {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-6) var(--sp-6) var(--sp-5);
  max-width: 540px;
  width: 100%;
  box-shadow: var(--shadow-2);
  /* Bij veel velden mag de dialoog scrollen i.p.v. buiten beeld groeien,
     zodat de actieknoppen (opslaan/annuleren) altijd bereikbaar blijven. */
  max-height: calc(100vh - 2 * var(--sp-5));
  overflow-y: auto;
  overscroll-behavior: contain;
}
/* Inline checkbox met label-tekst ernaast (bv. "Boven maaiveld") */
.check-inline {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-weight: 400;
}
.check-inline input { width: auto; margin: 0; flex: none; }
/* Keuzelijst in de "Woning doorkopiëren"-dialoog */
.kopie-opties {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  margin: var(--sp-4) 0;
}
.kopie-sep {
  border: none;
  border-top: 1px solid var(--border);
  margin: var(--sp-4) 0;
}
.kopie-adres-velden {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-2);
  margin: 2px 0 var(--sp-2) var(--sp-5);
  padding: var(--sp-2) var(--sp-3);
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
}
.kopie-adres-velden[hidden] { display: none; }
/* Galerij met standaard tekeningen */
.galerij-content { max-width: 760px; }
.galerij-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: var(--sp-3);
  margin: var(--sp-4) 0;
}
.galerij-card {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: var(--sp-3);
  border: 1px solid var(--border);
  border-radius: var(--r-md, 8px);
  background: var(--bg);
  cursor: pointer;
  text-align: left;
  transition: border-color 120ms, box-shadow 120ms;
}
.galerij-card:hover {
  border-color: var(--t-oranje-500, #e8772e);
  box-shadow: var(--shadow-1);
}
.galerij-thumb {
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: var(--r-sm, 6px);
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 6px;
}
.galerij-naam { font-weight: 600; font-size: 14px; }
.galerij-beschrijving { font-size: 12px; color: var(--muted, #6b6b6b); line-height: 1.3; }
.btn-galerij { white-space: nowrap; }
.dialog-content h2 {
  border: none;
  padding: 0;
  margin: 0 0 var(--sp-3);
  font-size: 22px;
}
.dialog-content h2::after,
.dialog-content h2::first-letter {
  /* geen sectie-nummer-treatment in dialogs */
  all: unset;
}
.dialog-content h2::after { display: none; }
.dialog-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  justify-content: flex-end;
  margin-top: var(--sp-5);
}

/* ============================================================
   14. Validatie-foutbalk
   ============================================================ */
.validation-errors {
  position: sticky;
  top: 68px;
  z-index: 50;
  margin: 0 var(--sp-4) var(--sp-4);
  background: var(--danger-bg);
  color: var(--danger-fg);
  border: 1px solid var(--danger);
  border-left: 4px solid var(--danger);
  border-radius: var(--r-md);
  padding: var(--sp-3) var(--sp-4);
  box-shadow: var(--shadow-2);
}
.validation-errors[hidden] { display: none; }
.validation-errors strong { color: var(--danger); }
.validation-errors ul {
  margin: 6px 0 0;
  padding-left: 22px;
  font-size: var(--fs-small);
  line-height: var(--lh-normal);
}

/* ============================================================
   15. Conditional fields
   ============================================================ */
.conditional[hidden],
[hidden] { display: none !important; }

.field.conditional:not([hidden]),
.subsection.conditional:not([hidden]) {
  animation: cond-appear 180ms ease-out;
}
@keyframes cond-appear {
  from { opacity: 0; transform: translateY(-2px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   16. Scrollbar
   ============================================================ */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 5px;
  border: 2px solid var(--bg);
}
::-webkit-scrollbar-thumb:hover { background: var(--border-strong); }

/* ============================================================
   17. Reduced motion
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* ============================================================
   17b. Dynamische lijsten (bouwdelen, verdiepingen, zonne, opp)
   ============================================================ */
.dyn-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  margin-bottom: var(--sp-4);
}
.dyn-row {
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--sp-4);
}
.dyn-row + .dyn-row { margin-top: 0; }
.dyn-row:hover { border-color: var(--accent); }

.dyn-row-head {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-3);
}
.dyn-row-code {
  font-family: var(--font-mono);
  font-weight: var(--fw-bold);
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 4px 10px;
  font-size: var(--fs-small);
  flex: 1;
}
.dyn-row-head .btn-icon { flex: 0 0 auto; }

.dyn-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  padding: var(--sp-3);
  border: 1px dashed var(--border-strong);
  border-radius: var(--r-md);
  background: transparent;
  margin-bottom: var(--sp-3);
}

/* ============================================================
   17c. Tekeningen (canvas + foto-achtergrond)
   ============================================================ */
.tekeningen-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  margin-bottom: var(--sp-3);
}
.tekening {
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--sp-4);
}
.tekening-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2);
  margin-bottom: var(--sp-3);
}
.tekening-head select {
  flex: 0 0 auto;
  max-width: 240px;
}
.tekening-head input[type="text"] {
  flex: 1 1 240px;
  min-width: 0;
}

.tekening-canvas-wrap {
  position: relative;
  width: 100%;
  background: #ffffff;
  border: 1px solid var(--border-strong);
  border-radius: var(--r-sm);
  overflow: hidden;
  /* hoogte op tablet/desktop */
  aspect-ratio: 4 / 3;
  margin-bottom: var(--sp-3);
}
.tekening-canvas {
  display: block;
  width: 100%;
  height: 100%;
  touch-action: none;        /* niet scrollen tijdens tekenen op tablet */
  cursor: crosshair;
  background: #ffffff;
}

.tekening-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  align-items: center;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: var(--sp-2);
  margin-bottom: var(--sp-3);
}
.tool-group {
  display: flex;
  gap: 4px;
  align-items: center;
  padding: 2px;
  border-right: 1px solid var(--border);
  padding-right: var(--sp-2);
}
.tool-group:last-child { border-right: 0; padding-right: 0; }

.tool {
  width: 38px;
  height: 38px;
  border: 1px solid var(--border-strong);
  border-radius: var(--r-sm);
  background: var(--bg-input);
  color: var(--text);
  font-size: 16px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}
.tool:hover { border-color: var(--accent); }
.tool.active {
  border-color: var(--accent);
  background: var(--accent-soft);
  color: var(--accent-strong);
}
.tool.color {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 2px solid var(--border-strong);
}
.tool.color.active {
  outline: 3px solid var(--accent);
  outline-offset: 1px;
}
.tool-select {
  height: 38px;
  min-height: 38px;
  padding: 0 var(--sp-2);
  width: auto;
  background: var(--bg-input);
  border-radius: var(--r-sm);
}

/* ============================================================
   17d. Input-with-action (rekenwidget knop naast getalveld)
   ============================================================ */
.input-with-action {
  display: flex;
  gap: var(--sp-2);
  align-items: stretch;
}
.input-with-action input { flex: 1; min-width: 0; }
.btn-bereken {
  flex: 0 0 auto;
  width: 44px;
  min-height: 44px;
  border: 1px solid var(--border-strong);
  border-radius: var(--r-md);
  background: var(--bg-input);
  color: var(--accent-strong);
  font-size: 18px;
  font-weight: var(--fw-bold);
  cursor: pointer;
}
.btn-bereken:hover {
  border-color: var(--accent);
  background: var(--accent-soft);
}

/* ============================================================
   17e. Rekenwidget dialoog
   ============================================================ */
.rekenwidget-rows {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin: var(--sp-3) 0;
}
.reken-rij {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto auto auto;
  gap: var(--sp-2);
  align-items: center;
}
.reken-rij input {
  min-height: 40px;
  padding: 6px var(--sp-3);
}
.reken-rij output {
  font-family: var(--font-mono);
  font-weight: var(--fw-bold);
  color: var(--accent-strong);
  min-width: 80px;
  text-align: right;
}
.rekenwidget-total {
  margin-top: var(--sp-3);
  padding-top: var(--sp-3);
  border-top: 1px solid var(--border);
  font-size: var(--fs-h3);
  text-align: right;
}
.rekenwidget-total strong {
  font-family: var(--font-mono);
  color: var(--accent-strong);
  font-size: 1.25em;
}

/* ============================================================
   17f. Raam-velden (binnen .constructie)
   ============================================================ */
.constructie-body[data-role="raam-fields"] {
  background: var(--accent-soft);
  border-radius: var(--r-sm);
  padding: var(--sp-3);
  margin-bottom: var(--sp-3);
}

/* ============================================================
   17g. Tekening — extra: raam-tool, maten-blok, maat-dialoog
   ============================================================ */
.tool.tool-raam {
  background: linear-gradient(135deg, #b8ddff 0%, #85a5d3 100%);
  color: #1f1f1f;
}
.tool.tool-deur {
  background: linear-gradient(135deg, #f3d6a8 0%, #c98f4b 100%);
  color: #2a1a08;
}
.tool.tool-paneel {
  background: linear-gradient(135deg, #d8d2c4 0%, #8c8474 100%);
  color: #1f1a14;
}
.tool.tool-raam.active,
.tool.tool-deur.active,
.tool.tool-paneel.active {
  outline: 3px solid var(--accent);
  outline-offset: 1px;
}
.tool-group.tool-group-gevel {
  background: var(--accent-soft);
  border-left: 1px solid var(--border);
  padding-left: var(--sp-2);
  margin-left: 4px;
  border-radius: var(--r-sm);
}

.tekening-head select[data-role="tekening-bouwdeel"] {
  flex: 0 0 auto;
  max-width: 240px;
}

.maten-blok {
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--bg-elev);
  padding: var(--sp-3);
  margin-bottom: var(--sp-3);
  font-size: var(--fs-small);
}
.maten-blok-row {
  display: grid;
  grid-template-columns: 1.4fr 1.6fr auto 36px;
  gap: var(--sp-2);
  align-items: center;
  padding: 6px 4px;
  border-bottom: 1px dashed var(--border);
}
.maten-blok-row:last-child { border-bottom: 0; }
.maten-blok-head {
  font-weight: var(--fw-bold);
  color: var(--text-muted);
  text-transform: uppercase;
  font-size: var(--fs-caption);
  letter-spacing: 0.04em;
}
.maten-blok-row .num {
  text-align: right;
  font-family: var(--font-mono);
}
/* Ondergeschikte regel: glas in een deur/paneel, ingesprongen onder het hoofditem */
.maten-blok-row.maten-blok-subrow {
  padding-top: 2px;
  color: var(--text-muted);
  font-size: var(--fs-caption);
}
.maten-blok-row.maten-blok-subrow > span:first-child { padding-left: var(--sp-5); }
.maten-blok-row.element-raam {
  background: var(--accent-soft);
  border-radius: var(--r-xs);
}
.maten-blok-row.element-deur {
  background: rgba(201, 143, 75, 0.18);
  border-radius: var(--r-xs);
}
.maten-blok-row.element-paneel {
  background: rgba(140, 132, 116, 0.18);
  border-radius: var(--r-xs);
}
.maten-blok-row.element-raam .element-icon { color: var(--accent-strong); }
.maten-blok-row.element-polygon,
.maten-blok-row.element-driehoek {
  background: rgba(70, 190, 100, 0.10);
  border-radius: var(--r-xs);
  font-weight: var(--fw-bold);
}
.maten-blok-totaal.maten-blok-netto {
  border-top: 2px solid var(--accent);
  background: var(--accent-soft);
  margin-top: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-sm);
}
.maten-blok-totaal.maten-blok-netto strong {
  font-size: 1.15em;
  color: var(--accent-strong);
}
.maten-blok-totaal {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-top: var(--sp-2);
  margin-top: var(--sp-2);
  border-top: 2px solid var(--border);
  font-size: var(--fs-body);
}
.maten-blok-totaal strong {
  font-family: var(--font-mono);
  font-size: var(--fs-h3);
  color: var(--accent-strong);
}
.maten-blok-totaal.maten-blok-ramen { border-top: 1px dashed var(--border); }
.maten-blok-empty {
  text-align: center;
  color: var(--text-faint);
  padding: var(--sp-3);
  font-style: italic;
}

/* Maat-popup (inline klein vakje, geen overlay) */
.maat-popup {
  position: fixed;
  z-index: 9999;
  background: var(--bg-elev);
  color: var(--text);
  border: 2px solid var(--accent);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-2), 0 0 0 1px var(--accent);
  padding: var(--sp-3);
  width: 280px;
  max-width: calc(100vw - 24px);
  /* Past het venster niet op het scherm? Dan scrollbaar maken i.p.v. afkappen */
  max-height: calc(100vh - 24px);
  overflow-y: auto;
  overscroll-behavior: contain;
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: var(--fs-small);
  /* Forceer pointer-events op alle children */
  pointer-events: auto;
}
.maat-popup * { pointer-events: auto; }
.maat-popup[hidden] { display: none; }
.maat-popup-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: var(--fw-bold);
  font-size: var(--fs-body);
  border-bottom: 1px solid var(--border);
  padding-bottom: 6px;
  margin-bottom: 4px;
}
.maat-popup-head .btn-icon {
  width: 28px; height: 28px;
  font-size: 18px;
  padding: 0;
}
.maat-popup-mode {
  display: flex;
  gap: 4px;
  background: var(--bg-input);
  border-radius: var(--r-sm);
  padding: 3px;
  margin-bottom: 4px;
}
.maat-popup-mode button {
  flex: 1;
  font: inherit;
  padding: 6px 8px;
  border: 0;
  background: transparent;
  color: var(--text-muted);
  border-radius: calc(var(--r-sm) - 2px);
  cursor: pointer;
  min-height: 32px;
}
.maat-popup-mode button.active {
  background: var(--accent);
  color: var(--accent-fg);
  font-weight: var(--fw-bold);
}
.maat-popup-row {
  display: grid;
  grid-template-columns: 70px 1fr;
  gap: 6px;
  align-items: center;
}
.maat-popup-row[hidden] { display: none; }
.maat-popup-row label {
  font-size: var(--fs-caption);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: var(--fw-bold);
  margin: 0;
}
.maat-popup-row input,
.maat-popup-row select {
  padding: 6px 8px;
  min-height: 34px;
  font-size: var(--fs-body);
}
.maat-popup-eenheid {
  display: flex;
  gap: 8px;
}
.maat-popup-eenheid label {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  text-transform: none;
  letter-spacing: 0;
  font-size: var(--fs-small);
  color: var(--text);
  cursor: pointer;
}
.maat-popup-eenheid input {
  margin: 0 2px 0 0;
  transform: scale(1.1);
  min-height: 0;
}
.maat-popup-actions {
  display: flex;
  justify-content: flex-end;
  gap: 6px;
  margin-top: 6px;
  padding-top: 6px;
  border-top: 1px solid var(--border);
}
.maat-popup-actions .btn {
  min-height: 36px;
  padding: 6px 12px;
  font-size: var(--fs-small);
}

/* Sectie 5: rij gekoppeld via tekening (read-only-ish indicator) */
.opp-from-tekening {
  font-size: var(--fs-caption);
  color: var(--accent-strong);
  margin-top: 2px;
}

/* Tekening-header: extra elementen */
.tekening-meetellen {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-small);
  color: var(--text-muted);
  cursor: pointer;
  white-space: nowrap;
}
.tekening-meetellen input {
  width: auto;
  min-height: 0;
  transform: scale(1.2);
  margin: 0;
}
.tekening-head select[data-role="tekening-orientatie"] {
  flex: 0 0 auto;
  max-width: 160px;
}

/* Sectie 5: tekeningen-toggle-lijst */
.opp-tekeningen-lijst {
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--bg-elev);
  padding: var(--sp-3);
  margin-bottom: var(--sp-4);
}
.opp-tekeningen-lijst h3 { margin: 0 0 var(--sp-2); font-size: var(--fs-h3); }
.opp-tekening-toggle {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: 6px 4px;
  border-bottom: 1px dashed var(--border);
}
.opp-tekening-toggle:last-child { border-bottom: 0; }
.opp-tekening-toggle input[type="checkbox"] {
  width: auto;
  min-height: 0;
  transform: scale(1.2);
}
.opp-tekening-toggle .toggle-naam {
  flex: 1;
}
.opp-tekening-toggle .toggle-opp {
  font-family: var(--font-mono);
  font-weight: var(--fw-bold);
  color: var(--accent-strong);
}
.opp-tekening-toggle.uitgesloten {
  opacity: 0.45;
}

/* Volle-breedte veld voor multi-select checkboxgroepen */
.field-fullwidth {
  grid-column: 1 / -1;
}

/* Afrond-pagina */
.afrond-missend {
  background: var(--danger-bg);
  border: 2px solid var(--danger);
  border-radius: var(--r-md);
  padding: var(--sp-4);
  margin-bottom: var(--sp-4);
  color: var(--danger-fg, var(--text));
}
.afrond-missend strong {
  color: var(--danger-strong);
  display: block;
  margin-bottom: var(--sp-2);
  font-size: var(--fs-h3);
}
.afrond-missend ul {
  margin: 0 0 var(--sp-3);
  padding-left: var(--sp-6);
}
.afrond-missend li {
  margin: 4px 0;
}
.afrond-overzicht {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.afrond-blok {
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--sp-3);
}
.afrond-blok h3 {
  margin: 0 0 var(--sp-2);
  font-size: var(--fs-h3);
  color: var(--accent-strong);
  border-bottom: 1px solid var(--border);
  padding-bottom: 4px;
}
.afrond-rij {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: var(--sp-3);
  padding: 4px 0;
  border-bottom: 1px dashed var(--border);
}
.afrond-rij:last-child { border-bottom: 0; }
.afrond-rij .label  { color: var(--text-muted); font-size: var(--fs-small); }
.afrond-rij .waarde { color: var(--text); }
.afrond-rij .leeg   { color: var(--text-faint); font-style: italic; }
.afrond-rij.afrond-rij-fout .waarde { color: var(--danger); font-weight: var(--fw-bold); }
.afrond-aantal {
  font-size: var(--fs-small);
  color: var(--text-muted);
  font-weight: var(--fw-regular);
  margin-left: 6px;
}
.afrond-bestandenlijst {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.afrond-bestand {
  display: grid;
  grid-template-columns: 48px 1fr auto;
  align-items: center;
  gap: var(--sp-2);
  padding: 6px 8px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
}
.afrond-bestand-icon {
  display: inline-block;
  font-size: 11px;
  font-weight: var(--fw-bold);
  text-align: center;
  padding: 2px 6px;
  background: var(--accent);
  color: #fff;
  border-radius: 3px;
}
.afrond-bestand-naam {
  word-break: break-all;
  color: var(--text);
}
.afrond-bestand-size {
  color: var(--text-muted);
  font-size: var(--fs-small);
  white-space: nowrap;
}
.afrond-thumb-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.afrond-thumb {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--bg-elev);
}
.afrond-thumb-meer {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 80px;
  border: 1px dashed var(--border-strong);
  border-radius: var(--r-sm);
  color: var(--text-muted);
  font-size: var(--fs-small);
}
.afrond-acties {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-top: var(--sp-4);
  padding: var(--sp-3) var(--sp-4);
  border-top: 2px solid var(--border);
  justify-content: flex-end;
  /* Sticky onderin scherm zodat actie-knoppen altijd bereikbaar zijn */
  position: sticky;
  bottom: 0;
  background: var(--bg-elev-2);
  z-index: 50;
  box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.18);
  margin-left: calc(-1 * var(--sp-4));
  margin-right: calc(-1 * var(--sp-4));
  margin-bottom: calc(-1 * var(--sp-4));
  border-bottom-left-radius: var(--r-md);
  border-bottom-right-radius: var(--r-md);
}

/* Indicatief energielabel */
.afrond-label-actie {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  align-items: center;
  margin: var(--sp-4) 0 var(--sp-3);
  padding: var(--sp-3);
  background: var(--bg-elev);
  border: 1px dashed var(--border-strong);
  border-radius: var(--r-md);
}
.energielabel-resultaat {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--sp-4);
  padding: var(--sp-4);
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  margin-bottom: var(--sp-3);
}
.energielabel-resultaat[hidden] { display: none; }
.label-badge {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 140px;
  height: 140px;
  font-size: 64px;
  font-weight: var(--fw-bold);
  border-radius: var(--r-lg);
  color: #ffffff;
  text-shadow: 0 1px 2px rgba(0,0,0,0.25);
  letter-spacing: -2px;
  font-family: var(--font-sans);
}
.label-A4 { background: #007a3d; }   /* A++++ */
.label-A3 { background: #2e9b3f; }   /* A+++  */
.label-A2 { background: #59b251; }   /* A++   */
.label-A1 { background: #97c84e; }   /* A+    */
.label-A  { background: #c6d743; }   /* A     */
.label-B  { background: #fcd734; }   /* B     */
.label-C  { background: #f9aa2c; }   /* C     */
.label-D  { background: #f17c24; }   /* D     */
.label-E  { background: #e6481f; }   /* E     */
.label-F  { background: #cb1f25; }   /* F     */
.label-G  { background: #9b1a22; }   /* G     */

.label-details {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.label-details .lbl-titel {
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: var(--text);
}
.label-details .lbl-primair {
  font-family: var(--font-mono);
  font-size: var(--fs-h3);
  color: var(--accent-strong);
}
.label-uitsplitsing {
  margin-top: var(--sp-2);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 4px 12px;
  font-size: var(--fs-small);
  color: var(--text-muted);
}
.label-uitsplitsing strong {
  font-family: var(--font-mono);
  color: var(--text);
  text-align: right;
}
.label-disclaimer {
  margin-top: var(--sp-3);
  font-size: var(--fs-caption);
  color: var(--text-muted);
  font-style: italic;
  padding: var(--sp-2);
  background: var(--bg);
  border-left: 3px solid var(--accent);
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
}

/* Waarschijnlijkheidsbalk */
.label-waarschijnlijkheid {
  margin-top: var(--sp-3);
}
.lbl-w-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 4px;
  font-size: var(--fs-small);
}
.lbl-w-row .lbl-w-titel { color: var(--text-muted); }
.lbl-w-row .lbl-w-pct {
  font-family: var(--font-mono);
  font-weight: var(--fw-bold);
  font-size: var(--fs-h3);
}
.lbl-w-bar {
  height: 14px;
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: 999px;
  overflow: hidden;
}
.lbl-w-fill {
  height: 100%;
  border-radius: inherit;
  transition: width 0.3s ease-out;
}
.lbl-w-fill.is-laag    { background: linear-gradient(90deg, #cb1f25, #e6481f); }
.lbl-w-fill.is-midden  { background: linear-gradient(90deg, #f17c24, #fcd734); }
.lbl-w-fill.is-hoog    { background: linear-gradient(90deg, #97c84e, #2e9b3f); }
.lbl-w-fill.is-volledig{ background: linear-gradient(90deg, #2e9b3f, #007a3d); }

.lbl-w-onderbouwing {
  margin-top: 6px;
  font-size: var(--fs-small);
  color: var(--text-muted);
  line-height: 1.4;
}
.lbl-w-onderbouwing strong { color: var(--text); }
@media (max-width: 640px) {
  .energielabel-resultaat { grid-template-columns: 1fr; }
  .label-badge { margin: 0 auto; }
}

/* Wider veld voor lange ID's (BAG VBO / pand-ID = 16 cijfers) */
.field-wide {
  grid-column: span 2;
}
.field-wide input {
  font-family: var(--font-mono);
  letter-spacing: 0.02em;
}
@media (max-width: 640px) {
  .field-wide { grid-column: 1 / -1; }
}

/* Onderdelen-sectie: geünificeerd blok per vlak */
.onderdelen-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  margin-bottom: var(--sp-3);
}
.onderdeel {
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--sp-4);
}
.onderdeel:hover { border-color: var(--accent); }

.onderdeel-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2);
  margin-bottom: var(--sp-3);
}
.onderdeel-code {
  font-family: var(--font-mono);
  font-weight: var(--fw-bold);
  background: var(--accent);
  color: var(--accent-fg);
  border-radius: var(--r-sm);
  padding: 4px 10px;
  font-size: var(--fs-small);
  min-width: 56px;
  text-align: center;
}
.onderdeel-head select[data-role="type"] {
  flex: 0 0 auto;
  max-width: 180px;
}
.onderdeel-head input[data-role="naam"] {
  flex: 1 1 200px;
  min-width: 0;
}
.onderdeel-head input[data-role="bouwdeel"] {
  flex: 0 0 auto;
  max-width: 160px;
}

/* ============================================================
   Opslaan / Inklappen — onderdelen + installaties
   ============================================================ */
.onderdeel-foot,
.installatie-foot {
  display: flex;
  justify-content: flex-end;
  margin-top: var(--sp-3);
  padding-top: var(--sp-3);
  border-top: 1px dashed var(--border);
}

.samenvatting-balk {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-2) var(--sp-3);
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  margin-top: var(--sp-2);
}
.samenvatting-tekst {
  flex: 1 1 auto;
  color: var(--text);
  font-size: var(--fs-base);
  line-height: 1.4;
  min-width: 0;
  word-break: break-word;
}
.samenvatting-tekst .sv-code {
  display: inline-block;
  font-family: var(--font-mono);
  font-weight: var(--fw-bold);
  background: var(--accent);
  color: var(--accent-fg);
  border-radius: var(--r-sm);
  padding: 2px 8px;
  font-size: var(--fs-small);
  margin-right: 6px;
}
.samenvatting-tekst .sv-sep {
  color: var(--text-muted);
  margin: 0 6px;
}
.samenvatting-tekst .sv-leeg {
  color: var(--text-faint);
  font-style: italic;
}

/* Onderdeel ingeklapt: alles verbergen behalve header + samenvatting */
.onderdeel.is-collapsed {
  padding: var(--sp-2) var(--sp-3);
  background: var(--bg-elev);
}
.onderdeel.is-collapsed .onderdeel-head {
  margin-bottom: 0;
}
.onderdeel.is-collapsed > .grid,
.onderdeel.is-collapsed > .tekening-canvas-wrap,
.onderdeel.is-collapsed > .tekening-toolbar,
.onderdeel.is-collapsed > .maten-blok,
.onderdeel.is-collapsed > .field,
.onderdeel.is-collapsed > .onderdeel-foot {
  display: none;
}
.onderdeel:not(.is-collapsed) > .samenvatting-balk {
  display: none;
}

/* Installatie-fieldset ingeklapt */
.subsection.is-collapsed {
  padding: var(--sp-2) var(--sp-3);
  background: var(--bg-elev);
}
.subsection.is-collapsed > *:not(legend):not([data-role="summary"]) {
  display: none;
}
.subsection:not(.is-collapsed) > [data-role="summary"] {
  display: none;
}
/* Forceer zichtbaarheid van de samenvattingsbalk wanneer ingeklapt,
   ook als HTML-attribuut [hidden] er nog op staat */
.subsection.is-collapsed > [data-role="summary"],
.onderdeel.is-collapsed   > [data-role="summary"] {
  display: flex !important;
}

/* Rode markering wanneer ingeklapt blok ontbrekende verplichte velden bevat */
.onderdeel.is-collapsed.heeft-fout {
  border-color: var(--danger);
  background: rgba(210, 55, 55, 0.06);
}
.onderdeel.is-collapsed.heeft-fout > .samenvatting-balk {
  border-color: var(--danger);
  background: rgba(210, 55, 55, 0.10);
}
.subsection.is-collapsed.heeft-fout {
  border-color: var(--danger);
  background: rgba(210, 55, 55, 0.06);
}
.subsection.is-collapsed.heeft-fout > [data-role="summary"] {
  border-color: var(--danger);
  background: rgba(210, 55, 55, 0.10);
}
.subsection.is-collapsed.heeft-fout > legend {
  color: var(--danger);
  font-weight: var(--fw-bold);
}
.sv-fout {
  display: block;
  margin-top: 4px;
  color: var(--danger);
  font-weight: var(--fw-bold);
  font-size: var(--fs-small);
}

/* ============================================================
   PDF-bijlagen — inhoud op afrond-pagina + in print
   ============================================================ */
.afrond-pdf-paginas {
  margin-top: var(--sp-4);
}
.afrond-pdf-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-bottom: var(--sp-3);
}
.afrond-pdf-header h3 {
  margin: 0;
  font-size: var(--fs-h3);
  color: var(--accent-strong);
}
.afrond-pdf-status {
  font-size: var(--fs-small);
  color: var(--text-muted);
  font-style: italic;
}
.afrond-pdf-blok {
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--sp-3);
  margin-bottom: var(--sp-3);
}
.afrond-pdf-titel {
  margin: 0 0 var(--sp-2);
  font-size: var(--fs-body);
  color: var(--text);
  border-bottom: 1px dashed var(--border);
  padding-bottom: 4px;
}
.afrond-pdf-pagina-wrap {
  margin: 0 0 var(--sp-3) 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.afrond-pdf-pagina {
  max-width: 100%;
  height: auto;
  border: 1px solid var(--border);
  background: #fff;
  box-shadow: var(--shadow-1);
}
.afrond-pdf-pagina-wrap figcaption {
  margin-top: 4px;
  font-size: var(--fs-small);
  color: var(--text-muted);
}

.hint-inline {
  font-size: var(--fs-caption);
  font-weight: normal;
  color: var(--accent-strong);
  text-transform: none;
  letter-spacing: 0;
  margin-left: 6px;
  font-style: italic;
}

/* Bestand-lijst (PDF / overige bestanden) */
.bestand-lijst {
  list-style: none;
  padding: 0;
  margin: var(--sp-2) 0 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.bestand-lijst li {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 6px 10px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  font-size: var(--fs-small);
}
.bestand-lijst .bestand-icon {
  flex: 0 0 auto;
  width: 24px;
  text-align: center;
  color: var(--accent-strong);
  font-weight: var(--fw-bold);
}
.bestand-lijst .bestand-naam {
  flex: 1;
  word-break: break-all;
}
.bestand-lijst .bestand-size {
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: var(--fs-caption);
}
.bestand-lijst .bestand-verwijder {
  background: transparent;
  border: 0;
  color: var(--text-muted);
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  padding: 4px 8px;
}
.bestand-lijst .bestand-verwijder:hover { color: var(--danger); }

/* Totaal-overzicht (Sectie 5) */
.totaal-overzicht {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.totaal-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 8px 12px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
}
.totaal-row strong {
  font-family: var(--font-mono);
  color: var(--accent-strong);
}
.totaal-row-grand {
  margin-top: var(--sp-2);
  border-color: var(--accent);
  background: var(--accent-soft);
  font-size: var(--fs-h3);
}
.totaal-row-grand strong {
  font-size: 1.25em;
  color: var(--accent-strong);
}

/* Koeling-aanwezig checkbox-label */
.koeling-aanwezig-label {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  cursor: pointer;
  font-size: var(--fs-body);
  color: var(--text);
  font-weight: var(--fw-bold);
  padding: var(--sp-2) 0;
}
.koeling-aanwezig-label input {
  width: auto;
  min-height: 0;
  transform: scale(1.3);
  margin: 0;
}

/* Foto-only tekening (zonder canvas) */
.tekening-foto .foto-upload-wrap {
  padding: var(--sp-4);
  border: 2px dashed var(--border-strong);
  border-radius: var(--r-md);
  background: var(--bg-elev);
  text-align: center;
  margin-bottom: var(--sp-3);
}
.tekening-foto .foto-preview {
  margin-top: var(--sp-3);
  justify-content: center;
}
.tekening-foto .foto-preview img {
  max-height: 320px;
}
.tekening-head select[data-role="tekening-verdieping"] {
  flex: 0 0 auto;
  max-width: 200px;
}

/* Tool uitgeschakeld (bv. raam-tool bij plattegrond) */
.tool[disabled],
.tool.disabled {
  opacity: 0.35;
  cursor: not-allowed;
  filter: grayscale(1);
}
.tool[disabled]:hover,
.tool.disabled:hover {
  border-color: var(--border-strong);
  background: var(--bg-input);
}

/* Constructie-toolbar opgedeeld in twee groepen */
.constructie-toolbar-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
}
.constructie-toolbar-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  align-items: center;
  padding: var(--sp-2) var(--sp-3);
  border: 1px dashed var(--border-strong);
  border-radius: var(--r-md);
  background: transparent;
  flex: 1 1 auto;
  min-width: 0;
}
.constructie-toolbar-group.constructie-toolbar-detail {
  border-color: var(--accent);
  background: var(--accent-soft);
}
.constructie-toolbar-group .toolbar-label {
  font-size: var(--fs-caption);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  font-weight: var(--fw-bold);
  margin-right: var(--sp-2);
  white-space: nowrap;
}
.constructie-toolbar-detail .toolbar-label {
  color: var(--accent-strong);
}

/* ============================================================
   18. Print
        Zwart-wit, één doorlopend document, secties beginnen op
        een nieuwe A4-pagina. Toevast-logo bovenaan iedere pagina
        via @page is niet portabel — in plaats daarvan: hairline
        + brand-prefix per sectie-kop.
   ============================================================ */
@media print {
  /* Tekeningen + canvas voor print: toon zichtbare canvas-content */
  .tekening-canvas-wrap { aspect-ratio: auto; height: 120mm; }
  .tekening-toolbar { display: none !important; }
  .dyn-toolbar { display: none !important; }
  .btn-bereken { display: none !important; }
  .bestand-verwijder { display: none !important; }

  /* Foto's: print-vriendelijk renderen */
  .foto-preview {
    display: flex;
    flex-wrap: wrap;
    gap: 4mm;
    page-break-inside: avoid;
  }
  .foto-preview img {
    max-width: 80mm;
    max-height: 60mm;
    border: 1px solid #888;
    page-break-inside: avoid;
  }
  /* PDF/bestand-lijst: toon namen */
  .bestand-lijst {
    border: 1px solid #888;
    padding: 4mm;
  }
  .bestand-lijst li {
    border: 0;
    background: transparent;
    padding: 2mm 0;
  }

  /* Bij print vanaf afrond-pagina: verberg overzicht/acties/energielabel,
     toon alleen de PDF-paginas + formulier-secties */
  body.printing-from-afrond #afrond-overzicht,
  body.printing-from-afrond #afrond-missend,
  body.printing-from-afrond .afrond-label-actie,
  body.printing-from-afrond .energielabel-resultaat,
  body.printing-from-afrond .afrond-acties,
  body.printing-from-afrond #sectie-afronden > h2,
  body.printing-from-afrond #sectie-afronden > p.hint {
    display: none !important;
  }

  /* PDF-bijlagen — inhoud (plattegronden e.d.) */
  .afrond-pdf-paginas {
    page-break-before: always;
  }
  .afrond-pdf-status { display: none !important; }
  .afrond-pdf-blok {
    border: 0;
    padding: 0;
    background: transparent;
    margin: 0;
  }
  .afrond-pdf-titel {
    font-size: 12pt;
    margin-bottom: 4mm;
    page-break-after: avoid;
  }
  .afrond-pdf-pagina-wrap {
    page-break-before: always;
    page-break-inside: avoid;
    margin: 0 0 8mm 0;
  }
  .afrond-pdf-pagina-wrap:first-child {
    page-break-before: avoid;
  }
  .afrond-pdf-pagina {
    width: 100%;
    max-width: 180mm;
    max-height: 250mm;
    object-fit: contain;
    border: 1px solid #888;
    box-shadow: none;
  }
  .afrond-pdf-pagina-wrap figcaption {
    font-size: 9pt;
    text-align: center;
    margin-top: 2mm;
  }
  :root {
    --bg:             #ffffff;
    --bg-elev:        #ffffff;
    --bg-elev-2:      #ffffff;
    --bg-input:       #ffffff;
    --bg-input-hover: #ffffff;
    --border:         #999999;
    --border-strong:  #555555;
    --text:           #000000;
    --text-strong:    #000000;
    --text-muted:     #333333;
    --text-faint:     #777777;
    --accent:         #000000;
    --accent-strong:  #000000;
    --accent-soft:    transparent;
    --accent-fg:      #ffffff;
    --success:        #000000;
    --danger:         #000000;
    --danger-bg:      #ffffff;
    --danger-fg:      #000000;
    --shadow-1: none;
    --shadow-2: none;
  }
  @page {
    size: A4;
    margin: 16mm 14mm 16mm 14mm;
  }
  html, body {
    background: #fff;
    color: #000;
    font-size: 10.5pt;
    line-height: 1.35;
    font-family: "Blinker", Tahoma, "Helvetica Neue", Arial, sans-serif;
  }

  .no-print { display: none !important; }

  .layout {
    display: block;
    max-width: none;
    padding: 0;
    margin: 0;
  }

  /* Print-titel: subtiele brand-strook bovenaan iedere sectie */
  .card {
    border: none;
    border-top: 1.5pt solid #000;
    border-radius: 0;
    padding: 6mm 0 3mm;
    margin: 0 0 4mm;
    page-break-inside: avoid;
    page-break-before: always;
    background: #fff;
    box-shadow: none;
    overflow: visible;
  }
  .card:first-of-type { page-break-before: auto; }
  #sectie-algemeen::before { display: none; }   /* geen achtergrond-beeldmerk */

  .card > h2 {
    font-size: 15pt;
    border: none;
    padding: 0;
    margin: 0 0 4mm;
  }
  .card > h2::first-letter { color: #000; font-size: 17pt; margin-right: 4pt; }
  .card > h2::after { display: none; }

  /* Brand-stempel rechtsboven op pagina 1 — niet portabel via @page,
     dus we tonen het via een ::after op de eerste sectie. */
  #sectie-algemeen::after {
    content: "Toevast — Woningopname";
    position: absolute;
    top: 0; right: 0;
    font-size: 8pt;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #555;
  }

  h3 { font-size: 11pt; margin: 4mm 0 2mm; }

  /* Velden = onderstreepte regel onder label */
  .field label,
  .field > legend {
    font-size: 8pt;
    text-transform: none;
    letter-spacing: 0;
    color: #444;
    margin: 0 0 1mm;
    font-weight: 700;
  }
  .req { color: #000; }
  input[type="text"],
  input[type="number"],
  input[type="date"],
  select,
  textarea {
    background: transparent !important;
    color: #000;
    border: none;
    border-bottom: 0.5pt solid #888;
    border-radius: 0;
    padding: 1pt 0;
    min-height: 0;
    font-size: 10pt;
    -webkit-appearance: none;
    appearance: none;
  }
  select { background-image: none !important; padding-right: 0; }
  textarea { border: 0.5pt solid #888; padding: 2pt 4pt; min-height: 18mm; }

  .grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 3mm 6mm;
    margin-bottom: 3mm;
  }
  .grid-adres {
    grid-template-columns: 2fr 0.6fr 0.6fr 1fr 1.4fr !important;
  }

  .field-group,
  .subsection {
    border: 0.5pt solid #888;
    border-radius: 0;
    padding: 3mm 4mm;
    margin: 3mm 0;
    background: #fff;
    page-break-inside: avoid;
  }
  .field-group > legend,
  .subsection > legend {
    background: #fff;
    border: none;
    padding: 0 4pt;
    font-size: 9pt;
    color: #000;
  }

  .radio-row, .checkbox-row { gap: 5mm; padding: 0; min-height: 0; }
  .radio-row label,
  .checkbox-row label {
    background: #fff;
    border: none;
    padding: 0;
    min-height: 0;
    font-size: 9.5pt;
    color: #000;
    font-weight: 400;
  }
  .radio-row label:has(input:checked),
  .checkbox-row label:has(input:checked) {
    font-weight: 700;
    background: transparent;
  }
  .radio-row input, .checkbox-row input { accent-color: #000; }

  /* Constructie-rij */
  .constructies-list { gap: 3mm; }
  .constructie {
    background: #fff;
    border: 0.5pt solid #888;
    border-radius: 0;
    padding: 3mm;
    page-break-inside: avoid;
  }
  .constructie-head { border-bottom: 0.3pt solid #ccc; padding-bottom: 2mm; }
  .constructie-code {
    background: #fff;
    border: 0.5pt solid #000;
    color: #000;
    font-family: ui-monospace, "Courier New", monospace;
    padding: 1mm 2mm;
    border-radius: 0;
  }
  .constructie .grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .constructie-toolbar { display: none; }

  /* Plattegronden */
  .plattegronden {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 4mm;
  }
  .plattegrond-slot, .schets {
    background: #fff;
    border: 0.5pt solid #888;
    border-radius: 0;
    padding: 3mm;
    page-break-inside: avoid;
  }
  .foto-preview img {
    max-height: 70mm;
    border-radius: 0;
    border: 0.5pt solid #888;
  }
  .schets > .btn-icon { display: none; }

  .btn, .btn-icon { display: none !important; }
  .validation-errors { display: none !important; }
  [hidden] { display: none !important; }

  *:focus, *:focus-visible {
    box-shadow: none !important;
    outline: none !important;
  }
}
