@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Space+Grotesk:wght@400;500;600;700&display=swap");:root{--primary:#7c3aed;--primary-dark:#5b21b6;--primary-light:#ede9fe;--primary-50:rgba(124,58,237,.06);--primary-10:rgba(124,58,237,.1);--secondary:#06b6d4;--success:#10b981;--success-light:rgba(16,185,129,.12);--danger:#ef4444;--danger-light:rgba(239,68,68,.12);--warning:#f59e0b;--warning-light:rgba(245,158,11,.12);--info:#3b82f6;--info-light:rgba(59,130,246,.12);--pink:#ec4899;--bg:#09090b;--bg-card:#111113;--bg-elevated:#18181b;--bg-hover:#1c1c21;--bg-active:#222228;--bg-surface:#0f0f11;--text:#fafafa;--text-secondary:#a1a1aa;--text-muted:#71717a;--text-dim:#52525b;--border:#27272a;--border-subtle:#1e1e22;--border-hover:#3f3f46;--shadow:0 4px 24px rgba(0,0,0,.5);--shadow-sm:0 1px 3px rgba(0,0,0,.3);--shadow-lg:0 8px 40px rgba(0,0,0,.6);--shadow-glow:0 0 60px rgba(124,58,237,.08);--radius-xs:6px;--radius-sm:8px;--radius-md:10px;--radius-lg:14px;--radius-xl:18px;--radius-2xl:24px;--radius-full:9999px;--font-sans:"Inter",-apple-system,system-ui,sans-serif;--font-display:"Space Grotesk","Inter",sans-serif;--font-mono:"SF Mono","Fira Code",monospace;--ease:cubic-bezier(0.16,1,0.3,1);--ease-spring:cubic-bezier(0.34,1.56,0.64,1);--transition:0.2s var(--ease);--transition-slow:0.4s var(--ease)}*,:after,:before{margin:0;padding:0;box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none}button,input,select,textarea{font-family:var(--font-sans);outline:none}ol,ul{list-style:none}img{max-width:100%;display:block}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);font-weight:600;font-size:13px;transition:all var(--transition);white-space:nowrap;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,hsla(0,0%,100%,.06),transparent);pointer-events:none;opacity:0;transition:opacity var(--transition)}.btn:hover:after{opacity:1}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 1px 3px rgba(124,58,237,.3)}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px rgba(124,58,237,.4)}.btn-outline{background:transparent;color:var(--text-secondary);border:1.5px solid var(--border)}.btn-outline:hover{border-color:var(--border-hover);color:var(--text);background:var(--bg-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#059669}.btn-sm{padding:5px 10px;font-size:12px;border-radius:var(--radius-xs)}.btn-lg{padding:10px 20px;font-size:14px}.btn-full{width:100%}.btn-icon{padding:7px;width:32px;height:32px}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.form-group{margin-bottom:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}.form-hint{font-size:11px;color:var(--text-muted);margin-top:4px}.form-input{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:13px;background:var(--bg-surface);color:var(--text);transition:all var(--transition)}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(124,58,237,.12);background:var(--bg-elevated)}.form-input::placeholder{color:var(--text-dim)}.form-input.error{border-color:var(--danger);box-shadow:0 0 0 3px rgba(239,68,68,.12)}.form-select{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:13px;background:var(--bg-surface);color:var(--text);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2371717a' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(124,58,237,.12)}textarea.form-input{resize:vertical;min-height:80px}.form-switch{position:relative;width:36px;height:20px;background:var(--border);border-radius:10px;cursor:pointer;transition:background var(--transition)}.form-switch.active{background:var(--primary)}.form-switch:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform var(--transition);box-shadow:0 1px 3px rgba(0,0,0,.3)}.form-switch.active:after{transform:translateX(16px)}.form-checkbox{width:16px;height:16px;border:1.5px solid var(--border);border-radius:4px;background:var(--bg-surface);cursor:pointer;transition:all var(--transition);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.form-checkbox.checked{background:var(--primary);border-color:var(--primary)}.form-checkbox.checked:after{content:"✓";color:#fff;font-size:10px;font-weight:700}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition)}.card:hover{border-color:var(--border-hover)}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;position:relative;overflow:hidden;transition:all var(--transition)}.stat-card:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;border-radius:0 3px 3px 0}.stat-card:hover{border-color:var(--border-hover);transform:translateY(-1px);box-shadow:var(--shadow)}.stat-card .stat-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:14px}.stat-card .stat-label{font-size:12px;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.stat-card .stat-value{font-family:var(--font-display);font-size:28px;font-weight:700;letter-spacing:-.02em;line-height:1}.stat-card .stat-trend{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;margin-top:8px;padding:2px 8px;border-radius:var(--radius-full)}.stat-card .stat-trend.up{color:#34d399;background:var(--success-light)}.stat-card .stat-trend.down{color:#f87171;background:var(--danger-light)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;letter-spacing:.01em}.badge:before{content:"";width:5px;height:5px;border-radius:50%;flex-shrink:0}.badge-success{background:var(--success-light);color:#34d399}.badge-success:before{background:#34d399}.badge-danger{background:var(--danger-light);color:#f87171}.badge-danger:before{background:#f87171}.badge-warning{background:var(--warning-light);color:#fbbf24}.badge-warning:before{background:#fbbf24}.badge-primary{background:rgba(124,58,237,.12);color:#a78bfa}.badge-primary:before{background:#a78bfa}.badge-info{background:var(--info-light);color:#60a5fa}.badge-info:before{background:#60a5fa}.badge-neutral{background:var(--bg-elevated);color:var(--text-muted)}.badge-neutral:before{background:var(--text-muted)}.table-wrap{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-card)}.table{width:100%;border-collapse:collapse}.table th{padding:10px 16px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;text-align:left;background:var(--bg-elevated);border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;z-index:5}.table td{padding:12px 16px;font-size:13px;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);transition:background var(--transition)}.table tr:last-child td{border-bottom:none}.table tbody tr{transition:background var(--transition);cursor:default}.table tbody tr:hover td{background:var(--bg-hover)}.table tbody tr.selected td{background:rgba(124,58,237,.06)}.table-toolbar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg-elevated)}.table-avatar{width:28px;height:28px;border-radius:7px;font-weight:700;font-size:11px;color:#fff;flex-shrink:0;background:linear-gradient(135deg,var(--primary),#9333ea)}.modal-overlay,.table-avatar{display:flex;align-items:center;justify-content:center}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;padding:24px;animation:fadeIn .2s ease}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 80px rgba(0,0,0,.6);animation:slideUp .3s var(--ease)}.modal-lg{max-width:680px}.modal-header{padding:20px 24px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}.modal-title{font-family:var(--font-display);font-size:17px;font-weight:700;letter-spacing:-.02em}.modal-subtitle{font-size:13px;color:var(--text-muted);margin-top:2px}.modal-close{width:30px;height:30px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:var(--transition);font-size:18px}.modal-close:hover{background:var(--bg-hover);color:var(--text)}.modal-body{padding:20px 24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.empty-state{text-align:center;padding:56px 24px}.empty-state-icon{font-size:40px;margin-bottom:12px;opacity:.4}.empty-state-title{font-family:var(--font-display);font-size:16px;font-weight:700;margin-bottom:4px}.empty-state-desc{font-size:13px;color:var(--text-muted);margin-bottom:20px;max-width:320px;margin-inline:auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.page-title{font-family:var(--font-display);font-size:22px;font-weight:700;letter-spacing:-.02em}.page-subtitle{font-size:13px;color:var(--text-muted);margin-top:3px}.filter-bar,.page-actions{display:flex;align-items:center;gap:8px}.filter-bar{padding:12px 0;flex-wrap:wrap}.filter-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:500;color:var(--text-muted);background:var(--bg-elevated);border:1px solid var(--border);cursor:pointer;transition:all var(--transition)}.filter-chip:hover{border-color:var(--border-hover);color:var(--text)}.filter-chip.active{background:var(--primary-50);border-color:var(--primary);color:#a78bfa}.search-input{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-surface);transition:all var(--transition)}.search-input:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px rgba(124,58,237,.12)}.search-input svg{color:var(--text-dim);flex-shrink:0}.search-input input{border:none;background:transparent;color:var(--text);font-size:13px;width:100%;outline:none}.search-input input::placeholder{color:var(--text-dim)}.progress{height:6px;background:var(--bg-elevated);border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;transition:width .6s var(--ease)}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:20px}.tab{padding:10px 16px;font-size:13px;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;transition:all var(--transition);cursor:pointer;margin-bottom:-1px}.tab:hover{color:var(--text)}.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.timeline{display:flex;flex-direction:column;gap:0}.timeline-item{display:flex;gap:12px;padding:12px 0;position:relative}.timeline-item:not(:last-child):after{content:"";position:absolute;left:15px;top:36px;bottom:-4px;width:1px;background:var(--border)}.timeline-dot{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:13px}.timeline-content{flex:1 1;min-width:0}.timeline-text{font-size:13px;color:var(--text-secondary)}.timeline-text strong{color:var(--text);font-weight:600}.timeline-time{font-size:11px;color:var(--text-dim);margin-top:2px}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.status-dot.online{background:var(--success);box-shadow:0 0 0 3px var(--success-light)}.status-dot.offline{background:var(--text-dim)}.status-dot.warning{background:var(--warning);box-shadow:0 0 0 3px var(--warning-light)}.tag{display:inline-flex;gap:4px;padding:2px 8px;border-radius:var(--radius-xs);font-size:11px;font-weight:500;background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border)}.pagination,.tag{align-items:center}.pagination{display:flex;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--border)}.pagination-info{font-size:12px;color:var(--text-muted)}.pagination-btns{display:flex;gap:4px}.pagination-btn{width:30px;height:30px;border-radius:var(--radius-xs);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--text-muted);background:transparent;border:1px solid transparent;transition:all var(--transition);cursor:pointer}.pagination-btn:hover{background:var(--bg-hover);color:var(--text)}.pagination-btn.active{background:var(--primary-50);color:#a78bfa;border-color:var(--primary)}.skeleton{background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-hover) 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}.skeleton-text{height:12px;width:60%;margin-bottom:8px}.skeleton-title{height:20px;width:40%;margin-bottom:12px}.skeleton-card{height:100px}.toast{position:fixed;bottom:24px;right:24px;padding:12px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:10px;font-size:13px;z-index:2000;animation:slideUp .3s var(--ease)}.toast-success{border-left:3px solid var(--success)}.toast-error{border-left:3px solid var(--danger)}.donut{width:120px;height:120px;border-radius:50%;position:relative;display:flex;align-items:center;justify-content:center}.donut-label{position:absolute;text-align:center}.donut-value{font-family:var(--font-display);font-size:20px;font-weight:700;display:block}.donut-text{font-size:11px;color:var(--text-muted);display:block}.grid-2{grid-template-columns:1fr 1fr;grid-gap:12px}.grid-2,.grid-3{display:grid;gap:12px}.grid-3{grid-template-columns:repeat(3,1fr);grid-gap:12px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:12px;gap:12px}.flex{display:flex}.flex-between,.flex-center{display:flex;align-items:center}.flex-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.text-sm{font-size:12px}.text-xs{font-size:11px}.text-muted{color:var(--text-muted)}.text-dim{color:var(--text-dim)}.font-mono{font-family:var(--font-mono)}.font-display{font-family:var(--font-display)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.fade-in{animation:fadeIn .3s ease}.slide-up{animation:slideUp .4s var(--ease)}.scale-in{animation:scaleIn .3s var(--ease)}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite}@media (max-width:1024px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page-header{flex-direction:column;gap:12px}.filter-bar{flex-direction:column;align-items:stretch}.form-row{grid-template-columns:1fr}}