@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";
:root{--bg:#0f1117;--surface:#1a1d27;--surface-2:#21253a;--border:#2a2e42;--text:#e2e8f0;--text-muted:#8892a4;--accent:#6366f1;--accent-h:#7c7ff5;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#3b82f6;--purple:#a855f7;--sidebar-w:240px;--header-h:60px;--radius:10px;--shadow:0 1px 3px #0000004d, 0 4px 20px #0003}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100%;font-family:Inter,system-ui,-apple-system,sans-serif}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit}.shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);z-index:20;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.main{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}.topbar{height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:0}.content{flex:1;padding:24px}.sidebar-logo{border-bottom:1px solid var(--border);padding:20px 20px 16px}.sidebar-logo h2{letter-spacing:.02em;font-size:15px;font-weight:700}.sidebar-logo p{color:var(--text-muted);margin-top:3px;font-size:11px}.sidebar-nav{flex:1;padding:12px 10px}.nav-section{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:12px 12px 6px;font-size:10px;font-weight:700}.nav-link{color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:7px;align-items:center;gap:10px;width:100%;padding:9px 12px;font-size:13.5px;font-weight:500;transition:all .12s;display:flex}.nav-link:hover{color:var(--accent);background:#6366f11a}.nav-link.active{color:var(--accent);background:#6366f126}.sidebar-footer{border-top:1px solid var(--border);padding:12px 10px}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.page-header h1{font-size:20px;font-weight:700}.page-header p{color:var(--text-muted);margin-top:3px;font-size:13px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--accent-color,var(--accent));height:2px;position:absolute;top:0;left:0;right:0}.stat-lbl{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:10.5px;font-weight:700}.stat-val{margin-top:6px;font-size:28px;font-weight:800;line-height:1}.stat-sub{color:var(--text-muted);margin-top:5px;font-size:11.5px}.stat-icon{opacity:.7;font-size:18px;position:absolute;top:16px;right:16px}.table-wrap{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}thead th{background:var(--surface-2);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 14px;font-size:10.5px;font-weight:700}tbody td{border-bottom:1px solid var(--border);vertical-align:middle;padding:11px 14px}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:#ffffff05}.badge{white-space:nowrap;border-radius:99px;align-items:center;gap:4px;padding:2px 9px;font-size:11px;font-weight:600;display:inline-flex}.badge-success{color:var(--success);background:#10b98124}.badge-danger{color:var(--danger);background:#ef444424}.badge-warning{color:var(--warning);background:#f59e0b24}.badge-info{color:var(--info);background:#3b82f624}.badge-gray{color:var(--text-muted);background:#8892a424}.badge-purple{color:var(--purple);background:#a855f724}.badge-accent{color:var(--accent);background:#6366f124}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:7px;justify-content:center;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:600;transition:all .12s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-h)}.btn-danger{color:var(--danger);background:#ef444424;border:1px solid #ef444440}.btn-danger:hover:not(:disabled){background:#ef44443d}.btn-ghost{color:var(--text-muted);border:1px solid var(--border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.btn-sm{border-radius:5px;padding:4px 10px;font-size:12px}.btn-icon{padding:6px 8px}.form-group{margin-bottom:15px}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.label{color:var(--text-muted);letter-spacing:.02em;margin-bottom:6px;font-size:11.5px;font-weight:600;display:block}.input,.select{background:var(--surface-2);border:1px solid var(--border);width:100%;color:var(--text);border-radius:7px;outline:none;padding:9px 12px;font-size:13px;transition:border-color .15s}.input:focus,.select:focus{border-color:var(--accent)}.select{cursor:pointer}.search-input{background:var(--surface-2);border:1px solid var(--border);min-width:200px;color:var(--text);border-radius:7px;outline:none;flex:1;padding:8px 12px 8px 34px;font-size:13px}.search-input:focus{border-color:var(--accent)}.search-wrap{position:relative}.search-icon{color:var(--text-muted);pointer-events:none;font-size:14px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.filter-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#000000a6;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:530px;max-width:94vw;max-height:90vh;padding:24px;animation:.2s slideUp;overflow-y:auto;box-shadow:0 24px 64px #00000080}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h3{font-size:16px;font-weight:700}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:24px;padding-top:16px;display:flex}.toast-stack{z-index:200;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:20px;right:20px}.toast{cursor:pointer;border-radius:9px;align-items:center;gap:10px;min-width:240px;padding:12px 18px;font-size:13px;font-weight:600;animation:.2s slideUp;display:flex;box-shadow:0 4px 20px #0000004d}.toast-success{color:#fff;background:#10b981eb}.toast-error{color:#fff;background:#ef4444eb}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}.dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.dot-on{background:var(--success)}.dot-off{background:var(--danger)}.dot-paused{background:var(--warning)}.dot-gray{background:var(--text-muted)}.empty-state{text-align:center;color:var(--text-muted);padding:56px 24px}.empty-state .empty-icon{margin-bottom:12px;font-size:40px}.empty-state p{font-size:14px}.progress-bar{background:var(--border);border-radius:4px;height:6px;overflow:hidden}.progress-fill{border-radius:4px;height:100%;transition:width .4s}code{background:var(--surface-2);color:var(--text-muted);border-radius:4px;padding:2px 6px;font-family:Menlo,Monaco,monospace;font-size:11px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width:768px){.sidebar{transform:translate(-100%)}.main{margin-left:0}.form-row{grid-template-columns:1fr}.stat-grid{grid-template-columns:1fr 1fr}}
