/* Tippietip — Swiss grid stijl (rebrand v2). Inter font, witte achtergrond,
   1px scheidingslijnen, geen schaduwen, KPI's met 3px status-balk. */
:root {
  /* Surfaces & text */
  --bg:               #ffffff;
  --bg-soft:          #fafafa;
  --bg-hover:         #f5f5f5;
  --text-primary:     #1a1a1a;
  --text-secondary:   #6b6b6b;
  --text-tertiary:    #999999;
  --border:           #e5e5e5;
  --border-strong:    #1a1a1a;

  /* Signaal */
  --status-ok:        #00875a;
  --status-bad:       #d4351c;
  --status-neutral:   #6b6b6b;

  /* Legacy aliases — bestaande regels gebruiken nog deze namen */
  --cream:    var(--bg);
  --cream-2:  var(--bg-hover);
  --donker:   var(--text-primary);
  --grijs:    var(--text-secondary);
  --hairline: var(--border);
  --mosterd:        var(--text-primary);
  --mosterd-soft:   var(--bg-hover);
  --status-warn:    var(--status-bad);

  --card-bg:        var(--bg);
  --card-border:    var(--border);
  --card-shadow:    none;
}
body.dark {
  --bg:             #0e0e0e;
  --bg-soft:        #161616;
  --bg-hover:       #1c1c1c;
  --text-primary:   #f0f0f0;
  --text-secondary: #b0b0b0;
  --text-tertiary:  #707070;
  --border:         #2a2a2a;
  --border-strong:  #f0f0f0;
  --status-ok:      #4cc38a;
  --status-bad:     #ff5f5f;
  --card-shadow:    none;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg);
  color: var(--text-primary);
  font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.5;
  min-height: 100vh;
  font-feature-settings: "ss01", "cv11";   /* Inter alt-cijfers */
  font-variant-numeric: tabular-nums;
  animation: fade-in 150ms ease-out;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
@supports (font-variation-settings: normal) {
  body { font-family: "Inter var", Inter, system-ui, sans-serif; }
}
/* Mono alleen voor cijfertabellen, factuur-IDs, code */
.data-table .num, code, .phone, kbd { font-family: "JetBrains Mono", "IBM Plex Mono", monospace; }
@keyframes fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ── Topbar ──────────────────────────────────────────── */
.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--border);
  padding: 14px 24px;
  background: var(--bg);
  position: sticky;
  top: 0;
  z-index: 50;
}
.brand { display: flex; align-items: center; gap: 12px; }
.brand-mark {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: inherit;
  font-weight: 600;
  font-size: 14px;
  color: var(--text-primary);
  letter-spacing: 0;
  text-transform: lowercase;
  text-decoration: none;
}
.brand-mark::before {
  content: "";
  display: inline-block;
  width: 14px; height: 14px;
  background: var(--text-primary);
}
.brand-mark img { display: none; }     /* oude logo-images uit */
.brand-mark .amp { display: none; }    /* legacy */
.brand-sub { display: none; }          /* legacy */
.page-title {
  font-family: inherit;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--text-tertiary);
  margin-left: 4px;
}
body.dark .page-title { color: var(--text-tertiary); }
/* ── Page title (next to brand mark) ──────────────────── */
.page-title {
  font-family: inherit;
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--donker);
  margin-left: 8px;
}
body.dark .page-title { color: var(--cream); }

/* ── Hamburger button ────────────────────────────────── */
.menu-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 2px;
  color: var(--text-primary);
  padding: 6px 10px;
  font-family: inherit;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  cursor: pointer;
  transition: border-color 120ms, background 120ms;
}
.menu-btn:hover { border-color: var(--text-primary); background: var(--bg-hover); color: var(--text-primary); }
.menu-btn-icon { width: 16px; height: 16px; }
body.dark .menu-btn { color: var(--text-primary); border-color: var(--border); }
body.dark .menu-btn:hover { background: var(--bg-hover); }

/* ── Menu overlay (dark, click-to-close) ─────────────── */
.menu-overlay {
  position: fixed;
  inset: 0;
  background: rgba(45, 74, 58, 0.25);
  opacity: 0;
  pointer-events: none;
  transition: opacity 200ms ease-out;
  z-index: 90;
}
.menu-overlay.open { opacity: 1; pointer-events: auto; }
body.dark .menu-overlay { background: rgba(0, 0, 0, 0.45); }

/* ── Menu panel (slide-in from right) ────────────────── */
.menu-panel {
  position: fixed;
  top: 0; right: 0;
  width: 320px;
  height: 100vh;
  background: var(--bg);
  border-left: 1px solid var(--border);
  box-shadow: none;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 180ms ease-out;
  z-index: 100;
}
.menu-panel.open { transform: translateX(0); }
body.dark .menu-panel { background: var(--bg); border-left-color: var(--border); }

.menu-nav {
  display: flex;
  flex-direction: column;
  padding-top: 18px;
  flex: 1;
  overflow-y: auto;
}
.menu-group-label {
  font-family: inherit;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--text-tertiary);
  padding: 16px 22px 4px;
}
.menu-group-label:first-child { padding-top: 0; }
.menu-item {
  display: block;
  padding: 12px 22px;
  font-family: inherit;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 1px;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--text-primary);
  background: transparent;
  border: none;
  border-left: 2px solid transparent;
  cursor: pointer;
  transition: background 120ms, border-color 120ms;
  text-align: left;
  width: 100%;
}
.menu-item:hover { background: var(--bg-hover); }
.menu-item.active {
  background: var(--bg-hover);
  border-left-color: var(--text-primary);
  color: var(--text-primary);
}
body.dark .menu-item { color: var(--text-primary); }
body.dark .menu-item:hover { background: var(--bg-hover); }
body.dark .menu-item.active { border-left-color: var(--text-primary); }

.menu-bottom {
  border-top: 1px solid var(--hairline);
  padding: 12px 0 18px;
  display: flex;
  flex-direction: column;
}
.menu-bottom .menu-item.theme-toggle {
  /* Reuse menu-item look; theme-toggle text is set by the existing theme JS. */
  letter-spacing: 1.2px;
}
.menu-logout { color: var(--status-bad) !important; }
.menu-logout:hover { background: rgba(168,80,64,0.10); color: var(--status-bad) !important; }
body.dark .menu-logout { color: var(--status-bad) !important; }

/* ── Service-period source pill (debug-affordance op invoice rows) ── */
.src-pill {
  display: inline-block;
  font-size: 9.5px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 1px 6px;
  border-radius: 2px;
  margin-top: 2px;
  font-weight: 500;
  color: var(--grijs);
  background: rgba(0,0,0,0.04);
}
.src-pill.src-ext  { color: #5a8a5a; background: rgba(90,138,90,0.10); }
.src-pill.src-pat  { color: #8C6E32; background: rgba(140,110,50,0.12); }
.src-pill.src-fact { color: var(--grijs); }
.src-pill.src-man  { color: #7355a8; background: rgba(115,85,168,0.10); }
body.dark .src-pill { background: rgba(255,255,255,0.06); }
body.dark .src-pill.src-ext { color: #87c787; }
body.dark .src-pill.src-pat { color: #d4a960; }

main { padding: 32px 24px 96px; max-width: 1280px; margin: 0 auto; }

/* ── Page ───────────────────────────────────────────── */
.page h1 {
  font-family: inherit;
  font-weight: 600;
  font-size: 22px;
  text-transform: none;
  letter-spacing: -0.5px;
  margin: 0 0 4px;
  color: var(--text-primary);
}
.page-intro {
  font-size: 12px;
  color: var(--text-secondary);
  margin: 0 0 28px;
  max-width: 720px;
}

/* ── Page header — sticky context-balk (componente) ──── */
.page-header {
  margin-bottom: 24px;
}
.page-header-row {
  display: flex;
  align-items: baseline;
  gap: 16px;
  flex-wrap: wrap;
}
.page-header-row h1 { margin: 0 0 4px; flex: 1 1 auto; }
.page-period {
  font-size: 12px;
  color: var(--text-secondary);
  font-variant-numeric: tabular-nums;
}
.page-header .page-intro { margin-top: 4px; }

/* ── Datum-filter component ──────────────────────────── */
.date-filter {
  position: relative;
  display: inline-block;
}
.date-filter-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 2px;
  color: var(--text-primary);
  padding: 6px 10px;
  font-family: inherit;
  font-size: 12px;
  cursor: pointer;
  transition: background 120ms;
}
.date-filter-toggle:hover { background: var(--bg-hover); border-color: var(--text-primary); }
.date-filter-current { font-variant-numeric: tabular-nums; }
.date-filter-caret { color: var(--text-tertiary); font-size: 9px; }
.date-filter-menu {
  position: absolute;
  right: 0; top: calc(100% + 4px);
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 2px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  display: flex;
  flex-direction: column;
  min-width: 180px;
  padding: 4px;
  z-index: 60;
}
.date-filter-menu .filter-chip {
  text-align: left;
  margin: 1px 0;
  border: none;
  background: transparent;
  border-radius: 2px;
}
.date-filter-menu .filter-chip:hover { background: var(--bg-hover); border-color: transparent; }
.date-filter-menu .filter-chip.active { background: var(--text-primary); color: var(--bg); }
.date-filter-menu .filter-chip-custom { border-top: 1px solid var(--border); margin-top: 2px; }

/* ── Destructieve actie ──────────────────────────────── */
.btn-destructive {
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  padding: 6px 10px;
  background: transparent;
  color: var(--status-bad);
  border: 1px solid transparent;
  border-radius: 2px;
  cursor: pointer;
  transition: background 120ms, border-color 120ms;
}
.btn-destructive:hover {
  background: rgba(212,53,28,0.08);
  border-color: var(--status-bad);
}

/* ── Empty state ─────────────────────────────────────── */
.empty-state {
  padding: 32px 16px;
  text-align: center;
  color: var(--text-secondary);
  font-size: 13px;
}
.empty-state p { margin: 0 0 12px; }

/* Filter-bar — compacte horizontale balk i.p.v. card-form */
.filter-bar {
  display: flex; flex-wrap: wrap; gap: 6px;
  align-items: center;
  margin: 0 0 16px;
  padding: 10px 12px;
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: 2px;
}
.filter-input, .filter-select {
  font-family: inherit;
  font-size: 12px;
  padding: 5px 8px;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text-primary);
  border-radius: 2px;
  min-width: 0;
}
.filter-input { width: 130px; }
.filter-input-narrow { width: 80px; }
.filter-select { min-width: 140px; }
.filter-bar .btn-primary, .filter-bar .btn-row { height: 30px; padding: 4px 12px; font-size: 12px; }
.page > .card,
.page > .kpi-grid,
.page > form,
.page > h2,
.page > section { margin-bottom: 36px; }
.page > .actions { margin-top: 36px; }
.muted { color: var(--grijs); margin: 0 0 28px; font-size: 13px; }
.muted code { background: var(--cream-2); padding: 1px 6px; border-radius: 2px; }
body.dark .muted code { background: rgba(255,255,255,0.07); color: var(--donker); }

/* ── Tables ─────────────────────────────────────────── */
.data-table {
  width: 100%;
  border-collapse: collapse;
  background: transparent;
  font-size: 13px;
  font-variant-numeric: tabular-nums;
}
.data-table th, .data-table td {
  text-align: left;
  padding: 9px 10px;
  border-bottom: 1px solid var(--hairline);
  vertical-align: middle;
}
.data-table th {
  font-family: inherit;
  font-weight: 500;
  font-size: 11px;
  text-transform: none;
  letter-spacing: 0;
  color: var(--text-tertiary);
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}
.data-table tbody tr:hover { background: var(--bg-hover); }
.data-table .centre { text-align: center; }
.data-table input[type="text"],
.data-table input:not([type]) {
  font-family: inherit;
  font-size: 12.5px;
  padding: 6px 8px;
  border: 1px solid var(--hairline);
  background: #fbf9f3;
  color: var(--donker);
  width: 100%;
}
.data-table input:focus {
  outline: none;
  border-color: var(--mosterd);
  background: #fff;
}
.data-table .soigne-name { font-weight: 500; }
.data-table tr.row-auto { background: rgba(155,137,47,0.04); }

/* ── Pills ──────────────────────────────────────────── */
.pill {
  display: inline-block;
  font-size: 9.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 2px 7px;
  margin-left: 8px;
  border-radius: 2px;
  vertical-align: middle;
}
.pill-auto { background: var(--mosterd); color: var(--cream); }

/* ── Form add-row ───────────────────────────────────── */
.add-row {
  margin-top: 20px;
  border: 1px dashed var(--hairline);
  padding: 14px 16px 16px;
  background: rgba(0,0,0,0.02);
}
.add-row legend {
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--grijs);
  padding: 0 6px;
}
.add-row .row { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 10px; }
.add-row input {
  font-family: inherit;
  font-size: 12.5px;
  padding: 7px 9px;
  border: 1px solid var(--hairline);
  background: #fbf9f3;
}

/* ── Actions ────────────────────────────────────────── */
.actions { margin-top: 22px; display: flex; gap: 12px; }
.btn-primary, .btn-secondary {
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
  padding: 8px 16px;
  height: 36px;
  cursor: pointer;
  border: 1px solid var(--text-primary);
  background: var(--text-primary);
  color: var(--bg);
  border-radius: 2px;
  transition: background 120ms, color 120ms, border-color 120ms;
}
.btn-primary:hover { background: #000; }
.btn-secondary {
  background: var(--bg);
  border-color: var(--border);
  color: var(--text-primary);
}
.btn-secondary:hover { background: var(--bg-hover); border-color: var(--text-primary); }
body.dark .btn-primary { background: var(--text-primary); color: var(--bg); }
body.dark .btn-secondary { background: var(--bg); }

.btn-row {
  display: inline-block;
  font-family: inherit;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
  padding: 5px 10px;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text-primary);
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  line-height: 1.3;
  border-radius: 2px;
  transition: background 120ms, border-color 120ms;
}
.btn-row:hover { background: var(--bg-hover); border-color: var(--text-primary); }
body.dark .btn-row { background: var(--bg); }
.btn-row.btn-disabled {
  border-color: var(--hairline);
  color: var(--grijs);
  cursor: not-allowed;
  opacity: 0.55;
}
.btn-row.btn-disabled:hover { background: transparent; color: var(--grijs); }
.btn-row.is-copied { background: var(--mosterd); color: var(--cream); }

.actions-cell { white-space: nowrap; }
.actions-cell .btn-row + .btn-row { margin-left: 6px; }

/* ── Dashboard KPI grid ─────────────────────────────── */
/* KPI-grid: één doorlopend raster met 1px scheidingen, géén gaps + géén
   per-card border. Achtergrond verzorgt de scheidings-strepen via gap-bg. */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  margin: 16px 0 32px;
}
@media (max-width: 1100px) { .kpi-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (max-width: 720px)  { .kpi-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 480px)  { .kpi-grid { grid-template-columns: 1fr; } }
.kpi-card {
  background: var(--bg);
  border: none;
  padding: 18px 20px 0;            /* status-bar krijgt zijn eigen ruimte onder */
  min-width: 0;
  box-shadow: none;
  display: flex;
  flex-direction: column;
  min-height: 130px;
  transition: background 120ms;
}
.kpi-card.kpi-clickable { cursor: pointer; }
.kpi-card.kpi-clickable:hover { background: var(--bg-hover); }
.kpi-label {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--text-tertiary);
  margin-bottom: 8px;
  display: flex; align-items: center; gap: 4px;
}
.kpi-icon { display: none; }            /* géén iconen */
.kpi-value {
  font-size: 28px;
  font-weight: 600;
  letter-spacing: -1px;
  font-variant-numeric: tabular-nums;
  color: var(--text-primary);
  margin-bottom: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.1;
}
.kpi-value.kpi-value-long { font-size: 22px; }
.kpi-sub {
  font-size: 12px;
  color: var(--text-secondary);
  flex: 1;
}
.kpi-sub .muted, .kpi-sub .muted-inline { color: var(--text-tertiary); font-size: 11px; }
/* Status-balk: schaal 0-150% van target. Verticale streep op 100% (= 66.67%
   van balk-breedte). Vier kleurzones gebaseerd op ratio actueel/target. */
.kpi-statusbar {
  height: 3px;
  background: var(--border);
  margin: 12px -20px -1px;
  margin-top: auto;          /* duwt 'm naar de bodem van de flex-card */
  position: relative;
  overflow: hidden;
}
.kpi-statusbar::after {
  content: "";
  position: absolute;
  left: calc(66.67% - 0.5px);
  top: 0; bottom: 0;
  width: 1px;
  background: var(--text-tertiary);
  z-index: 1;
}
.kpi-statusbar > span {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: var(--status-neutral);
  transition: width 240ms ease-out;
}
.kpi-statusbar.bar-ok        > span { background: #00875a; }
.kpi-statusbar.bar-warn      > span { background: #b45309; }
.kpi-statusbar.bar-bad-light > span { background: #d4351c; opacity: 0.75; }
.kpi-statusbar.bar-bad-full  > span { background: #d4351c; }
.kpi-statusbar .over-marker {
  position: absolute;
  right: 4px; top: -14px;
  font-size: 9px;
  font-weight: 600;
  color: #d4351c;
  letter-spacing: 0;
}
/* Tooltip-trigger (i) icoontje voor bron-attributies */
.kpi-info {
  display: inline-block;
  font-size: 10px;
  color: var(--text-tertiary);
  border: 1px solid var(--border);
  border-radius: 50%;
  width: 14px; height: 14px;
  text-align: center; line-height: 13px;
  cursor: help;
  margin-left: 4px;
}
.kpi-card.kpi-summary { background: var(--bg-soft); }
.kpi-card.kpi-summary .kpi-value { color: var(--text-primary); }
/* Legacy ratio-classes — neutraliseer de oude border/text-color regels */
.kpi-card.ratio-good, .kpi-card.ratio-warn, .kpi-card.ratio-bad, .kpi-card.ratio-none { border: none; }
.kpi-card.ratio-good .kpi-value,
.kpi-card.ratio-warn .kpi-value,
.kpi-card.ratio-bad  .kpi-value,
.kpi-card.ratio-none .kpi-value { color: var(--text-primary); }

.ratio-good { color: var(--status-ok); font-weight: 600; }
.ratio-warn { color: var(--status-warn); font-weight: 600; }
.ratio-bad  { color: var(--status-bad); font-weight: 600; }

.trend { font-weight: 600; font-variant-numeric: tabular-nums; }
.trend-up   { color: var(--status-ok); }
.trend-down { color: var(--status-bad); }
.trend-flat { color: var(--grijs); }
.trend-none { color: var(--grijs); }

.section-h {
  font-family: inherit;
  font-weight: 600;
  font-size: 16px;
  text-transform: none;
  letter-spacing: 0;
  color: var(--text-primary);
  margin: 32px 0 12px;
  padding-bottom: 0;
  border-bottom: none;
}
.muted { color: var(--text-secondary); margin: 0 0 16px; font-size: 13px; }
.muted.small { font-size: 11px; color: var(--text-tertiary); }
.backup-actions { margin-top: 24px; justify-content: flex-end; }

.period-toggle {
  display: flex;
  gap: 18px;
  margin: 0 0 14px;
  padding-bottom: 12px;
  border-bottom: 1px dashed var(--hairline);
}
.period-toggle label {
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  color: var(--grijs);
  display: flex;
  align-items: center;
  gap: 6px;
}
.period-toggle input[type="radio"] { accent-color: var(--mosterd); }

.pill-week  { background: var(--mosterd-soft); color: var(--mosterd); }
.pill-month { background: rgba(0,0,0,0.06); color: var(--grijs); }

/* ── Invoices ────────────────────────────────────────── */
.invoices-table tr.row-review { background: rgba(255, 220, 100, 0.18); }
.invoices-table tr.row-review:hover { background: rgba(255, 220, 100, 0.28); }

.modal-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(26, 26, 26, 0.55);
  z-index: 100;
  align-items: center;
  justify-content: center;
}
.modal {
  background: var(--cream);
  border: 1px solid var(--donker);
  padding: 0;                    /* padding lives on header/body/footer now */
  width: 540px;
  max-width: calc(100vw - 32px);
  max-height: 85vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.4);
}
.modal-title {
  font-family: inherit;
  font-size: 16px;
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0;
  color: var(--text-primary);
  padding: 18px 24px 14px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.modal-close {
  display: inline-flex;
  align-items: center; justify-content: center;
  width: 28px; height: 28px;
  border: none;
  background: transparent;
  color: var(--text-secondary);
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  border-radius: 2px;
  padding: 0;
  transition: background 120ms;
}
.modal-close:hover { background: var(--bg-hover); color: var(--text-primary); }

/* details/summary in modals — neutraal grijs driehoekje, geen goud-accent */
.contract-section { margin: 16px 0; }
.contract-section > summary {
  cursor: pointer;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-primary);
  padding: 8px 0;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 8px;
}
.contract-section > summary::-webkit-details-marker { display: none; }
.contract-section > summary::before {
  content: "▶";
  display: inline-block;
  font-size: 9px;
  color: var(--text-secondary);
  transition: transform 150ms;
}
.contract-section[open] > summary::before { transform: rotate(90deg); }
.contract-section > summary strong { font-weight: 600; }

/* Modal-meta: kleine kop in modal-body — periode links, totaal rechts */
.modal-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 12px;
  margin-bottom: 12px;
  border-bottom: 1px solid var(--border);
  font-size: 12px;
  color: var(--text-secondary);
}
.modal-meta strong { color: var(--text-primary); font-weight: 500; }

/* Afdelings-grid bovenaan personeel-modal — Keuken/Voorkant/Management/Events */
.dept-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  margin-bottom: 24px;
}
.dept-block {
  background: var(--bg);
  padding: 14px 16px;
  display: flex; flex-direction: column; gap: 4px;
}
.dept-name {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--text-tertiary);
}
.dept-amount {
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.5px;
  color: var(--text-primary);
}
.dept-pct { font-size: 11px; color: var(--text-tertiary); }

/* /bronnen — drie verticale panelen naast elkaar */
.bronnen-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  margin: 16px 0 32px;
}
@media (max-width: 900px) { .bronnen-grid { grid-template-columns: 1fr; } }
.source-panel {
  background: var(--bg);
  display: flex;
  flex-direction: column;
  min-height: 480px;
}
.panel-header {
  padding: 16px 18px 10px;
  border-bottom: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.panel-name {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
}
.panel-sub {
  font-size: 11px;
  color: var(--text-tertiary);
  letter-spacing: 0.2px;
}
.panel-status {
  padding: 10px 18px;
  border-bottom: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: 12px;
}
.fresh {
  display: inline-block;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.3px;
}
.fresh-ok   { color: #00875a; }
.fresh-warn { color: #b45309; }
.fresh-bad  { color: #d4351c; }
.fresh-none { color: var(--text-tertiary); }
.panel-status { gap: 4px; }
.panel-status .fresh-dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  margin-right: 6px;
  vertical-align: middle;
}
.dot-ok   { background: #00875a; }
.dot-warn { background: #b45309; }
.dot-bad  { background: #d4351c; }
.dot-none { background: var(--text-tertiary); }
.panel-months {
  flex: 1;
  overflow-y: auto;
  max-height: 320px;
}
.month-row {
  display: grid;
  grid-template-columns: 70px 1fr auto;
  align-items: baseline;
  gap: 8px;
  padding: 8px 18px;
  font-size: 12px;
  border-bottom: 1px solid var(--border);
  text-decoration: none;
  color: inherit;
}
.month-row:last-child { border-bottom: none; }
.month-row-link { cursor: pointer; transition: background 120ms; }
.month-row-link:hover { background: var(--bg-hover); }
.month-label {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  color: var(--text-secondary);
}
.month-amount {
  font-weight: 600;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}
.month-meta {
  font-size: 11px;
  color: var(--text-tertiary);
  text-align: right;
}
.panel-empty { padding: 16px 18px; }
.panel-upload {
  border-top: 1px solid var(--border);
  padding: 14px 18px;
  background: var(--bg-soft);
}
.panel-upload .field { margin-bottom: 10px; }
.panel-upload .actions { margin-top: 10px; gap: 8px; }
.panel-upload input[type="file"] { font-size: 12px; }

/* /bronnen status pills + day-row hover */
.status-pill {
  display: inline-block;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  padding: 2px 6px;
  border-radius: 2px;
  background: var(--bg-hover);
  color: var(--text-secondary);
}
.status-good      { background: rgba(0,135,90,0.10);  color: #00875a; }
.status-warn      { background: rgba(180,83,9,0.10);  color: #b45309; }
.status-bad-light { background: rgba(212,53,28,0.10); color: #d4351c; }
.status-bad-full  { background: #d4351c; color: #fff; }
.status-neutral   { background: var(--bg-hover); color: var(--text-tertiary); }

.day-row:hover { background: var(--bg-hover); }
.expanded-row > td { background: var(--bg-soft); padding: 0; }
.expanded-panel { padding: 16px 20px; }
.expanded-title {
  font-size: 11px; font-weight: 600; letter-spacing: 0.5px;
  text-transform: uppercase; color: var(--text-tertiary);
  margin-bottom: 8px;
}
.anomalies { margin-bottom: 12px; display: flex; flex-direction: column; gap: 4px; }
.anomaly { font-size: 11px; padding: 6px 10px; border-left: 2px solid var(--status-bad); background: var(--bg); }
.anomaly-no-revenue { border-left-color: var(--text-secondary); }
.day-table { margin: 0; }

/* /inzichten — recommendations inbox */
.filters-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  padding: 12px 0 16px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 16px;
}
.filter-spacer { flex: 1; }
.filter-group-label {
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--text-tertiary);
  margin-right: 2px;
}
.chip-count {
  font-size: 10px;
  opacity: 0.7;
  font-variant-numeric: tabular-nums;
}
.filter-chip {
  display: inline-block;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.2px;
  padding: 4px 10px;
  border: 1px solid var(--border);
  border-radius: 2px;
  text-decoration: none;
  color: var(--text-secondary);
  background: var(--bg);
  text-transform: capitalize;
}
.filter-chip:hover { background: var(--bg-hover); color: var(--text-primary); }
.filter-chip.active {
  background: var(--text-primary);
  color: var(--bg);
  border-color: var(--text-primary);
}
.filter-chip .muted { color: inherit; opacity: 0.65; }

.rec-card {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 0;
  margin-bottom: 8px;
}
.rec-card > summary {
  display: grid;
  grid-template-columns: 100px 1fr 140px 90px 80px;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  cursor: pointer;
  list-style: none;
  font-size: 13px;
  transition: background 120ms;
}
.rec-card > summary::-webkit-details-marker { display: none; }
.rec-card > summary:hover { background: var(--bg-hover); }
.rec-card[open] > summary { border-bottom: 1px solid var(--border); }

.rec-cat {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 2px;
  background: var(--bg-hover);
  color: var(--text-secondary);
  text-align: center;
}
.rec-cat-personeel  { background: rgba(0,135,90,0.10);  color: #00875a; }
.rec-cat-menu       { background: rgba(180,83,9,0.10);  color: #b45309; }
.rec-cat-inkoop     { background: rgba(212,53,28,0.10); color: #d4351c; }
.rec-cat-patronen   { background: rgba(40,80,160,0.10); color: #2855a0; }
.rec-cat-forecasting{ background: rgba(115,85,168,0.10); color: #7355a8; }

.rec-title { color: var(--text-primary); font-weight: 500; }
.rec-impact { font-weight: 600; color: var(--text-primary); font-variant-numeric: tabular-nums; text-align: right; }
.rec-date { text-align: right; }
.rec-status { justify-self: end; font-size: 9px; }
.status-pill.status-open      { background: rgba(0,135,90,0.10); color: #00875a; }
.status-pill.status-followed  { background: rgba(40,80,160,0.10); color: #2855a0; }
.status-pill.status-snoozed   { background: rgba(180,83,9,0.10); color: #b45309; }
.status-pill.status-dismissed { background: var(--bg-hover); color: var(--text-tertiary); }

.rec-body { padding: 16px 20px 18px; background: var(--bg-soft); }
.rec-section { margin-bottom: 12px; }
.rec-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--text-tertiary);
  margin-bottom: 4px;
}
.rec-text { font-size: 13px; color: var(--text-primary); line-height: 1.55; }
.rec-pre {
  font-family: inherit;
  margin: 0;
  white-space: pre-wrap;
  word-wrap: break-word;
}
.rec-actions { display: flex; gap: 8px; margin-top: 14px; }

@media (max-width: 700px) {
  .rec-card > summary { grid-template-columns: 80px 1fr; }
  .rec-card > summary > .rec-impact, .rec-card > summary > .rec-date,
  .rec-card > summary > .rec-status { display: none; }
}

/* /recepten — menu-engineering matrix */
.menu-matrix {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  margin-bottom: 24px;
}
.matrix-cell { background: var(--bg); padding: 18px 20px; min-height: 140px; }
.matrix-label { font-size: 14px; font-weight: 600; color: var(--text-primary); margin-bottom: 4px; }
.matrix-sub   { margin-bottom: 10px; }
.matrix-list  { list-style: none; padding: 0; margin: 0; font-size: 12px; }
.matrix-list li { padding: 4px 0; border-bottom: 1px solid var(--bg-hover); }
.matrix-list li:last-child { border-bottom: none; }
.matrix-list a { color: var(--text-primary); text-decoration: none; font-weight: 500; }
.matrix-list a:hover { text-decoration: underline; }
.matrix-ster      { background: rgba(0,135,90,0.04); }
.matrix-werkpaard { background: rgba(180,83,9,0.04); }
.matrix-puzzel    { background: rgba(40,80,160,0.04); }
.matrix-hond      { background: rgba(212,53,28,0.04); }

/* Benchmark-pill op KPI-kaarten */
.bench-pill {
  display: inline-block;
  font-size: 9.5px;
  font-weight: 500;
  letter-spacing: 0.3px;
  text-transform: uppercase;
  padding: 1px 6px;
  border-radius: 2px;
  margin-left: 2px;
  background: var(--bg-hover);
  color: var(--text-tertiary);
  cursor: help;
}
.bench-ok   { background: rgba(0,135,90,0.10);  color: #00875a; }
.bench-warn { background: rgba(180,83,9,0.10);  color: #b45309; }
.bench-bad  { background: rgba(212,53,28,0.10); color: #d4351c; }

/* Dashboard ticker — top recommendation banner */
.insight-ticker {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  margin-bottom: 12px;
  border: 1px solid var(--border);
  border-left: 3px solid var(--text-primary);
  background: var(--bg-soft);
  font-size: 13px;
}
.insight-ticker strong { color: var(--text-primary); }
.insight-ticker .ticker-impact { font-weight: 600; color: var(--text-primary); }
.insight-ticker .ticker-spacer { flex: 1; }
.modal-body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 18px 28px 18px;
  outline: none;             /* tabindex=0 for keyboard scroll, no focus ring */
}
.modal-footer {
  flex-shrink: 0;
  padding: 14px 28px 18px;
  border-top: 1px solid var(--hairline);
  background: var(--cream);
  font-size: 13px;
}
.modal .modal-totaal-sticky {
  /* Footer-card variant for fragments where total lives inside the body. */
  position: sticky;
  bottom: 0;
  background: var(--cream);
  border-top: 1px solid var(--hairline);
  margin: 18px -28px -18px;
  padding: 14px 28px;
}
body.dark .modal-title,
body.dark .modal-footer,
body.dark .modal .modal-totaal-sticky { background: #1a1a1a; }
.modal .field input:disabled {
  background: rgba(0,0,0,0.04);
  color: var(--grijs);
}
.modal .actions { margin-top: 22px; }

/* ── Bulk WhatsApp ──────────────────────────────────── */
.wa-bulk {
  margin: 0 0 24px;
  padding: 18px 20px;
  background: var(--mosterd-soft);
  border-left: 3px solid var(--mosterd);
}
.wa-bulk .btn-large {
  font-size: 13px;
  padding: 14px 24px;
}
.wa-bulk .wa-hint { margin: 12px 0 4px; font-size: 11.5px; }
.wa-bulk p:last-child { margin-bottom: 0; }

/* ── Cards ──────────────────────────────────────────── */
.card {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 0;
  padding: 24px;
  margin-top: 0;
  box-shadow: none;
}
.card.placeholder { color: var(--text-tertiary); font-style: normal; }
.card-title {
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
  color: var(--text-primary);
  margin-bottom: 16px;
  padding-bottom: 0;
  border-bottom: none;
}

/* ── Form fields ────────────────────────────────────── */
.grid-two { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.field { display: flex; flex-direction: column; gap: 6px; }
.field > span {
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--grijs);
}
.field > span em { font-style: normal; opacity: 0.7; text-transform: none; letter-spacing: 0.04em; }
.field input[type="text"],
.field input[type="file"],
.field select {
  font-family: inherit;
  font-size: 13px;
  padding: 9px 10px;
  border: 1px solid var(--hairline);
  background: #fbf9f3;
  color: var(--donker);
}
.field input[type="file"] { padding: 7px 6px; background: transparent; }
.field input:focus, .field select:focus { outline: none; border-color: var(--mosterd); background: #fff; }
.field small { font-size: 11px; }

/* ── Numeric cells / totals ─────────────────────────── */
.data-table th.num, .data-table td.num { text-align: right; font-variant-numeric: tabular-nums; }
.data-table tr.total-row td {
  border-top: 1px solid var(--donker);
  border-bottom: 2px solid var(--donker);
  font-weight: 600;
  background: var(--cream-2);
}
.muted-inline { color: var(--grijs); font-size: 11.5px; margin-left: 4px; }
.phone { background: var(--cream-2); padding: 1px 6px; border-radius: 2px; font-size: 12px; }
.warn { color: var(--status-bad); font-size: 11.5px; }

/* ── Pills ──────────────────────────────────────────── */
.pill-ok { background: rgba(0,0,0,0.06); color: var(--grijs); }
.pill-warn { background: rgba(181,79,29,0.15); color: #8d3c14; margin-left: 4px; }

/* ── Flash messages ─────────────────────────────────── */
.flash {
  padding: 10px 14px;
  margin-bottom: 14px;
  border-left: 3px solid var(--mosterd);
  background: var(--mosterd-soft);
  font-size: 12.5px;
}
.flash-error { border-color: var(--status-bad); background: rgba(181,79,29,0.08); color: #8d3c14; }

/* ── Calendar ──────────────────────────────────────── */
.calendar-card { padding: 18px 20px 16px; }
.calendar-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}
.cal-spacer { flex: 1; }
.cal-month-title {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 6px 16px;
}
.cal-nav { padding: 6px 12px; font-size: 14px; }
.calendar-grid {
  display: grid;
  grid-template-columns: 36px repeat(7, 1fr);
  gap: 2px;
  user-select: none;
}
.cal-cell {
  font-family: inherit;
  font-size: 12px;
  padding: 8px 4px;
  text-align: center;
  border: 1px solid transparent;
  background: transparent;
  cursor: pointer;
  position: relative;
  min-height: 38px;
  color: var(--donker);
}
.cal-corner { background: transparent; cursor: default; pointer-events: none; }
.cal-dow {
  font-size: 9.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--grijs);
  cursor: default;
  pointer-events: none;
}
.cal-week {
  font-size: 9.5px;
  color: var(--grijs);
  background: rgba(0,0,0,0.025);
}
.cal-week:hover { background: var(--mosterd-soft); color: var(--mosterd); }
.cal-day { background: rgba(255,255,255,0.45); border-color: var(--hairline); }
.cal-day:hover { border-color: var(--mosterd); }
.cal-day.cal-other { color: var(--grijs); opacity: 0.45; background: transparent; }
.cal-day.cal-today { font-weight: 700; box-shadow: inset 0 0 0 1px var(--donker); }
.cal-day.cal-selected {
  background: var(--mosterd-soft);
  border-color: var(--mosterd);
  color: var(--mosterd);
  font-weight: 700;
}
.cal-day.cal-has-data .cal-dot {
  position: absolute;
  bottom: 4px;
  left: 50%;
  transform: translateX(-50%);
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--mosterd);
}
.cal-day.cal-selected .cal-dot { background: var(--donker); }
.calendar-shortcuts {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px dashed var(--hairline);
}
.selection-status {
  margin: 18px 0 8px;
  font-size: 12px;
}

/* ── Page toolbar (h1 + theme toggle) ─────────────── */
.page-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.page-toolbar h1 { margin-bottom: 0; }

/* ── Calendar collapse ────────────────────────────── */
.calendar-card { padding-top: 0; padding-bottom: 14px; }
.calendar-header {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 12px 4px;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--border);
  font-family: inherit;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-primary);
  text-align: left;
  cursor: pointer;
}
.calendar-header:hover { color: var(--text-primary); }
.calendar-header .cal-icon { display: none; }
.calendar-header .cal-summary { flex: 1; color: var(--text-secondary); }
.calendar-header .cal-summary strong { color: var(--text-primary); font-weight: 500; }
.calendar-header .cal-toggle-hint {
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0;
  text-transform: none;
  color: var(--text-tertiary);
}
.calendar-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.32s ease, opacity 0.2s ease, margin-top 0.2s ease;
  opacity: 0;
  margin-top: 0;
}
.calendar-body.expanded {
  max-height: 540px;
  opacity: 1;
  margin-top: 14px;
}
.calendar-shortcuts { margin-top: 14px; padding-top: 14px; }

/* ── Dark mode (dashboard-only) ───────────────────── */
body.dark {
  --cream: #0f0f0f;
  --cream-2: #1a1a1a;
  --donker: #ece8df;
  --grijs: #8a8a85;
  --hairline: rgba(255,255,255,0.12);
  --mosterd-soft: rgba(155, 137, 47, 0.22);
}
body.dark .topbar { background: #0a0a0a; border-bottom-color: rgba(255,255,255,0.18); }
body.dark .data-table th { background: #0a0a0a; }
body.dark .data-table tbody tr:hover { background: rgba(255,255,255,0.04); }
body.dark .data-table input[type="text"],
body.dark .data-table input:not([type]),
body.dark .field input[type="text"],
body.dark .field input[type="file"],
body.dark .field select {
  background: #0a0a0a;
  color: var(--donker);
  border-color: var(--hairline);
}
body.dark .field input:focus,
body.dark .field select:focus { background: #1a1a1a; border-color: var(--mosterd); }
body.dark .card { background: #1a1a1a; border-color: rgba(255,255,255,0.10); }
body.dark .kpi-card { background: #1a1a1a; }
body.dark .kpi-card.kpi-summary { background: #141414; }
body.dark .kpi-value { color: var(--donker); }

/* Brighter status colors on dark background */
body.dark .ratio-good,
body.dark .trend-up      { color: #62d97a; }
body.dark .ratio-warn    { color: #f0c862; }
body.dark .ratio-bad,
body.dark .trend-down    { color: #ff7e5f; }
body.dark .kpi-card.ratio-good { border-top-color: #62d97a; }
body.dark .kpi-card.ratio-good .kpi-value { color: #62d97a; }
body.dark .kpi-card.ratio-warn { border-top-color: #f0c862; }
body.dark .kpi-card.ratio-warn .kpi-value { color: #f0c862; }
body.dark .kpi-card.ratio-bad  { border-top-color: #ff7e5f; }
body.dark .kpi-card.ratio-bad  .kpi-value { color: #ff7e5f; }

/* Calendar in dark mode — selected days stay mosterdgeel */
body.dark .cal-day        { background: #0a0a0a; border-color: var(--hairline); color: var(--donker); }
body.dark .cal-day:hover  { background: #181818; border-color: var(--mosterd); }
body.dark .cal-day.cal-other { background: transparent; }
body.dark .cal-day.cal-today { box-shadow: inset 0 0 0 1px var(--donker); }
body.dark .cal-day.cal-selected {
  background: var(--mosterd);
  border-color: var(--mosterd);
  color: #0a0a0a;
}
body.dark .cal-week { background: #0a0a0a; color: var(--grijs); }
body.dark .cal-week:hover { background: var(--mosterd-soft); }

body.dark .row-review { background: rgba(240, 200, 98, 0.10) !important; }
body.dark .modal { background: #1a1a1a; border-color: rgba(255,255,255,0.18); }
body.dark .modal .field input:disabled { background: #0a0a0a; }

/* Text-bound colours that should follow theme */
body.dark .flash-error { color: #ff8e7a; }

/* ── Theme toggle in nav ──────────────────────────── */
.theme-toggle {
  font-family: inherit;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-left: 28px;
  padding: 4px 12px;
  border: 1px solid var(--hairline);
  background: transparent;
  color: var(--grijs);
  cursor: pointer;
}
.theme-toggle:hover { border-color: var(--mosterd); color: var(--mosterd); }
body.dark .theme-toggle { border-color: rgba(255,255,255,0.18); color: var(--donker); }
body.dark .theme-toggle:hover { border-color: var(--mosterd); color: var(--mosterd); }

/* ── Tables: alternating-row contrast in dark ─────── */
body.dark .data-table tbody tr:nth-child(even) { background: rgba(255,255,255,0.025); }
body.dark .data-table tr.row-auto { background: rgba(155,137,47,0.12); }

/* ── Dark mode: chunkier text everywhere ──────────── */
body.dark { font-weight: 500; }
body.dark .page h1,
body.dark .section-h,
body.dark .kpi-value,
body.dark .brand-mark        { font-weight: 700; }
body.dark .card-title,
body.dark .data-table th,
body.dark .kpi-label,
body.dark .field > span,
body.dark .btn-primary,
body.dark .btn-secondary,
body.dark .btn-row,
body.dark .theme-toggle,
body.dark .topbar nav a      { font-weight: 600; }
body.dark .muted,
body.dark .kpi-sub           { font-weight: 500; }

/* ── Custom file dropzones ────────────────────────── */
.file-drop {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 20px;
  border: 1px dashed var(--border);
  background: var(--bg);
  cursor: pointer;
  transition: border-color 120ms, background 120ms;
  position: relative;
}
.file-drop input[type="file"] { display: none; }
.file-drop:hover {
  border-color: var(--text-primary);
  border-style: dashed;
}
.file-drop.dragging {
  border-color: var(--text-primary);
  border-style: dashed;
  background: var(--bg-hover);
}
.file-drop.has-file {
  border-style: solid;
  border-color: var(--text-primary);
  background: var(--bg-soft);
}
.file-drop.upload-flash {
  background: rgba(0, 135, 90, 0.15);
  border-color: #00875a;
  border-style: solid;
}
@keyframes upload-flash-fade {
  0%   { background: rgba(0, 135, 90, 0.30); border-color: #00875a; }
  100% { background: var(--bg);              border-color: var(--border); }
}
.file-drop-empty,
.file-drop-filled { display: flex; align-items: center; gap: 12px; flex: 1; min-width: 0; }
.file-drop-icon { display: none; }    /* geen 📄-emoji's meer */
.file-drop-icon.ok { display: inline; color: var(--status-ok); font-size: 14px; line-height: 1; }
.file-drop-text { color: var(--text-secondary); font-size: 13px; }
.file-drop-name {
  flex: 1; min-width: 0;
  font-weight: 600; font-size: 13px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.file-drop-size {
  font-size: 11px; color: var(--grijs); white-space: nowrap;
}
.file-drop-replace {
  font-family: inherit;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--mosterd);
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 4px 6px;
  margin-left: 4px;
}
.file-drop-replace:hover { text-decoration: underline; }

/* Dark variant */
body.dark .file-drop {
  background: rgba(255, 255, 255, 0.025);
  border-color: var(--mosterd);
  border-style: solid;
}
body.dark .file-drop:hover { background: rgba(155, 137, 47, 0.10); }
body.dark .file-drop.dragging,
body.dark .file-drop.has-file { background: rgba(155, 137, 47, 0.15); }
body.dark .file-drop-icon.ok { color: #62d97a; }
body.dark .file-drop-text { color: var(--donker); }

/* ── Payments tab ─────────────────────────────────── */
.kpi-grid.kpi-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (max-width: 760px) {
  .kpi-grid.kpi-grid-3 { grid-template-columns: 1fr; }
}
.kpi-card.kpi-cash         { border-top-color: #7c5b2b; }
.kpi-card.kpi-cash .kpi-value { color: #7c5b2b; }
.kpi-card.kpi-card-mosterd { border-top-color: var(--mosterd); }
.kpi-card.kpi-card-mosterd .kpi-value { color: var(--mosterd); }

body.dark .kpi-card.kpi-cash { border-top-color: #c79453; }
body.dark .kpi-card.kpi-cash .kpi-value { color: #c79453; }

.chart-card { padding: 18px 20px 14px; margin: 16px 0 24px; }
.chart-wrap {
  height: 280px;
  position: relative;
}

/* ── Login + nav-logout ───────────────────────────── */
.login-page { max-width: 460px; margin: 60px auto 0; }
.login-card { padding: 24px 28px 22px; }
.login-remember {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--grijs);
  text-transform: none;
  letter-spacing: 0.04em;
  cursor: pointer;
}
.login-remember input[type="checkbox"] { accent-color: var(--mosterd); }
.login-page .field input[type="password"] {
  font-family: inherit; font-size: 13px; padding: 9px 10px;
  border: 1px solid var(--hairline); background: #fbf9f3; color: var(--donker);
}
body.dark .login-page .field input[type="password"] {
  background: #0a0a0a; color: var(--donker); border-color: var(--hairline);
}

.nav-logout {
  margin-left: 18px !important;
  border-left: 1px solid var(--hairline);
  padding-left: 28px !important;
  color: var(--grijs) !important;
  font-size: 11px !important;
}
.nav-logout:hover { color: var(--status-bad) !important; border-bottom-color: transparent !important; }

/* ── Goal progress lines under KPI cards ──────────── */
.goal-line {
  margin-top: 8px;
  padding: 6px 8px;
  font-size: 10.5px;
  letter-spacing: 0.02em;
  border-left: 3px solid var(--hairline);
  background: rgba(0,0,0,0.025);
}
.goal-ok   { border-left-color: var(--status-ok); color: var(--status-ok); }
.goal-warn { border-left-color: var(--status-warn); color: #8a6310; }
.goal-bad  { border-left-color: var(--status-bad); color: var(--status-bad); }
body.dark .goal-line { background: rgba(255,255,255,0.03); }
body.dark .goal-ok   { color: #62d97a; border-left-color: #62d97a; }
body.dark .goal-warn { color: #f0c862; border-left-color: #f0c862; }
body.dark .goal-bad  { color: #ff7e5f; border-left-color: #ff7e5f; }

/* ── Heatmap ──────────────────────────────────────── */
.heatmap-card { padding: 18px 22px 16px; }
.heatmap-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}
.heatmap-month {
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--donker);
}
.heatmap-toggle { display: flex; gap: 4px; }
.hm-metric.active {
  background: var(--mosterd);
  color: var(--cream);
  border-color: var(--mosterd);
}
.heatmap-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 3px;
}
.hm-cell {
  position: relative;
  text-align: center;
  font-size: 11px;
  padding: 14px 4px;
  background: rgba(0,0,0,0.04);
  color: var(--donker);
  cursor: default;
  border-radius: 2px;
}
.hm-cell.hm-dow {
  font-size: 9px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 4px 0 8px;
  background: transparent;
  color: var(--grijs);
}
.hm-cell.hm-other { opacity: 0.35; }
.hm-num { display: block; }

.hm-best { background: var(--status-ok); color: #fff; font-weight: 700; }
.hm-good { background: #88c69e; color: #1a1a1a; }
.hm-meh  { background: #d9e2c2; color: #1a1a1a; }
.hm-poor { background: #b8b6ad; color: #1a1a1a; }
.hm-none { background: rgba(0,0,0,0.04); color: var(--grijs); }

body.dark .hm-best { background: #4ade80; color: #0a0a0a; }
body.dark .hm-good { background: #2c5e3d; color: #ece8df; }
body.dark .hm-meh  { background: #3a3a30; color: #c8c4ba; }
body.dark .hm-poor { background: #2a2a2a; color: #888; }
body.dark .hm-none { background: rgba(255,255,255,0.025); color: var(--grijs); }

.heatmap-legend {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-top: 14px;
  font-size: 10.5px;
  color: var(--grijs);
}
.hm-key {
  display: inline-block;
  width: 16px;
  height: 12px;
  border-radius: 2px;
  margin: 0 2px;
}

/* ── Loading skeleton ─────────────────────────────── */
@keyframes skeleton-pulse {
  0%, 100% { opacity: 0.55; }
  50%      { opacity: 0.95; }
}
.is-loading .kpi-value,
.is-loading .kpi-sub,
.is-loading .goal-line {
  color: transparent !important;
  background: linear-gradient(90deg, rgba(0,0,0,0.06), rgba(0,0,0,0.12), rgba(0,0,0,0.06));
  background-size: 200% 100%;
  border-radius: 3px;
  animation: skeleton-pulse 1.2s ease-in-out infinite;
}
body.dark .is-loading .kpi-value,
body.dark .is-loading .kpi-sub,
body.dark .is-loading .goal-line {
  background: linear-gradient(90deg, rgba(255,255,255,0.05), rgba(255,255,255,0.12), rgba(255,255,255,0.05));
  background-size: 200% 100%;
}
.is-loading .kpi-icon { opacity: 0.3; }

/* ── Calendar cell pulse on selection ────────────── */
@keyframes cal-pulse {
  0%   { transform: scale(1.0); }
  50%  { transform: scale(1.06); }
  100% { transform: scale(1.0); }
}
.cal-day.cal-selected { animation: cal-pulse 220ms ease-out; }

/* ── Shortcut hint (toast right-bottom) ─────────────── */
.shortcut-hint {
  position: fixed;
  right: 24px;
  bottom: 24px;
  background: var(--donker);
  color: var(--cream);
  padding: 12px 16px;
  font-size: 12px;
  letter-spacing: 0.04em;
  cursor: pointer;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 250ms ease, transform 250ms ease;
  pointer-events: none;
  z-index: 90;
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
}
.shortcut-hint.show { opacity: 1; transform: translateY(0); pointer-events: auto; }
.shortcut-hint kbd { margin: 0 4px; }
body.dark .shortcut-hint { background: #ece8df; color: #0a0a0a; }

/* ── Help overlay ──────────────────────────────────── */
.help-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.55);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 200;
}
.help-overlay.open { display: flex; }
.help-panel {
  background: var(--cream);
  color: var(--donker);
  padding: 28px 32px;
  width: 380px;
  max-width: calc(100vw - 32px);
  border: 1px solid var(--card-border);
  box-shadow: 0 18px 48px rgba(0,0,0,0.4);
}
body.dark .help-panel { background: #1a1a1a; }
.help-title {
  font-size: 14px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mosterd);
  margin-bottom: 18px;
  padding-bottom: 10px;
  border-bottom: 1px dashed var(--hairline);
  font-weight: 700;
}
.help-list {
  list-style: none;
  padding: 0; margin: 0 0 18px;
  font-size: 13px;
}
.help-list li {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 6px 0;
  border-bottom: 1px dashed var(--hairline);
}
.help-list kbd {
  display: inline-block;
  min-width: 32px;
  text-align: center;
}
kbd {
  font-family: inherit;
  font-size: 11px;
  background: var(--cream-2);
  border: 1px solid var(--hairline);
  border-radius: 3px;
  padding: 2px 7px;
  color: var(--donker);
  box-shadow: inset 0 -1px 0 rgba(0,0,0,0.06);
}
body.dark kbd { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.18); color: var(--donker); }

/* ── /jaar — visual showcase ──────────────────────── */
.year-page { max-width: 1200px; margin: 0 auto; }
.year-hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 36px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--hairline);
}
.year-eyebrow {
  font-size: 12px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--grijs);
  margin-bottom: 8px;
}
.year-title {
  font-family: inherit;
  font-weight: 700;
  font-size: 72px;
  letter-spacing: -0.02em;
  color: var(--mosterd);
  margin: 0 0 6px;
  line-height: 0.95;
}
.year-subtitle { color: var(--grijs); font-size: 14px; }
.year-hero-actions { display: flex; gap: 10px; align-items: center; }
.year-hero-actions select {
  font-family: inherit; font-size: 12px;
  padding: 7px 10px;
  border: 1px solid var(--hairline);
  background: var(--cream);
  color: var(--donker);
}
body.dark .year-hero-actions select { background: #0a0a0a; }

/* GitHub-style heatmap. */
.heatmap-year-card { padding: 24px 28px; overflow-x: auto; }
.heatmap-year-wrap { display: flex; gap: 8px; min-width: 0; }
.heatmap-year-dows {
  display: grid;
  grid-template-rows: 14px repeat(7, 14px);
  gap: 3px;
  font-size: 9px;
  color: var(--grijs);
  text-transform: lowercase;
  align-items: center;
  flex-shrink: 0;
}
.heatmap-year-scroll { overflow: hidden; min-width: 0; flex: 1; }
.heatmap-year-months {
  display: grid;
  grid-template-columns: repeat(54, 14px);
  gap: 3px;
  margin-bottom: 4px;
  font-size: 9px;
  color: var(--grijs);
  text-transform: uppercase;
  height: 14px;
}
.heatmap-month-label { white-space: nowrap; }
.heatmap-year-grid {
  display: grid;
  grid-template-columns: repeat(54, 14px);
  gap: 3px;
}
.heatmap-year-col {
  display: grid;
  grid-template-rows: repeat(7, 14px);
  gap: 3px;
  opacity: 0;
  animation: hy-pop 350ms ease-out forwards;
  animation-delay: calc(var(--col, 0) * 25ms);
}
@keyframes hy-pop { to { opacity: 1; } }

.hy-cell {
  width: 14px; height: 14px;
  border-radius: 2px;
  background: rgba(0,0,0,0.06);
  cursor: default;
}
.hy-cell.hy-out { visibility: hidden; }
.hy-b1 { background: #3a3020; }
.hy-b2 { background: #6e5a25; }
.hy-b3 { background: #9b892f; }
.hy-b4 { background: #d4a017; }
body.dark .hy-cell { background: rgba(255,255,255,0.06); }

.heatmap-year-legend {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-top: 16px;
  font-size: 10px;
  color: var(--grijs);
}
.heatmap-year-legend .hy-cell { display: inline-block; }

/* Records — bordered hover glow */
.record-card { border-top: 3px solid var(--mosterd); position: relative; overflow: hidden; }
.record-card::before {
  content: "";
  position: absolute; inset: 0;
  border: 1px solid transparent;
  pointer-events: none;
  transition: border-color 350ms;
}
.record-card:hover::before { border-color: var(--mosterd); }

/* Top 10 list */
.top-days-card { padding: 12px 18px; }
.top-days {
  list-style: none;
  margin: 0; padding: 0;
}
.top-days li {
  display: grid;
  grid-template-columns: 32px 100px 1fr auto;
  align-items: baseline;
  gap: 16px;
  padding: 10px 6px;
  border-bottom: 1px dashed var(--hairline);
  font-size: 14px;
}
.top-days li:last-child { border-bottom: 0; }
.top-days .rank { font-size: 16px; text-align: center; }
.top-days .weekday { color: var(--grijs); text-transform: capitalize; font-size: 12px; }
.top-days .date { color: var(--donker); font-variant-numeric: tabular-nums; }
.top-days .amount { font-weight: 700; color: var(--mosterd); font-size: 16px; }

/* AI quote */
.year-quote {
  margin: 36px 0 24px;
  padding: 24px 28px;
  font-style: italic;
  font-size: 15px;
  line-height: 1.6;
  border-left: 3px solid var(--mosterd);
  background: var(--mosterd-soft);
  color: var(--donker);
}

.year-footer {
  margin: 48px 0 0;
  padding-top: 20px;
  border-top: 1px dashed var(--hairline);
  font-size: 11px;
  color: var(--grijs);
  text-align: center;
}

@media print {
  .topbar, .shortcut-hint, .help-overlay, .year-hero-actions, .nav-logout, .theme-toggle,
  .menu-panel, .menu-overlay, .menu-btn { display: none !important; }
  body { background: white; color: black; }
  .card, .kpi-card { box-shadow: none; }
}

.btn-coach {
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
  padding: 6px 12px;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text-primary);
  border-radius: 2px;
  cursor: pointer;
  transition: background 120ms, border-color 120ms;
}
.btn-coach:hover { background: var(--bg-hover); border-color: var(--text-primary); }

/* ── Coach sidebar ─────────────────────────────────── */
.coach-panel {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: 380px;
  background: var(--cream);
  border-left: 1px solid var(--hairline);
  box-shadow: -8px 0 24px rgba(0,0,0,0.10);
  transform: translateX(100%);
  transition: transform 250ms ease;
  display: flex;
  flex-direction: column;
  z-index: 150;
}
body.dark .coach-panel { background: #0f0f0f; border-left-color: rgba(255,255,255,0.10); box-shadow: -8px 0 24px rgba(0,0,0,0.45); }
body.coach-open .coach-panel { transform: translateX(0); }

.coach-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px;
  border-bottom: 1px dashed var(--hairline);
}
.coach-title { font-weight: 700; font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--mosterd); }
.coach-sub { font-size: 11px; color: var(--grijs); }
.coach-actions { display: flex; gap: 6px; }

.coach-body {
  flex: 1;
  overflow-y: auto;
  padding: 16px 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.coach-suggestions { display: flex; flex-direction: column; gap: 6px; }
.coach-sugg-label {
  font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--grijs); margin-bottom: 4px;
}
.coach-chip {
  font-family: inherit;
  font-size: 12px;
  text-align: left;
  padding: 9px 12px;
  border: 1px solid var(--hairline);
  background: transparent;
  color: var(--donker);
  cursor: pointer;
  transition: border-color 150ms, background 150ms;
}
.coach-chip:hover { border-color: var(--mosterd); background: var(--mosterd-soft); }

.coach-msg {
  font-size: 13px;
  line-height: 1.5;
  padding: 10px 12px;
  border-radius: 4px;
}
.coach-msg p { margin: 0 0 6px; }
.coach-msg p:last-child { margin-bottom: 0; }
.coach-msg ul, .coach-msg ol { padding-left: 20px; margin: 4px 0; }
.coach-msg-user {
  background: var(--mosterd-soft);
  align-self: flex-end;
  max-width: 85%;
  border-left: 3px solid var(--mosterd);
}
.coach-msg-assistant {
  background: rgba(0,0,0,0.04);
  align-self: stretch;
}
body.dark .coach-msg-assistant { background: rgba(255,255,255,0.04); }
.coach-thinking { opacity: 0.6; font-style: italic; }

.coach-input {
  display: flex;
  gap: 8px;
  padding: 12px 14px;
  border-top: 1px dashed var(--hairline);
}
.coach-input textarea {
  flex: 1;
  font-family: inherit;
  font-size: 13px;
  padding: 8px 10px;
  border: 1px solid var(--hairline);
  background: var(--cream);
  color: var(--donker);
  resize: none;
}
.coach-input textarea:focus { outline: none; border-color: var(--mosterd); }
body.dark .coach-input textarea { background: #0a0a0a; }
.coach-input .btn-primary { padding: 8px 14px; }

.coach-foot {
  padding: 8px 16px 14px;
  font-size: 10px;
  color: var(--grijs);
  letter-spacing: 0.04em;
  text-align: right;
}

@media (max-width: 760px) {
  .coach-panel { width: 100vw; }
}

/* Logo → home link, kill default <a> styling */
a.brand-mark { text-decoration: none; cursor: pointer; transition: opacity 200ms; }
a.brand-mark:hover { opacity: 0.85; }

/* ── Brand image (replaces text logo in nav) ──────── */
.brand-img {
  display: block;
  height: 32px;
  width: auto;
  transition: opacity 200ms;
}
a.brand-mark:hover .brand-img { opacity: 0.8; }
.brand-img.dark-only { display: none; }
body.dark .brand-img.light-only { display: none; }
body.dark .brand-img.dark-only  { display: block; }
@media (max-width: 760px) {
  .brand-img { height: 24px; }
}

/* /jaar — olive ruit boven de hero-tekst */
.year-mark {
  display: block;
  width: 200px;
  height: auto;
  margin: 0 0 24px;
}
.year-hero-text { display: flex; flex-direction: column; align-items: flex-start; }
@media (max-width: 760px) {
  .year-mark { width: 140px; }
}

/* ── Inline banner (e.g. "no Tebi data" CTA on dashboard) ─ */
.banner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px 12px;
  padding: 8px 12px;
  margin-bottom: 12px;
  font-size: 12px;
  border-left: 2px solid var(--text-secondary);
  background: var(--bg-soft);
  color: var(--text-primary);
}
.banner.banner-warn { border-left-color: var(--status-bad); background: var(--bg-soft); }
.banner.banner-info { border-left-color: var(--text-secondary); background: var(--bg-soft); }
body.dark .banner { background: var(--bg-soft); }

/* ── Category breakdown card on /dashboard ─────────── */
.cat-breakdown-card { padding: 24px 28px; }
.cat-breakdown { display: flex; flex-direction: column; gap: 10px; }
.cat-row {
  display: grid;
  grid-template-columns: 100px 1fr auto auto;
  align-items: center;
  gap: 14px;
  font-size: 13px;
}
.cat-name {
  text-transform: capitalize;
  font-weight: 600;
  color: var(--donker);
}
.cat-bar {
  height: 6px;
  background: rgba(0,0,0,0.06);
  border-radius: 3px;
  overflow: hidden;
}
body.dark .cat-bar { background: rgba(255,255,255,0.06); }
.cat-bar-fill {
  height: 100%;
  background: var(--text-primary);
  border-radius: 0;
  transition: width 400ms ease-out;
}
.cat-amount {
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--donker);
  min-width: 90px;
  text-align: right;
}
.cat-n { font-size: 11px; }
.cat-row-link {
  text-decoration: none;
  color: inherit;
  padding: 6px 8px;
  margin: -6px -8px;
  border-radius: 3px;
  transition: background 120ms;
}
.cat-row-link:hover { background: var(--mosterd-soft); }

/* ── Compacte KPI-modus toggle (segmented control) ──────
   Vervangt de oude .kpi-toolbar (twee brede knoppen). Klein + rechts-uitgelijnd
   boven het KPI-grid. */
.kpi-section-head {
  display: flex; justify-content: flex-end; align-items: center;
  margin: 0 0 8px;
}
.kpi-mode-toggle {
  display: inline-flex;
  border: 1px solid var(--border);
  border-radius: 2px;
  overflow: hidden;
}
.kpi-mode-toggle button {
  font-family: inherit;
  font-size: 11px;
  padding: 4px 10px;
  border: 0;
  border-right: 1px solid var(--border);
  background: var(--bg);
  color: var(--text-secondary);
  cursor: pointer;
}
.kpi-mode-toggle button:last-child { border-right: 0; }
.kpi-mode-toggle button.is-active {
  background: var(--mosterd-soft);
  color: var(--mosterd);
}

/* ── Signalen-strip — top 3 + "+X meer" link ─────────────
   Compacte horizontale rij (max 40px per chip) onder de page-header.
   Vervangt de stack van losse banners. */
.signals-strip {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin: 0 0 16px;
}
.signal-chip {
  display: inline-flex; align-items: center; gap: 8px;
  max-height: 40px;
  padding: 6px 10px;
  font-size: 12px;
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: 2px;
  flex: 1 1 320px;
  min-width: 0;
}
.signal-tag {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.06em;
  padding: 2px 6px;
  border-radius: 2px;
  background: var(--bg);
  color: var(--text-secondary);
  white-space: nowrap;
}
.signal-tag.signal-tag-warn { background: var(--status-bad-soft, #fbe9e7); color: var(--status-bad); }
.signal-tag.signal-tag-info { background: var(--bg); color: var(--text-secondary); }
.signal-msg {
  flex: 1 1 auto;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--text-primary);
}
.signal-impact {
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--text-primary);
  white-space: nowrap;
}
.signal-action {
  font-size: 11px;
  color: var(--text-secondary);
  text-decoration: none;
  white-space: nowrap;
}
.signal-action:hover { color: var(--text-primary); }
.signals-more {
  font-size: 11px;
  color: var(--text-secondary);
  text-decoration: none;
  align-self: center;
  padding: 0 4px;
}
.signals-more:hover { color: var(--text-primary); }

/* ── Calendar inline-modus — chip + popover in page-header ─
   Wanneer .calendar-card binnen .page-header-row staat, klapt 'ie tot
   een kleine knop. De body wordt absolute popover (verstoort layout niet). */
.page-header-row .page-header-period-control {
  position: relative;
  display: inline-flex;
}
.page-header-row .calendar-card {
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  position: relative;
}
.page-header-row .calendar-header {
  border: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 4px 10px;
  font-size: 12px;
  border-radius: 2px;
  gap: 6px;
}
.page-header-row .calendar-header .cal-summary { font-size: 12px; }
.page-header-row .calendar-header .cal-toggle-hint {
  font-size: 10px;
  color: var(--text-tertiary);
}
.page-header-row .calendar-body {
  position: absolute;
  z-index: 50;
  top: calc(100% + 4px);
  right: 0;
  min-width: 320px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 2px;
  padding: 12px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
  margin-top: 0 !important;
}
.page-header-row .calendar-body.expanded { max-height: none; }
.page-header-row .calendar-shortcuts {
  margin-top: 0;
  padding-top: 0;
  border-bottom: 1px solid var(--border);
  padding-bottom: 10px;
  margin-bottom: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.page-header-row .calendar-shortcuts .btn-row {
  font-size: 11px;
  padding: 3px 8px;
}

@media (max-width: 760px) {
  .cat-row { grid-template-columns: 80px 1fr auto; }
  .cat-n { display: none; }
}
