*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #11100f;--bg-surface: #191816;--bg-panel: #201f1e;--border: #d7d1b012;--border-strong: #d7d1b024;--text: #ffffff;--text-muted: #a09b90;--accent: #d7d1b0;--critical: #dc2626;--high: #f97316;--medium: #eab308;--low: #8a857a;--green: #7ab88a;--font: "Space Grotesk", -apple-system, BlinkMacSystemFont, sans-serif;--mono: "JetBrains Mono", "Fira Code", monospace;--radius: 14px;--cluster-bg: #2a2520;--zone-label: #e8e3d6;--zone-label-halo: #11100f}[data-theme=light]{--bg: #f5f3ef;--bg-surface: #eae7e1;--bg-panel: #ffffff;--border: #201f1e14;--border-strong: #201f1e24;--text: #11100f;--text-muted: #6b6560;--accent: #8a7a50;--critical: #dc2626;--high: #ea580c;--medium: #ca8a04;--low: #78716c;--green: #16a34a;--cluster-bg: #e8e3d6;--zone-label: #11100f;--zone-label-halo: #ffffff}html{height:100%;overflow:hidden;background:#11100f}body{height:100%;overflow:hidden;position:fixed;width:100%;top:0;left:0;background:#11100f}body{font-family:var(--font);background:var(--bg);color:var(--text)}#app{display:flex;flex-direction:column;height:100dvh;overflow:hidden}#header{display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:48px;background:var(--bg-surface);border-bottom:.5px solid var(--border-strong);z-index:10;touch-action:manipulation;position:relative}.app-logo{display:flex;align-items:center;color:var(--accent);flex-shrink:0}.app-title{font-size:15px;font-weight:700;letter-spacing:-.02em;color:var(--text)}.header-nav{display:flex;align-items:center;gap:4px;margin-left:16px}.nav-item{background:none;border:none;color:var(--text-muted);font-family:var(--font);font-size:13px;font-weight:500;padding:6px 12px;border-radius:8px;cursor:pointer;transition:color .15s,background .15s}.nav-item:hover{color:var(--text);background:var(--border-strong)}.nav-item.active{color:var(--text);background:var(--bg-panel)}.nav-pill{font-size:9px;font-weight:700;background:var(--accent);color:var(--bg);min-width:16px;height:16px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;padding:0 4px;font-family:var(--mono);margin-left:4px}.nav-pill:empty{display:none}@media(max-width:768px){.nav-pill,#btn-alerts-count{display:none!important}}.header-left-tools{display:flex;align-items:center;gap:4px;margin-left:auto}.burger-btn{display:none;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px}.burger-menu{display:none}@media(max-width:768px){.app-title,.header-nav{display:none}.burger-btn{display:flex;align-items:center}.burger-menu{display:flex;flex-direction:column;position:absolute;top:48px;left:0;right:0;background:var(--bg-panel);border-bottom:1px solid var(--border-strong);box-shadow:0 8px 24px #00000080;z-index:20;padding:4px 0}.burger-menu.hidden{display:none}.burger-item{background:none;border:none;color:var(--text-muted);font-family:var(--font);font-size:14px;font-weight:500;padding:12px 20px;text-align:left;cursor:pointer}.burger-item:hover,.burger-item.active{color:var(--text);background:var(--bg-surface)}}.header-left{display:flex;align-items:center;gap:8px;min-width:0;flex-shrink:1}.header-left h1{font-size:15px;font-weight:600;letter-spacing:-.01em}.version{font-size:11px;color:var(--text-muted);background:var(--bg-panel);padding:2px 6px;border-radius:4px}.header-center{position:absolute;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:16px}.search-trigger{display:flex;align-items:center;gap:8px;padding:6px 14px;background:var(--bg);border:1px solid var(--border-strong);border-radius:8px;color:var(--text-muted);font-family:var(--font);font-size:13px;cursor:pointer;min-width:240px;transition:border-color .15s}.search-trigger:hover{border-color:var(--accent)}.search-trigger-text{flex:1;text-align:left}.search-kbd{font-family:var(--font);font-size:11px;color:var(--text-muted);background:var(--bg-panel);padding:2px 6px;border-radius:4px;border:1px solid var(--border-strong)}.stats{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text-muted)}.divider{color:var(--border)}.spinner{display:inline-block;width:10px;height:10px;border:1.5px solid var(--text-muted);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;vertical-align:middle;margin-right:2px}@keyframes spin{to{transform:rotate(360deg)}}.status-dot:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;margin-right:6px}.status-dot.connected:before{background:var(--green)}.status-dot.disconnected:before{background:var(--critical)}.header-right{display:flex;align-items:center;gap:4px;flex-shrink:0;margin-left:12px}@media(max-width:768px){.header-right{gap:2px}.burger-btn{display:none!important}}select,.header-btn{background:var(--bg-panel);color:var(--text);border:1px solid var(--border);padding:0;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;font-size:13px;cursor:pointer}select:hover,.header-btn:hover{border-color:var(--accent)}#main{flex:1;position:relative;overflow:hidden;min-height:0}.map-zoom-bar{position:absolute;bottom:16px;left:50%;transform:translate(-50%);z-index:5;display:flex;gap:1px;background:var(--bg-panel);border:.5px solid var(--border-strong);border-radius:10px;overflow:hidden;box-shadow:0 4px 16px #0006}.zoom-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-panel);border:none;color:var(--text-muted);cursor:pointer;transition:color .15s,background .15s}.zoom-btn:hover{color:var(--text);background:var(--bg-surface)}.maplibregl-ctrl-bottom-left .maplibregl-ctrl-group{display:none}#scale-indicator{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:5;background:var(--bg-panel);border:.5px solid var(--border-strong);border-radius:6px;padding:6px 14px;font-size:12px;font-family:var(--font);color:var(--text-muted);opacity:0;transition:opacity .3s;pointer-events:none;display:flex;align-items:center;gap:10px}.scale-wrap{position:relative;width:100px;height:10px}.scale-bar{position:absolute;bottom:0;left:0;width:100%;height:2px;background:var(--text-muted)}.scale-bar:before,.scale-bar:after{content:"";position:absolute;bottom:0;width:1px;height:8px;background:var(--text-muted)}.scale-bar:before{left:0}.scale-bar:after{right:0}.scale-ticks{position:absolute;bottom:0;left:0;width:100%;height:5px;display:flex;justify-content:space-between;pointer-events:none}.scale-tick{width:1px;height:100%;background:var(--text-muted);opacity:.5}.scale-tick:first-child,.scale-tick:last-child{opacity:0}#scale-indicator.visible{opacity:1}#map-container{width:100%;height:100%}.maplibregl-ctrl-group{background:var(--bg-panel)!important;border:.5px solid var(--border-strong)!important;box-shadow:0 2px 8px #0006!important}.maplibregl-ctrl-group button{background-color:transparent!important;border-color:var(--border)!important}.maplibregl-ctrl-group button+button{border-top-color:var(--border)!important}.maplibregl-ctrl-group button .maplibregl-ctrl-icon{filter:invert(.8)}[data-theme=light] .maplibregl-ctrl-group{background:var(--bg-panel)!important;border-color:var(--border-strong)!important;box-shadow:0 2px 8px #0000001a!important}[data-theme=light] .maplibregl-ctrl-group button .maplibregl-ctrl-icon{filter:none}[data-theme=light] .maplibregl-ctrl-attrib{background:#f5f3efb3!important;color:var(--text-muted)!important}[data-theme=light] .maplibregl-ctrl-attrib a{color:var(--text-muted)!important}.globe-btn{display:flex!important;align-items:center;justify-content:center;width:29px;height:29px;cursor:pointer;color:var(--text-muted)}.globe-btn:hover{color:var(--text)}.globe-btn svg{filter:none!important}.maplibregl-ctrl-attrib{background:#0f0e0cb3!important;color:var(--text-muted)!important;font-size:10px!important}.maplibregl-ctrl-attrib a{color:var(--text-muted)!important}.panel{position:absolute;top:0;right:0;width:380px;height:100%;background:var(--bg-panel);border-left:1px solid var(--border);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;z-index:5;transition:transform .2s ease}.panel.hidden{transform:translate(100%)}.vessel-panel{position:absolute;top:12px;left:12px;width:380px;max-height:calc(100% - 24px);background:var(--bg-panel);border:.5px solid var(--border-strong);border-radius:var(--radius);box-shadow:0 8px 32px #00000080;z-index:7;display:flex;flex-direction:column;overflow:hidden;transition:transform .2s ease,opacity .2s ease}.vessel-panel.hidden{transform:translate(calc(-100% - 24px));opacity:0;pointer-events:none}.floating-panel{position:absolute;top:12px;right:12px;width:380px;max-height:calc(100% - 24px);background:var(--bg-panel);border:.5px solid var(--border-strong);border-radius:var(--radius);box-shadow:0 8px 32px #00000080;z-index:6;display:flex;flex-direction:column;overflow:hidden;transition:transform .2s ease,opacity .2s ease}.floating-panel.hidden{transform:translate(calc(100% + 24px));opacity:0;pointer-events:none}.floating-panel-wide{width:460px}.floating-panel-left{left:12px;right:auto;width:320px}.floating-panel-left.hidden{transform:translate(calc(-100% - 24px))}.fp-body{overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex:1;min-height:0}@media(max-width:768px){.floating-panel,.floating-panel-left,.vessel-panel,.layers-panel{position:fixed;top:auto;bottom:0;left:0;right:0;width:100%;height:66vh;max-height:66vh;border-radius:16px 16px 0 0;z-index:20;box-shadow:0 -8px 32px #00000080;border:none;transition:transform .3s ease}.floating-panel.hidden,.floating-panel-left.hidden,.vessel-panel.hidden,.layers-panel.hidden{transform:translateY(100%)!important;opacity:1!important;pointer-events:none}.fp-header .layers-grip,.fp-header .panel-close{display:none}.reading-pane .fp-header .panel-close{display:flex}.fp-header:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:36px;height:4px;border-radius:2px;background:var(--text-muted);opacity:.4}.fp-header{position:relative;padding:32px 12px 10px 14px!important;height:auto!important}.fp-header h2{font-size:16px!important}.fp-header:before{top:10px}.panel-resize-handle{display:none}.drawer-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:19}.drawer-backdrop.hidden{display:none}.zs-dropdown-body{padding:0}}.fp-header{display:flex;align-items:center;gap:8px;padding:10px 12px 10px 14px;height:44px;border-bottom:.5px solid var(--border);cursor:grab;-webkit-user-select:none;user-select:none;flex-shrink:0}.fp-header:active{cursor:grabbing}.fp-header h2{font-size:13px;font-weight:600;color:var(--text);margin:0}.fp-header>div{flex:1}.fp-desc{font-size:11px;color:var(--text-muted);margin:1px 0 0;font-weight:400}.fp-header .panel-close{position:static;float:none;margin:0}.vessel-panel #vessel-detail{overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex:1;min-height:0}.fp-footer{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;font-size:10px;color:var(--text-muted);border-top:.5px solid var(--border);flex-shrink:0;min-height:28px}.panel-resize-handle{position:absolute;bottom:0;right:0;width:20px;height:20px;cursor:nwse-resize;z-index:2;margin-right:4px}.panel-resize-handle:after{content:"";position:absolute;bottom:4px;right:4px;width:8px;height:8px;border-right:2px solid var(--text-muted);border-bottom:2px solid var(--text-muted);opacity:.4}.panel-resize-handle:hover:after{opacity:.8}.panel-close{position:sticky;top:0;float:right;margin:12px 12px 0 0;background:var(--bg-panel);border:none;color:var(--text-muted);font-size:20px;cursor:pointer;z-index:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px}.panel-close:hover{color:var(--text)}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border)}.panel-header h2{font-size:15px;font-weight:600}.vc-header{padding:20px 16px 16px;border-bottom:.5px solid var(--border-strong)}.vc-risk{margin-bottom:8px}.vc-type{font-size:11px;color:var(--accent);font-weight:500;letter-spacing:.02em;margin-bottom:2px}.vc-name{font-size:20px;font-weight:700;line-height:1.2;margin-bottom:2px}.vc-name-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.vc-bookmark{background:none;border:none;color:var(--accent);font-size:20px;cursor:pointer;padding:0;line-height:1;flex-shrink:0}.vcard-bookmark{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--accent);font-size:18px;cursor:pointer;line-height:1}.vc-flag{font-size:12px;color:var(--text-muted);margin-top:4px}.vc-locate{display:inline-flex;align-items:center;gap:4px;margin-top:8px;padding:0;background:none;color:var(--accent);border:none;font-size:12px;font-weight:500;font-family:var(--font);cursor:pointer}.vc-locate:hover{opacity:.7}.vc-action-grid{display:grid;gap:8px;margin-top:8px}.vc-action-cell{display:flex;flex-direction:column;gap:2px}.vc-action-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.vc-dest-text{font-size:12px;color:var(--text)}.vc-eta{font-size:11px;color:var(--text-muted)}.vc-action-grid .vc-locate{margin-top:0}.vc-tabs{display:flex;border-bottom:1px solid var(--border);padding:0 16px;gap:0;position:sticky;top:-1px;background:var(--bg-panel);z-index:1}.vc-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-family:var(--font);font-size:12px;font-weight:500;padding:10px 14px;cursor:pointer;transition:color .15s,border-color .15s;display:flex;align-items:center;gap:5px}.vc-tab:hover{color:var(--text)}.vc-tab.active{color:var(--text);border-bottom-color:var(--accent)}.vc-tab-content{display:none}.vc-tab-content.active{display:block}.vc-sanctions-link{color:var(--accent);text-decoration:underline}.reading-pane{position:absolute;top:12px;left:404px;width:440px;max-height:calc(100% - 24px);background:var(--bg-panel);border:.5px solid var(--border-strong);border-radius:var(--radius);box-shadow:0 8px 32px #00000080;z-index:5;display:flex;flex-direction:column;overflow:hidden;transition:transform .3s ease,opacity .3s ease}.reading-pane.hidden{transform:translate(-100%);opacity:0;pointer-events:none}#reading-content{padding:16px;font-size:13px;line-height:1.6;color:var(--text);overflow-y:auto;-webkit-overflow-scrolling:touch}#reading-content h3{font-size:14px;font-weight:600;margin:16px 0 8px;color:var(--text)}#reading-content h3:first-child{margin-top:0}#reading-content a{color:var(--accent);text-decoration:underline}@media(max-width:768px){.reading-pane{position:fixed;top:auto;bottom:0;left:0;right:0;width:100%;height:66vh;max-height:66vh;border-radius:16px 16px 0 0;z-index:21;box-shadow:0 -8px 32px #00000080;border:none}.reading-pane.hidden{transform:translateY(100%);opacity:1}}.vc-read-more{color:var(--accent);text-decoration:underline;cursor:pointer;font-size:12px;background:none;border:none;font-family:var(--font);padding:0}.vc-info-box{margin-top:8px;margin-bottom:12px;background:var(--bg-surface);border-radius:8px;overflow:hidden}.vc-info-box-header{display:flex;align-items:center;gap:6px;padding:8px 10px;font-size:11px;color:var(--text-muted);cursor:pointer}.vc-info-chevron{margin-left:auto;transition:transform .2s}.vc-info-box.expanded .vc-info-chevron{transform:rotate(180deg)}.vc-info-box-body{display:none;padding:0 10px 14px;font-size:11px;line-height:1.5;color:var(--text-muted)}.vc-info-box.expanded .vc-info-box-body{display:block}.vc-news-item{padding:8px 0;border-bottom:.5px solid var(--border)}.vc-news-item:last-child{border-bottom:none}.vc-news-title{font-size:13px;font-weight:500;color:var(--accent);text-decoration:underline;line-height:1.3;display:block}.vc-news-meta{font-size:11px;color:var(--text-muted);margin-top:2px}.vc-news-summary{font-size:12px;color:var(--text-muted);line-height:1.4;margin-top:4px}.vc-sanctions-desc{margin-top:10px;padding:10px 12px;background:var(--bg-surface);border-radius:8px;font-size:12px;line-height:1.5;color:var(--text-muted)}.vc-row-list{flex-direction:column;gap:4px}.vc-row-stacked{flex-direction:column;gap:4px;align-items:flex-start}.vc-row-stacked .vc-val-wrap{text-align:right}.vc-sanctions-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:3px}.vc-sanctions-list li{font-size:13px;padding-left:12px;position:relative}.vc-sanctions-list li:before{content:"";position:absolute;left:0;top:8px;width:4px;height:4px;border-radius:50%;background:var(--accent)}.vc-dest-link-inline{color:var(--accent);text-decoration:underline;cursor:pointer;font-size:12px;font-weight:500;font-family:var(--font);background:none;border:none;padding:0;display:inline}.vcard-dest-link{color:var(--accent);text-decoration:underline;cursor:pointer}.vc-carousel{display:flex;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;border-bottom:.5px solid var(--border);touch-action:pan-x}.vc-carousel::-webkit-scrollbar{display:none}.vc-carousel-slide{flex-shrink:0;width:100%;aspect-ratio:16 / 9;position:relative;scroll-snap-align:start}.vc-carousel-slide img{width:100%;height:100%;object-fit:cover}.vc-photo-delete{position:absolute;top:8px;right:8px;width:28px;height:28px;background:#0f0e0cb3;border:none;border-radius:50%;color:var(--text);font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0 0 2px}.vc-photo-delete:hover{background:var(--critical)}.vc-carousel-upload{background:var(--bg-surface);border:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--accent);cursor:pointer;position:relative;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.vc-carousel-upload:hover{background:var(--bg-panel)}.vc-carousel-upload:active{opacity:.7}.vc-carousel-upload span{font-size:12px;font-weight:500}.vc-section{padding:14px 16px;border-bottom:.5px solid var(--border)}.vc-section h3{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:10px;display:flex;align-items:center;gap:5px}.vc-section h3 svg{opacity:.6}.zs-icon{opacity:1;flex-shrink:0}.vc-grid{display:flex;flex-direction:column;gap:6px}.vc-row{display:flex;justify-content:space-between;align-items:flex-start;font-size:13px}.vc-label{color:var(--text-muted)}.vc-val{font-size:13px;text-align:right}.vc-val-wrap{max-width:200px;word-break:break-word;font-size:11px;line-height:1.3;text-align:right}.vc-score{font-size:13px}.vc-zone-cards{display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}.vc-zone-cards::-webkit-scrollbar{display:none}.vc-zone-card{flex-shrink:0;width:90px;background:var(--bg-surface);border:.5px solid var(--border-strong);border-radius:8px;overflow:hidden;cursor:pointer;transition:border-color .15s}.vc-zone-card:hover{border-color:var(--accent)}.vc-zone-card-svg{display:flex;align-items:center;justify-content:center;padding:6px 4px 2px}.vc-zone-card-name{font-size:9px;text-align:center;padding:2px 4px 6px;color:var(--text-muted);text-transform:capitalize;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vc-alerts{border-bottom:none}.vc-alert{padding:10px 0;border-bottom:.5px solid var(--border)}.vc-alert:last-child{border-bottom:none}.vc-alert-head{display:flex;align-items:center;gap:6px;margin-bottom:3px}.vc-alert-type{font-size:11px;font-weight:600;font-family:var(--mono);text-transform:uppercase;letter-spacing:.02em}.vc-alert-count{font-size:10px;color:var(--text-muted);background:var(--bg-surface);padding:1px 5px;border-radius:3px;font-family:var(--mono)}.vc-alert-time{font-size:11px;color:var(--text-muted);margin-left:auto}.vc-alert-detail{font-size:12px;color:var(--text-muted);line-height:1.4}.vc-empty,.vc-error{padding:20px 16px;color:var(--text-muted);font-size:13px}.skel{background:var(--bg-surface);border-radius:4px;animation:skel-pulse 1.5s ease-in-out infinite}.skel-badge{width:80px;height:22px;margin-bottom:8px}.skel-type{width:60px;height:12px;margin-bottom:4px}.skel-name{width:180px;height:22px;margin-bottom:4px}.skel-flag{width:100px;height:14px}.skel-heading{width:70px;height:10px;margin-bottom:10px}.skel-row{width:100%;height:16px;margin-bottom:8px}@keyframes skel-pulse{0%,to{opacity:.4}50%{opacity:.8}}.badge{display:inline-flex;align-items:center;gap:5px;padding:2px 8px 2px 6px;border-radius:10px;font-size:11px;font-weight:500;background:var(--bg-surface);border:.5px solid var(--border-strong);color:var(--text)}.badge:before{content:"";width:6px;height:6px;border-radius:50%;flex-shrink:0}.badge-critical{color:var(--text)}.badge-critical:before{background:var(--critical)}.badge-high{color:var(--text)}.badge-high:before{background:var(--high)}.badge-medium{color:var(--text)}.badge-medium:before{background:var(--medium)}.badge-low{color:var(--text)}.badge-low:before{background:var(--low)}.badge-info{color:var(--text-muted)}.badge-info:before{background:var(--text-muted)}.badge-clear{color:var(--text)}.badge-clear:before{background:var(--green)}.badge-sanctioned{color:var(--text)}.badge-sanctioned:before{background:var(--critical)}.badge-laden{color:var(--text)}.badge-laden:before{background:#3b82f6}.badge-ballast{color:var(--text)}.badge-ballast:before{background:#8aafcf}.filter-wrap{position:relative}.filter-dropdown{position:absolute;top:calc(100% + 4px);right:0;width:240px;max-height:calc(100dvh - 80px);overflow-y:auto;background:var(--bg-panel);border:.5px solid var(--border-strong);border-radius:8px;box-shadow:0 8px 32px #00000080;z-index:30;padding:12px;-webkit-overflow-scrolling:touch}.filter-dropdown.hidden{display:none}.filter-clear{display:block;width:100%;background:none;border:none;color:var(--text-muted);font-size:11px;font-family:var(--font);text-align:right;padding:0 0 8px;cursor:pointer;border-bottom:.5px solid var(--border);margin-bottom:8px}#filter-body{padding:14px}.filter-clear-row{display:flex;justify-content:flex-end;margin-bottom:8px}.filter-clear{background:none;border:none;color:var(--text-muted);font-family:var(--font);font-size:12px;cursor:pointer;padding:0}.filter-clear:hover{color:var(--accent)}.filter-section{margin-bottom:16px}.filter-section:last-child{margin-bottom:0}.filter-label{font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:6px}.filter-options{display:flex;flex-wrap:wrap;gap:4px}.filter-chip{background:var(--bg-surface);border:.5px solid var(--border-strong);border-radius:6px;color:var(--text-muted);font-size:12px;font-family:var(--font);padding:5px 10px;cursor:pointer;transition:all .1s}.filter-chip:hover{border-color:var(--accent);color:var(--text)}.filter-pill{position:absolute;top:-4px;right:-4px;background:var(--accent);color:var(--bg);font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;font-family:var(--mono)}.filter-pill.hidden{display:none}.filter-chip.active{background:var(--accent);color:var(--bg);border-color:var(--accent);font-weight:500}.alert-item{padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}.alert-item:hover{background:#3b82f60d}.alert-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.alert-type{font-size:12px;font-weight:600;font-family:var(--mono)}.alert-time{font-size:11px;color:var(--text-muted);margin-left:auto}.alert-details{font-size:13px;color:var(--text-muted);line-height:1.4}.alert-vessel{font-size:13px;font-weight:500;color:var(--text)}.vessel-popup .maplibregl-popup-content{background:var(--bg-panel)!important;color:var(--text)!important;border:1px solid var(--border)!important;border-radius:12px!important;padding:0!important;font-family:var(--font)!important;box-shadow:0 8px 32px #0009!important;min-width:280px!important;max-width:340px!important;overflow:hidden}.vessel-popup .maplibregl-popup-tip{border-top-color:transparent!important;border-bottom-color:transparent!important;border-left-color:transparent!important;border-right-color:transparent!important}.vessel-popup.maplibregl-popup-anchor-bottom .maplibregl-popup-tip{border-top-color:var(--bg-panel)!important}.vessel-popup.maplibregl-popup-anchor-top .maplibregl-popup-tip{border-bottom-color:var(--bg-panel)!important}.vessel-popup.maplibregl-popup-anchor-left .maplibregl-popup-tip{border-right-color:var(--bg-panel)!important}.vessel-popup.maplibregl-popup-anchor-right .maplibregl-popup-tip{border-left-color:var(--bg-panel)!important}.vessel-popup.maplibregl-popup-anchor-bottom-left .maplibregl-popup-tip,.vessel-popup.maplibregl-popup-anchor-bottom-right .maplibregl-popup-tip{border-top-color:var(--bg-panel)!important}.vessel-popup.maplibregl-popup-anchor-top-left .maplibregl-popup-tip,.vessel-popup.maplibregl-popup-anchor-top-right .maplibregl-popup-tip{border-bottom-color:var(--bg-panel)!important}.vcard{padding:14px 16px 12px;position:relative}.vcard-badge{margin-bottom:8px}.vcard-type{font-size:11px;color:var(--accent);font-weight:500;letter-spacing:.02em;margin-bottom:2px}.vcard-name{font-size:16px;font-weight:700;line-height:1.2;margin-bottom:4px}.vcard-dest{font-size:11px;color:var(--text-muted);margin-bottom:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vcard-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 16px;margin-bottom:14px}.vcard-cell{display:flex;flex-direction:column;gap:1px}.vcard-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.vcard-val{font-size:13px;font-weight:500}.vcard-cta{display:block;width:100%;padding:10px;background:var(--bg-surface);color:var(--text);border:none;border-top:1px solid var(--border);font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;margin:0 -16px -12px;width:calc(100% + 32px);transition:background .15s}.vcard-cta:hover{background:var(--accent);color:#11100f}.search-toggle{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;display:flex;align-items:center}.search-toggle:hover{color:var(--text)}.search-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f0e0cb3;z-index:40;display:flex;align-items:flex-start;justify-content:center;padding-top:15vh}.search-overlay.hidden{display:none}.search-modal{width:420px;max-width:90vw;background:var(--bg-panel);border:.5px solid var(--border-strong);border-radius:var(--radius);box-shadow:0 16px 48px #0009;overflow:hidden}.search-input-wrap{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:.5px solid var(--border)}.search-input-wrap svg{flex-shrink:0;color:var(--text-muted)}.search-input{width:100%;background:transparent;border:none;color:var(--text);font-size:16px;font-family:var(--font);padding:4px 0;outline:none}.search-results{max-height:360px;overflow-y:auto;-webkit-overflow-scrolling:touch}.search-result{padding:8px 12px;cursor:pointer;transition:background .1s;border-bottom:.5px solid var(--border)}.search-result:hover{background:#c9a96e1a}.search-result:last-child{border-bottom:none}.search-result-name{font-size:13px;font-weight:500;color:var(--text)}.search-result-meta{font-size:11px;color:var(--text-muted);display:flex;gap:8px}.search-result-type{color:var(--accent);font-size:11px}.tracked-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;transition:background .1s;border-bottom:.5px solid var(--border)}.tracked-item:hover{background:#c9a96e0d}.tracked-info{flex:1;min-width:0}.tracked-remove{background:none;border:none;color:var(--accent);cursor:pointer;padding:4px;flex-shrink:0;opacity:.7;transition:opacity .15s}.tracked-remove:hover{opacity:1}.search-empty{padding:12px;font-size:12px;color:var(--text-muted);text-align:center}.zs{position:relative}.zs-btn{display:flex;align-items:center;gap:6px;background:var(--bg-panel);color:var(--text);border:.5px solid var(--border-strong);padding:6px 12px;border-radius:6px;font-size:13px;font-family:var(--font);cursor:pointer;white-space:nowrap;transition:border-color .15s}.zs-btn:hover,.zs-open .zs-btn{border-color:var(--accent)}.zs-chevron{transition:transform .2s}.zs-open .zs-chevron{transform:rotate(180deg)}.zs-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:220px;max-height:400px;overflow-y:auto;background:var(--bg-panel);border:.5px solid var(--border-strong);border-radius:8px;box-shadow:0 8px 32px #00000080;z-index:30;padding:0}.zs-dropdown.hidden{display:none}.zs-group{padding:6px 14px;margin-top:0;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:var(--bg-panel);pointer-events:none;position:sticky;top:-1px;z-index:1}.zs-grid{display:grid;grid-template-columns:1fr 1fr}.zs-item{padding:7px 14px;font-size:13px;cursor:pointer;transition:background .1s;color:var(--text)}.zs-item:hover{background:#c9a96e1a}.zs-item-active{color:var(--accent);font-weight:500}.last-known-marker{width:32px;height:32px;position:relative}.lkm-dot{position:absolute;top:50%;left:50%;width:8px;height:8px;background:var(--critical);border-radius:50%;transform:translate(-50%,-50%)}.lkm-ring{position:absolute;top:50%;left:50%;width:28px;height:28px;border:2px solid var(--critical);border-radius:50%;transform:translate(-50%,-50%);opacity:.5;animation:lkm-pulse 2s ease-out infinite}@keyframes lkm-pulse{0%{transform:translate(-50%,-50%) scale(.5);opacity:.8}to{transform:translate(-50%,-50%) scale(1.5);opacity:0}}@media(min-width:769px){.layers-panel{width:380px}}.layers-grip{color:var(--text-muted);opacity:.4;flex-shrink:0;display:flex;align-items:center}.layers-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:8px 0;min-height:0}.layers-toggle-all{display:flex;align-items:center;justify-content:space-between;padding:8px 20px;border-bottom:.5px solid var(--border);font-size:12px;color:var(--text-muted)}.layers-toggle-all button{background:none;border:1px solid var(--border-strong);border-radius:4px;color:var(--text-muted);font-size:11px;font-family:var(--font);padding:3px 10px;cursor:pointer;transition:all .1s}.layers-toggle-all button:hover{border-color:var(--accent);color:var(--text)}.layers-group{display:flex;align-items:center;justify-content:space-between;padding:10px 20px 4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.group-toggle{transform:scale(.8)}.layer-item{display:flex;align-items:center;gap:12px;padding:10px 20px;cursor:pointer;transition:background .1s}.layer-item:hover{background:#c9a96e0d}.layer-toggle{position:relative;width:36px;height:20px;background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:10px;flex-shrink:0;transition:background .2s,border-color .2s;cursor:pointer}.layer-toggle:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:var(--text-muted);border-radius:50%;transition:transform .2s,background .2s}.layer-toggle.active{background:var(--accent);border-color:var(--accent)}.layer-toggle.active:after{transform:translate(16px);background:var(--bg)}.layer-info{flex:1;min-width:0}.layer-name{font-size:13px;font-weight:500;color:var(--text)}.layer-desc{font-size:11px;color:var(--text-muted);line-height:1.3;margin-top:1px}.layer-color{width:10px;height:10px;border-radius:2px;flex-shrink:0}@media(max-width:768px){.header-center{display:none}.filter-dropdown{position:fixed;top:48px;right:8px;left:8px;width:auto;max-height:calc(100dvh - 60px)}.layers-grip{display:none}.layers-header{cursor:default}.zs-dropdown{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;max-height:100%;border-radius:0;z-index:30;padding:48px 0 0}}
