:root{--font-sans: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;--font-serif: "Noto Serif SC", "Songti SC", "SimSun", serif;--font-mono: "JetBrains Mono", "Menlo", monospace;--bg: #f7f4ef;--surface: #ffffff;--border: #e3dbd0;--border-2: #ede8e2;--text: #1a1510;--text-2: #6b5e54;--text-3: #a09287;--shadow: rgba(26, 21, 16, .06);font-family:var(--font-sans);color:var(--text);background:var(--bg);line-height:1.5;font-weight:400;color-scheme:light}*{box-sizing:border-box}html{min-height:100%;background:var(--bg);scroll-behavior:smooth}:focus-visible{outline:2px solid var(--text);outline-offset:2px;border-radius:4px}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg)}a,button,input{font:inherit}a{color:inherit}button{border:0;cursor:pointer}input{color:inherit}.app-shell{min-height:100vh}.app-frame{width:100%;min-height:100vh;display:flex;flex-direction:column}.desktop-header{display:none}.app-content{flex:1}.site-footer{margin-top:10px;padding:0 16px calc(68px + max(8px,env(safe-area-inset-bottom)))}.site-footer-meta{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px;margin:0;color:var(--text-3);font-size:12px;line-height:1.6;text-align:center}.site-footer a{color:inherit;text-decoration:none}.site-footer a:hover{color:var(--text-2);text-decoration:underline;text-underline-offset:2px}.site-footer-separator{color:var(--text-3)}.page-shell{width:100%;margin:0 auto;padding:16px 16px 0;animation:page-in .18s ease-out both}@keyframes page-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.hero,.app-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px}.hero{padding:20px}.app-panel{margin-top:12px;padding:16px;display:grid;gap:14px}.hero-grid{display:grid;gap:16px}.hero-copy-block{display:grid;gap:10px}.hero h1,.app-panel h2,.station-brief-card h3,.line-card h3,.help-card h3,.empty-state h3{margin:0}.hero h1{font-family:var(--font-serif);font-size:clamp(22px,5vw,30px);font-weight:700;line-height:1.2;letter-spacing:-.01em}.hero-station .hero h1,.hero-station h1{font-family:var(--font-sans);font-size:clamp(28px,7vw,42px);font-weight:700;line-height:1.1;letter-spacing:-.02em}.hero-copy{margin:0;color:var(--text-2);font-size:14px}.hero-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.line-tag{margin:0;display:inline-block;font-size:12px;font-weight:600;color:var(--line-accent, var(--text-2));letter-spacing:.02em}.time-badge{display:grid;gap:2px;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:10px}.time-badge.compact{min-height:96px}.time-badge-label{color:var(--text-3);font-size:11px;letter-spacing:.06em;text-transform:uppercase}.time-badge strong{font-family:var(--font-mono);font-size:clamp(28px,8vw,42px);line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.time-badge span:last-child{color:var(--text-2);font-size:13px}.summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.summary-grid.single{grid-template-columns:1fr}.summary-card{display:grid;gap:4px;padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:10px;position:relative;overflow:hidden}.summary-card:after{content:"";position:absolute;inset:0 0 auto;height:3px;background:var(--card-accent, var(--text-3))}.summary-card span,.panel-note,.station-brief-head p,.line-card-head p,.help-card p,.empty-state p,.schedule-head p,.direction-summary span,.search-box span,.station-brief-empty{margin:0;color:var(--text-3);font-size:12px}.summary-card strong{font-family:var(--font-mono);font-size:22px;font-weight:600;line-height:1.1;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.summary-card small{color:var(--text-2);font-size:12px}.panel-head,.line-card-head,.station-brief-head,.schedule-head,.station-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.app-panel h2{font-size:15px;font-weight:700;line-height:1.3}.utility-link{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 14px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);text-decoration:none;font-size:13px;transition:background .12s ease,border-color .12s ease}.utility-link.strong{background:var(--text);color:var(--bg);border-color:var(--text)}.utility-link:hover{background:var(--bg)}.utility-link.strong:hover{background:#3a2e26;border-color:#3a2e26}.station-brief-grid,.recent-grid,.help-grid,.loading-grid{display:grid;gap:10px}.line-list-grid{gap:10px}.station-brief-card{display:grid;gap:12px;padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:10px;position:relative;overflow:hidden}.station-brief-card:before,.line-card:before,.recent-card:before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:var(--line-accent, var(--text-3))}.station-brief-card h3{font-size:17px;font-weight:700;line-height:1.2}.favorite-button{flex-shrink:0;min-height:28px;padding:0 12px;border-radius:6px;background:transparent;color:var(--text-2);border:1px solid var(--border);font-size:12px;transition:background .12s ease,color .12s ease,border-color .12s ease}.favorite-button.large{min-height:34px;font-size:13px}.favorite-button.active{background:color-mix(in srgb,var(--line-accent, #888) 12%,transparent);color:var(--line-accent, var(--text));border-color:color-mix(in srgb,var(--line-accent, #888) 40%,transparent)}.station-brief-body{display:grid;gap:8px}.brief-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.brief-row span{color:var(--text-3);font-size:12px}.brief-row strong{font-family:var(--font-mono);font-size:14px;font-weight:600;letter-spacing:-.01em;font-variant-numeric:tabular-nums}.brief-row.subtle strong{color:var(--text-3);font-size:12px;font-family:var(--font-sans);font-weight:400}.brief-direction-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.brief-dest{color:var(--text-3);font-size:12px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.brief-departure{display:flex;align-items:center;gap:6px;flex-shrink:0}.brief-departure strong{font-family:var(--font-mono);font-size:14px;font-weight:600;letter-spacing:-.01em;font-variant-numeric:tabular-nums}.brief-departure em{font-style:normal;color:var(--line-accent, var(--text-2));font-size:12px;font-weight:600}.brief-ended{color:var(--text-3);font-size:12px;flex-shrink:0}.station-brief-link{display:inline-flex;align-items:center;justify-content:center;min-height:32px;padding:0 12px;border-radius:6px;background:var(--bg);border:1px solid var(--border);color:var(--text);text-decoration:none;font-size:12px;transition:background .12s ease}.station-brief-link:hover{background:var(--border-2)}.recent-card{position:relative;overflow:hidden;text-decoration:none;color:var(--text);display:grid;gap:10px;padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:10px;transition:box-shadow .15s ease,transform .15s ease}.recent-card:hover{box-shadow:0 3px 10px var(--shadow);transform:translateY(-1px)}.recent-card p{margin:0}.recent-card h3{margin:0;font-size:16px;font-weight:700}.recent-departures{display:grid;gap:3px}.recent-departures span{font-size:12px;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-variant-numeric:tabular-nums}.line-rail{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.line-chip{position:relative;overflow:hidden;text-decoration:none;color:var(--text);display:grid;gap:3px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px;border-left:3px solid var(--line-accent, var(--border));transition:box-shadow .15s ease,transform .15s ease}.line-chip:hover{box-shadow:0 2px 8px var(--shadow);transform:translateY(-1px)}.line-chip span{font-weight:700;font-size:13px}.line-chip small{color:var(--text-3);font-size:11px}.empty-state{display:grid;gap:8px;padding:20px;text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:10px}.empty-state h3{font-size:14px;font-weight:600}.search-box{display:grid;gap:8px;padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:10px}.search-box input{width:100%;height:44px;padding:0 12px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:14px;outline:none;transition:border-color .15s ease}.search-box input:focus{border-color:var(--text-2)}.search-box input::placeholder{color:var(--text-3)}.search-highlight{background:color-mix(in srgb,#f59e0b 25%,transparent);color:inherit;border-radius:2px;padding:0 1px}.search-result-hint{margin:0;font-size:12px;color:var(--text-3)}.line-list-grid{columns:1;column-gap:10px}.line-card{break-inside:avoid;margin-bottom:10px;position:relative;overflow:hidden;display:grid;grid-template-rows:auto auto;gap:14px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:10px}.line-card h3{font-size:16px;font-weight:700}.line-card-head{align-items:center}.line-card-head strong{color:var(--text-3);font-size:12px;font-weight:400;white-space:nowrap;flex-shrink:0}.station-links{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:6px;align-content:flex-start}.station-links a{display:flex;align-items:center;justify-content:center;min-height:40px;padding:8px 10px;border-radius:5px;border:1px solid var(--border);background:var(--bg);color:var(--text);text-decoration:none;font-size:12px;line-height:1.35;text-align:center;word-break:break-word;transition:background .12s ease,border-color .12s ease}.station-links a:hover{background:var(--border-2);border-color:var(--border)}.station-title-row{flex-wrap:wrap}.direction-pill-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px}.direction-pill{position:relative;overflow:hidden;display:grid;gap:2px;width:100%;padding:12px 14px 12px 18px;text-align:left;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:8px;transition:background .15s ease,border-color .15s ease,color .15s ease}.direction-pill:before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:var(--line-accent, var(--text-3))}.direction-pill span{font-weight:600;font-size:14px}.direction-pill small{color:var(--text-3);font-size:12px;transition:color .15s ease}.direction-pill.active{background:var(--line-accent, var(--text));border-color:var(--line-accent, var(--text));color:#fff}.direction-pill.active small{color:#ffffffb3}.timetable-grid{display:grid;gap:14px}.timetable-grid.focus{grid-template-columns:1fr}.timetable-card{overflow:hidden;background:var(--surface);border:1px solid var(--border);border-radius:10px}.timetable-card.current-schedule{border-color:var(--line-accent, var(--border))}.schedule-head{padding:12px 16px;background:color-mix(in srgb,var(--line-accent, #888) 6%,var(--surface));border-bottom:1px solid var(--border-2);display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.schedule-head>div{display:grid;gap:2px}.schedule-head h3{margin:0;font-size:14px;font-weight:700}.schedule-badge{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;min-height:24px;padding:0 10px;border-radius:4px;background:color-mix(in srgb,var(--line-accent, #888) 15%,transparent);color:var(--line-accent, var(--text));font-size:11px;font-weight:700}.hour-table{display:grid}.hour-row{display:grid;grid-template-columns:44px minmax(0,1fr);gap:10px;padding:9px 14px;border-top:1px solid var(--border-2)}.hour-row.current{background:color-mix(in srgb,var(--line-accent, #888) 5%,transparent)}.hour-label{display:inline-flex;align-items:flex-start;justify-content:center;padding-top:2px;font-family:var(--font-mono);font-size:16px;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}.hour-row.current .hour-label{color:var(--line-accent, var(--text))}.minute-grid{display:flex;flex-wrap:wrap;gap:5px;align-content:flex-start}.minute-chip{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:26px;padding:0 5px;border-radius:4px;background:var(--bg);color:var(--text);font-family:var(--font-mono);font-size:12px;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.01em}.minute-chip.is-past{background:transparent;color:var(--text-3)}.minute-chip.is-next{background:var(--line-accent, var(--text));color:#fff;font-weight:700}.help-grid{grid-template-columns:1fr}.help-card{display:grid;gap:8px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:10px}.help-card h3{font-size:14px;font-weight:700}.feature-grid{display:grid;gap:10px}.feature-card{display:grid;grid-template-columns:36px minmax(0,1fr);gap:12px;align-items:start;padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:10px}.feature-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;background:var(--bg);font-size:18px;flex-shrink:0}.feature-body{display:grid;gap:4px}.feature-body h4{margin:0;font-size:14px;font-weight:700}.feature-body p{margin:0;font-size:13px;color:var(--text-2);line-height:1.55}.tip-list{display:grid;gap:8px;padding:0;margin:0;list-style:none}.tip-list li{display:grid;grid-template-columns:20px minmax(0,1fr);gap:8px;align-items:start;font-size:13px;line-height:1.55;color:var(--text-2)}.tip-list li:before{content:attr(data-num);width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--border);color:var(--text-2);font-size:11px;font-weight:700;flex-shrink:0;margin-top:1px}.about-meta{display:grid;gap:6px}.about-meta-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-2);font-size:13px}.about-meta-row:first-child{padding-top:0}.about-meta-row:last-child{border-bottom:none;padding-bottom:0}.about-meta-row .meta-label{color:var(--text-3);flex-shrink:0}.about-meta-row .meta-value{color:var(--text);text-align:right}.about-disclaimer{padding:12px 14px;background:color-mix(in srgb,#f59e0b 8%,var(--surface));border:1px solid color-mix(in srgb,#f59e0b 30%,transparent);border-radius:8px;font-size:12px;color:var(--text-2);line-height:1.55}.station-meta-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.status-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--text-3)}.status-dot{width:6px;height:6px;border-radius:50%;background:var(--text-3);flex-shrink:0}.status-badge.operating{color:#16a34a}.status-badge.operating .status-dot{background:#22c55e}.scroll-back-btn{justify-self:start;display:inline-flex;align-items:center;gap:6px;min-height:30px;padding:0 12px;border-radius:6px;background:var(--text);color:var(--bg);border:none;font-size:12px;font-weight:600;cursor:pointer;transition:background .12s ease}.scroll-back-btn:hover{background:#3a2e26}.timetable-card.not-today-schedule{opacity:.75}.timetable-card.not-today-schedule .schedule-head{background:var(--surface)}.timetable-card.not-today-schedule .minute-chip{color:var(--text-3);background:transparent}.timetable-card.not-today-schedule .hour-row.current{background:transparent}.timetable-card.not-today-schedule .hour-row.current .hour-label{color:inherit}.loading-grid{grid-template-columns:1fr}.loading-card{height:80px;border-radius:10px;background:linear-gradient(90deg,#ede9e3,#e0d9d1,#ede9e3);background-size:400px 100%;animation:shimmer 1.6s ease-in-out infinite}.skeleton-card{background:linear-gradient(90deg,#ede9e3,#e0d9d1,#ede9e3);background-size:400px 100%;animation:shimmer 1.6s ease-in-out infinite}.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:20;padding:8px 12px max(8px,env(safe-area-inset-bottom));background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border)}.bottom-nav-links{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.nav-link{display:flex;align-items:center;justify-content:center;min-height:42px;border-radius:8px;color:var(--text-3);text-decoration:none;font-size:14px;transition:background .12s ease,color .12s ease}.nav-link.active{background:var(--text);color:var(--bg);font-weight:600}.nav-link:hover{color:var(--text-2)}.panel-note{font-size:11px;color:var(--text-3);white-space:nowrap;padding-top:2px}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.station-info-strip{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:8px 10px;background:var(--bg);border-radius:6px;font-size:13px;color:var(--text-2)}.sinfo-clock{font-family:var(--font-mono);font-size:15px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:-.01em}.sinfo-divider{width:1px;height:12px;background:var(--border);flex-shrink:0}.sinfo-next{display:flex;align-items:center;gap:4px}.sinfo-next strong{font-family:var(--font-mono);font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.sinfo-next em{font-style:normal;color:var(--line-accent, var(--text-2));font-weight:600}.sinfo-ended{color:var(--text-3)}.direction-snapshot{padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:10px;position:relative;overflow:hidden;display:grid;gap:10px}.direction-snapshot:before{content:"";position:absolute;inset:0 0 auto;height:3px;background:var(--line-accent, var(--text-3))}.snapshot-dest{margin:0;font-size:12px;color:var(--text-3);letter-spacing:.02em}.snapshot-times{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px;align-items:start}.snapshot-time-col{display:grid;gap:3px}.snapshot-time-val{font-family:var(--font-mono);font-size:16px;font-weight:600;letter-spacing:-.02em;font-variant-numeric:tabular-nums;color:var(--text-2);line-height:1}.snapshot-time-col.primary .snapshot-time-val{font-size:28px;font-weight:700;color:var(--text)}.snapshot-time-hint{font-size:11px;color:var(--text-3);letter-spacing:.01em}.snapshot-time-hint.accent{color:var(--line-accent, var(--text-2));font-weight:600;font-size:12px}.snapshot-ended{display:grid;gap:5px}.snapshot-ended strong{font-size:14px;font-weight:600;color:var(--text-2)}.snapshot-ended span{font-size:12px;color:var(--text-3);font-family:var(--font-mono);font-variant-numeric:tabular-nums}@media (min-width: 768px){.app-shell{padding:24px 28px}.app-frame{width:min(100%,1280px);margin:0 auto;min-height:calc(100vh - 48px)}.desktop-header{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border)}.brand-lockup{display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:var(--text)}.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:7px;background:var(--text);color:var(--bg);font-family:var(--font-serif);font-weight:700;font-size:16px}.brand-copy strong{font-size:15px;font-weight:700;letter-spacing:-.01em}.desktop-nav{display:inline-flex;align-items:center;gap:2px}.desktop-nav .nav-link{min-height:34px;padding:0 16px;border-radius:6px;font-size:14px;color:var(--text-2)}.desktop-nav .nav-link.active{background:var(--text);color:var(--bg);font-weight:600}.desktop-nav .nav-link:hover:not(.active){background:var(--bg);color:var(--text)}.page-shell{width:min(100%,1180px);padding:0 4px}.site-footer{margin-top:16px;padding:0 16px 16px}.hero,.app-panel{padding:22px 26px}.hero-grid{grid-template-columns:minmax(0,1.2fr) minmax(260px,.8fr);align-items:start}.hero-grid.compact{grid-template-columns:minmax(0,1fr) minmax(260px,.7fr)}.hero-grid.station{grid-template-columns:minmax(0,1.4fr) minmax(260px,.6fr)}.summary-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.station-brief-grid,.recent-grid,.help-grid,.feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.line-rail{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.line-list-grid{columns:2}.loading-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.bottom-nav,.station-info-strip{display:none}.hero-station .hero-side{display:grid;gap:10px;align-content:start}}@media (max-width: 767px){.hero-station .hero-side{display:none}}@media (max-width: 640px){.page-shell{padding:14px 12px 0}.site-footer{margin-top:16px;padding:0 16px calc(74px + max(8px,env(safe-area-inset-bottom)))}.summary-grid{grid-template-columns:1fr}.recent-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.panel-head{flex-direction:column}.hour-row{grid-template-columns:40px minmax(0,1fr);gap:8px;padding:8px 12px}.minute-chip{min-width:30px;height:24px;font-size:11px}}.toast-notification{position:fixed;top:16px;right:16px;z-index:200;display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 4px 20px var(--shadow);max-width:320px;animation:toast-in .2s ease}@keyframes toast-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.toast-body{flex:1;display:grid;gap:2px;min-width:0}.toast-title{font-size:13px;font-weight:600;color:var(--text)}.toast-desc{font-size:12px;color:var(--text-3)}.toast-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.toast-button{padding:5px 12px;border-radius:20px;background:var(--text);color:var(--bg);font-size:12px;font-weight:600;white-space:nowrap}.toast-button:hover{opacity:.85}.toast-close{width:26px;height:26px;border-radius:50%;background:transparent;color:var(--text-3);font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center}.toast-close:hover{background:var(--bg);color:var(--text)}.sw-status-card{display:flex;align-items:center;gap:10px}.sw-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sw-status-dot-ok{background:#4caf7d}.sw-status-dot-ready{background:#e9a84c}.sw-status-dot-error{background:#d95c5c}.sw-status-dot-pending{background:var(--border);animation:dot-pulse 1.2s ease-in-out infinite}@keyframes dot-pulse{0%,to{opacity:1}50%{opacity:.35}}.sw-status-text{flex:1;display:flex;align-items:baseline;gap:8px;min-width:0;flex-wrap:wrap}.sw-status-label{font-size:13px;color:var(--text-2)}.sw-status-build{font-family:var(--font-mono);font-size:11px;color:var(--text-3)}.sw-status-reload{padding:4px 12px;border-radius:20px;background:var(--text);color:var(--bg);font-size:12px;font-weight:600;flex-shrink:0}.sw-status-reload:hover{opacity:.85}
