body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--bg:#0f1923;--surface:#1a2634;--border:#2a3a4a;--text:#e0e6ed;--text-secondary:#89a;--primary:#3b82f6;--success:#2ecc71;--warning:#f39c12;--danger:#e74c3c}*{box-sizing:border-box;margin:0;padding:0}body{background:#0f1923;background:var(--bg);color:#e0e6ed;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,monospace}.app{min-height:100vh}.app-header{align-items:center;background:#1a2634;background:var(--surface);border-bottom:1px solid #2a3a4a;border-bottom:1px solid var(--border);display:flex;gap:16px;padding:16px 24px}.app-header h1{color:#3b82f6;color:var(--primary);font-size:22px}.logo-link{cursor:pointer}.logo-link:hover{opacity:.8}.subtitle{color:#89a;color:var(--text-secondary);font-size:14px}.cat-nav{background:#1a2634;background:var(--surface);border-bottom:2px solid #2a3a4a;border-bottom:2px solid var(--border);display:flex;overflow-x:auto;padding:0 24px}.cat-btn{background:none;border:none;border-bottom:2px solid #0000;color:#89a;color:var(--text-secondary);cursor:pointer;flex-shrink:0;font-size:14px;font-weight:500;margin-bottom:-2px;padding:12px 24px;transition:all .2s;white-space:nowrap}.cat-btn:hover{color:#e0e6ed;color:var(--text)}.cat-btn.active{border-bottom-color:#3b82f6;border-bottom-color:var(--primary);color:#3b82f6;color:var(--primary)}.app-body{display:flex;min-height:calc(100vh - 110px);position:relative}.app-body,.terminal-persist{background:#0f1923;background:var(--bg)}.terminal-persist{bottom:0;left:180px;overflow:hidden;position:absolute;right:0;top:0}.terminal-persist-visible{z-index:50}.terminal-persist-hidden{pointer-events:none;z-index:-1}@media (max-width:768px){.terminal-persist{left:0}}.sidebar{background:#1a2634;background:var(--surface);border-right:1px solid #2a3a4a;border-right:1px solid var(--border);display:flex;flex-direction:column;gap:2px;min-width:180px;padding:12px 0;width:180px}.sidebar-btn{background:none;border:none;border-left:3px solid #0000;color:#89a;color:var(--text-secondary);cursor:pointer;font-size:13px;padding:10px 20px;text-align:left;transition:all .2s}.sidebar-btn:hover{background:#ffffff08;color:#e0e6ed;color:var(--text)}.sidebar-btn.active{background:#3b82f614;border-left-color:#3b82f6;border-left-color:var(--primary);color:#3b82f6;color:var(--primary);font-weight:500}.main-content{background:#0f1923;background:var(--bg);flex:1 1;min-width:0;padding:24px;position:relative;z-index:1}.main-content>*{max-width:1400px}.main-content.full-width{margin:0 auto}.main-content.full-width>*{margin:0 auto;max-width:1400px}@media (max-width:768px){.app-header{flex-wrap:wrap;gap:8px;padding:10px 12px}.app-header h1{font-size:18px}.subtitle{display:none}.header-actions{gap:4px}.header-actions .btn{font-size:11px;padding:4px 8px}.cat-nav{padding:0 8px}.cat-btn{font-size:13px;padding:10px 14px}.app-body{flex-direction:column}.sidebar{border-bottom:1px solid #2a3a4a;border-bottom:1px solid var(--border);border-right:none;flex-direction:row;min-width:100%;overflow-x:auto;padding:0;width:100%}.sidebar-btn{border-bottom:2px solid #0000;border-left:none;padding:10px 16px;white-space:nowrap}.sidebar-btn.active{border-bottom-color:#3b82f6;border-bottom-color:var(--primary);border-left-color:#0000}.main-content{padding:12px}.data-table{font-size:11px}.data-table td,.data-table th{padding:6px 8px}.info-grid{gap:8px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.panel{padding:12px}.filter-row{flex-direction:column}.filter-row .filter-input{min-width:100%}}.panel{background:#1a2634;background:var(--surface);border:1px solid #2a3a4a;border:1px solid var(--border);border-radius:8px;margin-bottom:20px;padding:20px}.panel h2{color:#3b82f6;color:var(--primary);font-size:18px;margin-bottom:16px}.panel h3{color:#89a;color:var(--text-secondary);font-size:15px;margin:16px 0 10px}.panel-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:16px}.panel-header h2{margin-bottom:0}.info-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:16px}.info-item{background:#ffffff08;border-radius:4px;display:flex;justify-content:space-between;padding:8px 12px}.info-label{color:#89a;color:var(--text-secondary);font-size:13px}.info-value{font-size:13px;font-weight:600}.progress-section{display:flex;flex-direction:column;gap:12px}.progress-label{display:flex;font-size:13px;justify-content:space-between;margin-bottom:4px}.progress-bar{background:#ffffff1a;border-radius:4px;height:8px;overflow:hidden}.progress-fill{border-radius:4px;height:100%;transition:width .5s ease}.data-table{border-collapse:collapse;font-size:13px;width:100%}.data-table th{border-bottom:1px solid #2a3a4a;border-bottom:1px solid var(--border);color:#89a;color:var(--text-secondary);font-weight:500;padding:10px 12px;text-align:left}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.data-table th.sortable:hover{color:#3b82f6;color:var(--primary)}.data-table td{border-bottom:1px solid #ffffff0d;padding:8px 12px}.data-table tr:hover td{background:#ffffff05}.data-table code{color:#89a;color:var(--text-secondary);font-size:12px}.status-badge{border-radius:10px;display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;text-transform:uppercase}.status-badge.up{background:#2ecc7126;color:#2ecc71;color:var(--success)}.status-badge.down,.status-badge.error{background:#e74c3c26;color:#e74c3c;color:var(--danger)}.tag-badge{background:#3b82f6;background:var(--primary);border-radius:3px;color:#fff;display:inline-block;font-size:10px;opacity:.8;padding:1px 6px}.alerts-banner{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.alert-item{border-radius:4px;font-size:13px;font-weight:500;padding:8px 14px}.alert-warning{background:#f39c121f;border-left:3px solid #f39c12;border-left:3px solid var(--warning);color:#f39c12;color:var(--warning)}.alert-danger{background:#e74c3c1f;border-left:3px solid #e74c3c;border-left:3px solid var(--danger);color:#e74c3c;color:var(--danger)}.log-output{background:#0f1923;background:var(--bg);border:1px solid #2a3a4a;border:1px solid var(--border);border-radius:4px;color:#89a;color:var(--text-secondary);font-size:12px;margin-top:12px;max-height:400px;overflow-x:auto;overflow-y:auto;padding:12px;white-space:pre-wrap;word-break:break-all}.kpi-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:20px}.kpi-card{background:#ffffff08;border:1px solid #2a3a4a;border:1px solid var(--border);border-radius:8px;padding:20px 16px;text-align:center}.kpi-value{font-size:28px;font-weight:700;line-height:1.2}.kpi-label{font-size:13px}.kpi-label,.kpi-sub{color:#89a;color:var(--text-secondary);margin-top:4px}.kpi-sub{font-size:11px;opacity:.7}.server-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.charts-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.chart-box{background:#ffffff08;border-radius:6px;padding:12px}.chart-header{display:flex;font-size:13px;justify-content:space-between;margin-bottom:8px}.chart-value{color:#e0e6ed;color:var(--text);font-weight:600}.chart-svg{height:60px;width:100%}.file-editor{background:#0f1923;background:var(--bg);border:1px solid #2a3a4a;border:1px solid var(--border);border-radius:4px;color:#e0e6ed;color:var(--text);font-family:monospace;font-size:13px;min-height:400px;padding:12px;resize:vertical;width:100%}.btn{border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;padding:6px 14px;transition:opacity .2s}.btn:hover{opacity:.85}.btn-primary{background:#3b82f6;background:var(--primary);color:#fff}.btn-secondary{background:#2a3a4a;background:var(--border);color:#e0e6ed;color:var(--text)}.btn-danger{background:#e74c3c;background:var(--danger);color:#fff}.btn-warning{background:#f39c12;background:var(--warning);color:#fff}.btn-success{background:#2ecc71;background:var(--success);color:#fff}.btn-sm{font-size:12px;padding:3px 10px}.btn-group{display:flex;gap:8px}.text-success{color:#2ecc71;color:var(--success)}.text-secondary{color:#89a;color:var(--text-secondary);font-size:12px;padding:8px 0}.text-danger{color:#e74c3c;color:var(--danger)}.text-warning{color:#f39c12;color:var(--warning)}.loading{color:#89a;color:var(--text-secondary);padding:20px;text-align:center}.error{color:#e74c3c;color:var(--danger);padding:20px}.filter-input{background:#0f1923;background:var(--bg);border:1px solid #2a3a4a;border:1px solid var(--border);border-radius:4px;color:#e0e6ed;color:var(--text);font-size:13px;margin-bottom:12px;padding:8px 12px;width:100%}.filter-input:focus{border-color:#3b82f6;border-color:var(--primary);outline:none}.select-input{background:#0f1923;background:var(--bg);border:1px solid #2a3a4a;border:1px solid var(--border);border-radius:4px;color:#e0e6ed;color:var(--text);font-size:13px;padding:8px 12px}.select-input:focus{border-color:#3b82f6;border-color:var(--primary);outline:none}.inline-form{background:#ffffff08;border-radius:6px;display:flex;flex-direction:column;gap:10px;margin-bottom:16px;padding:16px}.inline-form input{background:#0f1923;background:var(--bg);border:1px solid #2a3a4a;border:1px solid var(--border);border-radius:4px;color:#e0e6ed;color:var(--text);font-size:13px;padding:8px 12px}.inline-form input:focus{border-color:#3b82f6;border-color:var(--primary);outline:none}.filter-row{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.filter-row .filter-input{flex:1 1;margin-bottom:0;min-width:200px}.form-row{align-items:center;display:flex;gap:8px}.form-row label{color:#89a;color:var(--text-secondary);font-size:13px;min-width:70px}.form-row input{flex:1 1}.message{background:#3b82f61a;border:1px solid #3b82f64d;border-radius:4px;cursor:pointer;font-size:13px;margin-bottom:12px;padding:8px 12px}.header-actions{align-items:center;display:flex;gap:8px;margin-left:auto}.lang-select{background:#0f1923;background:var(--bg);border:1px solid #2a3a4a;border:1px solid var(--border);border-radius:4px;color:#e0e6ed;color:var(--text);cursor:pointer;font-size:13px;padding:4px 8px}.lang-select:hover{border-color:#3b82f6;border-color:var(--primary)}.login-screen{align-items:center;background:var(--bg);display:flex;justify-content:center;min-height:100vh}.login-form{background:var(--surface);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;gap:16px;padding:40px;text-align:center;width:360px}.login-form h1{color:var(--primary);font-size:28px}.login-subtitle{color:var(--text-secondary);font-size:13px}.login-error{background:#e74c3c1a;border:1px solid #e74c3c4d;border-radius:4px;color:var(--danger);font-size:13px;padding:8px}.login-form input{background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:14px;padding:10px 14px;text-align:center}.login-form input:focus{border-color:var(--primary);outline:none}.login-form .btn{font-size:14px;padding:10px}.login-success{color:var(--success);font-size:13px;margin-bottom:8px}.modal-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:var(--surface);border:1px solid var(--border);border-radius:8px;max-width:90vw;min-width:360px;padding:24px}.modal-content h3{color:var(--primary);margin-bottom:16px}.modal-content input{background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:14px;margin-bottom:10px;padding:10px 12px;width:100%}.modal-content input:focus{border-color:var(--primary);outline:none}.modal-actions{display:flex;gap:8px;margin-top:8px}.config-section{border:1px solid var(--border);border-radius:6px;margin-bottom:16px;padding:16px}.config-header{flex-wrap:wrap;justify-content:space-between;margin-bottom:12px}.config-header,.config-meta{align-items:center;display:flex;gap:10px}.config-meta code{color:var(--text-secondary);font-size:12px}.config-editor{border:1px solid var(--border);color:var(--text);font-family:Fira Code,Cascadia Code,monospace;font-size:13px;margin-bottom:10px;min-height:300px;resize:vertical;width:100%}.config-editor,.config-preview{background:var(--bg);border-radius:4px;line-height:1.5;padding:12px}.config-preview{font-size:12px;max-height:400px;overflow:auto;white-space:pre-wrap;word-break:break-all}.editor-area{margin-top:12px}.traffic-interface{background:#ffffff05;border-radius:6px;margin-bottom:10px;padding:12px}.traffic-interface h4{color:var(--text);font-size:14px;margin-bottom:8px}.traffic-bar-item{align-items:center;display:flex;gap:10px;margin-bottom:6px}.traffic-label{color:var(--text-secondary);font-size:12px;font-weight:600;width:30px}.traffic-fill{background:var(--primary)}.traffic-bar-item .progress-bar{flex:1 1}.traffic-value{font-size:12px;font-weight:500;text-align:right;width:80px}.traffic-meta{color:var(--text-secondary);display:flex;font-size:11px;justify-content:space-between;margin-top:6px}.process-cmd{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.add-server-form{background:var(--card-bg);border:1px solid var(--border);border-radius:6px;margin-bottom:12px;padding:16px}.form-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-bottom:12px}.form-group label{color:var(--text-secondary);display:block;font-size:11px;margin-bottom:4px}.server-status-grid{grid-gap:8px;display:grid;font-size:12px;gap:8px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));padding:8px 0}.server-status-grid .status-item label{color:var(--text-secondary);display:block;font-size:10px;text-transform:uppercase}.server-summary{align-items:center;display:flex;gap:8px}.exec-area{padding:8px 0}.deploy-key-dialog{background:var(--bg);border:1px solid var(--border);border-radius:6px;margin:8px 0;padding:12px}.ssh-key-section{margin-bottom:12px}.log-viewer{background:var(--bg);border:1px solid var(--border);border-radius:6px;margin-bottom:16px;overflow:hidden}.log-header{align-items:center;background:#ffffff08;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:8px 12px}.log-header h3{font-size:14px;margin:0}.log-content{font-size:12px;line-height:1.5;max-height:400px;overflow:auto;padding:12px;white-space:pre-wrap;word-break:break-all}.log-container{background:var(--bg);border:1px solid var(--border);border-radius:6px;max-height:600px;overflow-y:auto;padding:4px}.log-line{border-bottom:1px solid #ffffff05;display:flex;font-family:Fira Code,Cascadia Code,monospace;font-size:12px;gap:8px;padding:2px 8px}.log-line:hover{background:#ffffff08}.log-line.log-error{background:#e74c3c14}.log-line.log-warning{background:#f39c1214}.log-timestamp{color:var(--text-secondary);min-width:180px;white-space:nowrap}.log-unit{color:var(--primary);max-width:200px;min-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.log-message{flex:1 1;word-break:break-all}.terminal-panel{padding-bottom:0}.terminal-controls{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.terminal-hint{background:#ffffff0d;border-radius:3px;color:var(--text-secondary);font-size:11px;padding:2px 8px}.ssh-form{align-items:center;background:#ffffff08;border-radius:6px;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px;padding:12px}.ssh-form input{background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);flex:1 1;font-size:13px;min-width:80px;padding:6px 10px}.ssh-form input:focus{border-color:var(--primary);outline:none}.terminal-container{background:var(--bg);border-radius:0 0 8px 8px;height:calc(100vh - 220px);min-height:400px;overflow:hidden;padding:4px}.terminal-container .xterm{height:100%}.terminal-container .xterm-viewport{overflow-y:auto!important}.xterm{cursor:text;position:relative;user-select:none;-ms-user-select:none;-webkit-user-select:none}.xterm.focus,.xterm:focus{outline:none}.xterm .xterm-helpers{position:absolute;top:0;z-index:5}.xterm .xterm-helper-textarea{border:0;height:0;left:-9999em;margin:0;opacity:0;overflow:hidden;padding:0;position:absolute;resize:none;top:0;white-space:nowrap;width:0;z-index:-5}.xterm .composition-view{background:#000;color:#fff;display:none;position:absolute;white-space:nowrap;z-index:1}.xterm .composition-view.active{display:block}.xterm .xterm-viewport{background-color:#000;bottom:0;cursor:default;left:0;overflow-y:scroll;position:absolute;right:0;top:0}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{left:0;position:absolute;top:0}.xterm .xterm-scroll-area{visibility:hidden}.xterm-char-measure-element{display:inline-block;left:-9999em;line-height:normal;position:absolute;top:0;visibility:hidden}.xterm.enable-mouse-events{cursor:default}.xterm .xterm-cursor-pointer,.xterm.xterm-cursor-pointer{cursor:pointer}.xterm.column-select.focus{cursor:crosshair}.xterm .xterm-accessibility,.xterm .xterm-message{bottom:0;color:#0000;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:10}.xterm .live-region{height:1px;left:-9999px;overflow:hidden;position:absolute;width:1px}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{-webkit-text-decoration:double underline;text-decoration:double underline}.xterm-underline-3{-webkit-text-decoration:wavy underline;text-decoration:wavy underline}.xterm-underline-4{-webkit-text-decoration:dotted underline;text-decoration:dotted underline}.xterm-underline-5{-webkit-text-decoration:dashed underline;text-decoration:dashed underline}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:overline underline}.xterm-overline.xterm-underline-2{-webkit-text-decoration:overline double underline;text-decoration:overline double underline}.xterm-overline.xterm-underline-3{-webkit-text-decoration:overline wavy underline;text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{-webkit-text-decoration:overline dotted underline;text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{-webkit-text-decoration:overline dashed underline;text-decoration:overline dashed underline}.xterm-strikethrough{text-decoration:line-through}.xterm-screen .xterm-decoration-container .xterm-decoration{position:absolute;z-index:6}.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer{z-index:7}.xterm-decoration-overview-ruler{pointer-events:none;position:absolute;right:0;top:0;z-index:8}.xterm-decoration-top{position:relative;z-index:2}
/*# sourceMappingURL=main.fe60f607.css.map*/