@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600&family=Inter:wght@300;400;500;600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#08090f;--surface:#0d1117;--surface2:#111827;--surface3:#1a2235;--border:#1e2d45;--border-bright:#2a3f5f;--cyan:#00c2ff;--cyan-dim:#0a3a52;--green:#00e5a0;--green-dim:#0a3d2e;--yellow:#ffb800;--yellow-dim:#3d2e00;--red:#ff4560;--red-dim:#3d0f18;--text:#f0f4ff;--text2:#9dafc8;--text3:#6b8aad;--font-mono:"JetBrains Mono", monospace;--font-ui:"Inter", sans-serif;--space-xs:4px;--space-sm:8px;--space-md:14px;--space-lg:20px;--space-xl:28px;--text-xs:10px;--text-sm:11px;--text-base:13px;--text-md:15px;--text-lg:18px;--text-xl:24px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--card-bg:var(--surface);--card-border:var(--border);--card-pad:18px}[data-theme=light]{--bg:#f0f4ff;--surface:#fff;--surface2:#f5f7ff;--surface3:#eaeffc;--border:#d0d8f0;--border-bright:#b0bcdf;--cyan:#08c;--cyan-dim:#d0eaf8;--green:#00a870;--green-dim:#d0f0e8;--yellow:#c80;--yellow-dim:#fdf0d0;--red:#c24;--red-dim:#fdd0d8;--text:#0d1117;--text2:#4a5568;--text3:#718096}html,body,#root{background:var(--bg);height:100%;color:var(--text);font-family:var(--font-ui);font-size:var(--text-base);line-height:1.5;overflow:hidden}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--border-bright)}button{cursor:pointer;font-family:var(--font-ui);font-size:var(--text-base)}input,select,textarea{font-family:var(--font-ui);font-size:var(--text-base)}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes status-pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(2.2)}to{opacity:1;transform:scale(1)}}.view-enter{animation:.18s both fade-up}.skeleton{background:linear-gradient(90deg, var(--surface3) 25%, var(--surface2) 50%, var(--surface3) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.4s infinite shimmer}.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:var(--card-pad)}.section-head{font-size:var(--text-xs);color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--space-md);font-weight:700}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 24px;animation:.2s fade-in;display:flex}.empty-state-icon{margin-bottom:4px;font-size:42px}.empty-state-title{font-size:var(--text-md);color:var(--text);font-weight:600}.empty-state-sub{font-size:var(--text-base);color:var(--text2);max-width:360px;line-height:1.7}.empty-state-btn{background:var(--cyan-dim);border:1px solid var(--cyan);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--cyan);margin-top:4px;padding:9px 20px;font-weight:600;transition:all .15s}.empty-state-btn:hover{background:var(--cyan);color:var(--bg)}.setup-screen{background:var(--bg);justify-content:center;align-items:center;height:100vh;padding:24px;display:flex}.setup-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:480px;padding:36px;animation:.3s fade-in}.setup-logo{align-items:center;gap:12px;margin-bottom:28px;display:flex}.lg span:nth-child(2),.lg span:nth-child(3){opacity:.4}.setup-logo-name{color:var(--text);font-size:18px;font-weight:600}.setup-logo-sub{color:var(--text3);font-size:11px}.setup-h{letter-spacing:-.3px;margin-bottom:8px;font-size:22px;font-weight:500}.setup-sub{color:var(--text2);margin-bottom:24px;font-size:13px;line-height:1.7}.setup-field{margin-bottom:16px}.setup-label{color:var(--text2);margin-bottom:6px;font-size:12px;font-weight:500;display:block}.setup-input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:10px;outline:none;padding:12px 14px;font-size:14px;transition:border-color .2s}.setup-input:focus{border-color:var(--cyan)}.setup-input::placeholder{color:var(--text3)}.setup-input.err{border-color:var(--red)}.setup-input.ok{border-color:var(--green)}.setup-hint{color:var(--text3);margin-top:6px;font-size:11px;line-height:1.6}.setup-hint code{color:var(--cyan);font-family:var(--font-mono);font-size:11px}.setup-error{background:var(--red-dim);border:1px solid #ff45604d;border-radius:10px;gap:12px;margin-bottom:16px;padding:14px;display:flex}.setup-error-icon{color:var(--red);flex-shrink:0;margin-top:1px;font-size:16px}.setup-error-title{color:var(--red);margin-bottom:3px;font-size:13px;font-weight:600}.setup-error-msg{color:var(--text2);font-size:12px;font-family:var(--font-mono);margin-bottom:4px}.setup-error-tips{color:var(--text2);font-size:12px}.setup-success{background:var(--green-dim);border:1px solid var(--green);color:var(--green);border-radius:10px;align-items:center;gap:8px;margin-bottom:16px;padding:12px 14px;font-size:13px;display:flex}.setup-btn{cursor:pointer;border:2px solid var(--cyan);color:#6b7fa3;background:#fff;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;margin-bottom:20px;padding:13px;font-size:14px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 0 0 3px #00c2ff22}.setup-btn:hover:not(:disabled){background:var(--cyan);color:var(--bg)}.setup-btn:disabled{opacity:.5;cursor:not-allowed}.setup-spinner{border:2px solid #6b7fa344;border-top-color:#6b7fa3;border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.8s linear infinite spin}.setup-footer{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding-top:16px;display:flex}.setup-footer-item{color:var(--text3);font-size:12px}.setup-footer-item a{color:var(--cyan)}.setup-footer-item a:hover{text-decoration:underline}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;height:100vh;display:flex;overflow:hidden}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:20px 16px;display:flex}.logo-mark{border:1.5px solid var(--cyan);border-radius:7px;flex-shrink:0;width:30px;height:30px;padding:5px}.lg{grid-template-columns:1fr 1fr;gap:2px;width:100%;height:100%;display:grid}.lg span{background:var(--cyan);border-radius:1px}.lg span:nth-child(2),.lg span:nth-child(3){opacity:.4}.lg span:nth-child(4){opacity:.7}.logo-name{color:var(--text);font-size:14px;font-weight:600}.logo-sub{color:var(--text3);font-size:10px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:10px 8px;display:flex;overflow-y:auto}.nav-item{color:var(--text2);text-align:left;background:0 0;border:none;border-radius:9px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{background:var(--surface3);color:var(--text)}.nav-item.active{background:var(--cyan-dim);color:var(--cyan)}.nav-icon{text-align:center;flex-shrink:0;width:20px;font-size:15px}.nav-label{flex:1}.nav-badge{background:var(--red);color:#fff;text-align:center;border-radius:10px;min-width:18px;padding:1px 6px;font-size:9px;font-weight:700}.sidebar-footer{border-top:1px solid var(--border);padding:14px 14px 12px}.server-block{background:var(--surface3);border:1px solid var(--border);border-radius:10px;margin-bottom:10px;padding:12px}.server-row{align-items:flex-start;gap:8px;margin-bottom:6px;display:flex}.server-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-top:4px;animation:2s infinite pulse-dot}.server-dot.on{background:var(--green)}.server-dot.off{background:var(--red);animation:none}.server-dot.pulse{animation:.6s status-pulse!important}.server-status-label{color:var(--text);margin-bottom:2px;font-size:11px;font-weight:600}.server-url{color:var(--cyan);font-size:10px;font-family:var(--font-mono);word-break:break-all}.server-updated{color:var(--text3);margin-bottom:4px;font-size:10px}.server-error-msg{color:var(--red);margin-bottom:4px;font-size:10px;line-height:1.4}.change-url-btn{border:1px solid var(--border);width:100%;color:var(--text2);background:0 0;border-radius:7px;margin-top:6px;padding:6px 10px;font-size:11px;transition:all .15s}.change-url-btn:hover{border-color:var(--cyan);color:var(--cyan)}.sidebar-version{color:var(--text3);text-align:center;font-size:10px}.sk-wrap{gap:var(--space-lg);flex-direction:column;display:flex}.sk-kpi-row{grid-template-columns:repeat(6,1fr);gap:12px;display:grid}.sk-kpi{padding:16px}.sk-kpi-val{width:60%;height:28px;margin-bottom:8px}.sk-kpi-lbl{width:50%;height:12px}.sk-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.sk-card{padding:var(--card-pad);flex-direction:column;gap:10px;display:flex}.sk-head{width:40%;height:12px;margin-bottom:4px}.sk-row{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:10px;padding:10px;display:flex}.sk-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.sk-icon{border-radius:var(--radius-sm);flex-shrink:0;width:24px;height:24px}.sk-line{border-radius:4px;width:100%;height:12px}.sk-line.short{width:60%}.sk-line.flex1{flex:1}.sk-pill{border-radius:5px;flex-shrink:0;width:60px;height:18px}.sk-lines{flex-direction:column;flex:1;gap:6px;display:flex}.sk-type-row{flex-wrap:wrap;gap:10px;display:flex}.sk-type-item{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);flex-direction:column;align-items:center;gap:6px;padding:12px 18px;display:flex}.sk-type-icon{border-radius:var(--radius-sm);width:28px;height:28px}.sk-type-lbl{border-radius:4px;width:50px;height:10px}.overview{gap:var(--space-lg);flex-direction:column;display:flex}.kpi-row{grid-template-columns:repeat(6,1fr);gap:12px;display:grid}.kpi{padding:16px 18px}.kpi-val{font-size:var(--text-xl);font-weight:700;font-family:var(--font-mono);margin-bottom:4px;line-height:1}.kpi-of{font-size:var(--text-base);color:var(--text3);font-weight:400}.kpi-lbl{font-size:var(--text-sm);color:var(--text2)}.ov-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.span2{grid-column:span 2}.loc-list{flex-direction:column;gap:8px;display:flex}.loc-row{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:10px;padding:10px 12px;display:flex}.loc-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.loc-dot.healthy{background:var(--green)}.loc-dot.warning{background:var(--yellow)}.loc-dot.critical{background:var(--red)}.loc-dot.unknown{background:var(--border-bright)}.loc-name{font-size:var(--text-base);flex:1;font-weight:500}.loc-cnt{font-size:var(--text-sm);color:var(--text2);font-family:var(--font-mono)}.loc-badge{font-size:var(--text-xs);text-transform:uppercase;border-radius:5px;padding:2px 8px;font-weight:700}.loc-badge.healthy{background:var(--green-dim);color:var(--green)}.loc-badge.warning{background:var(--yellow-dim);color:var(--yellow)}.loc-badge.critical{background:var(--red-dim);color:var(--red)}.loc-badge.unknown{background:var(--surface3);color:var(--text3)}.al-list{flex-direction:column;gap:7px;display:flex}.al-row{border-radius:var(--radius-md);background:var(--bg);border:1px solid var(--border);align-items:flex-start;gap:10px;padding:10px 12px;display:flex}.al-row.critical{border-color:#ff456040}.al-row.warning{border-color:#ffb80040}.al-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;display:flex}.al-icon.critical{background:var(--red-dim);color:var(--red)}.al-icon.warning{background:var(--yellow-dim);color:var(--yellow)}.al-icon.info{background:var(--cyan-dim);color:var(--cyan)}.al-msg{font-size:var(--text-base);margin-bottom:2px;font-weight:500}.al-meta{font-size:var(--text-sm);color:var(--text2)}.type-grid{flex-wrap:wrap;gap:10px;display:flex}.type-item{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:8px;padding:10px 14px;transition:border-color .15s;display:flex}.type-item:hover{border-color:var(--border-bright)}.type-icon{font-size:18px}.type-name{font-size:var(--text-sm);color:var(--text2);text-transform:capitalize}.type-count{font-size:var(--text-md);color:var(--cyan);font-weight:700;font-family:var(--font-mono)}.section-head-sub{font-size:var(--text-xs);color:var(--text3);text-transform:none;letter-spacing:0;margin-left:6px;font-weight:400}.prev-list{flex-direction:column;gap:6px;display:flex}.prev-row{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:12px;padding:9px 12px;display:flex}.prev-dot{background:var(--border-bright);border-radius:50%;flex-shrink:0;width:7px;height:7px}.prev-ip{font-size:var(--text-sm);font-family:var(--font-mono);color:var(--text2);flex:1}.prev-seen{font-size:var(--text-sm);color:var(--text3)}.dv{gap:var(--space-md);flex-direction:column;height:calc(100vh - 110px);display:flex}.dv-bar{gap:var(--space-sm);flex-wrap:wrap;align-items:center;display:flex}.dv-search{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-base);color:var(--text);outline:none;min-width:220px;padding:8px 12px}.dv-search:focus{border-color:var(--cyan)}.dv-search::placeholder{color:var(--text3)}.dv-sel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);outline:none;padding:8px 10px}.dv-counts{font-size:var(--text-sm);color:var(--text3);margin-left:auto}.dv-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex:1;overflow:auto}.dv-table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.dv-table thead tr{border-bottom:1px solid var(--border);background:var(--surface);z-index:1;position:sticky;top:0}.dv-table th{text-align:left;font-size:var(--text-xs);color:var(--text3);letter-spacing:.8px;text-transform:uppercase;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;padding:11px 14px;font-weight:700}.dv-table th:hover{color:var(--text)}.col-hint{font-size:var(--text-xs);color:var(--text3);text-transform:none;letter-spacing:0;margin-left:4px;font-weight:400}.dv-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s}.dv-table tbody tr:hover{background:var(--surface3)}.dv-table tbody tr:last-child{border-bottom:none}.dv-table tbody tr.row-off{opacity:.6}.dv-table td{color:var(--text);padding:10px 14px}.dv-icon{font-size:16px}.dv-name-cell{align-items:center;gap:6px;min-width:140px;display:flex}.dv-name-cell:hover .dv-pen{opacity:1}.dv-name{cursor:pointer;transition:color .15s}.dv-name:hover{color:var(--cyan)}.dv-pen{opacity:0;font-size:var(--text-sm);color:var(--text3);cursor:pointer;transition:opacity .15s}.dv-edit{background:var(--bg);border:1px solid var(--cyan);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--text);outline:none;width:150px;padding:4px 8px}.dv-renamed{font-size:var(--text-xs);background:var(--cyan-dim);color:var(--cyan);text-transform:uppercase;border-radius:4px;padding:1px 5px;font-weight:700}.dv-ip{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--cyan)}.dv-loc{font-size:var(--text-sm);color:var(--text2)}.dv-type{background:var(--surface3);border:1px solid var(--border);font-size:var(--text-xs);color:var(--text2);text-transform:capitalize;white-space:nowrap;border-radius:5px;padding:2px 7px}.dv-status{font-size:var(--text-sm);text-transform:capitalize;white-space:nowrap;align-items:center;gap:5px;font-weight:600;display:flex}.dv-status.online{color:var(--green)}.dv-status.offline{color:var(--red)}.dv-sdot{background:currentColor;border-radius:50%;width:5px;height:5px;animation:2s infinite pulse-dot}.dv-lat{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--green);white-space:nowrap}.dv-lat.med{color:var(--yellow)}.dv-lat.hi{color:var(--red)}.dv-mac{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text3)}.dv-vendor{font-size:var(--text-sm);color:var(--text3)}.dv-footer{font-size:var(--text-sm);color:var(--text3);padding:4px 2px}.dv-reset{color:var(--red);cursor:pointer;margin-left:6px}.dv-reset:hover{text-decoration:underline}.dv-export-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--text2);white-space:nowrap;padding:7px 14px;transition:all .15s}.dv-export-btn:hover{border-color:var(--green);color:var(--green)}.dv-lat.seen{color:var(--text3)}.av{gap:var(--space-md);flex-direction:column;display:flex}.av-toolbar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:10px;padding:14px 16px;display:flex}.av-search{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-base);color:var(--text);outline:none;width:100%;padding:8px 12px}.av-search:focus{border-color:var(--cyan)}.av-search::placeholder{color:var(--text3)}.av-filters{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.av-filter-group{gap:4px;display:flex}.av-filter-btn{border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--text2);text-transform:capitalize;background:0 0;padding:5px 12px;transition:all .15s}.av-filter-btn:hover{border-color:var(--cyan);color:var(--cyan)}.av-filter-btn.active{background:var(--cyan-dim);border-color:var(--cyan);color:var(--cyan)}.av-filter-btn.critical.active{background:var(--red-dim);border-color:var(--red);color:var(--red)}.av-filter-btn.warning.active{background:var(--yellow-dim);border-color:var(--yellow);color:var(--yellow)}.av-filter-btn.info.active{background:var(--cyan-dim);border-color:var(--cyan);color:var(--cyan)}.av-sel{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--text);outline:none;padding:5px 10px}.av-actions{align-items:center;gap:10px;display:flex}.av-summary{font-size:var(--text-sm);color:var(--text2);flex:1}.av-total{color:var(--text);font-weight:600}.av-unread{color:var(--red);font-weight:600}.av-btn{background:var(--surface3);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--text2);padding:5px 14px;transition:all .15s}.av-btn:hover{border-color:var(--cyan);color:var(--cyan)}.av-btn.danger:hover{border-color:var(--red);color:var(--red)}.av-list{gap:var(--space-sm);flex-direction:column;display:flex}.av-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;align-items:flex-start;gap:12px;padding:13px 15px;transition:all .15s;display:flex}.av-card:hover{background:var(--surface3)}.av-card.read{opacity:.45}.av-card.critical{border-color:#ff456040}.av-card.warning{border-color:#ffb80040}.av-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex}.av-icon.critical{background:var(--red-dim);color:var(--red)}.av-icon.warning{background:var(--yellow-dim);color:var(--yellow)}.av-icon.info{background:var(--cyan-dim);color:var(--cyan)}.av-body{flex:1}.av-msg{font-size:var(--text-base);margin-bottom:4px;font-weight:500}.av-meta{font-size:var(--text-sm);color:var(--text2)}.av-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;display:flex}.av-badge{font-size:var(--text-xs);text-transform:uppercase;border-radius:4px;padding:2px 7px;font-weight:700}.av-badge.critical{background:var(--red-dim);color:var(--red)}.av-badge.warning{background:var(--yellow-dim);color:var(--yellow)}.av-badge.info{background:var(--cyan-dim);color:var(--cyan)}.av-dot{background:var(--cyan);border-radius:50%;width:7px;height:7px;animation:2s infinite pulse-dot}.topo{flex-direction:column;gap:16px;display:flex}.topo-svg{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:100%;height:260px}.topo-legend{color:var(--text2);gap:20px;font-size:12px;display:flex}.topo-legend span{align-items:center;gap:6px;display:flex}.tl-dot{border-radius:50%;width:8px;height:8px}.tl-dot.healthy{background:var(--green)}.tl-dot.warning{background:var(--yellow)}.tl-dot.critical{background:var(--red)}.tl-dot.unknown{background:var(--border-bright)}.topo-cards{gap:12px;display:grid}.topo-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px}.topo-card.critical{border-color:#ff456059}.topo-card.warning{border-color:#ffb80059}.tc-head{align-items:center;gap:7px;margin-bottom:10px;display:flex}.tc-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.tc-dot.healthy{background:var(--green)}.tc-dot.warning{background:var(--yellow)}.tc-dot.critical{background:var(--red)}.tc-dot.unknown{background:var(--border-bright)}.tc-name{flex:1;font-size:12px;font-weight:600}.tc-cnt{color:var(--text2);font-size:10px;font-family:var(--font-mono)}.tc-dev{color:var(--text2);align-items:center;gap:6px;padding:3px 0;font-size:11px;display:flex}.tc-dev.offline{opacity:.5}.tc-dev-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.tc-dev-dot.online{color:var(--green);font-size:9px}.tc-dev-dot.offline{color:var(--red);font-size:9px}.tc-none{color:var(--text3);padding:6px 0;font-size:11px}.tc-more{color:var(--text3);padding-top:6px;font-size:10px}.tc-dev{cursor:pointer}.tc-dev:hover .tc-dev-name{color:var(--cyan)}.tc-dev-lastseen{color:var(--text3);font-size:9px}.lv{gap:var(--space-md);flex-direction:column;height:calc(100vh - 110px);display:flex}.lv-bar{align-items:center;gap:10px;display:flex}.lv-search{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-base);color:var(--text);outline:none;width:200px;padding:7px 12px}.lv-search:focus{border-color:var(--cyan)}.lv-search::placeholder{color:var(--text3)}.lv-sel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);outline:none;padding:7px 10px}.lv-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--text2);padding:7px 14px;transition:all .15s}.lv-btn:hover,.lv-btn.active{border-color:var(--cyan);color:var(--cyan)}.lv-count{font-size:var(--text-sm);color:var(--text3);margin-left:auto}.lv-term{border:1px solid var(--border);border-radius:var(--radius-lg);background:#060810;flex-direction:column;flex:1;display:flex;overflow:hidden}.lv-term-bar{border-bottom:1px solid var(--border);background:var(--surface);align-items:center;gap:6px;padding:10px 14px;display:flex}.tb-dot{border-radius:50%;width:10px;height:10px}.tb-dot.r{background:#ff5f57}.tb-dot.y{background:#febc2e}.tb-dot.g{background:#28c840}.tb-title{font-size:var(--text-sm);color:var(--text3);font-family:var(--font-mono);margin-left:6px}.tb-paused{background:var(--yellow-dim);color:var(--yellow);font-size:var(--text-xs);border-radius:4px;margin-left:auto;padding:2px 8px;font-weight:700}.lv-body{font-family:var(--font-mono);flex:1;padding:12px 14px;font-size:12px;line-height:1.8;overflow-y:auto}.lv-line{gap:14px;display:flex}.lv-line:hover{background:#ffffff05}.lv-ts{color:var(--text3);flex-shrink:0}.lv-line.critical .lv-msg{color:var(--red)}.lv-line.warning .lv-msg{color:var(--yellow)}.lv-line.info .lv-msg{color:var(--green)}.lv-empty{color:var(--text3);padding:20px 0;font-size:12px}.settings{flex-direction:column;gap:20px;display:flex}.settings-tabs{gap:6px;display:flex}.settings-tab{border:1px solid var(--border);color:var(--text2);background:0 0;border-radius:8px;padding:7px 16px;font-size:13px;transition:all .15s}.settings-tab:hover{border-color:var(--cyan);color:var(--cyan)}.settings-tab.active{background:var(--cyan-dim);border-color:var(--cyan);color:var(--cyan)}.settings-section{flex-direction:column;gap:16px;display:flex}.about-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:16px;padding:28px;display:flex}.about-logo{align-items:center;gap:14px;display:flex}.about-mark{border:2px solid var(--cyan);border-radius:10px;flex-shrink:0;width:44px;height:44px;padding:7px}.about-grid{grid-template-columns:1fr 1fr;gap:3px;width:100%;height:100%;display:grid}.about-grid span{background:var(--cyan);border-radius:1px}.about-grid span:nth-child(2),.about-grid span:nth-child(3){opacity:.4}.about-grid span:nth-child(4){opacity:.7}.about-name{font-size:20px;font-weight:600}.about-by{color:var(--text3);font-size:12px}.about-version{background:var(--cyan-dim);border:1px solid var(--cyan);color:var(--cyan);font-size:12px;font-weight:700;font-family:var(--font-mono);border-radius:8px;width:fit-content;padding:4px 14px;display:inline-block}.about-desc{color:var(--text2);max-width:520px;font-size:13px;line-height:1.7}.about-links{flex-direction:column;gap:8px;display:flex}.about-links a{color:var(--cyan);align-items:center;gap:8px;font-size:13px;text-decoration:none;display:flex}.about-links a:hover{text-decoration:underline}.about-info-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.about-info-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.about-info-label{color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px;font-size:10px;font-weight:700}.about-info-value{font-size:14px;font-weight:600;font-family:var(--font-mono);color:var(--text)}.settings-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:24px}.settings-card-title{margin-bottom:6px;font-size:15px;font-weight:600}.settings-card-sub{color:var(--text2);margin-bottom:20px;font-size:13px}.settings-field{background:var(--bg);border:1px solid var(--border);border-radius:9px;margin-bottom:14px;padding:12px 16px}.settings-label{color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:5px;font-size:11px;font-weight:600}.settings-value{color:var(--cyan);font-size:13px;font-family:var(--font-mono)}.settings-btn{background:var(--surface3);border:1px solid var(--border);color:var(--text2);border-radius:9px;padding:9px 18px;font-size:13px;transition:all .15s}.settings-btn:hover{border-color:var(--cyan);color:var(--cyan)}.interval-options{flex-wrap:wrap;gap:10px;margin-top:4px;display:flex}.interval-btn{background:var(--bg);border:1px solid var(--border);color:var(--text2);border-radius:9px;padding:10px 20px;font-size:13px;transition:all .15s}.interval-btn:hover{border-color:var(--cyan);color:var(--cyan)}.interval-btn.active{background:var(--cyan-dim);border-color:var(--cyan);color:var(--cyan);font-weight:600}.cl-entry{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:14px;padding:20px}.cl-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.cl-left{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.cl-version{background:var(--cyan-dim);border:1px solid var(--cyan);color:var(--cyan);font-size:11px;font-weight:700;font-family:var(--font-mono);white-space:nowrap;border-radius:6px;padding:2px 10px}.cl-number{color:var(--text3);font-size:11px;font-family:var(--font-mono)}.cl-title{color:var(--text);font-size:14px;font-weight:600}.cl-date{color:var(--text3);white-space:nowrap;flex-shrink:0;font-size:11px}.cl-list{flex-direction:column;gap:6px;padding-left:18px;display:flex}.cl-item{color:var(--text2);font-size:13px;line-height:1.6}.lm{flex-direction:column;gap:20px;animation:.2s fade-in;display:flex}.lm-header{justify-content:space-between;align-items:flex-start;display:flex}.lm-title{margin-bottom:4px;font-size:18px;font-weight:600}.lm-sub{color:var(--text2);font-size:13px}.lm-add-btn{border:2px solid var(--cyan);color:#6b7fa3;white-space:nowrap;background:#fff;border-radius:9px;padding:9px 18px;font-size:13px;font-weight:700;transition:all .2s;box-shadow:0 0 0 3px #00c2ff22}.lm-add-btn:hover{background:var(--cyan);color:var(--bg)}.lm-form{background:var(--surface);border:1px solid var(--cyan);border-radius:14px;flex-direction:column;gap:16px;padding:22px;display:flex}.lm-form-title{font-size:15px;font-weight:600}.lm-form-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.lm-field{flex-direction:column;gap:5px;display:flex}.lm-label{color:var(--text2);text-transform:uppercase;letter-spacing:.6px;font-size:11px;font-weight:600}.lm-input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:9px;outline:none;padding:10px 13px;font-size:13px}.lm-input:focus{border-color:var(--cyan)}.lm-input::placeholder{color:var(--text3)}.lm-input:disabled{opacity:.5;cursor:not-allowed}.lm-hint{color:var(--text3);font-size:11px;line-height:1.5}.lm-error{background:var(--red-dim);color:var(--red);border:1px solid #ff45604d;border-radius:8px;padding:10px 14px;font-size:12px}.lm-form-btns{gap:10px;display:flex}.lm-save-btn{border:2px solid var(--cyan);color:#6b7fa3;background:#fff;border-radius:9px;padding:9px 20px;font-size:13px;font-weight:700;transition:all .2s;box-shadow:0 0 0 3px #00c2ff22}.lm-save-btn:hover{background:var(--cyan);color:var(--bg)}.lm-cancel-btn{border:1px solid var(--border);color:var(--text2);background:0 0;border-radius:9px;padding:9px 18px;font-size:13px}.lm-cancel-btn:hover{border-color:var(--text2);color:var(--text)}.lm-empty{text-align:center;flex-direction:column;align-items:center;gap:14px;padding:60px 20px;display:flex}.lm-empty-icon{font-size:48px}.lm-empty-title{font-size:18px;font-weight:600}.lm-empty-sub{color:var(--text2);max-width:420px;font-size:13px;line-height:1.7}.lm-list{flex-direction:column;gap:10px;display:flex}.lm-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;display:flex}.lm-card.healthy{border-color:#00e5a033}.lm-card.warning{border-color:#ffb80033}.lm-card.critical{border-color:#ff456033}.lm-card.waiting{border-color:var(--border)}.lm-card-left{align-items:center;gap:14px;display:flex}.lm-status-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.lm-status-dot.healthy{background:var(--green);animation:2s infinite pulse-dot}.lm-status-dot.warning{background:var(--yellow)}.lm-status-dot.critical{background:var(--red)}.lm-status-dot.waiting{background:var(--border-bright)}.lm-card-name{margin-bottom:4px;font-size:15px;font-weight:600}.lm-card-meta{color:var(--text3);gap:12px;font-size:11px;display:flex}.lm-card-id{font-family:var(--font-mono);color:var(--cyan)}.lm-card-right{flex-shrink:0;align-items:center;gap:16px;display:flex}.lm-card-stats{align-items:baseline;gap:4px;display:flex}.lm-online{color:var(--green);font-size:16px;font-weight:700;font-family:var(--font-mono)}.lm-total{color:var(--text2);font-size:12px}.lm-waiting{color:var(--text3);font-size:12px;font-style:italic}.lm-card-actions{gap:6px;display:flex}.lm-edit-btn{border:1px solid var(--border);color:var(--text2);background:0 0;border-radius:7px;padding:5px 12px;font-size:12px;transition:all .15s}.lm-edit-btn:hover{border-color:var(--cyan);color:var(--cyan)}.lm-del-btn{border:1px solid var(--border);color:var(--text2);background:0 0;border-radius:7px;padding:5px 12px;font-size:12px;transition:all .15s}.lm-del-btn:hover{border-color:var(--red);color:var(--red)}.gs-trigger{background:var(--surface2);border:1px solid var(--border);color:var(--text3);border-radius:9px;align-items:center;gap:8px;width:100%;padding:7px 14px;font-size:13px;transition:all .15s;display:flex}.gs-trigger:hover{border-color:var(--cyan);color:var(--text2)}.gs-icon{font-size:13px}.gs-placeholder{text-align:left;flex:1}.gs-shortcut{background:var(--surface3);border:1px solid var(--border);font-size:10px;font-family:var(--font-mono);border-radius:5px;padding:1px 6px}.gs-overlay{z-index:500;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;justify-content:center;align-items:flex-start;padding-top:80px;display:flex;position:fixed;inset:0}.gs-modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:100%;max-width:580px;animation:.15s fade-in;overflow:hidden;box-shadow:0 20px 60px #00000080}.gs-input-wrap{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:14px 16px;display:flex}.gs-input-icon{flex-shrink:0;font-size:16px}.gs-input{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-size:15px}.gs-input::placeholder{color:var(--text3)}.gs-clear{color:var(--text3);background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:13px}.gs-clear:hover{color:var(--text);background:var(--surface3)}.gs-results{max-height:360px;overflow-y:auto}.gs-result{cursor:pointer;border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 16px;transition:background .1s;display:flex}.gs-result:last-child{border-bottom:none}.gs-result:hover,.gs-result.sel{background:var(--surface3)}.gs-result.offline{opacity:.6}.gs-r-icon{flex-shrink:0;font-size:18px}.gs-r-body{flex:1;min-width:0}.gs-r-name{margin-bottom:3px;font-size:13px;font-weight:500}.gs-r-meta{color:var(--text3);flex-wrap:wrap;gap:10px;font-size:11px;display:flex}.gs-r-ip{color:var(--cyan);font-family:var(--font-mono)}.gs-r-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.gs-r-status{text-transform:uppercase;border-radius:4px;padding:2px 7px;font-size:9px;font-weight:700}.gs-r-status.online{background:var(--green-dim);color:var(--green)}.gs-r-status.offline{background:var(--red-dim);color:var(--red)}.gs-r-type{color:var(--text3);text-transform:capitalize;font-size:10px}.gs-hl{color:var(--cyan);background:#00c2ff33;border-radius:2px;font-style:normal}.gs-empty{text-align:center;color:var(--text3);padding:28px;font-size:13px}.gs-empty strong{color:var(--text)}.gs-footer{border-top:1px solid var(--border);color:var(--text3);gap:16px;padding:10px 16px;font-size:11px;display:flex}.eb-wrap{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;height:100%;padding:40px;animation:.2s fade-in;display:flex}.eb-icon{color:var(--yellow);font-size:36px}.eb-title{color:var(--text);font-size:16px;font-weight:600}.eb-msg{color:var(--red);font-size:12px;font-family:var(--font-mono);background:var(--red-dim);border:1px solid #ff45604d;border-radius:8px;max-width:480px;padding:10px 16px}.eb-btn{background:var(--surface);border:1px solid var(--border);color:var(--text2);border-radius:8px;margin-top:4px;padding:8px 20px;font-size:13px}.eb-btn:hover{border-color:var(--cyan);color:var(--cyan)}.theme-toggle{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text2);background:0 0;padding:6px 10px;font-size:14px;line-height:1;transition:all .15s}.theme-toggle:hover{border-color:var(--cyan);color:var(--cyan)}.dashboard{background:var(--bg);flex-direction:column;height:100vh;display:flex;overflow:hidden}.dashboard.center{text-align:center;justify-content:center;align-items:center;gap:14px;padding:40px}.dash-header{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;align-items:center;gap:16px;padding:12px 24px;display:flex}.dash-title{flex-shrink:0}.dash-title h1{margin-bottom:2px;font-size:16px;font-weight:600}.dash-sub{color:var(--text2);align-items:center;gap:5px;font-size:11px;display:flex}.dot{border-radius:50%;width:6px;height:6px;display:inline-block}.dot.green{background:var(--green)}.dot.red{background:var(--red)}.dot.yellow{background:var(--yellow)}.dash-search{flex:1;max-width:400px}.dash-right{flex-shrink:0;align-items:center;gap:10px;margin-left:auto;display:flex}.btn-icon{border:1px solid var(--border);color:var(--text2);background:0 0;border-radius:7px;padding:6px 10px;font-size:14px;transition:all .15s}.btn-icon:hover{border-color:var(--cyan);color:var(--cyan)}.clock-time{font-size:17px;font-weight:600;font-family:var(--font-mono);color:var(--cyan)}.clock-date{color:var(--text3);text-align:right;font-size:10px}.dash-body{flex:1;padding:20px 24px;overflow-y:auto}.spinner{border:2px solid var(--border);border-top:2px solid var(--cyan);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.state-title{font-size:18px;font-weight:600}.state-sub{color:var(--text2);font-size:13px}.state-sub.mono{font-family:var(--font-mono);color:var(--red)}.state-err{font-size:40px}.error-tips{color:var(--text2);text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:10px;max-width:440px;padding:14px 18px;font-size:12px;line-height:2}.error-tips code{color:var(--cyan);font-family:var(--font-mono)}.error-btns{gap:10px;display:flex}.btn-retry{background:var(--cyan-dim);border:1px solid var(--cyan);color:var(--cyan);border-radius:8px;padding:9px 20px;font-size:13px;font-weight:600}.btn-retry:hover{background:var(--cyan);color:var(--bg)}.btn-change{border:1px solid var(--border);color:var(--text2);background:0 0;border-radius:8px;padding:9px 20px;font-size:13px}.btn-change:hover{border-color:var(--text2);color:var(--text)}.stale-banner{background:var(--yellow-dim);border-bottom:1px solid var(--yellow);color:var(--yellow);flex-shrink:0;align-items:center;gap:12px;padding:8px 24px;font-size:12px;display:flex}.stale-retry{border:1px solid var(--yellow);color:var(--yellow);background:0 0;border-radius:6px;margin-left:auto;padding:3px 10px;font-size:11px}.stale-retry:hover{background:var(--yellow);color:var(--bg)}.toast-wrap{z-index:1000;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{cursor:pointer;border:1px solid #0000;border-radius:10px;align-items:center;gap:10px;min-width:240px;max-width:360px;padding:11px 16px;font-size:13px;font-weight:500;animation:.25s toast-in;display:flex}.toast-success{border-color:var(--green);color:var(--green);background:#0a3d2e}.toast-error{background:var(--red-dim);border-color:var(--red);color:var(--red)}.toast-warning{background:var(--yellow-dim);border-color:var(--yellow);color:var(--yellow)}.toast-info{background:var(--cyan-dim);border-color:var(--cyan);color:var(--cyan)}.toast-icon{flex-shrink:0;font-size:14px}.toast-msg{flex:1;line-height:1.4}.toast-close{opacity:.6;flex-shrink:0;font-size:11px}.toast:hover .toast-close{opacity:1}.dd-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;position:fixed;inset:0}.dd-panel{background:var(--surface);border-left:1px solid var(--border);z-index:201;flex-direction:column;width:360px;animation:.2s slide-in;display:flex;position:fixed;top:0;bottom:0;right:0}.dd-header{border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:20px;display:flex}.dd-icon{flex-shrink:0;font-size:32px}.dd-title-wrap{flex:1;min-width:0}.dd-name{text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px;font-size:16px;font-weight:600;overflow:hidden}.dd-status{text-transform:capitalize;align-items:center;gap:6px;font-size:12px;font-weight:600;display:flex}.dd-status.online{color:var(--green)}.dd-status.offline{color:var(--red)}.dd-sdot{background:currentColor;border-radius:50%;width:6px;height:6px;animation:2s infinite pulse-dot;display:inline-block}.dd-close{border:1px solid var(--border);color:var(--text3);background:0 0;border-radius:7px;flex-shrink:0;padding:6px 10px;font-size:14px}.dd-close:hover{border-color:var(--red);color:var(--red)}.dd-body{flex:1;padding:20px;overflow-y:auto}.dd-section-title{color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;font-size:10px;font-weight:700}.dd-fields{flex-direction:column;gap:4px;display:flex}.dd-field{background:var(--bg);border:1px solid var(--border);border-radius:8px;justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.dd-field-label{color:var(--text3);font-size:11px}.dd-field-value{color:var(--text);font-size:13px;font-weight:500}.dd-field-value.mono{font-family:var(--font-mono);color:var(--cyan);font-size:11px}.dd-field-value.online{color:var(--green);align-items:center;gap:5px;display:flex}.dd-field-value.offline{color:var(--red);align-items:center;gap:5px;display:flex}.dd-sdot-sm{background:currentColor;border-radius:50%;width:5px;height:5px;display:inline-block}.dd-rename{flex-direction:column;gap:8px;display:flex}.dd-rename-input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:9px;outline:none;width:100%;padding:10px 14px;font-size:13px}.dd-rename-input:focus{border-color:var(--cyan)}.dd-rename-input::placeholder{color:var(--text3)}.dd-rename-hint{color:var(--text3);font-size:11px}.app{grid-template-columns:220px 1fr;height:100vh;display:grid;overflow:hidden}
