:root{--bg-color: #f8f9fa;--text-main: #1f2937;--text-sub: #6b7280;--sheet-bg: #ffffff;--sheet-border: rgba(0, 0, 0, .08);--accent: #BF1E2E;--accent-glow: rgba(191, 30, 46, .4);--secondary: #159BB3;--shadow: 0 4px 12px rgba(0, 0, 0, .08);--glass-blur: none;--font-main: "Outfit", sans-serif;--card-bg: #ffffff}.loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#fff,#f8f9fa);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .5s ease,visibility .5s ease}.loading-screen.hidden{opacity:0;visibility:hidden;pointer-events:none}.loading-content{text-align:center;animation:fadeInUp .6s ease-out}.loading-logo{width:150px;height:auto;margin-bottom:20px;animation:pulse-logo 2s infinite ease-in-out;filter:drop-shadow(0 4px 12px rgba(191,30,46,.3))}@keyframes pulse-logo{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.loading-title{font-size:1.8rem;font-weight:700;color:var(--text-main);margin-bottom:24px;letter-spacing:-.5px}.loading-spinner{width:50px;height:50px;margin:0 auto 16px;position:relative}.spinner-ring{width:100%;height:100%;border:4px solid rgba(191,30,46,.15);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:.95rem;color:var(--text-sub);font-weight:500}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;font-family:var(--font-main)}.text-danger{color:#ef4444!important;font-weight:600}.eta-inline{font-size:.75rem;font-weight:500;color:var(--text-sub);background:#0000000d;padding:2px 8px;border-radius:100px;margin-left:6px}.eta-inline i{color:var(--secondary)}body{overflow:hidden;background:var(--bg-color);height:100vh;width:100vw;transition:background .3s ease,color .3s ease}html{scroll-behavior:smooth}.floating-controls{position:fixed;top:16px;right:16px;z-index:100;display:flex;gap:8px}.admin-btn{width:44px;height:44px;background:var(--sheet-bg);border:1px solid var(--sheet-border);box-shadow:var(--shadow);color:var(--text-sub);transition:all .3s cubic-bezier(.4,0,.2,1)}.admin-btn:hover{background:var(--accent);color:#fff;transform:scale(1.05)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-enter{animation:fadeInUp .5s cubic-bezier(.16,1,.3,1) backwards}#map{position:absolute;top:0;left:0;width:100%;height:100dvh;z-index:0;transition:filter .3s ease}.mapboxgl-ctrl-logo,.mapboxgl-ctrl-attrib,.maplibregl-ctrl-logo,.maplibregl-ctrl-attrib{display:none!important}.toggle-sheet-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;margin-left:8px;border-radius:50%;background:#0000000d;z-index:20;cursor:pointer;border:none;font-size:1.2rem;transition:transform .3s ease}.floating-controls{position:absolute;top:50px;right:20px;display:flex;flex-direction:column;gap:12px;z-index:10}.fab-btn{width:44px;height:44px;border-radius:14px;border:1px solid var(--sheet-border);background:var(--sheet-bg);color:var(--text-main);box-shadow:var(--shadow);font-size:1.1rem;cursor:pointer;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.fab-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.fab-btn:active{transform:scale(.92)}.bottom-sheet{position:absolute;bottom:20px;left:20px;right:auto;width:380px;max-width:calc(100% - 40px);background:var(--sheet-bg);border:1px solid var(--sheet-border);border-radius:24px;box-shadow:var(--shadow);z-index:11;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);max-height:50vh;display:flex;flex-direction:column;overflow:hidden;transition:transform .3s ease,opacity .3s ease,bottom .3s ease}.bottom-sheet.collapsed{max-height:none!important;height:auto!important;padding-bottom:8px;transform:none!important;border-radius:28px;background:#fffffff2;box-shadow:0 10px 30px #00000026;bottom:25px}@media(max-width:768px){.bottom-sheet{bottom:100px;left:50%;transform:translate(-50%);width:90%;max-width:400px;right:auto;max-height:60vh}.bottom-sheet.collapsed{transform:translate(-50%)!important;left:50%;width:90%!important;max-width:400px;bottom:100px;right:auto}.bottom-sheet.hidden{transform:translate(-50%,150%)!important}}.bottom-sheet.collapsed .sheet-content{display:none!important;opacity:0;pointer-events:none}.bottom-sheet.collapsed .collapsed-summary{display:flex!important;font-size:.85rem;color:var(--text-sub);margin-top:4px;align-items:center;gap:6px;animation:fadeIn .4s ease-out .1s backwards}.bottom-sheet.hidden{transform:translate3d(0,150%,0)!important;pointer-events:none;opacity:0}.page-view{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-color);z-index:50;padding:20px;overflow-y:auto;display:none!important}.page-view.active-page{display:block!important}.page-view.hidden{transform:translate3d(100%,0,0)}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.bottom-sheet.collapsed .eta-badge{display:none}#toggleSheetBtn{transition:transform .3s ease}.bottom-sheet.collapsed #toggleSheetBtn{transform:rotate(180deg)}.gas-alert-popup{background:linear-gradient(145deg,#2b0306,#46050b)!important;border:1px solid rgba(255,59,81,.4)!important;box-shadow:0 0 50px #bf1e2e99!important;border-radius:28px!important;padding:40px 30px!important;max-width:400px!important}.gas-warning-icon{font-size:4rem;color:#ff4757;margin-bottom:16px;filter:drop-shadow(0 0 15px rgba(255,71,87,.5))}.gas-value-display{font-family:Outfit,sans-serif;font-size:4rem;font-weight:800;color:#fff;margin:8px 0;text-shadow:0 0 20px #BF1E2E;letter-spacing:-2px;line-height:1}.gas-alert-title{color:#fff!important;font-size:1.6rem!important;font-weight:800!important;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.gas-alert-text{color:#fffc!important;font-size:1rem!important;line-height:1.5;margin-top:10px}.gas-confirm-btn{margin-top:24px!important;padding:14px 32px!important;background:#ff4757!important;color:#fff!important;border-radius:100px!important;font-weight:700!important;font-size:.95rem!important;letter-spacing:1px;box-shadow:0 8px 20px #ff47574d!important;text-transform:uppercase;transition:transform .2s!important}.gas-confirm-btn:hover{transform:scale(1.05)!important;box-shadow:0 12px 25px #ff475780!important}@keyframes shake{0%{transform:rotate(0)}25%{transform:rotate(10deg)}50%{transform:rotate(-10deg)}75%{transform:rotate(5deg)}to{transform:rotate(0)}}@keyframes pulse-red-border{0%{box-shadow:0 0 #bf1e2eb3}70%{box-shadow:0 0 0 15px #bf1e2e00}to{box-shadow:0 0 #bf1e2e00}}.swal2-timer-progress-bar{background:#bf1e2e!important}.sheet-handle-bar{width:100%;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sheet-handle{width:32px;height:4px;background:#d1d5db;border-radius:10px;opacity:.5}.sheet-header{padding:0 24px 12px;flex-shrink:0}.header-text h1{font-size:1.5rem;font-weight:700;color:var(--text-main);display:flex;align-items:center;gap:10px;margin:0;letter-spacing:-.5px}.live-badge{font-size:.6rem;background:var(--accent);color:#fff;padding:4px 8px;border-radius:100px;font-weight:600;letter-spacing:.5px;box-shadow:0 0 10px var(--accent-glow);animation:pulse-badge 2s infinite}.eta-badge{margin-top:6px;font-size:.85rem;font-weight:500;color:#10b981;display:flex;align-items:center;gap:6px}.eta-badge.hidden{display:none}.chip{font-size:.8rem;padding:8px 16px;border-radius:100px;color:#fff;display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500;opacity:.7;border:1px solid transparent}.chip.active-route{opacity:1}.sheet-content{padding:0 24px 24px;overflow-y:auto;flex-grow:1}.sheet-content h3{font-size:.75rem;color:var(--text-sub);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;font-weight:600}.bus-item{display:flex;align-items:center;background:var(--card-bg);padding:12px;border-radius:16px;margin-bottom:12px;border:1px solid rgba(0,0,0,.03);cursor:pointer;position:relative;overflow:hidden}.bus-item.active-focus{border:2px solid var(--accent);background:#bf1e2e0d;box-shadow:0 4px 12px #bf1e2e26;transform:scale(1.02)}.bus-icon-wrapper{width:48px;height:48px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-right:16px;box-shadow:0 4px 12px #00000014}.bus-icon-wrapper img{width:32px;height:32px;object-fit:contain}.bus-info h4{font-size:1.05rem;margin-bottom:4px;color:var(--text-main);font-weight:600}.bus-info p{font-size:.85rem;color:var(--text-sub);margin:0}.status-dot{width:6px;height:6px;border-radius:50%;display:inline-block;vertical-align:middle;margin-left:6px;margin-bottom:2px}.dot-green{background:#10b981;box-shadow:0 0 8px #10b981}.dot-yellow{background:#f59e0b;box-shadow:0 0 8px #f59e0b;animation:blink 1.5s infinite}.dot-red{background:#ef4444;box-shadow:0 0 8px #ef4444;animation:blink 1s infinite}.dot-gray{background:#6b7280;box-shadow:0 0 8px #6b7280}.empty-state{text-align:center;padding:40px 20px;color:var(--text-sub);display:flex;flex-direction:column-reverse;align-items:center;gap:12px}.empty-state i{font-size:2.5rem;opacity:.4;color:var(--accent)}@keyframes pulse-badge{0%{box-shadow:0 0 0 0 var(--accent-glow)}70%{box-shadow:0 0 0 6px #bf1e2e00}to{box-shadow:0 0 #bf1e2e00}}@keyframes blink{50%{opacity:.5}}.marker-pulse{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;border-radius:50%;background:#bf1e2e4d;z-index:-1;animation:marker-ripple 2s infinite ease-out}@keyframes marker-ripple{0%{transform:translate(-50%,-50%) scale(.8);opacity:1}to{transform:translate(-50%,-50%) scale(2.5);opacity:0}}.mapboxgl-popup-content{background:var(--sheet-bg);border:1px solid var(--sheet-border);border-radius:16px;padding:0;box-shadow:var(--shadow);color:var(--text-main);overflow:hidden}.bus-popup{padding:16px;min-width:180px}.popup-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(0,0,0,.08)}.popup-icon{width:40px;height:40px;object-fit:contain}.popup-title h3{font-size:1.1rem;font-weight:700;margin:0;color:var(--text-main)}.popup-status{font-size:.75rem;padding:2px 8px;border-radius:100px;font-weight:600}.popup-status.status-moving{background:#10b98126;color:#059669}.popup-status.status-stopped{background:#6b728026;color:#6b7280}.popup-status.status-paused{background:#f59e0b26;color:#b45309}.popup-stats{display:flex;gap:16px}.popup-stat{display:flex;align-items:center;gap:6px;font-size:.9rem;color:var(--text-sub)}.popup-stat i{color:var(--secondary)}.popup-stat.popup-danger,.popup-stat.popup-danger i{color:#ef4444}.mapboxgl-popup-tip{border-top-color:var(--sheet-bg)}.mapboxgl-popup-close-button,.maplibregl-popup-close-button{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:#0000000f;border:none;font-size:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);z-index:10}.mapboxgl-popup-close-button:before,.maplibregl-popup-close-button:before{content:"×";font-size:18px;font-weight:600;color:var(--text-sub);line-height:1;transition:color .2s ease}.mapboxgl-popup-close-button:hover,.maplibregl-popup-close-button:hover{background:var(--accent);transform:scale(1.1);box-shadow:0 2px 8px #bf1e2e4d}.mapboxgl-popup-close-button:hover:before,.maplibregl-popup-close-button:hover:before{color:#fff}.mapboxgl-popup-close-button:active,.maplibregl-popup-close-button:active{transform:scale(.95)}.skeleton-loader{padding:10px 0}.skeleton-loader.hidden{display:none}.skeleton-item{height:70px;margin-bottom:12px;border-radius:16px;background:linear-gradient(90deg,var(--card-bg) 25%,rgba(0,0,0,.05) 50%,var(--card-bg) 75%);background-size:200% 100%;animation:loading 1.5s infinite}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.mobile-nav{position:fixed;bottom:20px;left:50%;transform:translate(-50%);width:90%;max-width:400px;height:65px;background:var(--sheet-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--sheet-border);border-radius:20px;box-shadow:0 10px 25px #0000001a;display:flex;justify-content:space-around;align-items:center;z-index:300;padding:0 10px}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-sub);font-size:.75rem;gap:4px;padding:8px 16px;border-radius:12px;transition:all .3s ease;cursor:pointer;flex:1}.nav-item i{font-size:1.25rem;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.nav-item.active{color:var(--accent);background:#bf1e2e1a}.nav-item.active i{transform:translateY(-2px)}.bottom-sheet{bottom:86px!important;transition:all .4s cubic-bezier(.16,1,.3,1)}.page-view.active-page{opacity:1;transform:translateY(0);visibility:visible;pointer-events:auto}#info-page.page-view{background:#fff}#info-page .page-header{background:transparent;padding-top:80px;padding-left:35px;padding-right:35px}.page-header h2{font-size:2rem;font-weight:800;color:var(--text-main);display:flex;align-items:center;gap:16px;letter-spacing:-1px}.page-content{flex:1;overflow-y:auto;padding:20px 24px 120px;display:flex;flex-direction:column;gap:20px}.info-card{background:#fff9;border:1px solid rgba(255,255,255,.6);border-radius:24px;padding:24px;margin-bottom:0;display:flex;align-items:flex-start;gap:20px;box-shadow:0 10px 30px #0000000d;transition:transform .3s ease,box-shadow .3s ease}.info-card:hover{transform:translateY(-5px);box-shadow:0 15px 35px #0000001a;background:#fffc}.info-icon{width:50px;height:50px;flex-shrink:0;background:linear-gradient(135deg,#e0f2fe,#bae6fd);color:#0284c7;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:0 4px 10px #0284c726}.info-icon.warning{background:#fef9c3;color:#ca8a04}.info-text h4{font-size:1.1rem;font-weight:700;margin-bottom:8px;color:var(--text-main)}.info-text p{font-size:.95rem;color:var(--text-sub);line-height:1.6}#route-view.page-view{background:transparent;display:flex;align-items:flex-end;justify-content:center;pointer-events:none;z-index:200;padding:0}#route-view.active-page{pointer-events:auto;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none}.route-panel-overlay{width:100%;height:100%;display:flex;align-items:flex-end;justify-content:center;padding-bottom:95px}.route-master-panel{width:100%;max-width:400px;background:#fff;border-top-left-radius:28px;border-top-right-radius:28px;box-shadow:0 -10px 40px #00000026;padding:24px;border:1px solid rgba(0,0,0,.08);margin:0 10px 20px}#route-view.active-page{display:flex!important;background-color:transparent!important}#route-view.active-page .route-master-panel{opacity:1}.panel-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.route-list-container{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.route-card-item{display:flex;align-items:center;padding:16px;background:#fff;border-radius:20px;border:2px solid transparent;box-shadow:0 4px 15px #00000008;cursor:pointer;position:relative;overflow:hidden}.route-card-item.active-card{border-color:var(--accent);background:#bf1e2e08}.route-card-item.active-card .custom-toggle{background:var(--accent)}.route-card-item.active-card .custom-toggle:after{transform:translate(14px);background:#fff}.route-card-item#card-ruteSore.active-card{border-color:var(--secondary);background:#159bb308;box-shadow:0 8px 25px #159bb31a}.route-card-item#card-ruteSore.active-card .custom-toggle{background:var(--secondary)}.route-card-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-right:16px;flex-shrink:0}.morning-theme{background:#fff7ed;color:#f97316}.afternoon-theme{background:#ecfeff;color:#06b6d4}.route-card-info{flex:1}.route-name{display:block;font-weight:700;font-size:1.05rem;color:var(--text-main);margin-bottom:4px}.route-meta{display:flex;gap:12px;font-size:.8rem;color:var(--text-sub);flex-wrap:wrap}.route-checkbox{margin-left:10px}.bus-marker-icon{width:48px;height:48px;background-size:contain;background-repeat:no-repeat;cursor:pointer;position:relative}.custom-toggle{width:36px;height:22px;background:#e5e7eb;border-radius:20px;position:relative}.custom-toggle:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003}.panel-footer-info{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.info-pill{background:#0000000a;padding:8px 14px;border-radius:100px;font-size:.8rem;color:var(--text-sub);display:flex;align-items:center;gap:6px;font-weight:500}.image-modal{display:none;position:fixed;z-index:2000;padding-top:50px;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#000000e6;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);transition:opacity .3s ease}.modal-content{margin:auto;display:block;width:80%;max-width:900px;max-height:80vh;object-fit:contain;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:zoomIn .3s}.close-modal{position:absolute;top:20px;right:35px;color:#f1f1f1;font-size:40px;font-weight:700;transition:.3s;cursor:pointer}.close-route-btn{width:36px;height:36px;border-radius:50%;border:none;background:#0000000d;color:var(--text-sub);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-route-btn:hover{background:#0000001a;color:var(--text-main)}.header-content h2{font-size:1.3rem;font-weight:700;color:var(--text-main);margin:0 0 4px}.header-content p{font-size:.85rem;color:var(--text-sub);margin:0}@media(min-width:768px){.bottom-sheet{inset:20px auto auto 20px;width:380px;max-height:85vh}.sheet-handle-bar{display:none}.sheet-header{padding-top:24px}.floating-controls{top:20px;right:20px}.mobile-nav{bottom:30px}.bottom-sheet{bottom:auto!important}.bottom-sheet.hidden{transform:none!important;opacity:1!important;pointer-events:auto!important}.route-panel-overlay{align-items:center;padding-bottom:0}.route-master-panel{margin:0;border-radius:28px}}#faq-page.page-view{background:#fff}#faq-page .page-header{background:transparent;padding-top:80px;padding-left:35px;padding-right:35px}.faq-content{padding-bottom:120px!important}.faq-intro{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:16px;padding:20px;margin-bottom:24px;border:1px solid rgba(14,165,233,.2)}.faq-intro p{margin:0;color:#0369a1;font-size:.95rem;line-height:1.6}.faq-section{margin-bottom:28px}.faq-section h3{font-size:1rem;font-weight:700;color:var(--text-main);margin-bottom:16px;display:flex;align-items:center;gap:10px;padding-bottom:10px;border-bottom:2px solid #f1f5f9}.faq-section h3 i{color:var(--accent)}.faq-item{display:flex;align-items:flex-start;gap:16px;padding:16px;background:#fafafa;border-radius:16px;margin-bottom:12px;border:1px solid #f1f5f9;transition:all .2s ease}.faq-item:hover{background:#f8fafc;transform:translate(4px);box-shadow:0 4px 12px #0000000d}.faq-icon{width:48px;height:48px;min-width:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.faq-icon.status-green{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#16a34a}.faq-icon.status-yellow{background:linear-gradient(135deg,#fef9c3,#fef08a);color:#ca8a04}.faq-icon.status-gray{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#6b7280}.faq-icon.status-red{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626}.faq-icon.status-blue{background:linear-gradient(135deg,#e0f2fe,#bae6fd);color:#0284c7}.faq-icon.status-orange{background:linear-gradient(135deg,#ffedd5,#fed7aa);color:#ea580c}.faq-icon.status-purple{background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:#7c3aed}.faq-text h4{font-size:1rem;font-weight:600;color:var(--text-main);margin:0 0 6px;display:flex;align-items:center;gap:8px}.faq-text p{font-size:.9rem;color:var(--text-sub);margin:0;line-height:1.6}.lost-items-section{margin-top:20px;padding-top:20px;border-top:2px dashed #e2e8f0}.lost-items-intro{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:14px;padding:16px;margin-bottom:20px;border:1px solid rgba(245,158,11,.3)}.lost-items-intro p{margin:0;color:#92400e;font-size:.9rem;display:flex;align-items:flex-start;gap:10px}.lost-items-intro p i{margin-top:2px;color:#f59e0b}.lost-item-form{background:transparent;padding:0;border:none;box-shadow:none}.lost-item-form .form-group{margin-bottom:20px}.lost-item-form label{display:block;font-size:.9rem;font-weight:600;color:var(--text-main);margin-bottom:8px}.lost-item-form label i{margin-right:6px;color:var(--accent)}.lost-item-form input,.lost-item-form textarea{width:100%;padding:14px 16px;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;font-family:inherit;transition:all .2s ease;background:#fafafa;color:var(--text-main)}.lost-item-form input:focus,.lost-item-form textarea:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 4px #bf1e2e1a}.lost-item-form input::placeholder,.lost-item-form textarea::placeholder{color:#a0aec0}.lost-item-form textarea{resize:vertical;min-height:100px}.btn-submit-lost{width:100%;padding:16px;background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;border:none;border-radius:14px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .3s ease;box-shadow:0 4px 15px #25d3664d}.btn-submit-lost:hover{transform:translateY(-2px);box-shadow:0 6px 20px #25d36666}.btn-submit-lost:active{transform:scale(.98)}.pwa-install-prompt{position:fixed;bottom:100px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#1f2937,#374151);color:#fff;padding:16px 24px;border-radius:16px;box-shadow:0 10px 40px #0000004d;z-index:1000;display:none;align-items:center;gap:16px;max-width:90%;animation:slideUpPrompt .5s cubic-bezier(.16,1,.3,1)}.pwa-install-prompt.show{display:flex}.pwa-install-prompt .prompt-icon{width:48px;height:48px;background:var(--accent);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.pwa-install-prompt .prompt-text h4{margin:0 0 4px;font-size:1rem;font-weight:600}.pwa-install-prompt .prompt-text p{margin:0;font-size:.85rem;opacity:.8}.pwa-install-prompt .prompt-actions{display:flex;gap:8px;margin-left:auto}.pwa-install-prompt button{padding:8px 16px;border-radius:8px;border:none;font-weight:600;cursor:pointer;transition:all .2s}.pwa-install-prompt .btn-install{background:var(--accent);color:#fff}.pwa-install-prompt .btn-later{background:#ffffff1a;color:#fff}@keyframes slideUpPrompt{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.offline-indicator{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;text-align:center;padding:8px;font-size:.85rem;font-weight:600;z-index:9999;display:none;align-items:center;justify-content:center;gap:8px}.offline-indicator.show{display:flex}.offline-indicator i{animation:pulse 1.5s infinite}.last-updated{font-size:.7rem;color:var(--text-sub);opacity:.7;display:flex;align-items:center;gap:4px;margin-top:4px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}*:focus-visible{outline:3px solid var(--accent);outline-offset:2px}.skip-link{position:absolute;top:-40px;left:0;background:var(--accent);color:#fff;padding:8px 16px;z-index:10000;transition:top .3s}.skip-link:focus{top:0}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media(prefers-contrast:high){:root{--bg-color: #ffffff;--text-main: #000000;--text-sub: #333333;--sheet-bg: #ffffff;--sheet-border: #000000;--accent: #BF1E2E;--card-bg: #ffffff}.bus-item,.info-card,.faq-item{border:2px solid #000000}.status-dot{width:10px;height:10px}}.voice-announce-btn{position:fixed;bottom:180px;right:16px;width:44px;height:44px;border-radius:50%;background:var(--sheet-bg);border:1px solid var(--sheet-border);box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:100;transition:all .3s}.voice-announce-btn:hover{background:var(--accent);color:#fff}.voice-announce-btn.active{background:var(--accent);color:#fff;animation:pulse-badge 2s infinite}.haptic-feedback{animation:hapticPulse .1s ease-out}@keyframes hapticPulse{0%,to{transform:scale(1)}50%{transform:scale(.97)}}.touch-ripple{position:absolute;border-radius:50%;background:#bf1e2e4d;transform:scale(0);animation:rippleEffect .6s ease-out;pointer-events:none}@keyframes rippleEffect{to{transform:scale(4);opacity:0}}.smooth-appear{animation:smoothAppear .4s cubic-bezier(.16,1,.3,1)}@keyframes smoothAppear{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.toast-notification{position:fixed;bottom:120px;left:50%;transform:translate(-50%);background:#1f2937;color:#fff;padding:12px 24px;border-radius:12px;font-size:.9rem;font-weight:500;z-index:9999;display:flex;align-items:center;gap:10px;box-shadow:0 10px 30px #0000004d;animation:toastSlideUp .3s ease-out}.toast-notification.success{background:linear-gradient(135deg,#10b981,#059669)}.toast-notification.warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.toast-notification.error{background:linear-gradient(135deg,#ef4444,#dc2626)}@keyframes toastSlideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.connection-status{position:fixed;top:16px;left:16px;padding:6px 12px;border-radius:100px;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:6px;z-index:100;box-shadow:var(--shadow)}.connection-status.online{background:#10b98126;color:#059669;border:1px solid rgba(16,185,129,.3)}.connection-status.offline{background:#ef444426;color:#dc2626;border:1px solid rgba(239,68,68,.3)}.connection-status .status-indicator{width:8px;height:8px;border-radius:50%}.connection-status.online .status-indicator{background:#10b981;box-shadow:0 0 8px #10b981}.connection-status.offline .status-indicator{background:#ef4444;animation:blink 1s infinite}.chip-dashboard{padding:6px 12px;border-radius:100px;font-size:.75rem;font-weight:600;cursor:pointer;border:1px solid rgba(0,0,0,.1);background:#f3f4f6;color:#9ca3af;display:flex;align-items:center;gap:6px;opacity:.8}.chip-dashboard.pagi.active-route{background:#fff7ed;color:#f97316;border-color:#fdba74;opacity:1;box-shadow:0 2px 5px #f9731626}.chip-dashboard.sore.active-route{background:#ecfeff;color:#06b6d4;border-color:#67e8f9;opacity:1;box-shadow:0 2px 5px #06b6d426}.chip-dashboard i{color:inherit}.stop-marker-modern{background:#fff;border:3px solid #0f172a;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 10px #0003;cursor:pointer;transition:transform .2s cubic-bezier(.175,.885,.32,1.275);z-index:10}.stop-marker-modern i{color:#0f172a;font-size:12px}.stop-marker-modern:hover{transform:scale(1.2);border-color:var(--accent);z-index:20}.stop-marker-modern:hover i{color:var(--accent)}@media screen and (orientation:landscape)and (max-height:600px){.bottom-sheet{top:10px;left:10px!important;bottom:10px!important;right:auto!important;width:320px!important;max-height:none!important;height:auto!important;border-radius:20px;display:flex;flex-direction:column;z-index:400;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transform:none!important}.bottom-sheet.collapsed{left:10px!important;width:50px!important;overflow:hidden;padding:0;background:#fff;transform:none!important;top:10px!important;bottom:auto!important}.bottom-sheet.collapsed .sheet-header,.bottom-sheet.collapsed .sheet-content{visibility:hidden;opacity:0}.bottom-sheet.collapsed #toggleSheetBtn{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) rotate(-90deg);display:flex!important;visibility:visible;opacity:1;z-index:50}.sheet-handle-bar{display:none}.sheet-header{padding-top:16px}.mobile-nav{left:auto;right:16px;bottom:50%;transform:translateY(50%);width:64px;height:auto;flex-direction:column;padding:16px 0;gap:12px;border-radius:30px;max-width:none;background:#ffffffe6;box-shadow:0 4px 20px #0000001a}.nav-item{padding:12px;width:100%;border-radius:16px}.nav-item span{display:none}.nav-item i{font-size:1.4rem;margin:0}.floating-controls{right:90px;top:16px;flex-direction:row}.sheet-content{padding-bottom:20px;overflow-y:auto}.route-panel-overlay{padding-bottom:0;align-items:center;justify-content:center}.route-master-panel{max-height:90vh;overflow-y:auto;border-radius:24px;margin:0 20px}}.arrival-notification-container{position:fixed;top:20px;left:50%;transform:translate(-50%);width:90%;max-width:400px;z-index:2000;pointer-events:none;display:flex;flex-direction:column;gap:10px}.arrival-card{background:#fffffff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:20px;padding:14px 18px;box-shadow:0 10px 40px #00000026;display:flex;align-items:center;gap:14px;transform:translateY(-50px) scale(.9);opacity:0;animation:arrivalIn .5s cubic-bezier(.34,1.56,.64,1) forwards;pointer-events:auto;border:1px solid rgba(255,255,255,.5);overflow:hidden;position:relative}.arrival-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent)}.arrival-card.leaving{animation:arrivalOut .4s cubic-bezier(.16,1,.3,1) forwards}@keyframes arrivalIn{to{transform:translateY(0) scale(1);opacity:1}}@keyframes arrivalOut{to{transform:translateY(-20px) scale(.95);opacity:0}}.arrival-icon{width:46px;height:46px;background:#fff;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0;box-shadow:0 4px 12px #00000014;padding:6px}.arrival-content{flex-grow:1}.arrival-content h4{margin:0;font-size:1rem;font-weight:700;color:var(--text-main);letter-spacing:-.3px}.arrival-content p{margin:3px 0 0;font-size:.8rem;color:var(--text-sub);font-weight:500}.arrival-time{font-size:.75rem;font-weight:700;color:#10b981;background:#ecfdf5;padding:4px 10px;border-radius:100px;white-space:nowrap}
