/* ============================================================
   LuxDev Control Tower — Design System
   Concept: Mission Control · Terminal precision · Dark-first
   Fonts: General Sans (body/UI) + JetBrains Mono (data/code)
   ============================================================ */

:root, [data-theme='dark'] {
  --color-bg: #0d0d0e;
  --color-surface: #111113;
  --color-surface-2: #161619;
  --color-surface-3: #1a1a1e;
  --color-surface-offset: #1e1e23;
  --color-border: #2a2a30;
  --color-border-subtle: #1f1f24;
  --color-divider: #232328;
  --color-text: #e2e2e6;
  --color-text-muted: #888891;
  --color-text-faint: #4a4a54;
  --color-text-inverse: #0d0d0e;

  /* Accent: Electric Teal */
  --color-primary: #00d4aa;
  --color-primary-dim: #00a882;
  --color-primary-bg: rgba(0, 212, 170, 0.08);
  --color-primary-border: rgba(0, 212, 170, 0.2);

  /* Status */
  --color-success: #4ade80;
  --color-success-bg: rgba(74, 222, 128, 0.08);
  --color-success-border: rgba(74, 222, 128, 0.2);
  --color-warning: #fbbf24;
  --color-warning-bg: rgba(251, 191, 36, 0.08);
  --color-warning-border: rgba(251, 191, 36, 0.2);
  --color-error: #f87171;
  --color-error-bg: rgba(248, 113, 113, 0.08);
  --color-error-border: rgba(248, 113, 113, 0.2);
  --color-blue: #60a5fa;
  --color-blue-bg: rgba(96, 165, 250, 0.08);
  --color-blue-border: rgba(96, 165, 250, 0.2);
  --color-purple: #a78bfa;
  --color-purple-bg: rgba(167, 139, 250, 0.08);
  --color-purple-border: rgba(167, 139, 250, 0.2);

  --font-body: 'General Sans', 'Inter', -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', 'Fira Code', monospace;

  --text-xs: clamp(0.7rem, 0.65rem + 0.2vw, 0.8rem);
  --text-sm: clamp(0.8rem, 0.75rem + 0.25vw, 0.9rem);
  --text-base: clamp(0.9rem, 0.85rem + 0.25vw, 1rem);
  --text-lg: clamp(1rem, 0.95rem + 0.3vw, 1.15rem);
  --text-xl: clamp(1.2rem, 1.1rem + 0.5vw, 1.5rem);
  --text-2xl: clamp(1.6rem, 1.4rem + 1vw, 2rem);

  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;

  --radius-sm: 4px;
  --radius-md: 6px;
  --radius-lg: 10px;
  --radius-xl: 14px;

  --topbar-h: 56px;
  --sidebar-w: 0px;
}

[data-theme='light'] {
  --color-bg: #f4f4f6;
  --color-surface: #ffffff;
  --color-surface-2: #f9f9fb;
  --color-surface-3: #f2f2f5;
  --color-surface-offset: #ebebef;
  --color-border: #dddde5;
  --color-border-subtle: #e8e8ef;
  --color-divider: #e2e2e8;
  --color-text: #13131a;
  --color-text-muted: #5a5a6e;
  --color-text-faint: #a8a8b8;
  --color-text-inverse: #ffffff;
  --color-primary: #007a60;
  --color-primary-dim: #005a46;
  --color-primary-bg: rgba(0, 122, 96, 0.06);
  --color-primary-border: rgba(0, 122, 96, 0.18);
  --color-success: #16a34a;
  --color-success-bg: rgba(22, 163, 74, 0.07);
  --color-success-border: rgba(22, 163, 74, 0.18);
  --color-warning: #d97706;
  --color-warning-bg: rgba(217, 119, 6, 0.07);
  --color-warning-border: rgba(217, 119, 6, 0.18);
  --color-error: #dc2626;
  --color-error-bg: rgba(220, 38, 38, 0.07);
  --color-error-border: rgba(220, 38, 38, 0.18);
  --color-blue: #2563eb;
  --color-blue-bg: rgba(37, 99, 235, 0.07);
  --color-blue-border: rgba(37, 99, 235, 0.18);
  --color-purple: #7c3aed;
  --color-purple-bg: rgba(124, 58, 237, 0.07);
  --color-purple-border: rgba(124, 58, 237, 0.18);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-font-smoothing: antialiased; scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text);
  background: var(--color-bg);
  min-height: 100dvh;
  line-height: 1.6;
}
button { cursor: pointer; font: inherit; color: inherit; background: none; border: none; }
a { color: var(--color-primary); text-decoration: none; }
a:hover { text-decoration: underline; }
table { border-collapse: collapse; width: 100%; }

/* ============ TOPBAR ============ */
.topbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  height: var(--topbar-h);
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  backdrop-filter: blur(12px);
}
.topbar-inner {
  display: flex; align-items: center; gap: var(--space-6);
  height: 100%; padding: 0 var(--space-6);
}
.brand { display: flex; align-items: center; gap: var(--space-3); flex-shrink: 0; }
.brand-logo { width: 28px; height: 28px; color: var(--color-primary); }
.brand-text { display: flex; flex-direction: column; gap: 1px; }
.brand-name { font-size: var(--text-sm); font-weight: 600; letter-spacing: -0.01em; line-height: 1.2; }
.brand-org { font-size: var(--text-xs); color: var(--color-text-muted); font-family: var(--font-mono); line-height: 1.2; }
.topnav { display: flex; align-items: center; gap: var(--space-1); flex: 1; }
.nav-btn {
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-muted);
  transition: all 150ms ease;
}
.nav-btn:hover { color: var(--color-text); background: var(--color-surface-offset); }
.nav-btn.active { color: var(--color-primary); background: var(--color-primary-bg); }
.topbar-actions { display: flex; align-items: center; gap: var(--space-3); flex-shrink: 0; margin-left: auto; }
.meta-tag {
  font-size: var(--text-xs); color: var(--color-text-faint);
  font-family: var(--font-mono);
  padding: var(--space-1) var(--space-2);
  background: var(--color-surface-offset);
  border-radius: var(--radius-sm);
}
.icon-btn {
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--radius-md);
  color: var(--color-text-muted);
  transition: all 150ms ease;
}
.icon-btn:hover { color: var(--color-text); background: var(--color-surface-offset); }

/* ============ MAIN ============ */
.main-content {
  margin-top: var(--topbar-h);
  padding: var(--space-8) var(--space-8);
  max-width: 1400px;
  margin-left: auto; margin-right: auto;
}

/* ============ VIEWS ============ */
.view { display: none; }
.view.active { display: block; }
.page-header { margin-bottom: var(--space-8); }
.page-title {
  font-size: var(--text-xl); font-weight: 700;
  letter-spacing: -0.02em; color: var(--color-text);
  line-height: 1.2; margin-bottom: var(--space-2);
}
.page-subtitle { color: var(--color-text-muted); font-size: var(--text-sm); max-width: 640px; }
.section-header {
  display: flex; align-items: baseline; gap: var(--space-3);
  margin-bottom: var(--space-4); margin-top: var(--space-10);
}
.section-title { font-size: var(--text-base); font-weight: 600; letter-spacing: -0.01em; }
.section-meta { font-size: var(--text-xs); color: var(--color-text-muted); font-family: var(--font-mono); }

/* ============ KPI STRIP ============ */
.kpi-strip {
  display: grid; grid-template-columns: repeat(5, 1fr);
  gap: var(--space-4); margin-bottom: var(--space-8);
}
.kpi-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-5);
  position: relative; overflow: hidden;
  transition: transform 150ms ease, box-shadow 150ms ease;
}
.kpi-card:hover { transform: translateY(-1px); box-shadow: 0 8px 24px rgba(0,0,0,0.15); }
.kpi-card::before {
  content: ''; position: absolute;
  top: 0; left: 0; right: 0; height: 2px;
}
.kpi-green::before { background: var(--color-success); }
.kpi-amber::before { background: var(--color-warning); }
.kpi-red::before { background: var(--color-error); }
.kpi-blue::before { background: var(--color-blue); }
.kpi-purple::before { background: var(--color-purple); }
.kpi-value {
  font-size: 2rem; font-weight: 700; line-height: 1;
  font-family: var(--font-mono); letter-spacing: -0.03em;
  margin-bottom: var(--space-2);
}
.kpi-green .kpi-value { color: var(--color-success); }
.kpi-amber .kpi-value { color: var(--color-warning); }
.kpi-red .kpi-value { color: var(--color-error); }
.kpi-blue .kpi-value { color: var(--color-blue); }
.kpi-purple .kpi-value { color: var(--color-purple); }
.kpi-label { font-size: var(--text-sm); font-weight: 600; margin-bottom: var(--space-1); }
.kpi-sub { font-size: var(--text-xs); color: var(--color-text-muted); }

/* ============ TIER BLOCKS ============ */
.tier-section { display: flex; flex-direction: column; gap: var(--space-4); }
.tier-block {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
}
.tier-1-block { border-left: 3px solid var(--color-success); }
.tier-2-block { border-left: 3px solid var(--color-warning); }
.tier-3-block { border-left: 3px solid var(--color-error); }
.tier-label-row { display: flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-3); }
.tier-badge {
  font-size: var(--text-xs); font-weight: 700; font-family: var(--font-mono);
  padding: 2px var(--space-2); border-radius: var(--radius-sm);
  letter-spacing: 0.05em;
}
.tier-badge-1 { background: var(--color-success-bg); color: var(--color-success); border: 1px solid var(--color-success-border); }
.tier-badge-2 { background: var(--color-warning-bg); color: var(--color-warning); border: 1px solid var(--color-warning-border); }
.tier-badge-3 { background: var(--color-error-bg); color: var(--color-error); border: 1px solid var(--color-error-border); }
.tier-desc { font-size: var(--text-sm); color: var(--color-text-muted); }
.tier-rules { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-4); }
.rule-chip {
  font-size: var(--text-xs); padding: 2px var(--space-2);
  border-radius: var(--radius-full, 999px);
  font-family: var(--font-mono);
}
.rule-green { background: var(--color-success-bg); color: var(--color-success); }
.rule-amber { background: var(--color-warning-bg); color: var(--color-warning); }
.rule-red { background: var(--color-error-bg); color: var(--color-error); }
.tier-repo-list { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.repo-pill {
  font-size: var(--text-xs); font-family: var(--font-mono);
  padding: var(--space-1) var(--space-3);
  background: var(--color-surface-offset);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full, 999px);
  cursor: pointer;
  transition: all 150ms ease;
  text-decoration: none; color: var(--color-text);
}
.repo-pill:hover { background: var(--color-primary-bg); border-color: var(--color-primary-border); color: var(--color-primary); text-decoration: none; }
.repo-pill.archived { opacity: 0.4; }

/* ============ TABLES ============ */
.table-wrap { overflow-x: auto; border-radius: var(--radius-lg); border: 1px solid var(--color-border); background: var(--color-surface); }
.data-table { width: 100%; }
.data-table th {
  background: var(--color-surface-2);
  padding: var(--space-3) var(--space-4);
  text-align: left;
  font-size: var(--text-xs); font-weight: 600;
  color: var(--color-text-muted);
  letter-spacing: 0.04em; text-transform: uppercase;
  border-bottom: 1px solid var(--color-border);
  white-space: nowrap;
}
.data-table td {
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-xs);
  border-bottom: 1px solid var(--color-border-subtle);
  vertical-align: middle;
}
.data-table tr:last-child td { border-bottom: none; }
.data-table tbody tr { transition: background 120ms ease; }
.data-table tbody tr:hover { background: var(--color-surface-2); cursor: pointer; }
.data-table tbody tr.archived-row { opacity: 0.45; }

/* Table cell helpers */
.cell-mono { font-family: var(--font-mono); }
.cell-name { font-weight: 500; color: var(--color-text); }
.cell-link { color: var(--color-primary); font-family: var(--font-mono); }
.badge {
  display: inline-flex; align-items: center;
  font-size: var(--text-xs); font-family: var(--font-mono); font-weight: 600;
  padding: 2px 7px; border-radius: var(--radius-sm);
  white-space: nowrap;
}
.badge-green { background: var(--color-success-bg); color: var(--color-success); border: 1px solid var(--color-success-border); }
.badge-amber { background: var(--color-warning-bg); color: var(--color-warning); border: 1px solid var(--color-warning-border); }
.badge-red { background: var(--color-error-bg); color: var(--color-error); border: 1px solid var(--color-error-border); }
.badge-blue { background: var(--color-blue-bg); color: var(--color-blue); border: 1px solid var(--color-blue-border); }
.badge-purple { background: var(--color-purple-bg); color: var(--color-purple); border: 1px solid var(--color-purple-border); }
.badge-muted { background: var(--color-surface-offset); color: var(--color-text-muted); border: 1px solid var(--color-border); }
.check-y { color: var(--color-success); }
.check-n { color: var(--color-text-faint); }
.score-bar {
  display: flex; align-items: center; gap: var(--space-2);
}
.score-track { flex: 1; height: 4px; background: var(--color-surface-offset); border-radius: 99px; min-width: 60px; }
.score-fill { height: 100%; border-radius: 99px; }
.score-fill.high { background: var(--color-success); }
.score-fill.medium { background: var(--color-warning); }
.score-fill.low { background: var(--color-error); }
.score-num { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--color-text-muted); min-width: 28px; }

/* ============ FILTER BAR ============ */
.filter-bar {
  display: flex; align-items: center; gap: var(--space-4); flex-wrap: wrap;
  margin-bottom: var(--space-4);
}
.filter-group { display: flex; align-items: center; gap: var(--space-2); }
.filter-btn, .task-filter-btn, .file-filter-btn {
  font-size: var(--text-xs); font-weight: 500;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text-muted);
  transition: all 150ms ease;
}
.filter-btn:hover, .task-filter-btn:hover, .file-filter-btn:hover {
  border-color: var(--color-primary-border);
  color: var(--color-primary);
  background: var(--color-primary-bg);
}
.filter-btn.active, .task-filter-btn.active, .file-filter-btn.active {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background: var(--color-primary-bg);
}
.search-input {
  font: inherit; font-size: var(--text-xs);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text);
  padding: var(--space-1) var(--space-3);
  min-width: 200px;
  transition: border-color 150ms ease;
}
.search-input:focus { outline: none; border-color: var(--color-primary); }

/* ============ DETAIL PANEL ============ */
.detail-panel {
  margin-top: var(--space-6);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  position: relative;
}
.detail-panel.hidden { display: none; }
.detail-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  margin-bottom: var(--space-5); padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}
.detail-title-row { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; }
.detail-name { font-size: var(--text-xl); font-weight: 700; letter-spacing: -0.02em; font-family: var(--font-mono); }
.detail-badges { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.close-btn {
  width: 28px; height: 28px;
  border-radius: var(--radius-md);
  background: var(--color-surface-offset);
  color: var(--color-text-muted);
  display: flex; align-items: center; justify-content: center;
  font-size: var(--text-xs); flex-shrink: 0;
  transition: all 150ms ease;
}
.close-btn:hover { background: var(--color-error-bg); color: var(--color-error); }
.detail-section { font-size: var(--text-sm); font-weight: 600; margin-bottom: var(--space-3); color: var(--color-text-muted); text-transform: uppercase; font-size: var(--text-xs); letter-spacing: 0.06em; }
.detail-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); margin-bottom: var(--space-6); }
.detail-col { display: flex; flex-direction: column; gap: var(--space-2); }
.detail-row { display: flex; align-items: center; gap: var(--space-3); font-size: var(--text-xs); padding: var(--space-2) 0; border-bottom: 1px solid var(--color-border-subtle); }
.detail-row:last-child { border-bottom: none; }
.detail-row-key { color: var(--color-text-muted); min-width: 110px; flex-shrink: 0; }
.detail-row-val { font-family: var(--font-mono); }
.detail-tasks { display: flex; flex-direction: column; gap: var(--space-2); margin-top: var(--space-4); }
.task-card {
  display: flex; align-items: center; gap: var(--space-3);
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
}
.task-id { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--color-text-muted); min-width: 120px; flex-shrink: 0; }
.task-title { font-size: var(--text-xs); font-weight: 500; flex: 1; }
.task-meta { display: flex; gap: var(--space-2); flex-shrink: 0; align-items: center; }
.task-rationale { font-size: var(--text-xs); color: var(--color-text-muted); margin-left: var(--space-3); font-style: italic; }
.detail-links { display: flex; gap: var(--space-3); margin-top: var(--space-6); padding-top: var(--space-4); border-top: 1px solid var(--color-border); flex-wrap: wrap; }
.link-btn {
  font-size: var(--text-xs); font-weight: 500;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-md);
  background: var(--color-primary);
  color: var(--color-bg);
  transition: all 150ms ease;
  cursor: pointer;
}
.link-btn:hover { background: var(--color-primary-dim); text-decoration: none; color: var(--color-bg); }
.link-btn-secondary { background: var(--color-surface-offset); color: var(--color-text); border: 1px solid var(--color-border); }
.link-btn-secondary:hover { border-color: var(--color-primary); color: var(--color-primary); background: var(--color-primary-bg); text-decoration: none; }

/* ============ PIPELINE ============ */
.pipeline-stats { display: flex; gap: var(--space-6); margin-bottom: var(--space-6); }
.pipe-stat { display: flex; flex-direction: column; gap: var(--space-1); }
.pipe-val { font-size: 1.6rem; font-weight: 700; font-family: var(--font-mono); color: var(--color-primary); letter-spacing: -0.03em; }
.pipe-val.pipe-amber { color: var(--color-warning); }
.pipe-val.pipe-blue { color: var(--color-blue); }
.pipe-label { font-size: var(--text-xs); color: var(--color-text-muted); }

/* ============ RISK VIEW ============ */
.risk-legend { display: flex; gap: var(--space-6); margin-bottom: var(--space-6); flex-wrap: wrap; }
.risk-item { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-xs); color: var(--color-text-muted); }
.risk-dot { width: 8px; height: 8px; border-radius: 50%; }
.risk-dot-high { background: var(--color-error); }
.risk-dot-med { background: var(--color-warning); }
.risk-dot-low { background: var(--color-success); }
.risk-factor-breakdown { margin-bottom: var(--space-6); }
.risk-factor-bar { display: flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-2); }
.rfc-label { font-size: var(--text-xs); font-family: var(--font-mono); color: var(--color-text-muted); min-width: 220px; }
.rfc-track { flex: 1; height: 6px; background: var(--color-surface-offset); border-radius: 99px; max-width: 300px; }
.rfc-fill { height: 100%; border-radius: 99px; background: var(--color-error); }
.rfc-count { font-size: var(--text-xs); font-family: var(--font-mono); color: var(--color-text-muted); min-width: 30px; }
.check-cell-y { color: var(--color-error); font-weight: 600; }
.check-cell-n { color: var(--color-text-faint); }

/* ============ FILES VIEW ============ */
.files-intro { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4); margin-bottom: var(--space-6); }
.file-type-card {
  display: flex; align-items: flex-start; gap: var(--space-3);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
}
.file-icon { font-size: 1.2rem; margin-top: 2px; }
.file-type-name { font-size: var(--text-sm); font-weight: 600; font-family: var(--font-mono); margin-bottom: var(--space-1); }
.file-type-desc { font-size: var(--text-xs); color: var(--color-text-muted); line-height: 1.5; }
.file-viewer {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.file-viewer-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  background: var(--color-surface-2);
  border-bottom: 1px solid var(--color-border);
  gap: var(--space-4);
  flex-wrap: wrap;
}
.file-viewer-tabs { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.file-tab {
  font-size: var(--text-xs); font-family: var(--font-mono);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text-muted);
  cursor: pointer;
  transition: all 150ms ease;
  white-space: nowrap;
}
.file-tab:hover { border-color: var(--color-primary-border); color: var(--color-primary); }
.file-tab.active { border-color: var(--color-primary); color: var(--color-primary); background: var(--color-primary-bg); }
.file-viewer-meta { font-size: var(--text-xs); color: var(--color-text-muted); font-family: var(--font-mono); }
.file-content {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  line-height: 1.7;
  padding: var(--space-5) var(--space-6);
  overflow: auto;
  max-height: 600px;
  color: var(--color-text);
  white-space: pre-wrap;
  word-break: break-word;
}

/* ============ PROMOTION TABLE ============ */
.gap-score { font-family: var(--font-mono); font-size: var(--text-xs); }
.gap-high { color: var(--color-error); }
.gap-med { color: var(--color-warning); }
.gap-low { color: var(--color-success); }

/* ============ MODAL ============ */
.modal { position: fixed; inset: 0; z-index: 200; display: flex; align-items: center; justify-content: center; }
.modal.hidden { display: none; }
.modal-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.7); backdrop-filter: blur(4px); }
.modal-box {
  position: relative; z-index: 1;
  width: 90%; max-width: 800px; max-height: 85vh;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  display: flex; flex-direction: column;
  overflow: hidden;
}
.modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border);
  background: var(--color-surface-2);
}
.modal-title { font-family: var(--font-mono); font-size: var(--text-sm); font-weight: 600; }
.modal-content {
  font-family: var(--font-mono);
  font-size: 0.72rem; line-height: 1.7;
  padding: var(--space-5);
  overflow: auto;
  flex: 1;
  color: var(--color-text);
  white-space: pre-wrap;
}

/* ============ COMMIT LIST ============ */
.commit-item {
  font-size: var(--text-xs); font-family: var(--font-mono);
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--color-border-subtle);
  color: var(--color-text-muted);
  line-height: 1.4;
}
.commit-item:last-child { border-bottom: none; }

/* ============ RESPONSIVE ============ */
@media (max-width: 900px) {
  .kpi-strip { grid-template-columns: repeat(3, 1fr); }
  .files-intro { grid-template-columns: repeat(2, 1fr); }
  .detail-grid { grid-template-columns: 1fr; }
  .main-content { padding: var(--space-4); }
  .topbar-inner { gap: var(--space-3); }
  .meta-tag { display: none; }
}
@media (max-width: 600px) {
  .kpi-strip { grid-template-columns: repeat(2, 1fr); }
  .files-intro { grid-template-columns: 1fr; }
  .topnav { display: none; }
}

/* ============ NOTION SYNC VIEW ============ */

/* Status card */
.notion-status-card {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
  margin-bottom: var(--space-2);
}
.notion-status-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.notion-status-label {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
}
.notion-status-val {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text);
}

/* Delta legend */
.comparison-delta-legend {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
  padding: var(--space-4) var(--space-5);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}
.delta-legend-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.delta-legend-desc {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

/* Impact badges */
.impact-badge {
  display: inline-flex;
  align-items: center;
  font-size: var(--text-xs);
  font-family: var(--font-mono);
  font-weight: 700;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  white-space: nowrap;
  letter-spacing: 0.04em;
}
.impact-critical {
  background: rgba(248, 113, 113, 0.18);
  color: #f87171;
  border: 1px solid rgba(248, 113, 113, 0.4);
  box-shadow: 0 0 0 1px rgba(248, 113, 113, 0.15);
}
.impact-high {
  background: rgba(251, 146, 60, 0.15);
  color: #fb923c;
  border: 1px solid rgba(251, 146, 60, 0.35);
}
.impact-stale {
  background: rgba(251, 191, 36, 0.12);
  color: #fbbf24;
  border: 1px solid rgba(251, 191, 36, 0.3);
}
.impact-unguarded {
  background: rgba(167, 139, 250, 0.12);
  color: #a78bfa;
  border: 1px solid rgba(167, 139, 250, 0.3);
}
.impact-clean {
  background: rgba(74, 222, 128, 0.08);
  color: #4ade80;
  border: 1px solid rgba(74, 222, 128, 0.2);
}
.impact-notion-only {
  background: var(--color-surface-offset);
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
}

/* Row highlighting in comparison table */
.notion-row-critical {
  background: rgba(248, 113, 113, 0.04) !important;
  border-left: 3px solid var(--color-error);
}
.notion-row-critical:hover {
  background: rgba(248, 113, 113, 0.09) !important;
}
.notion-row-high {
  background: rgba(251, 146, 60, 0.04) !important;
  border-left: 3px solid #fb923c;
}
.notion-row-high:hover {
  background: rgba(251, 146, 60, 0.09) !important;
}
.notion-row-stale {
  background: rgba(251, 191, 36, 0.04) !important;
  border-left: 3px solid var(--color-warning);
}
.notion-row-stale:hover {
  background: rgba(251, 191, 36, 0.09) !important;
}
.notion-row-unguarded {
  background: rgba(167, 139, 250, 0.04) !important;
  border-left: 3px solid var(--color-purple);
}
.notion-row-unguarded:hover {
  background: rgba(167, 139, 250, 0.09) !important;
}

/* Delta cell */
.notion-delta-cell {
  white-space: nowrap;
}

/* Filter toggle */
.notion-toggle-label {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  user-select: none;
}
.notion-toggle-input {
  accent-color: var(--color-primary);
  width: 14px;
  height: 14px;
  cursor: pointer;
}
.notion-toggle-text {
  font-size: var(--text-xs);
  font-weight: 500;
}

/* Notion filter buttons (reuse filter-btn pattern) */
.notion-filter-btn {
  font-size: var(--text-xs);
  font-weight: 500;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text-muted);
  transition: all 150ms ease;
}
.notion-filter-btn:hover {
  border-color: var(--color-primary-border);
  color: var(--color-primary);
  background: var(--color-primary-bg);
}
.notion-filter-btn.active {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background: var(--color-primary-bg);
}

/* Responsive */
@media (max-width: 900px) {
  .notion-status-card { grid-template-columns: repeat(2, 1fr); }
  .comparison-delta-legend { gap: var(--space-3); }
}
@media (max-width: 600px) {
  .notion-status-card { grid-template-columns: 1fr; }
}
