/**
 * Dashboard styles — matches landing page design tokens.
 * Uses same CSS vars from theme.css.
 */

.dash-container { padding: 0 48px 80px; }
.dash-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 40px 0 32px; border-bottom: 1px solid var(--border);
}
.dash-label {
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--accent); font-weight: 600; margin-bottom: 6px;
}
.dash-title {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 32px; font-weight: 800; letter-spacing: -1px;
  color: var(--fg); margin-bottom: 6px;
}
.dash-sub { font-size: 14px; color: var(--fg3); }
.dash-actions { display: flex; gap: 10px; align-items: center; padding-top: 8px; }

.status-bar {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 0; margin-bottom: 24px;
  font-size: 13px; color: var(--fg2);
}
.status-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--fg3); flex-shrink: 0;
}
.status-dot.running { background: #28C840; box-shadow: 0 0 6px #28C840; }
.status-dot.idle { background: var(--accent); }

/* Buttons */
.btn {
  padding: 8px 18px; border-radius: 6px; font-size: 13px;
  font-weight: 500; cursor: pointer; border: none;
  font-family: inherit; transition: opacity 0.15s;
}
.btn:hover { opacity: 0.85; }
.btn-primary { background: var(--accent); color: #000; }
.btn-secondary { background: var(--bg3); color: var(--fg); border: 1px solid var(--border); }

/* Stats row */
.stats-row {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 1px;
  background: var(--border); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden; margin: 24px 0;
}
.stat-card { background: var(--bg2); padding: 24px 20px; }
.stat-label { font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--fg3); margin-bottom: 8px; }
.stat-big { font-family: 'Space Grotesk', sans-serif; font-size: 28px; font-weight: 800; color: var(--fg); }

/* Grid */
.dash-grid { display: grid; grid-template-columns: 1fr 380px; gap: 16px; }

/* Panel */
.panel { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.panel-header { padding: 16px 20px; border-bottom: 1px solid var(--border); }
.panel-title { font-family: 'Space Grotesk', sans-serif; font-size: 14px; font-weight: 700; color: var(--fg); }

/* Table */
.table-wrap { overflow-x: auto; }
.dash-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.dash-table th { padding: 10px 16px; text-align: left; font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--fg3); border-bottom: 1px solid var(--border); white-space: nowrap; }
.dash-table td { padding: 12px 16px; color: var(--fg2); border-bottom: 1px solid var(--border); }
.dash-table tr:last-child td { border-bottom: none; }
.dash-table tr:hover td { background: var(--bg3); }
.dash-table strong { color: var(--fg); font-weight: 600; }

.score-badge { font-family: 'Space Grotesk', monospace; font-weight: 700; }
.status-badge { display: inline-block; padding: 2px 8px; border-radius: 4px; font-size: 11px; font-weight: 600; }
.email-link { color: var(--accent); text-decoration: none; }
.email-link:hover { text-decoration: underline; }

.loading { color: var(--fg3); font-style: italic; }
.empty { color: var(--fg3); text-align: center; padding: 32px; }

/* Activity feed */
.feed { padding: 8px 0; max-height: 400px; overflow-y: auto; }
.feed-item { display: flex; align-items: flex-start; gap: 12px; padding: 10px 20px; border-bottom: 1px solid var(--border); }
.feed-item:last-child { border-bottom: none; }
.feed-icon { font-size: 16px; flex-shrink: 0; margin-top: 2px; }
.feed-body { flex: 1; min-width: 0; }
.feed-event { font-size: 12px; font-weight: 600; color: var(--fg); text-transform: capitalize; }
.feed-detail { font-size: 11px; color: var(--fg3); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.feed-time { font-size: 11px; color: var(--fg3); flex-shrink: 0; }

/* Toast */
.toast { position: fixed; bottom: 24px; right: 24px; padding: 12px 20px; border-radius: 6px; font-size: 13px; font-weight: 500; z-index: 9999; }
.toast-success { background: #28C840; color: #fff; }
.toast-error { background: #FF3B30; color: #fff; }
.toast-info { background: var(--bg3); color: var(--fg); border: 1px solid var(--border); }

@media (max-width: 900px) {
  .dash-container { padding: 0 24px 48px; }
  .stats-row { grid-template-columns: repeat(3, 1fr); }
  .dash-grid { grid-template-columns: 1fr; }
}