.app{grid-template-rows:1fr;height:100vh;padding:1rem 1.5rem;display:grid}.app-main{grid-template-rows:1fr;grid-template-columns:auto 1fr;gap:1.5rem;min-height:0;display:grid}.panel{background:var(--bg-panel);border-radius:1rem;min-height:0;padding:1.5rem;overflow-y:auto}.clock{justify-content:space-between;align-items:center;display:flex}.clock-time{letter-spacing:-1px;font-size:3.5rem;font-weight:700;line-height:1;font-family:var(--font-mono)}.clock-info{color:var(--text-dim);text-transform:capitalize;font-size:1.1rem}.station-current{cursor:pointer;border-radius:.75rem;grid-template-columns:auto auto 1fr auto;align-items:center;gap:.5rem;padding:.5rem 0;transition:background .2s;display:grid}.station-current:hover{background:#ffffff08}.station-icon{font-size:1.5rem}.station-name{font-size:1.3rem;font-weight:600}.station-locality{color:var(--text-dim);font-size:1rem}.station-change{color:var(--accent);font-size:.9rem;font-weight:500}.station-selector{width:100%;position:relative}.station-input{border:2px solid var(--border);background:var(--bg-panel);width:100%;color:var(--text);border-radius:.75rem;outline:none;padding:.75rem 1rem;font-size:1.2rem}.station-input:focus{border-color:var(--accent)}.station-cancel{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:.5rem;font-size:1.3rem;position:absolute;top:50%;right:.5rem;transform:translateY(-50%)}.station-results{background:var(--bg-panel);border:1px solid var(--border);z-index:100;border-radius:.75rem;max-height:50vh;list-style:none;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden auto}.station-results li{cursor:pointer;border-bottom:1px solid var(--border);grid-template-columns:1fr auto;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:1.1rem;display:grid}.station-results li:last-child{border-bottom:none}.station-results li:hover{background:#60a5fa1a}.result-locality{color:var(--text-dim);font-size:.9rem}.weather-panel{grid-template-rows:auto 1fr auto;gap:1rem;max-width:22rem;display:grid;overflow:hidden}.weather-display{min-height:0;overflow:hidden}.weather-forecast-vertical{grid-template-columns:auto auto auto auto auto;align-content:start;gap:.15rem .4rem;display:grid;position:relative;overflow:hidden}.weather-forecast-vertical:after{content:"";pointer-events:none;background:linear-gradient(to bottom, transparent, var(--bg-panel));grid-column:1/-1;height:3rem;position:sticky;bottom:0}.forecast-row{grid-template-columns:subgrid;border-radius:.5rem;grid-column:1/-1;align-items:center;padding:.35rem .5rem;display:grid}.forecast-row:nth-child(odd){background:#ffffff08}.forecast-now{border-bottom:1px solid var(--border);margin-bottom:.15rem;padding:.5rem;font-size:1.3rem;background:0 0!important}.forecast-now .forecast-emoji{font-size:2rem}.forecast-now .forecast-temp{font-size:1.5rem;font-weight:700}.forecast-now .forecast-time{color:var(--text);font-size:1.1rem;font-weight:600}.forecast-time{color:var(--text-dim);font-size:.95rem;font-family:var(--font-mono)}.forecast-emoji{text-align:center;font-size:1.5rem}.forecast-temp{text-align:right;font-size:1.1rem;font-weight:600}.forecast-wind{color:var(--text-dim);white-space:nowrap;text-align:right;font-size:.8rem}.forecast-rain{color:var(--accent);white-space:nowrap;text-align:right;font-size:.85rem}.departure-panel{overflow:hidden}.departure-board{grid-template-rows:1fr;grid-template-columns:1fr 1fr;gap:1.5rem;height:100%;min-height:0;display:grid}.departure-column{grid-template-rows:auto max-content 1fr;grid-template-columns:auto 1fr auto;column-gap:.5rem;min-height:0;display:grid;overflow:hidden}.departure-rows{grid-column:1/-1;grid-template-columns:subgrid;align-content:start;row-gap:.25rem;min-height:0;display:grid;position:relative;overflow:hidden}.departure-rows:after{content:"";pointer-events:none;background:linear-gradient(to bottom, transparent, var(--bg-panel));grid-column:1/-1;height:3rem;position:sticky;bottom:0}.direction-label{color:var(--text);grid-column:1/-1;padding-bottom:.75rem;font-size:1.05rem;font-weight:600;line-height:1.3}.departure-header{grid-template-columns:subgrid;border-bottom:1px solid var(--border);grid-column:1/-1;padding:.4rem 0;display:grid}.departure-header span{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-size:.8rem;font-weight:500}.departure-row{grid-template-columns:subgrid;border-bottom:1px solid #ffffff0d;grid-column:1/-1;align-items:center;padding:.35rem 0;font-size:1.05rem;display:grid}.departure-row.fade{color:#999}.col-eta{text-align:right;font-family:var(--font-mono);flex-wrap:wrap;justify-content:flex-end;align-items:baseline;display:flex}.line-badge{background:var(--accent);color:#fff;text-align:center;border-radius:.3rem;min-width:2.5rem;padding:.1rem .4rem;font-size:1rem;font-weight:700;display:inline-block}.realtime{color:var(--green);white-space:nowrap;font-weight:600}.scheduled{color:var(--text);white-space:nowrap}.dep-time{color:var(--text-dim);white-space:nowrap;margin-left:.4rem;font-size:.9rem}@media (width<=900px){.app{padding:.5rem .75rem}}@media (width<=600px){.app{padding:.25rem .4rem}}.welcome-layout{place-content:center;place-items:center}.welcome{place-items:center;gap:1.5rem;display:grid}.welcome h1{color:var(--text);font-size:3rem;font-weight:700}.welcome p{color:var(--text-dim);font-size:1.5rem}.departure-error,.weather-error{color:var(--red);text-align:center;padding:2rem;font-size:1.2rem}.departure-loading,.weather-loading{color:var(--text-dim);text-align:center;padding:2rem;font-size:1.2rem}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}:root{--bg:#0f1117;--bg-panel:#1a1c25;--text:#e4e4e7;--text-dim:#9ca3af;--accent:#60a5fa;--green:#4ade80;--yellow:#fbbf24;--red:#f87171;--border:#2e303a;--font-mono:"Ubuntu Mono", ui-monospace, monospace;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:24px;line-height:1.4}*{box-sizing:border-box;margin:0;padding:0}body{width:100vw;height:100vh;margin:0;overflow:hidden}#root{width:100vw;height:100vh}
