:root{font-family:SF Mono,Roboto Mono,IBM Plex Mono,monospace;color:#e8f6ff;background:#05070b;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-right: env(safe-area-inset-right, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-left: env(safe-area-inset-left, 0px);--bg-top-glow: rgba(0, 179, 255, .08);--bg-start: #05070b;--bg-end: #090d13;--text-primary: #f6fbff;--text-secondary: #708096;--text-tertiary: #6d7f95;--text-muted: #6e8195;--border-color: #1a2431;--border-strong: #1b2736;--border-soft: #16202c;--surface-strong: rgba(10, 15, 22, .9);--surface-card: rgba(7, 11, 16, .96);--surface-soft: rgba(255, 255, 255, .03);--surface-active: rgba(255, 255, 255, .08);--station-fill: #081018;--station-stroke: #eaf5ff;--neutral-line: #314253;--card-shadow: 0 18px 40px rgba(0, 0, 0, .35);--card-inset: rgba(255, 255, 255, .015);--theme-toggle-text: #f6fbff;--accent-strong: #8df0b8;--status-chip-text: #f6fbff;--status-chip-bg: rgba(255, 255, 255, .06);--status-chip-border: rgba(255, 255, 255, .16);--duration-instant: 80ms;--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--ease-out: cubic-bezier(.2, .8, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--status-alert: #ff9a6a;--status-healthy: #4ade80;--status-warn: #facc15;--status-info: #60a5fa;--status-error: #f87171;--status-secondary: #fb923c;--status-link: #9ecbff;--radius-sm: 10px;--radius-md: 12px;--radius-lg: 14px;--radius-xl: 16px;--radius-2xl: 20px;--radius-pill: 999px;--z-base: 1;--z-raised: 2;--z-sticky: 20;--z-overlay: 60;font-synthesis:none;line-height:1.4;font-weight:400;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root[data-theme=light]{color:#163149;background:#edf5fb;--bg-top-glow: rgba(0, 128, 255, .12);--bg-start: #edf5fb;--bg-end: #f8fbfe;--text-primary: #163149;--text-secondary: #5f7388;--text-tertiary: #687e94;--text-muted: #73869c;--border-color: #cfdbe6;--border-strong: #c5d3df;--border-soft: #d9e4ed;--surface-strong: rgba(255, 255, 255, .92);--surface-card: rgba(255, 255, 255, .95);--surface-soft: rgba(22, 49, 73, .04);--surface-active: rgba(22, 49, 73, .08);--station-fill: #ffffff;--station-stroke: #163149;--neutral-line: #a8bccc;--card-shadow: 0 16px 36px rgba(71, 101, 133, .14);--card-inset: rgba(22, 49, 73, .03);--theme-toggle-text: #163149;--accent-strong: #1d6b52;--status-chip-text: #163149;--status-chip-bg: rgba(22, 49, 73, .05);--status-chip-border: rgba(22, 49, 73, .16)}*{box-sizing:border-box}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.station-search-dialog{max-width:640px}.station-search-dialog .dialog-content{min-height:0;overflow:hidden}.station-search-shell{display:grid;gap:12px;flex:1;min-height:0}.station-search-input{width:100%;padding:14px 16px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-soft);color:var(--text-primary);font:inherit;font-size:.96rem}.station-search-input:focus-visible{outline:2px solid color-mix(in srgb,var(--accent-strong) 72%,white);outline-offset:2px}.station-search-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.station-location-button{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:0 14px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--surface-soft);color:var(--text-primary);font:inherit;cursor:pointer}.station-location-button:disabled{opacity:.7;cursor:wait}.station-location-status{margin:0;color:var(--text-secondary)}.station-location-status.is-error{color:var(--status-error)}.station-search-results{display:grid;gap:8px;min-height:0;overflow:auto;padding-right:4px;overscroll-behavior:contain}.station-search-result{display:flex;width:100%;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-soft);color:var(--text-primary);font:inherit;text-align:left;cursor:pointer;transition:border-color .18s ease,background .18s ease,transform .18s ease}.station-search-result:hover,.station-search-result.is-active{background:var(--surface-active);border-color:color-mix(in srgb,var(--accent-strong) 35%,var(--border-color));transform:translateY(-1px)}.station-search-result-main{display:flex;align-items:center;gap:10px;min-width:0}.station-search-result-copy{display:grid;gap:4px;min-width:0}.station-search-result-title,.station-search-result-meta{margin:0}.station-search-result-title{color:var(--text-primary);font-size:.92rem;font-weight:700}.station-search-result-meta{color:var(--text-secondary);font-size:.78rem}.station-search-result-token{flex:0 0 auto}.station-search-result-actions{display:inline-flex;align-items:center;gap:8px;flex:0 0 auto}.station-search-result-badge{color:var(--text-secondary);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase}.station-search-nearby-badge{padding:2px 6px;border-radius:var(--radius-pill);background:color-mix(in srgb,var(--accent-strong) 15%,transparent);color:var(--accent-strong);font-size:.68rem;letter-spacing:.06em;white-space:nowrap}body{margin:0;background:radial-gradient(circle at top,var(--bg-top-glow),transparent 28%),linear-gradient(180deg,var(--bg-start) 0%,var(--bg-end) 100%)}#app{min-height:100vh;min-height:100dvh}.screen{width:min(1560px,calc(100vw - 32px - var(--safe-area-left) - var(--safe-area-right)));margin:0 auto;padding:calc(22px + var(--safe-area-top)) 0 calc(32px + var(--safe-area-bottom))}.toast-region{position:fixed;right:calc(16px + var(--safe-area-right));bottom:calc(16px + var(--safe-area-bottom));z-index:var(--z-overlay);display:grid;gap:10px;pointer-events:none}.toast{min-width:min(320px,calc(100vw - 32px));max-width:min(420px,calc(100vw - 32px - var(--safe-area-left) - var(--safe-area-right)));padding:12px 14px;border:1px solid color-mix(in srgb,var(--status-alert) 42%,var(--border-color));border-radius:var(--radius-lg);background:linear-gradient(180deg,color-mix(in srgb,var(--status-alert) 8%,transparent),transparent),color-mix(in srgb,var(--surface-card) 96%,#081018 4%);box-shadow:inset 0 0 0 1px var(--card-inset),0 16px 34px #00000057;color:var(--text-primary);font-size:.82rem;line-height:1.45;pointer-events:auto}.screen-header{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:16px}.screen-pills{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:6px}.screen-kicker,.updated-at,.line-title p,.train-readout{margin:0}.screen-kicker{color:var(--text-tertiary);font-size:.82rem;letter-spacing:.18em}h1,h2{margin:0;font-weight:700}h1{color:var(--text-primary);font-size:clamp(2rem,4vw,3rem);letter-spacing:.04em}.theme-toggle{margin:0;min-width:5.2em;padding:6px 10px;border:1px solid var(--border-color);border-radius:var(--radius-pill);background:var(--surface-strong);color:var(--theme-toggle-text);font:inherit;font-size:.74rem;line-height:1;letter-spacing:.08em;text-align:center}.status-pill{display:inline-flex;align-items:center;gap:8px;margin:0;min-width:5.2em;padding:6px 10px;border:1px solid var(--border-strong);border-radius:var(--radius-pill);background:var(--surface-strong);color:var(--accent-strong);font-size:.74rem;line-height:1;letter-spacing:.08em;box-shadow:inset 0 0 0 1px #8df0b814;font-family:inherit;font-weight:600;cursor:pointer;transition:all .2s ease}.status-pill:hover{background:var(--surface-hover);border-color:var(--border-color)}.status-pill:before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor;box-shadow:0 0 10px currentColor}.status-pill-error{color:#ff8e66}.updated-at{margin-top:8px;color:var(--text-secondary);font-size:.88rem}.updated-at-pill{color:var(--text-secondary)}.updated-at-pill:before{display:none}.dot-matrix-clock{display:inline-flex;align-items:center;gap:1px;margin:0;padding:6px 10px;border:1px solid var(--border-strong);border-radius:var(--radius-pill);background:var(--surface-strong);color:var(--accent-strong);box-shadow:inset 0 0 0 1px #8df0b814;font-family:Courier New,Menlo,monospace;font-size:.74rem;font-weight:700;letter-spacing:.08em;line-height:1}.dot-matrix-digit{display:inline-block;min-width:.65em;text-align:center}.dot-matrix-colon{opacity:.7;animation:colon-blink 1s step-end infinite;min-width:.3em;text-align:center}@keyframes colon-blink{50%{opacity:0}}.tab-bar{display:inline-flex;flex-wrap:wrap;gap:6px;margin-bottom:16px;padding:4px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-strong)}.switcher-stack{display:flex;flex-direction:column;align-items:flex-start}.system-bar{margin-bottom:10px}.tab-button{min-width:140px;padding:8px 14px;border:0;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font:inherit;font-size:.8rem;letter-spacing:.06em;transition:background .2s ease,color .2s ease,box-shadow .2s ease}.tab-button.is-active{background:var(--surface-active);color:var(--text-primary);box-shadow:inset 0 0 0 1px #ffffff0d}.board{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}.line-switcher{display:grid;grid-column:1 / -1;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;width:100%;min-width:0;max-width:100%;margin-bottom:2px}.line-switcher-button{display:inline-flex;align-items:center;gap:10px;min-width:0;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-strong);color:var(--text-secondary);font:inherit;transition:border-color .18s ease,background .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease}.line-switcher-button:hover{border-color:color-mix(in srgb,var(--line-color) 24%,var(--border-color));color:var(--text-primary)}.line-switcher-button.is-active{color:var(--text-primary);border-color:color-mix(in srgb,var(--line-color) 40%,var(--border-color));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--line-color) 35%,transparent)}.line-switcher-label-group{display:grid;min-width:0}.line-switcher-label-compact,.line-switcher-label-full{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-switcher-label-compact{display:none}.line-switcher-token{width:24px;height:24px;font-size:.78rem}.stack-board{display:grid;gap:18px}.line-card,.panel-card{min-width:0;padding:20px 18px 18px;border:1px solid var(--border-color);border-radius:var(--radius-2xl);background:linear-gradient(180deg,rgba(255,255,255,.02),transparent),var(--surface-card);box-shadow:inset 0 0 0 1px var(--card-inset),var(--card-shadow)}.panel-card-wide{max-width:920px}.system-summary-card{grid-column:1 / -1;max-width:none}.system-summary-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}.system-summary-hero{display:grid;gap:12px;margin-bottom:12px}.system-trend-copy{margin:0}.system-trend-strip{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.system-trend-chip{min-height:100%}.system-trend-copy{margin-top:6px;color:var(--text-secondary);font-size:.76rem}.system-ranking{display:grid;gap:10px;margin-top:12px}.system-summary-strip{grid-template-columns:repeat(5,minmax(0,1fr))}.system-composition,.system-priority{display:grid;gap:10px;margin-top:12px}.attention-breakdown-grid,.system-priority-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.system-priority-item{padding:12px 14px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:linear-gradient(180deg,color-mix(in srgb,var(--accent-strong) 4%,transparent),transparent),var(--surface-soft)}.system-ranking-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.system-ranking-item{padding:12px 14px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-soft)}.attention-reason-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.attention-reason-badge{display:inline-flex;align-items:center;min-height:24px;padding:.2rem .6rem;border:1px solid var(--border-color);border-radius:var(--radius-pill);background:var(--surface-strong);color:var(--text-secondary);font-size:.68rem;letter-spacing:.06em;text-transform:uppercase}.attention-reason-badge-healthy{border-color:color-mix(in srgb,var(--status-healthy) 28%,var(--border-color));color:color-mix(in srgb,var(--status-healthy) 60%,var(--text-primary))}.attention-reason-badge-info{border-color:color-mix(in srgb,var(--status-info) 30%,var(--border-color));color:color-mix(in srgb,var(--status-info) 58%,var(--text-primary))}.attention-reason-badge-warn{border-color:color-mix(in srgb,var(--status-warn) 34%,var(--border-color));color:color-mix(in srgb,var(--status-warn) 66%,var(--text-primary))}.attention-reason-badge-alert{border-color:color-mix(in srgb,var(--status-alert) 36%,var(--border-color));color:color-mix(in srgb,var(--status-alert) 72%,var(--text-primary))}.station-hotspots{display:grid;gap:10px;margin-top:12px}.station-hotspot-list{display:grid;gap:8px}.station-hotspot-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid var(--border-color);border-radius:14px;background:var(--surface-soft)}.station-hotspot-item-healthy{border-color:color-mix(in srgb,#4ade80 28%,var(--border-color))}.station-hotspot-item-warn{border-color:color-mix(in srgb,#facc15 34%,var(--border-color))}.station-hotspot-item-alert{border-color:color-mix(in srgb,#ff9a6a 36%,var(--border-color))}.station-hotspot-main{min-width:0}.station-hotspot-name{margin:0;color:var(--text-primary);font-size:.86rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.station-hotspot-meta{margin:4px 0 0;color:var(--text-secondary);font-size:.74rem}.station-hotspot-lines{display:flex;gap:5px;margin-top:6px}.station-hotspot-line-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--line-color);box-shadow:0 0 6px color-mix(in srgb,var(--line-color) 50%,transparent)}.station-hotspot-stats{flex-shrink:0;text-align:right}.station-hotspot-stat-value{margin:0;color:var(--text-primary);font-size:1rem;font-weight:700}.station-hotspot-stat-label{margin:2px 0 0;color:var(--text-secondary);font-size:.68rem;text-transform:uppercase;letter-spacing:.06em}.station-hotspot-stat-sub{margin:4px 0 0;color:var(--text-secondary);font-size:.72rem}.insights-ticker{grid-column:1 / -1;overflow:hidden;border:1px solid var(--border-color);border-radius:var(--radius-xl);background:linear-gradient(180deg,rgba(255,255,255,.02),transparent),var(--surface-card);box-shadow:inset 0 0 0 1px var(--card-inset),var(--card-shadow)}.insights-ticker-empty{overflow:visible}.insights-ticker-viewport{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr));align-items:stretch;gap:12px;min-height:56px;padding:12px 16px}.insights-ticker-item{display:flex;align-items:center;gap:10px;min-width:0;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-pill);background:var(--surface-soft);color:var(--text-primary);font-size:.8rem}.insights-ticker-copy{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.insights-ticker-item-animated{animation:insightsTickerVertical 5s ease both}.insights-ticker-item-healthy{border-color:color-mix(in srgb,var(--status-healthy) 28%,var(--border-color))}.insights-ticker-item-info{border-color:color-mix(in srgb,var(--status-info) 30%,var(--border-color))}.insights-ticker-item-warn{border-color:color-mix(in srgb,var(--status-warn) 34%,var(--border-color))}.insights-ticker-item-alert{border-color:color-mix(in srgb,var(--status-alert) 36%,var(--border-color))}.insights-ticker-dot{width:8px;height:8px;border-radius:50%;background:var(--line-color);box-shadow:0 0 10px color-mix(in srgb,var(--line-color) 65%,transparent)}.panel-header{margin-bottom:12px}.panel-header h2{color:var(--text-primary);font-size:1.05rem}.panel-header p{margin:4px 0 0;color:var(--text-secondary);font-size:.82rem}.line-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:8px}.line-title{display:flex;align-items:flex-start;gap:12px;min-width:0;flex:1 1 auto}.line-title-copy{min-width:0}.line-title-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.line-token{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:50%;background:var(--line-color);color:#051018;font-weight:900;box-shadow:0 0 18px color-mix(in srgb,var(--line-color) 55%,transparent)}.line-title h2{color:var(--text-primary);font-size:1.26rem}.line-title p{color:var(--text-secondary);font-size:.94rem}.line-alert-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid color-mix(in srgb,var(--status-alert) 28%,var(--border-color));border-radius:var(--radius-pill);background:color-mix(in srgb,var(--status-alert) 6%,var(--surface-soft));color:var(--text-primary);font:inherit;font-size:.74rem;cursor:pointer}.line-alert-badge:hover{border-color:color-mix(in srgb,var(--status-alert) 45%,var(--border-color));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--status-alert) 12%,transparent)}.line-alert-badge-count{display:inline-grid;place-items:center;min-width:20px;height:20px;padding:0 6px;border-radius:var(--radius-pill);background:var(--status-alert);color:#081018;font-size:.7rem;font-weight:700}.line-alert-badge-copy{color:#ffb38f;letter-spacing:.08em;text-transform:uppercase}.line-diagram{display:block;width:100%;max-width:none;height:auto;margin:6px auto 0;overflow:visible}.spine{stroke:var(--line-color);stroke-width:7;stroke-linecap:round;filter:drop-shadow(0 0 10px color-mix(in srgb,var(--line-color) 55%,transparent))}.segment-line{stroke:var(--neutral-line);stroke-width:1.5}.segment-time{fill:var(--text-secondary);font-size:12px}.station-group{cursor:pointer}.station-group:hover .station-stop{stroke:var(--line-color);stroke-width:2.5;filter:drop-shadow(0 0 8px var(--line-color))}.station-group:hover .terminal-stop{filter:drop-shadow(0 0 16px color-mix(in srgb,var(--line-color) 80%,transparent))}.station-group:hover .station-label{fill:var(--line-color)}.station-group.has-alert .station-stop,.station-group.has-alert .terminal-stop{stroke:var(--status-alert);stroke-width:2.5}.station-alert-dot{fill:var(--status-alert);stroke:#081018;stroke-width:1.5;filter:drop-shadow(0 0 8px rgba(255,154,106,.8))}.station-stop{fill:var(--station-fill);stroke:var(--station-stroke);stroke-width:1.5;transition:all .2s ease}.terminal-stop{fill:var(--line-color);stroke:var(--station-stroke);stroke-width:1.5;filter:drop-shadow(0 0 12px color-mix(in srgb,var(--line-color) 55%,transparent));transition:all .2s ease}.terminal-mark{fill:#061018;font-size:12px;font-weight:900}.station-label{fill:var(--text-primary);font-size:13px;font-weight:650;letter-spacing:.01em;transition:all .2s ease}.station-label-multiline{font-size:12.5px}.station-label tspan{dominant-baseline:hanging}.station-hitbox{cursor:pointer}.train-wave{fill:none;stroke:var(--line-color);stroke-width:1.5;opacity:.9;animation:wave 1.6s linear infinite}.train[data-train-id]{cursor:pointer}.train-ghost-dot{fill:color-mix(in srgb,var(--line-color) 85%,white 15%);opacity:var(--ghost-opacity, .35);filter:drop-shadow(0 0 8px color-mix(in srgb,var(--line-color) 45%,transparent))}.train-arrow{fill:var(--line-color);stroke:#f8fcff;stroke-width:1.5;filter:drop-shadow(0 0 10px color-mix(in srgb,var(--line-color) 65%,transparent))}.line-readout{display:grid;gap:6px;margin-top:8px;padding-top:10px;border-top:1px solid var(--border-soft)}.line-readout-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.line-readout-grid>*{min-width:0}.service-reminder{display:grid;gap:2px;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--surface-soft);flex:0 0 auto;align-self:flex-start;margin-left:auto;min-width:180px;max-width:min(240px,42%)}.service-reminder-headline,.service-reminder-detail{margin:0}.service-reminder-headline{color:var(--text-primary);font-size:.8rem;letter-spacing:.04em}.service-reminder-detail{color:var(--text-secondary);font-size:.76rem}.service-reminder-active{border-color:color-mix(in srgb,var(--accent-strong) 28%,var(--border-color))}.service-reminder-upcoming{border-color:color-mix(in srgb,var(--status-link) 34%,var(--border-color))}.service-reminder-ended{border-color:color-mix(in srgb,var(--status-alert) 34%,var(--border-color))}.service-reminder-muted{border-color:var(--border-color)}.line-marquee{position:relative;overflow:hidden;margin-top:12px;padding-top:12px}.line-marquee:after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,var(--surface-card) 0,transparent 6%,transparent 94%,var(--surface-card) 100%)}.line-marquee-track{display:inline-flex;align-items:center;gap:12px;min-width:max-content;padding-right:12px;animation:lineMarqueeScroll 30s linear infinite}.line-marquee-item{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-pill);background:var(--surface-soft);white-space:nowrap;font-size:.78rem}.line-marquee-token{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;background:var(--line-color);color:#051018;font-size:.72rem;font-weight:900;flex:0 0 auto}.line-marquee-copy{display:inline-flex;align-items:center;flex-wrap:wrap;gap:6px;color:currentColor}.line-insights{display:grid;gap:14px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-soft)}.service-timeline-card{display:grid;gap:12px;margin-top:12px;padding:14px;border:1px solid var(--border-color);border-radius:var(--radius-xl);background:var(--surface-soft)}.service-timeline-header,.service-timeline-labels{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.service-timeline-badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:var(--radius-pill);border:1px solid var(--border-color);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase}.service-timeline-badge.is-live{border-color:color-mix(in srgb,var(--status-healthy) 35%,var(--border-color));color:#8df0b8}.service-timeline-badge.is-off{border-color:color-mix(in srgb,var(--status-alert) 35%,var(--border-color));color:#ffb38f}.service-timeline-track{position:relative;height:30px;border-radius:var(--radius-pill);border:1px solid var(--border-color);background:linear-gradient(90deg,var(--surface-strong),var(--surface-soft));overflow:hidden}.service-timeline-band{position:absolute;top:4px;bottom:4px;min-width:10px;border-radius:var(--radius-pill);background:linear-gradient(90deg,color-mix(in srgb,var(--accent-strong) 45%,transparent),color-mix(in srgb,#7dd3fc 58%,transparent));box-shadow:0 0 24px color-mix(in srgb,var(--accent-strong) 26%,transparent)}.service-timeline-now{position:absolute;top:50%;transform:translate(-50%,-50%);display:inline-grid;justify-items:center;gap:0;pointer-events:none}.service-timeline-now-line{width:2px;height:26px;border-radius:var(--radius-pill);background:color-mix(in srgb,#f8fcff 92%,var(--accent-strong));box-shadow:0 0 10px #f8fcff29}.service-timeline-now-dot{width:8px;height:8px;margin-top:-17px;border-radius:50%;background:#f8fcff;box-shadow:0 0 0 3px #f8fcff14}.service-timeline-labels span{color:var(--text-secondary);font-size:.74rem}.metric-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.metric-chip{padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-soft)}.metric-chip-healthy{border-color:color-mix(in srgb,var(--status-healthy) 28%,var(--border-color))}.metric-chip-warn{border-color:color-mix(in srgb,var(--status-warn) 34%,var(--border-color))}.metric-chip-label,.metric-chip-value,.delay-chip-label,.delay-chip-value,.delay-chip-copy,.headway-health-label,.headway-health-value,.headway-health-copy,.headway-chart-title,.headway-chart-copy{margin:0}.metric-chip-label,.delay-chip-label,.headway-health-label,.headway-chart-title{color:var(--text-secondary);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}.metric-chip-value{margin-top:6px;color:var(--text-primary);font-size:.94rem;font-weight:700}.headway-health-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.headway-health-card{padding:12px 14px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-soft)}.headway-health-value{margin-top:6px;color:var(--text-primary);font-size:1rem;font-weight:700}.headway-health-copy{margin-top:4px;color:var(--text-secondary);font-size:.76rem}.delay-distribution{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.delay-chip{padding:12px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-soft)}.delay-chip-healthy{border-color:color-mix(in srgb,var(--status-healthy) 30%,var(--border-color))}.delay-chip-warn{border-color:color-mix(in srgb,var(--status-warn) 34%,var(--border-color))}.delay-chip-alert{border-color:color-mix(in srgb,var(--status-alert) 36%,var(--border-color))}.delay-chip-value{margin-top:6px;color:var(--text-primary);font-size:1rem;font-weight:700}.delay-chip-copy{margin-top:4px;color:var(--text-secondary);font-size:.78rem}.flow-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.flow-lane{display:grid;gap:10px;min-width:0;padding:12px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-soft)}.flow-lane-header{display:flex;align-items:end;justify-content:space-between;gap:12px;flex-wrap:wrap}.flow-lane-title{margin:0;color:var(--text-primary);font-size:.84rem}.flow-lane-copy{margin:0;color:var(--text-secondary);font-size:.74rem}.flow-track{position:relative;height:42px;border-radius:var(--radius-pill);border:1px solid var(--border-color);background:linear-gradient(90deg,transparent 0,transparent calc(100% - 1px),var(--border-soft) calc(100% - 1px)),linear-gradient(180deg,#ffffff08,#ffffff03),var(--surface-strong)}.flow-track:before{content:"";position:absolute;inset:50% 14px auto;height:2px;transform:translateY(-50%);background:color-mix(in srgb,var(--line-color, var(--accent-strong)) 32%,var(--border-soft))}.flow-vehicle{position:absolute;top:50%;width:12px;height:12px;border-radius:50%;transform:translate(-50%,-50%);background:var(--line-color);box-shadow:0 0 0 4px color-mix(in srgb,var(--line-color) 18%,transparent)}.insights-clickable{cursor:pointer;transition:opacity .15s}.insights-clickable:hover{opacity:.75}.insights-clickable:active{opacity:.55}.insights-detail-tone-healthy{color:var(--status-healthy)}.insights-detail-tone-warn{color:var(--status-warn)}.insights-detail-tone-alert{color:var(--status-alert)}.insights-detail-tone-info{color:var(--status-info)}.insight-exceptions{display:grid;gap:8px}.insight-exceptions-header{display:flex;align-items:end;justify-content:space-between;gap:12px;flex-wrap:wrap}.headway-chart-title{color:var(--text-primary);font-size:.86rem}.headway-chart-copy{color:var(--text-secondary);font-size:.74rem}.insight-exception{padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--surface-soft)}.insight-exception p{margin:0;color:var(--text-primary);font-size:.8rem}.insight-exception-healthy{border-color:color-mix(in srgb,var(--status-healthy) 28%,var(--border-color))}.insight-exception-info{border-color:color-mix(in srgb,var(--status-info) 30%,var(--border-color))}.insight-exception-warn{border-color:color-mix(in srgb,var(--status-warn) 34%,var(--border-color))}.insight-exception-alert{border-color:color-mix(in srgb,var(--status-alert) 36%,var(--border-color))}@keyframes insightsTickerVertical{0%{opacity:0;transform:translateY(14px)}10%,82%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-14px)}}@keyframes lineMarqueeScroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.train-readout{color:color-mix(in srgb,var(--text-primary) 78%,transparent);font-size:.82rem}.train-id{display:inline-block;min-width:56px;margin-right:10px;color:var(--text-primary)}.train-list-section-header{padding-bottom:8px;border-bottom:1px solid var(--border-soft)}.train-line-card{display:grid;align-content:start;min-width:0}.train-columns{margin-top:0;padding-top:0;border-top:0}.train-stack-layout{display:grid;gap:14px;min-width:0}.train-list-item{display:block;min-width:0;padding:14px 16px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-soft);cursor:pointer;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease,transform .18s ease,opacity .18s ease}button.train-list-item{width:100%;font:inherit;color:inherit;text-align:left}.train-list-item:hover{border-color:color-mix(in srgb,var(--accent-strong) 32%,var(--border-color));background:var(--surface-active);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent-strong) 20%,var(--card-inset)),0 10px 26px color-mix(in srgb,#000 18%,transparent);transform:translateY(-1px);opacity:.96}.train-list-item:active{transform:translateY(0);opacity:.82}.train-list-item:focus-visible{outline:2px solid color-mix(in srgb,var(--accent-strong) 70%,white);outline-offset:2px;border-color:color-mix(in srgb,var(--accent-strong) 38%,var(--border-color));background:var(--surface-active)}.train-list-main{display:flex;align-items:center;gap:12px;min-width:0;width:100%}.train-list-main>div{min-width:0;flex:1}.train-list-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px}.train-list-token{width:30px;height:30px;flex:0 0 auto}.train-list-title,.train-list-subtitle{margin:0}.train-list-title{color:var(--text-primary);font-size:.98rem;overflow-wrap:break-word;word-break:normal}.train-list-subtitle{color:var(--text-secondary);font-size:.86rem;margin-top:4px;display:-webkit-box;overflow:hidden;-webkit-line-clamp:2;-webkit-box-orient:vertical;white-space:normal;overflow-wrap:anywhere}.train-direction-badge{display:inline-flex;align-items:center;padding:.28rem .7rem;border:1px solid var(--border-color);border-radius:var(--radius-pill);background:var(--surface-strong);color:var(--text-secondary);font-size:.68rem;letter-spacing:.08em;white-space:normal;overflow-wrap:anywhere}.train-list-status{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0 0;color:var(--accent-strong);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;overflow-wrap:anywhere}.train-focus-card{padding:18px;border-color:color-mix(in srgb,var(--line-color, var(--accent-strong)) 22%,var(--border-color));background:linear-gradient(180deg,color-mix(in srgb,var(--line-color, var(--accent-strong)) 5%,transparent),transparent),var(--surface-soft)}.train-focus-header{display:flex;align-items:start;justify-content:space-between;gap:18px}.train-focus-header>div:first-child{min-width:0}.train-focus-kicker,.train-focus-title,.train-focus-destination,.train-focus-segment,.train-focus-time,.train-focus-clock,.train-queue-heading,.train-queue-time,.train-queue-clock{margin:0}.train-focus-kicker,.train-queue-heading,.train-queue-clock{color:var(--text-secondary);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase}.train-focus-title{color:var(--text-primary);font-size:1.14rem;font-weight:700;overflow-wrap:break-word;word-break:normal}.train-focus-destination{margin-top:10px;color:var(--text-primary);font-size:.96rem;overflow-wrap:break-word;word-break:normal;white-space:normal}.train-focus-segment{margin-top:6px;color:var(--text-secondary);font-size:.84rem}.train-focus-next-stop,.train-list-next-stop{margin:4px 0 0;color:var(--text-secondary);font-size:.84rem;font-weight:500}.train-card-delayed.status-late-minor{border-left:3px solid var(--status-warn)}.train-card-delayed.status-late-moderate{border-left:3px solid var(--status-secondary)}.train-card-delayed.status-late-severe{border-left:3px solid var(--status-error)}.train-delay-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-sm);font-size:.7rem;font-weight:600;letter-spacing:.04em;background:color-mix(in srgb,currentColor 12%,transparent)}.train-progress-metric{grid-column:1 / -1}.train-progress-track{position:relative;margin-top:8px;height:32px;border-radius:var(--radius-pill);border:1px solid var(--border-color);background:linear-gradient(180deg,#ffffff08,#ffffff03),var(--surface-strong)}.train-progress-track:before{content:"";position:absolute;inset:50% 14px auto;height:2px;transform:translateY(-50%);background:color-mix(in srgb,var(--line-color, var(--accent-strong)) 32%,var(--border-soft))}.train-progress-dot{position:absolute;top:50%;width:12px;height:12px;border-radius:50%;background:var(--line-color, var(--accent-strong));transform:translate(-50%,-50%);box-shadow:0 0 0 4px color-mix(in srgb,var(--line-color, var(--accent-strong)) 18%,transparent)}.direction-filter{display:inline-flex;gap:0;border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden}.direction-filter-btn{padding:4px 10px;border:none;background:transparent;color:var(--text-secondary);font:inherit;font-size:.72rem;font-weight:600;cursor:pointer;transition:background var(--duration-fast, 80ms) ease-out,color var(--duration-fast, 80ms) ease-out}.direction-filter-btn:not(:last-child){border-right:1px solid var(--border-color)}.direction-filter-btn:hover{background:var(--surface-active)}.direction-filter-active{background:color-mix(in srgb,var(--accent-strong) 18%,transparent);color:var(--accent-strong)}.train-headway-gap{display:flex;align-items:center;gap:8px;padding:2px 0}.train-headway-line{flex:1;height:1px;background:var(--border-soft)}.train-headway-label{font-size:.68rem;color:var(--text-tertiary);white-space:nowrap;letter-spacing:.03em}.train-headway-gap.gap-medium .train-headway-label{color:var(--status-warn)}.train-headway-gap.gap-medium .train-headway-line{background:color-mix(in srgb,var(--status-warn) 30%,var(--border-soft))}.train-headway-gap.gap-large .train-headway-label{color:var(--status-error)}.train-headway-gap.gap-large .train-headway-line{background:color-mix(in srgb,var(--status-error) 30%,var(--border-soft))}.train-focus-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:12px}.train-focus-metric{padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--surface-strong)}.train-focus-metric-label,.train-focus-metric-value,.train-focus-metric-copy{margin:0}.train-focus-metric-label,.train-focus-metric-copy{color:var(--text-secondary);font-size:.72rem}.train-focus-metric-label{letter-spacing:.08em;text-transform:uppercase}.train-focus-metric-value{margin-top:6px;color:var(--text-primary);font-size:.88rem;font-weight:700}.train-focus-metric-copy{margin-top:4px}.train-focus-side,.train-queue-side{text-align:right;flex:0 1 auto;min-width:100px;max-width:40%}.train-focus-time,.train-queue-time{color:var(--text-primary);font-size:1.4rem;font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap}.train-focus-clock{margin-top:6px;color:var(--accent-strong);font-size:.8rem}.train-focus-next-stop{margin:4px 0 0;color:var(--text-secondary);font-size:.72rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.train-queue-list{display:grid;gap:10px}.train-queue-item{display:flex;align-items:center;justify-content:space-between;gap:14px}.train-queue-clock{margin-top:4px}.status-chip{display:inline-flex;align-items:center;min-height:1.9em;padding:.32rem .72rem;border:1px solid var(--status-chip-border);border-radius:var(--radius-pill);background:var(--status-chip-bg);color:var(--status-chip-text);box-shadow:inset 0 0 0 1px #ffffff0a}.status-ontime.status-chip{color:#1f8f56;border-color:#34d399b8;background:#22c55e24}.status-arriving.status-chip,.status-early.status-chip{color:#4d94ff;border-color:#60a5fab8;background:#3b82f624}.status-late-minor.status-chip{color:#b77900;border-color:#f59e0bc7;background:#f59e0b24}.status-late-moderate.status-chip{color:#c96a11;border-color:#f97316c7;background:#f9731624}.status-late-severe.status-chip{color:#d84c4c;border-color:#f87171c7;background:#ef444424}.status-muted.status-chip{color:var(--text-secondary);border-color:var(--status-chip-border);background:var(--status-chip-bg)}:root:not([data-theme=light]) .status-ontime.status-chip{color:#8df0b8;background:#4ade8024}:root:not([data-theme=light]) .status-arriving.status-chip,:root:not([data-theme=light]) .status-early.status-chip{color:#90bfff;background:#60a5fa2e}:root:not([data-theme=light]) .status-late-minor.status-chip{color:#ffd34d;background:#facc1529}:root:not([data-theme=light]) .status-late-moderate.status-chip{color:#ffb066;background:#fb923c29}:root:not([data-theme=light]) .status-late-severe.status-chip{color:#ff9b9b;background:#f8717129}@media(max-width:430px){.station-dialog{--dialog-max-height: calc(100dvh - 16px - var(--safe-area-top) - var(--safe-area-bottom));width:96vw;border-radius:var(--radius-lg)}.dialog-content{padding:calc(12px + var(--safe-area-top)) 14px 16px}.dialog-header{gap:10px;margin-bottom:12px;padding-bottom:10px}.dialog-header h3{font-size:1.05rem;line-height:1.2}.dialog-service-summary{font-size:.75rem;margin-top:4px;-webkit-line-clamp:1}.dialog-actions,.dialog-actions-top{gap:6px}.dialog-direction-tabs{padding:3px;border-radius:var(--radius-sm)}.dialog-direction-tab{min-width:0;padding:6px 8px;font-size:.7rem;letter-spacing:.03em}.dialog-body{gap:8px}.arrivals-section{padding:10px 12px;border-radius:var(--radius-sm)}.arrivals-title{font-size:.8rem;margin-bottom:8px}.arrivals-pinned{gap:6px;margin-bottom:6px}.arrival-item{padding:10px;gap:8px;border-radius:8px}.arrival-line-token{width:20px;height:20px;font-size:.7rem}.arrival-vehicle{font-size:.8rem}.arrival-destination{font-size:.72rem}.arrival-countdown{font-size:.88rem;gap:1px}.arrival-status{font-size:.6rem}.arrival-precision{font-size:.62rem}.arrivals-loading,.arrivals-empty{padding:12px 8px;font-size:.8rem}.station-alerts{margin-bottom:10px;gap:6px}.station-alert-pill{padding:10px 12px;border-radius:var(--radius-sm)}.station-alert-pill-meta{font-size:.65rem}.station-alert-pill-copy{font-size:.78rem}}@media(max-width:375px){.dialog-content{padding:calc(10px + var(--safe-area-top)) 12px calc(14px + var(--safe-area-bottom))}.dialog-header h3{font-size:1rem}.dialog-direction-tab{padding:5px 6px;font-size:.66rem}.arrivals-section{padding:8px 10px}.arrival-item{padding:8px}}.train-list-status-ok{color:var(--accent-strong)}.train-list-status-delay{color:var(--status-alert)}.train-list-status-arr{color:#ffd166}.status-muted{color:var(--text-muted)}.status-ontime{color:var(--status-healthy)}.status-arriving{color:var(--status-info)}.status-late-minor{color:var(--status-warn)}.status-late-moderate{color:var(--status-secondary)}.status-late-severe{color:var(--status-error)}.status-early{color:var(--status-info)}.train-delay{font-size:.75rem;letter-spacing:.02em}.train-inline-direction{display:inline-block;width:16px;margin-right:8px;color:var(--accent-strong)}.muted{color:var(--text-muted)}.times-direction-column{display:grid;gap:10px}.times-item{display:block;padding:12px 14px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-soft)}.times-item-main{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.times-item-title,.times-item-subtitle,.times-item-relative,.times-item-clock{margin:0}.times-item-title{color:var(--text-primary);font-size:.88rem}.times-item-subtitle{margin-top:3px;color:var(--text-secondary);font-size:.76rem}.times-item-right{text-align:right;flex:0 0 auto}.times-item-relative{color:var(--text-primary);font-size:.84rem;font-weight:700;font-variant-numeric:tabular-nums}.times-item-clock{margin-top:3px;color:var(--accent-strong);font-size:.74rem}.station-dialog{--dialog-max-height: min(880px, calc(100dvh - 32px) );padding:0;border:1px solid var(--border-color);border-radius:var(--radius-xl);background:linear-gradient(180deg,color-mix(in srgb,var(--surface-card) 98%,white 2%) 0%,var(--surface-card) 100%);box-shadow:0 25px 50px #00000080,inset 0 0 0 1px #ffffff0d;color:var(--text-primary);max-width:520px;width:90vw;max-height:var(--dialog-max-height);overflow:hidden}.station-dialog::backdrop{background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.train-dialog{max-width:520px}.train-dialog-body{display:grid;gap:16px;min-height:0;overflow:auto;padding-right:4px;overscroll-behavior:contain}.train-detail-line{position:relative;display:grid;gap:26px;padding:12px 0;--anchor-top: 26px;--anchor-bottom: calc(100% - 26px) }.train-detail-stop{display:grid;grid-template-columns:28px minmax(0,1fr);gap:18px;align-items:center;min-height:96px}.train-detail-spine{position:absolute;top:18px;bottom:18px;left:9px;width:10px;border-radius:var(--radius-pill);background:var(--line-color);box-shadow:0 0 24px color-mix(in srgb,var(--line-color) 45%,transparent)}.train-detail-marker-floating{position:absolute;left:14px;top:calc(var(--anchor-top) + (var(--anchor-bottom) - var(--anchor-top)) * var(--segment-progress) + var(--direction-offset, 0px));transform:translate(-50%,-50%);z-index:var(--z-raised)}.train-detail-marker{position:relative;width:28px;height:28px;border-radius:50%;border:5px solid var(--station-stroke);background:var(--surface-card);z-index:var(--z-base)}.train-detail-marker-ghost{opacity:0}.train-detail-vehicle-marker{display:inline-grid;place-items:center;width:32px;height:32px;filter:drop-shadow(0 0 10px color-mix(in srgb,var(--line-color) 65%,transparent))}.train-detail-arrow{width:30px;height:30px;overflow:visible}.train-detail-arrow path{fill:var(--line-color);stroke:#f8fcff;stroke-width:1.5;stroke-linejoin:round}.train-detail-label,.train-detail-name,.train-detail-status{margin:0}.train-detail-label{color:var(--text-secondary);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase}.train-detail-name{margin-top:4px;color:var(--text-primary);font-size:1.22rem}.train-detail-stop.is-current .train-detail-name{color:var(--accent-strong)}.train-detail-status{display:flex;flex-wrap:wrap;gap:8px;font-size:.9rem;letter-spacing:.08em;text-transform:uppercase}.train-eta-panel{display:grid;gap:14px}.train-eta-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.train-eta-timeline{display:grid;gap:8px}.train-eta-header{display:flex;align-items:end;justify-content:space-between;gap:12px;flex-wrap:wrap}.train-eta-header-copy,.train-eta-stop-label,.train-eta-stop-name,.train-eta-stop-countdown,.train-eta-stop-clock{margin:0}.train-eta-header-copy,.train-eta-stop-label,.train-eta-stop-clock{color:var(--text-secondary);font-size:.74rem}.train-eta-stop{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-soft)}.train-eta-stop.is-next{border-color:color-mix(in srgb,var(--status-info) 34%,var(--border-color))}.train-eta-stop.is-terminal{border-color:color-mix(in srgb,var(--accent-strong) 28%,var(--border-color))}.train-eta-stop-name{margin-top:4px;color:var(--text-primary);font-size:.98rem}.train-eta-stop-side{text-align:right;flex:0 0 auto}.train-eta-stop-countdown{color:var(--text-primary);font-size:.96rem;font-weight:700;font-variant-numeric:tabular-nums}.train-eta-stop-clock{margin-top:4px}.alert-dialog-body{margin:0;color:var(--text-secondary);line-height:1.6}.alert-dialog-item{padding:12px 14px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-soft)}.alert-dialog-item+.alert-dialog-item{margin-top:10px}.alert-dialog-item-meta,.alert-dialog-item-title,.alert-dialog-item-copy,.alert-dialog-item-link-wrap{margin:0}.alert-dialog-item-meta{color:var(--status-alert);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}.alert-dialog-item-title{margin-top:6px;color:var(--text-primary);font-size:.92rem}.alert-dialog-item-copy{margin-top:6px;color:var(--text-secondary);line-height:1.55}.alert-dialog-item-link-wrap{margin-top:8px}.alert-dialog-link{color:#7fc8ff;text-decoration:none}.alert-dialog-link:hover{text-decoration:underline}@media(max-width:700px){.line-card-header{flex-direction:column}.service-reminder{min-width:0;max-width:100%;width:100%}.train-detail-stop{grid-template-columns:28px minmax(0,1fr);gap:14px;min-height:84px}.train-detail-spine{left:9px}.train-detail-line{--anchor-top: 24px;--anchor-bottom: calc(100% - 24px) }.train-detail-name{font-size:1.02rem}.train-eta-summary{grid-template-columns:1fr}.train-eta-stop{display:grid}.train-eta-stop-side{text-align:left}.metric-strip,.headway-health-grid,.delay-distribution,.flow-grid{grid-template-columns:1fr}.train-focus-header,.train-queue-item,.train-list-row{display:flex;flex-wrap:wrap;gap:10px}.train-focus-header{flex-direction:column;gap:8px}.train-list-row{align-items:flex-start}.train-list-title{font-size:.92rem;word-break:keep-all}.train-focus-title{font-size:1.05rem;word-break:keep-all}.train-focus-metrics{grid-template-columns:1fr}.train-focus-side,.train-queue-side{text-align:left}}.dialog-content{display:flex;flex-direction:column;max-height:var(--dialog-max-height);padding:20px 24px 24px}.dialog-header{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:16px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.dialog-header-main{min-width:0}.dialog-title-wrap{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.dialog-title-wrap .dialog-title{flex:1 1 auto;min-width:0}.dialog-title-wrap .dialog-meta{display:flex;align-items:center;gap:6px;margin-top:0;height:44px;padding:0 10px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--surface-strong);font-size:.75rem;white-space:nowrap;width:fit-content}.dialog-title-wrap .dialog-meta .status-pill{padding:4px 8px;font-size:.76rem}.dialog-title-wrap .dialog-meta .updated-at{margin-top:0;font-size:.72rem;color:var(--text-secondary)}.dialog-actions{display:flex;align-items:center;gap:8px;min-width:0}.dialog-actions-top{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end;min-width:0}.dialog-actions-top .dialog-meta,.dialog-actions-top .updated-at{margin-top:0}.dialog-direction-bar{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.dialog-direction-tabs{display:flex;gap:6px;padding:4px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-strong)}.dialog-direction-tab{min-width:60px;padding:8px 12px;border:0;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font:inherit;font-size:.78rem;letter-spacing:.08em;cursor:pointer;transition:background .15s ease,color .15s ease}.dialog-direction-tab:hover{color:var(--text-primary)}.dialog-direction-tab.is-active{background:var(--surface-active);color:var(--text-primary)}.dialog-meta{display:none;align-items:center;gap:8px;margin-top:12px}.dialog-header h3{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.dialog-service-summary{margin:8px 0 0;color:var(--text-secondary);font-size:.82rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.45}.dialog-title{max-width:100%;overflow:hidden}.dialog-title-track{display:block;max-width:100%}.dialog-title-text-clone{display:none}.dialog-header>div:first-child{min-width:0}.dialog-close{width:44px;height:44px;border:1px solid var(--border-color);border-radius:8px;background:var(--surface-soft);color:var(--text-secondary);font-size:1.5rem;line-height:1;cursor:pointer;transition:all .2s ease;flex:0 0 auto}.dialog-mode-button{width:auto;min-width:72px;height:44px;padding:0 12px;font-size:.82rem;letter-spacing:.08em}.dialog-header .status-pill,.dialog-actions .status-pill{flex:0 0 auto;min-width:max-content;white-space:nowrap}.dialog-close:hover{background:var(--surface-active);color:var(--text-primary);border-color:var(--border-color)}@media(max-width:700px){.dialog-content{padding:calc(16px + var(--safe-area-top)) 16px calc(16px + var(--safe-area-bottom))}.dialog-header{grid-template-columns:1fr auto;gap:12px;margin-bottom:12px;padding-bottom:12px}.dialog-title-wrap{gap:8px}.dialog-title-wrap .dialog-meta{padding:3px 8px;font-size:.7rem;display:flex;min-width:unset;width:fit-content}.dialog-title-wrap .dialog-meta .status-pill{padding:6px 10px;font-size:.72rem}.dialog-title-wrap .dialog-meta .updated-at{font-size:.68rem}.dialog-header h3{font-size:1.1rem;line-height:1.25}.dialog-service-summary{margin-top:6px;font-size:.78rem}.dialog-actions{display:flex;align-items:center;gap:4px}.dialog-actions .dialog-share-button,.dialog-actions .dialog-mode-button{padding:0 10px;font-size:.72rem;min-width:unset;width:auto;height:36px;letter-spacing:.04em}.dialog-actions .dialog-favorite-button{width:36px;height:36px}.dialog-direction-bar{margin-bottom:12px;padding-bottom:10px}.dialog-direction-tabs{width:100%;justify-content:space-between}.dialog-direction-tab{min-width:0;flex:1;padding:8px 10px;font-size:.72rem;letter-spacing:.05em}.dialog-actions-top{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;justify-content:start;gap:8px}.dialog-actions .status-pill{align-self:stretch;justify-content:center;padding-inline:10px}.dialog-mode-button{min-width:60px;height:36px;padding:0 10px;font-size:.74rem}.dialog-actions>.dialog-close:not(.dialog-share-button):not(.dialog-mode-button):not(.dialog-favorite-button){width:36px;height:36px;font-size:1.2rem}.dialog-meta{display:inline-grid;justify-items:start;gap:4px;min-width:0;padding:8px 10px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:color-mix(in srgb,var(--surface-strong) 92%,transparent)}.dialog-meta .status-pill{padding:6px 10px;font-size:.72rem}.dialog-meta .updated-at{margin-top:0;font-size:.76rem;line-height:1.3}.dialog-body{gap:10px}.arrivals-section{padding:14px}.arrivals-title{margin-bottom:8px}.arrivals-pinned{margin-bottom:6px}.arrivals-title{margin-bottom:10px;font-size:.86rem}.arrival-item{padding:8px 10px;gap:3px}.arrival-row-mid,.arrival-row-bottom{padding-left:30px}.arrival-line-token{width:22px;height:22px}.arrival-status{font-size:.64rem}.arrival-countdown{font-size:1.02rem}.arrival-precision{font-size:.68rem}}.dialog-body{display:grid;gap:20px;min-height:0;overflow:auto;padding-right:4px;overscroll-behavior:contain}.station-alerts{display:grid;gap:8px;margin-bottom:18px}.station-alert-pill{display:grid;gap:4px;width:100%;padding:12px 14px;border:1px solid color-mix(in srgb,var(--status-alert) 34%,var(--border-color));border-radius:var(--radius-lg);background:color-mix(in srgb,var(--status-alert) 7%,var(--surface-soft));color:var(--text-primary);text-align:left;font:inherit;cursor:pointer}.station-alert-pill-meta{color:var(--status-alert);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}.station-alert-pill-copy{color:var(--text-primary);font-size:.84rem}.arrivals-section{padding:16px;background:color-mix(in srgb,var(--surface-card) 88%,transparent);border-radius:var(--radius-md);border:1px solid var(--border-soft)}.arrivals-pinned{display:grid;gap:8px;margin-bottom:8px}.arrivals-pinned-kicker,.arrivals-following-heading{margin:0;color:var(--text-secondary);font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.arrivals-following-heading{margin-top:4px}.arrivals-title{margin:0 0 12px;font-size:.9rem;font-weight:600;color:var(--accent-strong);letter-spacing:.05em;line-height:1.35}.arrivals-list{display:grid;gap:8px;transition:transform .6s ease}.arrivals-viewport{overflow:hidden}.arrival-item{display:grid;gap:4px;padding:10px 12px;background:var(--surface-soft);border-radius:var(--radius-sm);border:1px solid var(--border-color);min-width:0}.arrival-row{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0}.arrival-row-mid{display:flex;align-items:baseline;gap:8px;padding-left:32px}.arrival-row-mid .arrival-status{margin-right:auto}.arrival-row-bottom{display:flex;align-items:center;gap:8px;padding-left:32px}button.arrival-item{width:100%;font:inherit;color:inherit;text-align:left}.arrival-item-clickable{cursor:pointer;transition:border-color .18s ease,background .18s ease,transform .18s ease}.arrival-item-clickable:hover{background:var(--surface-active);border-color:color-mix(in srgb,var(--accent-strong) 35%,var(--border-color));transform:translateY(-1px)}.arrival-item-clickable:focus-visible{outline:2px solid color-mix(in srgb,var(--accent-strong) 70%,white);outline-offset:2px}.arrival-meta{display:inline-flex;align-items:center;gap:8px;min-width:0;flex:1 1 0;overflow:hidden}.arrival-line-token{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;background:var(--line-color);color:#051018;font-size:.78rem;font-weight:900;box-shadow:0 0 14px color-mix(in srgb,var(--line-color) 60%,transparent)}.arrival-destination{font-size:.88rem;font-weight:600;line-height:1.25;color:color-mix(in srgb,var(--text-primary) 88%,transparent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1 1 0}.arrival-vehicle{font-size:.72rem;line-height:1.35;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1 1 0}.arrival-countdown{font-size:.96rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;white-space:nowrap}.arrival-status{font-size:.68rem;font-weight:700;letter-spacing:.08em}.arrival-status-ok{color:var(--accent-strong)}.arrival-status-delay{color:var(--status-alert)}.arrival-status-arr{color:#ffd166}.arrival-clock{font-size:.72rem;font-weight:500;color:var(--text-secondary);font-variant-numeric:tabular-nums;white-space:nowrap}.arrival-precision{font-size:.72rem;font-weight:400;color:var(--text-muted);white-space:nowrap;flex:0 0 auto}.arrivals-loading,.arrivals-empty{padding:16px 12px;color:var(--text-muted);font-size:.86rem;text-align:center;background:transparent;border:none;border-radius:0}.arrivals-loading{color:var(--text-secondary);font-style:italic}.station-dialog.is-display-mode{max-width:none;width:100vw;min-height:100vh;margin:0;border-radius:0}.station-dialog.is-display-mode .dialog-content{display:grid;grid-template-rows:auto 1fr;min-height:100vh;padding:calc(26px + env(safe-area-inset-top)) calc(32px + env(safe-area-inset-right)) calc(32px + env(safe-area-inset-bottom)) calc(32px + env(safe-area-inset-left))}.station-dialog.is-display-mode .dialog-header{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border-color);position:relative}.station-dialog.is-display-mode .dialog-header-main{min-width:0;flex:1 1 auto}.station-dialog.is-display-mode .dialog-title-wrap{display:flex;align-items:baseline;gap:16px}.station-dialog.is-display-mode .dialog-title-wrap .dialog-meta{display:flex;align-items:center;gap:12px;min-width:max-content;padding:0;border:none;background:transparent}.station-dialog.is-display-mode .dialog-title-wrap .dialog-meta .status-pill{font-size:.9rem;padding:8px 14px}.station-dialog.is-display-mode .dialog-title-wrap .dialog-meta .updated-at{font-size:.85rem;color:var(--text-tertiary)}.station-dialog.is-display-mode .dialog-title{display:flex;align-items:baseline;gap:16px}.station-dialog.is-display-mode .dialog-service-summary{margin-top:10px;font-size:.98rem;color:var(--text-secondary)}.station-dialog.is-display-mode .dialog-header h3{font-size:clamp(1.8rem,2.5vw,2.4rem);letter-spacing:.02em;line-height:1.2;white-space:nowrap;margin:0}.station-dialog.is-display-mode .dialog-title-track{display:inline-flex;align-items:center;gap:2.5rem;min-width:0}.station-dialog.is-display-mode .dialog-title.is-marquee .dialog-title-track{width:max-content;animation:dialogTitleMarquee 12s linear infinite}.station-dialog.is-display-mode .dialog-title.is-marquee .dialog-title-text-clone{display:inline}.station-dialog.is-display-mode .dialog-service-summary{margin-top:10px;font-size:.98rem}.station-dialog.is-display-mode .dialog-meta{display:flex;align-items:center;gap:12px;margin-top:0;min-width:max-content;padding:0;border:none;background:transparent}.station-dialog.is-display-mode .dialog-actions{display:flex;align-items:center;gap:16px;flex:0 0 auto}.station-dialog.is-display-mode .dialog-actions-top{display:flex;align-items:center;gap:12px}.station-dialog.is-display-mode .dialog-direction-bar,.station-dialog.is-display-mode #station-alerts-container:empty{display:none}.station-dialog.is-display-mode .dialog-direction-tabs{display:inline-flex;min-width:0;margin-left:8px}.station-dialog.is-display-mode .dialog-mode-button{position:static;min-width:72px;height:40px;font-size:.8rem}.station-dialog.is-display-mode .dialog-meta .status-pill{font-size:.9rem;padding:8px 14px}.station-dialog.is-display-mode .dialog-meta .updated-at{margin-top:0;font-size:.85rem;color:var(--text-tertiary)}.station-dialog.is-display-mode .dialog-body{grid-template-columns:repeat(2,minmax(0,1fr));align-content:start;gap:20px;overflow:hidden}.station-dialog.show-nb-only .dialog-body,.station-dialog.show-sb-only .dialog-body{grid-template-columns:1fr}.station-dialog.show-nb-only [data-direction-section=sb],.station-dialog.show-sb-only [data-direction-section=nb]{display:none}.station-dialog.is-display-mode .arrivals-section{display:grid;grid-template-rows:auto minmax(0,auto) minmax(0,1fr);min-height:0;padding:22px;transform-origin:center center;overflow:hidden}.station-dialog.is-display-mode .arrivals-pinned{gap:14px;margin-bottom:14px}.station-dialog.is-display-mode .arrivals-title{margin-bottom:18px;font-size:1.6rem;overflow:hidden;white-space:nowrap}.station-dialog.is-display-mode .arrivals-title-track{display:inline-flex;align-items:center;gap:2.5rem}.station-dialog.is-display-mode .arrivals-title.is-marquee .arrivals-title-track{animation:arrivalsTitleMarquee 10s linear infinite}.arrivals-title-clone,.station-dialog.is-display-mode .arrivals-title-clone{display:none}.station-dialog.is-display-mode .arrivals-title.is-marquee .arrivals-title-clone{display:inline}@keyframes arrivalsTitleMarquee{0%{transform:translate(0)}to{transform:translate(-50%)}}.station-dialog.is-display-mode .arrivals-viewport{min-height:0}.station-dialog.is-display-mode .arrivals-list{gap:14px}.station-dialog.is-display-mode .arrival-item{padding:18px 20px;border-radius:var(--radius-lg)}.station-dialog.is-display-mode .arrivals-section.is-direction-animating{animation:dialog-direction-swap .52s cubic-bezier(.2,.8,.2,1)}@keyframes dialog-direction-swap{0%{opacity:0;transform:translate(28px) scale(.985);filter:blur(8px)}to{opacity:1;transform:translate(0) scale(1);filter:blur(0)}}@media(prefers-reduced-motion:reduce){.station-dialog.is-display-mode .arrivals-section.is-direction-animating{animation:none}}.station-dialog.is-display-mode .arrival-line-token{width:42px;height:42px;font-size:1.3rem}.station-dialog.is-display-mode .arrival-vehicle{font-size:1.45rem;line-height:1.15}.station-dialog.is-display-mode .arrival-destination{font-size:1.15rem}.station-dialog.is-display-mode .arrival-countdown{font-size:2rem;white-space:nowrap}.station-dialog.is-display-mode .arrival-precision{display:none}.station-dialog.is-display-mode .arrival-status{font-size:1rem}.station-dialog.is-display-mode .arrival-source{font-size:.85rem;padding:4px 10px;border-radius:6px}.station-dialog.is-display-mode .arrival-clock{font-size:1.1rem}@keyframes wave{0%{opacity:.9;transform:scale(.55)}to{opacity:0;transform:scale(2.1)}}@keyframes dialogTitleMarquee{0%{transform:translate(0)}to{transform:translate(calc(-50% - 1.25rem))}}@media(max-width:1100px){.board{grid-template-columns:1fr}.screen{width:min(100vw - 20px - var(--safe-area-left) - var(--safe-area-right),100%);padding-top:calc(14px + var(--safe-area-top));padding-bottom:calc(22px + var(--safe-area-bottom))}.toast-region{right:calc(10px + var(--safe-area-right));left:calc(10px + var(--safe-area-left));bottom:calc(10px + var(--safe-area-bottom))}.toast{min-width:0;max-width:none}.screen-header{display:grid;gap:8px;margin-bottom:8px}.screen-kicker{font-size:.72rem;letter-spacing:.14em}h1{font-size:clamp(1.6rem,8vw,2.3rem);line-height:1.02}.screen-pills{justify-content:start}.switcher-stack{position:sticky;top:max(8px,var(--safe-area-top));z-index:var(--z-sticky);gap:6px;margin-bottom:8px;padding:2px 0 0}.tab-bar{margin-bottom:0;border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.line-switcher{display:flex;grid-column:1 / -1;gap:8px;width:100%;min-width:0;max-width:100%;margin:-2px 0 8px;padding:0 1px 2px;overflow-x:auto;overscroll-behavior-x:contain;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scrollbar-width:none}.line-switcher::-webkit-scrollbar{display:none}.line-switcher-button{position:relative;flex:0 0 auto;gap:8px;min-height:0;padding:7px 11px;border-radius:var(--radius-pill);background:color-mix(in srgb,var(--surface-card) 58%,transparent);box-shadow:none;scroll-snap-align:start}.line-switcher-button:after{content:"";position:absolute;inset:auto 10px -1px;height:2px;border-radius:var(--radius-pill);background:color-mix(in srgb,var(--line-color) 82%,white 18%);opacity:0;transform:scaleX(.65);transition:opacity .18s ease,transform .18s ease}.line-switcher-button.is-active{background:color-mix(in srgb,var(--line-color) 10%,var(--surface-card));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--line-color) 40%,var(--border-color))}.line-switcher-button.is-active:after{opacity:1;transform:scaleX(1)}.line-switcher-token{width:20px;height:20px;font-size:.68rem}.line-switcher-label-full{display:none}.line-switcher-label-compact{display:block;font-size:.76rem;letter-spacing:.02em}.board{gap:14px}.line-readout-grid{grid-template-columns:1fr}.line-diagram{max-width:520px}.metric-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.delay-distribution,.flow-grid{grid-template-columns:1fr}.system-summary-header{display:grid}.system-trend-strip,.system-summary-strip,.attention-breakdown-grid,.system-priority-list,.system-ranking-list{grid-template-columns:1fr}.tab-bar{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));width:100%}.tab-button{min-width:0}.line-card,.panel-card{padding:12px 12px 10px;border-radius:18px}.line-card-header{gap:8px;margin-bottom:2px}.line-title{gap:8px}.line-title h2{font-size:1rem}.line-title p{font-size:.78rem;line-height:1.2}.line-title-copy p:last-child{display:none}.service-reminder,.line-marquee{display:none}.line-diagram{display:block;width:calc(100% + 20px);max-width:none;height:auto;margin:2px -10px 0}.station-label{font-size:16px}.station-label-multiline{font-size:14px}.segment-time{font-size:12px}.times-item-main{flex-direction:column}.times-item-right{text-align:left}.station-dialog{--dialog-max-height: calc(100dvh - 20px) ;max-width:100%;width:95vw;margin:auto}.station-dialog.is-display-mode .dialog-content{padding:calc(16px + env(safe-area-inset-top)) calc(16px + env(safe-area-inset-right)) calc(20px + env(safe-area-inset-bottom)) calc(16px + env(safe-area-inset-left))}.station-dialog.is-display-mode .dialog-body{grid-template-columns:1fr}.station-dialog.is-display-mode .dialog-header{flex-direction:column;align-items:flex-start;gap:12px}.station-dialog.is-display-mode .dialog-title-wrap{flex-direction:column;align-items:flex-start;gap:8px}.station-dialog.is-display-mode .dialog-title-wrap .dialog-meta{padding:6px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--surface-strong)}.station-dialog.is-display-mode .dialog-header h3{font-size:1.5rem}.station-dialog.is-display-mode .dialog-actions{gap:8px;min-width:0}.station-dialog.is-display-mode .dialog-actions-top{grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:8px 10px}.station-dialog.is-display-mode .dialog-direction-tabs{width:100%;grid-column:1 / -1}.dialog-direction-tab{min-width:0;flex:1 1 0}.station-dialog.is-display-mode .dialog-meta .status-pill{font-size:.95rem;padding:10px 14px}.station-dialog.is-display-mode .dialog-meta .updated-at{font-size:.92rem}.station-dialog.is-display-mode .dialog-body{gap:14px}.station-dialog.is-display-mode .arrivals-title{margin-bottom:10px;font-size:1.1rem}.station-dialog.is-display-mode .arrivals-pinned{margin-bottom:8px}.station-dialog.is-display-mode .arrival-vehicle{font-size:1rem}.station-dialog.is-display-mode .arrival-destination{font-size:.86rem}.station-dialog.is-display-mode .arrival-countdown{font-size:1.2rem}.station-dialog.is-display-mode .arrival-status{font-size:.78rem}.station-dialog.is-display-mode .arrival-source{font-size:.72rem;padding:3px 8px}.station-dialog.is-display-mode .arrival-clock{font-size:.82rem}}@keyframes dialogIn{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes dialogOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(16px) scale(.97)}}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}dialog[open]{animation:dialogIn var(--duration-slow) var(--ease-out) both}dialog[open]::backdrop{animation:backdropIn var(--duration-normal) ease both}dialog.is-closing{animation:dialogOut var(--duration-normal) var(--ease-in-out) both}dialog.is-closing::backdrop{opacity:0;transition:opacity var(--duration-normal) ease}@keyframes toastIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(16px)}}.toast{animation:toastIn var(--duration-normal) var(--ease-out) both}.toast.toast-leaving{animation:toastOut var(--duration-fast) var(--ease-in-out) both}.board{transition:opacity var(--duration-fast) var(--ease-in-out)}@keyframes arrivalItemIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.arrival-item{animation:arrivalItemIn var(--duration-normal) var(--ease-out) both}.arrival-item:nth-child(1){animation-delay:0ms}.arrival-item:nth-child(2){animation-delay:40ms}.arrival-item:nth-child(3){animation-delay:50ms}.arrival-item:nth-child(4){animation-delay:60ms}.arrival-item:nth-child(5){animation-delay:70ms}.arrival-item:nth-child(6){animation-delay:80ms}.arrival-item:nth-child(7){animation-delay:90ms}.arrival-item:nth-child(8){animation-delay:.1s}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.arrivals-loading{background:linear-gradient(90deg,var(--surface-soft) 25%,var(--surface-active) 50%,var(--surface-soft) 75%);background-size:200% 100%;animation:shimmer 1.5s ease infinite;border-radius:8px}.line-switcher-button:active{transform:scale(.96);transition-duration:var(--duration-instant)}@media(min-width:701px)and (max-width:1100px){.metric-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.system-summary-strip{grid-template-columns:repeat(3,minmax(0,1fr))}.system-ranking-list{grid-template-columns:repeat(2,minmax(0,1fr))}.station-dialog{max-width:720px;width:92vw;margin:auto}.station-dialog .dialog-content{padding:24px 28px 28px}.station-dialog .dialog-header{gap:16px;margin-bottom:16px;padding-bottom:16px}.station-dialog .dialog-header h3{font-size:1.3rem}.station-dialog .dialog-service-summary{font-size:.88rem}.station-dialog .dialog-direction-tab{min-width:72px;padding:10px 14px;font-size:.82rem}.station-dialog .dialog-mode-button{min-width:80px;height:44px;font-size:.82rem}.station-dialog .dialog-body{gap:16px}.station-dialog .arrivals-section{padding:18px 20px}.station-dialog .arrivals-title{font-size:.94rem;margin-bottom:14px}.station-dialog .arrival-item{padding:14px 16px;gap:14px}.station-dialog .arrival-vehicle{font-size:.92rem}.station-dialog .arrival-destination{font-size:.82rem}.station-dialog .arrival-countdown{font-size:1.02rem}.train-focus-metrics,.train-eta-summary{grid-template-columns:repeat(3,minmax(0,1fr))}.headway-health-grid,.delay-distribution{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-height:500px)and (orientation:landscape){.station-dialog{--dialog-max-height: calc(100dvh - 12px) ;max-width:80vw}.dialog-content{padding:12px calc(16px + var(--safe-area-right)) 14px calc(16px + var(--safe-area-left))}.dialog-header{margin-bottom:8px;padding-bottom:8px;gap:10px}.dialog-header h3{font-size:1rem}.dialog-body{gap:8px}.arrivals-section{padding:8px 10px}}.arrival-source{font-size:.6rem;font-weight:700;letter-spacing:.1em;padding:2px 6px;border-radius:4px;text-align:center}.arrival-source-live{color:var(--accent-strong);background:color-mix(in srgb,var(--accent-strong) 14%,transparent)}.arrival-source-sched{color:var(--text-muted);background:var(--surface-soft)}.train-detail-stop-clickable{cursor:pointer;transition:background var(--duration-fast) ease;border-radius:8px;padding:4px 6px;margin:-4px -6px}.train-detail-stop-clickable:hover{background:var(--surface-active)}.train-detail-stop-clickable:focus-visible{outline:2px solid color-mix(in srgb,var(--accent-strong) 70%,white);outline-offset:2px}[data-timeline-station-id]{cursor:pointer;transition:background var(--duration-fast) ease}[data-timeline-station-id]:hover{background:var(--surface-active)}[data-timeline-station-id]:focus-visible{outline:2px solid color-mix(in srgb,var(--accent-strong) 70%,white);outline-offset:2px}.search-highlight{background:color-mix(in srgb,var(--accent-strong) 25%,transparent);color:var(--accent-strong);border-radius:2px;padding:0 1px}.skeleton-board{grid-column:1 / -1;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}.skeleton-card{display:grid;gap:12px;padding:20px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-card)}.skeleton-line{height:14px;border-radius:7px;background:linear-gradient(90deg,var(--surface-soft) 25%,var(--surface-active) 50%,var(--surface-soft) 75%);background-size:200% 100%;animation:shimmer 1.5s ease infinite}.skeleton-line-wide{width:75%}.skeleton-line-narrow{width:45%}@media(max-width:700px){.skeleton-board{grid-template-columns:1fr;gap:14px}}::view-transition-old(root),::view-transition-new(root){animation-duration:var(--duration-slow);animation-timing-function:var(--ease-in-out)}::view-transition-old(root){animation-name:none}::view-transition-new(root){animation-name:none;mix-blend-mode:normal}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-delay:0ms!important;transition-duration:.01ms!important}}.dialog-favorite-button{width:44px;height:44px;border:1px solid var(--border-color);border-radius:8px;background:var(--surface-soft);color:var(--text-secondary);font-size:1.4rem;line-height:1;cursor:pointer;transition:all .2s ease;flex:0 0 auto}.dialog-favorite-button:hover{background:var(--surface-active);color:var(--text-primary);border-color:color-mix(in srgb,var(--status-warn) 40%,var(--border-color))}.dialog-favorite-button.is-favorite{color:var(--status-warn);border-color:color-mix(in srgb,var(--status-warn) 50%,var(--border-color));background:color-mix(in srgb,var(--status-warn) 8%,var(--surface-soft))}.dialog-favorite-button.is-favorite:hover{background:color-mix(in srgb,var(--status-warn) 15%,var(--surface-active))}.favorites-list{display:grid;gap:10px}.favorite-item{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-soft);cursor:pointer;transition:border-color .18s ease,background .18s ease,transform .18s ease}.favorite-item:hover{background:var(--surface-active);border-color:color-mix(in srgb,var(--accent-strong) 35%,var(--border-color));transform:translateY(-1px)}.favorite-item:active{transform:translateY(0)}.favorite-item-missing{opacity:.6;cursor:not-allowed}.favorite-item-missing:hover{background:var(--surface-soft);border-color:var(--border-color);transform:none}.favorite-item-content{flex:1 1 auto;min-width:0}.favorite-item-header{display:flex;align-items:flex-start;gap:12px}.favorite-arrivals-preview{margin-top:12px}.favorite-arrivals-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.favorite-arrival-lane{display:grid;gap:6px;padding:10px 12px;border-radius:12px;border:1px solid color-mix(in srgb,var(--border-color) 90%,transparent);background:color-mix(in srgb,var(--surface) 55%,var(--surface-soft))}.favorite-arrival-direction{color:var(--text-secondary);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}.favorite-arrival-chips{display:flex;flex-wrap:wrap;gap:8px}.favorite-arrival-chip{display:inline-flex;align-items:center;gap:6px;min-height:30px;padding:0 10px;border-radius:999px;background:var(--surface-active);color:var(--text-primary);font-size:.8rem;font-weight:600}.favorite-arrival-chip.is-live{background:color-mix(in srgb,var(--status-ok) 18%,var(--surface-active))}.favorite-arrival-chip-badge{color:var(--status-ok);font-size:.64rem;letter-spacing:.08em}.favorite-arrival-status,.favorite-arrival-empty{margin:0;color:var(--text-secondary);font-size:.78rem}.favorite-arrival-updated{margin-top:8px}.favorite-item-title{margin:0;color:var(--text-primary);font-size:.98rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.favorite-item-meta{margin:4px 0 0;color:var(--text-secondary);font-size:.78rem}.favorite-item-arrow{color:var(--text-secondary);font-size:1.2rem;transition:transform .2s ease}.favorite-item:hover .favorite-item-arrow{transform:translate(3px);color:var(--text-primary)}.favorite-item-actions{display:flex;gap:4px;padding:6px 0 0;border-top:1px solid var(--border);margin-top:8px}.favorite-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:5px 0;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);font-size:.7rem;letter-spacing:.03em;cursor:pointer;transition:background .15s,color .15s}.favorite-action-btn:hover{background:var(--surface-hover, rgba(255, 255, 255, .06));color:var(--text-primary)}.favorite-action-remove:hover{color:var(--danger, #e53e3e)}@media(max-width:700px){.dialog-favorite-button{width:36px;height:36px;font-size:1.2rem}.favorite-item{padding:12px 14px}.favorite-arrivals-grid{grid-template-columns:1fr}.favorite-item-title{font-size:.92rem}.favorite-item-meta,.favorite-arrival-status,.favorite-arrival-empty{font-size:.74rem}}.dialog-share-button{width:auto;min-width:72px;height:48px;padding:0 14px;border:1px solid var(--border-color);border-radius:8px;background:var(--surface-soft);color:var(--text-secondary);font-size:.82rem;letter-spacing:.08em;line-height:1;cursor:pointer;transition:all .2s ease;flex:0 0 auto}.dialog-share-button:hover{background:var(--surface-active);color:var(--text-primary);border-color:color-mix(in srgb,var(--status-info) 40%,var(--border-color))}
