/* ============================================================
   PORTAL — Flex Stekkerdoos, Jinja2/HTMX-implementatie
   Recreëert de componenten uit de design-handoff
   (components/ + ui_kits/portal/) als gewone CSS-classes.
   Vereist styles.css (tokens) — link die vóór dit bestand.
   ============================================================ */

/* ---- Compat-aliassen ---------------------------------------
   Oudere templates gebruiken inline nog de v0-variabelen
   (--gray-*, --accent-*, --s*). Die wijzen hier naar de
   stekkerdoos-tokens zodat álle pagina's meekleuren totdat ze
   stuk voor stuk zijn omgebouwd. Niet gebruiken in nieuw werk. */
:root {
  --gray-50: var(--surface-2);  --gray-100: var(--off-50);
  --gray-200: var(--line);      --gray-300: var(--off-200);
  --gray-400: var(--off-hole);  --gray-500: var(--muted);
  --gray-600: #4C5F55;          --gray-700: #35463D;
  --gray-800: var(--text-body); --gray-900: var(--ink);
  --accent-50: var(--volt-soft);  --accent-100: rgba(14, 184, 122, .22);
  --accent-500: var(--volt);      --accent-600: var(--volt-ink);
  --accent-700: var(--accent-press);
  --green-100: var(--volt-soft); --green-600: var(--volt); --green-700: var(--volt-ink);
  --amber-100: var(--warn-soft); --amber-700: var(--warn-ink);
  --red-100: var(--alert-soft);  --red-600: #C5503B;       --red-700: var(--alert-ink);
  --s1: var(--space-1); --s2: var(--space-2); --s3: var(--space-3);
  --s4: var(--space-4); --s5: var(--space-6); --s6: var(--space-8);
  --s8: var(--space-12);
  --radius: var(--radius-md);
  /* let op: overschrijft --radius-sm uit de tokens niet — zelfde naam, zelfde rol */
  --shadow-sm: 0 1px 0 rgba(16, 40, 30, .03);
  --shadow: var(--shadow-soft);
  --font: var(--font-sans);
}

/* ---- Basis -------------------------------------------------- */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font: var(--type-body);
  color: var(--text-body);
  background: var(--bg-app);
  -webkit-font-smoothing: antialiased;
}
a { color: var(--text-on-tint); text-decoration: none; }
a:hover { text-decoration: underline; }
h1 {
  font: var(--w-extrabold) var(--fs-display-sm)/var(--lh-tight) var(--font-display);
  letter-spacing: var(--ls-display);
  color: var(--text-strong);
  margin: 0 0 var(--space-1);
}
h2 {
  font: var(--w-bold) var(--fs-section)/var(--lh-snug) var(--font-display);
  letter-spacing: var(--ls-display);
  color: var(--text-strong);
  margin: var(--space-8) 0 var(--space-4);
}
h3 {
  font: var(--w-bold) var(--fs-body-lg)/var(--lh-snug) var(--font-display);
  letter-spacing: var(--ls-display);
  color: var(--text-strong);
  margin: 0 0 var(--space-1);
}

:where(button, input, select, a, [role="switch"]):focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}

/* ---- Iconen (Lucide, inline SVG) ----------------------------- */
.ico {
  width: 18px; height: 18px;
  flex: 0 0 auto;
  stroke: currentColor; fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
  vertical-align: -3px;
}
.ico.sm { width: 14px; height: 14px; vertical-align: -2px; }
.ico.md { width: 16px; height: 16px; vertical-align: -2.5px; }

/* ---- App-shell ----------------------------------------------- */
.app { display: flex; min-height: 100vh; }
.sidebar {
  width: var(--sidebar-w); flex: 0 0 var(--sidebar-w);
  background: var(--surface-card);
  border-right: 1px solid var(--border-default);
  display: flex; flex-direction: column;
  position: sticky; top: 0; height: 100vh;
}
.brand {
  display: flex; align-items: center; gap: 11px;
  padding: var(--space-5) 18px;
  border-bottom: 1px solid var(--border-default);
}
.brand .logo { width: 38px; height: 38px; flex: 0 0 38px; }
.brand .who { display: flex; flex-direction: column; min-width: 0; }
.brand .who b {
  font: var(--w-extrabold) 16px/var(--lh-tight) var(--font-display);
  letter-spacing: var(--ls-display);
  color: var(--text-strong);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.brand .who small {
  font: var(--w-regular) 10.5px/1.4 var(--font-mono);
  letter-spacing: .04em;
  color: var(--text-muted);
  margin-top: 2px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.nav { padding: var(--space-4) var(--space-3); flex: 1; }
.nav .group-label {
  font: var(--w-regular) 10.5px/1.4 var(--font-mono);
  text-transform: uppercase; letter-spacing: var(--ls-label);
  color: var(--text-muted);
  padding: var(--space-2) var(--space-3);
  margin-top: var(--space-2);
}
.nav a {
  display: flex; align-items: center; gap: var(--space-3);
  padding: 10px var(--space-3);
  border-radius: var(--radius-sm);
  color: var(--text-body);
  font-size: 14.5px; font-weight: var(--w-medium);
  margin-bottom: 2px;
  transition: background var(--dur-fast) var(--ease-soft), color var(--dur-fast) var(--ease-soft);
}
.nav a .ico { color: var(--text-muted); }
.nav a:hover { background: var(--surface-nested); text-decoration: none; }
.nav a.active { background: var(--accent-tint); color: var(--text-on-tint); }
.nav a.active .ico { color: var(--accent); }
.nav-badge {
  margin-left: auto; min-width: 20px; height: 20px; padding: 0 6px;
  border-radius: var(--radius-pill);
  background: var(--alert-soft); color: var(--alert-ink);
  font: var(--w-medium) 11px/1 var(--font-mono);
  display: inline-flex; align-items: center; justify-content: center;
}
.sidebar-foot {
  padding: var(--space-3) var(--space-3) var(--space-4);
  border-top: 1px solid var(--border-default);
}
.sidebar-foot a {
  display: flex; align-items: center; gap: 10px;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  color: var(--text-muted); font-size: var(--fs-small);
}
.sidebar-foot a:hover { background: var(--surface-nested); color: var(--text-strong); text-decoration: none; }
.sidebar-foot .avatar {
  width: 30px; height: 30px; flex: 0 0 30px; border-radius: 50%;
  background: var(--accent-tint); color: var(--text-on-tint);
  display: grid; place-items: center;
  font: var(--w-bold) 13px/1 var(--font-display);
}

.main { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.topbar {
  height: 64px;
  background: var(--surface-card);
  border-bottom: 1px solid var(--border-default);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 28px;
  position: sticky; top: 0; z-index: 5;
}
.topbar .crumbs { color: var(--text-muted); font-size: 13.5px; }
.topbar .crumbs b { color: var(--text-strong); font-weight: var(--w-semibold); }
.content { padding: 28px; max-width: var(--content-max); width: 100%; }
.page-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: var(--space-5); margin-bottom: 22px;
}
.page-head p { margin: 6px 0 0; color: var(--text-muted); font-size: var(--fs-body); }

/* Mono-sectielabel ("JOUW STEKKERDOOS") met icoon ervoor */
.sectie-label {
  display: flex; align-items: center; gap: var(--space-2);
  margin: 0 0 var(--space-3);
  font: var(--w-regular) var(--fs-mono-label)/1.4 var(--font-mono);
  text-transform: uppercase; letter-spacing: var(--ls-label);
  color: var(--text-muted);
}
.sectie-label .ico { color: var(--accent); }

/* ---- Socket — het signatuurelement --------------------------- */
.socket {
  display: inline-grid; place-items: center;
  width: 48px; height: 48px; flex: 0 0 auto;
  border-radius: 50%;
  background: var(--off-50);
  border: 1.5px solid var(--line);
  box-shadow: inset 0 1px 2px rgba(16, 40, 30, .10);
  transition: box-shadow var(--dur-base) var(--ease-soft),
              background var(--dur-base) var(--ease-soft),
              border-color var(--dur-base) var(--ease-soft);
}
.socket svg { width: 62%; height: 62%; }
.socket .strip { fill: var(--off-200); }
.socket .gat { fill: var(--off-hole); }
.socket .gat-ring { stroke: transparent; stroke-width: 3; fill: none; }
.socket.aan {
  background: var(--volt-soft);
  border-color: var(--volt);
  box-shadow: 0 0 0 3px rgba(217, 244, 231, .9), 0 0 14px 1px rgba(47, 227, 155, .55);
}
.socket.aan .strip { fill: var(--volt); }
.socket.aan .gat { fill: var(--volt-ink); }
.socket.aan .gat-ring { stroke: var(--volt-bright); }

/* ---- ToolRow — één rij = één tool ----------------------------- */
.toolbord { display: flex; flex-direction: column; gap: 10px; }
.toolrow {
  display: flex; align-items: center; gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-default);
  background: var(--surface-card);
  color: inherit;
  transition: background var(--dur-base) var(--ease-soft),
              border-color var(--dur-base) var(--ease-soft),
              transform var(--dur-fast) var(--ease-soft),
              box-shadow var(--dur-fast) var(--ease-soft);
}
.toolrow:hover { text-decoration: none; transform: translateY(-3px); box-shadow: var(--shadow-soft); }
.toolrow.aan { border-color: var(--volt-soft); background: var(--volt-soft); }
.toolrow .romp { flex: 1; min-width: 0; }
.toolrow .naam {
  font: var(--w-bold) var(--fs-title)/var(--lh-snug) var(--font-display);
  letter-spacing: var(--ls-display);
  color: var(--text-strong);
}
.toolrow .omschrijving {
  font-size: var(--fs-small); color: var(--text-muted);
  margin-top: 2px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.toolrow .meta { margin-top: var(--space-2); display: flex; gap: var(--space-2); align-items: center; flex-wrap: wrap; }
.toolrow .open {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: var(--fs-small); font-weight: var(--w-semibold);
  color: var(--text-on-tint); white-space: nowrap;
}
.toolrow .open .ico { transition: transform var(--dur-fast) var(--ease-soft); }
.toolrow:hover .open .ico { transform: translateX(3px); }
.toolrow .prijs {
  font: var(--w-medium) var(--fs-small)/var(--lh-snug) var(--font-mono);
  color: var(--text-muted); text-align: right; white-space: nowrap;
}
.toolrow.aan .prijs { color: var(--volt-ink); }

/* ---- Meter — bedrag/meterstand met groene accentlijn ---------- */
.meter {
  position: relative;
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  padding: var(--space-5) var(--space-6);
  overflow: hidden;
}
.meter::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: var(--accent);
}
.meter .label {
  font: var(--w-regular) var(--fs-mono-label)/1.4 var(--font-mono);
  letter-spacing: var(--ls-label); text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: var(--space-2);
}
.meter .stand {
  display: flex; align-items: baseline; gap: 4px;
  font: var(--w-medium) 40px/1 var(--font-mono);
  letter-spacing: var(--ls-tight);
  color: var(--text-strong);
}
.meter.sm .stand { font-size: 28px; }
.meter .eenheid { font-size: .6em; color: var(--accent); }
.meter .periode { font-size: 14px; font-weight: var(--w-regular); color: var(--text-muted); margin-left: 4px; }
.meter .sublabel {
  margin-top: var(--space-2);
  font: var(--w-regular) var(--fs-tiny)/1.4 var(--font-mono);
  color: var(--text-muted);
}

/* ---- Badge — status-pill met mono-tekst en LED-stip ------------ */
.badge {
  display: inline-flex; align-items: center; gap: 7px;
  height: 24px; padding: 0 11px;
  border-radius: var(--radius-pill);
  background: var(--surface-nested); color: var(--text-body);
  font: var(--w-medium) var(--fs-tiny)/1 var(--font-mono);
  letter-spacing: .01em; white-space: nowrap;
}
.badge .led { width: 7px; height: 7px; border-radius: 50%; background: var(--muted); flex: 0 0 auto; }
.badge.stroom { background: var(--volt-soft); color: var(--volt-ink); }
.badge.stroom .led { background: var(--volt); box-shadow: 0 0 6px 1px rgba(47, 227, 155, .7); }
.badge.uit { background: var(--off-100); color: var(--muted); }
.badge.uit .led { background: var(--off-hole); }
.badge.warn { background: var(--warn-soft); color: var(--warn-ink); }
.badge.warn .led { background: #D9A22B; }
.badge.alert { background: var(--alert-soft); color: var(--alert-ink); }
.badge.alert .led { background: #C5503B; }

/* ---- Switch — groen = aan ------------------------------------- */
.switch {
  position: relative; width: 48px; height: 28px; flex: 0 0 auto;
  border-radius: var(--radius-pill); border: none; padding: 0;
  cursor: pointer;
  background: var(--off-200);
  box-shadow: inset 0 1px 2px rgba(16, 40, 30, .12);
  transition: background var(--dur-base) var(--ease-soft), box-shadow var(--dur-base) var(--ease-soft);
}
.switch::after {
  content: ""; position: absolute; top: 3px; left: 3px;
  width: 22px; height: 22px; border-radius: 50%;
  background: #fff; box-shadow: 0 1px 3px rgba(16, 40, 30, .28);
  transition: left var(--dur-base) var(--ease-soft);
}
.switch[aria-checked="true"] {
  background: var(--accent);
  box-shadow: 0 0 0 3px rgba(217, 244, 231, .85);
}
.switch[aria-checked="true"]::after { left: 23px; }

/* ---- Knoppen — pill, drie varianten ---------------------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--space-2);
  height: 42px; padding: 0 22px;
  background: var(--accent); color: var(--text-on-volt);
  border: 1px solid transparent;
  border-radius: var(--radius-pill);
  font-family: var(--font-sans); font-size: var(--fs-body); font-weight: var(--w-semibold);
  line-height: 1; cursor: pointer; white-space: nowrap;
  text-decoration: none;
  transition: background var(--dur-fast) var(--ease-soft),
              transform var(--dur-fast) var(--ease-soft),
              box-shadow var(--dur-fast) var(--ease-soft);
}
.btn:hover { background: var(--accent-hover); text-decoration: none; }
.btn:active { background: var(--accent-press); transform: translateY(1px); }
.btn.secundair { background: var(--accent-tint); color: var(--text-on-tint); }
.btn.secundair:hover { background: #CBEFDD; }
.btn.secundair:active { background: #CBEFDD; transform: translateY(1px); }
.btn.ghost { background: transparent; color: var(--text-strong); border-color: var(--border-default); }
.btn.ghost:hover { background: var(--surface-nested); }
.btn.ghost:active { background: var(--surface-nested); transform: translateY(1px); }
.btn.full { width: 100%; }
.btn.sm { height: 34px; padding: 0 14px; font-size: var(--fs-small); }
.btn:disabled { opacity: .5; cursor: not-allowed; transform: none; }

/* ---- Kaarten ---------------------------------------------------- */
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--space-4); }
.card {
  position: relative;
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-card);
  display: block; color: inherit;
  transition: transform var(--dur-fast) var(--ease-soft),
              box-shadow var(--dur-fast) var(--ease-soft),
              border-color var(--dur-fast) var(--ease-soft);
}
a.card:hover { transform: translateY(-3px); box-shadow: var(--shadow-soft); text-decoration: none; }
.card .ticon {
  width: 40px; height: 40px; border-radius: var(--radius-sm);
  background: var(--accent-tint); color: var(--text-on-tint);
  display: grid; place-items: center; font-size: 20px;
  margin-bottom: var(--space-3);
}
.card h3 {
  font: var(--w-bold) var(--fs-body)/var(--lh-snug) var(--font-display);
  letter-spacing: var(--ls-display); color: var(--text-strong);
}
.card p { margin: 0; color: var(--text-muted); font-size: var(--fs-small); }
.card .meta { margin-top: var(--space-4); display: flex; gap: var(--space-2); align-items: center; }
.card-badge {
  position: absolute; top: var(--space-4); right: var(--space-4);
  min-width: 22px; height: 22px; padding: 0 7px;
  border-radius: var(--radius-pill);
  background: var(--alert-soft); color: var(--alert-ink);
  font: var(--w-medium) 12px/1 var(--font-mono);
  display: inline-flex; align-items: center; justify-content: center;
}

/* Oude status-pills/tags — herskind op badge-toon */
.tag {
  display: inline-flex; align-items: center;
  height: 22px; padding: 0 10px;
  border-radius: var(--radius-pill);
  background: var(--surface-nested); color: var(--text-body);
  font: var(--w-medium) 11.5px/1 var(--font-mono);
}
.tag.tool { background: var(--volt-soft); color: var(--volt-ink); }
.tag.ef { background: var(--warn-soft); color: var(--warn-ink); }
.pill {
  display: inline-flex; align-items: center; gap: 5px;
  height: 24px; padding: 0 11px;
  border-radius: var(--radius-pill);
  font: var(--w-medium) var(--fs-tiny)/1 var(--font-mono);
}
.pill.ok { background: var(--volt-soft); color: var(--volt-ink); }
.pill.off { background: var(--off-100); color: var(--muted); }
.pill.warn { background: var(--warn-soft); color: var(--warn-ink); }

/* ---- Split / panels --------------------------------------------- */
.split { display: grid; grid-template-columns: 380px 1fr; gap: 22px; align-items: start; }
.panel {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
}
.panel .phead {
  padding: var(--space-4) var(--space-6);
  border-bottom: 1px solid var(--border-default);
  font: var(--w-bold) var(--fs-body)/var(--lh-snug) var(--font-display);
  letter-spacing: var(--ls-display);
  color: var(--text-strong);
}
.panel .pbody { padding: var(--space-6); }

/* ---- Formulieren -------------------------------------------------- */
.field { margin-bottom: var(--space-4); }
.field label {
  display: block;
  font-weight: var(--w-semibold); font-size: var(--fs-small);
  color: var(--text-strong);
  margin-bottom: 6px;
}
.field .hint { font-size: var(--fs-tiny); color: var(--text-muted); margin-top: 5px; }
.field .req { color: #C5503B; }
.field input[type=text], .field input[type=password], .field input[type=number],
.field input[type=date], .field select, .field input:not([type]) {
  width: 100%; height: 44px; padding: 0 14px;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-sm);
  background: var(--surface-card);
  font: var(--type-body); color: var(--text-strong);
  outline: none;
  transition: border-color var(--dur-fast) var(--ease-soft), box-shadow var(--dur-fast) var(--ease-soft);
}
.field input::placeholder { color: var(--text-muted); opacity: .7; }
.field input[type=file] { font-size: var(--fs-small); color: var(--text-muted); }
.field input:focus, .field select:focus {
  border-color: var(--accent);
  box-shadow: var(--focus-ring);
}

/* ---- Inline Easyflex-picker: zoeken + chip + uitklaplijst -------- */
.combo { position: relative; }
.combo-control {
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
  min-height: 44px; padding: 6px 10px;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-sm);
  background: var(--surface-card); cursor: text;
  transition: border-color var(--dur-fast) var(--ease-soft), box-shadow var(--dur-fast) var(--ease-soft);
}
.combo-control:focus-within { border-color: var(--accent); box-shadow: var(--focus-ring); }
.combo-control input[type=text] {
  border: 0; outline: 0; flex: 1; min-width: 90px; width: auto; height: 28px;
  padding: 0; font: var(--type-body); color: var(--text-strong); background: transparent;
}
.combo-control input[type=text]:focus { box-shadow: none; }
.combo .chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--accent-tint); color: var(--text-on-tint);
  border-radius: var(--radius-pill);
  padding: 3px 6px 3px 11px;
  font-size: var(--fs-small); font-weight: var(--w-medium);
}
.combo .chip button {
  border: 0; background: transparent; color: var(--text-on-tint);
  cursor: pointer; font-size: 15px; line-height: 1; padding: 0;
}
.combo-menu {
  position: absolute; left: 0; right: 0; top: 100%;
  background: var(--surface-card);
  border: 1px solid var(--accent); border-top: 0;
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  box-shadow: var(--shadow-soft);
  max-height: 240px; overflow: auto; z-index: 20;
}
.combo-menu:empty { display: none; }
.combo-opt { padding: 9px 14px; cursor: pointer; display: flex; justify-content: space-between; gap: var(--space-2); }
.combo-opt:hover { background: var(--accent-tint); }
.combo-opt .sub { color: var(--text-muted); font: var(--w-regular) var(--fs-tiny)/1.4 var(--font-mono); }
.combo-empty { padding: 10px 14px; color: var(--text-muted); font-size: var(--fs-small); }
.combo-foot {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 14px; border-top: 1px solid var(--border-default);
  color: var(--text-muted);
  font: var(--w-regular) var(--fs-tiny)/1.4 var(--font-mono);
}
.combo-foot .ico { color: var(--accent); width: 12px; height: 12px; }

/* ---- AI-spinner ---------------------------------------------------- */
@keyframes spin { to { transform: rotate(360deg); } }
.spin {
  display: inline-block; width: 13px; height: 13px;
  border: 2px solid currentColor; border-top-color: transparent;
  border-radius: 50%; animation: spin .6s linear infinite;
  opacity: .75; vertical-align: -2px;
}
.btn-spin { display: none; align-items: center; gap: var(--space-2); }
form.htmx-request .btn-label { display: none; }
form.htmx-request .btn-spin { display: inline-flex; }
form.htmx-request button[type=submit] { opacity: .9; pointer-events: none; }
.ai-word { font-variant: small-caps; letter-spacing: .02em; min-width: 8.5rem; text-align: left; }
.ef-spin { display: none; flex: 0 0 auto; color: var(--accent); }
.combo-control input.htmx-request ~ .ef-spin { display: inline-block; }

/* ---- Veel-velden formulier ------------------------------------------ */
.veld-filter-wrap {
  position: sticky; top: 64px;
  background: var(--surface-card);
  padding: var(--space-2) 0 var(--space-3); margin-bottom: var(--space-2);
  z-index: 4;
}
.veld-filter {
  width: 100%; height: 44px; padding: 0 14px;
  border: 1px solid var(--border-default); border-radius: var(--radius-sm);
  font: var(--type-body); color: var(--text-strong);
  outline: none; background: var(--surface-card);
  transition: border-color var(--dur-fast) var(--ease-soft), box-shadow var(--dur-fast) var(--ease-soft);
}
.veld-filter:focus { border-color: var(--accent); box-shadow: var(--focus-ring); }
.veld-list .field.gewijzigd > label::after {
  content: "• gewijzigd"; margin-left: 6px;
  font: var(--w-medium) 11px/1 var(--font-mono);
  color: var(--volt-ink);
}
.veld-list .field.gewijzigd input[type=text], .veld-list .field.gewijzigd input[type=number],
.veld-list .field.gewijzigd input[type=date], .veld-list .field.gewijzigd select,
.veld-list .field.gewijzigd .checkset { border-color: var(--accent); box-shadow: var(--focus-ring); }
.save-bar {
  position: sticky; bottom: 0;
  background: var(--surface-card);
  border-top: 1px solid var(--border-default);
  padding: var(--space-3) 0 var(--space-2); margin-top: var(--space-4);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4);
}
.save-bar .save-info { color: var(--text-muted); font-size: var(--fs-small); }
.save-bar .save-info .wijzig-teller { font: var(--w-medium) var(--fs-small)/1 var(--font-mono); color: var(--off-hole); }
.save-bar.heeft-wijzigingen .save-info .wijzig-teller { color: var(--volt-ink); }
.save-bar .btn { min-width: 150px; }

/* ---- Staten ----------------------------------------------------------- */
.empty-state { text-align: center; color: var(--text-muted); padding: var(--space-12) var(--space-6); }
.empty-state .big { font-size: 34px; display: block; margin-bottom: var(--space-3); opacity: .5; }
.empty-state .socket { margin: 0 auto var(--space-4); display: grid; }
.empty-state .ico { width: 30px; height: 30px; color: var(--off-200); display: block; margin: 0 auto var(--space-3); }
.empty-state b { color: var(--text-strong); }
.fout {
  background: var(--alert-soft); color: var(--alert-ink);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-sm);
}

/* Meldingsbanners — licht, status blijft rustig */
.banner {
  display: flex; align-items: center; gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-4);
  font-size: var(--fs-body);
}
.banner.ok { background: var(--volt-soft); color: var(--volt-ink); }
.banner.warn { background: var(--warn-soft); color: var(--warn-ink); }
.banner.fout { background: var(--alert-soft); color: var(--alert-ink); }
.banner.info { background: var(--surface-nested); color: var(--text-body); }

/* Mono-subtekst (slugs, registratienummers, specs) */
.mono-sub {
  font: var(--w-regular) var(--fs-tiny)/1.4 var(--font-mono);
  color: var(--text-muted);
}

/* Terug-link boven een detailpagina */
.terug {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 13.5px; color: var(--text-muted);
  margin-bottom: 14px;
}
.terug:hover { color: var(--text-strong); text-decoration: none; }

/* ---- Kerncijfers (mini-meters) ----------------------------------------- */
.stat-row { display: flex; gap: var(--space-4); flex-wrap: wrap; margin-bottom: 22px; }
.stat {
  position: relative; overflow: hidden;
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  padding: var(--space-4) var(--space-5);
  min-width: 140px;
}
.stat::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: var(--accent);
}
.stat .label {
  font: var(--w-regular) var(--fs-mono-label)/1.4 var(--font-mono);
  color: var(--text-muted);
  text-transform: uppercase; letter-spacing: var(--ls-label);
}
.stat .value {
  font: var(--w-medium) 28px/1.1 var(--font-mono);
  letter-spacing: var(--ls-tight);
  color: var(--text-strong);
  margin-top: 4px;
}

/* ---- Tabellen ------------------------------------------------------------ */
table.data { width: 100%; border-collapse: collapse; font-size: var(--fs-small); }
table.data thead th {
  background: var(--surface-nested); color: var(--text-muted);
  text-align: left; padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--border-default);
  font: var(--w-regular) var(--fs-mono-label)/1.4 var(--font-mono);
  text-transform: uppercase; letter-spacing: var(--ls-label);
}
table.data tbody td { padding: var(--space-2) var(--space-3); border-bottom: 1px solid var(--off-50); }
table.data tbody tr:nth-child(even) { background: var(--surface-nested); }

/* Groene download-banner — staat altijd bovenaan het resultaat */
.download {
  display: flex; align-items: center; gap: 14px;
  padding: 14px;
  border: 1px solid #BCE8D4;
  border-radius: var(--radius-sm);
  background: var(--volt-soft);
  margin-bottom: var(--space-4);
}
.download .fic {
  width: 36px; height: 36px; flex: 0 0 36px; border-radius: 50%;
  background: var(--accent); color: var(--text-on-volt);
  display: grid; place-items: center;
}
.download .fic .ico { width: 20px; height: 20px; }
.download .grow { flex: 1; min-width: 0; }
.download .ftitel { font-weight: var(--w-semibold); color: var(--volt-ink); }
.download .fname { font: var(--w-regular) 12px/1.4 var(--font-mono); color: var(--volt-ink); opacity: .85; }

.table-wrap {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-card);
}
table.beheer { width: 100%; border-collapse: collapse; font-size: var(--fs-body); }
table.beheer thead th {
  background: var(--surface-nested); text-align: left;
  padding: var(--space-3) var(--space-4);
  color: var(--text-muted);
  font: var(--w-regular) var(--fs-mono-label)/1.4 var(--font-mono);
  text-transform: uppercase; letter-spacing: var(--ls-label);
  border-bottom: 1px solid var(--border-default);
}
table.beheer tbody td { padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--off-50); }
table.beheer tbody tr:hover { background: var(--surface-nested); }
table.beheer .num { text-align: right; font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
.settings-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
section { margin: var(--space-6) 0; }

/* ---- Login ------------------------------------------------------------------ */
.auth-body { min-height: 100vh; display: grid; place-items: center; background: var(--bg-app); }
.auth-kolom { width: 380px; max-width: 92vw; }
.auth-merk { text-align: center; margin-bottom: var(--space-5); }
.auth-merk .logo { width: 60px; height: 60px; }
.auth-merk .naam {
  font: var(--w-extrabold) 26px/var(--lh-tight) var(--font-display);
  letter-spacing: var(--ls-display);
  color: var(--text-strong);
  margin-top: var(--space-3);
}
.auth-merk .sub { color: var(--text-muted); font-size: var(--fs-small); margin-top: 4px; }
.auth-card {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  padding: var(--space-6);
}
.auth-voet {
  text-align: center; margin-top: var(--space-4);
  font: var(--w-regular) var(--fs-tiny)/1.4 var(--font-mono);
  color: var(--text-muted);
}

/* ---- Inactiviteit: "ben je er nog?"-modal ------------------------------- */
.idle-overlay {
  position: fixed; inset: 0; z-index: 1000;
  display: none; align-items: center; justify-content: center;
  background: rgba(16, 40, 30, .45);
  padding: var(--space-4);
}
.idle-overlay.open { display: flex; }
.idle-modal {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  padding: var(--space-6);
  max-width: 420px; width: 100%;
  text-align: center;
}
.idle-modal h2 { margin: 0 0 var(--space-2); color: var(--text-strong); }
.idle-modal p { margin: 0 0 var(--space-2); color: var(--text-muted); font-size: var(--fs-body); }
.idle-modal .idle-aftel {
  font: var(--w-semibold) 30px/1 var(--font-mono);
  color: var(--accent); margin: var(--space-4) 0;
}
.idle-modal .idle-acties {
  display: flex; gap: var(--space-3); justify-content: center; margin-top: var(--space-5);
}

/* ---- Responsief & motion ------------------------------------------------------ */
@media (max-width: 900px) {
  .split, .settings-grid { grid-template-columns: 1fr; }
  .sidebar { display: none; }
  .page-head { flex-direction: column; align-items: stretch; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    transition-duration: 0s !important;
    animation-duration: 0s !important;
  }
}
