/* CrowdSec Dashboard - Classic Theme */ /* Professional SOC-style dark theme */ /* Theme-specific variables */ .cs-dashboard.theme-classic { --cs-bg-primary: #0d1117; --cs-bg-secondary: #161b22; --cs-bg-tertiary: #21262d; --cs-border: #30363d; --cs-accent: #58a6ff; } /* Header */ .theme-classic .cs-header { display: flex; justify-content: space-between; align-items: center; padding: var(--cs-space-md); border-bottom: 1px solid var(--cs-border); margin-bottom: var(--cs-space-lg); } .theme-classic .cs-title { font-size: var(--cs-font-size-xl); font-weight: 600; display: flex; align-items: center; gap: var(--cs-space-sm); } .theme-classic .cs-title svg { width: 28px; height: 28px; fill: var(--cs-accent); } .theme-classic .cs-status { display: flex; align-items: center; gap: var(--cs-space-sm); font-size: var(--cs-font-size-xs); text-transform: uppercase; letter-spacing: 0.5px; } .theme-classic .cs-status-dot { width: 8px; height: 8px; border-radius: 50%; animation: cs-pulse 2s infinite; } .theme-classic .cs-status-dot.online { background: var(--cs-success); } .theme-classic .cs-status-dot.offline { background: var(--cs-danger); animation: none; } /* Navigation */ .theme-classic .cs-nav { display: flex; gap: var(--cs-space-xs); margin-bottom: var(--cs-space-lg); border-bottom: 1px solid var(--cs-border); padding-bottom: var(--cs-space-sm); } .theme-classic .cs-nav a { color: var(--cs-text-muted); text-decoration: none; padding: var(--cs-space-sm) var(--cs-space-md); border-radius: var(--cs-radius-sm); font-size: var(--cs-font-size-sm); transition: all var(--cs-transition-fast); } .theme-classic .cs-nav a:hover { color: var(--cs-text); background: var(--cs-bg-secondary); } .theme-classic .cs-nav a.active { color: var(--cs-accent); background: rgba(88, 166, 255, 0.1); } /* Stats Grid */ .theme-classic .cs-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: var(--cs-space-sm); margin-bottom: var(--cs-space-lg); } .theme-classic .cs-stat { background: var(--cs-bg-secondary); border: 1px solid var(--cs-border); border-radius: var(--cs-radius-md); padding: var(--cs-space-md); text-align: center; } .theme-classic .cs-stat-value { font-size: var(--cs-font-size-2xl); font-weight: 700; font-family: var(--cs-font-mono); color: var(--cs-accent); } .theme-classic .cs-stat-label { font-size: var(--cs-font-size-xs); text-transform: uppercase; letter-spacing: 0.5px; color: var(--cs-text-muted); margin-top: var(--cs-space-xs); } .theme-classic .cs-stat.danger .cs-stat-value { color: var(--cs-danger); } .theme-classic .cs-stat.warning .cs-stat-value { color: var(--cs-warning); } .theme-classic .cs-stat.success .cs-stat-value { color: var(--cs-success); } /* Cards */ .theme-classic .cs-card { background: var(--cs-bg-secondary); border: 1px solid var(--cs-border); border-radius: var(--cs-radius-md); margin-bottom: var(--cs-space-md); } .theme-classic .cs-card-header { padding: var(--cs-space-sm) var(--cs-space-md); border-bottom: 1px solid var(--cs-border); font-size: var(--cs-font-size-sm); font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; display: flex; justify-content: space-between; align-items: center; } .theme-classic .cs-card-body { padding: var(--cs-space-md); } /* Tables */ .theme-classic .cs-table { width: 100%; border-collapse: collapse; font-size: var(--cs-font-size-sm); } .theme-classic .cs-table th { text-align: left; padding: var(--cs-space-sm); background: var(--cs-bg-primary); color: var(--cs-text-muted); font-weight: 500; font-size: var(--cs-font-size-xs); text-transform: uppercase; letter-spacing: 0.5px; border-bottom: 1px solid var(--cs-border); } .theme-classic .cs-table td { padding: var(--cs-space-sm); border-bottom: 1px solid var(--cs-border); } .theme-classic .cs-table tr:last-child td { border-bottom: none; } .theme-classic .cs-table tr:hover { background: rgba(88, 166, 255, 0.05); } /* Grid layouts */ .theme-classic .cs-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--cs-space-md); } @media (max-width: 900px) { .theme-classic .cs-grid-2 { grid-template-columns: 1fr; } } /* Health Check */ .theme-classic .cs-health { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--cs-space-sm); } .theme-classic .cs-health-item { display: flex; align-items: center; gap: var(--cs-space-sm); padding: var(--cs-space-sm); background: var(--cs-bg-primary); border-radius: var(--cs-radius-sm); } .theme-classic .cs-health-icon { width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 14px; } .theme-classic .cs-health-icon.ok { background: rgba(63, 185, 80, 0.2); color: var(--cs-success); } .theme-classic .cs-health-icon.error { background: rgba(248, 81, 73, 0.2); color: var(--cs-danger); } /* Empty state */ .theme-classic .cs-empty { text-align: center; padding: var(--cs-space-xl); color: var(--cs-text-muted); } .theme-classic .cs-empty-icon { font-size: 32px; margin-bottom: var(--cs-space-sm); opacity: 0.5; } /* Buttons */ .theme-classic .cs-btn { background: var(--cs-bg-secondary); border: 1px solid var(--cs-border); color: var(--cs-text); padding: 6px 12px; border-radius: var(--cs-radius-sm); font-size: var(--cs-font-size-sm); cursor: pointer; transition: all var(--cs-transition-fast); } .theme-classic .cs-btn:hover { background: var(--cs-border); border-color: var(--cs-text-muted); } .theme-classic .cs-btn-sm { padding: 3px 8px; font-size: var(--cs-font-size-xs); }