:root{--bg-primary:#0b0f19;--bg-secondary:#161c2d;--bg-card:#161c2db8;--bg-card-hover:#1e293bd9;--border-color:#ffffff1a;--border-color-focus:#3b82f680;--text-primary:#f8fafc;--text-muted:#94a3b8;--text-dark:#0f172a;--accent-blue:#3b82f6;--accent-blue-glow:#3b82f659;--sig-excellent:#10b981;--sig-excellent-glow:#10b98166;--sig-good:#34d399;--sig-fair:#fbbf24;--sig-poor:#f97316;--sig-none:#ef4444;--sig-none-glow:#ef444473;--top-bar-height:60px;--bottom-nav-height:72px;--ad-banner-height:0px;--bottom-stack-height:calc(var(--bottom-nav-height) + var(--ad-banner-height));--transition-speed:.25s;--panel-transition:.38s cubic-bezier(.34, 1.1, .64, 1);--radius-lg:20px;--radius-md:12px;--radius-sm:8px}*{box-sizing:border-box;margin:0;padding:0}html{overscroll-behavior:none;height:100%;overflow:hidden}body{background-color:var(--bg-primary);color:var(--text-primary);overscroll-behavior:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;height:100dvh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;overflow:hidden}h1,h2,h3,.logo-text h1{letter-spacing:-.02em;font-family:Montserrat,sans-serif;font-weight:700}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.font-mono{font-family:JetBrains Mono,Fira Code,monospace}.highlight{color:var(--accent-blue);font-weight:600}.hidden{display:none!important}.app-layout{grid-template-rows:var(--top-bar-height) 1fr;width:100vw;height:100dvh;max-height:100dvh;display:grid;position:fixed;top:0;left:0;overflow:hidden}.top-bar{height:var(--top-bar-height);-webkit-backdrop-filter:blur(16px)saturate(140%);border-bottom:1px solid var(--border-color);z-index:100;background:#0b0f19eb;grid-row:1;justify-content:space-between;align-items:center;gap:12px;min-width:0;max-width:100vw;padding:0 16px;display:flex;overflow:hidden}.top-bar-left{flex:0 auto;align-items:center;gap:10px;min-width:0;display:flex}.logo-icon{object-fit:contain;flex-shrink:0;width:28px;height:28px}.logo-text{min-width:0;overflow:hidden}.logo-text h1{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:8px;font-size:16px;line-height:1;display:flex;overflow:hidden}.logo-text h1 span{text-overflow:ellipsis;min-width:0;overflow:hidden}.logo-text h1 small{color:#93c5fd;letter-spacing:.04em;background:#2563eb29;border:1px solid #93c5fd59;border-radius:999px;flex-shrink:0;padding:3px 6px;font-size:10px;font-weight:800}.selected-tx-info{background:#3b82f61f;border:1px solid #3b82f64d;border-radius:20px;align-items:center;gap:8px;max-width:100%;padding:4px 12px;display:flex;overflow:hidden}.tx-quick-name{white-space:nowrap;text-overflow:ellipsis;color:var(--text-primary);font-size:12px;font-weight:600;overflow:hidden}.tx-quick-dist{color:var(--accent-blue);white-space:nowrap;flex-shrink:0;font-size:11px;font-weight:700}.icon-btn{border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;width:34px;height:34px;transition:background var(--transition-speed), border-color var(--transition-speed);background:#ffffff12;border-radius:10px;justify-content:center;align-items:center;padding:0;font-size:16px;display:flex}.icon-btn:hover{border-color:var(--border-color-focus);background:#ffffff24}.map-panel{width:100%;height:100%;padding-bottom:calc(var(--bottom-stack-height) + env(safe-area-inset-bottom,0px));grid-row:2;position:relative;overflow:hidden}#map{width:100%;height:100%}.map-instruction-overlay{-webkit-backdrop-filter:blur(8px);border:1px solid var(--border-color);pointer-events:none;z-index:5;white-space:nowrap;background:#0b0f19d1;border-radius:20px;padding:6px 14px;font-size:11px;font-weight:500;transition:opacity .4s;position:absolute;top:12px;left:50%;transform:translate(-50%);box-shadow:0 4px 15px #00000080}.map-instruction-overlay.map-instruction-hidden{opacity:0}.map-zoom-control{right:12px;bottom:calc(var(--bottom-stack-height) + env(safe-area-inset-bottom,0px) + 16px);z-index:20;background:#fff;border-radius:2px;flex-direction:column;width:40px;display:flex;position:absolute;overflow:hidden;box-shadow:0 1px 4px #0000004d}.map-zoom-btn{color:#333;cursor:pointer;touch-action:manipulation;background:#fff;border:0;width:40px;height:40px;font:400 26px/1 Arial,sans-serif}.map-zoom-btn+.map-zoom-btn{border-top:1px solid #e6e6e6}.map-zoom-btn:active{background:#f1f1f1}.resume-overlay{z-index:60;padding:18px;padding-bottom:calc(var(--bottom-stack-height) + env(safe-area-inset-bottom,0px) + 18px);-webkit-backdrop-filter:blur(1.5px);background:#0206172e;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.resume-dialog{width:min(100%,380px);max-height:min(440px, calc(100dvh - var(--top-bar-height) - var(--bottom-stack-height) - 34px));border-radius:var(--radius-lg);background:#0c121ff0;border:1px solid #ffffff24;flex-direction:column;gap:16px;padding:16px;display:flex;overflow:hidden;box-shadow:0 22px 70px #0000009e}.resume-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.resume-note{max-width:270px;color:var(--text-muted);margin-top:0;font-size:12px;line-height:1.55}.resume-close-btn{width:34px;height:34px;color:var(--text-primary);cursor:pointer;background:#ffffff14;border:1px solid #ffffff1f;border-radius:50%;flex:none}.resume-body{flex-direction:column;min-height:0;display:flex}.resume-promo-slot{gap:8px;width:100%;display:grid}.app-promo-card{border-radius:var(--radius-md);min-height:72px;color:var(--text-primary);background:#ffffff0f;border:1px solid #ffffff1a;grid-template-columns:42px minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px;text-decoration:none;display:grid}.app-promo-card:active{transform:translateY(1px)}.app-promo-icon{background:#ffffff14;border-radius:10px;width:42px;height:42px;overflow:hidden;box-shadow:0 4px 12px #00000047}.app-promo-icon img{object-fit:cover;width:100%;height:100%;display:block}.app-promo-copy{gap:4px;min-width:0;display:grid}.app-promo-copy strong,.app-promo-copy small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.app-promo-copy strong{font-size:14px;line-height:1.15}.app-promo-copy small{color:var(--text-muted);font-size:11px}.app-promo-action{color:#bfdbfe;white-space:nowrap;background:#ffffff1a;border-radius:999px;justify-self:end;padding:6px 8px;font-size:10px;font-weight:800}@media (width<=360px){.app-promo-card{grid-template-columns:38px minmax(0,1fr)}.app-promo-icon{width:38px;height:38px}.app-promo-action{display:none}}.resume-primary-btn{border-radius:var(--radius-md);color:#0f172a;cursor:pointer;background:#f8fafc;border:0;width:100%;min-height:44px;font-size:15px;font-weight:800}.resume-primary-btn:active{transform:translateY(1px)}.bottom-nav{left:0;right:0;bottom:calc(var(--ad-banner-height) + env(safe-area-inset-bottom,0px));height:var(--bottom-nav-height);-webkit-backdrop-filter:blur(20px)saturate(150%);border-top:1px solid var(--border-color);z-index:100;background:#0b0f19f2;align-items:stretch;padding:0 8px;display:flex;position:fixed;overflow:hidden}.nav-btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-md);transition:color var(--transition-speed), background var(--transition-speed);opacity:1;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;min-width:0;padding:10px 8px;display:flex;position:relative}@media (hover:hover) and (pointer:fine){.nav-btn:hover{color:var(--text-primary);background:#ffffff0d}.nav-btn:hover .nav-btn-icon{transform:translateY(-1px)}}.nav-btn.active{color:var(--text-primary);background:0 0}.nav-btn-icon{font-size:22px;line-height:1;transition:transform .2s}.nav-btn-icon svg{fill:none;stroke:currentColor;stroke-width:2.1px;stroke-linecap:round;stroke-linejoin:round;width:28px;height:28px;display:block}.nav-btn-icon svg .filled{fill:currentColor;stroke:none}.nav-btn.locating{color:var(--text-primary);background:0 0;animation:.9s ease-in-out infinite alternate nav-locating-pulse}@keyframes nav-locating-pulse{0%{opacity:.55}to{opacity:1}}.nav-btn-label{letter-spacing:.02em;font-size:10px;font-weight:600}.admob-banner{height:calc(var(--ad-banner-height) + env(safe-area-inset-bottom,0px));padding:0 8px;padding-bottom:env(safe-area-inset-bottom,0px);z-index:100;background:#0b0f19;border-top:1px solid #ffffff14;justify-content:center;align-items:flex-start;display:none;position:fixed;bottom:0;left:0;right:0;overflow:hidden}.admob-banner-slot{width:min(100%,320px);height:var(--ad-banner-height);background:#ffffff0f;border-left:1px solid #ffffff14;border-right:1px solid #ffffff14}.slide-panel{left:0;right:0;bottom:calc(var(--bottom-stack-height) + env(safe-area-inset-bottom,0px) + 8px);z-index:200;-webkit-backdrop-filter:blur(24px)saturate(160%);border-radius:var(--radius-lg);max-height:calc(100vh - var(--top-bar-height) - var(--bottom-stack-height) - 16px);max-height:80vh;max-height:min(80vh, calc(100dvh - var(--top-bar-height) - var(--bottom-stack-height) - env(safe-area-inset-bottom,0px) - 16px));visibility:hidden;transition:transform var(--panel-transition), visibility 0s linear var(--panel-transition);background:#0f1423f7;border-top:1px solid #ffffff1f;flex-direction:column;display:flex;position:fixed;transform:translateY(100%);box-shadow:0 -8px 40px #000000b3}.slide-panel.open{visibility:visible;transition:transform var(--panel-transition), visibility 0s linear 0s;transform:translateY(0)}.panel-handle-area{cursor:grab;flex-shrink:0;justify-content:center;padding:10px 0 4px;display:flex}.panel-handle{background:#fff3;border-radius:2px;width:36px;height:4px}.panel-header{border-bottom:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 20px 12px;display:flex}.panel-title{font-size:16px;font-weight:700}.panel-header-right{align-items:center;gap:10px;display:flex}.permission-notice{left:12px;right:12px;bottom:calc(var(--bottom-stack-height) + env(safe-area-inset-bottom,0px) + 12px);z-index:500;border-radius:var(--radius-md);-webkit-backdrop-filter:blur(18px)saturate(150%);background:#0f172af5;border:1px solid #fbbf2473;align-items:flex-start;gap:12px;padding:12px 14px;display:flex;position:fixed;box-shadow:0 12px 32px #00000080}.permission-notice.info{border-color:#93c5fd73}.permission-notice strong{color:var(--text-primary);margin-bottom:4px;font-size:13px;line-height:1.35;display:block}.permission-notice p{color:var(--text-muted);font-size:11px;line-height:1.45}.permission-notice-close{border:1px solid var(--border-color);width:28px;height:28px;color:var(--text-primary);cursor:pointer;background:#ffffff12;border-radius:8px;flex-shrink:0}.panel-close-btn{border:1px solid var(--border-color);color:var(--text-muted);cursor:pointer;width:30px;height:30px;transition:background var(--transition-speed), color var(--transition-speed);background:#ffffff14;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:14px;display:flex}.panel-close-btn:hover{color:var(--text-primary);background:#ffffff29}.panel-body{flex-direction:column;flex:1;gap:16px;padding:16px 20px 24px;display:flex;overflow-y:auto}.panel-backdrop{z-index:150;opacity:0;pointer-events:none;background:#00000080;transition:opacity .3s;position:fixed;inset:0}.panel-backdrop.visible{opacity:1;pointer-events:all}.button-group{gap:10px;display:flex}.btn{border-radius:var(--radius-md);cursor:pointer;transition:transform .1s ease, filter var(--transition-speed);border:none;flex:1;justify-content:center;align-items:center;gap:8px;padding:11px 14px;font-size:13px;font-weight:600;display:flex}.btn:active{transform:scale(.97)}.btn-primary{background-color:var(--accent-blue);color:#fff;box-shadow:0 4px 12px var(--accent-blue-glow)}.btn-primary:hover{filter:brightness(1.1);box-shadow:0 4px 16px #3b82f680}.btn-secondary{color:var(--text-primary);border:1px solid var(--border-color);background-color:#ffffff14}.btn-secondary:hover{background-color:#ffffff26}.search-box{align-items:center;display:flex;position:relative}.search-box input{border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:border-color var(--transition-speed), box-shadow var(--transition-speed);background-color:#0f172a99;outline:none;padding:12px 35px 12px 14px;font-size:13px}.search-box input:focus{border-color:var(--accent-blue);box-shadow:0 0 8px var(--accent-blue-glow)}.btn-clear{color:var(--text-muted);cursor:pointer;background:0 0;border:none;outline:none;font-size:18px;position:absolute;right:12px}.btn-clear:hover{color:var(--text-primary)}.location-telemetry{border-radius:var(--radius-md);background:#0003;border:1px solid #ffffff0a;padding:12px;font-size:12px}.telemetry-row{justify-content:space-between;margin-bottom:6px;display:flex}.telemetry-row:last-child{margin-bottom:0}.telemetry-row .label{color:var(--text-muted)}.telemetry-row .value{color:var(--text-primary);font-weight:500}.address-row{border-top:1px dashed var(--border-color);flex-direction:column;gap:4px;margin-top:6px;padding-top:6px}.address-row .value{word-break:break-all;line-height:1.4}.transmitters-list{flex-direction:column;gap:12px;min-height:60px;display:flex}.transmitter-list-section{flex-direction:column;gap:8px;display:flex}.transmitter-list-section h3{color:var(--text-muted);letter-spacing:.04em;font-size:11px;font-weight:800}.transmitter-card{border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-speed) cubic-bezier(.4, 0, .2, 1);background:#0f172a80;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex;position:relative;overflow:hidden}.transmitter-card:before{content:"";width:3px;height:100%;transition:background-color var(--transition-speed);background-color:#0000;position:absolute;top:0;left:0}.transmitter-card:hover{background:var(--bg-card-hover);border-color:#ffffff29;transform:translate(2px)}.transmitter-card .tx-header{justify-content:space-between;align-items:center;gap:10px;display:flex}.tx-main-info{flex:1;justify-content:space-between;align-items:center;gap:10px;min-width:0;display:flex}.tx-left,.tx-right{align-items:center;gap:8px;min-width:0;display:flex}.tx-left{flex:1;justify-content:flex-start}.tx-right{flex-shrink:0;justify-content:flex-end}.transmitter-card .tx-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:13px;font-weight:600;line-height:1.3;overflow:hidden}.transmitter-card .tx-distance,.transmitter-card .tx-power,.transmitter-card .tx-polarization,.transmitter-card .tx-summary{white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;font-size:11px;font-weight:700;overflow:hidden}.transmitter-card .tx-power,.transmitter-card .tx-polarization{color:var(--text-muted)}.transmitter-card .tx-distance{color:var(--accent-blue)}.line-toggle{cursor:pointer;width:32px;height:18px;transition:background var(--transition-speed), border-color var(--transition-speed);background:#0f172ae6;border:1px solid #94a3b880;border-radius:999px;flex-shrink:0;padding:2px}.line-toggle span{background:var(--text-muted);width:12px;height:12px;transition:transform var(--transition-speed), background var(--transition-speed);border-radius:50%;display:block}.line-toggle.active{background:#3b82f64d;border-color:#3b82f6cc}.line-toggle.active span{background:#fff;transform:translate(14px)}.transmitter-card .tx-desc{color:var(--text-muted);font-size:11px;line-height:1.4;display:none}.transmitter-card .tx-meta{display:none}.transmitter-detail{flex-direction:column;gap:12px;display:flex}.detail-summary{border:1px solid var(--border-color);border-radius:var(--radius-md);background:#0f172a80;justify-content:space-between;align-items:center;gap:12px;padding:14px;display:flex}.detail-summary-main{min-width:0}.detail-prefecture{color:var(--accent-blue);margin-bottom:4px;font-size:11px;font-weight:700;display:block}.detail-summary h3{color:var(--text-primary);font-size:18px;line-height:1.25}.detail-line-toggle{color:var(--text-muted);cursor:pointer;background:#0f172ae6;border:1px solid #94a3b873;border-radius:999px;flex-shrink:0;align-items:center;gap:8px;padding:7px 8px 7px 12px;font-size:11px;font-weight:700;display:flex}.detail-line-toggle i{background:#94a3b847;border-radius:999px;width:30px;height:16px;display:block;position:relative}.detail-line-toggle i:after{content:"";background:var(--text-muted);width:12px;height:12px;transition:transform var(--transition-speed), background var(--transition-speed);border-radius:50%;position:absolute;top:2px;left:2px}.detail-line-toggle.active{color:var(--text-primary);background:#3b82f638;border-color:#3b82f6cc}.detail-line-toggle.active i{background:#3b82f673}.detail-line-toggle.active i:after{background:#fff;transform:translate(14px)}.detail-grid,.detail-coordinates{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.detail-grid div,.detail-coordinates div{border-radius:var(--radius-sm);background:#0f172a6b;border:1px solid #ffffff12;min-width:0;padding:10px 12px}.detail-grid span,.detail-coordinates span{color:var(--text-muted);margin-bottom:4px;font-size:10px;font-weight:700;display:block}.detail-grid strong,.detail-coordinates strong{color:var(--text-primary);word-break:break-word;font-size:13px;line-height:1.35;display:block}.channel-section{flex-direction:column;gap:8px;display:flex}.channel-section h3{color:var(--text-primary);font-size:13px}.channel-list{flex-direction:column;gap:6px;display:flex}.channel-row{border-radius:var(--radius-sm);background:#0f172a80;border:1px solid #ffffff12;grid-template-columns:54px minmax(0,1fr) 58px 74px;align-items:center;gap:8px;padding:10px 12px;display:grid}.channel-number{color:var(--accent-blue);font-size:13px;font-weight:800}.channel-station{min-width:0;color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:600;overflow:hidden}.channel-remote{color:var(--text-muted);text-align:right;font-size:10px;font-weight:700}.channel-frequency{color:var(--text-muted);text-align:right;white-space:nowrap;font-size:10px;font-weight:700}.detail-loading{color:var(--text-muted);border-radius:var(--radius-sm);background:#0f172a6b;border:1px solid #ffffff12;padding:14px;font-size:12px}.skeleton-card{border-radius:var(--radius-md);border:1px solid var(--border-color);background:linear-gradient(90deg,#ffffff08 25%,#ffffff12 50%,#ffffff08 75%) 0 0/200% 100%;height:80px;animation:1.5s infinite skeleton-shimmer}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.telemetry-section{transition:opacity var(--transition-speed) ease;border-top:1px solid var(--border-color);padding-top:16px}.telemetry-section.inactive{opacity:.55;pointer-events:none}.no-transmitter-selected{text-align:center;color:var(--text-muted);border:1px dashed var(--border-color);border-radius:var(--radius-md);padding:14px;font-size:12px}.signal-gauge-area{border-radius:var(--radius-md);background:#00000040;border:1px solid #ffffff0a;padding:14px}.signal-gauge-header{justify-content:space-between;align-items:center;margin-bottom:8px;font-size:12px;display:flex}.signal-gauge-header .value{color:var(--text-dark);border-radius:12px;padding:2px 8px;font-size:13px;font-weight:700}.bg-excellent{background-color:var(--sig-excellent);color:#000!important}.bg-good{background-color:var(--sig-good);color:#000!important}.bg-fair{background-color:var(--sig-fair);color:#000!important}.bg-poor{background-color:var(--sig-poor);color:#000!important}.bg-none{background-color:var(--sig-none);color:#fff!important}.signal-progress-track{background:#ffffff14;border-radius:4px;width:100%;height:7px;margin-bottom:8px;overflow:hidden}.signal-progress-bar{border-radius:4px;width:0%;height:100%;transition:width .4s cubic-bezier(.1,.8,.2,1),background-color .4s}.signal-dbm{text-align:right;letter-spacing:-.01em;font-size:16px;font-weight:700}.text-excellent{color:var(--sig-excellent)}.text-good{color:var(--sig-good)}.text-fair{color:var(--sig-fair)}.text-poor{color:var(--sig-poor)}.text-none{color:var(--sig-none)}.telemetry-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-top:12px;display:grid}.metric-box{border:1px solid var(--border-color);border-radius:var(--radius-md);background:#ffffff08;padding:10px 12px}.metric-label{color:var(--text-muted);margin-bottom:4px;font-size:10px}.metric-value{font-size:13px;font-weight:600}.los-text-los{color:var(--sig-excellent);font-weight:700}.los-text-blocked{color:var(--sig-none);font-weight:700}.compass-section-inline{border-top:1px solid var(--border-color);padding-top:14px}.section-sub-title{margin-bottom:6px;font-size:14px;font-weight:600}.section-desc{color:var(--text-muted);margin-bottom:12px;font-size:11px;line-height:1.4}.compass-container-outer{justify-content:center;width:100%;margin:4px 0 8px;display:flex}.compass-widget-container{border:2px solid var(--border-color);width:160px;height:160px;transition:all var(--transition-speed) ease;-webkit-user-select:none;user-select:none;background:radial-gradient(circle,#0f172acc 0%,#0b0f19f2 100%);border-radius:50%;padding:6px;position:relative;box-shadow:inset 0 4px 12px #000c,0 4px 10px #0000004d}.compass-widget-container.aligned-close{border-color:var(--sig-fair);box-shadow:inset 0 2px 8px #000c,0 0 15px #fbbf2466}.compass-widget-container.aligned-perfect{border-color:var(--sig-excellent);box-shadow:inset 0 2px 8px #000c, 0 0 25px var(--sig-excellent-glow);animation:1.5s infinite alternate perfect-glow-pulse}.compass-widget-container.dragging{cursor:grabbing}.compass-svg{cursor:grab}.compass-widget-container.dragging .compass-svg{cursor:grabbing}.compass-outer-circle{fill:none;stroke:#ffffff1a;stroke-width:1px}.compass-inner-circle{fill:none;stroke:#ffffff0a;stroke-width:1px;stroke-dasharray:2 4}.compass-text{fill:var(--text-muted);font-family:Montserrat,sans-serif;font-size:14px;font-weight:700}.label-n{fill:#ef4444}.compass-tick-line{stroke:#ffffff40;stroke-width:1px}.compass-target-line{stroke:#f87171;stroke-width:2px;stroke-dasharray:4 3}.compass-target-arrow{fill:#ef4444;filter:drop-shadow(0 0 4px #ef444480)}.compass-pointer-group{transition:transform 50ms ease-out}.antenna-boom{stroke:var(--accent-blue);stroke-width:3px;stroke-linecap:round}.antenna-element{stroke:#ffffffd9;stroke-width:2.5px;stroke-linecap:round}.reflector{stroke-width:3.5px}.driver{stroke:#60a5fa}.antenna-handle{fill:var(--accent-blue);stroke:#fff;stroke-width:1.5px;cursor:pointer;filter:drop-shadow(0 2px 4px #00000080)}.compass-center-mask{fill:var(--bg-primary);stroke:#ffffff1a;stroke-width:1px}.compass-angle-value{fill:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:15px;font-weight:700}.aligned-perfect .antenna-boom{stroke:var(--sig-excellent)}.aligned-perfect .antenna-handle{fill:var(--sig-excellent);stroke:#fff}.aligned-perfect .compass-angle-value{fill:#34d399}@keyframes perfect-glow-pulse{0%{box-shadow:inset 0 2px 8px #000c,0 0 15px #10b98166}to{box-shadow:inset 0 2px 8px #000c,0 0 28px #10b981b3}}.angle-control{margin-top:4px}.angle-labels{justify-content:space-between;align-items:center;margin-bottom:6px;font-size:12px;display:flex}.angle-labels .value{color:var(--accent-blue);font-size:14px;font-weight:700}.custom-slider{appearance:none;background:#ffffff1f;border-radius:3px;outline:none;width:100%;height:5px;margin:8px 0}.custom-slider::-webkit-slider-thumb{appearance:none;background:var(--accent-blue);cursor:pointer;width:18px;height:18px;transition:transform .1s ease, background-color var(--transition-speed);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 6px #0006}.custom-slider::-webkit-slider-thumb:hover{background:#60a5fa;transform:scale(1.15)}.custom-slider::-webkit-slider-thumb:active{transform:scale(.95)}.technical-details{border-top:1px solid var(--border-color);padding-top:12px}.technical-details summary{color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;outline:none;font-size:11px;font-weight:600}.technical-details summary:hover{color:var(--text-primary)}.tech-grid{border-radius:var(--radius-sm);background:#00000040;grid-template-columns:1fr;gap:5px;margin-top:8px;padding:10px;font-size:11px;display:grid}.tech-grid div{border-bottom:1px solid #ffffff05;justify-content:space-between;padding-bottom:4px;display:flex}.tech-grid div:last-child{border-bottom:none;padding-bottom:0}.tech-grid span:first-child{color:var(--text-muted)}.channels-area{border-top:1px solid var(--border-color);padding-top:12px}.channels-title{color:var(--text-primary);margin-bottom:8px;font-size:12px;font-weight:600}.channels-list{flex-direction:column;gap:5px;max-height:140px;padding-right:2px;list-style:none;display:flex;overflow-y:auto}.channel-item{border-radius:var(--radius-sm);background:#ffffff05;border:1px solid #ffffff0a;justify-content:space-between;align-items:center;padding:6px 10px;font-size:11px;display:flex}.channel-name{font-weight:500}.channel-info{color:var(--text-muted);font-size:10px}.settings-group{flex-direction:column;gap:6px;display:flex}.setting-label{color:var(--text-muted);font-size:12px;font-weight:600}.setting-header{justify-content:space-between;align-items:center;display:flex}.setting-header .value{color:var(--accent-blue);font-size:12px;font-weight:700}.custom-select{border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:border-color var(--transition-speed);background-color:#0f172acc;outline:none;width:100%;padding:10px;font-size:12px}.custom-select:focus{border-color:var(--accent-blue)}.slider-helper{color:var(--text-muted);font-size:10px;line-height:1.3;display:block}.gm-style .gm-style-iw-c{background-color:var(--bg-primary)!important;border:1px solid var(--border-color)!important;border-radius:var(--radius-md)!important;padding:12px 14px!important;box-shadow:0 10px 25px #0009!important}.gm-style .gm-style-iw-t:after{background:var(--bg-primary)!important;border-bottom:1px solid var(--border-color)!important;border-right:1px solid var(--border-color)!important;box-shadow:none!important}.gm-style .gm-style-iw-d{color:var(--text-primary)!important;overflow:hidden!important}.gm-style .gm-style-iw-d h4{color:#fff;border-bottom:1px solid var(--border-color);margin-bottom:6px;padding-bottom:4px;font-family:Montserrat,sans-serif;font-size:13px;font-weight:700}.gm-style .gm-style-iw-d p{color:var(--text-muted);font-size:11px;line-height:1.4}.gm-style-iw-btn{filter:invert()}.loading-overlay{background-color:var(--bg-primary);z-index:10000;justify-content:center;align-items:center;transition:opacity .5s,visibility .5s;display:flex;position:fixed;inset:0}.loading-overlay.fade-out{opacity:0;visibility:hidden;pointer-events:none}.loading-content{text-align:center;flex-direction:column;align-items:center;gap:16px;display:flex}.spinner{border:4px solid #ffffff0d;border-top:4px solid var(--accent-blue);width:50px;height:50px;box-shadow:0 0 15px var(--accent-blue-glow);border-radius:50%;animation:1s linear infinite spin}.loading-content p{letter-spacing:.05em;background:linear-gradient(135deg, #fff 40%, var(--accent-blue) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-family:Montserrat,sans-serif;font-size:20px;font-weight:700}.loading-detail{color:var(--text-muted);font-size:12px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (width>=640px){.slide-panel{max-width:480px;left:50%;transform:translate(-50%)translateY(100%)}.slide-panel.open{transform:translate(-50%)translateY(0)}}@media (width<=380px){.logo-text p{display:none}.nav-btn-label{font-size:9px}}
