*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden;background-color:#0e1117;color:#e0e0e0;font-family:Segoe UI,Apple SD Gothic Neo,sans-serif;font-size:14px}.app-layout{display:flex;width:100vw;height:100vh;overflow:hidden}.sidebar{width:280px;min-width:280px;background-color:#161b22;border-right:1px solid #30363d;display:flex;flex-direction:column;padding:16px;overflow-y:auto;gap:12px;transition:width .2s ease,min-width .2s ease,padding .2s ease}.sidebar.sidebar-collapsed{width:48px;min-width:48px;padding:12px 8px;overflow:hidden}.sidebar-header{display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.sidebar-collapsed .sidebar-header{justify-content:center}.sidebar-toggle{background:none;border:1px solid #30363d;border-radius:6px;color:#8b949e;width:28px;height:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;transition:border-color .15s,color .15s}.sidebar-toggle:hover{border-color:#58a6ff;color:#58a6ff}.sidebar h2{font-size:15px;font-weight:700;color:#c9d1d9;margin:0;white-space:nowrap}.sidebar-divider{border:none;border-top:1px solid #30363d;margin:4px 0}.sidebar-section{display:flex;flex-direction:column;gap:8px}.sidebar-label{font-size:12px;color:#8b949e;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.sidebar select,.sidebar input[type=date]{width:100%;padding:6px 10px;background-color:#21262d;border:1px solid #30363d;border-radius:6px;color:#c9d1d9;font-size:13px;outline:none;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none}.sidebar select:hover,.sidebar input[type=date]:hover{border-color:#58a6ff}.sidebar select:focus,.sidebar input[type=date]:focus{border-color:#58a6ff;box-shadow:0 0 0 2px #58a6ff33}.direction-group{display:flex;gap:8px}.direction-option{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:5px 8px;background-color:#21262d;border:1px solid #30363d;border-radius:6px;cursor:pointer;font-size:13px;color:#8b949e;transition:all .15s}.direction-option:hover{border-color:#58a6ff;color:#c9d1d9}.direction-option.active{background-color:#1f6feb;border-color:#1f6feb;color:#fff;font-weight:600}.direction-option input[type=radio]{display:none}.status-box{background-color:#21262d;border:1px solid #30363d;border-radius:6px;padding:10px;font-size:12px;color:#8b949e;line-height:1.6}.status-box .status-line{display:flex;justify-content:space-between}.status-box .status-value{color:#c9d1d9;font-weight:600}.refresh-btn{width:100%;padding:7px 12px;background-color:#21262d;border:1px solid #30363d;border-radius:6px;color:#c9d1d9;font-size:13px;cursor:pointer;transition:all .15s}.refresh-btn:hover{background-color:#30363d;border-color:#58a6ff}.refresh-btn:active{background-color:#161b22}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden}.main-header{padding:10px 16px;background-color:#161b22;border-bottom:1px solid #30363d;display:flex;align-items:center;gap:16px;flex-shrink:0}.main-header .title{font-size:15px;font-weight:700;color:#c9d1d9}.main-header .meta{font-size:12px;color:#8b949e}.main-header .api-status{margin-left:auto;font-size:12px;color:#8b949e}.loading-indicator{font-size:14px;color:#58a6ff;animation:spin 1s linear infinite;display:inline-block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.main-content{flex:1;overflow:hidden;padding:8px}.info-msg{padding:20px;color:#8b949e;font-size:14px}.loading-msg{padding:20px;color:#58a6ff;font-size:14px}.tab-bar{display:flex;gap:0;background-color:#161b22;border-bottom:1px solid #30363d;flex-shrink:0;padding:0 12px}.tab-btn{padding:8px 20px;background:none;border:none;border-bottom:2px solid transparent;color:#8b949e;font-size:13px;font-weight:500;cursor:pointer;transition:color .15s,border-color .15s;margin-bottom:-1px}.tab-btn:hover{color:#c9d1d9}.tab-btn.active{color:#58a6ff;border-bottom-color:#58a6ff;font-weight:600}.route-search-container{width:100%;height:100%;overflow-y:auto;display:flex;justify-content:center;padding:24px 16px}.route-search-panel{width:100%;max-width:640px;display:flex;flex-direction:column;gap:20px}.route-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.route-panel-title{font-size:16px;font-weight:700;color:#c9d1d9;margin:0}.cache-refresh-area{display:flex;align-items:center;gap:8px;flex-shrink:0}.cache-built-at{font-size:11px;color:#8b949e;white-space:nowrap}.cache-refresh-btn{font-size:12px;padding:4px 10px;background-color:#21262d;color:#8b949e;border:1px solid #30363d;border-radius:6px;cursor:pointer;white-space:nowrap;transition:background-color .15s,color .15s,border-color .15s}.cache-refresh-btn:hover:not(:disabled){background-color:#30363d;color:#c9d1d9;border-color:#8b949e}.cache-refresh-btn:disabled{opacity:.5;cursor:not-allowed}.route-form{display:flex;flex-direction:column;gap:14px;background-color:#161b22;border:1px solid #30363d;border-radius:8px;padding:16px}.route-station-row{display:flex;align-items:flex-end;gap:8px}.station-input-wrap{flex:1;position:relative;display:flex;flex-direction:column;gap:6px}.route-label{font-size:11px;color:#8b949e;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.station-input-box{display:flex;align-items:center;background-color:#21262d;border:1px solid #30363d;border-radius:6px;padding:4px 8px;gap:6px;min-height:34px}.station-input-box:focus-within{border-color:#58a6ff;box-shadow:0 0 0 2px #58a6ff33}.station-badge{padding:1px 6px;border-radius:4px;font-size:10px;font-weight:600;color:#fff;white-space:nowrap;flex-shrink:0}.station-text-input{flex:1;background:none;border:none;color:#c9d1d9;font-size:13px;outline:none;min-width:0}.station-text-input::placeholder{color:#484f58}.station-badge-extra{padding:1px 5px;border-radius:4px;font-size:10px;font-weight:600;color:#8b949e;background-color:#30363d;white-space:nowrap;flex-shrink:0}.station-clear-btn{background:none;border:none;color:#8b949e;cursor:pointer;font-size:16px;line-height:1;padding:0 2px;flex-shrink:0}.station-clear-btn:hover{color:#c9d1d9}.station-dropdown{position:absolute;top:100%;left:0;right:0;z-index:100;background-color:#21262d;border:1px solid #30363d;border-radius:6px;margin-top:4px;max-height:240px;overflow-y:auto;list-style:none;padding:4px 0;box-shadow:0 4px 16px #0006}.station-dropdown-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 12px;cursor:pointer;font-size:13px;color:#c9d1d9;transition:background-color .1s}.station-dropdown-item:hover,.station-dropdown-item.highlighted{background-color:#30363d}.station-dropdown-badges{display:flex;gap:3px;flex-shrink:0;flex-wrap:wrap}.station-dropdown-badge{padding:1px 6px;border-radius:4px;font-size:10px;font-weight:600;color:#fff;white-space:nowrap}.swap-btn{background-color:#21262d;border:1px solid #30363d;border-radius:6px;color:#8b949e;width:34px;height:34px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s,color .15s;margin-bottom:0}.swap-btn:hover{border-color:#58a6ff;color:#58a6ff}.route-time-row{display:flex;gap:12px}.route-time-field{flex:1;display:flex;flex-direction:column;gap:6px}.route-date-input,.route-time-input{width:100%;height:32px;padding:0 10px;box-sizing:border-box;background-color:#21262d;border:1px solid #30363d;border-radius:6px;color:#c9d1d9;font-size:13px;outline:none;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none}.route-date-input:hover,.route-time-input:hover{border-color:#58a6ff}.route-date-input:focus,.route-time-input:focus{border-color:#58a6ff;box-shadow:0 0 0 2px #58a6ff33}.day-type-toggle{display:flex;gap:0;height:32px;box-sizing:border-box;border:1px solid #30363d;border-radius:6px;overflow:hidden}.day-type-btn{flex:1;padding:6px 8px;background-color:#21262d;border:none;border-right:1px solid #30363d;color:#8b949e;font-size:13px;cursor:pointer;transition:background-color .15s,color .15s}.day-type-btn:last-child{border-right:none}.day-type-btn:hover:not(.active){background-color:#30363d;color:#c9d1d9}.day-type-btn.active{background-color:#1f6feb;color:#fff;font-weight:600}.route-options-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 12px;align-items:end}.route-search-btn{width:100%;height:32px;padding:0 14px;box-sizing:border-box;background-color:#1f6feb;border:1px solid #1f6feb;border-radius:6px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background-color .15s}.route-search-btn:hover:not(:disabled){background-color:#388bfd}.route-search-btn:disabled{opacity:.5;cursor:not-allowed}.route-loading{color:#58a6ff;font-size:13px;padding:8px 0}.route-error{color:#f85149;background-color:#f851491a;border:1px solid rgba(248,81,73,.3);border-radius:6px;padding:12px 16px;font-size:13px}.route-result-list{display:flex;flex-direction:column;gap:10px}.route-result{display:flex;flex-direction:column;border:1px solid #30363d;border-radius:8px;overflow:hidden}.route-result.route-result-best{border-color:#388bfd}.route-summary{background-color:#161b22;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:16px;-webkit-user-select:none;user-select:none}.route-summary:hover{background-color:#1c2128}.route-summary-left{display:flex;align-items:center;gap:6px;min-width:0;flex-wrap:wrap}.route-time{font-size:15px;font-weight:700;color:#c9d1d9}.route-arrow{color:#8b949e;font-size:13px}.route-line-badges{display:flex;align-items:center;gap:4px;margin-left:8px}.route-line-badge-wrap{display:flex;align-items:center;gap:4px}.route-line-sep{color:#555;font-size:11px}.route-summary-badge{font-size:11px;padding:1px 6px;border-radius:3px;color:#fff;font-weight:600;white-space:nowrap}.route-summary-meta{display:flex;align-items:center;gap:12px}.route-total-time{font-size:16px;font-weight:700;color:#58a6ff}.route-transfers{font-size:12px;color:#8b949e}.route-diff{font-size:13px;font-weight:600;color:#8b949e}.route-fare{font-size:13px;font-weight:600;color:#3fb950}.route-fare-sub{font-size:12px;font-weight:500}.route-expand-icon{font-size:11px;color:#8b949e}.route-segments{display:flex;flex-direction:column;gap:8px;padding:12px}.route-segment-card{display:flex;background-color:#161b22;border:1px solid #30363d;border-radius:8px;overflow:hidden}.segment-line-bar{width:4px;flex-shrink:0}.segment-content{flex:1;padding:12px 14px;display:flex;flex-direction:column;gap:10px}.segment-header{display:flex;align-items:center;gap:8px}.segment-line-badge{padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700;color:#fff}.segment-train-id{font-size:11px;color:#8b949e}.segment-stations{display:flex;flex-direction:column;gap:6px}.segment-station-row{display:flex;align-items:center;gap:10px}.segment-time{font-size:13px;font-weight:700;color:#c9d1d9;width:62px;flex-shrink:0}.segment-dot{width:10px;height:10px;border-radius:50%;border:2px solid;background-color:#0e1117;flex-shrink:0}.segment-station-name{font-size:14px;font-weight:600;color:#c9d1d9;flex:1}.segment-label{font-size:11px;color:#8b949e;flex-shrink:0}.segment-mid-stops{display:flex;align-items:center;gap:10px}.segment-time-spacer{width:62px;flex-shrink:0}.segment-mid-dot-col{width:10px;display:flex;justify-content:center;flex-shrink:0}.segment-mid-line{width:0;height:20px;border-left:2px dashed;opacity:.4}.segment-mid-info{display:flex;align-items:center;gap:8px}.segment-mid-count{font-size:11px;color:#8b949e}.segment-distance{font-size:11px;color:#8b949e;opacity:.7}.route-fare-summary{display:flex;align-items:center;gap:10px;padding:8px 14px;background-color:#161b22;border-top:1px solid #21262d;font-size:12px}.route-fare-distance{color:#8b949e}.route-fare-amount{color:#3fb950;font-weight:600}.route-fare-note{color:#d29922;font-size:11px}.segment-transfer-row{display:flex;background-color:#0e1117}.segment-transfer-bar{width:4px;flex-shrink:0}.segment-transfer-content{flex:1;padding:11px 14px 3px;display:flex;align-items:center;gap:10px}.segment-transfer-line{width:0;height:20px;border-left:2px dashed #666}.segment-transfer-walk{width:62px;text-align:right;font-size:11px;font-weight:700;color:#adb5bd;flex-shrink:0;white-space:nowrap}.route-mode-toggle{display:flex;gap:0;width:100%;box-sizing:border-box;margin-bottom:12px;border-radius:8px;overflow:hidden;border:1px solid #333;flex-shrink:0}.toggle-btn{flex:1;padding:8px 0;border:none;background:#1a1a2e;color:#aaa;font-size:14px;cursor:pointer;transition:background .2s,color .2s}.toggle-btn.active{background:#2563eb;color:#fff;font-weight:600}.toggle-btn:hover:not(.active){background:#252540}.time-mode-toggle{display:flex;gap:0;height:32px;box-sizing:border-box;border-radius:6px;overflow:hidden;border:1px solid #333}.time-mode-btn{flex:1;padding:5px 0;border:none;background:#1a1a2e;color:#aaa;font-size:13px;cursor:pointer;transition:background .2s,color .2s}.time-mode-btn.active{background:#2563eb;color:#fff;font-weight:600}.time-mode-btn:hover:not(.active){background:#252540}.route-time-input:disabled{opacity:.5;cursor:not-allowed}
