.map-page{min-height:100vh;color:var(--spgx-text-muted);font-family:var(--spgx-font-mono);background-color:#02080a;padding:1rem}.map-page .terminal-frame{max-width:100%}.map-layout{grid-template-columns:1fr 380px;gap:1.5rem;min-height:75vh;margin-top:1rem;display:grid}@media (max-width:1024px){.map-layout{grid-template-columns:1fr}}.map-visual-container{background:#0006;border:1px solid #00e5ff26;flex-direction:column;padding:1.5rem;display:flex;position:relative;overflow:hidden}.map-header{border-bottom:1px solid #00e5ff1a;margin-bottom:1rem;padding-bottom:.75rem}.map-page-title{color:var(--spgx-accent-primary);letter-spacing:.1em;margin:.5rem 0 .2rem;font-size:1.3rem}.map-page-subtitle{opacity:.7;letter-spacing:.08em;margin:0;font-size:.75rem}.map-controls{z-index:5;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.map-btn{color:var(--spgx-accent-primary);font-family:var(--spgx-font-mono);cursor:pointer;letter-spacing:.05em;background:#0009;border:1px solid #00e5ff4d;padding:.4rem .8rem;font-size:.75rem;transition:all .2s}.map-btn:hover{border-color:var(--spgx-accent-primary);background:#00e5ff1a;box-shadow:0 0 8px #00e5ff33}.map-btn.active{background:var(--spgx-accent-primary-dim);border-color:var(--spgx-accent-primary);color:#000;font-weight:700}.map-btn.btn-warning{color:var(--spgx-accent-warning);border-color:#ffcc004d}.map-btn.btn-warning:hover{border-color:var(--spgx-accent-warning);background:#ffcc001a}.map-btn.btn-warning.active{background:var(--spgx-accent-warning);border-color:var(--spgx-accent-warning);color:#000;box-shadow:0 0 10px #fc06}.speed-control{background:#0000004d;border:1px solid #00e5ff26;align-items:center;gap:.3rem;padding:.2rem .5rem;font-size:.75rem;display:flex}.control-label{opacity:.7;margin-right:.3rem}.speed-btn{color:var(--spgx-text-muted);font-family:var(--spgx-font-mono);cursor:pointer;background:0 0;border:1px solid #0000;padding:.15rem .4rem;font-size:.7rem;transition:all .2s}.speed-btn:hover{color:var(--spgx-accent-primary)}.speed-btn.active{border-color:var(--spgx-accent-primary);color:var(--spgx-accent-primary);background:#00e5ff14}.map-svg-wrapper{background:radial-gradient(circle,#020f1466 0%,#000000b3 100%);border:1px solid #00e5ff14;flex-grow:1;justify-content:center;align-items:center;min-height:550px;max-height:850px;display:flex;position:relative}.tactical-svg{width:100%;max-width:100%;height:100%;max-height:850px}.radial-grid-line{stroke:#00e5ff0d;stroke-width:1px}.orbit-ring{fill:none;stroke:#00e5ff0f;stroke-width:1px;stroke-dasharray:4 8}.orbit-ring--grinder{stroke:#ff880014;stroke-width:8px;stroke-dasharray:2 4}.grinder-particle{fill:#ff880059;animation:4s ease-in-out infinite alternate orbit-sparkle}.silver-fringe-border{fill:none;stroke:#00e5ff1f;stroke-width:1.5px;stroke-dasharray:12 12}.silver-fringe-text{font-family:var(--spgx-font-mono);letter-spacing:.15em;fill:#00e5ff59;font-size:8px;font-weight:700}.eef-hazard-cloud{fill:#ffcc000a;stroke:#ffcc001f;stroke-width:1.5px;stroke-dasharray:3 6;filter:drop-shadow(0 0 6px #ffcc0026);animation:8s ease-in-out infinite alternate float-drift}.eef-hazard-polygon{fill:#ffcc0008;stroke:#ffcc001a;stroke-width:1px;stroke-dasharray:4 4;animation:10s ease-in-out infinite alternate float-drift-reverse}.travel-lane-line{stroke:var(--spgx-accent-primary);stroke-width:1.5px;stroke-dasharray:5 5;animation:20s linear infinite dash-flow}.travel-lane-glow{stroke:var(--spgx-accent-primary);stroke-width:4px;opacity:.25;filter:blur(2px)}.node-group{cursor:pointer;pointer-events:all}.node-core{filter:drop-shadow(0 0 4px #ffffff1a);transition:r .2s,filter .2s}.node-group:hover .node-core{filter:drop-shadow(0 0 8px)brightness(1.2);transform:scale(1.15)}.node-group:hover .node-label{fill:var(--spgx-accent-primary)!important}.node-label{font-family:var(--spgx-font-mono);letter-spacing:.08em;fill:#ffffffd9;pointer-events:none;filter:drop-shadow(0 0 2px #000000f2)drop-shadow(0 0 1px #000000f2);font-size:11px;font-weight:700;transition:fill .2s}.selection-ring{fill:none;stroke:var(--spgx-accent-primary);stroke-width:1px;stroke-dasharray:2 4;animation:8s linear infinite rotate-selector}.node-group.origin .selection-ring{stroke:var(--spgx-accent-primary);stroke-width:1.5px}.node-group.destination .selection-ring{stroke:var(--spgx-accent-warning);stroke-width:1.5px}.moon-orbit-line{fill:none;stroke:#ffffff08;stroke-width:.75px;stroke-dasharray:2 4}.moon-group{cursor:pointer}.moon-group:hover .moon-core{filter:drop-shadow(0 0 4px #fff)}.moon-label{font-family:var(--spgx-font-mono);fill:#fff6;font-size:7px}.map-sidebar{border-left:1px solid #00e5ff1a;flex-direction:column;gap:1.2rem;max-height:80vh;padding-left:1.2rem;display:flex;overflow-y:auto}.sidebar-title{color:var(--spgx-accent-primary);letter-spacing:.12em;border-bottom:2px solid #00e5ff33;margin:0;padding-bottom:.5rem;font-size:.95rem}.sidebar-block{background:#00e5ff05;border:1px solid #00e5ff14;padding:1rem}.block-title{color:var(--spgx-accent-primary);letter-spacing:.05em;border-bottom:1px solid #00e5ff14;margin:0 0 .8rem;padding-bottom:.3rem;font-size:.8rem}.selector-grid{grid-template-columns:1fr 1fr;gap:.8rem;margin-bottom:.8rem;display:grid}.selector-label{opacity:.6;margin-bottom:.3rem;font-size:.65rem;display:block}.map-select{width:100%;color:var(--spgx-accent-primary);font-family:var(--spgx-font-mono);background:#000;border:1px solid #00e5ff40;padding:.3rem;font-size:.7rem}.map-select:focus{border-color:var(--spgx-accent-primary);outline:none}.calculator-info{opacity:.6;margin:0;font-size:.7rem;line-height:1.4}.calculation-results{background:#0006;border:1px solid #00e5ff14;flex-direction:column;gap:.4rem;padding:.6rem;display:flex}.res-row{justify-content:space-between;font-size:.68rem;display:flex}.res-val{font-weight:700}.total-row{border-top:1px solid #00e5ff26;padding-top:.4rem;font-size:.72rem}.highlighted-text{color:var(--spgx-accent-warning);font-weight:700}.sidebar-placeholder{opacity:.5;text-align:center;margin:0;padding:1.5rem 0;font-size:.75rem;line-height:1.5}.details-content{flex-direction:column;gap:.75rem;display:flex}.details-header{border-bottom:1px solid #00e5ff1a;padding-bottom:.4rem}.details-type{color:var(--spgx-accent-primary);background:#00e5ff14;border:1px solid #00e5ff26;margin-bottom:.3rem;padding:.1rem .3rem;font-size:.6rem;display:inline-block}.details-name{color:#fff;margin:0;font-size:1.05rem}.details-meta{flex-direction:column;gap:.25rem;font-size:.7rem;display:flex}.meta-item{gap:.5rem;display:flex}.meta-lbl{opacity:.6}.meta-val{font-weight:500}.details-desc{color:#fffc;margin:0;font-size:.75rem;line-height:1.55}.details-pois{border-top:1px dashed #00e5ff1a;padding-top:.6rem;font-size:.7rem}.details-pois ul{flex-direction:column;gap:.25rem;margin:.4rem 0 0;padding:0;list-style:none;display:flex}.details-pois li{color:var(--spgx-accent-primary)}.garden-advisory-box{background:#ff444408;border:1px solid #ff44441f;flex-direction:column;gap:.6rem;margin-top:.5rem;padding:.75rem;font-size:.68rem;display:flex}.advisory-title{color:var(--spgx-accent-warning);border-bottom:1px solid #ff444426;margin:0;padding-bottom:.3rem;font-size:.72rem;font-weight:700}.advisory-text{margin:0;line-height:1.45}.advisory-list{flex-direction:column;gap:.3rem;display:flex}.district-item{flex-direction:column;gap:.1rem;margin-left:.4rem;display:flex}.district-name{color:var(--spgx-accent-primary);font-weight:700}.district-desc{color:#ffffffb3;margin-left:.6rem}.takeaway-item{color:var(--spgx-accent-warning);margin-left:.4rem}@keyframes rotate-selector{0%{transform:rotate(360deg)}to{transform:rotate(0)}}@keyframes dash-flow{to{stroke-dashoffset:-40px}}@keyframes orbit-sparkle{0%{opacity:.25}to{opacity:.75}}@keyframes float-drift{0%{transform:translate(0)scale(1)}to{transform:translate(15px,-15px)scale(1.05)}}@keyframes float-drift-reverse{0%{transform:translate(0)rotate(0)}to{transform:translate(-10px,10px)rotate(4deg)}}.sun-pulse{transform-origin:0 0;animation:3s ease-in-out infinite alternate sun-glow-pulse}.sun-pulse-inner{transform-origin:0 0;animation:2s ease-in-out infinite alternate-reverse sun-glow-pulse}.sun-flare-1{transform-origin:0 0;animation:5s ease-in-out infinite alternate flare-drift-1}.sun-flare-2{transform-origin:0 0;animation:6s ease-in-out infinite alternate flare-drift-2}.karpri-swirl-1{transform-origin:0 0;animation:35s linear infinite rotate-cpl}.karpri-swirl-2{transform-origin:0 0;animation:20s linear infinite rotate-cpl-reverse}.toril-shield{transform-origin:0 0;animation:4s ease-in-out infinite alternate shield-pulse}.toril-static-1{animation:.8s steps(2,end) infinite static-flash}.toril-static-2{animation:1.2s steps(2,end) infinite alternate static-flash}.iron-spine-spark{stroke-dashoffset:20px;animation:2.5s linear infinite spark-travel}.iron-spine-tip{animation:1s ease-in-out infinite alternate tip-pulse}.chandos-spin{transform-origin:0 0;animation:80s linear infinite rotate-cpl}@keyframes sun-glow-pulse{0%{opacity:.05;transform:scale(.98)}to{opacity:.15;transform:scale(1.02)}}@keyframes flare-drift-1{0%{opacity:.4;transform:rotate(0)scale(.98)}to{opacity:.6;transform:rotate(-10deg)scale(1.02)}}@keyframes flare-drift-2{0%{opacity:.5;transform:rotate(0)scale(.99)}to{opacity:.7;transform:rotate(15deg)scale(1.03)}}@keyframes rotate-cpl{0%{transform:rotate(360deg)}to{transform:rotate(0)}}@keyframes rotate-cpl-reverse{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shield-pulse{0%{stroke:#fff6;opacity:.7}to{stroke:#44ccfff2;opacity:.9}}@keyframes static-flash{0%,to{opacity:.1}50%{opacity:.85}}@keyframes spark-travel{to{stroke-dashoffset:-20px}}@keyframes tip-pulse{0%{filter:drop-shadow(0 0 2px #f7f);opacity:.7}to{filter:drop-shadow(0 0 8px #f7f);opacity:1}}.zoom-hud-overlay{z-index:10;font-family:var(--spgx-font-mono);pointer-events:auto;background:#000000bf;border:1px solid #00e5ff40;flex-direction:column;gap:.5rem;padding:.6rem .8rem;display:flex;position:absolute;top:1rem;right:1.5rem}.hud-readout{color:var(--spgx-accent-primary);letter-spacing:.05em;font-size:.7rem}.hud-presets{border-top:1px dashed #00e5ff26;gap:.4rem;margin-top:.3rem;padding-top:.4rem;display:flex}.hud-preset-btn{color:var(--spgx-text-muted);font-family:var(--spgx-font-mono);cursor:pointer;background:0 0;border:none;padding:.1rem .3rem;font-size:.65rem;transition:all .2s}.hud-preset-btn:hover{color:var(--spgx-accent-primary);background:#00e5ff14}.label-connector{stroke:#00e5ff2e;stroke-dasharray:2 3;stroke-width:1px;pointer-events:none;transition:stroke .2s,stroke-width .2s}.node-group:hover .label-connector{stroke:var(--spgx-accent-primary);stroke-width:1.5px;opacity:.8}.label-pill-bg{fill:#020a0d;stroke:#00e5ff38;stroke-width:1px;pointer-events:none;transition:all .2s}.node-group:hover .label-pill-bg{stroke:var(--spgx-accent-primary);fill:#00e5ff14;filter:drop-shadow(0 0 4px #00e5ff40)}.node-group.selected .label-pill-bg{stroke:var(--spgx-accent-primary);fill:#00e5ff26}.node-group.origin .label-pill-bg{stroke:var(--spgx-accent-primary)}.node-group.destination .label-pill-bg{stroke:var(--spgx-accent-warning)}.label-pill-bg--moon{fill:#010508;stroke:#ffffff26}.moon-group:hover .label-pill-bg--moon{stroke:#fff;fill:#ffffff0d}.moon-label-relaxed{font-family:var(--spgx-font-mono);fill:#ffffff80;pointer-events:none;font-size:7.5px;font-weight:700;transition:fill .2s}.moon-group:hover .moon-label-relaxed{fill:#fff}.travel-guide-box{border-left:3px solid var(--accent-color,var(--spgx-accent-primary));background:#00000080;margin-bottom:1.2rem;padding:.8rem;box-shadow:inset 0 0 10px #000c}.travel-guide-title{letter-spacing:.08em;text-shadow:0 0 4px #ffffff26;margin-bottom:.5rem;font-size:.78rem;font-weight:700}.travel-guide-text{color:var(--spgx-text);margin-bottom:.5rem;font-size:.72rem;line-height:1.45}.travel-guide-text strong{color:#fffffff2;letter-spacing:.03em}.travel-advisory-box{color:#ffa3a3;background:#ff44440f;border:1px dashed #ff444459;border-radius:2px;margin-top:.6rem;padding:.5rem .6rem;font-size:.7rem;line-height:1.4}.travel-advisory-box strong{color:#f55;text-shadow:0 0 4px #f553}.scdf-dossier-box{background:#00e5ff05;border:1px solid #00e5ff26;margin-top:1rem;padding:.8rem;box-shadow:inset 0 0 8px #00e5ff0d}.scdf-dossier-title{color:var(--spgx-accent-primary);letter-spacing:.08em;text-shadow:0 0 5px #00e5ff4d;border-bottom:1px solid #00e5ff33;margin-bottom:.6rem;padding-bottom:.3rem;font-size:.75rem;font-weight:700}.compact-moons-list{background:#ffffff05;border:1px solid #ffffff14;margin-top:1.2rem;padding:.6rem}.moon-links-container{flex-wrap:wrap;gap:.35rem;margin-top:.4rem;display:flex}.moon-link-btn{color:#fffc;font-family:var(--spgx-font-mono);cursor:pointer;background:#ffffff0a;border:1px solid #ffffff1f;border-radius:1px;padding:.25rem .5rem;font-size:.68rem;transition:all .18s}.moon-link-btn:hover{border-color:var(--spgx-accent-primary);color:var(--spgx-accent-primary);background:#00e5ff1f;box-shadow:0 0 6px #00e5ff33}.grinder-click-ring{pointer-events:visibleStroke}.grinder-click-ring:hover~.orbit-ring--grinder{stroke:#ff880047;stroke-width:13px}.grinder-click-ring:hover~.grinder-particle{fill:#ffaa32d9;filter:drop-shadow(0 0 3px #f809)}.eef-zone{mix-blend-mode:screen;pointer-events:none;filter:drop-shadow(0 0 8px #b733ff4d);animation:4s ease-in-out infinite alternate eef-pulse-animate}.eef-zone--epicenter{animation-duration:2.5s}.eef-zone--epicenter-core{animation-duration:1.8s;animation-delay:.3s}.eef-zone--minor{animation-duration:5s;animation-delay:.5s}.eef-zone--concentrated{animation-duration:3.2s}.eef-zone--trail{animation-duration:4.5s}.eef-zone--weak{opacity:.5;animation-duration:6s}@keyframes eef-pulse-animate{0%{opacity:.35;transform:scale(.97)}50%{opacity:.7;transform:scale(1.02)}to{opacity:.45;transform:scale(.98)}}.toril-eef-permanent-ring{transform-origin:0 0;animation:12s linear infinite toril-eef-spin}.toril-eef-permanent-ring-outer{transform-origin:0 0;animation:18s linear infinite toril-eef-spin-reverse}@keyframes toril-eef-spin{0%{transform:rotate(360deg)}to{transform:rotate(0)}}@keyframes toril-eef-spin-reverse{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
