:root{--c-bg:#0a004f;--c-bg-2:#150a63;--c-card:#1c1147;--c-text:#f4f4ff;--c-muted:#a9a6cf;--c-accent:#00e0a8;--c-delay:#ffb020;--c-cancel:#ff5a5a;--c-ok:#00c389;--radius:14px;--gap:12px;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}body{background:linear-gradient(180deg, var(--c-bg), var(--c-bg-2));color:var(--c-text);min-height:100vh;margin:0}.app{max-width:640px;padding:max(16px, env(safe-area-inset-top)) 16px 32px;margin:0 auto}.app__header{align-items:center;gap:10px;margin-bottom:16px;display:flex}.app__logo-btn{cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:0;border-radius:9px;flex:none;padding:0;line-height:0;transition:transform .12s,filter .12s}.app__logo-btn:active{filter:brightness(1.1);transform:scale(.92)}.app__logo-btn:focus-visible{outline:2px solid var(--c-accent);outline-offset:2px}.app__logo{border-radius:9px;flex:none;display:block;box-shadow:0 2px 8px #00000059}.env-badge{letter-spacing:.08em;border-radius:6px;align-self:center;margin-left:auto;padding:3px 8px;font-size:.72rem;font-weight:800}.env-badge--dev{background:var(--c-delay);color:#2a1a00}.env-badge--local{color:#fff;background:#6b7280}[data-env=dev] body:before,[data-env=local] body:before{content:"";z-index:10;background:repeating-linear-gradient(45deg, var(--c-delay), var(--c-delay) 10px, #2a1a00 10px, #2a1a00 20px);height:4px;position:fixed;inset:0 0 auto}.app__title{margin:0;font-size:1.5rem}.app__subtitle{color:var(--c-muted);font-size:.85rem}.station-picker{flex-direction:column;gap:4px;display:flex}.station-picker__label{color:var(--c-muted);font-size:.8rem}.station-picker select{appearance:none;background:var(--c-card);color:var(--c-text);border-radius:var(--radius);border:1px solid #33308f;width:100%;padding:12px;font-size:1rem}.controls{align-items:center;gap:8px;margin:14px 0;display:flex}.controls .routebar{flex:1;min-width:0;margin:0}.controls__icon{border-radius:var(--radius);background:var(--c-card);width:40px;height:40px;color:var(--c-text);cursor:pointer;border:1px solid #33308f;flex:none;justify-content:center;align-items:center;font-size:1.15rem;transition:border-color .15s;display:flex}.controls__icon.is-active{border-color:var(--c-accent);box-shadow:inset 0 0 0 1px var(--c-accent)}.controls__icon:disabled{opacity:.5;cursor:default}.controls__msg{color:var(--c-delay);margin:-6px 0 8px;font-size:.8rem}.routebar{grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;margin:14px 0;display:grid}.routebar .station-picker{min-width:0}.routebar__station{text-align:left;background:var(--c-card);border-radius:var(--radius);cursor:pointer;min-width:0;color:var(--c-text);border:1px solid #33308f;padding:9px 12px;font-size:.95rem;font-weight:600}.routebar__station:active{filter:brightness(1.1)}.routebar__name{white-space:nowrap;text-overflow:ellipsis;display:block;overflow:hidden}.routebar__swap{border-radius:var(--radius);background:var(--c-card);width:38px;height:38px;color:var(--c-accent);cursor:pointer;border:1px solid #33308f;justify-content:center;align-self:center;align-items:center;font-size:1.05rem;transition:transform .15s;display:flex}.routebar__swap:hover:not(:disabled){transform:rotate(180deg)}.routebar__swap:disabled{opacity:.4;cursor:default}.traffic{flex-direction:column;gap:8px;display:flex}.traffic__bar{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.traffic-status{border-radius:var(--radius);flex:auto;padding:10px 12px;font-size:.9rem;font-weight:600}.traffic-status--ok{color:var(--c-ok);background:#00c3891f}.traffic-status--muted{background:var(--c-card);color:var(--c-muted)}.traffic-status--alert{color:#ffb3b3;background:#ff5a5a1f;border:1px solid #ff5a5a66}.traffic-status--btn{text-align:left;cursor:pointer;font:inherit;justify-content:space-between;align-items:center;gap:8px;font-weight:600;display:flex}.traffic__chevron{opacity:.8;flex:none;font-size:.8rem}.traffic__toggle{background:var(--c-card);color:var(--c-muted);cursor:pointer;border:1px solid #33308f;border-radius:999px;flex:none;padding:8px 12px;font-size:.85rem;font-weight:700}.traffic__x{color:var(--c-accent);align-self:flex-start;padding:2px 0;font-size:.82rem;text-decoration:none}.traffic__x:hover{text-decoration:underline}.disruption{background:var(--c-card);border-radius:var(--radius);border-left:4px solid var(--c-delay);padding:10px 12px}.disruption--upcoming{border-left-color:#4a5bd0}.disruption__title{margin:0 0 4px;font-size:.9rem}.disruption__summary{color:var(--c-muted);cursor:pointer;margin:0;font-size:.85rem}.disruption__summary.is-clamped{-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.disruption__link{color:var(--c-accent);margin-top:6px;font-size:.82rem;display:inline-block}.board__header h2{margin:16px 0 4px;font-size:1.05rem}.board__filter{color:var(--c-muted);margin:0 0 8px;font-size:.85rem}.board--loading,.board--empty,.board--error,.app__hint{background:var(--c-card);border-radius:var(--radius);color:var(--c-muted);text-align:center;padding:18px}.board--error{color:var(--c-cancel)}.board__list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.departure{background:var(--c-card);border-radius:var(--radius);border-left:4px solid #0000;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:12px 14px;display:grid}.departure--delayed{border-left-color:var(--c-delay)}.departure--cancelled{border-left-color:var(--c-cancel);opacity:.75}.departure--on_time{border-left-color:var(--c-ok)}.departure__time{flex-direction:column;align-items:flex-start;display:flex}.departure__hour{font-variant-numeric:tabular-nums;font-size:1.3rem;font-weight:600}.departure__delay{color:var(--c-delay);font-size:.78rem;font-weight:600}.departure__main{flex-direction:column;gap:2px;min-width:0;display:flex}.departure__dest{white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.departure__mission{color:var(--c-muted);letter-spacing:.08em;font-size:.72rem}.departure__status{font-size:.78rem}.departure__status--delayed{color:var(--c-delay)}.departure__status--cancelled{color:var(--c-cancel);font-weight:600}.departure__status--on_time{color:var(--c-ok)}.departure__meta{text-align:right;flex-direction:column;gap:2px;display:flex}.departure__platform{font-weight:600}.departure__countdown{color:var(--c-accent);font-size:.8rem}.timectl{flex-wrap:wrap;align-items:center;gap:8px;margin:4px 0 12px;display:flex}.timectl__modes{background:var(--c-card);border-radius:999px;padding:3px;display:inline-flex}.timectl__mode{color:var(--c-muted);cursor:pointer;background:0 0;border:0;border-radius:999px;padding:7px 14px;font-size:.85rem}.timectl__mode.is-active{background:var(--c-accent);color:#07203a;font-weight:700}.timectl__input{background:var(--c-card);color:var(--c-text);border-radius:var(--radius);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;border:1px solid #33308f;padding:9px 12px;font-size:.9rem}.timectl__now{color:var(--c-accent);cursor:pointer;background:0 0;border:1px solid #33308f;border-radius:999px;padding:7px 14px;font-size:.85rem}.journey{background:var(--c-card);border-radius:var(--radius);border-left:4px solid var(--c-ok);flex-direction:column;gap:6px;padding:12px 14px;list-style:none;display:flex}.journey--delayed{border-left-color:var(--c-delay)}.journey--cancelled{border-left-color:var(--c-cancel);opacity:.75}.journey__times{align-items:baseline;gap:8px;display:flex}.journey__dep,.journey__arr{font-variant-numeric:tabular-nums;font-size:1.3rem;font-weight:700}.journey__arrow{color:var(--c-muted)}.journey__delay{color:var(--c-delay);margin-left:auto;font-size:.78rem;font-weight:600}.journey__info{align-items:center;gap:10px;font-size:.85rem;display:flex}.journey__duration{color:var(--c-text);font-weight:600}.journey__transfers{color:var(--c-ok)}.journey__transfers--change{color:var(--c-delay)}.journey__train{color:var(--c-muted);flex-wrap:wrap;align-items:center;gap:8px;font-size:.78rem;display:flex}.journey__line{background:var(--c-accent);color:#07203a;border-radius:6px;padding:1px 6px;font-weight:700}.journey__mission{letter-spacing:.08em}.journey__platform{color:var(--c-text);font-weight:600}.app__footer{color:var(--c-muted);text-align:center;margin-top:28px;font-size:.72rem}.notify{background:var(--c-card);border-radius:var(--radius);margin-top:var(--gap);flex-direction:column;gap:12px;padding:14px;display:flex}.notify__title{margin:0;font-size:.95rem}.notify__switch{align-items:center;gap:10px;font-weight:600;display:flex}.notify__switch input{width:20px;height:20px;accent-color:var(--c-accent)}.notify__group{border-radius:var(--radius);border:1px solid #ffffff14;margin:0;padding:10px 12px}.notify__group legend{color:var(--c-muted);padding:0 6px;font-size:.78rem}.notify__group:disabled{opacity:.5}.notify__days{flex-wrap:wrap;gap:6px;display:flex}.notify__day{min-width:42px;color:var(--c-text);cursor:pointer;background:0 0;border:1px solid #ffffff24;border-radius:10px;flex:auto;padding:8px 4px;font-size:.82rem}.notify__day.is-on{border-color:var(--c-accent);color:var(--c-accent);background:#00e0a824;font-weight:600}.notify__window{align-items:center;gap:8px;margin-top:8px;display:flex}.notify__window input[type=time]{background:var(--c-bg-2);color:var(--c-text);border:1px solid #ffffff24;border-radius:10px;flex:auto;padding:8px}.notify__remove{color:var(--c-cancel);cursor:pointer;background:0 0;border:none;padding:6px;font-size:1rem}.notify__add{color:var(--c-text);cursor:pointer;background:0 0;border:1px dashed #fff3;border-radius:10px;margin-top:10px;padding:8px 12px;font-size:.85rem}.notify__hint{color:var(--c-muted);margin:0;font-size:.78rem}.notify__msg{color:var(--c-accent);margin:0;font-size:.82rem}.app__notify{border-radius:var(--radius);background:var(--c-card);width:38px;height:38px;color:var(--c-text);cursor:pointer;border:1px solid #ffffff24;justify-content:center;align-items:center;margin-left:auto;font-size:1.15rem;line-height:1;display:inline-flex}.env-badge+.app__notify{margin-left:8px}.app__notify.is-active{border-color:var(--c-accent);box-shadow:inset 0 0 0 1px var(--c-accent)}.app__notify:focus-visible{outline:2px solid var(--c-accent)}.notify__top{align-items:center;gap:10px;display:flex}.notify__test{border:1px solid var(--c-accent);color:var(--c-accent);cursor:pointer;background:0 0;border-radius:10px;margin-left:auto;padding:7px 14px;font-size:.82rem;font-weight:600}.notify__test:disabled{color:var(--c-muted);cursor:not-allowed;border-color:#ffffff24}.notify__test:active:not(:disabled){transform:scale(.97)}.app__account{border-radius:var(--radius);background:var(--c-card);width:38px;height:38px;color:var(--c-text);cursor:pointer;border:1px solid #ffffff24;justify-content:center;align-items:center;font-size:1.15rem;line-height:1;display:inline-flex}.app__account.is-active{border-color:var(--c-accent);box-shadow:inset 0 0 0 1px var(--c-accent)}.app__account:focus-visible{outline:2px solid var(--c-accent)}.app--loading{min-height:50vh}.login{justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.login__card{background:var(--c-card);border-radius:var(--radius);border:1px solid #ffffff1a;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:340px;padding:28px 24px;display:flex}.login__logo{border-radius:12px}.login__title{margin:0;font-size:1.25rem}.login__hint{color:var(--c-muted);margin:0;font-size:.9rem}.login__input{letter-spacing:.12em;text-align:center;text-transform:uppercase;width:100%;color:var(--c-text);background:var(--c-bg);border:1px solid #ffffff29;border-radius:10px;padding:12px 14px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:1.1rem}.login__input:focus-visible{outline:2px solid var(--c-accent)}.login__btn{color:#fff;background:var(--c-accent);cursor:pointer;border:0;border-radius:10px;width:100%;padding:12px;font-size:.95rem;font-weight:600}.login__btn:disabled{opacity:.5;cursor:not-allowed}.login__error{color:var(--c-danger,#ff6b6b);text-align:center;margin:0;font-size:.85rem}.admin{background:var(--c-card);border-radius:var(--radius);border:1px solid #ffffff1a;margin-bottom:16px;padding:16px}.admin__title{margin:0 0 12px;font-size:1rem}.admin__actions{flex-wrap:wrap;gap:10px;display:flex}.admin__regen,.admin__logout,.admin__cancel,.admin__copy,.admin__done{cursor:pointer;border-radius:10px;padding:9px 14px;font-size:.85rem;font-weight:600}.admin__regen{color:var(--c-accent);border:1px solid var(--c-accent);background:0 0}.admin__logout,.admin__cancel{color:var(--c-muted);background:0 0;border:1px solid #ffffff29}.admin__warn{color:var(--c-muted);margin:0 0 10px;font-size:.85rem}.admin__coderow{align-items:center;gap:10px;margin-bottom:12px;display:flex}.admin__code{letter-spacing:.1em;text-align:center;color:var(--c-text);background:var(--c-bg);border:1px dashed var(--c-accent);border-radius:8px;flex:1;padding:10px 12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:1.1rem}.admin__copy{color:var(--c-accent);border:1px solid var(--c-accent);white-space:nowrap;background:0 0}.admin__done{color:#fff;background:var(--c-accent);border:0}.admin__error{color:var(--c-danger,#ff6b6b);margin:10px 0 0;font-size:.85rem}
