:root{--color-primary: #3b82f6;--color-success: #10b981;--color-error: #ef4444;--color-warning: #f59e0b;--color-bg: #0f172a;--color-surface: #1e293b;--color-surface-light: #334155;--color-text: #f1f5f9;--color-text-muted: #94a3b8;--color-border: #475569;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--radius: 8px}[data-theme=light]{--color-bg: #f1f5f9;--color-surface: #ffffff;--color-surface-light: #e2e8f0;--color-text: #1e293b;--color-text-muted: #64748b;--color-border: #cbd5e1}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.6}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{background:linear-gradient(135deg,var(--color-primary) 0%,#6366f1 100%);padding:var(--spacing-lg);text-align:center;box-shadow:0 4px 6px #0000004d}.app-header h1{font-size:2rem;margin-bottom:var(--spacing-sm);font-weight:700}.app-header p{font-size:1rem;opacity:.9}.app-main{flex:1;padding:var(--spacing-lg) clamp(12px,2vw,28px);width:min(96vw,2100px);margin:0 auto}.config-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.config-panel h2{margin-bottom:var(--spacing-md);color:var(--color-primary)}.iperf-info{background:var(--color-surface-light);padding:var(--spacing-md);border-radius:var(--radius);margin-bottom:var(--spacing-md);border-left:3px solid var(--color-success)}.iperf-info small{color:var(--color-text-muted)}.profiles-bar{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg);border-radius:var(--radius)}.profile-select{flex:1;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:8px 12px;color:var(--color-text);font-size:.9rem;cursor:pointer;appearance:auto}.profile-select:focus{outline:none;border-color:var(--color-primary)}.profile-select:disabled{opacity:.5;cursor:not-allowed}form{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-group label{font-weight:600;color:var(--color-text)}.form-group .required{color:var(--color-error)}.form-group input{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:10px 12px;color:var(--color-text);font-size:.95rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--color-primary)}.form-group input:disabled{opacity:.5;cursor:not-allowed}.form-group small{color:var(--color-text-muted);font-size:.85rem}.public-wan-picker{margin-top:8px;display:flex;flex-direction:column;gap:6px;width:100%;max-width:100%;min-width:0}.public-wan-row{display:grid;grid-template-columns:1fr 120px auto;gap:8px;align-items:center;width:100%;max-width:100%;min-width:0}.public-wan-row>*{min-width:0}.public-wan-row select{width:100%;max-width:100%;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:8px 10px;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.btn-primary{background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius);padding:12px 24px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.loading-indicator{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-lg);text-align:center;margin-bottom:var(--spacing-lg)}.spinner{width:40px;height:40px;margin:0 auto var(--spacing-md);border:4px solid var(--color-surface-light);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-banner{background:#ef44441a;border:1px solid var(--color-error);border-radius:var(--radius);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);color:var(--color-error)}.npcap-banner{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);background:#f59e0b26;border:1px solid var(--color-warning);border-radius:var(--radius);padding:var(--spacing-sm) var(--spacing-md);margin:0 var(--spacing-lg);color:var(--color-warning);font-size:.9rem}.success-banner{background:#10b9811a;border:1px solid var(--color-success);border-radius:var(--radius);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);color:var(--color-success);font-weight:500}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.progress-step{font-weight:600;color:var(--color-primary);text-transform:uppercase;font-size:.9rem;letter-spacing:.5px}.progress-percent{font-weight:700;color:var(--color-text);font-size:1.1rem}.progress-bar-track{width:100%;height:12px;background:var(--color-bg);border-radius:6px;overflow:hidden;margin-bottom:var(--spacing-sm)}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),#6366f1);border-radius:6px;transition:width .3s ease;min-width:0}.progress-detail{color:var(--color-text-muted);font-size:.9rem;text-align:center}.results-display{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-lg)}.results-placeholder{text-align:center;padding:var(--spacing-lg) * 2;color:var(--color-text-muted)}.results-header{margin-bottom:var(--spacing-lg)}.results-header h2{color:var(--color-primary);margin-bottom:var(--spacing-sm)}.metadata{display:flex;gap:var(--spacing-lg);color:var(--color-text-muted);font-size:.9rem;flex-wrap:wrap}.results-cards{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.test-card{border-radius:var(--radius);padding:var(--spacing-md);border:2px solid}.test-card-blue{background:#3b82f61a;border-color:var(--color-primary)}.test-card-green{background:#10b9811a;border-color:var(--color-success)}.test-card h3{margin-bottom:var(--spacing-md);font-size:1.2rem}.test-card-content{display:flex;flex-direction:column;gap:var(--spacing-sm)}.test-info{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm);background:var(--color-bg);border-radius:4px}.test-info.highlight{background:var(--color-surface-light);font-weight:600;font-size:1.1rem}.test-info .label{color:var(--color-text-muted)}.test-info .value{color:var(--color-text);font-weight:500}.status{padding:4px 12px;border-radius:4px;font-size:.85rem;font-weight:600}.status.success{background:#10b98133;color:var(--color-success)}.status.error{background:#ef444433;color:var(--color-error)}.error-message{background:#ef44441a;border:1px solid var(--color-error);border-radius:4px;padding:var(--spacing-sm);color:var(--color-error);font-size:.9rem}.comparison-chart{margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--radius)}.comparison-chart h3{margin-bottom:var(--spacing-md);color:var(--color-text)}.chart-row{display:grid;grid-template-columns:80px 1fr;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.chart-label{font-weight:600;color:var(--color-text)}.chart-bar-container{background:var(--color-surface);border-radius:4px;height:40px;overflow:hidden}.chart-bar{height:100%;display:flex;align-items:center;justify-content:flex-end;padding:0 var(--spacing-sm);transition:width .3s ease;min-width:100px}.chart-bar.wan{background:linear-gradient(90deg,var(--color-primary),#60a5fa)}.chart-bar.vpn{background:linear-gradient(90deg,var(--color-success),#34d399)}.chart-value{color:#fff;font-weight:600;font-size:.9rem;white-space:nowrap}.comparison-metrics{padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--radius)}.comparison-metrics h3{margin-bottom:var(--spacing-md);color:var(--color-text)}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.metric{background:var(--color-surface);padding:var(--spacing-md);border-radius:var(--radius);display:flex;flex-direction:column;gap:var(--spacing-sm)}.metric-label{color:var(--color-text-muted);font-size:.9rem}.metric-value{font-size:1.5rem;font-weight:700;color:var(--color-text)}.metric-value.degradation{color:var(--color-warning)}.metric-value.efficiency{color:var(--color-success)}.app-footer{background:var(--color-surface);border-top:1px solid var(--color-border);padding:var(--spacing-md);display:flex;justify-content:space-between;align-items:center;color:var(--color-text-muted);font-size:.85rem}@media(max-width:768px){.results-cards,.form-row{grid-template-columns:1fr}.metadata{flex-direction:column;gap:var(--spacing-sm)}.app-footer{flex-direction:column;gap:var(--spacing-sm);text-align:center}}.app-tabs{display:flex;gap:8px;background:linear-gradient(180deg,var(--color-surface),color-mix(in srgb,var(--color-surface) 88%,black));border-bottom:1px solid var(--color-border);padding:10px var(--spacing-lg);flex-wrap:wrap}.tab-btn{background:color-mix(in srgb,var(--color-surface-light) 78%,transparent);border:1px solid transparent;border-radius:10px;padding:10px 14px;color:var(--color-text-muted);font-size:.95rem;font-weight:600;cursor:pointer;position:relative;transition:all .2s ease;white-space:nowrap}.tab-btn:hover{color:var(--color-text);border-color:color-mix(in srgb,var(--color-primary) 35%,var(--color-border));transform:translateY(-1px)}.tab-btn.active{color:#fff;background:linear-gradient(135deg,var(--color-primary),color-mix(in srgb,var(--color-primary) 72%,#7dd3fc));border-color:color-mix(in srgb,var(--color-primary) 45%,#ffffff30);box-shadow:0 8px 20px #2563eb33}.tab-btn.active:after{display:none}.test-history{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-lg)}.test-history.loading{text-align:center;padding:var(--spacing-lg) * 2}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.history-header h2{color:var(--color-primary)}.history-actions{display:flex;gap:var(--spacing-sm)}.btn-secondary{background:var(--color-surface-light);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius);padding:8px 16px;font-size:.9rem;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--color-border)}.btn-danger{background:#ef444433;color:var(--color-error);border:1px solid var(--color-error);border-radius:var(--radius);padding:8px 16px;font-size:.9rem;cursor:pointer;transition:all .2s}.btn-danger:hover{background:var(--color-error);color:#fff}.history-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--radius)}.stat-item{display:flex;flex-direction:column;gap:4px;text-align:center}.stat-label{font-size:.85rem;color:var(--color-text-muted)}.stat-value{font-size:1.2rem;font-weight:700;color:var(--color-text)}.history-empty{text-align:center;padding:var(--spacing-lg) * 2;color:var(--color-text-muted)}.history-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.history-item{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-md);cursor:pointer;transition:all .2s}.history-item:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.history-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.history-date{font-size:.85rem;color:var(--color-text-muted)}.btn-icon{background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s}.btn-icon:hover{background:var(--color-error);color:#fff}.history-item-body{display:flex;flex-direction:column;gap:var(--spacing-sm)}.history-servers{display:flex;gap:var(--spacing-md);font-size:.9rem}.history-results{display:flex;align-items:center;gap:var(--spacing-md);font-size:1.1rem}.throughput{font-weight:600}.throughput.wan{color:var(--color-primary)}.throughput.vpn{color:var(--color-success)}.separator{color:var(--color-text-muted)}.degradation{padding:4px 8px;border-radius:4px;font-weight:600;font-size:.9rem}.degradation.negative{background:#ef444433;color:var(--color-error)}.degradation.positive{background:#10b98133;color:var(--color-success)}.history-item-footer{margin-top:var(--spacing-sm);font-size:.85rem;color:var(--color-text-muted)}.network-interfaces{background:var(--color-bg);border-radius:var(--radius);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.interfaces-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.interfaces-header h3{font-size:1rem;color:var(--color-text)}.btn-small{padding:6px 12px;font-size:.85rem}.error-text{color:var(--color-error);font-size:.9rem;margin-bottom:var(--spacing-md)}.suggestion-box{background:var(--color-surface);border:1px solid var(--color-success);border-radius:var(--radius);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.suggestion-box h4{font-size:.95rem;color:var(--color-success);margin-bottom:var(--spacing-sm)}.suggestion-details{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.suggestion-item{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.9rem}.suggestion-item .label{font-weight:600;color:var(--color-text-muted);min-width:40px}.suggestion-item .value{color:var(--color-text);font-family:monospace}.suggestion-item .interface-name{color:var(--color-text-muted);font-size:.85rem}.warning-text{color:var(--color-warning);font-size:.9rem;font-style:italic}.interfaces-toggle{margin-bottom:var(--spacing-sm)}.btn-link{background:transparent;border:none;color:var(--color-primary);font-size:.9rem;cursor:pointer;padding:0;text-decoration:underline}.btn-link:hover{color:#60a5fa}.interfaces-list{margin-top:var(--spacing-md)}.interface-group{margin-bottom:var(--spacing-md)}.interface-group h4{font-size:.9rem;color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.interface-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-surface);border-radius:4px;margin-bottom:4px;font-size:.85rem}.interface-item.vpn{border-left:3px solid var(--color-success)}.interface-item.wan{border-left:3px solid var(--color-primary)}.interface-icon{font-family:monospace;color:var(--color-text-muted)}.interface-name{flex:1;color:var(--color-text)}.interface-ip{font-family:monospace;color:var(--color-primary)}.interface-type{font-size:.8rem;padding:2px 6px;background:var(--color-surface-light);border-radius:4px;color:var(--color-text-muted)}.mode-selector{display:flex;justify-content:center;gap:0;padding:var(--spacing-md) var(--spacing-lg);background:var(--color-surface)}.mode-btn{background:var(--color-surface-light);border:2px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-lg);color:var(--color-text-muted);font-size:1rem;font-weight:700;letter-spacing:1px;cursor:pointer;transition:all .2s;min-width:140px}.mode-btn:first-child{border-radius:var(--radius) 0 0 var(--radius);border-right:none}.mode-btn:last-child{border-radius:0 var(--radius) var(--radius) 0}.mode-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.mode-btn:not(.active):hover{background:var(--color-border);color:var(--color-text)}.server-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-lg)}.server-panel h2{color:var(--color-primary);margin-bottom:var(--spacing-sm)}.server-description,.panel-description{color:var(--color-text-muted);font-size:.9rem;margin-bottom:var(--spacing-lg)}.server-info-box{background:var(--color-bg);border-radius:var(--radius);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.server-info-box h3{font-size:1rem;color:var(--color-text);margin-bottom:var(--spacing-lg)}.loading-text{color:var(--color-text-muted);font-style:italic}.server-field{margin-bottom:var(--spacing-lg)}.server-field label{display:block;font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-sm)}.server-field small{display:block;color:var(--color-text-muted);font-size:.85rem;margin-top:var(--spacing-sm)}.server-interface-select{width:100%;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:10px 12px;color:var(--color-text);font-size:.95rem}.server-interface-select:focus{outline:none;border-color:var(--color-primary)}.server-ip-display{display:flex;align-items:center;gap:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:10px 14px}.ip-value{font-family:monospace;font-size:1.1rem;color:var(--color-primary);font-weight:600}.port-badge{background:var(--color-surface-light);color:var(--color-text-muted);padding:4px 10px;border-radius:4px;font-size:.85rem;font-weight:500}.client-config-hint{background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius);padding:var(--spacing-md)}.config-row{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-sm)}.config-row:last-child{margin-bottom:0}.config-label{font-weight:600;color:var(--color-text-muted);min-width:100px}.config-row code{font-family:monospace;color:var(--color-primary);background:var(--color-bg);padding:4px 8px;border-radius:4px;font-size:.95rem}.server-controls{display:flex;align-items:center;gap:var(--spacing-lg)}.server-status{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius);font-weight:700;font-size:.9rem;letter-spacing:1px}.server-status.running{background:#10b98133;color:var(--color-success);border:1px solid var(--color-success)}.server-status.stopped{background:#ef44441a;color:var(--color-error);border:1px solid var(--color-error)}.server-buttons{display:flex;gap:var(--spacing-sm)}.chart-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-lg);position:relative}.chart-panel.loading{text-align:center;padding:48px var(--spacing-lg)}.chart-empty{text-align:center;padding:48px var(--spacing-lg);color:var(--color-text-muted)}.chart-empty .text-muted{font-size:.9rem;margin-top:var(--spacing-sm)}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.chart-header h2{color:var(--color-primary)}.chart-view-toggle{display:flex;gap:0}.btn-toggle{background:var(--color-surface-light);border:1px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-md);color:var(--color-text-muted);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-toggle:first-child{border-radius:var(--radius) 0 0 var(--radius);border-right:none}.btn-toggle:last-child{border-radius:0 var(--radius) var(--radius) 0}.btn-toggle.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.btn-toggle:not(.active):hover{background:var(--color-border);color:var(--color-text)}.chart-svg{width:100%;height:auto;background:var(--color-bg);border-radius:var(--radius);margin-bottom:var(--spacing-md)}.chart-tooltip{background:var(--color-surface-light);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.tooltip-date{font-size:.85rem;color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.tooltip-row{display:flex;justify-content:space-between;gap:var(--spacing-md);padding:2px 0;font-size:.95rem}.tooltip-row.wan span:first-child{color:var(--color-primary)}.tooltip-row.vpn span:first-child{color:var(--color-success)}.tooltip-row.degradation span:first-child{color:var(--color-warning)}.chart-legend{display:flex;align-items:center;gap:var(--spacing-lg);padding-top:var(--spacing-sm)}.legend-item{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.9rem;color:var(--color-text)}.legend-dot{width:12px;height:12px;border-radius:50%}.legend-dot.wan{background:var(--color-primary)}.legend-dot.vpn{background:var(--color-success)}.legend-dot.degradation{background:var(--color-warning)}.legend-count{margin-left:auto;font-size:.85rem;color:var(--color-text-muted)}.settings-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-lg);box-shadow:inset 0 1px #ffffff0a}.settings-panel>h2{color:var(--color-primary);margin-bottom:var(--spacing-lg)}.settings-section{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-md);margin-bottom:var(--spacing-md);box-shadow:0 6px 16px #00000018;transition:border-color .2s ease,transform .2s ease}.settings-section:hover{border-color:color-mix(in srgb,var(--color-primary) 35%,var(--color-border));transform:translateY(-1px)}.settings-section h3{font-size:1rem;color:var(--color-text);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.settings-info-grid{display:flex;flex-direction:column;gap:var(--spacing-sm)}.settings-info-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm);background:var(--color-surface);border-radius:4px}.settings-info-label{font-weight:600;color:var(--color-text-muted);font-size:.9rem}.settings-info-value{color:var(--color-text);font-size:.9rem}code.settings-info-value{font-family:monospace;color:var(--color-primary);background:var(--color-bg);padding:2px 8px;border-radius:4px;font-size:.85rem}.settings-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.settings-field{display:flex;flex-direction:column;gap:var(--spacing-sm)}.settings-field label{font-weight:600;color:var(--color-text);font-size:.9rem}.settings-field input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:10px 12px;color:var(--color-text);font-size:.95rem;transition:border-color .2s}.settings-field input:focus{outline:none;border-color:var(--color-primary)}.settings-field select{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:10px 12px;color:var(--color-text);font-size:.95rem}.settings-field select:focus{outline:none;border-color:var(--color-primary)}.settings-actions{display:flex;align-items:center;gap:var(--spacing-md);margin-top:var(--spacing-md)}.settings-saved{color:var(--color-success);font-weight:600;font-size:.9rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.scheduler-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-lg)}.scheduler-panel h2{color:var(--color-primary);margin-bottom:var(--spacing-sm)}.scheduler-config{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.scheduler-config .form-group input{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:10px 12px;color:var(--color-text);font-size:.95rem}.scheduler-config .form-group input:focus{outline:none;border-color:var(--color-primary)}.scheduler-controls{margin-bottom:var(--spacing-lg)}.scheduler-status{background:var(--color-bg);border-radius:var(--radius);padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm)}.scheduler-status-row{display:flex;align-items:center;gap:var(--spacing-md)}.scheduler-indicator{padding:4px 12px;border-radius:4px;font-weight:700;font-size:.8rem;letter-spacing:1px}.scheduler-indicator.running{background:#10b98133;color:var(--color-success);border:1px solid var(--color-success)}.scheduler-info{color:var(--color-text-muted);font-size:.9rem}.scheduler-countdown{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-text);font-size:.95rem}.spinner-small{width:16px;height:16px;border:2px solid var(--color-surface-light);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.scheduler-last{font-size:.9rem;color:var(--color-text-muted);padding:var(--spacing-sm);background:var(--color-surface);border-radius:4px}.scheduler-last.error{color:var(--color-error);background:#ef44441a}.compare-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-lg)}.compare-panel.loading{text-align:center;padding:48px var(--spacing-lg)}.compare-panel h2{color:var(--color-primary);margin-bottom:var(--spacing-sm)}.compare-selectors{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.compare-selector{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.compare-selector label{font-weight:600;color:var(--color-text);font-size:.9rem}.compare-selector select{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:10px 12px;color:var(--color-text);font-size:.9rem;cursor:pointer}.compare-selector select:focus{outline:none;border-color:var(--color-primary)}.compare-vs{font-weight:700;font-size:1.2rem;color:var(--color-text-muted);padding-top:20px}.compare-table{width:100%;border-collapse:collapse;margin-bottom:var(--spacing-lg)}.compare-table th,.compare-table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-border);font-size:.9rem}.compare-table th{background:var(--color-bg);color:var(--color-text-muted);font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.compare-table .metric-name{font-weight:600;color:var(--color-text)}.compare-table .highlight-row{background:var(--color-bg)}.compare-table .value-wan{color:var(--color-primary);font-weight:600}.compare-table .value-vpn,.compare-table .diff-positive{color:var(--color-success);font-weight:600}.compare-table .diff-negative{color:var(--color-error);font-weight:600}.compare-bars{background:var(--color-bg);border-radius:var(--radius);padding:var(--spacing-md)}.compare-bars h3{font-size:1rem;color:var(--color-text);margin-bottom:var(--spacing-md)}.compare-bar-group{margin-bottom:var(--spacing-md)}.compare-bar-label{display:block;font-weight:600;color:var(--color-text);font-size:.9rem;margin-bottom:var(--spacing-sm)}.compare-bar-pair{display:flex;flex-direction:column;gap:4px}.compare-bar-row{display:flex;align-items:center;gap:var(--spacing-sm)}.compare-bar-tag{width:20px;font-weight:700;font-size:.8rem;color:var(--color-text-muted);text-align:center}.compare-bar-track{flex:1;height:24px;background:var(--color-surface);border-radius:4px;overflow:hidden}.compare-bar-fill{height:100%;border-radius:4px;transition:width .3s ease;min-width:2px}.compare-bar-value{min-width:70px;text-align:right;font-size:.85rem;font-weight:600;color:var(--color-text)}.header-row{display:flex;justify-content:space-between;align-items:center}.header-content{flex:1}.theme-toggle{background:#ffffff26;border:1px solid rgba(255,255,255,.25);border-radius:var(--radius);padding:8px 14px;font-size:1.2rem;cursor:pointer;transition:all .2s;color:#fff;line-height:1}.theme-toggle:hover{background:#ffffff40;transform:scale(1.1)}[data-theme=light] .app-header{box-shadow:0 4px 6px #0000001a}.threshold-ok{border-left:4px solid var(--color-success)!important}.threshold-warn{border-left:4px solid var(--color-warning)!important}.threshold-fail{border-left:4px solid var(--color-error)!important}.threshold-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.threshold-badge.ok{background:#10b98133;color:var(--color-success)}.threshold-badge.warn{background:#f59e0b33;color:var(--color-warning)}.threshold-badge.fail{background:#ef444433;color:var(--color-error)}.threshold-summary{background:var(--color-bg);border-radius:var(--radius);padding:var(--spacing-md);margin-top:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-md)}.threshold-summary .threshold-icon{font-size:1.5rem}.threshold-summary .threshold-message{flex:1;font-size:.95rem}.udp-metrics{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px dashed var(--color-border)}.udp-metrics .test-info .label{font-style:italic}.test-mode-toggle{display:flex;gap:0;margin-bottom:var(--spacing-md)}.test-mode-btn{background:var(--color-surface-light);border:1px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-md);color:var(--color-text-muted);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;min-width:80px;text-align:center}.test-mode-btn:first-child{border-radius:var(--radius) 0 0 var(--radius);border-right:none}.test-mode-btn:last-child{border-radius:0 var(--radius) var(--radius) 0}.test-mode-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.test-mode-btn:not(.active):hover{background:var(--color-border);color:var(--color-text)}.traceroute-options{display:flex;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface-light);border-radius:var(--radius);font-size:.88rem;color:var(--color-text-muted)}.traceroute-info{font-style:italic}.checkbox-label{display:flex;align-items:center;gap:6px;cursor:pointer;color:var(--color-text)}.checkbox-label input[type=checkbox]{accent-color:var(--color-primary);width:16px;height:16px;cursor:pointer}.traceroute-section{margin-top:var(--spacing-lg)}.traceroute-section h3{margin-bottom:var(--spacing-sm);color:var(--color-text);font-size:1rem}.traceroute-map-wrap,.traceroute-chart-wrap{margin-top:var(--spacing-sm)}.traceroute-leaflet-map{width:100%;min-height:380px;height:clamp(320px,42vh,520px);border-radius:var(--radius);overflow:hidden;border:1px solid var(--color-border);background:var(--color-surface-light)}.traceroute-map-svg,.traceroute-chart-svg{width:100%;height:auto;display:block}.traceroute-map-bg{fill:var(--color-surface-light)}.traceroute-map-line{fill:none;stroke:var(--color-primary);stroke-width:2.5;stroke-linejoin:round;stroke-linecap:round;opacity:.9}.traceroute-map-node{fill:var(--color-success);stroke:var(--color-bg);stroke-width:1.5}.traceroute-map-label{fill:var(--color-text);font-size:11px;font-weight:700}.traceroute-chart-line{fill:none;stroke:var(--color-warning);stroke-width:2.5;stroke-linejoin:round;stroke-linecap:round}.traceroute-chart-header{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;color:var(--color-text-muted);margin-bottom:6px}.traceroute-chart-endpoints{color:var(--color-text-muted)}.traceroute-axis{stroke:var(--color-border);stroke-width:1}.traceroute-grid-line{stroke:var(--color-border);stroke-width:.8;opacity:.35}.traceroute-axis-label{fill:var(--color-text-muted);font-size:10px}.traceroute-axis-title{fill:var(--color-text);font-size:10px;font-weight:600}.traceroute-map-empty{margin-top:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius);background:var(--color-surface-light);color:var(--color-text-muted);font-size:.85rem}.traceroute-layout{display:grid;grid-template-columns:2fr 1fr;gap:var(--spacing-md);align-items:start}.traceroute-left{display:flex;flex-direction:column;gap:var(--spacing-sm)}.traceroute-right{background:var(--color-surface-light);border-radius:var(--radius);padding:var(--spacing-sm)}.traceroute-right h4{margin:0 0 var(--spacing-sm) 0;font-size:.9rem}.traceroute-locations{max-height:430px;overflow:auto;display:flex;flex-direction:column;gap:6px}.traceroute-location-row{display:grid;grid-template-columns:42px 1fr auto;gap:8px;align-items:center;font-size:.82rem;padding:6px;border-radius:6px;background:var(--color-surface)}.traceroute-location-hop{font-weight:700;color:var(--color-primary)}.traceroute-location-text{color:var(--color-text)}.traceroute-location-ip{color:var(--color-text-muted);font-size:.78rem}.outage-bulletin{margin-top:var(--spacing-sm);background:var(--color-surface);border-radius:var(--radius);padding:var(--spacing-sm);border:1px solid var(--color-border)}.outage-item{background:var(--color-surface-light);border-radius:6px;padding:8px;margin-bottom:8px}.outage-item-title{font-weight:700;color:var(--color-text);font-size:.82rem}.outage-item-meta,.outage-notice{color:var(--color-text-muted);font-size:.78rem}.outage-link{color:var(--color-primary);font-size:.78rem;text-decoration:none}.stats-modal-backdrop{position:fixed;inset:0;background:#0000008c;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.stats-modal{width:min(1200px,95vw);max-height:85vh;overflow:auto;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-md)}.stats-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}@media(max-width:1200px){.traceroute-layout{grid-template-columns:1fr}}.traceroute-panel{padding:var(--spacing-md)}.traceroute-panel h2{margin-bottom:var(--spacing-md);color:var(--color-text)}.traceroute-controls{margin-bottom:var(--spacing-lg)}.traceroute-input-row{display:flex;gap:var(--spacing-sm)}.traceroute-input{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface-light);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:1rem;font-family:Cascadia Code,Fira Code,monospace}.traceroute-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #6366f133}.traceroute-btn{white-space:nowrap;min-width:140px}.traceroute-progress{margin-top:var(--spacing-sm);color:var(--color-primary);font-size:.9rem;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.traceroute-error{background:#ef44441a;border:1px solid var(--color-danger);border-radius:var(--radius);padding:var(--spacing-md);color:var(--color-danger);margin-bottom:var(--spacing-md)}.traceroute-results{margin-top:var(--spacing-md)}.traceroute-summary{display:flex;gap:var(--spacing-lg);align-items:center;margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface-light);border-radius:var(--radius);font-size:.9rem;color:var(--color-text-muted)}.traceroute-target strong{color:var(--color-text)}.traceroute-hops{background:var(--color-primary);color:#fff;padding:2px 10px;border-radius:12px;font-weight:600;font-size:.85rem}.traceroute-table-wrapper{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--color-border)}.traceroute-table{width:100%;border-collapse:collapse;font-size:.88rem}.traceroute-table thead{background:var(--color-surface-light);position:sticky;top:0}.traceroute-table th{padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-weight:600;color:var(--color-text-muted);border-bottom:2px solid var(--color-border);white-space:nowrap}.traceroute-table td{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border);vertical-align:middle}.traceroute-table tbody tr:hover{background:#6366f10d}.traceroute-table tbody tr.hop-loss{opacity:.5}.hop-number{font-weight:700;color:var(--color-text-muted);text-align:center;min-width:30px}.hop-ip code{background:var(--color-bg);padding:2px 6px;border-radius:4px;font-size:.85rem;color:var(--color-primary)}.hop-ip .timeout{color:var(--color-text-muted);font-style:italic}.hop-isp .isp-info{display:flex;flex-direction:column;gap:2px}.isp-badge{font-size:.82rem;color:var(--color-text);font-weight:500;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.as-badge{font-size:.75rem;color:var(--color-text-muted);background:var(--color-bg);padding:1px 6px;border-radius:4px;display:inline-block;width:fit-content}.hop-location{font-size:.85rem;white-space:nowrap}.hop-location .timeout{color:var(--color-text-muted)}.hop-rtt{text-align:right;font-family:Cascadia Code,Fira Code,monospace;font-size:.83rem;white-space:nowrap}.hop-avg{font-weight:700}.latency-good{color:var(--color-success)}.latency-medium{color:var(--color-warning)}.latency-high{color:var(--color-danger)}.latency-timeout{color:var(--color-text-muted);font-style:italic}.traceroute-legend{display:flex;gap:var(--spacing-lg);margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface-light);border-radius:var(--radius);font-size:.82rem;color:var(--color-text-muted)}.legend-item{display:flex;align-items:center;gap:6px}.legend-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.legend-dot.latency-good{background:var(--color-success)}.legend-dot.latency-medium{background:var(--color-warning)}.legend-dot.latency-high{background:var(--color-danger)}.legend-dot.latency-timeout{background:var(--color-text-muted)}.captures-container{margin-top:var(--spacing-lg)}.captures-container h3{margin-bottom:var(--spacing-sm);color:var(--color-text);font-size:1rem}.capture-section{margin-top:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.capture-section h4{margin:0 0 var(--spacing-sm) 0;color:var(--color-primary);font-size:.9rem}.capture-info{display:flex;flex-direction:column;gap:4px}.capture-field{display:flex;gap:var(--spacing-sm);align-items:center;font-size:.85rem}.capture-label{font-weight:600;min-width:45px;color:var(--color-text-muted)}.capture-path{font-size:.8em;word-break:break-all;color:var(--color-text)}.server-capture-section{margin-top:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.server-capture-section h3{margin-bottom:var(--spacing-sm);color:var(--color-text)}.capture-description{font-size:.85rem;color:var(--color-text-muted);margin-bottom:var(--spacing-md)}.capture-controls{display:flex;align-items:center;gap:var(--spacing-md)}.capture-buttons{display:flex;gap:var(--spacing-sm)}.capture-status{padding:4px 12px;border-radius:var(--radius);font-size:.8rem;font-weight:700;letter-spacing:.05em;background:var(--color-surface-light);color:var(--color-text-muted)}.capture-status.capturing{background:#10b98126;color:var(--color-success);animation:capture-pulse 2s ease-in-out infinite}@keyframes capture-pulse{0%,to{opacity:1}50%{opacity:.6}}.capture-results{margin-top:var(--spacing-md)}.capture-results h4{margin-bottom:var(--spacing-sm);font-size:.9rem;color:var(--color-text)}.capture-file-info{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface-light);border-radius:var(--radius);margin-bottom:var(--spacing-sm)}.capture-file-info .capture-field{display:flex;gap:var(--spacing-sm);align-items:center;font-size:.85rem}.pcap-badge{display:inline-block;margin-top:4px;padding:2px 8px;border-radius:4px;font-size:.8rem;font-weight:600}.pcap-badge.available{background:#10b98126;color:var(--color-success)}.pcap-badge.unavailable{background:#ef444426;color:var(--color-error)}.capture-iface-select{margin-top:6px;display:flex;align-items:center;gap:8px;font-size:.85rem}.capture-iface-select label{color:var(--color-text-muted);white-space:nowrap}.capture-iface-select select{flex:1;padding:4px 8px;border-radius:4px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:.85rem}.pcap-unavailable{margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface-light);border-radius:var(--radius);color:var(--color-text-muted);text-align:center}.data-analysis-panel{display:flex;flex-direction:column;gap:var(--spacing-md)}.data-analysis-header{display:flex;justify-content:space-between;align-items:center}.analysis-current-results h3{margin-bottom:var(--spacing-sm)}.analysis-session-layout{display:grid;grid-template-columns:300px 1fr;gap:var(--spacing-md);align-items:start}.analysis-session-list,.analysis-session-detail{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-md)}.analysis-session-list h3,.analysis-session-detail h3{margin-bottom:var(--spacing-sm)}.analysis-session-item{width:100%;text-align:left;border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);border-radius:var(--radius);padding:10px;margin-bottom:8px;display:flex;flex-direction:column;gap:3px;cursor:pointer}.analysis-session-item.active{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.analysis-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.analysis-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.analysis-card h4{margin-bottom:var(--spacing-sm)}.analysis-ai-header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-sm)}.analysis-ai-text{margin-top:var(--spacing-sm);white-space:pre-wrap;word-break:break-word;font-family:Consolas,Courier New,monospace;font-size:.88rem;line-height:1.45;color:var(--color-text);background:var(--color-surface-light);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-sm)}.analysis-kv{display:grid;grid-template-columns:1fr 1fr;gap:8px 14px}.analysis-kv div{display:flex;justify-content:space-between;gap:12px}.analysis-kv span{color:var(--color-text-muted)}.analysis-notes{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:6px}.analysis-files{display:flex;flex-direction:column;gap:8px}.analysis-file-row{background:var(--color-surface-light);border-radius:6px;padding:8px;display:grid;grid-template-columns:180px 110px 1fr;gap:10px;align-items:center}.analysis-empty{color:var(--color-text-muted)}.analysis-mtr-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.analysis-mtr h5,.analysis-pcap-card h5{margin-bottom:var(--spacing-sm)}.analysis-hop-table{margin-top:var(--spacing-sm);display:flex;flex-direction:column;gap:6px}.analysis-hop-row{background:var(--color-surface-light);border-radius:6px;padding:6px 8px;display:grid;grid-template-columns:50px 1.2fr 110px 70px 1fr;gap:8px;align-items:center;font-size:.82rem}.analysis-pcap-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.analysis-pcap-card{background:var(--color-surface-light);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-md)}.analysis-proto-list{margin-top:var(--spacing-sm);display:flex;flex-direction:column;gap:4px}.analysis-proto-row{display:grid;grid-template-columns:1fr 80px 100px;gap:8px;font-size:.82rem}@media(max-width:1200px){.analysis-session-layout,.analysis-grid,.analysis-file-row,.analysis-mtr-grid,.analysis-pcap-grid,.analysis-hop-row{grid-template-columns:1fr}}.app-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);text-align:left}.app-header h1{font-size:1.5rem;margin-bottom:0}.header-left{display:flex;align-items:baseline;gap:var(--spacing-sm)}.app-title{font-size:1.4rem;font-weight:700;color:#fff}.app-subtitle{font-size:.85rem;opacity:.75;color:#fff}.header-right{display:flex;align-items:center;gap:var(--spacing-sm)}.theme-toggle{background:#ffffff26;border:1px solid rgba(255,255,255,.25);border-radius:var(--radius);color:#fff;font-size:1.1rem;cursor:pointer;padding:4px 8px;transition:background .2s}.theme-toggle:hover{background:#ffffff40}.tabs-nav{display:flex;gap:8px;background:linear-gradient(180deg,var(--color-surface),color-mix(in srgb,var(--color-surface) 88%,black));border-bottom:1px solid var(--color-border);padding:10px var(--spacing-lg);flex-wrap:wrap}.app-content{flex:1;padding:var(--spacing-lg) clamp(12px,2vw,28px);width:min(96vw,1400px);margin:0 auto}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius);border:1px solid var(--color-border);background:var(--color-surface-light);color:var(--color-text);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s}.btn:hover:not(:disabled){background:color-mix(in srgb,var(--color-surface-light) 70%,white)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:4px 10px;font-size:.8rem}.loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg) * 2;color:var(--color-text-muted);font-size:1rem;min-height:120px}.empty-state{text-align:center;padding:var(--spacing-lg);color:var(--color-text-muted)}.empty-state p{margin-bottom:var(--spacing-sm)}.dashboard-home h2{margin-bottom:var(--spacing-md)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--spacing-md)}.kpi-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-md);text-align:center;transition:border-color .2s}.kpi-card:hover{border-color:var(--color-primary)}.kpi-value{font-size:2rem;font-weight:700;color:var(--color-primary);line-height:1.2}.kpi-label{font-size:.8rem;color:var(--color-text-muted);margin-top:4px;text-transform:uppercase;letter-spacing:.04em}.agents-list h2{margin-bottom:var(--spacing-md)}.agents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--spacing-md);margin-top:var(--spacing-md)}.agent-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-md);cursor:pointer;transition:border-color .2s,box-shadow .2s}.agent-card:hover{border-color:var(--color-primary)}.agent-card.selected{border-color:var(--color-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--color-primary) 30%,transparent)}.agent-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm)}.agent-type-badge{font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:999px;background:var(--color-surface-light);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.agent-type-badge[data-type=client]{background:color-mix(in srgb,var(--color-primary) 20%,transparent);color:var(--color-primary)}.agent-type-badge[data-type=server]{background:color-mix(in srgb,var(--color-success) 20%,transparent);color:var(--color-success)}.agent-status{font-size:.82rem;font-weight:600}.agent-info{font-size:.88rem;line-height:1.6;color:var(--color-text)}.agent-heartbeat{font-size:.78rem;color:var(--color-text-muted);margin-top:4px}.agent-actions{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border);display:flex;gap:8px}.api-keys h2{margin-bottom:4px}.api-keys>p{color:var(--color-text-muted);margin-bottom:var(--spacing-md)}.create-key-form{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);flex-wrap:wrap}.create-key-form input,.create-key-form select{flex:1;min-width:180px;padding:8px 12px;border-radius:var(--radius);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:.9rem}.create-key-form input:focus,.create-key-form select:focus{outline:none;border-color:var(--color-primary)}.key-created-banner{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;background:color-mix(in srgb,var(--color-success) 12%,var(--color-surface));border:1px solid var(--color-success);border-radius:var(--radius);padding:var(--spacing-md);margin-bottom:var(--spacing-md);font-size:.88rem}.api-key-display{flex:1;font-family:Consolas,Fira Code,monospace;font-size:.82rem;background:var(--color-surface-light);padding:4px 8px;border-radius:4px;word-break:break-all;color:var(--color-success)}.keys-list{margin-top:var(--spacing-md)}.keys-table{width:100%;border-collapse:collapse;font-size:.9rem}.keys-table th,.keys-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--color-border)}.keys-table th{color:var(--color-text-muted);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}.keys-table tr:hover td{background:color-mix(in srgb,var(--color-surface-light) 40%,transparent)}@media(max-width:640px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.agents-grid{grid-template-columns:1fr}.create-key-form{flex-direction:column}.tabs-nav{padding:8px var(--spacing-md);gap:6px}}
