:root{--bg-primary: #0d1117;--bg-surface: #161b22;--bg-overlay: rgba(255, 255, 255, .04);--border-subtle: rgba(255, 255, 255, .08);--text-primary: #e6edf3;--text-secondary: #8b949e;--text-muted: #6e7681;--color-online: #34d058;--color-offline: #f85149;--color-warn: #f0883e;--color-info: #58a6ff;--color-stream-local: #bc8cff;--color-stream-direct: #34d058;--color-stream-transcode: #ffa657;--radius-sm: 6px;--radius-md: 8px;--font-mono: "JetBrains Mono", "Fira Code", "SF Mono", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Segoe UI,Helvetica,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.map-shell{display:grid;grid-template-rows:auto 1fr;height:100vh;overflow:hidden}.map-topbar{padding:12px 20px;display:flex;align-items:center;justify-content:space-between;background:#161b22b8;backdrop-filter:blur(20px) saturate(1.8);-webkit-backdrop-filter:blur(20px) saturate(1.8);border-bottom:1px solid rgba(255,255,255,.08);z-index:10}.map-topbar .brand-link{text-decoration:none;color:inherit;transition:opacity .2s ease}.map-topbar .brand-link:hover{opacity:.8}.map-topbar .kicker{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.map-topbar h1{font-size:16px;font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.map-container{position:relative;width:100%;height:100%;overflow:hidden;background:#000}.star-field{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden;pointer-events:none}.star-field canvas{width:100%;height:100%;display:block}#map{position:relative;z-index:1;width:100%;height:100%}.stream-popup .mapboxgl-popup-content{background:#161b22eb;backdrop-filter:blur(16px) saturate(1.6);-webkit-backdrop-filter:blur(16px) saturate(1.6);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:0;box-shadow:0 8px 32px #00000080;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,sans-serif;min-width:220px;max-width:280px;overflow:hidden;animation:popup-fade-in .25s ease-out}.stream-popup .mapboxgl-popup-tip{border-top-color:#161b22eb}.stream-popup .mapboxgl-popup-close-button{color:var(--text-muted);font-size:16px;padding:4px 8px;right:2px;top:2px}.stream-popup .mapboxgl-popup-close-button:hover{color:var(--text-primary);background:transparent}.stream-card{display:flex;gap:10px;padding:10px}.stream-card-poster{width:56px;height:84px;border-radius:6px;object-fit:cover;flex-shrink:0;background:#ffffff0f}.stream-card-info{display:flex;flex-direction:column;gap:3px;min-width:0}.stream-card-title{font-size:13px;font-weight:600;line-height:1.3;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stream-card-meta{font-size:11px;color:var(--text-secondary);line-height:1.4}.stream-card-location{font-size:10px;color:var(--text-muted);margin-top:auto}.relay-popup .mapboxgl-popup-content{background:#161b22eb;backdrop-filter:blur(16px) saturate(1.6);-webkit-backdrop-filter:blur(16px) saturate(1.6);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:0;box-shadow:0 8px 32px #00000080;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,sans-serif;min-width:220px;max-width:280px;overflow:hidden;animation:popup-fade-in .25s ease-out}.relay-popup .mapboxgl-popup-tip{border-top-color:#161b22eb}.relay-popup .mapboxgl-popup-close-button{color:var(--text-muted);font-size:16px;padding:4px 8px;right:2px;top:2px}.relay-popup .mapboxgl-popup-close-button:hover{color:var(--text-primary);background:transparent}.relay-card{padding:12px}.relay-card-header{display:flex;align-items:center;gap:8px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.08)}.relay-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.relay-card-name{font-size:14px;font-weight:600;color:var(--text-primary)}.relay-card-tier{margin-left:auto;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.relay-card-rows{display:flex;flex-direction:column;gap:5px}.relay-card-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px}.relay-label{font-size:11px;color:var(--text-muted);flex-shrink:0}.relay-value{font-size:11px;color:var(--text-secondary);text-align:right;word-break:break-all}.relay-mono{font-family:SF Mono,Cascadia Code,Fira Code,monospace;font-size:10px;letter-spacing:.02em}.relay-weather{margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.08)}.relay-weather-loading{font-size:10px;color:var(--text-muted);font-style:italic}.relay-weather-data{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.relay-weather-icon{width:28px;height:28px;flex-shrink:0}.relay-weather-temp{font-size:12px;font-weight:600;color:var(--text-primary)}.relay-weather-desc{font-size:11px;color:var(--text-secondary);text-transform:capitalize}.relay-weather-detail{font-size:10px;color:var(--text-muted);width:100%}.map-tool-btn{position:absolute;bottom:40px;left:12px;z-index:5;width:36px;height:36px;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#161b22d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#8b949e;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s,border-color .2s}.map-tool-btn:hover{background:#161b22f2;color:#e6edf3}.map-tool-btn.active{border-color:#58a6ff80;color:#58a6ff;background:#58a6ff1f}.route-popup .mapboxgl-popup-content{background:#161b22eb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:10px 14px;color:#e6edf3}.route-popup .mapboxgl-popup-tip{border-top-color:#161b22eb}.route-info{font-size:12px;line-height:1.5}.route-info-row{margin-bottom:2px}.route-clear-btn{margin-top:6px;padding:4px 10px;background:#f8514926;border:1px solid rgba(248,81,73,.3);border-radius:6px;color:#f85149;font-size:11px;cursor:pointer;transition:background .2s}.route-clear-btn:hover{background:#f8514940}@keyframes popup-fade-in{0%{opacity:0;transform:translateY(4px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
