:root{--bg: #0a0e17;--surface: #141a28;--border: #1e2a40;--text: #e0e6f0;--text-muted: #8892a4;--accent: #f0c040;--accent-dim: #a08020;--red: #e05050;--orange: #e09030;--green: #40c060;--blue: #4080e0}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}.app{max-width:1280px;margin:0 auto;padding:1.5rem}.app-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--accent)}.header-title-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.app-header h1{font-size:1.5rem;font-weight:700;color:var(--accent);white-space:nowrap}.stations-loading{font-size:.8rem;color:var(--text-muted)}.station-picker{position:relative}.station-input{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:.4rem .8rem;border-radius:6px;font-size:.85rem;outline:none;width:220px;transition:border-color .2s}.station-input:focus{border-color:var(--accent)}.station-input::placeholder{color:var(--text-muted)}.station-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:var(--surface);border:1px solid var(--border);border-radius:6px;max-height:280px;overflow-y:auto;list-style:none;z-index:100;box-shadow:0 4px 20px #0006;min-width:220px}.station-option{padding:.45rem .8rem;font-size:.83rem;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.station-option.highlighted{background:#f0c0401a}.station-option.selected{color:var(--accent);font-weight:600}.station-option:active{background:#f0c04033}.header-meta{display:flex;align-items:center;gap:1rem}.last-update{font-size:.85rem;color:var(--text-muted)}.refresh-btn{background:var(--accent);color:var(--bg);border:none;padding:.4rem 1rem;border-radius:4px;cursor:pointer;font-weight:600;font-size:.85rem}.refresh-btn:hover{background:var(--accent-dim)}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.error-banner{background:#3a1010;border:1px solid var(--red);color:var(--red);padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem}.loading{text-align:center;padding:3rem;color:var(--text-muted)}.filter-bar{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.filter-input{flex:1;background:var(--surface);border:1px solid var(--border);color:var(--text);padding:.6rem 1rem;border-radius:6px;font-size:.9rem;outline:none;transition:border-color .2s}.filter-input:focus{border-color:var(--accent)}.filter-input::placeholder{color:var(--text-muted)}.result-count{font-size:.8rem;color:var(--text-muted);white-space:nowrap}.table-container{overflow-x:auto}.departures-table{width:100%;border-collapse:collapse;font-size:.9rem}.departures-table thead{position:sticky;top:0;z-index:1}.departures-table th{background:var(--surface);color:var(--accent);text-align:left;padding:.7rem .8rem;border-bottom:2px solid var(--border);white-space:nowrap;font-weight:600}.sortable-th{cursor:pointer;-webkit-user-select:none;user-select:none}.sortable-th:hover{color:#fff}.sort-indicator{font-size:.75rem;opacity:.6}.departures-table td{padding:.6rem .8rem;border-bottom:1px solid var(--border);vertical-align:top}.departures-table tbody tr:hover{background:#f0c0400d}.row-departing{background:#40c06012!important}.train-number{font-weight:700;font-variant-numeric:tabular-nums}.destination{font-weight:500}.time{font-variant-numeric:tabular-nums}.platform{text-align:center;font-weight:600}.delay-none{color:var(--text-muted)}.delay-minor{color:var(--orange);font-weight:600}.delay-major{color:var(--red);font-weight:700}.delay-cancelled{color:var(--red);font-weight:700;text-transform:uppercase;font-size:.8rem}.departing-badge{display:inline-block;background:var(--green);color:var(--bg);font-size:.75rem;font-weight:700;padding:.15rem .5rem;border-radius:3px;text-transform:uppercase;letter-spacing:.03em}.info-cell{position:relative}.info-btn{background:var(--border);color:var(--text);border:none;width:1.8rem;height:1.8rem;border-radius:50%;cursor:pointer;font-size:.85rem;display:inline-flex;align-items:center;justify-content:center}.info-btn:hover{background:var(--accent);color:var(--bg)}.info-popup{position:absolute;right:0;top:2.2rem;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:.75rem 1rem;min-width:280px;max-width:400px;z-index:10;box-shadow:0 4px 20px #0006;font-size:.82rem;line-height:1.6}.info-stops{margin-bottom:.4rem}.no-results{text-align:center;padding:2rem;color:var(--text-muted)}.login-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.2rem}.login-screen h1{font-size:1.8rem;color:var(--accent)}.login-subtitle{color:var(--text-muted);font-size:.95rem}.google-btn{background:#fff;color:#333;border:none;padding:.6rem 1.5rem;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:box-shadow .2s}.google-btn:hover{box-shadow:0 2px 12px #ffffff26}.user-info{display:flex;align-items:center;gap:.5rem}.user-avatar{width:1.8rem;height:1.8rem;border-radius:50%}.logout-btn{background:transparent;color:var(--text-muted);border:1px solid var(--border);padding:.3rem .7rem;border-radius:4px;font-size:.78rem;cursor:pointer}.logout-btn:hover{color:var(--text);border-color:var(--text-muted)}@media(max-width:768px){.app{padding:1rem}.app-header{flex-direction:column;align-items:flex-start}.app-header h1{font-size:1.2rem}.header-title-row,.station-input{width:100%}.departures-table{font-size:.8rem}.departures-table th,.departures-table td{padding:.4rem .5rem}}
