/* Jasper Hub — Shared Styles */
:root {
  --bg: #0f1117;
  --bg-card: #1a1d27;
  --bg-card-hover: #222633;
  --border: #2a2e3a;
  --text: #e1e4ed;
  --text-muted: #8b8fa3;
  --accent: #89b4fa;
  --accent-hover: #a6c8ff;
  --success: #a6e3a1;
  --warning: #fab387;
  --error: #f38ba8;
  --purple: #cba6f7;
  --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono: 'JetBrains Mono', 'Fira Code', monospace;
  --radius: 12px;
  --radius-sm: 8px;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: var(--font); background: var(--bg); color: var(--text); line-height: 1.6; min-height: 100vh; }
a { color: var(--accent); text-decoration: none; transition: color 0.2s; }
a:hover { color: var(--accent-hover); }
.container { max-width: 1200px; margin: 0 auto; padding: 2rem; }
.header { display: flex; align-items: center; gap: 1rem; margin-bottom: 2rem; padding-bottom: 1.5rem; border-bottom: 1px solid var(--border); }
.header-icon { font-size: 2.5rem; }
.header h1 { font-size: 1.8rem; font-weight: 700; letter-spacing: -0.02em; }
.header .subtitle { color: var(--text-muted); font-size: 0.9rem; margin-top: 0.2rem; }
nav { display: flex; gap: 0.5rem; margin-bottom: 2rem; }
nav a { padding: 0.5rem 1.2rem; border-radius: var(--radius-sm); background: var(--bg-card); border: 1px solid var(--border); color: var(--text-muted); font-size: 0.85rem; font-weight: 500; transition: all 0.2s; }
nav a:hover, nav a.active { background: var(--bg-card-hover); color: var(--accent); border-color: var(--accent); }
.card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 1.2rem; }
.card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.5rem; transition: all 0.25s ease; position: relative; overflow: hidden; }
.card:hover { background: var(--bg-card-hover); border-color: var(--accent); transform: translateY(-2px); box-shadow: 0 8px 30px rgba(0,0,0,0.3); }
.card-date { font-size: 0.75rem; color: var(--text-muted); font-family: var(--font-mono); margin-bottom: 0.5rem; }
.card h3 { font-size: 1.1rem; font-weight: 600; margin-bottom: 0.5rem; }
.card p { color: var(--text-muted); font-size: 0.85rem; line-height: 1.5; }
.card-tag { display: inline-block; padding: 0.2rem 0.6rem; border-radius: 4px; font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; margin-top: 0.8rem; }
.stats-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; margin-bottom: 2rem; }
.stat-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.2rem 1.5rem; }
.stat-value { font-size: 2rem; font-weight: 700; font-family: var(--font-mono); }
.stat-label { font-size: 0.8rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; }
.table-wrapper { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
table { width: 100%; border-collapse: collapse; }
th { text-align: left; padding: 0.8rem 1.2rem; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-muted); background: var(--bg); border-bottom: 1px solid var(--border); }
td { padding: 0.8rem 1.2rem; font-size: 0.85rem; border-bottom: 1px solid var(--border); }
tr:last-child td { border-bottom: none; }
tr:hover td { background: var(--bg-card-hover); }
.badge { display: inline-block; padding: 0.15rem 0.5rem; border-radius: 4px; font-size: 0.7rem; font-weight: 600; }
.badge-ok { background: #a6e3a120; color: var(--success); }
.badge-error { background: #f38ba820; color: var(--error); }
.badge-pending { background: #fab38720; color: var(--warning); }
.loading { text-align: center; padding: 3rem; color: var(--text-muted); }
@keyframes spin { to { transform: rotate(360deg); } }
@media (max-width: 768px) { .container { padding: 1rem; } .card-grid { grid-template-columns: 1fr; } .header h1 { font-size: 1.4rem; } nav { flex-wrap: wrap; } }
