:root{--city-bg: #F8FAFC;--city-card: #FFFFFF;--city-text: #1E293B;--city-muted: #64748B;--city-primary: #0F4FA3;--city-accent: #4A90E2;--city-success: #2E7D32;--city-warn: #F9A825;--city-danger: #E53935;--bg: var(--city-bg);--bg-secondary: var(--city-card);--card: var(--city-card);--text: var(--city-text);--muted: var(--city-muted);--kmc-brand: var(--city-primary);--kmc-accent: var(--city-accent);--accent-blue: var(--city-primary);--accent-green: var(--city-success);--accent-yellow: var(--city-warn);--success: var(--city-success);--warn: var(--city-warn);--danger: var(--city-danger);--border: #E6E9EF;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--line-blue: #0F4FA3;--line-green: #2E7D32;--line-purple: #9333EA;--line-orange: #F97316}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.app{max-width:480px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.logo{display:flex;align-items:center;gap:10px}.logo-circle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden}.logo-circle svg{width:100%;height:100%}.app-title{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.5px}.lang-toggle{display:flex;background:var(--bg);border-radius:6px;overflow:hidden;border:1px solid var(--border)}.lang-btn{padding:6px 10px;border:none;background:transparent;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease}.lang-btn:hover{color:var(--text)}.lang-btn.active{background:var(--accent-blue);color:#fff}.status-strip{display:flex;gap:6px;padding:8px 12px;background:var(--bg-secondary);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;justify-content:center}.status-strip::-webkit-scrollbar{display:none}.status-item{display:flex;align-items:center;gap:6px;flex-shrink:0;padding:6px 10px;background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border);font-size:12px;font-weight:500;transition:all .2s ease}.status-item.normal{border-color:#22c55e4d}.status-item.advisory{border-color:var(--accent-yellow);background:#fbbf241a}.status-item.suspended{border-color:var(--danger);background:#ef44441a}.line-letter{width:22px;height:22px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff}.line-letter.blue{background:var(--line-blue)}.line-letter.green{background:var(--line-green)}.line-letter.purple{background:var(--line-purple)}.line-letter.orange{background:var(--line-orange)}.status-badge{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.3px}.status-item.normal .status-badge{background:#22c55e26;color:#16a34a}.status-item.advisory .status-badge{background:#fbbf2433;color:#d97706;animation:pulse-warning 2s ease-in-out infinite}.status-item.suspended .status-badge{background:#ef444433;color:#dc2626;animation:pulse-danger 1s ease-in-out infinite}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.6}}@keyframes pulse-danger{0%,to{opacity:1}50%{opacity:.5}}.sponsor-strip{display:none;font-size:10px;color:var(--muted);padding-left:12px;border-left:1px solid var(--border);margin-left:auto;flex-shrink:0}.sponsor-strip.show{display:flex;align-items:center;gap:4px}.main{flex:1;padding:16px;display:flex;flex-direction:column;gap:16px}.station-selector{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;border:1px solid var(--border)}.station-selector:hover{background:#f1f5f9}.location-icon{width:20px;height:20px;color:var(--accent-blue)}.station-info{flex:1}.station-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.station-name{font-size:16px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px}.line-badge{width:10px;height:10px;border-radius:50%}.dropdown-arrow{width:20px;height:20px;color:var(--muted);transition:transform .2s ease}.station-selector.open .dropdown-arrow{transform:rotate(180deg)}.station-dropdown{display:none;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);max-height:300px;overflow-y:auto;box-shadow:var(--shadow-md)}.station-dropdown.show{display:block}.dropdown-group-header{padding:8px 16px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);background:var(--bg);display:flex;align-items:center;gap:8px}.dropdown-item{padding:12px 16px;cursor:pointer;font-size:14px;display:flex;align-items:center;gap:10px;transition:background .15s ease}.dropdown-item:hover{background:var(--bg)}.next-trains{background:var(--bg-secondary);border:2px solid var(--accent-blue);border-radius:var(--radius-lg);overflow:hidden}.direction-tabs{display:flex;border-bottom:1px solid var(--border)}.direction-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:10px 12px;background:var(--bg);border:none;font-size:11px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .2s ease}.direction-tab:first-child{border-right:1px solid var(--border)}.direction-tab.active{background:var(--accent-blue);color:#fff}.direction-tab:not(.active):hover{background:#e2e8f0;color:var(--text)}.tab-arrow{font-size:20px;font-weight:700;line-height:1}.tab-terminal{font-size:10px;opacity:.9;max-width:100px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.next-trains-body{padding:16px;text-align:center}.train-times-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:12px}.train-card{background:var(--bg);border-radius:var(--radius-sm);padding:12px 8px;text-align:center;border:1px solid var(--border);position:relative}.train-card.primary{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.train-card.primary .train-time{color:#fff}.train-card.primary .train-eta{color:#fffc}.countdown-bar{position:absolute;bottom:0;left:0;height:4px;background:#fff6;border-radius:0 0 var(--radius-sm) var(--radius-sm);transition:width 1s linear}.train-time{font-size:24px;font-weight:700;color:var(--text);letter-spacing:-.5px}.train-card.primary .train-time{font-size:28px}.train-eta{font-size:11px;color:var(--muted);margin-top:4px}.urgency-indicator{display:flex;align-items:center;justify-content:center;gap:10px;padding:10px 20px;border-radius:24px;font-size:13px;font-weight:600}.urgency-indicator.safe{background:#dcfce7;color:#166534}.urgency-indicator.warning{background:#fef9c3;color:#854d0e;animation:urgency-pulse 1.5s ease-in-out infinite}.urgency-indicator.danger{background:#fee2e2;color:#991b1b;animation:urgency-flash .8s ease-in-out infinite}@keyframes urgency-pulse{0%,to{transform:scale(1);box-shadow:0 0 #f9a82566}50%{transform:scale(1.02);box-shadow:0 0 0 8px #f9a82500}}@keyframes urgency-flash{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.03);opacity:.85}}.urgency-figure{width:28px;height:28px;display:flex;align-items:center;justify-content:center}.urgency-figure svg{width:100%;height:100%}.urgency-time{font-size:18px;font-weight:700;font-variant-numeric:tabular-nums}.urgency-unit{font-size:11px;font-weight:500;opacity:.8}.no-trains{padding:24px;text-align:center;color:var(--muted)}.no-trains-icon{width:48px;height:48px;margin:0 auto 12px;opacity:.5}.no-trains-title{font-size:15px;font-weight:600;margin-bottom:4px}.no-trains-sub{font-size:13px}.action-row{display:flex;gap:10px}.action-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:14px 10px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:10px;font-weight:500;color:var(--muted);text-decoration:none;cursor:pointer;transition:all .2s ease}.action-btn:hover{border-color:var(--accent-blue);background:#1f4fa30d;color:var(--accent-blue)}.action-btn svg{width:24px;height:24px;color:var(--text)}.action-btn:hover svg{color:var(--accent-blue)}.action-btn.primary{background:var(--accent-blue);border-color:var(--accent-blue);color:#ffffffe6}.action-btn.primary svg{color:#fff}.action-btn.primary:hover{background:#184090}.ad-card{position:relative;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;height:60px;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:opacity .3s ease,transform .3s ease}.ad-card[aria-hidden=true],.ad-card.hidden{display:none!important}.ad-card.loading{opacity:.6}.ad-label{position:absolute;top:6px;left:8px;font-size:10px;font-weight:600;text-transform:uppercase;color:var(--muted);letter-spacing:.3px}.ad-content,.ad-slot{width:100%;display:flex;align-items:center;justify-content:center}.ad-fallback{font-size:11px;color:var(--muted);text-align:center}.ad-card ins.adsbygoogle{display:block;width:100%;height:50px}.more-section{background:var(--bg-secondary);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border)}.more-toggle{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px 16px;background:transparent;border:none;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer}.more-toggle svg{width:18px;height:18px;color:var(--muted);transition:transform .2s ease}.more-section.open .more-toggle svg{transform:rotate(180deg)}.more-content{display:none;padding:0 16px 16px}.more-section.open .more-content{display:block}.first-last-row{display:flex;gap:16px;padding:12px 0;border-bottom:1px solid var(--border)}.fl-item{flex:1;display:flex;align-items:center;gap:8px}.fl-icon{width:20px;height:20px;color:var(--muted)}.fl-time{font-size:16px;font-weight:700;color:var(--text)}.station-meta{padding:12px 0}.meta-row{display:flex;align-items:center;gap:8px;padding:8px 0;font-size:13px;color:var(--text)}.meta-icon{width:18px;height:18px;color:var(--muted)}.meta-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.meta-chip-labeled{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg);border:1px solid var(--border);border-radius:20px;color:var(--text);font-size:12px;font-weight:500}.meta-chip-labeled svg{width:16px;height:16px;flex-shrink:0;color:var(--accent-blue)}.last-verified{display:flex;align-items:center;gap:6px;padding-top:12px;font-size:11px;color:var(--muted)}.last-verified a{color:var(--accent-blue);text-decoration:none}.last-verified a:hover{text-decoration:underline}.ad-card.compact,.ad-card-secondary{margin-top:16px;height:50px;border:none;border-top:1px solid var(--border);border-radius:0;background:transparent}.footer{padding:16px;text-align:center;background:var(--bg-secondary);border-top:1px solid var(--border)}.footer-text{font-size:11px;color:var(--muted);line-height:1.5}.footer-text a{color:var(--accent-blue);text-decoration:none}.privacy-banner{position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border);padding:16px;box-shadow:0 -4px 12px #0000001a;z-index:200;display:none}.privacy-banner.show{display:block}.privacy-text{font-size:12px;color:var(--text);margin-bottom:12px;line-height:1.5}.privacy-buttons{display:flex;gap:10px}.privacy-btn{flex:1;padding:10px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.privacy-btn.accept{background:var(--accent-blue);border:none;color:#fff}.privacy-btn.decline{background:transparent;border:1px solid var(--border);color:var(--text)}.hidden{display:none!important}@media (max-width: 360px){.action-row{flex-wrap:wrap}.action-btn{flex:1 1 30%}.train-time{font-size:20px}.train-card.primary .train-time{font-size:24px}}@media (prefers-color-scheme: dark){:root{--bg: #0F172A;--bg-secondary: #1E293B;--text: #F1F5F9;--muted: #94A3B8;--border: #334155}.urgency-indicator.safe{background:#166534;color:#dcfce7}.urgency-indicator.warning{background:#854d0e;color:#fef9c3}.urgency-indicator.danger{background:#991b1b;color:#fee2e2}.status-badge.normal{background:#166534;color:#dcfce7}.status-badge.advisory{background:#854d0e;color:#fef9c3}.status-badge.suspended{background:#991b1b;color:#fee2e2}}
