/* Basis: reset, chrome, knoppen, badges, formulieren, modal, toast — HiX-stijl. */

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: var(--font-ui);
  color: var(--c-ink);
  background: var(--c-bg);
  font-size: 12.5px;
  line-height: 1.4;
}
h1, h2, h3, h4 { margin: 0; font-weight: 600; line-height: 1.2; }
a { color: var(--c-accent); text-decoration: none; }
a:hover { text-decoration: underline; }
button { font-family: inherit; }

.eyebrow {
  font-size: 10.5px; font-weight: 700; letter-spacing: .06em;
  text-transform: uppercase; color: var(--c-ink-3);
}
.mono { font-family: var(--font-data); font-variant-numeric: tabular-nums; }

/* ---------- Topbar ---------- */
.topbar {
  position: sticky; top: 0; z-index: 40;
  display: flex; align-items: center; gap: var(--sp-4);
  padding: 0 var(--sp-3);
  height: 44px;
  background: var(--c-chrome);
  color: var(--c-chrome-ink);
  border-bottom: 1px solid #06243a;
}
.brand { display: flex; align-items: center; gap: 8px; font-weight: 700; font-size: 14px; }
.brand .mark {
  width: 24px;
  height: 24px;
  display: inline-block;
  background: url('assets/zsa.png') center center / contain no-repeat;
  border-radius: 6px;
}

.brand .mark::before {
  content: none;
}
.brand small { display: block; font-weight: 400; font-size: 10.5px; color: var(--c-chrome-ink-2); }
.topbar .spacer { flex: 1; }
.topbar .klok { font-family: var(--font-data); font-size: 13px; }
.topbar .verbinding { display: flex; align-items: center; gap: 6px; font-size: 11.5px; color: var(--c-chrome-ink-2); }
.topbar .verbinding .stip { width: 8px; height: 8px; border-radius: 50%; background: var(--c-ink-3); }
.topbar .verbinding.live .stip { background: #4cd07d; }
.topbar .verbinding.weg .stip { background: var(--t-oranje); }

.topnav { display: flex; gap: 1px; }
.topnav a {
  color: var(--c-chrome-ink-2); padding: 6px 12px; border-radius: 2px;
  font-weight: 600; font-size: 12px;
}
.topnav a:hover { background: rgba(255,255,255,.08); color: #fff; text-decoration: none; }
.topnav a.actief { background: var(--c-paneelkop); color: #fff; }

/* ---------- Knoppen ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 11px; border-radius: var(--r-sm);
  border: 1px solid var(--c-line); background: linear-gradient(180deg,#fff,#eef2f6);
  color: var(--c-ink); font-weight: 600; font-size: 12px; cursor: pointer;
}
.btn:hover { background: linear-gradient(180deg,#fff,#e2e9ef); }
.btn:active { background: #e2e9ef; }
.btn-primair { background: linear-gradient(180deg,var(--c-paneelkop-2),var(--c-paneelkop)); border-color: #245a7e; color: #fff; }
.btn-primair:hover { background: linear-gradient(180deg,#3d86b3,#2a6991); }
.btn-gevaar { color: var(--c-alert); border-color: #d8a59f; background: linear-gradient(180deg,#fff,#f7eceb); }
.btn-gevaar:hover { background: var(--t-rood-zacht); }
.btn-stil { border-color: transparent; background: transparent; color: var(--c-accent); }
.btn-stil:hover { background: var(--c-surface-3); }
.btn-sm { padding: 3px 7px; font-size: 11.5px; }
.btn:disabled { opacity: .5; cursor: not-allowed; }

/* ---------- Velden ---------- */
.veld { display: flex; flex-direction: column; gap: 3px; }
.veld > label { font-size: 11.5px; font-weight: 600; color: var(--c-ink-2); }
.invoer, select.invoer, textarea.invoer {
  width: 100%; padding: 5px 7px; font-family: inherit; font-size: 12.5px;
  border: 1px solid var(--c-line); border-radius: var(--r-sm);
  background: var(--c-surface); color: var(--c-ink);
}
.invoer:focus { outline: none; border-color: var(--c-accent); box-shadow: 0 0 0 2px var(--c-accent-soft); }
textarea.invoer { resize: vertical; min-height: 58px; }

/* ---------- Badges ---------- */
.badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 1px 7px; border-radius: var(--r-sm); font-size: 11.5px; font-weight: 700;
  border: 1px solid var(--c-line);
}
.kleur-badge { color: #fff; border: none; }
.kleur-rood { background: var(--t-rood); }
.kleur-oranje { background: var(--t-oranje); }
.kleur-geel { background: var(--t-geel); color: #4a3b00; }
.kleur-groen { background: var(--t-groen); }
.kleur-blauw { background: var(--t-blauw); }
.kleur-leeg { background: var(--c-surface-3); color: var(--c-ink-3); }

.ews-pil {
  display: inline-flex; align-items: baseline; gap: 4px;
  padding: 1px 7px; border-radius: var(--r-sm); font-weight: 700; color: #fff;
  font-family: var(--font-data);
}
.ews-pil small { font-weight: 600; font-size: 9.5px; opacity: .9; font-family: var(--font-ui); }
.ews-laag { background: var(--ews-laag); }
.ews-midden { background: var(--ews-midden); }
.ews-hoog { background: var(--ews-hoog); }
.ews-leeg { background: var(--c-surface-3); color: var(--c-ink-3); }

.status-pil {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 2px 8px; border-radius: var(--r-sm); font-size: 11.5px; font-weight: 600;
  background: var(--c-surface-3); color: var(--c-ink-2); border: 1px solid var(--c-line-2);
}
.status-pil::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--c-ink-3); }
.status-behandeling::before, .status-onderzoek-loopt::before { background: var(--c-accent); }
.status-wachtend::before, .status-aangemeld::before, .status-in-triage::before { background: var(--t-oranje); }
.status-wacht-op-bed::before { background: var(--t-blauw); }
.status-opgenomen::before { background: var(--ews-laag); }
.status-ontslagen::before { background: var(--c-ink-3); }

/* ---------- Modal ---------- */
.overlay {
  position: fixed; inset: 0; z-index: 60;
  background: rgba(15, 58, 89, .4);
  display: grid; place-items: start center; padding: 4vh 16px; overflow: auto;
}
.modal {
  width: 100%; max-width: 720px; background: var(--c-surface);
  border: 1px solid #0c3148; border-radius: var(--r-lg); box-shadow: var(--schaduw-3);
}
.modal-groot { max-width: 880px; }
.modal-kop {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 14px; background: var(--c-chrome); color: var(--c-chrome-ink);
}
.modal-kop h2 { font-size: 14px; font-weight: 600; }
.modal-body { padding: var(--sp-4); }
.modal-voet {
  display: flex; justify-content: flex-end; gap: var(--sp-2);
  padding: 8px var(--sp-4); border-top: 1px solid var(--c-line-2);
  background: var(--c-surface-2);
}
.sluit-x { border: none; background: none; font-size: 18px; cursor: pointer; color: var(--c-chrome-ink-2); line-height: 1; }
.sluit-x:hover { color: #fff; }

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
.grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--sp-3); }
.vol { grid-column: 1 / -1; }

/* ---------- Toast ---------- */
.toast-laag { position: fixed; bottom: 16px; right: 16px; z-index: 80; display: flex; flex-direction: column; gap: 7px; }
.toast {
  background: var(--c-chrome); color: #fff; padding: 9px 14px; border-radius: var(--r-sm);
  box-shadow: var(--schaduw-2); font-size: 12.5px; max-width: 340px;
  border-left: 3px solid var(--c-paneelkop-2);
}
.toast.fout { border-left-color: var(--t-rood); }
.toast.ok { border-left-color: var(--ews-laag); }

/* ---------- Combobox ---------- */
.combobox { position: relative; }
.combobox-lijst {
  position: absolute; left: 0; right: 0; top: 100%; z-index: 50;
  background: #fff; border: 1px solid var(--c-line); border-top: none;
  max-height: 230px; overflow: auto; box-shadow: var(--schaduw-2);
}
.combobox-optie { padding: 5px 8px; font-size: 12.5px; cursor: pointer; }
.combobox-optie:hover, .combobox-optie.actief { background: var(--c-selectie); }
.combobox-optie small { color: var(--c-ink-3); margin-left: 6px; }
.combobox-leeg { padding: 6px 8px; font-size: 12px; color: var(--c-ink-3); }

/* ---------- Patiëntzoeker (burgers uit SnailyCad) ---------- */
.bz { display: flex; flex-direction: column; gap: var(--sp-3); }
.bz-zoekbalk {
  display: grid; grid-template-columns: 1.2fr 1.4fr 1fr 1fr; gap: var(--sp-3);
  padding: var(--sp-3); background: var(--c-surface-2); border: 1px solid var(--c-line-2); border-radius: var(--r-md);
}
.bz-veld { display: flex; flex-direction: column; gap: 3px; }
.bz-veld > label { font-size: 11px; font-weight: 600; color: var(--c-ink-2); }
.bz-teller { font-size: 11px; color: var(--c-ink-3); font-family: var(--font-data); }
.bz-lijst {
  max-height: 46vh; overflow: auto;
  border: 1px solid var(--c-line); border-radius: var(--r-md); background: var(--c-surface);
}
.bz-rij {
  display: flex; flex-direction: column; gap: 1px;
  padding: 6px 10px; border-bottom: 1px solid var(--c-line-2); cursor: pointer;
}
.bz-rij:hover, .bz-rij:focus { background: var(--c-selectie); outline: none; }
.bz-rij.overleden { opacity: .72; }
.bz-r1 { display: flex; align-items: center; gap: 8px; }
.bz-naam { font-weight: 700; font-size: 13px; }
.bz-gesl { font-family: var(--font-data); font-size: 11px; color: var(--c-ink-3); border: 1px solid var(--c-line-2); border-radius: 2px; padding: 0 4px; }
.bz-r2 { font-size: 11.5px; color: var(--c-ink-2); font-family: var(--font-data); }
.bz-dood { color: var(--t-rood); font-weight: 700; font-size: 11px; }
.bz-leeg { padding: 14px; color: var(--c-ink-3); font-size: 12px; text-align: center; }

/* ---------- Gekoppelde burger in de aanmelding ---------- */
.aanmeld-burger { margin-bottom: 4px; }
.burger-leeg {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 8px 10px; background: var(--c-surface-2); border: 1px dashed var(--c-line);
  border-radius: var(--r-md); font-size: 12px; color: var(--c-ink-2);
}
.burger-leeg span { flex: 1; min-width: 200px; }
.burger-chip {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; background: var(--c-accent-soft); border: 1px solid var(--c-accent-2);
  border-radius: var(--r-md);
}
.burger-chip-tekst { flex: 1; min-width: 0; }
.burger-chip-naam { font-weight: 700; font-size: 13px; display: flex; gap: 8px; align-items: center; }
.burger-chip-info { font-size: 11.5px; color: var(--c-ink-2); font-family: var(--font-data); }
.burger-chip-acties { display: flex; gap: 6px; flex: 0 0 auto; }
.burger-hist { margin-top: 4px; font-size: 11px; color: var(--c-ink-3); font-family: var(--font-data); }

/* ---------- Read-only velden (komen uit SnailyCad / aangemelde persoon) ---------- */
.invoer-vast {
  background: var(--c-surface-3, #eef2f6); color: var(--c-ink-2);
  cursor: not-allowed; opacity: .9;
}
.burger-vast-hint {
  display: flex; align-items: center; gap: 6px; margin-bottom: 10px;
  padding: 7px 10px; font-size: 12px; color: var(--c-ink-2);
  background: var(--c-surface-2); border: 1px solid var(--c-line-2); border-radius: var(--r-md);
}

/* ---------- "Aanmelden als" ---------- */
.aangemeld-chip {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 5px 11px; margin-right: 4px; cursor: pointer;
  background: var(--c-surface-2); color: var(--c-ink);
  border: 1px solid var(--c-line-2); border-radius: 999px;
  font-size: 12px; font-weight: 600;
}
.aangemeld-chip:hover { background: var(--c-selectie); }
.aangemeld-punt { width: 8px; height: 8px; border-radius: 50%; background: var(--t-groen, #2e9e5b); flex: 0 0 auto; }
.aangemeld-label { white-space: nowrap; max-width: 240px; overflow: hidden; text-overflow: ellipsis; }
.aanmeld-uitleg { font-size: 12px; color: var(--c-ink-2); }
.bz-zoekbalk-enkel {
  padding: var(--sp-3); background: var(--c-surface-2);
  border: 1px solid var(--c-line-2); border-radius: var(--r-md);
}

/* ---------- Medicatiezoeker (BCFI autocomplete) ---------- */
.med-zoek { position: relative; }
.med-zoek-lijst {
  position: absolute; left: 0; right: 0; top: 100%; z-index: 70;
  background: #fff; border: 1px solid var(--c-line); border-top: none;
  max-height: 280px; overflow: auto; box-shadow: var(--schaduw-2);
}
.med-optie { padding: 6px 9px; cursor: pointer; border-bottom: 1px solid var(--c-line-2); }
.med-optie:hover, .med-optie.actief { background: var(--c-selectie); }
.med-optie-top { display: flex; align-items: center; gap: 7px; }
.med-naam { font-weight: 700; font-size: 12.5px; }
.med-optie-sub { font-size: 11px; color: var(--c-ink-3); font-family: var(--font-data); margin-top: 1px; }
.med-zoek-leeg { padding: 8px 10px; font-size: 12px; color: var(--c-ink-3); }
.med-vlag {
  font-size: 9.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em;
  padding: 0 5px; border-radius: 3px; line-height: 1.6;
}
.med-vlag.spoed { background: var(--t-rood, #e74c3c); color: #fff; }
.med-vlag.narc { background: #4a3b00; color: #ffd86b; }

/* ---------- Thuismedicatie-beheer ---------- */
.thuismed-lijst { display: flex; flex-direction: column; gap: 6px; }
.thuismed-rij {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  padding: 7px 9px; border: 1px solid var(--c-line-2); border-radius: var(--r-sm); background: var(--c-surface-2);
}
.thuismed-info { flex: 1 1 150px; min-width: 0; }
.thuismed-naam { font-weight: 700; font-size: 12.5px; display: flex; align-items: center; gap: 6px; }
.thuismed-sub { font-size: 11px; color: var(--c-ink-3); font-family: var(--font-data); }
.thuismed-schema { display: flex; align-items: center; gap: 3px; }
.thuismed-schema-lbl { font-size: 9.5px; color: var(--c-ink-3); margin-right: 2px; letter-spacing: .02em; }
.thuismed-slot { width: 34px; text-align: center; padding: 6px 2px; }

/* ---------- Patiëntenzoeker (spoedbord) ---------- */
.pz-groep { border-bottom: 1px solid var(--c-line-2); }
.pz-kop { display: flex; align-items: center; gap: 10px; padding: 8px 10px; }
.pz-id { flex: 1; min-width: 0; }
.pz-naam { font-weight: 700; font-size: 13px; display: flex; align-items: center; gap: 8px; }
.pz-sub { font-size: 11.5px; color: var(--c-ink-2); font-family: var(--font-data); }
.pz-acties { display: flex; gap: 6px; flex: 0 0 auto; flex-wrap: wrap; justify-content: flex-end; }
.pz-tag { font-size: 9.5px; font-weight: 700; text-transform: uppercase; padding: 0 5px; border-radius: 3px; }
.pz-tag.burger { background: var(--c-accent-soft); color: var(--c-accent); border: 1px solid var(--c-accent-2); }
.pz-tag.lokaal { background: var(--c-surface-3); color: var(--c-ink-3); border: 1px solid var(--c-line-2); }
.pz-bezoeken { padding: 0 10px 10px 10px; display: flex; flex-direction: column; gap: 4px; }
.pz-bezoeken .hist-rij {
  display: flex; align-items: center; gap: 10px; padding: 6px 8px;
  border: 1px solid var(--c-line-2); border-radius: var(--r-sm); background: var(--c-surface);
}
.pz-bezoeken .hist-rij:hover { background: var(--c-selectie); text-decoration: none; }
.pz-bezoeken .hist-datum { font-size: 11px; color: var(--c-ink-3); min-width: 96px; }
.pz-bezoeken .hist-tekst { flex: 1; min-width: 0; }
.pz-bezoeken .hist-titel { font-weight: 600; font-size: 12px; color: var(--c-ink); }
.pz-bezoeken .hist-sub { font-size: 11px; color: var(--c-ink-3); }

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

/* ---------- Burgerzoeker: secties (SnailyCad + lokaal) ---------- */
.bz-sectie { margin-bottom: 10px; }
.bz-sectie-kop {
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em;
  color: var(--c-ink-3); padding: 6px 2px 4px; border-bottom: 1px solid var(--c-line-2);
  display: flex; align-items: center; gap: 8px;
}
.bz-sectie-tel { background: var(--c-surface-3); border-radius: 8px; padding: 0 7px; font-size: 10.5px; }

/* ---------- Triage-cascade (aanmelding + EPD-triageformulier) ---------- */
.cascade { margin-top: 4px; }
.cascade-hint { font-size: 12px; color: var(--c-ink-2); padding: 6px 0; }
.cascade-stap { border: 1px solid var(--c-line); border-radius: var(--r-md); overflow: hidden; background: var(--c-surface); }
.cascade-kop { display: flex; align-items: center; gap: 8px; padding: 6px 10px; background: var(--c-surface-2); border-bottom: 1px solid var(--c-line-2); }
.cascade-doel { font-size: 11.5px; color: var(--c-ink-2); }
.cascade-teller { margin-left: auto; font-size: 10.5px; color: var(--c-ink-3); }
.cascade-vragen { padding: 4px 10px; max-height: 220px; overflow: auto; }
.cascade-vraag { display: flex; align-items: flex-start; gap: 8px; padding: 4px 0; font-size: 12.5px; cursor: pointer; border-bottom: 1px solid var(--c-line-2); }
.cascade-vraag:last-child { border-bottom: none; }
.cascade-vraag input { margin-top: 2px; }
.cascade-acties { display: flex; gap: 8px; align-items: center; padding: 8px 10px; border-top: 1px solid var(--c-line-2); background: var(--c-surface-2); flex-wrap: wrap; }
.cascade-acties .btn-stil:nth-child(2) { margin-left: auto; }
.cascade-bevestigd { display: flex; align-items: center; gap: 10px; padding: 8px 10px; border: 1px solid var(--c-line); border-radius: var(--r-md); background: var(--c-surface-2); }
.cascade-handmatig { padding: 4px 0; }
