.app-sidebar{z-index:1050;background-color:#fff;border-right:1px solid #e5e7eb;flex-direction:column;width:240px;height:100vh;transition:left .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;left:-240px;box-shadow:4px 0 15px #0000000d}.app-sidebar.open{left:0}.sidebar-scrollable-content{flex:1;overflow-y:auto}.sidebar-scrollable-content::-webkit-scrollbar{display:none}.sidebar-scrollable-content{-ms-overflow-style:none;scrollbar-width:none}.sidebar-nav .nav-link{color:#4b5563;border-left:4px solid #0000;border-radius:0 8px 8px 0;align-items:center;margin-right:.5rem;padding:.85rem 1.25rem;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.sidebar-nav .nav-link:hover{color:#111827;background-color:#f3f4f6}.sidebar-nav .nav-link.active{color:#2563eb;background-color:#e8f0ff;border-left:4px solid #2563eb;font-weight:600}.sidebar-nav .nav-link.active.bg-danger{border-left:4px solid #dc2626;color:#dc2626!important;background-color:#fee2e2!important}.sidebar-backdrop{z-index:1040;background-color:#00000080;width:100vw;height:100vh;animation:.3s fadeIn;position:fixed;top:0;left:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (min-width:992px){.app-sidebar.persistent-desktop{z-index:1020;height:calc(100vh - 60px);box-shadow:none;border-right:1px solid #e5e7eb;top:60px;left:0}.has-persistent-sidebar main{width:calc(100% - 240px);margin-left:240px;transition:margin-left .3s}.has-persistent-sidebar footer{width:calc(100% - 240px);margin-left:240px}.has-persistent-sidebar .navbar-toggler-custom,.app-sidebar.persistent-desktop .sidebar-header{display:none!important}}.home-container{background:linear-gradient(135deg,#f0f9ff 0%,#e0f2fe 25%,#dbeafe 50%,#eff6ff 100%) 0 0/400% 400%;justify-content:center;align-items:center;width:100%;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;animation:15s infinite meshGradient;display:flex;position:relative;overflow:hidden}@keyframes meshGradient{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.bg-blob{filter:blur(80px);z-index:1;opacity:.4;border-radius:50%;animation:20s infinite alternate-reverse floatBlobs;position:absolute}.blob-1{background:#3b82f6;width:500px;height:500px;top:-100px;left:-100px}.blob-2{background:#60a5fa;width:400px;height:400px;animation-delay:-5s;bottom:-100px;right:-50px}.blob-3{background:#93c5fd;width:300px;height:300px;animation-delay:-10s;top:40%;right:15%}@keyframes floatBlobs{0%{transform:translate(0)scale(1)}to{transform:translate(100px,50px)scale(1.1)}}.bg-logo-overlay{opacity:.05;filter:grayscale()invert(0);z-index:2;pointer-events:none;background-image:url(/assets/logo-pIJjoKUm.png);background-position:50%;background-repeat:no-repeat;background-size:contain;width:70vh;height:70vh;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.glass-card{z-index:10;-webkit-backdrop-filter:blur(20px)saturate(200%);text-align:center;background:#ffffff73;border:1px solid #ffffffb3;border-radius:40px;width:90%;max-width:640px;padding:4rem 3rem;position:relative;box-shadow:0 40px 100px -20px #0000001a,inset 0 0 0 1px #fff3}.floating-card{animation:6s ease-in-out infinite floatCard}@keyframes floatCard{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.home-logo-small{filter:drop-shadow(0 10px 15px #0000001a);width:80px;height:80px;margin-bottom:2rem}.home-title{color:#0f172a;letter-spacing:-.05em;background:linear-gradient(135deg,#1e293b 0%,#334155 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1.5rem;font-size:3.5rem;font-weight:900;line-height:1.1}.home-subtitle{color:#475569;max-width:500px;margin-bottom:3.5rem;margin-left:auto;margin-right:auto;font-size:1.25rem;font-weight:500;line-height:1.6}.home-actions{flex-direction:column;gap:1.25rem;padding:0 1rem;display:flex}.btn-premium{cursor:pointer;border:none;border-radius:20px;justify-content:center;align-items:center;gap:1rem;padding:1.15rem 2.5rem;font-size:1.1rem;font-weight:700;text-decoration:none;transition:all .4s cubic-bezier(.23,1,.32,1);display:flex;position:relative;overflow:hidden}.btn-premium:active{transform:scale(.96)}.icon-anim{transition:transform .4s cubic-bezier(.175,.885,.32,1.275)}.btn-premium:hover .icon-anim{transform:scale(1.25)rotate(-10deg)}.btn-primary-premium{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);box-shadow:0 15px 30px -5px #2563eb4d}.btn-primary-premium:hover{transform:translateY(-4px);box-shadow:0 25px 45px -10px #2563eb66}.btn-secondary-premium{color:#1e293b;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffc;border:1px solid #ffffff80}.btn-secondary-premium:hover{background:#fff;transform:translateY(-4px);box-shadow:0 15px 30px -5px #0000000d}.btn-accent-premium{color:#fff;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);box-shadow:0 15px 30px -5px #d977064d}.btn-accent-premium:hover{transform:translateY(-4px);box-shadow:0 25px 45px -10px #d9770666}@media (max-width:420px){.glass-card{border-radius:32px;width:100%;max-width:100%;padding:3rem 1.5rem}.home-title{font-size:2.2rem}.home-subtitle{margin-bottom:2rem;font-size:1rem}.btn-premium{padding:1rem 1.5rem;font-size:1rem}}@media (max-width:640px){.home-title{font-size:2.5rem}.glass-card{border-radius:32px;padding:3.5rem 1.5rem}.home-subtitle{margin-bottom:2.5rem;font-size:1.1rem}.btn-premium{padding:1rem 2rem;font-size:1rem}.bg-blob{width:300px;height:300px}}:root{--card-radius:14px;--accent:#0b6cff;--muted:#6c757d}.register-page-wrapper{background:radial-gradient(900px 420px at 5% 10%,#0b6cff0a,#0000 8%),radial-gradient(700px 320px at 95% 90%,#00c89605,#0000 6%),#f6f8fb;justify-content:center;align-items:center;min-height:100vh;padding:2rem;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;display:flex}.card-auth{border-radius:var(--card-radius);background:linear-gradient(#fff,#fbfdff);border:1px solid #fffc;width:100%;max-width:520px;overflow:hidden;box-shadow:0 12px 40px #0f16280f}.brand{background:linear-gradient(90deg,#0b6cff08,#00c89603);border-bottom:1px solid #0f162805;align-items:center;gap:12px;padding:18px 20px;display:flex}.brand img{object-fit:cover;border-radius:10px;width:48px;height:48px}.brand h1{color:#07304b;margin:0;font-size:1.05rem;font-weight:700}.brand p{color:var(--muted);margin:0;font-size:.85rem}.card-body-auth{padding:1.4rem 1.6rem}.form-label{color:#123044;font-weight:600}.text-muted-custom{color:var(--muted);font-size:.88rem}.strength{background:#0000000f;border-radius:6px;height:6px;margin-top:8px;overflow:hidden}.strength>span{width:0;height:100%;transition:width .3s,background-color .3s;display:block}.strength.weak span{background:#ff6b6b;width:33%}.strength.fair span{background:#ffb86b;width:66%}.strength.strong span{background:#6be08a;width:100%}.footer-note{color:var(--muted);text-align:center;border-top:1px solid #0f162805;padding:14px;font-size:.86rem}@media (max-width:540px){.register-page-wrapper{padding:1rem}.brand p{display:none}.card-auth{max-width:420px}}:root{--primary-accent:#6366f1;--secondary-accent:#a855f7;--glass-bg:#ffffff73;--glass-border:#fff9;--text-dark:#0f172a;--text-muted:#475569}.conductor-login-page{background:linear-gradient(135deg,#f0f9ff 0%,#e0f2fe 25%,#dbeafe 50%,#eff6ff 100%) 0 0/400% 400%;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:1.5rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;animation:15s infinite meshGradient;display:flex;position:relative;overflow:hidden}.bg-decor{pointer-events:none;z-index:0;width:100%;height:100%;position:absolute;top:0;left:0}.bg-circle{filter:blur(100px);opacity:.3;border-radius:50%;animation:20s infinite alternate floatDecor;position:absolute}.bg-circle-1{background:var(--primary-accent);width:500px;height:500px;top:-150px;right:-100px}.bg-circle-2{background:var(--secondary-accent);width:400px;height:400px;animation-delay:-5s;bottom:-100px;left:-50px}@keyframes floatDecor{0%{transform:translate(0)scale(1)}to{transform:translate(50px,30px)scale(1.1)}}.logo-overlay{opacity:.04;filter:grayscale();pointer-events:none;z-index:1;width:60vh;height:60vh;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.conductor-login-container{background:var(--glass-bg);-webkit-backdrop-filter:blur(25px)saturate(180%);border:1px solid var(--glass-border);z-index:10;border-radius:40px;width:100%;max-width:520px;padding:4.5rem 3.5rem;animation:1.2s cubic-bezier(.16,1,.3,1) cardEntrance;position:relative;box-shadow:0 40px 100px -20px #00000014,inset 0 0 0 1px #fff3}@keyframes cardEntrance{0%{opacity:0;transform:translateY(40px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.conductor-login-header{text-align:center;margin-bottom:3rem}.login-logo{filter:drop-shadow(0 10px 15px #0000001a);width:72px;height:auto;margin-bottom:1.5rem}.conductor-login-title{color:#0f172a;letter-spacing:-.05em;background:linear-gradient(135deg,#1e293b 0%,#334155 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 .5rem;font-size:2.75rem;font-weight:900}.conductor-login-subtitle{color:var(--text-muted);font-size:1.1rem;font-weight:500}.conductor-login-error{background:#ef44441a;border:1px solid #ef44441a;border-radius:16px;align-items:center;gap:.75rem;margin-bottom:2rem;padding:1rem 1.25rem;animation:.4s shake;display:flex}.error-text{color:#b91c1c;font-size:.95rem;font-weight:600}.conductor-login-form{flex-direction:column;gap:2rem;display:flex}.form-group{flex-direction:column;gap:.85rem;display:flex}.form-label{color:#1e293b;text-transform:uppercase;letter-spacing:.075em;padding-left:.25rem;font-size:.875rem;font-weight:700}.form-input{color:#0f172a;background:#fffc;border:1px solid #fff;border-radius:18px;padding:1.15rem 1.5rem;font-size:1.05rem;font-weight:500;transition:all .4s cubic-bezier(.23,1,.32,1);box-shadow:0 4px 6px -1px #0000000d}.form-input:focus{border-color:var(--primary-accent);background:#fff;outline:none;transform:translateY(-2px);box-shadow:0 10px 20px -5px #6366f126,0 0 0 4px #6366f11a}.form-input::placeholder{color:#94a3b8}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper .form-input{width:100%;padding-right:4rem}.password-toggle{color:#64748b;cursor:pointer;background:0 0;border:none;align-items:center;padding:.5rem;transition:all .3s;display:flex;position:absolute;right:1.25rem}.password-toggle:hover{color:var(--primary-accent);transform:scale(1.1)}.conductor-login-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border:none;border-radius:20px;justify-content:center;align-items:center;gap:.75rem;margin-top:1rem;padding:1.25rem;font-size:1.15rem;font-weight:800;transition:all .4s cubic-bezier(.23,1,.32,1);display:flex;box-shadow:0 15px 30px -5px #2563eb4d}.conductor-login-button:hover:not(:disabled){transform:translateY(-4px);box-shadow:0 25px 45px -10px #2563eb66}.conductor-login-button:active:not(:disabled){transform:translateY(-1px)}.conductor-login-button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.spinner{border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:22px;height:22px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.conductor-login-footer{text-align:center;flex-direction:column;gap:1.25rem;margin-top:3.5rem;display:flex}.footer-text{color:var(--text-muted);font-size:1rem}.footer-link{color:var(--primary-accent);font-weight:800;text-decoration:none;transition:all .3s;position:relative}.footer-link:after{content:"";background:var(--primary-accent);width:100%;height:2px;transition:transform .3s;position:absolute;bottom:-2px;left:0;transform:scaleX(0)}.footer-link:hover:after{transform:scaleX(1)}.footer-note{color:#94a3b8;font-size:.85rem;font-weight:500}@media (max-width:640px){.conductor-login-container{border-radius:32px;padding:3.5rem 1.75rem}.conductor-login-title{font-size:2.25rem}.form-input{padding:1rem 1.25rem}}@media (max-width:400px){.conductor-login-title{font-size:1.875rem}}.reset-wrapper{margin-top:5rem;animation:.6s both fadeUp}@keyframes fadeUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}.reset-card{background-color:#fff;border:none;border-radius:16px;overflow:hidden;box-shadow:0 14px 40px #0000001f}.reset-card .card-header{color:#fff;text-align:center;background:linear-gradient(135deg,#0d6efd,#0b5ed7);border-bottom:none;padding:1.5rem}.form-control{border-radius:10px;padding:.65rem .75rem;transition:all .25s}.form-control:focus{border-color:#0d6efd;box-shadow:0 0 0 .18rem #0d6efd2e}.password-wrapper{position:relative}.toggle-password{cursor:pointer;color:#6c757d;z-index:10;position:absolute;top:42px;right:12px}.strength-bar{background:#e9ecef;border-radius:5px;height:6px;margin-top:5px;overflow:hidden}.strength-fill{width:0;height:100%;transition:width .4s,background-color .4s}.btn-reset{border-radius:10px;width:100%;padding:.65rem;font-weight:500;transition:all .2s}.btn-reset:hover{transform:translateY(-2px);box-shadow:0 10px 22px #0d6efd59}.custom-modal-backdrop{z-index:9999;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.custom-modal{background:#fff;border-radius:14px;width:90%;max-width:520px;animation:.25s modalPop;overflow:hidden;box-shadow:0 10px 40px #0000004d}.custom-modal-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:14px 18px;font-weight:600;display:flex}.close-btn{cursor:pointer;background:0 0;border:none;font-size:22px}.custom-modal-body{max-height:70vh;padding:18px;overflow-y:auto}@keyframes modalPop{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.stops-list{margin:0;padding:0;list-style:none}.stop-row{border-bottom:1px solid #eee;grid-template-columns:1fr auto auto;align-items:center;gap:10px;padding:10px 6px;font-size:.95rem;display:grid}.stop-left{align-items:center;gap:8px;display:flex}.stop-dot{background:#9ca3af;border-radius:50%;width:8px;height:8px}.stop-name{font-size:.9rem;font-weight:600}.stop-right{text-align:right}.stop-time{color:#fff;background:#111827;border-radius:999px;padding:4px 8px;font-size:.75rem;font-weight:600}.stop-row.current{background:#e6f4ff;border-radius:8px;animation:1.8s infinite pulse}.stop-row.current .stop-dot{background:#0d6efd}.stop-row.next .stop-dot{background:#16a34a}.stop-row.passed{opacity:.55}.origin-stop .stop-name:before{content:"📍 "}.destination-stop .stop-name:before{content:"🏁 "}.search-stop{background:#fff8e1;border-left:4px solid #ffc107}.bus-icon{margin-left:6px;animation:1.2s ease-in-out infinite busMove}.badge{border-radius:999px;padding:3px 8px;font-size:.7rem;font-weight:600}.badge.reached{background:#f1f3f5}.badge.current{color:#0d6efd;background:#e3f2fd}.badge.moving{color:#2e7d32;background:#e8f5e9}@keyframes pulse{0%{box-shadow:0 6px 16px #ef444459}50%{box-shadow:0 6px 20px #ef444480}to{box-shadow:0 6px 16px #ef444459}}@keyframes busMove{0%{transform:translate(0)}50%{transform:translate(4px)}to{transform:translate(0)}}@media (max-width:576px){.stop-row{padding:12px 6px;font-size:.88rem}.stop-time{font-size:.7rem}}.bus-extension-features{width:100%;margin-top:10px;font-family:Inter,sans-serif}.led-status-board{background:#1a1a1a;border-top:2px solid #333;border-bottom:2px solid #000;border-radius:8px;width:100%;padding:6px 10px;position:relative;overflow:hidden;box-shadow:inset 0 2px 4px #00000080}.led-inner{align-items:center;gap:10px;display:flex}.led-indicator{flex-shrink:0}.led-dot{background:#333;border-radius:50%;width:10px;height:10px;transition:all .3s}.led-dot.active{background:#f59e0b;animation:1.5s infinite ledPulse;box-shadow:0 0 8px #f59e0b}.led-marquee-container{white-space:nowrap;align-items:center;width:100%;height:20px;display:flex;position:relative;overflow:hidden}.led-marquee-text{color:#f59e0b;white-space:nowrap;text-shadow:0 0 2px #f59e0b80;letter-spacing:.05em;will-change:transform;font-family:Courier New,Courier,monospace;font-size:.9rem;font-weight:700;animation:15s linear infinite ledMarquee;display:inline-block}.led-marquee-text.static{text-align:center;color:#ef4444;text-shadow:0 0 4px #ef44444d;opacity:.9;width:100%;font-size:.85rem;animation:none}@keyframes ledMarquee{0%{transform:translate(100%)}to{transform:translate(-100%)}}@keyframes ledPulse{0%{opacity:.4}50%{opacity:1}to{opacity:.4}}.led-timer{color:#4b5563;text-align:right;opacity:.8;margin-top:4px;font-family:Courier New,Courier,monospace;font-size:10px}.btn-seat-availability{color:#475569;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;width:100%;padding:8px;font-size:.8rem;font-weight:700;transition:all .4s cubic-bezier(.4,0,.2,1)}.btn-seat-availability:hover{color:#1e293b;background-color:#f1f5f9;border-color:#cbd5e1}.btn-seat-availability.status-green{color:#166534;background-color:#dcfce7;border-color:#86efac;box-shadow:0 4px 6px -1px #1665341a}.btn-seat-availability.status-orange{color:#9a3412;background-color:#ffedd5;border-color:#fdba74;box-shadow:0 4px 6px -1px #9a34121a}.btn-seat-availability.status-red{color:#991b1b;background-color:#fee2e2;border-color:#fca5a5;box-shadow:0 4px 6px -1px #991b1b1a}.btn-seat-availability.status-grey{color:#475569;opacity:.8;background-color:#f1f5f9;border-color:#e2e8f0}.availability-dropdown{background-color:#f8fafc;max-height:300px;margin-top:4px;animation:.3s ease-out slideDown;overflow-y:auto;border-color:#e2e8f0!important}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.fade-in-premium{animation:.4s fadeIn}.availability-list-item{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:4px 0;display:flex}.availability-label{white-space:nowrap;text-transform:uppercase;letter-spacing:.025em;border-radius:6px;padding:3px 10px;font-size:.7rem;font-weight:800}.status-green{color:#065f46;background-color:#d1fae5}.status-orange{color:#9a3412;background-color:#ffedd5}.status-red{color:#991b1b;background-color:#fee2e2}.status-grey{color:#4b5563;background-color:#f3f4f6;border:1px solid #d1d5db!important}.x-small{font-size:.7rem}.stop-name{color:#4b5563;text-overflow:ellipsis;font-size:.85rem;overflow:hidden}@media (max-width:480px){.led-marquee-text{font-size:.8rem}.led-status-board{padding:4px 8px}.availability-label{padding:2px 4px;font-size:.65rem}.btn-seat-availability{font-size:.75rem}}button:focus-visible,.popular-card:focus-visible{outline-offset:3px;outline:2px solid #0d6efd}@media (prefers-reduced-motion:reduce){.bus-count-toast,.skeleton-card,.bus-image,.popular-card{transition:none!important;animation:none!important}}.routes-search{margin-bottom:40px}.route-datepicker-wrapper{width:100%}.route-datepicker-trigger{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:12px;justify-content:center;align-items:center;gap:12px;width:100%;padding:.75rem 1rem;font-size:.95rem;font-weight:700;transition:all .2s;display:flex}.route-datepicker-trigger:hover{background:#f8fafc;border-color:#cbd5e1}.route-datepicker-trigger:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.route-datepicker-trigger i{color:#64748b;font-size:1rem}.route-datepicker-chevron{opacity:.5;font-size:.8rem!important}@media (min-width:768px){.route-datepicker-trigger{justify-content:flex-start}.route-datepicker-chevron{margin-left:auto}}.route-datepicker-calendar{overflow:hidden;background:#fff!important;border:1px solid #e2e8f0!important;border-radius:16px!important;font-family:inherit!important;font-size:.8rem!important;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a!important}.react-datepicker-popper{z-index:1060!important}.route-datepicker-calendar .react-datepicker__header{background:#fff!important;border-bottom:1px solid #f1f5f9!important;border-radius:0!important;padding:10px 0 4px!important}.route-datepicker-calendar .react-datepicker__current-month{color:#0f172a!important;margin-bottom:8px!important;font-size:.9rem!important;font-weight:700!important}.route-datepicker-calendar .react-datepicker__day-name{color:#94a3b8!important;width:1.8rem!important;font-size:.7rem!important;font-weight:600!important}.route-datepicker-calendar .react-datepicker__navigation{top:12px!important}.route-datepicker-calendar .react-datepicker__navigation-icon:before{border-width:2px 2px 0 0!important;border-color:#64748b!important;width:7px!important;height:7px!important}.route-datepicker-calendar .react-datepicker__navigation:hover :before{border-color:#0f172a!important}.route-datepicker-calendar .react-datepicker__day{color:#334155!important;border-radius:8px!important;width:1.8rem!important;margin:1px!important;font-size:.8rem!important;line-height:1.8rem!important;transition:all .15s!important}.route-datepicker-calendar .react-datepicker__day:hover{color:#0f172a!important;background:#f1f5f9!important}.route-datepicker-calendar .react-datepicker__day--selected{color:#fff!important;background:#3b82f6!important;font-weight:600!important}.route-datepicker-calendar .react-datepicker__day--today{position:relative;color:#3b82f6!important;font-weight:700!important}.route-datepicker-calendar .react-datepicker__day--today:after{content:"";background:#3b82f6;border-radius:50%;width:4px;height:4px;position:absolute;bottom:4px;left:50%;transform:translate(-50%)}.route-datepicker-calendar .react-datepicker__day--today.react-datepicker__day--selected:after{background:#fff}.route-datepicker-calendar .react-datepicker__day--disabled{color:#e2e8f0!important;cursor:not-allowed!important}.route-datepicker-calendar .react-datepicker__day--disabled:hover{background:0 0!important}.route-datepicker-calendar .react-datepicker__triangle{display:none!important}@media (max-width:480px){.route-datepicker-calendar .react-datepicker__day,.route-datepicker-calendar .react-datepicker__day-name{width:1.6rem!important;line-height:1.6rem!important}.route-datepicker-calendar .react-datepicker__current-month{font-size:.8rem!important}}@media (max-width:350px){.route-datepicker-calendar .react-datepicker__day,.route-datepicker-calendar .react-datepicker__day-name{width:1.4rem!important;font-size:.7rem!important;line-height:1.4rem!important}}.popular-section:before{content:"";background:#e5e7eb;width:100%;height:1px;margin-bottom:28px;display:block}.popular-section{margin-top:48px;padding-bottom:32px}.popular-title{color:#0f172a;letter-spacing:-.5px;margin-bottom:8px;font-size:1.75rem;font-weight:800}.popular-subtitle-text{color:#64748b;text-align:center;margin-bottom:28px;font-size:.95rem}.popular-card{cursor:pointer;background:#1e293b 50%/cover no-repeat;border:none;border-radius:20px;flex-direction:column;height:100%;padding:0;transition:all .38s cubic-bezier(.165,.84,.44,1);display:flex;position:relative;overflow:hidden;box-shadow:0 4px 20px #00000026}.popular-card:before{content:"";z-index:1;background:linear-gradient(160deg,#0000008c 0%,#0000004d 50%,#000000a6 100%);border-radius:20px;transition:background .38s;position:absolute;inset:0}.popular-card:hover:before{background:linear-gradient(160deg,#0006 0%,#00000026 50%,#00000080 100%)}.popular-card:hover{transform:translateY(-8px)scale(1.01);box-shadow:0 24px 50px #00000040}.popular-card>*{z-index:2;position:relative}.popular-card-accent{opacity:.9;width:100%;height:5px}.popular-card-body{flex-direction:column;flex:1;gap:12px;padding:1.5rem;display:flex}.popular-icon{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid #fff3;border-radius:14px;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:4px;font-size:1.4rem;display:flex;color:#fff!important;background:#ffffff26!important}.popular-route{color:#fff;text-shadow:0 1px 4px #0006;flex-wrap:wrap;align-items:center;gap:8px;font-size:1.15rem;font-weight:800;display:flex}.popular-route-arrow{color:#fff9;font-size:.85rem}.popular-subtitle{color:#ffffffbf;font-size:.875rem;line-height:1.55}.popular-card-footer{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff0d;border-top:1px solid #ffffff1f;align-items:center;gap:8px;padding:.75rem 1.5rem;font-size:.8rem;font-weight:600;transition:background .2s;display:flex;color:#ffffffe6!important}.popular-card:hover .popular-card-footer{background:#ffffff1a}.popular-card:focus-visible{outline-offset:3px;outline:2px solid #fff}@media (max-width:576px){.popular-title{font-size:1.4rem}.popular-card-body{padding:1.25rem}}.bus-card{-webkit-backdrop-filter:blur(15px)saturate(160%);cursor:pointer;transition:all .3s;overflow:hidden;background:#ffffffb3!important;border:1px solid #fff9!important;border-radius:20px!important}.bus-card:active{filter:brightness(.95);transform:scale(.98)}.bus-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -10px #0000001a;background:#ffffffd9!important}.bus-action-tray{opacity:0;background:#00000005;border-top:0 solid #0000000d;gap:12px;max-height:0;padding:0 1.25rem;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;overflow:hidden}.bus-action-tray.expanded{opacity:1;border-top-width:1px;max-height:80px;padding:1rem 1.25rem}.tray-btn{cursor:pointer;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:8px;padding:10px;font-size:.85rem;font-weight:600;transition:all .2s;display:flex}.tray-btn-feedback{color:#3b82f6;background:#3b82f61a}.tray-btn-feedback:hover{background:#3b82f633;transform:translateY(-2px)}.tray-btn-report{color:#ef4444;background:#ef44441a}.tray-btn-report:hover{background:#ef444433;transform:translateY(-2px)}.tray-btn:active{transform:scale(.95)}.bus-card .card-header{background:0 0!important;border-bottom:1px solid #0000000d!important;padding:1rem 1.25rem!important}.bus-card .card-body{padding:1.25rem!important}@media (max-width:480px){.bus-card .card-header{flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem!important}}.bus-action-group{gap:8px;width:100%;margin-top:10px;display:flex}.bus-action-group .btn{text-transform:uppercase;letter-spacing:.02em;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;height:40px;padding:10px 4px;font-size:.8rem;font-weight:700;transition:all .2s;display:flex}.btn-action-stops{color:#475569;background:#f1f5f9}.btn-action-map{color:#fff;background:#3b82f6}.btn-action-live{color:#fff;background:#ef4444;box-shadow:0 4px 12px #ef444433}.bus-action-group .btn:hover{filter:brightness(1.05);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}@keyframes fav-bounce{0%{transform:scale(1)}40%{transform:scale(1.35)}70%{transform:scale(.95)}to{transform:scale(1)}}@keyframes fav-glow{0%{text-shadow:0 0 #f59e0b00}50%{text-shadow:0 0 10px #f59e0bcc}to{text-shadow:0 0 #f59e0b00}}.favorite-btn{cursor:pointer;color:#9ca3af;background:0 0;border:none;padding:4px;font-size:1.1rem;transition:transform .18s,color .18s}.favorite-btn:hover{color:#f59e0b;transform:scale(1.15)}.favorite-btn.favorited{color:#f59e0b;animation:.35s fav-bounce,1.2s fav-glow}.favorite-btn.disabled{opacity:.4;cursor:not-allowed;pointer-events:none;filter:grayscale()}.bus-count-toast{color:#fff;z-index:9999;white-space:nowrap;background:#16a34a;border-radius:999px;padding:10px 20px;font-size:.95rem;font-weight:600;animation:.6s forwards slideDown,.6s 4.4s forwards fadeOut;position:fixed;top:16px;left:50%;transform:translate(-50%)translateY(-120%);box-shadow:0 4px 12px #00000026}@media (max-width:576px){.bus-count-toast{padding:8px 16px;font-size:.85rem;animation:.6s forwards slideUp,.6s 4.4s forwards fadeOut;top:auto;bottom:20px}@keyframes slideUp{0%{transform:translate(-50%)translateY(120%)}to{transform:translate(-50%)translateY(0)}}}@keyframes fadeOut{to{opacity:0}}.skeleton-card{background:linear-gradient(90deg,#e5e7eb 25%,#f3f4f6 37%,#e5e7eb 63%) 0 0/400% 100%;border-radius:14px;height:320px;animation:1.4s infinite skeleton}@keyframes skeleton{0%{background-position:100% 0}to{background-position:0 0}}body[data-theme=dark] .popular-card{background:#1e1e1e;border-color:#2a2a2a}body[data-theme=dark] .popular-route{color:#60a5fa}body[data-theme=dark] .popular-subtitle{color:#b0b0b0}body[data-theme=dark] .bus-card{background:#111827;border-color:#1f2937}body[data-theme=dark] .bus-card h6{color:#e5e7eb}body[data-theme=dark] .bus-image-wrapper{background:#1f2937}body[data-theme=dark] .bus-count-toast{background:#15803d}body[data-theme=dark] .skeleton-card{background:linear-gradient(90deg,#1f2937 25%,#374151 37%,#1f2937 63%)}#map{background:#f8fafc;width:100%;height:calc(100vh - 100px);position:relative}.map-page-wrapper{height:calc(100vh - 100px);margin-top:-24px;position:relative;overflow:hidden}.bus-marker{color:#fff;z-index:5;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:2px solid #fffc;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.2rem;transition:transform .3s;display:flex;box-shadow:0 4px 12px #1e40af4d}.bus-marker:hover{transform:scale(1.1)}.bus-marker .pulse{z-index:-1;background:#3b82f64d;border-radius:50%;animation:2s ease-out infinite premium-pulse;position:absolute;inset:-4px}@keyframes premium-pulse{0%{opacity:.8;transform:scale(1)}to{opacity:0;transform:scale(2.4)}}.stops-drawer-toggle{z-index:10;position:absolute;bottom:24px;left:24px}.stops-progression-drawer{-webkit-backdrop-filter:blur(16px);z-index:9;background:#ffffffd9;border:1px solid #ffffff80;border-radius:24px;flex-direction:column;width:280px;transition:transform .4s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;top:80px;bottom:80px;left:20px;overflow:hidden;box-shadow:10px 0 40px #0000001a}.stops-progression-drawer.closed{transform:translate(-320px)}.drawer-header{background:#ffffff80;border-bottom:1px solid #0000000d;padding:20px}.drawer-header h5{color:#1e293b;margin:0;font-weight:700}.stops-list{flex:1;padding:15px;overflow-y:auto}.stops-list::-webkit-scrollbar{width:5px}.stops-list::-webkit-scrollbar-thumb{background:#0000001a;border-radius:10px}.stop-item{cursor:pointer;border-radius:12px;align-items:center;gap:12px;margin-bottom:4px;padding:12px;transition:all .2s;display:flex;position:relative}.map-utility-controls{z-index:10;flex-direction:column;gap:8px;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.map-utility-controls .btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#475569;background:#ffffffe6;border:1px solid #0000000d;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;padding:0;display:flex}.map-utility-controls .btn:hover{color:#3b82f6;background:#fff}.stop-item:hover{background:#3b82f614}.stop-item.active{background:#3b82f626;border:1px solid #3b82f633}.stop-dot{z-index:2;background:#cbd5e1;border-radius:50%;flex-shrink:0;width:10px;height:10px}.stop-item.active .stop-dot{background:#3b82f6;box-shadow:0 0 0 4px #3b82f633}.stop-item:before{content:"";z-index:1;background:#f1f5f9;width:2px;position:absolute;top:50%;bottom:-50%;left:16px}.stop-item:last-child:before{display:none}.stop-info{flex-direction:column;display:flex}.stop-name{color:#334155;font-size:.9rem;font-weight:600}.stop-time{color:#94a3b8;font-size:.75rem}.marker-label{white-space:nowrap;pointer-events:none;background:#fff;border:1px solid #f1f5f9;border-radius:8px;padding:4px 10px;font-size:.75rem;font-weight:700;position:absolute;top:-30px;left:50%;transform:translate(-50%);box-shadow:0 4px 10px #0000001a}.marker-icon-custom{border:3px solid #fff;border-radius:50%;width:24px;height:24px;box-shadow:0 4px 10px #0003}.back-button-container{z-index:1000;position:absolute;top:20px;left:20px}@media (max-width:768px){#map{height:calc(100vh - 56px)}.map-page-wrapper{height:calc(100vh - 56px);margin-top:-100px}.back-button-container{z-index:1000;top:75px;left:12px}.back-button-container .back-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;box-shadow:0 4px 12px #00000026;padding:8px 16px!important;font-size:.9rem!important}.marker-label{display:none}}.glass-back-btn{-webkit-backdrop-filter:blur(12px);color:#1e293b;cursor:pointer;background:#ffffff73;border:1px solid #ffffff4d;border-radius:12px;outline:none;align-items:center;gap:10px;padding:10px 18px;font-size:.95rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 4px 15px #00000014}.glass-back-btn:hover{background:#ffffffa6;border-color:#ffffff80;transform:translate(-4px);box-shadow:0 8px 25px #0000001f}.glass-back-btn i{font-size:.8rem;transition:transform .3s}.glass-back-btn:hover i{transform:translate(-2px)}.glass-back-btn span{letter-spacing:.3px}@keyframes pulseSoft{0%,to{opacity:.9;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}@keyframes slideIn{0%{opacity:0;transform:translate(120%)}to{opacity:1;transform:none}}@keyframes slideOut{to{opacity:0;transform:translate(120%)}}.profile-page{animation:.6s both fadeUp}.profile-card,.favorite-card{border:none;border-radius:16px;transition:transform .25s,box-shadow .25s}.profile-card:hover,.favorite-card:hover{transform:translateY(-6px);box-shadow:0 16px 30px #0000001f}.profile-avatar{font-size:5rem;animation:3s infinite pulseSoft}.badge-wrap{flex-wrap:wrap;justify-content:center;gap:.4rem;margin-top:.5rem;display:flex}.user-badge{border-radius:999px;padding:.35rem .6rem;font-size:.7rem;font-weight:700}.badge-head{color:#fff;background:linear-gradient(135deg,#ff9800,#ff5722);box-shadow:0 0 12px #ff572280}.badge-admin{color:#fff;background:#0d6efd}.badge-top{color:#fff;background:#198754}.badge-contributor{color:#fff;background:#6c757d}.level-badge{border-radius:999px;align-items:center;gap:.4rem;padding:.4rem .75rem;font-size:.8rem;font-weight:700;display:inline-flex}.level-bronze{color:#fff;background:linear-gradient(135deg,#cd7f32,#a97142)}.level-silver{color:#263238;background:linear-gradient(135deg,#cfd8dc,#90a4ae)}.level-gold{color:#5d4037;background:linear-gradient(135deg,#ffd54f,#ffb300);box-shadow:0 0 14px #ffc10780}.favorite-route{color:inherit;border-radius:12px;text-decoration:none;transition:all .2s;display:block}.favorite-route:hover{color:inherit;background-color:#f8f9fa;transform:translateY(-4px);box-shadow:0 8px 20px #0000001a}.achievement-toast{z-index:9999;background:#fff;border-radius:14px;align-items:center;gap:12px;width:320px;padding:16px 18px;animation:.5s forwards slideIn;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 12px 30px #0003}.achievement-toast.hiding{animation:.5s forwards slideOut}.route-form-container{max-width:1000px;margin:0 auto;padding-bottom:100px;font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif}.card{background:#fff;margin-bottom:24px;transition:transform .2s;border:none!important;border-radius:16px!important;overflow:visible!important;box-shadow:0 4px 20px #0000000d!important}.card-header{background:#fff!important;border-bottom:1px solid #f0f4f8!important;border-radius:16px 16px 0 0!important;padding:1.25rem 1.5rem!important}.card-header h4,.card-header h5{color:#1e293b;align-items:center;margin:0;font-size:1.1rem;font-weight:700;display:flex}.form-label{color:#64748b;text-transform:uppercase;letter-spacing:.025em;margin-bottom:8px;font-size:.75rem;font-weight:700}.form-control,.form-select{color:#1e293b;transition:all .2s;background-color:#fff!important;border:2px solid #e2e8f0!important;border-radius:10px!important;padding:10px 14px!important;font-size:.95rem!important}.form-control:focus,.form-select:focus{background-color:#fff!important;border-color:#4f46e5!important;box-shadow:0 0 0 4px #4f46e51a!important}.autocomplete-list{max-height:250px;margin-top:6px;overflow-y:auto;z-index:2000!important;background:#fff!important;border:1px solid #e2e8f0!important;border-radius:12px!important;padding:8px 0!important;box-shadow:0 10px 30px #00000026!important}.list-group-item-action{color:#334155;font-size:.9rem;border:none!important;padding:12px 16px!important}.btn-primary{box-shadow:0 4px 12px #4f46e533;background-color:#4f46e5!important;border:none!important;border-radius:10px!important;padding:10px 24px!important;font-weight:600!important}.btn-primary:hover{transform:translateY(-1px);background-color:#4338ca!important}.btn-soft-primary{color:#3b82f6;background-color:#eff6ff;border:1px dashed #3b82f6;border-radius:10px;padding:12px;transition:all .2s}.btn-soft-primary:hover{background-color:#dbeafe}.modal-backdrop{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background-color:#0f172ab3!important}.modal-content{border:none!important;border-radius:24px!important;box-shadow:0 25px 50px -12px #00000040!important}.table th{color:#64748b;letter-spacing:.05em;background:#f8fafc;font-size:.75rem;font-weight:700;padding:12px!important}.table td{vertical-align:middle;padding:12px 8px!important}.fixed-bottom{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid #e2e8f0;background:#fffc!important}.contribute-container{color:#334155;background-color:#f8fafc;min-height:100vh;padding-bottom:80px;font-family:Inter,Segoe UI,Roboto,sans-serif}.page-title{color:#0f172a;margin-bottom:4px;font-size:1.75rem;font-weight:700}.text-muted{color:#64748b;font-size:.95rem}.custom-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;margin-bottom:28px;overflow:visible;box-shadow:0 4px 12px #0f172a0f}.card-header-custom{padding:18px 24px 10px}.card-header-custom h5{color:#334155;text-transform:uppercase;letter-spacing:.04em;margin:0;font-size:.9rem;font-weight:700}.card-body{padding:20px 24px 24px}.form-label{color:#475569;margin-bottom:6px;font-size:.8rem;font-weight:600}.form-control-custom,.form-select-custom{color:#0f172a;background-color:#fff;border:1px solid #e2e8f0;border-radius:10px;width:100%;padding:12px 14px;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.form-control-custom:focus,.form-select-custom:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px #2563eb26}.form-control-custom[readonly]{color:#64748b;cursor:not-allowed;background-color:#f1f5f9}.force-uppercase{text-transform:uppercase}.autocomplete-list{z-index:9999;background:#fff;border:1px solid #e2e8f0;border-radius:10px;width:100%;max-height:40vh;padding:4px;position:absolute;top:calc(100% + 6px);overflow-y:auto;box-shadow:0 8px 16px #0f172a1f}.list-group-item-action{cursor:pointer;border:none;border-radius:8px;padding:10px 14px;font-size:.9rem}.list-group-item-action:hover{color:#1d4ed8;background-color:#eff6ff}.stop-row{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:12px;padding:12px 14px}.stop-main{grid-template-columns:1fr 150px;gap:12px;margin-bottom:10px;display:grid}.stop-meta{grid-template-columns:1fr 1fr 90px 40px;align-items:center;gap:10px;display:grid}.stop-meta .form-control-custom{background-color:#f8fafc;font-size:.85rem}.stop-order{text-align:center;background-color:#eef2ff;border:1px solid #c7d2fe;border-radius:8px;font-weight:700}.stop-delete-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.stop-delete-btn:hover{color:#ef4444;background-color:#fef2f2}.btn-primary-custom{color:#fff;background-color:#2563eb;border:none;border-radius:12px;padding:14px;font-size:1rem;font-weight:600}.btn-primary-custom:hover{background-color:#1d4ed8}.btn-outline-custom{color:#475569;background:#fff;border:1px dashed #cbd5e1;border-radius:12px;padding:12px;font-weight:600}.btn-outline-custom:hover{color:#2563eb;background-color:#eff6ff;border-color:#2563eb}@media (max-width:1023px){.stop-main{grid-template-columns:1fr}.stop-meta{grid-template-columns:1fr 1fr 90px 40px}}@media (max-width:767px){.page-title{font-size:1.4rem}.custom-card{border-radius:12px}.card-header-custom{padding:14px 16px 6px}.card-body{padding:14px 16px}.stop-row{padding:12px;box-shadow:0 2px 8px #0f172a14}.stop-main,.stop-meta{grid-template-columns:1fr;gap:8px}.stop-meta .form-control-custom{font-size:.8rem}.stop-delete-btn{background-color:#f8fafc;border:1px dashed #e2e8f0;width:100%;height:auto;padding:10px}.stop-delete-btn:hover{color:#ef4444;background-color:#fef2f2}.btn-outline-custom,.btn-primary-custom{width:100%}}:root{--accent:#0b6cff;--muted:#6b7a88;--card-radius:12px;--glass:#0b6cff0f}.add-route-btn,.add-route-cta{transition:transform .12s,box-shadow .12s}.add-route-btn:hover,.add-route-cta:hover{transform:translateY(-3px);box-shadow:0 12px 30px #0b6cff1a}.contributions-card{border:none;border-radius:12px;overflow:hidden}.contributions-card .card-body{padding:.8rem}.table thead{z-index:2;background:#fff;position:sticky;top:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.contributions-table tbody tr{opacity:0;border-radius:6px;transition:box-shadow .18s,transform .18s,background .2s;animation:.45s cubic-bezier(.2,.9,.2,1) forwards fadeInUp}.contributions-table tbody tr:hover{background:linear-gradient(90deg,#0b6cff08,#0000);transform:translateY(0)translate(6px);box-shadow:0 10px 28px #0b6cff0f}.badge{transition:transform .18s,box-shadow .18s}.badge.bg-success{box-shadow:0 8px 24px #28a74514}.badge.bg-warning{box-shadow:0 8px 24px #ffc10714}.badge.bg-danger{box-shadow:0 8px 24px #dc354514}@keyframes badgePulse{0%{transform:translateY(0)scale(1)}50%{transform:translateY(-2px)scale(1.03)}to{transform:translateY(0)scale(1)}}.badge.pulse{animation:1.8s infinite badgePulse}.empty-state{position:relative;overflow:hidden}.empty-illustration{color:#c6cdd6;transition:transform .35s cubic-bezier(.2,.9,.2,1),opacity .35s}.empty-state:hover .empty-illustration{color:#e0e6ed;transform:translateY(-6px)rotate(-6deg)}.add-route-cta{border-radius:999px}.decorative-accent{opacity:.06;filter:blur(2px)saturate(.9);pointer-events:none;z-index:0;background-image:url(/images/logo.png);background-position:50%;background-size:cover;width:420px;height:240px;position:fixed;top:-40px;right:-60px;transform:rotate(-8deg)}@media (max-width:720px){.contributions-table thead{display:none}.contributions-table tbody tr{background:#fff;border:1px solid #eee;border-radius:10px;margin-bottom:12px;padding:12px;display:block}.contributions-table tbody tr td{border:none;width:100%;padding:.25rem 0;display:block}}@media (prefers-reduced-motion:reduce){.contributions-table tbody tr,.badge.pulse,.empty-illustration,.add-route-btn,.add-route-cta{opacity:1!important;transition:none!important;animation:none!important;transform:none!important}.decorative-accent{display:none}}.manage-users-bg{background:linear-gradient(135deg,#eef2f7,#f8f9fa);min-height:100vh}.custom-card{background:#fff;border:none;border-radius:14px;box-shadow:0 12px 30px #00000014}.table thead{color:#fff;background:#0d6efd}.table tbody tr{transition:all .25s}.table tbody tr:hover{background:#f1f6ff;transform:scale(1.005)}.badge-role{letter-spacing:.5px;border-radius:20px;align-items:center;padding:6px 12px;font-size:.8rem;display:inline-flex}.role-admin{color:#fff;background:linear-gradient(45deg,#dc3545,#ff6b6b)}.role-user{color:#fff;background:linear-gradient(45deg,#6c757d,#adb5bd)}.role-conductor{color:#fff;background:linear-gradient(45deg,#0d6efd,#0dcaf0)}.role-partner{color:#fff;background:linear-gradient(45deg,#6610f2,#6f42c1)}.btn-update{transition:all .2s}.btn-update:hover{transform:translateY(-2px);box-shadow:0 6px 14px #0d6efd59}.success-row{animation:1.5s successGlow}@keyframes successGlow{0%{background-color:#d1e7dd;transform:scale(1.02)}to{background-color:#0000;transform:scale(1)}}.import-export-bg{background:linear-gradient(135deg,#eef2f7,#f8f9fa);min-height:100vh}.page-wrapper{animation:.6s both fadeInUp}.custom-card{background:#fff;border:none;border-radius:12px;transition:transform .2s}.custom-card:hover{transform:translateY(-2px)}.card-header-custom{border-bottom:1px solid #0000000d;padding:1.5rem;border-radius:12px 12px 0 0!important}.danger-card{border:1px solid #dc3545}.danger-header{color:#fff;background:#dc3545}.code-block{color:#d63384;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:15px;font-family:monospace;overflow-x:auto}.trip-start-screen{justify-content:center;align-items:center;padding:2rem 0;animation:.6s fadeIn;display:flex}.trip-start-container{text-align:center;background:#fff;border:1px solid #0000000d;border-radius:28px;width:100%;max-width:480px;padding:3.5rem 2.5rem;box-shadow:0 20px 25px -5px #0000001a}.trip-start-title{color:#0f172a;letter-spacing:-.05em;margin-bottom:2.5rem;font-size:2rem;font-weight:900}.trip-start-form{flex-direction:column;gap:2rem;display:flex}.input-type-selector{background:#f1f5f9;border-radius:14px;gap:.25rem;padding:.4rem;display:flex}.input-type-option{cursor:pointer;color:#64748b;-webkit-user-select:none;user-select:none;border-radius:10px;flex:1;justify-content:center;align-items:center;padding:.75rem;font-size:.9rem;font-weight:700;transition:all .2s;display:flex}.input-type-option input{display:none}.input-type-option.active{color:#0f172a;background:#fff;box-shadow:0 4px 6px -1px #0000000d}.trip-input-wrapper{position:relative}.trip-start-input{color:#0f172a;background:#f8fafc;border:2px solid #e2e8f0;border-radius:16px;width:100%;padding:1.25rem 1.5rem;font-size:1.15rem;font-weight:700;transition:all .2s}.trip-start-input:focus{background:#fff;border-color:#0f172a;outline:none;box-shadow:0 0 0 4px #0f172a0d}.trip-start-input::placeholder{color:#94a3b8;font-weight:500}.trip-suggestion-dropdown{z-index:100;background:#fff;border:1px solid #e2e8f0;border-radius:16px;max-height:250px;padding:.5rem;position:absolute;top:calc(100% + .5rem);left:0;right:0;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.trip-suggestion-item{cursor:pointer;text-align:left;border-radius:10px;flex-direction:column;gap:.2rem;padding:1rem 1.25rem;transition:all .15s;display:flex}.trip-suggestion-item:hover{background:#f1f5f9}.trip-suggestion-item strong{color:#0f172a;font-size:1.1rem}.route-subtext{color:#64748b;font-size:.8rem;font-weight:600}.trip-searching-indicator{color:#94a3b8;text-transform:uppercase;pointer-events:none;font-size:.75rem;font-weight:700;position:absolute;top:50%;right:1.25rem;transform:translateY(-50%)}.trip-start-button{color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:.1em;background:#0f172a;border:none;border-radius:16px;padding:1.15rem;font-size:1.1rem;font-weight:800;transition:all .2s;box-shadow:0 10px 15px -3px #0f172a1a}.trip-start-button:hover:not(:disabled){background:#1e293b;transform:translateY(-2px);box-shadow:0 20px 25px -5px #0f172a26}.trip-start-button:disabled{color:#94a3b8;cursor:not-allowed;box-shadow:none;background:#e2e8f0}@media (max-width:480px){.trip-start-container{box-shadow:none;background:0 0;border:none;padding:2.5rem 1.25rem}.trip-start-screen{padding:1rem 0}}@media (max-width:320px){.trip-start-title{font-size:1.5rem}}.poll-ui{flex-direction:column;gap:1.5rem;animation:.4s fadeIn;display:flex}.poll-header{text-align:center}.poll-question{color:#0f172a;margin:0 0 .25rem;font-size:1.15rem;font-weight:800}.poll-instruction{color:#64748b;margin:0;font-size:.85rem;font-weight:500}.poll-options{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}@media (max-width:320px){.poll-options{grid-template-columns:1fr}}.poll-option{cursor:pointer;background:#fff;border:2px solid #f1f5f9;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:.4rem;padding:1rem .5rem;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.poll-option:hover:not(:disabled){background:#f8fafc;border-color:#e2e8f0;transform:translateY(-2px)}.poll-option.selected{border-width:2.5px;transform:scale(.98);box-shadow:0 4px 6px -1px #0000000d}.poll-option-icon{font-size:1.5rem}.poll-option-label{color:#475569;font-size:.85rem;font-weight:700}.poll-option.selected .poll-option-label{color:#0f172a}.poll-submit-button{color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;background:#0f172a;border:none;border-radius:12px;width:100%;margin-top:.5rem;padding:1rem;font-size:1rem;font-weight:800;transition:all .2s;box-shadow:0 10px 15px -3px #0f172a1a}.poll-submit-button:hover:not(:disabled){background:#1e293b;transform:translateY(-2px);box-shadow:0 10px 15px -3px #0f172a33}.poll-submit-button:disabled{color:#94a3b8;cursor:not-allowed;box-shadow:none;background:#e2e8f0}@media (max-width:480px){.poll-option{padding:1rem .5rem}.poll-option-icon{font-size:1.25rem}}.count-update-ui{flex-direction:column;gap:1.5rem;animation:.4s fadeIn;display:flex}.count-header{color:#0f172a;text-align:center;margin:0;font-size:1.15rem;font-weight:800}.count-error{color:#991b1b;text-align:center;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:.75rem;font-size:.85rem;font-weight:600}.count-form{flex-direction:column;gap:1.75rem;display:flex}.count-group{flex-direction:column;gap:1rem;display:flex}.count-label{color:#64748b;text-transform:uppercase;letter-spacing:.05em;text-align:center;font-size:.85rem;font-weight:700}.count-control{justify-content:center;align-items:center;gap:1.5rem;display:flex}.count-btn{color:#0f172a;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fff;border:2px solid #e2e8f0;border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.25rem;font-weight:600;transition:all .2s;display:flex}.count-btn:hover:not(:disabled){background:#f8fafc;border-color:#0f172a}.count-btn:active:not(:disabled){background:#f1f5f9;transform:scale(.95)}.count-btn:disabled{opacity:.3;cursor:not-allowed}.count-input{text-align:center;color:#0f172a;appearance:none;background:0 0;border:none;outline:none;width:60px;margin:0;font-size:1.75rem;font-weight:800}.count-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.count-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.count-submit-btn{color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;background:#0f172a;border:none;border-radius:14px;width:100%;margin-top:.5rem;padding:1.15rem;font-size:1.1rem;font-weight:800;transition:all .2s;box-shadow:0 10px 15px -3px #0f172a1a}.count-submit-btn:hover:not(:disabled){background:#1e293b;transform:translateY(-2px);box-shadow:0 10px 15px -3px #0f172a33}.count-submit-btn:disabled{color:#94a3b8;cursor:not-allowed;box-shadow:none;background:#e2e8f0}.confirmation-dialog-overlay{z-index:10000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0000008c;justify-content:center;align-items:center;padding:1rem;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.confirmation-dialog{background:#fff;border-radius:16px;width:100%;max-width:450px;animation:.4s slideUp;overflow:hidden;box-shadow:0 12px 40px #00000040}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.confirmation-dialog.dangerous{border:3px solid #ef4444}.confirmation-dialog-header{background:linear-gradient(135deg,#f9fafb 0%,#f3f4f6 100%);border-bottom:1px solid #e5e7eb;padding:1.75rem 2rem 1rem}.confirmation-dialog.dangerous .confirmation-dialog-header{background:linear-gradient(135deg,#fef2f2 0%,#fee2e2 100%)}.confirmation-dialog-title{color:#1f2937;letter-spacing:.3px;margin:0;font-size:1.4rem;font-weight:700}.confirmation-dialog.dangerous .confirmation-dialog-title{color:#991b1b}.confirmation-dialog-body{padding:2rem}.confirmation-dialog-message{color:#6b7280;margin:0;font-size:1rem;font-weight:500;line-height:1.6}.confirmation-dialog.dangerous .confirmation-dialog-message{color:#7c2d12;background:#ef44440d;border-left:4px solid #ef4444;border-radius:8px;padding:1rem}.confirmation-dialog-footer{background:#f9fafb;border-top:1px solid #e5e7eb;gap:1rem;padding:1.5rem 2rem;display:flex}.confirmation-btn{letter-spacing:.5px;cursor:pointer;text-transform:uppercase;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:.5rem;min-height:44px;padding:.9rem 1.5rem;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:.95rem;font-weight:700;transition:all .3s;display:flex}.confirmation-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.confirmation-btn:active{transform:translateY(0)}.confirmation-cancel{color:#6b7280;background:#fff;border:2px solid #e5e7eb}.confirmation-cancel:hover{color:#1f2937;background:#f3f4f6;border-color:#d1d5db}.confirmation-confirm{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);box-shadow:0 4px 12px #3b82f64d}.confirmation-confirm:hover{box-shadow:0 6px 16px #3b82f666}.confirmation-confirm.dangerous{background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);box-shadow:0 4px 12px #ef44444d}.confirmation-confirm.dangerous:hover{box-shadow:0 6px 16px #ef444466}@media (max-width:768px){.confirmation-dialog{max-width:400px}.confirmation-dialog-header{padding:1.5rem 1.75rem .9rem}.confirmation-dialog-title{font-size:1.2rem}.confirmation-dialog-body{padding:1.75rem}.confirmation-dialog-message{font-size:.95rem}.confirmation-dialog-footer{gap:.75rem;padding:1.25rem 1.75rem}.confirmation-btn{padding:.8rem 1.25rem;font-size:.9rem}}@media (max-width:480px){.confirmation-dialog-overlay{padding:1rem .75rem}.confirmation-dialog{border-radius:12px;max-width:100%}.confirmation-dialog-header{padding:1.25rem 1.5rem .75rem}.confirmation-dialog-title{font-size:1.1rem}.confirmation-dialog-body{padding:1.5rem}.confirmation-dialog-message{font-size:.9rem;line-height:1.5}.confirmation-dialog.dangerous .confirmation-dialog-message{padding:.85rem}.confirmation-dialog-footer{flex-direction:column;gap:.6rem;padding:1rem 1.5rem}.confirmation-btn{width:100%;min-height:42px;padding:.75rem 1.25rem;font-size:.85rem}}@media (max-width:360px){.confirmation-dialog-overlay{padding:.75rem}.confirmation-dialog-header{padding:1.1rem 1.25rem .65rem}.confirmation-dialog-title{font-size:1rem}.confirmation-dialog-body{padding:1.25rem}.confirmation-dialog-message{font-size:.85rem}.confirmation-dialog-footer{padding:.9rem 1.25rem}.confirmation-btn{padding:.7rem 1rem;font-size:.8rem}}@media (prefers-color-scheme:dark){.confirmation-dialog-overlay{background:#000000b3}.confirmation-dialog{background:#1f2937;box-shadow:0 12px 40px #00000080}.confirmation-dialog-header{background:linear-gradient(135deg,#2d2d2d 0%,#1f2937 100%);border-bottom-color:#374151}.confirmation-dialog-title{color:#f3f4f6}.confirmation-dialog-body,.confirmation-dialog-message{color:#d1d5db}.confirmation-dialog-footer{background:#111827;border-top-color:#374151}.confirmation-cancel{color:#d1d5db;background:#2d2d2d;border-color:#374151}.confirmation-cancel:hover{color:#f3f4f6;background:#374151}}.mark-departed-button{color:#fff;letter-spacing:1px;cursor:pointer;text-transform:uppercase;background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);border:none;border-radius:8px;justify-content:center;align-items:center;gap:.75rem;width:100%;min-height:54px;padding:1.3rem 2.5rem;font-size:1.1rem;font-weight:700;transition:all .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 6px 16px #ef444459}.mark-departed-button:before{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.mark-departed-button:not(:disabled):hover:before{left:100%}.mark-departed-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 24px #ef444466}.mark-departed-button:active:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}.mark-departed-button:disabled{cursor:not-allowed;color:#9ca3af;background:#d1d5db;transform:none;box-shadow:0 2px 8px #0000000d}.mark-departed-button:not(:disabled){animation:3s infinite pulse}.mark-departed-button:after{content:"";width:0;height:0;transition:all .3s;display:inline-block}.mark-departed-button:hover:not(:disabled):after{width:4px}@media (max-width:768px){.mark-departed-button{letter-spacing:.5px;min-height:50px;padding:1.1rem 2rem;font-size:1rem}}@media (max-width:480px){.mark-departed-button{letter-spacing:0;min-height:46px;padding:.95rem 1.5rem;font-size:.95rem}}@media (max-width:360px){.mark-departed-button{letter-spacing:-.5px;min-height:44px;padding:.85rem 1.25rem;font-size:.9rem}}@media (prefers-color-scheme:dark){.mark-departed-button{box-shadow:0 6px 16px #ef444466}.mark-departed-button:disabled{color:#6b7280;background:#4b5563}}.live-occupancy-indicator{background:linear-gradient(135deg,#f0f9ff 0%,#f5f3ff 100%);border:2px solid #e0e7ff;border-radius:10px;flex-direction:column;gap:.75rem;padding:1.25rem 1.5rem;animation:.4s slideDown;display:flex}.occupancy-badge{background:#fff;border:2px solid;border-radius:8px;justify-content:center;align-items:center;gap:.75rem;min-height:60px;padding:1rem 1.5rem;transition:all .3s;display:flex}.occupancy-badge:hover{transform:scale(1.02);box-shadow:0 4px 12px #0000001a}.occupancy-badge[style*="border-color: rgb(34, 197, 94)"],.occupancy-badge[style*="border-color: #22c55e"]{background:#f0fdf4}.occupancy-badge[style*="border-color: rgb(234, 179, 8)"],.occupancy-badge[style*="border-color: #eab308"]{background:#fefce8}.occupancy-badge[style*="border-color: rgb(239, 68, 68)"],.occupancy-badge[style*="border-color: #ef4444"]{background:#fef2f2}.occupancy-badge[style*="border-color: rgb(168, 85, 247)"],.occupancy-badge[style*="border-color: #a855f7"]{background:#faf5ff}.occupancy-icon{flex-shrink:0;font-size:2rem;animation:2s infinite bounce}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.occupancy-label{color:#1f2937;letter-spacing:.3px;white-space:nowrap;font-size:1.1rem;font-weight:700}.occupancy-note{color:#9ca3af;text-align:center;text-transform:uppercase;letter-spacing:.5px;margin:0;font-size:.8rem;font-weight:500}@media (max-width:768px){.live-occupancy-indicator{gap:.6rem;padding:1rem 1.25rem}.occupancy-badge{min-height:55px;padding:.9rem 1.25rem}.occupancy-icon{font-size:1.75rem}.occupancy-label{font-size:1rem}.occupancy-note{font-size:.75rem}}@media (max-width:480px){.live-occupancy-indicator{border-radius:8px;gap:.5rem;padding:.9rem 1rem}.occupancy-badge{flex-direction:column;gap:.5rem;min-height:auto;padding:.8rem 1rem}.occupancy-icon{font-size:1.5rem}.occupancy-label{text-align:center;font-size:.95rem}.occupancy-note{font-size:.7rem}}@media (max-width:360px){.live-occupancy-indicator{padding:.8rem .9rem}.occupancy-badge{padding:.75rem .9rem}.occupancy-icon{font-size:1.3rem}.occupancy-label{font-size:.9rem}}@media (prefers-color-scheme:dark){.live-occupancy-indicator{background:linear-gradient(135deg,#1e293b 0%,#2d1b69 100%);border-color:#374151}.occupancy-badge{background:#1f2937}.occupancy-label{color:#f3f4f6}.occupancy-note{color:#6b7280}}.stop-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;transition:all .4s cubic-bezier(.23,1,.32,1);animation:.6s cubic-bezier(.16,1,.3,1) both fadeInUp;position:relative;overflow:hidden;box-shadow:0 4px 6px -1px #0000000d}.stop-card:hover{border-color:#cbd5e1;transform:translateY(-4px);box-shadow:0 10px 20px -5px #00000014}.stop-card.completed{background:#f8fafc;border-color:#f1f5f9}.stop-card.completed .stop-card-header{opacity:.7;background:#f1f5f9}.stop-card.active{z-index:2;border-color:#0f172a;transform:scale(1.02);box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.stop-card.active:hover{transform:translateY(-4px)scale(1.02)}.stop-card.active .stop-card-header{color:#fff;background:#0f172a}.stop-card.upcoming{border-color:#e2e8f0}.stop-card-header{background:#fff;border-bottom:1px solid #f1f5f9;align-items:center;gap:1rem;padding:1rem 1.25rem;transition:all .3s;display:flex}.stop-card.active .stop-card-header{border-bottom:none}.stop-card-icon{background:#f1f5f9;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;transition:all .3s;display:flex}.stop-card.active .stop-card-icon{color:#fff;background:#ffffff26;animation:2s infinite pulseWhite;box-shadow:0 0 15px #fff3}.stop-card.completed .stop-card-icon{background:#dcfce7}.stop-card-info{flex:1;min-width:0}.stop-card-name{color:#0f172a;white-space:normal;word-wrap:break-word;overflow-wrap:break-word;letter-spacing:-.01em;margin:0;font-size:1rem;font-weight:800;line-height:1.2}.stop-card.active .stop-card-name{color:#fff}.stop-card-status{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:.1rem 0 0;font-size:.7rem;font-weight:700}.stop-card.active .stop-card-status{color:#fff9}.stop-card-location{color:#cbd5e1;font-size:1.2rem}.stop-card.active .stop-card-location{color:#fff6}.stop-card-details{background:#f8fafc;flex-direction:column;gap:.3rem;padding:.75rem 1.25rem;display:flex}.detail-row{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.detail-label{color:#64748b;text-transform:uppercase;white-space:nowrap;font-size:.7rem;font-weight:600}.detail-value{color:#1e293b;text-align:right;font-size:.8rem;font-weight:700}.stop-card .live-occupancy-indicator{background:#fff;border:none;border-bottom:1px solid #f1f5f9;padding:1rem 1.5rem}.stop-card-poll,.stop-card-count,.stop-card-depart{background:#fff;border-bottom:1px solid #f1f5f9;padding:1.25rem}.stop-card-poll-result,.stop-card-count-result{background:#fff;border-bottom:1px solid #f1f5f9;padding:1rem 1.5rem;display:flex}.poll-result-badge,.count-result-badge{border-radius:12px;flex:1;justify-content:center;align-items:center;gap:.75rem;padding:1rem;font-size:.9rem;font-weight:700;display:flex}.poll-result-badge{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.count-result-badge{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe}.show-count-button{color:#0f172a;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;background:#fff;border:1.5px solid #0f172a;border-radius:12px;justify-content:center;align-items:center;gap:.5rem;width:100%;margin-bottom:1rem;padding:1rem;font-size:.9rem;font-weight:800;transition:all .2s;display:flex}.show-count-button:hover:not(:disabled){background:#f8fafc;transform:translateY(-2px)}.show-count-button:disabled{opacity:.5;cursor:not-allowed}.stop-card-footer{color:#94a3b8;text-align:center;text-transform:uppercase;letter-spacing:.05em;background:#f8fafc;padding:1rem 1.5rem;font-size:.8rem;font-weight:700}@media (max-width:480px){.stop-card-header{gap:.5rem;padding:.75rem .6rem}.stop-card-name{font-size:.95rem}.stop-card-status{font-size:.65rem}.stop-card-details,.stop-card-poll,.stop-card-count,.stop-card-depart{padding:.75rem .6rem}.poll-result-badge,.count-result-badge{text-align:center;flex-direction:column;gap:.5rem;padding:.75rem;font-size:.8rem}}@keyframes pulseWhite{0%{box-shadow:0 0 #fff6}70%{box-shadow:0 0 0 10px #fff0}to{box-shadow:0 0 #fff0}}.stop-list-container{flex-direction:column;gap:1.5rem;animation:.5s fadeIn;display:flex}.stop-list-header{flex-direction:column;gap:.75rem;padding:0 .5rem;display:flex}.stop-list-title{color:#0f172a;align-items:center;gap:.5rem;margin:0;font-size:1.1rem;font-weight:800;display:flex}.stop-progress{flex-direction:column;gap:.5rem;display:flex}.stop-progress-text{color:#64748b;text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:700}.stop-progress-bar{background:#e2e8f0;border-radius:999px;height:8px;overflow:hidden}.stop-progress-fill{background:#0f172a;border-radius:999px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.stop-list{flex-direction:column;gap:1rem;display:flex;position:relative}.stop-list:before{content:"";z-index:0;background:#e2e8f0;width:2px;position:absolute;top:40px;bottom:40px;left:31px}.stop-list-item{z-index:1;position:relative}.trip-completed-notice{color:#166534;text-align:center;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;justify-content:center;align-items:center;gap:.5rem;padding:1rem 1.5rem;font-size:.9rem;font-weight:700;display:flex;box-shadow:0 4px 6px -1px #0000000d}@media (max-width:640px){.stop-list:before{left:27px}}.error-message-container{z-index:9999;pointer-events:auto;max-width:500px;animation:.4s slideInRight;position:fixed;top:20px;left:20px;right:auto}@keyframes slideInRight{0%{opacity:0;transform:translate(400px)}to{opacity:1;transform:translate(0)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(400px)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.error-message{color:#991b1b;background:linear-gradient(135deg,#fee2e2 0%,#fecaca 100%);border:2px solid #fca5a5;border-left:5px solid #ef4444;border-radius:10px;align-items:center;gap:1rem;padding:1.25rem 1.5rem;font-size:.95rem;font-weight:600;animation:.3s shake;display:flex;position:relative;overflow:hidden;box-shadow:0 6px 20px #ef444440}.error-message:before{content:"";pointer-events:none;background:linear-gradient(90deg,#0000,#ffffff1a,#0000);position:absolute;inset:0}.error-icon{flex-shrink:0;font-size:1.5rem;animation:2s infinite bounce}.error-text{color:#991b1b;z-index:1;flex:1;font-size:.95rem;line-height:1.5;position:relative}.error-close{color:#991b1b;cursor:pointer;z-index:1;background:#ef444433;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;min-width:28px;height:28px;padding:0;font-size:1.2rem;font-weight:700;transition:all .2s;display:flex;position:relative}.error-close:hover{background:#ef44444d;transform:scale(1.1);box-shadow:0 2px 6px #ef44444d}.error-close:active{transform:scale(.95)}@media (max-width:768px){.error-message-container{max-width:calc(100% - 40px);left:20px;right:20px}.error-message{border-radius:10px;gap:.75rem;padding:1rem 1.25rem}.error-icon{font-size:1.3rem}.error-text{font-size:.9rem}.error-close{width:26px;min-width:26px;height:26px;font-size:1rem}}@media (max-width:480px){.error-message-container{max-width:calc(100% - 20px);top:10px;left:10px;right:10px}.error-message{border-left-width:4px;border-radius:8px;gap:.6rem;padding:.9rem 1rem;font-size:.9rem}.error-icon{font-size:1.2rem}.error-text{font-size:.85rem;line-height:1.4}.error-close{width:24px;min-width:24px;height:24px;font-size:.9rem}}@media (max-width:360px){.error-message-container{max-width:calc(100% - 16px);top:8px;left:8px;right:8px}.error-message{border-radius:6px;gap:.5rem;padding:.8rem .9rem;font-size:.8rem}.error-text{font-size:.8rem}.error-icon{font-size:1.1rem}.error-close{width:22px;min-width:22px;height:22px;font-size:.85rem}}@media (prefers-color-scheme:dark){.error-message{color:#fecaca;background:linear-gradient(135deg,#7c2d12 0%,#92400e 100%);border-color:#dc2626}.error-text{color:#fecaca}.error-icon{color:#fca5a5}.error-close{color:#fecaca;background:#ef44444d}.error-close:hover{background:#ef444466}}@keyframes fadeOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(500px)}}.conductor-dashboard{color:#1e293b;background-color:#0000;background-image:radial-gradient(at 0 0,#f5faff 0,#0000 50%),radial-gradient(at 50% 0,#f0f5ff 0,#0000 50%),radial-gradient(at 100% 0,#f5f9ff 0,#0000 50%),radial-gradient(at 100%,#fafcff 0,#0000 50%),radial-gradient(at 0 100%,#f5f7ff 0,#0000 50%);background-position:0 0,0 0,0 0,0 0,0 0;background-repeat:repeat,repeat,repeat,repeat,repeat;background-size:auto,auto,auto,auto,auto;background-attachment:fixed;background-origin:padding-box,padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box,border-box;flex-direction:column;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex;overflow-x:hidden}.offline-banner{color:#fff;text-align:center;z-index:1001;background:#dc2626;justify-content:center;align-items:center;gap:.5rem;padding:.75rem;font-size:.9rem;font-weight:600;display:flex;box-shadow:0 2px 10px #dc262633}.sync-badge{text-transform:uppercase;letter-spacing:.025em;border-radius:999px;align-items:center;gap:.5rem;padding:.4rem 1rem;font-size:.8rem;font-weight:700;transition:all .2s;display:flex}.sync-badge.synced{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.sync-badge.syncing{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe}.sync-badge.offline{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.sync-badge.error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.conductor-header{-webkit-backdrop-filter:blur(20px);z-index:1000;background:#ffffffd9;border-bottom:1px solid #0000000d;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;padding:.75rem 1.5rem;animation:.6s cubic-bezier(.16,1,.3,1) slideDown;display:flex;position:sticky;top:0;box-shadow:0 4px 6px -1px #0000000d}.conductor-header-left{align-items:center;gap:1rem;display:flex}.conductor-title{color:#0f172a;letter-spacing:-.025em;margin:0;font-size:1.4rem;font-weight:800}.conductor-header-right{align-items:center;gap:1.25rem;display:flex}.logout-button{color:#64748b;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:.4rem;padding:.4rem .75rem;font-size:.8rem;font-weight:600;transition:all .2s;display:flex}.logout-button:hover{color:#ef4444;background:#f1f5f9;border-color:#fee2e2}.trip-active-status{color:#fff;text-transform:uppercase;letter-spacing:.05em;background:#0f172a;border-radius:8px;align-items:center;gap:.5rem;padding:.4rem .75rem;font-size:.8rem;font-weight:700;display:flex;box-shadow:0 0 10px #0f172a33}.pulse-icon{animation:2s infinite pulseWhite}.conductor-content{flex:1;width:100%;max-width:600px;margin:0 auto;padding:1.5rem .5rem}.conductor-trip-view{flex-direction:column;gap:1.75rem;display:flex}.trip-info-header{background:#fff;border:1px solid #00000008;border-radius:20px;flex-wrap:wrap;justify-content:space-around;align-items:center;gap:.75rem;padding:1.25rem;animation:.8s cubic-bezier(.16,1,.3,1) both popIn;display:flex;box-shadow:0 10px 15px -3px #0000000d}.trip-info-segment{flex-direction:column;align-items:center;min-width:80px;display:flex}.trip-info-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.15rem;font-size:.7rem;font-weight:700}.trip-info-value{color:#1e293b;text-align:center;word-wrap:break-word;overflow-wrap:break-word;font-size:1.1rem;font-weight:800;line-height:1.2}.trip-info-arrow{color:#cbd5e1;font-size:1rem}.trip-completed-screen{justify-content:center;align-items:center;padding:2rem 0;display:flex}.trip-completed-container{text-align:center;background:#fff;border:1px solid #0000000d;border-radius:24px;width:100%;padding:3.5rem 2.5rem;box-shadow:0 20px 25px -5px #0000001a}.trip-completed-icon{margin-bottom:1.5rem;font-size:4rem}.trip-completed-title{color:#0f172a;margin-bottom:.75rem;font-size:2rem;font-weight:800}.trip-completed-message{color:#64748b;margin-bottom:2.5rem;font-size:1.1rem}.trip-completed-details{text-align:left;background:#f8fafc;border-radius:16px;margin-bottom:3rem;padding:2rem}.trip-completed-details p{color:#475569;justify-content:space-between;margin:.75rem 0;font-size:1rem;display:flex}.trip-completed-details strong{color:#1e293b}.start-new-trip-button{color:#fff;cursor:pointer;background:#0f172a;border:none;border-radius:14px;width:100%;padding:1.15rem 2rem;font-size:1.1rem;font-weight:700;transition:all .2s}.start-new-trip-button:hover{background:#1e293b;transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a}.conductor-footer{text-align:center;background:0 0;margin-top:auto;padding:2rem;animation:.8s cubic-bezier(.16,1,.3,1) .4s both slideUp}.conductor-footer-text{color:#94a3b8;margin:0;font-size:.9rem;font-weight:600}@keyframes popIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (max-width:640px){.conductor-header{padding:1rem 1.5rem}.conductor-title{font-size:1.25rem}.conductor-content{padding:2rem 1rem}.trip-info-header{gap:1rem;padding:1.25rem}.trip-info-value{font-size:1rem}.trip-completed-icon{font-size:3rem}.trip-completed-title{font-size:1.75rem}}.global-loader-overlay{-webkit-backdrop-filter:blur(8px);z-index:1010;pointer-events:all;background:#ffffffbf;justify-content:center;align-items:center;width:100vw;height:calc(100vh - 60px);transition:left .3s,width .3s;display:flex;position:fixed;top:60px;left:0}@media (min-width:992px){.loader-with-sidebar{width:calc(100vw - 240px);left:240px}}.loader-content{background:#ffffffe6;border:1px solid #ffffff80;border-radius:24px;flex-direction:column;align-items:center;gap:2rem;padding:2.5rem 3.5rem;display:flex;box-shadow:0 20px 40px #00000014}.bus-spinner{justify-content:center;align-items:center;width:70px;height:70px;display:flex;position:relative}.loader-icon{color:#3b82f6;z-index:2;font-size:2rem;animation:1s ease-in-out infinite alternate bounceBus}.spinner-ring{z-index:1;border:4px solid #f1f5f9;border-top-color:#3b82f6;border-radius:50%;width:100%;height:100%;animation:1s linear infinite spinRing;position:absolute;top:0;left:0}.loader-text-container-wrapper{justify-content:center;align-items:center;height:25px;display:flex;position:relative;overflow:visible}.loader-text-container{white-space:nowrap;justify-content:center;align-items:center;display:flex}.loader-message{color:#1e293b;letter-spacing:.3px;text-align:center;margin:0;font-size:1.15rem;font-weight:500}@keyframes spinRing{to{transform:rotate(360deg)}}@keyframes bounceBus{0%{transform:translateY(2px)}to{transform:translateY(-4px)}}@media (max-width:480px){.loader-content{padding:2rem 2.5rem}.loader-message{font-size:1rem}}.update-prompt-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:.3s ease-in-out fadeIn}.update-prompt-box{border:1px solid #0000001a;animation:.4s cubic-bezier(.175,.885,.32,1.275) slideUpFade}@keyframes slideUpFade{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}*{scrollbar-width:none;-ms-overflow-style:none}::-webkit-scrollbar{display:none}body{background-color:#f5f7fb!important}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}.hero-wrapper{background:linear-gradient(135deg,#0d6efd,#6610f2);justify-content:center;align-items:center;height:100vh;font-family:Segoe UI,system-ui,sans-serif;display:flex;position:relative;overflow:hidden}.bg-overlay{pointer-events:none;background:radial-gradient(circle at 20% 20%,#0e0c0c2e,#0000 40%),radial-gradient(circle at 80% 80%,#ffffff1f,#0000 40%);animation:8s ease-in-out infinite float;position:absolute;inset:0}.hero-card{text-align:center;z-index:1;background:#fff;border-radius:18px;width:90%;max-width:420px;padding:50px 40px;animation:1s forwards fadeUp;box-shadow:0 20px 50px #00000040}.hero-title{color:#212529;margin-bottom:12px;font-size:2.6rem;font-weight:700}.hero-title span{color:#0d6efd}.cta-btn-custom{color:#fff;background:linear-gradient(135deg,#0d6efd,#6610f2);border:none;border-radius:30px;padding:14px 30px;font-size:1rem;font-weight:600;text-decoration:none;transition:all .25s;display:inline-block;box-shadow:0 8px 20px #0d6efd73}.cta-btn-custom:hover{color:#fff;transform:scale(1.06);box-shadow:0 12px 28px #0d6efd99}
