@import"https://fonts.googleapis.com/css2?family=Fira+Code:wght@400;500;600&family=Fira+Sans:wght@400;500;600;700&display=swap";:root{--bg: #07090d;--bg-1: #0d1017;--bg-2: #141925;--border: #1e2533;--text: #e6edf6;--text-dim: #8b97a8;--primary: #3b82f6;--primary-2: #1e40af;--accent: #f59e0b;--online: #22c55e;--offline: #6b7280;--danger: #ef4444;--glow: 0 0 10px rgba(59, 130, 246, .35);--radius: 12px;--shadow: 0 8px 24px rgba(0, 0, 0, .45);--z-drawer: 30;--z-modal: 40;--z-toast: 50;--font-ui: "Fira Sans", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;--font-mono: "Fira Code", ui-monospace, SFMono-Regular, Menlo, monospace}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-ui);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.mono{font-family:var(--font-mono);font-variant-ligatures:none}h1,h2,h3{margin:0;font-weight:600;line-height:1.25}a{color:var(--primary);text-decoration:none}:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:6px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-ui);font-size:14px;font-weight:500;line-height:1;padding:0 14px;min-height:38px;border-radius:10px;border:1px solid transparent;background:transparent;color:var(--text);cursor:pointer;transition:background-color .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease,opacity .18s ease;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-2);border-color:var(--primary-2);box-shadow:var(--glow)}.btn-ghost{background:var(--bg-2);border-color:var(--border);color:var(--text)}.btn-ghost:hover:not(:disabled){border-color:var(--primary);color:var(--text)}.btn-danger{background:transparent;border-color:var(--danger);color:var(--danger)}.btn-danger:hover:not(:disabled){background:#ef44441f}.btn-icon{min-height:34px;width:34px;padding:0;border-radius:9px;background:transparent;border:1px solid var(--border);color:var(--text-dim)}.btn-icon:hover:not(:disabled){color:var(--text);border-color:var(--primary)}.btn-icon.danger:hover:not(:disabled){color:var(--danger);border-color:var(--danger)}.btn-sm{min-height:32px;font-size:13px;padding:0 10px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:13px;font-weight:500;color:var(--text-dim)}.input,.select,.textarea{font-family:var(--font-ui);font-size:14px;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:9px 12px;width:100%;transition:border-color .16s ease,box-shadow .16s ease}.input::placeholder,.textarea::placeholder{color:var(--text-dim)}.input:focus,.select:focus,.textarea:focus{border-color:var(--primary);outline:none;box-shadow:var(--glow)}.textarea{resize:vertical;min-height:72px;line-height:1.5}.field-hint{font-size:12px;color:var(--text-dim)}.field-error{font-size:12px;color:var(--danger)}.badge{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:var(--text)}.dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto;background:var(--offline)}.dot.online{background:var(--online);box-shadow:0 0 8px #22c55e99}.dot.offline{background:var(--offline)}.dot.disabled{background:var(--danger)}.card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius)}.app{min-height:100%;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:16px;height:60px;padding:0 22px;background:#0d1017eb;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.brand{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.2px}.brand-mark{display:inline-flex;color:var(--primary)}.topbar-spacer{flex:1}.nav-tabs{display:flex;gap:4px}.nav-tab{font-family:var(--font-ui);font-size:14px;font-weight:500;color:var(--text-dim);background:transparent;border:0;padding:8px 14px;border-radius:9px;cursor:pointer;transition:color .16s ease,background-color .16s ease}.nav-tab:hover{color:var(--text)}.nav-tab.active{color:var(--text);background:var(--bg-2)}.status-pill{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;padding:6px 12px;border-radius:999px;background:var(--bg-2);border:1px solid var(--border);color:var(--text-dim)}.status-pill .pill-mono{font-family:var(--font-mono);color:var(--text)}.content{flex:1;width:100%;max-width:1240px;margin:0 auto;padding:26px 22px 60px}.page-head{display:flex;align-items:center;gap:14px;margin-bottom:20px}.page-head h1{font-size:22px}.page-sub{color:var(--text-dim);font-size:13px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}.kpi{padding:18px;display:flex;flex-direction:column;gap:10px}.kpi-top{display:flex;align-items:center;justify-content:space-between}.kpi-label{font-size:13px;color:var(--text-dim);font-weight:500}.kpi-icon{color:var(--text-dim)}.kpi-value{font-family:var(--font-mono);font-size:28px;font-weight:600;line-height:1;color:var(--text)}.kpi-value.accent{color:var(--accent)}.kpi-foot{font-size:12px;color:var(--text-dim)}.dash-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:16px;align-items:start}.panel{padding:18px}.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.panel-title{font-size:15px;font-weight:600}.server-rows{display:flex;flex-direction:column;gap:0}.server-row{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--border)}.server-row:last-child{border-bottom:0}.server-row .k{color:var(--text-dim);font-size:13px}.server-row .v{font-family:var(--font-mono);font-size:13px;color:var(--text)}.chart-wrap{position:relative;width:100%}.chart-legend{display:flex;gap:16px;font-size:12px;color:var(--text-dim)}.legend-item{display:inline-flex;align-items:center;gap:6px}.legend-swatch{width:14px;height:3px;border-radius:2px;display:inline-block}.chart-svg{display:block;width:100%;height:auto}.chart-empty{display:flex;align-items:center;justify-content:center;height:180px;color:var(--text-dim);font-size:13px}.chart-tooltip{position:absolute;pointer-events:none;transform:translate(-50%,-110%);background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:12px;box-shadow:var(--shadow);white-space:nowrap;z-index:5}.chart-tooltip .tt-ts{color:var(--text-dim);font-family:var(--font-mono);margin-bottom:4px;font-size:11px}.chart-tooltip .tt-row{display:flex;align-items:center;gap:6px;font-family:var(--font-mono)}.toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}.search-box{position:relative;flex:1 1 240px;min-width:180px;max-width:360px}.search-box .search-ic{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-dim);pointer-events:none}.search-box .input{padding-left:36px}.segmented{display:inline-flex;background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:3px;gap:2px}.segmented button{font-family:var(--font-ui);font-size:13px;font-weight:500;color:var(--text-dim);background:transparent;border:0;padding:6px 12px;border-radius:8px;cursor:pointer;transition:color .15s ease,background-color .15s ease}.segmented button:hover{color:var(--text)}.segmented button[aria-pressed=true]{background:var(--primary);color:#fff}.toolbar-spacer{flex:1}.table-scroll{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-1)}table.clients{width:100%;border-collapse:collapse;min-width:880px}table.clients thead th{text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);background:var(--bg-2);padding:12px 14px;border-bottom:1px solid var(--border);white-space:nowrap}table.clients tbody td{padding:13px 14px;border-bottom:1px solid var(--border);font-size:14px;vertical-align:middle;white-space:nowrap}table.clients tbody tr:last-child td{border-bottom:0}table.clients tbody tr.row{cursor:pointer;transition:background-color .14s ease}table.clients tbody tr.row:hover{background:var(--bg-2)}table.clients tbody tr.disabled-row td:not(.actions-cell){opacity:.6}.cell-name{font-weight:500;color:var(--text)}.cell-note{font-size:12px;color:var(--text-dim);font-weight:400}.cell-mono{font-family:var(--font-mono);font-size:13px;color:var(--text)}.cell-dim{color:var(--text-dim)}.actions-cell{text-align:right}.row-actions{display:inline-flex;gap:6px;justify-content:flex-end}.skel{display:inline-block;height:12px;border-radius:6px;background:linear-gradient(90deg,var(--bg-2) 25%,#1b2230 37%,var(--bg-2) 63%);background-size:400% 100%;animation:skel 1.4s ease infinite}@keyframes skel{0%{background-position:100% 50%}to{background-position:0 50%}}.empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:54px 20px;text-align:center}.empty .empty-ic{color:var(--text-dim)}.empty h3{font-size:16px}.empty p{margin:0;color:var(--text-dim);font-size:13px;max-width:320px}table.clients.nodes-table{min-width:760px}table.clients.node-breakdown{min-width:520px}.node-driver{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:12px;font-weight:500;line-height:1;padding:4px 8px;border-radius:999px;border:1px solid var(--border);background:var(--bg-2);color:var(--text-dim)}.node-driver.local{color:var(--text-dim);border-color:var(--border)}.node-driver.ssh{color:var(--primary);border-color:#3b82f666}.node-tag{display:inline-flex;align-items:center;font-size:12px;font-weight:500;line-height:1;padding:4px 9px;border-radius:999px;border:1px solid var(--border);background:var(--bg-2);color:var(--text)}.note-banner{font-size:13px;color:var(--text-dim);background:var(--bg-2);border:1px solid var(--border);border-radius:9px;padding:10px 12px}.node-descriptor{min-height:160px;font-size:12px;line-height:1.55;white-space:pre;overflow-wrap:normal;word-break:normal}.probe-result{display:flex;align-items:center;gap:8px;font-size:13px;border-radius:9px;padding:9px 11px}.probe-result.ok{color:var(--online);background:#22c55e1a;border:1px solid rgba(34,197,94,.35)}.probe-result.err{color:var(--danger);background:#ef44441a;border:1px solid rgba(239,68,68,.35)}.modal.modal-wide{max-width:560px}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(1200px 600px at 50% -10%,rgba(59,130,246,.12),transparent 70%),var(--bg)}.login-card{width:100%;max-width:380px;padding:30px;background:var(--bg-1);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow)}.login-brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;margin-bottom:4px}.login-sub{color:var(--text-dim);font-size:13px;margin-bottom:22px}.login-form{display:flex;flex-direction:column;gap:16px}.login-error{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--danger);background:#ef44441a;border:1px solid rgba(239,68,68,.35);border-radius:9px;padding:9px 11px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:20px;z-index:var(--z-modal);animation:fade .16s ease}.modal{width:100%;max-width:440px;background:var(--bg-1);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);animation:pop .18s ease}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border)}.modal-head h2{font-size:17px}.modal-body{padding:20px;display:flex;flex-direction:column;gap:16px}.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--border)}.drawer-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:var(--z-drawer);animation:fade .16s ease}.drawer{position:fixed;top:0;right:0;height:100vh;width:100%;max-width:520px;background:var(--bg-2);border-left:1px solid var(--border);box-shadow:var(--shadow);z-index:var(--z-drawer);display:flex;flex-direction:column;animation:slide-in .22s cubic-bezier(.2,.8,.2,1)}.drawer-head{display:flex;align-items:flex-start;gap:12px;padding:18px 20px;border-bottom:1px solid var(--border)}.drawer-head .dh-main{flex:1;min-width:0}.drawer-head h2{font-size:19px;word-break:break-word}.drawer-head .dh-sub{font-size:12px;color:var(--text-dim);margin-top:4px;font-family:var(--font-mono)}.drawer-actions{display:flex;gap:8px;align-items:center}.drawer-body{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:22px}.drawer-section{display:flex;flex-direction:column;gap:12px}.section-title{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--text-dim)}.conf-block{position:relative}pre.conf{margin:0;font-family:var(--font-mono);font-size:12px;line-height:1.6;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:14px 46px 14px 14px;overflow-x:auto;white-space:pre}.copy-float{position:absolute;top:8px;right:8px}.qr-row{display:flex;gap:16px;align-items:center}.qr-img{width:140px;height:140px;border-radius:10px;border:1px solid var(--border);background:#fff;flex:0 0 auto;image-rendering:pixelated}.qr-meta{font-size:13px;color:var(--text-dim);display:flex;flex-direction:column;gap:4px}.qr-btn{padding:0;margin:0;border:0;background:none;line-height:0;border-radius:10px;cursor:pointer;flex:0 0 auto}.qr-btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.qr-btn .qr-img{transition:border-color .15s ease}.qr-btn:hover .qr-img{border-color:var(--primary)}.modal.qr-modal{max-width:380px}.qr-modal-body{padding:24px;display:flex;flex-direction:column;align-items:center;gap:16px}.qr-img-large{width:300px;height:300px;max-width:78vw;max-height:78vw;background:#fff;padding:12px;border-radius:12px;border:1px solid var(--border);image-rendering:pixelated}.qr-modal-hint{margin:0;max-width:320px;font-size:14px;line-height:1.5;color:var(--text-dim);text-align:center}.dl-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.share-box{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.share-row{display:flex;gap:8px;align-items:stretch}.share-row .input{flex:1 1 auto;min-width:0}.share-row .btn{flex:0 0 auto;white-space:nowrap}.share-hint{margin-top:8px;font-size:13px;line-height:1.5;color:var(--text-dim)}.share-actions{display:flex;gap:8px;margin-top:10px}.vpn-row{display:flex;gap:8px;margin:14px 0 6px}.vpn-row .btn{flex:1 1 auto;white-space:nowrap}.split-toggle{display:flex;gap:10px;align-items:flex-start;margin:8px 0 14px;font-size:13px;line-height:1.45;color:var(--text-dim);cursor:pointer}.split-toggle input{flex:0 0 auto;width:18px;height:18px;margin-top:1px;cursor:pointer;accent-color:var(--primary)}.dl-grid .btn{width:100%}.totals{display:grid;grid-template-columns:1fr 1fr;gap:12px}.total-card{padding:14px;background:var(--bg-1);border:1px solid var(--border);border-radius:10px}.total-card .tl{font-size:12px;color:var(--text-dim)}.total-card .tv{font-family:var(--font-mono);font-size:20px;font-weight:600;margin-top:4px}.total-card .tv.rx{color:var(--primary)}.total-card .tv.tx{color:var(--accent)}table.ip-history{width:100%;border-collapse:collapse}table.ip-history th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);padding:8px 10px;border-bottom:1px solid var(--border)}table.ip-history td{padding:9px 10px;border-bottom:1px solid var(--border);font-size:12px}table.ip-history tr:last-child td{border-bottom:0}.ip-cell{font-family:var(--font-mono);color:var(--text)}.ts-cell{font-family:var(--font-mono);color:var(--text-dim);font-size:11px}.toast-stack{position:fixed;bottom:20px;right:20px;z-index:var(--z-toast);display:flex;flex-direction:column;gap:10px;max-width:360px}.toast{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg-2);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);font-size:13px;animation:slide-up .2s ease}.toast.ok{border-color:#22c55e66}.toast.err{border-color:#ef444466}.toast .toast-ic{flex:0 0 auto}.toast.ok .toast-ic{color:var(--online)}.toast.err .toast-ic{color:var(--danger)}.spin{animation:spin .9s linear infinite}.center-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;color:var(--text-dim);gap:10px}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fade{0%{opacity:0}}@keyframes pop{0%{opacity:0;transform:scale(.96)}}@keyframes slide-in{0%{transform:translate(20px);opacity:0}}@keyframes slide-up{0%{transform:translateY(12px);opacity:0}}@media (max-width: 1024px){.dash-grid{grid-template-columns:1fr}}@media (max-width: 768px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.content{padding:20px 16px 48px}.nav-tabs{display:none}}@media (max-width: 480px){.kpi-grid{grid-template-columns:1fr}.status-pill .pill-label{display:none}.dl-grid,.totals{grid-template-columns:1fr}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}
