@font-face{font-family:Silkscreen;font-style:normal;font-weight:400;font-display:block;src:url(/fonts/silkscreen-400.woff2)format("woff2")}:root{--bg:#fff;--bg-secondary:#f5f5f5;--bg-card:#fff;--border:#e5e5e5;--text-primary:#1a1a1a;--text-secondary:#666;--text-muted:#999;--accent:#2563eb;--accent-muted:#2563eb1a;--cargo:#059669;--cargo-muted:#0596691a;--tanker:#9333ea;--tanker-muted:#9333ea1a;--passenger:#0284c7;--passenger-muted:#0284c71a;--other:#ca8a04;--other-muted:#ca8a041a;--error:#dc2626;--error-bg:#dc262614;--map-bg:#e1e7d5;--map-self:#db2777}@media (prefers-color-scheme:dark){:root{--bg:#0a0a0a;--bg-secondary:#141414;--bg-card:#1a1a1a;--border:#2a2a2a;--text-primary:#e5e5e5;--text-secondary:#a0a0a0;--text-muted:#666;--accent:#60a5fa;--accent-muted:#60a5fa1a;--cargo:#34d399;--cargo-muted:#34d3991a;--tanker:#a855f7;--tanker-muted:#a855f71a;--passenger:#38bdf8;--passenger-muted:#38bdf81a;--other:#fbbf24;--other-muted:#fbbf241a;--error:#f87171;--error-bg:#f8717114;--map-bg:#0a1520;--map-self:#f472b6}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100dvh}body{background:var(--bg);color:var(--text-primary);flex-direction:column;font-family:Silkscreen,monospace;font-size:16px;line-height:1;display:flex;overflow:hidden}.mono{font-family:Silkscreen,monospace}#root{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.layout{flex:1;display:flex;overflow:hidden}.map-pane{background:var(--map-bg);border-right:1px solid var(--border);flex-shrink:0;width:60%;position:relative;overflow:hidden}.list-pane{flex-direction:column;flex:1;min-width:0;padding:8px 10px 0;display:flex;overflow:hidden}.map-style-error{z-index:2;background:var(--bg-secondary);border:1px solid var(--error);color:var(--error);pointer-events:none;border-radius:2px;padding:3px 8px;font-family:Silkscreen,monospace;font-size:11px;position:absolute;top:8px;left:8px}.map-flip-btn,.map-seamark-btn{text-align:center;font-size:18px;line-height:29px}.map-seamark-btn-active{background:var(--accent);color:var(--bg)}.map-info-btn{text-align:center;font-size:17px;line-height:29px}.legend-backdrop{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.legend-panel{background:var(--bg-card);border:2px solid var(--border);width:100%;max-width:720px;max-height:85vh;color:var(--text-primary);border-radius:4px;outline:none;flex-direction:column;display:flex;position:relative}.legend-close{z-index:1;border:1px solid var(--border);background:var(--bg-secondary);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;border-radius:2px;font-family:Silkscreen,monospace;font-size:13px;position:absolute;top:10px;right:10px}.legend-close:hover{color:var(--text-primary);border-color:var(--text-muted)}.legend-body{padding:16px;overflow-y:auto}.legend-body section{margin-top:14px}.legend-body section:first-child{margin-top:0;padding-right:36px}.legend-body h3{color:var(--accent);margin:0 0 6px;font-size:13px}.legend-note{color:var(--text-secondary);margin:0 0 8px;font-size:12px;line-height:1.5}.legend-row{align-items:center;gap:10px;padding:3px 0;font-size:13px;display:flex}.legend-dots{flex-wrap:wrap;gap:4px 14px;margin-bottom:8px;font-size:12px;display:flex}.legend-dot-item{align-items:center;gap:6px;display:inline-flex}.legend-shapes{grid-template-columns:repeat(2,minmax(0,1fr));gap:2px 14px;display:grid}.legend-shape-row{align-items:center;gap:8px;min-width:0;padding:2px 0;font-size:12px;display:flex}.legend-shape-row .legend-label{min-width:0}.legend-shape{flex-shrink:0;align-items:center;width:40px;display:inline-flex}.legend-shape svg{width:auto;height:12px}.legend-icon{text-align:center;flex-shrink:0;width:22px;font-size:15px}.legend-dot{vertical-align:middle;border-radius:50%;width:12px;height:12px;display:inline-block}.legend-label{color:var(--text-primary)}.legend-sublink{display:block}.legend-credits{border-top:1px solid var(--border);margin-top:14px;padding-top:14px}.legend-credit-row{gap:10px;padding:2px 0;font-size:12px;display:flex}.legend-credit-label{min-width:72px;color:var(--text-secondary);flex-shrink:0}.legend-credit-list{color:var(--text-muted)}.legend-body a{color:var(--accent);text-decoration:none}.legend-body a:hover{text-decoration:underline}@media (width>=641px){.legend-body{grid-template-columns:1fr 1fr;align-items:start;gap:18px 32px;display:grid}.legend-body section{margin:0}.legend-body section:first-child{padding-right:0}.legend-credits{flex-wrap:wrap;grid-column:1/-1;align-items:baseline;gap:4px 22px;display:flex}.legend-credits h3{width:100%;margin-bottom:4px}.legend-credit-row{gap:6px;padding:0;display:inline-flex}.legend-credit-label{min-width:0}}.status-bar{background:var(--bg-secondary);border-bottom:2px solid var(--border);color:var(--text-secondary);flex-shrink:0;align-items:center;padding:9px 20px;font-size:16px;display:flex;position:relative}.status-left{white-space:nowrap;text-overflow:ellipsis;flex:1;align-items:center;gap:6px;font-size:16px;display:flex;overflow:hidden}.status-center{white-space:nowrap;align-items:center;gap:6px;font-size:clamp(12px,2.8vw,16px);display:flex;position:absolute;left:calc(60% + 10px);right:20px}.status-right{flex:1}.dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.dot-green{background:#22c55e}.dot-yellow{background:#eab308}.dot-red{background:var(--error)}.location-search{align-items:center;width:100%;display:flex;position:relative}.location-search:before{content:"📍";pointer-events:none;color:var(--text-secondary);z-index:1;font-size:.9em;line-height:1;position:absolute;left:5px}.location-search-input{background:var(--bg-secondary);border:1px solid var(--border);font-size:inherit;cursor:pointer;color:var(--text-secondary);border-radius:2px;width:100%;min-width:130px;padding:2px 8px 2px 24px;font-family:Silkscreen,monospace}.location-search-input::placeholder{color:var(--text-secondary);opacity:.45}.location-search:has(.location-search-input:hover):before{color:var(--accent)}.location-search:has(.location-search-input:focus):before{color:var(--accent)}.location-search-input:hover,.location-search-input:focus{border-color:var(--accent);color:var(--accent);cursor:text;outline:none}.location-suggestions{background:var(--bg-secondary);border:1px solid var(--border);z-index:100;border-top:none;border-radius:0 0 2px 2px;min-width:100%;max-height:200px;margin:0;padding:0;list-style:none;position:absolute;top:100%;left:0;overflow-y:auto}.location-suggestion{cursor:pointer;color:var(--text-secondary);font-family:Silkscreen,monospace;font-size:inherit;white-space:nowrap;text-overflow:ellipsis;padding:4px 10px;overflow:hidden}.location-suggestion:hover,.location-suggestion--active{background:var(--accent-muted);color:var(--accent)}.location-suggestion-spinner{color:var(--text-secondary);font-family:Silkscreen,monospace;font-size:inherit;padding:4px 10px}.filter-bar-wrap{margin-bottom:8px;position:relative}.sort-bar-wrap{margin-bottom:8px}.sort-bar{align-items:center;gap:6px;display:flex}.sort-label{color:var(--text-secondary);white-space:nowrap;flex-shrink:0;font-family:Silkscreen,monospace;font-size:13px}.sort-pill{flex:1}.filter-bar-wrap:after{content:"";background:linear-gradient(to right, transparent, var(--bg));pointer-events:none;width:40px;position:absolute;top:0;bottom:0;right:0}.filter-bar{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;gap:6px;padding:0;display:flex;overflow-x:auto}.filter-bar::-webkit-scrollbar{display:none}.filter-pill{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:3px;padding:4px 12px;font-family:Silkscreen,monospace;font-size:16px;transition:background .1s,color .1s,border-color .1s}.filter-pill-cargo{border-color:var(--cargo)}.filter-pill-tanker{border-color:var(--tanker)}.filter-pill-passenger{border-color:var(--passenger)}.filter-pill-other{border-color:var(--other)}.filter-pill:focus:not(:focus-visible){outline:none}@media (hover:hover){.filter-pill:hover{border-color:var(--accent);color:var(--accent)}.filter-pill-cargo:hover{background:color-mix(in srgb, var(--cargo) 10%, transparent);border-color:var(--cargo);color:var(--text-secondary)}.filter-pill-tanker:hover{background:color-mix(in srgb, var(--tanker) 10%, transparent);border-color:var(--tanker);color:var(--text-secondary)}.filter-pill-passenger:hover{background:color-mix(in srgb, var(--passenger) 10%, transparent);border-color:var(--passenger);color:var(--text-secondary)}.filter-pill-other:hover{background:color-mix(in srgb, var(--other) 10%, transparent);border-color:var(--other);color:var(--text-secondary)}.filter-pill-active:hover{color:var(--bg);border-color:var(--accent)}.filter-pill-active-cargo:hover{color:var(--bg);border-color:var(--cargo);background:var(--cargo)}.filter-pill-active-tanker:hover{color:var(--bg);border-color:var(--tanker);background:var(--tanker)}.filter-pill-active-passenger:hover{color:var(--bg);border-color:var(--passenger);background:var(--passenger)}.filter-pill-active-other:hover{color:var(--bg);border-color:var(--other);background:var(--other)}}.filter-pill-active{background:var(--accent);border-color:var(--accent);color:var(--bg)}.filter-pill-active-cargo{background:var(--cargo);border-color:var(--cargo);color:var(--bg)}.filter-pill-active-tanker{background:var(--tanker);border-color:var(--tanker);color:var(--bg)}.filter-pill-active-passenger{background:var(--passenger);border-color:var(--passenger);color:var(--bg)}.filter-pill-active-other{background:var(--other);border-color:var(--other);color:var(--bg)}.ship-list{flex-direction:column;flex:1;gap:4px;min-height:0;padding:0 0 40px;display:flex;overflow-y:auto}.ship-card{border:1px solid var(--border);background:var(--bg-card);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:3px;padding:10px 12px;transition:border-color .15s}.ship-card:hover{border-color:var(--text-muted)}.ship-card-expanded{border-left:3px solid var(--border)}.ship-card-expanded.ship-card-cargo{border-left-color:var(--cargo)}.ship-card-expanded.ship-card-tanker{border-left-color:var(--tanker)}.ship-card-expanded.ship-card-passenger{border-left-color:var(--passenger)}.ship-card-expanded.ship-card-other{border-left-color:var(--other)}.ship-card-row{align-items:center;gap:8px;min-width:0;display:flex}.type-pill{border-radius:2px;flex-shrink:0;padding:2px 6px;font-size:16px}.type-pill-cargo{background:var(--cargo-muted)}.type-pill-tanker{background:var(--tanker-muted)}.type-pill-passenger{background:var(--passenger-muted)}.type-pill-other{background:var(--other-muted)}.ship-name{white-space:nowrap;text-overflow:ellipsis;flex:1;align-items:center;gap:6px;font-size:16px;font-weight:400;display:flex;overflow:hidden}.ship-flag{flex-shrink:0;font-size:16px}.ship-direction,.ship-speed{color:var(--text-secondary);flex-shrink:0;font-size:16px}.ship-distance{color:var(--text-muted);flex-shrink:0;margin-left:auto;font-size:16px}.ship-icon-row{justify-content:center;margin-top:6px;margin-bottom:2px;display:flex}.ship-card-footer{align-items:center;gap:6px;margin-top:5px;display:flex;position:relative}.ship-lastseen{color:var(--text-muted);font-size:16px}.ship-destination{color:var(--text-muted);white-space:nowrap;pointer-events:none;font-size:16px;position:absolute;left:50%;transform:translate(-50%)}.ship-status-icon{cursor:default;flex-shrink:0;font-size:14px}.ship-photo-probe{display:none}.ship-photo-link{font-size:16px;text-decoration:none}.ship-photo-links{justify-content:flex-end;gap:6px;display:flex}.ship-card-details{border-top:1px solid var(--border);-webkit-user-select:text;user-select:text;flex-direction:column;gap:4px;margin-top:10px;padding-top:10px;display:flex}.detail-row{justify-content:space-between;gap:12px;font-size:16px;display:flex}.detail-label{color:var(--text-muted);flex-shrink:0}.detail-value{color:var(--text-primary);text-align:right}.detail-cols{display:flex}.detail-col{flex-direction:column;flex:1;gap:4px;display:flex}.detail-col:first-child{border-right:1px solid var(--border);padding-right:10px}.detail-col:last-child{padding-left:10px}.loading,.empty-state{text-align:center;color:var(--text-muted);padding:40px 0;font-size:16px}.error-state{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:32px 16px;display:flex}.error-state-inner{text-align:center;max-width:320px}.error-state-title{margin-bottom:10px;font-size:24px;font-weight:400}.error-state-body{color:var(--text-secondary);font-size:16px;line-height:1.6}@media (width<=640px){.layout{flex-direction:column}.map-pane{border-right:none;border-bottom:1px solid var(--border);width:100%;height:45vh}.status-center{margin-left:auto;position:static}.status-right{display:none}.status-bar{padding:7px 12px;font-size:12px}.status-bar--error .status-center{display:none}.location-search-input{font-size:16px}.filter-pill{padding:3px 8px;font-size:12px}.type-pill{padding:1px 4px;font-size:12px}.ship-name,.ship-flag,.ship-direction,.ship-speed,.ship-distance,.ship-lastseen,.ship-destination,.ship-status-icon,.detail-row{font-size:12px}.list-pane{padding:6px 6px 0}.ship-card{padding:8px 10px}}
