*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0f0e0c;--bg-surface: #161412;--bg-panel: #1c1a17;--border: #e8e3d614;--border-strong: #e8e3d62e;--text: #e8e3d6;--text-muted: #b8b3a6;--accent: #c9a96e;--critical: #d6837a;--high: #d4a54a;--medium: #c9a96e;--low: #8a857a;--green: #7ab88a;--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--mono: "JetBrains Mono", "Fira Code", monospace}body{font-family:var(--font);background:var(--bg);color:var(--text);height:100vh;overflow:hidden}#app{display:flex;flex-direction:column;height:100vh}#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}.header-left{display:flex;align-items:center;gap:8px}.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{display:flex;align-items:center}.stats{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text-muted);font-family:var(--mono)}.divider{color:var(--border)}.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:8px}select,.header-btn{background:var(--bg-panel);color:var(--text);border:1px solid var(--border);padding:6px 12px;border-radius:6px;font-size:13px;cursor:pointer}select:hover,.header-btn:hover{border-color:var(--accent)}#main{flex:1;position:relative;overflow:hidden}#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(--mono);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%}.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}#vessel-panel{box-shadow:-4px 0 24px #0006}.panel.hidden{transform:translate(100%)}@media(max-width:768px){#vessel-panel{position:fixed;top:0;left:0;width:100%;height:100%;z-index:20;box-shadow:none;border-left:none}}.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-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-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;overflow:hidden}.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:.6}.vc-grid{display:flex;flex-direction:column;gap:6px}.vc-row{display:flex;justify-content:space-between;align-items:center;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}.vc-score{font-weight:600;font-size:14px}.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-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-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.badge-critical{background:#ef444433;color:var(--critical)}.badge-high{background:#f59e0b33;color:var(--high)}.badge-medium{background:#eab30833;color:var(--medium)}.badge-low{background:#6b728033;color:var(--low)}.badge-clear{background:#22c55e33;color:var(--green)}.badge-sanctioned{background:#ef44444d;color:var(--critical)}#alert-filters{display:flex;gap:8px;padding:10px 16px;border-bottom:.5px solid var(--border-strong)}#alert-filters select{flex:1;background:var(--bg-surface);color:var(--text);border:.5px solid var(--border-strong);padding:6px 10px;border-radius:6px;font-size:12px;font-family:var(--font);cursor:pointer}#alert-filters select:hover{border-color:var(--accent)}.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:220px!important;max-width:260px!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}.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:12px}.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-family:var(--mono);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:#fff}.search-wrap{position:relative;display:flex;align-items:center}.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-input{background:var(--bg-panel);border:.5px solid var(--border-strong);border-radius:6px;color:var(--text);font-size:13px;font-family:var(--font);padding:6px 10px;width:220px;outline:none}.search-input:focus{border-color:var(--accent)}.search-input.hidden{display:none}.search-results{position:absolute;top:calc(100% + 4px);left:0;width:280px;max-height:300px;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}.search-results.hidden{display:none}.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)}.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:4px 0}.zs-dropdown.hidden{display:none}.zs-group{padding:6px 14px;margin-top:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:var(--bg-surface);pointer-events:none;position:sticky;top:0}.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}.alerts-icon{display:none}@media(max-width:768px){.header-center,.alerts-label{display:none}.alerts-icon{display:block}}
