:root{--bg-primary: #050506;--bg-secondary: #0c0c0e;--bg-tertiary: #121216;--bg-hover: #1a1a20;--text-primary: #ffffff;--text-secondary: #a1a1aa;--text-muted: #71717a;--accent: #8a3ffc;--accent-hover: #a166ff;--accent-dim: rgba(138, 63, 252, .12);--accent-glow: rgba(138, 63, 252, .4);--online: #10b981;--offline: #ef4444;--unknown: #f59e0b;--warning: #f59e0b;--border: rgba(255, 255, 255, .08);--border-light: rgba(255, 255, 255, .15);--glass-bg: rgba(12, 12, 14, .7);--glass-blur: blur(12px);--glass-border: rgba(255, 255, 255, .05);--shadow-premium: 0 8px 32px 0 rgba(0, 0, 0, .8);--font-sans: "Space Grotesk", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--transition-fast: .15s ease;--transition-normal: .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100vh}a{color:var(--accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-hover)}.app{display:flex;flex-direction:column;min-height:100vh}.header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-xl);background:#050506cc;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:1000;box-shadow:0 4px 30px #00000080}.header-left{display:flex;align-items:center;gap:var(--space-lg)}.logo{width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--accent);filter:drop-shadow(0 0 8px var(--accent-glow))}.shogun-logo{width:100%;height:100%}.header-titles{display:flex;align-items:baseline;gap:var(--space-md)}.title{font-size:1.25rem;font-weight:600;letter-spacing:-.02em}.subtitle{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;padding-left:var(--space-md);border-left:1px solid var(--border)}.header-right{display:flex;align-items:center;gap:var(--space-md)}.btn-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.btn-icon:hover{background:var(--bg-hover);border-color:var(--border-light);color:var(--text-primary)}.btn-icon svg{width:18px;height:18px}.btn-icon.spinning svg,.btn-icon.testing svg{animation:spin 1s linear infinite}.btn-icon.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.status-indicator{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);font-size:.75rem;font-family:var(--font-mono)}.pulse{width:8px;height:8px;background:var(--accent);border-radius:50%;animation:pulse 2s infinite}.pulse.scanning{background:var(--warning)}.pulse.error{background:var(--offline);animation:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-md);padding:var(--space-xl) var(--space-lg);background:var(--bg-primary);max-width:1600px;margin:0 auto;width:100%}.stat{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-lg);transition:transform var(--transition-normal),border-color var(--transition-fast);box-shadow:0 4px 12px #0003}.stat:hover{transform:translateY(-4px);border-color:var(--border-light);background:var(--bg-hover)}.stat-value{font-size:1.75rem;font-weight:600;font-family:var(--font-mono);letter-spacing:-.02em}.stat-value.online{color:var(--online)}.stat-value.offline{color:var(--offline)}.stat-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.main-content{flex:1;display:grid;grid-template-columns:1fr;gap:var(--space-lg);padding:var(--space-lg);max-width:1600px;margin:0 auto;width:100%}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.section-header h2{font-size:.875rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.nodes-section{display:flex;flex-direction:column;min-height:0}.filter-group{display:flex;gap:var(--space-xs)}.filter-btn{padding:var(--space-xs) var(--space-sm);background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.7rem;font-family:var(--font-mono);cursor:pointer;transition:all var(--transition-fast)}.filter-btn:hover{background:var(--bg-hover);color:var(--text-secondary)}.filter-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.nodes-list{flex:1;overflow-y:auto;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-lg);max-height:700px;box-shadow:var(--shadow-premium)}.node-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--border);transition:all var(--transition-fast);animation:itemReveal .4s ease-out forwards;opacity:0}@keyframes itemReveal{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.node-item:last-child{border-bottom:none}.node-item:hover{background:var(--bg-hover);padding-left:calc(var(--space-md) + 4px);border-left:2px solid var(--accent)}.node-status{width:10px;height:10px;border-radius:50%;flex-shrink:0}.node-status.online{background:var(--online);box-shadow:0 0 8px var(--online)}.node-status.offline{background:var(--offline)}.node-status.unknown{background:var(--unknown)}.node-status.checking{background:var(--text-muted);animation:pulse 1s infinite}.node-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.node-url{font-family:var(--font-mono);font-size:.8rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.node-meta{display:flex;gap:var(--space-md);font-size:.7rem;color:var(--text-muted)}.node-meta span{display:flex;align-items:center;gap:var(--space-xs)}.node-ip{font-family:var(--font-mono);color:var(--text-muted);font-size:.65rem;opacity:.7}.location-unknown{color:var(--text-muted);font-style:italic;font-size:.65rem;opacity:.6}.node-latency{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);text-align:right;min-width:60px}.node-latency.fast{color:var(--online)}.node-latency.medium{color:var(--warning)}.node-latency.slow{color:var(--offline)}.loading-skeleton{padding:var(--space-md)}.skeleton-item{height:48px;background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-hover) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;border-radius:var(--radius-md);margin-bottom:var(--space-sm);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);color:var(--text-muted);text-align:center}.empty-state svg{width:48px;height:48px;margin-bottom:var(--space-md);opacity:.5}.footer{padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border-top:1px solid var(--border)}.footer-content{display:flex;justify-content:center;align-items:center;gap:var(--space-md);font-size:.75rem;color:var(--text-muted)}.separator{color:var(--border-light)}.map-section{display:flex;flex-direction:column;min-height:400px}.map-container{flex:1;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-premium);min-height:400px}.map-legend{display:flex;gap:var(--space-md);font-size:.7rem;color:var(--text-muted)}.legend-item{display:flex;align-items:center;gap:var(--space-xs)}.legend-item .dot{width:8px;height:8px;border-radius:50%}.legend-item .dot.online{background:var(--online)}.legend-item .dot.offline{background:var(--offline)}.line-sample.mesh{width:15px;height:2px;background:var(--accent);opacity:.6}.leaflet-container{background:var(--bg-primary)!important}.node-marker{width:12px;height:12px;border-radius:50%;border:2px solid white}.node-marker.online{background:var(--online);box-shadow:0 0 10px var(--online)}.node-marker.offline{background:var(--offline);box-shadow:0 0 10px var(--offline)}.popup-content{padding:var(--space-sm);background:var(--bg-tertiary);color:var(--text-primary);font-family:var(--font-sans)}.popup-url{font-weight:600;font-family:var(--font-mono);font-size:.75rem;margin-bottom:4px}.popup-status{display:flex;align-items:center;gap:var(--space-sm);font-size:.7rem;margin-bottom:4px}.popup-status .dot{width:6px;height:6px;border-radius:50%}.popup-status .dot.online{background:var(--online)}.popup-status .dot.offline{background:var(--offline)}.popup-location{font-size:.65rem;color:var(--text-muted)}.view{display:none;animation:fadeIn var(--transition-normal)}.view.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.view-nav{display:flex;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);padding:2px;margin-right:var(--space-md)}.nav-btn{padding:6px 14px;background:transparent;border:none;border-radius:calc(var(--radius-md) - 2px);color:var(--text-muted);font-size:.75rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.nav-btn:hover{color:var(--text-secondary)}.nav-btn.active{background:var(--bg-hover);color:var(--text-primary);box-shadow:0 2px 8px #0003}.header-actions{display:flex;gap:var(--space-sm);margin-right:var(--space-sm)}.diagnostic-content{display:flex;flex-direction:column}.diagnostic-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl)}@media (min-width: 1200px){.diagnostic-grid{grid-template-columns:1fr 450px}}.diagnostic-panel-group{display:flex;flex-direction:column;gap:var(--space-md)}.diagnostic-row{display:grid;grid-template-columns:1fr;gap:var(--space-md)}@media (min-width: 768px){.diagnostic-row{grid-template-columns:1.5fr 1fr}}.panel{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-premium);transition:all var(--transition-normal)}.panel:hover{border-color:#ffffff1f;box-shadow:0 10px 40px #0009}.panel:focus-within{border-color:var(--accent);box-shadow:0 0 20px var(--accent-dim)}.panel label{display:block;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--space-sm)}input[type=text],textarea{width:100%;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-mono);font-size:.8rem;padding:var(--space-sm) var(--space-md);outline:none;transition:all var(--transition-fast)}input[type=text]:focus,textarea:focus{border-color:var(--accent);background:var(--bg-hover)}textarea{height:120px;resize:vertical}.settings-group{display:flex;flex-direction:column;gap:var(--space-lg)}.setting{display:flex;flex-direction:column}.slider-wrap{display:flex;align-items:center;gap:var(--space-md)}input[type=range]{flex:1;accent-color:var(--accent);cursor:pointer}.slider-val{font-family:var(--font-mono);font-size:.8rem;color:var(--text-primary);min-width:45px}.radio-group{display:flex;flex-direction:column;gap:var(--space-xs)}.radio-label{display:flex!important;align-items:center;gap:var(--space-sm);cursor:pointer;font-size:.8rem!important;color:var(--text-secondary)!important;text-transform:none!important;letter-spacing:normal!important;margin-bottom:0!important;padding:var(--space-xs) 0}.radio-label input[type=radio]{accent-color:var(--accent)}.btn-row{display:flex;gap:var(--space-md)}.btn-primary,.btn-danger,.btn-secondary{flex:1;padding:var(--space-md);border-radius:var(--radius-md);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:all var(--transition-fast);border:1px solid transparent}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 12px var(--accent-glow)}.btn-primary:disabled{opacity:.5;cursor:default;transform:none;box-shadow:none}.btn-danger{background:transparent;border-color:var(--offline);color:var(--offline);display:none}.btn-danger:hover{background:#ef44441a}.btn-secondary{background:var(--bg-tertiary);border-color:var(--border);color:var(--text-secondary)}.btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary)}.progress-bar{height:4px;background:var(--bg-tertiary);border-radius:var(--radius-sm);overflow:hidden;display:none}.progress-fill{height:100%;background:var(--accent);width:0%;transition:width .3s ease}.diagnostic-stats-results{display:flex;flex-direction:column;gap:var(--space-md)}.diagnostic-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm)}.diag-stat{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);display:flex;flex-direction:column}.diag-stat-label{font-size:.6rem;color:var(--text-muted);text-transform:uppercase;margin-bottom:2px}.diag-stat-val{font-family:var(--font-mono);font-size:1.1rem;font-weight:600}.results-container{flex:1;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md);max-height:570px;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-sm)}.diag-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md);transition:border-color .2s;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.diag-card.ok{border-color:#10b9814d}.diag-card.fail{border-color:#ef444433}.diag-card.warn{border-color:#f59e0b4d}.diag-card-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-sm)}.diag-card-relay{font-family:var(--font-mono);font-size:.75rem;color:var(--text-primary);flex:1;word-break:break-all}.diag-badges{display:flex;gap:6px}.diag-badge{font-size:.65rem;font-weight:600;padding:2px 8px;border-radius:4px;text-transform:uppercase}.diag-badge.ok{background:#10b9811a;color:var(--online)}.diag-badge.fail{background:#ef44441a;color:var(--offline)}.diag-badge.warn{background:#f59e0b1a;color:var(--warning)}.diag-badge.pending{background:var(--bg-hover);color:var(--text-muted)}.diag-card-metrics{display:flex;gap:var(--space-lg);font-size:.7rem;padding-left:18px}.metric-item{color:var(--text-muted)}.metric-item span{color:var(--text-secondary);font-family:var(--font-mono)}.diag-card-data{margin-top:var(--space-md);background:var(--bg-primary);border-radius:var(--radius-sm);padding:var(--space-sm);font-family:var(--font-mono);font-size:.7rem;color:var(--online);white-space:pre-wrap;word-break:break-all;max-height:150px;overflow-y:auto;border-left:2px solid var(--online)}.diag-card-data-header{color:var(--text-muted);margin-bottom:4px;font-size:.65rem;text-transform:uppercase}@media (max-width: 768px){.header{flex-direction:column;gap:var(--space-md);padding:var(--space-md)}.header-titles{flex-direction:column;align-items:center;gap:2px}.subtitle{border-left:none;padding-left:0}.stats-bar{grid-template-columns:repeat(2,1fr);padding:var(--space-md)}.stat-value{font-size:1.25rem}.main-content{padding:var(--space-md)}.nodes-list{max-height:500px}.diagnostic-stats{grid-template-columns:repeat(2,1fr)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}
