:root{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-tertiary: #f9fafb;--bg-hover: #f3f4f6;--bg-hover-accent: #f0f7ff;--text-primary: #1a1a1a;--text-secondary: #374151;--text-tertiary: #6b7280;--text-muted: #9ca3af;--text-heading: #1e293b;--border-light: #f3f4f6;--border-default: #e5e7eb;--border-input: #d1d5db;--bg-status-realtime: #dcfce7;--text-status-realtime: #166534;--bg-status-scheduled: #f3f4f6;--text-status-scheduled: #6b7280;--shadow-panel: -4px 0 16px rgba(0,0,0,.1);--shadow-card: 0 2px 8px rgba(0,0,0,.15);--shadow-dropdown: 0 4px 12px rgba(0,0,0,.15)}[data-theme=dark]{--bg-primary: #1e293b;--bg-secondary: #0f172a;--bg-tertiary: #1e293b;--bg-hover: #334155;--bg-hover-accent: #1e3a5f;--text-primary: #f1f5f9;--text-secondary: #e2e8f0;--text-tertiary: #94a3b8;--text-muted: #64748b;--text-heading: #f1f5f9;--border-light: #334155;--border-default: #475569;--border-input: #475569;--bg-status-realtime: #064e3b;--text-status-realtime: #6ee7b7;--bg-status-scheduled: #334155;--text-status-scheduled: #94a3b8;--shadow-panel: -4px 0 16px rgba(0,0,0,.4);--shadow-card: 0 2px 8px rgba(0,0,0,.4);--shadow-dropdown: 0 4px 12px rgba(0,0,0,.5)}:root{--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:var(--bg-secondary);color:var(--text-primary);-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{display:flex;align-items:center;gap:12px;padding:10px 20px;background:#1e293b;color:#fff;z-index:1000}.app-header h1{font-size:18px;font-weight:700}.live-badge{background:#ef4444;color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:4px;letter-spacing:.5px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.vehicle-count{font-size:13px;color:#94a3b8}.header-nav{display:flex;align-items:center;gap:2px;margin-left:4px;padding:2px;background:#ffffff0f;border-radius:6px}.header-nav-link{font-size:12px;font-weight:600;color:#94a3b8;text-decoration:none;padding:4px 10px;border-radius:4px;transition:all .15s}.header-nav-link:hover{color:#e2e8f0;background:#ffffff14}.header-tools{display:flex;align-items:center;gap:2px}.header-icon-btn{width:30px;height:30px;border-radius:6px;border:none;background:none;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.header-icon-btn:hover{color:#e2e8f0;background:#ffffff1a}.header-icon-btn.active{color:#60a5fa}.header-auth{margin-left:auto;display:flex;align-items:center;gap:10px}.header-auth-btn{padding:5px 14px;font-size:12px;font-weight:600;border:1px solid #475569;border-radius:6px;background:transparent;color:#e2e8f0;cursor:pointer}.header-auth-btn:hover{background:#334155}.app-body{position:relative;flex:1;display:flex;overflow:hidden}.bus-map{flex:1;height:100%;z-index:1}.bus-marker,.stop-marker,.stop-marker-selected{background:transparent!important;border:none!important;will-change:transform}.bus-following{animation:busGlowPulse 1.5s ease-in-out infinite}@keyframes busGlowPulse{0%,to{filter:drop-shadow(0 0 6px #facc15) drop-shadow(0 0 12px #facc15)}50%{filter:drop-shadow(0 0 12px #facc15) drop-shadow(0 0 24px #facc15) drop-shadow(0 0 36px rgba(250,204,21,.4))}}.info-btn{width:24px;height:24px;border-radius:50%;border:1.5px solid #64748b;background:transparent;color:#94a3b8;font-size:13px;font-weight:700;font-style:italic;font-family:Georgia,serif;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.info-btn:hover{border-color:#e2e8f0;color:#e2e8f0}.changelog-link{font-size:11px;font-weight:600;color:#64748b;text-decoration:none;padding:2px 6px;border:1px solid #475569;border-radius:4px;font-family:monospace}.changelog-link:hover{color:#e2e8f0;border-color:#e2e8f0}.nearby-btn{display:flex;align-items:center;gap:4px;background:transparent;border:1px solid #475569;border-radius:4px;color:#94a3b8;font-size:12px;font-weight:600;padding:2px 8px;cursor:pointer;white-space:nowrap}.nearby-btn:hover{color:#e2e8f0;border-color:#e2e8f0}.nearby-btn svg{flex-shrink:0}.nearby-error{color:#ef4444;padding:8px 16px;font-size:13px}.nearby-empty{color:var(--text-secondary, #94a3b8);padding:24px 16px;text-align:center;font-size:14px}.nearby-list{display:flex;flex-direction:column}.nearby-bus-row{display:flex;align-items:center;gap:12px;padding:10px 16px;border:none;background:transparent;cursor:pointer;text-align:left;width:100%;border-bottom:1px solid var(--border-color, #1e293b);color:var(--text-primary, #e2e8f0);transition:background .15s}.nearby-bus-row:hover{background:var(--hover-bg, rgba(255,255,255,.05))}.nearby-line-badge{color:#fff;font-weight:700;font-size:14px;padding:4px 10px;border-radius:4px;min-width:36px;text-align:center;flex-shrink:0}.nearby-bus-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.nearby-dest{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nearby-operator{font-size:12px;color:var(--text-secondary, #94a3b8)}.nearby-bus-meta{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0;gap:2px}.nearby-distance{font-size:14px;font-weight:700;color:var(--text-primary, #e2e8f0)}.nearby-eta{font-size:12px;color:#22c55e;font-weight:600}.disclaimer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:9000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.disclaimer-modal{background:var(--bg-primary);border-radius:12px;padding:24px;width:480px;max-width:calc(100vw - 32px);max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.disclaimer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.disclaimer-header h2{font-size:18px;font-weight:700;margin:0}.disclaimer-body p{font-size:13px;color:var(--text-secondary);line-height:1.5;margin:0 0 10px}.disclaimer-body p strong{color:var(--text-heading);font-size:13px}.search-bar{position:absolute;top:12px;left:55px;z-index:1000;width:340px;max-width:calc(100vw - 70px);transition:left .2s ease}@media (min-width: 769px){.sidebar-expanded .search-bar{left:308px}}.search-category-header{display:flex;align-items:center;gap:6px;padding:6px 14px!important;font-size:11px!important;font-weight:700!important;text-transform:uppercase;letter-spacing:.6px;color:var(--text-tertiary)!important;background:var(--bg-tertiary)!important;cursor:default!important;border-bottom:1px solid var(--border-default)!important}.search-category-header:hover{background:var(--bg-tertiary)!important}.search-cat-count{margin-left:auto;background:var(--bg-secondary);padding:1px 6px;border-radius:10px;font-size:10px;font-weight:600}.search-input-row{display:flex;gap:6px}.search-bar input[type=text]{flex:1;padding:10px 14px;font-size:14px;border:none;border-radius:10px;background:var(--bg-primary);color:var(--text-primary);box-shadow:var(--shadow-card);outline:none}.search-bar input[type=text]:focus{box-shadow:0 2px 8px #00000026,0 0 0 2px #2563eb}.locate-btn{padding:10px 14px;font-size:13px;font-weight:600;border:none;border-radius:10px;background:#2563eb;color:#fff;cursor:pointer;box-shadow:0 2px 8px #00000026;white-space:nowrap}.locate-btn:hover{background:#1d4ed8}.search-dropdown{margin-top:4px;background:var(--bg-primary);border-radius:10px;box-shadow:var(--shadow-dropdown);overflow:hidden;display:flex;flex-direction:column;max-height:60vh}.search-filter-chips{display:flex;gap:4px;padding:8px 10px 4px;flex-wrap:wrap;flex-shrink:0;border-bottom:1px solid var(--border-primary)}.search-chip{display:flex;align-items:center;gap:4px;padding:3px 10px;font-size:12px;font-weight:500;border:1px solid var(--border-primary);border-radius:20px;background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all .15s}.search-chip:hover{background:var(--bg-hover-accent)}.search-chip.active{background:#2563eb;color:#fff;border-color:#2563eb}.chip-count{font-size:10px;background:#0000001f;padding:0 5px;border-radius:10px;line-height:16px}.search-chip.active .chip-count{background:#ffffff40}.search-results{list-style:none;overflow-y:auto;flex:1}.search-result-item{display:flex;align-items:center;gap:10px;padding:9px 14px;cursor:pointer;font-size:13px;border-bottom:1px solid var(--border-light);transition:background .1s}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--bg-hover-accent)}.search-result-icon{flex-shrink:0;opacity:.7}.search-result-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.result-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-subtitle{font-size:11px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-badge{flex-shrink:0;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;background:#2563eb1a;color:#2563eb}.result-badge-muted{flex-shrink:0;font-size:11px;color:#9ca3af}.search-operator-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.search-no-results{margin-top:4px;padding:10px 14px;background:var(--bg-primary);border-radius:10px;box-shadow:var(--shadow-dropdown);font-size:13px;color:var(--text-tertiary)}.side-panel{position:absolute;top:0;right:0;width:380px;max-width:100vw;height:100%;background:var(--bg-primary);box-shadow:var(--shadow-panel);z-index:1001;overflow-y:auto;padding:20px;animation:slideIn .2s ease-out}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.panel-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.panel-header h2{font-size:18px;font-weight:700}.panel-subtitle{font-size:13px;color:var(--text-tertiary);font-weight:400;margin-top:2px}.close-btn{padding:6px 12px;font-size:12px;font-weight:600;border:1px solid var(--border-input);border-radius:6px;background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;flex-shrink:0}.close-btn:hover{background:var(--bg-hover)}.share-btn{padding:6px 12px;font-size:12px;font-weight:600;border:1px solid var(--border-input);border-radius:6px;background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;flex-shrink:0}.share-btn:hover{background:var(--bg-hover)}.share-btn.share-copied{background:#16a34a;color:#fff;border-color:#16a34a}.follow-btn{padding:6px 12px;font-size:12px;font-weight:600;border:1px solid #2563eb;border-radius:6px;background:transparent;color:#2563eb;cursor:pointer;flex-shrink:0}.follow-btn:hover{background:#eff6ff}.follow-btn.following{background:#2563eb;color:#fff;border-color:#2563eb}.follow-btn.following:hover{background:#1d4ed8}.left-sidebar{position:absolute;top:0;left:0;height:100%;width:300px;background:var(--bg-primary);box-shadow:4px 0 16px #00000014;z-index:1001;display:flex;flex-direction:column;transition:width .2s ease;overflow:hidden}.left-sidebar.collapsed{width:48px}.left-sidebar-toggle{width:100%;height:40px;display:flex;align-items:center;justify-content:center;border:none;background:none;color:var(--text-tertiary);cursor:pointer;border-bottom:1px solid var(--border-light);flex-shrink:0}.left-sidebar-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.left-sidebar-collapsed-icons{display:flex;flex-direction:column;align-items:center;gap:4px;padding-top:6px}a.left-sidebar-icon-btn{text-decoration:none}.left-sidebar-icon-btn{width:36px;height:36px;border-radius:8px;border:none;background:none;color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;position:relative}.left-sidebar-icon-btn:hover,.left-sidebar-icon-btn.active{background:var(--bg-hover);color:var(--text-primary)}.left-sidebar-icon-btn.has-alert{color:#f59e0b}.icon-badge{position:absolute;top:2px;right:2px;min-width:14px;height:14px;padding:0 3px;font-size:9px;font-weight:700;background:#ef4444;color:#fff;border-radius:7px;display:flex;align-items:center;justify-content:center}.left-sidebar-panels{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px;padding:6px}.sidebar-mobile-nav{display:none}.sidebar-filters-body{padding:0!important}.sidebar-filter-section{padding:10px 12px;border-bottom:1px solid var(--border-light)}.sidebar-filter-section:last-child{border-bottom:none}.sidebar-filter-heading{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:8px}.sidebar-op-list{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.sidebar-op-row{display:flex;align-items:center;gap:6px;padding:4px 6px;border-radius:4px;cursor:pointer;font-size:12px;color:var(--text-secondary);transition:background .1s}.sidebar-op-row:hover{background:var(--bg-hover)}.sidebar-op-row input[type=checkbox]{accent-color:#0d9488;width:14px;height:14px;cursor:pointer;flex-shrink:0}.sidebar-op-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-op-count{font-size:10px;font-weight:600;color:var(--text-muted);background:var(--bg-hover);padding:1px 6px;border-radius:8px;flex-shrink:0}.sidebar-type-pills{display:flex;flex-wrap:wrap;gap:6px}.sidebar-type-pill{padding:4px 10px;font-size:11px;font-weight:600;border-radius:12px;border:1px solid var(--border-default);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;transition:all .15s}.sidebar-type-pill:hover{border-color:#0d9488;color:#0d9488}.sidebar-type-pill.active{background:#0d9488;color:#fff;border-color:#0d9488}.sidebar-toggle-list{display:flex;flex-direction:column;gap:4px}.sidebar-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:4px 6px;border-radius:4px;cursor:pointer;font-size:12px;color:var(--text-secondary);transition:background .1s}.sidebar-toggle-row:hover{background:var(--bg-hover)}.sidebar-toggle-switch{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:32px;height:18px;background:var(--border-default);border-radius:9px;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}.sidebar-toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:transform .2s}.sidebar-toggle-switch:checked{background:#0d9488}.sidebar-toggle-switch:checked:after{transform:translate(14px)}.sidebar-panel-card{background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-default);flex-shrink:0}.sidebar-panel-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;border:none;background:none;cursor:pointer;color:var(--text-primary);font-size:13px;font-weight:600;transition:background .15s}.sidebar-panel-header:hover{background:var(--bg-hover)}.sidebar-panel-title{display:flex;align-items:center;gap:8px}.sidebar-live-badge{font-size:9px;font-weight:700;padding:1px 5px;border-radius:3px;background:#22c55e;color:#fff;letter-spacing:.5px}.sidebar-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;background:#ef4444;color:#fff;border-radius:8px}.sidebar-panel-body{padding:2px 10px 10px;max-height:400px;overflow-y:auto}.sidebar-filters-body.sidebar-panel-body{max-height:none;overflow-y:visible}.sidebar-subsection-header{display:flex;justify-content:space-between;align-items:center;margin:12px 0 6px;padding-top:8px;border-top:1px solid var(--border-default);font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.sidebar-view-count{display:flex;align-items:center;gap:3px;font-size:11px;color:var(--text-muted);font-weight:600}.sidebar-fav-tabs{display:flex;gap:2px;margin-bottom:8px;border-bottom:1px solid var(--border-default)}.sidebar-fav-tabs button{flex:1;padding:6px 2px;font-size:11px;font-weight:600;border:none;background:none;color:var(--text-tertiary);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}.sidebar-fav-tabs button.active{color:#2563eb;border-bottom-color:#2563eb}.sidebar-fav-tabs button:hover:not(.active){background:var(--bg-hover)}.sidebar-fav-content{min-height:40px}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;background:#ef4444;color:#fff;border-radius:8px;margin-left:4px}.sidebar-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:13px;font-weight:600;color:var(--text-secondary)}.sidebar-refresh-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;border-radius:4px}.sidebar-refresh-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-empty{font-size:13px;color:var(--text-muted);text-align:center;padding:20px 0}.sidebar-route-row{display:flex;align-items:center;gap:8px;padding:8px 6px;border-radius:6px;cursor:default}.sidebar-route-row:hover{background:var(--bg-hover)}.sidebar-route-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.sidebar-route-name{font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-route-dest{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-route-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.sidebar-vehicle-count{font-size:11px;color:var(--text-muted);white-space:nowrap}.delay-badge-sm{font-size:10px;font-weight:600;padding:1px 4px;border-radius:3px}.delay-badge-sm.delay-moderate{background:#fef3c7;color:#92400e}.delay-badge-sm.delay-severe{background:#fecaca;color:#991b1b}[data-theme=dark] .delay-badge-sm.delay-moderate{background:#78350f;color:#fde68a}[data-theme=dark] .delay-badge-sm.delay-severe{background:#7f1d1d;color:#fca5a5}.sidebar-tracked-rank{font-size:11px;font-weight:700;color:var(--text-tertiary);width:18px;text-align:center;flex-shrink:0}.sidebar-tracked-clickable:hover{background:var(--bg-hover)}.sidebar-live-dot{display:inline-block;width:6px;height:6px;background:#22c55e;border-radius:50%;margin-left:4px;vertical-align:middle}.sidebar-photo-icon{font-size:10px;margin-left:3px;vertical-align:middle}.disruptions-embedded{display:flex;flex-direction:column;gap:2px}.disruptions-embedded .disruption-item{border-radius:6px}.sidebar-favourites{display:flex;flex-direction:column;gap:4px}.sidebar-fav-section h4{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin:12px 0 6px;padding:0}.sidebar-fav-section:first-child h4{margin-top:4px}.sidebar-fav-item{display:flex;align-items:center;gap:8px;padding:7px 8px;border:none;background:none;width:100%;text-align:left;cursor:pointer;border-radius:6px;color:var(--text-primary);font-size:13px;text-decoration:none}.sidebar-fav-item:hover{background:var(--bg-hover)}.sidebar-login-prompt{text-align:center;padding:24px 12px}.sidebar-login-prompt p{font-size:13px;color:var(--text-muted);margin-bottom:12px}.sidebar-login-btn{background:#2563eb;color:#fff;border:none;border-radius:6px;padding:8px 20px;font-size:13px;font-weight:600;cursor:pointer}.sidebar-login-btn:hover{background:#1d4ed8}.sidebar-commutes-link{display:flex;align-items:center;gap:8px;padding:10px 12px;margin-top:4px;border-radius:8px;font-size:13px;font-weight:600;color:var(--text-secondary);text-decoration:none;background:var(--bg-tertiary);border:1px solid var(--border-default);transition:background .15s,color .15s}.sidebar-commutes-link:hover{background:var(--bg-hover);color:var(--text-primary)}.right-ad-sidebar{position:absolute;top:12px;right:12px;width:160px;z-index:999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.ad-slot{pointer-events:auto;background:var(--bg-primary);border-radius:8px;box-shadow:var(--shadow-card);overflow:hidden;min-height:250px;display:flex;align-items:center;justify-content:center}.ad-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:250px;color:var(--text-muted);font-size:12px}.pro-upgrade-card{pointer-events:auto;display:flex;flex-direction:column;align-items:center;background:linear-gradient(135deg,#1e1b4b,#312e81,#4338ca);border-radius:8px;padding:16px 14px;text-decoration:none;color:#fff;box-shadow:0 2px 8px #0003;transition:transform .15s,box-shadow .15s}.pro-upgrade-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #4338ca66}.pro-upgrade-badge{font-size:11px;font-weight:800;letter-spacing:1.5px;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1e1b4b;padding:2px 10px;border-radius:4px;margin-bottom:10px}.pro-upgrade-title{font-size:15px;font-weight:700;margin-bottom:8px}.pro-upgrade-perks{list-style:none;padding:0;margin:0 0 10px;font-size:11px;line-height:1.7;opacity:.9;text-align:left;width:100%}.pro-upgrade-perks li:before{content:"✓";color:#fbbf24;font-weight:700;margin-right:4px}.pro-upgrade-price{font-size:13px;font-weight:600;opacity:.85;margin-bottom:8px}.pro-upgrade-cta{font-size:12px;font-weight:700;background:#fbbf24;color:#1e1b4b;padding:5px 16px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.ad-slot-label{font-size:9px;color:var(--text-muted);text-align:center;letter-spacing:.5px;text-transform:uppercase;pointer-events:auto}.ad-unit-wrapper{overflow:hidden}.ad-unit-label{font-size:9px;color:var(--text-muted);text-align:center;letter-spacing:.5px;text-transform:uppercase;margin-top:4px}.page-ad{margin:16px 0}.page-ad .adsbygoogle{min-height:90px}.mobile-sidebar-btn{display:none;position:absolute;bottom:80px;left:12px;width:44px;height:44px;border-radius:50%;background:var(--bg-primary);box-shadow:var(--shadow-card);border:none;color:var(--text-secondary);font-size:20px;cursor:pointer;z-index:1000;align-items:center;justify-content:center}.mobile-sidebar-btn:hover{background:var(--bg-hover)}.tracking-bar{position:fixed;bottom:16px;left:50%;transform:translate(-50%);z-index:800;display:flex;align-items:center;gap:8px;background:var(--bg-primary);border-radius:12px;box-shadow:0 2px 12px #0003;padding:8px 8px 8px 12px;max-width:calc(100vw - 32px);animation:slideUp .15s ease-out}.tracking-bar-info{display:flex;align-items:center;gap:8px;border:none;background:none;cursor:pointer;padding:0;min-width:0}.tracking-bar-line{color:#fff;font-weight:700;font-size:14px;padding:2px 10px;border-radius:4px;flex-shrink:0}.tracking-bar-dest{font-size:13px;color:var(--text-secondary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.tracking-bar-following{font-size:11px;font-weight:600;color:#2563eb;background:#eff6ff;padding:2px 6px;border-radius:4px;flex-shrink:0}.tracking-bar-actions{display:flex;gap:4px;flex-shrink:0}.tracking-bar-btn{width:32px;height:32px;border:1px solid var(--border-default);border-radius:8px;background:var(--bg-tertiary);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary)}.tracking-bar-btn:hover{background:var(--bg-hover)}.tracking-bar-btn.active{background:#eff6ff;border-color:#2563eb;color:#2563eb}.side-panel h3{font-size:14px;font-weight:700;color:var(--text-secondary);margin:16px 0 8px;text-transform:uppercase;letter-spacing:.5px}.panel-loading,.panel-empty{font-size:13px;color:var(--text-muted);padding:12px 0}.panel-links{display:flex;gap:12px;align-items:center;margin-top:10px}.panel-page-link{font-size:13px;font-weight:600;color:#2563eb;text-decoration:none}.panel-page-link:hover{text-decoration:underline}.panel-area-link{font-size:12px;color:#6366f1;text-decoration:none}.panel-area-link:hover{text-decoration:underline}.approaching-heading{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:#16a34a;margin:8px 0 4px}.approaching-live-dot{width:8px;height:8px;background:#16a34a;border-radius:50%;animation:approachPulse 1.5s ease-in-out infinite}@keyframes approachPulse{0%,to{opacity:1}50%{opacity:.3}}.approaching-list{list-style:none;margin-bottom:8px}.approaching-row{display:flex;align-items:center;gap:8px;padding:8px 6px;border-radius:6px;cursor:pointer;font-size:13px;transition:background .15s}.approaching-row:hover{background:#f0fdf4}.approaching-dest{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-secondary)}.approaching-eta{font-weight:700;color:#16a34a;white-space:nowrap}.approaching-dist{font-size:11px;color:var(--text-muted);white-space:nowrap;min-width:40px;text-align:right}.approaching-live-tag{font-size:10px;background:#16a34a;color:#fff;padding:1px 5px;border-radius:3px;font-weight:600;white-space:nowrap}.departure-list{list-style:none}.departure-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-light);font-size:14px}.dep-line{background:#2563eb;color:#fff;font-weight:700;font-size:13px;padding:2px 8px;border-radius:4px;min-width:40px;text-align:center}.dep-dest{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dep-time{font-weight:600;font-variant-numeric:tabular-nums}.dep-status{font-size:11px;font-weight:600;padding:1px 6px;border-radius:3px}.dep-status.realtime{background:var(--bg-status-realtime);color:var(--text-status-realtime)}.dep-status.scheduled{background:var(--bg-status-scheduled);color:var(--text-status-scheduled)}.dep-delay{color:#ef4444;font-size:12px;font-weight:600}.vehicle-status{margin-bottom:12px}.status-late{color:#ef4444;font-weight:600;font-size:15px}.status-early{color:#2563eb;font-weight:600;font-size:15px}.status-ontime{color:#16a34a;font-weight:600;font-size:15px}.status-unknown{color:var(--text-muted);font-size:14px}.status-speed{display:inline-block;background:#eff6ff;color:#2563eb;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:600;margin-left:8px}.panel-section{border:1px solid var(--border-default);border-radius:8px;margin:8px 0;overflow:hidden}.panel-section-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-tertiary);border:none;cursor:pointer;font-size:13px;font-weight:700;color:var(--text-heading);text-transform:uppercase;letter-spacing:.5px}.panel-section-header:hover{background:var(--bg-hover)}.panel-section-title{display:flex;align-items:center;gap:8px}.panel-section-badge{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:none;letter-spacing:0}.panel-section-arrow{font-size:10px;color:var(--text-muted)}.panel-section-body{padding:8px 14px 14px;border-top:1px solid var(--border-default)}.route-progress{margin:0 0 10px;padding:0}.route-progress-labels{display:flex;justify-content:space-between;gap:12px;margin-bottom:6px}.route-progress-from,.route-progress-to{font-size:11px;font-weight:600;color:var(--text-secondary);max-width:45%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.route-progress-to{text-align:right}.route-progress-track{position:relative;height:6px;background:var(--border-default);border-radius:3px;margin-bottom:6px}.route-progress-fill{position:absolute;top:0;left:0;height:100%;border-radius:3px;transition:width .5s ease;min-width:2px}.route-progress-bus{position:absolute;top:50%;width:12px;height:12px;background:#fff;border:3px solid #2563eb;border-radius:50%;transform:translate(-50%,-50%);transition:left .5s ease;box-shadow:0 1px 3px #0003}.route-progress-stats{display:flex;justify-content:space-between;font-size:11px;color:var(--text-tertiary);font-weight:500}.route-data-notice{font-size:12px;color:var(--text-muted);background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:6px;padding:8px 12px;margin:8px 0;line-height:1.4;font-style:italic}.detail-table{width:100%;font-size:13px;border-collapse:collapse}.detail-table td{padding:6px 0;border-bottom:1px solid var(--border-light)}.detail-table td:first-child{color:var(--text-tertiary);width:110px;font-weight:500}.detail-table td:last-child{font-weight:600}.photos-header{display:flex;justify-content:space-between;align-items:center}.upload-toggle-btn{font-size:12px;font-weight:600;padding:4px 10px;border:1px solid #2563eb;border-radius:5px;background:transparent;color:#2563eb;cursor:pointer}.upload-toggle-btn:hover{background:#eff6ff}.upload-form{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--bg-tertiary);border-radius:8px;margin-bottom:12px}.upload-form input[type=text]{padding:8px 10px;font-size:13px;border:1px solid var(--border-input);border-radius:6px;outline:none}.upload-form button{padding:8px;font-size:13px;font-weight:600;border:none;border-radius:6px;background:#2563eb;color:#fff;cursor:pointer}.upload-form button:disabled{opacity:.6;cursor:not-allowed}.upload-error{color:#ef4444;font-size:12px}.upload-note{color:var(--text-muted);font-size:11px}.upload-success{color:#16a34a;font-size:13px;font-weight:500;padding:8px 12px;background:#f0fdf4;border-radius:6px;margin-bottom:8px}.photo-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.photo-card{position:relative;overflow:hidden;border-radius:6px}.photo-card img{width:100%;border-radius:6px;object-fit:cover;aspect-ratio:4 / 3}.photo-credit-overlay{position:absolute;bottom:0;left:0;right:0;padding:3px 8px;background:#0000008c;color:#fff;font-size:10px;font-weight:500;border-radius:0 0 6px 6px}.photo-caption{font-size:12px;margin-top:4px;color:var(--text-secondary)}.photo-credit{font-size:11px;color:var(--text-muted)}.photo-card,.page-photo-card{cursor:pointer}.photo-card:hover img,.page-photo-card:hover img{opacity:.85;transition:opacity .15s}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;z-index:10000;display:flex;align-items:center;justify-content:center}.lightbox-content{position:relative;max-width:95vw;max-height:95vh;display:flex;flex-direction:column;align-items:center}.lightbox-content img{max-width:90vw;max-height:80vh;object-fit:contain;border-radius:6px}.lightbox-close{position:absolute;top:-40px;right:0;background:none;border:none;color:#fff;font-size:32px;cursor:pointer;padding:4px 12px;line-height:1;opacity:.8}.lightbox-close:hover{opacity:1}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#00000080;border:none;color:#fff;font-size:40px;padding:8px 16px;cursor:pointer;border-radius:6px;line-height:1;opacity:.7}.lightbox-nav:hover{opacity:1;background:#000000b3}.lightbox-prev{left:-60px}.lightbox-next{right:-60px}.lightbox-info{margin-top:12px;text-align:center;color:#e2e8f0}.lightbox-caption{font-size:15px;margin:0 0 4px}.lightbox-credit{font-size:13px;color:#94a3b8;margin:0 0 4px}.lightbox-counter{font-size:12px;color:#64748b;margin:0}@media (max-width: 640px){.lightbox-prev{left:8px}.lightbox-next{right:8px}.lightbox-nav{font-size:28px;padding:6px 12px}.lightbox-close{top:-36px;right:4px}}.alert-any-btn{width:100%;padding:8px 12px;font-size:13px;font-weight:600;border:1px solid #2563eb;border-radius:6px;background:#eff6ff;color:#2563eb;cursor:pointer;margin-bottom:8px}.alert-any-btn:hover{background:#dbeafe}.alert-bell-btn{background:none;border:none;cursor:pointer;font-size:16px;padding:2px 4px;line-height:1;opacity:.5;transition:opacity .15s;flex-shrink:0}.alert-bell-btn:hover{opacity:1}.alert-toast{padding:8px 12px;background:#f0fdf4;color:#166534;border:1px solid #bbf7d0;border-radius:6px;font-size:13px;font-weight:500;margin-bottom:8px;animation:fadeIn .2s ease-out}.alert-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out}.alert-modal{background:var(--bg-primary);border-radius:12px;padding:28px 24px 20px;max-width:400px;width:90%;text-align:center;box-shadow:0 20px 60px #0000004d;animation:alertPop .3s cubic-bezier(.34,1.56,.64,1)}@keyframes alertPop{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.alert-modal-icon{margin-bottom:12px}.alert-modal-line-badge{display:inline-block;color:#fff;font-size:28px;font-weight:800;padding:6px 20px;border-radius:8px;min-width:60px}.alert-modal-title{font-size:20px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.alert-modal-body{font-size:14px;color:var(--text-tertiary);line-height:1.5;margin:0 0 20px}.alert-modal-actions{display:flex;gap:10px;justify-content:center}.alert-modal-btn-primary{background:#0d9488;color:#fff;border:none;padding:10px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}.alert-modal-btn-primary:hover{background:#0f766e}.alert-modal-btn-secondary{background:var(--bg-hover);color:var(--text-secondary);border:1px solid var(--border-input);padding:10px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer}.alert-modal-btn-secondary:hover{background:var(--border-default)}.dep-line-clickable{cursor:pointer}.dep-line-clickable:hover{background:#1d4ed8}.route-badge{display:inline-block;background:#2563eb;color:#fff;font-size:16px;font-weight:700;padding:2px 12px;border-radius:4px}.route-stop-list{list-style:none;max-height:300px;overflow-y:auto}.route-stop-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border-light)}.route-stop-num{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--border-default);color:var(--text-secondary);border-radius:50%;font-size:11px;font-weight:700;flex-shrink:0}.route-stop-name{font-size:13px;font-weight:500;color:#0d9488;background:none;border:none;cursor:pointer;text-align:left;padding:0}.route-stop-name:hover{text-decoration:underline}.error-toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#ef4444;color:#fff;padding:10px 20px;border-radius:8px;font-size:13px;font-weight:500;box-shadow:0 4px 12px #0003;z-index:9999;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.next-stop-row td{color:#16a34a!important;font-weight:600!important}.next-stop-link{background:none;border:none;color:#16a34a;font-weight:700;font-size:13px;cursor:pointer;padding:0;text-align:left;text-decoration:underline;text-decoration-style:dotted}.next-stop-link:hover{text-decoration-style:solid}.next-stop{background:#f0fdf4}.next-stop-num{background:#16a34a!important;color:#fff!important}.next-stop-badge{font-size:11px;font-weight:700;color:#16a34a;background:#dcfce7;padding:1px 8px;border-radius:4px;flex-shrink:0}@media (max-width: 1024px){.left-sidebar{width:260px}.right-ad-sidebar{display:none}}@media (max-width: 640px){.app-header{padding:8px 12px;padding-top:calc(8px + var(--safe-top));padding-left:calc(12px + var(--safe-left));padding-right:calc(12px + var(--safe-right));gap:8px}.app-header h1{font-size:15px}.header-nav,.vehicle-count,.header-username{display:none}.header-tools{gap:0}.header-icon-btn{width:44px;height:44px;border-radius:8px}.header-icon-btn svg{width:20px;height:20px}.header-fav-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center}.header-auth-btn{min-height:36px;padding:6px 12px;font-size:11px}.nearby-btn{min-height:44px;padding:8px 12px}.nearby-btn svg{width:20px;height:20px}.nearby-btn-label{display:none}.search-bar{left:12px;width:calc(100vw - 24px)}.side-panel{width:100vw;border-radius:16px 16px 0 0;height:55vh;max-height:calc(100dvh - 60px);top:auto;bottom:0;animation:slideUp .2s ease-out;padding-bottom:calc(20px + var(--safe-bottom))}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.close-btn{padding:10px 16px;font-size:14px;min-height:44px;display:flex;align-items:center}.tracking-bar{bottom:calc(12px + var(--safe-bottom));left:calc(12px + var(--safe-left));right:calc(12px + var(--safe-right));transform:none;max-width:none}.tracking-bar-dest{max-width:140px}.left-sidebar{display:none}.left-sidebar.open.mobile-visible{display:flex;position:fixed;bottom:0;top:auto;left:0;right:0;width:100vw;height:50vh;max-height:calc(100dvh - 60px);border-radius:16px 16px 0 0;z-index:1101;animation:slideUp .2s ease-out;padding-bottom:calc(12px + var(--safe-bottom))}.mobile-sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:1100}.right-ad-sidebar{display:none}.mobile-sidebar-btn{display:flex;bottom:calc(80px + var(--safe-bottom));left:calc(12px + var(--safe-left))}.sidebar-op-row{padding:10px 8px;gap:10px;font-size:14px}.sidebar-op-row input[type=checkbox]{width:20px;height:20px}.sidebar-toggle-row{padding:10px 8px;font-size:14px}.sidebar-toggle-switch{width:40px;height:22px}.sidebar-toggle-switch:after{width:16px;height:16px}.sidebar-toggle-switch:checked:after{transform:translate(18px)}.sidebar-fav-item,.sidebar-route-row{min-height:44px;padding:10px 8px}.sidebar-fav-tabs button{min-height:40px;padding:8px 12px;font-size:13px}.side-panel:before,.left-sidebar.open.mobile-visible:before{content:"";display:block;width:36px;height:4px;border-radius:2px;background:var(--text-muted);margin:8px auto 12px;flex-shrink:0}.sidebar-mobile-nav{display:flex;gap:8px;padding:12px 12px 8px;border-bottom:1px solid var(--border-light);margin-bottom:4px}.sidebar-mobile-nav-link{font-size:13px;font-weight:600;color:var(--text-secondary);text-decoration:none;padding:8px 14px;border-radius:8px;background:var(--bg-hover);min-height:40px;display:flex;align-items:center}.sidebar-mobile-nav-link:hover{background:var(--bg-hover-accent)}}@media (max-width: 900px) and (orientation: landscape){.side-panel{width:100vw;height:100dvh;max-height:none;border-radius:0;top:0;bottom:0}.left-sidebar.open.mobile-visible{height:100dvh;max-height:none;border-radius:0}.mobile-sidebar-btn{bottom:12px}.tracking-bar{bottom:8px;left:8px;right:8px}.side-panel:before,.left-sidebar.open.mobile-visible:before{display:none}}.admin-login{max-width:360px;margin:80px auto;padding:32px;background:#1e293b;border-radius:12px}.admin-login-page{background:#0f172a;min-height:100vh}.admin-login h1{margin:0 0 24px;color:#f1f5f9;font-size:24px}.admin-login form{display:flex;flex-direction:column;gap:12px}.admin-login input{padding:10px 14px;border:1px solid #334155;border-radius:6px;background:#0f172a;color:#f1f5f9;font-size:14px}.admin-login button{padding:10px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer}.admin-login button:hover{background:#2563eb}.admin-error{color:#ef4444;font-size:13px;margin:4px 0 0}.admin-panel{max-width:960px;margin:0 auto;padding:24px;color:#f1f5f9;background:#0f172a;min-height:100vh}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.admin-header h1{margin:0;font-size:22px}.admin-header button{padding:6px 16px;background:#475569;color:#fff;border:none;border-radius:6px;cursor:pointer}.admin-stats{display:flex;gap:16px;margin-bottom:24px}.admin-stat{flex:1;background:#1e293b;padding:16px;border-radius:8px;text-align:center;font-size:13px;color:#94a3b8}.admin-stat span{display:block;font-size:28px;font-weight:700;color:#f1f5f9;margin-bottom:4px}.admin-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid #334155}.admin-tabs button{padding:8px 20px;background:none;border:none;color:#94a3b8;font-size:14px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.admin-tabs button.active{color:#3b82f6;border-bottom-color:#3b82f6}.admin-photos{display:flex;flex-direction:column;gap:16px}.admin-photo-card{display:flex;gap:16px;background:#1e293b;border-radius:8px;padding:12px}.admin-photo-card img{width:160px;height:120px;object-fit:cover;border-radius:6px}.admin-photo-info{flex:1;font-size:13px}.admin-photo-info p{margin:0 0 4px}.admin-muted{color:#94a3b8}.admin-photo-actions{display:flex;gap:8px;margin-top:8px}.admin-btn-approve{padding:4px 14px;background:#22c55e;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px}.admin-btn-reject{padding:4px 14px;background:#ef4444;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px}.admin-users table{width:100%;border-collapse:collapse;font-size:13px}.admin-users th{text-align:left;padding:8px 12px;border-bottom:1px solid #334155;color:#94a3b8;font-weight:600}.admin-users td{padding:8px 12px;border-bottom:1px solid #1e293b;color:#f1f5f9}.admin-badge-yes{padding:2px 10px;background:#22c55e;color:#fff;border:none;border-radius:12px;font-size:12px;cursor:pointer}.admin-badge-no{padding:2px 10px;background:#475569;color:#cbd5e1;border:none;border-radius:12px;font-size:12px;cursor:pointer}.admin-gifted-badge{display:inline-block;margin-left:4px;font-size:14px;vertical-align:middle;cursor:help}.admin-btn-delete{padding:2px 10px;background:none;color:#ef4444;border:1px solid #ef4444;border-radius:4px;font-size:12px;cursor:pointer}.admin-actions-cell{display:flex;gap:4px;align-items:center;flex-wrap:wrap}.admin-grant-btns{display:flex;gap:3px}.admin-btn-grant{padding:2px 8px;background:#22c55e;color:#fff;border:none;border-radius:4px;font-size:11px;cursor:pointer}.admin-btn-grant:hover{background:#16a34a}.admin-btn-revoke{padding:2px 8px;background:none;color:#f59e0b;border:1px solid #f59e0b;border-radius:4px;font-size:11px;cursor:pointer}.admin-btn-revoke:hover{background:#f59e0b;color:#fff}.admin-photo-views{display:flex;gap:8px;margin-bottom:16px}.admin-photo-views button{padding:6px 16px;background:#1e293b;border:1px solid #334155;color:#94a3b8;border-radius:6px;cursor:pointer;font-size:13px}.admin-photo-views button.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.admin-status-pending{color:#f59e0b;font-weight:600;font-size:12px}.admin-status-approved{color:#22c55e;font-weight:600;font-size:12px}.admin-status-rejected{color:#ef4444;font-weight:600;font-size:12px}.admin-panel{max-width:1100px}.admin-loading{color:#94a3b8;font-size:14px;padding:20px 0}.admin-overview-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:24px}.admin-overview-card{background:#1e293b;border-radius:8px;padding:16px 12px;text-align:center;border:1px solid #334155}.admin-overview-card.admin-overview-pro{border-color:#f59e0b}.admin-overview-card.admin-overview-highlight{border-color:#3b82f6}.admin-pill-filter{display:flex;gap:4px;justify-content:center;margin-top:8px}.admin-pill{padding:2px 8px;font-size:10px;font-weight:500;border:1px solid #475569;border-radius:20px;background:transparent;color:#94a3b8;cursor:pointer;transition:all .15s}.admin-pill:hover{border-color:#3b82f6;color:#e2e8f0}.admin-pill.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.admin-alert-banner{display:flex;align-items:center;gap:10px;padding:10px 16px;margin-bottom:16px;background:#1e293b;border:1px solid #f59e0b;border-radius:8px;color:#fbbf24;font-size:13px;cursor:pointer;transition:background .15s}.admin-alert-banner:hover{background:#263548}.admin-alert-dot{width:8px;height:8px;border-radius:50%;background:#f59e0b;animation:pulse-dot 1.5s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.admin-alert-arrow{margin-left:auto;font-size:16px}.admin-overview-num{display:block;font-size:24px;font-weight:700;color:#f1f5f9;margin-bottom:2px}.admin-overview-label{font-size:11px;color:#94a3b8;text-transform:uppercase;letter-spacing:.3px}.admin-charts-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}.admin-chart-card{background:#1e293b;border-radius:8px;padding:16px;border:1px solid #334155}.admin-chart-card-wide{grid-column:span 2}.admin-chart-card h3{font-size:13px;font-weight:600;color:#94a3b8;margin:0 0 12px;text-transform:uppercase;letter-spacing:.3px}.admin-mini-table{width:100%;border-collapse:collapse;font-size:13px}.admin-mini-table th{text-align:left;padding:6px 8px;color:#64748b;font-weight:600;border-bottom:1px solid #334155;font-size:11px;text-transform:uppercase}.admin-mini-table td{padding:6px 8px;color:#e2e8f0;border-bottom:1px solid #1e293b}.admin-user-controls{display:flex;gap:8px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.admin-search-input{flex:1;min-width:200px;padding:8px 12px;background:#1e293b;border:1px solid #334155;border-radius:6px;color:#f1f5f9;font-size:13px;outline:none}.admin-search-input:focus{border-color:#3b82f6}.admin-filter-select{padding:8px 12px;background:#1e293b;border:1px solid #334155;border-radius:6px;color:#f1f5f9;font-size:13px;outline:none;cursor:pointer}.admin-result-count{font-size:12px;color:#64748b;white-space:nowrap;margin-left:auto}.admin-username-link{background:none;border:none;color:#93c5fd;font-size:13px;cursor:pointer;text-decoration:none;padding:0}.admin-username-link:hover{text-decoration:underline;color:#bfdbfe}.admin-pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:16px;font-size:13px;color:#94a3b8}.admin-pagination button{padding:6px 16px;background:#1e293b;border:1px solid #334155;color:#f1f5f9;border-radius:6px;cursor:pointer;font-size:13px}.admin-pagination button:disabled{opacity:.4;cursor:not-allowed}.admin-pagination button:not(:disabled):hover{background:#334155}.admin-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:10000;display:flex;align-items:center;justify-content:center}.admin-modal{background:#1e293b;border-radius:12px;padding:24px;min-width:400px;max-width:90vw;max-height:80vh;overflow-y:auto;border:1px solid #334155}.admin-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.admin-modal-header h3{margin:0;font-size:18px;color:#f1f5f9}.admin-modal-header button{padding:4px 12px;background:#475569;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px}.admin-detail-table{width:100%;border-collapse:collapse;font-size:14px}.admin-detail-table td{padding:8px 0;border-bottom:1px solid #334155;color:#e2e8f0}.admin-detail-table td:first-child{color:#94a3b8;width:130px;font-weight:500}.admin-photo-checkbox{position:absolute;top:12px;left:12px;width:16px;height:16px;cursor:pointer;z-index:1}.admin-photo-card{position:relative}.admin-photo-card.selected{border:2px solid #3b82f6}.admin-photo-thumb{cursor:pointer;transition:opacity .15s}.admin-photo-thumb:hover{opacity:.8}.admin-bulk-actions{display:flex;gap:8px;align-items:center;margin-bottom:12px;font-size:13px;color:#94a3b8}.admin-select-all{display:flex;align-items:center;gap:4px;cursor:pointer;font-size:13px;color:#94a3b8}.admin-lightbox{max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}.admin-lightbox img{max-width:90vw;max-height:80vh;object-fit:contain;border-radius:8px}.admin-lightbox-close{position:absolute;top:16px;right:16px;padding:6px 16px;background:#0009;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:13px;z-index:1}.admin-lightbox-caption{color:#e2e8f0;font-size:14px;margin-top:8px}.admin-gauges-row{display:flex;gap:24px;justify-content:center;margin-bottom:20px}.admin-gauge{display:flex;flex-direction:column;align-items:center;gap:4px}.admin-gauge-label{font-size:12px;font-weight:600;color:#94a3b8;text-transform:uppercase}.admin-feed-status{display:flex;align-items:center;gap:8px;margin-bottom:12px}.admin-feed-dot{width:10px;height:10px;border-radius:50%}.admin-feed-healthy{background:#22c55e;animation:pulse 2s infinite}.admin-feed-warning{background:#f59e0b;animation:pulse 1.5s infinite}.admin-feed-critical{background:#ef4444;animation:pulse 1s infinite}.admin-feed-unknown{background:#64748b}.admin-feed-text{font-size:14px;font-weight:600;color:#e2e8f0}.admin-feed-stats{display:flex;gap:16px;font-size:13px;color:#94a3b8}.admin-health-footer{display:flex;align-items:center;gap:12px;margin-top:16px}.admin-announce-form{display:flex;flex-direction:column;gap:10px}.admin-announce-title{padding:10px 14px;background:#0f172a;border:1px solid #334155;border-radius:6px;color:#f1f5f9;font-size:14px;outline:none}.admin-announce-title:focus{border-color:#3b82f6}.admin-announce-body{padding:10px 14px;background:#0f172a;border:1px solid #334155;border-radius:6px;color:#f1f5f9;font-size:14px;resize:vertical;outline:none;font-family:inherit}.admin-announce-body:focus{border-color:#3b82f6}.admin-announce-controls{display:flex;gap:8px;align-items:center}.admin-recipient-preview{margin-top:16px;padding-top:12px;border-top:1px solid #1e293b}.admin-recipient-preview h4{font-size:13px;color:#94a3b8;margin:0 0 8px}.admin-recipient-list{display:flex;flex-wrap:wrap;gap:6px}.admin-recipient-chip{display:inline-block;padding:3px 10px;background:#1e293b;border-radius:12px;font-size:12px;color:#e2e8f0}.admin-recipient-email{color:#64748b;font-size:11px}.admin-audience-badge{padding:2px 8px;background:#334155;border-radius:4px;font-size:11px;color:#94a3b8;text-transform:capitalize}.admin-btn-delete-sm{padding:2px 8px;background:none;color:#ef4444;border:1px solid #ef4444;border-radius:3px;font-size:11px;cursor:pointer}.admin-btn-delete-sm:hover{background:#ef44441a}@media (max-width: 900px){.admin-panel{padding:16px}.admin-overview-grid{grid-template-columns:repeat(3,1fr)}.admin-charts-row{grid-template-columns:1fr}.admin-chart-card-wide{grid-column:span 1}.admin-photo-card{flex-direction:column}.admin-photo-card img{width:100%;height:180px}.admin-gauges-row{flex-wrap:wrap;gap:16px}}@media (max-width: 640px){.admin-panel{padding:12px 8px}.admin-header h1{font-size:17px}.admin-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:0;flex-wrap:nowrap}.admin-tabs::-webkit-scrollbar{display:none}.admin-tabs button{padding:8px 14px;font-size:12px;white-space:nowrap;flex-shrink:0}.admin-overview-grid{grid-template-columns:repeat(2,1fr);gap:8px}.admin-overview-card{padding:12px 8px}.admin-overview-num{font-size:20px}.admin-overview-label{font-size:10px}.admin-chart-card{padding:12px}.admin-chart-card h3{font-size:12px;margin-bottom:8px}.admin-modal{min-width:auto;width:calc(100vw - 16px);padding:16px}.admin-user-controls{flex-direction:column}.admin-search-input{min-width:auto;width:100%}.admin-photo-views{flex-wrap:wrap}.admin-photo-views button{padding:5px 12px;font-size:12px}.admin-users{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-users table{min-width:700px}.admin-mini-table{font-size:12px}.admin-mini-table th,.admin-mini-table td{padding:5px 6px}.admin-announce-controls{flex-direction:column}.admin-announce-controls .admin-filter-select{width:100%}.admin-announce-controls .admin-btn-approve{width:100%;padding:10px}.admin-feed-stats{flex-direction:column;gap:4px}.admin-recipient-chip{font-size:11px;padding:2px 8px}.admin-bulk-actions{flex-wrap:wrap}}@media (max-width: 400px){.admin-overview-grid{grid-template-columns:1fr 1fr;gap:6px}.admin-overview-num{font-size:18px}.admin-tabs button{padding:6px 10px;font-size:11px}}.account-page{min-height:100vh;background:#0f172a;padding:20px}.account-container{max-width:520px;margin:0 auto}.account-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}.account-header h1{font-size:22px;font-weight:700;color:#f1f5f9;margin:0}.account-back-btn{padding:6px 16px;background:#475569;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:13px}.account-back-btn:hover{background:#64748b}.account-section{background:#1e293b;border-radius:10px;padding:20px;margin-bottom:16px}.account-section h2{font-size:15px;font-weight:700;color:#f1f5f9;margin:0 0 12px}.account-section p{font-size:13px;color:#94a3b8;margin:0 0 12px;line-height:1.4}.account-info-table{width:100%;font-size:13px;border-collapse:collapse}.account-info-table td{padding:7px 0;border-bottom:1px solid #334155;color:#e2e8f0}.account-info-table td:first-child{color:#94a3b8;width:120px;font-weight:500}.account-badge-yes{display:inline-block;padding:2px 10px;background:#22c55e;color:#fff;border-radius:12px;font-size:12px;font-weight:600}.account-badge-no{display:inline-block;padding:2px 10px;background:#475569;color:#cbd5e1;border-radius:12px;font-size:12px;font-weight:600}.account-form{display:flex;flex-direction:column;gap:10px}.account-form input{padding:10px 14px;border:1px solid #334155;border-radius:6px;background:#0f172a;color:#f1f5f9;font-size:14px;outline:none}.account-form input:focus{border-color:#3b82f6}.account-form button{padding:10px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer}.account-form button:hover{background:#2563eb}.account-success{color:#22c55e;font-size:13px;margin:4px 0 0}.account-error{color:#ef4444;font-size:13px;margin:4px 0 0}.account-danger{border:1px solid #7f1d1d}.account-danger h2{color:#fca5a5}.account-delete-toggle{padding:8px 16px;background:none;border:1px solid #ef4444;color:#ef4444;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer}.account-delete-toggle:hover{background:#ef44441a}.account-delete-btn{background:#dc2626!important}.account-delete-btn:hover{background:#b91c1c!important}.header-username{color:#94a3b8;text-decoration:none;font-size:13px}.header-username:hover{color:#e2e8f0;text-decoration:underline}.fav-star{background:none;border:none;font-size:24px;cursor:pointer;color:#9ca3af;margin-left:8px;vertical-align:middle;padding:4px;line-height:1;transition:color .15s,transform .15s}.fav-star:active{transform:scale(1.2)}.fav-star:hover,.fav-star.fav-active{color:#facc15}.account-fav-list{list-style:none;padding:0;margin:0}.account-fav-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #334155}.account-fav-item:last-child{border-bottom:none}.account-fav-info{display:flex;flex-direction:column;gap:2px}.account-fav-name{font-size:14px;font-weight:600;color:#e2e8f0}.account-fav-locality{font-size:12px;color:#94a3b8}.account-fav-remove{padding:4px 12px;font-size:12px;background:none;border:1px solid #475569;color:#94a3b8;border-radius:4px;cursor:pointer;flex-shrink:0}.account-fav-remove:hover{border-color:#ef4444;color:#ef4444}.auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:9000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.auth-modal{background:var(--bg-primary);border-radius:12px;padding:28px;width:360px;max-width:calc(100vw - 32px);box-shadow:0 8px 32px #0003}.auth-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.auth-modal-header h2{font-size:20px;font-weight:700;margin:0}.auth-modal form{display:flex;flex-direction:column;gap:10px}.auth-modal input{padding:10px 14px;font-size:14px;border:1px solid var(--border-input);background:var(--bg-secondary);color:var(--text-primary);border-radius:8px;outline:none}.auth-modal input:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb26}.auth-modal form button[type=submit]{padding:10px;font-size:14px;font-weight:600;border:none;border-radius:8px;background:#2563eb;color:#fff;cursor:pointer;margin-top:4px}.auth-modal form button[type=submit]:hover{background:#1d4ed8}.auth-modal form button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.auth-error{color:#ef4444;font-size:13px;margin:4px 0 0}.auth-switch{text-align:center;font-size:13px;color:var(--text-tertiary);margin-top:16px}.auth-switch button{background:none;border:none;color:#2563eb;font-weight:600;cursor:pointer;font-size:13px}.auth-switch button:hover{text-decoration:underline}.page-header-bar{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#1e293b;color:#fff}.page-logo{font-size:16px;font-weight:700;color:#fff;text-decoration:none}.page-logo:hover{color:#93c5fd}.page-header-sep{color:#475569;font-size:14px}.page-header-crumb{font-size:14px;color:#94a3b8}.page-container{max-width:800px;margin:0 auto;padding:24px 20px 60px;min-height:100vh;background:var(--bg-primary)}.page-loading-spinner{width:32px;height:32px;border:3px solid var(--border-default);border-top-color:#2563eb;border-radius:50%;margin:80px auto;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.page-empty-state{text-align:center;padding:60px 20px}.page-empty-icon{width:56px;height:56px;margin:0 auto 16px;background:var(--bg-hover);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:var(--text-muted)}.page-empty-state h2{font-size:20px;font-weight:700;margin:0 0 8px}.page-empty-state p{color:var(--text-tertiary);margin:0 0 20px}.page-empty-inline{padding:20px 0;text-align:center}.page-empty-inline p{margin:0 0 4px}.page-title{font-size:24px;font-weight:700;color:var(--text-primary);margin:4px 0}.page-subtitle{font-size:15px;color:var(--text-tertiary);margin:2px 0 0}.page-subtle{font-size:13px;color:var(--text-muted)}.page-count{font-size:14px;font-weight:400;color:var(--text-muted)}.page-track-btn{display:inline-block;padding:10px 20px;background:#2563eb;color:#fff;font-size:14px;font-weight:600;border-radius:8px;text-decoration:none;white-space:nowrap;flex-shrink:0;transition:background .15s}.page-track-btn:hover{background:#1d4ed8}.page-action-btn{padding:6px 14px;font-size:13px;font-weight:600;border:1px solid #2563eb;border-radius:6px;background:transparent;color:#2563eb;cursor:pointer}.page-action-btn:hover{background:#eff6ff}.page-login-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding:12px 0;border-bottom:1px solid var(--border-light);margin-bottom:12px}.page-login-form input{padding:6px 10px;border:1px solid var(--border-input);border-radius:6px;font-size:13px}.page-login-form button{padding:6px 14px;border:none;border-radius:6px;font-size:13px;cursor:pointer;background:#2563eb;color:#fff}.page-login-form button[type=button]{background:#f1f5f9;color:#374151}.page-login-form button:hover{opacity:.9}.page-error-msg{font-size:13px;color:#dc2626;width:100%}.page-msg{font-size:13px;color:#16a34a;background:#f0fdf4;padding:8px 12px;border-radius:6px;margin-bottom:12px}.page-card{background:var(--bg-primary);border:1px solid var(--border-default);border-radius:12px;padding:20px;margin-bottom:16px}.page-card-muted{background:var(--bg-tertiary);color:var(--text-tertiary);text-align:center}.page-card-muted p{margin:0}.page-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.page-card-header h2{font-size:16px;font-weight:700;color:var(--text-primary);margin:0;text-transform:uppercase;letter-spacing:.5px}.page-card-badge{color:#fff;font-weight:700;font-size:14px;padding:2px 10px;border-radius:5px}.page-live-pill{display:inline-flex;align-items:center;gap:6px;background:var(--bg-status-realtime);color:var(--text-status-realtime);font-size:11px;font-weight:700;padding:3px 10px;border-radius:12px;margin-bottom:8px;letter-spacing:.5px}.page-live-dot{width:7px;height:7px;border-radius:50%;background:#16a34a;animation:pulse 2s infinite}.page-live-count{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#16a34a}.page-hero-banner{display:flex;gap:24px;margin-bottom:20px;padding:20px;background:var(--bg-tertiary);border-radius:12px;border-left:4px solid #2563eb}.page-hero-left{width:280px;flex-shrink:0}.page-hero-img{width:100%;border-radius:8px;object-fit:cover;aspect-ratio:4 / 3}.page-hero-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:210px;background:var(--border-default);border-radius:8px;color:var(--text-muted);font-size:14px}.page-hero-right{flex:1;display:flex;flex-direction:column;justify-content:center}.page-quick-facts{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0 16px}.page-fact{background:var(--bg-primary);border:1px solid var(--border-default);border-radius:6px;padding:6px 12px;display:flex;flex-direction:column}.page-fact-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.page-fact-value{font-size:14px;font-weight:600;color:var(--text-primary)}.page-live-route-row{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:500;margin-bottom:10px}.page-route-arrow{color:var(--text-muted);font-size:18px}.page-live-delay{display:flex;align-items:center}.page-stop-hero{display:flex;gap:16px;align-items:flex-start;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border-default)}.page-stop-icon{font-size:36px;flex-shrink:0;line-height:1}.page-stop-hero-info{flex:1}.page-stop-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.page-tag{display:inline-block;padding:2px 8px;font-size:11px;font-weight:600;color:var(--text-tertiary);background:var(--bg-hover);border-radius:4px;font-family:monospace}.page-route-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.page-route-chip{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-hover-accent);border:1px solid var(--border-default);border-radius:8px;text-decoration:none;color:var(--text-primary);font-size:13px;transition:border-color .15s}.page-route-chip:hover{border-color:#2563eb}.page-route-chip-line{font-weight:700;color:#2563eb}.page-route-chip-dest{color:var(--text-tertiary)}.page-route-hero{display:flex;gap:16px;align-items:center;margin-bottom:20px;padding:20px;background:var(--bg-tertiary);border-radius:12px;border-left:4px solid #2563eb}.page-route-badge-lg{font-size:28px;font-weight:800;color:#fff;padding:8px 20px;border-radius:8px;flex-shrink:0;min-width:60px;text-align:center}.page-route-hero-info{flex:1}.page-route-stop-list{display:flex;flex-direction:column}.page-route-stop-item{display:flex;align-items:stretch;text-decoration:none;color:var(--text-primary);transition:background .1s;border-radius:4px}.page-route-stop-item:hover{background:var(--bg-tertiary)}.page-route-stop-line{width:3px;position:relative;margin:0 16px;flex-shrink:0}.page-route-stop-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:9px;height:9px;background:var(--bg-primary);border:2px solid var(--text-muted);border-radius:50%}.page-route-stop-dot-lg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:13px;height:13px;background:var(--bg-primary);border:3px solid #2563eb;border-radius:50%}.page-route-stop-info{padding:8px 0;font-size:14px}.page-route-stop-name{font-weight:500}.page-detail-table{width:100%;font-size:14px;border-collapse:collapse}.page-detail-table td{padding:8px 0;border-bottom:1px solid var(--border-light)}.page-detail-table td:first-child{color:var(--text-tertiary);width:120px;font-weight:500}.page-detail-table td:last-child{font-weight:600;color:var(--text-primary)}.page-photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.page-photo-card{position:relative;overflow:hidden;border-radius:8px}.page-photo-card img{width:100%;border-radius:8px;object-fit:cover;aspect-ratio:4 / 3}.page-photo-card .photo-caption{font-size:12px;margin-top:4px;color:var(--text-secondary)}.page-departures-table{width:100%;border-collapse:collapse;font-size:14px}.page-departures-table th{text-align:left;padding:8px 12px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);border-bottom:2px solid var(--border-default)}.page-departures-table td{padding:10px 12px;border-bottom:1px solid var(--border-light)}.page-departures-table tr:hover{background:var(--bg-tertiary)}.page-line-link{display:inline-block;background:#2563eb;color:#fff;font-weight:700;font-size:13px;padding:2px 8px;border-radius:4px;text-decoration:none;min-width:36px;text-align:center}.page-line-link:hover{background:#1d4ed8}.page-vehicle-list{display:flex;flex-direction:column;gap:8px}.page-vehicle-card{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:8px;text-decoration:none;color:var(--text-primary);transition:border-color .15s,box-shadow .15s}.page-vehicle-card:hover{border-color:#2563eb;box-shadow:0 2px 8px #2563eb1a}.page-vehicle-dir{flex:1;font-size:14px;font-weight:500}.page-vehicle-id{font-size:13px;font-weight:600;color:var(--text-tertiary);font-family:monospace}.page-nearby-list{list-style:none;padding:0}.page-nearby-list li{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border-light)}.page-nearby-list li:last-child{border-bottom:none}.page-nearby-list a{color:var(--text-primary);text-decoration:none;font-size:14px}.page-nearby-list a:hover{color:#2563eb}.page-distance{font-size:12px;font-weight:600;color:#2563eb;white-space:nowrap}@media (max-width: 640px){.page-container{padding:16px 14px 40px}.page-title{font-size:20px}.page-hero-banner{flex-direction:column;gap:16px;padding:16px}.page-hero-left{width:100%}.page-stop-hero{flex-direction:column;gap:12px}.page-stop-hero .page-track-btn{align-self:flex-start}.page-route-hero{flex-direction:column;align-items:flex-start;gap:12px}.page-photo-grid{grid-template-columns:repeat(2,1fr)}.page-departures-table{font-size:13px}.page-departures-table th,.page-departures-table td{padding:8px 6px}}.header-fav-btn{background:none;border:none;font-size:18px;cursor:pointer;color:#94a3b8;padding:2px 6px;line-height:1;transition:color .15s}.header-fav-btn:hover,.header-fav-btn.has-favs{color:#facc15}.favourites-dropdown{position:fixed;top:48px;right:12px;width:320px;max-width:calc(100vw - 24px);max-height:calc(100vh - 64px);overflow-y:auto;background:var(--bg-primary);border-radius:12px;box-shadow:var(--shadow-dropdown);z-index:9000;padding:12px;animation:favDropIn .15s ease-out}@keyframes favDropIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.favourites-dropdown-section{margin-bottom:8px}.favourites-dropdown-section:last-child{margin-bottom:0}.favourites-dropdown-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);padding:4px 6px;margin:0}.favourites-dropdown-empty{font-size:13px;color:var(--text-muted);padding:12px 6px;text-align:center}.favourites-dropdown-item{display:flex;align-items:center;gap:8px;padding:8px 6px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--text-primary);text-decoration:none;border:none;background:none;width:100%;text-align:left}.favourites-dropdown-item:hover{background:var(--bg-hover-accent)}.favourites-dropdown-item-name{font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.favourites-dropdown-item-sub{font-size:11px;color:var(--text-muted)}.fav-dropdown-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.favourites-dropdown-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:8999}.fav-star-inline{font-size:16px;margin-left:4px;padding:2px;vertical-align:middle}.operator-link{color:#2563eb;text-decoration:none;font-weight:600}.operator-link:hover{text-decoration:underline}.account-fav-link{text-decoration:none;color:#93c5fd;display:flex;align-items:center;gap:6px}.account-fav-link:hover{text-decoration:underline;color:#bfdbfe}.account-operator-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;display:inline-block}.page-operator-badge{font-size:14px;font-weight:800;color:#fff;padding:10px 16px;border-radius:8px;flex-shrink:0;text-align:center;letter-spacing:.5px;text-transform:uppercase}.page-operator-stats{display:flex;gap:24px}.page-operator-stat{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;padding:12px;background:var(--bg-tertiary);border-radius:8px}.page-operator-stat-value{display:flex;align-items:center;gap:6px;font-size:28px;font-weight:700;color:var(--text-primary)}.page-operator-stat-label{font-size:13px;font-weight:500;color:var(--text-tertiary)}.page-operator-route-list{display:flex;flex-direction:column}.page-operator-route-item{display:flex;align-items:center;gap:10px;padding:10px 8px;text-decoration:none;color:var(--text-primary);border-bottom:1px solid var(--border-light);transition:background .1s}.page-operator-route-item:last-child{border-bottom:none}.page-operator-route-item:hover{background:var(--bg-tertiary)}.page-route-badge-sm{display:inline-block;color:#fff;font-weight:700;font-size:13px;padding:2px 10px;border-radius:4px;min-width:40px;text-align:center;flex-shrink:0}.page-operator-route-desc{font-size:14px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.page-area-stop-name{font-weight:500;color:var(--text-primary)}.page-show-more-btn{display:block;width:100%;padding:10px;margin-top:8px;background:var(--surface);color:var(--text-link, #3b82f6);border:1px solid var(--border);border-radius:8px;cursor:pointer;font-size:14px;font-weight:500}.page-show-more-btn:hover{background:var(--hover-bg, rgba(59, 130, 246, .08))}.areas-list-input{width:100%;padding:10px 14px;font-size:14px;border:1px solid var(--border-input);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);box-sizing:border-box}.areas-list-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}.areas-list-items{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:2px 8px}.areas-list-item{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;border-radius:6px;text-decoration:none;color:var(--text-primary);font-size:14px;transition:background .15s}.areas-list-item:hover{background:var(--bg-hover)}.areas-list-name{font-weight:500}.areas-list-count{font-size:12px;color:var(--text-tertiary);white-space:nowrap;margin-left:8px}.changelog-page{min-height:100vh;background:#0f172a;padding:20px}.changelog-container{max-width:680px;margin:0 auto}.changelog-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.changelog-header h1{font-size:24px;font-weight:700;color:#f1f5f9;margin:0 0 6px}.changelog-status{display:flex;align-items:center;gap:8px;font-size:13px;color:#22c55e;font-weight:600;margin:0}.changelog-status-dot{width:8px;height:8px;background:#22c55e;border-radius:50%;animation:pulse 2s infinite}.changelog-intro{background:#1e293b;border-radius:10px;padding:16px 20px;margin-bottom:24px}.changelog-intro p{font-size:14px;color:#94a3b8;line-height:1.6;margin:0}.changelog-intro strong{color:#e2e8f0}.changelog-release{background:#1e293b;border-radius:10px;padding:20px;margin-bottom:12px;border-left:3px solid #3b82f6}.changelog-release h2{font-size:16px;font-weight:700;color:#f1f5f9;margin:0 0 12px}.changelog-release-header{display:flex;align-items:center;gap:10px;margin-bottom:8px;flex-wrap:wrap}.changelog-version{display:inline-block;padding:2px 10px;background:#3b82f6;color:#fff;font-size:13px;font-weight:700;border-radius:4px;font-family:monospace}.changelog-version-plain{font-size:15px;font-weight:700;color:#f1f5f9}.changelog-date{font-size:13px;color:#64748b}.changelog-tag{font-size:11px;font-weight:700;padding:2px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.changelog-tag-new{background:#22c55e;color:#fff}.changelog-tag-major{background:#8b5cf6;color:#fff}.changelog-list{list-style:none;padding:0;margin:0}.changelog-list li{position:relative;padding:5px 0 5px 20px;font-size:13px;color:#cbd5e1;line-height:1.5}.changelog-list li:before{position:absolute;left:0;top:5px;font-size:13px}.changelog-feat:before{content:"+";color:#22c55e;font-weight:700}.changelog-fix:before{content:"•";color:#f59e0b;font-weight:700}.changelog-note:before{content:"ℹ";color:#64748b;font-weight:700;font-size:12px}.changelog-planned-item:before{content:"○";color:#64748b;font-size:11px}.changelog-list li strong{color:#e2e8f0}.changelog-list li code{background:#334155;padding:1px 5px;border-radius:3px;font-size:12px;color:#93c5fd}.changelog-list li a{color:#60a5fa;text-decoration:none;border-bottom:1px solid rgba(96,165,250,.3);transition:border-color .15s}.changelog-list li a:hover{border-bottom-color:#60a5fa}.changelog-bugfixes{border-left-color:#f59e0b}.changelog-planned{border-left-color:#64748b;border-style:dashed}.changelog-footer{padding:24px 0 40px;text-align:center}.changelog-footer p{font-size:13px;color:#64748b;line-height:1.6;margin:0}.changelog-footer a{color:#93c5fd;text-decoration:none}.changelog-footer a:hover{text-decoration:underline}@media (max-width: 640px){.changelog-header{flex-direction:column;gap:12px}.changelog-release{padding:16px}}.profile-hero{background:linear-gradient(135deg,#1e293b,#334155);border-radius:12px;padding:24px;margin-bottom:16px}.profile-hero-info{display:flex;align-items:center;gap:16px;margin-bottom:20px}.profile-avatar{width:56px;height:56px;border-radius:50%;background:#3b82f6;color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;flex-shrink:0}.profile-username{font-size:22px;font-weight:700;color:#f1f5f9;margin-bottom:2px}.profile-meta{font-size:13px;color:#94a3b8;display:flex;align-items:center;gap:8px}.profile-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.profile-stat-card{background:#ffffff12;border-radius:8px;padding:14px 10px;display:flex;flex-direction:column;align-items:center;gap:4px}.profile-stat-number{font-size:22px;font-weight:700;color:#f1f5f9}.profile-stat-label{font-size:11px;color:#94a3b8;text-align:center}.profile-photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.profile-photo-card{position:relative;border-radius:8px;overflow:hidden;display:block;text-decoration:none;background:#1e293b}.profile-photo-card img{width:100%;aspect-ratio:4 / 3;object-fit:cover;display:block}.profile-photo-card:hover img{opacity:.85}.profile-photo-status{position:absolute;top:6px;right:6px;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600}.profile-photo-status-approved{background:#16a34ad9;color:#fff}.profile-photo-status-pending{background:#eab308d9;color:#000}.profile-photo-status-rejected{background:#ef4444d9;color:#fff}.profile-photo-caption{position:absolute;bottom:0;left:0;right:0;padding:4px 8px;background:#0000008c;color:#fff;font-size:11px}.profile-empty{color:#94a3b8;font-size:14px;padding:12px 0}.profile-fav-tabs{display:flex;gap:4px;margin-bottom:12px;flex-wrap:wrap}.profile-fav-tab{padding:6px 14px;border-radius:20px;font-size:13px;font-weight:500;border:1px solid #334155;background:transparent;color:#94a3b8;cursor:pointer;transition:all .15s}.profile-fav-tab:hover{background:#334155;color:#e2e8f0}.profile-fav-tab.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.profile-fav-tab-count{font-size:11px;opacity:.7;margin-left:2px}.profile-section-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;cursor:pointer;padding:0;color:inherit}.profile-section-toggle h2{margin:0;font-size:16px;color:#e2e8f0}.profile-section-toggle span{color:#64748b;font-size:12px}.profile-settings-body{margin-top:16px}.profile-settings-group{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #334155}.profile-settings-group:last-child{border-bottom:none;margin-bottom:0}.profile-settings-group h3{font-size:14px;color:#cbd5e1;margin-bottom:10px}@media (max-width: 640px){.profile-stats-grid{grid-template-columns:repeat(2,1fr)}.profile-hero-info{flex-direction:column;text-align:center}.profile-meta{justify-content:center;flex-wrap:wrap}}.disruptions-wrapper{position:relative}.disruptions-btn{padding:6px 12px;font-size:13px;font-weight:600;border:none;border-radius:8px;background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;box-shadow:var(--shadow-card);white-space:nowrap;display:flex;align-items:center;gap:5px}.disruptions-btn:hover{background:var(--bg-tertiary)}.disruptions-btn.has-delays{background:#fef3c7;color:#92400e}.disruptions-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#f59e0b;color:#fff;font-size:11px;font-weight:800}.disruptions-panel{position:absolute;top:calc(100% + 8px);right:0;width:340px;max-height:400px;overflow-y:auto;background:var(--bg-primary);border-radius:10px;box-shadow:var(--shadow-dropdown);z-index:1001}.disruptions-panel-header{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid var(--border-default);font-size:14px}.disruptions-close{background:none;border:none;font-size:16px;color:var(--text-muted);cursor:pointer;padding:2px 6px;border-radius:4px}.disruptions-close:hover{background:var(--bg-hover);color:var(--text-secondary)}.disruptions-empty{padding:20px 14px;text-align:center;color:var(--text-tertiary);font-size:13px}.disruption-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border-light);cursor:default}.disruption-item:last-child{border-bottom:none}.disruption-info{flex:1;min-width:0}.disruption-route-name{display:block;font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.disruption-meta{display:block;font-size:11px;color:var(--text-muted);margin-top:1px}.delay-badge{padding:3px 8px;border-radius:6px;font-size:12px;font-weight:700;white-space:nowrap}.delay-moderate{background:#fef3c7;color:#92400e}.delay-severe{background:#fee2e2;color:#991b1b}.disruption-official{padding:10px 12px;border-bottom:1px solid var(--border-light)}.disruption-official-header{display:flex;align-items:center;gap:8px;cursor:pointer}.disruption-severity{font-size:10px;font-weight:700;text-transform:uppercase;padding:2px 6px;border-radius:4px;flex-shrink:0}.severity-slight{background:#dbeafe;color:#1e40af}.severity-normal{background:#fef3c7;color:#92400e}.severity-severe{background:#fed7aa;color:#9a3412}.severity-verySevere{background:#fecaca;color:#991b1b}[data-theme=dark] .severity-slight{background:#1e3a5f;color:#93c5fd}[data-theme=dark] .severity-normal{background:#78350f;color:#fde68a}[data-theme=dark] .severity-severe{background:#7c2d12;color:#fdba74}[data-theme=dark] .severity-verySevere{background:#7f1d1d;color:#fca5a5}.disruption-summary{font-size:13px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.disruption-lines{display:flex;gap:4px;flex-wrap:wrap;margin-top:6px}.disruption-line-pill{font-size:11px;padding:1px 6px;border-radius:4px;background:var(--bg-tertiary);color:var(--text-secondary)}.disruption-description{font-size:12px;color:var(--text-secondary);margin-top:8px;line-height:1.5}.disruption-validity{display:block;font-size:11px;color:var(--text-muted);margin-top:4px}.disruption-section-label{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--text-muted);padding:8px 12px 4px;letter-spacing:.5px}.vehicle-disruption-banner{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:#fef3c7;border-left:3px solid #f59e0b;margin:0 12px 8px;border-radius:6px}[data-theme=dark] .vehicle-disruption-banner{background:#f59e0b1f;border-left-color:#f59e0b}.vehicle-disruption-icon{font-size:16px;line-height:1;flex-shrink:0}.vehicle-disruption-text{display:flex;flex-direction:column;gap:2px;min-width:0}.vehicle-disruption-text strong{font-size:12px;font-weight:600;color:var(--text-primary)}.vehicle-disruption-desc{font-size:11px;color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}[data-theme=dark] .leaflet-popup-content-wrapper{background:var(--bg-primary);color:var(--text-primary)}[data-theme=dark] .leaflet-popup-tip{background:var(--bg-primary)}[data-theme=dark] .leaflet-control-zoom a{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-default)}[data-theme=dark] .leaflet-control-attribution{background:#0f172abf;color:var(--text-muted)}[data-theme=dark] .leaflet-control-attribution a{color:var(--text-tertiary)}.weather-toggle{background:none;border:none;cursor:pointer;color:#94a3b8;padding:4px;line-height:0;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;transition:color .2s,background .2s}.weather-toggle:hover{color:#60a5fa;background:#ffffff1a}.weather-toggle.active{color:#60a5fa}.weather-toggle svg{display:block}.report-flag-btn{display:flex;align-items:center;justify-content:center;padding:6px 8px;border:1px solid var(--border-primary);border-radius:6px;background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all .15s}.report-flag-btn:hover{color:#ef4444;border-color:#ef4444}.report-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:10000;display:flex;align-items:center;justify-content:center;padding:16px}.report-modal{background:var(--bg-primary);border-radius:14px;width:100%;max-width:420px;padding:20px;box-shadow:0 20px 60px #0000004d}.report-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.report-modal-header h3{margin:0;font-size:17px}.report-modal-close{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px}.report-modal-subtitle{font-size:13px;color:var(--text-secondary);margin:0 0 10px}.report-category-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}.report-cat-btn{display:flex;align-items:center;gap:8px;padding:10px 12px;border:2px solid var(--border-primary);border-radius:10px;background:var(--bg-secondary);cursor:pointer;font-size:12px;font-weight:500;color:var(--text-primary);transition:all .15s}.report-cat-btn:hover{border-color:var(--text-secondary)}.report-cat-btn.active{font-weight:600}.report-desc-wrap{position:relative;margin-bottom:12px}.report-desc{width:100%;padding:10px 12px;border:1px solid var(--border-primary);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:13px;resize:vertical;font-family:inherit}.report-char-count{position:absolute;bottom:8px;right:10px;font-size:10px;color:var(--text-muted)}.report-error{color:#ef4444;font-size:13px;margin:0 0 10px}.report-submit-btn{width:100%;padding:10px;border:none;border-radius:8px;background:#2563eb;color:#fff;font-size:14px;font-weight:600;cursor:pointer}.report-submit-btn:disabled{opacity:.5;cursor:not-allowed}.report-submit-btn:hover:not(:disabled){background:#1d4ed8}.report-login-prompt{text-align:center;padding:16px 0}.report-login-prompt p{margin:0 0 12px;font-size:13px;color:var(--text-secondary)}.report-login-btn{padding:8px 24px;border:none;border-radius:8px;background:#2563eb;color:#fff;font-size:13px;font-weight:600;cursor:pointer}.reports-list{display:flex;flex-direction:column;gap:8px}.report-card{padding:10px 12px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-primary)}.report-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.report-cat-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}.report-time{font-size:11px;color:var(--text-muted)}.report-desc-text{font-size:12px;color:var(--text-secondary);margin:4px 0;line-height:1.4}.report-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:6px}.report-author{font-size:11px;color:var(--text-muted)}.report-actions{display:flex;align-items:center;gap:6px}.report-confirm-btn,.report-confirm-count{display:flex;align-items:center;gap:4px;padding:3px 8px;border:1px solid var(--border-primary);border-radius:6px;background:none;color:var(--text-secondary);font-size:12px;cursor:pointer}.report-confirm-count{cursor:default}.report-confirm-btn:hover{background:var(--bg-hover-accent)}.report-confirm-btn.confirmed{color:#2563eb;border-color:#2563eb;background:#2563eb14}.report-delete-btn{display:flex;align-items:center;padding:3px 6px;border:none;border-radius:6px;background:none;color:var(--text-muted);cursor:pointer}.report-delete-btn:hover{color:#ef4444;background:#ef444414}.theme-toggle{background:none;border:none;cursor:pointer;color:#94a3b8;padding:4px;line-height:0;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;transition:color .2s,background .2s}.theme-toggle:hover{color:#facc15;background:#ffffff1a}.theme-toggle svg{display:block}.route-delay-stats{padding:12px 0}.delay-stats-row{display:flex;gap:12px;margin-bottom:10px}.delay-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 6px;background:var(--bg-tertiary);border-radius:8px}.delay-stat-value{font-size:20px;font-weight:700;color:var(--text-primary)}.delay-stat-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--text-muted)}.delay-stat-value.on-time{color:#16a34a}.delay-stat-value.late{color:#dc2626}.delay-stat-value.early{color:#2563eb}.delay-breakdown{display:flex;height:6px;border-radius:3px;overflow:hidden;background:var(--bg-hover)}.delay-breakdown-on-time{background:#16a34a}.delay-breakdown-late{background:#dc2626}.delay-breakdown-early{background:#2563eb}.delay-avg{text-align:center;font-size:13px;font-weight:600;color:var(--text-secondary);margin-top:8px}.delay-avg-value{font-weight:700}.delay-avg-value.on-time{color:#16a34a}.delay-avg-value.late{color:#dc2626}.delay-avg-value.early{color:#2563eb}.playback-bar{position:fixed;bottom:16px;left:50%;transform:translate(-50%);z-index:800;display:flex;align-items:center;gap:8px;background:var(--bg-primary);border-radius:12px;box-shadow:0 2px 12px #0003;padding:8px 12px;max-width:calc(100vw - 32px);animation:slideUp .15s ease-out}.playback-btn{width:32px;height:32px;border:1px solid var(--border-default);border-radius:8px;background:var(--bg-tertiary);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);flex-shrink:0}.playback-btn:hover{background:var(--bg-hover)}.playback-btn.active{background:#2563eb;border-color:#2563eb;color:#fff}.playback-btn-stop{background:transparent;border-color:#ef4444;color:#ef4444}.playback-btn-stop:hover{background:#fef2f2}[data-theme=dark] .playback-btn-stop:hover{background:#451a1a}.playback-speed{font-size:11px;font-weight:700;min-width:36px;text-align:center;color:var(--text-secondary);cursor:pointer;padding:4px 6px;border:1px solid var(--border-default);border-radius:6px;background:var(--bg-tertiary);flex-shrink:0}.playback-speed:hover{background:var(--bg-hover)}.playback-scrubber{flex:1;min-width:100px;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border-default);border-radius:3px;outline:none;cursor:pointer}.playback-scrubber::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#2563eb;border:2px solid #fff;box-shadow:0 1px 3px #0003;cursor:grab}.playback-scrubber::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#2563eb;border:2px solid #fff;box-shadow:0 1px 3px #0003;cursor:grab}.playback-time{font-size:12px;font-weight:600;color:var(--text-secondary);white-space:nowrap;font-variant-numeric:tabular-nums;min-width:60px;text-align:center;flex-shrink:0}.playback-route-badge{color:#fff;font-weight:700;font-size:12px;padding:2px 8px;border-radius:4px;flex-shrink:0}.replay-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:600;border:1px solid #38bdf8;border-radius:6px;background:transparent;color:#38bdf8;cursor:pointer;margin:8px 0}.replay-btn:hover{background:#f0f9ff}[data-theme=dark] .replay-btn:hover{background:#0c2d48}.ghost-bus-marker{transition:none}@media (max-width: 640px){.playback-bar{bottom:12px;left:12px;right:12px;transform:none;max-width:none;gap:6px;padding:8px}.playback-scrubber{min-width:60px}.playback-route-badge{display:none}}.pro-badge{display:inline-block;padding:1px 5px;font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-radius:3px;vertical-align:middle;margin-left:4px}.replay-btn-locked{opacity:.6;text-decoration:none;color:var(--text-secondary);cursor:pointer}.replay-btn-locked:hover{opacity:.8}.upload-btn-locked{text-decoration:none;opacity:.7}.upload-btn-locked:hover{opacity:.9}.subscription-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;padding:16px 20px}.subscription-status{display:flex;align-items:center;gap:10px;margin-bottom:8px}.subscription-badge{display:inline-block;padding:3px 10px;font-size:12px;font-weight:700;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.subscription-badge-pro{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.subscription-badge-free{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.subscription-label{font-size:13px;color:var(--text-secondary)}.subscription-renew{font-size:13px;color:var(--text-secondary);margin:4px 0 12px}.subscription-upsell{font-size:13px;color:var(--text-secondary);margin:4px 0 12px;line-height:1.4}.subscription-manage-btn{padding:8px 16px;font-size:13px;font-weight:600;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer}.subscription-manage-btn:hover{background:var(--bg-tertiary)}.subscription-upgrade-btn{display:inline-block;padding:8px 16px;font-size:13px;font-weight:600;border-radius:6px;background:#2563eb;color:#fff;text-decoration:none;cursor:pointer}.subscription-upgrade-btn:hover{background:#1d4ed8}.pricing-page{min-height:100vh;background:var(--bg-primary);color:var(--text-primary);padding:40px 16px}.pricing-container{max-width:800px;margin:0 auto}.pricing-header{text-align:center;margin-bottom:32px}.pricing-header h1{font-size:28px;margin:12px 0 8px}.pricing-subtitle{font-size:15px;color:var(--text-secondary)}.pricing-toggle-wrap{display:flex;justify-content:center;gap:4px;margin-bottom:28px;background:var(--bg-secondary);border-radius:8px;padding:4px;width:fit-content;margin-left:auto;margin-right:auto}.pricing-toggle-btn{padding:8px 18px;font-size:13px;font-weight:600;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s}.pricing-toggle-btn.active{background:var(--bg-primary);color:var(--text-primary);box-shadow:0 1px 3px #0000001a}.pricing-save-badge{font-size:10px;font-weight:700;color:#16a34a;margin-left:4px}.pricing-cards{display:grid;grid-template-columns:1fr 1fr;gap:20px}.pricing-card{position:relative;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:28px 24px}.pricing-card-pro{border-color:#2563eb;border-width:2px;box-shadow:0 4px 20px #2563eb1f}.pricing-card-popular{position:absolute;top:-11px;left:50%;transform:translate(-50%);background:#2563eb;color:#fff;font-size:11px;font-weight:700;padding:3px 12px;border-radius:10px;text-transform:uppercase;letter-spacing:.5px}.pricing-card-header{margin-bottom:20px}.pricing-card-header h2{font-size:20px;margin:0 0 8px}.pricing-price{display:flex;align-items:baseline;gap:2px}.pricing-amount{font-size:36px;font-weight:800;line-height:1}.pricing-period{font-size:14px;color:var(--text-secondary)}.pricing-feature-list{list-style:none;padding:0;margin:0 0 24px}.pricing-feature-list li{font-size:13px;padding:6px 0 6px 22px;position:relative}.pricing-feature-yes:before{content:"✓";position:absolute;left:0;color:#16a34a;font-weight:700}.pricing-feature-no:before{content:"✗";position:absolute;left:0;color:var(--text-muted, #94a3b8)}.pricing-feature-no{color:var(--text-muted, #94a3b8)}.pricing-btn{display:block;width:100%;padding:12px;font-size:14px;font-weight:600;border:none;border-radius:8px;cursor:pointer;text-align:center;text-decoration:none;transition:background .15s}.pricing-btn-free{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.pricing-btn-free:hover{background:var(--bg-secondary)}.pricing-btn-pro{background:#2563eb;color:#fff}.pricing-btn-pro:hover{background:#1d4ed8}.pricing-btn-pro:disabled{opacity:.6;cursor:not-allowed}.pricing-btn-manage{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color)}.pricing-btn-manage:hover{background:var(--bg-tertiary)}.pricing-current-badge{text-align:center;padding:12px;font-size:13px;font-weight:600;color:var(--text-secondary);background:var(--bg-tertiary);border-radius:8px}.pricing-error{color:#ef4444;font-size:12px;margin-bottom:8px}@media (max-width: 640px){.pricing-cards{grid-template-columns:1fr}.pricing-header h1{font-size:22px}.pricing-amount{font-size:28px}}.commutes-page{min-height:100vh;background:#0f172a;padding:20px}.commutes-container{max-width:720px;margin:0 auto}.commutes-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.commutes-header h1{font-size:22px;font-weight:700;color:#f1f5f9;margin:0}.commutes-pro-gate{text-align:center;padding:60px 20px;color:#94a3b8}.commutes-pro-gate h2{color:#f1f5f9;font-size:22px;margin:16px 0 8px}.commutes-pro-gate p{font-size:14px;line-height:1.5;max-width:400px;margin:0 auto 20px}.commutes-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid #334155}.commutes-tab{padding:8px 20px;background:none;border:none;color:#94a3b8;font-size:14px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;font-weight:500;transition:color .15s}.commutes-tab:hover{color:#e2e8f0}.commutes-tab.active{color:#3b82f6;border-bottom-color:#3b82f6}.trip-form{display:grid;grid-template-columns:1fr 1fr;gap:16px;background:#1e293b;border-radius:10px;padding:20px}.trip-form-field{display:flex;flex-direction:column;gap:4px}.trip-form-field label{font-size:12px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.3px}.trip-form-field input,.trip-form-field select,.trip-form-field textarea{padding:9px 12px;border:1px solid #334155;border-radius:6px;background:#0f172a;color:#f1f5f9;font-size:14px;outline:none;font-family:inherit}.trip-form-field input:focus,.trip-form-field select:focus,.trip-form-field textarea:focus{border-color:#3b82f6}.trip-form-field textarea{resize:vertical}.trip-form-full{grid-column:1 / -1}.trip-form-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.trip-selected-badge{font-size:12px;color:#3b82f6;margin-top:2px;font-weight:500}.trip-submit-btn{padding:10px 28px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.trip-submit-btn:hover{background:#2563eb}.trip-submit-btn:disabled{opacity:.6;cursor:not-allowed}.trip-error{color:#ef4444;font-size:13px;margin:0}.trip-success{color:#22c55e;font-size:13px;margin:0}.trip-search-dropdown{position:absolute;top:100%;left:0;right:0;z-index:100;background:#1e293b;border:1px solid #334155;border-radius:8px;margin-top:4px;list-style:none;padding:4px;box-shadow:0 8px 24px #0000004d;max-height:200px;overflow-y:auto}.trip-search-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;cursor:pointer;font-size:13px;color:#e2e8f0;transition:background .1s}.trip-search-item:hover{background:#334155}.trip-history-table{width:100%;border-collapse:collapse;font-size:13px}.trip-history-table th{text-align:left;padding:8px 10px;border-bottom:1px solid #334155;color:#94a3b8;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.3px}.trip-history-table td{padding:10px;border-bottom:1px solid #1e293b;color:#e2e8f0}.trip-history-table tr:hover{background:#3b82f60a}.trip-delay-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;white-space:nowrap}.trip-delay-on_time{background:#22c55e26;color:#22c55e}.trip-delay-late{background:#ef444426;color:#ef4444}.trip-delay-early{background:#3b82f626;color:#3b82f6}.trip-delete-btn{background:none;border:1px solid #475569;color:#94a3b8;border-radius:4px;padding:2px 8px;font-size:12px;cursor:pointer;transition:all .15s}.trip-delete-btn:hover{border-color:#ef4444;color:#ef4444}.trip-load-more{display:block;width:100%;padding:10px;margin-top:12px;background:#1e293b;border:1px solid #334155;color:#3b82f6;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500}.trip-load-more:hover{background:#334155}.commutes-muted{color:#94a3b8;font-size:14px;padding:20px 0;text-align:center}.commutes-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.commutes-stat-card{background:#1e293b;border-radius:10px;padding:18px 14px;text-align:center;border:1px solid #334155}.commutes-stat-value{font-size:28px;font-weight:700;color:#f1f5f9;margin-bottom:2px}.commutes-stat-label{font-size:11px;color:#94a3b8;text-transform:uppercase;letter-spacing:.3px;font-weight:600}.commutes-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.commutes-chart-card{background:#1e293b;border-radius:10px;padding:16px;border:1px solid #334155}.commutes-chart-title{font-size:13px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.3px;margin:0 0 12px}@media (max-width: 640px){.trip-form,.commutes-stats-grid,.commutes-charts-grid{grid-template-columns:1fr}.trip-history-table th:nth-child(4),.trip-history-table td:nth-child(4){display:none}.commutes-header{flex-direction:column;gap:10px;align-items:flex-start}}.stats-page{min-height:100vh;background:var(--bg-secondary);padding:20px}.stats-container{max-width:960px;margin:0 auto}.stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.stats-header h1{font-size:22px;font-weight:700;color:var(--text-primary);margin:0}.stats-subtitle{font-size:13px;color:var(--text-muted);margin:4px 0 0}.stats-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.stats-stat-card{background:var(--bg-primary);border-radius:10px;padding:18px 14px;text-align:center;border:1px solid var(--border-default)}.stats-stat-value{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:2px}.stats-stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;font-weight:600}.stats-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.stats-chart-card{background:var(--bg-primary);border-radius:10px;padding:16px;border:1px solid var(--border-default)}.stats-chart-card.stats-chart-wide{grid-column:1 / -1}.stats-chart-title{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin:0 0 12px}.stats-table{width:100%;border-collapse:collapse;font-size:13px}.stats-table th{text-align:left;font-weight:600;color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.3px;padding:6px 8px;border-bottom:1px solid var(--border-default)}.stats-table td{padding:8px;color:var(--text-secondary);border-bottom:1px solid var(--border-light)}.stats-table tr:last-child td{border-bottom:none}.stats-updated{text-align:center;font-size:12px;color:var(--text-muted);margin-top:20px}.stats-error{color:#ef4444;text-align:center;padding:40px 20px}@media (max-width: 768px){.stats-summary-grid{grid-template-columns:repeat(2,1fr)}.stats-charts-grid{grid-template-columns:1fr}.stats-chart-card.stats-chart-wide{grid-column:1}.stats-header{flex-direction:column;align-items:flex-start;gap:12px}}@media (max-width: 480px){.stats-summary-grid{grid-template-columns:1fr}}.tester-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:10000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.tester-modal{background:var(--bg-primary);border-radius:14px;padding:32px 28px;max-width:420px;width:90%;text-align:center;box-shadow:0 20px 60px #0000004d}.tester-icon{font-size:48px;margin-bottom:12px}.tester-modal h2{color:var(--text-primary);font-size:20px;font-weight:700;margin:0 0 12px}.tester-modal p{color:var(--text-secondary);font-size:14px;line-height:1.5;margin:0 0 8px}.tester-email{display:inline-block;background:var(--accent, #2563eb);color:#fff;font-size:15px;font-weight:700;padding:10px 24px;border-radius:8px;text-decoration:none;margin:14px 0 18px;transition:opacity .15s}.tester-email:hover{opacity:.85}.tester-dismiss{display:block;width:100%;background:none;border:none;color:var(--text-muted, #9ca3af);font-size:13px;cursor:pointer;padding:6px}.tester-dismiss:hover{color:var(--text-secondary)}.xp-toast{position:fixed;bottom:24px;right:24px;z-index:9999;background:var(--bg-primary);border:1px solid var(--border-default);border-radius:12px;padding:14px 20px;box-shadow:0 8px 32px #00000040;transform:translateY(120%);opacity:0;transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .3s;min-width:180px}.xp-toast-show{transform:translateY(0);opacity:1}.xp-toast-xp{font-size:22px;font-weight:800;color:#f59e0b;letter-spacing:-.3px}.xp-toast-label{font-size:13px;color:var(--text-secondary);margin-top:2px}.xp-toast-achievement{display:flex;align-items:center;gap:8px;margin-top:8px;padding:6px 10px;border:2px solid;border-radius:8px;background:var(--bg-secondary)}.xp-toast-ach-icon{font-size:18px}.xp-toast-ach-name{font-size:13px;font-weight:600;color:var(--text-primary);flex:1}.xp-toast-ach-xp{font-size:12px;font-weight:700;color:#f59e0b}.header-level-badge{display:inline-flex;align-items:center;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:11px;font-weight:800;padding:2px 8px;border-radius:4px;text-decoration:none;letter-spacing:.3px;margin-right:4px;transition:opacity .15s}.header-level-badge:hover{opacity:.85}.gam-account-card{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:12px;padding:20px}.gam-account-top{display:flex;align-items:center;gap:16px;margin-bottom:12px}.gam-account-level{display:flex;flex-direction:column;align-items:center;min-width:60px}.gam-level-number{font-size:28px;font-weight:800;color:#f59e0b;line-height:1}.gam-level-title{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin-top:2px}.gam-account-xp-wrap{flex:1}.gam-xp-bar{height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.gam-xp-fill{height:100%;background:linear-gradient(90deg,#f59e0b,#d97706);border-radius:4px;transition:width .5s ease}.gam-xp-text{font-size:12px;color:var(--text-muted);margin-top:4px;display:block}.gam-account-stats{display:flex;gap:16px;font-size:13px;color:var(--text-secondary);margin-bottom:12px}.gam-account-link{display:inline-block;font-size:13px;font-weight:600;color:#2563eb;text-decoration:none}.gam-account-link:hover{text-decoration:underline}.gam-howto{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:12px;margin-bottom:16px}.gam-howto-toggle{padding:14px 20px;font-size:14px;font-weight:700;color:var(--text-primary);cursor:pointer;list-style:none}.gam-howto-toggle::-webkit-details-marker{display:none}.gam-howto-toggle:before{content:"▶";display:inline-block;margin-right:8px;font-size:10px;transition:transform .15s}.gam-howto[open] .gam-howto-toggle:before{transform:rotate(90deg)}.gam-howto-body{padding:0 20px 16px;font-size:13px;color:var(--text-secondary);line-height:1.6}.gam-howto-body p{margin:0 0 10px}.gam-howto-table{width:100%;border-collapse:collapse;margin:10px 0;font-size:13px}.gam-howto-table th{text-align:left;font-weight:600;color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.3px;padding:6px 8px;border-bottom:1px solid var(--border-default)}.gam-howto-table td{padding:6px 8px;border-bottom:1px solid var(--border-light);color:var(--text-secondary)}.gam-howto-table td:nth-child(2){font-weight:700;color:#f59e0b;white-space:nowrap}.gam-hero{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:12px;padding:24px;margin-bottom:20px}.gam-hero-level{display:flex;align-items:baseline;gap:12px;margin-bottom:12px}.gam-hero-xp{margin-bottom:16px}.gam-xp-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--text-muted);margin-top:4px}.gam-hero-stats{display:flex;gap:24px;flex-wrap:wrap}.gam-stat{display:flex;flex-direction:column;align-items:center}.gam-stat-num{font-size:20px;font-weight:700;color:var(--text-primary)}.gam-stat-lbl{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.gam-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--border-default);padding-bottom:0}.gam-tab{background:none;border:none;border-bottom:2px solid transparent;padding:8px 16px;font-size:14px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:color .15s,border-color .15s}.gam-tab:hover{color:var(--text-secondary)}.gam-tab.active{color:#f59e0b;border-bottom-color:#f59e0b}.gam-cat-filter{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}.gam-cat-btn{background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:16px;padding:4px 12px;font-size:12px;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}.gam-cat-btn:hover{background:var(--bg-secondary)}.gam-cat-btn.active{background:#f59e0b;color:#fff;border-color:#f59e0b}.gam-badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.gam-badge-card{background:var(--bg-secondary);border:2px solid var(--border-default);border-radius:10px;padding:16px 12px;text-align:center;transition:transform .15s,box-shadow .15s}.gam-badge-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-card)}.gam-badge-card.locked{opacity:.4;filter:grayscale(.8);border-color:var(--border-light)}.gam-badge-icon{display:block;font-size:32px;margin-bottom:6px}.gam-badge-name{display:block;font-size:13px;font-weight:700;color:var(--text-primary);margin-bottom:2px}.gam-badge-desc{display:block;font-size:11px;color:var(--text-muted);margin-bottom:4px}.gam-badge-rarity{display:block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.gam-badge-date{display:block;font-size:10px;color:var(--text-muted);margin-top:4px}.gam-lb-controls{display:flex;gap:8px;margin-bottom:12px}.gam-lb-controls select{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:6px;padding:6px 10px;font-size:13px;color:var(--text-primary);cursor:pointer}.gam-lb-table{width:100%;border-collapse:collapse;font-size:13px}.gam-lb-table th{text-align:left;font-weight:600;color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.3px;padding:6px 8px;border-bottom:1px solid var(--border-default)}.gam-lb-table td{padding:8px;color:var(--text-secondary);border-bottom:1px solid var(--border-light)}.gam-lb-top1 td{color:#f59e0b;font-weight:700}.gam-lb-top2 td{color:#94a3b8;font-weight:600}.gam-lb-top3 td{color:#cd7f32;font-weight:600}.gam-lb-level{background:var(--bg-tertiary);padding:1px 6px;border-radius:4px;font-size:11px;font-weight:700;color:var(--text-muted)}.gam-lb-you{padding:12px 0;font-size:14px;color:var(--text-secondary);text-align:center;border-top:1px solid var(--border-default);margin-top:4px}.gam-special-grid{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}.gam-special-card{display:flex;align-items:center;gap:8px;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:8px;padding:8px 14px;font-size:13px;color:var(--text-primary)}.gam-special-card.locked{opacity:.4;filter:grayscale(.6)}.gam-special-icon{font-size:18px}.gam-special-check{color:#22c55e;font-weight:700}.gam-operator-list{display:flex;flex-direction:column;gap:4px}.gam-operator-row{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:var(--bg-secondary);border-radius:6px}.gam-operator-name{font-size:13px;font-weight:600;color:var(--text-primary)}.gam-operator-count{font-size:12px;color:var(--text-muted)}@media (max-width: 768px){.gam-badge-grid{grid-template-columns:repeat(2,1fr)}.gam-hero-stats{gap:12px}.xp-toast{right:12px;bottom:12px;left:12px;min-width:auto}}
