:root{--bg-primary: #ffffff;--bg-secondary: #f4f7fb;--bg-card: #ffffff;--bg-card-hover: #f8fafc;--bg-elevated: #ffffff;--accent-blue: #0d59f2;--accent-blue-dark: #003b5c;--accent-blue-light: #eff4ff;--accent-blue-glow: rgba(13, 89, 242, .15);--accent-orange: #f27b1d;--accent-orange-light: #fff3e0;--accent-orange-glow: rgba(242, 123, 29, .15);--accent-green: #10b981;--accent-red: #ef4444;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--text-inverse: #ffffff;--border-subtle: #e2e8f0;--border-medium: #cbd5e1;--border-accent: rgba(13, 89, 242, .3);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 999px;--shadow-sm: 0 1px 3px rgba(15, 23, 42, .05);--shadow-md: 0 4px 12px rgba(15, 23, 42, .05);--shadow-lg: 0 10px 30px rgba(15, 23, 42, .08);--shadow-glow-blue: 0 0 20px rgba(13, 89, 242, .2);--shadow-glow-orange: 0 0 20px rgba(242, 123, 29, .2);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{display:flex;flex-direction:column;height:100%;width:100%;position:relative;background:var(--bg-primary);overflow:hidden}.header{padding:16px 24px;display:flex;align-items:center;justify-content:space-between;z-index:50;background:var(--bg-primary);border-bottom:1px solid var(--border-subtle)}.header-logo{display:flex;align-items:center;gap:12px}.header-logo-icon{width:36px;height:36px;background:var(--accent-blue-dark);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:#fff;box-shadow:var(--shadow-sm)}.header-logo h1{font-size:20px;font-weight:800;color:var(--accent-blue-dark);letter-spacing:-.5px}.header-actions{display:flex;align-items:center;gap:8px}.header-btn{width:38px;height:38px;border-radius:var(--radius-full);border:1px solid var(--border-subtle);background:var(--bg-card);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-normal)}.header-btn:hover{background:var(--bg-secondary);color:var(--accent-blue);border-color:var(--border-medium)}.app-content{display:flex;flex:1;overflow:hidden;position:relative}.app-sidebar{width:100%;display:flex;flex-direction:column;background:var(--bg-primary);z-index:10}.app-main{width:100%;display:flex;flex-direction:column;background:var(--bg-secondary);position:absolute;inset:0;z-index:5}@media(min-width:768px){.app-sidebar{width:380px;border-right:1px solid var(--border-subtle);position:relative;box-shadow:var(--shadow-md)}.app-main{position:relative;flex:1}.mobile-only{display:none!important}.app-sidebar.mobile-hidden,.app-main.mobile-hidden{display:flex}}@media(max-width:767px){.desktop-only{display:none!important}.app-sidebar.mobile-hidden,.app-main.mobile-hidden{display:none}}.sidebar-nav{display:flex;padding:16px 20px 0;gap:8px;border-bottom:1px solid var(--border-subtle);background:var(--bg-primary)}.sidebar-tab{padding:12px 16px;font-size:14px;font-weight:600;color:var(--text-secondary);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all var(--transition-normal)}.sidebar-tab.active{color:var(--accent-blue);border-bottom-color:var(--accent-blue)}.sidebar-tab:hover:not(.active){color:var(--text-primary);background:var(--bg-secondary);border-radius:var(--radius-sm) var(--radius-sm) 0 0}.service-badge{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-full);font-size:13px;font-weight:600;width:fit-content;transition:all var(--transition-normal);box-shadow:var(--shadow-sm)}.service-badge.active{background:var(--bg-card);border-color:#0d59f233;color:var(--accent-blue-dark)}.service-badge.inactive{background:var(--bg-card);border-color:#ef444433}.service-badge-dot{width:8px;height:8px;border-radius:50%;animation:pulse-dot 2s ease-in-out infinite}.service-badge.active .service-badge-dot{background:var(--accent-blue);box-shadow:0 0 8px #0d59f280}.service-badge.inactive .service-badge-dot{background:var(--accent-red);box-shadow:0 0 8px #ef444480}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}}.map-section{flex:1;position:relative;width:100%;height:100%}.map-container{height:100%;width:100%}.map-container .leaflet-container{height:100%;width:100%;background:var(--bg-secondary)}.leaflet-control-zoom{border:none!important;box-shadow:var(--shadow-md)!important}.leaflet-control-zoom a{background:var(--bg-card)!important;color:var(--text-primary)!important;border:1px solid var(--border-subtle)!important;width:36px!important;height:36px!important;line-height:36px!important;font-size:16px!important}.leaflet-control-zoom a:hover{background:var(--bg-card-hover)!important}.leaflet-control-attribution{display:none!important}.bus-marker{background:none;border:none}.bus-marker-inner{width:48px;height:48px;background:var(--accent-blue-dark);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 4px #003b5c33,var(--shadow-lg);animation:bus-pulse 2s ease-in-out infinite;position:relative}.bus-marker-inner:after{content:"";position:absolute;width:100%;height:100%;border-radius:50%;border:2px solid rgba(0,59,92,.4);animation:bus-ring 2s ease-out infinite}.bus-marker-inner .material-symbols-rounded{font-size:26px;color:#fff}@keyframes bus-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes bus-ring{0%{transform:scale(1);opacity:1}to{transform:scale(1.8);opacity:0}}.stop-marker-inner{width:32px;height:32px;background:var(--bg-card);border:2px solid var(--accent-blue-dark);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);transition:all var(--transition-normal)}.stop-marker-inner.active-stop{background:var(--accent-orange);border-color:#fff;box-shadow:var(--shadow-lg),var(--shadow-glow-orange);transform:scale(1.15)}.stop-marker-inner .material-symbols-rounded{font-size:16px;color:var(--accent-blue-dark)}.stop-marker-inner.active-stop .material-symbols-rounded{color:#fff}.stop-popup .leaflet-popup-content-wrapper{background:var(--bg-card)!important;color:var(--text-primary)!important;border-radius:var(--radius-lg)!important;border:1px solid var(--border-subtle)!important;box-shadow:var(--shadow-lg)!important;padding:0!important}.stop-popup .leaflet-popup-tip{background:var(--bg-card)!important;border:1px solid var(--border-subtle)!important}.stop-popup .leaflet-popup-content{margin:16px!important;font-family:Inter,sans-serif!important}.info-overlay{position:absolute;bottom:24px;left:24px;right:24px;z-index:600;pointer-events:none}@media(min-width:768px){.info-overlay{bottom:32px;left:50%;right:auto;transform:translate(-50%);width:380px}}@media(max-width:767px){.info-overlay{bottom:80px}}.next-stop-card{background:#fffffff2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-lg);pointer-events:all;transition:all var(--transition-slow)}.next-stop-label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--accent-orange);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.next-stop-name{font-size:22px;font-weight:800;color:var(--accent-blue-dark);margin-bottom:4px;letter-spacing:-.5px}.next-stop-campus{font-size:13px;color:var(--text-secondary);margin-bottom:16px}.next-stop-eta-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.eta-info{display:flex;align-items:center;gap:12px}.eta-icon{width:36px;height:36px;background:var(--accent-blue-light);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.eta-icon .material-symbols-rounded{font-size:20px;color:var(--accent-blue)}.eta-text span:first-child{font-size:12px;color:var(--text-secondary);font-weight:500;display:block}.eta-text span:last-child{font-size:15px;font-weight:800;color:var(--text-primary)}.eta-badge{padding:6px 14px;border-radius:var(--radius-full);font-size:14px;font-weight:800;display:flex;align-items:center;gap:6px}.eta-badge.arriving{background:#ecfdf5;color:var(--accent-green);border:1px solid #a7f3d0}.eta-badge.en-route{background:var(--accent-blue-light);color:var(--accent-blue);border:1px solid #bfdbfe}.bottom-nav{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:space-around;padding:12px 20px 24px;background:#ffffffe6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-top:1px solid var(--border-subtle);z-index:700}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;padding:8px 16px;border-radius:var(--radius-md);border:none;background:none;color:var(--text-muted);transition:all var(--transition-normal)}.nav-item.active{color:var(--accent-blue)}.nav-item.active .material-symbols-rounded{font-variation-settings:"FILL" 1}.nav-item:hover{color:var(--accent-blue-dark)}.nav-item .material-symbols-rounded{font-size:26px}.nav-item span:last-child{font-size:11px;font-weight:700}.panel-container{flex:1;overflow-y:auto;padding:24px}.timeline-header{margin-bottom:24px}.timeline-header h2{font-size:24px;font-weight:800;color:var(--accent-blue-dark);margin-bottom:6px;letter-spacing:-.5px}.timeline-header p{font-size:14px;color:var(--text-secondary)}.timeline-list{display:flex;flex-direction:column;position:relative}.timeline-item{display:flex;gap:16px;position:relative;padding:0 0 24px}.timeline-connector{display:flex;flex-direction:column;align-items:center;width:36px;flex-shrink:0}.timeline-dot{width:16px;height:16px;border-radius:50%;border:3px solid var(--border-medium);background:var(--bg-primary);z-index:2;transition:all var(--transition-normal)}.timeline-item.arrived .timeline-dot{background:var(--accent-green);border-color:var(--accent-green);box-shadow:0 0 0 4px #ecfdf5}.timeline-item.next .timeline-dot{background:var(--accent-orange);border-color:var(--accent-orange);box-shadow:0 0 0 4px #fff3e0;animation:pulse-dot 2s infinite}.timeline-line{width:2px;flex:1;background:var(--border-subtle);margin-top:4px}.timeline-item.arrived .timeline-line{background:var(--accent-green)}.timeline-content{flex:1}.timeline-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm);transition:all var(--transition-normal)}.timeline-item:hover .timeline-card{border-color:var(--border-medium);box-shadow:var(--shadow-md)}.timeline-item.next .timeline-card{border-color:var(--accent-orange);background:#fffaf5}.timeline-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.timeline-stop-name{font-size:16px;font-weight:800;color:var(--text-primary)}.timeline-stop-fav{width:32px;height:32px;border-radius:50%;border:none;background:var(--bg-secondary);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.timeline-stop-fav:hover,.timeline-stop-fav.favorited{color:var(--accent-orange);background:var(--accent-orange-light)}.timeline-stop-fav .material-symbols-rounded{font-size:20px}.timeline-stop-detail{font-size:13px;color:var(--text-secondary);margin-bottom:12px}.timeline-eta-row{display:flex;align-items:center;justify-content:space-between}.timeline-eta-time{font-size:14px;font-weight:700;color:var(--text-primary)}.timeline-eta-badge{padding:4px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:800}.timeline-eta-badge.arrived{background:#ecfdf5;color:var(--accent-green)}.timeline-eta-badge.soon{background:#fff3e0;color:var(--accent-orange)}.timeline-eta-badge.later{background:var(--bg-secondary);color:var(--text-secondary)}.favorites-panel.centered{text-align:center;max-width:600px;margin:0 auto}.favorites-panel.centered .timeline-header{margin-bottom:40px}.favorites-empty{padding:60px 20px;display:flex;flex-direction:column;align-items:center;gap:16px}.favorites-empty-icon{width:80px;height:80px;background:var(--accent-orange-light);color:var(--accent-orange);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:8px;font-size:40px;box-shadow:var(--shadow-glow-orange)}.favorites-empty h3{font-size:20px;font-weight:800;color:var(--accent-blue-dark)}.favorites-empty p{color:var(--text-secondary);max-width:280px;line-height:1.5}.favorite-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:24px;margin-bottom:24px;box-shadow:var(--shadow-md);transition:all var(--transition-slow);position:relative;overflow:hidden}.favorites-panel.centered .favorite-card{display:flex;flex-direction:column;align-items:center}.favorite-card:hover{transform:translateY(-4px);border-color:var(--accent-blue-dark);box-shadow:var(--shadow-lg)}.favorite-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--accent-orange);opacity:.8}.favorites-panel.centered .favorite-card:before{width:100%;height:4px;top:0;left:0}.favorite-card-header{display:flex;align-items:center;justify-content:space-between;width:100%;margin-bottom:20px}.favorites-panel.centered .favorite-card-header{flex-direction:column;gap:12px}.favorite-card-name{font-size:20px;font-weight:800;color:var(--accent-blue-dark);letter-spacing:-.5px}.favorite-remove-btn{background:var(--bg-secondary);border:none;color:var(--text-muted);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.favorite-remove-btn:hover{color:var(--accent-red);background:#fef2f2}.favorite-eta-bar{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--bg-secondary);border-radius:var(--radius-lg);width:100%;border:1px solid var(--border-subtle)}.favorites-panel.centered .favorite-eta-bar{flex-direction:column;text-align:center;padding:20px}.favorite-eta-icon{width:48px;height:48px;background:#fff;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);flex-shrink:0}.favorite-eta-icon .material-symbols-rounded{font-size:28px;color:var(--accent-blue)}.favorite-eta-text{flex:1}.favorite-eta-text .label{font-size:13px;color:var(--text-secondary);font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.favorite-eta-text .value{font-size:18px;font-weight:800;color:var(--text-primary)}.favorite-status-icon{display:flex;align-items:center;justify-content:center}.admin-section{margin-bottom:32px}.admin-section-title{font-size:14px;font-weight:800;color:var(--accent-blue-dark);text-transform:uppercase;letter-spacing:1px;margin-bottom:16px}.stat-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}.stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm)}.stat-card-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:12px}.stat-card-icon.blue{background:var(--accent-blue-light);color:var(--accent-blue)}.stat-card-icon.orange{background:var(--accent-orange-light);color:var(--accent-orange)}.stat-card-icon.green{background:#ecfdf5;color:var(--accent-green)}.stat-card-icon.red{background:#fef2f2;color:var(--accent-red)}.stat-card-value{font-size:24px;font-weight:800;color:var(--text-primary);margin-bottom:4px}.stat-card-label{font-size:13px;color:var(--text-secondary);font-weight:500}.cost-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}.cost-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.cost-card-title{font-weight:800;font-size:16px}.cost-card-period{font-size:12px;background:var(--bg-secondary);padding:6px 12px;border-radius:var(--radius-full);font-weight:700;color:var(--text-secondary)}.slider-container{margin-bottom:16px}.slider-label{display:flex;justify-content:space-between;margin-bottom:12px}.slider-label span:first-child{font-weight:600;color:var(--text-secondary)}.slider-label span:last-child{font-weight:800;color:var(--accent-blue);font-size:18px}.slider-input{width:100%;height:8px;border-radius:4px;background:var(--bg-secondary);outline:none;-webkit-appearance:none;appearance:none}.slider-input::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;border-radius:50%;background:var(--accent-blue);cursor:pointer;box-shadow:var(--shadow-sm);border:2px solid white}.cost-bar-chart{display:flex;align-items:flex-end;gap:8px;height:140px;margin-bottom:16px}.cost-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.cost-bar{flex:1;width:100%;display:flex;flex-direction:column;justify-content:flex-end;margin-bottom:8px}.cost-bar-fill{width:100%;border-radius:6px 6px 2px 2px;transition:height var(--transition-slow)}.cost-bar-fill.blue{background:var(--accent-blue)}.cost-bar-fill.orange{background:var(--accent-orange)}.cost-bar-label{font-size:11px;color:var(--text-secondary);font-weight:700}table.frequency-table{width:100%;border-collapse:collapse}table.frequency-table th{text-align:left;padding:12px 16px;font-size:13px;font-weight:700;color:var(--text-secondary);border-bottom:2px solid var(--border-subtle)}table.frequency-table td{padding:14px 16px;font-size:14px;border-bottom:1px solid var(--border-subtle);color:var(--text-primary)}.frequency-badge{padding:4px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:800}.frequency-badge.high{background:#ecfdf5;color:var(--accent-green)}.frequency-badge.medium{background:#fff3e0;color:var(--accent-orange)}.frequency-badge.low{background:#fef2f2;color:var(--accent-red)}.notification-toast{position:fixed;top:80px;left:50%;transform:translate(-50%) translateY(-150%);width:calc(100% - 32px);max-width:400px;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-lg);z-index:1000;display:flex;align-items:center;gap:16px;transition:transform var(--transition-slow);pointer-events:none}.notification-toast.show{transform:translate(-50%) translateY(0);pointer-events:all}.notification-icon{width:44px;height:44px;background:var(--accent-orange-light);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.notification-icon .material-symbols-rounded{font-size:24px;color:var(--accent-orange)}.notification-title{font-size:15px;font-weight:800;color:var(--text-primary);margin-bottom:2px}.notification-body{font-size:13px;color:var(--text-secondary)}.animate-in{animation:fadeInUp .4s var(--transition-slow) both}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:var(--border-medium)}
