:root{--color-text: #172026;--color-muted: #69736c;--color-subtle: #5f6b63;--color-surface: #ffffff;--color-page: #f4f6f4;--color-border: #dbe3dd;--color-soft: #edf5f1;--color-warning-bg: #fff7ed;--color-warning: #9a3412;--color-error-bg: #fff4f1;--color-error-border: #efc5bd;--color-error: #9a3412;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--radius: 8px;--shadow-soft: 0 8px 24px rgba(20, 35, 28, .08);--shadow-float: 0 14px 34px rgba(20, 35, 28, .16);--sidebar-width: 320px}:root{color:var(--color-text);background:var(--color-page);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button{font:inherit}img{max-width:100%}.app-shell{min-height:100dvh;padding:clamp(var(--space-3),2vw,var(--space-5))}.page-frame{--page-shell-padding: clamp(var(--space-3), 2vw, var(--space-5));--page-layout-gap: var(--space-3);--page-sidebar-width: var(--sidebar-width);--page-topbar-height: 68px;--page-main-extra-height: 48px;--page-main-available-height: calc(100dvh - var(--page-shell-padding) - var(--page-shell-padding) - var(--page-topbar-height) - var(--page-layout-gap) - var(--page-main-extra-height));--page-main-width: min( calc(var(--page-main-available-height) * var(--map-aspect-ratio, .5625)), calc(100vw - var(--page-sidebar-width) - var(--page-layout-gap) - var(--page-shell-padding) - var(--page-shell-padding)) );--page-main-height: calc(var(--page-main-width) * var(--map-height-ratio, 1.7778) + var(--page-main-extra-height));--page-content-width: calc(var(--page-main-width) + var(--page-layout-gap) + var(--page-sidebar-width));display:grid;width:var(--page-content-width);max-width:100%;min-height:calc(100dvh - var(--page-shell-padding) - var(--page-shell-padding));margin:0 auto;align-content:center;gap:var(--page-layout-gap)}.home-content{position:relative}.page-view-enter{animation:page-view-enter .22s ease-out both}.page-layout{display:grid;width:var(--page-content-width);max-width:100%;min-width:0;grid-template-columns:minmax(0,var(--page-main-width)) var(--page-sidebar-width);gap:var(--page-layout-gap);align-items:start}.page-main{width:var(--page-main-width);max-width:100%;min-width:0}.page-sidebar{width:var(--page-sidebar-width);min-width:0}@keyframes page-view-enter{0%{opacity:0}to{opacity:1}}@media(prefers-reduced-motion:reduce){.page-view-enter,.page-frame,.initial-loading-overlay,.initial-loading-overlay__progress-row i:before,.route-card-page--active,.overflow-marquee--active .overflow-marquee__track,.icon-button--locating,.icon-button--locating svg{animation:none}}@media(min-width:801px){.app-shell{height:100dvh;overflow:hidden}}.topbar{display:flex;min-height:68px;align-items:center;justify-content:space-between;gap:var(--space-3);padding:10px;border:1px solid var(--color-border);border-radius:var(--radius);background:#ffffffeb;box-shadow:var(--shadow-soft)}.brand-lockup,.top-actions{display:flex;min-width:0;align-items:center}.brand-lockup{gap:10px}.brand-mark{display:block;flex:0 0 auto;width:38px;height:38px}.brand-mark img{display:block;width:100%;height:100%}.topbar h1{margin:0;overflow:hidden;font-size:clamp(20px,2.4vw,28px);line-height:1.05;letter-spacing:0;text-overflow:ellipsis;white-space:nowrap}.top-actions{flex:0 0 auto;gap:var(--space-1);height:46px;padding:3px;border:1px solid var(--color-border);border-radius:var(--radius);background:#f4f6f4}.icon-button,.route-card{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer}.icon-button{display:grid;width:38px;height:38px;place-items:center;border-radius:var(--radius)}.icon-button--locating{background:var(--color-soft);color:#166534;animation:locating-pulse 1.35s ease-in-out infinite}.icon-button--locating svg{animation:locating-spin 1.05s linear infinite}@keyframes locating-pulse{0%,to{box-shadow:inset 0 0 0 1px #16653400}50%{box-shadow:inset 0 0 0 1px #16653447,0 0 0 3px #16653414}}@keyframes locating-spin{to{transform:rotate(360deg)}}.announcement-board-button{position:relative;display:grid;flex:0 0 auto;width:30px;height:30px;place-items:center;padding:0;border:0;border-radius:999px;background:transparent;color:#60736a;cursor:pointer}.announcement-board-button span{position:absolute;top:1px;right:-1px;display:inline-flex;min-width:15px;height:15px;align-items:center;justify-content:center;padding:0 var(--space-1);border-radius:999px;border:1px solid rgba(22,101,52,.16);background:#16a34a;color:#fff;font-size:10px;font-weight:900;line-height:1}.announcement-board-button--open,.announcement-board-button:hover{background:var(--color-soft);color:#166534}.announcement-board-button:not(.announcement-board-button--unread) span{border-color:#d8e2dc;background:#eef3ef;color:#60736a}.connection{display:inline-flex;min-height:34px;align-items:center;gap:7px;padding:0 9px;border-radius:var(--radius);background:var(--color-soft);color:#166534;font-size:13px;font-weight:800;white-space:nowrap}.connection--connecting{background:var(--color-warning-bg);color:var(--color-warning)}@media(max-width:800px){.page-layout{grid-template-columns:1fr}.route-cards{order:-1}}.map-stage{display:grid;min-width:0;min-height:0;place-items:start}.route-cards{display:grid;min-width:0;align-content:start;gap:var(--space-2)}.route-card-strip,.route-card-page{display:grid;gap:var(--space-2)}.route-card{--route-title-line-height: 20px;--route-summary-line-height: 16px;--route-summary-lines: 2;--route-summary-gap: 2px;--route-content-gap: 4px;--route-color: #166534;container-type:inline-size;display:grid;grid-template-columns:5px minmax(0,1fr) auto;height:90px;align-items:center;gap:var(--space-3);padding:9px 14px;border-radius:var(--radius);text-align:left;box-shadow:var(--shadow-soft)}.route-card__color{width:5px;height:64px;border-radius:99px}.route-card__body{display:grid;min-width:0;align-content:center;align-items:center;grid-template-rows:var(--route-title-line-height) auto;gap:var(--route-content-gap)}.route-card strong{display:flex;align-items:center;margin:0;overflow:hidden;font-size:18px;line-height:var(--route-title-line-height);text-overflow:ellipsis;white-space:nowrap}.route-card__title-compact{display:none}.route-card>svg{opacity:.9}@media(max-width:800px){.route-card{grid-template-columns:4px minmax(0,1fr);height:82px;gap:var(--space-2);padding:7px 10px}.route-card>svg{display:none}.route-card__color{width:4px;height:60px}}@container (max-width: 250px){.route-card__title-full{display:none}.route-card__title-compact{display:inline}}.route-summary-list{display:grid;max-height:calc(var(--route-summary-line-height) * var(--route-summary-lines) + var(--route-summary-gap));align-content:center;gap:var(--route-summary-gap);overflow:hidden}.route-eta-line{display:grid;grid-template-columns:max-content minmax(0,1fr);align-items:center;gap:6px;min-width:0;height:var(--route-summary-line-height)}.route-eta-line--plain{grid-template-columns:minmax(0,1fr)}.route-eta-line__label{display:inline-flex;width:var(--label-width, auto);height:16px;align-items:center;justify-content:center;padding:0 5px;border-radius:5px;border:1px solid color-mix(in srgb,var(--route-color) 32%,transparent);background:color-mix(in srgb,var(--route-color) 12%,#ffffff);color:var(--route-color);font-size:11px;font-weight:900;line-height:1;white-space:nowrap}.route-eta-line__text{display:block;min-width:0;overflow:hidden;color:#5f6b63;font-size:13px;line-height:var(--route-summary-line-height, 1.35em);text-overflow:ellipsis;white-space:nowrap}.overflow-marquee{position:relative;display:block;overflow:hidden;min-width:0;height:var(--route-summary-line-height, 1.35em);color:var(--color-subtle);font-size:13px;line-height:var(--route-summary-line-height, 1.35em);white-space:nowrap}.overflow-marquee__measure{position:absolute;visibility:hidden;white-space:nowrap;pointer-events:none}.overflow-marquee__track{position:absolute;inset:0 auto auto 0;display:flex;width:max-content;min-width:100%;height:var(--route-summary-line-height, 1.35em);align-items:center;gap:22px;white-space:nowrap;will-change:transform}.overflow-marquee__track>span{display:block;flex:0 0 auto;min-width:max-content}.overflow-marquee--active .overflow-marquee__track{animation:summary-marquee 7s linear infinite}@keyframes summary-marquee{0%{transform:translate(0)}to{transform:translate(calc(-50% - 11px))}}.notice{display:flex;align-items:center;gap:var(--space-2);padding:10px 12px;border:1px solid #d7e2dc;border-radius:var(--radius);background:var(--color-surface);color:#435048}.notice--error{border-color:var(--color-error-border);background:var(--color-error-bg);color:var(--color-error)}.floating-toast{position:fixed;top:82px;left:50%;z-index:80;display:inline-flex;max-width:min(720px,calc(100% - 28px));min-height:42px;align-items:center;gap:var(--space-2);padding:0 14px;border:1px solid #d7e2dc;border-radius:var(--radius);background:#fffffff5;color:#435048;font-size:14px;font-weight:800;white-space:nowrap;box-shadow:var(--shadow-float);transform:translate(-50%);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.loading{display:grid;min-height:360px;place-items:center;color:var(--color-muted)}.initial-loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120;display:grid;place-items:center;background:var(--color-page);color:var(--color-text)}.initial-loading-overlay.presence-enter{animation:none}.initial-loading-overlay.presence-exit{animation:modal-backdrop-exit .26s ease-in both}.initial-loading-overlay__content{display:grid;justify-items:center;gap:var(--space-4)}.initial-loading-overlay__content img{display:block;width:54px;height:54px;filter:drop-shadow(0 8px 18px rgba(20,35,28,.14))}.initial-loading-overlay__progress-row{display:grid;grid-template-columns:1fr;justify-items:center;gap:var(--space-2)}.initial-loading-overlay__progress-row span{color:var(--color-muted);font-size:13px;font-weight:800;white-space:nowrap}.initial-loading-overlay__progress-row i{position:relative;display:block;overflow:hidden;width:220px;height:6px;border-radius:999px;background:#dfe8e2}.initial-loading-overlay__progress-row i{order:1}.initial-loading-overlay__progress-row span{order:2}.initial-loading-overlay__progress-row i:before{position:absolute;top:0;right:0;bottom:0;left:0;width:42%;border-radius:inherit;background:linear-gradient(90deg,#16653414,#16653494,#16653414);animation:loading-progress 1.2s ease-in-out infinite;content:""}@keyframes loading-progress{0%{transform:translate(-110%)}to{transform:translate(260%)}}.site-footer{display:grid;width:100%;justify-items:center;gap:5px;color:var(--color-muted);font-size:12px;font-weight:700;line-height:1.35;text-align:center}.site-footer p{margin:0}.site-footer a{margin:0;color:inherit;text-decoration:none}.site-footer__beian-group{display:inline-flex;flex-wrap:wrap;justify-content:center;column-gap:0;row-gap:5px}.site-footer__beian-group>p{display:inline-flex;align-items:center;gap:6px;margin:0;white-space:nowrap}.site-footer__beian-group>p:first-child{gap:0}.site-footer__beian-group.site-footer__beian-group--separator>p:first-child:after{content:"|";margin:0 4px;color:var(--color-muted)}.site-footer__beian a{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.site-footer a:hover,.site-footer a:focus-visible{color:var(--color-text);text-decoration:underline}.site-footer__police img{display:block;width:16px;height:16px;flex:0 0 auto}.site-footer--home-side{padding-top:var(--space-1)}.site-footer--home-mobile{display:none}@media(max-width:800px){.app-shell{padding:10px}.page-frame{--page-main-height: auto;width:100%;align-content:start}.topbar{min-height:58px;gap:var(--space-2);padding:var(--space-2)}.topbar h1{font-size:20px}.top-actions{height:40px;gap:1px;padding:2px}.connection{min-height:30px;padding:0 7px;font-size:12px}.icon-button{width:32px;height:32px}.route-card strong{font-size:16px}.site-footer--home-side{display:none}.site-footer--home-mobile{display:grid;width:100%;max-width:100%;position:relative;box-sizing:border-box;margin-top:var(--space-1);padding:0 var(--space-2) var(--space-1)}.page-layout{width:100%}.map-stage{width:100%;place-items:stretch}.route-cards{width:100%;overflow:hidden}.route-card-strip{display:flex;overflow-x:auto;gap:var(--space-2);scroll-snap-type:x mandatory;scrollbar-width:none;cursor:grab;touch-action:pan-x;-webkit-user-select:none;user-select:none}.route-card-strip--dragging{cursor:grabbing}.route-card-strip::-webkit-scrollbar{display:none}.route-card-page{display:grid;flex:0 0 100%;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-2);scroll-snap-align:start}.route-card-page--active{animation:route-card-page-active .18s ease-out both}.route-card-dots{display:flex;justify-content:center;gap:6px;padding:2px 0 0}.route-card-dot{width:6px;height:6px;padding:0;border:0;border-radius:999px;background:#cdd8d1;cursor:pointer}.route-card-dot--active{width:16px;background:#166534}}@media(min-width:801px){.route-card-dots{display:none}}@keyframes route-card-page-active{0%{opacity:.82;transform:scale(.985)}to{opacity:1;transform:scale(1)}}@media(max-width:800px){.initial-loading-overlay__content{gap:var(--space-3)}.initial-loading-overlay__content img{width:48px;height:48px}.initial-loading-overlay__progress-row i{width:min(220px,calc(100vw - 96px))}}@media(max-width:380px){.topbar h1{font-size:18px}.route-card strong{font-size:15px}.connection svg{display:none}}.map-shell{display:flex;overflow:hidden;width:var(--page-main-width, min( calc((100dvh - 130px) * var(--map-aspect-ratio, .5625)), calc(100vw - var(--sidebar-width) - var(--space-3) - clamp(var(--space-3), 2vw, var(--space-5)) * 2) ));height:var(--page-main-height, auto);max-width:100%;flex-direction:column;align-items:center;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface)}.map-viewport{position:relative;flex:1 1 auto;overflow:hidden;aspect-ratio:var(--map-aspect-ratio);width:100%;min-width:0;border:4px solid #ffffff;border-bottom-width:0;border-radius:var(--radius) var(--radius) 0 0;background:#e9eee8;touch-action:pan-y;-webkit-user-select:none;user-select:none}.map-viewport--zoomed{touch-action:none}.map-canvas{position:relative;width:100%;height:100%;min-width:0;cursor:grab;transform-origin:0 0}.map-canvas--zoomed{cursor:grab;transform:translate(var(--map-translate-x, 0),var(--map-translate-y, 0)) scale(var(--map-scale, 1))}.map-viewport:active .map-canvas--zoomed{cursor:grabbing}.map-image,.map-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.map-image{object-fit:fill;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.map-overlay{pointer-events:none}.map-route-path{opacity:0;transition:opacity .18s ease}.map-route-path--visible{opacity:1}.map-reset-button,.map-layer-menu__trigger{position:absolute;z-index:6;display:grid;width:38px;height:38px;place-items:center;padding:0;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);cursor:pointer;box-shadow:0 8px 18px #14231c24}.map-reset-button{top:10px;left:10px}.map-layer-menu{position:absolute;right:var(--space-3);bottom:var(--space-3);z-index:6}.map-layer-menu__trigger{position:static}.map-station,.map-vehicle{position:absolute;z-index:3;transform:translate(-50%,-50%) scale(var(--map-marker-scale, 1));transform-origin:center}.map-station{width:26px;height:26px;padding:0;border:0;border-radius:50%;background:transparent;cursor:pointer}.map-station span{display:block;width:12px;height:12px;margin:7px;border:2px solid #ffffff;border-radius:50%;background:#22312a;box-shadow:0 2px 8px #00000059;pointer-events:none}.map-vehicle{--vehicle-status-corner: transparent;--vehicle-status-corner-stroke: rgba(255, 255, 255, .92);display:grid;width:32px;height:32px;place-items:center;padding:0;border:2px solid #ffffff;border-radius:var(--radius);color:#fff;cursor:pointer;line-height:0;box-shadow:0 6px 14px #00000047}.map-marker-enter{animation:map-marker-enter .18s ease-out both}.map-marker-exit{pointer-events:none;animation:map-marker-exit .16s ease-in both}.map-vehicle:before,.map-vehicle:after{position:absolute;top:0;right:0;border-top-right-radius:6px;clip-path:polygon(0 0,100% 0,100% 100%);content:"";opacity:0;pointer-events:none}.map-vehicle:before{width:15.5px;height:15.5px;background:var(--vehicle-status-corner-stroke)}.map-vehicle:after{width:13px;height:13px;background:var(--vehicle-status-corner)}.map-vehicle svg{position:relative;z-index:1;display:block;pointer-events:none}.map-vehicle--waiting{--vehicle-status-corner: #b5c3d1}.map-vehicle--location-issue{--vehicle-status-corner: #fa2828}.map-vehicle--full{--vehicle-status-corner: #f2e422}.map-vehicle--waiting:before,.map-vehicle--location-issue:before,.map-vehicle--full:before,.map-vehicle--waiting:after,.map-vehicle--location-issue:after,.map-vehicle--full:after{opacity:1}.map-legend{position:absolute;right:var(--space-3);bottom:var(--space-3);z-index:5;display:flex;flex-wrap:wrap;gap:var(--space-2)}.map-legend--menu{right:0;bottom:44px;display:grid;min-width:148px;padding:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);box-shadow:var(--shadow-float)}.map-legend--menu.presence-enter{animation:presence-card-enter .18s ease-out both}.map-legend--menu.presence-exit{animation:presence-card-exit .16s ease-in both}.map-legend button{display:inline-flex;min-height:34px;align-items:center;gap:7px;padding:0 10px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:13px;font-weight:700}.map-legend button.map-legend__toggle--active{border-color:var(--route-color, var(--color-border));box-shadow:0 6px 16px #14231c1a}.map-legend button.map-legend__toggle:not(.map-legend__toggle--active){border-style:dashed;border-color:var(--route-color, #93a29a);background:#f5faf7}.map-legend span{position:relative;flex:0 0 auto;width:10px;height:10px;border-radius:50%;box-shadow:0 0 0 1px #14231c1f}.vehicle-map-legend{display:flex;width:100%;flex-wrap:wrap;align-items:center;justify-content:center;gap:var(--space-2);padding:10px 12px;border-radius:0 0 7px 7px;background:var(--color-surface);color:#435048;font-size:13px;font-weight:800}.vehicle-map-legend span{display:inline-flex;min-height:24px;align-items:center;gap:6px}.vehicle-legend-dot{position:relative;display:inline-block;overflow:hidden;width:12px;height:12px;border:2px solid #ffffff;border-radius:4px;box-shadow:0 0 0 1px #14231c24}.vehicle-legend-dot--waiting{background:#b5c3d1}.vehicle-legend-dot--location-issue{background:#fa2828}.vehicle-legend-dot--full{background:#f2e422}@keyframes map-marker-enter{0%{opacity:0;transform:translate(-50%,-50%) scale(calc(var(--map-marker-scale, 1) * .82))}to{opacity:1;transform:translate(-50%,-50%) scale(var(--map-marker-scale, 1))}}@keyframes map-marker-exit{0%{opacity:1;transform:translate(-50%,-50%) scale(var(--map-marker-scale, 1))}to{opacity:0;transform:translate(-50%,-50%) scale(calc(var(--map-marker-scale, 1) * .82))}}@media(prefers-reduced-motion:reduce){.map-route-path{transition:none}.map-marker-enter,.map-marker-exit,.map-legend--menu.presence-enter,.map-legend--menu.presence-exit{animation:none}}@media(max-width:800px){.map-shell{width:100%;height:auto;max-width:100%}.map-reset-button{top:8px;left:8px;width:32px;height:32px}.map-vehicle{width:28px;height:28px}}.selection-card,.selection-panel{position:absolute;left:var(--space-3);bottom:var(--space-3);z-index:5;width:min(400px,calc(100% - var(--space-6)));padding:14px;border:1px solid var(--color-border);border-radius:var(--radius);background:#fffffff5;box-shadow:var(--shadow-float);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.selection-card.presence-enter{animation:presence-card-enter .18s ease-out both}.selection-card.presence-exit{animation:presence-card-exit .16s ease-in both}.selection-card__header{display:flex;min-width:0;align-items:flex-start;justify-content:space-between;gap:var(--space-3)}.selection-card__header>div{min-width:0}.selection-card__trailing{display:inline-flex;flex:0 0 auto;color:#60736a}.selection-panel--sidebar{position:relative;inset:auto;display:block;width:100%}@media(min-width:801px){.selection-panel--map{display:none}}@media(max-width:800px){.selection-panel--sidebar{display:none}}.panel-close{position:absolute;top:var(--space-2);right:var(--space-2);display:grid;width:28px;height:28px;place-items:center;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:#435048;cursor:pointer}.selection-card p,.selection-panel p{margin:0 32px var(--space-1) 0;color:var(--color-muted);font-size:12px;font-weight:700}.selection-card h2,.selection-panel h2{margin:0 32px var(--space-3) 0;font-size:20px;line-height:1.2}.selection-card__header h2{margin:0 0 var(--space-3);overflow:hidden;color:var(--color-text);text-overflow:ellipsis;white-space:nowrap}.selection-card__header p+h2{margin-top:0}.selection-panel__divider{height:1px;margin:0 0 var(--space-3);background:#edf0ed}.selection-card dl,.selection-panel dl{display:grid;gap:var(--space-2);margin:0}.selection-card dl>div:not(.selection-panel__group),.selection-panel dl>div:not(.selection-panel__group){display:grid;grid-template-columns:max-content minmax(120px,1fr);align-items:baseline;gap:14px}.selection-panel__eta-row{display:grid;min-width:0;grid-template-columns:minmax(0,1fr) max-content;align-items:baseline;gap:10px;container-type:inline-size}.selection-panel__group{display:grid;gap:var(--space-2)}.selection-card dl strong,.selection-panel dl strong{font-size:13px}.selection-card dt,.selection-panel dt{display:inline-flex;min-width:0;flex-wrap:nowrap;align-items:center;gap:5px;overflow:hidden;color:var(--color-muted);white-space:nowrap}.selection-card dd,.selection-panel dd{min-width:0;margin:0;overflow:hidden;font-weight:700;text-align:right;text-overflow:ellipsis;white-space:nowrap}.selection-panel__eta-label{overflow:hidden;min-width:0;color:inherit;font-weight:inherit;text-overflow:ellipsis;white-space:nowrap}.eta-chip{display:inline-flex;min-width:0;height:16px;align-items:center;gap:3px;padding:0 5px;border-radius:5px;font-size:11px;font-weight:900;line-height:1;white-space:nowrap}.eta-chip--load{border:1px solid color-mix(in srgb,var(--route-color, #166534) 32%,transparent);background:color-mix(in srgb,var(--route-color, #166534) 12%,#ffffff);color:var(--route-color, #166534)}.eta-chip--status{border:1px solid #ead3bd;background:var(--color-warning-bg);color:var(--color-warning)}.eta-chip--location,.eta-chip--passenger{padding:0 4px}.eta-chip svg{display:block;flex:0 0 auto}.eta-chip-queue{display:inline-flex;min-width:0;flex:0 0 auto}.eta-chip-queue__inline{display:inline-flex;min-width:0;align-items:center;gap:5px}.eta-chip-stack{display:none}@container (max-width: 340px){.eta-chip-queue--multi .eta-chip-queue__inline{display:none}.eta-chip-queue--multi .eta-chip-stack{position:relative;display:inline-grid;align-items:center;justify-items:center;isolation:isolate;padding-right:5px;padding-bottom:3px}.eta-chip-stack__item{grid-area:1 / 1;justify-content:center;justify-self:center;text-align:center;will-change:opacity,transform}.eta-chip-stack__item--1{z-index:2;animation:eta-chip-stack-primary 6s ease-in-out infinite}.eta-chip-stack__item--2{z-index:1;animation:eta-chip-stack-secondary 6s ease-in-out infinite}}@keyframes eta-chip-stack-primary{0%,42%,to{z-index:2;opacity:1;transform:translate(0) scale(1)}50%,92%{z-index:1;opacity:.56;transform:translate(5px,3px) scale(.96)}}@keyframes eta-chip-stack-secondary{0%,42%,to{z-index:1;opacity:.56;transform:translate(5px,3px) scale(.96)}50%,92%{z-index:2;opacity:1;transform:translate(0) scale(1)}}@media(prefers-reduced-motion:reduce){.selection-card.presence-enter,.selection-card.presence-exit,.announcement-modal-backdrop.presence-enter,.announcement-modal-backdrop.presence-exit,.announcement-modal-backdrop.presence-enter .announcement-modal,.announcement-modal-backdrop.presence-exit .announcement-modal,.eta-chip-stack__item{animation:none}.eta-chip-stack__item:not(:first-child){display:none}}.announcement-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;display:grid;place-items:center;padding:var(--space-6);background:#1720262e;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.announcement-modal-backdrop.presence-enter{animation:modal-backdrop-enter .18s ease-out both}.announcement-modal-backdrop.presence-exit{animation:modal-backdrop-exit .16s ease-in both}.announcement-modal-backdrop.presence-enter .announcement-modal{animation:presence-card-enter .18s ease-out both}.announcement-modal-backdrop.presence-exit .announcement-modal{animation:presence-card-exit .16s ease-in both}.announcement-modal{display:grid;overflow:hidden;width:min(500px,calc(100vw - 48px));max-height:min(640px,calc(100dvh - 48px));grid-template-rows:auto minmax(0,1fr) auto;border:1px solid #d7e2dc;border-radius:var(--radius);background:var(--color-surface);color:#435048;box-shadow:0 24px 56px #14231c33}@keyframes presence-card-enter{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}@keyframes presence-card-exit{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.98)}}@keyframes modal-backdrop-enter{0%{opacity:0}to{opacity:1}}@keyframes modal-backdrop-exit{0%{opacity:1}to{opacity:0}}.announcement-modal__header{display:flex;align-items:center;justify-content:center;padding:16px 18px 14px;border-bottom:1px solid #edf0ed}.announcement-modal__header strong{color:var(--color-text);font-size:15px}.announcement-modal__body{display:grid;overflow-y:auto;align-content:start;gap:5px;padding:var(--space-1) 18px var(--space-4)}.announcement-modal article{display:grid;gap:5px;padding-top:10px;border-top:1px solid #edf0ed}.announcement-modal article:first-child{border-top:0}.announcement-modal h2,.announcement-modal p{margin:0}.announcement-modal h2{color:var(--color-text);font-size:15px}.announcement-modal p{color:#435048;font-size:14px;line-height:1.55;white-space:pre-wrap}.announcement-modal__footer{display:flex;justify-content:flex-end;padding:14px 18px 16px;border-top:1px solid #edf0ed}.announcement-modal__footer button{min-height:30px;padding:0 18px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:#435048;cursor:pointer;font-size:13px;font-weight:800}@media(max-width:800px){.announcement-modal-backdrop{padding:var(--space-3)}.announcement-modal{width:min(320px,calc(100vw - 32px))}.selection-card,.selection-panel{right:var(--space-2);bottom:var(--space-2);left:var(--space-2);width:auto;padding:var(--space-3)}.selection-card h2,.selection-panel h2{font-size:18px}}.route-page{display:grid;min-height:100dvh;align-items:center;justify-items:center}.route-detail-content{--map-legend-height: var(--page-main-extra-height)}.route-detail-topbar{width:100%}.route-detail-title{display:flex;flex:1 1 auto;min-width:0;align-items:baseline;gap:var(--space-1)}.route-detail-topbar h1{margin:0;overflow:hidden;font-size:clamp(20px,2.4vw,28px);line-height:1.05;text-align:left;text-overflow:ellipsis;white-space:nowrap}.route-detail-title span{flex:0 0 auto;color:var(--color-muted);font-size:13px;font-weight:800;white-space:nowrap}.route-info-button{flex:0 0 auto}.route-back-button{width:38px;height:38px}.route-timeline-shell{--timeline-vehicle-lane: 48px;--timeline-gap: var(--space-2);--timeline-dot-column: 34px;--timeline-axis-left: calc(var(--timeline-vehicle-lane) + var(--timeline-gap) + var(--timeline-dot-column) / 2);--station-row-left: calc(var(--timeline-vehicle-lane) + 2px);--station-dot-hit-column: 40px;--station-dot-offset: 16px;--vehicle-road-width: 30px;--vehicle-road-left: 9px;--vehicle-card-width: 42px;--vehicle-card-left: 3px;--vehicle-stub-gap: 7px;position:relative;overflow:hidden;height:var(--page-main-height);min-width:0;border-radius:var(--radius);background:transparent}.route-timeline-shell:before,.route-timeline-shell:after{position:absolute;right:0;left:0;z-index:8;height:34px;pointer-events:none;content:""}.route-timeline-shell:before{top:0;background:linear-gradient(var(--color-page) 10%,rgba(244,246,244,0))}.route-timeline-shell:after{bottom:0;background:linear-gradient(rgba(244,246,244,0),var(--color-page))}.route-timeline-scroll{position:absolute;top:0;right:0;bottom:0;left:0;overflow-y:auto;scrollbar-width:none}.route-timeline-scroll::-webkit-scrollbar,.route-detail-card::-webkit-scrollbar{display:none}.route-timeline-content{position:relative;min-height:100%}.route-timeline-track{position:relative;min-height:100%;height:max(100%,calc(var(--route-stop-count, 1) * 72px + var(--space-5) + var(--space-4)))}.route-detail-card-spacer{display:none}.route-station-timeline{position:relative;display:grid;grid-template-rows:repeat(var(--route-stop-count, 1),minmax(72px,1fr));align-content:start;height:100%;margin:0;padding:var(--space-5) var(--space-3) var(--space-4);list-style:none}.route-station-timeline li{position:relative;min-height:72px}.route-station-timeline li:before{position:absolute;top:0;bottom:0;left:var(--timeline-axis-left);width:2px;border-radius:999px;z-index:2;background:#d6ded8;content:""}.route-station-timeline li:first-child:before{top:50%}.route-station-timeline li:last-child:before{bottom:50%}.route-station-row{position:relative;display:grid;width:calc(100% - var(--station-row-left));min-height:72px;grid-template-columns:var(--station-dot-hit-column) minmax(0,1fr);align-items:center;gap:var(--timeline-gap);margin-left:var(--station-row-left);padding:10px 10px 12px 0;border:0;border-radius:var(--radius);background:transparent;color:var(--color-text);cursor:pointer;text-align:left}.route-station-row--active{background:transparent}.route-station-row--active:before{position:absolute;top:6px;right:0;bottom:6px;left:0;border-radius:var(--radius);background:var(--color-soft);content:""}.route-station-row>*{position:relative;z-index:1}.route-station-dot{position:relative;z-index:3;display:block;width:14px;height:14px;justify-self:start;margin-left:var(--station-dot-offset);border:3px solid var(--route-color, #166534);border-radius:50%;background:#fff;box-shadow:0 0 0 3px #fff}.route-station-lane{display:none}.route-station-copy{display:grid;min-width:0;gap:5px}.route-station-copy strong,.route-station-eta{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.route-station-copy strong{color:var(--color-text);font-size:15px;line-height:1.2}.route-station-eta{display:inline-flex;min-width:0;align-items:center;gap:5px;color:var(--color-subtle);font-size:13px;font-weight:700;line-height:1.25}.route-station-eta-text{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.route-vehicle-axis{position:absolute;inset:var(--space-5) var(--space-3) var(--space-4);bottom:var(--space-4);z-index:6;pointer-events:none}.route-vehicle-axis:before{position:absolute;top:0;bottom:0;left:var(--vehicle-road-left);width:var(--vehicle-road-width);border-right:1px solid rgba(154,172,162,.55);border-left:1px solid rgba(154,172,162,.55);border-radius:0;background-image:repeating-linear-gradient(to bottom,rgba(96,115,106,.46) 0 8px,transparent 8px 15px);background-repeat:no-repeat;background-position:center;background-size:2px 100%;content:""}.route-vehicle-axis-node{--vehicle-axis-alert-color: transparent;--vehicle-axis-alert-opacity: 0;position:absolute;top:var(--vehicle-axis-top, -4px);left:var(--vehicle-card-left);display:grid;width:var(--vehicle-card-width);min-height:42px;align-content:center;justify-items:center;gap:2px;padding:4px 5px;border:1px solid var(--color-border);border-radius:var(--radius);background:#fff;color:var(--color-text);cursor:pointer;font-size:10px;font-weight:900;line-height:1;pointer-events:auto;transform:translateY(-50%);z-index:1;box-shadow:0 6px 16px #14231c1a}.route-vehicle-axis-node--active{border-color:var(--route-color, #166534);background:var(--color-soft);box-shadow:0 0 0 3px color-mix(in srgb,var(--route-color, #166534) 16%,transparent),var(--shadow-soft)}.route-vehicle-axis-node:after{position:absolute;top:50%;right:calc((var(--timeline-axis-left) - var(--vehicle-card-left) - var(--vehicle-card-width) - var(--vehicle-stub-gap)) * -1);width:calc(var(--timeline-axis-left) - var(--vehicle-card-left) - var(--vehicle-card-width) - var(--vehicle-stub-gap));height:2px;border-radius:999px;background:color-mix(in srgb,var(--route-color, #166534) 60%,#ffffff);content:""}.route-vehicle-axis-node svg{color:var(--route-color, #166534)}.route-vehicle-axis-node span{overflow:hidden;max-width:100%;text-overflow:ellipsis;white-space:nowrap}.route-vehicle-axis-corner,.route-vehicle-axis-corner:before,.route-vehicle-axis-corner:after{position:absolute;clip-path:polygon(0 0,100% 0,100% 100%);pointer-events:none}.route-vehicle-axis-corner{top:1px;right:1px;display:block;width:18px;height:18px;border-top-right-radius:var(--radius);opacity:var(--vehicle-axis-alert-opacity)}.route-vehicle-axis-corner:before,.route-vehicle-axis-corner:after{content:""}.route-vehicle-axis-corner:before{top:0;right:0;width:18px;height:18px;border-top-right-radius:var(--radius);background:#fff}.route-vehicle-axis-corner:after{top:1px;right:1px;width:17px;height:17px;border-top-right-radius:7px;background:var(--vehicle-axis-alert-color)}.route-vehicle-axis-node--location-issue{--vehicle-axis-alert-color: #fa2828;--vehicle-axis-alert-opacity: 1}.route-vehicle-axis-node--full{--vehicle-axis-alert-color: #f2e422;--vehicle-axis-alert-opacity: 1}.route-vehicle-axis-node--waiting{--vehicle-axis-alert-color: #b5c3d1;--vehicle-axis-alert-opacity: 1}.route-detail-card{position:relative;inset:auto;display:grid;width:100%;min-width:0;align-content:start;padding:14px;border:1px solid var(--color-border);border-radius:var(--radius);background:#fffffff5;box-shadow:var(--shadow-soft)}.route-detail-card .selection-card__header h2{margin:0 0 var(--space-3);overflow:hidden;color:var(--color-text);font-size:20px;line-height:1.2;text-overflow:ellipsis;white-space:nowrap}.route-detail-card .selection-card__trailing svg{flex:0 0 auto;color:#60736a}.route-detail-card__divider{height:1px;margin:var(--space-3) 0;background:#edf0ed}.route-detail-eta-list{display:grid;gap:0}.route-detail-eta-row{display:grid;grid-template-columns:minmax(0,1fr) max-content;align-items:center;gap:14px;padding:10px 0;border-top:1px solid #edf0ed}.route-detail-eta-row:first-child{border-top:0;padding-top:0}.route-detail-eta-row__left{display:inline-flex;min-width:0;flex-wrap:wrap;align-items:center;gap:5px}.route-detail-eta-row strong{overflow:hidden;color:var(--color-text);line-height:1.25;text-overflow:ellipsis;white-space:nowrap}.route-detail-eta-row em{display:inline-flex;min-width:0;align-items:center;justify-content:flex-end;gap:5px;color:var(--color-text);font-style:normal;font-weight:700;line-height:1.25;white-space:nowrap}.route-detail-card__facts{display:grid;gap:var(--space-2);margin:0}.route-detail-card__facts>div{display:grid;grid-template-columns:max-content minmax(120px,1fr);align-items:baseline;gap:14px}.route-detail-card__facts dt{color:var(--color-muted);white-space:nowrap}.route-detail-card__facts dd{min-width:0;margin:0;overflow:hidden;font-weight:700;text-align:right;text-overflow:ellipsis;white-space:nowrap}.route-detail-empty{display:grid;min-height:52px;place-items:center;color:var(--color-muted);font-size:13px;font-weight:800}.route-info-modal__body{gap:var(--space-3);padding-top:var(--space-3)}.route-info-section{display:grid;gap:5px;padding-top:0;border-top:0}.route-info-section+.route-info-section{padding-top:var(--space-3);border-top:1px solid #edf0ed}.route-info-section h2{color:var(--color-muted);font-size:13px;font-weight:800}.route-info-section__primary{color:var(--color-text);font-size:14px;font-weight:800}.route-info-section__secondary{color:var(--color-subtle);font-size:12px;line-height:1.45}.route-schedule-group{display:grid;overflow:hidden;border:1px solid var(--color-border);border-radius:var(--radius);background:#f8fbf9}.route-schedule-group strong{color:var(--color-text);font-size:13px}.route-schedule-group__trigger{display:flex;width:100%;align-items:center;justify-content:space-between;gap:var(--space-2);min-height:34px;padding:0 10px;border:0;background:transparent;color:inherit;cursor:pointer;text-align:left}.route-schedule-group__trigger svg{flex:0 0 auto;color:var(--color-muted)}.route-schedule-group__content{display:grid;grid-template-rows:0fr;border-top:1px solid transparent;opacity:0;transition:grid-template-rows .18s ease,opacity .18s ease,border-color .18s ease}.route-schedule-group--open .route-schedule-group__content{grid-template-rows:1fr;border-top-color:#e5ece7;opacity:1}.route-schedule-group__times{display:flex;min-height:0;flex-wrap:wrap;gap:6px;overflow:hidden;padding:0 10px;transition:padding .18s ease}.route-schedule-group--open .route-schedule-group__times{padding:10px}.route-schedule-group__times b{display:inline-flex;min-height:24px;align-items:center;padding:0 7px;border:1px solid var(--color-border);border-radius:6px;background:#f7faf8;color:var(--color-text);font-size:12px;line-height:1}@media(max-width:800px){.route-page{height:100dvh;align-items:start;justify-items:stretch;overflow:hidden}.route-detail-content{width:100%;height:calc(100dvh - 20px);min-height:0;align-content:start;grid-template-rows:auto minmax(0,1fr);gap:var(--space-2)}.route-detail-topbar{min-height:58px;gap:var(--space-2);padding:var(--space-2)}.route-detail-title{gap:2px}.route-detail-topbar h1{font-size:20px}.route-detail-title span{font-size:12px}.route-detail-topbar .icon-button{width:32px;height:32px}.route-detail-topbar .route-back-button{width:38px;height:38px}.route-detail-layout{width:100%;height:100%;min-height:0;grid-template-columns:1fr;gap:0}.route-timeline-shell{--timeline-vehicle-lane: 40px;--timeline-dot-column: 30px;--station-row-left: calc(var(--timeline-vehicle-lane) + 2px);--station-dot-hit-column: 36px;--station-dot-offset: 14px;--vehicle-road-width: 24px;--vehicle-road-left: 8px;--vehicle-card-width: 38px;--vehicle-card-left: 1px;width:100%;max-width:100%;height:100%;min-height:0;aspect-ratio:auto}.route-station-timeline{grid-template-rows:repeat(var(--route-stop-count, 1),minmax(64px,1fr));padding:var(--space-2)}.route-timeline-track{height:max(100%,calc(var(--route-stop-count, 1) * 64px + var(--space-4)))}.route-detail-card-spacer{display:block;height:var(--route-detail-card-space, 128px)}.route-station-row,.route-station-timeline li{min-height:64px}.route-station-copy strong{font-size:14px}.route-detail-card{position:fixed;right:var(--space-2);bottom:var(--space-2);left:var(--space-2);z-index:35;width:auto;max-height:min(42dvh,320px);overflow-y:auto;scrollbar-width:none;padding:var(--space-3);box-shadow:var(--shadow-float)}.route-detail-card h2{font-size:18px}}@media(prefers-reduced-motion:reduce){.route-schedule-group__content,.route-schedule-group__times{transition:none}}@media(max-width:380px){.route-detail-topbar h1{font-size:18px}}.passenger-shell{display:grid;height:100dvh;min-height:0;overflow:hidden;place-items:stretch center;padding:10px;background:var(--color-page)}.passenger-page{--passenger-route-color: #1f7a52;display:grid;width:min(100%,640px);height:calc(100dvh - 20px);min-height:0;grid-template-rows:auto minmax(0,1fr) auto;gap:var(--space-3);overflow:hidden}.passenger-card{border:1px solid var(--color-border);border-radius:var(--radius);background:#fffffff0;box-shadow:var(--shadow-soft)}.passenger-header{display:flex;align-items:center;gap:var(--space-3);padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius);background:#fffffff0;box-shadow:var(--shadow-soft)}.passenger-header-title{display:flex;flex:0 0 auto;min-height:44px;align-items:center;color:#17251d;font-size:24px;font-weight:900;line-height:1.2}.passenger-header-divider{flex:0 0 auto;width:1px;height:44px;background:#cddbd3}.passenger-header-info{display:grid;flex:1 1 auto;min-width:0;min-height:44px;align-content:center;gap:3px}.passenger-header-info strong{overflow:hidden;color:#17251d;font-size:18px;font-weight:900;line-height:1.2;text-overflow:ellipsis;white-space:nowrap}.passenger-header-info span{overflow:hidden;color:#60736a;font-size:12px;font-weight:800;line-height:1.2;text-overflow:ellipsis;white-space:nowrap}.passenger-main{display:flex;flex-direction:column;min-width:0;min-height:0;gap:var(--space-3);overflow:hidden}.passenger-main--loading,.passenger-main[data-placeholder=hidden]{gap:0}.passenger-content{display:grid;flex:0 0 auto;min-width:0;min-height:0;width:100%;overflow:hidden}.passenger-content--loading{flex:1 1 auto;height:100%}.passenger-content--list,.passenger-content--submitting,.passenger-content--result,.passenger-content--error{align-self:start;max-height:100%}.passenger-content--result,.passenger-content--error{overflow:visible}.passenger-content__presence{min-width:0;min-height:0}.passenger-content--loading .passenger-content__presence,.passenger-content--list .passenger-content__presence,.passenger-content--submitting .passenger-content__presence{display:grid;max-height:100%}.passenger-content--loading .passenger-content__presence{height:100%}.passenger-content__presence.presence-enter{animation:presence-card-enter .18s ease-out both}.passenger-content__presence.presence-exit{animation:presence-card-exit .16s ease-in both}.passenger-card,.passenger-panel{display:grid;min-width:0;gap:var(--space-3);padding:var(--space-4)}.passenger-status-card{--passenger-status-row-height: 32px;display:grid;width:100%;max-width:100%;gap:18px;padding:20px;border:1px solid var(--color-border);border-radius:var(--radius);background:#fff;color:#17251d;box-shadow:0 12px 28px #18352714;font-weight:800}.passenger-status-card--success{--passenger-status-color: var(--passenger-route-color);--passenger-status-button-bg: var(--passenger-route-color);--passenger-status-button-border: var(--passenger-route-color);--passenger-status-button-text: #ffffff}.passenger-status-card--warning{--passenger-status-color: #d99400;--passenger-status-button-bg: #d99400;--passenger-status-button-border: #d99400;--passenger-status-button-text: #ffffff}.passenger-result-stack{display:grid;gap:var(--space-3);min-width:0}.passenger-warn-banner{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid #f0c85a;border-radius:var(--radius);background:#fff7d8;color:#6f4f00;line-height:1.5;animation:passenger-warning-enter .22s ease-out both;transform-origin:top center}.passenger-warn-banner svg{flex:0 0 auto;color:#d99400}.passenger-warn-banner span{display:-webkit-box;min-width:0;min-height:2.7em;align-content:center;overflow-wrap:anywhere;overflow:hidden;font-size:clamp(13px,3.4vw,15px);font-weight:900;line-height:1.35;-webkit-box-orient:vertical;-webkit-line-clamp:2}.passenger-status-card__status{display:grid;justify-items:center;gap:10px;padding:8px 0 14px;border-bottom:1px solid color-mix(in srgb,var(--passenger-status-color) 24%,#edf3ef);text-align:center}.passenger-status-card__status svg,.passenger-status-card__status h2{color:var(--passenger-status-color)}.passenger-status-card__status h2{margin:0;font-size:28px;font-weight:900;line-height:1.2}.passenger-status-card__body{display:grid;width:100%;justify-items:center;min-width:0;container-type:inline-size}.passenger-status-fields{display:grid;grid-template-columns:max-content max-content;align-items:center;justify-content:center;column-gap:clamp(30px,10vw,96px);row-gap:0;margin:0;width:100%}.passenger-status-fields--loading{place-self:center;max-width:100%}.passenger-status-fields dt{min-height:var(--passenger-status-row-height);align-content:center;color:#68776e;font-size:13px;font-weight:900;line-height:1.2;text-align:center;white-space:nowrap}.passenger-status-fields dd{min-height:var(--passenger-status-row-height);align-content:center;margin:0;color:#17251d;font-size:18px;font-weight:900;line-height:1.2;text-align:left;white-space:nowrap}.passenger-status-separator{display:block;grid-column:1 / -1;width:100%;height:1px;margin:4px 0;background:#edf3ef}.passenger-status-message{margin:0;color:#17251d;font-size:18px;font-weight:900;line-height:1.35;text-align:center}.passenger-status-card__button{display:inline-flex;min-height:48px;align-items:center;justify-content:center;gap:var(--space-2);border:1px solid var(--passenger-status-button-border);border-radius:var(--radius);background:var(--passenger-status-button-bg);color:var(--passenger-status-button-text);cursor:pointer;font-size:16px;font-weight:900}.passenger-status-card--loading .passenger-status-card__status{border-bottom-color:#edf3ef}.passenger-status-title-skeleton,.passenger-status-field-skeleton,.passenger-status-button-skeleton{position:relative;display:block;overflow:hidden;border-radius:999px;background:#edf3ef}.passenger-status-title-skeleton:before,.passenger-status-field-skeleton:before,.passenger-status-button-skeleton:before{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.72),transparent);animation:passenger-skeleton 1.15s ease-in-out infinite;content:"";transform:translate(-100%)}.passenger-status-title-skeleton{width:128px;height:34px}.passenger-status-field-skeleton-row{display:grid;min-height:var(--passenger-status-row-height);grid-column:1 / -1;align-items:center}.passenger-status-field-skeleton{width:100%;height:24px;align-self:center}.passenger-status-button-skeleton{width:100%;height:48px;border-radius:var(--radius)}.passenger-card__header{display:grid;grid-template-columns:32px minmax(0,1fr);align-items:center;gap:var(--space-3)}.passenger-panel{border:1px solid var(--color-border);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow-soft)}.passenger-destination-panel{position:relative;height:var(--destination-panel-height, auto);max-height:var(--destination-panel-max-height, 100%);min-height:0;grid-template-rows:auto auto;overflow:hidden;transition:height .22s ease}.passenger-destination-panel[data-scrollable=true]{grid-template-rows:auto minmax(0,1fr)}.passenger-destination-panel--loading,.passenger-destination-panel--submitting{height:var(--destination-panel-height, 100%);transition:none}.passenger-destination-list-shell{position:relative;display:grid;min-height:0;overflow:hidden}.passenger-destination-list-shell:after{position:absolute;right:0;bottom:0;left:0;height:30px;background:linear-gradient(to bottom,#fff0,#fff 78%);content:"";pointer-events:none}.passenger-destination-panel[data-scrollable=false] .passenger-destination-list-shell:after{opacity:0}.passenger-panel-icon{display:grid;width:28px;height:28px;place-items:center;color:var(--passenger-route-color)}.passenger-panel-icon svg,.passenger-loading-spinner{color:var(--passenger-route-color)}.passenger-card__header h2{margin:0;color:var(--color-text);font-size:18px;font-weight:900;line-height:1.25}.passenger-card__header p{margin:3px 0 0;color:var(--color-muted);font-size:13px;font-weight:700;line-height:1.45}.passenger-destination-list{display:grid;min-height:0;overflow-y:auto;overscroll-behavior:contain;padding-right:2px;padding-bottom:0;scrollbar-width:none;touch-action:pan-y;-webkit-overflow-scrolling:touch}.passenger-destination-panel--loading .passenger-destination-list-content{padding-bottom:18px}.passenger-destination-panel[data-scrollable=true] .passenger-destination-list-content{padding-bottom:22px}.passenger-destination-list::-webkit-scrollbar{display:none}.passenger-destination-panel[data-scrollable=false] .passenger-destination-list{overflow-y:hidden}.passenger-destination-list-content{display:grid;align-content:start;gap:var(--space-2);min-height:0}.passenger-destination-option{display:grid;grid-template-columns:minmax(0,1fr) max-content;align-items:center;gap:var(--space-3);min-height:54px;padding:0 var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius);background:#fff;color:var(--color-text);cursor:pointer;text-align:left;transition:border-color .16s ease,background-color .16s ease,transform .16s ease}.passenger-destination-option:active{transform:scale(.99)}.passenger-destination-option:hover,.passenger-destination-option:focus-visible{border-color:color-mix(in srgb,var(--passenger-route-color) 38%,var(--color-border));background:color-mix(in srgb,var(--passenger-route-color) 8%,#ffffff);outline:none;box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--passenger-route-color) 36%,transparent)}.passenger-destination-option span{min-width:0;overflow:hidden;font-size:16px;font-weight:900;line-height:1.25;text-overflow:ellipsis;white-space:nowrap}.passenger-destination-option small{display:inline-flex;width:56px;height:24px;align-items:center;justify-content:center;padding:0;border-radius:999px;background:color-mix(in srgb,var(--passenger-route-color) 12%,#ffffff);color:var(--passenger-route-color);font-size:12px;font-weight:900;white-space:nowrap}.passenger-destination-skeleton{position:relative;display:block;min-height:54px;border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;background:#edf3ef}.passenger-destination-skeleton:before{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.72),transparent);animation:passenger-skeleton 1.15s ease-in-out infinite;content:"";transform:translate(-100%)}.passenger-skeleton{position:relative;display:block;overflow:hidden;height:48px;border-radius:var(--radius);background:#edf3ef}.passenger-skeleton--header-title{width:min(160px,100%);height:18px;border-radius:999px}.passenger-skeleton--header-meta{width:min(120px,72%);height:13px;border-radius:999px}.passenger-skeleton:before{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.72),transparent);animation:passenger-skeleton 1.15s ease-in-out infinite;content:"";transform:translate(-100%)}.passenger-loading-spinner{display:block;width:26px;height:26px;border:3px solid color-mix(in srgb,var(--passenger-route-color) 16%,transparent);border-top-color:var(--passenger-route-color);border-radius:50%;animation:passenger-spin .8s linear infinite}.passenger-loading-spinner--status{width:56px;height:56px;border-width:5px}.passenger-placeholder{display:flex;flex:1 1 auto;min-width:0;min-height:0;width:100%;height:100%;align-items:center;justify-content:center;gap:var(--space-3);overflow:hidden;padding:0 clamp(18px,7vw,42px);color:#5f6b635c;font-size:clamp(20px,7vw,38px);font-weight:900;text-align:center;opacity:1;transform:scale(1);transition:opacity .18s ease,transform .18s ease}.passenger-main--loading .passenger-placeholder,.passenger-main--submitting .passenger-placeholder{height:0;opacity:0;pointer-events:none;transform:scale(.78)}.passenger-placeholder img{width:clamp(42px,14vw,86px);height:clamp(42px,14vw,86px);opacity:.18;filter:grayscale(1)}.passenger-placeholder--compact{opacity:.48;font-size:clamp(16px,5vw,26px);transform:scale(.86)}.passenger-placeholder--hidden{flex-basis:0;height:0;opacity:0;transform:scale(.78);pointer-events:none}.site-footer--passenger{flex:0 0 auto;padding:var(--space-2) var(--space-2) var(--space-1)}@keyframes passenger-skeleton{to{transform:translate(100%)}}@keyframes passenger-spin{to{transform:rotate(360deg)}}@keyframes passenger-warning-enter{0%{opacity:0;transform:scaleY(.82)}to{opacity:1;transform:scaleY(1)}}@media(max-width:380px){.passenger-page{gap:var(--space-2)}.passenger-card{padding:var(--space-3)}.passenger-header{gap:var(--space-2)}.passenger-header-title{font-size:22px}.passenger-destination-option{min-height:50px;padding:0 10px}.passenger-destination-option span{font-size:15px}}@media(prefers-reduced-motion:reduce){.passenger-content__presence.presence-enter,.passenger-content__presence.presence-exit,.passenger-skeleton:before,.passenger-destination-skeleton:before,.passenger-status-title-skeleton:before,.passenger-status-field-skeleton:before,.passenger-status-button-skeleton:before,.passenger-loading-spinner,.passenger-warn-banner{animation:none}.passenger-destination-panel,.passenger-placeholder{transition:none}}
