*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0a;--surface:#111;--border:#2a2a2a;--border-hi:#444;--text:#e8e8e8;--muted:#666;--accent:#fff;--danger:#f44;--warn:#ca0;--ok:#4b4;--mono:"IBM Plex Mono",monospace;--sans:"IBM Plex Sans",sans-serif;--bar-h:48px}#root,body,html{height:100%}body{-webkit-font-smoothing:antialiased;background:#0a0a0a;background:var(--bg);color:#e8e8e8;color:var(--text);font-family:IBM Plex Sans,sans-serif;font-family:var(--sans);font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0a0a0a;background:var(--bg)}::-webkit-scrollbar-thumb{background:#444;background:var(--border-hi);border-radius:3px}.mono{font-family:IBM Plex Mono,monospace;font-family:var(--mono)}.muted{color:#666;color:var(--muted)}.ok{color:#4b4;color:var(--ok)}.warn{color:#ca0;color:var(--warn)}.danger{color:#f44;color:var(--danger)}.topbar{align-items:center;background:#111;background:var(--surface);border-bottom:1px solid #2a2a2a;border-bottom:1px solid var(--border);display:flex;gap:24px;height:48px;height:var(--bar-h);padding:0 24px;position:sticky;top:0;z-index:100}.topbar-logo{color:#fff;color:var(--accent);font-family:IBM Plex Mono,monospace;font-family:var(--mono);font-size:15px;font-weight:600;letter-spacing:.1em}.topbar-logo span{color:#666;color:var(--muted)}.topbar-nav{display:flex;gap:8px;margin-left:auto}.topbar-btn{background:none;border:1px solid #2a2a2a;border:1px solid var(--border);color:#e8e8e8;color:var(--text);font-family:IBM Plex Mono,monospace;font-family:var(--mono);font-size:12px;letter-spacing:.05em;padding:6px 14px;transition:border-color .15s,color .15s}.topbar-btn:hover{border-color:#fff;border-color:var(--accent);color:#fff;color:var(--accent)}.topbar-btn.danger:hover{border-color:#f44;border-color:var(--danger);color:#f44;color:var(--danger)}.card{background:#111;background:var(--surface);border:1px solid #2a2a2a;border:1px solid var(--border);padding:16px}.card-title{color:#666;color:var(--muted);font-size:11px;letter-spacing:.12em;margin-bottom:12px;text-transform:uppercase}.card-title,.card-value{font-family:IBM Plex Mono,monospace;font-family:var(--mono)}.card-value{color:#fff;color:var(--accent);font-size:22px;font-weight:500}.bar-wrap{background:#2a2a2a;background:var(--border);height:6px;margin-top:8px;position:relative}.bar-fill{background:#fff;background:var(--accent);height:100%;transition:width .4s ease}.bar-fill.warn{background:#ca0;background:var(--warn)}.bar-fill.danger{background:#f44;background:var(--danger)}.tbl{border-collapse:collapse;font-family:IBM Plex Mono,monospace;font-family:var(--mono);font-size:12px;width:100%}.tbl th{color:#666;color:var(--muted);font-weight:500;letter-spacing:.08em;text-align:left}.tbl td,.tbl th{border-bottom:1px solid #2a2a2a;border-bottom:1px solid var(--border);padding:6px 8px}.tbl td{max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:#ffffff08}.badge{border:1px solid;display:inline-block;font-size:10px;letter-spacing:.05em;padding:2px 7px}.badge,.inp{font-family:IBM Plex Mono,monospace;font-family:var(--mono)}.inp{background:#0a0a0a;background:var(--bg);border:1px solid #2a2a2a;border:1px solid var(--border);color:#e8e8e8;color:var(--text);font-size:13px;outline:none;padding:8px 12px;transition:border-color .15s;width:100%}.inp:focus{border-color:#fff;border-color:var(--accent)}.btn{background:none;border:1px solid #2a2a2a;border:1px solid var(--border);color:#e8e8e8;color:var(--text);font-family:IBM Plex Mono,monospace;font-family:var(--mono);font-size:12px;letter-spacing:.06em;padding:8px 16px;transition:background .15s,border-color .15s,color .15s}.btn:hover{background:#2a2a2a;background:var(--border);border-color:#444;border-color:var(--border-hi)}.btn.primary{border-color:#fff;border-color:var(--accent);color:#fff;color:var(--accent)}.btn.primary:hover{background:#fff;background:var(--accent);color:#0a0a0a;color:var(--bg)}.btn.danger{border-color:#f44;border-color:var(--danger);color:#f44;color:var(--danger)}.btn.danger:hover{background:#f44;background:var(--danger);color:#0a0a0a;color:var(--bg)}.login-wrap{align-items:center;background:#0a0a0a;background:var(--bg);display:flex;justify-content:center;min-height:100vh}.login-box{background:#111;background:var(--surface);border:1px solid #2a2a2a;border:1px solid var(--border);padding:40px;width:360px}.login-title{font-family:IBM Plex Mono,monospace;font-family:var(--mono);font-size:18px;font-weight:600;letter-spacing:.12em;margin-bottom:32px;text-align:center}.login-title span{color:#666;color:var(--muted)}.login-field{margin-bottom:16px}.login-label{color:#666;color:var(--muted);display:block;font-size:11px;letter-spacing:.1em;margin-bottom:6px}.login-error,.login-label{font-family:IBM Plex Mono,monospace;font-family:var(--mono)}.login-error{color:#f44;color:var(--danger);font-size:12px;margin-bottom:16px}.overview-wrap{padding:24px}.overview-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}.overview-toolbar h1{color:#666;color:var(--muted);font-family:IBM Plex Mono,monospace;font-family:var(--mono);font-size:13px;font-weight:500;letter-spacing:.15em;margin-right:auto;text-transform:uppercase}.host-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.host-card{background:#111;background:var(--surface);border:1px solid #2a2a2a;border:1px solid var(--border);cursor:pointer;padding:20px;position:relative;transition:border-color .2s}.host-card:hover{border-color:#fff;border-color:var(--accent)}.host-card.offline{opacity:.5}.host-card-name{font-size:14px;font-weight:500;margin-bottom:4px}.host-card-ip,.host-card-name{font-family:IBM Plex Mono,monospace;font-family:var(--mono)}.host-card-ip{color:#666;color:var(--muted);font-size:11px;margin-bottom:16px}.host-card-stats{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.host-card-stat-label{color:#666;color:var(--muted);font-size:10px;letter-spacing:.1em;margin-bottom:3px;text-transform:uppercase}.host-card-stat-label,.host-card-stat-value{font-family:IBM Plex Mono,monospace;font-family:var(--mono)}.host-card-stat-value{font-size:16px;font-weight:500}.host-status{border-radius:50%;height:8px;position:absolute;right:16px;top:16px;width:8px}.host-status.online{background:#4b4;background:var(--ok);box-shadow:0 0 6px #4b4;box-shadow:0 0 6px var(--ok)}.host-status.offline{background:#f44;background:var(--danger)}.host-card-actions{border-top:1px solid #2a2a2a;border-top:1px solid var(--border);display:flex;gap:8px;margin-top:16px;padding-top:16px}.dialog-overlay{align-items:center;background:#000000b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:200}.dialog-box{background:#111;background:var(--surface);border:1px solid #444;border:1px solid var(--border-hi);padding:32px;width:420px}.dialog-title{color:#666;color:var(--muted);font-family:IBM Plex Mono,monospace;font-family:var(--mono);font-size:13px;letter-spacing:.12em;margin-bottom:24px;text-transform:uppercase}.dialog-field{margin-bottom:14px}.dialog-label{color:#666;color:var(--muted);display:block;font-family:IBM Plex Mono,monospace;font-family:var(--mono);font-size:11px;letter-spacing:.08em;margin-bottom:5px}.dialog-actions{display:flex;gap:10px;margin-top:24px}.detail-wrap{padding:24px}.detail-header{align-items:center;border-bottom:1px solid #2a2a2a;border-bottom:1px solid var(--border);display:flex;gap:16px;margin-bottom:24px;padding-bottom:16px}.detail-header h1{font-family:IBM Plex Mono,monospace;font-family:var(--mono);font-size:18px;font-weight:500}.detail-header .sub{font-size:12px}.detail-back,.detail-header .sub{color:#666;color:var(--muted);font-family:IBM Plex Mono,monospace;font-family:var(--mono)}.detail-back{background:none;border:1px solid #2a2a2a;border:1px solid var(--border);font-size:11px;letter-spacing:.08em;padding:6px 12px;transition:border-color .15s,color .15s}.detail-back:hover{border-color:#fff;border-color:var(--accent);color:#fff;color:var(--accent)}.detail-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));margin-bottom:24px}.detail-wide{grid-column:1/-1}.section-title{color:#666;color:var(--muted);font-family:IBM Plex Mono,monospace;font-family:var(--mono);font-size:11px;letter-spacing:.15em;margin-bottom:16px;margin-top:24px;text-transform:uppercase}.tabs{border-bottom:1px solid #2a2a2a;border-bottom:1px solid var(--border);display:flex;gap:0;margin-bottom:20px}.tab{background:none;border:none;border-bottom:2px solid #0000;color:#666;color:var(--muted);font-family:IBM Plex Mono,monospace;font-family:var(--mono);font-size:11px;letter-spacing:.1em;margin-bottom:-1px;padding:10px 18px;text-transform:uppercase;transition:color .15s,border-color .15s}.tab:hover{color:#e8e8e8;color:var(--text)}.tab.active{border-bottom-color:#fff;border-bottom-color:var(--accent);color:#fff;color:var(--accent)}.admin-wrap{max-width:900px;padding:24px}@media (max-width:600px){.overview-toolbar{gap:8px}.detail-grid,.host-grid{grid-template-columns:1fr}}
/*# sourceMappingURL=main.9939aa0a.css.map*/