/* ═══ Tokens ═══ */
:root {
    --bg-primary: #0a0a0f;
    --glass-bg: rgba(255, 255, 255, 0.04);
    --glass-border: rgba(255, 255, 255, 0.08);
    --text-primary: #e8e8ed;
    --text-secondary: #8b8b9e;
    --accent-1: #6366f1;
    --accent-2: #8b5cf6;
    --accent-3: #06b6d4;
    --accent-4: #f59e0b;
    --success: #10b981;
    --danger: #ef4444;
    --font-heading: 'Outfit', sans-serif;
    --font-body: 'Inter', sans-serif;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

body {
    font-family: var(--font-body); background: var(--bg-primary);
    color: var(--text-primary); min-height: 100vh; overflow-x: hidden;
}

/* ═══ BG Blobs ═══ */
.background-blobs { position: fixed; inset: 0; z-index: -1; overflow: hidden; }
.blob { position: absolute; border-radius: 50%; filter: blur(120px); opacity: 0.1; animation: blobFloat 20s ease-in-out infinite alternate; }
.blob-1 { width: 500px; height: 500px; background: var(--accent-1); top: -10%; left: -5%; }
.blob-2 { width: 400px; height: 400px; background: var(--accent-2); bottom: -10%; right: -5%; animation-delay: -7s; }
.blob-3 { width: 350px; height: 350px; background: var(--accent-3); top: 40%; left: 50%; animation-delay: -14s; }
@keyframes blobFloat { 0% { transform: translate(0,0) scale(1); } 100% { transform: translate(60px,40px) scale(1.15); } }

/* ═══ Layout ═══ */
.container { max-width: 1400px; margin: 0 auto; padding: 0.6rem 1rem; display: flex; flex-direction: column; gap: 0.6rem; }

/* ═══ Header ═══ */
.header { display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--glass-border); padding-bottom: 0.4rem; }
.branding { display: flex; align-items: center; gap: 0.5rem; }
.logo-icon { width: 26px; height: 26px; border-radius: 7px; background: linear-gradient(135deg, var(--accent-1), var(--accent-2)); box-shadow: 0 0 14px rgba(99,102,241,0.4); }
h1 { font-family: var(--font-heading); font-size: 1.2rem; font-weight: 700; background: linear-gradient(135deg, var(--text-primary), var(--accent-3)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.header-badges { display: flex; gap: 0.4rem; align-items: center; flex-wrap: wrap; }
.status-indicator { display: flex; align-items: center; gap: 0.3rem; font-size: 0.7rem; font-weight: 500; color: var(--text-secondary); background: var(--glass-bg); border: 1px solid var(--glass-border); padding: 0.2rem 0.55rem; border-radius: 14px; white-space: nowrap; }
.fps-badge { background: linear-gradient(135deg, rgba(16,185,129,0.08), rgba(16,185,129,0.15)); border-color: rgba(16,185,129,0.25); color: #10b981; font-weight: 700; }
.speed-badge { background: linear-gradient(135deg, rgba(99,102,241,0.08), rgba(99,102,241,0.15)); border-color: rgba(99,102,241,0.25); color: #818cf8; font-weight: 600; }
.eta-badge { background: linear-gradient(135deg, rgba(245,158,11,0.08), rgba(245,158,11,0.15)); border-color: rgba(245,158,11,0.25); color: #f59e0b; font-weight: 600; }
.dot { width: 6px; height: 6px; border-radius: 50%; background: var(--danger); }
.dot.active { background: var(--success); box-shadow: 0 0 8px rgba(16,185,129,0.6); }

/* ═══ Stats Row ═══ */
.stats-row { display: flex; gap: 0.4rem; flex-wrap: wrap; }
.stat-card.mini { flex: 1; min-width: 110px; background: var(--glass-bg); border: 1px solid var(--glass-border); padding: 0.4rem 0.6rem; border-radius: 7px; display: flex; flex-direction: column; gap: 0.1rem; }
.stat-card.mini .stat-label { font-size: 0.6rem; text-transform: uppercase; letter-spacing: 0.7px; color: var(--text-secondary); font-weight: 600; }
.stat-card.mini .stat-value { font-family: var(--font-heading); font-size: 0.95rem; font-weight: 600; }
.accent-green { color: var(--success) !important; }
.accent-purple { color: var(--accent-2) !important; }
.accent-cyan { color: var(--accent-3) !important; }

/* ═══ System Stats ═══ */
.sys-row { display: flex; gap: 0.4rem; flex-wrap: wrap; }
.sys-card { flex: 1; min-width: 180px; background: var(--glass-bg); border: 1px solid var(--glass-border); padding: 0.35rem 0.6rem; border-radius: 7px; display: flex; align-items: center; gap: 0.5rem; }
.sys-label { font-size: 0.65rem; font-weight: 600; color: var(--text-secondary); text-transform: uppercase; min-width: 50px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sys-bar-wrap { flex: 1; height: 8px; background: rgba(255,255,255,0.06); border-radius: 4px; overflow: hidden; }
.sys-bar-fill { height: 100%; border-radius: 4px; transition: width 1s ease-out; }
.sys-pct { font-size: 0.65rem; font-weight: 600; color: var(--text-primary); min-width: 40px; text-align: right; white-space: nowrap; }

/* ═══ Glass Panel ═══ */
.glass-panel { background: var(--glass-bg); border: 1px solid var(--glass-border); box-shadow: 0 4px 16px rgba(0,0,0,0.1); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border-radius: 10px; padding: 0.7rem; }
h2 { font-family: var(--font-heading); font-size: 0.9rem; font-weight: 600; margin-bottom: 0.5rem; display: flex; align-items: center; gap: 0.4rem; }
.badge { background: var(--accent-1); color: white; font-size: 0.6rem; padding: 0.1rem 0.4rem; border-radius: 10px; font-weight: 700; }
.section-header { display: flex; justify-content: space-between; align-items: center; }
.export-btn { font-size: 0.7rem; color: var(--accent-3); text-decoration: none; padding: 0.15rem 0.5rem; border: 1px solid rgba(6,182,212,0.2); border-radius: 6px; background: rgba(6,182,212,0.08); transition: background 0.2s; }
.export-btn:hover { background: rgba(6,182,212,0.2); }

/* ═══ Active Cards ═══ */
.active-card { background: rgba(0,0,0,0.2); border: 1px solid var(--glass-border); border-radius: 8px; padding: 0.6rem; margin-bottom: 0.4rem; animation: fadeIn 0.3s ease-out; }
.active-card:last-child { margin-bottom: 0; }
@keyframes fadeIn { from { opacity:0; transform:translateY(5px); } to { opacity:1; transform:translateY(0); } }
.ac-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.35rem; }
.ac-name { display: flex; align-items: center; gap: 0.35rem; font-size: 0.85rem; font-weight: 600; word-break: break-all; line-height: 1.2; }
.pulse-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--text-secondary); flex-shrink: 0; }
.pulse-dot.active { background: var(--success); box-shadow: 0 0 6px rgba(16,185,129,0.5); animation: pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%,100% { opacity:1; } 50% { opacity:0.4; } }
.ac-badges { display: flex; gap: 0.25rem; flex-shrink: 0; }
.pill { font-size: 0.6rem; padding: 0.1rem 0.4rem; border-radius: 8px; font-weight: 600; }
.preset-pill { background: rgba(99,102,241,0.15); color: var(--accent-1); border: 1px solid rgba(99,102,241,0.2); }
.fps-pill { background: rgba(6,182,212,0.15); color: var(--accent-3); border: 1px solid rgba(6,182,212,0.2); }

/* Progress Bar */
.ac-progress-wrap { position: relative; height: 16px; background: rgba(255,255,255,0.05); border-radius: 5px; overflow: hidden; margin-bottom: 0.35rem; }
.ac-progress-fill { height: 100%; border-radius: 5px; background: linear-gradient(90deg, var(--accent-1), var(--accent-3)); transition: width 1.5s ease-out; }
.ac-progress-text { position: absolute; top: 50%; right: 5px; transform: translateY(-50%); font-size: 0.6rem; font-weight: 700; text-shadow: 0 1px 3px rgba(0,0,0,0.6); }

/* Job Stats Row */
.ac-stats { display: flex; gap: 0.3rem; flex-wrap: wrap; }
.ms { flex: 1; min-width: 70px; background: rgba(0,0,0,0.15); border: 1px solid var(--glass-border); padding: 0.25rem 0.4rem; border-radius: 5px; display: flex; flex-direction: column; gap: 0.05rem; }
.ms .l { font-size: 0.55rem; text-transform: uppercase; letter-spacing: 0.4px; color: var(--text-secondary); font-weight: 600; }
.ms .v { font-family: var(--font-heading); font-size: 0.8rem; font-weight: 500; }
.spark-cell { min-width: 130px; }
.sparkline { display: block; }

/* ═══ Split Layout ═══ */
.split-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 0.6rem; }

/* ═══ Lists ═══ */
.job-list { list-style: none; display: flex; flex-direction: column; gap: 0.25rem; max-height: 220px; overflow-y: auto; padding-right: 0.3rem; }
.job-list::-webkit-scrollbar { width: 4px; }
.job-list::-webkit-scrollbar-track { background: transparent; }
.job-list::-webkit-scrollbar-thumb { background: var(--glass-border); border-radius: 10px; }
.list-item { background: rgba(0,0,0,0.12); border: 1px solid var(--glass-border); padding: 0.35rem 0.5rem; border-radius: 5px; display: flex; flex-direction: column; gap: 0.1rem; transition: background 0.2s, opacity 0.5s; }
.list-item:hover { background: rgba(255,255,255,0.04); }
.item-title { font-size: 0.75rem; font-weight: 500; word-break: break-all; line-height: 1.2; }
.item-meta { font-size: 0.65rem; color: var(--text-secondary); display: flex; gap: 0.4rem; align-items: center; flex-wrap: wrap; }
.completed-item .cs { color: var(--success); font-weight: 600; }
.completed-item .ca { color: var(--text-secondary); }
.completed-item .cd { color: var(--accent-4); margin-left: auto; }
.empty-state { text-align: center; padding: 0.8rem; color: var(--text-secondary); font-size: 0.75rem; font-style: italic; }

/* ═══ Preset Table ═══ */
.preset-grid { font-size: 0.7rem; }
.preset-header, .preset-row { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr; gap: 0.3rem; padding: 0.3rem 0.4rem; align-items: center; }
.preset-header { font-weight: 700; color: var(--text-secondary); text-transform: uppercase; font-size: 0.6rem; letter-spacing: 0.5px; border-bottom: 1px solid var(--glass-border); margin-bottom: 0.2rem; }
.preset-row { background: rgba(0,0,0,0.1); border-radius: 4px; margin-bottom: 0.15rem; }
.preset-name { font-weight: 600; color: var(--accent-1); }

/* ═══ Daily Chart ═══ */
.chart-container { height: 120px; }
.chart-bars { display: flex; align-items: flex-end; height: 100%; gap: 1px; }
.chart-col { display: flex; flex-direction: column; align-items: center; justify-content: flex-end; height: 100%; }
.chart-bar { width: 100%; background: linear-gradient(180deg, var(--accent-1), var(--accent-2)); border-radius: 2px 2px 0 0; min-height: 2px; transition: height 0.5s ease; }
.chart-col:hover .chart-bar { background: linear-gradient(180deg, var(--accent-3), var(--accent-1)); }
.chart-label { font-size: 0.5rem; color: var(--text-secondary); margin-top: 2px; writing-mode: vertical-rl; transform: rotate(180deg); }

/* ═══ Spinner ═══ */
.no-task-state { display: flex; flex-direction: column; align-items: center; gap: 0.4rem; padding: 0.8rem 0; }
.spinner { width: 24px; height: 24px; border: 3px solid var(--glass-border); border-top-color: var(--accent-1); border-radius: 50%; animation: spin 1s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ═══ Responsive ═══ */
@media (max-width: 800px) {
    .split-layout { grid-template-columns: 1fr; }
    .header { flex-direction: column; gap: 0.4rem; align-items: flex-start; }
    .header-badges { flex-wrap: wrap; }
    .preset-header, .preset-row { grid-template-columns: 2fr 1fr 1fr; }
    .preset-header span:nth-child(n+4), .preset-row span:nth-child(n+4) { display: none; }
}
