*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{margin:0}#root{min-height:100vh}:root{--bg:#0f1117;--bg-card:#1a1d27;--bg-sidebar:#141620;--bg-input:#1e2130;--border:#2a2d3a;--text:#c4c7d4;--text-h:#e8eaf0;--text-dim:#6b7080;--accent:#5b8def;--accent-hover:#4a7de0;--green:#4ade80;--red:#f87171;--yellow:#fbbf24;--orange:#fb923c}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}.app{min-height:100vh;display:flex}.sidebar{background:var(--bg-sidebar);border-right:1px solid var(--border);flex-direction:column;width:220px;padding:20px 0;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{border-bottom:1px solid var(--border);padding:0 20px 20px}.sidebar-header h2{color:var(--text-h);font-size:18px;font-weight:700}.user-email{color:var(--text-dim);font-size:12px}.sidebar ul{flex:1;padding:12px 0;list-style:none;overflow-y:auto}.sidebar li button{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;padding:10px 20px;font-size:14px;transition:background .15s,color .15s}.sidebar li button:hover{background:var(--bg-card);color:var(--text-h)}.sidebar li button.active{background:var(--accent);color:#fff}.dashboard-btn{background:linear-gradient(135deg, var(--accent), var(--accent-hover));color:#fff;text-align:center;letter-spacing:.3px;cursor:pointer;border:none;border-radius:8px;margin:16px 14px 8px;padding:12px 16px;font-size:14px;font-weight:700;transition:transform .15s,box-shadow .15s;display:block;box-shadow:0 2px 8px #5b8def40}.dashboard-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #5b8def66}.dashboard-btn.active{background:var(--text-h);color:var(--bg);box-shadow:0 0 0 2px var(--accent)}.nav-group-toggle{text-align:left;width:100%;color:var(--text-dim);cursor:pointer;text-transform:uppercase;letter-spacing:.5px;background:0 0;border:none;align-items:center;gap:8px;padding:10px 20px;font-size:13px;font-weight:600;transition:color .15s;display:flex}.nav-group-toggle:hover{color:var(--text-h)}.nav-group-toggle.group-active{color:var(--accent)}.nav-arrow{width:10px;font-size:9px}.nav-sub{padding:0;list-style:none}.nav-sub button{padding-left:40px!important;font-size:13px!important}.logout-btn{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:6px;margin:12px 20px 0;padding:8px;font-size:13px}.logout-btn:hover{border-color:var(--red);color:var(--red)}.content{flex:1;min-width:0;margin-left:220px;padding:24px 32px}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-form{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;width:360px;padding:40px}.login-form h1{color:var(--text-h);text-align:center;margin-bottom:24px;font-size:22px}.login-form input{background:var(--bg-input);border:1px solid var(--border);width:100%;color:var(--text-h);border-radius:6px;outline:none;margin-bottom:12px;padding:10px 14px;font-size:14px}.login-form input:focus{border-color:var(--accent)}.login-form button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;width:100%;margin-top:4px;padding:10px;font-size:14px;font-weight:600}.login-form button:hover{background:var(--accent-hover)}.login-form button:disabled{opacity:.6;cursor:not-allowed}.cards{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin:20px 0;display:grid}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:20px}.card h3{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:12px}.card-value{color:var(--text-h);font-size:28px;font-weight:700}.card-detail{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.card-detail span{background:var(--bg-input);border-radius:4px;padding:2px 8px;font-size:12px}.status-breakdown{flex-direction:column;gap:6px;margin-top:12px;display:flex}.status-row{align-items:center;gap:8px;font-size:13px;display:flex}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.status-dot-active{background:var(--green)}.status-dot-unpaid{background:var(--yellow)}.status-dot-expired{background:var(--red)}.status-dot-shaped{background:var(--orange)}.status-label{color:var(--text);flex:1}.status-count{color:var(--text-h);font-weight:600}.revenue-breakdown{flex-direction:column;gap:6px;margin-top:12px;display:flex}.revenue-row{justify-content:space-between;font-size:13px;display:flex}.revenue-row span:first-child{color:var(--text-dim)}.revenue-row span:last-child{color:var(--text-h);font-weight:500}.pool-grid{grid-template-columns:1fr 1fr;gap:12px;margin-top:8px;display:grid}.pool-item{background:var(--bg-input);border-radius:8px;flex-direction:column;align-items:center;padding:10px;display:flex}.pool-network{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.pool-count{color:var(--text-h);margin-top:2px;font-size:20px;font-weight:700}.pool-sub{color:var(--text-dim);margin-top:2px;font-size:10px}.page-header{align-items:center;gap:12px;margin-bottom:4px;display:flex}.page-header h1{margin-bottom:0}.refresh-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:6px;padding:5px 12px;font-size:13px;transition:border-color .15s,color .15s}.refresh-btn:hover{border-color:var(--accent);color:var(--accent)}h1{color:var(--text-h);margin-bottom:4px;font-size:22px}h2{color:var(--text-h);margin:20px 0 8px;font-size:16px}table{border-collapse:collapse;width:100%;margin:8px 0 16px}thead th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);border-bottom:1px solid var(--border);padding:10px 12px;font-size:11px}tbody td{border-bottom:1px solid var(--border);padding:10px 12px}tbody tr:hover{background:var(--bg-card)}tr.clickable{cursor:pointer}tr.inactive{opacity:.5}.mono{font-family:SF Mono,Fira Code,monospace;font-size:12px}.filters{gap:8px;margin:16px 0;display:flex}.filters input,.filters select{background:var(--bg-input);border:1px solid var(--border);color:var(--text-h);border-radius:6px;outline:none;padding:8px 12px;font-size:13px}.filters input:focus,.filters select:focus{border-color:var(--accent)}.filters button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:13px}.pagination{align-items:center;gap:12px;margin:16px 0;display:flex}.pagination button{background:var(--bg-card);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:6px;padding:6px 14px;font-size:13px}.pagination button:disabled{opacity:.4;cursor:not-allowed}.pagination span{color:var(--text-dim);font-size:13px}.status-active{color:var(--green)}.status-expired{color:var(--red)}.status-unpaid{color:var(--yellow)}.status-shaped{color:var(--orange)}.loading{color:var(--text-dim);text-align:center;padding:40px}.error{border:1px solid var(--red);color:var(--red);background:#f871711a;border-radius:6px;margin-bottom:16px;padding:10px 16px;font-size:13px}table button{background:var(--bg-input);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:4px;padding:4px 10px;font-size:12px}table button:hover{border-color:var(--accent);color:var(--accent)}.client-detail>button:first-child{background:var(--bg-card);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:6px;margin-bottom:16px;padding:6px 14px;font-size:13px}.client-detail>button:first-child:hover{border-color:var(--accent);color:var(--accent)}.node-form{max-width:800px}.node-form h2{margin-bottom:16px}.form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-group{flex-direction:column;gap:4px;display:flex}.form-group label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.3px;font-size:12px;font-weight:600}.form-group input,.form-group select{background:var(--bg-input);border:1px solid var(--border);color:var(--text-h);border-radius:6px;outline:none;padding:8px 12px;font-size:13px}.form-group input:focus,.form-group select:focus{border-color:var(--accent)}.traffic-input{align-items:center;gap:10px;display:flex}.traffic-input input{flex:1}.checkbox-label{white-space:nowrap;cursor:pointer;align-items:center;gap:5px;display:flex;color:var(--text)!important;text-transform:none!important;letter-spacing:0!important;font-size:13px!important;font-weight:400!important}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}.form-actions{gap:8px;margin-top:20px;display:flex}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:8px 20px;font-size:13px;font-weight:600}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--bg-card);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:6px;padding:8px 20px;font-size:13px}.btn-secondary:hover{border-color:var(--text-dim)}.node-details-grid{grid-template-columns:1fr 1fr 1fr;gap:8px;padding:12px 0;font-size:13px;display:grid}.node-actions-bar{border-top:none;flex-wrap:nowrap;gap:4px;margin-top:0;padding-top:0;display:flex}.node-action-btn{cursor:pointer;border:1px solid var(--border);background:var(--bg-input);color:var(--text);white-space:nowrap;border-radius:4px;align-items:center;gap:3px;padding:3px 8px;font-size:11px;font-weight:500;transition:background .15s,border-color .15s;display:flex}.node-action-btn:hover{filter:brightness(1.2)}.action-icon{font-size:12px}.action-edit{background:var(--bg-card);border-color:var(--accent);color:var(--accent)}.action-edit:hover{background:#5b8def1a}.action-script{background:var(--bg-card);color:var(--text-h)}.action-script:hover{border-color:var(--text-h);background:var(--bg-input)}.action-apply{border-color:var(--green);color:var(--green);background:#4ade801a}.action-apply:hover{background:#4ade8033}.action-danger{border-color:var(--red);color:var(--red);background:#f871710f}.action-danger:hover{background:#f8717126}.node-services{border-top:1px dashed var(--border);margin-top:16px;padding-top:12px}.node-services h3{text-transform:uppercase;letter-spacing:.5px;color:var(--accent);margin-bottom:6px;font-size:12px}.node-services table{font-size:13px}.node-role-badge{background:var(--accent);color:#fff;text-transform:uppercase;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600}.accordion{flex-direction:column;gap:8px;margin-top:16px;display:flex}.accordion-item{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;overflow:hidden}.accordion-item.inactive{opacity:.5}.accordion-header{cursor:pointer;align-items:center;gap:12px;padding:14px 16px;transition:background .15s;display:flex}.accordion-header:hover{background:var(--bg-input)}.accordion-arrow{color:var(--text-dim);width:14px;font-size:11px}.accordion-title{color:var(--text-h);font-size:14px}.accordion-meta{color:var(--text-dim);font-family:SF Mono,Fira Code,monospace;font-size:12px}.accordion-badge{background:var(--bg-input);color:var(--text-dim);border-radius:4px;margin-left:auto;padding:2px 8px;font-size:11px}.accordion-body{border-top:1px solid var(--border);padding:0 16px 16px}.accordion-body table{margin-top:12px}.accordion-details{color:var(--text);gap:24px;padding:12px 0 4px;font-size:13px;display:flex}.accordion-empty{color:var(--text-dim);padding:12px 0;font-size:13px}.telem-total{color:var(--text-dim);margin-left:4px;font-size:13px}.telem-bar-wrap{background:var(--bg-input);border-radius:5px;flex:1;height:10px;margin:0 8px;display:flex;overflow:hidden}.telem-bar{height:100%}.telem-bar-ok{background:var(--green)}.telem-bar-err{background:var(--red)}.telem-rate{text-align:right;min-width:48px;font-size:13px;font-weight:600}.rate-good{color:var(--green)}.rate-warn{color:var(--yellow)}.rate-bad{color:var(--red)}.filters button{background:var(--bg-card);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:6px;padding:6px 14px;font-size:13px}.filters button.filter-active{background:var(--accent);border-color:var(--accent);color:#fff}.daily-chart{margin:16px 0}.chart-bars{align-items:flex-end;gap:4px;height:120px;padding:8px 0;display:flex}.chart-col{flex-direction:column;flex:1;align-items:center;height:100%;display:flex}.chart-bar-container{flex-direction:column;flex:1;justify-content:flex-end;width:100%;display:flex}.chart-bar{border-radius:2px;width:100%;min-height:1px}.chart-bar-ok{background:var(--green)}.chart-bar-err{background:var(--red)}.chart-label{color:var(--text-dim);white-space:nowrap;margin-top:4px;font-size:10px}.ssh-status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.dot-active{background:var(--green)}.dot-inactive{background:var(--red)}.ssh-actions{gap:6px;margin-left:auto;display:flex}.ssh-actions button{background:var(--bg-input);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:4px;padding:4px 10px;font-size:12px}.ssh-actions button:hover{border-color:var(--accent);color:var(--accent)}.btn-danger{color:var(--red)!important;border-color:var(--red)!important}.btn-danger:hover{background:#f871711a!important}.ssh-key-preview{border-top:1px solid var(--border);padding:8px 16px}.ssh-key-preview code{color:var(--text-dim);word-break:break-all;font-family:SF Mono,Fira Code,monospace;font-size:11px;line-height:1.4}.ssh-key-notes{color:var(--text-dim);padding:4px 16px 10px;font-size:12px;font-style:italic}.ssh-key-textarea{background:var(--bg-input);border:1px solid var(--border);width:100%;color:var(--text-h);resize:vertical;border-radius:6px;outline:none;padding:8px 12px;font-family:SF Mono,Fira Code,monospace;font-size:12px}.ssh-key-textarea:focus{border-color:var(--accent)}.config-group{margin-bottom:20px}.config-group-header{cursor:pointer;align-items:center;gap:10px;padding:8px 0;display:flex}.config-group-header h2{margin:0}.config-list{flex-direction:column;gap:8px;margin-top:8px;display:flex}.config-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;overflow:hidden}.config-card-header{justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.config-card-info{flex-direction:column;gap:2px;display:flex}.config-key{color:var(--accent);font-family:SF Mono,Fira Code,monospace;font-size:13px;font-weight:600}.config-desc{color:var(--text-dim);font-size:12px}.config-card-value{border-top:1px solid var(--border);background:var(--bg);cursor:default;padding:8px 16px}.config-card-value code{color:var(--text);word-break:break-all;font-family:SF Mono,Fira Code,monospace;font-size:12px}.config-card-value pre{white-space:pre-wrap;word-break:break-all;margin:0}.config-expand{color:var(--accent);cursor:pointer;font-size:11px}.config-card-footer{border-top:1px solid var(--border);color:var(--text-dim);padding:6px 16px;font-size:11px}.config-textarea{min-height:80px}.client-actions{flex-wrap:wrap;gap:12px;margin:12px 0 20px;display:flex}.action-group{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;align-items:center;gap:6px;padding:8px 12px;display:flex}.action-group label{color:var(--text-dim);white-space:nowrap;font-size:12px}.action-group input,.action-group select{background:var(--bg-input);border:1px solid var(--border);color:var(--text-h);border-radius:4px;width:80px;padding:5px 8px;font-size:13px}.action-group select{width:auto}.links-container{justify-content:center;gap:120px;margin-top:16px;display:flex;position:relative}.links-svg{pointer-events:none;z-index:0;width:100%;height:100%;position:absolute;inset:0}.links-col{z-index:1;flex-direction:column;gap:12px;min-width:280px;display:flex;position:relative}.links-col h2{text-align:center;margin:0 0 4px}.link-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:14px;transition:border-color .2s,box-shadow .2s}.link-card-active{border-color:var(--accent);box-shadow:0 0 12px #5b8def40}.link-card-target{border-color:var(--green);cursor:pointer}.link-card-target:hover{box-shadow:0 0 12px #4ade804d}.link-card-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.link-card-meta{color:var(--text-dim);margin-bottom:8px;font-size:12px}.link-card-routes{flex-direction:column;gap:4px;margin-bottom:8px;display:flex}.route-tag{border-radius:4px;align-items:center;gap:6px;padding:4px 8px;font-size:12px;display:flex}.route-active{color:var(--green);background:#4ade801a}.route-disabled{color:var(--text-dim);background:#6b70801a}.weight-input{background:var(--bg-input);border:1px solid var(--border);width:36px;color:var(--text-h);text-align:center;border-radius:3px;padding:1px 4px;font-size:11px}.route-toggle,.route-del{cursor:pointer;color:inherit;background:0 0;border:none;padding:0 2px;font-size:14px}.route-del:hover{color:var(--red)}.btn-link{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:4px;width:100%;padding:4px 10px;font-size:12px}.btn-link:hover{border-color:var(--accent);color:var(--accent)}.linking-hint{color:var(--green);font-size:13px;animation:1.5s infinite pulse}.sni-legend{color:var(--text-dim);gap:16px;margin:12px 0 16px;font-size:12px;display:flex}.sni-legend>div{align-items:center;gap:6px;display:flex}.legend-dot{border-radius:3px;width:12px;height:12px;display:inline-block}.cell-clean{background:#4ade8066}.cell-warn{background:#fbbf2466}.cell-blocked{background:#f8717166}.cell-nodata{background:#6b708033}.country-bars{flex-direction:column;gap:6px;margin:12px 0 24px;display:flex}.country-bar{align-items:center;gap:12px;display:flex}.country-bar-label{flex-direction:column;width:140px;font-size:13px;display:flex}.country-bar-label .dim{color:var(--text-dim);font-size:10px}.country-bar-track{background:var(--bg-input);border-radius:4px;flex:1;height:18px;display:flex;overflow:hidden}.cb{height:100%}.cb-clean{background:var(--green)}.cb-warn{background:var(--yellow)}.cb-blocked{background:var(--red)}.cb-nodata{background:var(--bg-input)}.sni-matrix-wrap{margin-top:12px;overflow-x:auto}.sni-matrix{border-collapse:collapse;width:100%;font-size:12px}.sni-matrix th{background:var(--bg-card);border-bottom:1px solid var(--border);text-align:center;z-index:1;padding:8px 6px;position:sticky;top:0}.sni-matrix th.sni-domain-col{text-align:left;min-width:200px;padding-left:12px}.sni-matrix th.sni-cc{width:50px;font-family:SF Mono,monospace}.sni-matrix tbody tr:hover{background:var(--bg-card)}.sni-matrix td{border-bottom:1px solid var(--border);text-align:center;padding:6px}.sni-matrix td.sni-domain{text-align:left;padding-left:12px}.sni-matrix td.sni-cat{color:var(--text-dim);font-size:10px}.sni-cell{cursor:pointer;color:var(--text-h);border:1px solid var(--border);font-size:11px;font-weight:600}.sni-cell:hover{outline:2px solid var(--accent)}.sni-tooltip{background:var(--bg-card);border:1px solid var(--accent);z-index:50;border-radius:8px;min-width:280px;padding:12px 16px;font-size:12px;line-height:1.6;position:fixed;top:80px;right:32px;box-shadow:0 4px 16px #0006}.sni-tooltip .dim{color:var(--text-dim);font-size:10px}.sni-current-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin:12px 0 24px;display:grid}.sni-country-card{border:1px solid var(--border);text-align:center;border-radius:8px;padding:12px}.cc-code{color:var(--text-h);font-size:16px;font-weight:700}.cc-name{color:var(--text-dim);margin-bottom:6px;font-size:11px}.cc-status{font-size:12px;font-weight:600}.cc-detail{color:var(--text-dim);margin-top:4px;font-size:11px}.sni-history{flex-direction:column;gap:6px;margin-top:12px;display:flex}.history-row{background:var(--bg-card);border-radius:6px;align-items:center;gap:12px;padding:8px 12px;display:flex}.history-label{width:120px;font-size:13px}.history-label .dim{color:var(--text-dim);font-size:11px}.history-bars{flex:1;align-items:flex-end;gap:1px;height:40px;display:flex}.history-bar{border-radius:1px;flex:1;min-width:2px}.history-meta{color:var(--text-dim);text-align:right;width:50px;font-size:11px}.ip-matrix-wrap{margin-top:12px;overflow-x:auto}.ip-matrix{border-collapse:collapse;width:100%;font-size:12px}.ip-matrix th{background:var(--bg-card);border-bottom:1px solid var(--border);text-align:center;padding:8px 6px}.ip-matrix th.sni-domain-col{text-align:left;min-width:220px;padding-left:12px}.ip-matrix th.sni-cc{width:70px;font-family:SF Mono,monospace}.ip-matrix th.cc-high-risk{color:var(--red);background:#f8717126}.ip-matrix td{border-bottom:1px solid var(--border);border-right:1px solid var(--border);text-align:center;padding:8px 6px}.ip-matrix td.sni-domain{text-align:left;padding-left:12px}.ip-matrix .sni-cell{cursor:pointer;color:var(--text-h);font-size:13px;font-weight:700}.ip-matrix .sni-cell:hover{outline:2px solid var(--accent)}.alerts-list{flex-direction:column;gap:6px;margin:12px 0 24px;display:flex}.alert-row{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--yellow);border-radius:6px;align-items:center;gap:16px;padding:10px 14px;font-size:13px;display:flex}.alert-row.alert-critical{border-left-color:var(--red);background:#f871710f}.alert-cc{color:var(--text-h);font-weight:600}.alert-sr{color:var(--red);margin-left:auto;font-weight:700}.modal-wide{width:800px;max-width:95vw}.ip-chart{background:var(--bg-input);border-radius:6px;align-items:flex-end;gap:1px;height:80px;margin-bottom:16px;padding:4px;display:flex}.ip-bar{border-radius:1px;flex:1;min-width:2px;min-height:1px}.tier-summary{gap:8px;margin:16px 0 12px;display:flex}.tier-pill{background:var(--bg-card);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:20px;align-items:center;gap:8px;padding:8px 16px;font-size:12px;font-weight:700;transition:transform .1s;display:flex}.tier-pill:hover{transform:translateY(-1px)}.tier-pill.active{box-shadow:0 0 0 2px var(--accent)}.tier-count{background:#0006;border-radius:10px;padding:1px 8px;font-size:11px}.tier-badge{letter-spacing:.5px;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-block}.tier-gold{color:#1a1d27;background:linear-gradient(135deg,#fbbf24,#f59e0b)}.tier-silver{color:#1a1d27;background:linear-gradient(135deg,#cbd5e1,#94a3b8)}.tier-bronze{color:#fff;background:linear-gradient(135deg,#cd7f32,sienna)}.tier-unrated{background:var(--bg-input);color:var(--text-dim)}.tier-reject{background:var(--red);color:#fff}.tier-pill.tier-gold{color:#fbbf24;background:linear-gradient(135deg,#fbbf2433,#f59e0b33);border-color:#fbbf24}.tier-pill.tier-silver{color:#cbd5e1;background:linear-gradient(135deg,#cbd5e126,#94a3b826);border-color:#cbd5e1}.tier-pill.tier-bronze{color:#cd7f32;background:linear-gradient(135deg,#cd7f3226,#a0522d26);border-color:#cd7f32}.sni-scanned-table{font-size:12px}.sni-scanned-table .dim{color:var(--text-dim)}.notes-cell{cursor:pointer;color:var(--text-dim);border-radius:3px;min-width:100px;padding:2px 6px;font-size:11px;display:inline-block}.notes-cell:hover{background:var(--bg-input);color:var(--text-h)}.dpi-sources{gap:12px;margin:16px 0;display:flex}.dpi-source-card{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--green);border-radius:6px;flex-direction:column;gap:4px;padding:12px 16px;font-size:13px;display:flex}.dpi-source-card.dpi-stale{border-left-color:var(--yellow)}.dpi-source-card .dim{color:var(--text-dim);font-size:11px}.dpi-matrix .dpi-target{text-align:left;min-width:220px;padding-left:12px}.dpi-section-header td{background:var(--bg-input);color:var(--text-h);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--accent);font-size:11px;font-weight:700;padding:8px 12px!important}.dpi-cell-label{font-size:12px;font-weight:700}.dpi-known{color:var(--yellow);margin-top:2px;font-size:9px}.cell-firewall{color:var(--accent)!important;background:#5b8def26!important}.dpi-delta-marker{color:var(--yellow);width:60px;font-size:11px;font-weight:700}.chat-layout{border:1px solid var(--border);border-radius:10px;gap:0;height:calc(100vh - 140px);margin-top:16px;display:flex;overflow:hidden}.chat-sidebar{border-right:1px solid var(--border);background:var(--bg-card);width:280px;overflow-y:auto}.chat-user{border-bottom:1px solid var(--border);cursor:pointer;padding:12px 14px;transition:background .1s}.chat-user:hover{background:var(--bg-input)}.chat-user.active{background:var(--bg-input);border-left:3px solid var(--accent)}.chat-user.chat-unread{border-left:3px solid var(--green)}.chat-user-id{color:var(--text-h);font-family:SF Mono,monospace;font-size:11px}.chat-preview{color:var(--text-dim);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-size:12px;overflow:hidden}.chat-time{color:var(--text-dim);margin-top:4px;font-size:10px}.chat-messages{background:var(--bg);flex-direction:column;flex:1;display:flex}.chat-thread{flex-direction:column;flex:1;gap:8px;padding:16px;display:flex;overflow-y:auto}.chat-msg{max-width:70%}.msg-in{align-self:flex-start}.msg-out{align-self:flex-end}.msg-bubble{word-break:break-word;border-radius:12px;padding:8px 14px;font-size:13px;line-height:1.4}.msg-in .msg-bubble{background:var(--bg-card);color:var(--text-h);border-bottom-left-radius:2px}.msg-out .msg-bubble{background:var(--accent);color:#fff;border-bottom-right-radius:2px}.msg-time{color:var(--text-dim);margin-top:2px;padding:0 4px;font-size:10px}.chat-input{border-top:1px solid var(--border);background:var(--bg-card);gap:8px;padding:12px 16px;display:flex}.chat-input input{background:var(--bg-input);border:1px solid var(--border);color:var(--text-h);border-radius:8px;outline:none;flex:1;padding:10px 14px;font-size:13px}.chat-input input:focus{border-color:var(--accent)}.dpi-delta-kind{text-transform:uppercase;color:var(--text-dim);background:var(--bg-input);border-radius:3px;margin-right:8px;padding:2px 8px;font-size:10px}.script-toolbar{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;gap:8px;margin:16px 0;padding:12px;display:flex}.script-cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin:12px 0 24px;display:grid}.script-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:8px;padding:16px;display:flex}.script-card.script-dangerous{border-color:var(--red)}.script-card-header{align-items:center;gap:8px;display:flex}.script-card-desc{color:var(--text-dim);font-size:12px;line-height:1.4}.script-warn{color:var(--red);background:#f8717126;border-radius:3px;padding:1px 6px;font-size:10px;font-weight:600}.modal-overlay{z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;width:480px;max-width:90vw;max-height:80vh;padding:28px;overflow-y:auto}.modal h2{margin-bottom:8px}.btn-danger-bg{background:var(--red)!important}.script-output-view{max-width:100%}.run-meta{color:var(--text-dim);flex-wrap:wrap;gap:16px;margin:12px 0;font-size:13px;display:flex}.script-toast{background:var(--green);color:#000;z-index:200;border-radius:8px;padding:10px 20px;font-size:13px;font-weight:600;animation:.2s fadeIn;position:fixed;bottom:24px;right:24px}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.cron-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:12px;margin-top:16px;display:grid}.cron-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:8px;padding:16px;display:flex}.cron-card-header{justify-content:space-between;align-items:center;display:flex}.cron-schedule{background:var(--bg-input);color:var(--accent);border-radius:4px;padding:2px 8px;font-family:SF Mono,Fira Code,monospace;font-size:12px}.cron-card-desc{color:var(--text-dim);font-size:12px;line-height:1.4}.cron-log-preview{background:#0a0b0f;border-radius:6px;padding:8px 10px;overflow:hidden}.cron-log-preview pre{color:var(--green);white-space:pre-wrap;word-break:break-all;max-height:80px;margin:0;font-family:SF Mono,Fira Code,monospace;font-size:11px;line-height:1.4;overflow:hidden}.cron-card-meta{color:var(--text-dim);gap:12px;font-size:11px;display:flex}.cron-card-actions{gap:6px;margin-top:4px;display:flex}.live-badge{background:var(--red);color:#fff;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:700;animation:1.5s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.cursor-blink{color:var(--green);animation:1s step-end infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.live-panel{border:1px solid var(--border);background:var(--bg-card);border-radius:10px;margin-top:24px;overflow:hidden}.live-panel-header{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 16px;font-size:13px;display:flex}.live-panel .script-output{border:none;border-radius:0;max-height:400px}.script-output-live{border-color:var(--green)}.script-output{border:1px solid var(--border);color:var(--green);white-space:pre-wrap;word-break:break-all;background:#0a0b0f;border-radius:8px;max-height:600px;padding:16px;font-family:SF Mono,Fira Code,monospace;font-size:12px;line-height:1.5;overflow-y:auto}.cell-red{color:#ef9a9a;background:#e573732e}.cell-yellow{color:#ffcc80;background:#ffa72629}
