.route-map.svelte-bdgyfb{border:1px solid var(--color-border-subtle);background:var(--color-surface-raised);border-radius:8px;width:100%;overflow:hidden}.route-map-compact.svelte-bdgyfb{border-color:var(--color-border);background:var(--color-surface)}.route-map-head.svelte-bdgyfb{border-bottom:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;gap:12px;padding:12px 14px 11px;display:flex}.route-map-compact.svelte-bdgyfb .route-map-head:where(.svelte-bdgyfb){background:var(--color-surface-raised);padding:10px 12px 9px}.route-map-kicker.svelte-bdgyfb{color:var(--color-ink-subtle);letter-spacing:.16em;text-transform:uppercase;margin:0 0 3px;font-size:10px;font-weight:700}.route-map-title.svelte-bdgyfb{color:var(--color-ink-strong);letter-spacing:0;text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:14px;font-weight:700;line-height:1.25;overflow:hidden}.route-map-live.svelte-bdgyfb{color:var(--color-accent);letter-spacing:.08em;text-transform:uppercase;flex-shrink:0;align-items:center;gap:7px;font-size:11px;font-weight:700;display:inline-flex}.route-map-live-loading.svelte-bdgyfb{color:var(--color-ink-muted)}.route-map-live-dot.svelte-bdgyfb{background:var(--color-accent);width:8px;height:8px;box-shadow:0 0 12px color-mix(in srgb, var(--color-accent) 80%, transparent);border-radius:999px}.route-map-live-loading.svelte-bdgyfb .route-map-live-dot:where(.svelte-bdgyfb){background:var(--color-ink-faint);box-shadow:none}.route-map-frame.svelte-bdgyfb{aspect-ratio:16/9;background:var(--color-surface);width:100%;min-height:260px;position:relative}.route-map-canvas.svelte-bdgyfb{position:absolute;inset:0}.route-map-compact.svelte-bdgyfb .route-map-frame:where(.svelte-bdgyfb){aspect-ratio:2;min-height:188px}.route-map-loading.svelte-bdgyfb,.route-map-fallback.svelte-bdgyfb{min-height:220px;color:var(--color-ink-muted);letter-spacing:.12em;text-transform:uppercase;background:var(--color-surface);place-items:center;font-size:13px;font-weight:700;display:grid}.route-map-compact.svelte-bdgyfb .route-map-loading:where(.svelte-bdgyfb),.route-map-compact.svelte-bdgyfb .route-map-fallback:where(.svelte-bdgyfb){min-height:188px}.route-map-loading.svelte-bdgyfb{pointer-events:none;position:absolute;inset:0}.route-map-fallback.svelte-bdgyfb{border-top:1px solid var(--color-border-subtle)}.route-map-marker{cursor:pointer;border:0;padding:0;display:block}.route-map-marker-station{background:var(--color-surface);border:3px solid var(--color-accent);border-radius:999px;width:14px;height:14px;box-shadow:0 0 0 2px #0000007a}.route-map-marker-origin,.route-map-marker-destination{background:var(--color-accent);border-color:var(--color-surface-raised);width:20px;height:20px;box-shadow:0 0 0 2px color-mix(in srgb, var(--color-accent) 48%, transparent), 0 6px 14px #00000059;border-radius:6px}.route-map-marker-destination{background:var(--color-surface);border-color:var(--color-accent)}.route-map-marker-vehicle{background:0 0;width:19px;height:19px}.route-map-marker-vehicle-shape{background:var(--color-accent);border:2px solid var(--color-surface-raised);width:19px;height:19px;box-shadow:0 0 0 2px color-mix(in srgb, var(--color-accent) 38%, transparent), 0 6px 16px #00000059;border-radius:5px;display:block;position:relative;transform:rotate(45deg)}.route-map-marker-vehicle.vehicle-bus .route-map-marker-vehicle-shape{background:var(--color-sky-300);border-radius:999px 999px 4px}.route-map-marker-vehicle.vehicle-train .route-map-marker-vehicle-shape{background:var(--color-accent)}.route-map-marker-vehicle.is-late .route-map-marker-vehicle-shape{box-shadow:0 0 0 2px #f59e0bb8,0 0 12px #f59e0b57,0 6px 16px #00000059}.route-map-marker-vehicle.is-very-late .route-map-marker-vehicle-shape{box-shadow:0 0 0 2px #ef4444cc,0 0 14px #ef444470,0 6px 16px #00000059}.route-map-marker-vehicle.is-early .route-map-marker-vehicle-shape{box-shadow:0 0 0 2px #38bdf899,0 6px 16px #00000059}.route-map-marker-vehicle.is-stationary .route-map-marker-vehicle-shape{opacity:.72;filter:saturate(.72)}.route-map-marker-vehicle-arrow{transform:rotate(var(--arrow-bearing));pointer-events:none;display:none;position:absolute;inset:3px}.route-map-marker-vehicle.has-direction .route-map-marker-vehicle-arrow{display:block}.route-map-marker-vehicle-arrow:before{border-right:3.5px solid #0000;border-bottom:7px solid var(--color-surface);content:"";filter:drop-shadow(0 1px 1px #00000073);border-left:3.5px solid #0000;width:0;height:0;position:absolute;top:0;left:50%;transform:translate(-50%)}.route-map-marker-vehicle-arrow:after{background:var(--color-surface);content:"";filter:drop-shadow(0 1px 1px #00000073);border-radius:999px;width:3px;height:7px;position:absolute;top:6px;left:50%;transform:translate(-50%)}.route-map-marker-vehicle-status{border:1.5px solid var(--color-surface-raised);background:var(--color-ok);pointer-events:none;border-radius:999px;width:7px;height:7px;position:absolute;bottom:-5px;right:-5px}.route-map-marker-vehicle.is-early .route-map-marker-vehicle-status{background:#38bdf8}.route-map-marker-vehicle.is-late .route-map-marker-vehicle-status{background:#f59e0b}.route-map-marker-vehicle.is-very-late .route-map-marker-vehicle-status{background:#ef4444}.route-map-marker-vehicle.is-stationary .route-map-marker-vehicle-status{background:var(--color-ink-muted)}.route-map-marker-vehicle-delay{border:1px solid var(--color-surface-raised);background:var(--color-surface);min-width:18px;height:13px;color:var(--color-ink-strong);font-variant-numeric:tabular-nums;pointer-events:none;border-radius:999px;place-items:center;padding:0 4px;font-size:8px;font-weight:900;line-height:1;display:grid;position:absolute;top:-10px;right:-15px;transform:rotate(-45deg)}.route-map-marker-vehicle.is-early .route-map-marker-vehicle-delay{color:#38bdf8}.route-map-marker-vehicle.is-late .route-map-marker-vehicle-delay{color:#f59e0b}.route-map-marker-vehicle.is-very-late .route-map-marker-vehicle-delay{color:#ef4444}.mapboxgl-popup-content{background:var(--color-surface-raised);color:var(--color-ink-strong);border:1px solid var(--color-border);box-shadow:var(--shadow-overlay);border-radius:8px;font-family:inherit;font-size:12px}.mapboxgl-popup-tip{border-top-color:var(--color-surface-raised)}@media (width<=560px){.route-map-head.svelte-bdgyfb{flex-direction:row;align-items:flex-start}.route-map-frame.svelte-bdgyfb{aspect-ratio:4/3;min-height:230px}.route-map-compact.svelte-bdgyfb .route-map-frame:where(.svelte-bdgyfb){aspect-ratio:16/9;min-height:188px}}
