:root{--bg-base:#080d1a;--bg-surface:#0d1526;--bg-elevated:#121c32;--bg-hover:#1a2640;--bg-active:#1e2d4a;--accent-primary:#00d4c8;--accent-secondary:#09f;--accent-tertiary:#7c3aed;--accent-warm:#f59e0b;--accent-danger:#ef4444;--accent-success:#22c55e;--text-primary:#f0f4ff;--text-secondary:#8fa3c8;--text-muted:#4a6080;--text-accent:#00d4c8;--border-subtle:#ffffff0f;--border-default:#ffffff1a;--border-strong:#00d4c840;--glass-bg:#0d1526cc;--glass-border:#ffffff14;--glass-blur:20px;--glass-shadow:0 8px 32px #0009, 0 2px 8px #0006;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--font-ui:"Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--text-xs:11px;--text-sm:12px;--text-base:14px;--text-md:15px;--text-lg:16px;--text-xl:18px;--text-2xl:22px;--topbar-height:52px;--panel-min-w:260px;--panel-min-h:120px;--z-map:0;--z-controls:10;--z-panels:100;--z-topbar:500;--z-modal:1000;--z-toast:2000;--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--ease-smooth:cubic-bezier(.4, 0, .2, 1);--duration-fast:.12s;--duration-normal:.2s;--duration-slow:.35s}html[data-theme=light]{--bg-base:#eef2f7;--bg-surface:#fff;--bg-elevated:#f8fafc;--bg-hover:#e8eef5;--bg-active:#dde6f0;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-accent:#00b8ae;--border-subtle:#0000000f;--border-default:#0000001c;--border-strong:#00b4aa59;--glass-bg:#ffffffe0;--glass-border:#00000017;--glass-shadow:0 8px 32px #0000001a, 0 2px 8px #00000012;--accent-primary:#00b8ae;--accent-secondary:#0080e0}html[data-theme=light] .floating-panel:hover{box-shadow:0 12px 48px #00000024,0 2px 8px #00b4aa14}html[data-theme=light] .floating-panel.focused{border-color:#00b4aa40;box-shadow:0 12px 48px #00000024,0 0 0 1px #00b4aa2e}html[data-theme=light] ::-webkit-scrollbar-thumb{background:#00000024}html[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#00b4aa66}html[data-theme=light] .select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23475569' d='M6 8L1 3h10z'/%3E%3C/svg%3E")}html[data-theme=light] .tool-card:hover{box-shadow:0 4px 16px #0000001f}html[data-theme=light] .btn-primary{color:#fff}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{background:var(--bg-base);width:100%;height:100%;color:var(--text-primary);font-family:var(--font-ui);font-size:var(--text-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;overflow:hidden}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#ffffff1f}::-webkit-scrollbar-thumb:hover{background:#00d4c859}h1,h2,h3,h4,h5,h6{font-family:var(--font-ui);color:var(--text-primary);font-weight:600;line-height:1.25}p{color:var(--text-secondary)}code,pre,.mono{font-family:var(--font-mono);font-size:var(--text-sm)}.app-container{flex-direction:column;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.map-container{position:absolute;inset:0}.topbar{z-index:var(--z-topbar);height:var(--topbar-height);background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border-bottom:1px solid var(--border-subtle);padding:0 var(--space-4);align-items:center;gap:var(--space-3);flex-shrink:0;display:flex;position:relative}.topbar-logo{align-items:center;gap:var(--space-2);flex-shrink:0;text-decoration:none;display:flex}.topbar-logo-icon{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));border-radius:var(--radius-md);justify-content:center;align-items:center;width:30px;height:30px;font-size:16px;display:flex}.topbar-logo-text{font-size:var(--text-lg);background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));-webkit-text-fill-color:transparent;letter-spacing:-.3px;-webkit-background-clip:text;background-clip:text;font-weight:700}.topbar-divider{background:var(--border-default);flex-shrink:0;width:1px;height:28px}.topbar-actions{align-items:center;gap:var(--space-2);flex:1;display:flex}.topbar-right{align-items:center;gap:var(--space-2);margin-left:auto;display:flex}.btn{align-items:center;gap:var(--space-2);border-radius:var(--radius-md);font-family:var(--font-ui);font-size:var(--text-sm);cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth);white-space:nowrap;-webkit-user-select:none;user-select:none;border:none;padding:6px 14px;font-weight:500;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#080d1a;font-weight:600}.btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 16px #00d4c859}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border-default);background:0 0}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.btn-icon{color:var(--text-secondary);border-radius:var(--radius-md);background:0 0;border:1px solid #0000;justify-content:center;width:32px;height:32px;padding:6px}.btn-icon:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-default)}.btn-icon.active{color:var(--accent-primary);border-color:var(--border-strong);background:#00d4c81f}.btn-danger{color:var(--accent-danger);background:#ef44441f;border:1px solid #ef444440}.btn-danger:hover{background:#ef444438;transform:translateY(-1px)}.btn-sm{font-size:var(--text-xs);padding:4px 10px}.btn-xs{font-size:var(--text-xs);border-radius:var(--radius-sm);padding:3px 8px}.floating-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);transition:box-shadow var(--duration-normal) var(--ease-smooth);min-width:var(--panel-min-w);min-height:var(--panel-min-h);flex-direction:column;display:flex;position:absolute;overflow:hidden}.floating-panel:hover{box-shadow:0 12px 48px #000000b3,0 2px 8px #00d4c814}.floating-panel.focused{border-color:#00d4c833;box-shadow:0 12px 48px #000000b3,0 0 0 1px #00d4c826}.panel-header{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);cursor:move;-webkit-user-select:none;user-select:none;background:#ffffff08;flex-shrink:0;display:flex}.panel-drag-handle{align-items:center;gap:var(--space-2);flex:1;display:flex}.panel-title{font-size:var(--text-sm);color:var(--text-primary);letter-spacing:.02em;font-weight:600}.panel-icon{opacity:.8;font-size:14px}.panel-controls{align-items:center;gap:4px;display:flex}.panel-control-btn{border-radius:var(--radius-sm);width:22px;height:22px;color:var(--text-muted);cursor:pointer;transition:all var(--duration-fast);background:0 0;border:none;justify-content:center;align-items:center;font-size:12px;display:flex}.panel-control-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.panel-control-btn.close:hover{color:var(--accent-danger);background:#ef444433}.panel-body{flex-direction:column;flex:1;display:flex;overflow:auto}.panel-minimized .panel-body{display:none}.panel-minimized{height:auto!important;min-height:0!important}.react-resizable-handle{cursor:se-resize;opacity:0;width:14px;height:14px;transition:opacity var(--duration-normal);position:absolute;bottom:0;right:0}.floating-panel:hover .react-resizable-handle{opacity:1}.react-resizable-handle:after{content:"";border-bottom:2px solid var(--accent-primary);border-right:2px solid var(--accent-primary);opacity:.6;border-radius:1px;width:8px;height:8px;position:absolute;bottom:4px;right:4px}.panel-section{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle)}.panel-section:last-child{border-bottom:none}.section-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--space-2);font-weight:600}.input{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-family:var(--font-ui);font-size:var(--text-sm);transition:border-color var(--duration-fast);outline:none;padding:7px 10px}.input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #00d4c81a}.input::placeholder{color:var(--text-muted)}.input-sm{font-size:var(--text-xs);padding:5px 8px}.select{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-family:var(--font-ui);font-size:var(--text-sm);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238fa3c8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;outline:none;padding:7px 30px 7px 10px}.select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #00d4c81a}.label{font-size:var(--text-xs);color:var(--text-secondary);margin-bottom:var(--space-1);font-weight:500;display:block}.form-row{gap:var(--space-1);margin-bottom:var(--space-3);flex-direction:column;display:flex}.form-row:last-child{margin-bottom:0}.form-row-inline{align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.toggle{cursor:pointer;align-items:center;gap:var(--space-2);display:inline-flex;position:relative}.toggle input{display:none}.toggle-track{background:var(--bg-active);border-radius:var(--radius-full);border:1px solid var(--border-default);width:32px;height:18px;transition:background var(--duration-normal);flex-shrink:0;position:relative}.toggle input:checked+.toggle-track{background:var(--accent-primary);border-color:var(--accent-primary)}.toggle-track:after{content:"";width:12px;height:12px;transition:transform var(--duration-normal) var(--ease-spring);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px}.toggle input:checked+.toggle-track:after{transform:translate(14px)}.toggle-label{font-size:var(--text-sm);color:var(--text-secondary)}.slider{-webkit-appearance:none;background:var(--bg-active);border-radius:var(--radius-full);cursor:pointer;outline:none;width:100%;height:4px}.slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent-primary);width:14px;height:14px;transition:transform var(--duration-fast);border-radius:50%;box-shadow:0 0 6px #00d4c880}.slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.color-swatch{border-radius:var(--radius-md);border:2px solid var(--border-default);cursor:pointer;width:28px;height:28px;transition:border-color var(--duration-fast);flex-shrink:0}.color-swatch:hover{border-color:var(--accent-primary)}.layer-item{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);cursor:pointer;transition:background var(--duration-fast);border-left:3px solid #0000;display:flex}.layer-item:hover{background:var(--bg-hover)}.layer-item.active{border-left-color:var(--accent-primary);background:#00d4c814}.layer-color-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.layer-name{font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.layer-type-badge{font-size:var(--text-xs);color:var(--text-muted);background:var(--bg-elevated);border-radius:var(--radius-sm);padding:1px 5px}.layer-opacity-badge{color:var(--text-muted);white-space:nowrap;text-align:right;flex-shrink:0;min-width:28px;font-size:10px}.layer-edit-input{font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-elevated);border:1px solid var(--accent-primary);border-radius:var(--radius-sm);outline:none;flex:1;min-width:0;padding:1px 4px}.layer-item.locked{opacity:.7}.layer-item.locked .layer-name:after{content:" 🔒";font-size:10px}.attr-table-wrapper{width:100%;font-family:var(--font-mono);font-size:var(--text-xs);overflow:auto}.attr-table{border-collapse:collapse;white-space:nowrap;width:100%}.attr-table th{background:var(--bg-elevated);color:var(--text-secondary);font-family:var(--font-ui);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;text-align:left;border-bottom:1px solid var(--border-default);z-index:1;cursor:pointer;-webkit-user-select:none;user-select:none;padding:8px 12px;font-weight:600;position:sticky;top:0}.attr-table th:hover{color:var(--text-primary)}.attr-table th.sorted{color:var(--accent-primary)}.attr-table td{border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);text-overflow:ellipsis;max-width:200px;padding:6px 12px;overflow:hidden}.attr-table tr:hover td{background:var(--bg-hover);color:var(--text-primary)}.attr-table tr.selected td{color:var(--text-primary);background:#00d4c814}.attr-table td input{border:1px solid var(--accent-primary);color:var(--text-primary);font-family:var(--font-mono);font-size:var(--text-xs);border-radius:var(--radius-sm);background:0 0;outline:none;width:100%;padding:2px 4px}.tool-grid{gap:var(--space-2);padding:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.tool-card{align-items:center;gap:var(--space-2);padding:var(--space-3);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-normal);text-align:center;flex-direction:column;display:flex}.tool-card:hover{background:var(--bg-hover);border-color:var(--border-strong);transform:translateY(-2px);box-shadow:0 4px 16px #0000004d}.tool-card:active{transform:translateY(0)}.tool-card-icon{font-size:22px;line-height:1}.tool-card-name{font-size:var(--text-xs);color:var(--text-secondary);font-weight:500}.filter-rule{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-bottom:1px solid var(--border-subtle);display:flex}.filter-chip{border:1px solid var(--border-strong);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--accent-primary);background:#00d4c81f;align-items:center;gap:5px;padding:3px 8px;display:inline-flex}.filter-chip-remove{color:var(--accent-primary);cursor:pointer;opacity:.7;background:0 0;border:none;padding:0;line-height:1}.filter-chip-remove:hover{opacity:1}.chart-widget{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-4);margin:var(--space-3)}.chart-widget-header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.chart-title{font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.legend-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);z-index:var(--z-controls);min-width:150px;max-width:220px;box-shadow:var(--glass-shadow);position:absolute;bottom:28px;right:12px}.legend-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--space-2);font-weight:600}.legend-item{align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-secondary);margin-bottom:5px;display:flex}.legend-swatch{border-radius:var(--radius-sm);flex-shrink:0;width:14px;height:14px}.mapboxgl-ctrl-group{background:var(--glass-bg)!important;-webkit-backdrop-filter:blur(var(--glass-blur))!important;backdrop-filter:blur(var(--glass-blur))!important;border:1px solid var(--glass-border)!important;box-shadow:var(--glass-shadow)!important;border-radius:var(--radius-md)!important}.mapboxgl-ctrl-group button{color:var(--text-secondary)!important;border-color:var(--border-subtle)!important;background-color:#0000!important}.mapboxgl-ctrl-group button:hover{background-color:var(--bg-hover)!important;color:var(--text-primary)!important}.mapboxgl-ctrl-attrib{background:var(--glass-bg)!important;font-family:var(--font-ui)!important;border-radius:var(--radius-sm)!important;font-size:10px!important}.draw-toolbar{gap:var(--space-2);background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-2);z-index:var(--z-controls);box-shadow:var(--glass-shadow);display:flex;position:absolute;bottom:77px;left:12px}.draw-tool-btn{border-radius:var(--radius-md);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast);background:0 0;border:none;justify-content:center;align-items:center;font-size:16px;display:flex;position:relative}.draw-tool-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.draw-tool-btn.active{color:var(--accent-primary);background:#00d4c826}.measure-result{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-bottom:1px solid var(--border-subtle);font-size:var(--text-sm);background:#0099ff1a;display:flex}.measure-value{font-family:var(--font-mono);color:var(--accent-secondary);font-weight:500}.toast-container{top:calc(var(--topbar-height) + 12px);z-index:var(--z-toast);gap:var(--space-2);pointer-events:none;flex-direction:column;display:flex;position:fixed;right:16px}.toast{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);pointer-events:all;animation:slideInRight var(--duration-slow) var(--ease-spring) both;font-size:var(--text-sm);max-width:320px;display:flex}.toast.success{border-left:3px solid var(--accent-success)}.toast.error{border-left:3px solid var(--accent-danger)}.toast.info{border-left:3px solid var(--accent-secondary)}.toast.warning{border-left:3px solid var(--accent-warm)}.toast-icon{flex-shrink:0;font-size:16px}.toast-message{color:var(--text-primary);flex:1}.toast-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:16px;line-height:1}.toast-close:hover{color:var(--text-primary)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal);animation:fadeIn var(--duration-normal) var(--ease-smooth);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);max-height:90vh;animation:scaleIn var(--duration-slow) var(--ease-spring);flex-direction:column;display:flex;box-shadow:0 24px 80px #000c}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--text-xl);font-weight:600}.modal-body{padding:var(--space-5) var(--space-6);flex:1;overflow-y:auto}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-subtle);display:flex}.tabs{padding:var(--space-2) var(--space-4);border-bottom:1px solid var(--border-subtle);gap:2px;display:flex}.tab-btn{border-radius:var(--radius-md);font-family:var(--font-ui);font-size:var(--text-xs);color:var(--text-muted);cursor:pointer;transition:all var(--duration-fast);background:0 0;border:none;padding:5px 12px;font-weight:500}.tab-btn:hover{color:var(--text-secondary);background:var(--bg-hover)}.tab-btn.active{color:var(--accent-primary);background:#00d4c81a}.empty-state{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-8);text-align:center;flex-direction:column;display:flex}.empty-state-icon{opacity:.3;font-size:40px}.empty-state-title{font-size:var(--text-md);color:var(--text-secondary);font-weight:500}.empty-state-desc{font-size:var(--text-sm);color:var(--text-muted)}.drop-zone{border:2px dashed var(--border-default);border-radius:var(--radius-lg);padding:var(--space-8);text-align:center;cursor:pointer;transition:all var(--duration-normal);background:var(--bg-elevated)}.drop-zone:hover,.drop-zone.dragover{border-color:var(--accent-primary);background:#00d4c80d}.drop-zone-icon{margin-bottom:var(--space-3);opacity:.5;font-size:36px}.drop-zone-text{font-size:var(--text-sm);color:var(--text-secondary)}.drop-zone-sub{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}.badge{border-radius:var(--radius-full);font-size:var(--text-xs);align-items:center;padding:2px 7px;font-weight:600;display:inline-flex}.badge-teal{color:var(--accent-primary);background:#00d4c826}.badge-blue{color:var(--accent-secondary);background:#0099ff26}.badge-purple{color:var(--accent-tertiary);background:#7c3aed26}.badge-amber{color:var(--accent-warm);background:#f59e0b26}.badge-red{color:var(--accent-danger);background:#ef444426}.badge-green{color:var(--accent-success);background:#22c55e26}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);background:var(--bg-elevated);color:var(--text-primary);font-size:var(--text-xs);border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--duration-fast);border:1px solid var(--border-default);z-index:99999;padding:4px 8px;position:absolute;top:110%;left:50%;transform:translate(-50%)}[data-tooltip]:hover:after{opacity:1}.spinner{border:2px solid var(--border-default);border-top-color:var(--accent-primary);border-radius:50%;width:18px;height:18px;animation:.6s linear infinite spin}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}.panel-enter{animation:panelOpen var(--duration-slow) var(--ease-spring) both}@keyframes panelOpen{0%{opacity:0;transform:scale(.92)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.accent-line{background:linear-gradient(90deg, var(--accent-primary), var(--accent-secondary));border-radius:var(--radius-full);height:2px}.divider{background:var(--border-subtle);height:1px;margin:var(--space-2) 0}.topbar-hamburger{flex-shrink:0;margin-left:auto;display:none}.topbar-mobile-menu{top:var(--topbar-height);background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border-bottom:1px solid var(--border-subtle);padding:var(--space-3) var(--space-4);z-index:calc(var(--z-topbar) - 1);gap:var(--space-3);flex-direction:column;display:flex;position:fixed;left:0;right:0;box-shadow:0 8px 32px #0006}.topbar-mobile-actions{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.topbar-mobile-panels{gap:var(--space-2);grid-template-columns:repeat(5,1fr);display:grid}.topbar-mobile-panel-btn{border:1px solid var(--border-subtle);border-radius:var(--radius-md);font-size:var(--text-xs);flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:8px 4px}.topbar-mobile-panel-btn.active{border-color:var(--accent-primary);color:var(--accent-primary);background:#00d4c81f}.topbar-mobile-panel-icon{font-size:18px;line-height:1}.topbar-mobile-panel-label{color:var(--text-secondary);font-size:10px;font-weight:500}@media (width<=1024px){.topbar-actions .btn span{display:none}.topbar-actions .input{width:120px!important}.topbar-logo-text{display:none}}@media (width<=768px){.floating-panel{border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:60vh;width:100%!important;position:fixed!important;inset:auto 0 0!important;transform:none!important}.legend-panel,.topbar-logo-text,.topbar-actions,.topbar-divider:first-of-type,.topbar-right{display:none}.topbar-hamburger{display:inline-flex}.topbar-actions .btn span{display:none}}.mapbox-gl-draw_ctrl-draw-btn{background-color:#0000!important;border:none!important}.logic-toggle{border:1px solid var(--border-default);border-radius:var(--radius-md);display:flex;overflow:hidden}.logic-toggle button{color:var(--text-muted);font-size:var(--text-xs);font-family:var(--font-ui);cursor:pointer;transition:all var(--duration-fast);background:0 0;border:none;flex:1;padding:5px 10px;font-weight:600}.logic-toggle button.active{color:var(--accent-primary);background:#00d4c81f}.map-panel-launchers{gap:var(--space-2);z-index:var(--z-controls);flex-direction:column;display:flex;position:absolute;top:12px;right:12px}.map-panel-launchers [data-tooltip]:after{top:50%;left:auto;right:calc(100% + 8px);transform:translateY(-50%)}@media (width<=768px){.map-panel-launchers{display:none}}.launcher-btn{background:var(--glass-bg);width:38px;height:38px;-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast);box-shadow:var(--glass-shadow);justify-content:center;align-items:center;font-size:16px;display:flex}.launcher-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.launcher-btn.active{color:var(--accent-primary);border-color:var(--border-strong);background:#00d4c81f}.coord-readout{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-full);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-muted);pointer-events:none;z-index:var(--z-controls);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));padding:4px 14px;position:absolute;bottom:28px;right:12px}[data-map-theme=light] .draw-toolbar,[data-map-theme=light] .coord-readout,[data-map-theme=light] .legend-panel{-webkit-backdrop-filter:blur(var(--glass-blur));background:#ffffffeb;border-color:#00000024;box-shadow:0 2px 12px #00000024}[data-map-theme=light] .draw-tool-btn{color:#475569}[data-map-theme=light] .draw-tool-btn:hover{color:#1e293b;background:#00000012}[data-map-theme=light] .draw-tool-btn.active{color:#0050b3;background:#0050b31f}[data-map-theme=light] .coord-readout{color:#64748b}[data-map-theme=light] .legend-panel{color:#1e293b}[data-map-theme=light] .launcher-btn{color:#475569;background:#ffffffeb;border-color:#00000024;box-shadow:0 2px 8px #0000001f}[data-map-theme=light] .launcher-btn:hover{color:#1e293b;background:#fff}[data-map-theme=light] .launcher-btn.active{color:#0050b3;background:#0050b31f;border-color:#0050b34d}[data-map-theme=light] .mapboxgl-ctrl-group{background:#ffffffeb!important;border:1px solid #00000024!important;box-shadow:0 2px 8px #0000001f!important}[data-map-theme=light] .mapboxgl-ctrl-group button{background-color:#0000!important}[data-map-theme=light] .mapboxgl-ctrl-group button .mapboxgl-ctrl-icon{filter:invert(0)!important}[data-map-theme=light] .mapboxgl-ctrl-attrib{background:#ffffffd9!important}.opacity-row{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);display:flex}.opacity-value{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--text-muted);text-align:right;flex-shrink:0;width:28px}.profile-avatar{width:28px;height:28px;font-size:var(--text-xs);color:#000c;-webkit-user-select:none;user-select:none;letter-spacing:.02em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.profile-avatar-lg{width:44px;height:44px;font-size:var(--text-md)}.profile-badge-wrapper{position:relative}.profile-badge-btn{align-items:center;gap:var(--space-2);border:1px solid var(--border-default);border-radius:var(--radius-full);cursor:pointer;transition:all var(--duration-normal);color:var(--text-primary);font-family:var(--font-ui);background:0 0;padding:4px 8px 4px 4px;display:flex}.profile-badge-btn:hover,.profile-badge-btn.active{background:var(--bg-hover);border-color:var(--border-strong)}.profile-badge-name{font-size:var(--text-sm);text-overflow:ellipsis;white-space:nowrap;max-width:80px;font-weight:500;overflow:hidden}.profile-signin-btn{gap:var(--space-2);border-radius:var(--radius-full)!important}.profile-signin-text{font-size:var(--text-sm)}.profile-dropdown{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);min-width:200px;z-index:calc(var(--z-topbar) + 10);animation:scaleIn var(--duration-normal) var(--ease-spring);transform-origin:100% 0;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden;box-shadow:0 12px 40px #0009,0 2px 8px #0000004d}.profile-dropdown-header{align-items:center;gap:var(--space-3);padding:var(--space-4);border-bottom:1px solid var(--border-subtle);background:#ffffff08;display:flex}.profile-dropdown-name{font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.profile-dropdown-sub{font-size:var(--text-xs);color:var(--text-muted);margin-top:1px}.profile-dropdown-divider{background:var(--border-subtle);height:1px;margin:var(--space-1) 0}.profile-dropdown-item{align-items:center;gap:var(--space-3);width:100%;padding:var(--space-2) var(--space-4);color:var(--text-secondary);font-family:var(--font-ui);font-size:var(--text-sm);cursor:pointer;transition:all var(--duration-fast);text-align:left;background:0 0;border:none;display:flex}.profile-dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.profile-dropdown-signout{color:var(--accent-danger)!important}.profile-dropdown-signout:hover{background:#ef444414!important}.login-overlay{-webkit-backdrop-filter:blur(6px);z-index:var(--z-modal);animation:fadeIn var(--duration-normal) var(--ease-smooth);background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.login-dialog{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);width:420px;max-width:calc(100vw - 32px);max-height:calc(100vh - 64px);animation:scaleIn var(--duration-slow) var(--ease-spring);flex-direction:column;display:flex;overflow-y:auto;box-shadow:0 24px 80px #000000d9,0 0 0 1px #00d4c814}.login-header{align-items:center;gap:var(--space-4);padding:var(--space-6);border-bottom:1px solid var(--border-subtle);display:flex;position:relative}.login-logo{border:1px solid var(--border-strong);border-radius:var(--radius-lg);background:linear-gradient(135deg,#00d4c826,#0099ff26);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.login-title{font-size:var(--text-xl);background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.login-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}.login-close-btn{top:var(--space-4);right:var(--space-4);border:1px solid var(--border-subtle);border-radius:var(--radius-md);width:28px;height:28px;color:var(--text-muted);cursor:pointer;transition:all var(--duration-fast);background:0 0;justify-content:center;align-items:center;display:flex;position:absolute}.login-close-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-default)}.login-profile-list{gap:var(--space-2);padding:var(--space-4);flex-direction:column;display:flex}.login-profile-row{align-items:center;gap:var(--space-2);display:flex}.login-profile-card{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-normal);text-align:left;color:var(--text-primary);font-family:var(--font-ui);flex:1;display:flex}.login-profile-card:hover{background:var(--bg-hover);border-color:var(--border-strong);transform:translateY(-1px);box-shadow:0 4px 16px #0003}.login-profile-info{flex:1;min-width:0}.login-profile-name{font-size:var(--text-sm);text-overflow:ellipsis;white-space:nowrap;font-weight:600;display:block;overflow:hidden}.login-profile-date{font-size:var(--text-xs);color:var(--text-muted);margin-top:1px;display:block}.login-profile-check{color:var(--text-muted);opacity:0;transition:opacity var(--duration-fast);flex-shrink:0}.login-profile-card:hover .login-profile-check{opacity:1;color:var(--accent-primary)}.login-profile-delete{opacity:0;transition:opacity var(--duration-fast);flex-shrink:0;color:var(--accent-danger)!important}.login-profile-row:hover .login-profile-delete{opacity:1}.login-delete-confirm{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--accent-danger);background:#ef444414;border:1px solid #ef444433;flex:1;display:flex}.login-divider{background:var(--border-subtle);height:1px;margin:0 var(--space-4)}.login-add-profile-btn{margin:var(--space-2) var(--space-4);width:calc(100% - var(--space-8));justify-content:center;gap:var(--space-2);border-radius:var(--radius-lg)}.login-create-form{padding:var(--space-4) var(--space-5);flex-direction:column;display:flex}.login-field-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:var(--space-2);font-weight:600;display:block}.login-color-picker{flex-wrap:wrap;gap:10px;display:flex}.login-color-swatch{cursor:pointer;width:32px;height:32px;transition:all var(--duration-fast);border:2px solid #0000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.login-color-swatch:hover{transform:scale(1.15)}.login-color-swatch.selected{border-color:var(--text-primary);box-shadow:0 0 0 3px #ffffff26}.login-avatar-preview{align-items:center;gap:var(--space-3);margin-top:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);display:flex}.login-preview-name{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.login-form-actions{gap:var(--space-2);margin-top:var(--space-4);display:flex}.login-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-subtle);background:#ffffff05;justify-content:space-between;align-items:center;display:flex}.btn-link{cursor:pointer;font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-muted);align-items:center;gap:var(--space-2);transition:color var(--duration-fast);background:0 0;border:none;padding:4px 0;display:inline-flex}.btn-link:hover{color:var(--text-primary)}.login-guest-btn{font-size:var(--text-sm)}.login-footer-note{font-size:var(--text-xs);color:var(--text-muted);opacity:.6}html[data-theme=light] .login-dialog{box-shadow:0 24px 80px #0000002e,0 0 0 1px #00b4aa1f}html[data-theme=light] .profile-dropdown{box-shadow:0 12px 40px #00000024,0 2px 8px #00000014}
