:root{--bg: #0f1117;--bg-panel: #171b24;--bg-raised: #1e2330;--border: #2a3040;--accent: #00d4aa;--accent-dim: #00d4aa22;--danger: #ff4f4f;--text: #d4dce8;--text-dim: #6b7a94;--text-bright: #eef2f8;--font-ui: "Fira Sans Condensed", sans-serif;--font-mono: "JetBrains Mono", monospace;--panel-w: 450px;--radius: 6px;--gap: 10px}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{font-family:var(--font-ui);background:var(--bg);color:var(--text);font-size:15px}.app{display:flex;height:100dvh;width:100vw}.panel{width:var(--panel-w);min-width:var(--panel-w);background:var(--bg-panel);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;overflow-x:hidden;gap:0}.panel::-webkit-scrollbar{width:4px}.panel::-webkit-scrollbar-track{background:transparent}.panel::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.map-container{flex:1;position:relative;overflow:hidden}#mapG{width:100%;height:100%}.map-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-dim);font-family:var(--font-ui);font-size:15px;background:var(--bg);pointer-events:none}.map-empty__icon{font-size:48px;opacity:.2}.panel__header{display:flex;align-items:center;gap:8px;padding:14px 14px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.panel__logo{font-size:22px;color:var(--accent);line-height:1}.panel__title{font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:.15em;color:var(--text-bright);flex:1}.panel__version{font-family:var(--font-mono);font-size:11px;color:var(--text-dim);background:var(--bg-raised);padding:2px 6px;border-radius:3px}.panel__section{padding:var(--gap) 14px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:var(--gap)}.panel__section--row{flex-direction:row;align-items:flex-end;gap:8px}.panel__footer{margin-top:auto;padding:10px 14px;font-size:12px;color:var(--text-dim);border-top:1px solid var(--border);font-family:var(--font-mono)}.drop-zone{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px;border:1.5px dashed var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .2s,background .2s;text-align:center}.drop-zone:hover,.drop-zone--active{border-color:var(--accent);background:var(--accent-dim)}.drop-zone__icon{font-size:22px;color:var(--accent);line-height:1}.drop-zone__text{font-size:14px;font-weight:600;color:var(--text-bright)}.drop-zone__hint{font-size:12px;color:var(--text-dim)}.coord-sys{padding:6px 14px;font-size:12px;color:var(--accent);font-family:var(--font-mono);background:var(--accent-dim);border-bottom:1px solid var(--border)}.info-row{display:flex;flex-direction:column;flex-grow:1;gap:2px}.info-row__label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim)}.info-row__value{font-family:var(--font-mono);font-size:13px;color:var(--accent);word-break:break-all;cursor:pointer;text-decoration:none}.info-row__value:hover{color:#00f0c5}.info-row__value:active{text-shadow:#00d4aa 1px 0 10px}button,.btn{min-width:40px;font-family:var(--font-ui);font-size:14px;font-weight:600;border:none;border-radius:var(--radius);cursor:pointer;padding:9px 13px;transition:background .15s,color .15s,border-color .15s;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:6px}.btn--full{width:100%}.btn--primary{background:var(--accent);color:#0a1a15}.btn--primary:hover{background:#00f0c5}.btn--ghost{background:var(--bg-raised);color:var(--text);border:1px solid var(--border)}.btn--ghost:hover{border-color:var(--accent);color:var(--accent)}.btn--accent{background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent)}.btn--accent:hover{background:var(--accent);color:#0a1a15}.btn--square{width:42px;min-width:42px;padding:9px 0;font-family:var(--font-mono);font-size:11px;flex-shrink:0}.field{display:flex;flex-direction:column;gap:4px;flex:1}.field__label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim)}.field__input{font-family:var(--font-mono);font-size:14px;background:var(--bg-raised);color:var(--text-bright);border:1px solid var(--border);border-radius:var(--radius);padding:7px 10px;width:100%;transition:border-color .2s}.field__input:focus{outline:none;border-color:var(--accent)}.panel__section--output{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.output{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:10px;flex:1;min-height:0;overflow:auto;white-space:pre-wrap;word-break:break-word;font-family:var(--font-mono);font-size:14px;letter-spacing:.4px;line-height:1.6;color:var(--text)}.output::-webkit-scrollbar{width:4px}.output::-webkit-scrollbar-track{background:transparent}.output::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.output-modal{display:none;position:fixed;inset:0;z-index:900;align-items:center;justify-content:center}.output-modal.is-open{display:flex}.output-modal__backdrop{position:absolute;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.output-modal__box{position:relative;z-index:1;background:var(--bg-panel);border:1px solid var(--border);border-radius:10px;display:flex;flex-direction:column;width:min(600px,90vw);height:60vh;box-shadow:0 8px 40px #0009;overflow:hidden}.output-modal__header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.output-modal__title{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;color:var(--text-dim);text-transform:uppercase}.output-modal__close{width:28px;height:28px;border-radius:50%;background:var(--bg-raised);border:1px solid var(--border);color:var(--text);font-size:14px;cursor:pointer;padding:0;transition:background .15s,color .15s}.output-modal__close:hover{background:var(--danger);border-color:var(--danger);color:#fff}.output-modal__content{flex:1;min-height:0;border:none;border-radius:0;margin:0;padding:14px 16px}@media(max-width:640px){.output-modal__box{width:100%;height:100%;border-radius:0;border:none}}#btnShowMap{display:none}#btnCloseMap{display:none;position:absolute;top:12px;right:12px;z-index:1000;width:40px;height:40px;border-radius:50%;background:var(--bg-panel);border:1px solid var(--border);color:var(--text-bright);font-size:20px;cursor:pointer;align-items:center;justify-content:center;transition:background .15s,color .15s}#btnCloseMap:hover{background:var(--danger);border-color:var(--danger);color:#fff}@media(max-width:640px){.app{flex-direction:column}.panel{width:100%;min-width:unset;height:100dvh;border-right:none;overflow:hidden;flex-shrink:0}.drop-zone.downloaded{flex-direction:row;justify-content:center;padding:8px}.drop-zone.downloaded .drop-zone__hint{display:none}.map-container{position:fixed;inset:0;z-index:500;display:none;flex:unset}.map-container.is-open{display:block}.map-container.is-open #btnCloseMap,#btnShowMap{display:flex}.panel__section--geolocation{display:none!important}.map-container.is-open~.panel-geolocation-portal,body.map-open .panel__section--geolocation{display:flex!important}.panel__section--geolocation.on-map{display:flex!important;position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:600;border:none;background:transparent;padding:0;gap:10px;width:auto}.panel__section--geolocation.on-map .btn{box-shadow:0 2px 16px #0009;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.output{max-height:none}}
