:root{--bg:#f1f5f9;--surface:#fff;--border:#e2e8f0;--text:#1e293b;--muted:#64748b;--nav-bg:#1e293b;--nav-link:#fffc;--warning-bg:#fef3c7;--warning-border:#d97706;--warning-text:#92400e;--green:#16a34a;--yellow:#ca8a04;--orange:#ea580c;--red:#dc2626;--gray:#64748b;--tram:#005ea5;--bus:#e07b00;--train:#7c3aed;--ferry:#0891b2;color:var(--text);background:var(--bg);font:15px/1.6 system-ui,-apple-system,sans-serif}[data-theme=dark]{--bg:#0f1117;--surface:#1a1f2e;--border:#2d3348;--text:#e2e8f0;--muted:#8b95a8;--nav-bg:#111827;--warning-bg:#422006;--warning-border:#92400e;--warning-text:#fde68a}*{box-sizing:border-box;margin:0;padding:0}.page{flex-direction:column;min-height:100vh;display:flex}.main{flex-direction:column;flex:1;gap:1rem;width:100%;max-width:680px;margin:0 auto;padding:1.5rem 1rem;display:flex}.nav{background:var(--nav-bg);color:#fff;justify-content:space-between;align-items:center;height:52px;padding:0 1.5rem;display:flex}.nav-brand{letter-spacing:.01em;margin:0;font-size:1.25rem;font-weight:700}.nav a{color:inherit;text-decoration:none}.nav-links{gap:1.25rem;font-size:.875rem;display:flex}.nav-links a{color:var(--nav-link);text-decoration:none}.nav-links a:hover{color:#fff}.nav-active{color:#fff;font-weight:600}.theme-toggle{color:#fff;cursor:pointer;background:0 0;border:none;align-items:center;padding:.25rem;transition:color .2s;display:flex}.theme-toggle svg{width:20px;height:20px}.theme-toggle[data-mode=dark]:hover{color:#fbbf24}.theme-toggle[data-mode=light]:hover{color:#818cf8}.card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1.25rem 1.5rem}.card h2{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:1rem;font-size:.9rem;font-weight:700}.selectors{flex-wrap:wrap;gap:1rem;display:flex}.selectors label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;flex-direction:column;gap:.25rem;font-size:.8rem;font-weight:600;display:flex}.selectors select{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;border-radius:6px;padding:.4rem .6rem;font-size:.95rem}.reliability-header{justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;display:flex}.score{font-size:2rem;font-weight:800;line-height:1}.score-track{background:var(--border);border-radius:4px;height:8px;overflow:hidden}.score-fill{border-radius:4px;height:100%;transition:width .4s}.warning{background:var(--warning-bg);border:1px solid var(--warning-border);color:var(--warning-text);border-radius:6px;margin-top:.875rem;padding:.6rem .875rem;font-size:.875rem}.rec{align-items:flex-start;gap:.875rem;display:flex}.rec-icon{margin-top:.1rem;font-size:1.5rem;line-height:1}.rec p{color:var(--muted);margin-top:.25rem;font-size:.925rem}.dep-table{border-collapse:collapse;width:100%;font-size:.9rem}.dep-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);border-bottom:1px solid var(--border);padding:0 .5rem .5rem;font-size:.75rem;font-weight:700}.dep-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:.6rem .5rem}.dep-table tr:last-child td{border-bottom:none}.row-canceled{opacity:.5}.text-canceled{text-decoration:line-through}.line-badge{color:#fff;text-align:center;border-radius:4px;min-width:2rem;padding:.2rem .5rem;font-size:.8rem;font-weight:700;text-decoration:none;display:inline-block}.muted{color:var(--muted)}.heatmap-grid{grid-template-columns:3rem repeat(5,1fr);gap:3px;display:grid}.hm-day{text-align:center;color:var(--muted);padding-bottom:.25rem;font-size:.75rem;font-weight:700}.hm-hour{color:var(--muted);align-items:center;font-size:.7rem;display:flex}.hm-cell{border-radius:3px;height:26px}.heatmap-legend{align-items:center;gap:.5rem;margin-top:.75rem;font-size:.75rem;display:flex}.legend-green{color:#1f931f}.legend-red{color:#b12525}[data-theme=dark] .legend-green{color:#42d742}[data-theme=dark] .legend-red{color:#e06c6c}.legend-bar{background:linear-gradient(90deg,#25b125,#b1b125,#b12525);border-radius:4px;flex:1;height:8px}.worst-list{flex-direction:column;gap:.5rem;list-style:none;display:flex}.worst-list li{border-bottom:1px solid var(--border);justify-content:space-between;padding:.4rem 0;font-size:.9rem;display:flex}.worst-list li:last-child{border-bottom:none}.worst-time{color:var(--text)}.footer{text-align:center;color:var(--muted);border-top:1px solid var(--border);padding:1rem;font-size:.75rem}@media (width>=768px){.nav-brand{font-size:1.5rem}.nav-links{font-size:1rem}}
