:root{--bg: #080a12;--bg2: #0d0f1c;--bg3: #111322;--card: #141728;--card2: #181b2e;--b1: rgba(255,255,255,.06);--b2: rgba(255,255,255,.1);--b3: rgba(255,255,255,.16);--vi: #7c6ff7;--vi2: #6055e0;--cy: #38bdf8;--gr: #34d399;--re: #fb7185;--am: #fbbf24;--grad: linear-gradient(135deg, #7c6ff7 0%, #38bdf8 100%);--glow: 0 0 40px rgba(124,111,247,.25);--t1: #f1f1f8;--t2: #6e7490;--t3: #373d5a;--sans: "Geist", -apple-system, sans-serif;--mono: "Geist Mono", "JetBrains Mono", monospace;--ease: cubic-bezier(.22, 1, .36, 1);--tx: .2s var(--ease)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{background:var(--bg);color:var(--t1);font-family:var(--sans);font-size:15px;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--b2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--b3)}.app{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--bg2);border-right:1px solid var(--b1);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform var(--tx)}.sidebar-logo{padding:20px 16px 16px;border-bottom:1px solid var(--b1);display:flex;align-items:center;gap:10px}.logo-icon{width:34px;height:34px;background:var(--grad);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 0 20px #7c6ff766}.logo-icon svg{width:18px;height:18px;color:#fff}.logo-name{font-size:14px;font-weight:600;letter-spacing:-.2px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.logo-sub{font-size:10px;color:var(--t3);margin-top:1px;font-family:var(--mono)}.nav{flex:1;padding:10px 8px;overflow-y:auto}.nav-section{font-size:10px;font-weight:600;color:var(--t3);letter-spacing:1.2px;text-transform:uppercase;padding:12px 10px 6px}.nav-item{display:flex;align-items:center;gap:9px;padding:10px 12px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:400;color:var(--t2);transition:all var(--tx);margin-bottom:2px;-webkit-user-select:none;user-select:none;position:relative;border:1px solid transparent}.nav-item svg{width:15px;height:15px;flex-shrink:0}.nav-item:hover{background:var(--card);color:var(--t1)}.nav-item.active{background:linear-gradient(135deg,#7c6ff726,#38bdf80f);color:var(--t1);border-color:#7c6ff733}.nav-item.active:before{content:"";position:absolute;left:-1px;top:25%;bottom:25%;width:3px;border-radius:0 3px 3px 0;background:var(--grad)}.version-sidebar-btn{margin:0 8px 8px;width:calc(100% - 16px);padding:9px 12px;border-radius:9px;background:var(--card);border:1px solid var(--b2);color:var(--t2);cursor:pointer;font-size:12px;font-weight:500;font-family:var(--sans);display:flex;align-items:center;gap:8px;transition:all var(--tx)}.version-sidebar-btn:hover{background:var(--card2);color:var(--t1);border-color:var(--b3)}.version-sidebar-btn svg{width:13px;height:13px;flex-shrink:0}.version-sidebar-tag{margin-left:auto;font-size:10px;font-weight:600;font-family:var(--mono);padding:1px 6px;border-radius:5px}.version-sidebar-tag.ok{background:#34d3991f;color:var(--gr)}.version-sidebar-tag.warn{background:#fbbf241f;color:var(--am)}.version-sidebar-tag.load{background:var(--b1);color:var(--t3)}.ver-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:4px}.ver-table th{text-align:left;padding:8px 12px;font-size:11px;font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.7px;border-bottom:1px solid var(--b1)}.ver-table td{padding:11px 12px;border-bottom:1px solid var(--b1);vertical-align:middle}.ver-table tr:last-child td{border-bottom:none}.ver-table tbody tr:hover td{background:#7c6ff70a}.node-info-row{margin-top:10px;padding-top:10px;border-top:1px solid var(--b1);font-size:11px;color:var(--t3);font-family:var(--mono);line-height:1.8;animation:pg-in .15s var(--ease)}.sidebar-footer{padding:12px;border-top:1px solid var(--b1)}.main{margin-left:240px;flex:1;padding:28px 32px;max-width:calc(100vw - 240px);min-height:100vh}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:12px}.page-title{font-size:22px;font-weight:600;letter-spacing:-.5px}.page-title em{font-style:normal;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.page-desc{font-size:13px;color:var(--t3);margin-top:3px;font-family:var(--mono)}.topbar-right{display:flex;align-items:center;gap:8px}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:9px;border:none;cursor:pointer;font-size:14px;font-weight:500;transition:all var(--tx);font-family:var(--sans);white-space:nowrap;line-height:1}.btn svg{width:15px;height:15px;flex-shrink:0}.btn-primary{background:var(--grad);color:#fff;box-shadow:0 0 20px #7c6ff74d}.btn-primary:hover{opacity:.87;transform:translateY(-1px);box-shadow:0 0 32px #7c6ff773}.btn-secondary{background:var(--card2);color:var(--t1);border:1px solid var(--b2)}.btn-secondary:hover{background:var(--card);border-color:var(--b3)}.btn-ghost{background:transparent;color:var(--t2);border:1px solid var(--b2)}.btn-ghost:hover{background:var(--card);color:var(--t1)}.btn-danger{background:transparent;color:var(--re);border:1px solid rgba(251,113,133,.2)}.btn-danger:hover{background:#fb718514;border-color:#fb718566}.btn-sm{padding:6px 13px;font-size:13px;border-radius:7px}.btn-sm svg{width:13px;height:13px}.btn-icon{padding:7px;width:34px;height:34px;justify-content:center}.btn-icon svg{width:16px;height:16px}.btn:disabled{opacity:.35;cursor:not-allowed;transform:none!important}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px}.stat-card{background:var(--card);border:1px solid var(--b1);border-radius:12px;padding:18px 20px;position:relative;overflow:hidden;transition:border-color var(--tx),transform var(--tx);cursor:default}.stat-card:hover{border-color:var(--b2);transform:translateY(-2px)}.stat-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.stat-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center}.stat-icon svg{width:17px;height:17px}.stat-icon.vi{background:#7c6ff71f;color:var(--vi);border:1px solid rgba(124,111,247,.2)}.stat-icon.gr{background:#34d3991f;color:var(--gr);border:1px solid rgba(52,211,153,.2)}.stat-icon.cy{background:#38bdf81f;color:var(--cy);border:1px solid rgba(56,189,248,.2)}.stat-icon.am{background:#fbbf241f;color:var(--am);border:1px solid rgba(251,191,36,.2)}.stat-val{font-size:32px;font-weight:700;font-family:var(--mono);letter-spacing:-1.5px;line-height:1;margin-bottom:4px}.stat-val.vi{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.stat-val.gr{color:var(--gr)}.stat-val.cy{color:var(--cy)}.stat-val.am{color:var(--am)}.stat-lbl{font-size:12px;color:var(--t3);font-weight:400}.card{background:var(--card);border:1px solid var(--b1);border-radius:12px;padding:20px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--b1)}.card-title{font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px}.card-title svg{width:15px;height:15px;color:var(--t3)}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.node-card{background:var(--card);border:1px solid var(--b1);border-radius:12px;padding:20px;cursor:pointer;transition:border-color var(--tx),transform var(--tx),box-shadow var(--tx);position:relative;overflow:hidden}.node-card:after{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--grad);opacity:0;transition:opacity var(--tx)}.node-card:hover{border-color:#7c6ff74d;transform:translateY(-3px);box-shadow:0 12px 40px #0000004d}.node-card:hover:after{opacity:1}.node-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#7c6ff726,#38bdf814);border:1px solid rgba(124,111,247,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0}.node-icon svg{width:18px;height:18px;color:var(--vi)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:14px}th{text-align:left;padding:11px 14px;color:var(--t3);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.7px;border-bottom:1px solid var(--b1);white-space:nowrap;background:var(--card);position:sticky;top:0;z-index:1}td{padding:12px 14px;border-bottom:1px solid var(--b1);vertical-align:middle}tr:last-child td{border-bottom:none}tr{transition:background var(--tx)}tbody tr:hover td{background:#7c6ff70a}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:500;font-family:var(--mono);white-space:nowrap}.badge-green{background:#34d3991a;color:var(--gr);border:1px solid rgba(52,211,153,.18)}.badge-red{background:#fb71851a;color:var(--re);border:1px solid rgba(251,113,133,.18)}.badge-amber{background:#fbbf241a;color:var(--am);border:1px solid rgba(251,191,36,.18)}.badge-blue{background:#38bdf81a;color:var(--cy);border:1px solid rgba(56,189,248,.18)}.badge-purple{background:#7c6ff71a;color:var(--vi);border:1px solid rgba(124,111,247,.18)}.dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}.dot-live{animation:dot-pulse 2.4s ease infinite}@keyframes dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.form-group{margin-bottom:14px}.form-label{display:block;font-size:12px;color:var(--t2);margin-bottom:5px;font-weight:500}.form-input{width:100%;padding:8px 11px;background:var(--bg3);border:1px solid var(--b2);border-radius:8px;color:var(--t1);font-size:13px;font-family:var(--sans);outline:none;transition:border-color var(--tx),box-shadow var(--tx)}.form-input:focus{border-color:var(--vi);box-shadow:0 0 0 3px #7c6ff726}.form-input::placeholder{color:var(--t3)}.radio-group{display:flex;gap:6px}.radio-btn{flex:1;padding:7px;border-radius:7px;text-align:center;font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--b2);color:var(--t2);background:var(--bg3);transition:all var(--tx);display:flex;align-items:center;justify-content:center;gap:6px}.radio-btn svg{width:12px;height:12px}.radio-btn.on{background:#7c6ff71f;color:var(--t1);border-color:#7c6ff74d}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:ov-in .15s ease}@keyframes ov-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg2);border:1px solid var(--b2);border-radius:16px;padding:0;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;animation:modal-in .22s var(--ease);box-shadow:0 32px 80px #0009}@keyframes modal-in{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:none}}.modal-head{padding:20px 22px 18px;border-bottom:1px solid var(--b1);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px}.modal-title svg{width:15px;height:15px;color:var(--vi)}.modal-close{cursor:pointer;color:var(--t3);transition:color var(--tx);background:none;border:none;padding:4px}.modal-close:hover{color:var(--t1)}.modal-close svg{width:16px;height:16px}.modal-body{padding:20px 22px}.modal-foot{padding:16px 22px;border-top:1px solid var(--b1);display:flex;gap:8px;justify-content:flex-end}.link-box{display:flex;align-items:center;gap:8px;background:var(--bg3);border:1px solid var(--b1);border-radius:7px;padding:6px 10px;font-family:var(--mono);font-size:11px;color:var(--cy);cursor:pointer;transition:all var(--tx);max-width:280px}.link-box:hover{border-color:var(--vi);background:var(--card)}.link-box svg{width:11px;height:11px;flex-shrink:0}.link-txt{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.toasts{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{display:flex;align-items:flex-start;gap:10px;background:var(--card2);border:1px solid var(--b2);border-radius:10px;padding:12px 14px;font-size:13px;min-width:240px;max-width:340px;animation:toast-in .25s var(--ease);box-shadow:0 12px 40px #00000080}.toast svg{width:15px;height:15px;flex-shrink:0;margin-top:1px}.toast.success{border-left:3px solid var(--gr)}.toast.success svg{color:var(--gr)}.toast.error{border-left:3px solid var(--re)}.toast.error svg{color:var(--re)}.toast.info{border-left:3px solid var(--vi)}.toast.info svg{color:var(--vi)}@keyframes toast-in{0%{transform:translate(32px) scale(.95);opacity:0}to{transform:none;opacity:1}}.spin{width:16px;height:16px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--cy);border-radius:50%;animation:spinning .5s linear infinite;display:inline-block;flex-shrink:0}.spin-sm{width:12px;height:12px}@keyframes spinning{to{transform:rotate(360deg)}}.loading-center{display:flex;align-items:center;justify-content:center;gap:10px;padding:48px;color:var(--t2);font-size:13px}.refreshing{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--t3)}.refreshing .spin{width:11px;height:11px}.empty{text-align:center;padding:56px 24px;color:var(--t3)}.empty-icon{margin-bottom:16px;display:flex;justify-content:center}.empty-icon svg{width:40px;height:40px;color:var(--t3);opacity:.4}.empty-title{font-size:14px;font-weight:500;color:var(--t2);margin-bottom:6px}.empty-desc{font-size:13px}.traf{font-family:var(--mono);font-size:11px;display:inline-flex;align-items:center;gap:6px}.traf .rx{color:var(--gr)}.traf .tx{color:var(--re)}.acts{display:flex;gap:4px;align-items:center;flex-wrap:wrap}.pg{animation:pg-in .22s var(--ease)}@keyframes pg-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.sec-lbl{font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:1.2px;margin:22px 0 14px;display:flex;align-items:center;gap:10px}.sec-lbl:after{content:"";flex:1;height:1px;background:var(--b1)}.divider{height:1px;background:var(--b1);margin:16px 0}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg);background-image:radial-gradient(ellipse 60% 50% at 50% 0%,rgba(124,111,247,.1) 0%,transparent 70%),radial-gradient(ellipse 40% 30% at 80% 80%,rgba(56,189,248,.05) 0%,transparent 60%)}.login-card{width:100%;max-width:400px;background:var(--bg2);border:1px solid var(--b2);border-radius:20px;overflow:hidden;box-shadow:0 32px 80px #00000080;animation:modal-in .3s var(--ease)}.login-head{padding:32px 28px 24px;text-align:center;border-bottom:1px solid var(--b1)}.login-icon{width:60px;height:60px;background:var(--grad);border-radius:18px;display:inline-flex;align-items:center;justify-content:center;margin-bottom:16px;box-shadow:0 0 40px #7c6ff766}.login-icon svg{width:28px;height:28px;color:#fff}.login-title{font-size:22px;font-weight:700;letter-spacing:-.5px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.login-sub{font-size:13px;color:var(--t3);margin-top:5px;font-family:var(--mono)}.login-body{padding:24px 28px 28px}.totp-code-input{text-align:center;font-size:32px;letter-spacing:12px;font-family:var(--mono);font-weight:600}@media (max-width: 860px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:8px 0 40px #00000080}.main{margin-left:0;max-width:100vw;padding:16px 14px 80px}.mobile-bar{display:flex!important}.stats-row{grid-template-columns:repeat(2,1fr);gap:10px}.grid-2{grid-template-columns:1fr}.stat-val{font-size:26px}.modal{border-radius:20px 20px 0 0;position:fixed;bottom:0;left:0;right:0;max-width:100%;max-height:90vh}.overlay{align-items:flex-end}table{font-size:12px}th,td{padding:8px 10px}.link-box{max-width:160px}}.mobile-bar{display:none;position:fixed;bottom:0;left:0;right:0;height:64px;background:#0d0f1cf2;border-top:1px solid var(--b1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:200;align-items:stretch}.mob-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;color:var(--t3);transition:color var(--tx);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.mob-item.active{color:var(--vi)}.mob-item svg{width:20px;height:20px}.mob-label{font-size:10px;font-weight:500}
