/* ==========================================
   Mission Control - Apple Liquid Glass UI v8
   ========================================== */

:root {
  --bg-primary: #0a0d14;
  --bg-secondary: #0f1319;
  --bg-card: #141a24;
  --bg-card-hover: #1a2230;
  --bg-sidebar: #242a38;
  --bg-sidebar-header: #242a38;
  
  /* Liquid Glass Variables */
  --glass-bg: rgba(100, 140, 200, 0.08);
  --glass-border: rgba(100, 150, 220, 0.12);
  --glass-border-light: rgba(120, 170, 240, 0.18);
  
  /* Liquid Glass - Light variant (for cards) */
  --liquid-glass-bg: linear-gradient(
    145deg,
    rgba(180, 200, 230, 0.12) 0%,
    rgba(140, 170, 210, 0.08) 50%,
    rgba(120, 150, 200, 0.05) 100%
  );
  --liquid-glass-border: rgba(255, 255, 255, 0.15);
  --liquid-glass-shadow: 0 4px 24px rgba(0, 0, 0, 0.15);
  
  /* Liquid Glass - Dark variant (for sidebar cards) */
  --liquid-glass-dark-bg: linear-gradient(
    145deg,
    rgba(60, 80, 110, 0.5) 0%,
    rgba(50, 70, 100, 0.4) 50%,
    rgba(40, 60, 90, 0.35) 100%
  );
  
  --text-primary: #e8edf5;
  --text-secondary: rgba(200, 215, 240, 0.75);
  --text-muted: rgba(150, 175, 220, 0.5);
  --text-dim: rgba(120, 150, 200, 0.35);
  
  --accent-blue: #4a9eff;
  --accent-cyan: #22d3ee;
  --accent-purple: #a78bfa;
  --accent-green: #34d399;
  --accent-yellow: #fbbf24;
  --accent-orange: #fb923c;
  --accent-red: #f87171;
  
  --sidebar-width: 260px;
  
  /* Font Scale - STRICT: only use these 6 sizes */
  --font-micro: 10px;   /* uppercase labels */
  --font-small: 12px;   /* meta, descriptions */
  --font-base: 14px;    /* body text */
  --font-title: 16px;   /* section titles */
  --font-stat: 24px;    /* stat values */
  --font-hero: 48px;    /* agent name only */
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; overflow: hidden; }

body {
  font-family: 'Inter', -apple-system, sans-serif;
  background: var(--bg-primary);
  color: var(--text-primary);
  font-size: var(--font-base);
  -webkit-font-smoothing: antialiased;
}

/* macOS Title Bar */
.title-bar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 38px;
  background: rgba(10, 13, 20, 0.95);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  -webkit-app-region: drag;
  user-select: none;
}

.title-bar-text {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
  letter-spacing: 0.3px;
  -webkit-app-region: no-drag;
  pointer-events: none;
}

.app {
  display: flex;
  height: calc(100vh - 38px);
  margin-top: 38px;
  background: 
    radial-gradient(ellipse at 15% 5%, rgba(30, 100, 200, 0.15) 0%, transparent 40%),
    radial-gradient(ellipse at 85% 20%, rgba(50, 130, 220, 0.08) 0%, transparent 35%),
    radial-gradient(ellipse at 50% 80%, rgba(20, 80, 180, 0.1) 0%, transparent 45%),
    radial-gradient(ellipse at 80% 90%, rgba(100, 140, 250, 0.06) 0%, transparent 40%),
    linear-gradient(180deg, #0a0d14 0%, #0c1220 50%, #080c15 100%);
  position: relative;
  z-index: 1;
}

/* Global SVG alignment - prevents icons from being offset */
svg { 
  display: inline-block; 
  vertical-align: middle;
  flex-shrink: 0;
}

/* Fix SVG baseline alignment in flex containers */
[class*="-icon"] svg,
[class*="-header"] svg,
.stat-top svg,
.nav-item svg {
  display: block;
}

.icon-xs { width: 12px; height: 12px; }
.icon-sm { width: 14px; height: 14px; }

/* ==========================================
   SIDEBAR - Lighter gray background
   ========================================== */

.sidebar {
  width: var(--sidebar-width);
  height: 100%;
  background: var(--bg-sidebar);
  border-right: 1px solid var(--glass-border);
  display: flex;
  flex-direction: column;
  position: relative;
  flex-shrink: 0;
}

/* Sidebar edge glow */
.sidebar::after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 1px;
  height: 100%;
  background: linear-gradient(
    180deg,
    transparent 0%,
    rgba(74, 158, 255, 0.3) 20%,
    rgba(74, 158, 255, 0.5) 50%,
    rgba(74, 158, 255, 0.3) 80%,
    transparent 100%
  );
  pointer-events: none;
}

/* Subtle noise texture overlay */
.sidebar::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  opacity: 0.02;
  pointer-events: none;
  mix-blend-mode: overlay;
}

/* Mission Control Header Box - glass effect */
.sidebar-header {
  padding: 16px;
  margin: 12px;
  cursor: pointer;
  transition: all 0.2s;
  background: linear-gradient(135deg, rgba(40, 48, 65, 0.9), rgba(30, 38, 52, 0.9));
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  position: relative;
  overflow: hidden;
}

/* Top highlight on header */
.sidebar-header::before {
  content: '';
  position: absolute;
  top: 0;
  left: 20%;
  right: 20%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.12), transparent);
  pointer-events: none;
}

.sidebar-header:hover {
  background: linear-gradient(135deg, rgba(50, 58, 78, 0.95), rgba(38, 46, 62, 0.95));
  border-color: rgba(74, 158, 255, 0.2);
}

.logo {
  display: flex;
  align-items: center;
  gap: 12px;
}

/* Gradient icon with status indicator */
.logo-icon {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  background: conic-gradient(from 180deg, #ff6b6b, #feca57, #48dbfb, #ff9ff3, #54a0ff, #ff6b6b);
  position: relative;
}

.logo-icon::after {
  content: '';
  position: absolute;
  inset: 3px;
  background: rgba(30, 35, 45, 0.5);
  border-radius: 9px;
}

/* Custom avatar image */
/* Fix #6: Avatar rainbow ring visible */
.logo-icon-img {
  position: absolute;
  inset: 3px;
  width: calc(100% - 6px);
  height: calc(100% - 6px);
  object-fit: cover;
  border-radius: 9px;
  z-index: 1;
}

/* Upload overlay */
.logo-icon-upload {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.6);
  border-radius: 12px;
  opacity: 0;
  transition: opacity 0.2s;
  cursor: pointer;
  z-index: 2;
}
.logo-icon:hover .logo-icon-upload {
  opacity: 1;
}
.logo-icon-upload svg {
  width: 18px;
  height: 18px;
  color: white;
}

/* Status dot on the icon */
.logo-icon-status {
  position: absolute;
  bottom: -2px;
  right: -2px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--accent-yellow);
  border: 2px solid var(--bg-sidebar-header);
  z-index: 3;
}

/* Status-based colors */
.logo-icon-status.idle { background: var(--accent-yellow); }
.logo-icon-status.processing { background: var(--accent-green); animation: pulse 1.5s ease-in-out infinite; }
.logo-icon-status.waiting { background: var(--accent-blue); }
.logo-icon-status.offline { background: var(--text-dim); }

@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.7; transform: scale(1.1); }
}

.logo-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.logo-title {
  font-size: var(--font-base);
  font-weight: 600;
}

.logo-status {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--font-base);
  color: var(--text-muted);
}

.logo-status svg {
  width: 12px;
  height: 12px;
}

/* Nav Menu */
.nav-menu {
  flex: 1;
  padding: 0 12px;
  overflow-y: auto;
}

.nav-section-label {
  font-size: var(--font-micro);
  font-weight: 600;
  color: var(--text-dim);
  letter-spacing: 0.1em;
  padding: 16px 12px 10px;
  text-transform: uppercase;
  position: relative;
}

/* Section divider line */
.nav-section-label::before {
  content: '';
  position: absolute;
  top: 6px;
  left: 12px;
  right: 12px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.06), transparent);
}

.nav-section-label:first-child::before {
  display: none;
}

.nav-section-label.documents-label {
  margin-top: 24px;
}

/* Sidebar Recent Documents */
.sidebar-recent-docs {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.sidebar-doc-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.15s;
}
.sidebar-doc-item:hover {
  background: rgba(74, 158, 255, 0.08);
}
.sidebar-doc-icon {
  width: 26px;
  height: 26px;
  background: linear-gradient(135deg, #ef4444, #dc2626);
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 9px;
  font-weight: 700;
  flex-shrink: 0;
}
.sidebar-doc-icon.md {
  background: linear-gradient(135deg, #8b5cf6, #7c3aed);
}
.sidebar-doc-name {
  font-size: var(--font-base);
  color: var(--text-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 10px;
  color: var(--text-secondary);
  text-decoration: none;
  font-size: var(--font-base);
  transition: all 0.15s;
  position: relative;
  margin-bottom: 2px;
}

.nav-item:hover {
  background: rgba(74, 158, 255, 0.08);
  color: var(--text-primary);
}

.nav-item.active {
  background: linear-gradient(90deg, rgba(74, 158, 255, 0.15), rgba(74, 158, 255, 0.05));
  color: var(--accent-blue);
  box-shadow: inset 0 0 20px rgba(74, 158, 255, 0.1);
}

.nav-item.active::before {
  content: '';
  position: absolute;
  left: 0;
  top: 6px;
  bottom: 6px;
  width: 3px;
  background: linear-gradient(180deg, #6bb5ff, #4a9eff, #3d8ce8);
  border-radius: 0 2px 2px 0;
  box-shadow: 0 0 8px rgba(74, 158, 255, 0.5);
}

/* Workshop NOT purple - same as other items */
.nav-item.workshop-link {
  color: var(--text-secondary);
}

.nav-item.workshop-link:hover {
  color: var(--text-primary);
}

.nav-icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  opacity: 0.8;
  display: block;
}

.nav-item.active .nav-icon {
  opacity: 1;
}

/* Sidebar Footer */
.sidebar-footer {
  padding: 16px 20px;
  border-top: 1px solid var(--glass-border);
  min-height: 60px;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  gap: 12px;
}

.logout-btn { display: none !important; }
.logout-btn-hidden {
  width: 36px;
  height: 36px;
  padding: 0;
  background: rgba(248, 113, 113, 0.1);
  border: 1px solid rgba(248, 113, 113, 0.2);
  border-radius: 10px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  flex-shrink: 0;
}

.logout-btn svg {
  width: 18px;
  height: 18px;
  stroke: var(--accent-red);
}

.logout-btn:hover {
  background: rgba(248, 113, 113, 0.2);
  border-color: rgba(248, 113, 113, 0.4);
  transform: translateY(-1px);
}

.mc-brand {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
}

.mc-brand-watermark {
  margin-left: auto;
  width: 56px;
  height: 56px;
  color: var(--accent-blue);
  opacity: 0.15;
  pointer-events: none;
  flex-shrink: 0;
}

.mc-brand-content {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.mc-brand-title {
  display: flex;
  align-items: center;
  gap: 8px;
}

.mc-brand-name {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: 0.3px;
}

.mc-brand-version {
  font-size: 12px;
  color: var(--text-dim);
}

.mc-brand-status {
  display: flex;
  align-items: center;
}

.mc-brand-status .status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--text-dim);
}

.mc-brand-status .status-dot.offline {
  background: var(--accent-red);
  box-shadow: 0 0 6px var(--accent-red);
}

.mc-brand-status .status-dot.online {
  background: var(--accent-green);
  box-shadow: 0 0 6px var(--accent-green);
}

.mc-brand-datetime {
  font-size: 11px;
  color: var(--text-dim);
  font-variant-numeric: tabular-nums;
}

.user-details {
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.user-name {
  font-size: var(--font-base);
  font-weight: 500;
  color: var(--text-primary);
}

.user-plan {
  font-size: var(--font-base);
  color: var(--text-muted);
}

/* Floating Help Button */
.floating-help-btn {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
  cursor: pointer;
  border-radius: 50%;
  transition: all 0.15s;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
  z-index: 9999;
  pointer-events: auto !important;
}

.floating-help-btn:hover {
  background: var(--bg-card-hover);
  border-color: var(--accent-blue);
  color: var(--accent-blue);
  transform: scale(1.05);
}

.floating-help-btn svg {
  width: 22px;
  height: 22px;
}

/* ==========================================
   AGENT POPUP
   ========================================== */

.agent-popup {
  display: none;
  position: fixed;
  top: 80px;
  left: calc(var(--sidebar-width) + 20px);
  z-index: 10000;
  animation: popupFadeIn 0.2s ease;
}

.agent-popup.active { display: block; }

@keyframes popupFadeIn {
  from { opacity: 0; transform: translateY(-10px); }
  to { opacity: 1; transform: translateY(0); }
}

.agent-popup-content {
  width: 360px;
  background: rgba(180, 195, 220, 0.12);
  backdrop-filter: blur(40px);
  -webkit-backdrop-filter: blur(40px);
  border: 1px solid rgba(200, 220, 255, 0.2);
  border-radius: 20px;
  padding: 24px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

.agent-popup-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 24px;
}

.agent-popup-icon {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: conic-gradient(from 180deg, #ff6b6b, #feca57, #48dbfb, #ff9ff3, #54a0ff, #ff6b6b);
  position: relative;
}

/* Status dot indicator on popup icon */
.agent-popup-icon::before {
  content: '';
  position: absolute;
  bottom: -3px;
  right: -3px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--accent-yellow);
  border: 2px solid var(--bg-card);
  z-index: 3;
  transition: background 0.3s ease, box-shadow 0.3s ease;
}

.agent-popup-icon.idle::before { background: var(--accent-yellow); }
.agent-popup-icon.processing::before { background: var(--accent-green); animation: pulse 1.5s ease-in-out infinite; }
.agent-popup-icon.waiting::before { background: var(--accent-blue); }
.agent-popup-icon.offline::before { background: var(--text-dim); }

.agent-popup-icon::after {
  content: '';
  position: absolute;
  inset: 4px;
  background: rgba(40, 50, 70, 0.5);
  border-radius: 10px;
}

.agent-popup-icon-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 14px;
  z-index: 1;
}

.agent-popup-title { display: flex; flex-direction: column; gap: 2px; }
.agent-status-text { font-size: var(--font-title); font-weight: 600; }
.agent-name-text { font-size: var(--font-base); color: var(--text-secondary); }

.agent-popup-body { display: flex; flex-direction: column; gap: 18px; }
.agent-field { display: flex; flex-direction: column; gap: 8px; }
.field-label { font-size: var(--font-base); color: var(--text-secondary); display: flex; align-items: center; gap: 6px; }
.field-value { font-size: var(--font-title); font-weight: 500; }

.bandwidth-row { display: flex; align-items: center; gap: 12px; }
.bandwidth-bar { flex: 1; height: 8px; background: rgba(255, 255, 255, 0.12); border-radius: 4px; overflow: hidden; }
.bandwidth-fill { height: 100%; background: linear-gradient(90deg, var(--accent-blue), var(--accent-purple)); border-radius: 4px; }
.bandwidth-value { font-size: var(--font-base); color: var(--text-secondary); min-width: 35px; }

.agent-stats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  padding: 20px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.agent-stat { display: flex; flex-direction: column; }
.stat-label { font-size: var(--font-micro); font-weight: 600; color: var(--text-muted); letter-spacing: 0.05em; margin-bottom: 6px; }
.stat-value { font-size: var(--font-stat); font-weight: 600; line-height: 1; }
.stat-sub { font-size: var(--font-base); color: var(--text-muted); margin-top: 6px; }

.agent-available { display: flex; align-items: center; gap: 10px; font-size: var(--font-base); }
.available-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--accent-green); }
.available-dot.available { background: var(--accent-green); }
.available-dot.light { background: var(--accent-blue); }
.available-dot.moderate { background: var(--accent-orange); }
.available-dot.heavy { background: var(--accent-red); }
.agent-last-active { font-size: var(--font-base); color: var(--text-muted); }

/* ==========================================
   MAIN CONTENT
   ========================================== */

.main-content {
  flex: 1;
  height: 100%;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  position: relative;
  z-index: 1;
  -webkit-app-region: no-drag;
}

.top-bar {
  padding: 12px 24px;
  border-bottom: 1px solid var(--glass-border);
  text-align: right;
}

.top-bar-title { font-size: var(--font-base); color: var(--text-muted); }

.page { display: none; padding: 24px; flex: 1; overflow-y: hidden; }
.page.active { display: block; }
.page.agents-page.active { display: flex; flex-direction: column; padding: 0 !important; }

.page-header { margin-bottom: 20px; }
.page-header h1 { font-size: var(--font-stat); font-weight: 600; letter-spacing: -0.02em; margin-bottom: 4px; }
.page-subtitle { font-size: var(--font-small); color: var(--text-muted); }

.page-title-section {
  display: flex;
  align-items: center;
  gap: 14px;
}
.page-icon-green {
  width: 48px;
  height: 48px;
  background: linear-gradient(135deg, #22c55e, #4ade80);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  flex-shrink: 0;
}
.page-icon-green svg {
  width: 24px;
  height: 24px;
}
.page-icon-orange {
  width: 48px;
  height: 48px;
  background: linear-gradient(135deg, #f97316, #fb923c);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  flex-shrink: 0;
}
.page-icon-orange svg {
  width: 24px;
  height: 24px;
}

/* ==========================================
   STATS ROW
   ========================================== */

.stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}

.stat-card {
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  padding: 16px 18px;
  position: relative;
}
.stat-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 20%;
  right: 20%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.08), transparent);
}

.stat-card.clickable {
  cursor: pointer;
  transition: all 0.15s;
}

.stat-card.clickable:hover {
  background: var(--bg-card-hover);
  border-color: var(--glass-border-light);
}

.stat-card-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  line-height: 1;
}

.stat-card-header svg {
  display: block;
}

.stat-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}

.stat-dot.green { background: var(--accent-green); }
.stat-dot.purple { background: var(--accent-purple); }
.stat-dot.blue { background: var(--accent-blue); }
.stat-dot.orange { background: var(--accent-orange); }

.stat-icon-small {
  width: 16px;
  height: 16px;
  color: var(--accent-blue);
}

.stat-card-label {
  font-size: var(--font-micro);
  font-weight: 600;
  color: var(--text-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  flex: 1;
  line-height: 1;
}

.stat-card-icon {
  width: 16px;
  height: 16px;
  color: var(--text-muted);
}

.stat-card-icon.arrow { color: var(--text-dim); }

.stat-card-body { display: flex; flex-direction: column; gap: 2px; }
.stat-card-title { font-size: var(--font-title); font-weight: 600; }
.stat-card-number { font-size: var(--font-stat); font-weight: 700; line-height: 1; margin-bottom: 4px; }
.stat-card-desc { font-size: var(--font-small); color: var(--text-muted); }

.stat-card-time {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: var(--font-small);
  color: var(--text-muted);
  margin-top: 6px;
}

.time-interval { color: var(--text-dim); }

.workshop-stat { display: flex; align-items: baseline; gap: 6px; margin-bottom: 4px; }
.workshop-num { font-size: var(--font-stat); font-weight: 700; line-height: 1; }
.workshop-label { font-size: var(--font-small); color: var(--text-secondary); }

.workshop-stat-icon {
  width: 16px;
  height: 16px;
  color: var(--accent-blue);
  margin-right: 4px;
}

/* ==========================================
   DASHBOARD CONTENT
   ========================================== */

.dashboard-content {
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: 20px;
}

.dashboard-main {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* ==========================================
   SECTION CARDS - NO header border
   ========================================== */

.section-card {
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  overflow: hidden;
}

/* NO border-bottom on section header */
.section-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  line-height: 1;
  /* NO border-bottom */
}

.section-header h2 svg,
.section-header .section-icon svg {
  display: block;
}

.section-icon {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.section-icon svg { 
  width: 14px; 
  height: 14px; 
  display: block;
}

.section-icon.blue { background: rgba(74, 158, 255, 0.2); color: var(--accent-blue); }
.section-icon.red { background: rgba(248, 113, 113, 0.2); color: var(--accent-red); }

.section-header h2 {
  font-size: var(--font-base);
  font-weight: 600;
  flex: 1;
}

.section-link {
  font-size: var(--font-base);
  color: var(--accent-blue);
  text-decoration: none;
}

.section-link:hover { text-decoration: underline; }

.section-count {
  font-size: var(--font-base);
  color: var(--text-muted);
}

.section-body { padding: 0; }

/* Activity & Commits - NO row dividers, BOLD titles, with scrollbars */
.activity-list-wrapper,
.commits-list-wrapper {
  position: relative;
  height: 240px;
  min-height: 240px;
}

/* Visible scrollbar track */
.activity-list-wrapper::after,
.commits-list-wrapper::after {
  content: '';
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 6px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 3px;
  pointer-events: none;
}

.activity-list,
.commits-list {
  display: flex;
  flex-direction: column;
  height: 240px;
  overflow-y: auto;
  padding-right: 10px;
}

.activity-list::-webkit-scrollbar,
.commits-list::-webkit-scrollbar {
  width: 6px;
}

.activity-list::-webkit-scrollbar-track,
.commits-list::-webkit-scrollbar-track {
  background: transparent;
  border-radius: 3px;
}

.activity-list::-webkit-scrollbar-thumb,
.commits-list::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.35);
  border-radius: 3px;
}

.activity-list::-webkit-scrollbar-thumb:hover,
.commits-list::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.5);
}

.activity-item,
.commit-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  transition: background 0.1s;
  cursor: pointer;
}

.activity-item:hover,
.commit-item:hover {
  background: rgba(74, 158, 255, 0.06);
}

.activity-icon,
.commit-icon {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.activity-icon svg,
.commit-icon svg { 
  width: 14px; 
  height: 14px; 
  display: block;
}

.activity-icon.orange { background: rgba(251, 146, 60, 0.2); color: var(--accent-orange); }
.activity-icon.green { background: rgba(52, 211, 153, 0.2); color: var(--accent-green); }
.commit-icon { background: rgba(248, 113, 113, 0.2); color: var(--accent-red); }

.activity-content,
.commit-content {
  flex: 1;
  min-width: 0;
}

/* BOLD titles */
.activity-title,
.commit-message {
  font-size: var(--font-base);
  font-weight: 600;
  margin-bottom: 2px;
  color: var(--text-primary);
}

.activity-desc,
.commit-meta {
  font-size: 13px;
  color: var(--text-muted);
  font-weight: 400;
}

.activity-time,
.commit-time {
  font-size: var(--font-base);
  color: var(--text-dim);
  flex-shrink: 0;
  margin-left: 12px;
}

/* ==========================================
   RIGHT SIDEBAR
   ========================================== */

.dashboard-sidebar {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.sidebar-card {
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  overflow: hidden;
  position: relative;
}
.sidebar-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 15%;
  right: 15%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
}

.sidebar-card-header {
  padding: 12px 16px;
  border-bottom: 1px solid var(--glass-border);
}

.sidebar-card-label {
  font-size: var(--font-small);
  font-weight: 600;
  color: var(--text-muted);
  letter-spacing: 0.05em;
}

.sidebar-card-body {
  padding: 14px 16px;
}

.sidebar-card-body.centered {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 24px 16px;
}

.empty-icon {
  width: 32px;
  height: 32px;
  color: var(--text-dim);
}

.bandwidth-status {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: var(--font-base);
  color: var(--text-secondary);
}

.muted-text {
  font-size: var(--font-base);
  color: var(--text-dim);
}

/* Dashboard Recent Docs */
.dashboard-docs-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.dashboard-doc-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.15s;
}
.dashboard-doc-item:hover {
  background: rgba(74, 158, 255, 0.08);
}
.dashboard-doc-icon {
  width: 28px;
  height: 28px;
  background: linear-gradient(135deg, #ef4444, #dc2626);
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 9px;
  font-weight: 700;
  flex-shrink: 0;
}
.dashboard-doc-icon.md {
  background: linear-gradient(135deg, #8b5cf6, #7c3aed);
}
.dashboard-doc-info {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.dashboard-doc-name {
  font-size: var(--font-base);
  color: var(--text-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dashboard-doc-date {
  font-size: 12px;
  color: var(--text-dim);
}

/* Quick Links */
.quick-links { padding: 8px; }

.quick-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 8px;
  color: var(--text-secondary);
  text-decoration: none;
  font-size: var(--font-base);
  transition: all 0.15s;
  line-height: 1;
}

.quick-link:hover {
  background: rgba(74, 158, 255, 0.08);
  color: var(--text-primary);
}

.quick-link-icon {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.quick-link-icon svg { 
  width: 14px; 
  height: 14px; 
  display: block;
}

.quick-link-icon.purple { background: rgba(167, 139, 250, 0.2); color: var(--accent-purple); }
.quick-link-icon.blue { background: rgba(74, 158, 255, 0.2); color: var(--accent-blue); }
.quick-link-icon.green { background: rgba(52, 211, 153, 0.2); color: var(--accent-green); }

/* ==========================================
   WORKSHOP PAGE - KANBAN VIEW
   ========================================== */

/* Workshop Header */
.workshop-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 20px;
  flex-wrap: wrap;
  gap: 16px;
}

.workshop-title-section {
  display: flex;
  align-items: center;
  gap: 14px;
}

.workshop-icon-purple {
  width: 48px;
  height: 48px;
  background: linear-gradient(135deg, #a78bfa, #c4b5fd);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  flex-shrink: 0;
}

.workshop-icon-purple svg { 
  width: 24px; 
  height: 24px; 
  display: block;
}

.workshop-title {
  font-size: var(--font-stat);
  font-weight: 600;
  margin-bottom: 2px;
}

.workshop-subtitle {
  font-size: var(--font-small);
  color: var(--text-muted);
}

/* Workshop Toolbar - all elements right-aligned */
.workshop-toolbar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  width: 100%;
}

.toolbar-spacer {
  flex: 1;
}

/* Search bar - fixed width */
.workshop-search-box {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 18px;
  background: var(--bg-card);
  border: 1px solid var(--glass-border-light);
  border-radius: 10px;
  width: 200px;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.workshop-search-box:focus-within {
  border-color: var(--accent-blue);
  box-shadow: 0 0 0 3px rgba(74, 158, 255, 0.15);
}
.workshop-search-box svg {
  width: 18px;
  height: 18px;
  color: var(--text-secondary);
  flex-shrink: 0;
  display: block;
}

.workshop-search-box input {
  background: none;
  border: none;
  color: var(--text-primary);
  font-size: var(--font-base);
  width: 100%;
  outline: none;
}

.workshop-search-box input::placeholder { color: var(--text-secondary); }

/* No Activity Today - darker */
.workshop-status-pill {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  background: #1a1f28;
  border: none;
  border-radius: 10px;
  font-size: var(--font-base);
  color: var(--text-secondary);
  white-space: nowrap;
  height: 44px;
  line-height: 1;
}

.workshop-status-pill svg {
  width: 14px;
  height: 14px;
  color: var(--text-muted);
  display: block;
}

.workshop-status-pill.has-activity {
  background: rgba(52, 211, 153, 0.1);
  color: var(--accent-green);
}

.workshop-status-pill.has-activity svg {
  color: var(--accent-green);
}

/* NEXT timer */
.workshop-next-pill {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 4px 16px;
  background: #2d3545;
  border: none;
  border-radius: 10px;
  min-width: 70px;
  height: 44px;
}

.next-label {
  font-size: var(--font-base);
  font-weight: 600;
  color: var(--text-dim);
  letter-spacing: 0.05em;
  line-height: 1;
}

.next-time {
  font-size: var(--font-title);
  font-weight: 600;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
  line-height: 1.2;
}

/* Add Task button - matches Deploy Strategy button */
.add-task-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  background: linear-gradient(135deg, #4a9eff 0%, #3182ce 100%);
  border: none;
  border-radius: 12px;
  color: white;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
  box-shadow: 0 4px 16px rgba(74, 158, 255, 0.3);
}

.add-task-btn:hover {
  background: linear-gradient(135deg, #5aa8ff 0%, #4192de 100%);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(74, 158, 255, 0.4);
}

.add-task-btn svg {
  width: 18px;
  height: 18px;
}

/* Workshop Stats Row - Colored icons and numbers */
.workshop-stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}

.workshop-stat-card.vertical {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 10px;
  padding: 20px;
  background: #1e2530;
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  min-height: 100px;
}

.workshop-stat-card .stat-top {
  display: flex;
  align-items: center;
  gap: 8px;
  line-height: 1;
}

.workshop-stat-card .stat-icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  position: relative;
  top: -3px;
}

.workshop-stat-card .stat-icon svg {
  display: block;
  width: 16px;
  height: 16px;
}

.workshop-stat-card .stat-label {
  font-size: var(--font-base);
  color: var(--text-muted);
  line-height: 1;
}

/* Colored icons */
.workshop-stat-card .stat-icon.queued-icon { color: var(--accent-blue); }
.workshop-stat-card .stat-icon.active-icon { color: var(--accent-orange); }
.workshop-stat-card .stat-icon.completed-icon { color: var(--accent-green); }
.workshop-stat-card .stat-icon.bandwidth-icon { color: var(--accent-purple); }

.workshop-stat-card .stat-number {
  font-size: var(--font-stat);
  font-weight: 700;
  line-height: 1;
}

/* Colored numbers */
.workshop-stat-card .stat-number.blue { color: var(--accent-blue); }
.workshop-stat-card .stat-number.orange { color: var(--accent-orange); }
.workshop-stat-card .stat-number.green { color: var(--accent-green); }
.workshop-stat-card .stat-number.purple { color: var(--accent-purple); }

/* View Tabs */
.workshop-view-tabs {
  display: inline-flex;
  gap: 4px;
  padding: 4px;
  background: #1e2530;
  border-radius: 10px;
  margin-bottom: 20px;
}

.view-tab {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 16px;
  background: none;
  border: none;
  border-radius: 8px;
  color: var(--text-muted);
  font-size: var(--font-small);
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
}
.view-tab svg {
  width: 14px;
  height: 14px;
}

.view-tab.active {
  background: var(--accent-blue);
  color: white;
}

.view-tab:not(.active):hover {
  color: var(--text-primary);
}

/* Kanban Board - 3 columns with independent scrolling */
.kanban-board {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  flex: 1;
  min-height: 0;
}

.kanban-board.three-columns {
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.kanban-column {
  display: flex;
  flex-direction: column;
  min-width: 0;
  height: 720px;
  max-height: 720px;
}

/* Stacked column (Active + Paused) */
.kanban-column.stacked {
  gap: 16px;
}

.kanban-section {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  max-height: calc(50% - 8px);
}

.kanban-column-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
  padding: 0 4px;
  flex-shrink: 0;
  line-height: 1;
}

.kanban-column-header .column-icon {
  width: 16px;
  height: 16px;
  color: var(--text-muted);
  display: block;
}

.kanban-column-header .column-icon.completed-check {
  color: var(--accent-green);
}

.kanban-column-header .column-title {
  font-size: var(--font-base);
  font-weight: 600;
  color: var(--text-secondary);
}

/* Oval-ish count badges */
.kanban-column-header .column-count {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  height: 20px;
  padding: 0 10px;
  border-radius: 10px;
  font-size: var(--font-base);
  font-weight: 600;
}

.kanban-column-header .column-count.blue {
  background: var(--accent-blue);
  color: white;
}

.kanban-column-header .column-count.green {
  background: var(--accent-green);
  color: white;
}

.kanban-column-header .column-count.orange {
  background: var(--accent-orange);
  color: white;
}

.kanban-column-header .column-count.gray {
  background: rgba(150, 160, 180, 0.5);
  color: white;
}

/* Scrollable Tasks Container wrapper - shows scrollbar track */
.kanban-tasks-wrapper {
  flex: 1;
  position: relative;
  min-height: 0;
  display: flex;
}

/* Visible scrollbar track (always shown) */
.kanban-tasks-wrapper::after {
  content: '';
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 6px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 3px;
  pointer-events: none;
}

/* Scrollable Tasks Container */
.kanban-tasks-scroll {
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 10px;
  padding-bottom: 8px;
  min-height: 0;
  position: relative;
}

/* Custom scrollbar styling */
.kanban-tasks-scroll::-webkit-scrollbar {
  width: 6px;
}

.kanban-tasks-scroll::-webkit-scrollbar-track {
  background: rgba(255,255,255,0.02);
  border-radius: 3px;
}

.kanban-tasks-scroll::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.15);
  border-radius: 3px;
}

.kanban-tasks-scroll::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.25);
}

/* Firefox scrollbar */
.kanban-tasks-scroll {
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.15) rgba(255,255,255,0.02);
}

/* Empty State - dashed outline, no fill */
.kanban-empty-state {
  text-align: center;
  padding: 24px 16px;
  background: transparent;
  border: 1px dashed var(--glass-border-light);
  border-radius: 12px;
}

.kanban-empty-state .empty-title {
  font-size: var(--font-base);
  color: var(--text-muted);
  margin-bottom: 6px;
}

.kanban-empty-state .empty-subtitle {
  font-size: var(--font-base);
  color: var(--text-dim);
}

/* Kanban Task Card */
.kanban-task {
  background: #1e2530;
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  padding: 16px;
  position: relative;
  transition: all 0.15s;
  flex-shrink: 0;
  cursor: grab;
}
.kanban-task::before {
  content: '';
  position: absolute;
  top: 0;
  left: 15%;
  right: 15%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.06), transparent);
  border-radius: 1px;
}

.kanban-task:hover {
  border-color: var(--glass-border-light);
}

.kanban-task {
  cursor: grab;
  -webkit-app-region: no-drag;
  -webkit-user-drag: element;
}

.kanban-task.dragging {
  opacity: 0.4;
  cursor: grabbing;
  transform: scale(0.98);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

/* Ghost element for custom drag */
.drag-ghost {
  background: var(--card-bg);
  border: 1px solid var(--accent-blue);
  border-radius: 12px;
  padding: 16px;
}

.kanban-tasks-scroll {
  min-height: 100px;
  transition: background 0.15s ease, border-color 0.15s ease;
  -webkit-app-region: no-drag;
}

.kanban-tasks-scroll.drag-over {
  background: rgba(74, 158, 255, 0.12);
  border-radius: 8px;
  outline: 2px dashed rgba(74, 158, 255, 0.4);
  outline-offset: -2px;
}

/* Ensure child elements don't block drop events */
.kanban-tasks-scroll.drag-over * {
  pointer-events: none;
}

.kanban-tasks-scroll.drag-over .kanban-task {
  pointer-events: none;
}

/* Assigned agent avatar on task card */
.task-assigned-agent {
  position: absolute;
  top: 12px;
  left: 12px;
  width: 24px;
  height: 24px;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid var(--glass-border);
}
.task-assigned-agent img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.kanban-task .task-delete {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  color: var(--accent-red);
  cursor: pointer;
  opacity: 0.3;
  transition: opacity 0.15s;
}

.kanban-task .task-delete:hover { opacity: 1; }
.kanban-task .task-delete svg { width: 14px; height: 14px; }

.kanban-task .task-title {
  font-size: var(--font-base);
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 6px;
  padding-left: 32px;
  padding-right: 24px;
}

.kanban-task.completed .task-title {
  text-decoration: line-through;
  color: var(--text-secondary);
}

.kanban-task.completed .task-desc {
  text-decoration: line-through;
  color: var(--text-dim);
}

.kanban-task.completed .task-tags .task-tag,
.kanban-task.completed .task-tags .task-momentum {
  text-decoration: line-through;
}

.kanban-task .task-desc {
  font-size: var(--font-base);
  color: var(--text-muted);
  line-height: 1.5;
  margin-bottom: 12px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.kanban-task .task-tags {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.kanban-task .task-tag {
  font-size: var(--font-base);
  font-weight: 500;
  padding: 4px 10px;
  border-radius: 6px;
}

.kanban-task .task-tag.task-type {
  background: rgba(251, 146, 60, 0.2);
  color: var(--accent-orange);
}

.kanban-task .task-tag.cognitive-load {
  background: rgba(120, 150, 200, 0.15);
  color: var(--text-secondary);
}

.kanban-task .task-momentum {
  font-size: var(--font-base);
  color: var(--accent-blue);
  font-weight: 500;
}

/* Shimmer loading animation for assessing state */
.kanban-task .task-tag.shimmer,
.kanban-task .task-momentum.shimmer {
  background: linear-gradient(
    90deg,
    rgba(100, 140, 200, 0.1) 25%,
    rgba(100, 140, 200, 0.25) 50%,
    rgba(100, 140, 200, 0.1) 75%
  );
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  color: transparent;
  border-radius: 6px;
  min-width: 70px;
  height: 22px;
}

.kanban-task .task-momentum.shimmer {
  min-width: 45px;
}

@keyframes shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.kanban-task.assessing {
  border-color: rgba(74, 158, 255, 0.3);
}

.kanban-task .task-spinner {
  display: inline-flex;
  align-items: center;
  margin-left: 6px;
}

.kanban-task .task-spinner svg {
  width: 14px;
  height: 14px;
  color: var(--text-muted);
  animation: spin 1.5s linear infinite;
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.kanban-task .task-footer {
  display: flex;
  justify-content: flex-end;
}

.kanban-task .task-action {
  font-size: var(--font-base);
  color: var(--accent-blue);
  background: none;
  border: none;
  cursor: pointer;
  font-weight: 500;
  opacity: 0.3;
  transition: opacity 0.15s;
  display: flex;
  align-items: center;
  justify-content: center;
}

.kanban-task .task-action:hover {
  opacity: 1;
  text-decoration: none;
}

.kanban-task .task-action svg {
  width: 14px;
  height: 14px;
}

.kanban-task .task-completed-date {
  font-size: var(--font-base);
  color: var(--text-dim);
  margin-top: 4px;
}

/* ==========================================
   TASK STATUS FEED VIEW (formerly Live Feed)
   ========================================== */

.live-feed-view {
  flex: 1;
  min-height: 0;
}

.live-feed-container {
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  height: 600px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.live-feed-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  line-height: 1;
  /* Match section-header styling from dashboard */
}

.live-feed-header .feed-icon {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(74, 158, 255, 0.2);
  color: var(--accent-blue);
}

.live-feed-header .feed-icon svg {
  width: 14px;
  height: 14px;
  display: block;
}

.live-feed-header h3 {
  font-size: var(--font-title);
  font-weight: 600;
  flex: 1;
}

.feed-count {
  font-size: var(--font-base);
  color: var(--text-muted);
}

/* Scrollable content wrapper */
.live-feed-content-wrapper {
  flex: 1;
  position: relative;
  min-height: 0;
}

/* Visible scrollbar track */
.live-feed-content-wrapper::after {
  content: '';
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 6px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 3px;
  pointer-events: none;
}

.live-feed-content {
  height: 100%;
  overflow-y: auto;
  padding: 0 10px 0 0;
}

.live-feed-content::-webkit-scrollbar {
  width: 6px;
}

.live-feed-content::-webkit-scrollbar-track {
  background: transparent;
  border-radius: 3px;
}

.live-feed-content::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.35);
  border-radius: 3px;
}

.live-feed-content::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.5);
}

.live-feed-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
  transition: background 0.1s;
  cursor: pointer;
}

.live-feed-item:hover {
  background: rgba(74, 158, 255, 0.06);
}

.feed-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

.feed-dot.green { background: var(--accent-green); }
.feed-dot.yellow { background: var(--accent-yellow); }
.feed-dot.orange { background: var(--accent-orange); }
.feed-dot.blue { background: var(--accent-blue); }

.feed-content {
  flex: 1;
  min-width: 0;
}

.feed-message {
  font-size: var(--font-base);
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 2px;
}

.feed-meta {
  font-size: var(--font-base);
  color: var(--text-muted);
}

.feed-task {
  color: var(--accent-blue);
}

.feed-time {
  color: var(--text-dim);
  margin-left: 8px;
}

/* ==========================================
   TASK DETAIL MODAL
   ========================================== */

.task-modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(5, 15, 30, 0.75);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 10000;
  align-items: center;
  justify-content: center;
  pointer-events: auto;
  cursor: pointer;
}

.task-modal-overlay.active {
  display: flex;
}

/* Ensure modal content is clickable and doesn't close on click */
.task-modal-overlay .task-modal {
  pointer-events: auto;
  cursor: default;
}

.task-modal {
  width: 580px;
  max-width: 90vw;
  max-height: 85vh;
  background: linear-gradient(
    165deg,
    rgba(30, 50, 80, 0.95) 0%,
    rgba(20, 35, 60, 0.92) 50%,
    rgba(15, 25, 45, 0.95) 100%
  );
  backdrop-filter: blur(40px) saturate(180%);
  -webkit-backdrop-filter: blur(40px) saturate(180%);
  border: 1px solid rgba(100, 150, 220, 0.2);
  border-radius: 20px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 
    0 25px 80px rgba(0, 0, 0, 0.5),
    0 0 0 1px rgba(255, 255, 255, 0.05),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
  position: relative;
}
.task-modal::before {
  content: '';
  position: absolute;
  top: 0;
  left: 10%;
  right: 10%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(100, 180, 255, 0.4), transparent);
  border-radius: 1px;
}

.task-modal-header {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 24px 24px 20px;
  position: relative;
}

.modal-status-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.modal-status-icon.queued { background: rgba(74, 158, 255, 0.2); }
.modal-status-icon.active { background: rgba(251, 146, 60, 0.2); }
.modal-status-icon.paused { background: rgba(150, 160, 180, 0.3); }
.modal-status-icon.completed { background: var(--accent-green); }

.modal-status-icon svg {
  width: 22px;
  height: 22px;
  display: block;
}

.modal-status-icon.queued svg { color: var(--accent-blue); }
.modal-status-icon.active svg { color: var(--accent-orange); }
.modal-status-icon.paused svg { color: rgba(150, 160, 180, 0.8); }
.modal-status-icon.completed svg { color: white; }

.modal-title-section {
  flex: 1;
  min-width: 0;
}

.modal-title {
  font-size: var(--font-stat);
  font-weight: 600;
  margin-bottom: 4px;
  color: var(--text-primary);
}

.modal-status {
  font-size: var(--font-base);
  color: var(--text-muted);
}

.modal-edit-toggle {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  color: var(--text-secondary);
  cursor: pointer;
  border-radius: 6px;
  transition: all 0.15s;
}

.modal-edit-toggle:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--accent-blue);
}

.modal-edit-toggle svg {
  width: 20px;
  height: 20px;
}

.task-modal-body {
  flex: 1;
  overflow-y: auto;
  padding: 0 24px 24px;
}

.modal-section {
  margin-bottom: 20px;
}

.modal-section h3 {
  font-size: var(--font-base);
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
  line-height: 1;
}

.modal-section h3 svg {
  width: 16px;
  height: 16px;
  display: block;
}

.modal-section p {
  font-size: var(--font-base);
  color: var(--text-muted);
  line-height: 1.6;
}

.modal-tags-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}

.modal-tags-row .task-tag {
  font-size: var(--font-base);
  font-weight: 500;
  padding: 4px 10px;
  border-radius: 6px;
}

.modal-tags-row .task-tag.task-type {
  background: rgba(251, 146, 60, 0.2);
  color: var(--accent-orange);
}

.modal-tags-row .task-tag.cognitive-load {
  background: rgba(120, 150, 200, 0.15);
  color: var(--text-secondary);
}

.modal-tags-row .task-tag.assigned-agent {
  background: rgba(167, 139, 250, 0.2);
  color: var(--accent-purple);
}

.modal-tags-row .task-momentum {
  font-size: var(--font-base);
  color: var(--accent-blue);
  font-weight: 500;
}

.modal-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.modal-tags .tag-pill {
  font-size: var(--font-base);
  padding: 6px 14px;
  border-radius: 20px;
  background: rgba(100, 140, 200, 0.15);
  color: var(--text-secondary);
  border: 1px solid var(--glass-border);
}

.modal-dates {
  display: flex;
  gap: 40px;
  margin-bottom: 20px;
}

.modal-date {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.modal-date .date-label {
  font-size: var(--font-base);
  color: var(--text-dim);
}

.modal-date .date-value {
  font-size: var(--font-base);
  font-weight: 500;
  color: var(--text-primary);
}

.modal-progress {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.modal-progress-bar {
  height: 8px;
  background: rgba(167, 139, 250, 0.2);
  border-radius: 4px;
  overflow: hidden;
}

.modal-progress-fill {
  height: 100%;
  background: var(--accent-purple);
  border-radius: 4px;
  transition: width 0.3s;
}

.modal-progress-text {
  font-size: var(--font-base);
  color: var(--text-muted);
}

.modal-activity-log-wrapper {
  position: relative;
  max-height: 180px;
}

/* Visible scrollbar track */
.modal-activity-log-wrapper::after {
  content: '';
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 6px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 3px;
  pointer-events: none;
}

.modal-activity-log {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-height: 180px;
  overflow-y: auto;
  padding-right: 10px;
}

.modal-activity-log::-webkit-scrollbar {
  width: 6px;
}

.modal-activity-log::-webkit-scrollbar-track {
  background: transparent;
  border-radius: 3px;
}

.modal-activity-log::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.3);
  border-radius: 3px;
}

.activity-log-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.activity-log-item .log-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-top: 6px;
  flex-shrink: 0;
}

.activity-log-item .log-dot.green { background: var(--accent-green); }
.activity-log-item .log-dot.yellow { background: var(--accent-yellow); }
.activity-log-item .log-dot.orange { background: var(--accent-orange); }
.activity-log-item .log-dot.blue { background: var(--accent-blue); }
.activity-log-item .log-dot.gray { background: rgba(150, 160, 180, 0.6); }

.activity-log-item .log-content {
  flex: 1;
}

.activity-log-item .log-message {
  font-size: var(--font-base);
  color: var(--text-primary);
  margin-bottom: 2px;
}

.activity-log-item .log-time {
  font-size: var(--font-base);
  color: var(--text-dim);
}

.task-modal-footer {
  padding: 16px 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid var(--glass-border);
}

.modal-delete-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 16px;
  background: rgba(248, 113, 113, 0.15);
  border: 1px solid rgba(248, 113, 113, 0.3);
  border-radius: 8px;
  color: var(--accent-red);
  font-size: var(--font-base);
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
}

.modal-delete-btn svg {
  width: 16px;
  height: 16px;
}

.modal-delete-btn:hover {
  background: rgba(248, 113, 113, 0.25);
  border-color: rgba(248, 113, 113, 0.5);
}

.modal-close-btn {
  padding: 10px 24px;
  background: var(--bg-secondary);
  border: 1px solid var(--glass-border);
  border-radius: 8px;
  color: var(--text-primary);
  font-size: var(--font-base);
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
}

.modal-close-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.15);
}

/* Editable modal fields */
.modal-edit-input,
.modal-edit-textarea,
.modal-edit-select {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid var(--glass-border);
  border-radius: 8px;
  color: var(--text-primary);
  font-family: inherit;
  font-size: inherit;
  padding: 10px 14px;
  width: 100%;
  outline: none;
  transition: border-color 0.15s;
}

.modal-edit-input:focus,
.modal-edit-textarea:focus,
.modal-edit-select:focus {
  border-color: var(--accent-blue);
}

.modal-edit-title {
  font-size: var(--font-stat);
  font-weight: 600;
  padding: 8px 12px;
  width: calc(100% - 50px);
}

.modal-edit-textarea {
  min-height: 80px;
  resize: vertical;
  line-height: 1.5;
}

.modal-edit-select {
  padding: 6px 12px;
  width: auto;
  cursor: pointer;
  font-size: var(--font-base);
}

.modal-edit-tags {
  font-size: var(--font-base);
}

/* Assessment Preview */
.assessment-preview-tags {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

.assessment-preview-tags .task-tag {
  font-size: var(--font-base);
  font-weight: 500;
  padding: 4px 10px;
  border-radius: 6px;
}

.assessment-preview-tags .task-tag.task-type {
  background: rgba(251, 146, 60, 0.2);
  color: var(--accent-orange);
}

.assessment-preview-tags .task-tag.cognitive-load {
  background: rgba(120, 150, 200, 0.15);
  color: var(--text-secondary);
}

.assessment-preview-tags .task-momentum {
  font-size: var(--font-base);
  color: var(--accent-blue);
  font-weight: 500;
}

.assessment-preview-domain {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.assessment-preview-domain .tag-pill {
  font-size: var(--font-base);
  padding: 4px 10px;
  border-radius: 12px;
  background: rgba(100, 140, 200, 0.15);
  color: var(--text-secondary);
  border: 1px solid var(--glass-border);
}

/* Help Modal */
.help-modal {
  width: 580px;
  max-height: 80vh;
}

.help-content {
  max-height: 60vh;
  overflow-y: auto;
}

.help-section {
  margin-bottom: 24px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--glass-border);
}

.help-section:last-child {
  border-bottom: none;
  margin-bottom: 0;
}

.help-section h3 {
  font-size: var(--font-base);
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 10px;
}

.help-section p {
  font-size: var(--font-base);
  color: var(--text-secondary);
  line-height: 1.6;
  margin-bottom: 12px;
}

.help-section ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.help-section li {
  font-size: var(--font-base);
  color: var(--text-secondary);
  line-height: 1.6;
  padding: 6px 0;
  padding-left: 16px;
  position: relative;
}

.help-section li::before {
  content: '•';
  position: absolute;
  left: 0;
  color: var(--text-dim);
}

.help-section li strong {
  color: var(--text-primary);
}

.help-section li em {
  color: var(--text-muted);
  font-style: italic;
}

.help-note {
  font-size: var(--font-base) !important;
  color: var(--text-muted) !important;
  background: rgba(74, 158, 255, 0.08);
  padding: 10px 14px;
  border-radius: 8px;
  margin-top: 12px;
}

/* View All Completed Button */
.view-all-completed {
  width: 100%;
  padding: 12px 16px;
  background: transparent;
  border: 1px dashed var(--glass-border-light);
  border-radius: 10px;
  color: var(--accent-blue);
  font-size: var(--font-base);
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
  margin-top: 8px;
}

.view-all-completed:hover {
  background: rgba(74, 158, 255, 0.08);
  border-color: var(--accent-blue);
}

/* Archive Modal */
.archive-modal {
  width: 640px;
  max-height: 85vh;
}

.archive-toolbar {
  display: flex;
  gap: 10px;
  margin-bottom: 16px;
}

.archive-search {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 18px;
  background: var(--bg-card);
  border: 1px solid var(--glass-border-light);
  border-radius: 10px;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.archive-search:focus-within {
  border-color: var(--accent-blue);
  box-shadow: 0 0 0 3px rgba(74, 158, 255, 0.15);
}
.archive-search svg {
  width: 18px;
  height: 18px;
  color: var(--text-secondary);
  flex-shrink: 0;
}

.archive-search input {
  flex: 1;
  background: none;
  border: none;
  color: var(--text-primary);
  font-size: var(--font-base);
  outline: none;
}

.archive-search input::placeholder {
  color: var(--text-secondary);
}

.archive-filter-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--glass-border);
  border-radius: 8px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.15s;
  flex-shrink: 0;
}

.archive-filter-btn:hover {
  background: rgba(74, 158, 255, 0.1);
  border-color: var(--accent-blue);
  color: var(--accent-blue);
}

.archive-filter-btn.active {
  background: rgba(74, 158, 255, 0.15);
  border-color: var(--accent-blue);
  color: var(--accent-blue);
}

.archive-filter-btn svg {
  width: 18px;
  height: 18px;
}

.archive-filters {
  padding: 16px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  margin-bottom: 16px;
}

.filter-group {
  margin-bottom: 14px;
}

.filter-group:last-child {
  margin-bottom: 0;
}

.filter-group label {
  display: block;
  font-size: var(--font-base);
  font-weight: 600;
  color: var(--text-muted);
  letter-spacing: 0.05em;
  margin-bottom: 8px;
}

.filter-options {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.filter-chip {
  padding: 6px 12px;
  background: transparent;
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  color: var(--text-secondary);
  font-size: var(--font-base);
  cursor: pointer;
  transition: all 0.15s;
}

.filter-chip:hover {
  border-color: var(--glass-border-light);
  color: var(--text-primary);
}

.filter-chip.active {
  background: var(--accent-blue);
  border-color: var(--accent-blue);
  color: white;
}

.filter-reset-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-top: 12px;
  padding: 8px 16px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--glass-border);
  border-radius: 6px;
  color: var(--text-secondary);
  font-size: var(--font-base);
  cursor: pointer;
  transition: all 0.15s;
}

.filter-reset-btn svg {
  width: 14px;
  height: 14px;
}

.filter-reset-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-primary);
}

.archive-tasks-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  height: 45vh;
  min-height: 45vh;
  overflow-y: auto;
  padding-right: 8px;
}

.archive-task {
  padding: 14px 16px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.15s;
}

.archive-task:hover {
  background: rgba(74, 158, 255, 0.06);
  border-color: var(--glass-border-light);
}

.archive-task-title {
  font-size: var(--font-base);
  font-weight: 600;
  color: var(--text-secondary);
  text-decoration: line-through;
  margin-bottom: 8px;
}

.archive-task-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.archive-task-meta .task-tag {
  font-size: var(--font-base);
  padding: 3px 8px;
  border-radius: 4px;
}

.archive-task-meta .task-tag.task-type {
  background: rgba(251, 146, 60, 0.2);
  color: var(--accent-orange);
}

.archive-task-meta .task-tag.cognitive-load {
  background: rgba(120, 150, 200, 0.15);
  color: var(--text-secondary);
}

.archive-task-meta .task-momentum {
  font-size: var(--font-base);
  color: var(--accent-blue);
  font-weight: 500;
}

.archive-task-date {
  font-size: var(--font-base);
  color: var(--text-dim);
  margin-left: auto;
}

.archive-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  text-align: center;
  padding: 40px 20px;
  color: var(--text-muted);
  font-size: var(--font-base);
}

/* API Usage */
.usage-section { margin-bottom: 32px; }
.usage-section h2 { font-size: var(--font-base); font-weight: 600; color: var(--text-secondary); margin-bottom: 16px; }
.section-title-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.section-title-row h2 { margin-bottom: 0; }
.edit-budget-btn { padding: 6px; background: transparent; border: 1px solid var(--glass-border); border-radius: 6px; color: var(--text-muted); cursor: pointer; transition: all 0.15s; }
.edit-budget-btn:hover { border-color: var(--accent-blue); color: var(--accent-blue); }
.edit-budget-btn svg { width: 14px; height: 14px; }

.budget-progress-bar { height: 8px; background: rgba(255, 255, 255, 0.08); border-radius: 4px; overflow: hidden; }
.budget-progress-fill { height: 100%; background: linear-gradient(90deg, var(--accent-green), var(--accent-blue)); border-radius: 4px; transition: width 0.3s ease; }
.budget-progress-fill.warning { background: linear-gradient(90deg, var(--accent-orange), var(--accent-yellow)); }
.budget-progress-fill.danger { background: linear-gradient(90deg, var(--accent-red), var(--accent-orange)); }

/* Tall Spend Cards */
.usage-cards-tall { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 24px; }
.usage-card-tall {
  display: flex;
  flex-direction: column;
  padding: 24px;
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  min-height: 160px;
}
.usage-card-icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  margin-bottom: 16px;
}
.usage-card-icon.blue { background: linear-gradient(135deg, #4a9eff, #80bdff); }
.usage-card-icon.purple { background: linear-gradient(135deg, #a78bfa, #c4b5fd); }
.usage-card-icon.green { background: linear-gradient(135deg, #34d399, #6ee7b7); }
.usage-card-label { font-size: var(--font-base); color: var(--text-secondary); margin-bottom: 8px; }
.usage-card-value { font-size: var(--font-stat); font-weight: 700; color: var(--text-primary); margin-bottom: 8px; }
.usage-card-sub { font-size: var(--font-base); color: var(--text-dim); }

/* Today/History Tabs */
.usage-tabs-container {
  display: flex;
  justify-content: center;
  margin-bottom: 24px;
}
.usage-tabs {
  display: flex;
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  padding: 4px;
}
.usage-tab {
  padding: 10px 32px;
  background: transparent;
  border: none;
  border-radius: 8px;
  color: var(--text-muted);
  font-size: var(--font-base);
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
}
.usage-tab:hover { color: var(--text-secondary); }
.usage-tab.active {
  background: rgba(255, 255, 255, 0.1);
  color: var(--text-primary);
}

/* Token Usage Content */
.usage-tab-content { 
  margin-bottom: 24px;
  min-height: 140px;
}
.token-section {
  min-height: 140px;
}
/* Fix #11: Empty state centered with absolute positioning */
.usage-empty-state {
  position: relative;
  height: 140px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  color: var(--text-muted);
  font-size: var(--font-base);
}
.usage-empty-state p {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  margin: 0;
}
.token-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.token-stat {
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  padding: 28px 20px;
  text-align: center;
  min-height: 100px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.token-stat-label { font-size: var(--font-base); color: var(--text-muted); display: block; margin-bottom: 8px; }
.token-stat-value { font-size: var(--font-stat); font-weight: 700; color: var(--text-primary); font-family: 'SF Mono', Monaco, monospace; }

/* Bottom Row: Insights + Distribution */
.usage-bottom-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.usage-insights-card,
.usage-budget-card {
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 24px;
  min-width: 480px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}
.usage-budget-card {
  max-height: 340px;
  overflow: hidden;
}
.usage-insights-card h3,
.usage-budget-card h3 {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: var(--font-base);
  font-weight: 600;
  color: var(--text-secondary);
  margin: 0 0 20px 0;
}
.usage-budget-card h3 {
  margin-bottom: 16px;
}
.usage-insights-card h3 svg,
.usage-budget-card h3 svg {
  width: 18px;
  height: 18px;
}

/* Budget Card */
.usage-budget-card .budget-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}
/* Budget display inside donut center */
.pie-center-budget {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.budget-display {
  font-size: 24px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1;
}
.pie-budget-input {
  display: none;
  width: 50px;
  padding: 4px 8px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid var(--accent-blue);
  border-radius: 6px;
  color: var(--text-primary);
  font-size: var(--font-title);
  font-weight: 600;
  text-align: center;
  outline: none;
}
.pie-center-budget.editing .budget-display {
  display: none;
}
.pie-center-budget.editing .pie-budget-input {
  display: block;
}
.pie-center-budget.editing .budget-edit-btn {
  display: none;
}
.budget-edit-btn {
  display: none;
}
.budget-display {
  cursor: pointer;
  text-decoration: underline;
  text-decoration-style: dotted;
  text-underline-offset: 4px;
  text-decoration-color: var(--text-muted);
  transition: text-decoration-color 0.15s;
}
.budget-display:hover {
  text-decoration-color: var(--accent-blue);
}
.budget-tooltip {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--bg-card);
  border: 1px solid var(--glass-border-light);
  border-radius: 6px;
  padding: 6px 10px;
  font-size: var(--font-base);
  color: var(--text-secondary);
  white-space: nowrap;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}
.budget-tooltip::before {
  content: '';
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-bottom-color: var(--glass-border-light);
}
.pie-center-budget.editing .budget-tooltip {
  display: block;
}
.pie-budget-input::-webkit-inner-spin-button,
.pie-budget-input::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.budget-summary {
  margin-bottom: 24px;
}
.budget-summary .budget-amounts {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 10px;
}
.budget-summary .budget-spent {
  font-size: var(--font-stat);
  font-weight: 700;
  color: var(--text-primary);
}
.budget-summary .budget-total {
  font-size: var(--font-base);
  color: var(--text-muted);
}
.budget-summary .budget-remaining {
  font-size: var(--font-base);
  color: var(--text-muted);
  margin-top: 8px;
  display: block;
}

/* Donut Chart */
/* Fix #10: Empty states horizontally aligned */
.spend-breakdown {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 48px;
}
.pie-chart-container {
  position: relative;
  width: 260px;
  height: 260px;
  flex-shrink: 0;
  order: 2;
  transform: translate(-10px, -40px);
}
.pie-chart {
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
}
.pie-center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}
.pie-center-value {
  font-size: 38px;
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1;
}
.pie-center-of {
  font-size: 15px;
  color: var(--text-muted);
}
.pie-center-label {
  display: none;
}
/* Fix #1 & #10: Pie legend repositioned */
.pie-legend {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 160px;
  order: 1;
  transform: translateX(20px);
  padding-top: 10px;
}
.pie-legend-item {
  display: flex;
  align-items: center;
  gap: 12px;
}
.pie-legend-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.pie-legend-dot.blue { background: var(--accent-blue); }
.pie-legend-dot.green { background: var(--accent-green); }
.pie-legend-dot.purple { background: var(--accent-purple); }
.pie-legend-dot.orange { background: var(--accent-orange); }
.pie-legend-text {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.pie-legend-name {
  font-size: var(--font-base);
  color: var(--text-secondary);
}
.pie-legend-value {
  font-size: var(--font-base);
  color: var(--text-muted);
}
/* Fix #10: Simplified for alignment */
.pie-empty {
  color: var(--text-muted);
  font-size: var(--font-base);
  text-align: left;
  padding: 0;
}

/* Intelligence Insights */
.insights-list { display: flex; flex-direction: column; gap: 12px; }
.insight-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 18px;
  border-radius: 12px;
  transition: transform 0.15s;
}
.insight-card:hover { transform: translateX(4px); }
.insight-card.blue {
  background: rgba(74, 158, 255, 0.15);
  border: 1px solid rgba(74, 158, 255, 0.25);
}
.insight-card.green {
  background: rgba(52, 211, 153, 0.15);
  border: 1px solid rgba(52, 211, 153, 0.25);
}
.insight-card.purple {
  background: rgba(167, 139, 250, 0.15);
  border: 1px solid rgba(167, 139, 250, 0.25);
}
.insight-icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}
.insight-icon svg {
  width: 24px;
  height: 24px;
}
.insight-card.blue .insight-icon { color: var(--accent-blue); }
.insight-card.green .insight-icon { color: var(--accent-green); }
.insight-card.purple .insight-icon { color: var(--accent-purple); }
.insight-content { display: flex; flex-direction: column; gap: 2px; }
.insight-title { font-size: var(--font-base); font-weight: 600; color: var(--text-primary); }
.insight-desc { font-size: var(--font-base); color: var(--text-secondary); }

.insight-card.orange {
  background: rgba(251, 146, 60, 0.15);
  border: 1px solid rgba(251, 146, 60, 0.25);
}
.insight-card.orange .insight-icon { color: var(--accent-orange); }

.recommendations-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 80px;
  color: var(--text-muted);
  font-size: var(--font-base);
}

/* (Spend distribution bars replaced by pie chart) */

/* Agents */
/* ==========================================
   AGENTS PAGE - Card Grid Design
   ========================================== */

/* Agents Page Layout */
.agents-page.active {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  padding: 0 !important;
}

.agents-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px;
  flex-shrink: 0;
  flex-wrap: wrap;
  gap: 16px;
  border-bottom: 1px solid var(--glass-border);
}

.agents-title-section {
  display: flex;
  align-items: center;
  gap: 14px;
}

.agents-title-section .page-subtitle {
  font-size: var(--font-small);
  color: var(--text-muted);
  margin: 0;
}

.agents-title-section h1 {
  font-size: var(--font-stat);
  font-weight: 600;
  letter-spacing: -0.02em;
  margin-bottom: 4px;
}

.agents-view-tabs {
  display: inline-flex;
  gap: 4px;
  padding: 4px;
  background: rgba(255,255,255,0.04);
  border-radius: 10px;
}

.agents-view-tab {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 16px;
  background: none;
  border: none;
  border-radius: 8px;
  color: var(--text-muted);
  font-size: var(--font-small);
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
}

.agents-view-tab svg {
  width: 14px;
  height: 14px;
}

.agents-view-tab.active {
  background: var(--accent-blue);
  color: white;
}

.agents-view-tab:not(.active):hover {
  color: var(--text-primary);
}

/* Personnel View (Master-Detail) */
.agents-personnel-view {
  flex: 1;
  display: flex;
  overflow: hidden;
}

.agents-personnel-view.hidden {
  display: none;
}

/* Roster Sidebar */
.agents-roster-sidebar {
  width: 320px;
  background: var(--bg-secondary);
  border-right: 1px solid var(--glass-border);
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
}

.roster-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  border-bottom: 1px solid var(--glass-border);
}

.roster-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.roster-count {
  font-size: 12px;
  color: var(--text-dim);
}

.roster-list {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

.roster-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px;
  cursor: pointer;
  transition: background 0.1s;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}

.roster-item:hover {
  background: rgba(255,255,255,0.04);
}

.roster-item.active {
  background: rgba(74, 158, 255, 0.12);
}

.roster-item-avatar {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  padding: 6px;
  box-sizing: border-box;
}

.roster-item-avatar.commander,
.roster-item-avatar.architect,
.roster-item-avatar.scout,
.roster-item-avatar.defender {
  background: transparent;
  padding: 0;
}

.roster-item-avatar img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: 12px;
}

.roster-item-info {
  flex: 1;
  min-width: 0;
}

.roster-item-name {
  display: block;
  font-size: var(--font-title);
  font-weight: 500;
  margin-bottom: 2px;
}

.roster-item-role {
  display: block;
  font-size: var(--font-small);
  color: var(--text-muted);
}

.roster-item-status {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent-green);
  flex-shrink: 0;
}

.roster-item-status.idle {
  background: var(--accent-yellow);
}

.roster-item-status.offline {
  background: var(--text-dim);
}

/* Agent Detail Panel */
.agent-detail-panel {
  flex: 1;
  overflow-y: auto;
  padding: 32px 40px;
  background: var(--bg-primary);
}

.detail-header {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  margin-bottom: 32px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--glass-border);
}

.detail-avatar {
  width: 80px;
  height: 80px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  padding: 12px;
  box-sizing: border-box;
}

.detail-avatar.commander,
.detail-avatar.architect,
.detail-avatar.scout,
.detail-avatar.defender {
  background: transparent;
  padding: 0;
}

.detail-avatar img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: 16px;
}

.detail-title h2 {
  font-size: 28px;
  font-weight: 600;
  margin-bottom: 4px;
}

.detail-role {
  display: block;
  font-size: var(--font-title);
  color: var(--text-muted);
  margin-bottom: 10px;
}

.detail-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 20px;
  font-size: var(--font-small);
  font-weight: 500;
}

.detail-status.active {
  background: rgba(16, 185, 129, 0.15);
  color: var(--accent-green);
}

.detail-status.idle {
  background: rgba(234, 179, 8, 0.15);
  color: var(--accent-yellow);
}

.detail-status .status-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}

.detail-section {
  margin-bottom: 28px;
}

.detail-section h3 {
  font-size: var(--font-small);
  font-weight: 600;
  color: var(--text-muted);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 12px;
}

.detail-bio {
  font-size: var(--font-title);
  color: var(--text-secondary);
  line-height: 1.6;
}

.detail-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.detail-list li {
  position: relative;
  padding-left: 20px;
  margin-bottom: 8px;
  font-size: var(--font-title);
  color: var(--text-secondary);
  line-height: 1.5;
}

.detail-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 8px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent-blue);
}

.detail-attributes {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.attribute-tag {
  padding: 6px 12px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--glass-border);
  border-radius: 6px;
  font-size: var(--font-base);
  color: var(--text-secondary);
}

/* Detail Task Cards */
.detail-tasks {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.detail-task-card {
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  padding: 16px;
}

.detail-task-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.detail-task-name {
  font-size: var(--font-base);
  font-weight: 600;
}

.detail-task-progress {
  font-size: var(--font-small);
  font-weight: 600;
  color: var(--accent-blue);
}

.detail-task-bar {
  height: 6px;
  background: rgba(255,255,255,0.1);
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 16px;
}

.detail-task-fill {
  height: 100%;
  background: var(--accent-blue);
  border-radius: 3px;
  transition: width 0.3s;
}

.detail-subtasks {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.detail-subtask {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: var(--font-small);
  color: var(--text-secondary);
}

.subtask-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

.subtask-icon.done {
  color: var(--accent-green);
}

.subtask-icon.in-progress {
  color: var(--accent-blue);
}

.subtask-icon.pending {
  color: var(--text-dim);
}

.detail-subtask.done {
  color: var(--accent-green);
}

.detail-subtask.in-progress {
  color: var(--text-primary);
}

.no-tasks {
  color: var(--text-dim);
  font-style: italic;
  font-size: var(--font-base);
}

/* Profile Card (Agent Detail Redesign) */
.profile-card {
  max-width: 900px;
}

.profile-header {
  display: flex;
  align-items: flex-start;
  gap: 28px;
  margin-bottom: 40px;
}

.profile-avatar {
  width: 100px;
  height: 100px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: transparent;
  padding: 0;
}

.profile-avatar img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: 20px;
}

.profile-title {
  flex: 1;
}

.profile-badges {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
}

.profile-role-badge {
  padding: 4px 12px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.profile-role-badge.blue { background: var(--accent-blue); color: white; }
.profile-role-badge.purple { background: #7c3aed; color: white; }
.profile-role-badge.gold { background: #e89830; color: white; }
.profile-role-badge.red { background: #ef4444; color: white; }

.profile-status-badge {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-muted);
}

.profile-status-badge.online { color: var(--accent-green); }
.profile-status-badge.idle { color: var(--text-dim); }

.profile-status-badge .status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
}

.profile-name {
  font-size: 42px;
  font-weight: 300;
  letter-spacing: -1px;
  margin: 0 0 8px 0;
  font-family: 'Georgia', serif;
}

.profile-tagline {
  font-size: 18px;
  color: var(--text-muted);
  font-style: italic;
  margin: 0;
}

.profile-body {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 60px;
}

.profile-left {
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.profile-section {
  /* spacing handled by gap */
}

.section-label {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1px;
  color: var(--text-dim);
  margin: 0 0 12px 0;
}

.section-text {
  font-size: 16px;
  line-height: 1.7;
  color: var(--text-secondary);
  margin: 0;
}

.profile-right {
  /* Active task card container */
}

.standing-assignment-card {
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 20px;
}

.assignment-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
}

.assignment-icon {
  width: 18px;
  height: 18px;
  color: var(--accent-blue);
}

.assignment-label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1px;
  color: var(--accent-blue);
}

.assignment-name {
  font-size: 18px;
  font-weight: 600;
  margin: 0 0 8px 0;
}

.assignment-desc {
  font-size: 13px;
  color: var(--text-muted);
  line-height: 1.5;
  margin: 0 0 8px 0;
}

.assignment-tasks {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--glass-border);
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.assignment-task {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.task-status-icon {
  width: 22px;
  height: 22px;
  flex-shrink: 0;
  margin-top: 1px;
}

.task-status-icon svg {
  width: 100%;
  height: 100%;
}

.task-status-icon.done {
  color: var(--accent-green);
}

.task-status-icon.pending {
  color: var(--text-dim);
  opacity: 0.5;
}

.assignment-task.pending {
  opacity: 0.7;
}

.assignment-task-content {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
}

.assignment-task-header {
  display: flex;
  align-items: center;
  gap: 10px;
}

.assignment-task-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-primary);
}

.assignment-task.pending .assignment-task-name {
  color: var(--text-secondary);
}

.frequency-badge {
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 2px 6px;
  border-radius: 4px;
  background: rgba(255,255,255,0.08);
  color: var(--text-dim);
}

.frequency-badge.daily {
  background: rgba(74, 158, 255, 0.15);
  color: var(--accent-blue);
}

.frequency-badge.weekly {
  background: rgba(168, 85, 247, 0.15);
  color: var(--accent-purple);
}

.frequency-badge.monthly {
  background: rgba(251, 146, 60, 0.15);
  color: var(--accent-orange);
}

.assignment-task-desc {
  font-size: 11px;
  color: var(--text-muted);
  line-height: 1.4;
}

/* Collaborations */
.collaborations-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.collaboration-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.collab-avatar {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  flex-shrink: 0;
  overflow: hidden;
}

.collab-avatar img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.collab-content {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.collab-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
}

.collab-desc {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.4;
}

/* Assigned Tasks Section (Horizontal Table) */
.assigned-tasks-section {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--glass-border);
}

.assigned-tasks-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
}

.assigned-tasks-icon {
  width: 18px;
  height: 18px;
  color: var(--accent-purple);
}

.assigned-tasks-label {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1px;
  color: var(--text-dim);
}

.assigned-tasks-count {
  background: var(--accent-purple);
  color: white;
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 10px;
  margin-left: 8px;
}

.assigned-tasks-table {
  display: flex;
  flex-direction: column;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  overflow: hidden;
}

.tasks-table-header {
  display: grid;
  grid-template-columns: 2fr 100px 100px 1fr;
  gap: 16px;
  padding: 10px 16px;
  background: rgba(255,255,255,0.04);
  border-bottom: 1px solid var(--glass-border);
}

.tasks-table-header span {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.tasks-table-row {
  display: grid;
  grid-template-columns: 2fr 100px 100px 1fr;
  gap: 16px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--glass-border);
  align-items: center;
}

.tasks-table-row:last-child {
  border-bottom: none;
}

.tasks-table-row .col-task {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
}

.tasks-table-row .col-status,
.tasks-table-row .col-project {
  font-size: 13px;
  color: var(--text-muted);
}

.priority-badge {
  display: inline-block;
  padding: 3px 8px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.5px;
}

.priority-badge.high { background: rgba(239, 68, 68, 0.2); color: #ef4444; }
.priority-badge.medium { background: rgba(234, 179, 8, 0.2); color: var(--accent-yellow); }
.priority-badge.low { background: rgba(52, 211, 153, 0.2); color: var(--accent-green); }

.no-assigned-tasks {
  font-size: 13px;
  color: var(--text-dim);
  font-style: italic;
  margin: 0;
}

/* Chat View */
.agents-chat-view {
  flex: 1;
  display: flex;
  overflow: hidden;
}

.agents-chat-view.hidden {
  display: none;
}

.chat-sidebar {
  width: 280px;
  background: var(--bg-secondary);
  border-right: 1px solid var(--glass-border);
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  overflow-y: auto;
}

.chat-sidebar-section {
  padding: 16px;
}

.chat-section-label {
  font-size: var(--font-micro);
  font-weight: 600;
  color: var(--text-dim);
  letter-spacing: 1px;
  margin-bottom: 12px;
}

.chat-channel-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.15s;
}

.chat-channel-item:hover {
  background: rgba(255,255,255,0.04);
}

.chat-channel-item.active {
  background: rgba(255,255,255,0.08);
}

.chat-channel-icon {
  width: 36px;
  height: 36px;
  background: var(--accent-blue);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.chat-channel-icon svg {
  width: 18px;
  height: 18px;
  color: white;
}

.chat-channel-icon.agent-icon {
  background: var(--bg-card);
  font-size: 18px;
}

/* Chat Agent Avatars - matches roster style */
.chat-agent-avatar {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: transparent;
  padding: 0;
}

.chat-agent-avatar img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: 10px;
}

.chat-channel-info {
  flex: 1;
  min-width: 0;
}

.chat-channel-name {
  display: block;
  font-size: var(--font-title);
  font-weight: 500;
  margin-bottom: 2px;
}

.chat-channel-meta {
  display: block;
  font-size: var(--font-small);
  color: var(--text-muted);
}

.chat-agent-status {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent-green);
  flex-shrink: 0;
}

.chat-agent-status.idle {
  background: var(--accent-yellow);
}

.chat-agent-status.offline {
  background: var(--text-dim);
}

/* Chat Main Area */
.chat-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--bg-primary);
}

.chat-header {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 24px;
  border-bottom: 1px solid var(--glass-border);
  flex-shrink: 0;
}

.chat-header-icon {
  width: 40px;
  height: 40px;
  background: var(--accent-blue);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.chat-header-icon svg {
  width: 20px;
  height: 20px;
  color: white;
}

.chat-header-icon.agent-icon {
  background: var(--bg-card);
  font-size: 20px;
}

.chat-header-info h2 {
  font-size: var(--font-title);
  font-weight: 600;
  margin-bottom: 2px;
}

.chat-header-info span {
  font-size: var(--font-small);
  color: var(--text-muted);
}

.chat-messages {
  flex: 1;
  overflow-y: auto;
  padding: 20px 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.chat-message {
  max-width: 75%;
}

.chat-message-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}

.chat-message-author {
  font-size: var(--font-base);
  font-weight: 600;
}

.chat-message-author.clause { color: var(--accent-blue); }
.chat-message-author.architect { color: var(--accent-orange); }
.chat-message-author.scout { color: var(--accent-green); }
.chat-message-author.defender { color: #ef4444; }
.chat-message-author.user { color: var(--accent-purple); }

.chat-message-time {
  font-size: var(--font-small);
  color: var(--text-dim);
}

.chat-message-body {
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  padding: 12px 16px;
  font-size: var(--font-title);
  line-height: 1.5;
  color: var(--text-secondary);
}

.chat-message.from-user {
  align-self: flex-end;
}

.chat-message.from-user .chat-message-header {
  justify-content: flex-end;
}

.chat-message.from-user .chat-message-body {
  background: var(--accent-blue);
  border-color: var(--accent-blue);
  color: white;
}

.chat-input-area {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 24px;
  border-top: 1px solid var(--glass-border);
  flex-shrink: 0;
}

.chat-input-area input {
  flex: 1;
  padding: 12px 18px;
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 24px;
  color: var(--text-primary);
  font-size: var(--font-base);
  outline: none;
}

.chat-input-area input:focus {
  border-color: var(--accent-blue);
}

.chat-send-btn {
  width: 44px;
  height: 44px;
  background: var(--accent-blue);
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.15s;
  flex-shrink: 0;
}

.chat-send-btn:hover {
  background: #5ba8ff;
  transform: scale(1.05);
}

.chat-send-btn svg {
  width: 20px;
  height: 20px;
  color: white;
}

/* Agent Cards Grid */
.agent-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 20px;
  padding-top: 8px;
}

.agent-card {
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 24px;
  cursor: pointer;
  transition: all 0.2s;
  position: relative;
}

.agent-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 15%;
  right: 15%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.08), transparent);
}

.agent-card:hover {
  background: var(--bg-card-hover);
  border-color: var(--glass-border-light);
  transform: translateY(-2px);
}

.agent-card-header {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 16px;
  position: relative;
}

.agent-card-avatar {
  width: 64px;
  height: 64px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
  padding: 8px;
  box-sizing: border-box;
}

.agent-card-avatar.commander { background: linear-gradient(135deg, #1e3a5f, #2d4a6f); }
.agent-card-avatar.architect { background: linear-gradient(135deg, #422006, #713f12); }
.agent-card-avatar.scout { background: linear-gradient(135deg, #064e3b, #065f46); }
.agent-card-avatar.defender { background: linear-gradient(135deg, #450a0a, #7f1d1d); }

.agent-card-avatar img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.agent-card-avatar svg {
  width: 28px;
  height: 28px;
  color: white;
}

.agent-card-view-btn {
  position: absolute;
  top: 0;
  right: 0;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--glass-border);
  border-radius: 8px;
  color: var(--text-muted);
  cursor: pointer;
  transition: all 0.15s;
}

.agent-card-view-btn:hover {
  background: rgba(74, 158, 255, 0.15);
  border-color: var(--accent-blue);
  color: var(--accent-blue);
}

.agent-card-view-btn svg {
  width: 16px;
  height: 16px;
}

.agent-card-info {
  flex: 1;
  min-width: 0;
}

.agent-card-name {
  font-size: var(--font-title);
  font-weight: 600;
  margin-bottom: 4px;
}

.agent-card-role {
  font-size: var(--font-small);
  color: var(--text-muted);
  margin-bottom: 8px;
}

.agent-card-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 12px;
  font-size: var(--font-micro);
  font-weight: 600;
  letter-spacing: 0.3px;
}

.agent-card-status.active {
  background: rgba(16, 185, 129, 0.15);
  color: var(--accent-green);
}

.agent-card-status.idle {
  background: rgba(234, 179, 8, 0.15);
  color: var(--accent-yellow);
}

.agent-card-status.offline {
  background: rgba(107, 114, 128, 0.15);
  color: var(--text-muted);
}

.agent-card-status::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}

.agent-card-description {
  font-size: var(--font-base);
  color: var(--text-secondary);
  line-height: 1.5;
  margin-bottom: 16px;
}

.agent-card-footer {
  display: flex;
  align-items: center;
  padding-top: 16px;
  border-top: 1px solid var(--glass-border);
}

.agent-card-capabilities {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.agent-capability-tag {
  padding: 4px 10px;
  background: rgba(255,255,255,0.06);
  border-radius: 6px;
  font-size: var(--font-micro);
  color: var(--text-muted);
}

/* Agent Profile Modal */
.agent-modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(8px);
  z-index: 10000;
  justify-content: center;
  align-items: center;
  padding: 40px;
}

.agent-modal-overlay.active {
  display: flex;
}

.agent-modal {
  width: 100%;
  max-width: 560px;
  background: var(--bg-secondary);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

.agent-modal-header {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 24px;
  background: var(--bg-card);
  border-bottom: 1px solid var(--glass-border);
  position: relative;
}

.agent-modal-avatar {
  width: 64px;
  height: 64px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  flex-shrink: 0;
  overflow: hidden;
}

.agent-modal-avatar.commander { background: linear-gradient(135deg, #4a9eff, #7ab8ff); }
.agent-modal-avatar.architect { background: linear-gradient(135deg, #f59e0b, #fbbf24); }
.agent-modal-avatar.scout { background: linear-gradient(135deg, #10b981, #34d399); }
.agent-modal-avatar.defender { background: linear-gradient(135deg, #ef4444, #f87171); }

.agent-modal-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.agent-modal-avatar svg {
  width: 32px;
  height: 32px;
  color: white;
}

.agent-modal-title {
  flex: 1;
}

.agent-modal-title h2 {
  font-size: var(--font-stat);
  font-weight: 600;
  margin-bottom: 4px;
}

.agent-modal-role {
  font-size: var(--font-small);
  color: var(--text-muted);
}

.agent-modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  border-radius: 8px;
  transition: all 0.15s;
}

.agent-modal-close:hover {
  background: rgba(255,255,255,0.08);
  color: var(--text-primary);
}

.agent-modal-close svg {
  width: 18px;
  height: 18px;
}

.agent-modal-body {
  padding: 24px;
  max-height: 60vh;
  overflow-y: auto;
}

.agent-modal-section {
  margin-bottom: 24px;
}

.agent-modal-section:last-child {
  margin-bottom: 0;
}

.agent-modal-section h3 {
  font-size: var(--font-micro);
  font-weight: 600;
  color: var(--text-muted);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 12px;
}

.agent-modal-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: rgba(16, 185, 129, 0.15);
  border-radius: 10px;
  font-size: var(--font-base);
  font-weight: 500;
  color: var(--accent-green);
}

.agent-modal-status .status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent-green);
}

/* Modal Task Card */
.modal-task-card {
  background: rgba(74, 158, 255, 0.1);
  border: 1px solid rgba(74, 158, 255, 0.2);
  border-radius: 10px;
  padding: 14px 16px;
}

.modal-task-name {
  font-size: var(--font-base);
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: 10px;
}

.modal-task-progress {
  display: flex;
  align-items: center;
  gap: 12px;
}

.modal-task-bar {
  flex: 1;
  height: 6px;
  background: rgba(255,255,255,0.1);
  border-radius: 3px;
  overflow: hidden;
}

.modal-task-fill {
  height: 100%;
  background: var(--accent-blue);
  border-radius: 3px;
  transition: width 0.3s;
}

.modal-task-percent {
  font-size: var(--font-small);
  font-weight: 600;
  color: var(--accent-blue);
  min-width: 36px;
  text-align: right;
}

.task-empty {
  color: var(--text-dim);
  font-style: italic;
  font-size: var(--font-base);
}

.agent-modal-status.idle {
  background: rgba(234, 179, 8, 0.15);
  color: var(--accent-yellow);
}

.agent-modal-status.idle .status-dot {
  background: var(--accent-yellow);
}

.agent-modal-section p {
  font-size: var(--font-base);
  color: var(--text-secondary);
  line-height: 1.6;
}

.agent-modal-capabilities {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.agent-modal-capability {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  font-size: var(--font-small);
  color: var(--text-secondary);
}

.agent-modal-capability svg {
  width: 14px;
  height: 14px;
  color: var(--accent-blue);
}

.agent-modal-activity {
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  padding: 16px;
}

.agent-modal-activity .activity-empty {
  color: var(--text-dim);
  font-style: italic;
  text-align: center;
  padding: 8px;
}

.agent-modal-activity .activity-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--glass-border);
}

.agent-modal-activity .activity-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.agent-modal-activity .activity-item:first-child {
  padding-top: 0;
}

.activity-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent-blue);
  margin-top: 6px;
  flex-shrink: 0;
}

.activity-content {
  flex: 1;
}

.activity-text {
  font-size: var(--font-base);
  color: var(--text-secondary);
  line-height: 1.4;
  margin-bottom: 4px;
}

.activity-time {
  font-size: var(--font-micro);
  color: var(--text-dim);
}

/* Cron */
/* Cron Jobs - Card Design */
.cron-list { display: flex; flex-direction: column; gap: 12px; }
.cron-card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 18px 20px;
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 14px;
  transition: all 0.15s;
  position: relative;
}
.cron-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 15%;
  right: 15%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.08), transparent);
}
.cron-card:hover {
  background: var(--bg-card-hover);
  border-color: var(--glass-border-light);
}
.cron-card.disabled {
  opacity: 0.5;
}
.cron-icon {
  width: 48px;
  height: 48px;
  background: var(--accent-green);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.cron-icon svg {
  width: 22px;
  height: 22px;
  color: #0a0d14;
}
.cron-card.disabled .cron-icon {
  background: var(--text-dim);
}
.cron-content {
  flex: 1;
  min-width: 0;
}
.cron-name {
  font-size: var(--font-base);
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 4px;
}
.cron-desc {
  font-size: var(--font-small);
  color: var(--text-secondary);
  margin-bottom: 10px;
  line-height: 1.4;
}
.cron-meta {
  display: flex;
  align-items: center;
  gap: 20px;
}
.cron-schedule,
.cron-next {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--font-small);
  color: var(--text-muted);
}
.cron-schedule svg,
.cron-next svg {
  width: 14px;
  height: 14px;
  opacity: 0.7;
}
.cron-schedule {
  font-family: 'SF Mono', Monaco, monospace;
}
.cron-model {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--font-small);
  color: var(--accent-purple);
}
.cron-model svg {
  width: 14px;
  height: 14px;
  opacity: 0.7;
}
.cron-status-badge {
  display: inline-flex;
  align-items: center;
  margin-left: 8px;
}
.cron-status-badge.success {
  color: var(--accent-green);
}
.cron-status-badge svg {
  width: 14px;
  height: 14px;
}
/* Cron Run Status Indicators */
.cron-run-status {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 600;
  margin-left: auto;
}

.cron-run-status.success {
  background: rgba(52, 211, 153, 0.15);
  color: var(--accent-green);
}

.cron-run-status.failed {
  background: rgba(239, 68, 68, 0.15);
  color: #ef4444;
}

.cron-run-status.pending {
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-dim);
}
.cron-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}

/* Cron Tabs - Pill Toggle Style */
.cron-tabs {
  display: inline-flex;
  gap: 4px;
  padding: 4px;
  background: rgba(255, 255, 255, 0.04);
  border-radius: 10px;
  margin-bottom: 20px;
}
.cron-tab {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 16px;
  background: none;
  border: none;
  border-radius: 8px;
  color: var(--text-muted);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s ease;
}
.cron-tab svg {
  width: 14px;
  height: 14px;
}
.cron-tab:not(.active):hover {
  color: var(--text-primary);
}
.cron-tab.active {
  background: var(--accent-orange);
  color: white;
}

/* Cron Tab Content */
.cron-tab-content {
  display: none;
}
.cron-tab-content.active {
  display: block;
}

/* Cron History */
.cron-history-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
  padding: 12px 16px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 10px;
}
.cron-history-filters {
  display: flex;
  gap: 12px;
}
.cron-history-select {
  padding: 8px 12px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  color: var(--text-primary);
  font-size: 13px;
  cursor: pointer;
}
.cron-history-select:focus {
  outline: none;
  border-color: var(--accent-orange);
}
.cron-history-stats {
  display: flex;
  gap: 16px;
}
.cron-history-stat {
  font-size: 13px;
  color: var(--text-dim);
}
.cron-history-stat.success {
  color: var(--accent-green);
}
.cron-history-stat.failed {
  color: #ef4444;
}

/* History List */
.cron-history-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-height: calc(100vh - 380px);
  overflow-y: auto;
}
.cron-history-item {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px 18px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 10px;
  transition: all 0.15s ease;
}
.cron-history-item:hover {
  background: rgba(255, 255, 255, 0.05);
}
.cron-history-status {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
}
.cron-history-status.success {
  background: rgba(52, 211, 153, 0.15);
  color: var(--accent-green);
}
.cron-history-status.failed {
  background: rgba(239, 68, 68, 0.15);
  color: #ef4444;
}
.cron-history-info {
  flex: 1;
  min-width: 0;
}
.cron-history-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: 4px;
}
.cron-history-time {
  font-size: 12px;
  color: var(--text-dim);
}
.cron-history-duration {
  font-size: 13px;
  color: var(--text-secondary);
  padding: 4px 10px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 6px;
}
.cron-history-empty {
  text-align: center;
  padding: 60px 20px;
  color: var(--text-dim);
}

/* Toggle Switch */
.toggle-switch {
  position: relative;
  width: 44px;
  height: 24px;
  cursor: pointer;
}
.toggle-switch input {
  opacity: 0;
  width: 0;
  height: 0;
}
.toggle-slider {
  position: absolute;
  inset: 0;
  background: var(--text-dim);
  border-radius: 24px;
  transition: all 0.2s ease;
}
.toggle-slider::before {
  content: '';
  position: absolute;
  width: 18px;
  height: 18px;
  left: 3px;
  bottom: 3px;
  background: white;
  border-radius: 50%;
  transition: all 0.2s ease;
}
.toggle-switch input:checked + .toggle-slider {
  background: var(--accent-green);
}
.toggle-switch input:checked + .toggle-slider::before {
  transform: translateX(20px);
}
.cron-menu-wrapper {
  position: relative;
}
.cron-menu-btn {
  width: 36px;
  height: 36px;
  background: transparent;
  border: 1px solid var(--glass-border);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--text-muted);
  transition: all 0.15s;
}
.cron-menu-btn:hover {
  background: var(--bg-card-hover);
  border-color: var(--glass-border-light);
  color: var(--text-secondary);
}
.cron-menu-btn svg {
  width: 16px;
  height: 16px;
}
.cron-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 140px;
  background: var(--bg-card);
  border: 1px solid var(--glass-border-light);
  border-radius: 10px;
  padding: 6px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: all 0.15s ease;
  z-index: 100;
}
.cron-dropdown.open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.cron-dropdown-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 12px;
  background: transparent;
  border: none;
  border-radius: 6px;
  color: var(--text-secondary);
  font-size: var(--font-base);
  cursor: pointer;
  transition: all 0.1s;
}
.cron-dropdown-item:hover {
  background: rgba(255, 255, 255, 0.06);
  color: var(--text-primary);
}
.cron-dropdown-item svg {
  width: 16px;
  height: 16px;
}
.cron-dropdown-item.danger {
  color: var(--accent-red);
}
.cron-dropdown-item.danger:hover {
  background: rgba(248, 113, 113, 0.12);
  color: var(--accent-red);
}

.placeholder { padding: 48px; text-align: center; color: var(--text-muted); background: var(--bg-card); border: 1px solid var(--glass-border); border-radius: 12px; }

::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: rgba(255,255,255,0.02); border-radius: 3px; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.15); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.25); }

@media (max-width: 1100px) {
  .dashboard-content { grid-template-columns: 1fr; }
  .dashboard-sidebar { display: none; }
  .stats-row { grid-template-columns: repeat(2, 1fr); }
  .workshop-layout { grid-template-columns: 1fr; }
  .workshop-sidebar { display: none; }
  .usage-cards { grid-template-columns: 1fr; }
}

/* ==========================================
   DOCSDIGEST PAGE
   ========================================== */
.page-icon-purple {
  width: 48px;
  height: 48px;
  background: linear-gradient(135deg, #a78bfa, #c4b5fd);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  flex-shrink: 0;
}
.page-icon-purple svg {
  width: 24px;
  height: 24px;
}
.page-icon-cyan {
  width: 48px;
  height: 48px;
  background: linear-gradient(135deg, #22d3ee, #67e8f9);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  flex-shrink: 0;
}
.page-icon-cyan svg {
  width: 24px;
  height: 24px;
}
.page-icon-blue {
  width: 48px;
  height: 48px;
  background: linear-gradient(135deg, #2563eb, #3b82f6);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  flex-shrink: 0;
}
.page-icon-blue svg {
  width: 24px;
  height: 24px;
}
.docs-upload-zone {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 48px;
  border: 2px dashed var(--glass-border);
  border-radius: 16px;
  background: rgba(255,255,255,0.02);
  cursor: pointer;
  transition: all 0.2s;
  margin-bottom: 20px;
}
.docs-upload-zone:hover {
  border-color: var(--accent-blue);
  background: rgba(74, 158, 255, 0.05);
}
.docs-upload-zone svg {
  width: 48px;
  height: 48px;
  color: var(--text-muted);
}
.docs-upload-zone:hover svg {
  color: var(--accent-blue);
}
.docs-upload-zone.drag-over {
  border-color: var(--accent-blue);
  background: rgba(74, 158, 255, 0.1);
  transform: scale(1.01);
}
.docs-upload-zone.drag-over svg {
  color: var(--accent-blue);
  transform: translateY(-4px);
  transition: transform 0.2s;
}
.docs-upload-zone.uploading {
  pointer-events: none;
  border-color: var(--accent-purple);
  background: rgba(168, 85, 247, 0.05);
}
.upload-spinner {
  width: 40px;
  height: 40px;
  border: 3px solid var(--glass-border);
  border-top-color: var(--accent-purple);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}
@keyframes spin {
  to { transform: rotate(360deg); }
}
.upload-title {
  font-size: var(--font-base);
  font-weight: 500;
  color: var(--text-secondary);
}
.upload-subtitle {
  font-size: var(--font-small);
  color: var(--text-muted);
}
.docs-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}

/* Wide search bar */
.docs-search-wide {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 18px;
  background: var(--bg-card);
  border: 1px solid var(--glass-border-light);
  border-radius: 10px;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.docs-search-wide:focus-within {
  border-color: var(--accent-blue);
  box-shadow: 0 0 0 3px rgba(74, 158, 255, 0.15);
}
.docs-search-wide svg {
  width: 18px;
  height: 18px;
  color: var(--text-secondary);
  flex-shrink: 0;
}
.docs-search-wide input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  color: var(--text-primary);
  font-size: var(--font-base);
}
.docs-search-wide input::placeholder {
  color: var(--text-secondary);
}

/* Filter dropdown wrapper */
.docs-filter-wrapper {
  position: relative;
}
.docs-filter-btn {
  width: 44px;
  height: 44px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  color: var(--text-dim);
  font-size: var(--font-small);
  cursor: pointer;
  transition: all 0.15s;
  flex-shrink: 0;
}
.docs-filter-btn svg {
  width: 18px;
  height: 18px;
}
.docs-filter-btn:hover {
  border-color: var(--glass-border-light);
  color: var(--text-secondary);
}

/* Filter dropdown */
.docs-filter-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 220px;
  background: var(--bg-card);
  border: 1px solid var(--glass-border-light);
  border-radius: 12px;
  padding: 8px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: all 0.2s ease;
  z-index: 100;
}
.docs-filter-dropdown.active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.docs-filter-header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px 6px;
}
.docs-filter-header-row span {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.docs-filter-reset {
  font-size: 12px;
  font-weight: 500;
  color: var(--accent-blue);
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 6px;
  transition: all 0.15s;
}
.docs-filter-reset:hover {
  background: rgba(74, 158, 255, 0.15);
}
.docs-filter-header {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 8px 12px 6px;
}
.docs-filter-option {
  display: block;
  width: 100%;
  padding: 10px 12px;
  background: none;
  border: none;
  border-radius: 8px;
  color: var(--text-secondary);
  font-size: var(--font-small);
  text-align: left;
  cursor: pointer;
  transition: all 0.15s;
}
.docs-filter-option:hover {
  background: rgba(255,255,255,0.08);
}
.docs-filter-option.active {
  background: var(--accent-blue);
  color: white;
}
.docs-filter-divider {
  height: 1px;
  background: var(--glass-border);
  margin: 8px 0;
}
/* DocsDigest Page */
.docs-page.active {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
}
.docs-page .page-header {
  flex-shrink: 0;
}

/* Docs List - 2 Column Grid */
.docs-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  overflow-y: auto;
  max-height: calc(100vh - 420px);
  padding: 16px 12px 16px 0;
  margin-top: 8px;
}
.docs-list::-webkit-scrollbar {
  width: 6px;
}
.docs-list::-webkit-scrollbar-track {
  background: rgba(255,255,255,0.02);
  border-radius: 3px;
}
.docs-list::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.12);
  border-radius: 3px;
}

/* Doc Card - Clean Card Style */
.doc-item {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 16px 18px;
  min-height: 120px;
  background: rgba(40, 50, 70, 0.4);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.15s ease;
}
.doc-item:hover {
  background: rgba(50, 60, 85, 0.5);
  border-color: rgba(255, 255, 255, 0.12);
}

/* Doc Header Row */
.doc-header {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.doc-icon {
  width: 36px;
  height: 36px;
  background: linear-gradient(135deg, #ef4444, #dc2626);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 10px;
  font-weight: 700;
  flex-shrink: 0;
}
.doc-icon.md {
  background: linear-gradient(135deg, #8b5cf6, #7c3aed);
}
.doc-icon.json {
  background: linear-gradient(135deg, #f59e0b, #d97706);
}
.doc-icon.txt {
  background: linear-gradient(135deg, #6b7280, #4b5563);
}
.doc-icon.pdf {
  background: linear-gradient(135deg, #ef4444, #dc2626);
}
.doc-icon.xlsx, .doc-icon.xls {
  background: linear-gradient(135deg, #22c55e, #16a34a);
}
.doc-info {
  flex: 1;
  min-width: 0;
}
.doc-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 4px;
  line-height: 1.3;
}
.doc-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  color: var(--text-muted);
}
.doc-meta span {
  display: flex;
  align-items: center;
  gap: 4px;
}
.doc-desc {
  font-size: 12px;
  color: rgba(180, 195, 220, 0.7);
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.doc-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 4px;
}
.doc-tag {
  padding: 4px 10px;
  background: rgba(74, 158, 255, 0.15);
  border-radius: 6px;
  font-size: 10px;
  font-weight: 500;
  color: var(--accent-blue);
  text-transform: capitalize;
}
.doc-auto-badge {
  padding: 3px 8px;
  background: rgba(167, 139, 250, 0.2);
  border-radius: 6px;
  font-size: 9px;
  font-weight: 600;
  color: var(--accent-purple);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.doc-uploaded-badge {
  padding: 3px 8px;
  background: rgba(59, 130, 246, 0.2);
  border-radius: 6px;
  font-size: 9px;
  font-weight: 600;
  color: #60a5fa;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* ==========================================
   DOCUDIGEST - INBOX/OUTBOX TABS
   ========================================== */

/* Tab Bar */
.docs-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 20px;
  padding: 4px;
  background: rgba(30, 40, 60, 0.5);
  border-radius: 12px;
  width: fit-content;
}

.docs-tab {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  background: transparent;
  border: none;
  border-radius: 10px;
  color: var(--text-muted);
  font-size: var(--font-base);
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
}

.docs-tab svg {
  width: 18px;
  height: 18px;
}

.docs-tab:hover {
  color: var(--text-primary);
  background: rgba(255, 255, 255, 0.05);
}

.docs-tab.active {
  background: var(--accent-blue);
  color: white;
}

.docs-tab-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 10px;
  font-size: 11px;
  font-weight: 600;
}

.docs-tab.active .docs-tab-badge {
  background: rgba(255, 255, 255, 0.3);
}

.docs-tab-badge.new {
  background: var(--accent-green);
  color: white;
  animation: pulse-badge 2s ease-in-out infinite;
}

.docs-tab.active .docs-tab-badge.new {
  background: rgba(52, 211, 153, 0.9);
}

@keyframes pulse-badge {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.1); }
}

/* Tab Content */
.docs-tab-content {
  display: none;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}

.docs-tab-content.active {
  display: flex;
}

/* Section Headers */
.docs-inbox-header,
.docs-outbox-header {
  margin-bottom: 16px;
}

.docs-section-label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  font-weight: 600;
  color: var(--accent-purple);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 6px;
}

.docs-section-label svg {
  width: 18px;
  height: 18px;
}

.docs-outbox-header .docs-section-label {
  color: var(--accent-green);
}

.docs-section-desc {
  font-size: var(--font-small);
  color: var(--text-muted);
}

/* Empty States */
.docs-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 40px;
  text-align: center;
  background: rgba(40, 50, 70, 0.3);
  border: 1px dashed var(--glass-border);
  border-radius: 16px;
  grid-column: 1 / -1;
}

.docs-empty-state svg {
  width: 48px;
  height: 48px;
  color: var(--text-dim);
  margin-bottom: 16px;
}

.docs-empty-state .empty-title {
  font-size: var(--font-base);
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 6px;
}

.docs-empty-state .empty-subtitle {
  font-size: var(--font-small);
  color: var(--text-muted);
}

/* Outbox List - prioritize NEW items */
.docs-list.outbox {
  max-height: calc(100vh - 380px);
}

/* NEW indicator on doc cards */
.doc-new-indicator {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 2;
}

.doc-new-badge {
  display: inline-block;
  padding: 4px 10px;
  background: var(--accent-green);
  border-radius: 6px;
  font-size: 9px;
  font-weight: 700;
  color: white;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  animation: pulse-new 2s ease-in-out infinite;
}

@keyframes pulse-new {
  0%, 100% { box-shadow: 0 0 0 0 rgba(52, 211, 153, 0.4); }
  50% { box-shadow: 0 0 12px 4px rgba(52, 211, 153, 0.3); }
}

/* New doc card highlight */
.doc-item.is-new {
  border-color: rgba(52, 211, 153, 0.3);
  background: rgba(52, 211, 153, 0.08);
}

.doc-item.is-new:hover {
  background: rgba(52, 211, 153, 0.12);
  border-color: rgba(52, 211, 153, 0.4);
}

/* Document Type Badge */
.doc-type-badge {
  padding: 3px 8px;
  border-radius: 6px;
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.doc-type-badge.purple { background: rgba(167, 139, 250, 0.2); color: var(--accent-purple); }
.doc-type-badge.blue { background: rgba(74, 158, 255, 0.2); color: var(--accent-blue); }
.doc-type-badge.green { background: rgba(52, 211, 153, 0.2); color: var(--accent-green); }
.doc-type-badge.orange { background: rgba(251, 146, 60, 0.2); color: var(--accent-orange); }
.doc-type-badge.cyan { background: rgba(34, 211, 238, 0.2); color: var(--accent-cyan); }
.doc-type-badge.yellow { background: rgba(251, 191, 36, 0.2); color: var(--accent-yellow); }
.doc-type-badge.gray { background: rgba(150, 160, 180, 0.2); color: var(--text-secondary); }

/* Processing Status Badges */
.doc-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  border-radius: 6px;
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.doc-status-badge.pending {
  background: rgba(251, 191, 36, 0.2);
  color: var(--accent-yellow);
}

.doc-status-badge.processing {
  background: rgba(74, 158, 255, 0.2);
  color: var(--accent-blue);
}

.doc-status-badge.processed {
  background: rgba(52, 211, 153, 0.15);
  color: var(--accent-green);
}

.doc-status-badge.error {
  background: rgba(248, 113, 113, 0.2);
  color: var(--accent-red);
}

/* Processing spinner */
.doc-spinner {
  width: 10px;
  height: 10px;
  border: 2px solid transparent;
  border-top-color: currentColor;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

/* Agent attribution */
.doc-agent {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
  font-size: 11px;
}

.doc-agent-label {
  color: var(--text-dim);
}

.doc-agent-name {
  color: var(--accent-purple);
  font-weight: 500;
}

/* Mark All Read Button */
.docs-mark-read-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  background: rgba(52, 211, 153, 0.15);
  border: 1px solid rgba(52, 211, 153, 0.3);
  border-radius: 10px;
  color: var(--accent-green);
  font-size: var(--font-small);
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
}

.docs-mark-read-btn:hover {
  background: rgba(52, 211, 153, 0.25);
  border-color: rgba(52, 211, 153, 0.4);
}

.docs-mark-read-btn svg {
  width: 16px;
  height: 16px;
}

/* Sidebar NEW indicator */
.sidebar-doc-new {
  margin-left: auto;
  padding: 2px 6px;
  background: var(--accent-green);
  border-radius: 4px;
  font-size: 8px;
  font-weight: 700;
  color: white;
  text-transform: uppercase;
}

/* ==========================================
   INTELLIGENCE PAGE
   ========================================== */
.intel-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 20px;
}
.intel-tab {
  padding: 10px 20px;
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 8px;
  color: var(--text-muted);
  font-size: var(--font-small);
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
}
.intel-tab:hover {
  border-color: var(--accent-blue);
  color: var(--text-secondary);
}
.intel-tab.active {
  background: var(--accent-blue);
  border-color: var(--accent-blue);
  color: white;
}
/* Intelligence page - full height layout */
.intel-page.active {
  display: flex !important;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
}
.intel-page .page-header {
  flex-shrink: 0;
}
.intel-content {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 24px;
  flex: 1;
  min-height: 0;
  overflow: hidden;
  align-items: stretch;
  padding-bottom: 0;
}
.intel-feed-wrapper {
  display: flex;
  flex-direction: column;
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 14px;
  overflow: hidden;
  height: 100%;
}
.intel-feed-toolbar {
  display: flex;
  gap: 10px;
  padding: 14px;
  border-bottom: 1px solid var(--glass-border);
  flex-shrink: 0;
  min-height: 68px;
  box-sizing: border-box;
  align-items: center;
}
.intel-feed-search {
  flex: 1;
  min-width: 180px;
  max-width: 100%;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 18px;
  background: var(--bg-card);
  border: 1px solid var(--glass-border-light);
  border-radius: 10px;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.intel-feed-search:focus-within {
  border-color: var(--accent-blue);
  box-shadow: 0 0 0 3px rgba(74, 158, 255, 0.15);
}
.intel-feed-search svg {
  width: 18px;
  height: 18px;
  color: var(--text-secondary);
  flex-shrink: 0;
}
.intel-feed-search input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  color: var(--text-primary);
  font-size: var(--font-base);
}
.intel-feed-search input::placeholder {
  color: var(--text-secondary);
}
.intel-feed-filter {
  width: 42px;
  height: 42px;
  padding: 0;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  color: var(--text-dim);
  font-size: var(--font-small);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s;
  flex-shrink: 0;
}
.intel-feed-filter:hover {
  background: rgba(255,255,255,0.1);
  border-color: var(--glass-border-light);
  color: var(--text-secondary);
}
.intel-feed-filter svg {
  width: 18px;
  height: 18px;
}
.intel-filter-wrapper {
  position: relative;
}
.intel-feed-refresh {
  width: 42px;
  height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  color: var(--text-dim);
  cursor: pointer;
  transition: all 0.15s;
  flex-shrink: 0;
}
.intel-feed-refresh:hover {
  background: rgba(255,255,255,0.1);
  border-color: var(--glass-border-light);
  color: var(--text-secondary);
}
.intel-feed-refresh svg {
  width: 18px;
  height: 18px;
}
.intel-filter-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 240px;
  background: var(--bg-card);
  border: 1px solid var(--glass-border-light);
  border-radius: 12px;
  padding: 8px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: all 0.2s ease;
  z-index: 100;
}
.intel-filter-dropdown.active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.intel-filter-header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px 6px;
}
.intel-filter-header-row span {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.intel-filter-reset {
  font-size: 12px;
  font-weight: 500;
  color: var(--accent-blue);
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 6px;
  transition: all 0.15s;
}
.intel-filter-reset:hover {
  background: rgba(74, 158, 255, 0.15);
}
.intel-filter-header {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 8px 12px 6px;
}
.intel-filter-option {
  display: block;
  width: 100%;
  padding: 10px 12px;
  background: none;
  border: none;
  border-radius: 8px;
  color: var(--text-secondary);
  font-size: var(--font-small);
  text-align: left;
  cursor: pointer;
  transition: all 0.15s;
}
.intel-filter-option:hover {
  background: rgba(255,255,255,0.08);
}
.intel-filter-option.active {
  background: var(--accent-blue);
  color: white;
}
.intel-filter-divider {
  height: 1px;
  background: var(--glass-border);
  margin: 8px 0;
}
.intel-feed {
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  flex: 1;
  padding: 8px;
}
.intel-feed::-webkit-scrollbar {
  width: 6px;
}
.intel-feed::-webkit-scrollbar-track {
  background: rgba(255,255,255,0.02);
  border-radius: 3px;
}
.intel-feed::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.15);
  border-radius: 3px;
}
.intel-feed::-webkit-scrollbar-thumb:hover {
  background: rgba(255,255,255,0.25);
}
.intel-feed-item {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 14px 16px;
  margin-bottom: 4px;
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.15s;
}
.intel-feed-item:hover {
  background: rgba(255,255,255,0.05);
}
.intel-feed-item.active {
  background: var(--accent-blue);
}
.intel-feed-item.active .intel-feed-title,
.intel-feed-item.active .intel-feed-desc,
.intel-feed-item.active .intel-feed-meta {
  color: white;
}
.intel-feed-item.active .intel-feed-meta span {
  color: rgba(255,255,255,0.7);
}
.intel-feed-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}
.intel-feed-tag {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 4px;
  background: rgba(74, 158, 255, 0.15);
  color: var(--accent-blue);
}
.intel-feed-item.active .intel-feed-tag {
  background: rgba(255,255,255,0.2);
  color: white;
}
.intel-feed-tag.green { background: rgba(34, 197, 94, 0.15); color: var(--accent-green); }
.intel-feed-tag.orange { background: rgba(251, 146, 60, 0.15); color: var(--accent-orange); }
.intel-feed-tag.purple { background: rgba(167, 139, 250, 0.15); color: var(--accent-purple); }
.intel-feed-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}
.intel-feed-time {
  font-size: var(--font-small);
  color: var(--text-muted);
  flex-shrink: 0;
  white-space: nowrap;
}
.intel-feed-delete {
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  border-radius: 4px;
  color: var(--text-muted);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  opacity: 0;
  transition: all 0.15s;
  flex-shrink: 0;
}
.intel-feed-item:hover .intel-feed-delete {
  opacity: 0.6;
}
.intel-feed-delete:hover {
  opacity: 1 !important;
  color: #f87171;
  background: rgba(248, 113, 113, 0.15);
}
.intel-feed-title {
  font-size: var(--font-base);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.3;
  flex: 1;
  min-width: 0;
}
.intel-feed-desc {
  font-size: var(--font-small);
  color: var(--text-muted);
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.intel-main-wrapper {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-width: 0;
  height: 100%;
  overflow: hidden;
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
}
/* Top Bar - just action buttons in top right */
.intel-topbar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 0 0 16px 0;
  border-bottom: none;
  margin-bottom: 0;
  flex-shrink: 0;
  min-height: auto;
  box-sizing: border-box;
}
.intel-topbar-label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  font-weight: 600;
  color: rgba(180, 195, 220, 0.6);
  letter-spacing: 1.5px;
  text-transform: uppercase;
}
.intel-topbar-label svg {
  width: 18px;
  height: 18px;
  opacity: 0.7;
}
.intel-topbar-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  position: relative;
  z-index: 9999;
}
.intel-dismiss-btn {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 12px;
  color: rgba(180, 195, 220, 0.5);
  cursor: pointer;
  transition: all 0.2s;
}
.intel-dismiss-btn:hover {
  background: rgba(248, 113, 113, 0.15);
  border-color: rgba(248, 113, 113, 0.3);
  color: #f87171;
}
.intel-dismiss-btn svg {
  width: 20px;
  height: 20px;
}

/* New unified button class for Tauri compatibility */
.intel-action-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 44px;
  padding: 0 18px;
  border: none;
  border-radius: 12px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  pointer-events: auto !important;
  position: relative;
  z-index: 9999;
}
.intel-action-btn svg {
  width: 18px;
  height: 18px;
  pointer-events: none;
}
.intel-action-delete {
  background: rgba(248, 113, 113, 0.15);
  color: #f87171;
}
.intel-action-delete:hover {
  background: rgba(248, 113, 113, 0.25);
}
.intel-action-deploy {
  background: linear-gradient(135deg, #4a9eff 0%, #3182ce 100%);
  color: white;
  box-shadow: 0 4px 16px rgba(74, 158, 255, 0.3);
}
.intel-action-deploy:hover {
  background: linear-gradient(135deg, #5aa8ff 0%, #4192de 100%);
  transform: translateY(-1px);
}
.intel-delete-btn {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 12px;
  color: rgba(180, 195, 220, 0.5);
  cursor: pointer;
  transition: all 0.2s;
  pointer-events: auto !important;
  position: relative;
  z-index: 9999;
}
.intel-delete-btn:hover {
  background: rgba(248, 113, 113, 0.15);
  border-color: rgba(248, 113, 113, 0.3);
  color: var(--accent-red);
}
.intel-delete-btn svg {
  width: 20px;
  height: 20px;
  pointer-events: none;
}
/* Fix #3: Deploy button height matches Delete button */
.intel-deploy-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 44px;
  padding: 0 18px;
  background: linear-gradient(135deg, #4a9eff 0%, #3182ce 100%);
  border: none;
  border-radius: 12px;
  color: white;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  box-shadow: 0 4px 16px rgba(74, 158, 255, 0.3);
  pointer-events: auto !important;
  position: relative;
  z-index: 9999;
}
.intel-deploy-btn:hover {
  background: linear-gradient(135deg, #5aa8ff 0%, #4192de 100%);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(74, 158, 255, 0.4);
}
.intel-deploy-btn svg {
  width: 18px;
  height: 18px;
  pointer-events: none;
}

/* Main Content - Full width header, then 2-column below */
.intel-main-content {
  display: flex;
  flex-direction: column;
  flex: 1;
  overflow-y: auto;
  overflow-x: auto;
  padding-right: 8px;
}
.intel-main-content::-webkit-scrollbar {
  width: 6px;
}
.intel-main-content::-webkit-scrollbar-track {
  background: rgba(255,255,255,0.02);
  border-radius: 3px;
}
.intel-main-content::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.12);
}
/* Horizontal scrollbar styling */
.intel-main-content::-webkit-scrollbar:horizontal {
  height: 6px;
}
.intel-main-content::-webkit-scrollbar-track:horizontal {
  background: rgba(255,255,255,0.02);
  border-radius: 3px;
}
.intel-main-content::-webkit-scrollbar-thumb:horizontal {
  background: rgba(255,255,255,0.12);
  border-radius: 3px;
}

/* Empty state */
.intel-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex: 1;
  min-height: 300px;
  padding: 40px;
}

/* Hide topbar label when showing empty state */
.intel-main-wrapper:has(.intel-empty-state:not([style*="display: none"])) .intel-topbar-label {
  visibility: hidden;
}

/* Full-width header section */
.intel-header-section {
  margin-bottom: 32px;
}

/* Two-column body wrapper */
.intel-body-wrapper {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 32px;
  flex: 1;
}

.intel-main {
  padding-bottom: 40px;
}
.intel-main::-webkit-scrollbar {
  width: 6px;
}
.intel-main::-webkit-scrollbar-track {
  background: rgba(255,255,255,0.02);
  border-radius: 3px;
}
.intel-main::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.12);
  border-radius: 3px;
}
/* Tag Label - Blue Style */
.intel-tag-label {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  font-weight: 600;
  color: var(--accent-blue);
  letter-spacing: 4px;
  text-transform: uppercase;
  margin-bottom: 24px;
  text-shadow: 0 0 20px rgba(74, 158, 255, 0.5);
}
.intel-tag-glyph {
  font-size: 18px;
  color: var(--accent-blue);
  text-shadow: 0 0 16px rgba(74, 158, 255, 0.7);
}

/* Title - Large Hero Text */
.intel-title {
  font-size: 44px;
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.12;
  margin-bottom: 24px;
  letter-spacing: -1px;
}

/* Description */
.intel-desc {
  font-size: 18px;
  color: rgba(180, 195, 220, 0.75);
  line-height: 1.65;
  margin-bottom: 56px;
  max-width: 680px;
}

/* Section - Breakdown/Validation */
.intel-section {
  margin-bottom: 48px;
}
.intel-section-header {
  display: flex;
  align-items: center;
  gap: 24px;
  margin-bottom: 24px;
}
.intel-section-header span {
  font-size: 12px;
  font-weight: 700;
  color: rgba(180, 195, 220, 0.5);
  letter-spacing: 3px;
  white-space: nowrap;
}
.intel-section-line {
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, rgba(255,255,255,0.15) 0%, transparent 80%);
}
.intel-section-body {
  font-size: 15px;
  color: rgba(200, 215, 240, 0.8);
  line-height: 1.9;
}
.intel-section-body p {
  margin-bottom: 18px;
}
.intel-section-body strong {
  color: var(--text-primary);
  font-weight: 600;
}

/* BREAKDOWN Grid - Multiple components */
.intel-breakdown-grid {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.intel-breakdown-item {
  padding: 0;
}
.intel-breakdown-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 8px;
}
.intel-breakdown-item p {
  font-size: 15px;
  color: rgba(200, 215, 240, 0.8);
  line-height: 1.7;
  margin: 0;
}
.intel-breakdown-item a {
  color: var(--accent-blue);
  text-decoration: none;
}
.intel-breakdown-item a:hover {
  text-decoration: underline;
}

/* Business Case Section - 3 Columns */
.intel-business-case {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.intel-bc-item {
  padding: 16px 18px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 12px;
  border-top: 3px solid var(--accent-blue);
}
.intel-bc-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--accent-blue);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.intel-bc-item p {
  font-size: 14px;
  color: rgba(200, 215, 240, 0.85);
  line-height: 1.6;
  margin: 0;
}

/* Validation Section */
.intel-validation-section {
  margin-bottom: 48px;
}
.intel-validation-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
}
.intel-validation-header svg {
  width: 18px;
  height: 18px;
  color: var(--accent-purple);
}
.intel-validation-header span {
  font-size: 12px;
  font-weight: 700;
  color: var(--accent-purple);
  letter-spacing: 2px;
  text-shadow: 0 0 12px rgba(167, 139, 250, 0.4);
}
.intel-validation-quote {
  padding: 0 0 0 28px;
  background: transparent;
  border-left: 3px solid var(--accent-purple);
}
.intel-validation-quote p {
  font-size: 18px;
  font-style: italic;
  color: rgba(200, 215, 240, 0.8);
  line-height: 1.75;
  margin: 0;
}
/* ==========================================
   INTELLIGENCE - APPLE LIQUID GLASS UI
   ========================================== */

/* Deployment Section - Full Width Centered */
.intel-deployment-section {
  text-align: center;
  padding: 24px 0 32px;
  margin-top: 16px;
}
.intel-deployment-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--accent-purple);
  letter-spacing: 3px;
  text-transform: uppercase;
  margin-bottom: 16px;
  text-shadow: 0 0 20px rgba(167, 139, 250, 0.5);
}
.intel-roadmap-title {
  font-size: 36px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 20px;
  letter-spacing: -0.5px;
}
.intel-roadmap-divider {
  width: 80px;
  height: 4px;
  background: linear-gradient(90deg, transparent, var(--glass-border-light), transparent);
  margin: 0 auto 40px;
  border-radius: 2px;
}

/* Roadmap Grid - Liquid Glass Cards */
.intel-roadmap-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 16px;
}
.intel-roadmap-grid.single {
  grid-template-columns: repeat(4, 1fr);
}
.intel-roadmap-grid.single .intel-roadmap-card {
  grid-column: 1;
}

/* LIQUID GLASS CARD - Implementation Roadmap */
.intel-roadmap-card {
  background: linear-gradient(
    145deg,
    rgba(180, 200, 230, 0.12) 0%,
    rgba(140, 170, 210, 0.08) 50%,
    rgba(120, 150, 200, 0.05) 100%
  );
  backdrop-filter: blur(40px) saturate(180%);
  -webkit-backdrop-filter: blur(40px) saturate(180%);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 20px;
  padding: 20px 18px;
  min-height: 140px;
  text-align: left;
  box-shadow: 
    0 4px 24px rgba(0, 0, 0, 0.15),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
  transition: all 0.2s ease;
  display: flex;
  flex-direction: column;
}
.intel-roadmap-card:hover {
  background: linear-gradient(
    145deg,
    rgba(180, 200, 230, 0.16) 0%,
    rgba(140, 170, 210, 0.12) 50%,
    rgba(120, 150, 200, 0.08) 100%
  );
  border-color: rgba(255, 255, 255, 0.2);
  transform: translateY(-2px);
}

.intel-card-number {
  width: 32px;
  height: 32px;
  background: rgba(100, 115, 140, 0.5);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  font-weight: 700;
  color: rgba(180, 195, 220, 0.7);
  margin-bottom: 14px;
  flex-shrink: 0;
  transition: all 0.25s ease;
}

/* Hover animation - gray turns purple */
.intel-roadmap-card:hover .intel-card-number {
  background: linear-gradient(135deg, #a78bfa 0%, #8b5cf6 100%);
  color: white;
  box-shadow: 0 0 16px rgba(139, 92, 246, 0.5);
  transform: scale(1.1);
}
.intel-roadmap-card p {
  font-size: 13px;
  color: rgba(220, 230, 245, 0.85);
  line-height: 1.5;
  margin: 0;
}

/* Right Sidebar - Stacked Cards */
.intel-sidebar {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding-bottom: 40px;
}

/* LIQUID GLASS SIDEBAR CARDS - Impact/Strategic (Black Glass/Obsidian) */
.intel-glass-card {
  position: relative;
  overflow: hidden;
  background: linear-gradient(
    180deg,
    rgba(25, 30, 40, 0.95) 0%,
    rgba(15, 20, 30, 0.95) 100%
  );
  backdrop-filter: blur(40px) saturate(1.5);
  -webkit-backdrop-filter: blur(40px) saturate(1.5);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-top: 1.5px solid rgba(255, 255, 255, 0.35);
  border-radius: 16px;
  padding: 20px;
  box-shadow: 
    0 8px 32px rgba(0, 0, 0, 0.4),
    inset 0 1px 0 rgba(255, 255, 255, 0.15);
}

/* Hide sheen element - using border-top instead */
.intel-glass-sheen {
  display: none;
}

.intel-glass-header {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}
.intel-glass-card .intel-glass-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}
.intel-glass-card.impact .intel-glass-icon {
  color: #34d399;
  filter: drop-shadow(0 0 6px rgba(52, 211, 153, 0.5));
}
.intel-glass-card.strategic .intel-glass-icon {
  color: var(--accent-orange);
  filter: drop-shadow(0 0 6px rgba(251, 146, 60, 0.5));
}
.intel-glass-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
}
.intel-glass-card.impact .intel-glass-label {
  color: #34d399;
  text-shadow: 0 0 8px rgba(52, 211, 153, 0.4);
}
.intel-glass-card.strategic .intel-glass-label {
  color: var(--accent-orange);
  text-shadow: 0 0 8px rgba(251, 146, 60, 0.4);
}
.intel-glass-card.validation .intel-glass-icon {
  color: #ff7f7f;
  filter: drop-shadow(0 0 6px rgba(255, 127, 127, 0.5));
}
.intel-glass-card.validation .intel-glass-label {
  color: #ff7f7f;
  text-shadow: 0 0 8px rgba(255, 127, 127, 0.4);
}
/* Validation with left red bar instead of top border */
.intel-glass-card.validation.left-bar {
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  border-left: 3px solid #ff7f7f;
  border-radius: 0 16px 16px 0;
}
.intel-glass-card p {
  font-size: 14px;
  color: rgba(220, 230, 245, 0.85);
  line-height: 1.6;
  margin: 0;
}

/* Impact Metrics */
.intel-impact-metrics {
  display: flex;
  gap: 16px;
  margin-bottom: 14px;
}
.intel-metric {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.intel-metric-value {
  font-size: 20px;
  font-weight: 700;
  color: var(--accent-green);
}
.intel-metric-label {
  font-size: 10px;
  color: rgba(180, 195, 220, 0.6);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.intel-glass-card em {
  font-style: italic;
}

/* Requirements Section - Simple pills, NOT glass card */
.intel-requirements-section {
  margin-top: 16px;
}
.intel-requirements-title {
  font-size: 11px;
  font-weight: 700;
  color: rgba(180, 195, 220, 0.5);
  letter-spacing: 1.5px;
  margin-bottom: 14px;
}
.intel-req-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.intel-req-item {
  padding: 12px 16px;
  background: rgba(30, 40, 60, 0.6);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 10px;
  font-size: 10px;
  font-weight: 600;
  color: rgba(180, 195, 220, 0.7);
  letter-spacing: 0.3px;
  line-height: 1.4;
}

/* Intel Detail Panel - Use Case Analysis */
.intel-use-case {
  margin-bottom: 24px;
}
.intel-use-case h3 {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 16px;
  letter-spacing: 0.3px;
}
.intel-use-case-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.intel-use-case-item {
  background: rgba(30, 40, 60, 0.5);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 12px;
  padding: 16px;
}
.intel-use-case-item .label {
  display: block;
  font-size: 10px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 8px;
}
.intel-use-case-item p {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.5;
  margin: 0;
}

/* Intel Summary */
.intel-summary {
  margin-bottom: 24px;
}
.intel-summary h3 {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 12px;
}
.intel-summary p {
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.6;
  margin: 0;
}

/* Intel Sidebar Sections */
.intel-sidebar-section {
  margin-bottom: 20px;
}
.intel-sidebar-label {
  display: block;
  font-size: 10px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 6px;
}
.intel-sidebar-value {
  display: block;
  font-size: 13px;
  color: var(--text-primary);
}
.intel-sidebar-link {
  display: inline-block;
  font-size: 13px;
  color: var(--accent-blue);
  text-decoration: none;
  transition: color 0.2s;
}
.intel-sidebar-link:hover {
  color: var(--accent-light);
}
.intel-sidebar-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.intel-sidebar-tag {
  display: inline-block;
  padding: 4px 10px;
  background: rgba(100, 130, 180, 0.15);
  border: 1px solid rgba(100, 130, 180, 0.25);
  border-radius: 12px;
  font-size: 11px;
  color: var(--accent-blue);
}

/* Intel Sidebar Metadata Footer */
.intel-sidebar-meta {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

/* ==========================================
   SESSIONS PAGE
   ========================================== */

.page.sessions-page.active {
  display: flex !important;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  padding: 0 !important;
}
.sessions-header {
  margin-bottom: 0;
  flex-shrink: 0;
  padding: 24px;
  border-bottom: 1px solid var(--glass-border);
}

/* Sessions Split Layout */
.sessions-layout {
  display: flex;
  flex: 1;
  overflow: hidden;
  position: relative;
  z-index: 1;
  width: 100%;
}
/* Ensure help button area is clickable */
.sessions-layout::after {
  content: '';
  position: fixed;
  bottom: 16px;
  right: 16px;
  width: 60px;
  height: 60px;
  pointer-events: none;
  z-index: 9998;
}

/* Sessions Sidebar (Left) */
.sessions-sidebar {
  width: 320px;
  background: var(--bg-secondary);
  border-right: 1px solid var(--glass-border);
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  overflow: hidden;
}
.sessions-sidebar::-webkit-scrollbar {
  width: 8px;
}
.sessions-sidebar::-webkit-scrollbar-track {
  background: rgba(255,255,255,0.04);
}
.sessions-sidebar::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.15);
  border-radius: 4px;
}
.sessions-sidebar::-webkit-scrollbar-thumb:hover {
  background: rgba(255,255,255,0.25);
}
.sessions-sidebar-header {
  padding: 14px 20px;
  border-bottom: 1px solid var(--glass-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.sessions-sidebar-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.btn-icon-sm {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s;
}
.btn-icon-sm:hover {
  background: rgba(255,255,255,0.08);
  color: var(--text-primary);
}
.btn-icon-sm svg {
  width: 16px;
  height: 16px;
}

/* Mini Stats Row */
.sessions-mini-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--glass-border);
  border-bottom: 1px solid var(--glass-border);
}
.sessions-mini-stat {
  padding: 12px 8px;
  background: var(--bg-secondary);
  text-align: center;
}
.sessions-mini-value {
  display: block;
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
}
.sessions-mini-label {
  font-size: 10px;
  font-weight: 600;
  color: var(--text-dim);
  letter-spacing: 0.3px;
}

/* Session Type Filter */
.sessions-type-filter {
  padding: 12px 20px;
  display: flex;
  gap: 6px;
  border-bottom: 1px solid var(--glass-border);
}
.session-type-btn {
  flex: 1;
  padding: 6px 10px;
  border-radius: 6px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
}
.session-type-btn:hover {
  background: rgba(255,255,255,0.08);
  color: var(--text-primary);
}
.session-type-btn.active {
  background: var(--accent-blue);
  color: white;
}

/* Bulk Actions */
.sessions-bulk-actions {
  padding: 12px 20px;
  display: flex;
  gap: 8px;
  border-bottom: 1px solid var(--glass-border);
}
.sessions-bulk-btn {
  flex: 1;
  height: 32px;
  border-radius: 8px;
  border: 1px solid var(--glass-border);
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s;
}
.sessions-bulk-btn:hover {
  background: rgba(255,255,255,0.08);
  color: var(--text-primary);
  border-color: rgba(255,255,255,0.15);
}
.sessions-bulk-btn.pause-mode:hover {
  background: rgba(251, 191, 36, 0.15);
  color: var(--accent-yellow);
  border-color: rgba(251, 191, 36, 0.3);
}
.sessions-bulk-btn.resume-mode:hover {
  background: rgba(52, 211, 153, 0.15);
  color: var(--accent-green);
  border-color: rgba(52, 211, 153, 0.3);
}
.sessions-bulk-btn.danger:hover {
  background: rgba(239, 68, 68, 0.15);
  color: var(--accent-red);
  border-color: rgba(239, 68, 68, 0.3);
}
.sessions-bulk-btn svg {
  width: 14px;
  height: 14px;
}

/* Sessions Stats Row */
.sessions-stats-row {
  display: flex;
  gap: 16px;
  margin-bottom: 24px;
  flex-shrink: 0;
}
.sessions-stat {
  flex: 1;
  padding: 20px;
  background: linear-gradient(
    160deg,
    rgba(50, 60, 80, 0.5) 0%,
    rgba(35, 45, 65, 0.4) 100%
  );
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-top: 1.5px solid rgba(255, 255, 255, 0.15);
  border-radius: 16px;
  text-align: center;
}
.sessions-stat-value {
  display: block;
  font-size: 28px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 4px;
}
.sessions-stat-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted);
  letter-spacing: 0.5px;
}

/* Sessions List */
.sessions-list {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}
.sessions-list::-webkit-scrollbar {
  width: 8px;
}
.sessions-list::-webkit-scrollbar-track {
  background: rgba(255,255,255,0.04);
  border-radius: 4px;
}
.sessions-list::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.15);
  border-radius: 4px;
}
.sessions-list::-webkit-scrollbar-thumb:hover {
  background: rgba(255,255,255,0.25);
}

.sessions-sidebar-footer {
  padding: 12px 20px;
  border-top: 1px solid var(--glass-border);
  font-size: 12px;
  color: var(--text-dim);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.sessions-archive-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
}
.sessions-archive-toggle input {
  cursor: pointer;
}

/* Session List Item (simple) */
.session-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px;
  cursor: pointer;
  transition: background 0.1s;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.session-item:hover {
  background: rgba(255,255,255,0.04);
}
.session-item.active {
  background: rgba(74, 158, 255, 0.12);
}
.session-item .session-status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.session-item-info {
  flex: 1;
  min-width: 0;
}
.session-item-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: flex;
  align-items: center;
  gap: 6px;
}
.session-item-name .star-icon {
  width: 12px;
  height: 12px;
  color: var(--accent-yellow);
}
.session-item-meta {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 2px;
}
.session-item-type {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 4px;
  letter-spacing: 0.3px;
  flex-shrink: 0;
}
.session-item-type.main { background: rgba(74, 158, 255, 0.2); color: var(--accent-blue); }
.session-item-type.spawn { background: rgba(167, 139, 250, 0.2); color: var(--accent-purple); }
.session-item-type.channel { background: rgba(52, 211, 153, 0.2); color: var(--accent-green); }

/* Sessions Detail Panel (Right) */
.sessions-detail {
  flex: 1;
  overflow-y: auto;
  background: var(--bg-primary);
  padding: 24px;
  padding-right: 24px;
  padding-bottom: 80px; /* Space for help button */
}
.sessions-detail-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: var(--text-dim);
}
.sessions-detail-empty svg {
  width: 64px;
  height: 64px;
  margin-bottom: 16px;
  opacity: 0.4;
}
.sessions-detail-empty p {
  font-size: 14px;
}

/* Session Detail Content */
.session-detail-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 24px;
}
.session-detail-title {
  display: flex;
  align-items: center;
  gap: 12px;
}
.session-detail-title h2 {
  font-size: 22px;
  font-weight: 600;
  color: var(--text-primary);
}
.session-detail-status {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--text-muted);
  margin-top: 4px;
}
.session-detail-actions {
  display: flex;
  gap: 8px;
}
.session-detail-btn {
  height: 36px;
  padding: 0 14px;
  border-radius: 8px;
  border: 1px solid var(--glass-border);
  background: transparent;
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: all 0.15s;
}
.session-detail-btn:hover {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.15);
  color: var(--text-primary);
}
.session-detail-btn.pause-btn:hover {
  background: rgba(251, 191, 36, 0.15);
  border-color: rgba(251, 191, 36, 0.3);
  color: var(--accent-yellow);
}
.session-detail-btn.resume-btn:hover {
  background: rgba(52, 211, 153, 0.15);
  border-color: rgba(52, 211, 153, 0.3);
  color: var(--accent-green);
}
.session-detail-btn.primary {
  background: var(--accent-blue);
  border-color: var(--accent-blue);
  color: white;
}
.session-detail-btn.primary:hover {
  background: #3b8bff;
}
.session-detail-btn.danger:hover {
  background: rgba(239, 68, 68, 0.15);
  border-color: rgba(239, 68, 68, 0.3);
  color: var(--accent-red);
}
.session-detail-btn svg {
  width: 14px;
  height: 14px;
}

/* Session Stats Grid */
.session-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 24px;
}
.session-stat-card {
  padding: 16px;
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  text-align: center;
}
.session-stat-card-value {
  font-size: 24px;
  font-weight: 700;
  color: var(--text-primary);
}
.session-stat-card-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-dim);
  margin-top: 4px;
  letter-spacing: 0.5px;
}

/* Session Info Section */
.session-info-section {
  margin-bottom: 24px;
}
.session-info-section h3 {
  font-size: 12px;
  font-weight: 700;
  color: var(--text-dim);
  letter-spacing: 1px;
  margin-bottom: 12px;
}
.session-info-row {
  display: flex;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.session-info-row:last-child {
  border-bottom: none;
}
.session-info-label {
  font-size: 13px;
  color: var(--text-muted);
}
.session-info-value {
  font-size: 13px;
  color: var(--text-secondary);
  font-weight: 500;
}
.session-info-value.session-model-editable {
  cursor: pointer;
  display: flex;
  align-items: center;
  transition: color 0.15s;
}
.session-info-value.session-model-editable:hover {
  color: var(--accent-blue);
}
.session-info-value.session-model-editable:hover svg {
  opacity: 1 !important;
}

/* Transcript Preview */
.session-transcript {
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  overflow: hidden;
}
.session-transcript-header {
  padding: 12px 16px;
  border-bottom: 1px solid var(--glass-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.session-transcript-header h3 {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
}
.session-transcript-body {
  padding: 16px;
  max-height: 300px;
  overflow-y: auto;
}
.transcript-message {
  margin-bottom: 16px;
}
.transcript-message:last-child {
  margin-bottom: 0;
}
.transcript-message.user {
  text-align: right;
}
.transcript-bubble {
  display: inline-block;
  max-width: 80%;
  padding: 10px 14px;
  border-radius: 12px;
  font-size: 13px;
  line-height: 1.4;
}
.transcript-message.user .transcript-bubble {
  background: var(--accent-blue);
  color: white;
  border-bottom-right-radius: 4px;
}
.transcript-message.agent .transcript-bubble {
  background: var(--bg-secondary);
  color: var(--text-secondary);
  border-bottom-left-radius: 4px;
}
.transcript-sender {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted);
  margin-bottom: 4px;
}
.transcript-message.user .transcript-sender {
  text-align: right;
}
.transcript-time {
  font-size: 10px;
  color: var(--text-dim);
  margin-top: 4px;
}

.session-status-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.session-status-dot.active {
  background: var(--accent-green);
  box-shadow: 0 0 8px var(--accent-green);
}
.session-status-dot.idle {
  background: var(--accent-yellow);
}
.session-status-dot.running {
  background: var(--accent-purple);
  box-shadow: 0 0 8px var(--accent-purple);
  animation: pulse 2s infinite;
}
.session-status-dot.paused {
  background: var(--accent-orange);
}
.session-status-dot.ended {
  background: var(--text-dim);
}

/* Utilization colors */
.session-stat-value.util-high { color: var(--accent-green); }
.session-stat-value.util-medium { color: var(--accent-yellow); }
.session-stat-value.util-low { color: var(--text-muted); }

/* Starred sessions */
.session-card.starred {
  border-color: rgba(251, 191, 36, 0.3);
  border-top-color: rgba(251, 191, 36, 0.5);
}
.session-card .star-icon {
  width: 14px;
  height: 14px;
  color: var(--accent-yellow);
  margin-right: 4px;
  flex-shrink: 0;
}
.session-action-btn.active {
  color: var(--accent-yellow);
  border-color: rgba(251, 191, 36, 0.3);
}

.session-info {
  flex: 1;
  min-width: 0;
}
.session-name {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.session-type-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 4px;
  letter-spacing: 0.5px;
}
.session-type-badge.main {
  background: rgba(74, 158, 255, 0.2);
  color: var(--accent-blue);
}
.session-type-badge.spawn {
  background: rgba(167, 139, 250, 0.2);
  color: var(--accent-purple);
}
.session-type-badge.channel {
  background: rgba(52, 211, 153, 0.2);
  color: var(--accent-green);
}
.session-meta {
  font-size: 13px;
  color: var(--text-muted);
}
.session-meta span {
  margin-right: 12px;
}

.session-stats {
  display: flex;
  gap: 20px;
  flex-shrink: 0;
}
.session-stat-item {
  text-align: right;
}
.session-stat-value {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-secondary);
}
.session-stat-label {
  font-size: 11px;
  color: var(--text-dim);
}

.session-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}
.session-action-btn {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.05);
  color: var(--text-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s;
}
.session-action-btn:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--text-primary);
}
.session-action-btn.danger:hover {
  background: rgba(239, 68, 68, 0.2);
  color: var(--accent-red);
  border-color: rgba(239, 68, 68, 0.3);
}
.session-action-btn svg {
  width: 14px;
  height: 14px;
}

/* Empty State */
.sessions-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 20px;
  color: var(--text-dim);
}
.sessions-empty svg {
  width: 48px;
  height: 48px;
  margin-bottom: 16px;
  opacity: 0.5;
}
.sessions-empty p {
  font-size: 14px;
}

/* Model Select Modal */
.model-select-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
}
.model-select-modal {
  background: var(--bg-card);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 24px;
  width: 400px;
  max-width: 90vw;
}
.model-select-modal h3 {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 8px;
}
.model-select-options {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 20px;
  max-height: 400px;
  overflow-y: auto;
}
.model-provider-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-dim);
  letter-spacing: 0.5px;
  padding: 12px 0 6px 4px;
  margin-top: 8px;
}
.model-provider-label:first-child {
  margin-top: 0;
  padding-top: 0;
}
.model-select-option {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: var(--bg-secondary);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.15s;
}
.model-select-option:hover {
  border-color: rgba(255, 255, 255, 0.15);
}
.model-select-option.selected {
  border-color: var(--accent-blue);
  background: rgba(74, 158, 255, 0.1);
}
.model-select-radio {
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent-blue);
  font-size: 14px;
}
.model-select-info {
  flex: 1;
}
.model-select-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
}
.model-select-desc {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 2px;
}
.model-select-hint {
  font-size: 12px;
  color: var(--text-dim);
  margin-bottom: 16px;
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 8px;
  border-left: 3px solid var(--accent-blue);
}
.model-select-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}

/* ==========================================
   WEEKLY RECAPS PAGE
   ========================================== */

.recaps-page {
  padding: 24px;
}

.recaps-layout {
  display: flex;
  gap: 24px;
  height: calc(100vh - 180px);
}

/* Recaps Timeline (Left) */
.recaps-timeline {
  width: 320px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  background: var(--glass-bg);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  overflow: hidden;
  position: relative;
}
.recaps-timeline::before {
  content: '';
  position: absolute;
  top: 0;
  left: 10%;
  right: 10%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  border-radius: 1px;
}

.recaps-timeline-header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--glass-border);
}
.recaps-timeline-header h3 {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.recaps-list {
  flex: 1;
  overflow-y: auto;
  padding: 12px;
}
.recaps-list::-webkit-scrollbar { width: 6px; }
.recaps-list::-webkit-scrollbar-track { background: transparent; }
.recaps-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 3px; }

.recap-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  margin-bottom: 8px;
  background: var(--bg-secondary);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.15s;
  position: relative;
}
.recap-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: 15%;
  right: 15%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent);
  border-radius: 1px;
}
.recap-item:hover {
  background: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.12);
}
.recap-item.active {
  background: rgba(74, 158, 255, 0.12);
  border-color: rgba(74, 158, 255, 0.3);
}

.recap-item-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-purple));
  border-radius: 10px;
  flex-shrink: 0;
}
.recap-item-icon svg {
  width: 20px;
  height: 20px;
  color: white;
}

.recap-item-info {
  flex: 1;
  min-width: 0;
}
.recap-item-week {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 2px;
}
.recap-item-date {
  font-size: 12px;
  color: var(--text-dim);
}

.recap-item-badge {
  font-size: 11px;
  padding: 4px 8px;
  background: rgba(52, 211, 153, 0.15);
  color: var(--accent-green);
  border-radius: 6px;
  font-weight: 500;
}

/* Recap Detail (Right) */
.recap-detail {
  flex: 1;
  overflow-y: auto;
  background: var(--glass-bg);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  position: relative;
}
.recap-detail::before {
  content: '';
  position: absolute;
  top: 0;
  left: 10%;
  right: 10%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  border-radius: 1px;
}

.recap-detail-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: var(--text-dim);
  gap: 12px;
}

.recap-detail-content {
  padding: 24px;
}

.recap-header {
  margin-bottom: 24px;
}
.recap-header-title {
  font-size: 24px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 4px;
}
.recap-header-subtitle {
  font-size: 14px;
  color: var(--text-dim);
}

/* Recap Stats Grid */
.recap-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 24px;
}

.recap-stat-card {
  background: var(--bg-secondary);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  padding: 16px;
  position: relative;
}
.recap-stat-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 20%;
  right: 20%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
}
.recap-stat-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 8px;
}
.recap-stat-value {
  font-size: 28px;
  font-weight: 700;
  color: var(--text-primary);
}
.recap-stat-change {
  font-size: 12px;
  margin-top: 4px;
}
.recap-stat-change.up { color: var(--accent-green); }
.recap-stat-change.down { color: var(--accent-red); }

/* Recap Sections */
.recap-section {
  margin-bottom: 24px;
}
.recap-section-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.recap-section-title svg {
  width: 16px;
  height: 16px;
  opacity: 0.6;
}

.recap-highlights {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.recap-highlight {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: var(--bg-secondary);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
}
.recap-highlight-icon {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(52, 211, 153, 0.15);
  border-radius: 8px;
  color: var(--accent-green);
}
.recap-highlight-icon svg {
  width: 16px;
  height: 16px;
}
.recap-highlight-text {
  flex: 1;
  font-size: 14px;
  color: var(--text-primary);
}
.recap-highlight-meta {
  font-size: 12px;
  color: var(--text-dim);
}

/* Recap Activity Chart */
.recap-activity-chart {
  display: flex;
  gap: 4px;
  height: 80px;
  align-items: flex-end;
  padding: 16px;
  background: var(--bg-secondary);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
}
.recap-activity-bar {
  flex: 1;
  background: linear-gradient(to top, var(--accent-blue), var(--accent-purple));
  border-radius: 4px 4px 0 0;
  min-height: 8px;
  opacity: 0.8;
  transition: opacity 0.15s;
}
.recap-activity-bar:hover {
  opacity: 1;
}

/* ==========================================
   JOURNAL PAGE
   ========================================== */

.journal-page {
  padding: 24px;
}

.journal-layout {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.journal-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.journal-filters {
  display: flex;
  gap: 8px;
}
.journal-filter-btn {
  padding: 8px 14px;
  background: var(--bg-secondary);
  border: 1px solid var(--glass-border);
  border-radius: 8px;
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
}
.journal-filter-btn:hover {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.12);
}
.journal-filter-btn.active {
  background: rgba(74, 158, 255, 0.15);
  border-color: rgba(74, 158, 255, 0.3);
  color: var(--accent-blue);
}

.journal-search {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 18px;
  background: var(--bg-card);
  border: 1px solid var(--glass-border-light);
  border-radius: 10px;
  width: 340px;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.journal-search:focus-within {
  border-color: var(--accent-blue);
  box-shadow: 0 0 0 3px rgba(74, 158, 255, 0.15);
}
.journal-search svg {
  width: 18px;
  height: 18px;
  color: var(--text-secondary);
  flex-shrink: 0;
}
.journal-search input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  color: var(--text-primary);
  font-size: 14px;
}
.journal-search input::placeholder {
  color: var(--text-secondary);
}

/* Journal Timeline */
.journal-timeline {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.journal-date-group {
  margin-bottom: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.journal-date-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 12px;
  padding-left: 4px;
}

.journal-entry {
  display: flex;
  gap: 16px;
  padding: 16px 20px;
  background: var(--glass-bg);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--glass-border);
  border-radius: 14px;
  position: relative;
  transition: all 0.15s;
}
.journal-entry::before {
  content: '';
  position: absolute;
  top: 0;
  left: 10%;
  right: 10%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
  border-radius: 1px;
}
.journal-entry:hover {
  border-color: rgba(255,255,255,0.12);
  transform: translateY(-1px);
}

.journal-entry-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  flex-shrink: 0;
  font-size: 18px;
}
.journal-entry-icon.memory { background: rgba(167, 139, 250, 0.15); }
.journal-entry-icon.decision { background: rgba(251, 191, 36, 0.15); }
.journal-entry-icon.learning { background: rgba(52, 211, 153, 0.15); }
.journal-entry-icon.note { background: rgba(74, 158, 255, 0.15); }

.journal-entry-content {
  flex: 1;
  min-width: 0;
}
.journal-entry-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}
.journal-entry-type {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 3px 8px;
  border-radius: 4px;
}
.journal-entry-type.memory { background: rgba(167, 139, 250, 0.2); color: var(--accent-purple); }
.journal-entry-type.decision { background: rgba(251, 191, 36, 0.2); color: var(--accent-yellow); }
.journal-entry-type.learning { background: rgba(52, 211, 153, 0.2); color: var(--accent-green); }
.journal-entry-type.note { background: rgba(74, 158, 255, 0.2); color: var(--accent-blue); }

.journal-entry-time {
  font-size: 12px;
  color: var(--text-dim);
}
.journal-entry-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 4px;
}
.journal-entry-text {
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.5;
}
.journal-entry-tags {
  display: flex;
  gap: 6px;
  margin-top: 10px;
}
.journal-entry-tag {
  font-size: 11px;
  padding: 3px 8px;
  background: rgba(255,255,255,0.05);
  border-radius: 4px;
  color: var(--text-dim);
}

.journal-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 20px;
  color: var(--text-dim);
  gap: 12px;
}
.journal-empty svg {
  width: 48px;
  height: 48px;
  opacity: 0.3;
}

/* ==========================================
   Task Assignment Modal - Workforce System
   ========================================== */

/* Modal Overlay */
#taskAssignModal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(4px);
  z-index: 9999;
  align-items: center;
  justify-content: center;
}

#taskAssignModal.active {
  display: flex;
}

.task-assign-modal {
  background: var(--bg-secondary);
  border-radius: 12px;
  width: 90%;
  max-width: 500px;
  max-height: 90vh;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
  border: 1px solid var(--border);
}

.task-assign-modal .modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
}

.task-assign-modal .modal-header h2 {
  font-size: 18px;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
}

.task-assign-modal .modal-close {
  background: none;
  border: none;
  font-size: 24px;
  color: var(--text-dim);
  cursor: pointer;
  padding: 0;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  transition: all 0.2s;
}

.task-assign-modal .modal-close:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--text-primary);
}

.task-assign-modal .modal-body {
  padding: 20px;
  overflow-y: auto;
  max-height: calc(90vh - 140px);
}

.task-assign-modal .form-group {
  margin-bottom: 16px;
}

.task-assign-modal .form-group label {
  display: block;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-secondary);
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.task-assign-modal .form-group input,
.task-assign-modal .form-group textarea,
.task-assign-modal .form-group select {
  width: 100%;
  padding: 10px 12px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text-primary);
  font-size: 14px;
  font-family: inherit;
  transition: all 0.2s;
}

.task-assign-modal .form-group input:focus,
.task-assign-modal .form-group textarea:focus,
.task-assign-modal .form-group select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.2);
}

.task-assign-modal .form-group textarea {
  resize: vertical;
  min-height: 100px;
}

.task-assign-modal .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.task-assign-modal .modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding: 16px 20px;
  border-top: 1px solid var(--border);
  background: var(--bg-tertiary);
}

/* Agent Badge in Modal */
.agent-badge {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 12px;
  background: var(--bg-tertiary);
  border-radius: 8px;
  border: 1px solid var(--border);
}

.agent-badge .agent-name {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
}

.agent-badge .agent-role {
  font-size: 12px;
  color: var(--text-secondary);
}

.agent-badge.architect {
  border-left: 3px solid #3b82f6;
}

.agent-badge.scout {
  border-left: 3px solid #10b981;
}

.agent-badge.defender {
  border-left: 3px solid #f59e0b;
}

/* Assign Task Button */
.assign-task-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 16px;
  width: 100%;
  padding: 12px 20px;
  font-size: 14px;
  font-weight: 500;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s;
}

.assign-task-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.assign-task-btn svg {
  flex-shrink: 0;
}

/* Notifications */
#notificationContainer {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.notification {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 16px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
  animation: slideIn 0.3s ease;
  min-width: 280px;
}

.notification.success {
  border-left: 3px solid #10b981;
}

.notification.error {
  border-left: 3px solid #ef4444;
}

.notification.info {
  border-left: 3px solid #3b82f6;
}

.notification span {
  font-size: 14px;
  color: var(--text-primary);
}

.notification button {
  background: none;
  border: none;
  color: var(--text-dim);
  font-size: 18px;
  cursor: pointer;
  padding: 0;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
}

.notification button:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--text-primary);
}

@keyframes slideIn {
  from {
    opacity: 0;
    transform: translateX(20px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

/* Agent Status Colors */
.roster-item-status.working,
.detail-status.working .status-dot,
.chat-agent-status.working {
  background: #f59e0b !important;
}

.detail-status.working {
  color: #f59e0b;
}

/* ==========================================
   Real-Time Connection Indicators
   ========================================== */

/* Connection Status Indicator */
.connection-indicator {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 500;
  transition: all 0.3s ease;
}

.connection-indicator.connected {
  background: rgba(34, 197, 94, 0.15);
  color: #22c55e;
}

.connection-indicator.disconnected {
  background: rgba(239, 68, 68, 0.15);
  color: #ef4444;
}

.connection-indicator::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}

.connection-indicator.connected::before {
  animation: pulse-dot 2s infinite;
}

@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.5; transform: scale(1.2); }
}

/* Refresh Indicator */
.refresh-indicator {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  border-radius: 12px;
  font-size: 11px;
  background: rgba(59, 130, 246, 0.1);
  color: var(--text-dim);
  opacity: 0;
  transform: translateY(-5px);
  transition: all 0.3s ease;
}

.refresh-indicator.active {
  opacity: 1;
  transform: translateY(0);
  color: #3b82f6;
  background: rgba(59, 130, 246, 0.15);
}

.refresh-indicator .refresh-icon {
  width: 12px;
  height: 12px;
  animation: spin 1s linear infinite;
}

.refresh-indicator.active .refresh-icon {
  animation: spin 0.5s linear;
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

/* SSE Heartbeat Dot */
.sse-heartbeat-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #22c55e;
  transition: all 0.3s ease;
}

.sse-heartbeat-dot.pulse {
  animation: heartbeat-pulse 0.5s ease;
}

@keyframes heartbeat-pulse {
  0% { transform: scale(1); box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.7); }
  50% { transform: scale(1.3); box-shadow: 0 0 0 8px rgba(34, 197, 94, 0); }
  100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(34, 197, 94, 0); }
}

/* Data Card Refresh Animation */
.stat-card.refreshing,
.session-item.refreshing,
[data-refresh-type].refreshing {
  animation: data-refresh 0.5s ease;
}

@keyframes data-refresh {
  0% { opacity: 1; }
  30% { opacity: 0.6; background: rgba(59, 130, 246, 0.05); }
  100% { opacity: 1; }
}

/* Real-Time Status Bar - Hidden, using title bar indicator instead */
.realtime-status-bar {
  display: none !important;
}

.realtime-status-bar .status-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text-dim);
}

.realtime-status-bar .status-item.active {
  color: #22c55e;
}

.realtime-status-bar .status-label {
  color: var(--text-muted);
}

.realtime-status-bar .status-value {
  font-weight: 500;
  color: var(--text-primary);
}

/* Last Updated Badge */
.last-updated-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  border-radius: 6px;
  background: var(--bg-tertiary);
  font-size: 10px;
  color: var(--text-dim);
}

.last-updated-badge .update-time {
  font-weight: 500;
}

/* Connection Mode Chip */
.connection-mode-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.connection-mode-chip.sse {
  background: rgba(168, 85, 247, 0.15);
  color: #a855f7;
}

.connection-mode-chip.polling {
  background: rgba(251, 191, 36, 0.15);
  color: #fbbf24;
}

/* Toolbar Connection Info */
.toolbar-connection-info {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-left: auto;
}

.toolbar-connection-info .divider {
  width: 1px;
  height: 16px;
  background: var(--glass-border);
}
