*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0f1923;--bg-secondary:#1a2633;--bg-card:#1e2d3d;--bg-hover:#253545;--text-primary:#e8edf2;--text-secondary:#89a;--text-muted:#5a6a7a;--accent:#00d4ff;--accent-dim:#00d4ff26;--border:#2a3a4a;--danger:#ff4757;--success:#2ed573;--warning:#ffa502;--ship-other:#89a;--sidebar-width:340px;--topbar-height:0px}body{background:var(--bg-primary);color:var(--text-primary);height:100dvh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden}#app{height:100dvh;display:flex}#sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);z-index:1000;flex-direction:column;display:flex;position:relative;overflow:hidden}@media (width>=769px){#sidebar.collapsed{min-width:0}}.sidebar-toggle-tab:hover{background:var(--bg-hover);color:var(--accent)}.sidebar-toggle-tab .mobile-icon{display:none}#sidebar.collapsed .sidebar-toggle-tab{left:var(--sidebar-width);box-shadow:4px 0 12px #0006}#map{flex:1;height:100dvh}.sidebar-header{border-bottom:1px solid var(--border);padding:16px}.search-filter-area{border-bottom:1px solid var(--border);padding:8px 16px 12px}.sidebar-title{color:var(--accent);letter-spacing:1px;align-items:center;gap:8px;margin-bottom:12px;font-size:18px;font-weight:700;display:flex}.sidebar-title .icon{padding-left:44px;font-size:22px}.sidebar-title .version{color:var(--text-secondary);vertical-align:super;font-size:8px}.search-box{position:relative}.search-box input{background:var(--bg-card);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:8px;outline:none;padding:10px 12px 10px 36px;font-family:inherit;font-size:13px;transition:border-color .2s}.search-box input:focus{border-color:var(--accent)}.search-box:before{content:"🔍";opacity:.5;font-size:14px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.filter-box{margin-top:8px}.filter-box select{background:var(--bg-card);border:1px solid var(--border);width:100%;color:var(--text-primary);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%238899aa' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 0 0 1 .753 1.659l-4.796 5.48a1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border-radius:8px;outline:none;padding:8px 12px;font-family:inherit;font-size:12px;transition:border-color .2s}.filter-box select:focus{border-color:var(--accent)}.header-left{align-items:center;gap:20px;display:flex}.hide-others-text{color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;-webkit-user-select:none;user-select:none;font-size:10px;font-weight:700}.toggle-container{flex-shrink:0;width:28px;height:16px;display:inline-block;position:relative}.toggle-container input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background-color:var(--border);border-radius:16px;transition:all .3s;position:absolute;inset:0}.toggle-slider:before{content:"";background-color:#fff;border-radius:50%;width:12px;height:12px;transition:all .3s;position:absolute;bottom:2px;left:2px}.toggle-container input:checked+.toggle-slider{background-color:var(--accent)}.toggle-container input:checked+.toggle-slider:before{transform:translate(12px)}.stats-bar{border-bottom:1px solid var(--border);color:var(--text-secondary);gap:6px;padding:10px 16px;font-size:11px;display:flex}.stat{align-items:center;gap:4px;display:flex}.right-stat{margin-left:auto}.vessel-list-header{color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;border-left:3px solid #0000;justify-content:space-between;align-items:center;padding:12px 16px 4px;font-size:10px;font-weight:700;display:flex}.header-actions{align-items:center;gap:12px;display:flex}.deselect-all-btn{color:var(--accent);cursor:pointer;opacity:.8;text-transform:none;letter-spacing:normal;background:0 0;border:none;padding:0;font-family:inherit;font-size:10px;font-weight:500;text-decoration:underline;transition:opacity .2s}.deselect-all-btn:hover{opacity:1}.heatmap-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;transition:all .2s;display:flex}.heatmap-btn:hover{background:var(--bg-hover);border-color:var(--accent);color:var(--text-primary)}.heatmap-btn.active{color:#ff4757;background:#ff47571a;border-color:#ff4757}#live-toggle{color:var(--success);border-color:var(--success);background:#2ed5731a}.mobile-branding,.mobile-list-close{display:none}.stat-dot{background:var(--success);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.vessel-list{flex:1;padding:4px 0;overflow-y:auto}.vessel-list::-webkit-scrollbar{width:4px}.vessel-list::-webkit-scrollbar-track{background:0 0}.vessel-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.vessel-item{cursor:pointer;border-left:3px solid #0000;align-items:center;gap:12px;padding:10px 16px;transition:background .15s;display:flex}.vessel-pin{cursor:pointer;width:16px;height:16px;accent-color:var(--accent);opacity:.6;flex-shrink:0;transition:opacity .2s}.vessel-item:hover .vessel-pin,.vessel-pin:checked{opacity:1}.vessel-item:hover{background:var(--bg-hover)}.vessel-item.active{background:var(--accent-dim);border-left-color:var(--accent)}.vessel-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-left:-4px}.vessel-info{flex:1;min-width:0}.vessel-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.vessel-mmsi{color:var(--text-muted);font-family:SF Mono,Fira Code,monospace;font-size:11px}.vessel-speed{color:var(--text-secondary);text-align:right;white-space:nowrap;font-size:11px}.detail-panel{background:var(--bg-card);border-top:2px solid var(--accent);z-index:5;padding:20px 16px;display:none;position:relative;box-shadow:0 -4px 20px #0006}.detail-panel.visible{display:block}.detail-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.detail-name-row{align-items:center;gap:12px;display:flex}.detail-name{color:var(--accent);letter-spacing:.5px;font-size:16px;font-weight:700}.detail-follow-btn{background:var(--bg-hover);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;transition:all .2s;display:flex}.detail-follow-btn:hover{background:var(--bg-card);border-color:var(--accent);color:var(--text-primary)}.detail-follow-btn.active{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.detail-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:18px;transition:background .15s}.detail-close:hover{background:var(--bg-hover);color:var(--text-primary)}.detail-grid{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;display:grid}.detail-field{background:#0003;border:1px solid #ffffff0d;border-radius:8px;padding:10px 12px;transition:all .2s}.detail-field:hover{border-color:var(--accent-dim);background:#0000004d;transform:translateY(-1px)}.detail-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;font-size:10px}.detail-value{font-size:13px;font-weight:500}.history-controls{gap:4px;margin-top:8px;display:flex}.history-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:6px;flex:1;padding:6px;font-family:inherit;font-size:11px;font-weight:500;transition:all .15s}.history-btn:hover{border-color:var(--accent);color:var(--text-primary)}.history-btn:disabled{opacity:.55;cursor:wait}.history-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.sidebar-handle{display:none}.map-legend{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:10px;width:140px;padding:0;font-size:11px;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.map-legend.collapsed{width:110px}.legend-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:10px 12px;font-size:10px;font-weight:600;transition:background .2s;display:flex}.legend-title:hover{background:var(--bg-hover);color:var(--text-primary)}.legend-title .toggle-icon{opacity:.6;font-size:12px;transition:transform .3s}.map-legend.collapsed .toggle-icon{transform:rotate(-90deg)}#map-legend-items{max-height:400px;padding:0 12px 10px;transition:opacity .2s,max-height .3s;overflow:hidden}.map-legend.collapsed #map-legend-items{opacity:0;max-height:0;padding-bottom:0}.legend-row{color:var(--text-secondary);align-items:center;gap:6px;margin:3px 0;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.leaflet-control-zoom a{background:var(--bg-secondary)!important;color:var(--text-primary)!important;border-color:var(--border)!important}.leaflet-control-attribution{color:var(--text-muted)!important;background:#0f1923b3!important;font-size:10px!important}.leaflet-control-attribution a{color:var(--text-secondary)!important}.leaflet-popup-content-wrapper{background:var(--bg-card)!important;color:var(--text-primary)!important;border:1px solid var(--border)!important;border-radius:10px!important;box-shadow:0 4px 20px #0006!important}.leaflet-popup-tip{background:var(--bg-card)!important}.popup-title{margin-bottom:6px;font-size:14px;font-weight:600}.popup-row{color:var(--text-secondary);justify-content:space-between;padding:2px 0;font-size:12px;display:flex}.popup-row span:last-child{color:var(--text-primary);font-weight:500}.ship-icon{transition:transform .8s,filter .3s}.ship-icon.pinned{filter:drop-shadow(0 0 3px var(--accent))}.ship-icon.active{filter:drop-shadow(0 0 6px var(--accent)) drop-shadow(0 0 2px white);stroke-width:2.5px!important}@keyframes selectPulse{0%{opacity:0;transform:scale(.8)}20%{opacity:1}to{opacity:0;transform:scale(2.2)}}.selected-ring{border:3px solid var(--accent);width:48px;height:48px;box-shadow:0 0 15px var(--accent);pointer-events:none;border-radius:50%;animation:1.5s ease-out infinite selectPulse}#loading-overlay{z-index:2000;background:#0f1923d9;justify-content:center;align-items:center;transition:opacity .5s;display:flex;position:fixed;inset:0}#loading-overlay.hidden{opacity:0;pointer-events:none}.loader{text-align:center}.loader-spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;margin:0 auto 12px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loader-text{color:var(--text-secondary);font-size:13px}@media (width<=768px){:root{--sidebar-width:100vw}.mobile-branding{color:var(--accent);letter-spacing:.5px;white-space:nowrap;flex:1;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex}.left-stat{flex:1;justify-content:flex-start}.right-stat{flex:1;justify-content:flex-end;margin-left:0}.mobile-list-close{background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;width:20px;height:20px;margin-left:6px;font-size:14px;line-height:1;transition:all .2s;display:inline-flex}.mobile-list-close:hover{background:var(--bg-hover);color:var(--text-primary)}.leaflet-popup{display:none!important}#sidebar{z-index:1200;border:none;flex-direction:column;width:100vw;height:55dvh;display:flex;position:fixed;top:auto;bottom:0;left:0;overflow:visible;transform:translateY(0);transition:transform .3s cubic-bezier(.25,1,.5,1),width .3s,height .3s!important}#sidebar.detail-active .tab-content{display:none!important}#sidebar.detail-active .results-container{flex:none}#sidebar.collapsed{pointer-events:none;visibility:hidden;border:none;width:100vw!important;min-width:100vw!important;transform:translateY(100%)!important}.sidebar-handle{background:var(--bg-secondary);border:none;border-top:2px solid var(--accent);cursor:pointer;height:32px;color:var(--text-muted);pointer-events:auto;visibility:visible;touch-action:none;border-radius:20px 20px 0 0;justify-content:center;align-items:center;padding:0 0 4px;display:flex;position:absolute;top:-32px;left:0;right:0;box-shadow:0 -8px 30px #0009}.sidebar-handle:after{content:"";background:var(--border);border-radius:2px;width:40px;height:4px}.detail-panel{flex:1;min-height:200px;padding:12px 16px;overflow-y:auto}.detail-grid{gap:6px}.detail-field{padding:8px 10px}.detail-name{font-size:15px}.sidebar-handle:hover:after{background:var(--text-muted)}.sidebar-toggle-tab{display:none}#sidebar.detail-view{height:auto;bottom:-100%}.sidebar-visible #sidebar.detail-view{bottom:0}#sidebar.detail-view .sidebar-header,#sidebar.detail-view .stats-bar,#sidebar.detail-view .search-filter-area,#sidebar.detail-view .vessel-list,.sidebar-header{display:none}.search-filter-area{padding:12px 16px}#sidebar .detail-panel.visible{background:var(--bg-card);z-index:10;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px));border-top:none;border-radius:0;position:relative}.leaflet-control-zoom{margin-top:10px!important}}.multiselect.svelte-nqlpnp{width:100%;position:relative}.multiselect-btn.svelte-nqlpnp{background:var(--bg-card);border:1px solid var(--border);width:100%;color:var(--text-primary);cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;padding:8px 12px;font-family:inherit;font-size:12px;transition:all .2s;display:flex}.multiselect-btn.svelte-nqlpnp:hover,.multiselect-btn.active.svelte-nqlpnp{border-color:var(--accent)}.chevron.svelte-nqlpnp{color:var(--text-secondary);font-size:10px;transition:transform .2s}.chevron.open.svelte-nqlpnp{transform:rotate(180deg)}.multiselect-dropdown.svelte-nqlpnp{background:var(--bg-card);border:1px solid var(--border);z-index:1100;border-radius:8px;flex-direction:column;max-height:300px;display:flex;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden;box-shadow:0 4px 12px #0006}.dropdown-actions.svelte-nqlpnp{border-bottom:1px solid var(--border);gap:8px;padding:8px;display:flex}.dropdown-actions.svelte-nqlpnp button:where(.svelte-nqlpnp){background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:4px;flex:1;padding:4px;font-size:10px}.dropdown-actions.svelte-nqlpnp button:where(.svelte-nqlpnp):hover{color:var(--text-primary);border-color:var(--accent)}.options-list.svelte-nqlpnp{padding:4px 0;overflow-y:auto}.option.svelte-nqlpnp{cursor:pointer;align-items:center;gap:10px;padding:8px 12px;transition:background .15s;display:flex}.option.svelte-nqlpnp:hover{background:var(--bg-hover)}.option.svelte-nqlpnp input:where(.svelte-nqlpnp){cursor:pointer;pointer-events:none;margin:0}.legend-dot.svelte-nqlpnp{border-radius:50%;flex-shrink:0;width:8px;height:8px}.option-label.svelte-nqlpnp{color:var(--text-primary);text-transform:capitalize;font-size:12px}.buoy-list.svelte-1qe866f{flex-direction:column;display:flex}.empty-state.svelte-1qe866f{text-align:center;color:var(--text-muted,#888);padding:32px}.buoy-item.svelte-1qe866f{border-bottom:1px solid var(--border-color,#333);cursor:pointer;padding:12px 16px;transition:background .2s}.buoy-item.svelte-1qe866f:hover{background:var(--bg-hover,#2a2a2a)}.buoy-item.active.svelte-1qe866f{background:var(--bg-active,#333);border-left:3px solid var(--accent-color,#4a9eff)}.buoy-header.svelte-1qe866f{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.buoy-name.svelte-1qe866f{color:var(--text-color,#fff);font-size:14px;font-weight:600}.buoy-number.svelte-1qe866f{color:var(--text-muted,#888);font-size:11px}.buoy-details.svelte-1qe866f{grid-template-columns:1fr 1fr;gap:4px 12px;margin-bottom:4px;display:grid}.detail-row.svelte-1qe866f{font-size:12px}.label.svelte-1qe866f{color:var(--text-muted,#888);margin-right:4px}.value.svelte-1qe866f{color:var(--text-color,#eee)}.buoy-footer.svelte-1qe866f{color:var(--text-muted,#666);text-align:right;font-size:10px}.results-container.svelte-nkocuf{flex-direction:column;flex:1;min-height:0;display:flex}.tabs-header.svelte-nkocuf{border-bottom:1px solid var(--border-color,#333);background:var(--bg-secondary,#1a1a1a);padding:0 8px;display:flex}.tab-btn.svelte-nkocuf{color:var(--text-muted,#888);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 16px;font-size:13px;font-weight:500;transition:all .2s}.tab-btn.svelte-nkocuf:hover{color:var(--text-color,#fff)}.tab-btn.active.svelte-nkocuf{color:var(--accent-color,#4a9eff);border-bottom-color:var(--accent-color,#4a9eff)}.tab-content.svelte-nkocuf{flex:1;position:relative;overflow-y:auto}.stats-placeholder.svelte-nkocuf{text-align:center;color:var(--text-muted,#888);padding:24px}.stats-placeholder.svelte-nkocuf h3:where(.svelte-nkocuf){color:var(--text-color,#fff);margin-top:0}.heatmap-info.svelte-nkocuf{color:var(--text-muted,#888);margin-top:16px;font-size:12px;font-style:italic}.open-plots-btn.svelte-nkocuf{background:var(--accent-color,#4a9eff);color:#fff;cursor:pointer;border:none;border-radius:6px;margin-top:20px;padding:10px 20px;font-weight:600;transition:background .2s,transform .1s}.open-plots-btn.svelte-nkocuf:hover{background:#3a8eef}.open-plots-btn.svelte-nkocuf:active{transform:scale(.98)}.stats-overlay-container.svelte-hrp0xb{z-index:10000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.stats-modal.svelte-hrp0xb{background:var(--bg-secondary,#1a1a1a);border:1px solid var(--border-color,#333);width:90%;max-width:800px;height:85%;max-height:700px;color:var(--text-color,#fff);box-sizing:border-box;border-radius:8px;flex-direction:column;padding:20px;display:flex;box-shadow:0 10px 30px #00000080}.stats-header.svelte-hrp0xb{border-bottom:1px solid var(--border-color,#333);justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;display:flex}.stats-header.svelte-hrp0xb h2:where(.svelte-hrp0xb){margin:0;font-size:1.3rem}.close-btn.svelte-hrp0xb{color:var(--text-muted,#888);cursor:pointer;background:0 0;border:none;padding:0;font-size:2rem;line-height:1}.close-btn.svelte-hrp0xb:hover{color:#fff}.stats-controls.svelte-hrp0xb{background:#0003;border-radius:6px;align-items:center;gap:15px;margin-bottom:20px;padding:10px;display:flex}.stats-controls.svelte-hrp0xb .control-label:where(.svelte-hrp0xb){color:var(--text-muted,#aaa);white-space:nowrap;font-size:.9rem}.charts-container.svelte-hrp0xb{flex-direction:column;flex-grow:1;gap:20px;display:flex;overflow-y:auto}.chart-box.svelte-hrp0xb{border:1px solid var(--border-color,#333);background:#ffffff08;border-radius:6px;flex-direction:column;flex:1;min-height:250px;padding:15px;display:flex;overflow:hidden}.chart-box.svelte-hrp0xb h3:where(.svelte-hrp0xb){color:#ccc;text-align:center;margin:0 0 15px;font-size:1.1rem}.chart-wrapper.svelte-hrp0xb{flex-grow:1;justify-content:center;align-items:center;min-height:0;display:flex;position:relative}.loading.svelte-hrp0xb{color:var(--text-muted,#888);flex-grow:1;justify-content:center;align-items:center;font-size:1.2rem;display:flex}.heatmap-loading-overlay.svelte-181dlmc{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:2000;color:var(--accent);background:#0f1923b3;flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:14px;font-weight:600;display:flex;position:absolute;inset:48px 0 0}.loading-spinner.svelte-181dlmc{border:3px solid #ffffff1a;border-top-color:var(--accent-color,#4a9eff);border-radius:50%;width:40px;height:40px;animation:1s ease-in-out infinite svelte-181dlmc-spin}@keyframes svelte-181dlmc-spin{to{transform:rotate(360deg)}}.loading-spinner.small.svelte-181dlmc{border-width:2px;width:24px;height:24px}.dev-tools.svelte-181dlmc{border-top:1px solid #ffffff1a;justify-content:center;margin-top:12px;padding-top:12px;display:flex}.dev-btn.svelte-181dlmc{color:#ffab00;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;background:#ffab001a;border:1px solid #ffab004d;border-radius:4px;align-items:center;gap:6px;padding:6px 12px;font-size:11px;font-weight:700;transition:all .2s;display:flex}.dev-btn.svelte-181dlmc:hover{background:#ffab0033;border-color:#ffab0080;transform:translateY(-1px)}.dev-btn.svelte-181dlmc:active{transform:translateY(0)}.map-legend.svelte-pswzrf{z-index:1000;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#1a222ef2;border:1px solid #ffffff26;border-radius:8px;width:130px;padding:8px 12px;font-size:10px;position:absolute;top:10px;right:10px;box-shadow:0 4px 12px #0000004d}.map-legend.collapsed.svelte-pswzrf #map-legend-items:where(.svelte-pswzrf){display:none}.legend-title.svelte-pswzrf{cursor:pointer;justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px;font-size:11px;font-weight:600;display:flex}.legend-row.svelte-pswzrf{align-items:center;gap:6px;margin:2px 0;display:flex}.legend-dot.svelte-pswzrf{border-radius:50%;width:8px;height:8px}.toggle-icon.svelte-pswzrf{opacity:.6;font-size:9px}.leaflet-control-layers{transition:margin-top .3s;margin-top:var(--control-offset,200px)!important;z-index:1100!important}.leaflet-top.leaflet-right{flex-direction:column;align-items:flex-end;display:flex}#map-container.svelte-c20cna{flex:1;height:100vh;position:relative}#map.svelte-c20cna{width:100%;height:100%}.app-container.svelte-1n46o8q{width:100vw;height:100dvh;display:flex;overflow:hidden}
