: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;width:100%;height:100%;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{flex-direction:column;width:100%;height:100dvh;min-height:100dvh;background:var(--surface-strong)}.app,.app-body{display:flex;overflow:hidden}.app-body{flex:1 1;min-height:0;flex-direction:row;position:relative;gap:1rem;padding:1rem}.app-sidebar{width:288px;min-width:260px;max-width:min(320px,38vw);flex-shrink:0;display:flex;flex-direction:column;gap:.75rem;padding:1.1rem 1rem 1.25rem;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 4px 6px rgba(0,0,0,.1);transition:transform .3s ease-in-out}.sidebar-brand{padding-bottom:.35rem}.sidebar-title{margin:0;font-size:1.1rem;font-weight:700}.sidebar-tagline{margin:.35rem 0 0;font-size:.8rem;line-height:1.35;color:var(--text-muted)}.sidebar-section{display:flex;flex-direction:column;gap:.55rem;background:rgba(5,15,25,.45);border:1px solid rgba(148,197,255,.16);border-radius:10px;padding:.8rem}.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;display:flex;flex-direction:column;min-height:0;gap:.85rem}.viewer-header{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:.95rem 1rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;box-shadow:0 4px 6px rgba(0,0,0,.1)}.viewer-header-left{display:flex;align-items:center;gap:.9rem;min-width:0}.viewer-title{margin:0;font-size:1.15rem;font-weight:700}.viewer-subtitle{margin:.2rem 0 0;color:var(--text-muted);font-size:.82rem}.viewer-header-actions{display:flex;align-items:center;gap:.55rem}.viewer-link{display:inline-flex;align-items:center;padding:.45rem .75rem;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:6px;color:var(--text);text-decoration:none;font-size:.8rem;font-weight:500;transition:all .2s ease}.viewer-link:hover{background:rgba(255,255,255,.1);border-color:var(--accent)}.controls-panel{display:flex;flex-direction:column;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:.48rem .56rem;background:rgba(8,17,29,.88);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 var(--border);border-radius:8px;background:rgba(255,255,255,.05);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.1);border-color:var(--accent)}.frame-readout{font-size:.8rem;color:var(--text-muted);white-space:nowrap}.status-strip{display:flex;flex-wrap:wrap;gap:.6rem;padding:.7rem .9rem;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 4px 6px rgba(0,0,0,.1)}.status-pill{padding:.28rem .58rem;border-radius:6px;border:1px solid var(--border);font-size:.77rem;color:var(--text-muted);background:rgba(255,255,255,.03)}.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;background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:0 4px 6px rgba(0,0,0,.1)}.radar-view-placeholder{flex:1 1;min-height:0;width:100%}.radar-view{flex:1 1;min-height:0;position:relative;background:#050a10;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{padding:.55rem}.app-sidebar{position:absolute;top:.55rem;left:0;bottom:.55rem;z-index:1000;width:80%;min-width:280px;max-width:380px;max-height:none;transform:translateX(-100%);border-bottom:1px solid var(--border);border:1px solid var(--border);background:var(--surface);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-sidebar-toggle{background:none;border:none;color:var(--text);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:6px}.viewer-header{padding:.75rem .7rem;align-items:flex-start;flex-direction:column}.viewer-header-left{width:100%;align-items:flex-start}.viewer-header-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}.viewer-subtitle{font-size:.76rem}.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-sidebar-backdrop,.mobile-sidebar-close,.mobile-sidebar-toggle{display:none}.sidebar-title{margin:0}}.info-page-shell{min-height:100vh;background:var(--surface-strong,#081321);color:var(--text,#ebf5ff)}.info-page-header{background:var(--surface);border-bottom:1px solid var(--border);padding:1.5rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.info-page-header h1{margin:0;font-size:1.5rem;font-weight:700}.info-page-header p{margin:.35rem 0 0;color:var(--text-muted);font-size:.875rem}.info-page-actions{display:flex;gap:.6rem;align-items:center}.info-page{padding:2rem;max-width:1200px;margin:0 auto;color:var(--text);line-height:1.6}.info-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.5rem;margin-bottom:1.25rem;box-shadow:0 4px 6px rgba(0,0,0,.1)}.info-lead{border-left:3px solid var(--accent)}.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:0;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-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;margin-bottom:0;color:var(--text);background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:6px;text-decoration:none;font-weight:500;font-size:.875rem;transition:all .2s ease}.info-page .back-link:hover{background:rgba(255,255,255,.1);border-color:var(--accent)}.info-footnote{margin:2rem 0 0;color:var(--text-muted);font-size:.9rem}@media (max-width:900px){.info-page-header{padding:1rem;flex-direction:column;align-items:flex-start}.info-page{padding:1rem}.info-page-actions{flex-wrap:wrap}}.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)}