@import"https://fonts.googleapis.com/css2?family=Share+Tech+Mono&display=swap";.flight-board{--color-text: #0b2545;--color-text-secondary: #5b7ba8;--color-accent: #3aa0ff;--color-accent-bg: #dcefff;--color-divider: rgba(11, 37, 69, .08);--color-success: #16a34a;--color-warning: #f59e0b;--color-muted: #94a3b8;min-height:100vh;background:linear-gradient(180deg,#fff,#f0f7ff);color:var(--color-text);font-family:Inter,system-ui,-apple-system,sans-serif;font-feature-settings:"tnum";padding:24px 16px}@media (prefers-color-scheme: dark){.flight-board{background:linear-gradient(180deg,#fff,#f0f7ff);color:var(--color-text)}}.flight-board__grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:1200px;margin:0 auto}@media (max-width: 720px){.flight-board__grid{grid-template-columns:1fr;gap:16px}.flight-board{padding:16px 12px}}.flight-board__section{background:#fff;border-radius:20px;box-shadow:0 1px 3px #0b25450f,0 4px 12px #0b25450a,0 8px 24px #0b254505;padding:24px;overflow:hidden}.flight-board__section-title{font-size:18px;font-weight:700;color:var(--color-text);margin:0 0 16px;display:flex;align-items:center;gap:8px}.flight-board__section-title-icon{color:var(--color-accent);flex-shrink:0}.flight-board__table-wrapper{overflow-x:auto}.flight-board__table{width:100%;border-collapse:collapse}.flight-board__table-header{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);padding:0 8px 10px;text-align:left;white-space:nowrap;border-bottom:1px solid var(--color-divider)}.flight-board__row{transition:transform .3s ease,opacity .3s ease}.flight-board__row td{padding:12px 8px;vertical-align:middle;border-bottom:1px solid var(--color-divider)}.flight-board__row:last-child td{border-bottom:none}.flight-board__row--imminent{position:relative}.flight-board__row--imminent td:first-child{box-shadow:inset 2px 0 0 var(--color-accent)}.flight-board__row--imminent td{background:#3aa0ff1f}.flight-board__row--imminent .flight-board__time-number{color:#1e7fd6;font-weight:800}.flight-board__arriving-soon{color:#1e7fd6;font-weight:700;font-size:16px}.flight-board__row--arrived td{background:#16a34a14;opacity:.75}.flight-board__arrived{color:#16a34a;font-weight:800;font-size:16px}.flight-board__arrived-label{display:inline-block;margin-left:6px;padding:1px 6px;border-radius:999px;background:#16a34a;color:#fff;font-size:10px;font-weight:700;letter-spacing:.05em;vertical-align:middle}.flight-board__badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:999px;font-size:13px;font-weight:700;white-space:nowrap;line-height:1.2}.flight-board__badge--normal{background:#e0f2fe;color:#0284c7}.flight-board__badge--seat{background:#dbeafe;color:#1d4ed8}.flight-board__badge--village{background:#dcfce7;color:#15803d}.flight-board__time{display:inline-flex;align-items:baseline;gap:2px}.flight-board__time-number{font-size:22px;font-weight:700;line-height:1;color:var(--color-text)}.flight-board__time-unit{font-size:12px;font-weight:500;color:var(--color-text-secondary)}.flight-board__time--ended{font-size:13px;font-weight:600;color:var(--color-muted)}.flight-board__location{font-size:13px;color:var(--color-text-secondary);white-space:nowrap}.flight-board__platform{font-size:12px;font-weight:600;color:var(--color-text-secondary);background:#0b25450d;padding:2px 8px;border-radius:6px;white-space:nowrap}.flight-board__row-icon{color:var(--color-text-secondary);flex-shrink:0;width:18px;height:18px}.flight-board__subway{margin-top:16px;padding:16px;background:linear-gradient(135deg,#f8fafc,#f0f7ff);border-radius:14px;border:1px solid var(--color-divider)}.flight-board__subway-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.flight-board__subway-label{font-size:14px;font-weight:700;color:var(--color-text)}.flight-board__subway-icon{color:var(--color-accent);flex-shrink:0}.flight-board__subway-trains{display:flex;flex-direction:column;gap:8px}.flight-board__subway-row{display:flex;justify-content:space-between;align-items:center}.flight-board__subway-row-label{font-size:12px;font-weight:500;color:var(--color-text-secondary)}.flight-board__subway-row-time{font-size:16px;font-weight:700;color:var(--color-text)}.flight-board__skeleton{max-width:1200px;margin:0 auto}.flight-board__skeleton-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}@media (max-width: 720px){.flight-board__skeleton-grid{grid-template-columns:1fr;gap:16px}}.flight-board__skeleton-card{background:#fff;border-radius:20px;box-shadow:0 1px 3px #0b25450f,0 4px 12px #0b25450a;padding:24px}.flight-board__skeleton-title{width:140px;height:20px;background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%);background-size:200% 100%;animation:flight-board-shimmer 1.5s ease-in-out infinite;border-radius:8px;margin-bottom:20px}.flight-board__skeleton-row{display:flex;gap:12px;align-items:center;padding:14px 0;border-bottom:1px solid var(--color-divider)}.flight-board__skeleton-row:last-child{border-bottom:none}.flight-board__skeleton-pill{width:64px;height:24px;background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%);background-size:200% 100%;animation:flight-board-shimmer 1.5s ease-in-out infinite;border-radius:999px}.flight-board__skeleton-time{width:48px;height:28px;background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%);background-size:200% 100%;animation:flight-board-shimmer 1.5s ease-in-out infinite;border-radius:6px}.flight-board__skeleton-text{width:36px;height:16px;background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%);background-size:200% 100%;animation:flight-board-shimmer 1.5s ease-in-out infinite;border-radius:4px}@keyframes flight-board-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.flight-board__off-hours,.flight-board__empty{text-align:center;padding:2rem 1rem;color:var(--color-text-secondary);font-size:.9375rem}.flight-board__off-hours{background:var(--color-accent-bg);border-radius:12px;margin-bottom:1rem}.crowded{font-size:.625rem;padding:1px 6px;border-radius:999px;font-weight:600;margin-left:4px}.crowded--1{background:#dcfce7;color:#16a34a}.crowded--2{background:#dbeafe;color:#2563eb}.crowded--3{background:#ffedd5;color:#ea580c}.crowded--4{background:#fee2e2;color:#dc2626}.low-plate{font-size:.5625rem;color:#94a3b8;margin-left:4px}@media (max-width: 400px){.flight-board{padding:12px 8px}.flight-board__section{padding:16px}.flight-board__col-location{display:none}.flight-board__badge{font-size:11px;padding:3px 8px}.flight-board__time-number{font-size:18px}.flight-board__row td{padding:8px 4px}.flight-board__table-header{font-size:10px;padding:0 4px 8px}}.solari-board{--bg: #1a1a1a;--bg-cell: #2a2a2a;--text: #f5e6c8;--text-dim: #a89878;--border: #333;--accent: #e8c44a;--led-red: #ff3b30;font-family:Share Tech Mono,monospace;background:var(--bg);color:var(--text);min-height:100vh;padding:1.5rem;box-sizing:border-box}.solari-board--loading{display:flex;align-items:center;justify-content:center}.solari-loading-text{font-size:1.4rem;color:var(--text-dim);animation:solari-pulse 1.5s ease-in-out infinite}@keyframes solari-pulse{0%,to{opacity:.4}50%{opacity:1}}.solari-header{text-align:center;padding:.75rem 0 1.25rem;border-bottom:2px solid var(--border);margin-bottom:1.5rem}.solari-header__title{font-size:1.6rem;font-weight:400;letter-spacing:.08em;color:var(--accent);margin:0}.solari-section{margin-bottom:2rem}.solari-section__title{font-size:1.1rem;font-weight:400;color:var(--text-dim);margin:0 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);letter-spacing:.05em}.solari-table{width:100%;border-collapse:collapse;table-layout:fixed}.solari-table thead th{font-size:.75rem;font-weight:400;color:var(--text-dim);text-align:left;padding:.25rem .5rem .5rem;letter-spacing:.1em;text-transform:uppercase}.solari-table thead th:nth-child(1){width:38%}.solari-table thead th:nth-child(2){width:18%}.solari-table thead th:nth-child(3){width:20%}.solari-table thead th:nth-child(4){width:24%}.solari-row{border-bottom:1px solid var(--border)}.solari-row:last-child{border-bottom:none}.solari-cell{padding:.5rem;vertical-align:middle;white-space:nowrap;overflow:hidden}.solari-cell--time{display:flex;align-items:center;gap:.4rem}.solari-led{color:var(--led-red);font-size:.65rem;animation:solari-blink 1s infinite;flex-shrink:0}@keyframes solari-blink{0%,to{opacity:1}50%{opacity:.2}}.solari-off-hours{text-align:center;padding:2rem 1rem;color:var(--text-dim);font-size:1rem;border:1px solid var(--border);border-radius:4px;margin-bottom:1.5rem}.solari-subway-card{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;padding:.75rem;border-top:1px solid var(--border);margin-top:1rem}.solari-subway-times{display:flex;align-items:center;gap:.5rem;margin-left:auto}.solari-subway-label{font-size:.7rem;color:var(--text-dim);text-transform:uppercase}.solari-direction{color:var(--text-dim);font-size:.85rem}.solari-subway-badge{display:inline-block;background:#f5a623;color:#1a1a1a;font-size:.8rem;padding:.15rem .5rem;border-radius:3px;font-weight:700;letter-spacing:.02em}.flap-cell-fallback{display:inline-flex;gap:2px}.flap-char{display:inline-block;background:linear-gradient(to bottom,#333 49.5%,#1a1a1a 49.5%,#1a1a1a 50.5%,#2a2a2a 50.5%);color:#f5e6c8;border:1px solid #444;border-radius:3px;padding:.15em .25em;min-width:.72em;text-align:center;line-height:1.3;box-shadow:inset 0 -1px #00000080,inset 0 1px #ffffff0d,0 2px 4px #0000004d;transform-style:preserve-3d;perspective:200px}@keyframes flap-flip{0%{transform:rotateX(0)}50%{transform:rotateX(-90deg);opacity:.5}to{transform:rotateX(0);opacity:1}}.flap-char.flipping{animation:flap-flip .3s ease-in-out}.solari-crowded{font-size:.6rem;margin-left:4px;padding:1px 4px;border-radius:2px}.solari-crowded--1{color:#4ade80}.solari-crowded--2{color:#94a3b8}.solari-crowded--3{color:#fb923c}.solari-crowded--4{color:#ef4444}.solari-lowplate{font-size:.55rem;color:#888;margin-left:4px}.solari-row--arrived{opacity:.7}.solari-row--arrived .solari-cell{background:#4ade800f}.solari-arrived-label{display:inline-block;margin-left:6px;padding:1px 5px;border-radius:2px;background:#4ade80;color:#1a1a1a;font-size:.55rem;font-weight:700;letter-spacing:.05em}@media (max-width: 720px){.solari-board{padding:.75rem}.solari-header__title{font-size:1.2rem}.solari-section__title{font-size:.95rem}.solari-table thead th{font-size:.65rem}.solari-cell{padding:.35rem .25rem}.solari-table thead th:nth-child(1){width:36%}.solari-table thead th:nth-child(2){width:18%}.solari-table thead th:nth-child(3){width:22%}.solari-table thead th:nth-child(4){width:24%}}.route-line-view{flex:1;padding:1rem;display:flex;flex-direction:column;gap:1rem;background:#f8fafc;min-height:0}.route-line-view__heading{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;padding:0 .25rem}.route-line-view__direction{font-size:1.0625rem;font-weight:700;color:#0b2545}.route-line-view__count{font-size:.8125rem;color:#6b7280}.route-line-view__empty{padding:1.5rem;text-align:center;font-size:.875rem;color:#6b7280;background:#fff;border:1px dashed #d1d5db;border-radius:10px}.route-line-view__hint{margin:auto;padding:.625rem 1.125rem;background:#111827d9;color:#fff;border-radius:999px;font-size:.875rem}.route-line-view__hint--error{background:#dc2626e6}.route-line-view__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:.75rem}.route-line{padding:.875rem 1rem .75rem;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:12px;box-shadow:0 1px 2px #0000000a;display:flex;flex-direction:column;gap:.625rem}.route-line__header{display:flex;align-items:center;gap:.5rem}.route-line__name{font-size:1.0625rem;font-weight:700;color:#111827}.route-line__badge{padding:.125rem .5rem;border-radius:999px;font-size:.6875rem;font-weight:600;letter-spacing:.02em}.route-line__badge--regular{background:#dbeafe;color:#1e40af}.route-line__badge--express{background:#fee2e2;color:#b91c1c}.route-line__badge--village{background:#dcfce7;color:#166534}.route-line__platform{margin-left:auto;padding:.125rem .5rem;background:#f1f5f9;color:#334155;border-radius:6px;font-size:.75rem;font-weight:600;letter-spacing:.01em}.route-line__track{position:relative;height:44px;padding:0 14px}.route-line__rail{position:absolute;left:14px;right:14px;top:50%;height:3px;background:#e5e7eb;border-radius:2px;transform:translateY(-50%)}.route-line__dot{position:absolute;top:50%;width:12px;height:12px;margin-left:-6px;background:#fff;border:2px solid #9ca3af;border-radius:50%;transform:translateY(-50%);z-index:1}.route-line__home{position:absolute;left:100%;top:50%;transform:translate(-50%,-50%);font-size:1.25rem;z-index:2;background:#fff;padding:0 2px;border-radius:4px}.route-line__bus{position:absolute;top:50%;left:calc(14px + var(--position) * (100% - 28px));transform:translate(-50%,-50%);font-size:1.25rem;z-index:3;transition:left 30s linear;filter:drop-shadow(0 1px 1px rgba(0,0,0,.2))}.route-line__footer{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:#4b5563}.route-line__sep{color:#d1d5db}.route-line__status--ease{color:#16a34a;font-weight:600}.route-line__status--normal{color:#2563eb;font-weight:600}.route-line__status--crowded{color:#f59e0b;font-weight:600}.route-line__status--full{color:#dc2626;font-weight:600}.route-line__empty{color:#9ca3af;font-style:italic}.theme-solari .route-line-view{background:#121212}.theme-solari .route-line-view__direction{color:#f5e6c8}.theme-solari .route-line-view__count,.theme-solari .route-line-view__empty{color:#888}.theme-solari .route-line-view__empty{background:#1a1a1a;border-color:#333}.theme-solari .route-line{background:#1a1a1a;border-color:#333;box-shadow:none}.theme-solari .route-line__name{color:#f5e6c8}.theme-solari .route-line__rail{background:#333}.theme-solari .route-line__dot{background:#1a1a1a;border-color:#666}.theme-solari .route-line__home{background:#1a1a1a}.theme-solari .route-line__footer{color:#aaa}.theme-solari .route-line__sep{color:#444}.theme-solari .route-line__badge--regular{background:#3aa0ff33;color:#8bc4ff}.theme-solari .route-line__badge--express{background:#dc262633;color:#fca5a5}.theme-solari .route-line__badge--village{background:#16a34a33;color:#86efac}.theme-solari .route-line__platform{background:#2a2a2a;color:#f5e6c8}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:Inter,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column;transition:background-color .3s ease,color .3s ease}.app.embed .header,.app.embed .footer{display:none}.header{padding:1rem 1.5rem;border-bottom:1px solid rgba(0,0,0,.08)}.header-top{display:flex;align-items:center;justify-content:space-between}.header-title{font-size:1.25rem;font-weight:700;color:#0b2545}.header-segments{display:flex;gap:.5rem;align-items:center}.theme-segment,.view-segment{display:flex;border:1px solid #d1d5db;border-radius:8px;overflow:hidden}.theme-segment__btn,.view-segment__btn{padding:.375rem .75rem;border:none;background:transparent;font-size:.8125rem;font-weight:500;cursor:pointer;transition:background .2s,color .2s;color:#6b7280}.theme-segment__btn.active,.view-segment__btn.active{background:#3aa0ff;color:#fff}.theme-segment.disabled{opacity:.5}.theme-segment__btn:disabled{cursor:not-allowed}.header-meta{margin-top:.25rem;font-size:.75rem;color:#6b7280}.direction-tabs{display:flex;gap:0;margin-top:.75rem;border:1px solid #d1d5db;border-radius:10px;overflow:hidden}.direction-tabs--embed{margin:.5rem}.direction-tab{flex:1;padding:.5rem 1rem;border:none;background:transparent;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .2s,color .2s;color:#6b7280}.direction-tab.active{background:#0b2545;color:#fff}.direction-tab:not(.active):hover{background:#f3f4f6}.theme-solari .direction-tabs{border-color:#444}.theme-solari .direction-tab{color:#888}.theme-solari .direction-tab.active{background:#e8c44a;color:#1a1a1a}.theme-solari .direction-tab:not(.active):hover{background:#2a2a2a}.footer{margin-top:auto;padding:1rem 1.5rem;border-top:1px solid rgba(0,0,0,.08);font-size:.75rem;color:#6b7280;text-align:center}.footer a{color:#3b82f6;text-decoration:none}.footer a:hover{text-decoration:underline}.footer-hint{margin-top:.25rem}.footer-hint code{padding:.125rem .375rem;background:#f3f4f6;border-radius:4px;font-size:.6875rem}.error-toast{position:fixed;bottom:1rem;left:50%;transform:translate(-50%);padding:.5rem 1rem;background:#ef4444;color:#fff;border-radius:8px;font-size:.8125rem;box-shadow:0 4px 12px #00000026;z-index:100;animation:toast-in .3s ease}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(1rem)}to{opacity:1;transform:translate(-50%) translateY(0)}}.pause-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;margin:.75rem 1rem;background:#fffbeb;border:1px solid #fde68a;border-radius:10px;color:#92400e;font-size:.875rem;flex-wrap:wrap}.pause-banner__btn{padding:.375rem .875rem;background:#f59e0b;color:#fff;border:none;border-radius:6px;font-size:.8125rem;font-weight:600;cursor:pointer;transition:background .15s}.pause-banner__btn:hover{background:#d97706}.theme-solari .pause-banner{background:#2a1f0f;border-color:#4a3a1f;color:#f5c542}.theme-solari .pause-banner__btn{background:#e8c44a;color:#1a1a1a}.theme-solari .pause-banner__btn:hover{background:#f5c542}.initial-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;color:#6b7280;gap:1rem}.loading-spinner{width:2rem;height:2rem;border:3px solid #e5e7eb;border-top-color:#3aa0ff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.theme-solari .header{background:#1a1a1a;border-bottom-color:#333}.theme-solari .header-title{color:#f5e6c8}.theme-solari .header-meta{color:#888}.theme-solari .theme-segment,.theme-solari .view-segment{border-color:#444}.theme-solari .theme-segment__btn,.theme-solari .view-segment__btn{color:#888}.theme-solari .theme-segment__btn.active,.theme-solari .view-segment__btn.active{background:#e8c44a;color:#1a1a1a}.theme-solari .initial-loading{color:#888}.theme-solari .loading-spinner{border-color:#444;border-top-color:#e8c44a}.theme-solari .footer{background:#1a1a1a;border-top-color:#333;color:#888}.theme-solari .footer a{color:#f5c542}.theme-solari .footer-hint code{background:#2a2a2a;color:#f5e6c8}
