:root{--surface:rgba(11,23,37,0.85);--surface-soft:rgba(21,38,59,0.72);--surface-strong:rgba(8,17,29,0.95);--accent:#5ad3ff;--accent-soft:#1ca6d9;--text:#ebf5ff;--text-muted:rgba(231,242,255,0.7);--border:rgba(148,197,255,0.25)}*{box-sizing:border-box}body,html{margin:0;font-family:Avenir Next,Segoe UI,sans-serif;background:radial-gradient(circle at 20% -20%,#1d4a73 0,#0c1b2f 50%,#081321 100%);color:var(--text)}.app,body,html{width:100%;height:100%}.app{display:flex;flex-direction:column}.app-body{flex:1 1;min-height:0;display:flex;flex-direction:row;position:relative}.app-sidebar{width:288px;min-width:260px;max-width:min(320px,38vw);flex-shrink:0;display:flex;flex-direction:column;gap:.75rem;padding:1rem 1rem 1.25rem;overflow-y:auto;background:linear-gradient(180deg,var(--surface-strong),var(--surface));border-right:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:transform .3s ease-in-out}.sidebar-brand{padding-bottom:.35rem;border-bottom:1px solid rgba(148,197,255,.15)}.sidebar-title{margin:0;font-size:1.15rem;letter-spacing:.06em;text-transform:uppercase}.sidebar-tagline{margin:.35rem 0 0;font-size:.78rem;line-height:1.35;color:var(--text-muted)}.sidebar-section{display:flex;flex-direction:column;gap:.55rem}.sidebar-section-title{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-soft);margin:.15rem 0 0}.sidebar-hint{font-size:.75rem;line-height:1.45}.sidebar-hint,.sidebar-readout{margin:0;color:var(--text-muted)}.sidebar-readout{font-size:.78rem;line-height:1.4;word-break:break-word}.app-main{flex:1 1;min-width:0;min-height:0}.app-main,.controls-panel{display:flex;flex-direction:column}.controls-panel{gap:1rem;width:100%}.controls-row{display:flex;flex-wrap:wrap;gap:.6rem;align-items:end}.controls-row-tight{align-items:center}.control-field{display:flex;flex-direction:column;gap:.3rem;min-width:150px}.app-sidebar .control-field{min-width:0;width:100%}.control-grow{flex:1 1;min-width:180px}.control-label{font-size:.74rem;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted)}.control-input,.control-input-range{width:100%}.control-input{padding:.44rem .52rem;background:var(--surface-strong);color:var(--text);border:1px solid var(--border);border-radius:8px}.control-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(90,211,255,.28)}.control-input-range{accent-color:var(--accent-soft)}.toggle-field{display:flex;align-items:center;gap:.45rem;padding:.45rem .6rem;background:rgba(6,16,30,.5);border:1px solid var(--border);border-radius:8px;min-height:37px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.toggle-field input{accent-color:var(--accent-soft)}.refresh-button{width:100%;min-height:37px;padding:.5rem .85rem;border:1px solid rgba(90,211,255,.6);border-radius:8px;background:linear-gradient(155deg,rgba(20,85,130,.85),rgba(18,46,78,.9));color:var(--text);font-weight:600;cursor:pointer;transition:transform .12s ease,filter .12s ease}.refresh-button:disabled{cursor:progress;filter:saturate(.4)}.refresh-button:not(:disabled):hover{transform:translateY(-1px);filter:brightness(1.07)}.frame-readout{font-size:.8rem;color:var(--text-muted);white-space:nowrap}.status-strip{display:flex;flex-wrap:wrap;gap:.6rem;padding:.45rem 1rem .65rem;background:rgba(7,18,31,.8);border-bottom:1px solid rgba(126,187,255,.2)}.status-pill{padding:.3rem .58rem;border-radius:999px;border:1px solid var(--border);font-size:.77rem;color:var(--text-muted);background:rgba(9,30,50,.65)}.info-button{background:none;border:none;color:var(--accent);cursor:pointer;margin-left:.35rem;font-size:1rem;padding:0;display:inline-flex;align-items:center;justify-content:center;line-height:1}.info-button:hover{color:var(--accent-soft)}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:2rem}.modal-content{background:var(--surface-strong);border:1px solid var(--border);border-radius:12px;padding:2rem;max-width:600px;width:100%;max-height:85vh;overflow-y:auto;color:var(--text);box-shadow:0 12px 48px rgba(0,0,0,.6);position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(148,197,255,.15);padding-bottom:1rem;margin-bottom:1.5rem}.modal-title{margin:0;font-size:1.4rem;color:var(--text);font-weight:600}.modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1.8rem;line-height:1;padding:0}.modal-close:hover{color:var(--text)}.modal-body h4{margin:1.5rem 0 .5rem;color:var(--accent-soft);font-size:1.1rem}.modal-body p{margin:0 0 1rem;line-height:1.6;color:var(--text-muted);font-size:.95rem}.status-pill-warning{color:#ffdca8;border-color:rgba(255,189,84,.5);background:rgba(80,48,8,.72)}.main-view{flex:1 1;min-height:0;display:flex;flex-direction:column;position:relative}.radar-view-placeholder{flex:1 1;min-height:0;width:100%}.radar-view{flex:1 1;min-height:0;position:relative;background:#070a12;overflow:hidden;-webkit-user-select:none;-moz-user-select:none;user-select:none}.radar-canvas{display:block;width:100%;height:100%}.rv-overlay{position:absolute;font-family:monospace;pointer-events:none;line-height:1.6}.rv-top-left{top:12px;left:14px;color:#9ab;font-size:11px}.rv-site-line{display:flex;align-items:baseline;gap:6px}.rv-site-id{color:#fff;font-size:13px;font-weight:500}.rv-site-name{color:#5af;font-size:11px}.rv-hint,.rv-top-right{font-size:10px;color:#789}.rv-top-right{top:12px;right:14px;text-align:right}.rv-tilt-count{color:#cde;font-size:11px}.rv-elev-range{color:#789;font-size:10px}.rv-bottom-left{bottom:12px;left:14px;display:flex;flex-direction:column;gap:3px}.rv-colorbar{border-radius:2px;display:block}.rv-colorbar-labels{display:flex;justify-content:space-between;width:140px;font-size:9px;color:#678}.rv-bottom-right{bottom:12px;right:14px;display:flex;flex-direction:column;align-items:flex-end;gap:4px;pointer-events:all}.rv-thresh-label{font-size:10px;color:#789}.rv-thresh-slider{width:100px;accent-color:#5af}.rv-thresh-value{font-size:9px;color:#678}.rv-btn-row{display:flex;gap:4px}.rv-btn{font-size:10px;padding:3px 8px;cursor:pointer;background:rgba(255,255,255,.05);color:#9ab;border:.5px solid rgba(255,255,255,.12);border-radius:4px;font-family:monospace;transition:color .12s ease,border-color .12s ease}.rv-btn-active{color:#5af;border-color:rgba(85,170,255,.4)}@media (max-width:900px){.app-body{flex-direction:column}.app-sidebar{position:absolute;top:0;left:0;bottom:0;z-index:1000;width:80%;min-width:280px;max-width:380px;max-height:none;transform:translateX(-100%);border-right:1px solid var(--border);border-bottom:none;background:var(--surface-strong);box-shadow:2px 0 10px rgba(0,0,0,.5)}.app-sidebar.open{transform:translateX(0)}.mobile-sidebar-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;z-index:999;background:rgba(0,0,0,.4);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.mobile-header{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--surface-strong);border-bottom:1px solid var(--border);z-index:100}.mobile-sidebar-toggle{background:none;border:none;color:var(--text);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}.mobile-header-title{font-size:1.1rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.sidebar-header-row{display:flex;justify-content:space-between;align-items:center}.mobile-sidebar-close{background:none;border:none;color:var(--text);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity .2s}.mobile-sidebar-close:hover{opacity:1}}@media (min-width:901px){.mobile-header,.mobile-sidebar-backdrop,.mobile-sidebar-close,.mobile-sidebar-toggle{display:none}.sidebar-title{margin:0}}.info-page{padding:3rem 2rem;max-width:800px;margin:0 auto;color:var(--text);line-height:1.6}.info-page h1{font-size:2.2rem}.info-page h1,.info-page h2{margin-bottom:1rem;color:var(--accent)}.info-page h2{font-size:1.5rem;margin-top:2.5rem;border-bottom:1px solid var(--border);padding-bottom:.5rem}.info-page h3{font-size:1.2rem;margin-top:2rem;margin-bottom:.5rem;color:var(--text)}.info-page ol,.info-page p,.info-page ul{margin-bottom:1.2rem;color:var(--text-muted)}.info-page ol,.info-page ul{padding-left:1.5rem}.info-page li{margin-bottom:.5rem}.info-page pre{padding:1rem;border-radius:4px;overflow-x:auto;font-size:.9rem;border:1px solid var(--border)}.info-page code,.info-page pre{background:var(--surface-strong)}.info-page code{padding:.2rem .4rem;border-radius:3px;font-family:monospace;font-size:.9em;color:var(--accent)}.info-page .back-link{display:inline-block;margin-bottom:2rem;color:var(--accent);text-decoration:none;font-weight:500;transition:color .15s ease}.info-page .back-link:hover{color:var(--accent-soft);text-decoration:underline}.info-link{color:var(--accent);text-decoration:none;font-size:.8rem;font-weight:500;display:inline-block;margin-top:.5rem;transition:color .15s ease}.info-link:hover{text-decoration:underline;color:var(--accent-soft)}