:root{--bg:#0d0d0f;--bg2:#13131a;--bg3:#1a1a24;--border:#2a2a3a;--accent:#4f8ef7;--accent2:#7b5ea7;--success:#34d399;--warning:#fbbf24;--error:#f87171;--text:#e8e8f0;--text2:#9090a8;--text3:#5a5a72;--font:-apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", sans-serif;--mono:"JetBrains Mono", "SF Mono", Menlo, monospace;--radius:10px;--radius-sm:6px}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}#root{flex-direction:column;display:flex;position:fixed;inset:0}.topbar{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10;background:#13131ae6;flex:0 0 48px;align-items:center;gap:12px;height:48px;padding:0 16px;display:flex}.topbar-logo{letter-spacing:-.3px;background:linear-gradient(135deg, var(--accent), var(--accent2));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:15px;font-weight:700}.topbar-sep{flex:1}.topbar-home{color:var(--text2);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg3);padding:5px 10px;font-size:12px;font-weight:600;text-decoration:none;transition:color .15s,border-color .15s}.topbar-home:hover{color:var(--text);border-color:var(--text3)}.topbar-info{width:28px;height:28px;color:var(--text3);border-radius:50%;justify-content:center;align-items:center;font-size:16px;text-decoration:none;transition:color .15s,background .15s;display:flex}.topbar-info:hover{color:var(--accent);background:#4f8ef71a}.topbar-badge{text-transform:uppercase;letter-spacing:.06em;color:var(--text3);background:var(--bg3);border:1px solid var(--border);border-radius:20px;padding:3px 8px;font-size:11px;font-weight:600}.layout{flex:1 1 0;min-height:0;display:flex;overflow:hidden}.map-wrapper{background:var(--bg);flex:1;min-width:0;position:relative}.map-placeholder{width:100%;height:100%;color:var(--text3);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:24px;font-size:13px;display:flex}.map-placeholder-icon{opacity:.4;font-size:40px}.map-placeholder code{font-family:var(--mono);background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--accent);padding:4px 8px;font-size:12px}.panel{background:var(--bg2);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;width:360px;display:flex;overflow:hidden}.panel-header{flex-shrink:0;padding:14px 16px 0}.panel-title{text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:10px;font-size:10px;font-weight:700}.tabs{background:var(--bg3);border-radius:var(--radius-sm);gap:2px;margin-bottom:12px;padding:3px;display:flex}.tab-btn{font-size:12px;font-weight:600;font-family:var(--font);color:var(--text2);cursor:pointer;background:0 0;border:none;border-radius:4px;flex:1;padding:6px 8px;transition:all .15s}.tab-btn.active{background:var(--bg2);color:var(--text);box-shadow:0 1px 4px #0000004d}.tab-btn:hover:not(.active){color:var(--text)}.panel-body{flex-direction:column;flex:1;gap:10px;padding:0 16px 16px;display:flex;overflow-y:auto}.panel-body::-webkit-scrollbar{width:4px}.panel-body::-webkit-scrollbar-track{background:0 0}.panel-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.geojson-textarea{background:var(--bg3);width:100%;min-height:200px;color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:11.5px;font-family:var(--mono);resize:vertical;outline:none;padding:10px 12px;line-height:1.55;transition:border-color .15s}.geojson-textarea:focus{border-color:var(--accent)}.geojson-textarea.has-error{border-color:var(--error)}.dropzone{border:2px dashed var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;color:var(--text2);background:var(--bg3);flex-direction:column;align-items:center;gap:8px;padding:32px 16px;font-size:13px;transition:all .2s;display:flex}.dropzone:hover,.dropzone.over{border-color:var(--accent);color:var(--text);background:#4f8ef70f}.dropzone-icon{font-size:30px;line-height:1}.dropzone small{color:var(--text3);font-size:11px}.btn-row{gap:8px;display:flex}.btn{font-size:13px;font-weight:600;font-family:var(--font);border-radius:var(--radius-sm);cursor:pointer;border:none;flex:1;padding:9px 14px;transition:all .15s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{filter:brightness(1.12)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;filter:none}.btn-ghost{background:var(--bg3);color:var(--text2);border:1px solid var(--border)}.btn-ghost:hover{color:var(--text);border-color:var(--text3)}.status-msg{border-radius:var(--radius-sm);align-items:flex-start;gap:6px;padding:8px 10px;font-size:12px;line-height:1.45;display:flex}.status-msg.success{color:var(--success);background:#34d3991a;border:1px solid #34d39933}.status-msg.error{color:var(--error);background:#f871711a;border:1px solid #f8717133}.status-msg.warning{color:var(--warning);background:#fbbf241a;border:1px solid #fbbf2433}.status-msg.info{color:var(--accent);background:#4f8ef71a;border:1px solid #4f8ef733}.info-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px}.info-card-label{color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;font-size:10px;font-weight:700}.info-card-value{color:var(--text);font-family:var(--mono);word-break:break-all;font-size:11.5px}.crs-badge{color:var(--accent2);background:#7b5ea726;border:1px solid #7b5ea74d;border-radius:20px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.layer-item{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:8px;padding:8px 10px;font-size:12px;display:flex}.layer-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.layer-name{color:var(--text);flex:1;font-weight:500}.layer-count{color:var(--text3);font-size:11px}.divider{background:var(--border);height:1px;margin:2px 0}.ad-footer{background:var(--bg2);border-top:1px solid var(--border);flex:0 0 90px;align-items:center;width:100%;height:90px;display:flex;overflow:hidden}.ad-footer .adsbygoogle{width:100%;height:90px;display:block}@media (width<=700px){.layout{flex-direction:column}.panel{border-left:none;border-top:1px solid var(--border);width:100%;max-height:48dvh}}
