:root{--bg: #0a0a0a;--surface: #161616;--surface-2: #232323;--text: #ffffff;--text-dim: #a0a0a0;--border: #2a2a2a;--accent: #fc650b;--accent-text: #0a0a0a;--low: #3ddc84;--med: #ffd43b;--high: #ff922b;--crit: #ff6b6b;--closed: #6b7280}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif;-webkit-font-smoothing:antialiased}.app{max-width:720px;margin:0 auto;padding:env(safe-area-inset-top) 0 env(safe-area-inset-bottom);min-height:100%;display:flex;flex-direction:column}.header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:.75rem;padding:.75rem 1rem .5rem}.logo{height:clamp(56px,14vw,90px);width:auto;max-width:100%;grid-column:2;justify-self:center}.refresh{grid-column:3;justify-self:end}.refresh{background:var(--surface);color:var(--text);border:1px solid var(--border);width:2.5rem;height:2.5rem;border-radius:999px;font-size:1.25rem;cursor:pointer}.refresh:disabled{opacity:.5}.refresh:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.controls{padding:.5rem 1.25rem .75rem;display:flex;flex-direction:column;gap:.5rem;position:sticky;top:0;background:var(--bg);z-index:1}.chips{display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none}.chips::-webkit-scrollbar{display:none}.chip{padding:.4rem .9rem;border-radius:999px;background:var(--surface);color:var(--text-dim);border:1px solid var(--border);font-size:.9rem;white-space:nowrap;cursor:pointer}.chip-active{background:var(--accent);color:var(--accent-text);border-color:var(--accent);font-weight:600}.search{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:.5rem;padding:.6rem .9rem;font-size:1rem;width:100%}.search::placeholder{color:var(--text-dim)}.location-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.location-cta,.location-active{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:999px;padding:.4rem .9rem;font-size:.85rem;cursor:pointer}.location-cta:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.location-cta:disabled{opacity:.6}.location-active{background:var(--accent);color:var(--accent-text);border-color:var(--accent);font-weight:600}.location-note{font-size:.75rem;color:var(--text-dim)}.card-head-right{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.distance{font-size:.75rem;font-weight:600;color:var(--accent);font-variant-numeric:tabular-nums}.favorite-btn{background:transparent;border:none;color:var(--text-dim);font-size:1.3rem;line-height:1;cursor:pointer;padding:.1rem .3rem;margin:-.1rem -.3rem;border-radius:.3rem}.favorite-btn:hover,.favorite-btn-on{color:var(--accent)}.favorite-btn:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.list{list-style:none;margin:0;padding:0 1.25rem 1rem;flex:1}.card{background:var(--surface);border:1px solid var(--border);border-radius:.75rem;padding:.9rem 1rem;margin-bottom:.6rem;display:flex;flex-direction:column;gap:.5rem;cursor:pointer;transition:border-color .15s}.card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.card-expanded{border-color:var(--accent)}.card-closed{opacity:.55}.card-awaiting{opacity:.85}.graph-pane{display:flex;flex-direction:column;gap:.6rem;cursor:default}.expanded-tabs{margin-top:.5rem;border-top:1px solid var(--border);padding-top:.5rem;cursor:default}.tab-bar{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:.75rem}.tab{flex:1;background:transparent;border:none;color:var(--text-dim);padding:.55rem .5rem;cursor:pointer;border-bottom:2px solid transparent;font-size:.85rem;font-family:inherit}.tab:hover{color:var(--text)}.tab-active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.cameras-pane{display:flex;flex-direction:column;gap:.5rem;cursor:default}.camera-image-wrap{width:100%;border-radius:.4rem;overflow:hidden;background:var(--surface-2);aspect-ratio:4 / 3}.camera-image{width:100%;height:100%;display:block;object-fit:cover}.camera-controls{display:flex;align-items:center;gap:.5rem}.camera-nav{background:var(--surface-2);border:1px solid var(--border);color:var(--text);width:2rem;height:2rem;border-radius:999px;cursor:pointer;font-size:1.1rem;line-height:1;padding:0}.camera-nav:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.camera-nav:disabled{opacity:.3;cursor:not-allowed}.camera-label{flex:1;text-align:center;font-size:.8rem;color:var(--text-dim);line-height:1.3}.camera-label strong{display:block;color:var(--text);font-weight:600}.camera-meta{font-size:.7rem}.graph-presets{display:flex;gap:.4rem;flex-wrap:wrap}.chip-sm{padding:.3rem .7rem;border-radius:999px;background:var(--surface-2);color:var(--text-dim);border:1px solid var(--border);font-size:.8rem;cursor:pointer}.chip-sm.chip-active{background:var(--accent);color:var(--accent-text);border-color:var(--accent);font-weight:600}.graph-custom{display:flex;gap:.6rem;flex-wrap:wrap}.graph-custom label{display:flex;flex-direction:column;font-size:.75rem;color:var(--text-dim);gap:.2rem;flex:1;min-width:9rem}.graph-custom input{background:var(--surface-2);color:var(--text);border:1px solid var(--border);border-radius:.4rem;padding:.35rem .5rem;font-size:.85rem;font-family:inherit;color-scheme:dark}.graph-status{color:var(--text-dim);font-size:.85rem;padding:.75rem .25rem;text-align:center}.graph-error{color:var(--crit)}.graph-chart{display:flex;flex-direction:column;gap:.4rem}.graph-legend{display:flex;gap:.8rem;flex-wrap:wrap;font-size:.75rem;color:var(--text-dim);padding:0 .25rem}.graph-legend-item{display:inline-flex;align-items:center;gap:.35rem}.graph-legend-swatch{display:inline-block;width:.7rem;height:.7rem;border-radius:.15rem}.card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.port{font-weight:600;font-size:1.05rem;line-height:1.2}.crossing{color:var(--text-dim);font-size:.85rem;margin-top:.15rem}.tag{font-size:.75rem;padding:.2rem .55rem;border-radius:999px;background:var(--surface-2);color:var(--text-dim);white-space:nowrap}.lanes{display:flex;flex-direction:column;gap:.25rem}.lane{display:grid;grid-template-columns:1fr auto auto;gap:.75rem;align-items:baseline;padding:.15rem 0}.lane-label{color:var(--text-dim);font-size:.85rem}.lane-wait{display:flex;align-items:baseline;gap:.2rem;font-variant-numeric:tabular-nums}.lane-min{font-size:1.25rem;font-weight:700;letter-spacing:-.01em}.lane-unit{font-size:.75rem;color:var(--text-dim)}.lane-meta{color:var(--text-dim);font-size:.8rem;min-width:4.5rem;text-align:right}.lane-low .lane-min{color:var(--low)}.lane-med .lane-min{color:var(--med)}.lane-high .lane-min{color:var(--high)}.lane-crit .lane-min{color:var(--crit)}.lane-empty .lane-empty-text{color:var(--closed);font-size:1rem;grid-column:2 / span 2;text-align:right}.update-time{color:var(--text-dim);font-size:.75rem;text-align:right;border-top:1px solid var(--border);padding-top:.4rem;margin-top:.2rem}.closed-line,.awaiting-line{color:var(--closed);font-weight:500;display:flex;gap:.5rem;align-items:baseline}.hours{font-size:.8rem;color:var(--text-dim);font-weight:400}.empty{color:var(--text-dim);text-align:center;padding:2rem 1rem;list-style:none}.error{margin:0 1.25rem .75rem;padding:.75rem 1rem;background:#ff6b6b26;border:1px solid var(--crit);border-radius:.5rem;color:var(--crit)}.footer{display:flex;justify-content:space-between;padding:.75rem 1.25rem 1rem;color:var(--text-dim);font-size:.8rem;border-top:1px solid var(--border)}@media(min-width:600px){.list{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem;padding-bottom:1.25rem}.card{margin-bottom:0}}
