@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}body{background:var(--bg);color:var(--text-primary);flex-direction:column;height:100vh;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}.status-bar{padding:max(9px, env(safe-area-inset-top)) 20px 9px;background:var(--bg-secondary);border-bottom:2px solid var(--border);color:var(--text-secondary);flex-shrink:0;align-items:center;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}}
