@import url(https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@300;400;500;600;700&display=swap);body{font-family:Noto Sans TC,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.modal-overlay{align-items:center;animation:fadeIn .2s ease;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:modalAppear .3s ease;background-color:#fff;border:2px solid #2196f3;border-radius:8px;color:#2c3e50;max-width:90%;padding:2rem;position:relative;text-align:center;width:400px}.modal-content p{color:#2c3e50;font-size:1rem;line-height:1.6;margin-bottom:1.5rem}.modal-overlay.closing{animation:fadeOut .2s ease forwards}.modal-overlay.closing .modal-content{animation:modalDisappear .2s ease forwards}@media (max-width:480px){.modal-content{padding:1.5rem;width:95%}.modal-content p{font-size:.9375rem}}.train-details-modal-overlay{align-items:center;animation:fadeIn .2s ease;background-color:#0009;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.train-details-modal-content{animation:modalAppear .3s ease;background-color:#fff;border:2px solid #2196f3;border-radius:8px;display:flex;flex-direction:column;max-height:90vh;max-width:700px;overflow-y:auto;padding:2rem;position:relative;width:90%}@keyframes modalAppear{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.train-details-modal-content h2{color:#2c3e50;font-size:1.5rem;margin-bottom:1.5rem;margin-top:0;text-align:left}.train-info{grid-gap:.5rem;animation:fadeIn .5s cubic-bezier(.19,1,.22,1) .1s both;background-color:#ffffff0d;border:1px solid #ffffff0d;border-radius:16px;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:1.5rem;padding:1.25rem}.train-info p{border-bottom:1px solid #ffffff0d;display:flex;justify-content:space-between;margin:.75rem 0;padding-bottom:.75rem}.train-info p:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.train-info p strong{color:#00e5ff;font-weight:500}.stop-times-container{animation:fadeIn .3s ease;flex-grow:1;margin:1rem 0;max-height:500px;min-height:400px;overflow-y:auto}.stop-times{background-color:#fff;border:1px solid #e1e8ed;border-radius:8px;display:flex;flex-direction:column;height:100%;overflow:hidden;padding:1.5rem 0;position:relative}.timeline{background-color:#e1e8ed;bottom:0;left:40px;position:absolute;top:0;width:3px;z-index:1}.stop-time{align-items:center;color:#2c3e50;display:flex;font-size:1rem;margin-left:60px;min-height:44px;padding:1rem 1.5rem 1rem 0;position:relative;transition:all .2s ease}.station-circle{background-color:#fff;border:3px solid #bdbdbd;border-radius:50%;height:14px;left:-26px;position:absolute;transition:all .2s ease;width:14px;z-index:2}.stop-time.past .station-circle{background-color:#2196f3;border-color:#90caf9}.stop-time.current .station-circle{background-color:#2196f3;border-color:#2196f3;box-shadow:0 0 0 4px #2196f333;transform:scale(1.3)}.train-indicator{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));height:18px;left:-39px;position:absolute;transition:all .3s ease;width:36px;z-index:5}.train-indicator-bg{background-color:#fff;border:1px solid #e1e8ed;border-radius:4px;height:24px;left:-42px;position:absolute;width:42px;z-index:4}.stop-time{opacity:.7}.stop-time.past{color:#7f8c8d;opacity:.5}.stop-time.current{background-color:#e3f2fd;border-radius:4px;font-size:1.0625rem;font-weight:600;opacity:1;padding-left:.75rem}.stop-time:hover{background-color:#f5f7fa;opacity:1}.station-content{align-items:center;display:flex;justify-content:space-between;padding-left:10px;width:100%}.station-name{color:#2c3e50;flex:1 1;font-weight:500}.time-info{align-items:flex-end;color:#7f8c8d;display:flex;flex-direction:column;text-align:right}.scheduled-time{color:#2c3e50;font-weight:400}.delayed-time{color:#ff6b6b;font-size:.875rem;margin-top:.125rem}.close-button{align-items:center;background-color:#f5f7fa;border:1px solid #e1e8ed;border-radius:4px;color:#2c3e50;cursor:pointer;display:flex;font-size:1.5rem;font-weight:700;height:36px;justify-content:center;padding:0;position:absolute;right:12px;top:12px;transition:all .2s ease;width:36px}.close-button:hover{background-color:#2196f3;border-color:#2196f3;color:#fff}.close-button:active{transform:scale(.95)}.stop-times-container::-webkit-scrollbar,.train-details-modal-content::-webkit-scrollbar{width:8px}.stop-times-container::-webkit-scrollbar-track,.train-details-modal-content::-webkit-scrollbar-track{background:#e1e8ed}.stop-times-container::-webkit-scrollbar-thumb,.train-details-modal-content::-webkit-scrollbar-thumb{background:#7f8c8d;border-radius:4px}.stop-times-container::-webkit-scrollbar-thumb:hover,.train-details-modal-content::-webkit-scrollbar-thumb:hover{background:#2196f3}.train-details-modal-overlay.closing{animation:fadeOut .2s ease forwards}.train-details-modal-overlay.closing .train-details-modal-content{animation:modalDisappear .2s ease forwards}@keyframes modalDisappear{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.95)}}.stop-times-header{background-color:#f5f7fa;border-bottom:2px solid #e1e8ed;color:#2c3e50;display:flex;font-weight:600;justify-content:space-between;padding:1rem 1.5rem 1rem 60px;position:sticky;top:0;z-index:4}@media (max-width:768px){.train-details-modal-content{padding:1.5rem;width:95%}.stop-time{font-size:.9375rem;margin-left:50px;padding:.875rem 1rem .875rem 0}.station-circle{height:12px;left:-24px;width:12px}.timeline{left:35px;width:2px}.train-indicator{height:14px;left:-34px;width:28px}.train-indicator-bg{height:18px;left:-36px;width:32px}.train-info{grid-template-columns:1fr}.stop-times-container{min-height:350px}.stop-times-header{padding-left:50px}}@media (max-width:480px){.train-details-modal-content{padding:1.25rem}.train-details-modal-content h2{font-size:1.25rem}.train-info p{align-items:flex-start;flex-direction:column;gap:.25rem}.stop-time{font-size:.875rem;margin-left:45px;padding:.875rem .75rem .875rem 0}.station-circle{border-width:2px;height:10px;left:-23px;width:10px}.timeline{left:32px;width:2px}.train-indicator{height:12px;left:-32px;width:24px}.train-indicator-bg{height:16px;left:-34px;width:28px}.stop-times-header{font-size:.875rem;padding-left:45px}}.cache-indicator{animation:slideIn .3s ease;background-color:#fff;border:2px solid #2196f3;border-radius:8px;bottom:1rem;box-shadow:0 4px 12px #00000026;min-width:200px;padding:.75rem;position:fixed;right:1rem;z-index:999}.cache-indicator-header{align-items:center;border-bottom:1px solid #e1e8ed;display:flex;gap:.5rem;margin-bottom:.5rem;padding-bottom:.5rem}.cache-icon{animation:rotate 2s linear infinite;font-size:1.25rem}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.cache-text{color:#2c3e50;font-size:.875rem;font-weight:600}.cache-item{align-items:center;display:flex;font-size:.75rem;gap:.5rem;margin-top:.5rem}.cache-key{color:#7f8c8d;flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cache-age{color:#2196f3;font-weight:500}.cache-refresh-badge{background-color:#4caf50;border-radius:4px;color:#fff;font-size:.625rem;font-weight:600;padding:.125rem .375rem}@media (max-width:768px){.cache-indicator{bottom:.5rem;min-width:160px;padding:.5rem;right:.5rem}.cache-text{font-size:.75rem}.cache-item{font-size:.6875rem}}:root{--primary-color:#2196f3;--primary-dark:#1976d2;--secondary-color:#ff6b6b;--background-color:#f5f7fa;--card-bg:#fff;--text-color:#2c3e50;--text-secondary:#7f8c8d;--border-color:#e1e8ed;--border-radius:8px;--transition:0.2s ease;--spacing-xs:0.5rem;--spacing-sm:1rem;--spacing-md:1.5rem;--spacing-lg:2rem;--touch-target:44px}*{-webkit-tap-highlight-color:transparent;box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#2c3e50;color:var(--text-color);font-family:Noto Sans TC,-apple-system,BlinkMacSystemFont,sans-serif;font-size:16px;line-height:1.6;margin:0;overflow-x:hidden}.app,body{background-color:#f5f7fa;background-color:var(--background-color)}.app{align-items:center;padding:1rem;padding:var(--spacing-sm)}.app,.container{position:relative}.container{animation:fadeIn .3s ease;background-color:#fff;background-color:var(--card-bg);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--border-radius);max-width:800px;padding:2rem;padding:var(--spacing-lg);transition:all .2s ease;transition:all var(--transition);width:100%}.container:hover{border-color:#2196f3;border-color:var(--primary-color)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}h1,h2{color:#2c3e50;color:var(--text-color);font-weight:700;text-align:center;transition:all .2s ease;transition:all var(--transition)}h1,h2{margin-bottom:2rem;margin-bottom:var(--spacing-lg)}h1{font-size:1.75rem}h2{font-size:1.5rem;margin-bottom:1.5rem;margin-bottom:var(--spacing-md)}.search-container{display:flex;gap:1rem;gap:var(--spacing-sm);margin-bottom:2rem;margin-bottom:var(--spacing-lg);position:relative}input[type=text]{background-color:#fff;background-color:var(--card-bg);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:8px;border-radius:var(--border-radius);color:#2c3e50;color:var(--text-color);flex-grow:1;font-family:Noto Sans TC,sans-serif;font-size:1rem;min-height:44px;min-height:var(--touch-target);outline:none;padding:.875rem 1rem;transition:all .2s ease;transition:all var(--transition)}input[type=text]:focus{background-color:#f8fafb;border-color:#2196f3;border-color:var(--primary-color)}input[type=text]::placeholder{color:#7f8c8d;color:var(--text-secondary)}button{background-color:#2196f3;background-color:var(--primary-color);border:none;border-radius:8px;border-radius:var(--border-radius);color:#fff;cursor:pointer;font-family:Noto Sans TC,sans-serif;font-size:1rem;font-weight:600;min-height:44px;min-height:var(--touch-target);padding:.875rem 1.5rem;position:relative;transition:all .2s ease;transition:all var(--transition);white-space:nowrap}button:hover:not(:disabled){background-color:#1976d2;background-color:var(--primary-dark)}button:active:not(:disabled){transform:scale(.98)}button:disabled{background-color:#7f8c8d;background-color:var(--text-secondary);cursor:not-allowed;opacity:.5}.result{animation:fadeIn .3s ease;background-color:#f8fafb;border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--border-radius);margin-top:2rem;margin-top:var(--spacing-lg);padding:1.5rem;padding:var(--spacing-md)}.info-grid,.result{transition:all .2s ease;transition:all var(--transition)}.info-grid{grid-gap:1rem;grid-gap:var(--spacing-sm);display:grid;gap:1rem;gap:var(--spacing-sm);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));overflow-y:auto}.info-item{animation:fadeIn .3s ease;background-color:#fff;background-color:var(--card-bg);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:8px;border-radius:var(--border-radius);cursor:pointer;min-height:44px;min-height:var(--touch-target);padding:1.5rem;padding:var(--spacing-md);position:relative;transition:all .2s ease;transition:all var(--transition)}.info-item:hover{background-color:#f8fafb;border-color:#2196f3;border-color:var(--primary-color)}.info-item:active{background-color:#f0f3f7;transform:scale(.98)}.label{color:#2c3e50;color:var(--text-color);display:inline-block;font-weight:600;margin-right:.5rem;margin-right:var(--spacing-xs)}.label,.value{transition:color .2s ease;transition:color var(--transition)}.value{color:#7f8c8d;color:var(--text-secondary)}.home-page{animation:fadeIn .3s ease;text-align:center}.selection-buttons{display:flex;flex-wrap:wrap;gap:1.5rem;gap:var(--spacing-md);justify-content:center;margin-top:2rem;margin-top:var(--spacing-lg)}.selection-buttons,.selection-buttons button{transition:all .2s ease;transition:all var(--transition)}.selection-buttons button{font-size:1.125rem;min-width:200px;padding:1rem 2rem}.train-header{align-items:center;display:flex;font-size:1.1rem;justify-content:space-between;margin-bottom:1rem;margin-bottom:var(--spacing-sm)}.train-details,.train-header{transition:all .2s ease;transition:all var(--transition)}.train-details{grid-gap:.5rem;grid-gap:var(--spacing-xs);display:grid;gap:.5rem;gap:var(--spacing-xs)}.train-details div{border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1rem 0;padding:var(--spacing-sm) 0;transition:all .2s ease;transition:all var(--transition)}.train-details div:last-child{border-bottom:none}.error,.info-message,.loading{animation:fadeIn .3s ease;border:2px solid;border-radius:8px;border-radius:var(--border-radius);font-weight:500;margin-top:1.5rem;margin-top:var(--spacing-md);padding:1.5rem;padding:var(--spacing-md);text-align:center;transition:all .2s ease;transition:all var(--transition)}.loading{background-color:#e3f2fd;border-color:#2196f3;border-color:var(--primary-color);color:#2196f3;color:var(--primary-color)}.error{background-color:#ffebee;border-color:#d32f2f;color:#d32f2f}.info-message{background-color:#f5f5f5;border-color:#e1e8ed;border-color:var(--border-color);color:#2c3e50;color:var(--text-color)}.header{justify-content:space-between;margin-bottom:2rem;margin-bottom:var(--spacing-lg);position:relative;transition:all .2s ease;transition:all var(--transition)}.back-button,.header{align-items:center;display:flex}.back-button{background-color:#f5f7fa;border:1px solid #e1e8ed;border:1px solid var(--border-color);color:#2c3e50;color:var(--text-color);font-size:.9375rem;gap:.5rem;gap:var(--spacing-xs);padding:.75rem 1.25rem}.back-button:before{content:"←";display:inline-block;font-size:1.25rem;transition:transform .2s ease;transition:transform var(--transition)}.back-button:hover{background-color:#e8ebed;border-color:#7f8c8d;border-color:var(--text-secondary)}.back-button:hover:before{transform:translateX(-2px)}.train-type{border-radius:8px;border-radius:var(--border-radius);color:#fff;display:inline-block;font-size:.875rem;font-weight:600;letter-spacing:.25px;padding:.375rem .875rem}.train-type-local{background-color:#0072c6}.train-type-express{background-color:#ff6b00}.train-type-tze-chiang{background-color:#e60012}.train-type-chu-kuang{background-color:#00a040}.train-type-fu-hsing{background-color:#9e005d}.train-type-other{background-color:#757575}.station-dropdown{background-color:#fff;background-color:var(--card-bg);border:2px solid #2196f3;border:2px solid var(--primary-color);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 4px 6px #0000001a;left:0;max-height:0;opacity:0;overflow-y:auto;position:absolute;right:0;top:100%;transition:all .2s ease;transition:all var(--transition);z-index:10}.station-dropdown.open{margin-top:.5rem;margin-top:var(--spacing-xs);max-height:240px;opacity:1}.station-option{align-items:center;border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);cursor:pointer;display:flex;min-height:44px;min-height:var(--touch-target);padding:.875rem 1rem;transition:all .2s ease;transition:all var(--transition)}.station-option:last-child{border-bottom:none}.station-option:hover{background-color:#e3f2fd;color:#2196f3;color:var(--primary-color)}.station-option:active{background-color:#bbdefb}.info-grid::-webkit-scrollbar,.station-dropdown::-webkit-scrollbar,.stop-times-container::-webkit-scrollbar,.train-details-modal-content::-webkit-scrollbar{width:8px}.info-grid::-webkit-scrollbar-track,.station-dropdown::-webkit-scrollbar-track,.stop-times-container::-webkit-scrollbar-track,.train-details-modal-content::-webkit-scrollbar-track{background:#e1e8ed;background:var(--border-color)}.info-grid::-webkit-scrollbar-thumb,.station-dropdown::-webkit-scrollbar-thumb,.stop-times-container::-webkit-scrollbar-thumb,.train-details-modal-content::-webkit-scrollbar-thumb{background:#7f8c8d;background:var(--text-secondary);border-radius:4px}.info-grid::-webkit-scrollbar-thumb:hover,.station-dropdown::-webkit-scrollbar-thumb:hover,.stop-times-container::-webkit-scrollbar-thumb:hover,.train-details-modal-content::-webkit-scrollbar-thumb:hover{background:#2196f3;background:var(--primary-color)}.fade-in{animation:fadeIn .3s ease}.fade-out{animation:fadeOut .2s ease;opacity:0;pointer-events:none}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@media (max-width:768px){.container{padding:1.5rem;padding:var(--spacing-md)}h1{font-size:1.5rem}h2{font-size:1.25rem}.selection-buttons{align-items:stretch;flex-direction:column}.selection-buttons button{min-width:auto;width:100%}.info-grid{grid-template-columns:1fr}.search-container{flex-direction:column}button,input[type=text]{width:100%}.header{align-items:stretch;flex-direction:column;gap:1rem;gap:var(--spacing-sm)}.back-button{align-self:flex-start}}@media (max-width:480px){.container{padding:1rem;padding:var(--spacing-sm)}h1{font-size:1.375rem}h2{font-size:1.125rem}.selection-buttons button{font-size:1rem;padding:.875rem 1.5rem}}body,html{height:100%;overflow-x:hidden;overflow-y:auto}.app{align-items:flex-start;display:flex;justify-content:center;min-height:100vh;padding-bottom:2rem;padding-bottom:var(--spacing-lg);padding-top:2rem;padding-top:var(--spacing-lg)}.modal-overlay,.train-details-modal-overlay{align-items:center;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0}.bike-info .city-select{background-color:var(--card-bg);border:2px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-color);cursor:pointer;flex:1 1;font-family:Noto Sans TC,sans-serif;font-size:1rem;min-height:var(--touch-target);outline:none;padding:.875rem 1rem;transition:all var(--transition)}.bike-info .city-select:focus{border-color:var(--primary-color)}.bike-info .bike-station{background-color:var(--card-bg);border:2px solid var(--border-color);border-radius:var(--border-radius);cursor:default;padding:var(--spacing-md);transition:all var(--transition)}.bike-info .bike-station:hover{background-color:#f8fafb;border-color:var(--primary-color)}.bike-info .station-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm)}.bike-info .station-name{color:var(--text-color);flex:1 1;font-size:1rem;font-weight:600}.bike-info .availability-badge{border-radius:var(--border-radius);font-size:.875rem;font-weight:600;padding:.375rem .75rem;white-space:nowrap}.bike-info .availability-badge.good{background-color:#4caf50;color:#fff}.bike-info .availability-badge.low{background-color:#ff9800;color:#fff}.bike-info .availability-badge.critical{background-color:#f44336;color:#fff}.bike-info .availability-badge.unavailable{background-color:#9e9e9e;color:#fff}.bike-info .station-details{display:flex;flex-direction:column;gap:var(--spacing-xs)}.bike-info .detail-row{align-items:center;display:flex;font-size:.875rem;justify-content:space-between}.bike-info .detail-row.address{align-items:flex-start;border-top:1px solid var(--border-color);flex-direction:column;margin-top:var(--spacing-xs);padding-top:var(--spacing-xs)}.bike-info .detail-row.address .value{color:var(--text-secondary);font-size:.8125rem;line-height:1.4;margin-top:.25rem}.bike-info .detail-row.update-time{color:var(--text-secondary);font-size:.75rem;margin-top:.25rem}.bike-info .detail-row .label{color:var(--text-color);font-weight:500}.bike-info .detail-row .value{color:var(--text-secondary);font-weight:500}@media (max-width:768px){.bike-info .search-container{flex-direction:column}.bike-info .city-select,.bike-info .station-search{width:100%}.bike-info .station-header{align-items:flex-start;flex-direction:column;gap:var(--spacing-xs)}.bike-info .availability-badge{align-self:flex-start}}@media (max-width:480px){.bike-info .station-name{font-size:.9375rem}.bike-info .detail-row{font-size:.8125rem}}
/*# sourceMappingURL=main.a96269ff.css.map*/