@import "https://fonts.googleapis.com/css2?family=DM+Mono:wght@300;400;500&family=Instrument+Serif:ital@0;1&display=swap";*{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=dark]{--bg:#0a0c10;--surface:#12151c;--border:#1e2330;--text:#c8cdd8;--text-dim:#9098a8;--accent:#e85d3a;--ocean:#111f2e;--land:#334d66;--land-stroke:#3d5a75;--graticule:#263848;--indicatrix-fill:#e85d3a4d;--indicatrix-stroke:#f06a45;--outline:#2a3a4e}[data-theme=light]{--bg:#f0f1f4;--surface:#fff;--border:#d4d8e0;--text:#2c3040;--text-dim:#6b7280;--accent:#d04e2e;--ocean:#d6e6f5;--land:#9ab8a0;--land-stroke:#7a9e82;--graticule:#c0d0dc;--indicatrix-fill:#d04e2e40;--indicatrix-stroke:#d04e2e;--outline:#a0b0c0}body{background:var(--bg);color:var(--text);flex-direction:column;height:100dvh;font-family:DM Mono,monospace;display:flex;overflow:hidden}#root{flex-direction:column;height:100dvh;display:flex}header{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:16px;padding:12px 28px 8px;display:flex}header h1{color:var(--accent);letter-spacing:-.02em;font-family:DM Mono,monospace;font-size:26px;font-weight:400}.header-actions{align-items:center;gap:8px;margin-left:auto;display:flex}header .about-btn{border:1px solid var(--border);background:var(--surface);color:var(--text-dim);cursor:pointer;letter-spacing:.02em;border-radius:4px;padding:4px 12px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Helvetica,Arial,sans-serif;font-size:12px;transition:all .15s}@media (hover:hover){header .about-btn:hover{border-color:var(--accent);color:var(--text)}}header .about-btn:active{border-color:var(--accent);color:var(--text)}header .about-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}header .undo-btn{aspect-ratio:1;justify-content:center;align-items:center;padding:4px;display:inline-flex}header .undo-btn .undo-icon{width:14px;height:14px}header span.sub{color:var(--text-dim);letter-spacing:.02em;font-size:12px}.controls{flex-shrink:0;padding:14px 28px}.controls-desktop{flex-direction:column;gap:8px;display:flex}.projection-group{align-items:baseline;gap:8px;display:flex}.group-label{text-transform:uppercase;letter-spacing:.08em;color:var(--accent);white-space:nowrap;cursor:default;flex-shrink:0;min-width:120px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Helvetica,Arial,sans-serif;font-size:10px;position:relative}.group-tooltip{background:var(--surface);border:1px solid var(--border);text-transform:none;letter-spacing:normal;color:var(--text);white-space:nowrap;z-index:10;pointer-events:none;border-radius:4px;padding:6px 10px;font-size:11px;display:none;position:absolute;top:calc(100% + 6px);left:0}.group-label:hover .group-tooltip,.group-label:focus .group-tooltip{display:block}.group-label:focus{outline:2px solid var(--accent,#4a90d9);outline-offset:2px;border-radius:2px}.group-buttons{flex-wrap:wrap;gap:4px;display:flex}.controls-expanded{gap:12px;display:flex}.controls-groups{flex-direction:column;flex:1;gap:8px;display:flex}.controls-hide-btn{flex-shrink:0;align-self:flex-start}.controls-mobile{display:none}.controls button{border:1px solid var(--border);background:var(--surface);color:var(--text-dim);cursor:pointer;letter-spacing:.02em;border-radius:4px;padding:6px 14px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Helvetica,Arial,sans-serif;font-size:12px;font-weight:400;transition:all .15s}.controls button:hover{border-color:var(--accent);color:var(--text)}.controls button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.controls button.active{color:#fff;background:#d04e2e;border-color:#d04e2e;transition:all .15s}.central-lon{flex-shrink:0;align-items:center;gap:10px;padding:6px 28px 10px;display:flex}.central-lon.disabled{opacity:.35;pointer-events:none}.central-lon-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);white-space:nowrap;flex-shrink:0;min-width:120px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Helvetica,Arial,sans-serif;font-size:10px}.central-lon input[type=range]{appearance:none;background:var(--border);cursor:pointer;border-radius:2px;outline:none;flex:1;max-width:280px;height:4px}.central-lon input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent);cursor:pointer;border:none;border-radius:50%;width:24px;height:24px}.central-lon input[type=range]::-moz-range-thumb{background:var(--accent);cursor:pointer;border:none;border-radius:50%;width:24px;height:24px}.central-lon-value{color:var(--text);text-align:right;min-width:42px;font-family:DM Mono,monospace;font-size:12px}.central-lon-reset{border:1px solid var(--border);background:var(--surface);min-height:24px;color:var(--text-dim);cursor:pointer;border-radius:3px;padding:4px 10px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Helvetica,Arial,sans-serif;font-size:11px;transition:all .15s}@media (hover:hover){.central-lon-reset:hover{border-color:var(--accent);color:var(--text)}}.central-lon-reset:active{border-color:var(--accent);color:var(--text)}.central-lon-reset:focus-visible,.central-lon input[type=range]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.size-toggle-row{flex-shrink:0;align-items:center;gap:8px;padding:4px 28px 8px;display:flex}.size-toggle-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Helvetica,Arial,sans-serif;font-size:10px}.toggle-switch{background:var(--border);cursor:pointer;border:none;border-radius:12px;width:40px;height:24px;padding:0;transition:background .2s;position:relative}.toggle-switch:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.toggle-switch.on{background:var(--accent)}.toggle-knob{background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:3px;left:3px}.toggle-switch.on .toggle-knob{transform:translate(16px)}.map-container{cursor:crosshair;flex:1;min-height:0;position:relative;overflow:hidden}.map-container svg{width:100%;height:100%;overflow:hidden}.info-panel{color:var(--text-dim);pointer-events:none;flex-direction:column;gap:10px;font-size:12px;display:flex;position:absolute;bottom:20px;left:28px}.info-panel .coord{color:var(--text);font-size:15px;font-weight:500}.info-panel .label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;font-size:10px}.info-panel .metric{color:var(--accent);font-size:15px;font-weight:500}.info-panel .group{flex-direction:column;gap:1px;display:flex}.hint{color:var(--text-dim);opacity:.5;pointer-events:none;font-size:12px;transition:opacity .4s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.hint.hidden{opacity:0}.modal-overlay{z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);max-width:540px;max-height:80vh;color:var(--text);border-radius:8px;padding:32px 36px;font-size:13px;line-height:1.65;position:relative;overflow-y:auto}.modal h2{color:var(--text);margin-bottom:16px;font-family:DM Mono,monospace;font-size:22px;font-weight:400}.modal h3{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin:20px 0 8px;font-size:12px}.modal p{margin-bottom:10px}.modal dl{margin:8px 0 12px}.modal dt{color:var(--text);margin-top:10px;font-weight:500}.modal dd{color:var(--text-dim);margin-left:0;font-size:12px}.modal-close{float:right;color:var(--text-dim);cursor:pointer;z-index:1;background:0 0;border:none;justify-content:center;align-items:center;min-width:32px;min-height:32px;font-size:22px;line-height:1;display:flex;position:sticky;top:0}.modal-close:hover{color:var(--text)}.theme-toggle{border:1px solid var(--border);background:var(--surface);width:36px;height:36px;color:var(--text);cursor:pointer;z-index:50;border-radius:50%;justify-content:center;align-items:center;padding:0;line-height:1;transition:border-color .15s;display:flex;position:fixed;bottom:20px;right:20px}@media (hover:hover){.theme-toggle:hover{border-color:var(--accent)}}.theme-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media (height<=500px){body{height:auto;overflow:auto}#root{height:auto;min-height:100dvh}.map-container{min-height:60vw}}@media (width<=900px){header{gap:10px;padding:10px 16px 6px}header h1{font-size:20px}header .about-btn{min-height:36px;padding:8px 12px;font-size:11px}header .undo-btn{min-height:36px;padding:8px}header .undo-btn .undo-icon{width:14px;height:14px}header span.sub{font-size:11px}.central-lon-label{white-space:normal;text-align:right;min-width:70px;max-width:70px;margin-right:12px;line-height:1.3}}@media (width<=640px){header{gap:10px;padding:10px 16px 6px}header h1{font-size:20px}header span.sub{display:none}.controls{z-index:20;padding:14px 16px 0;position:relative}.controls-desktop{display:none}.controls-mobile{display:block}.controls-mobile-bar{align-items:center;gap:6px;display:flex}.controls-toggle{border:1px solid var(--border);background:var(--surface);color:var(--text-dim);cursor:pointer;border-radius:4px;align-items:center;gap:4px;padding:8px 12px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Helvetica,Arial,sans-serif;font-size:11px;display:flex}.toggle-arrow{font-size:9px;transition:transform .2s}.toggle-arrow.open{transform:rotate(180deg)}.controls-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:6px;flex-direction:column;gap:14px;max-height:calc(100dvh - 120px);padding:10px;display:flex;position:absolute;top:calc(100% + 6px);left:16px;right:16px;overflow-y:auto}.controls-dropdown .projection-group{flex-direction:column;align-items:flex-start;gap:4px}.group-tooltip{text-transform:none;letter-spacing:normal;color:var(--text-dim);opacity:.7;pointer-events:none;background:0 0;border:none;margin-left:4px;padding:0;font-size:11px;display:inline;position:static}.group-label:hover .group-tooltip,.group-label:focus .group-tooltip{display:inline}.controls button{min-height:36px;padding:8px 12px;font-size:11px}.size-toggle-row{display:none}.controls-mobile-extra{align-items:center;gap:6px;margin-left:auto;display:flex}.controls-mobile-extra .toggle-switch{border:none;border-radius:12px;width:40px;height:24px;min-height:24px;padding:0}.central-lon{padding:14px 16px 8px}.central-lon-label{white-space:normal;text-align:right;min-width:70px;max-width:70px;margin-right:12px;line-height:1.3}.info-panel{bottom:12px;left:16px}.modal{max-height:85vh;margin:16px;padding:24px}}
