*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0a0e17;--bg-surface: #111827;--bg-panel: #1a2035;--border: #1e293b;--text: #e2e8f0;--text-muted: #94a3b8;--accent: #3b82f6;--critical: #ef4444;--high: #f59e0b;--medium: #eab308;--low: #6b7280;--green: #22c55e;--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:1px solid var(--border);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}#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;z-index:5;transition:transform .2s ease}.panel.hidden{transform:translate(100%)}.panel-close{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;z-index:1}.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}.vessel-header{padding:20px 16px;border-bottom:1px solid var(--border)}.vessel-name{font-size:18px;font-weight:700;margin-bottom:4px}.vessel-meta{font-size:12px;color:var(--text-muted);font-family:var(--mono)}.vessel-section{padding:16px;border-bottom:1px solid var(--border)}.vessel-section h3{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:10px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:13px}.detail-label{color:var(--text-muted)}.detail-value{font-family:var(--mono)}.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-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)}.mapboxgl-popup-content{background:var(--bg-panel)!important;color:var(--text)!important;border:1px solid var(--border)!important;border-radius:8px!important;padding:12px!important;font-family:var(--font)!important;box-shadow:0 4px 20px #00000080!important;max-width:280px!important}.mapboxgl-popup-tip{border-top-color:var(--bg-panel)!important}.mapboxgl-popup-close-button{color:var(--text-muted)!important;font-size:16px!important}.popup-name{font-size:14px;font-weight:600;margin-bottom:6px}.popup-row{display:flex;justify-content:space-between;font-size:12px;padding:2px 0}.popup-label{color:var(--text-muted)}.popup-value{font-family:var(--mono)}.popup-cta{margin-top:8px;padding:6px 0;text-align:center;font-size:12px;font-weight:600;color:var(--accent);cursor:pointer;border-top:1px solid var(--border)}.popup-cta:hover{color:#60a5fa}@media(max-width:768px){.panel{width:100%}.header-center{display:none}}
