.route-card{background:var(--color-surface);border-radius:var(--radius-l);overflow:hidden;box-shadow:0 2px 16px #00000012;display:flex;flex-direction:column}.hero-section{padding:24px 20px 20px;display:flex;flex-direction:column;gap:10px}.hero-meta{display:flex;align-items:center;gap:10px}.hero-time{font-size:15px;font-weight:600;color:var(--color-text-sub)}.level-badge{font-size:12px;font-weight:700;color:#fff;padding:3px 10px;border-radius:100px}.hero-pct{font-size:64px;font-weight:800;line-height:1;letter-spacing:-2px}.hero-unit{font-size:28px;font-weight:700;letter-spacing:0}.card-divider{height:1px;background:var(--color-border);margin:0 20px}.tl-tabs{display:flex;border-bottom:1px solid var(--color-border)}.tl-tab{flex:1;padding:13px 0;font-size:15px;font-weight:700;color:var(--color-text-sub);border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.tl-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.timeline-section{padding:16px 20px 20px;display:flex;flex-direction:column;gap:0}.tl-header{font-size:13px;font-weight:700;color:var(--color-text-sub);margin-bottom:8px;text-transform:uppercase;letter-spacing:.04em}.tl-row{display:grid;grid-template-columns:44px 1fr 44px 48px;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-s);margin:0 -10px;transition:background .15s}.tl-now{background:#3182f612}.tl-time{font-size:14px;font-weight:700;color:var(--color-text);white-space:nowrap}.tl-now .tl-time{color:var(--color-primary)}.tl-pct{font-size:14px;font-weight:700;text-align:right;white-space:nowrap}.tl-tags{display:flex;gap:3px;justify-content:flex-end}.tl-tag{font-size:11px;font-weight:700;padding:2px 6px;border-radius:100px;white-space:nowrap}.tl-tag-now{background:#3182f61f;color:var(--color-primary)}.tl-tag-avoid,.tl-tag-rec{font-size:14px}.bar-bg{height:6px;background:var(--color-border);border-radius:3px;overflow:hidden}.bar-thick{height:10px;border-radius:5px}.bar-fill{height:100%;border-radius:inherit;transition:width .4s ease}.reason-box{margin:0 20px 20px;background:var(--color-bg);border-radius:var(--radius-m);padding:14px 16px;font-size:14px;line-height:1.65;color:var(--color-text)}.lm-card{background:var(--color-surface);border-radius:var(--radius-l);box-shadow:0 2px 12px #0000000f;padding:14px 0 8px;overflow:visible}.lm-header{display:flex;align-items:center;justify-content:space-between;padding:0 16px 10px}.lm-title{font-size:13px;font-weight:700;color:var(--color-text-sub)}.lm-expand-btn{font-size:12px;font-weight:600;color:var(--color-primary)}.lm-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}.lm-scroll::-webkit-scrollbar{display:none}.lm-track{display:flex;align-items:center;position:relative;padding:40px 28px 72px;min-width:max-content}.lm-line{position:absolute;left:0;right:0;height:5px;border-radius:3px;opacity:.45;pointer-events:none;top:50%;transform:translateY(-50%);margin-top:-16px}.lm-station{display:flex;flex-direction:column;align-items:center;flex-shrink:0;cursor:pointer;position:relative;z-index:1}.lm-arrow-slot{height:28px;display:flex;align-items:center;justify-content:center;margin-bottom:6px}.lm-arrow{font-weight:900;display:inline-block}.lm-arrow.asc{animation:bounce-r 1s ease-in-out infinite}.lm-arrow.desc{animation:bounce-l 1s ease-in-out infinite}@keyframes bounce-r{0%,to{transform:translate(0)}50%{transform:translate(4px)}}@keyframes bounce-l{0%,to{transform:translate(0)}50%{transform:translate(-4px)}}.lm-dot{border-radius:50%;flex-shrink:0;transition:background .3s}.lm-dot-current{border:3px solid #fff}.lm-name{color:var(--color-text);white-space:nowrap;transform:rotate(-45deg);transform-origin:top left;margin-left:8px;position:absolute;top:calc(100% - 4px);left:50%}.lm-name-current{font-weight:800;color:var(--color-text)}.lm-popup{position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%);background:var(--color-text);border-radius:var(--radius-m);padding:10px 14px;display:flex;flex-direction:column;align-items:center;gap:3px;white-space:nowrap;z-index:30;box-shadow:0 6px 20px #00000040;pointer-events:none}.lm-popup:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--color-text)}.lm-popup-name{font-size:13px;font-weight:700;color:#fff}.lm-popup-pct{font-size:20px;font-weight:800}.lm-popup-level{font-size:11px;color:#fff9}.lm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;align-items:flex-end}.lm-modal{width:100%;background:var(--color-surface);border-radius:20px 20px 0 0;padding-top:8px;max-height:70dvh;overflow:hidden;display:flex;flex-direction:column}.lm-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;flex-shrink:0}.lm-modal-title{font-size:17px;font-weight:800}.lm-close-btn{font-size:16px;color:var(--color-text-sub);width:32px;height:32px;display:flex;align-items:center;justify-content:center}.lm-modal-legend{display:flex;align-items:center;gap:12px;padding:16px 20px;font-size:12px;font-weight:600;color:var(--color-text-sub);flex-shrink:0;border-top:1px solid var(--color-border)}.lm-legend-dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:4px}.home-page{display:flex;flex-direction:column;min-height:100dvh;background:var(--color-bg)}.home-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.home-title{font-size:18px;font-weight:800}.day-badge{font-size:12px;font-weight:600;color:var(--color-text-sub);background:var(--color-border);padding:3px 10px;border-radius:100px}.picker-section{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:16px 20px 20px;display:flex;flex-direction:column;gap:16px}.picker-block{display:flex;flex-direction:column;gap:10px}.picker-label{font-size:12px;font-weight:700;color:var(--color-text-sub);letter-spacing:.04em;text-transform:uppercase}.line-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.line-btn{height:36px;border-radius:var(--radius-s);border:1.5px solid;font-size:12px;font-weight:700;background:transparent;transition:transform .1s;display:flex;align-items:center;justify-content:center;white-space:nowrap}.line-btn:active{transform:scale(.92)}.line-btn.selected{box-shadow:0 2px 8px #0000002e}.station-btn{width:100%;height:42px;border-radius:var(--radius-s);border:1.5px solid var(--color-border);background:var(--color-surface);display:flex;align-items:center;justify-content:space-between;padding:0 12px;font-size:14px;font-weight:600;color:var(--color-text-sub);transition:border-color .15s}.station-btn.filled{color:var(--color-text)}.station-btn:active{background:var(--color-bg)}.station-btn-arrow{font-size:16px;color:var(--color-border)}.dir-toggle{display:flex;gap:8px}.dir-btn{flex:1;min-height:46px;border-radius:var(--radius-s);border:1.5px solid var(--color-border);background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 6px;color:var(--color-text-sub);transition:background .15s,color .15s,border-color .15s}.dir-btn.selected{color:#fff;box-shadow:0 2px 8px #00000026}.direction-flow{display:flex;align-items:center;gap:5px;padding:10px 2px 2px;font-size:13px;flex-wrap:wrap}.df-current{font-size:13px;font-weight:700;color:var(--color-text)}.df-arrow{color:var(--color-text-sub);font-size:12px}.df-next{font-size:13px;font-weight:700;color:var(--color-primary)}.df-terminus{font-size:12px;color:var(--color-text-sub)}.df-landmark{color:var(--color-orange)!important}.landmark-row{display:flex;flex-direction:column;gap:8px;padding:10px 0 2px}.landmark-title{font-size:11px;font-weight:700;color:var(--color-text-sub);letter-spacing:.04em;text-transform:uppercase}.landmark-chips{display:flex;flex-wrap:wrap;gap:6px}.landmark-chip{font-size:13px;font-weight:600;color:var(--color-orange);background:#ff6b0014;border:1px solid rgba(255,107,0,.2);padding:4px 10px;border-radius:100px}.df-hot{font-size:10px;font-weight:700;color:var(--color-orange);background:#ff6b001a;padding:1px 5px;border-radius:4px}.dir-label{font-size:12px;font-weight:700}.dir-terminal{font-size:11px;font-weight:500;opacity:.85;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.result-area{flex:1;padding:16px 16px 32px}.line-map-card{background:var(--color-surface);border-radius:var(--radius-l);box-shadow:0 2px 12px #0000000f;margin-bottom:12px;overflow:visible}.time-selector-row{display:flex;align-items:center;gap:8px;margin-bottom:12px}.time-chip{display:flex;align-items:center;gap:6px;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:100px;padding:6px 14px;font-size:14px;font-weight:700;color:var(--color-text)}.time-chip-auto{font-size:11px;font-weight:700;color:var(--color-primary);background:#3182f61a;padding:1px 6px;border-radius:100px}.time-chip-arrow{font-size:10px;color:var(--color-text-sub)}.time-reset-btn{font-size:13px;font-weight:600;color:var(--color-primary)}.time-sheet-list{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:8px 16px 32px}.time-period-label{grid-column:1 / -1;font-size:11px;font-weight:700;color:var(--color-text-sub);padding:8px 4px 4px;letter-spacing:.04em}.time-slot-btn{position:relative;height:44px;border-radius:var(--radius-s);border:1.5px solid var(--color-border);font-size:14px;font-weight:600;color:var(--color-text);display:flex;align-items:center;justify-content:center;gap:4px}.time-slot-btn.selected{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.time-slot-btn.is-now{border-color:var(--color-primary);color:var(--color-primary)}.time-slot-btn.selected.is-now{color:#fff}.now-badge{font-size:9px;font-weight:700;background:var(--color-primary);color:#fff;padding:1px 4px;border-radius:3px;position:absolute;top:4px;right:4px}.time-slot-btn.selected .now-badge{background:#ffffff4d}.guide-card{margin-top:40px;text-align:center;font-size:15px;color:var(--color-text-sub);line-height:1.8}.no-data-card{margin-top:40px;text-align:center;font-size:15px;color:var(--color-text-sub)}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000;z-index:100;transition:background .25s}.sheet-overlay.visible{background:#00000073}.sheet{position:absolute;bottom:0;left:0;right:0;max-height:75dvh;background:var(--color-surface);border-radius:20px 20px 0 0;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .26s cubic-bezier(.32,.72,0,1)}.sheet.visible{transform:translateY(0)}.sheet-handle{width:36px;height:4px;background:var(--color-border);border-radius:2px;margin:12px auto 0;flex-shrink:0}.sheet-top{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 8px;flex-shrink:0}.sheet-title{font-size:17px;font-weight:800}.sheet-close{font-size:16px;color:var(--color-text-sub);width:32px;height:32px;display:flex;align-items:center;justify-content:center}.sheet-search-wrap{margin:8px 16px 12px;display:flex;align-items:center;gap:10px;background:var(--color-bg);border-radius:var(--radius-m);padding:0 14px;flex-shrink:0}.sheet-search{flex:1;height:44px;background:transparent;border:none;outline:none;font-size:15px;font:inherit;color:var(--color-text)}.sheet-list{flex:1;overflow-y:auto;padding:0 8px 32px}.sheet-item{width:100%;height:50px;display:flex;align-items:center;padding:0 12px;font-size:16px;font-weight:500;color:var(--color-text);border-radius:var(--radius-s)}.sheet-item:active{background:var(--color-bg)}.sheet-empty{text-align:center;padding:32px 0;font-size:14px;color:var(--color-text-sub)}.loading-screen,.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;gap:14px;color:var(--color-text-sub);font-size:15px}.spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-screen button{color:var(--color-primary);font-size:15px;font-weight:700}.ob-page{display:flex;flex-direction:column;min-height:100dvh;background:var(--color-bg)}.ob-body{flex:1;display:flex;flex-direction:column;align-items:center;padding:64px 28px 32px}.ob-icon{font-size:56px;margin-bottom:20px}.ob-title{font-size:28px;font-weight:900;color:var(--color-text);margin-bottom:12px;text-align:center}.ob-desc{font-size:16px;color:var(--color-text-sub);line-height:1.7;text-align:center;margin-bottom:40px}.ob-features{width:100%;display:flex;flex-direction:column;gap:16px;margin-bottom:36px}.ob-feature{display:flex;align-items:center;gap:16px;background:var(--color-surface);border-radius:var(--radius-l);padding:16px 18px}.ob-feat-icon{font-size:24px;flex-shrink:0}.ob-feature strong{display:block;font-size:15px;font-weight:700;color:var(--color-text);margin-bottom:2px}.ob-feature p{font-size:13px;color:var(--color-text-sub)}.ob-coverage{width:100%;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px}.ob-coverage-title{font-size:13px;font-weight:600;color:var(--color-text-sub)}.ob-lines{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.ob-line-chip{font-size:12px;font-weight:700;color:#fff;padding:4px 10px;border-radius:100px}.ob-line-chip-more{font-size:12px;font-weight:600;color:var(--color-text-sub);background:var(--color-border);padding:4px 10px;border-radius:100px}.ob-caution{display:flex;align-items:flex-start;gap:8px;background:#fff8ec;border:1px solid #ffe0a0;border-radius:var(--radius-m);padding:12px 14px;text-align:left;width:100%}.ob-caution-icon{font-size:16px;flex-shrink:0;margin-top:1px}.ob-caution p{font-size:13px;color:#7a5c00;line-height:1.6}.ob-coverage-note{font-size:12px;color:var(--color-text-sub);opacity:.7}.ob-footer{padding:16px 24px 40px}.ob-start-btn{width:100%;height:56px;border-radius:var(--radius-l);background:var(--color-primary);color:#fff;font-size:17px;font-weight:800;transition:opacity .15s}.ob-start-btn:active{opacity:.85}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #3182f6;--color-bg: #f9fafb;--color-surface: #ffffff;--color-text: #191f28;--color-text-sub: #8b95a1;--color-border: #e5e8eb;--color-green: #05c072;--color-orange: #ff6b00;--color-red: #f04452;--radius-s: 8px;--radius-m: 12px;--radius-l: 16px;font-family:-apple-system,Apple SD Gothic Neo,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased}body{min-height:100dvh;max-width:430px;margin:0 auto;background:var(--color-bg)}#root{min-height:100dvh;display:flex;flex-direction:column}button{cursor:pointer;border:none;background:none;font:inherit}
