:root{--cepheus-void-black:#000;--cepheus-phosphor-green:#39ff14;--cepheus-star-white:#fff;--cepheus-bone:#ecd5bb;--cepheus-panel:#050805;--c-bg:#000;--c-surface:#050805;--c-primary:#39ff14;--c-on-primary:#000;--c-text:#fff;--c-muted:#ffffff8c;--c-border-soft:#39ff142e;--c-border:#39ff1433;--c-border-strong:#39ff1473;--c-glow-soft:#39ff1414;--c-glow:#39ff1473;--c-focus:#39ff14;--c-accent:#ecd5bb;--color-bg:var(--c-bg);--surface-0:#000;--surface-1:#050805b3;--surface-1-solid:#050805e6;--surface-2:#39ff140b;--surface-2-hover:#39ff1416;--surface-3:#39ff141f;--color-text:var(--c-text);--color-text-dim:var(--c-muted);--color-text-muted:#ffffff73;--color-text-strong:var(--c-text);--color-accent:var(--c-primary);--color-accent-soft:var(--c-border-soft);--color-accent-hover:#39ff1447;--color-accent-border:var(--c-border-strong);--color-accent-glow:var(--c-glow-soft);--color-danger:#ff6e6e73;--color-success:#6edc96bf;--color-warning:#ffc86ecc;--color-main-world:#ecd5bbf2;--color-main-world-star:#ffdc78f2;--border-panel:var(--c-border-soft);--border-control:var(--c-border);--border-strong:var(--c-border-strong);--border-divider:#39ff141a;--rail:#39ff1429;--space-1:2px;--space-2:4px;--space-3:6px;--space-4:8px;--space-5:10px;--space-6:14px;--space-7:18px;--space-8:24px;--type-xs:10px;--type-sm:11px;--type-body:12px;--type-base:13px;--type-lg:14px;--type-xl:18px;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:10px;--radius-2xl:14px;--motion-fast:.14s;--motion-base:.16s;--motion-medium:.2s;--motion-slow:.28s;--motion-ease:cubic-bezier(.22, 1, .36, 1);--shadow-panel:0 16px 48px #0000009e, 0 0 28px var(--c-glow-soft);--shadow-button:0 4px 16px #00000059;--focus-ring:0 0 0 2px var(--c-focus);--font-sans:"JetBrains Mono", "SF Mono", Menlo, ui-monospace, monospace;--font-mono:"JetBrains Mono", "SF Mono", Menlo, ui-monospace, monospace;--font-display:"Orbitron", sans-serif;--backdrop-blur:blur(18px) saturate(140%);--safe-top:env(safe-area-inset-top,0px);--safe-right:env(safe-area-inset-right,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--safe-left:env(safe-area-inset-left,0px);--bg:var(--color-bg);--panel:var(--surface-1);--panel-border:var(--border-panel);--text:var(--color-text);--text-dim:var(--color-text-dim);--accent:var(--color-accent);--accent-soft:var(--color-accent-soft)}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}:focus-visible{outline:2px solid var(--c-focus);outline-offset:1px}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}*{box-sizing:border-box}html,body,#app{background:radial-gradient(circle at 16% 18%, #39ff140f, transparent 18%), radial-gradient(circle at 78% 28%, #39ff140b, transparent 22%), radial-gradient(circle at 50% 84%, #39ff1409, transparent 24%), var(--bg);width:100%;height:100%;min-height:100dvh;color:var(--text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;overscroll-behavior:none;margin:0;padding:0;font-size:13px;overflow:hidden}.app{width:100%;height:100dvh;min-height:100%;position:relative}.planet-canvas{cursor:grab;touch-action:none;width:100%;height:100%;display:block;position:absolute;inset:0}.planet-canvas:active{cursor:grabbing}.planet-canvas-inert{pointer-events:none;cursor:default}.panel{top:calc(var(--safe-top) + 68px);right:calc(var(--safe-right) + 16px);width:308px;max-height:calc(100dvh - var(--safe-top) - var(--safe-bottom) - 84px);background:var(--panel);border:1px solid var(--panel-border);-webkit-backdrop-filter:blur(18px)saturate(140%);border-radius:var(--radius-lg);scrollbar-width:thin;scrollbar-color:#ffffff26 transparent;z-index:8;touch-action:pan-y;padding:18px 18px 14px;transition:transform .28s cubic-bezier(.22,1,.36,1),opacity .2s;position:fixed;overflow-y:auto;box-shadow:0 16px 48px #0000008c}.panel::-webkit-scrollbar{width:6px}.panel::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.panel-closed{opacity:0;pointer-events:none;transform:translate(calc(100% + 24px))}.chart-shell-actions{flex:none;align-items:center;gap:6px;display:inline-flex;position:static}.chart-shell-actions .share-trigger,.chart-shell-actions .encounter-trigger{border:1px solid var(--border-strong);background:var(--surface-1-solid);-webkit-backdrop-filter:blur(14px)saturate(140%);border-radius:9px;width:36px;min-width:36px;height:36px;padding:0}.chart-shell-actions .encounter-trigger{color:var(--color-text);cursor:pointer;transition:background var(--motion-fast), color var(--motion-fast), border-color var(--motion-fast);justify-content:center;align-items:center;display:inline-flex}.chart-shell-actions .encounter-trigger:hover{background:var(--surface-2-hover);color:var(--color-accent);border-color:var(--color-accent-border)}.export-toolbar{align-items:center;gap:4px;display:inline-flex}.export-toolbar-btn{appearance:none;border:1px solid var(--border-strong);background:var(--surface-1-solid);height:36px;color:var(--color-text);font-size:var(--type-sm);cursor:pointer;border-radius:9px;padding:0 10px}.export-toolbar-btn:hover:not(:disabled){background:var(--surface-2-hover)}.export-toolbar-btn:disabled{opacity:.45;cursor:default}.panel-toggle{top:calc(var(--safe-top) + 12px);right:calc(var(--safe-right) + 12px);border:1px solid var(--border-strong);background:var(--surface-1-solid);-webkit-backdrop-filter:blur(14px)saturate(140%);width:36px;height:36px;color:var(--color-accent);cursor:pointer;z-index:10;border-radius:9px;justify-content:center;align-items:center;font-size:18px;font-weight:500;line-height:1;transition:background .16s,transform .16s,border-color .16s;display:flex;position:fixed;box-shadow:0 4px 16px #00000059}.panel-toggle:hover{background:var(--surface-2-hover);border-color:var(--border-strong)}.panel-toggle:active{transform:scale(.95)}.panel-toggle-open{font-size:14px}.panel-toggle-glyph{fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round;display:block}.panel-toggle-glyph circle:last-child{fill:currentColor;stroke:none}.support-link{border:1px solid color-mix(in srgb, var(--accent) 34%, transparent);background:color-mix(in srgb, var(--surface-1-solid) 86%, transparent);min-height:36px;color:var(--color-text-dim);box-shadow:var(--shadow-button);transition:color var(--motion-fast), border-color var(--motion-fast), background var(--motion-fast), transform var(--motion-fast);border-radius:999px;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:650;line-height:1;text-decoration:none;display:inline-flex}.support-link:hover,.support-link:focus-visible{border-color:color-mix(in srgb, var(--accent) 58%, transparent);background:color-mix(in srgb, var(--accent) 13%, var(--surface-1-solid));color:var(--color-text-strong)}.support-link:focus-visible{box-shadow:var(--focus-ring);outline:none}.support-link:active{transform:scale(.96)}.view-toggle{top:calc(var(--safe-top) + 16px);right:calc(var(--safe-right) + 68px);border:1px solid var(--border-strong);background:var(--surface-1-solid);-webkit-backdrop-filter:blur(14px)saturate(140%);height:40px;color:var(--color-accent);cursor:pointer;z-index:10;border-radius:10px;align-items:center;gap:6px;padding:0 14px;font-size:13px;font-weight:500;transition:background .16s,transform .16s,border-color .16s;display:flex;position:fixed;box-shadow:0 4px 16px #00000059}.view-toggle:hover{background:var(--surface-2-hover);border-color:var(--border-strong)}.view-toggle:active{transform:scale(.95)}.sys-meta{gap:var(--space-2) var(--space-5);margin:0 0 var(--space-4);font-size:var(--type-body);grid-template-columns:minmax(96px,auto) 1fr;line-height:1.5;display:grid}.sys-meta-row{display:contents}.sys-meta-row dt{color:var(--text-dim);letter-spacing:.2px;font-weight:500}.sys-meta-row dd{color:var(--color-text);margin:0}.sys-meta-bar dd{align-items:center;display:flex}.sys-survey{gap:var(--space-3);margin:var(--space-4) 0 var(--space-3);padding:var(--space-4);border:1px solid var(--border-panel);border-radius:var(--radius-md);font-size:var(--type-body);background:#ffffff09;display:grid}.sys-survey-line{justify-content:space-between;gap:var(--space-4);color:var(--text-dim);display:flex}.sys-survey-line strong{color:var(--color-text-strong)}.sys-survey-counts,.sys-survey-notes{gap:var(--space-2);flex-wrap:wrap;display:flex}.sys-survey-counts span,.sys-survey-notes span{color:var(--text-dim);white-space:nowrap;background:#ffffff0f;border-radius:4px;padding:3px 7px}.sys-actions{align-items:center;gap:10px;margin-top:10px;display:flex}.sys-export-row{margin-top:6px}.sys-export-row button{color:#ffffffb3;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:4px;padding:4px 10px;font-size:11px;transition:background .12s,border-color .12s}.sys-export-row button:hover:not(:disabled){background:#ffffff14;border-color:#ffffff2e}.sys-export-row button:disabled{opacity:.5;cursor:not-allowed}.sys-import-row{flex-wrap:wrap;margin-top:6px}.sys-import-row button,.sys-import-panel button{color:#ffffffb3;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:4px;padding:4px 10px;font-size:11px;transition:background .12s,border-color .12s}.sys-import-row button:hover:not(:disabled),.sys-import-panel button:hover:not(:disabled){background:#ffffff14;border-color:#ffffff2e}.sys-import-row button:disabled,.sys-import-panel button:disabled{opacity:.5;cursor:not-allowed}.sys-import-panel{flex-direction:column;gap:6px;margin-top:8px;display:flex}.sys-import-label{color:var(--text-dim);font-size:11px}.sys-import-textarea{box-sizing:border-box;width:100%;font-family:var(--font-mono);color:var(--color-text);resize:vertical;background:#00000059;border:1px solid #ffffff1f;border-radius:6px;padding:8px;font-size:11px;line-height:1.4}.sys-import-status{color:var(--text-dim);font-size:11px}.sys-import-hint{color:var(--text-dim);margin:0;font-size:11px;line-height:1.45}.sys-import-hint code{font-family:var(--font-mono);background:#ffffff14;border-radius:3px;padding:0 3px;font-size:10px}.sys-source-tag{color:var(--color-accent,var(--color-accent));font-weight:500}.time-scrubber{align-items:center;gap:10px;margin-top:8px;font-size:11px;display:flex}.time-scrubber-label{text-transform:uppercase;letter-spacing:.6px;color:#fff6}.time-scrubber-buttons{background:#ffffff0a;border:1px solid #ffffff1a;border-radius:6px;gap:1px;padding:2px;display:inline-flex}.time-scrubber-btn{font:inherit;color:#fff9;cursor:pointer;font-variant-numeric:tabular-nums;background:0 0;border:none;border-radius:4px;min-width:28px;padding:3px 8px;transition:background .12s,color .12s}.time-scrubber-btn:hover:not(:disabled){color:var(--color-text);background:#ffffff0f}.time-scrubber-btn.active{color:var(--color-text);background:#39ff142e}.time-scrubber-btn:disabled{opacity:.5;cursor:not-allowed}.sys-seed{color:#ffffff73;font-variant-numeric:tabular-nums;font-size:11px}.seed-field{color:#ffffff8c;font-variant-numeric:tabular-nums;align-items:center;gap:6px;font-size:11px;display:inline-flex}.seed-field-label{text-transform:uppercase;letter-spacing:.6px;color:#fff6}.seed-field input{background:var(--surface-2,#ffffff0a);border:1px solid var(--border-control,#ffffff1f);width:9ch;color:var(--color-text,#e8e8e8);font:inherit;font-variant-numeric:tabular-nums;text-align:right;border-radius:4px;outline:none;padding:3px 6px;transition:border-color .12s,background .12s}.seed-field input:hover:not(:disabled){border-color:#ffffff38}.seed-field input:focus{border-color:var(--accent,var(--color-accent));background:#ffffff0f}.seed-field input:disabled{opacity:.5;cursor:not-allowed}.sys-inspector{padding:var(--space-4) var(--space-3) var(--space-4) var(--space-5);background:#39ff140a;border-left:2px solid #39ff1473;margin:2px 0}.sys-inspector-grid{gap:var(--space-3) var(--space-4);margin:0 0 var(--space-3) 0;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));display:grid}.sys-inspector-stat{flex-direction:column;gap:2px;display:flex}.sys-inspector-stat dt{text-transform:uppercase;letter-spacing:.6px;color:var(--text-dim);font-size:10px}.sys-inspector-stat dd{color:var(--color-text);font-variant-numeric:tabular-nums;margin:0;font-size:13px}.sys-inspector-moons h4{text-transform:uppercase;letter-spacing:.6px;color:var(--text-dim);margin:var(--space-3) 0 var(--space-2) 0;font-size:10px;font-weight:500}.sys-inspector-moons ul{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.sys-inspector-moons li{gap:var(--space-3);font-variant-numeric:tabular-nums;color:var(--color-text);grid-template-columns:12px 1fr auto auto auto;align-items:center;font-size:12px;display:grid}.moon-dot{background:#a08a6a;border-radius:50%;justify-self:center;width:8px;height:8px}.moon-dot-icy{background:#d8e8f0}.moon-name{color:var(--text-dim)}.moon-stat{color:var(--color-text)}.moon-type{color:var(--text-dim);text-transform:lowercase;font-style:italic}.sys-unit{color:var(--text-dim);margin-left:3px;font-size:.85em}.sys-inline-action{vertical-align:middle;border:1px solid var(--border-control);width:24px;height:24px;color:var(--text-dim);border-radius:var(--radius-md);cursor:pointer;transition:background var(--motion-fast), color var(--motion-fast), border-color var(--motion-fast);background:#ffffff08;justify-content:center;align-items:center;margin-left:6px;padding:0;display:inline-flex}.sys-inline-action:hover:not(:disabled){background:var(--color-accent-soft);border-color:var(--color-accent-border);color:var(--color-text-strong)}.sys-inline-action:disabled{opacity:.4;cursor:default}.sys-belt{font-size:var(--type-body);color:var(--color-text);padding:var(--space-2) 0;align-items:center;gap:var(--space-4);display:flex}.sys-belt-dots{color:var(--text-dim);letter-spacing:2px}.detail-target-card{padding:var(--space-4);border:1px solid var(--border-panel);border-radius:var(--radius-lg);background:#ffffff09}.detail-target-head{align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.detail-target-head .icon,.detail-target-star{color:var(--color-accent);flex:none}.detail-target-star{text-align:center;width:18px;font-size:17px;line-height:1}.detail-target-head strong{color:var(--color-text-strong);font-size:var(--type-body);display:block}.detail-target-head span{color:var(--text-dim);font-size:var(--type-sm);margin-top:2px;display:block}.detail-target-grid{gap:var(--space-3);grid-template-columns:repeat(2,minmax(0,1fr));margin:0;display:grid}.detail-target-grid div{min-width:0}.detail-target-grid dt{color:var(--text-dim);font-size:var(--type-xs);text-transform:uppercase;letter-spacing:.6px}.detail-target-grid dd{color:var(--color-text);font-variant-numeric:tabular-nums;margin:2px 0 0}.detail-target-return{margin-top:var(--space-3)}.hab-bar{border-radius:var(--radius-sm);background:#ffffff0f;width:100%;max-width:140px;height:14px;position:relative;overflow:hidden}.hab-bar-fill{border-radius:var(--radius-sm);transition:width var(--motion-medium) var(--motion-ease);position:absolute;inset:0 auto 0 0}.hab-bar-good .hab-bar-fill{background:linear-gradient(90deg,#6edc968c,#6edc96d9)}.hab-bar-fair .hab-bar-fill{background:linear-gradient(90deg,#ffc86e8c,#ffc86ed9)}.hab-bar-poor .hab-bar-fill{background:linear-gradient(90deg,#ff6e6e73,#ff6e6ebf)}.hab-bar-label{font-size:var(--type-xs);color:var(--color-text-strong);font-variant-numeric:tabular-nums;text-shadow:0 1px 2px #0006;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.trade-codes{align-items:baseline;gap:var(--space-3);margin-top:var(--space-3);flex-wrap:wrap;display:flex}.trade-codes-label{font-size:var(--type-sm);color:var(--color-text-dim);flex-shrink:0}.trade-codes-list{gap:var(--space-2);flex-wrap:wrap;display:inline-flex}.trade-chip{padding:1px var(--space-3);border:1px solid var(--color-accent-border);border-radius:var(--radius-sm);background:var(--color-accent-soft);color:var(--color-text-strong);font:600 var(--type-sm)/1.4 var(--font-mono);letter-spacing:.6px;cursor:help;transition:background var(--motion-fast), border-color var(--motion-fast);text-decoration:none;display:inline-block}.trade-chip:hover,.trade-chip:focus-visible{background:var(--color-accent-hover);outline:none}.route-codes{align-items:baseline;gap:var(--space-3);margin-top:var(--space-3);flex-wrap:wrap;display:flex}.route-chip{padding:1px var(--space-3);border-radius:var(--radius-sm);color:var(--color-text-strong);font:600 var(--type-sm)/1.4 var(--font-mono);background:#94a3b81f;border:1px solid #94a3b873;display:inline-block}.route-chip-trade{background:#f8bf5624;border-color:#f8bf569e}.route-chip-more{color:var(--color-text-dim)}.polity-chip{align-items:center;gap:var(--space-2);margin-right:var(--space-2);padding:1px var(--space-3);border-radius:var(--radius-sm);color:var(--color-text-strong);font:600 var(--type-sm)/1.4 var(--font-mono);background:#94a3b81a;border:1px solid #94a3b86b;display:inline-flex}.polity-chip-0{background:#60a5fa24;border-color:#60a5fa94}.polity-chip-1{background:#2dd4bf1f;border-color:#2dd4bf8a}.polity-chip-2{background:#e2e8f014;border-color:#e2e8f061}.polity-chip-3{background:#f472b61f;border-color:#f472b685}.polity-chip-4{background:#a78bfa1f;border-color:#a78bfa85}.polity-chip-5{background:#fb923c1f;border-color:#fb923c85}.panel-header{flex-direction:column;gap:10px;margin-bottom:14px;display:flex}.panel-header h1{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;margin:0;font-size:18px;font-weight:700}.panel-actions{gap:6px;display:flex}.panel-actions button{border:1px solid var(--panel-border);background:var(--accent-soft);color:var(--text);font:inherit;cursor:pointer;border-radius:8px;flex:1;padding:8px 10px;transition:background .14s}.panel-actions button:hover{background:#39ff1447}.panel-actions button.ghost{background:0 0}.panel-actions button.ghost:hover{background:#ffffff0f}section{margin-bottom:14px}section h2{font-family:var(--font-display);letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent);margin:0 0 8px;font-size:10px;font-weight:700}.slider{margin:8px 0}.slider-row{justify-content:space-between;align-items:baseline;margin-bottom:4px;display:flex}.slider label{color:var(--text);font-size:12px}.slider-value{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:11px}input[type=range]{appearance:none;touch-action:none;background:0 0;width:100%;height:18px}input[type=range]::-webkit-slider-runnable-track{background:var(--rail);border-radius:2px;height:3px}input[type=range]::-moz-range-track{background:var(--rail);border-radius:2px;height:3px}input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--accent);border-radius:50%;width:14px;height:14px;margin-top:-5.5px;transition:transform .12s;box-shadow:0 0 0 4px #39ff1414}input[type=range]:active::-webkit-slider-thumb{transform:scale(1.15)}input[type=range]::-moz-range-thumb{background:var(--accent);border:none;border-radius:50%;width:14px;height:14px}.uwp-row{gap:6px;margin-bottom:4px;display:flex}.uwp-input{border:1px solid var(--panel-border);color:var(--text);font:13px var(--font-mono);letter-spacing:1px;background:#ffffff0a;border-radius:8px;outline:none;flex:1;padding:8px 10px;transition:border-color .14s,background .14s}.uwp-input:focus{background:#39ff140f;border-color:#39ff1473}.uwp-input.invalid{border-color:#ff6e6e73}.uwp-row button{border:1px solid var(--panel-border);background:var(--accent-soft);color:var(--text);font:inherit;cursor:pointer;border-radius:8px;padding:8px 12px;transition:background .14s}.uwp-row button:hover{background:#39ff1447}.uwp-legend{color:var(--text-dim);letter-spacing:.4px;margin-top:4px;font-size:10px;line-height:1.4}.starport-row{grid-template-columns:repeat(6,1fr);gap:4px;display:grid}.starport-btn{border:1px solid var(--panel-border);color:var(--text);font:600 13px var(--font-mono);cursor:pointer;background:#ffffff08;border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:6px 0 4px;transition:background .14s,border-color .14s,color .14s;display:flex}.starport-btn:hover{background:#ffffff14}.starport-btn.active{background:var(--accent-soft);color:var(--color-accent);border-color:#39ff1473}.starport-btn .icon{opacity:.75}.starport-btn.active .icon{opacity:1}.starport-btn-label{letter-spacing:.4px;font-size:11px}.icon{vertical-align:middle;flex:none;display:inline-block}.uwp-slider{margin:10px 0}.uwp-slider-row{justify-content:space-between;align-items:baseline;margin-bottom:4px;display:flex}.uwp-slider-label{color:var(--text);font-size:12px}.uwp-slider-code{font:600 12px var(--font-mono);color:var(--accent);background:var(--accent-soft);letter-spacing:1px;border-radius:4px;padding:1px 7px}.uwp-slider-desc{color:var(--text-dim);min-height:14px;margin-top:2px;font-size:11px;line-height:1.4}.perf-fps{margin-bottom:var(--space-5);padding:var(--space-4) var(--space-6);border-radius:var(--radius-lg);border:1px solid var(--border-panel);background:var(--surface-2);font-variant-numeric:tabular-nums;justify-content:space-between;align-items:center;display:flex}.perf-fps-number{align-items:baseline;gap:var(--space-2);display:inline-flex}.perf-fps-value{letter-spacing:.4px;color:var(--color-text-strong);transition:color var(--motion-medium);font-size:22px;font-weight:600}.perf-fps-unit{font-size:var(--type-sm);color:var(--text-dim);letter-spacing:.6px}.perf-fps-meta{text-align:right;font-size:var(--type-xs);color:var(--text-dim);flex-direction:column;gap:2px;display:flex}.perf-fps-good{border-color:#6edc9666}.perf-fps-good .perf-fps-value{color:#b4f5c8}.perf-fps-fair{border-color:#ffc86e73}.perf-fps-fair .perf-fps-value{color:#ffdca0}.perf-fps-poor{border-color:#ff6e6e73}.perf-fps-poor .perf-fps-value{color:#ffb4b4}.perf-fps-idle{opacity:.7}.perf-profile{margin-bottom:var(--space-5);padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);background:var(--color-accent-glow);border:1px solid var(--color-accent-soft);font-size:var(--type-body);justify-content:space-between;align-items:center;display:flex}.perf-profile-label{color:var(--text-dim);letter-spacing:.3px}.perf-profile-value{color:var(--color-text-strong);letter-spacing:.4px;font-weight:600}.perf-profile-auto{color:var(--text-dim);font-weight:400}.quality-segments{width:100%;margin-bottom:var(--space-5);grid-template-columns:repeat(3,1fr);gap:4px;display:grid}.quality-segment{appearance:none;border:1px solid var(--border-panel);border-radius:var(--radius-sm);background:var(--surface-2);min-width:0;color:var(--text-dim);letter-spacing:.3px;cursor:pointer;transition:background var(--motion-fast), color var(--motion-fast);padding:7px 6px;font-family:inherit;font-size:11px;font-weight:500;line-height:1.2}.quality-segment:hover{background:var(--surface-2-hover);color:var(--color-text)}.quality-segment.active{background:var(--color-accent-soft);color:var(--color-text-strong);border-color:color-mix(in srgb, var(--color-accent) 50%, var(--border-panel))}.quality-segment:disabled{opacity:.45;cursor:default}.quality-row,.quality-btn{display:none}.perf-grid{font-variant-numeric:tabular-nums;grid-template-columns:minmax(64px,1fr) minmax(0,1.5fr);gap:5px 10px;font-size:11px;line-height:1.25;display:grid}.perf-grid span{color:var(--text-dim)}.perf-grid strong{color:#ffffffe0;text-align:right;overflow-wrap:anywhere;min-width:0;font-weight:500}label.color{justify-content:space-between;align-items:center;margin:6px 0;font-size:12px;display:flex}label.color input[type=color]{border:1px solid var(--panel-border);cursor:pointer;background:0 0;border-radius:6px;width:36px;height:22px;padding:0}label.color input[type=color]::-webkit-color-swatch-wrapper{padding:2px}label.color input[type=color]::-webkit-color-swatch{border:none;border-radius:4px}.panel-footer{border-top:1px solid var(--panel-border);color:var(--text-dim);text-align:center;align-items:center;gap:var(--space-5);flex-direction:column;margin-top:10px;padding-top:12px;font-size:11px;display:flex}.panel-footer-hint{justify-content:center;align-items:center;gap:var(--space-4);display:flex}.panel-footer .link{color:var(--color-accent);font:inherit;cursor:pointer;text-underline-offset:3px;background:0 0;border:none;padding:0;text-decoration:underline dotted}.panel-footer .link:hover{color:var(--color-text-strong)}.panel-footer .link:disabled{color:var(--text-dim);cursor:default;text-decoration:none}.about-modal .about-lede{color:var(--color-text);font-size:var(--type-base);margin:0 0 var(--space-6);line-height:1.6}.about-modal a{color:var(--color-accent);text-underline-offset:3px;text-decoration:underline dotted}.about-modal a:hover{color:var(--color-text-strong)}.error-overlay{text-align:center;padding:var(--space-8);z-index:10;background:radial-gradient(#1e080cd9,#05070df2);flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.error-card{border-radius:var(--radius-2xl);border:1px solid var(--border-panel);background:var(--surface-1-solid);max-width:520px;backdrop-filter:var(--backdrop-blur);box-shadow:var(--shadow-panel);padding:28px 32px}.error-card h2{font-family:var(--font-display);font-size:var(--type-xl);letter-spacing:.08em;text-transform:uppercase;margin:0 0 var(--space-4);color:var(--color-text-strong);font-weight:700}.error-card p{color:var(--text-dim);margin:0 0 var(--space-5);line-height:1.55}.error-card .hint{margin-top:var(--space-6);font-size:var(--type-body)}.error-card code{border-radius:var(--radius-sm);font-family:var(--font-mono);background:#ffffff0f;padding:1px 6px;font-size:.92em}.error-checklist{text-align:left;margin:0 0 var(--space-6);padding-left:var(--space-7);color:var(--color-text);line-height:1.7}.error-checklist li{margin-bottom:var(--space-2)}.error-detail{text-align:left;margin:var(--space-5) 0;font-size:var(--type-body)}.error-detail summary{cursor:pointer;color:var(--text-dim);margin-bottom:var(--space-3)}.error-detail pre{padding:var(--space-4) var(--space-5);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:var(--type-sm);color:var(--color-text);white-space:pre-wrap;word-break:break-word;background:#00000059;max-height:180px;margin:0;overflow:auto}.error-reload{margin-top:var(--space-5);padding:var(--space-4) var(--space-7);border-radius:var(--radius-md);border:1px solid var(--color-accent-border);background:var(--color-accent-soft);color:var(--color-text-strong);font-size:var(--type-base);cursor:pointer;transition:background var(--motion-fast)}.error-reload:hover{background:var(--color-accent-hover)}.region-backdrop{z-index:25;animation:glossary-fade-in var(--motion-medium) var(--motion-ease);padding:calc(var(--safe-top) + var(--space-5)) calc(var(--safe-right) + var(--space-5)) calc(var(--safe-bottom) + var(--space-5)) calc(var(--safe-left) + var(--space-5));background:#020408eb;justify-content:center;align-items:stretch;display:flex;position:fixed;inset:0;overflow:hidden}.region-modal{gap:var(--space-4);background:var(--surface-1-solid);border:1px solid var(--border-panel);border-radius:var(--radius-xl);width:100%;height:100%;box-shadow:var(--shadow-panel);padding:var(--space-5) var(--space-6) var(--space-6);grid-template-rows:auto auto minmax(0,1fr);align-items:stretch;display:grid;overflow:hidden}.region-header{justify-content:space-between;align-items:center;gap:var(--space-6);width:100%;display:flex}.region-header h2{font-family:var(--font-display);font-size:var(--type-xl);color:var(--color-text-strong);letter-spacing:.08em;text-transform:uppercase;margin:0;font-weight:700}.region-subtitle{color:var(--text-dim);font-size:var(--type-body);margin:4px 0 0}.region-close{margin-left:auto}.region-header-actions{align-items:center;gap:var(--space-3);flex:none;display:inline-flex}.region-header-actions .region-close{margin-left:0}.region-encounter-btn{border-radius:var(--radius-md);border:1px solid var(--color-accent-border);background:var(--color-accent-soft);width:36px;height:36px;color:var(--color-text-strong);cursor:pointer;transition:background var(--motion-fast), border-color var(--motion-fast);flex:none;justify-content:center;align-items:center;display:inline-flex}.region-encounter-btn:hover{background:var(--surface-2-hover);color:var(--color-accent)}.region-features-overlay{pointer-events:none;width:100%;height:100%;position:absolute;inset:0;overflow:visible}.region-feature line{stroke:#ffe296d1;stroke-width:1.2px}.region-feature circle{fill:#ffe296f2;stroke:#0009;stroke-width:.8px}.region-feature text{fill:#fff;font-family:var(--font-sans);paint-order:stroke;stroke:#000000d9;stroke-width:3px;stroke-linejoin:round;font-size:11px;font-weight:600}.region-facts{gap:var(--space-2);color:var(--text-dim);font-size:var(--type-sm);flex-wrap:wrap;display:flex}.region-facts span{border:1px solid var(--border-panel);background:#ffffff0a;border-radius:4px;padding:3px 8px}.region-canvas-wrap{width:min(100%, calc((100dvh - var(--safe-top) - var(--safe-bottom) - 178px) * 1.2667), 1180px);aspect-ratio:760/600;place-self:center;max-width:100%;min-height:0;max-height:100%;position:relative}.region-canvas{border-radius:var(--radius-lg);background:#02040a;width:100%;height:100%;display:block}.region-label{pointer-events:none;white-space:nowrap;font-family:var(--font-sans);color:#fff;text-shadow:0 1px #000000e6,0 -1px #000000e6,1px 0 #000000e6,-1px 0 #000000e6,0 0 6px #000c;font-size:11px;position:absolute;transform:translate(-50%,-50%)}.region-label-starport{color:#ffe680;font-weight:700}.region-label-tier-3{letter-spacing:.4px;font-size:14px;font-weight:700}.region-label-tier-2{font-size:12px;font-weight:600}.region-refining{text-transform:uppercase;letter-spacing:.6px;color:#ffffffb3;pointer-events:none;background:#00000073;border-radius:4px;padding:3px 8px;font-size:10px;animation:1s ease-in-out infinite region-refining-blink;position:absolute;top:14px;left:14px}@keyframes region-refining-blink{50%{opacity:.45}}@media (prefers-reduced-motion:reduce){.region-refining{opacity:.7;animation:none}}@media (width<=720px){.region-backdrop{padding:calc(var(--safe-top) + var(--space-3)) calc(var(--safe-right) + var(--space-3)) calc(var(--safe-bottom) + var(--space-3)) calc(var(--safe-left) + var(--space-3))}.region-modal{gap:var(--space-3);padding:var(--space-4)}.region-header{gap:var(--space-4)}.region-header h2{font-size:var(--type-lg)}.region-subtitle{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.region-canvas-wrap{width:min(100%, calc((100dvh - var(--safe-top) - var(--safe-bottom) - 162px) * 1.2667))}}.region-backdrop.region-backdrop-sheet{padding-top:var(--space-2);background:linear-gradient(#02040800,#020408b8 18%,#020408eb);top:52dvh}.region-backdrop.region-backdrop-sheet .region-modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0;border-bottom:0}.region-backdrop.region-backdrop-sheet .region-canvas-wrap{width:min(100%, calc((48dvh - var(--safe-bottom) - 156px) * 1.2667))}.region-compass{pointer-events:none;opacity:.85;position:absolute;top:18px;right:18px}.region-compass svg circle{fill:#0000008c;stroke:#ffffff8c;stroke-width:1.2px}.region-compass-north{fill:#ffd86a}.region-compass-south{fill:#ffffff73}.region-compass-letter{fill:#fff;font-family:var(--font-sans);font-size:6px;font-weight:700}.region-scale{pointer-events:none;flex-direction:column;align-items:flex-start;gap:3px;display:flex;position:absolute;bottom:18px;left:24px}.region-scale-bar{background:#ffffffd9;border:1px solid #000c;border-radius:1px;width:90px;height:4px}.region-scale span{font-family:var(--font-sans);color:#fff;text-shadow:0 1px #000000e6,0 -1px #000000e6,1px 0 #000000e6,-1px 0 #000000e6;font-size:11px;font-weight:600}.share-trigger{width:32px;font-size:var(--type-base);transition:background var(--motion-fast), color var(--motion-fast);flex:none!important;padding:0!important}.share-trigger.share-status-copied{color:#b4f5c8;background:#6edc962e!important}.share-trigger.share-status-error{color:#ffb4b4;background:#ff6e6e2e!important}.glossary-trigger{width:32px;font-weight:700;font-size:var(--type-base);margin-left:auto;flex:none!important;padding:0!important}.glossary-backdrop{-webkit-backdrop-filter:blur(4px)saturate(120%);padding:var(--space-7);z-index:20;animation:glossary-fade-in var(--motion-fast) var(--motion-ease);background:#020408b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.glossary-modal{background:var(--surface-1-solid);border:1px solid var(--border-panel);border-radius:var(--radius-2xl);width:min(560px,100%);max-height:calc(100vh - 64px);box-shadow:var(--shadow-panel);flex-direction:column;display:flex;overflow:hidden}.glossary-header{padding:var(--space-6) var(--space-7);border-bottom:1px solid var(--border-divider);justify-content:space-between;align-items:center;display:flex}.glossary-header h2{font-family:var(--font-display);font-size:var(--type-xl);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-strong);margin:0;font-weight:700}.glossary-close{border-radius:var(--radius-md);border:1px solid var(--border-panel);background:var(--surface-2);width:30px;height:30px;color:var(--color-text);cursor:pointer;font-size:var(--type-base);transition:background var(--motion-fast);justify-content:center;align-items:center;display:flex}.glossary-close:hover{background:var(--surface-2-hover)}.glossary-body{padding:var(--space-5) var(--space-7) var(--space-7);overflow-y:auto}.glossary-list{gap:var(--space-6);margin:0;display:grid}.glossary-entry{margin:0}.glossary-entry dt{font-size:var(--type-base);color:var(--color-accent);letter-spacing:.4px;margin-bottom:var(--space-2);font-weight:600}.glossary-entry dd{color:var(--color-text);line-height:1.55;font-size:var(--type-body);margin:0}@keyframes glossary-fade-in{0%{opacity:0}to{opacity:1}}.encounter-backdrop{-webkit-backdrop-filter:blur(4px)saturate(120%);padding:var(--space-7);z-index:30;animation:glossary-fade-in var(--motion-fast) var(--motion-ease);background:#020408b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.encounter-modal{background:var(--surface-1-solid);border:1px solid var(--border-panel);border-radius:var(--radius-2xl);width:min(560px,100%);max-height:calc(100vh - 64px);box-shadow:var(--shadow-panel);flex-direction:column;display:flex;overflow:hidden}.encounter-header{justify-content:space-between;align-items:flex-start;gap:var(--space-5);padding:var(--space-6) var(--space-7);border-bottom:1px solid var(--border-divider);display:flex}.encounter-heading{min-width:0}.encounter-heading h2{font-family:var(--font-display);font-size:var(--type-lg);letter-spacing:.04em;color:var(--color-text-strong);margin:0;font-weight:700}.encounter-subtitle{color:var(--text-dim);font-size:var(--type-sm);margin:4px 0 0}.encounter-close{border-radius:var(--radius-md);border:1px solid var(--border-panel);background:var(--surface-2);width:30px;height:30px;color:var(--color-text);cursor:pointer;font-size:var(--type-base);transition:background var(--motion-fast);flex:none;justify-content:center;align-items:center;display:flex}.encounter-close:hover{background:var(--surface-2-hover)}.encounter-list{padding:var(--space-5) var(--space-7);gap:var(--space-3);margin:0;list-style:none;display:grid;overflow-y:auto}.encounter-entry{gap:var(--space-4);padding:var(--space-3) var(--space-3) var(--space-3) var(--space-2);border-radius:var(--radius-md);transition:background var(--motion-fast), border-color var(--motion-fast);border:1px solid #0000;grid-template-columns:28px 1fr;align-items:start;display:grid}.encounter-entry.rolled{background:#39ff141f;border-color:#39ff1466;box-shadow:inset 0 0 0 1px #39ff1424}.encounter-pip{border-radius:var(--radius-md);border:1px solid var(--border-control);background:var(--surface-2);width:28px;height:28px;color:var(--text-dim);font-variant-numeric:tabular-nums;justify-content:center;align-items:center;font-weight:700;display:inline-flex}.encounter-entry.rolled .encounter-pip{color:var(--color-text-strong);border-color:#39ff1480}.encounter-text{color:var(--color-text);line-height:1.5;font-size:var(--type-body)}.encounter-footer{justify-content:space-between;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-7) var(--space-6);border-top:1px solid var(--border-divider);display:flex}.encounter-roll-readout{color:var(--text-dim);font-size:var(--type-sm);letter-spacing:.04em}.encounter-actions{gap:var(--space-3);display:inline-flex}.encounter-action{appearance:none;border:1px solid var(--color-accent-border);background:var(--color-accent-soft);height:34px;color:var(--color-text-strong);font:inherit;font-size:var(--type-sm);cursor:pointer;transition:background var(--motion-fast), border-color var(--motion-fast);border-radius:9px;align-items:center;gap:6px;padding:0 14px;display:inline-flex}.encounter-action:hover{background:var(--surface-2-hover)}.encounter-action.ghost{border-color:var(--border-control);color:var(--color-text);background:0 0}.encounter-action.ghost:hover{background:#ffffff0f}.map-gesture-viewport{touch-action:none;flex:auto;justify-content:center;align-items:center;width:100%;height:100%;min-height:0;display:flex;position:relative}.subsector-jump{-webkit-backdrop-filter:blur(8px);z-index:3;background:#0a0e16b3;border-radius:8px;grid-template-columns:repeat(4,1fr);gap:3px;padding:4px;display:grid;position:absolute;top:8px;left:8px}.subsector-jump-btn{appearance:none;color:#ffffffb8;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:5px;min-width:22px;padding:3px 5px;font-size:11px;font-weight:600}.subsector-jump-btn:hover{color:#fff;background:#39ff1447}.subsector-jump-all{grid-column:span 4}.subsector-legend{z-index:3;font-size:11px;position:absolute;bottom:8px;left:8px}.subsector-legend-toggle{appearance:none;color:#ffffffb8;-webkit-backdrop-filter:blur(8px);cursor:pointer;background:#0a0e16b3;border:1px solid #ffffff1f;border-radius:8px;padding:4px 10px}.subsector-legend-body{-webkit-backdrop-filter:blur(8px);color:#ffffffc7;background:#0a0e16d1;border:1px solid #ffffff1f;border-radius:8px;gap:4px;max-width:220px;margin:6px 0 0;padding:8px 10px;list-style:none;display:grid}.subsector-legend-body li{align-items:center;gap:6px;display:flex}.legend-glyph{text-align:center;min-width:16px;font-weight:700;display:inline-block}.legend-port{color:#aae6ff}.legend-gas,.legend-belt{color:#ffffffd9}.subsector-legend .base-naval{color:#fff}.subsector-legend .base-scout{color:#ffd78c}.subsector-legend .base-research{color:#aae6ff}.subsector-legend .base-aid{color:#ffc8e6}.legend-swatch{border:2px solid;border-radius:50%;width:12px;height:12px;display:inline-block}.legend-amber{color:#ffbe5a}.legend-red{color:#ff6e6e}.legend-line{border-top:2px solid;width:16px;height:0;display:inline-block}.legend-trade{color:#78dca0}.legend-comm{color:#96beff}.subsector-overlay{padding:calc(var(--safe-top) + 72px) calc(var(--safe-right) + var(--space-7)) calc(var(--safe-bottom) + var(--space-7)) calc(var(--safe-left) + var(--space-7));z-index:5;touch-action:none;background:#000;justify-content:center;align-items:center;display:flex;position:absolute;inset:0;overflow:hidden}.subsector-overlay.panel-open{padding-right:340px}.subsector-overlay.overlay-hidden{display:none}.subsector-map{width:100%;height:100%;color:var(--color-text)}.subsector-map svg{cursor:grab;width:100%;height:100%;display:block}.subsector-map svg:active{cursor:grabbing}.hex-cell .hex-shape{stroke:#ffffff38;stroke-width:.8px;fill:#0000;transition:stroke var(--motion-fast);pointer-events:none}.hex-hit-area{fill:#ffffff05;stroke:none;pointer-events:all}.hex-cell.hex-occupied .hex-label,.hex-cell.hex-occupied .hex-starport,.hex-cell.hex-occupied .hex-name,.hex-cell.hex-occupied .hex-base,.hex-cell.hex-occupied .hex-system-dot,.hex-cell.hex-occupied .hex-gas-giant,.hex-cell.hex-occupied .hex-belt-glyph,.hex-cell.hex-occupied .hex-zone-ring,.hex-cell.hex-empty .hex-label,.hex-cell.hex-empty .hex-shape{pointer-events:none}.hex-cell.hex-empty{cursor:pointer}.hex-cell.hex-empty:hover .hex-shape{stroke:#ffffff8c}.hex-cell.hex-empty.hex-selected .hex-shape{stroke:var(--color-accent);stroke-width:1.8px}.jump-routes{pointer-events:none}.hex-polity-fill{opacity:.22;pointer-events:none}.polity-fill-0{fill:#60a5fa61}.polity-fill-1{fill:#2dd4bf57}.polity-fill-2{fill:#e2e8f029}.polity-fill-3{fill:#f472b64d}.polity-fill-4{fill:#a78bfa4d}.polity-fill-5{fill:#fb923c4d}.polity-borders{pointer-events:none}.polity-border-halo,.polity-border-line{fill:none;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}.polity-border-halo{stroke:#000000d1;stroke-width:4px}.polity-border-line{stroke:#eef4ff9e;stroke-width:1.35px}.polity-capitals{pointer-events:none}.polity-capital path{stroke:#000000d9;stroke-width:2.4px;vector-effect:non-scaling-stroke}.polity-capital text{fill:var(--color-text-strong);font:700 7px/1 var(--font-mono);paint-order:stroke;stroke:#000000d1;stroke-width:2.2px}.polity-capital-0 path{fill:#60a5faeb}.polity-capital-1 path{fill:#2dd4bfe6}.polity-capital-2 path{fill:#e2e8f0c2}.polity-capital-3 path{fill:#f472b6db}.polity-capital-4 path{fill:#a78bfadb}.polity-capital-5 path{fill:#fb923cdb}.subsector-seam{stroke:#9bcaff52;stroke-width:1px;stroke-dasharray:8 8}.subsector-letter{fill:#9bcaff4d;letter-spacing:.5px;dominant-baseline:hanging;pointer-events:none;font-size:20px;font-weight:700}.hex-cell.hex-occupied{cursor:pointer}.hex-cell.hex-occupied:hover .hex-shape{stroke:#ffffff8c}.hex-cell.hex-occupied:focus-visible .hex-shape{stroke:var(--color-accent);stroke-width:1.6px;outline:none}.hex-cell.hex-selected .hex-shape{stroke:var(--color-accent);stroke-width:1.8px}.hex-zone-ring{fill:none;pointer-events:none}.zone-ring-amber{stroke:#ffc43cf2;stroke-width:1.6px}.zone-ring-red{stroke:#e63838f2;stroke-width:1.8px}.jump-route{fill:none;stroke-linecap:round}.jump-route-1{stroke:#4ec866d9;stroke-width:1.6px}.jump-route-2{stroke:#ffc86e8c;stroke-width:1.1px;stroke-dasharray:3 3}.jump-route-local{stroke:#8296aa52}.jump-route-comm{stroke:#4ec866b8}.jump-route-trade{stroke:#f8bf56e0;stroke-width:2px}.toggle-label{align-items:center;gap:var(--space-3);cursor:pointer;user-select:none;display:inline-flex}.toggle-label input[type=checkbox]{accent-color:var(--color-accent)}.hex-system-dot{fill:var(--color-text-strong)}.hex-cell.port-a .hex-system-dot{fill:#fff}.hex-cell.port-b .hex-system-dot{fill:#ebf5ff}.hex-cell.port-c .hex-system-dot{fill:#c8dcffe6}.hex-cell.port-d .hex-system-dot{fill:#b4c3d7d9}.hex-cell.port-e .hex-system-dot{fill:#aab4c3b3}.hex-cell.port-x .hex-system-dot{fill:#0000;stroke:#c85050e6;stroke-width:1px}.hex-label{font-family:var(--font-sans);fill:#ffffff6b;pointer-events:none;letter-spacing:.4px;font-size:7px}.hex-starport{font-family:var(--font-sans);fill:#fff;pointer-events:none;font-size:11px;font-weight:700}.hex-starport-warn{fill:#ff6e6e}.hex-name{font-family:var(--font-sans);letter-spacing:.2px;fill:#fff;pointer-events:none;font-size:8px;font-weight:500}.hex-cell.hex-hipop .hex-name{letter-spacing:.6px;font-size:8.5px;font-weight:700}.hex-name-warn{fill:#ff6e6e}.hex-gas-giant{fill:#0000;stroke:#ffffffd9;stroke-width:.9px}.hex-belt-glyph circle{fill:#ffffffa6}.hex-base{pointer-events:none;font-size:9px;font-weight:700}.base-naval{fill:#fff}.base-scout{fill:#ffd78c}.base-research{fill:#aae6ff}.base-aid{fill:#ffc8e6}.surface-map{width:min(100%, calc((100dvh - var(--safe-top) - var(--safe-bottom) - 140px) * 2.117));max-width:1120px;color:var(--color-text);position:relative}.surface-map svg{width:100%;max-height:calc(100dvh - var(--safe-top) - var(--safe-bottom) - 140px);filter:drop-shadow(0 24px 50px #0000008c);cursor:grab;height:auto;display:block}.surface-map svg:active{cursor:grabbing}.surface-empty{color:var(--text-dim);font-size:var(--type-body);text-align:center;padding:var(--space-7)}.surface-bg-image{opacity:1;pointer-events:none}.surface-guide-lines{pointer-events:none}.surface-guide-lines rect{fill:none;stroke:#ebf2fa4d;stroke-width:.9px;vector-effect:non-scaling-stroke}.surface-guide-lines line{stroke:#ebf2fa38;stroke-width:.55px;vector-effect:non-scaling-stroke}.surface-guide-lines .surface-equator-guide{stroke:#ebf2fa6b;stroke-width:.85px;stroke-dasharray:6 6}.surface-hex{cursor:pointer}.surface-hit-area{fill:#ffffff05;stroke:none;pointer-events:all}.surface-hex .surface-hex-shape,.surface-hex .surface-marker,.surface-starport-group{pointer-events:none}.surface-hex-shape{fill:none;shape-rendering:geometricprecision;stroke:#ebf8ff47;stroke-linejoin:round;stroke-width:.55px;transition:stroke var(--motion-fast), filter var(--motion-fast);vector-effect:non-scaling-stroke}.surface-shoreline .surface-hex-shape{stroke:#f0ebbe61}.surface-hex:hover .surface-hex-shape{stroke:#ffffffc7}.surface-selected .surface-hex-shape{fill:#78c8ff24;stroke:var(--color-accent);stroke-width:1.35px}.surface-fold-lines polygon{fill:none;stroke:#ffffff57;stroke-width:1.05px;stroke-linejoin:round;pointer-events:none;vector-effect:non-scaling-stroke}.surface-starport-group{pointer-events:none}.surface-starport-halo{fill:#000000bf;stroke:#ffe080cc;stroke-width:.75px}.surface-hex:hover .surface-hex-shape{filter:brightness(1.18);stroke:#ffffff8c}.surface-hex:focus-visible .surface-hex-shape{stroke:var(--color-accent);stroke-width:1.4px;outline:none}.surface-selected .surface-hex-shape{stroke:var(--color-accent);stroke-width:1.25px}.surface-marker{fill:#ffd86a;stroke:#000c;stroke-width:.7px;paint-order:stroke fill;pointer-events:none;font-size:12px}.surface-starport{fill:#ffe680;stroke:#000000f2;stroke-width:1.4px;paint-order:stroke fill;font-weight:700}.surface-city{fill:#fffffff2;stroke:#000c;stroke-width:.8px;pointer-events:none}.surface-city-3{fill:#ffe9a0}.surface-city-2{fill:#fffffff2}.surface-city-1{fill:#dcdce6e0}.surface-city-0{fill:#b4b4c8b3}.surface-label{font-family:var(--font-sans);letter-spacing:.3px;fill:#fff;stroke:#000000e6;stroke-width:2.8px;paint-order:stroke fill;pointer-events:none;font-size:8.5px;font-weight:600}.surface-label-tier-3{font-size:10px;font-weight:700}.surface-label-tier-2{font-size:8.5px}.sys-empty{color:var(--text-dim);font-style:italic}.hex-detail-uwp{font-family:var(--font-mono);font-size:var(--type-base);color:var(--color-text-strong);letter-spacing:.6px}.zone-tag{padding:1px var(--space-3);border-radius:var(--radius-sm);font-size:var(--type-xs);letter-spacing:.6px;text-transform:uppercase;font-weight:600;display:inline-block}.zone-tag-green{color:#b4f5c8;background:#6edc962e}.zone-tag-amber{color:#ffdca0;background:#ffc86e38}.zone-tag-red{color:#ffb4b4;background:#ff6e6e38}.export-row{gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.export-btn{border-radius:var(--radius-md);border:1px solid var(--border-control);background:var(--surface-2);color:var(--color-text);font:500 var(--type-body) inherit;cursor:pointer;transition:background var(--motion-fast), border-color var(--motion-fast);flex:1 1 0;padding:8px 0}.export-btn:hover{background:var(--color-accent-soft);border-color:var(--color-accent-border)}.export-btn:disabled{opacity:.45;cursor:default}.export-status{min-height:1.2em;color:var(--text-dim);font-size:var(--type-sm);letter-spacing:.2px;margin:0}.export-status-ok{color:#b4f5c8}.export-status-error{color:#ffb4b4}.export-status-busy{color:var(--color-accent)}.hover-tooltip{pointer-events:none;z-index:9;border-radius:var(--radius-md);border:1px solid var(--color-accent-border);-webkit-backdrop-filter:var(--backdrop-blur);color:var(--color-text-strong);font-size:var(--type-body);letter-spacing:.2px;background:#080c16eb;max-width:240px;padding:8px 12px 10px;position:fixed;box-shadow:0 4px 16px #00000080}.hover-tooltip-head{align-items:center;gap:var(--space-3);margin-bottom:4px;display:flex}.hover-tooltip-head .icon{color:var(--color-accent)}.hover-tooltip-idx{color:var(--text-dim);font-family:var(--font-mono);font-size:var(--type-sm);margin-left:auto}.hover-tooltip-class{color:var(--text-dim);font-size:var(--type-sm);letter-spacing:.3px;margin-bottom:4px}.hover-tooltip-meta{color:var(--text-dim);font-size:var(--type-sm);font-variant-numeric:tabular-nums;gap:6px;display:flex}.hover-tooltip-meta-sub{font-size:var(--type-xs);opacity:.85;margin-top:2px}.hover-tooltip-tag{font-size:var(--type-xs);color:#b4f5c8;letter-spacing:.4px;margin-top:4px}.system-object-list{top:calc(var(--safe-top) + 72px);left:calc(var(--safe-left) + 16px);width:min(236px, calc(100vw - var(--safe-left) - var(--safe-right) - 32px));max-height:calc(100dvh - var(--safe-top) - var(--safe-bottom) - 96px);border:1px solid var(--border-panel);border-radius:var(--radius-lg);box-shadow:var(--shadow-panel);z-index:7;pointer-events:auto;background:#070a10e6;grid-template-rows:auto minmax(0,1fr);gap:7px;padding:8px;display:grid;position:absolute}.system-object-header{align-items:center;gap:8px;display:flex}.system-object-header h2{min-width:0;font-family:var(--font-display);color:var(--color-text-strong);font-size:var(--type-base);letter-spacing:.08em;text-transform:uppercase;flex:auto;margin:0;font-weight:700}.system-object-minimize{appearance:none;border:1px solid var(--border-panel);border-radius:var(--radius-md);background:var(--surface-2);width:28px;height:28px;color:var(--color-text);font:inherit;cursor:pointer;flex:none;font-size:16px;line-height:1}.system-object-minimize:hover{background:var(--surface-2-hover);color:var(--color-text-strong)}.system-object-options{scrollbar-width:thin;gap:2px;min-height:0;padding-right:2px;display:grid;overflow-y:auto}.system-object-row{border-radius:var(--radius-md);width:100%;color:var(--color-text);cursor:pointer;background:0 0;border:1px solid #0000;align-items:center;gap:6px;padding:6px 6px 6px 8px;display:flex}.system-object-row:focus-visible{border-color:#39ff1480;outline:none}.system-object-text{flex:auto;gap:2px;min-width:0;display:grid}.system-object-view-btn{appearance:none;border-radius:var(--radius-sm);width:26px;height:26px;color:var(--text-dim);cursor:pointer;transition:color var(--motion-fast), background var(--motion-fast), border-color var(--motion-fast);background:0 0;border:1px solid #0000;flex:none;justify-content:center;align-items:center;padding:0;display:inline-flex}.system-object-view-btn:hover{color:var(--color-accent);background:var(--surface-2);border-color:var(--border-panel)}.system-object-view-btn:focus-visible{color:var(--color-accent);border-color:#39ff1480;outline:none}.system-object-row:hover{background:#ffffff0d}.system-object-row.active{color:var(--color-text-strong);background:#39ff1429;border-color:#39ff1473;box-shadow:inset 0 0 0 1px #39ff1429}.system-object-label{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-weight:600;overflow:hidden}.system-object-meta{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--text-dim);font-size:var(--type-xs);overflow:hidden}.system-object-chevron{width:10px;color:var(--text-dim);text-align:center;flex:none;font-size:10px;line-height:1}.system-object-chevron-empty{visibility:hidden}.system-object-row.open:not(.active){background:#39ff1414}.system-object-detail{border-radius:var(--radius-md);background:#39ff140d;border:1px solid #39ff1438;margin:1px 0 3px;padding:8px 8px 8px 10px}.system-object-detail .sys-inspector{background:0 0;border-left:none;margin:0;padding:0}.system-object-detail .sys-inspector-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:7px 10px}.system-object-reroll{appearance:none;border:1px solid var(--border-control);border-radius:var(--radius-md);background:var(--surface-2);width:100%;color:var(--color-text);font:inherit;font-size:var(--type-xs);cursor:pointer;transition:background var(--motion-fast), color var(--motion-fast), border-color var(--motion-fast);justify-content:center;align-items:center;gap:6px;margin-top:8px;padding:6px 10px;display:inline-flex}.system-object-reroll:hover{background:var(--surface-2-hover);color:var(--color-text-strong);border-color:var(--color-accent-border)}.system-object-reroll:focus-visible{border-color:#39ff1480;outline:none}.system-object-list-minimized{width:min(160px, calc(100vw - var(--safe-left) - var(--safe-right) - 32px));padding:6px;display:block}.system-object-expand{appearance:none;border-radius:var(--radius-md);width:100%;color:var(--color-text);text-align:left;font:inherit;cursor:pointer;background:#39ff141f;border:1px solid #39ff1447;gap:2px;padding:7px 9px;display:grid}.system-object-expand:hover{color:var(--color-text-strong);background:#39ff142e}.system-object-expand-title{color:var(--color-text-strong);font-size:var(--type-sm);font-weight:700}.system-object-expand-meta{text-overflow:ellipsis;white-space:nowrap;color:var(--text-dim);font-size:var(--type-xs);overflow:hidden}.chart-shell-top{top:calc(var(--safe-top) + 12px);left:calc(var(--safe-left) + 12px);right:calc(var(--safe-right) + 60px);z-index:10;pointer-events:none;align-items:center;gap:8px;display:flex;position:fixed}.chart-shell-top>*{pointer-events:auto}.chart-shell-top-start{flex:auto;align-items:center;gap:8px;min-width:0;display:inline-flex}.chart-shell-top-end{flex:none;align-items:center;display:inline-flex}.brand-lockup{appearance:none;border:1px solid var(--border-strong);border-radius:var(--radius-xl);background:var(--surface-1-solid);min-width:0;height:36px;color:var(--c-accent);box-shadow:var(--shadow-button);-webkit-backdrop-filter:var(--backdrop-blur);cursor:pointer;transition:background var(--motion-fast), border-color var(--motion-fast), transform var(--motion-fast);flex:none;align-items:center;gap:7px;padding:0 10px 0 8px;display:inline-flex}.brand-lockup:hover{border-color:var(--border-strong);background:var(--surface-2-hover)}.brand-lockup:active{transform:scale(.97)}.brand-lockup img{filter:drop-shadow(0 0 10px #39ff1447);width:clamp(102px,9vw,122px);height:auto;display:block}.brand-lockup span{color:var(--c-accent);font:800 10px/1 var(--font-mono);letter-spacing:.14em}.breadcrumb{border:1px solid var(--border-panel);background:var(--surface-1-solid);min-width:0;height:36px;-webkit-backdrop-filter:var(--backdrop-blur);color:var(--color-text);font-size:var(--type-body);letter-spacing:.2px;box-shadow:var(--shadow-button);border-radius:999px;flex:auto;align-items:center;padding:0 12px;display:flex;position:static;overflow:hidden}.breadcrumb.breadcrumb-scrolled{mask-image:linear-gradient(90deg,#0000 0,#000 22px)}.breadcrumb-list{align-items:center;gap:var(--space-3);scrollbar-width:none;min-width:0;margin:0;padding:0;list-style:none;display:flex;overflow-x:auto}.breadcrumb-list::-webkit-scrollbar{display:none}.breadcrumb-item{align-items:center;gap:var(--space-3);flex:none;display:inline-flex}.breadcrumb-sep{color:var(--text-dim);flex:none}.breadcrumb-crumb{appearance:none;color:var(--text-dim);font:inherit;cursor:pointer;border-radius:var(--radius-sm);white-space:nowrap;transition:color var(--motion-fast), background var(--motion-fast);background:0 0;border:none;padding:3px 5px}.breadcrumb-crumb:hover{color:var(--color-text-strong);background:var(--surface-2)}.breadcrumb-crumb.active{color:var(--color-text-strong)}.breadcrumb-crumb.muted{color:var(--color-text-muted)}.breadcrumb-crumb.muted:hover{color:var(--text-dim)}@media (width<=1080px){.brand-lockup{justify-content:center;width:36px;padding:0}.brand-lockup img{object-fit:cover;object-position:left center;width:22px;height:22px}.brand-lockup span{display:none}}@media (width<=900px){.system-object-list{top:calc(var(--safe-top) + 112px);max-height:calc(100dvh - var(--safe-top) - var(--safe-bottom) - 136px)}.subsector-overlay,.subsector-overlay.panel-open{padding-top:calc(var(--safe-top) + 100px)}.chart-shell-top{flex-wrap:wrap;align-items:flex-start;gap:8px}.chart-shell-top-end{flex:100%;order:1}.view-mode-toggle{width:100%}.view-mode-segment{flex:1 1 0}.chart-shell-top-start{flex:1 1 0;order:2;min-width:0}.chart-shell-actions{flex:none;order:3}}@media (width<=640px){.system-object-list{left:calc(var(--safe-left) + 8px);right:calc(var(--safe-right) + 8px);width:auto}.system-object-list-minimized{width:min(160px, calc(100vw - var(--safe-left) - var(--safe-right) - 16px));right:auto}.chart-shell-top{left:calc(var(--safe-left) + 8px);right:calc(var(--safe-right) + 54px)}}.panel-note{margin:0 0 var(--space-4);border-radius:var(--radius-md);background:var(--surface-2);color:var(--text-dim);font-size:var(--type-sm);padding:8px 10px;line-height:1.4}.view-mode-toggle{-webkit-backdrop-filter:blur(14px)saturate(140%);height:36px;box-shadow:var(--shadow-button);background:#0a0e16c7;border:1px solid #ffffff2e;border-radius:9px;flex:none;display:inline-flex;position:static;overflow:hidden}.view-mode-segment{appearance:none;color:var(--color-text);font-size:var(--type-body);white-space:nowrap;cursor:pointer;transition:background var(--motion-fast), color var(--motion-fast);background:0 0;border:none;border-right:1px solid #ffffff14;padding:0 13px;font-family:inherit}.view-mode-segment:last-child{border-right:none}.view-mode-segment:hover{background:#ffffff0f}.view-mode-segment.active{background:var(--color-accent-soft);color:var(--color-text-strong)}.view-mode-segment:disabled{color:var(--text-dim);cursor:not-allowed;opacity:.55}.view-mode-segment.active:disabled{color:var(--color-text-strong);opacity:1}@media (width<=640px){.subsector-overlay{padding:calc(var(--safe-top) + 112px) calc(var(--safe-right) + var(--space-6)) calc(var(--safe-bottom) + var(--space-6)) calc(var(--safe-left) + var(--space-6));align-items:flex-start}.subsector-overlay.panel-open{padding-right:calc(var(--safe-right) + var(--space-6))}.surface-map{width:100%}.surface-map svg{max-height:calc(100dvh - var(--safe-top) - var(--safe-bottom) - 220px)}}.surface-hex-magnifier{display:none}@media (pointer:coarse){.surface-hex-magnifier{align-items:center;gap:var(--space-5);margin-top:var(--space-5);padding:var(--space-4) var(--space-5);border-radius:var(--radius-md);border:1px solid var(--panel-border);background:#080c14eb;display:flex;box-shadow:0 12px 32px #00000073}.surface-hex-magnifier svg{filter:drop-shadow(0 4px 12px #00000080);flex:none}.surface-hex-magnifier-meta{font-size:var(--type-sm);color:var(--text-dim);flex-direction:column;gap:4px;display:flex}.surface-hex-magnifier-meta strong{font-size:var(--type-body);color:var(--color-text-strong)}}.view-transition{opacity:0;pointer-events:none;z-index:6;background:#02040a;position:absolute;inset:0}.view-transition-active{animation:.14s ease-out view-transition-wash}@keyframes view-transition-wash{0%{opacity:0}40%{opacity:.4}to{opacity:0}}@media (prefers-reduced-motion:reduce){.view-transition-active{animation:none}}.onboarding-hint{left:50%;bottom:calc(var(--safe-bottom) + 68px);gap:var(--space-6);border:1px solid var(--border-panel);background:var(--surface-1-solid);-webkit-backdrop-filter:var(--backdrop-blur);color:var(--color-text);font-size:var(--type-body);letter-spacing:.3px;box-shadow:var(--shadow-button);z-index:7;pointer-events:none;animation:onboarding-hint-in var(--motion-medium) var(--motion-ease);border-radius:999px;padding:10px 16px;display:flex;position:fixed;transform:translate(-50%)}.onboarding-hint-row{align-items:center;gap:var(--space-3);color:var(--text-dim);white-space:nowrap;display:inline-flex}.onboarding-hint kbd,.glossary-body kbd{border-radius:var(--radius-sm);border:1px solid var(--border-strong);min-width:22px;color:var(--color-text-strong);font-family:var(--font-mono);font-size:var(--type-sm);background:#ffffff14;justify-content:center;align-items:center;padding:2px 6px;line-height:1;display:inline-flex}@keyframes onboarding-hint-in{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}@media (width<=640px){.onboarding-hint{gap:var(--space-5);font-size:var(--type-sm);padding:8px 12px}}.loading-overlay{justify-content:center;align-items:center;gap:var(--space-7);z-index:9;pointer-events:none;background:radial-gradient(#080c168c,#020408eb);flex-direction:column;display:flex;position:absolute;inset:0}.loading-orbit{width:96px;height:96px;position:relative}.loading-star{background:radial-gradient(circle,#ffe9a8 0%,#f5b850 60%,#0000 75%);border-radius:50%;width:14px;height:14px;margin:-7px 0 0 -7px;position:absolute;top:50%;left:50%;box-shadow:0 0 18px 4px #ffc86e73}.loading-planet{border:1px solid #39ff142e;border-radius:50%;width:96px;height:96px;margin:-48px 0 0 -48px;animation:2.4s linear infinite loading-orbit-spin;position:absolute;top:50%;left:50%}.loading-planet:after{content:"";background:var(--color-accent);border-radius:50%;width:8px;height:8px;margin-left:-4px;position:absolute;top:-4px;left:50%;box-shadow:0 0 10px 2px #39ff1473}@keyframes loading-orbit-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-label{color:var(--text-dim);font-size:var(--type-base);letter-spacing:.4px;margin:0}@media (prefers-reduced-motion:reduce){.loading-planet{animation:none}}@media (width<=640px){.panel{width:calc(100% - 16px);right:calc(var(--safe-right) + 8px);top:calc(var(--safe-top) + 104px);max-height:calc(100dvh - var(--safe-top) - var(--safe-bottom) - 120px);border-radius:12px}.panel-closed{transform:translateY(calc(-100% - 80px))}.panel-toggle{top:calc(var(--safe-top) + 10px);right:calc(var(--safe-right) + 8px);width:38px;height:38px}.view-toggle{top:calc(var(--safe-top) + 10px);right:calc(var(--safe-right) + 60px);height:44px;font-size:var(--type-body);padding:0 12px}.glossary-modal{width:100%;max-height:calc(100dvh - var(--safe-top) - var(--safe-bottom) - 32px);border-radius:var(--radius-xl)}.glossary-close{width:44px;height:44px}.encounter-modal{width:100%;max-height:calc(100dvh - var(--safe-top) - var(--safe-bottom) - 32px);border-radius:var(--radius-xl)}.encounter-close{width:44px;height:44px}.encounter-footer{flex-wrap:wrap}.encounter-actions{flex:100%;justify-content:flex-end}.encounter-action,.panel-actions button{min-height:44px}.panel-actions .share-trigger,.panel-actions .glossary-trigger{min-width:44px}.export-btn,.quality-segment,.sys-actions button{min-height:44px}.sys-export-row button{min-height:44px;padding:8px 12px}.time-scrubber-btn{min-width:44px;min-height:44px;padding:6px 10px}.glossary-backdrop{padding:var(--space-4)}.starport-row{grid-template-columns:repeat(6,1fr);gap:6px}.starport-btn{min-height:44px;padding-top:8px;padding-bottom:6px}}@media (pointer:coarse){input[type=range]{height:36px}input[type=range]::-webkit-slider-thumb{width:22px;height:22px;margin-top:-9.5px}input[type=range]::-moz-range-thumb{width:22px;height:22px}.starport-btn{min-height:44px}.panel-actions button,.quality-btn,button.link{min-height:36px}}
