@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-base:#080b12;--bg-surface:#0d1117;--bg-elevated:#161b22;--bg-hover:#1c2332;--border:#21262d;--border-focus:#388bfd;--text-primary:#e6edf3;--text-secondary:#7d8590;--text-muted:#484f58;--accent:#2f81f7;--accent-glow:#2f81f726;--success:#3fb950;--success-glow:#3fb95026;--warning:#d29922;--danger:#f85149;--danger-glow:#f8514926;--purple:#8b5cf6;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 16px #00000080;--shadow-lg:0 8px 32px #0009}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{background:var(--bg-base);height:100%;color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,sans-serif;font-size:14px;line-height:1.6}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}a{color:var(--accent);text-decoration:none}button{cursor:pointer;border:none;font-family:inherit}.app-shell{height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:220px;padding:16px 0;display:flex}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:8px;padding:0 16px 20px;display:flex}.sidebar-logo .logo-icon{background:linear-gradient(135deg, var(--accent), var(--purple));border-radius:var(--radius-sm);justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.sidebar-logo .logo-text{letter-spacing:-.3px;font-size:15px;font-weight:700}.sidebar-logo .logo-sub{color:var(--text-secondary);font-size:10px}.nav-section{margin-bottom:4px;padding:4px 8px}.nav-section-label{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);padding:8px 8px 4px;font-size:10px;font-weight:600}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;align-items:center;gap:10px;padding:8px 10px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-glow);color:var(--accent)}.nav-item svg{flex-shrink:0}.main-content{flex-direction:column;flex:1;display:flex;overflow-y:auto}.top-bar{border-bottom:1px solid var(--border);background:var(--bg-surface);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 24px;display:flex}.top-bar h1{font-size:16px;font-weight:600}.top-bar-actions{align-items:center;gap:8px;display:flex}.page-content{flex:1;padding:24px}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;transition:border-color .2s;position:relative;overflow:hidden}.stat-card:hover{border-color:var(--border-focus)}.stat-card:before{content:"";height:2px;position:absolute;top:0;left:0;right:0}.stat-card.green:before{background:var(--success)}.stat-card.blue:before{background:var(--accent)}.stat-card.red:before{background:var(--danger)}.stat-card.purple:before{background:var(--purple)}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:11px}.stat-value{font-size:28px;font-weight:700;line-height:1}.stat-value.green{color:var(--success)}.stat-value.blue{color:var(--accent)}.stat-value.red{color:var(--danger)}.stat-value.purple{color:var(--purple)}.stat-sub{color:var(--text-secondary);margin-top:6px;font-size:11px}.node-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.node-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;padding:0;transition:all .2s;overflow:hidden}.node-card:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-glow)}.node-card.online{border-color:var(--success)}.node-card.offline{opacity:.65}.node-card-header{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:16px;display:flex}.node-status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.node-status-dot.online{background:var(--success);box-shadow:0 0 8px var(--success);animation:2s infinite pulse-green}.node-status-dot.offline{background:var(--text-muted)}.node-status-dot.degraded{background:var(--warning);box-shadow:0 0 8px var(--warning)}@keyframes pulse-green{0%,to{box-shadow:0 0 6px var(--success)}50%{box-shadow:0 0 12px var(--success), 0 0 20px var(--success-glow)}}.node-id{font-size:13px;font-weight:600}.node-label{color:var(--text-secondary);margin-top:2px;font-size:11px}.node-card-body{padding:14px 16px}.node-meta{grid-template-columns:1fr 1fr;gap:8px 16px;display:grid}.node-meta-key{color:var(--text-muted);text-transform:uppercase;font-size:10px}.node-meta-val{margin-top:2px;font-family:JetBrains Mono,monospace;font-size:13px;font-weight:500}.node-card-footer{border-top:1px solid var(--border);background:var(--bg-elevated);gap:8px;padding:12px 16px;display:flex}.btn{border-radius:var(--radius-sm);cursor:pointer;border:1px solid #0000;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#388bfd}.btn-ghost{color:var(--text-secondary);border-color:var(--border);background:0 0}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-danger{color:var(--danger);border-color:var(--danger);background:0 0}.btn-danger:hover{background:var(--danger-glow)}.btn-success{background:var(--success);color:#000}.btn-success:hover{opacity:.9}.btn-sm{padding:4px 10px;font-size:12px}.btn-icon{padding:6px}.btn:disabled{opacity:.4;cursor:not-allowed}.badge{border-radius:12px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-green{background:var(--success-glow);color:var(--success);border:1px solid #3fb9504d}.badge-red{background:var(--danger-glow);color:var(--danger);border:1px solid #f851494d}.badge-blue{background:var(--accent-glow);color:var(--accent);border:1px solid #2f81f74d}.badge-gray{color:var(--text-secondary);border:1px solid var(--border);background:#ffffff0f}.badge-yellow{color:var(--warning);background:#d2992226;border:1px solid #d299224d}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border);padding:10px 12px;font-size:11px;font-weight:600}.data-table td{border-bottom:1px solid var(--bg-elevated);padding:12px;font-size:13px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg-elevated)}.mono{font-family:JetBrains Mono,monospace;font-size:12px}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:480px;max-width:95vw;box-shadow:var(--shadow-lg);padding:28px;animation:.2s slideUp}.modal-title{margin-bottom:20px;font-size:16px;font-weight:700}.modal-actions{justify-content:flex-end;gap:8px;margin-top:24px;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:12px;font-weight:600;display:block}.form-input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);padding:9px 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.form-input:focus{border-color:var(--border-focus);outline:none}.form-input::placeholder{color:var(--text-muted)}.toast-container{z-index:9999;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);align-items:center;gap:10px;max-width:360px;padding:12px 16px;font-size:13px;animation:.2s slideUp;display:flex}.toast.success{border-color:var(--success)}.toast.error{border-color:var(--danger)}.vnc-container{width:100%;height:calc(100vh - 120px);position:relative}.vnc-container iframe{border-radius:var(--radius-md);border:none;width:100%;height:100%}.tabs{border-bottom:1px solid var(--border);gap:0;margin-bottom:20px;display:flex}.tab{color:var(--text-secondary);cursor:pointer;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 16px;font-size:13px;font-weight:500;transition:all .15s}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-secondary);padding:60px 20px}.empty-state svg{color:var(--text-muted);margin:0 auto 16px}.empty-state h3{color:var(--text-primary);margin-bottom:8px;font-size:16px;font-weight:600}.copy-group{align-items:center;gap:6px;display:flex}.copy-val{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--accent);word-break:break-all;flex:1;padding:8px 10px;font-family:JetBrains Mono,monospace;font-size:12px}.pulse{animation:2s infinite pulse-green}
