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