/* ARNE Control — UI Kit styles (v3 retrofuture) */
@import url('../../colors_and_type.css');

/* ============ Scrollbar (ARNE themed) ============ */
* { scrollbar-width: thin; scrollbar-color: var(--accent) var(--bg-inset); }
*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-track { background: var(--bg-inset); border-left: 1px solid var(--border-divider); }
*::-webkit-scrollbar-thumb { background: linear-gradient(180deg, var(--accent), #c43810); border: 2px solid var(--bg-inset); box-shadow: inset 0 0 4px rgba(0,0,0,0.4); }
*::-webkit-scrollbar-thumb:hover { background: var(--accent); box-shadow: 0 0 6px var(--accent-glow); }
*::-webkit-scrollbar-corner { background: var(--bg-inset); }

/* ============ App shell ============ */
* { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--bg-void);
  font-family: var(--font-ui);
  color: var(--fg-1);
  min-height: 100vh;
}
.app {
  padding: 14px 18px 14px;
  display: grid;
  grid-template-rows: auto auto auto 1fr auto;
  gap: 12px;
  min-height: 100vh;
  max-width: 1720px;
  margin: 0 auto;
}

/* ============ Header ============ */
.hdr {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 28px;
  align-items: center;
  padding: 14px 22px;
  background: var(--bg-panel);
  border: 1px solid var(--border-soft);
}
.hdr-mark-3d { width: 56px !important; height: 56px !important; filter: drop-shadow(0 4px 10px rgba(0,0,0,0.8)); }
.hdr-brand { display: flex; align-items: center; gap: 14px; }
.hdr-mark { width: 44px; height: 44px; flex-shrink: 0; }
.hdr-word {
  font-family: var(--font-display); font-weight: 700;
  font-size: 26px; letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--fg-1); line-height: 1;
  white-space: nowrap;
}
.hdr-word-accent { color: var(--accent); }
.hdr-sub {
  font-family: var(--font-display);
  font-size: 10px; letter-spacing: var(--tracking-widest);
  color: var(--fg-3); margin-top: 4px; text-transform: uppercase; font-weight: 500;
}
.hdr-stats { display: flex; gap: 28px; justify-content: center; align-items: center; flex-wrap: nowrap; }
.hdr-stat-lbl { white-space: nowrap; }
.hdr-stat { display: flex; flex-direction: column; gap: 4px; align-items: flex-start; }
.hdr-stat-lbl {
  font-family: var(--font-display);
  font-size: 9px; letter-spacing: var(--tracking-widest);
  color: var(--fg-3); text-transform: uppercase; font-weight: 600;
}
.hdr-stat-val {
  font-family: var(--font-display); font-weight: 700;
  font-size: 16px; letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--fg-1);
}
.hdr-stat-val {
  white-space: nowrap;
}
.hdr-stat-val.big {
  font-family: var(--font-numeric); font-size: 22px; font-weight: 500;
  text-transform: none; letter-spacing: 0;
  font-variant-numeric: tabular-nums; color: var(--accent);
  line-height: 1;
}
.hdr-stat-val.mono { font-family: var(--font-mono); font-size: 15px; }
.hdr-stat-val.tone-ready { color: var(--status-ready); }
.hdr-stat-val.tone-hot { color: var(--accent); }
.hdr-stat-val.dim { color: var(--fg-2); }
.hdr-dim { color: var(--fg-3); font-weight: 400; }
.hdr-radar { width: 62px; height: 62px; }

/* ============ TabNav ============ */
.tabnav { display: flex; gap: 0; border-bottom: 1px solid var(--border-divider); padding: 0 8px; }
.tabnav-tab {
  font-family: var(--font-display);
  font-size: 12px; font-weight: 600;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  padding: 11px 18px;
  color: var(--fg-3);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  display: flex; align-items: center; gap: 8px;
  transition: color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
}
.tabnav-tab:hover { color: var(--fg-2); }
.tabnav-tab.active { color: var(--accent); border-bottom-color: var(--accent); background: var(--accent-wash); }
.tabnav-glyph { opacity: 0.9; }

/* ============ Stat Cards ============ */
.statcards { display: grid; grid-template-columns: repeat(6, 1fr); gap: 10px; }
.statcard {
  background: var(--bg-panel);
  border: 1px solid var(--border-soft);
  padding: 12px 14px;
  position: relative;
  min-height: 88px;
}
.statcard-lbl {
  font-family: var(--font-display);
  font-size: 10px; letter-spacing: var(--tracking-widest);
  text-transform: uppercase; color: var(--fg-3); font-weight: 600;
}
.statcard-val {
  font-family: var(--font-numeric);
  font-size: 36px; font-weight: 500; line-height: 1;
  margin-top: 6px;
  font-variant-numeric: tabular-nums;
  color: var(--fg-1);
}
.statcard-val.tone-hot { color: var(--accent); }
.statcard-val.tone-ready { color: var(--status-ready); }
.statcard-val.tone-warn { color: var(--status-warn); }
.statcard-val.tone-alert { color: var(--status-alert); }
.statcard-meta { font-family: var(--font-mono); font-size: 10px; margin-top: 5px; }
.tone-ready { color: var(--status-ready); }
.tone-warn  { color: var(--status-warn); }
.tone-alert { color: var(--status-alert); }
.tone-hot   { color: var(--accent); }
.tone-fg3   { color: var(--fg-3); }
.tone-dim   { color: var(--fg-3); }
.statcard-glyph {
  position: absolute; top: 12px; right: 14px;
  color: var(--fg-3); font-size: 18px;
}

/* ============ Panel (generic) ============ */
.panel { background: var(--bg-panel); border: 1px solid var(--border-soft); display: flex; flex-direction: column; }
.panel-hdr {
  display: flex; justify-content: space-between; align-items: center;
  padding: 11px 14px; border-bottom: 1px solid var(--border-divider);
}
.panel-title {
  font-family: var(--font-display);
  font-size: 11px; font-weight: 700;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase; color: var(--fg-1);
}
.panel-meta {
  font-family: var(--font-display);
  font-size: 10px; font-weight: 600;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
}
.panel-body { flex: 1; padding: 0; }
.panel-foot-link {
  padding: 10px 14px;
  font-family: var(--font-display);
  font-size: 10px; font-weight: 600;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--accent);
  cursor: pointer;
  border-top: 1px solid var(--border-divider);
  text-align: right;
}
.panel-foot-link:hover { color: var(--accent-bright); }

/* ============ Need Input ============ */
.nilist { display: flex; flex-direction: column; }
.ni-row {
  display: grid; grid-template-columns: 18px 1fr auto;
  gap: 12px; padding: 11px 14px;
  border-bottom: 1px solid var(--border-divider);
  align-items: start;
}
.ni-row:last-child { border-bottom: none; }
.ni-pip { width: 8px; height: 8px; border-radius: 50%; margin-top: 6px; }
.ni-pip.prio-high { background: var(--prio-high); box-shadow: 0 0 6px var(--prio-high); }
.ni-pip.prio-medium { background: var(--prio-medium); }
.ni-pip.prio-low { background: var(--prio-low); }
.ni-title { font-weight: 500; color: var(--fg-1); font-size: 13px; }
.ni-proj { font-family: var(--font-mono); font-size: 10px; color: var(--fg-3); margin-top: 2px; }
.ni-desc { font-size: 12px; color: var(--fg-3); margin-top: 3px; line-height: 1.4; }
.ni-right { text-align: right; }
.ni-prio {
  font-family: var(--font-display); font-size: 10px; font-weight: 700;
  letter-spacing: var(--tracking-widest); text-transform: uppercase;
}
.ni-prio.prio-high { color: var(--prio-high); }
.ni-prio.prio-medium { color: var(--prio-medium); }
.ni-prio.prio-low { color: var(--prio-low); }
.ni-time { font-family: var(--font-mono); font-size: 10px; color: var(--fg-4); margin-top: 4px; }

/* ============ Ongoing (progress) ============ */
.prog-list { display: flex; flex-direction: column; }
.prog-row {
  display: grid; grid-template-columns: 1fr 120px 42px 90px;
  gap: 14px; align-items: center;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border-divider);
}
.prog-row:last-child { border-bottom: none; }
.prog-title { font-size: 13px; color: var(--fg-1); }
.prog-proj { font-family: var(--font-mono); font-size: 10px; color: var(--fg-3); margin-top: 2px; }
.prog-track { height: 3px; background: var(--bg-inset); border-radius: 2px; overflow: hidden; }
.prog-fill { height: 100%; background: var(--accent); box-shadow: 0 0 8px var(--accent-glow); transition: width var(--dur-base) var(--ease-out); }
.prog-fill.done { background: var(--status-ready); box-shadow: 0 0 8px var(--status-ready); }
.prog-count { font-family: var(--font-mono); font-size: 11px; color: var(--fg-2); }
.prog-session {
  font-family: var(--font-display); font-size: 10px;
  letter-spacing: var(--tracking-widest); text-transform: uppercase;
  font-weight: 700; text-align: right;
}

/* ============ Decisions ============ */
.dec-list { display: flex; flex-direction: column; }
.dec-row {
  display: grid; grid-template-columns: 46px 1fr 18px;
  gap: 12px; padding: 10px 14px;
  border-bottom: 1px solid var(--border-divider);
  align-items: start;
}
.dec-row:last-child { border-bottom: none; }
.dec-time { font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); padding-top: 1px; }
.dec-title { font-size: 13px; color: var(--fg-1); }
.dec-desc { font-size: 12px; color: var(--fg-3); margin-top: 2px; line-height: 1.4; }
.dec-check { color: var(--status-ready); font-size: 14px; margin-top: 2px; }

/* ============ Projects table ============ */
.proj-table { width: 100%; border-collapse: collapse; }
.proj-table th, .proj-table td { padding: 8px 14px; text-align: left; font-size: 12px; }
.proj-table th {
  font-family: var(--font-display);
  font-size: 9px; font-weight: 600;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase; color: var(--fg-3);
  border-bottom: 1px solid var(--border-divider);
}
.proj-table th:not(:first-child), .proj-table td:not(:first-child) { text-align: right; }
.proj-table td { border-bottom: 1px solid var(--border-divider); color: var(--fg-2); font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
.proj-table tr:last-child td { border-bottom: none; }
.proj-name { font-family: var(--font-ui) !important; color: var(--fg-1) !important; font-weight: 500; font-size: 13px !important; }
.proj-status { font-family: var(--font-display) !important; font-weight: 600; text-transform: uppercase; letter-spacing: var(--tracking-wide); font-size: 11px !important; }

/* ============ Trend chart ============ */
.trend-legend { display: flex; gap: 20px; padding: 10px 14px 4px; }
.trend-l-item { display: flex; align-items: center; gap: 6px; }
.trend-l-dot { width: 8px; height: 8px; border-radius: 50%; }
.trend-l-name { font-family: var(--font-display); font-size: 10px; letter-spacing: var(--tracking-wider); text-transform: uppercase; color: var(--fg-3); font-weight: 500; }
.trend-svg { width: 100%; height: 180px; display: block; padding: 0 8px; }

/* ============ Sessions ============ */
.sess-grid { display: grid; grid-template-columns: 120px 1fr; }
.sess-side { padding: 14px; border-right: 1px solid var(--border-divider); display: flex; flex-direction: column; gap: 16px; }
.sess-side-row { display: flex; flex-direction: column; gap: 3px; }
.sess-side-lbl { font-family: var(--font-display); font-size: 9px; letter-spacing: var(--tracking-widest); text-transform: uppercase; color: var(--fg-3); font-weight: 600; }
.sess-side-val { font-family: var(--font-numeric); font-size: 20px; font-weight: 500; color: var(--fg-1); font-variant-numeric: tabular-nums; }
.sess-list { display: flex; flex-direction: column; }
.sess-row {
  display: grid; grid-template-columns: 80px 1fr auto;
  gap: 10px; padding: 9px 14px;
  border-bottom: 1px solid var(--border-divider);
  align-items: center;
}
.sess-row:last-child { border-bottom: none; }
.sess-id { font-family: var(--font-display); font-size: 11px; font-weight: 600; letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--fg-2); }
.sess-name { font-size: 12px; color: var(--fg-1); }
.sess-state {
  font-family: var(--font-display); font-size: 9px; font-weight: 700;
  letter-spacing: var(--tracking-widest); text-transform: uppercase;
  padding: 3px 8px; border: 1px solid currentColor;
}

/* ============ Voice agent ============ */
.voice {
  display: grid;
  grid-template-columns: 56px 170px 1fr 130px 110px;
  gap: 18px;
  align-items: center;
  padding: 10px 18px;
  background: var(--bg-panel);
  border: 1px solid var(--border-soft);
}
.voice-mic {
  width: 40px; height: 40px; border-radius: 50%;
  background: radial-gradient(circle, rgba(255,59,47,0.22), transparent 70%), var(--bg-panel-2);
  border: 2px solid var(--status-alert);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 22px rgba(255,59,47,0.55), inset 0 0 10px rgba(255,59,47,0.3);
  color: var(--status-alert);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.voice-mic:hover { transform: scale(1.05); }
.voice-mic.voice-mic-on {
  background: radial-gradient(circle, rgba(255,59,47,0.45), transparent 70%), var(--bg-panel-2);
  box-shadow: 0 0 32px rgba(255,59,47,0.85), inset 0 0 14px rgba(255,59,47,0.5);
  animation: micPulse 1.2s ease-in-out infinite;
}
@keyframes micPulse {
  0%, 100% { box-shadow: 0 0 28px rgba(255,59,47,0.7), inset 0 0 14px rgba(255,59,47,0.5); }
  50%     { box-shadow: 0 0 40px rgba(255,59,47,1), inset 0 0 18px rgba(255,59,47,0.7); }
}
.voice-lbl-wrap { display: flex; flex-direction: column; gap: 4px; }
.voice-lbl {
  font-family: var(--font-display);
  font-size: 11px; font-weight: 700;
  letter-spacing: var(--tracking-widest); text-transform: uppercase;
  color: var(--status-alert);
}
.voice-key { font-family: var(--font-mono); font-size: 10px; color: var(--fg-3); }
.voice-mid { display: flex; flex-direction: column; align-items: center; gap: 6px; width: 100%; }
/* ============ Knight Rider scanner ============ */
.kr-housing {
  width: 100%;
  padding: 6px 12px;
  background: linear-gradient(180deg, #1a0606 0%, #050202 30%, #0a0303 70%, #1a0606 100%);
  border: 1px solid #2a0605;
  border-radius: 3px;
  box-shadow:
    inset 0 2px 0 rgba(60, 10, 8, 0.6),
    inset 0 -2px 0 rgba(0, 0, 0, 0.9),
    inset 0 0 30px rgba(255, 15, 5, 0.04),
    0 2px 6px rgba(0, 0, 0, 0.6);
}
.kr-frame {
  display: grid;
  grid-template-columns: repeat(24, 1fr);
  gap: 3px;
  height: 12px;
}
.kr-cell {
  height: 100%;
  background: rgba(60, 6, 4, 0.6);
  border-radius: 1px;
  box-shadow: inset 0 0 2px rgba(0,0,0,0.9);
}
.kr-cell.lit-0 {
  background: radial-gradient(circle at center, #fff6f0 0%, #ff3020 30%, #c8150a 70%);
  box-shadow: 0 0 16px 2px rgba(255,30,15,1), 0 0 30px 8px rgba(255,50,20,0.7), inset 0 0 4px #fff;
}
.kr-cell.lit-1 {
  background: radial-gradient(circle at center, #ff5030 0%, #c0150a 60%);
  box-shadow: 0 0 12px rgba(255,25,10,0.85), 0 0 20px rgba(255,40,20,0.5);
}
.kr-cell.lit-2 {
  background: radial-gradient(circle at center, #b0200e 0%, #50060a 70%);
  box-shadow: 0 0 8px rgba(255,20,8,0.5);
}
.kr-cell.lit-3 {
  background: radial-gradient(circle at center, #601008 0%, #300303 80%);
  box-shadow: 0 0 4px rgba(255,15,5,0.25);
}
.kr-cell.lit-4 { background: #300404; }
.voice-mode {
  font-family: var(--font-display);
  font-size: 10px; letter-spacing: var(--tracking-widest);
  text-transform: uppercase; color: var(--fg-3); font-weight: 600;
}
.voice-status { display: flex; flex-direction: column; gap: 4px; }
.voice-status .voice-lbl { color: var(--fg-3); }
.voice-state { font-size: 12px; color: var(--fg-2); display: flex; align-items: center; gap: 6px; }
.voice-state-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--fg-3); }
.voice-state-dot.on { background: var(--status-alert); box-shadow: 0 0 8px var(--status-alert); animation: blink 1s steps(2, end) infinite; }
@keyframes blink { 0%, 50% { opacity: 1; } 50.01%, 100% { opacity: 0.3; } }
.voice-settings {
  font-family: var(--font-display); font-size: 11px; font-weight: 600;
  letter-spacing: var(--tracking-widest); text-transform: uppercase;
  padding: 8px 14px; background: var(--bg-panel-2);
  border: 1px solid var(--border-soft); color: var(--fg-2);
  cursor: pointer; display: inline-flex; align-items: center; gap: 8px;
}
.voice-settings:hover { border-color: var(--border-strong); color: var(--fg-1); }

/* ============ Dashboard grid ============ */
.dash-mid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }
.dash-bot { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }

/* ============ Projects View ============ */
.pv { display: flex; flex-direction: column; gap: 12px; }
.pv-summary { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.pv-sum-card { background: var(--bg-panel); border: 1px solid var(--border-soft); padding: 12px 14px; }
.pv-sum-lbl { font-family: var(--font-display); font-size: 10px; letter-spacing: var(--tracking-widest); text-transform: uppercase; color: var(--fg-3); font-weight: 600; }
.pv-sum-val { font-family: var(--font-numeric); font-size: 32px; font-weight: 500; margin-top: 4px; color: var(--fg-1); font-variant-numeric: tabular-nums; }
.pv-sum-dim { color: var(--fg-3); font-size: 18px; }

.pv-table { width: 100%; border-collapse: collapse; }
.pv-table th, .pv-table td { padding: 10px 14px; text-align: left; font-size: 12px; }
.pv-table th { font-family: var(--font-display); font-size: 9px; font-weight: 600; letter-spacing: var(--tracking-widest); text-transform: uppercase; color: var(--fg-3); border-bottom: 1px solid var(--border-divider); }
.pv-table td { border-bottom: 1px solid var(--border-divider); color: var(--fg-2); font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
.pv-table tr:last-child td { border-bottom: none; }
.pv-id { color: var(--fg-3) !important; font-size: 11px !important; }
.pv-name { font-family: var(--font-ui) !important; color: var(--fg-1) !important; font-weight: 500; font-size: 13px !important; }
.pv-lead { color: var(--accent) !important; }
.pv-upd { color: var(--fg-3) !important; }
.pv-status { font-family: var(--font-display) !important; font-weight: 700 !important; text-transform: uppercase; letter-spacing: var(--tracking-wide); font-size: 10px !important; }
.status-active { color: var(--status-ready) !important; }
.status-review { color: var(--status-warn) !important; }
.status-blocked { color: var(--status-alert) !important; }
.status-idle { color: var(--fg-3) !important; }
.pv-track { width: 100%; height: 4px; background: var(--bg-inset); border-radius: 2px; overflow: hidden; }
.pv-fill { height: 100%; background: var(--accent); box-shadow: 0 0 6px var(--accent-glow); }
.pv-fill.done { background: var(--status-ready); box-shadow: 0 0 6px var(--status-ready); }
.pv-prio { font-family: var(--font-display); font-size: 10px; font-weight: 700; letter-spacing: var(--tracking-widest); }
.pv-prio.prio-high { color: var(--prio-high); }
.pv-prio.prio-medium { color: var(--prio-medium); }
.pv-prio.prio-low { color: var(--prio-low); }

.tv { display: flex; flex-direction: column; gap: 12px; }

/* ============ Diagnostics Strip ============ */
.diag { background: var(--bg-panel); border: 1px solid var(--border-soft); padding: 10px 14px 12px; }
.diag-hdr { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.diag-hdr-lbl { font-family: var(--font-display); font-size: 11px; font-weight: 700; letter-spacing: var(--tracking-widest); text-transform: uppercase; color: var(--accent); white-space: nowrap; }
.diag-hdr-meta { font-family: var(--font-mono); font-size: 10px; color: var(--fg-3); display: flex; align-items: center; gap: 8px; }
.diag-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--status-ready); box-shadow: 0 0 6px var(--status-ready); }
.diag-dot.on { animation: blink 1.4s steps(2, end) infinite; }
.diag-grid { display: grid; grid-template-columns: repeat(8, 1fr); gap: 6px; }
.diag-cell { background: var(--bg-panel-2); border: 1px solid var(--border-divider); border-left: 2px solid var(--status-ready); padding: 8px 10px; display: flex; flex-direction: column; gap: 2px; }
.diag-cell.st-warn { border-left-color: var(--status-warn); }
.diag-cell.st-alert { border-left-color: var(--status-alert); }
.diag-cell-top { display: flex; justify-content: space-between; align-items: center; }
.diag-cell-name { font-family: var(--font-display); font-size: 10px; font-weight: 700; letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--fg-1); white-space: nowrap; }
.diag-pip { width: 6px; height: 6px; border-radius: 50%; background: var(--status-ready); box-shadow: 0 0 4px var(--status-ready); }
.diag-pip.st-warn { background: var(--status-warn); box-shadow: 0 0 4px var(--status-warn); }
.diag-pip.st-alert { background: var(--status-alert); box-shadow: 0 0 6px var(--status-alert); animation: blink 0.8s steps(2,end) infinite; }
.diag-cell-id { font-family: var(--font-mono); font-size: 9px; color: var(--fg-3); letter-spacing: 0.02em; }
.diag-cell-metric { font-family: var(--font-numeric); font-size: 14px; font-weight: 500; color: var(--fg-1); margin-top: 2px; font-variant-numeric: tabular-nums; }
.diag-cell.st-warn .diag-cell-metric { color: var(--status-warn); }
.diag-cell.st-alert .diag-cell-metric { color: var(--status-alert); }
.diag-cell-sub { font-family: var(--font-mono); font-size: 9px; color: var(--fg-3); }

/* Live voice bar stays visible across tab switches */
.app { grid-template-rows: auto auto 1fr auto auto; }
.tab-body { min-height: 400px; }

/* ============ Kanban ============ */
.kb { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; }
.kb-col { background: var(--bg-panel); border: 1px solid var(--border-soft); border-top: 2px solid var(--fg-3); display: flex; flex-direction: column; min-height: 520px; }
.kb-col.tone-hot { border-top-color: var(--accent); }
.kb-col.tone-alert { border-top-color: var(--status-alert); }
.kb-col.tone-ready { border-top-color: var(--status-ready); }
.kb-col.tone-dim { border-top-color: var(--fg-3); opacity: 0.85; }
.kb-col-hdr { display: flex; justify-content: space-between; align-items: center; padding: 10px 12px; border-bottom: 1px solid var(--border-divider); }
.kb-col-title { font-family: var(--font-display); font-size: 11px; font-weight: 700; letter-spacing: var(--tracking-widest); text-transform: uppercase; color: var(--fg-1); }
.kb-col-count { font-family: var(--font-numeric); font-size: 14px; color: var(--accent); font-variant-numeric: tabular-nums; }
.kb-col.tone-ready .kb-col-count { color: var(--status-ready); }
.kb-col.tone-alert .kb-col-count { color: var(--status-alert); }
.kb-col.tone-dim .kb-col-count { color: var(--fg-3); }
.kb-col-body { padding: 8px; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.kb-card { background: var(--bg-panel-2); border: 1px solid var(--border-divider); border-left: 2px solid var(--fg-3); padding: 8px 10px; cursor: grab; }
.kb-card:active { cursor: grabbing; }
.kb-card.prio-high { border-left-color: var(--prio-high); }
.kb-card.prio-medium { border-left-color: var(--prio-medium); }
.kb-card.prio-low { border-left-color: var(--prio-low); }
.kb-card.cancelled { opacity: 0.5; text-decoration: line-through; }
.kb-card-top { display: flex; align-items: center; gap: 6px; margin-bottom: 4px; }
.kb-pip { width: 6px; height: 6px; border-radius: 50%; }
.kb-pip.prio-high { background: var(--prio-high); }
.kb-pip.prio-medium { background: var(--prio-medium); }
.kb-pip.prio-low { background: var(--prio-low); }
.kb-card-id { font-family: var(--font-mono); font-size: 10px; color: var(--fg-3); }
.kb-card-age { font-family: var(--font-mono); font-size: 10px; color: var(--fg-3); margin-left: auto; }
.kb-card-title { font-size: 12px; color: var(--fg-1); font-weight: 500; line-height: 1.3; margin-bottom: 4px; }
.kb-card-bot { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 10px; color: var(--fg-3); }
.kb-card-proj { color: var(--accent); }
.kb-empty { font-family: var(--font-mono); font-size: 10px; color: var(--fg-3); text-align: center; padding: 14px 0; opacity: 0.5; }

/* ============ Task Detail Modal ============ */
.tk-overlay { position: fixed; inset: 0; background: rgba(5,5,5,0.72); backdrop-filter: blur(4px); display: flex; align-items: center; justify-content: center; z-index: 100; padding: 40px 20px; }
.tk-modal { background: var(--bg-panel); border: 1px solid var(--accent); box-shadow: 0 0 40px rgba(255,90,31,0.25), 0 20px 60px rgba(0,0,0,0.6); width: 100%; max-width: 760px; max-height: calc(100vh - 80px); display: flex; flex-direction: column; position: relative; }
.tk-modal::before { content: ''; position: absolute; top: -1px; left: -1px; right: -1px; height: 2px; background: linear-gradient(90deg, transparent, var(--accent), transparent); }
.tk-hdr { display: flex; justify-content: space-between; align-items: center; padding: 12px 18px; border-bottom: 1px solid var(--border-divider); background: var(--bg-panel-2); }
.tk-hdr-l { display: flex; align-items: center; gap: 12px; }
.tk-id { font-family: var(--font-mono); font-size: 12px; color: var(--accent); font-weight: 700; letter-spacing: 0.04em; }
.tk-status { font-family: var(--font-display); font-size: 10px; font-weight: 700; letter-spacing: var(--tracking-widest); text-transform: uppercase; padding: 3px 8px; border: 1px solid currentColor; }
.tk-status.st-todo { color: var(--fg-2); }
.tk-status.st-doing { color: var(--accent); }
.tk-status.st-input { color: var(--status-alert); }
.tk-status.st-done { color: var(--status-ready); }
.tk-status.st-cancelled { color: var(--fg-3); opacity: 0.6; }
.tk-close { background: transparent; border: 1px solid var(--border-soft); color: var(--fg-2); width: 28px; height: 28px; font-family: var(--font-mono); font-size: 14px; cursor: pointer; transition: all 120ms; }
.tk-close:hover { border-color: var(--accent); color: var(--accent); }

.tk-body { padding: 20px; overflow-y: auto; flex: 1; }
.tk-title { font-family: var(--font-display); font-size: 20px; font-weight: 600; color: var(--fg-1); margin-bottom: 18px; letter-spacing: var(--tracking-wide); line-height: 1.25; }
.tk-meta-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px 18px; padding: 12px 14px; background: var(--bg-panel-2); border-left: 2px solid var(--accent); margin-bottom: 18px; }
.tk-meta-lbl { font-family: var(--font-display); font-size: 9px; letter-spacing: var(--tracking-widest); text-transform: uppercase; color: var(--fg-3); font-weight: 600; }
.tk-meta-val { font-family: var(--font-mono); font-size: 12px; color: var(--fg-1); margin-top: 2px; font-variant-numeric: tabular-nums; }
.tk-meta-val.accent { color: var(--accent); }
.tk-meta-val.prio-high { color: var(--prio-high); }
.tk-meta-val.prio-medium { color: var(--prio-medium); }
.tk-meta-val.prio-low { color: var(--prio-low); }

.tk-section-lbl { font-family: var(--font-display); font-size: 10px; font-weight: 700; letter-spacing: var(--tracking-widest); text-transform: uppercase; color: var(--accent); margin-bottom: 8px; }
.tk-desc { font-family: var(--font-ui); font-size: 13px; line-height: 1.5; color: var(--fg-2); margin-bottom: 20px; padding: 12px 14px; background: var(--bg-panel-2); border: 1px solid var(--border-divider); }

.tk-thread { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.tk-empty { font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); text-align: center; padding: 16px; border: 1px dashed var(--border-divider); }
.tk-msg { padding: 10px 12px; border-left: 2px solid var(--fg-3); background: var(--bg-panel-2); }
.tk-msg.tk-msg-me { border-left-color: var(--accent); background: rgba(255,90,31,0.06); }
.tk-msg.tk-msg-arne { border-left-color: var(--status-info); }
.tk-msg.tk-msg-agent { border-left-color: var(--status-ready); }
.tk-msg-who { display: flex; justify-content: space-between; margin-bottom: 4px; font-family: var(--font-mono); font-size: 10px; }
.tk-msg-who-name { color: var(--fg-1); font-weight: 700; letter-spacing: 0.04em; }
.tk-msg.tk-msg-me .tk-msg-who-name { color: var(--accent); }
.tk-msg-when { color: var(--fg-3); }
.tk-msg-text { font-family: var(--font-ui); font-size: 12px; line-height: 1.45; color: var(--fg-2); }

.tk-reply { border-top: 1px solid var(--border-divider); padding: 14px 18px; background: var(--bg-panel-2); }
.tk-reply-input { width: 100%; background: var(--bg-void); border: 1px solid var(--border-soft); color: var(--fg-1); font-family: var(--font-ui); font-size: 13px; padding: 10px 12px; resize: vertical; box-sizing: border-box; outline: none; transition: border-color 120ms; }
.tk-reply-input:focus { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent); }
.tk-reply-input::placeholder { color: var(--fg-3); font-family: var(--font-mono); font-size: 11px; }
.tk-reply-bar { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-top: 10px; }
.tk-move { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.tk-move-lbl { font-family: var(--font-display); font-size: 9px; letter-spacing: var(--tracking-widest); text-transform: uppercase; color: var(--fg-3); font-weight: 600; margin-right: 4px; }
.tk-move-btn { background: transparent; border: 1px solid var(--border-soft); color: var(--fg-2); font-family: var(--font-display); font-size: 10px; letter-spacing: var(--tracking-wide); text-transform: uppercase; font-weight: 600; padding: 4px 8px; cursor: pointer; transition: all 120ms; }
.tk-move-btn:hover { border-color: var(--accent); color: var(--accent); }
.tk-move-btn.tone-ready:hover { border-color: var(--status-ready); color: var(--status-ready); }
.tk-move-btn.tone-alert:hover { border-color: var(--status-alert); color: var(--status-alert); }
.tk-send { background: var(--accent); border: 1px solid var(--accent); color: var(--bg-void); font-family: var(--font-display); font-size: 11px; font-weight: 700; letter-spacing: var(--tracking-wide); text-transform: uppercase; padding: 7px 14px; cursor: pointer; transition: all 120ms; white-space: nowrap; }
.tk-send:hover:not(:disabled) { box-shadow: 0 0 14px var(--accent-glow); }
.tk-send:disabled { opacity: 0.4; cursor: not-allowed; }

.pv-row-click { cursor: pointer; transition: background 120ms; }
.pv-row-click:hover td { background: rgba(255,90,31,0.06); }
.dec-row-click { cursor: pointer; transition: background 120ms; }
.dec-row-click:hover { background: rgba(255,90,31,0.06); }
.tk-status.st-doing { color: var(--accent); }
.tk-meta-val.accent { color: var(--accent); }

/* ============ Sessions ============ */
.sv { display: flex; flex-direction: column; gap: 10px; }
.sv-top { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.sv-bot { display: grid; grid-template-columns: 2fr 1fr; gap: 10px; }
.sv-live, .sv-recent { display: flex; align-items: center; gap: 12px; padding: 8px 14px; border-bottom: 1px solid var(--border-divider); font-family: var(--font-mono); font-size: 11px; color: var(--fg-2); }
.sv-live:last-child, .sv-recent:last-child { border-bottom: none; }
.sv-live-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 6px var(--accent-glow); animation: blink 1.2s steps(2,end) infinite; }
.sv-id { color: var(--accent); font-weight: 700; }
.sv-agent { color: var(--fg-1); }
.sv-proj { color: var(--fg-3); flex: 1; }
.sv-mode { font-family: var(--font-display); font-size: 9px; letter-spacing: var(--tracking-wide); text-transform: uppercase; padding: 2px 6px; border: 1px solid var(--border-divider); }
.sv-mode.m-voice { color: var(--accent); border-color: var(--accent); }
.sv-mode.m-text { color: var(--fg-3); }
.sv-tpm, .sv-tasks, .sv-start, .sv-dur, .sv-outcome, .sv-end { font-variant-numeric: tabular-nums; }
.sv-dur { color: var(--fg-1); font-weight: 600; }
.sv-outcome { flex: 1; color: var(--fg-2); }
.sv-heatmap { padding: 14px; }
.sv-heat-hours { display: grid; grid-template-columns: 36px repeat(24, 1fr); margin-bottom: 4px; }
.sv-heat-hour { font-family: var(--font-mono); font-size: 9px; color: var(--fg-3); text-align: center; }
.sv-heat-row { display: grid; grid-template-columns: 36px repeat(24, 1fr); gap: 2px; margin-bottom: 2px; align-items: center; }
.sv-heat-day { font-family: var(--font-display); font-size: 10px; color: var(--fg-3); text-transform: uppercase; }
.sv-heat-cell { height: 16px; border: 1px solid var(--border-divider); }
.sv-ratio-body { padding: 14px; }
.sv-ratio { display: flex; height: 28px; border: 1px solid var(--border-soft); margin-bottom: 16px; }
.sv-ratio-v { background: var(--accent); color: var(--bg-void); font-family: var(--font-display); font-size: 11px; font-weight: 700; display: flex; align-items: center; justify-content: center; letter-spacing: var(--tracking-wide); }
.sv-ratio-t { background: var(--bg-inset); color: var(--fg-2); font-family: var(--font-display); font-size: 10px; font-weight: 700; display: flex; align-items: center; justify-content: center; letter-spacing: var(--tracking-wide); }
.sv-top-lbl { font-family: var(--font-display); font-size: 10px; letter-spacing: var(--tracking-widest); text-transform: uppercase; color: var(--fg-3); margin-bottom: 8px; font-weight: 600; }
.sv-top-row { display: grid; grid-template-columns: 1fr auto; gap: 8px; margin-bottom: 8px; align-items: center; }
.sv-top-name { font-family: var(--font-mono); font-size: 11px; color: var(--fg-1); }
.sv-top-time { font-family: var(--font-numeric); font-size: 11px; color: var(--accent); font-variant-numeric: tabular-nums; }
.sv-top-track { grid-column: 1 / -1; height: 3px; background: var(--bg-inset); }
.sv-top-fill { height: 100%; background: var(--accent); box-shadow: 0 0 4px var(--accent-glow); }

/* ============ Analytics ============ */
.av { display: flex; flex-direction: column; gap: 10px; }
.av-filter-bar { display: flex; align-items: center; gap: 12px; padding: 8px 12px; background: var(--bg-panel); border: 1px solid var(--border-divider); }
.av-filter-lbl { font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); letter-spacing: 0.08em; }
.av-filter-group { display: flex; gap: 0; border: 1px solid var(--border-divider); background: var(--bg-inset); }
.av-filter-btn { font-family: var(--font-mono); font-size: 12px; color: var(--fg-2); background: transparent; border: none; padding: 6px 12px; cursor: pointer; letter-spacing: 0.06em; border-right: 1px solid var(--border-divider); transition: color 120ms, background 120ms; }
.av-filter-btn:last-child { border-right: none; }
.av-filter-btn:hover { color: var(--fg-1); background: rgba(255,90,31,0.08); }
.av-filter-btn.active { color: var(--accent); background: rgba(255,90,31,0.14); box-shadow: inset 0 -2px 0 var(--accent); }
.av-filter-meta { margin-left: auto; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; }
.av-gauges { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; }
.av-gauge { background: var(--bg-panel); border: 1px solid var(--border-soft); padding: 12px 14px; }
.av-g-lbl { font-family: var(--font-display); font-size: 10px; letter-spacing: var(--tracking-widest); text-transform: uppercase; color: var(--fg-3); font-weight: 600; }
.av-g-val { font-family: var(--font-numeric); font-size: 28px; color: var(--fg-1); margin-top: 4px; font-variant-numeric: tabular-nums; }
.av-g-val.tone-hot { color: var(--accent); }
.av-g-val.tone-ready { color: var(--status-ready); }
.av-g-dim { color: var(--fg-3); font-size: 16px; }
.av-g-sub { font-family: var(--font-mono); font-size: 10px; color: var(--fg-3); margin-top: 2px; }
.av-svg { width: 100%; height: 200px; }
.av-legend { display: flex; gap: 14px; font-family: var(--font-mono); font-size: 10px; color: var(--fg-3); }
.av-legend span { display: flex; align-items: center; gap: 4px; }
.av-legend i { width: 10px; height: 2px; display: inline-block; }
.av-bot { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.av-velocity { padding: 14px; display: flex; flex-direction: column; gap: 10px; }
.av-vel-row { display: grid; grid-template-columns: 80px repeat(4, 1fr); gap: 6px; align-items: end; height: 60px; }
.av-vel-name { font-family: var(--font-mono); font-size: 11px; color: var(--fg-2); align-self: center; }
.av-vel-bar-wrap { height: 100%; display: flex; flex-direction: column; justify-content: flex-end; align-items: center; position: relative; }
.av-vel-bar { width: 100%; background: var(--accent); box-shadow: 0 0 6px var(--accent-glow); }
.av-vel-val { position: absolute; top: -14px; font-family: var(--font-numeric); font-size: 10px; color: var(--fg-3); }
.av-agents { padding: 14px; display: flex; flex-direction: column; gap: 8px; }
.av-ag-row { display: grid; grid-template-columns: 80px 1fr 40px; gap: 8px; align-items: center; }
.av-ag-name { font-family: var(--font-mono); font-size: 11px; color: var(--fg-1); }
.av-ag-bar { display: flex; height: 16px; border: 1px solid var(--border-divider); }
.av-ag-total { font-family: var(--font-numeric); font-size: 11px; color: var(--accent); text-align: right; }
.av-ag-legend { display: flex; gap: 14px; font-family: var(--font-mono); font-size: 10px; color: var(--fg-3); margin-top: 6px; }
.av-ag-legend span { display: flex; align-items: center; gap: 4px; }
.av-ag-legend i { width: 10px; height: 10px; display: inline-block; }
