@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg-base:#0b0e14;--bg-primary:#111520;--bg-secondary:#171c28;--bg-surface:#1e2433;--bg-elevated:#252c3d;--bg-hover:#2a3245;--border-subtle:#ffffff0f;--border-default:#ffffff14;--border-strong:#ffffff1f;--border-focus:#6366f180;--text-primary:#e2e8f0;--text-secondary:#8892a6;--text-tertiary:#5a6478;--text-inverse:#0b0e14;--accent-primary:#6366f1;--accent-hover:#818cf8;--accent-muted:#6366f126;--accent-glow:#6366f140;--success:#22c55e;--success-muted:#22c55e1f;--success-strong:#22c55e4d;--warning:#f59e0b;--warning-muted:#f59e0b1f;--danger:#ef4444;--danger-muted:#ef44441f;--danger-strong:#ef44444d;--info:#38bdf8;--info-muted:#38bdf81f;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--text-xs:.6875rem;--text-sm:.75rem;--text-base:.8125rem;--text-md:.875rem;--text-lg:1rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-8:32px;--sp-10:40px;--sp-12:48px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--shadow-xl:0 16px 48px #0009;--shadow-glow:0 0 20px var(--accent-glow);--sidebar-width:240px;--sidebar-collapsed:64px;--topbar-height:56px;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{background:var(--bg-base);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;overflow-x:hidden}a{color:var(--accent-primary);text-decoration:none}a:hover{color:var(--accent-hover)}code,.mono{font-family:var(--font-mono);font-size:.9em}::selection{background:var(--accent-primary);color:#fff}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-primary);border-right:1px solid var(--border-default);z-index:100;transition:width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{padding:var(--sp-5) var(--sp-5);border-bottom:1px solid var(--border-subtle);align-items:center;gap:var(--sp-3);height:var(--topbar-height);display:flex}.sidebar-logo{font-size:var(--text-xl);background:linear-gradient(135deg, var(--accent-primary), #a78bfa);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text;font-weight:800}.sidebar-version{font-size:var(--text-xs);color:var(--text-tertiary);background:var(--bg-surface);border-radius:var(--radius-sm);padding:2px 6px}.sidebar-nav{padding:var(--sp-3);flex:1;overflow-y:auto}.nav-section{margin-bottom:var(--sp-4)}.nav-section-title{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;padding:var(--sp-2) var(--sp-3);margin-bottom:var(--sp-1);font-weight:600}.nav-item{align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-md);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;border:1px solid #0000;margin-bottom:2px;font-weight:500;display:flex}.nav-item:hover{color:var(--text-primary);background:var(--bg-surface)}.nav-item.active{color:var(--accent-primary);background:var(--accent-muted);border-color:#6366f126;font-weight:600}.nav-item .nav-icon{justify-content:center;align-items:center;width:22px;font-size:18px;display:flex}.nav-badge{font-size:var(--text-xs);background:var(--accent-primary);color:#fff;border-radius:var(--radius-full);text-align:center;min-width:20px;margin-left:auto;padding:1px 7px;font-weight:700}.nav-badge.success{background:var(--success)}.nav-badge.danger{background:var(--danger)}.sidebar-footer{padding:var(--sp-4);border-top:1px solid var(--border-subtle)}.system-status{background:var(--bg-surface);border-radius:var(--radius-md);padding:var(--sp-3);margin-bottom:var(--sp-3)}.system-status-title{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--sp-2);font-weight:700}.system-stat{font-size:var(--text-sm);padding:var(--sp-1) 0;justify-content:space-between;align-items:center;display:flex}.system-stat-value{font-weight:700;font-family:var(--font-mono)}.btn-logout{width:100%;padding:var(--sp-2) var(--sp-3);border:1px solid var(--danger-strong);border-radius:var(--radius-md);color:var(--danger);font-size:var(--text-sm);font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;gap:var(--sp-2);background:0 0;display:flex}.btn-logout:hover{background:var(--danger-muted);border-color:var(--danger)}.main-wrapper{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.topbar{height:var(--topbar-height);background:var(--bg-primary);border-bottom:1px solid var(--border-default);padding:0 var(--sp-6);z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#111520d9;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:var(--sp-3);display:flex}.breadcrumb{align-items:center;gap:var(--sp-2);font-size:var(--text-md);display:flex}.breadcrumb-item{color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast)}.breadcrumb-item:hover{color:var(--text-primary)}.breadcrumb-item.active{color:var(--text-primary);cursor:default;font-weight:600}.breadcrumb-sep{color:var(--text-tertiary);font-size:10px}.topbar-right{align-items:center;gap:var(--sp-4);display:flex}.user-pill{align-items:center;gap:var(--sp-2);padding:var(--sp-1) var(--sp-3) var(--sp-1) var(--sp-1);background:var(--bg-surface);border-radius:var(--radius-full);font-size:var(--text-sm);border:1px solid var(--border-default);display:flex}.user-avatar{background:linear-gradient(135deg, var(--accent-primary), #a78bfa);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:flex}.page-content{padding:var(--sp-6);flex:1;width:100%;max-width:1400px}.page-header{margin-bottom:var(--sp-6)}.page-title{font-size:var(--text-2xl);letter-spacing:-.02em;margin-bottom:var(--sp-1);font-weight:700}.page-subtitle{font-size:var(--text-md);color:var(--text-secondary)}.stat-grid{gap:var(--sp-4);margin-bottom:var(--sp-6);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.stat-card{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--sp-5);transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card:before{content:"";background:linear-gradient(90deg, var(--stat-color,var(--accent-primary)), transparent);opacity:.8;height:3px;position:absolute;top:0;left:0;right:0}.stat-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-label{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--sp-2);font-weight:600}.stat-value{font-size:var(--text-3xl);font-weight:800;font-family:var(--font-mono);letter-spacing:-.02em;line-height:1}.stat-change{font-size:var(--text-xs);margin-top:var(--sp-2);border-radius:var(--radius-full);align-items:center;gap:4px;padding:2px 8px;font-weight:600;display:inline-flex}.stat-change.up{color:var(--success);background:var(--success-muted)}.stat-change.down{color:var(--danger);background:var(--danger-muted)}.data-card{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden}.data-card-header{padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;display:flex}.data-card-title{font-size:var(--text-md);font-weight:700}.data-card-actions{gap:var(--sp-2);align-items:center;display:flex}.data-table{border-collapse:collapse;width:100%}.data-table thead{background:var(--bg-surface)}.data-table th{padding:var(--sp-3) var(--sp-4);text-align:left;font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-default);white-space:nowrap;font-weight:700}.data-table td{padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border-subtle);font-size:var(--text-base);vertical-align:middle}.data-table tbody tr{transition:background var(--transition-fast);cursor:pointer}.data-table tbody tr:hover{background:var(--bg-hover)}.data-table tbody tr:last-child td{border-bottom:none}.btn{justify-content:center;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-ghost{color:var(--text-secondary);border-color:var(--border-default);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg-surface);color:var(--text-primary);border-color:var(--border-strong)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626;box-shadow:0 0 20px #ef44444d}.btn-warning{background:var(--warning);color:var(--text-inverse)}.btn-warning:hover:not(:disabled){background:#d97706}.btn-success{background:var(--success);color:var(--text-inverse)}.btn-success:hover:not(:disabled){background:#16a34a}.btn-sm{padding:var(--sp-1) var(--sp-3);font-size:var(--text-xs)}.btn-lg{padding:var(--sp-3) var(--sp-6);font-size:var(--text-md)}.btn-icon{padding:var(--sp-2);width:34px;height:34px}.search-bar{width:100%;position:relative}.search-bar input{width:100%;padding:var(--sp-2) var(--sp-4) var(--sp-2) var(--sp-10);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-md);font-family:var(--font-sans);transition:all var(--transition-fast);outline:none}.search-bar input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-muted);background:var(--bg-elevated)}.search-bar input::placeholder{color:var(--text-tertiary)}.search-bar .search-icon{left:var(--sp-3);color:var(--text-tertiary);pointer-events:none;font-size:16px;position:absolute;top:50%;transform:translateY(-50%)}.input-field{width:100%;padding:var(--sp-3) var(--sp-4);background:var(--bg-base);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-md);font-family:var(--font-sans);transition:all var(--transition-fast);outline:none}.input-field:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-muted)}.input-field::placeholder{color:var(--text-tertiary)}.form-group{margin-bottom:var(--sp-4)}.form-label{font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--sp-2);font-weight:600;display:block}.badge{font-size:var(--text-xs);border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:5px;padding:3px 10px;font-weight:600;display:inline-flex}.badge-online{background:var(--success-muted);color:var(--success);border:1px solid var(--success-strong)}.badge-offline{background:var(--danger-muted);color:var(--danger);border:1px solid var(--danger-strong)}.badge-info{background:var(--info-muted);color:var(--info)}.badge-warning{background:var(--warning-muted);color:var(--warning)}.status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.status-dot.online{background:var(--success);animation:2s ease-in-out infinite pulse-dot;box-shadow:0 0 8px #22c55e80}.status-dot.offline{background:var(--danger);opacity:.6}@keyframes pulse-dot{0%,to{box-shadow:0 0 4px #22c55e66}50%{box-shadow:0 0 12px #22c55eb3}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;animation:fadeIn var(--transition-fast);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border:1px solid var(--border-strong);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow-xl);animation:slideUp var(--transition-base);overflow-y:auto}.modal-header{padding:var(--sp-5) var(--sp-6);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--text-lg);font-weight:700}.modal-close{background:var(--bg-surface);border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;font-size:18px;display:flex}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{padding:var(--sp-6)}.modal-footer{justify-content:flex-end;gap:var(--sp-3);padding:var(--sp-4) var(--sp-6);border-top:1px solid var(--border-subtle);display:flex}.tab-bar{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-default);margin-bottom:var(--sp-5);gap:2px;padding:3px;display:flex}.tab-item{padding:var(--sp-2) var(--sp-4);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;gap:var(--sp-2);background:0 0;border:none;flex:1;display:flex}.tab-item:hover{color:var(--text-primary);background:var(--bg-hover)}.tab-item.active{background:var(--accent-primary);color:#fff;font-weight:700;box-shadow:0 2px 8px #6366f14d}.agent-card-grid{gap:var(--sp-4);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));display:grid}.agent-card{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden}.agent-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-lg), var(--shadow-glow);transform:translateY(-3px)}.agent-card.offline{opacity:.65}.agent-card.offline:hover{opacity:1;border-color:var(--danger)}.agent-card-status{align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);background:var(--bg-base);border-bottom:1px solid var(--border-subtle);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);font-weight:600;display:flex}.agent-card-screen{background:#000;justify-content:center;align-items:center;height:130px;display:flex;overflow:hidden}.agent-card-screen img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-slow)}.agent-card:hover .agent-card-screen img{transform:scale(1.05)}.agent-card-placeholder{align-items:center;gap:var(--sp-1);color:var(--text-tertiary);font-size:var(--text-sm);flex-direction:column;display:flex}.agent-card-placeholder .icon{opacity:.3;font-size:32px}.agent-card-body{padding:var(--sp-3) var(--sp-4)}.agent-card-hostname{font-size:var(--text-md);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-weight:700;overflow:hidden}.agent-card-meta{font-size:var(--text-xs);color:var(--text-secondary);align-items:center;gap:var(--sp-2);margin-bottom:2px;display:flex}.agent-card-score{padding:var(--sp-2) var(--sp-4);border-top:1px solid var(--border-subtle);background:var(--bg-base);justify-content:space-between;align-items:center;display:flex}.score-bar{background:var(--bg-hover);height:4px;margin-right:var(--sp-3);border-radius:2px;flex:1;overflow:hidden}.score-bar-fill{background:linear-gradient(90deg, var(--accent-primary), var(--success));border-radius:2px;height:100%;transition:width .8s}.score-text{font-size:var(--text-xs);font-weight:700;font-family:var(--font-mono);color:var(--text-secondary)}.detail-layout{gap:var(--sp-6);display:flex}.detail-main{flex:1;min-width:0}.detail-sidebar{flex-shrink:0;width:280px}.detail-info-card{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--sp-5);margin-bottom:var(--sp-4)}.detail-info-item{padding:var(--sp-2) 0;border-bottom:1px solid var(--border-subtle);font-size:var(--text-sm);justify-content:space-between;align-items:center;display:flex}.detail-info-item:last-child{border:none}.detail-info-label{color:var(--text-secondary)}.detail-info-value{font-weight:600;font-family:var(--font-mono)}.dlp-actions{gap:var(--sp-2);flex-direction:column;display:flex}.dlp-btn{width:100%;padding:var(--sp-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:700;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:var(--sp-2);border:none;display:flex}.dlp-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.dlp-btn.danger{background:var(--danger);color:#fff}.dlp-btn.warning{background:var(--warning);color:var(--text-inverse)}.dlp-btn.success{background:var(--success);color:var(--text-inverse)}.dlp-btn.ghost{border:1px solid var(--border-default);color:var(--text-secondary);background:0 0}.dlp-btn.ghost:hover{border-color:var(--accent-primary);color:var(--text-primary)}.live-viewer{border-radius:var(--radius-lg);border:1px solid var(--border-default);background:#000;justify-content:center;align-items:center;min-height:400px;display:flex;position:relative;overflow:hidden}.live-viewer img{width:100%;height:auto;display:block}.live-viewer-placeholder{align-items:center;gap:var(--sp-3);color:var(--text-tertiary);flex-direction:column;display:flex}.live-viewer-placeholder .icon{opacity:.2;font-size:48px}.live-badge{top:var(--sp-3);left:var(--sp-3);background:var(--danger);color:#fff;font-size:var(--text-xs);border-radius:var(--radius-full);align-items:center;gap:4px;padding:3px 10px;font-weight:700;animation:2s ease-in-out infinite pulse-live;display:flex;position:absolute}@keyframes pulse-live{0%,to{opacity:1}50%{opacity:.6}}.log-table{border-collapse:collapse;width:100%;font-family:var(--font-mono);font-size:var(--text-xs)}.log-table th{padding:var(--sp-2) var(--sp-3);text-align:left;color:var(--text-tertiary);border-bottom:1px solid var(--border-default);background:var(--bg-surface);font-weight:600}.log-table td{padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--border-subtle)}.log-type{border-radius:3px;padding:1px 6px;font-size:10px;font-weight:600}.log-type.info{background:var(--info-muted);color:var(--info)}.log-type.warn{background:var(--warning-muted);color:var(--warning)}.log-type.error{background:var(--danger-muted);color:var(--danger)}.customer-header{align-items:center;gap:var(--sp-4);margin-bottom:var(--sp-6);display:flex}.customer-avatar{border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--accent-primary), #a78bfa);width:56px;height:56px;font-size:var(--text-2xl);color:#fff;justify-content:center;align-items:center;font-weight:800;display:flex}.customer-info-grid{gap:var(--sp-4);margin-bottom:var(--sp-6);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid}.customer-info-item{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--sp-4)}.customer-info-item .label{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--sp-1);font-weight:600}.customer-info-item .value{font-size:var(--text-md);font-weight:700;font-family:var(--font-mono)}.progress-bar{background:var(--bg-hover);width:100%;height:6px;margin-top:var(--sp-2);border-radius:3px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--accent-primary), var(--success));border-radius:3px;height:100%;transition:width .8s}.progress-bar-fill.warning{background:var(--warning)}.progress-bar-fill.danger{background:var(--danger)}.login-page{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-bg{pointer-events:none;background:radial-gradient(at 20%,#6366f114 0%,#0000 60%),radial-gradient(at 80% 20%,#a78bfa0d 0%,#0000 50%),radial-gradient(at 50% 90%,#22c55e0a 0%,#0000 50%);animation:8s ease-in-out infinite alternate bg-breathe;position:absolute;inset:0}@keyframes bg-breathe{0%{opacity:.5;transform:scale(1)}to{opacity:1;transform:scale(1.02)}}.login-card{z-index:2;background:var(--bg-primary);border:1px solid var(--border-strong);border-radius:var(--radius-xl);width:100%;max-width:400px;padding:var(--sp-10);box-shadow:var(--shadow-xl), 0 0 80px #6366f10d;position:relative}.login-logo-section{text-align:center;margin-bottom:var(--sp-8)}.login-logo-icon{width:56px;height:56px;margin:0 auto var(--sp-4);background:linear-gradient(135deg, var(--accent-primary), #a78bfa);border-radius:var(--radius-lg);justify-content:center;align-items:center;font-size:28px;animation:3s ease-in-out infinite logo-float;display:flex}@keyframes logo-float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.login-title{font-size:var(--text-2xl);background:linear-gradient(135deg, var(--accent-primary), #a78bfa);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text;font-weight:800}.login-subtitle{font-size:var(--text-sm);color:var(--text-tertiary);margin-top:var(--sp-1)}.login-error{background:var(--danger-muted);border:1px solid var(--danger-strong);color:var(--danger);padding:var(--sp-3) var(--sp-4);border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:var(--sp-5);animation:.4s shake}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-3px)}80%{transform:translate(3px)}}.login-form{gap:var(--sp-5);flex-direction:column;display:flex}.login-btn{width:100%;padding:var(--sp-3);background:var(--accent-primary);color:#fff;border-radius:var(--radius-md);font-size:var(--text-md);font-weight:700;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);border:none}.login-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-footer{margin-top:var(--sp-8);text-align:center;padding-top:var(--sp-5);border-top:1px solid var(--border-subtle)}.login-footer p{font-size:var(--text-xs);color:var(--text-tertiary)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.gap-6{gap:var(--sp-6)}.text-muted{color:var(--text-secondary)}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.font-mono{font-family:var(--font-mono)}.font-bold{font-weight:700}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.mt-auto{margin-top:auto}.empty-state{padding:var(--sp-12) var(--sp-6);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state .icon{opacity:.2;margin-bottom:var(--sp-4);font-size:48px}.empty-state h3{font-size:var(--text-lg);margin-bottom:var(--sp-2)}.empty-state p{color:var(--text-secondary);font-size:var(--text-md);max-width:320px}.skeleton{background:linear-gradient(90deg, var(--bg-surface) 25%, var(--bg-elevated) 50%, var(--bg-surface) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s ease-in-out infinite skeleton-shimmer}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.toast{top:var(--sp-5);right:var(--sp-5);z-index:2000;padding:var(--sp-3) var(--sp-5);border-radius:var(--radius-md);font-size:var(--text-sm);animation:slideInRight var(--transition-base);box-shadow:var(--shadow-lg);max-width:400px;font-weight:600;position:fixed}.toast.success{background:var(--success);color:#fff}.toast.error{background:var(--danger);color:#fff}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.animate-fadeIn{animation:fadeIn var(--transition-base)}.animate-slideUp{animation:slideUp var(--transition-base)}@media (width<=1024px){.sidebar{width:var(--sidebar-collapsed)}.sidebar .nav-item span,.sidebar .nav-section-title,.sidebar .sidebar-version,.sidebar .system-status-title,.sidebar .system-stat span:first-child,.sidebar .btn-logout span,.sidebar .nav-badge{display:none}.main-wrapper{margin-left:var(--sidebar-collapsed)}.detail-layout{flex-direction:column}.detail-sidebar{width:100%}}@media (width<=768px){.sidebar{display:none}.main-wrapper{margin-left:0}.stat-grid{grid-template-columns:repeat(2,1fr)}.agent-card-grid{grid-template-columns:1fr}.page-content{padding:var(--sp-4)}.topbar{padding:0 var(--sp-4)}}
