/* ============================================================
   components.css — Cards, KPI, charts, table, advisory, badges
   Premium Dark Liquid Glass · Huize Priester Energiedashboard
   ============================================================ */

/* ── Utility-klassen (vervangen herhaalde inline-styles) ─── */
.flex5  { display:flex; align-items:center; gap:5px; }
.flex6  { display:flex; align-items:center; gap:6px; }
.dot-em { background:var(--emerald); border-radius:50%; }
.dot-bl { background:var(--blue);    border-radius:50%; }
.fs11m  { font-size:11px; color:var(--muted); }
.fs12m  { font-size:12px; color:var(--muted); }
.fs12ml { font-size:12px; color:var(--muted); line-height:1.6; }
.fs12e5 { font-size:12px; color:var(--emerald); margin-top:8px; font-weight:500; }
.fs10d  { font-size:10px; color:var(--dim); }
.fs14b  { font-size:14px; font-weight:600; margin-bottom:4px; }
.comp-hdr { display:flex; align-items:center; gap:5px; font-size:10px; color:var(--dim);
            text-transform:uppercase; letter-spacing:.06em; margin-bottom:8px; }
.stat-cell { background:var(--surface2); border-radius:var(--rs); padding:10px; text-align:center; }
.td-r  { text-align:right; padding:7px 10px; font-family:var(--mono); font-size:12px; font-weight:600; border-bottom:1px solid rgba(0,0,0,.05); }
.td-r0 { text-align:right; padding:7px 10px; font-family:var(--mono); font-size:12px; border-bottom:1px solid rgba(0,0,0,.05); }
.td-b  { padding:7px 10px; font-size:12px; border-bottom:1px solid rgba(0,0,0,.05); }
.td-hd { text-align:right; padding:6px 10px; color:var(--dim); font-weight:600;
         font-size:10px; letter-spacing:.04em; text-transform:uppercase; border-bottom:1px solid rgba(0,0,0,.12); }

/* ── Header ─────────────────────────────────────────────── */
.hdr { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:32px; gap:24px; }
.hl  { font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--emerald); font-family:var(--mono); }
h1   { font-size:28px; font-weight:600; letter-spacing:-.02em; }
.hp  { font-size:13px; color:var(--muted); }
.hr  { flex-shrink:0; }
.sd  { width:8px; height:8px; border-radius:50%; background:var(--emerald); box-shadow:0 0 8px var(--emerald-glow); animation:pulse 2.4s ease-in-out infinite; }
.st  { font-size:12px; color:var(--muted); font-family:var(--mono); }
.at  { background:var(--surface); border:1px solid var(--border); border-radius:var(--rs); padding:6px 12px; font-size:12px; color:var(--muted); font-family:var(--mono); }

/* ── Theme toggle ───────────────────────────────────────── */
#themeToggle {
  background: none; border: none; font-size:16px; cursor:pointer;
  padding: 0 10px; min-height:44px; min-width:44px;
  display: flex; align-items:center; justify-content:center;
  margin-left: auto; flex-shrink:0; border-radius:var(--rs);
  color: var(--muted); transition: background var(--transition);
}
#themeToggle:hover { background: var(--surface2); }

/* ── Glass card base (gedeeld door .cc, .kc, .gg, .adv-card) ── */
.cc, .kc, .gg, .adv-card {
  position: relative;
  background: var(--glass-grad);
  backdrop-filter: blur(var(--blur-card)) saturate(150%);
  -webkit-backdrop-filter: blur(var(--blur-card)) saturate(150%);
  border: 1px solid var(--border);
  border-radius: var(--r);
  box-shadow: var(--shadow-card);
  transition: background var(--transition), border-color var(--transition),
              box-shadow var(--transition), transform var(--transition);
}

/* Liquid sheen — bovenrand highlight */
.cc::before, .kc::before, .gg::before, .adv-card::before {
  content: "";
  position: absolute; inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(160deg,
              rgba(255,255,255,0.16), rgba(255,255,255,0.02) 40%,
              transparent 60%);
  -webkit-mask: linear-gradient(#000 0 0) content-box,
                linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}

/* Hover: lift + lichter glas */
.cc:hover, .kc:hover, .adv-card:hover {
  background: linear-gradient(160deg, rgba(255,255,255,0.08), rgba(255,255,255,0.03));
  border-color: var(--border2);
  box-shadow: var(--shadow-pop);
  transform: translateY(-2px);
}

/* ── Glow-varianten op kaarten ──────────────────────────── */
.glow-emerald { box-shadow: var(--shadow-card), var(--glow-emerald); }
.glow-emerald .kv { color: var(--emerald); text-shadow: 0 0 18px var(--emerald-glow); }

.glow-blue { box-shadow: var(--shadow-card), var(--glow-blue); }
.glow-blue .kv { color: var(--blue); text-shadow: 0 0 18px var(--blue-glow); }

.glow-amber { box-shadow: var(--shadow-card), var(--glow-amber); }
.glow-amber .kv { color: var(--amber); text-shadow: 0 0 18px var(--amber-glow); }

.glow-danger { box-shadow: var(--shadow-card), var(--glow-danger); border-color: var(--danger-border); }

/* ── KPI cards ──────────────────────────────────────────── */
.kc {
  padding: 20px 22px;
  overflow: hidden;
  cursor: default;
  display: flex;
  flex-direction: column;
}

/* Kleurvarianten: accent via linker border + top-glow */
.kc.ct, .kc.cg { border-left: var(--glass-accent-w) solid var(--emerald); }
.kc.ca         { border-left: var(--glass-accent-w) solid var(--amber); }
.kc.cb, .kc.cp { border-left: var(--glass-accent-w) solid var(--blue); }
.kc.cgas       { border-left: var(--glass-accent-w) solid var(--gas); }
.kc.cbatt      { border-left: var(--glass-accent-w) solid var(--batt); }
.kc.cev        { border-left: var(--glass-accent-w) solid var(--ev); }
.kc.chome      { border-left: var(--glass-accent-w) solid var(--home); }

/* Subtiele top-gloed per variant */
.kc.ct::after, .kc.cg::after { content:''; position:absolute; inset:0; border-radius:inherit;
  background:linear-gradient(to bottom, rgba(16,185,129,0.08), transparent 50%); pointer-events:none; }
.kc.ca::after  { content:''; position:absolute; inset:0; border-radius:inherit;
  background:linear-gradient(to bottom, rgba(245,158,11,0.08), transparent 50%); pointer-events:none; }
.kc.cb::after, .kc.cp::after { content:''; position:absolute; inset:0; border-radius:inherit;
  background:linear-gradient(to bottom, rgba(59,130,246,0.08), transparent 50%); pointer-events:none; }
.kc.cgas::after  { content:''; position:absolute; inset:0; border-radius:inherit;
  background:linear-gradient(to bottom, rgba(251,113,133,0.08), transparent 50%); pointer-events:none; }
.kc.cbatt::after { content:''; position:absolute; inset:0; border-radius:inherit;
  background:linear-gradient(to bottom, rgba(139,92,246,0.08), transparent 50%); pointer-events:none; }
.kc.cev::after   { content:''; position:absolute; inset:0; border-radius:inherit;
  background:linear-gradient(to bottom, rgba(132,204,22,0.08), transparent 50%); pointer-events:none; }
.kc.chome::after { content:''; position:absolute; inset:0; border-radius:inherit;
  background:linear-gradient(to bottom, rgba(56,189,248,0.08), transparent 50%); pointer-events:none; }

/* Hero KPI — speciale radiale gloed */
.kc.hero::after {
  content:""; position:absolute; inset:0; border-radius:inherit;
  background: radial-gradient(120% 100% at 0% 100%, var(--emerald-soft), transparent 55%);
  pointer-events:none;
}

/* Icoon-cirkel */
.ki {
  width: 32px; height: 32px;
  border-radius: var(--rs);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; margin-bottom: 12px; flex-shrink: 0;
}
.ki.ct, .ki.cg { background: var(--emerald-soft); color: var(--emerald); }
.ki.ca         { background: var(--amber-soft);   color: var(--amber); }
.ki.cb, .ki.cp { background: var(--blue-soft);    color: var(--blue); }
.ki.cbatt      { background: rgba(139,92,246,.14);  color: var(--batt); }
.ki.cgas       { background: rgba(251,113,133,.14); color: var(--gas); }
.ki.cev        { background: rgba(132,204,22,.14);  color: var(--ev); }
.ki.chome      { background: rgba(56,189,248,.14);  color: var(--home); }

/* ── SVG icon (sprite use) ───────────────────────────────── */
.ic { display:block; width:18px; height:18px; stroke:currentColor; stroke-width:1.25; stroke-linecap:round; stroke-linejoin:round; fill:none; flex-shrink:0; }
.ic-xs { display:inline-block; width:13px; height:13px; stroke:currentColor; stroke-width:1.25; stroke-linecap:round; stroke-linejoin:round; fill:none; vertical-align:-.1em; flex-shrink:0; }

/* ── KPI typografie ─────────────────────────────────────── */
.kl { font-size:12px; font-weight:500; color:var(--muted); letter-spacing:.04em; text-transform:uppercase; margin-bottom:6px; font-family:var(--sans); }
.kv { font-family:var(--mono); font-size:30px; font-weight:500; letter-spacing:-.02em; line-height:1; margin-bottom:4px; color:var(--text); }
.kv.ct, .kv.cg { color:var(--emerald); }
.kv.ca         { color:var(--amber); }
.kv.cb, .kv.cp { color:var(--blue); }
.kv.cev        { color:var(--ev); }
.kv.chome      { color:var(--home); }
.ku { font-size:13px; font-weight:400; opacity:.65; margin-left:3px; font-family:var(--mono); }
.ks { font-size:12px; color:var(--muted); margin-top:auto; padding-top:6px; line-height:1.5;
      display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }

/* Sparkline */
.kv-spark { margin-top:8px; opacity:.75; line-height:0; }
.kv-spark svg { display:block; width:100%; height:28px; }

/* Multi-metric card (tarieven 2×2) */
.kv-multi { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 10px 0; flex: 1; }
.km       { display: flex; flex-direction: column; gap: 3px; }
.km-l     { font-size: 10px; color: var(--dim); text-transform: uppercase; letter-spacing: .06em; font-family: var(--mono); }
.km-v     { font-family: var(--mono); font-size: 20px; font-weight: 600; letter-spacing: -.02em; line-height: 1.1; }

/* ── Data-state badges (live vs vast) + delta pill ─────────── */
.ds-live, .ds-fixed, .delta-badge {
  position: absolute; top: 12px; right: 14px;
  font-size: 8px; letter-spacing: .10em; text-transform: uppercase;
  font-family: var(--mono); font-weight: 600;
  display: inline-flex; align-items: center; gap: 5px;
  z-index: 2; pointer-events: none;
  padding: 3px 8px; border-radius: var(--r-pill);
  white-space: nowrap;
}
.ds-live {
  background: var(--emerald-soft);
  color: var(--emerald);
  border: 1px solid var(--emerald-border);
}
.ds-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 5px currentColor;
  animation: pulse 2.4s ease-in-out infinite;
  flex-shrink: 0;
}
.ds-fixed {
  color: var(--dim);
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--border);
}

/* ── Financiën cluster divider ──────────────────────────────── */
.fin-divider {
  display: flex; align-items: center; gap: 12px;
  margin: 20px 0 14px;
  border-top: 1px solid var(--hairline);
  padding-top: 14px;
}
.fin-divider span {
  font-size: 10px; letter-spacing: .08em; text-transform: uppercase;
  font-family: var(--mono); color: var(--dim);
}

/* ── Gauge ──────────────────────────────────────────────── */
.gg {
  padding: 20px;
  display: flex; flex-direction: column; align-items: center;
  gap: 6px; height: 100%; box-sizing: border-box;
}
.gl { font-size:11px; color:var(--muted); letter-spacing:.06em; text-transform:uppercase; text-align:center; }
.gw { position:relative; width:100px; height:60px; overflow:hidden; }
.gw canvas { position:absolute; top:0; left:0; }
.gv { font-family:var(--mono); font-size:20px; color:var(--emerald); text-align:center;
      text-shadow: 0 0 14px var(--emerald-glow); }
.gd { font-size:11px; color:var(--muted); text-align:center; max-width:130px; line-height:1.5; }

/* ── Chart card ─────────────────────────────────────────── */
.cc {
  padding: 20px 22px;
  display: flex; flex-direction: column;
  min-width: 0;
}
.sh  { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; flex-wrap:wrap; gap:8px; }
.st2 {
  font-size: 14px; font-weight: 600; color: var(--text);
  letter-spacing: .01em;
  display: flex; align-items: center; gap: 8px;
}
.st2::before {
  content:''; width:3px; height:14px;
  background: var(--blue);
  border-radius: 2px; display: block;
  box-shadow: 0 0 8px var(--blue-glow);
}

/* Canvas-wrapper */
.cw { position:relative; flex-shrink:0; }
.cc canvas, .gg canvas, .cw canvas { background: transparent; }

/* ── Tabs (segmented control op glas) ───────────────────── */
.tg {
  display: flex; gap: 3px; flex-wrap: wrap;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  padding: 3px;
}
.tb {
  background: transparent;
  border: none;
  border-radius: var(--r-pill);
  padding: 4px 12px; min-height: 30px;
  font-size: 12px; color: var(--muted);
  cursor: pointer; font-family: var(--sans);
  transition: background var(--transition), color var(--transition), box-shadow var(--transition);
  display: inline-flex; align-items: center;
}
.tb.active, .tb:hover {
  background: rgba(255,255,255,0.08);
  color: var(--text);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.10);
}
.tb.active { color: var(--text); font-weight: 500; }

/* ── Legenda ────────────────────────────────────────────── */
.leg     { display:flex; flex-wrap:wrap; gap:14px; margin-bottom:12px; }
.li      { display:flex; align-items:center; gap:6px; font-size:12px; color:var(--muted); }
.ls      { width:8px; height:8px; border-radius:2px; }           /* bar/area */
.ls-line { width:14px; height:2px; border-radius:1px; }          /* line dataset */
.ls-dash { width:14px; height:0; border-top:2px dashed; }        /* dashed reference line */

/* ── Mini-metric rij ────────────────────────────────────── */
.mm  { display:flex; justify-content:space-between; align-items:center; padding:9px 0; border-bottom:1px solid var(--hairline); }
.mm:last-child { border-bottom:none; }
.ml  { font-size:12px; color:var(--muted); }
.mv  { font-family:var(--mono); font-size:13px; color:var(--text); }

/* ── Formula ─────────────────────────────────────────────── */
.fb  { background:var(--emerald-soft); border:1px solid var(--emerald-border); border-radius:var(--rs); padding:14px 18px; margin-bottom:16px; font-size:13px; color:var(--muted); line-height:1.7; }
.fb strong { color:var(--emerald); font-weight:500; }
.feq { font-family:var(--mono); font-size:12px; background:rgba(16,185,129,0.08); border-radius:4px; padding:8px 12px; margin:10px 0 0; display:block; color:var(--emerald); letter-spacing:.02em; }

/* ── Benchmark ──────────────────────────────────────────── */
.br    { display:flex; align-items:center; gap:10px; padding:10px 0; border-bottom:1px solid var(--hairline); min-width:340px; }
.br:last-child { border-bottom:none; }
.bbl   { font-size:12px; color:var(--muted); min-width:160px; }
.bbw   { flex:1; height:6px; background:rgba(255,255,255,0.06); border-radius:var(--r-pill); position:relative; overflow:visible; }
.bbar  { height:100%; border-radius:var(--r-pill); width:0; transition: width 700ms cubic-bezier(.22,1,.36,1); }
.bbar.bar-grown { /* width gezet via inline style bij in-view */ }
.bbadge { font-size:10px; padding:2px 7px; border-radius:var(--r-pill); font-weight:500;
           background:var(--emerald-soft); color:var(--emerald); border:1px solid var(--emerald-border); }
.bbadge.warn    { background:var(--amber-soft);  color:var(--amber);  border-color:var(--amber-border); }
.bbadge.neutral { background:rgba(113,113,122,.12); color:var(--dim); border:1px solid var(--border); }
.bbadge.high    { background:var(--blue-soft);   color:var(--blue);   border-color:var(--blue-border); }

/* ── CO₂ bars ───────────────────────────────────────────── */
.c2r  { display:flex; gap:10px; margin-bottom:6px; align-items:center; }
.c2bo { flex:1; height:10px; background:rgba(255,255,255,0.06); border-radius:var(--r-pill); overflow:hidden; }
.c2bi { height:100%; border-radius:var(--r-pill); }
.c2l  { font-size:12px; color:var(--muted); min-width:80px; }
.c2v  { font-family:var(--mono); font-size:12px; min-width:70px; text-align:right; }

/* ── Table ──────────────────────────────────────────────── */
.tw { overflow-x:auto; -webkit-overflow-scrolling:touch; }
.fade-wrap { position:relative; }
.fade-wrap:not(.at-end) > .tw,
.fade-wrap:not(.at-end) > .scroll-x {
  -webkit-mask-image: linear-gradient(to right, black calc(100% - 56px), transparent 100%);
  mask-image: linear-gradient(to right, black calc(100% - 56px), transparent 100%);
}
.tw, .scroll-x { scrollbar-width:thin; scrollbar-color:var(--faint) transparent; }
.tw::-webkit-scrollbar, .scroll-x::-webkit-scrollbar { height:5px; display:block; }
.tw::-webkit-scrollbar-track, .scroll-x::-webkit-scrollbar-track { background:transparent; }
.tw::-webkit-scrollbar-thumb, .scroll-x::-webkit-scrollbar-thumb { background:var(--faint); border-radius:3px; }

table { width:100%; border-collapse:collapse; font-size:10.5px; }
thead th { text-align:right; padding:6px 8px; color:var(--dim); font-weight:400;
  letter-spacing:.06em; text-transform:uppercase; font-size:9.5px; font-family:var(--mono);
  border-bottom:1px solid var(--border2); white-space:nowrap; }
thead th:first-child { text-align:left; }
tbody tr { border-bottom:1px solid rgba(255,255,255,.04); transition:background var(--transition); }
tbody tr:hover { background:rgba(255,255,255,.03); }
tbody tr.tr { border-top:1px solid var(--border2); background:rgba(16,185,129,.04); font-weight:500; }
tbody td { padding:6px 8px; font-family:var(--mono); text-align:right; white-space:nowrap; }
tbody td:first-child { text-align:left; color:var(--muted); font-size:10px; }

/* Table color utilities */
.cbl { color:var(--blue); }
.cte { color:var(--emerald); }
.cgr { color:var(--emerald); }
.cam { color:var(--amber); }
.cmu { color:var(--muted); }
.cpo { color:var(--emerald); }
.cne { color:var(--emerald); }
.cga { color:var(--gas); }

/* ── Footnote ───────────────────────────────────────────── */
.fn {
  font-size:12px; color:var(--muted);
  background:rgba(255,255,255,0.03);
  border-left: 2px solid var(--blue);
  border-radius:0 var(--rs) var(--rs) 0;
  padding:10px 14px; line-height:1.6; margin-top:10px;
}

/* ── Glass chart tooltip ─────────────────────────────────── */
#chartTooltip {
  position: absolute;
  pointer-events: none;
  z-index: 9999;
  background: rgba(10, 15, 30, 0.88);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  border: 1px solid rgba(255,255,255,0.13);
  border-radius: 10px;
  padding: 10px 14px;
  font-family: var(--sans);
  font-size: 12px;
  color: var(--text);
  box-shadow: 0 8px 32px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.08);
  min-width: 130px;
  max-width: 260px;
  transition: opacity 120ms ease, transform 120ms ease;
}
#chartTooltip.ct-hidden {
  opacity: 0;
  transform: translateY(4px);
  pointer-events: none;
}
#chartTooltip .ct-title {
  font-size: 10px;
  font-family: var(--mono);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--dim);
  margin-bottom: 8px;
  padding-bottom: 6px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
#chartTooltip .ct-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 3px 0;
}
#chartTooltip .ct-swatch {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
#chartTooltip .ct-lbl {
  color: var(--muted);
  font-size: 11px;
  flex: 1;
}
#chartTooltip .ct-val {
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
  padding-left: 10px;
}

/* ── Footer ─────────────────────────────────────────────── */
.footer { margin-top:40px; text-align:center; font-size:11px; color:var(--faint); font-family:var(--mono); letter-spacing:.05em; }

/* ── Delta badge (periodevergelijking) ──────────────────── */
.delta-badge { display:inline-block; font-size:10px; font-family:var(--mono); padding:1px 6px; border-radius:4px; margin-left:4px; vertical-align:middle; }
.delta-pos { color:#34d399; background:rgba(52,211,153,.12); }
.delta-neg { color:#f87171; background:rgba(248,113,113,.12); }

/* ── Advisory section ───────────────────────────────────── */
.adv-impact { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:20px; }
.adv-card {
  padding: 20px 22px;
  display: flex; flex-direction: column;
}
.adv-warn { border-color:var(--danger-border); box-shadow:var(--shadow-card), var(--glow-danger); }
.adv-pri {
  font-size:10px; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  font-family:var(--mono); padding:3px 8px; border-radius:var(--r-pill);
  display:inline-flex; align-items:center; gap:5px;
  margin-bottom:12px; width:fit-content;
}
.adv-pri.p1 { background:var(--danger-soft); color:var(--danger); border:1px solid var(--danger-border); }
.adv-pri.p2 { background:var(--amber-soft);  color:var(--amber);  border:1px solid var(--amber-border); }
.adv-pri.p3 { background:var(--blue-soft);   color:var(--blue);   border:1px solid var(--blue-border); }
.adv-title  { font-size:15px; font-weight:600; color:var(--text); margin-bottom:6px; font-family:var(--sans); }
.adv-desc   { font-size:12px; color:var(--muted); line-height:1.65; margin-bottom:16px; flex:1; }
.adv-metrics { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; padding-top:14px; border-top:1px solid var(--hairline); }
.adv-met-label { font-size:10px; color:var(--dim); text-transform:uppercase; letter-spacing:.06em; font-family:var(--mono); margin-bottom:3px; }
.adv-met-val   { font-size:14px; font-weight:600; font-family:var(--mono); }
.adv-comp { background:var(--glass-grad); backdrop-filter:blur(var(--blur-card));
  border:1px solid var(--border); border-radius:var(--r); padding:20px; margin-bottom:14px; }
.adv-comp-row { display:flex; align-items:center; gap:12px; margin-bottom:10px; }
.adv-comp-label { font-size:12px; color:var(--muted); width:180px; flex-shrink:0; }
.adv-comp-bar-wrap { flex:1; height:8px; background:rgba(255,255,255,.06); border-radius:var(--r-pill); overflow:hidden; }
.adv-comp-bar { height:100%; border-radius:var(--r-pill); transition:width .7s ease-out; }
.adv-comp-val { font-size:12px; font-family:var(--mono); color:var(--text); width:55px; text-align:right; flex-shrink:0; }

/* ── Section title ─────────────────────────────────────── */
.st2.prose { letter-spacing:.01em; }

/* ── Toegankelijkheid ───────────────────────────────── */
.tb:focus-visible { outline: 2px solid var(--blue); outline-offset: 2px; }

@media (prefers-reduced-motion: reduce) {
  .ds-dot, .sd { animation: none; }
  .kc, .cc, .adv-card, .adv-comp-bar { transition: none; }
}
