/* ─────────────────────────────────────────────────────────────────
   PB COMMS — Communications Console — iteration 3
   Readable font sizes (Paul-feedback) · LLC brand-conform
   ───────────────────────────────────────────────────────────────── */

/* Geist + Geist-Mono self-hosted (DSGVO + FOUT-mitigation, Q8 Audit 2026-05-15) */
@font-face {
  font-family: 'Geist';
  src: url('fonts/geist-variable.woff2') format('woff2');
  font-weight: 100 900; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Geist Mono';
  src: url('fonts/geist-mono-variable.woff2') format('woff2');
  font-weight: 100 900; font-style: normal; font-display: swap;
}
/* CDN-Fallback entfernt 2026-05-15 (Q8 Audit) — Fonts liegen unter assets/fonts/ */

/* WCAG 2.3.3 + 2.2.2 — prefers-reduced-motion (Q1 Audit 2026-05-15) */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* Skip-Link für Tastatur-Navigation (Q2 Audit 2026-05-15) */
.skip-link {
  position: absolute;
  top: -100px; left: 12px;
  z-index: 9999;
  padding: 10px 18px;
  background: var(--accent);
  color: var(--text-inverse);
  font-family: var(--font-sans);
  font-size: 13.5px; font-weight: 600;
  border-radius: var(--r-sm);
  text-decoration: none;
}
.skip-link:focus { top: 12px; }

:root {
  --bg-canvas:      #09090B;
  --bg-surface:     #111113;
  --bg-elevated:    #18181B;
  --bg-overlay:     #1F1F23;
  --bg-input:       #0F0F11;

  --border-subtle:  #1F1F23;
  --border-default: #27272A;
  --border-strong:  #3F3F46;

  --text-primary:   #FAFAFA;
  --text-secondary: #A1A1AA;
  --text-tertiary:  #8B8B95;  /* erhöht von #71717A für WCAG-AA-Contrast 4,7:1 auf bg-elevated */
  --text-disabled:  #52525B;
  --text-inverse:   #09090B;

  --accent:         #FACC15;
  --accent-hover:   #FDE047;
  --accent-press:   #EAB308;
  --accent-muted:   rgba(250,204,21,0.10);
  --accent-ring:    rgba(250,204,21,0.40);
  --accent-critical:#EAFF00;

  --ok-fg:    #10B981;  --ok-bg:    rgba(16,185,129,0.10);  --ok-border:    rgba(16,185,129,0.25);
  --warn-fg:  #F59E0B;  --warn-bg:  rgba(245,158,11,0.10);  --warn-border:  rgba(245,158,11,0.25);
  --err-fg:   #EF4444;  --err-bg:   rgba(239,68,68,0.10);   --err-border:   rgba(239,68,68,0.25);
  --info-fg:  #38BDF8;  --info-bg:  rgba(56,189,248,0.10);  --info-border:  rgba(56,189,248,0.25);
  --idle-fg:  #71717A;  --idle-bg:  rgba(113,113,122,0.10); --idle-border:  rgba(113,113,122,0.25);

  --viz-1: #FACC15; --viz-2: #38BDF8; --viz-3: #A78BFA; --viz-4: #34D399; --viz-5: #FB7185;

  --sp-1: 4px; --sp-2: 8px; --sp-3: 12px; --sp-4: 16px; --sp-5: 20px;
  --sp-6: 24px; --sp-8: 32px; --sp-10: 40px; --sp-12: 48px; --sp-16: 64px; --sp-20: 80px;

  --r-sm: 4px; --r-md: 6px; --r-lg: 8px; --r-xl: 12px; --r-full: 9999px;

  --shadow-sm: 0 1px 2px rgba(0,0,0,0.5);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.5);
  --shadow-lg: 0 12px 32px rgba(0,0,0,0.6);
  --shadow-ring-accent: 0 0 0 1px rgba(250,204,21,0.50), 0 0 24px rgba(250,204,21,0.12);
  --shadow-ring-err:    0 0 0 1px rgba(239,68,68,0.60),  0 0 16px rgba(239,68,68,0.18);

  --t-instant: 80ms cubic-bezier(.4,0,.2,1);
  --t-fast:    150ms cubic-bezier(.4,0,.2,1);
  --t-base:    200ms cubic-bezier(.4,0,.2,1);
  --t-slow:    300ms cubic-bezier(.4,0,.2,1);

  --sidebar-w: 260px;
  --topbar-h: 56px;
  --row-h: 38px;
  --rail-w: 340px;
  --statusbar-h: 36px;

  --font-sans: 'Geist', ui-sans-serif, system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono: 'Geist Mono', 'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;
}

/* reset */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  background: var(--bg-canvas);
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 15.5px;
  font-weight: 400;
  line-height: 1.55;
  font-feature-settings: 'ss03', 'cv11';
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; text-align: left; }
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
input, textarea, select { font: inherit; color: inherit; }

/* focus */
*:focus { outline: none; }
*:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--r-sm);
  transition: outline-offset var(--t-instant);
}
button:focus-visible, .nav-item:focus-visible, .filter-pill:focus-visible,
.proof-actions button:focus-visible, .toggle:focus-visible {
  outline-offset: -2px;
}

.mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
.tnum { font-variant-numeric: tabular-nums; }
.muted { color: var(--text-secondary); }
.tert  { color: var(--text-tertiary); }
.accent { color: var(--accent); }

/* app shell */
.app {
  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr var(--rail-w);
  grid-template-rows: var(--topbar-h) 1fr var(--statusbar-h);
  grid-template-areas:
    "head head head"
    "nav  main rail"
    "foot foot foot";
  height: 100vh;
  width: 100vw;
}
.topbar    { grid-area: head; }
.sidebar   { grid-area: nav; }
.mainwork  { grid-area: main; overflow: hidden; position: relative; }
.siderail  { grid-area: rail; }
.statusbar { grid-area: foot; }

.app[data-rail="hidden"] {
  grid-template-columns: var(--sidebar-w) 1fr;
  grid-template-areas:
    "head head"
    "nav  main"
    "foot foot";
}
.app[data-rail="hidden"] .siderail { display: none; }

/* topbar */
.topbar {
  background: var(--bg-canvas);
  border-bottom: 1px solid var(--border-default);
  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr auto;
  align-items: center;
  z-index: 30;
}
.topbar-brand {
  display: flex; align-items: center; gap: 12px;
  padding: 0 18px;
  height: 100%;
  border-right: 1px solid var(--border-default);
}
.brand-mark {
  width: 30px; height: 30px;
  display: flex; align-items: center; justify-content: center;
  background: var(--accent);
  color: var(--text-inverse);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: -0.04em;
  border-radius: var(--r-sm);
}
.brand-text {
  display: flex; flex-direction: column;
  font-size: 14.5px;
  line-height: 1.1;
  font-weight: 500;
  letter-spacing: -0.005em;
}
.brand-text .l1 { color: var(--text-primary); }
.brand-text .l2 {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  margin-top: 4px;
}
.topbar-trail {
  display: flex; align-items: center;
  padding: 0 18px;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--text-secondary);
}
.topbar-trail .crumb { color: var(--text-tertiary); }
.topbar-trail .crumb.active { color: var(--text-primary); }
.topbar-trail .sep { color: var(--text-disabled); }
.topbar-actions {
  display: flex; height: 100%; align-items: center;
  padding: 0 16px;
  gap: 12px;
  border-left: 1px solid var(--border-default);
}

.killswitch-wrap { position: relative; }
.killswitch-toggle {
  display: inline-flex; align-items: center; gap: 8px;
  height: 34px; padding: 0 12px;
  background: rgba(34, 197, 94, 0.08);
  border: 1px solid rgba(34, 197, 94, 0.45);
  border-radius: var(--r-md);
  font-family: var(--font-mono); font-size: 12.5px;
  color: var(--text-primary);
  cursor: pointer;
  transition: background-color 0.15s, border-color 0.15s;
}
.killswitch-toggle:hover { background: rgba(34, 197, 94, 0.14); }
.killswitch-toggle.paused {
  background: rgba(239, 68, 68, 0.10);
  border-color: rgba(239, 68, 68, 0.55);
}
.killswitch-toggle .ks-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--ok-fg);
  box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.18);
  animation: ks-pulse 2.4s ease-in-out infinite;
}
.killswitch-toggle.paused .ks-dot {
  background: var(--err-fg);
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.18);
  animation: none;
}
@keyframes ks-pulse {
  0%, 100% { box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.18); }
  50% { box-shadow: 0 0 0 5px rgba(34, 197, 94, 0.08); }
}
@media (prefers-reduced-motion: reduce) {
  .killswitch-toggle .ks-dot { animation: none; }
}
.killswitch-toggle .ks-label strong { font-weight: 700; letter-spacing: 0.04em; }
.killswitch-toggle .ks-chev { font-size: 10px; color: var(--text-tertiary); }

.killswitch-menu {
  position: fixed; top: 52px; right: 60px;
  width: 340px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-md);
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.55), 0 4px 8px rgba(0, 0, 0, 0.30);
  z-index: 9999;
  padding: 14px 16px 12px;
  max-height: calc(100vh - 80px);
  overflow-y: auto;
}
.killswitch-menu[hidden] { display: none; }
.killswitch-menu .ks-menu-head { margin-bottom: 10px; padding-bottom: 10px; border-bottom: 1px solid var(--border-default); }
.killswitch-menu .ks-menu-head strong { font-size: 14px; color: var(--text-primary); }
.killswitch-menu .ks-menu-head p { font-size: 11.5px; color: var(--text-secondary); margin: 6px 0 0; line-height: 1.45; }
.killswitch-menu .ks-section-head {
  margin-top: 12px; margin-bottom: 4px;
  font-family: var(--font-mono); font-size: 10.5px;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--text-tertiary);
}
.killswitch-menu .ks-row {
  display: flex; align-items: center; gap: 8px;
  height: 28px; padding: 0 4px;
  font-size: 12.5px; color: var(--text-primary);
  cursor: pointer; border-radius: var(--r-sm);
}
.killswitch-menu .ks-row:hover { background: var(--bg-overlay); }
.killswitch-menu .ks-row.main {
  height: 36px; font-weight: 600; font-size: 13.5px;
  background: rgba(34, 197, 94, 0.06);
  border: 1px solid rgba(34, 197, 94, 0.30);
  padding: 0 10px;
  margin-bottom: 4px;
}
.killswitch-menu .ks-row input[type="checkbox"] { accent-color: var(--ok-fg); }
.killswitch-menu .ks-menu-foot {
  margin-top: 12px; padding-top: 10px;
  border-top: 1px solid var(--border-default);
}
.killswitch-menu .ks-foot-note {
  font-family: var(--font-mono); font-size: 10.5px;
  color: var(--text-tertiary);
}
.kpi-mini {
  display: flex; align-items: center; gap: 7px;
  font-family: var(--font-mono);
  font-size: 12.5px;
  padding: 7px 12px;
  border: 1px solid var(--border-default);
  border-radius: var(--r-md);
  color: var(--text-secondary);
  letter-spacing: 0.02em;
  background: transparent;
  transition: all var(--t-fast);
  cursor: pointer;
}
.kpi-mini:hover { color: var(--text-primary); border-color: var(--border-strong); }
.kpi-mini .v { color: var(--text-primary); font-weight: 700; }
.kpi-mini .v.accent { color: var(--accent); }
.kpi-mini .v.err { color: var(--err-fg); }
.kpi-mini .v.ok { color: var(--ok-fg); }
.kpi-mini.alert {
  border-color: var(--err-border);
  background: var(--err-bg);
  color: var(--err-fg);
}
.kpi-mini.alert .v { color: var(--err-fg); }

.help-key {
  font-family: var(--font-mono);
  font-size: 13px;
  padding: 5px 10px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  border-radius: var(--r-sm);
  color: var(--text-tertiary);
  cursor: pointer;
  transition: all var(--t-fast);
  font-weight: 600;
}
.help-key:hover { color: var(--text-primary); border-color: var(--border-strong); }

/* sidebar */
.sidebar {
  background: var(--bg-canvas);
  border-right: 1px solid var(--border-default);
  overflow-y: auto;
  padding: 10px 0;
}
.nav-group { padding: 8px 0 6px; }
.nav-group-label {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  padding: 10px 18px 8px;
  display: flex; align-items: center; gap: 6px;
  font-weight: 600;
}

/* Collapsible nav-group (Iteration 4.2) */
button.nav-group-label.nav-group-toggle {
  background: transparent; border: none; cursor: pointer;
  width: 100%; text-align: left;
  font-family: var(--font-mono); font-size: 12px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-tertiary);
  padding: 10px 18px 8px;
  display: flex; align-items: center; gap: 8px;
  transition: color var(--t-fast);
}
button.nav-group-label.nav-group-toggle:hover { color: var(--text-secondary); }
button.nav-group-label.nav-group-toggle .chev {
  display: inline-block;
  transition: transform 180ms ease-out;
  font-size: 10px;
  width: 10px;
}
.nav-group.collapsible[aria-expanded="true"] .chev,
.nav-group.collapsible:not(.collapsed) .chev { transform: rotate(90deg); }
.nav-group-items {
  display: flex; flex-direction: column;
  overflow: hidden;
  max-height: 600px;
  transition: max-height 220ms ease-out;
}
.nav-group.collapsible.collapsed .nav-group-items {
  max-height: 0;
}
.nav-item {
  display: grid;
  grid-template-columns: 20px 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
  margin: 2px 8px;
  font-size: 15px;
  color: var(--text-secondary);
  cursor: pointer;
  border-radius: var(--r-md);
  transition: all var(--t-fast);
  width: calc(100% - 16px);
  letter-spacing: -0.005em;
}
.nav-item:hover { background: var(--bg-elevated); color: var(--text-primary); }
.nav-item.active {
  background: var(--accent-muted);
  color: var(--accent);
  font-weight: 600;
}
.nav-item .ico {
  display: flex; align-items: center; justify-content: center;
  color: var(--text-tertiary);
  font-size: 16px;
}
.nav-item.active .ico { color: var(--accent); }
.nav-item .badge {
  font-family: var(--font-mono);
  font-size: 12.5px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: var(--r-sm);
  background: var(--bg-overlay);
  color: var(--text-secondary);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0;
}
.nav-item .badge.accent { background: var(--accent); color: var(--text-inverse); }
.nav-item .badge.err { background: var(--err-fg); color: var(--text-inverse); }
.nav-item .badge.ok { background: var(--ok-fg); color: var(--text-inverse); }
.nav-item .badge.warn { background: var(--warn-fg); color: var(--text-inverse); }
.nav-item.active .badge { background: var(--accent); color: var(--text-inverse); }

/* main */
.mainwork {
  background: var(--bg-surface);
  overflow-y: auto;
}
.view { display: none; }
.view.active { display: block; animation: fade-in var(--t-base); }

.view-header {
  padding: 24px 32px 20px;
  border-bottom: 1px solid var(--border-default);
  background: var(--bg-canvas);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: end;
  position: sticky;
  top: 0;
  z-index: 20;
}
.view-header h1, .view-header .h1 {
  font-size: 28px;
  font-weight: 600;
  letter-spacing: -0.022em;
  color: var(--text-primary);
}
.view-header .deck {
  font-size: 15px;
  color: var(--text-secondary);
  margin-top: 8px;
  max-width: 720px;
  letter-spacing: -0.005em;
  line-height: 1.5;
}
.view-header .header-actions {
  display: flex; gap: 8px; align-items: center;
}
.view-header-titlewrap {
  display: flex; align-items: center; gap: 20px;
  flex-wrap: wrap;
}
.view-header-titlewrap .queue-toolbar.inline {
  border-bottom: none;
  padding: 0;
  position: static;
  height: auto;
  background: transparent;
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
}
.view-header-titlewrap .queue-toolbar.inline .filter-pill {
  height: 26px;
  padding: 0 11px;
  font-size: 12px;
}
.view-header-titlewrap .queue-toolbar.inline .pill-sep {
  display: inline-block;
  width: 1px; height: 16px;
  background: var(--border-default);
  margin: 0 4px;
}
.view-body { padding: 24px 32px 48px; }

/* right rail */
.siderail {
  background: var(--bg-canvas);
  border-left: 1px solid var(--border-default);
  overflow-y: auto;
  padding: 20px 18px;
}
.rail-block { margin-bottom: 24px; }
.rail-block-label {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-secondary);
  padding-bottom: 10px;
  margin-bottom: 12px;
  border-bottom: 1px solid var(--border-default);
  display: flex; justify-content: space-between; align-items: center;
  font-weight: 600;
}
.rail-block-label .count {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--accent);
  letter-spacing: 0;
  font-weight: 600;
}

/* statusbar */
.statusbar {
  background: var(--bg-canvas);
  border-top: 1px solid var(--border-default);
  display: flex; align-items: center;
  padding: 0 18px;
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--text-secondary);
  gap: 20px;
  letter-spacing: 0.02em;
}
.statusbar .item { display: flex; align-items: center; gap: 6px; }
.statusbar .item .v { color: var(--text-primary); font-weight: 600; }
.statusbar .item .v.accent { color: var(--accent); }
.statusbar .item .v.ok { color: var(--ok-fg); }
.statusbar .item .v.warn { color: var(--warn-fg); }
.statusbar .item .v.err { color: var(--err-fg); }
.statusbar .spacer { flex: 1; }
.dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--ok-fg);
  flex-shrink: 0;
}
.dot.warn { background: var(--warn-fg); }
.dot.err  { background: var(--err-fg); }
.pulse {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--ok-fg);
  box-shadow: 0 0 0 0 currentColor;
  animation: pulse-anim 2.4s infinite;
  color: var(--ok-fg);
  flex-shrink: 0;
}
.pulse.err { background: var(--err-fg); color: var(--err-fg); }
@keyframes pulse-anim {
  0% { box-shadow: 0 0 0 0 currentColor; }
  70% { box-shadow: 0 0 0 7px transparent; }
  100% { box-shadow: 0 0 0 0 transparent; }
}

/* buttons */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 14px;
  font-weight: 500;
  padding: 7px 14px;
  height: 34px;
  border: 1px solid var(--border-default);
  background: var(--bg-elevated);
  color: var(--text-primary);
  border-radius: var(--r-md);
  cursor: pointer;
  transition: all var(--t-fast);
  letter-spacing: -0.005em;
  text-align: center;
  justify-content: center;
  white-space: nowrap;
}
.btn:hover { background: var(--bg-overlay); border-color: var(--border-strong); }
.btn.primary {
  background: var(--accent);
  color: var(--text-inverse);
  border-color: var(--accent);
  font-weight: 600;
}
.btn.primary:hover { background: var(--accent-hover); border-color: var(--accent-hover); }
.btn.danger {
  background: var(--err-bg);
  color: var(--err-fg);
  border-color: var(--err-border);
}
.btn.danger:hover { background: rgba(239,68,68,0.18); border-color: var(--err-fg); }
.btn.ghost {
  background: transparent;
  border-color: var(--border-default);
  color: var(--text-secondary);
}
.btn.ghost:hover { color: var(--text-primary); background: var(--bg-elevated); }
.btn .kbd {
  font-family: var(--font-mono);
  font-size: 12px;
  padding: 2px 6px;
  background: rgba(0,0,0,0.30);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 3px;
  margin-left: 5px;
  font-weight: 600;
}
.btn-sm { font-size: 13px; padding: 5px 11px; height: 30px; }
.btn-sm .kbd { font-size: 11px; padding: 1px 5px; }

/* pills */
.pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 600;
  padding: 3px 9px;
  border-radius: var(--r-sm);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: var(--idle-bg);
  color: var(--text-secondary);
  border: 1px solid var(--border-default);
  white-space: nowrap;
}
.pill::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}
.pill.accent { background: var(--accent-muted); color: var(--accent); border-color: var(--accent-ring); }
.pill.ok    { background: var(--ok-bg);    color: var(--ok-fg);    border-color: var(--ok-border); }
.pill.warn  { background: var(--warn-bg);  color: var(--warn-fg);  border-color: var(--warn-border); }
.pill.err   { background: var(--err-bg);   color: var(--err-fg);   border-color: var(--err-border); }
.pill.info  { background: var(--info-bg);  color: var(--info-fg);  border-color: var(--info-border); }
.pill.viz3  { background: rgba(167,139,250,0.10); color: var(--viz-3); border-color: rgba(167,139,250,0.25); }
.pill.viz4  { background: rgba(52,211,153,0.10); color: var(--viz-4); border-color: rgba(52,211,153,0.25); }
.pill.viz5  { background: rgba(251,113,133,0.10); color: var(--viz-5); border-color: rgba(251,113,133,0.25); }
.pill.no-dot::before { display: none; }

/* QUEUE */
.queue-toolbar {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 32px;
  background: var(--bg-canvas);
  border-bottom: 1px solid var(--border-default);
  position: sticky;
  top: var(--view-header-h, 88px);
  z-index: 15;
}
.filter-pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 13.5px;
  font-weight: 500;
  padding: 5px 12px;
  height: 30px;
  border: 1px solid var(--border-default);
  border-radius: var(--r-md);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all var(--t-fast);
  background: transparent;
  letter-spacing: -0.005em;
}
.filter-pill:hover { color: var(--text-primary); border-color: var(--border-strong); background: var(--bg-elevated); }
.filter-pill.active { color: var(--text-inverse); background: var(--accent); border-color: var(--accent); font-weight: 600; }
.filter-pill .count {
  font-family: var(--font-mono);
  font-size: 12px;
  font-variant-numeric: tabular-nums;
  opacity: 0.80;
}

.queue-progress {
  margin-left: auto;
  display: flex; align-items: center; gap: 14px;
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--text-secondary);
}
.queue-progress .bar {
  width: 140px; height: 5px;
  background: var(--bg-overlay);
  border-radius: var(--r-full);
  position: relative;
  overflow: hidden;
}
.queue-progress .bar::after {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0;
  width: var(--p, 30%); background: var(--accent);
}
.queue-progress .v { color: var(--text-primary); font-weight: 700; }

/* sticky action bar */
.action-bar {
  position: sticky;
  top: calc(var(--topbar-h) + 102px);
  z-index: 14;
  background: var(--bg-canvas);
  border-bottom: 1px solid var(--border-default);
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 12px 28px;
  box-shadow: 0 6px 16px rgba(0,0,0,0.35);
}
.action-bar .now-reviewing {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--text-tertiary);
  letter-spacing: 0.02em;
  flex: 1 1 auto;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
}
.action-bar .now-reviewing .counter { color: var(--text-secondary); font-weight: 700; flex-shrink: 0; }
.action-bar .now-reviewing .who {
  font-family: var(--font-sans);
  font-size: 16px;
  color: var(--text-primary);
  font-weight: 600;
  letter-spacing: -0.005em;
  overflow: hidden; text-overflow: ellipsis;
  min-width: 0;
}
.action-bar .now-reviewing .score {
  font-family: var(--font-mono);
  font-size: 14.5px;
  font-weight: 700;
  color: var(--accent);
  padding: 3px 10px;
  background: var(--accent-muted);
  border: 1px solid var(--accent-ring);
  border-radius: var(--r-sm);
  flex-shrink: 0;
}
.action-bar .now-reviewing .sep { color: var(--text-disabled); flex-shrink: 0; }
.action-bar .quick-actions {
  display: flex; gap: 6px; flex-shrink: 0;
}
.action-bar .quick-actions .btn {
  height: 34px;
  padding: 0 14px;
  font-size: 13.5px;
}

/* proof card — full width, content-first with side actions */
.proof-card {
  margin: 18px 28px 24px;
  background: var(--bg-canvas);
  border: 1px solid var(--border-default);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}

.proof-body { padding: 28px 36px 24px; display: grid; gap: 22px; }

/* layout split: content fills, actions on the right side */
.proof-layout {
  display: grid;
  grid-template-columns: 1fr 170px;
  gap: 24px;
  align-items: start;
}
/* content area splits the inbound message and the draft side by side */
.proof-content {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 20px;
  min-width: 0;
  align-items: stretch;
}
.proof-content > .proof-inbound,
.proof-content > .proof-draft { min-width: 0; }
.proof-draft .draft-toolbar { flex-wrap: wrap; min-width: 0; }
.proof-draft .draft-toolbar .dt-hint { white-space: normal; max-width: 100%; }

.proof-actions-side {
  position: sticky;
  top: 24px;
  display: grid;
  gap: 8px;
  align-content: start;
}
.proof-actions-side .btn {
  width: 100%;
  height: 42px;
  font-size: 14.5px;
  justify-content: space-between;
}
.proof-actions-side .btn .kbd {
  background: rgba(0,0,0,0.30);
  border: 1px solid rgba(255,255,255,0.08);
}
.proof-actions-side .btn.primary .kbd {
  background: rgba(0,0,0,0.20);
  border-color: rgba(0,0,0,0.25);
  color: var(--text-inverse);
  opacity: 0.75;
}
.proof-actions-side .actions-label {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  font-weight: 600;
  padding-bottom: 4px;
  margin-bottom: 4px;
  border-bottom: 1px solid var(--border-subtle);
}

.donor-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 12px;
  background: var(--accent-muted);
  border: 1px solid var(--accent-ring);
  border-radius: var(--r-md);
  font-size: 13.5px;
  color: var(--accent);
  font-weight: 600;
  letter-spacing: -0.005em;
}
.donor-badge .sep { color: var(--text-tertiary); }
.donor-badge .amt { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
.donor-badge .status { color: var(--warn-fg); font-weight: 600; }

.proof-tech {
  margin: 0 36px 24px;
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--text-secondary);
}
.proof-tech summary {
  cursor: pointer;
  color: var(--text-tertiary);
  font-size: 12.5px;
  letter-spacing: 0.04em;
  padding: 8px 0;
  list-style: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  user-select: none;
}
.proof-tech summary::-webkit-details-marker { display: none; }
.proof-tech summary::before {
  content: "▸";
  transition: transform var(--t-fast);
  display: inline-block;
}
.proof-tech[open] summary::before { transform: rotate(90deg); }
.proof-tech summary:hover { color: var(--text-secondary); }
.proof-tech .tech-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px 28px;
  padding: 14px 18px;
  margin-top: 8px;
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-md);
}
.proof-tech .tech-grid > div { display: grid; grid-template-columns: 140px 1fr; gap: 8px; }
.proof-tech .tech-grid dt {
  color: var(--text-tertiary);
  font-size: 12px;
  letter-spacing: 0.04em;
}
.proof-tech .tech-grid dd {
  color: var(--text-primary);
  font-size: 13px;
  font-weight: 600;
}
.proof-tech .tech-grid dd.accent { color: var(--accent); }
.proof-tech .tech-grid dd.warn { color: var(--warn-fg); }

.proof-from {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--border-subtle);
  flex-wrap: wrap;
}
.proof-from .who {
  font-size: 22px;
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: -0.012em;
}
.proof-from .who-sub {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--text-tertiary);
  margin-top: 5px;
  letter-spacing: 0.02em;
}

.proof-inbound {
  font-size: 15.5px;
  line-height: 1.7;
  color: var(--text-primary);
  letter-spacing: -0.005em;
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  border-radius: var(--r-md);
  padding: 20px 24px;
  position: relative;
}
.proof-inbound::before {
  content: "NACHRICHT";
  position: absolute;
  top: -10px;
  left: 16px;
  background: var(--bg-canvas);
  padding: 0 10px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  color: var(--text-tertiary);
  font-weight: 700;
}
.proof-inbound p + p { margin-top: 0.75em; }
.proof-inbound em { color: var(--text-secondary); font-style: italic; }

.proof-classify {
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  border-radius: var(--r-md);
  padding: 14px 18px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.cf .l {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  margin-bottom: 6px;
  font-weight: 600;
}
.cf .v {
  font-size: 17px;
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: -0.01em;
  line-height: 1.2;
}
.cf .v.accent { color: var(--accent); }
.cf .v.err { color: var(--err-fg); }
.cf .v.warn { color: var(--warn-fg); }
.cf .v.mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }

.proof-draft {
  background: var(--bg-surface);
  border: 1px solid var(--accent-ring);
  border-radius: var(--r-md);
  padding: 20px 24px;
  position: relative;
}
.proof-draft::before {
  content: "ENTWURF";
  position: absolute;
  top: -10px;
  left: 16px;
  background: var(--bg-canvas);
  padding: 0 10px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  color: var(--accent);
  font-weight: 700;
}
.proof-draft .draft-text {
  font-size: 15.5px;
  line-height: 1.7;
  color: var(--text-primary);
  letter-spacing: -0.005em;
  outline: none;
  cursor: text;
  border-radius: var(--r-sm);
  padding: 4px 6px;
  margin: -4px -6px;
  transition: background var(--t-fast), box-shadow var(--t-fast);
}
.proof-draft .draft-text[contenteditable="true"]:hover {
  background: rgba(250,204,21,0.025);
}
.proof-draft .draft-text[contenteditable="true"]:focus {
  background: rgba(250,204,21,0.04);
  box-shadow: inset 0 0 0 1px var(--accent-ring);
}
.proof-draft .draft-text p + p { margin-top: 0.75em; }
.proof-draft .draft-text em { font-style: italic; color: var(--accent); }
.proof-draft .draft-text strong, .proof-draft .draft-text b { font-weight: 700; color: var(--text-primary); }
.proof-draft .draft-text u { text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }

/* Draft Format-Toolbar (Iteration 4.3) */
.draft-toolbar {
  display: flex; align-items: center; gap: 4px;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border-subtle);
}
.dt-btn {
  background: transparent;
  border: 1px solid var(--border-default);
  color: var(--text-secondary);
  padding: 4px 9px;
  height: 28px;
  font-family: var(--font-sans);
  font-size: 13.5px;
  border-radius: var(--r-sm);
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 5px;
  transition: all var(--t-fast);
  min-width: 28px; justify-content: center;
}
.dt-btn:hover { color: var(--text-primary); border-color: var(--border-strong); background: var(--bg-elevated); }
.dt-btn.active { color: var(--accent); border-color: var(--accent-ring); background: var(--accent-muted); }
.dt-btn b { font-weight: 700; }
.dt-btn i { font-style: italic; }
.dt-btn u { text-decoration: underline; text-underline-offset: 2px; }
.dt-btn.dt-spell {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  padding: 4px 12px;
  white-space: nowrap;
}
.dt-btn.dt-spell:hover { color: var(--accent); border-color: var(--accent-ring); }
.dt-btn.dt-spell.busy {
  color: var(--text-tertiary);
  cursor: wait;
  position: relative;
}
.dt-btn.dt-spell.busy::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -1px;
  height: 1px; background: var(--accent);
  animation: dt-progress 1.5s linear forwards;
  transform-origin: left;
}
@keyframes dt-progress { from { transform: scaleX(0); } to { transform: scaleX(1); } }
.dt-sep {
  display: inline-block; width: 1px; height: 18px;
  background: var(--border-default); margin: 0 6px;
}
.dt-hint {
  margin-left: auto;
  font-family: var(--font-mono); font-size: 11px;
  color: var(--text-tertiary);
  letter-spacing: 0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.proof-draft .draft-meta {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--border-subtle);
  display: flex;
  gap: 22px;
  flex-wrap: wrap;
  row-gap: 8px;
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--text-secondary);
  letter-spacing: 0.02em;
}
.proof-draft .draft-meta > span { white-space: nowrap; }
.proof-draft .draft-meta .v { color: var(--text-primary); font-weight: 700; }

/* pending stack */
.proof-stack {
  margin: 0 28px 32px;
  border: 1px solid var(--border-default);
  border-radius: var(--r-md);
  overflow: hidden;
  background: var(--bg-canvas);
}
.proof-stack-label {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-secondary);
  padding: 12px 18px;
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border-default);
  display: flex; align-items: center; justify-content: space-between;
  font-weight: 600;
}
.proof-stack-label .count {
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--accent);
  font-weight: 700;
}

.mini {
  display: grid;
  grid-template-columns: 70px 1fr 160px 64px 32px;
  align-items: center;
  gap: 14px;
  padding: 12px 18px;
  border-bottom: 1px solid var(--border-subtle);
  background: var(--bg-canvas);
  cursor: pointer;
  transition: all var(--t-fast);
  font-size: 14.5px;
  border-left: 2px solid transparent;
  width: 100%;
  text-align: left;
}
.mini .action { display: none; }
.mini:last-of-type { border-bottom: none; }
.mini:hover { background: var(--bg-elevated); }

/* DIREKT-Kanäle (E-Mail, Telegram-DM) heben sich visuell ab */
.mini[data-direct] {
  border-left-color: var(--accent);
  background: linear-gradient(90deg, var(--accent-muted) 0%, var(--bg-canvas) 14%);
}
.mini[data-direct]:hover {
  background: linear-gradient(90deg, var(--accent-muted) 0%, var(--bg-elevated) 14%);
}

.mini .channel-tag {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  color: var(--text-tertiary);
  padding: 1px 6px;
  border: 1px solid var(--border-default);
  border-radius: 3px;
  margin-right: 8px;
  font-weight: 700;
  vertical-align: 1px;
}
.mini[data-direct] .channel-tag {
  color: var(--accent);
  border-color: var(--accent-ring);
  background: var(--accent-muted);
}

.mini .sla-chip {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
  padding: 1px 7px;
  border-radius: var(--r-sm);
  white-space: nowrap;
  margin-left: 8px;
}
.mini .sla-chip.warn   { color: var(--warn-fg); background: var(--warn-bg); border: 1px solid var(--warn-border); }
.mini .sla-chip.urgent { color: var(--err-fg);  background: var(--err-bg);  border: 1px solid var(--err-border); }
.mini .sla-chip.normal { color: var(--text-secondary); background: var(--bg-overlay); border: 1px solid var(--border-default); }

.mini-divider {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  padding: 14px 18px 10px;
  border-top: 1px solid var(--border-default);
  font-weight: 700;
  background: var(--bg-surface);
  display: flex;
  align-items: center;
  gap: 12px;
}
.mini-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--border-subtle);
}

/* Proof-from SLA chip — inline */
.proof-from .sla-inline {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.02em;
  padding: 3px 10px;
  border-radius: var(--r-sm);
  margin-left: 10px;
}
.proof-from .sla-inline.warn   { color: var(--warn-fg); background: var(--warn-bg); border: 1px solid var(--warn-border); }
.proof-from .sla-inline.urgent { color: var(--err-fg);  background: var(--err-bg);  border: 1px solid var(--err-border); }
.mini .when {
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--text-secondary);
  letter-spacing: 0.02em;
}
.mini .who {
  font-size: 14.5px; color: var(--text-primary); font-weight: 600;
  letter-spacing: -0.005em;
  min-width: 0;
}
.mini .who .preview {
  display: block;
  font-family: var(--font-sans);
  font-size: 13.5px;
  color: var(--text-secondary);
  font-weight: 400;
  margin-top: 3px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mini .score {
  font-family: var(--font-mono);
  font-size: 15px;
  font-weight: 700;
  text-align: right;
  font-variant-numeric: tabular-nums;
  color: var(--text-secondary);
}
.mini .score.high { color: var(--accent); }
.mini .score.crit { color: var(--err-fg); }
.mini .action {
  font-family: var(--font-mono);
  font-size: 11.5px;
  text-align: right;
  color: var(--text-secondary);
  letter-spacing: 0.04em;
  font-weight: 600;
}
.mini .arrow {
  font-family: var(--font-mono);
  text-align: right;
  color: var(--text-tertiary);
  font-size: 16px;
}
.mini:hover .arrow { color: var(--accent); }

/* donor card */
.donor-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  border-radius: var(--r-md);
  padding: 16px 16px 14px;
}
.donor-top {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 12px;
  align-items: center;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border-subtle);
}
.donor-top .ava {
  width: 42px; height: 42px;
  background: var(--accent-muted);
  border: 1px solid var(--accent-ring);
  border-radius: var(--r-full);
  color: var(--accent);
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; font-weight: 700;
}
.donor-top .name { font-size: 15.5px; font-weight: 700; color: var(--text-primary); letter-spacing: -0.005em; }
.donor-top .tier {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  margin-top: 4px;
  font-weight: 700;
}
.donor-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 8px;
  padding: 14px 0;
  border-bottom: 1px solid var(--border-subtle);
}
.donor-stats .l {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  font-weight: 600;
}
.donor-stats .v {
  font-family: var(--font-mono);
  font-size: 17px;
  font-weight: 700;
  color: var(--text-primary);
  margin-top: 4px;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.005em;
}
.donor-recent { padding-top: 12px; }
.donor-recent .item {
  display: grid;
  grid-template-columns: 1fr auto;
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--text-secondary);
  padding: 6px 0;
  border-bottom: 1px solid var(--border-subtle);
  letter-spacing: 0.02em;
}
.donor-recent .item:last-child { border-bottom: none; }
.donor-recent .item .when { color: var(--text-tertiary); }
.donor-recent .item .v { color: var(--text-primary); font-weight: 700; }

/* sys-row */
.sys-row {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  padding: 7px 0;
  font-size: 14px;
  border-bottom: 1px solid var(--border-subtle);
}
.sys-row:last-child { border-bottom: none; }
.sys-row .l { color: var(--text-secondary); }
.sys-row .v { font-family: var(--font-mono); color: var(--text-primary); font-weight: 700; font-variant-numeric: tabular-nums; font-size: 13px; }
.sys-row .v.accent { color: var(--accent); }
.sys-row .v.ok { color: var(--ok-fg); }
.sys-row .v.warn { color: var(--warn-fg); }
.sys-row .v.err { color: var(--err-fg); }

/* inbox stream */
.stream-table {
  background: var(--bg-canvas);
  border: 1px solid var(--border-default);
  border-radius: var(--r-md);
  overflow: hidden;
}
.stream-th, .stream-row {
  display: grid;
  grid-template-columns: 70px 64px 220px 1fr 140px 64px 110px;
  align-items: center;
  gap: 14px;
  padding: 0 16px;
}
.stream-th {
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border-default);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-secondary);
  font-weight: 600;
  height: 38px;
}
.stream-row {
  border-bottom: 1px solid var(--border-subtle);
  cursor: pointer;
  font-size: 14.5px;
  transition: background var(--t-fast), border-color var(--t-fast);
  letter-spacing: -0.005em;
  height: 52px;
  border-left: 2px solid transparent;
  width: 100%;
  text-align: left;
}
.stream-row:last-child { border-bottom: none; }
.stream-row:hover { background: var(--bg-elevated); border-left-color: var(--accent); }
.stream-row .when {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--text-secondary);
  letter-spacing: 0.02em;
}
.stream-row .chan {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-primary);
  padding: 3px 7px;
  background: var(--bg-overlay);
  border: 1px solid var(--border-default);
  border-radius: var(--r-sm);
  text-align: center;
  font-weight: 700;
}
.stream-row .who {
  color: var(--text-primary); font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  min-width: 0;
}
.stream-row .who .h {
  display: block;
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--text-secondary);
  margin-top: 4px;
  font-weight: 400;
  letter-spacing: 0.02em;
}
.stream-row .preview {
  color: var(--text-secondary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  font-size: 14.5px;
  min-width: 0;
}

/* KPI */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 22px;
}
.kpi-cell {
  background: var(--bg-canvas);
  border: 1px solid var(--border-default);
  border-radius: var(--r-md);
  padding: 18px 20px;
  display: flex; flex-direction: column; gap: 8px;
}
.kpi-cell .l {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  font-weight: 600;
}
.kpi-cell .v {
  font-size: 34px;
  font-weight: 600;
  letter-spacing: -0.025em;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
  line-height: 1.05;
}
.kpi-cell .v .u { font-size: 16px; color: var(--text-tertiary); margin-left: 4px; font-weight: 400; }
.kpi-cell .v.accent { color: var(--accent); }
.kpi-cell .v.ok { color: var(--ok-fg); }
.kpi-cell .v.warn { color: var(--warn-fg); }
.kpi-cell .v.err { color: var(--err-fg); }
.kpi-cell .delta {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--text-secondary);
  display: flex; gap: 4px; align-items: center;
  letter-spacing: 0.02em;
}
.kpi-cell .delta.up { color: var(--ok-fg); }
.kpi-cell .delta.down { color: var(--err-fg); }
.kpi-cell .spark { width: 100%; height: 32px; margin-top: 8px; }

.card {
  background: var(--bg-canvas);
  border: 1px solid var(--border-default);
  border-radius: var(--r-lg);
  padding: 20px 22px;
}
.card h3 {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: -0.005em;
}
.card .deck {
  font-size: 14px;
  color: var(--text-secondary);
  margin-top: 6px;
  margin-bottom: 16px;
  line-height: 1.5;
}

.bucket-bar {
  display: grid;
  grid-template-columns: 220px 1fr 68px 68px;
  align-items: center;
  gap: 14px;
  padding: 9px 0;
}
.bucket-bar .name { font-size: 14.5px; color: var(--text-primary); letter-spacing: -0.005em; }
.bucket-bar .name .h { color: var(--text-tertiary); font-size: 12.5px; margin-left: 8px; }
.bucket-bar .track {
  height: 9px;
  background: var(--bg-overlay);
  border-radius: var(--r-full);
  position: relative;
  overflow: hidden;
}
.bucket-bar .track::after {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0;
  width: var(--w); background: var(--c, var(--accent));
  border-radius: var(--r-full);
}
.bucket-bar .pct {
  font-family: var(--font-mono);
  font-size: 13.5px;
  font-weight: 700;
  text-align: right;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}
.bucket-bar .n {
  font-family: var(--font-mono);
  font-size: 12.5px;
  text-align: right;
  color: var(--text-secondary);
}

/* channels */
.channel-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
.channel-cell {
  background: var(--bg-canvas);
  border: 1px solid var(--border-default);
  border-radius: var(--r-md);
  padding: 18px 20px;
  display: grid;
  grid-template-columns: 48px 1fr auto;
  gap: 16px;
  align-items: center;
}
.channel-cell .tile {
  width: 48px; height: 48px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.04em;
}
.channel-cell .info .name {
  font-size: 16px; font-weight: 600; color: var(--text-primary);
  letter-spacing: -0.005em;
}
.channel-cell .info .h {
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--text-secondary);
  margin-top: 4px;
  letter-spacing: 0.02em;
}
.channel-cell .info .meta {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-secondary);
  margin-top: 10px;
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  letter-spacing: 0.02em;
}
.channel-cell .info .meta .v { color: var(--text-primary); font-weight: 700; }
.channel-cell .health {
  display: flex; flex-direction: column; align-items: flex-end; gap: 8px;
  min-width: 88px;
}
.channel-cell .health .status {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 700;
}
.channel-cell .health .status.ok { color: var(--ok-fg); }
.channel-cell .health .status.warn { color: var(--warn-fg); }
.channel-cell .health .status.err { color: var(--err-fg); }
.channel-cell .health .glyph {
  width: 22px; height: 22px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px;
  font-weight: 700;
}
.channel-cell .health .glyph.ok { background: var(--ok-bg); color: var(--ok-fg); border: 1px solid var(--ok-border); }
.channel-cell .health .glyph.warn { background: var(--warn-bg); color: var(--warn-fg); border: 1px solid var(--warn-border); }
.channel-cell .health .glyph.err { background: var(--err-bg); color: var(--err-fg); border: 1px solid var(--err-border); }
.channel-cell .health .status.pending { color: var(--viz-3); }
.channel-cell .health .glyph.pending { background: rgba(167,139,250,0.10); color: var(--viz-3); border: 1px solid rgba(167,139,250,0.25); }

/* crisis */
.crisis-banner {
  background: var(--err-bg);
  border: 1px solid var(--err-border);
  box-shadow: var(--shadow-ring-err);
  padding: 22px 26px;
  border-radius: var(--r-md);
  margin-bottom: 22px;
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: 20px;
  align-items: center;
}
.crisis-banner .icon {
  width: 56px; height: 56px;
  background: var(--err-fg);
  color: var(--text-inverse);
  border-radius: var(--r-full);
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; font-weight: 700;
}
.crisis-banner h2 {
  font-size: 21px; font-weight: 600; color: var(--text-primary);
  letter-spacing: -0.015em;
}
.crisis-banner p { font-size: 15px; color: var(--text-secondary); margin-top: 6px; line-height: 1.5; }
.crisis-banner .stats { display: flex; gap: 32px; }
.crisis-banner .stat { text-align: right; }
.crisis-banner .stat .v {
  font-family: var(--font-mono);
  font-size: 28px; font-weight: 700;
  color: var(--err-fg);
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.crisis-banner .stat .l {
  font-family: var(--font-mono);
  font-size: 11.5px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-secondary);
  margin-top: 5px;
  font-weight: 600;
}

.crisis-item {
  background: var(--bg-canvas);
  border: 1px solid var(--border-default);
  border-left: 3px solid var(--err-fg);
  border-radius: var(--r-md);
  padding: 20px 24px;
  margin-bottom: 12px;
  display: grid;
  grid-template-columns: 1fr 180px;
  gap: 26px;
}
.crisis-item .head {
  display: flex; gap: 14px; align-items: center;
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--text-secondary);
  margin-bottom: 12px;
  letter-spacing: 0.02em;
  flex-wrap: wrap;
}
.crisis-item .head .who { color: var(--text-primary); font-weight: 700; font-size: 13.5px; }
.crisis-item .head .chan { color: var(--err-fg); font-weight: 700; }
.crisis-item .body {
  font-size: 15.5px; line-height: 1.6; color: var(--text-primary);
  letter-spacing: -0.005em;
}
.crisis-item .body em { font-style: italic; color: var(--err-fg); }
.crisis-item .actions { display: flex; flex-direction: column; gap: 8px; }

/* identity */
.match-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.match-card {
  background: var(--bg-canvas);
  border: 1px solid var(--border-default);
  border-radius: var(--r-md);
  padding: 18px 20px;
}
.match-top {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 14px; border-bottom: 1px solid var(--border-subtle);
}
.match-reason {
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-secondary);
  font-weight: 600;
}
.match-conf {
  font-family: var(--font-mono); font-size: 13px;
  color: var(--text-secondary);
}
.match-conf .v { color: var(--text-primary); font-weight: 700; font-variant-numeric: tabular-nums; }
.match-conf.high .v { color: var(--ok-fg); }
.match-conf.low  .v { color: var(--warn-fg); }
.match-pair {
  display: grid; grid-template-columns: 1fr 28px 1fr; gap: 16px;
  padding: 16px 0; align-items: center;
  border-bottom: 1px solid var(--border-subtle);
}
.match-pair .arrow {
  font-family: var(--font-mono); text-align: center;
  font-size: 20px; color: var(--accent);
}
.match-pair .side .who {
  font-size: 15.5px; font-weight: 600; color: var(--text-primary);
  letter-spacing: -0.005em;
}
.match-pair .side .ctx {
  font-family: var(--font-mono); font-size: 12.5px;
  color: var(--text-secondary); margin-top: 5px; letter-spacing: 0.02em;
}
.match-pair .side .ctx .v { color: var(--accent); font-weight: 700; }
.match-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 14px; }

/* proactive */
.batch {
  background: var(--bg-canvas);
  border: 1px solid var(--border-default);
  border-radius: var(--r-md);
  margin-bottom: 14px;
  overflow: hidden;
}
.batch.large { border-left: 3px solid var(--accent); }
.batch-head {
  padding: 18px 22px;
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 26px;
  border-bottom: 1px solid var(--border-subtle);
}
.batch-head h3 { font-size: 17.5px; font-weight: 600; letter-spacing: -0.01em; }
.batch-head .deck { font-size: 14px; color: var(--text-secondary); margin-top: 4px; }
.batch-head .count {
  font-family: var(--font-mono);
  font-size: 28px; font-weight: 700;
  color: var(--accent);
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.batch-head .count .l {
  display: block;
  font-family: var(--font-mono);
  font-size: 11.5px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--text-secondary);
  margin-top: 6px; font-weight: 600;
}
.batch-preview {
  padding: 14px 22px 18px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.batch-preview .micro {
  font-family: var(--font-mono); font-size: 12.5px;
  color: var(--text-secondary);
  padding-right: 16px;
  border-right: 1px solid var(--border-subtle);
  letter-spacing: 0.02em;
}
.batch-preview .micro:last-child { border-right: none; padding-right: 0; }
.batch-preview .micro .who {
  display: block; color: var(--text-primary); font-weight: 700;
  font-family: var(--font-sans); font-size: 14.5px;
  margin-bottom: 5px;
  letter-spacing: -0.005em;
}
.batch-preview .micro .det { color: var(--text-secondary); font-size: 12.5px; }

/* settings */
.settings-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.settings-block {
  background: var(--bg-canvas);
  border: 1px solid var(--border-default);
  border-radius: var(--r-lg);
  padding: 20px 24px;
}
.settings-block h3 { font-size: 16px; font-weight: 600; letter-spacing: -0.005em; }
.settings-block .deck {
  font-size: 14px; color: var(--text-secondary);
  margin-top: 5px; padding-bottom: 14px;
  border-bottom: 1px solid var(--border-subtle); margin-bottom: 14px;
  line-height: 1.5;
}
.settings-row {
  display: grid; grid-template-columns: 1fr auto;
  gap: 14px; align-items: center;
  padding: 14px 0;
  border-bottom: 1px solid var(--border-subtle);
}
.settings-row:last-child { border-bottom: none; }
.settings-row .name { font-size: 14.5px; color: var(--text-primary); font-weight: 500; letter-spacing: -0.005em; }
.settings-row .hint { font-size: 13.5px; color: var(--text-secondary); margin-top: 5px; max-width: 400px; letter-spacing: -0.005em; line-height: 1.5; }
.settings-row .val {
  font-family: var(--font-mono);
  font-size: 13px;
  padding: 5px 12px;
  background: var(--bg-input);
  border: 1px solid var(--border-default);
  color: var(--text-primary);
  border-radius: var(--r-sm);
  font-weight: 700;
}
.settings-row .val.accent { color: var(--accent); border-color: var(--accent-ring); }
.toggle {
  width: 44px; height: 24px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  border-radius: var(--r-full);
  position: relative;
  cursor: pointer;
  transition: all var(--t-fast);
  box-shadow: inset 0 1px 0 rgba(0,0,0,0.25);
}
.toggle::after {
  content: "";
  position: absolute; top: 2px; left: 2px;
  width: 18px; height: 18px;
  background: var(--text-tertiary);
  border-radius: var(--r-full);
  transition: all var(--t-fast);
  box-shadow: 0 1px 2px rgba(0,0,0,0.5);
}
.toggle.on, .toggle[aria-checked="true"] {
  background: var(--accent-muted);
  border-color: var(--accent-ring);
  box-shadow: var(--shadow-ring-accent), inset 0 1px 0 rgba(0,0,0,0.25);
}
.toggle.on::after, .toggle[aria-checked="true"]::after {
  left: 22px; background: var(--accent);
}

.code-block {
  font-family: var(--font-mono);
  font-size: 13.5px;
  background: var(--bg-input);
  border: 1px solid var(--border-default);
  border-radius: var(--r-sm);
  padding: 18px 20px;
  color: var(--text-secondary);
  line-height: 1.7;
  white-space: pre;
  overflow-x: auto;
  letter-spacing: 0.01em;
}
.code-block .kw  { color: var(--viz-3); }
.code-block .str { color: var(--accent); }
.code-block .cm  { color: var(--text-tertiary); font-style: italic; }
.code-block .fn  { color: var(--viz-2); }

/* telegram bot */
.tg-mockup-wrap { position: relative; }
.tg-mockup-wrap::before {
  content: "MOCKUP";
  position: absolute;
  top: -10px;
  right: -8px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.18em;
  color: var(--text-tertiary);
  background: var(--bg-surface);
  padding: 3px 10px;
  border: 1px solid var(--border-default);
  border-radius: var(--r-sm);
  z-index: 1;
  font-weight: 600;
}
.tg-frame {
  max-width: 440px;
  background: #17212b;
  border: 1px solid var(--border-default);
  border-radius: var(--r-lg);
  display: grid;
  grid-template-rows: 60px 1fr 56px;
  height: 760px;
  font-family: 'SF Pro Text', -apple-system, sans-serif;
  overflow: hidden;
}
.tg-head {
  background: #212d3b;
  padding: 0 16px;
  display: grid; grid-template-columns: 40px 1fr auto;
  align-items: center; gap: 12px;
  border-bottom: 1px solid #0e1621;
}
.tg-head .ava {
  width: 40px; height: 40px; border-radius: var(--r-full);
  background: linear-gradient(135deg, #f2c94c, #d68a2e);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 15px; color: #1a1208;
}
.tg-head .name { font-size: 15px; font-weight: 600; color: #fff; }
.tg-head .sub  { font-size: 12.5px; color: #91a3b3; margin-top: 2px; }
.tg-body {
  background: #0e1621; padding: 16px;
  overflow-y: auto;
  display: flex; flex-direction: column; gap: 6px;
}
.tg-msg {
  max-width: 80%;
  padding: 8px 12px;
  font-size: 14.5px;
  line-height: 1.45;
  border-radius: 10px;
  color: #fff;
  word-wrap: break-word;
}
.tg-msg.in  { background: #182533; align-self: flex-start; }
.tg-msg.out { background: #2b5278; align-self: flex-end; }
.tg-msg .ts { display: block; font-size: 11.5px; color: #aed4f9; text-align: right; margin-top: 5px; }
.tg-msg.in .ts { color: #91a3b3; }
.tg-msg pre {
  font-family: 'Geist Mono', monospace; font-size: 12.5px;
  background: rgba(0,0,0,0.30);
  padding: 7px 9px; margin: 5px 0;
  border-radius: 4px; white-space: pre-wrap; color: #e0e6eb;
  line-height: 1.55;
}
.tg-msg .b { font-weight: 700; }
.tg-input {
  background: #17212b; border-top: 1px solid #0e1621;
  padding: 10px 16px;
  display: flex; align-items: center;
  font-size: 14px; color: #91a3b3;
}

.cmd-chip {
  font-family: var(--font-mono);
  font-size: 12.5px;
  font-weight: 600;
  padding: 3px 8px;
  background: var(--bg-overlay);
  color: var(--accent);
  border-radius: var(--r-sm);
  border: 1px solid var(--border-default);
  display: inline-block;
}

/* audit log */
.audit-row {
  display: grid;
  grid-template-columns: 130px 96px 100px 170px 1fr;
  align-items: center;
  gap: 16px;
  padding: 0 16px;
  height: 38px;
  font-family: var(--font-mono);
  font-size: 13px;
  border-bottom: 1px solid var(--border-subtle);
  color: var(--text-secondary);
}
.audit-row:nth-child(even) { background: rgba(255,255,255,0.012); }
.audit-row:hover { background: var(--bg-elevated); }
.audit-row:last-child { border-bottom: none; }
.audit-row .ts { color: var(--text-tertiary); letter-spacing: 0.02em; }
.audit-row .actor.user { color: var(--accent); font-weight: 700; }
.audit-row .actor.system { color: var(--text-secondary); font-weight: 600; }
.audit-row .actor.auto { color: var(--viz-4); font-weight: 700; }
.audit-row .action { font-weight: 700; color: var(--text-primary); }
.audit-row .target { color: var(--text-secondary); }
.audit-row .meta { color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* help */
.help-overlay {
  position: fixed; inset: 0;
  background: rgba(9,9,11,0.85);
  z-index: 200;
  display: none;
  align-items: center;
  justify-content: center;
}
.help-overlay.open { display: flex; animation: fade-in var(--t-base); }
.help-panel {
  max-width: 640px;
  background: var(--bg-canvas);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-lg);
  padding: 36px 44px;
  box-shadow: var(--shadow-lg);
}
.help-panel h2 {
  font-size: 21px; font-weight: 600; letter-spacing: -0.015em;
  margin-bottom: 7px;
}
.help-panel .deck {
  font-size: 14.5px; color: var(--text-secondary);
  margin-bottom: 28px;
}
.help-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 36px;
}
.help-row {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 16px;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid var(--border-subtle);
}
.help-row .k {
  font-family: var(--font-mono);
  font-size: 12.5px;
  padding: 4px 10px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  border-radius: var(--r-sm);
  text-align: center;
  font-weight: 700;
  color: var(--accent);
}
.help-row .desc { font-size: 14.5px; color: var(--text-primary); letter-spacing: -0.005em; }
.help-row .desc .sub { color: var(--text-secondary); font-size: 13.5px; display: block; margin-top: 2px; }

/* toast */
.toast {
  position: fixed; bottom: 60px; left: 50%;
  transform: translateX(-50%) translateY(10px);
  background: var(--bg-elevated);
  border: 1px solid var(--accent-ring);
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 14.5px;
  padding: 14px 18px;
  border-radius: var(--r-md);
  box-shadow: var(--shadow-lg), var(--shadow-ring-accent);
  z-index: 200;
  opacity: 0;
  transition: all var(--t-base);
  display: flex; align-items: center; gap: 16px;
  min-width: 360px;
  pointer-events: none;
}
.toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}
.toast .icon {
  width: 26px; height: 26px;
  background: var(--accent);
  color: var(--text-inverse);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; font-weight: 700;
}
.toast .msg .head { font-weight: 700; color: var(--text-primary); }
.toast .msg .sub { font-size: 12.5px; color: var(--text-secondary); margin-top: 3px; }
.toast .undo {
  margin-left: 14px;
  padding: 6px 14px;
  font-family: var(--font-mono);
  font-size: 12.5px;
  background: transparent;
  color: var(--accent);
  border: 1px solid var(--accent-ring);
  border-radius: var(--r-sm);
  cursor: pointer;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}
.toast .undo:hover { background: var(--accent-muted); }
.toast .countdown {
  position: absolute;
  left: 0; bottom: -1px; right: 0;
  height: 2px;
  background: var(--accent);
  transform-origin: left;
  animation: countdown 6s linear forwards;
}
@keyframes countdown {
  from { transform: scaleX(1); }
  to { transform: scaleX(0); }
}

@keyframes fade-in {
  from { opacity: 0; transform: translateY(3px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ──────────────────────────────────────────────────────────────────────────
   Iteration 4 — Auto-Reply-Audit + Regelwerk
   Plan: ~/.claude/plans/tidy-rolling-lantern.md
   ────────────────────────────────────────────────────────────────────────── */

/* Sub-Tabs für Audit-View (Reuse .queue-toolbar+.filter-pill Pattern) */
.subtab-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 24px;
  height: 44px;
  border-bottom: 1px solid var(--border-default);
  background: var(--bg-canvas);
  position: sticky;
  top: 0;
  z-index: 14;
  overflow-x: auto;
  scrollbar-width: thin;
}
.subtab-bar::-webkit-scrollbar { height: 4px; }
.subtab-bar::-webkit-scrollbar-thumb { background: var(--border-default); border-radius: 2px; }
.subfilter-bar { overflow-x: auto; scrollbar-width: thin; }
.subtab-bar .spacer { flex: 1; }
.subtab-bar .filter-pill { height: 28px; }
.subtab-bar .filter-pill .count {
  margin-left: 6px; padding: 0 6px;
  font-size: 11px; font-family: var(--font-mono);
  background: var(--bg-elevated); color: var(--text-secondary);
  border-radius: 999px; line-height: 16px; min-width: 18px;
  display: inline-flex; align-items: center; justify-content: center;
}
.subtab-bar .filter-pill.active .count {
  background: var(--text-inverse); color: var(--accent);
}
.subtab-bar .filter-pill.warn-count .count {
  background: var(--err-bg); color: var(--err-fg);
}

/* Auto-erledigt Pill-Filter sekundäre Leiste */
.subfilter-bar {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  padding: 12px 24px;
  background: var(--bg-canvas);
  border-bottom: 1px solid var(--border-subtle);
}
.subfilter-bar .search {
  margin-left: auto;
  font-family: var(--font-mono); font-size: 12.5px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  border-radius: var(--r-sm);
  padding: 6px 12px;
  color: var(--text-secondary);
  min-width: 200px;
}

/* Auto-erledigt Row-Layout */
.auto-row {
  display: grid;
  grid-template-columns: 44px 76px 1fr 220px 72px 160px;
  align-items: center;
  gap: 14px;
  padding: 0 16px;
  min-height: 48px;
  font-family: var(--font-mono);
  font-size: 13px;
  border-bottom: 1px solid var(--border-subtle);
  cursor: pointer;
  transition: background var(--t-fast);
}
.auto-row:nth-child(even) { background: rgba(255,255,255,0.012); }
.auto-row:hover { background: var(--bg-elevated); }
.auto-row:last-child { border-bottom: none; }
.auto-row .who {
  color: var(--text-primary); font-weight: 600;
  font-family: var(--font-sans); font-size: 14px; letter-spacing: -0.005em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.auto-row .who .ch {
  margin-left: 8px; color: var(--text-tertiary); font-family: var(--font-mono);
  font-size: 11.5px; font-weight: 500;
}
.auto-row .action-cell {
  color: var(--text-primary);
  font-family: var(--font-sans); font-size: 13.5px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.auto-row .action-cell .kind {
  display: inline-block; padding: 1px 7px; border-radius: var(--r-sm);
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  letter-spacing: 0.04em; margin-right: 8px;
  background: rgba(52,211,153,0.10); color: var(--viz-4);
}
.auto-row .action-cell .kind.hide  { background: rgba(167,139,250,0.10); color: var(--viz-3); }
.auto-row .action-cell .kind.like  { background: rgba(52,211,153,0.10); color: var(--viz-4); }
.auto-row .action-cell .kind.faq   { background: var(--accent-muted); color: var(--accent); }
.auto-row .rule-id {
  color: var(--text-secondary); font-weight: 700;
  font-family: var(--font-mono); font-size: 12.5px;
}
.auto-row .verify {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 12px;
  color: var(--text-tertiary);
}

/* Risk-Dots */
.risk-dot {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 0.5px;
  line-height: 1;
  font-weight: 700;
}
.risk-dot.r3 { color: var(--err-fg); }
.risk-dot.r2 { color: var(--warn-fg); }
.risk-dot.r1 { color: var(--text-tertiary); }

/* Neue .pill-Varianten */
.pill.sandbox {
  background: rgba(249,115,22,0.10);
  color: #FB923C;
  border-color: rgba(249,115,22,0.30);
}
.pill.outbox {
  background: var(--warn-bg);
  color: var(--warn-fg);
  border-color: var(--warn-border);
  position: relative;
  animation: outbox-pulse 2.2s ease-in-out infinite;
}
.pill.outbox::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -1px;
  height: 1.5px; background: var(--warn-fg);
  transform-origin: left;
  transform: scaleX(var(--countdown-pct, 1));
  transition: transform 1s linear;
}
.pill.pending {
  background: rgba(167,139,250,0.10);
  color: var(--viz-3);
  border-color: rgba(167,139,250,0.25);
}
@keyframes outbox-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(234,179,8,0); }
  50%      { box-shadow: 0 0 0 3px rgba(234,179,8,0.15); }
}

/* Lock-Indikator statt Toggle */
.lock-indicator {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 12px; font-weight: 700;
  letter-spacing: 0.04em; text-transform: uppercase;
  color: var(--err-fg);
  padding: 5px 10px;
  background: var(--err-bg);
  border: 1px solid var(--err-border);
  border-radius: var(--r-sm);
}
.lock-indicator .ico { font-size: 14px; }

/* Rule-Row im Settings-Block (Reuse .audit-row grid, eigener Strang) */
.rule-row {
  display: grid;
  grid-template-columns: 16px 56px 1fr 56px 50px 48px;
  align-items: center;
  gap: 10px;
  padding: 0 14px;
  height: 36px;
  font-family: var(--font-mono);
  font-size: 12.5px;
  border-bottom: 1px solid var(--border-subtle);
  cursor: pointer;
  color: var(--text-secondary);
  transition: background var(--t-fast);
}
.rule-row:nth-child(even) { background: rgba(255,255,255,0.012); }
.rule-row:hover { background: var(--bg-elevated); }
.rule-row:last-child { border-bottom: none; }
.rule-row .state-dot {
  display: inline-block; width: 9px; height: 9px; border-radius: 50%;
}
.rule-row .state-dot.active   { background: var(--ok-fg); }
.rule-row .state-dot.sandbox  { background: #FB923C; }
.rule-row .state-dot.off      { background: var(--text-tertiary); opacity: 0.5; }
.rule-row .rid { color: var(--text-tertiary); }
.rule-row .name {
  color: var(--text-primary); font-family: var(--font-sans);
  font-size: 13.5px; font-weight: 500; letter-spacing: -0.005em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.rule-row .kind {
  font-weight: 700; color: var(--text-secondary);
  font-size: 11px; letter-spacing: 0.06em;
}
.rule-row .ch  { color: var(--text-tertiary); }
.rule-row .conf {
  color: var(--text-secondary); text-align: right;
  font-variant-numeric: tabular-nums;
}

/* Side-Drawer (lebt im .siderail-Slot) */
.app[data-rail="drawer-audit"] .siderail,
.app[data-rail="drawer-rule"]  .siderail { display: block; }
.app[data-rail="drawer-audit"] .siderail > .rail-block,
.app[data-rail="drawer-rule"]  .siderail > .rail-block { display: none; }
.app[data-rail="drawer-audit"] .audit-drawer { display: block; }
.app[data-rail="drawer-rule"]  .rule-drawer  { display: block; }

.side-drawer {
  display: none;
  animation: drawer-slide 220ms ease-out;
  padding: 18px 22px 28px;
  height: 100%;
  overflow-y: auto;
}
@keyframes drawer-slide {
  from { opacity: 0; transform: translateX(8px); }
  to   { opacity: 1; transform: translateX(0); }
}
.side-drawer .dr-head {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 14px; margin-bottom: 16px;
  border-bottom: 1px solid var(--border-default);
}
.side-drawer .dr-title {
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-tertiary);
}
.side-drawer .dr-title .sub {
  display: block; margin-top: 4px;
  font-family: var(--font-sans); font-size: 15px; font-weight: 600;
  color: var(--text-primary); letter-spacing: -0.01em; text-transform: none;
}
.side-drawer .dr-close {
  background: transparent; border: 1px solid var(--border-default);
  color: var(--text-secondary); padding: 6px 10px;
  font-family: var(--font-mono); font-size: 12px;
  border-radius: var(--r-sm); cursor: pointer;
}
.side-drawer .dr-close:hover { background: var(--bg-elevated); color: var(--text-primary); }
.side-drawer .dr-section {
  margin-bottom: 18px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--border-subtle);
}
.side-drawer .dr-section:last-child { border-bottom: none; }
.side-drawer .dr-section h4 {
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-tertiary);
  margin-bottom: 8px;
}
.side-drawer .dr-body-text {
  font-family: var(--font-sans); font-size: 13.5px;
  color: var(--text-primary); line-height: 1.55; letter-spacing: -0.005em;
}
.side-drawer .dr-body-text p { margin-bottom: 8px; }
.side-drawer .dr-body-text p:last-child { margin-bottom: 0; }
.side-drawer .dr-meta {
  display: grid; grid-template-columns: 100px 1fr; gap: 4px 14px;
  font-family: var(--font-mono); font-size: 12px;
  color: var(--text-secondary);
}
.side-drawer .dr-meta dt { color: var(--text-tertiary); }
.side-drawer .dr-meta dd { color: var(--text-primary); }
.side-drawer .dr-actions {
  display: flex; flex-direction: column; gap: 8px; margin-top: 4px;
}
.side-drawer .dr-actions .btn { width: 100%; justify-content: flex-start; }
.side-drawer .dr-actions .btn .kbd { margin-left: auto; }
.side-drawer .dr-kpi-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px;
}
.side-drawer .dr-kpi {
  background: var(--bg-elevated); border: 1px solid var(--border-subtle);
  border-radius: var(--r-sm); padding: 10px 12px;
}
.side-drawer .dr-kpi .l {
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-tertiary); margin-bottom: 4px;
}
.side-drawer .dr-kpi .v {
  font-size: 18px; font-weight: 700; color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}
.side-drawer .dr-kpi .v.ok   { color: var(--ok-fg); }
.side-drawer .dr-kpi .v.err  { color: var(--err-fg); }
.side-drawer .dr-template {
  background: var(--bg-elevated); border: 1px solid var(--border-subtle);
  border-radius: var(--r-sm); padding: 10px 12px;
  font-family: var(--font-mono); font-size: 12px; line-height: 1.6;
  color: var(--text-primary);
  max-height: 200px; overflow-y: auto;
  white-space: pre-wrap;
}
.side-drawer .dr-template .var { color: var(--accent); }

/* Spender-Cadence-System (Iteration 4.8) */
.donors-flow {
  display: flex; flex-direction: column;
  padding: 0;
}
.donor-bucket-row {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
  padding: 18px 24px 8px;
}
.donor-bucket {
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  border-radius: var(--r-md);
  padding: 14px 18px;
  display: flex; flex-direction: column; gap: 4px;
}
.donor-bucket.spike {
  border-color: var(--accent-ring);
  background: var(--accent-muted);
  position: relative;
}
.donor-bucket.spike::before {
  content: ""; position: absolute; top: 12px; right: 12px;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--accent);
  animation: bucket-pulse 1.4s ease-in-out infinite;
  box-shadow: 0 0 0 0 rgba(250, 204, 21, 0.5);
}
@keyframes bucket-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(250, 204, 21, 0.55); }
  50%      { box-shadow: 0 0 0 6px rgba(250, 204, 21, 0); }
}
.donor-bucket .l {
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-tertiary);
}
.donor-bucket.spike .l { color: var(--accent); }
.donor-bucket .v {
  font-size: 30px; font-weight: 700; line-height: 1.05;
  color: var(--text-primary); font-variant-numeric: tabular-nums;
  letter-spacing: -0.018em;
}
.donor-bucket .sub {
  font-family: var(--font-mono); font-size: 11.5px;
  color: var(--text-secondary);
}

.donor-list-card {
  margin: 14px 24px 24px;
  background: var(--bg-canvas);
  border: 1px solid var(--border-default);
  border-radius: var(--r-md);
  overflow: hidden;
}
.donor-group-head {
  display: flex; align-items: baseline; gap: 12px;
  padding: 14px 18px 10px;
  font-family: var(--font-mono); font-size: 12px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-tertiary);
  background: var(--bg-elevated);
  border-bottom: 1px solid var(--border-default);
}
.donor-group-head.spike { color: var(--accent); }
.donor-group-head .count {
  background: var(--bg-canvas); color: var(--text-primary);
  padding: 1px 8px; border-radius: 999px;
  border: 1px solid var(--border-default);
  font-size: 11px;
}
.donor-group-head .icon-pulse {
  display: inline-block; width: 8px; height: 8px; border-radius: 50%;
  background: var(--accent);
  margin-right: 4px;
  animation: bucket-pulse 1.4s ease-in-out infinite;
}

.donor-row {
  display: grid;
  grid-template-columns: 36px 1fr 64px 150px 170px 150px;
  gap: 12px; align-items: center;
  padding: 10px 16px;
  min-height: 58px;
  border-bottom: 1px solid var(--border-subtle);
  cursor: pointer;
  transition: background var(--t-fast);
}
.donor-row:nth-child(even) { background: rgba(255,255,255,0.012); }
.donor-row:hover { background: var(--bg-elevated); }
.donor-row:last-child { border-bottom: none; }
.donor-row.spike-row {
  background: rgba(250, 204, 21, 0.06);
  border-left: 3px solid var(--accent);
  padding-left: 15px;
}
.donor-row.spike-row:hover { background: rgba(250, 204, 21, 0.10); }

.donor-bubble {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono); font-size: 12px; font-weight: 700;
  color: var(--text-secondary);
  letter-spacing: 0.02em;
}
.donor-row.spike-row .donor-bubble {
  border-color: var(--accent-ring);
  color: var(--accent);
  animation: bubble-pulse 2s ease-in-out infinite;
}
@keyframes bubble-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(250, 204, 21, 0.45); }
  50%      { box-shadow: 0 0 0 5px rgba(250, 204, 21, 0); }
}

.donor-name {
  display: flex; flex-direction: column; gap: 3px;
  min-width: 0;
}
.donor-name .nm {
  font-family: var(--font-sans); font-size: 14.5px; font-weight: 600;
  color: var(--text-primary); letter-spacing: -0.005em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.donor-name .sub {
  font-family: var(--font-mono); font-size: 11.5px;
  color: var(--text-tertiary);
}
.donor-row.spike-row .spike-meta {
  display: block;
  font-family: var(--font-mono); font-size: 11.5px;
  color: var(--accent); font-weight: 700;
  margin-top: 2px;
}

.donor-tier-pill {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 4px 10px;
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  letter-spacing: 0.08em;
  border-radius: var(--r-sm);
  border: 1px solid;
  width: fit-content;
}
.donor-tier-pill.major { color: var(--accent); border-color: var(--accent-ring); background: var(--accent-muted); }
.donor-tier-pill.mid   { color: var(--viz-3); border-color: rgba(167,139,250,0.30); background: rgba(167,139,250,0.10); }
.donor-tier-pill.small { color: var(--text-secondary); border-color: var(--border-default); background: var(--bg-elevated); }

.cadence-bar {
  position: relative;
  height: 9px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: 4px;
  overflow: hidden;
}
.cadence-bar .fill {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: var(--fill-pct, 0%);
  background: var(--ok-fg);
  transition: width var(--t-base), background var(--t-base);
  border-radius: 2px;
}
.cadence-bar.warn .fill   { background: var(--warn-fg); }
.cadence-bar.due .fill    { background: var(--accent); }
.cadence-bar.over .fill   { background: var(--accent); }
.cadence-bar.over.major .fill { background: var(--err-fg); }
.cadence-bar.spike .fill  { background: var(--accent); }
.cadence-cell {
  display: flex; flex-direction: column; gap: 6px;
  min-width: 0;
}
.cadence-cell .lbl {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--text-secondary);
  letter-spacing: 0.02em;
}
.cadence-cell .lbl .v-over { color: var(--err-fg); font-weight: 700; }
.cadence-cell .lbl .v-due  { color: var(--accent); font-weight: 700; }
.cadence-cell .lbl .v-soon { color: var(--warn-fg); font-weight: 700; }
.cadence-cell .lbl .v-ok   { color: var(--ok-fg); font-weight: 700; }

.donor-thanks {
  display: flex; flex-direction: column; gap: 3px;
  font-family: var(--font-mono); font-size: 11.5px;
  color: var(--text-secondary);
}
.donor-thanks .date { color: var(--text-primary); font-weight: 600; }
.donor-thanks .ago  { color: var(--text-tertiary); font-size: 11px; }
.donor-thanks .next { color: var(--text-secondary); margin-top: 4px; }
.donor-thanks .next .v {
  color: var(--accent); font-weight: 600;
}
.donor-thanks .ch-tag {
  display: inline-block;
  margin-left: 4px;
  padding: 1px 7px;
  font-size: 10.5px; font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--text-primary);
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  border-radius: 999px;
}

.donor-actions {
  display: flex; flex-direction: column; gap: 4px;
  align-items: stretch;
}
.donor-actions .btn { padding: 5px 10px; height: 28px; font-size: 12px; }
.donor-actions .ghosts {
  display: flex; gap: 4px;
}
.donor-actions .ghosts .btn {
  flex: 1;
  font-size: 10.5px;
  padding: 3px 6px;
  height: 24px;
  letter-spacing: 0.02em;
}

/* Sub-Tab Sticky Header für Donors */
.app[data-active-view="donors"] .siderail { /* Drawer reuse */ }

/* Donor-Drawer (Reuse Side-Drawer Pattern) */
.app[data-rail="drawer-donor"] .siderail { display: block; }
.app[data-rail="drawer-donor"] .siderail > .rail-block,
.app[data-rail="drawer-donor"] .rail-inbox-kpi { display: none; }
.app[data-rail="drawer-donor"] .donor-drawer { display: block; }

.donor-drawer .dr-donor-head {
  display: flex; align-items: center; gap: 14px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border-default);
  margin-bottom: 16px;
}
.donor-drawer .dr-donor-bubble {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--bg-elevated);
  border: 1px solid var(--accent-ring);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono); font-size: 18px; font-weight: 700;
  color: var(--accent);
}
.donor-drawer .dr-donor-info { flex: 1; min-width: 0; }
.donor-drawer .dr-donor-info .nm {
  font-family: var(--font-sans); font-size: 17px; font-weight: 600;
  color: var(--text-primary); letter-spacing: -0.01em;
}
.donor-drawer .dr-donor-info .sub {
  font-family: var(--font-mono); font-size: 11.5px;
  color: var(--text-secondary); margin-top: 3px;
}

.dr-touch-history {
  display: grid; grid-template-columns: 80px 1fr 60px;
  gap: 6px 10px;
  font-family: var(--font-mono); font-size: 11.5px;
}
.dr-touch-history .th-date { color: var(--text-tertiary); }
.dr-touch-history .th-desc { color: var(--text-primary); }
.dr-touch-history .th-kind {
  text-align: right; color: var(--text-secondary);
  font-size: 10.5px; letter-spacing: 0.04em; text-transform: uppercase;
}

.dr-sparkline {
  display: flex; align-items: flex-end; gap: 4px;
  height: 50px;
  padding: 8px 0;
}
.dr-sparkline .bar {
  flex: 1;
  background: var(--accent);
  border-radius: 2px 2px 0 0;
  min-height: 2px;
  opacity: 0.85;
}
.dr-sparkline .bar.dim { opacity: 0.35; background: var(--text-tertiary); }
.dr-sparkline-labels {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono); font-size: 10.5px;
  color: var(--text-tertiary);
  margin-top: 4px;
}

.dr-suggestion {
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  border-radius: var(--r-sm);
  padding: 10px 12px;
  margin-bottom: 8px;
}
.dr-suggestion .sg-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 6px;
}
.dr-suggestion .sg-kind {
  font-family: var(--font-mono); font-size: 10.5px;
  font-weight: 700; letter-spacing: 0.08em;
  color: var(--accent);
}
.dr-suggestion .sg-preview {
  font-family: var(--font-sans); font-size: 12.5px;
  color: var(--text-secondary); line-height: 1.4;
  font-style: italic;
}

/* Kanal-Tile Profil-Selector inline (Iteration 4.7) */
.channel-cell .info .meta .tile-poll-wrap {
  display: inline-flex; align-items: center; gap: 6px;
}
.channel-cell .info .meta .tile-profile-select {
  background: var(--bg-elevated);
  border: 1px solid var(--accent-ring);
  color: var(--accent);
  font-family: var(--font-mono); font-size: 11.5px;
  padding: 2px 8px;
  height: 22px;
  border-radius: var(--r-sm);
  cursor: pointer;
  font-weight: 600;
  letter-spacing: 0.02em;
}
.channel-cell .info .meta .tile-profile-select:focus { outline: none; border-color: var(--accent); }
.channel-cell .info .meta .tile-profile-select:hover { background: var(--accent-muted); }

.tile-config {
  display: flex; align-items: center; gap: 10px;
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px dashed var(--border-subtle);
}
.tile-config .lbl {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-tertiary); font-weight: 600;
}
.tile-config .tile-profile-select {
  flex: 1;
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  color: var(--text-primary);
  font-family: var(--font-mono); font-size: 11.5px;
  padding: 5px 10px;
  border-radius: var(--r-sm);
  cursor: pointer;
}
.tile-config .tile-profile-select:focus { outline: none; border-color: var(--accent-ring); color: var(--accent); }
.tile-config .tile-profile-select:hover { border-color: var(--border-strong); }
.tile-config .push-pill {
  display: inline-block;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.08em;
  padding: 4px 10px;
  background: var(--ok-bg); color: var(--ok-fg);
  border: 1px solid var(--ok-border);
  border-radius: var(--r-sm);
  font-weight: 600;
}
.tile-config .slots {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--text-tertiary);
  margin-left: auto;
  white-space: nowrap;
}

/* Einstellungen-Rebuild (Iteration 4.6) */
.settings-nav {
  display: flex; gap: 4px; flex-wrap: wrap; margin-top: 10px;
}
.settings-nav-pill {
  display: inline-flex; align-items: center;
  padding: 5px 12px; height: 28px;
  font-family: var(--font-mono); font-size: 12px; font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--text-tertiary);
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  border-radius: var(--r-sm);
  text-decoration: none;
  transition: all var(--t-fast);
}
.settings-nav-pill:hover { color: var(--text-primary); border-color: var(--border-strong); }
.settings-nav-pill.active { color: var(--accent); border-color: var(--accent-ring); background: var(--accent-muted); }

.view-body.settings-flow {
  display: flex; flex-direction: column; gap: 36px;
  padding: 28px 32px 60px;
}
/* Hidden-Attribut hat Vorrang vor display:flex (Q5-Bug-Fix 2026-05-15) */
.subtab-body[hidden] { display: none !important; }
.settings-section {
  border-top: 1px solid var(--border-default);
  padding-top: 24px;
}
.settings-section:first-child { border-top: none; padding-top: 0; }
.settings-section-head { margin-bottom: 18px; }
.settings-section-head h2 {
  font-size: 22px; font-weight: 600; letter-spacing: -0.015em;
  color: var(--text-primary);
  display: flex; align-items: baseline; gap: 12px;
  margin-bottom: 6px;
}
.settings-section-head h2 .num {
  font-family: var(--font-mono); font-size: 13px;
  color: var(--accent); font-weight: 700;
  background: var(--accent-muted);
  border: 1px solid var(--accent-ring);
  border-radius: var(--r-sm);
  padding: 2px 9px;
  letter-spacing: 0.04em;
}
.settings-section-head .deck {
  font-size: 15px; color: var(--text-secondary);
  letter-spacing: -0.005em; line-height: 1.55;
  max-width: 880px;
}

/* Section 1: Auto-Cards */
.auto-cards {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
.auto-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  border-radius: var(--r-md);
  padding: 20px 22px;
}
.auto-card.on { border-color: var(--accent-ring); }
.auto-card.lock { border-color: var(--err-border); background: rgba(239,68,68,0.03); }
.auto-card .ac-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 12px;
}
.auto-card .ac-head h3 {
  font-size: 16.5px; font-weight: 600;
  color: var(--text-primary); letter-spacing: -0.008em;
}
.auto-card .ac-body {
  font-size: 14.5px; line-height: 1.55;
  color: var(--text-secondary);
  letter-spacing: -0.005em;
}
.auto-card .ac-body strong { color: var(--text-primary); font-weight: 700; }
.auto-card .ac-meta {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border-subtle);
  display: flex; flex-wrap: wrap; gap: 4px 0;
  font-family: var(--font-mono); font-size: 11.5px;
  color: var(--text-tertiary);
  align-items: center;
}
.auto-card .ac-meta .sep { margin: 0 6px; opacity: 0.5; }
.auto-card .ac-meta a {
  color: var(--accent); text-decoration: none;
  margin-left: auto;
}

/* Section 2: Rules-Table */
.rules-table .rt-toolbar {
  display: flex; align-items: center; gap: 6px;
  margin-bottom: 12px;
}
.rules-table .rt-search {
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  color: var(--text-secondary);
  font-family: var(--font-mono); font-size: 12.5px;
  padding: 6px 12px; height: 30px;
  border-radius: var(--r-sm);
  min-width: 240px;
}
.rules-table .rt-search:focus {
  outline: none; border-color: var(--accent-ring); color: var(--text-primary);
}

/* Section 3: Poll-Summary + Poll-Rows */
.poll-summary {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
  margin-bottom: 18px;
}
.poll-summary-item {
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  border-radius: var(--r-md);
  padding: 16px 18px;
  display: flex; flex-direction: column; gap: 4px;
}
.poll-summary-item .l {
  font-family: var(--font-mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-tertiary);
}
.poll-summary-item .v {
  font-size: 26px; font-weight: 700;
  color: var(--text-primary); font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
.poll-summary-item .v.accent { color: var(--accent); }
.poll-summary-item .sub {
  font-family: var(--font-mono); font-size: 11.5px;
  color: var(--text-secondary);
  margin-top: 2px;
}
.stream-th.poll-th {
  grid-template-columns: 200px 220px 1fr 80px 130px;
  font-family: var(--font-mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-tertiary);
  padding: 10px 18px; height: auto;
  background: var(--bg-elevated);
  border-top: 1px solid var(--border-default);
  border-bottom: 1px solid var(--border-default);
  display: grid; gap: 16px; align-items: center;
}
.poll-row {
  display: grid;
  grid-template-columns: 200px 220px 1fr 80px 130px;
  gap: 16px; align-items: center;
  padding: 0 18px;
  min-height: 52px;
  border-bottom: 1px solid var(--border-subtle);
  font-family: var(--font-mono); font-size: 12.5px;
}
.poll-row:nth-child(even) { background: rgba(255,255,255,0.012); }
.poll-row:hover { background: var(--bg-elevated); }
.poll-row .pr-ch {
  display: flex; align-items: center; gap: 10px;
  color: var(--text-primary); font-family: var(--font-sans);
  font-size: 13.5px; font-weight: 500;
}
.poll-row .pr-ch .tile {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 24px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  border-radius: var(--r-sm);
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  color: var(--text-secondary);
}
.poll-row .pr-slots {
  color: var(--text-secondary); font-size: 11.5px;
}
.poll-row .pr-calls {
  text-align: right; color: var(--text-primary); font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.poll-row .pr-cost {
  text-align: right; color: var(--text-secondary);
}
.poll-row .pr-cost.free { color: var(--ok-fg); }
.profile-select {
  width: 100%;
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  color: var(--text-primary);
  font-family: var(--font-mono); font-size: 11.5px;
  padding: 6px 10px;
  border-radius: var(--r-sm);
  cursor: pointer;
}
.profile-select:focus { outline: none; border-color: var(--accent-ring); }
.poll-row .pr-profile .pill { display: inline-block; }
.poll-foot {
  margin-top: 14px;
  font-family: var(--font-mono); font-size: 11.5px;
  color: var(--text-tertiary);
}

/* Section 4 zwei-spaltig */
.settings-twocol {
  display: grid; grid-template-columns: 1fr 1fr; gap: 18px;
}
.settings-twocol .settings-block { margin: 0; }

@media (max-width: 1300px) {
  .auto-cards, .settings-twocol { grid-template-columns: 1fr; }
  .poll-summary { grid-template-columns: 1fr; }
  .stream-th.poll-th, .poll-row { grid-template-columns: 1fr; padding: 12px 18px; gap: 8px; }
}

/* Eingang-Kennzahlen-Rail (Iteration 4.4) */
.rail-inbox-kpi { display: none; }
.app[data-active-view="inbox"] .rail-inbox-kpi { display: block; }
.app[data-active-view="inbox"] .rail-donor { display: none; }

.kpi-rail-section {
  margin-bottom: 22px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border-subtle);
}
.kpi-rail-section:last-of-type { border-bottom: none; }
.kpi-rail-head {
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-tertiary); margin-bottom: 10px;
}
.bucket-bar.small {
  grid-template-columns: 1fr 56px 36px;
  height: 22px;
  font-size: 12.5px;
}
.bucket-bar.small .pct { font-size: 11.5px; }
.bucket-bar.small .name { font-size: 12.5px; }
.bucket-bar.small .name .h {
  color: var(--text-tertiary); font-size: 10.5px;
  margin-left: 4px; font-family: var(--font-mono);
}
.kpi-rail-foot {
  margin-top: 8px;
  font-family: var(--font-mono); font-size: 11.5px;
  color: var(--text-tertiary);
}
.kpi-rail-foot .v { color: var(--text-primary); font-weight: 700; }
.kpi-rail-foot .v.ok { color: var(--ok-fg); }
.kpi-rail-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 6px 0;
  font-family: var(--font-mono); font-size: 12.5px;
  color: var(--text-secondary);
  border-bottom: 1px solid var(--border-subtle);
}
.kpi-rail-row:last-child { border-bottom: none; }
.kpi-rail-row .v {
  color: var(--text-primary); font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.kpi-rail-row .v.accent { color: var(--accent); }
.kpi-rail-link {
  width: 100%;
  background: transparent;
  border: 1px solid var(--border-default);
  color: var(--text-secondary);
  padding: 10px 14px;
  font-family: var(--font-mono); font-size: 12px;
  border-radius: var(--r-sm);
  cursor: pointer;
  letter-spacing: 0.02em;
  text-align: center;
  transition: all var(--t-fast);
  margin-top: 4px;
}
.kpi-rail-link:hover {
  color: var(--accent);
  border-color: var(--accent-ring);
  background: var(--accent-muted);
}

/* Stream-th-Variante für auto-row + rule-row */
.stream-th.auto-th {
  grid-template-columns: 44px 76px 1fr 220px 72px 160px;
  font-family: var(--font-mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-tertiary);
  padding: 10px 16px; height: auto;
  background: var(--bg-elevated);
  border-bottom: 1px solid var(--border-default);
  display: grid; gap: 14px; align-items: center;
}
.stream-th.rule-th {
  grid-template-columns: 16px 56px 1fr 56px 50px 48px;
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-tertiary);
  padding: 8px 14px;
  background: var(--bg-elevated);
  border-bottom: 1px solid var(--border-default);
  display: grid; gap: 10px; align-items: center;
}

/* Sub-Constraint-Rows (Auto-Like Konfig + Auto-Hide Buffer) */
.constraint-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 0 8px 22px;
  font-family: var(--font-mono); font-size: 12.5px;
  color: var(--text-secondary);
  border-bottom: 1px solid var(--border-subtle);
}
.constraint-row:last-child { border-bottom: none; }
.constraint-row .lbl {
  font-family: var(--font-sans); font-size: 13px; color: var(--text-secondary);
}
.constraint-row .val {
  color: var(--accent); font-weight: 700;
  font-variant-numeric: tabular-nums;
}

body::before {
  content: ""; position: fixed; inset: 0;
  pointer-events: none; z-index: 1;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.015 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
  opacity: 0.20;
}
.app { position: relative; z-index: 2; }

@media (max-width: 1500px) { :root { --rail-w: 320px; } }
@media (max-width: 1300px) {
  :root { --rail-w: 300px; --sidebar-w: 240px; }
  .view-header, .view-body, .queue-toolbar, .action-bar { padding-left: 22px; padding-right: 22px; }
  .proof-card, .proof-stack { margin-left: 22px; margin-right: 22px; }
}
@media (max-width: 1100px) {
  .app { grid-template-columns: var(--sidebar-w) 1fr; grid-template-areas: "head head" "nav main" "foot foot"; }
  .siderail { display: none; }
  .topbar { grid-template-columns: var(--sidebar-w) 1fr; }
  .topbar-actions { display: none; }
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .channel-grid, .match-grid, .settings-grid { grid-template-columns: 1fr; }
}
