.auth-card{width:100%;max-width:420px;background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:1.25rem;padding:2rem;box-shadow:0 18px 45px #0f172a14}.auth-header{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;margin-bottom:1.75rem}.auth-logo{transform:translateY(-.25rem)}.role-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .85rem;background-color:#f1f5f9;border-radius:9999px;color:#475569;font-size:.85rem;font-weight:600}.auth-title{font-size:2.5rem;font-weight:700;color:#0f172a;letter-spacing:-.02em}.auth-form{display:flex;flex-direction:column;gap:1rem}.input-group{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;color:#94a3b8}.text-input{width:100%;padding:.95rem 1rem .95rem 3rem;border-radius:.9rem;border:1px solid #E2E8F0;background-color:#fff;font-size:.95rem;color:#0f172a;transition:border-color .2s ease,box-shadow .2s ease}.text-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.toggle-password{position:absolute;right:.85rem;background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.25rem;transition:color .2s ease}.toggle-password:hover{color:#64748b}.primary-button:disabled{opacity:.7;cursor:not-allowed;box-shadow:none}.primary-button:hover{transform:translateY(-1px);box-shadow:0 16px 30px #2563eb4d}.primary-button:active{transform:translateY(0)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2.5rem 1.5rem;background:radial-gradient(circle at top,#f7f9fc,#eef2f7 45%,#e9eef5)}.auth-card{width:100%;max-width:440px;background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:1.25rem;padding:2rem;box-shadow:0 18px 45px #0f172a14}.auth-back{display:inline-flex;align-items:center;gap:.5rem;color:#64748b;font-weight:600;font-size:.9rem;margin-bottom:1.5rem;transition:color .2s ease;background:none;border:none;cursor:pointer}.auth-back:hover{color:#1e293b}.auth-header{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;margin-bottom:1.5rem}.auth-title{font-size:2.1rem;font-weight:700;color:#0f172a;letter-spacing:-.02em}.auth-subtitle{font-size:.95rem;color:#64748b}.verification-form{display:flex;flex-direction:column;gap:1.5rem}.auth-error{background-color:#fee2e2;color:#b91c1c;border:1px solid #FECACA;padding:.75rem 1rem;border-radius:.85rem;font-size:.9rem;margin-bottom:1rem}.code-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem;justify-items:center}.code-grid.single{grid-template-columns:1fr}.code-input{width:3rem;height:3rem;text-align:center;font-size:1.4rem;font-weight:700;border-radius:.85rem;border:1px solid #E2E8F0;background-color:#fff;color:#0f172a;transition:border-color .2s ease,box-shadow .2s ease}.code-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.primary-button{width:100%;border:none;border-radius:.95rem;padding:.95rem 1rem;font-weight:600;font-size:1rem;color:#fff;background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 12px 25px #2563eb40;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease}.primary-button:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.primary-button:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 16px 30px #2563eb4d}.primary-button:not(:disabled):active{transform:translateY(0)}.remember-device{display:flex;align-items:center;gap:.6rem;color:#64748b;font-size:.9rem;font-weight:500;cursor:pointer}.remember-device input{width:1rem;height:1rem;accent-color:#2563EB}.resend-container{text-align:center;margin-top:.5rem}.resend-success{font-size:.9rem;color:#16a34a;margin-bottom:.5rem}.resend-button{background:none;border:none;color:#2563eb;font-size:.9rem;font-weight:600;cursor:pointer;padding:.5rem .75rem;border-radius:.5rem;transition:opacity .2s,background-color .2s}.resend-button:hover:not(:disabled){text-decoration:underline;background-color:#2563eb14}.resend-button:disabled{color:#94a3b8;cursor:not-allowed;opacity:.7}@media (max-width: 480px){.auth-card{padding:1.5rem}.code-input{width:2.6rem;height:2.6rem;font-size:1.2rem}}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;animation:slideUp .5s ease-out;position:relative;flex-shrink:0}.dashboard-header-left{flex:1}.dashboard-app-name{color:#2563eb;font-size:1rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:.2rem}.dashboard-title{font-size:1.75rem;font-weight:700;background:linear-gradient(to right,#111827,#374151);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-top:.2rem}@media (min-width: 1024px){.dashboard-title{font-size:2.15rem}}.dashboard-header-actions{display:flex;align-items:center;gap:.5rem;position:fixed;top:1.5rem;right:1.5rem;z-index:1000}.dashboard-header-btn{padding:.625rem;background-color:#fefefe;border:1px solid rgb(229,231,235);border-radius:.75rem;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #0000001a,0 1px 2px -1px #0000001a}.dashboard-header-btn:hover{background-color:#f9fafb;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.dashboard-header-icon{width:1.5rem;height:1.5rem;color:#1f2937}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:998;animation:fadeIn .3s ease}.sidebar{position:fixed;top:0;right:0;height:100vh;width:20rem;background:linear-gradient(to bottom,#1e293b,#0f172a);z-index:999;transform:translate(100%);transition:transform .3s ease;display:flex;flex-direction:column;padding:1.5rem;box-shadow:-4px 0 20px #0000004d;border-left:1px solid rgb(51,65,85)}.sidebar.open{transform:translate(0)}.sidebar-close-button{align-self:flex-end;margin-bottom:1.5rem;background:transparent;border:none;color:#fff;padding:.625rem;border-radius:.75rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.sidebar-close-button:hover{background-color:#334155}.sidebar-close-icon{width:1.5rem;height:1.5rem}.sidebar-logo-container{display:flex;justify-content:center;margin-bottom:2rem}.sidebar-nav{display:flex;flex-direction:column;gap:.5rem}.sidebar-nav-button{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:transparent;border:none;color:#cbd5e1;font-size:1rem;font-weight:500;border-radius:.75rem;cursor:pointer;transition:all .2s ease;text-align:left}.sidebar-nav-button:hover{background-color:#334155;color:#fff}.sidebar-nav-button.logout{margin-top:auto;color:#ef4444}.sidebar-nav-button.logout:hover{background-color:#ef44441a;color:#f87171}.sidebar-nav-icon{width:1.25rem;height:1.25rem}.card{background-color:#fefefe;border-radius:1rem;box-shadow:0 2px 15px -3px #00000012,0 10px 20px -2px #0000000a;border:1px solid rgb(243,244,246)}.button{font-weight:600;border-radius:.75rem;transition:all .2s ease-in-out;display:flex;align-items:center;justify-content:center;gap:.5rem;border:none;cursor:pointer}.button-small{padding:.5rem 1rem;font-size:.875rem}.button-medium,.button-md{padding:.875rem 1.75rem;font-size:1rem;min-height:2.75rem}.button-large{padding:1rem 2rem;font-size:1.125rem;min-height:3rem}.button-primary{background:linear-gradient(to right,#2563eb,#1d4ed8);color:#fff;box-shadow:0 10px 15px -3px #2563eb4d,0 4px 6px -2px #2563eb4d}.button-primary:hover{background:linear-gradient(to right,#1d4ed8,#1e40af);box-shadow:0 20px 25px -5px #2563eb66,0 10px 10px -5px #2563eb66}.button-danger{background:linear-gradient(to right,#dc2626,#b91c1c);color:#fff;box-shadow:0 10px 15px -3px #dc26264d,0 4px 6px -2px #dc26264d}.button-danger:hover{background:linear-gradient(to right,#b91c1c,#991b1b);box-shadow:0 20px 25px -5px #dc262666,0 10px 10px -5px #dc262666}.button-secondary{background-color:#e5e7eb;color:#1f2937}.button-secondary:hover{background-color:#d1d5db}.button-ghost{background-color:transparent;color:#4b5563}.button-ghost:hover{background-color:#f3f4f6}.button:active{transform:scale(.95)}.dashboard-page{min-height:100vh;min-height:100dvh;overflow-y:auto;overflow-x:hidden;background:linear-gradient(to bottom right,#f9fafb,#eff6ff);display:flex;flex-direction:column}.dashboard-main-content{flex:1;min-height:0;display:flex;flex-direction:column;transition:all .3s ease}.dashboard-main-content.with-sidebar{margin-right:0}@media (max-width: 768px){.dashboard-main-content.with-sidebar{margin-right:0}}.dashboard-content-wrapper{padding:clamp(.5rem,2vw,1rem) clamp(1rem,4vw,2rem);max-width:100%;width:100%;margin:0;flex:1;display:flex;flex-direction:column;min-height:0}.dashboard-grid-layout{display:grid;grid-template-columns:1fr;gap:clamp(.5rem,1.5vh,1rem);flex:1 1 auto;min-height:0}@media (min-width: 1024px){.dashboard-grid-layout{grid-template-columns:1fr 2fr;gap:clamp(.5rem,1.5vh,1rem)}}.dashboard-grid-layout>div{min-height:0;display:flex;flex-direction:column}.dashboard-grid-layout>div>.dashboard-section,.dashboard-grid-layout>div>.card{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden}@media (max-height: 700px){.dashboard-content-wrapper{padding:.5rem 1rem}.dashboard-section,.dashboard-section.large{padding:.5rem .75rem}.dashboard-section-header{margin-bottom:.5rem}.dashboard-section-title{font-size:1rem}.terminal-card{min-height:52px}.stat-card{min-height:52px;padding:.4rem .6rem}.stat-value{font-size:1.4rem}.passenger-count-text{font-size:2rem}.passenger-count-display img{width:3rem;height:3rem}}@media (max-height: 500px){.dashboard-header{margin-bottom:.4rem}.dashboard-title{font-size:1.35rem}.terminal-card{min-height:44px;padding:.35rem .6rem}.terminal-icon-container img{width:2rem;height:2rem}.terminal-name{font-size:.8rem}.passenger-count{font-size:1.2rem}.stat-card{min-height:44px;padding:.35rem .5rem}.stat-value{font-size:1.15rem}.stat-label-text{font-size:.7rem}.passenger-count-text{font-size:1.5rem}.passenger-count-display img{width:2.5rem;height:2.5rem}}.terminal-card{padding:clamp(.5rem,1.5vh,1rem) clamp(.75rem,2vw,1.25rem);border-radius:.75rem;display:flex;align-items:center;position:relative;border:1px solid #E0E0E0;transition:all .2s ease-in-out;animation:slideUp .5s ease-out;box-shadow:0 2px 8px #00000014;min-height:clamp(56px,12vh,90px)}.terminal-card:hover{box-shadow:0 4px 12px #0000001f}.status-indicator{position:absolute;top:.65rem;left:.65rem;width:.9rem;height:.9rem;border-radius:9999px;z-index:1}.status-indicator.active{background-color:#6dd400}.status-indicator.inactive{background-color:#f44336}.terminal-card-content{display:flex;align-items:center;width:100%;gap:0;height:100%}.terminal-left-section{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding-right:.85rem;border-right:1px solid #E0E0E0;height:100%}.terminal-icon-container{padding:0;background:transparent;border-radius:0;box-shadow:none;display:flex;align-items:center;justify-content:center;margin-bottom:.2rem}.terminal-icon-container img{width:3rem;height:3rem;-o-object-fit:contain;object-fit:contain}.terminal-name{color:#1f2937;font-weight:600;font-size:1.1rem;text-align:center}.terminal-passenger-info{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding-left:.85rem;gap:.3rem;height:100%}.passenger-icon-container{padding:0;border-radius:0;background:transparent;display:flex;align-items:center;justify-content:center}.passenger-icon-container.active img{width:2.75rem;height:2.75rem;-o-object-fit:contain;object-fit:contain;filter:sepia(1) saturate(6) hue-rotate(8deg)}.passenger-icon-container.inactive img{width:2.75rem;height:2.75rem;-o-object-fit:contain;object-fit:contain}.passenger-count{font-weight:700;font-size:1.75rem}.passenger-count.active{color:#1f2937}.passenger-count.inactive{color:#ccc}.passenger-card{display:flex;gap:0;padding:.85rem 1rem;background-color:#f8fafc;border-radius:.6rem;border:1px solid rgb(229,231,235);transition:all .2s ease-in-out}.passenger-card:hover{border-color:#bfdbfe;box-shadow:0 2px 15px -3px #00000012,0 10px 20px -2px #0000000a}.passenger-card--in-destination{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-color:#f87171;box-shadow:0 0 0 1px #f8717140}.passenger-card--in-destination:hover{border-color:#ef4444;box-shadow:0 2px 15px -3px #ef444433,0 4px 12px -2px #dc26261f}.passenger-card--in-destination .passenger-icon-wrapper{background-color:#fecaca}.passenger-card--extended-trip{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-color:#34d399;box-shadow:0 0 0 1px #34d39940}.passenger-card--extended-trip:hover{border-color:#10b981;box-shadow:0 2px 15px -3px #10b98133,0 4px 12px -2px #0596691f}.passenger-card--extended-trip .passenger-icon-wrapper{background-color:#a7f3d0}.passenger-card--in-destination.passenger-card--extended-trip{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-color:#f87171;box-shadow:0 0 0 1px #f8717140}.passenger-card--in-destination.passenger-card--extended-trip .passenger-icon-wrapper{background-color:#fecaca}.passenger-card--violator{background:linear-gradient(135deg,#fca5a5,#ef4444 55%,#dc2626);border-color:#7f1d1d;box-shadow:0 0 0 2px #7f1d1da6,0 4px 20px -4px #7f1d1d73}.passenger-card--violator:hover{border-color:#450a0a;box-shadow:0 0 0 2px #450a0abf,0 6px 24px -4px #450a0a66}.passenger-card--violator .passenger-icon-wrapper{background-color:#fecaca}.passenger-card--violator .passenger-number,.passenger-card--violator .route-label,.passenger-card--violator .route-terminal{color:#1f0505}.passenger-card--violator.passenger-card--extended-trip{background:linear-gradient(135deg,#fca5a5,#ef4444 55%,#dc2626);border-color:#7f1d1d;box-shadow:0 0 0 2px #7f1d1da6,0 4px 20px -4px #7f1d1d73}.passenger-card--violator.passenger-card--extended-trip .passenger-icon-wrapper{background-color:#fecaca}.passenger-card-left{display:flex;align-items:center;gap:.5rem;flex-shrink:0;padding-right:.85rem;border-right:1px solid #E0E0E0}.passenger-icon-wrapper{padding:.35rem;background-color:#dbeafe;border-radius:.4rem;display:flex;align-items:center;justify-content:center}.passenger-icon-wrapper img{width:1.75rem;height:1.75rem;-o-object-fit:contain;object-fit:contain}.passenger-number{font-weight:700;font-size:1.15rem;color:#111827}.passenger-card-right{flex:1;display:flex;flex-direction:column;gap:.2rem;padding-left:1rem}.route-segment{display:flex;align-items:center;gap:1.25rem;flex-wrap:nowrap;width:100%;justify-content:space-between}.route-main-content{display:flex;align-items:center;gap:.9rem;flex:1;justify-content:center}.route-badge-wrap{min-width:5.5rem;max-width:11rem;display:flex;flex-wrap:wrap;gap:.35rem;justify-content:flex-end;align-items:center}.in-destination-badge{display:inline-flex;align-items:center;padding:.2rem .55rem;border-radius:.35rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;background-color:#fecaca;color:#991b1b;border:1px solid #f87171;margin-right:0}.extended-badge{display:inline-flex;align-items:center;padding:.2rem .55rem;border-radius:.35rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;background-color:#6ee7b7;color:#065f46;border:1px solid #34d399;white-space:nowrap}.violator-badge{display:inline-flex;align-items:center;padding:.22rem .55rem;border-radius:.35rem;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;line-height:1.2;background-color:#450a0a;color:#fef2f2;border:1px solid #1f0505;white-space:nowrap}.route-stop{display:flex;flex-direction:column;align-items:center;gap:.125rem;justify-content:center;flex-shrink:0}.route-label{font-size:.85rem;color:#94a3b8;font-weight:400;line-height:1;text-align:center}.route-terminal{font-size:1.05rem;color:#334155;font-weight:600;line-height:1}.route-extended-badge{font-size:.625rem;font-weight:600;color:#2563eb;background-color:#dbeafe;padding:.3rem .55rem;border-radius:.375rem;line-height:1.2;text-transform:uppercase;letter-spacing:.025em;white-space:nowrap;flex-shrink:0;align-self:center}.route-arrow{width:1rem;height:1rem;flex-shrink:0;align-self:center}.route-arrow-main{color:#16a34a}.route-arrow-extended{color:#2563eb}.route-pin{width:1rem;height:1rem;flex-shrink:0}.route-pin-canceled{color:#6b7280}.route-pin-destination{color:#ef4444}.stat-card{background-color:#fefefe;border-radius:.75rem;padding:clamp(.5rem,1.5vh,1rem) clamp(.65rem,2vw,1.25rem);box-shadow:0 10px 20px #0f172a0f;border:1px solid #E5E7EB;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;animation:slideUp .5s ease-out;display:flex;flex-direction:column;gap:clamp(.25rem,.8vh,.5rem);min-height:clamp(60px,12vh,95px)}.stat-card:hover{box-shadow:0 18px 30px #0f172a1f;transform:translateY(-.2rem);border-color:#d1d5db}.stat-card-clickable{cursor:pointer}.stat-card-clickable:hover{box-shadow:0 18px 30px #0f172a26;transform:translateY(-.25rem);border-color:#9ca3af}.stat-card-clickable:active{transform:translateY(-.1rem)}.stat-edit-hint{font-size:.85rem;color:#6b7280;margin-left:auto;opacity:.7;transition:opacity .2s ease}.stat-card-clickable:hover .stat-edit-hint{opacity:1}.stat-value{font-size:1.9rem;font-weight:700;letter-spacing:-.02em}.stat-value.blue{color:#2563eb}.stat-value.green{color:#16a34a}.stat-value.yellow{color:#ca8a04}.stat-value.gray{color:#4b5563}.stat-label{display:flex;align-items:center;gap:.5rem;margin-top:auto}.stat-label-text{font-size:.9rem;color:#64748b;font-weight:600;line-height:1.25}.stat-icon{width:1.4rem;height:1.4rem;padding:.35rem;border-radius:.5rem;box-sizing:content-box}.stat-icon.blue{color:#2563eb;background-color:#2563eb1f}.stat-icon.green{color:#16a34a;background-color:#16a34a1f}.stat-icon.yellow{color:#ca8a04;background-color:#ca8a041f}.stat-icon.gray{color:#4b5563;background-color:#4b55631f}.dashboard-section{background-color:#fefefe;border-radius:.75rem;box-shadow:0 2px 15px -3px #00000012,0 10px 20px -2px #0000000a;border:1px solid rgb(243,244,246);padding:clamp(.6rem,1.5vh,1rem) clamp(.75rem,2vw,1.25rem);animation:slideUp .5s ease-out}.dashboard-section.large{padding:clamp(.6rem,1.5vh,1rem) clamp(.75rem,2vw,1.25rem)}.dashboard-section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.85rem}.dashboard-section-icon{padding:.5rem;background-color:#dbeafe;border-radius:.5rem;display:flex;align-items:center;justify-content:center}.dashboard-section-icon svg{width:1.5rem;height:1.5rem;color:#2563eb}.dashboard-section-icon img{width:1.5rem;height:1.5rem;-o-object-fit:contain;object-fit:contain}.dashboard-section-title{font-size:1.15rem;font-weight:700;color:#111827}.terminals-list{display:flex;flex-direction:column;gap:.5rem}.current-passengers-header{display:flex;align-items:center;margin-bottom:.75rem}.current-passengers-content{display:flex;align-items:flex-start;gap:0;min-height:0}.passenger-count-section{flex-shrink:0;display:flex;flex-direction:column;padding-right:1.25rem;width:32%;min-width:130px;justify-content:flex-start;align-self:center}.passenger-count-title{font-size:1.15rem;font-weight:600;color:#111827;margin-bottom:0;line-height:1.2}.passenger-count-display{display:flex;align-items:center;justify-content:flex-start;gap:.85rem;flex:1}.passenger-count-display img{width:4.5rem;height:4.5rem;-o-object-fit:contain;object-fit:contain;flex-shrink:0}.passenger-count-text{font-size:2.85rem;font-weight:700;color:#2563eb;line-height:1}.current-passengers-divider{width:1px;background-color:#e0e0e0;align-self:stretch;margin:0 1rem;flex-shrink:0}.passengers-list{flex:1;display:flex;flex-direction:column;gap:.5rem;padding-left:0;min-width:0}.shift-status-card{display:flex;align-items:center;justify-content:space-between;gap:1.25rem}.shift-status-text{display:flex;flex-direction:column;gap:.35rem}.shift-status-title{font-size:1.25rem;font-weight:700;color:#1f2937}.shift-status-subtitle{font-size:1.05rem;color:#94a3b8}.shift-time-highlight{color:#1f2937;font-weight:600}.shift-status-button{padding:.75rem 1.5rem;border-radius:9999px;font-size:1.05rem;box-shadow:0 10px 20px #ef444440}.shift-status-button-icon{width:.75rem;height:.75rem;background-color:#fff;border-radius:9999px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 0 0 4px #ffffff40}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.65rem}@media (min-width: 768px){.stats-grid{grid-template-columns:repeat(5,1fr)}}.dashboard-right-column{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto auto;gap:clamp(.5rem,1.2vh,.75rem);min-height:0}.dashboard-right-column>*:nth-child(1){grid-column:1;grid-row:1}.dashboard-right-column>*:nth-child(2){grid-column:2;grid-row:1}.dashboard-right-column>*:nth-child(3){grid-column:1 / -1;grid-row:2}.dashboard-right-column>*:nth-child(4){grid-column:1 / -1;grid-row:3}@media (max-width: 1023px){.dashboard-right-column{display:flex;flex-direction:column}.dashboard-right-column>*:nth-child(1),.dashboard-right-column>*:nth-child(2),.dashboard-right-column>*:nth-child(3),.dashboard-right-column>*:nth-child(4){grid-column:unset;grid-row:unset}}.route-selection-section{margin-top:0;padding:.6rem 1rem}.route-selection-inline{display:flex;align-items:center;justify-content:center;gap:.75rem;flex-wrap:wrap}.route-selection-header-compact{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.route-selection-icon-inline{color:#2563eb;flex-shrink:0}.route-selection-title-compact{font-size:1.05rem;font-weight:700;color:#111827}.route-selection-controls{display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap;min-width:0}.route-control-group{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.route-control-label{font-size:.9rem;font-weight:600;color:#64748b;white-space:nowrap}.route-control-select{font-size:1rem;font-weight:600;color:#111827;padding:.4rem 1.75rem .4rem .6rem;border:2px solid #E5E7EB;border-radius:.5rem;background-color:#fff;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center;min-width:2.5rem}.route-control-select:hover:not(:disabled){border-color:#d1d5db}.route-control-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #3b82f633}.route-control-select:disabled{opacity:.7;cursor:not-allowed}.route-control-arrow{color:#2563eb;opacity:.8;flex-shrink:0}.route-control-divider{width:1px;height:1.25rem;background:#e2e8f0;flex-shrink:0}.route-selection-button-compact{flex-shrink:0;padding:.45rem .9rem;font-size:.95rem;font-weight:600}.terminals-section{display:flex;flex-direction:column;min-height:0;overflow:hidden}.terminals-section .terminals-list{flex:1;display:flex;flex-direction:column;gap:.5rem;min-height:0}.driver-insights-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}.driver-insights-icon{padding:.5rem;background-color:#dbeafe;border-radius:.75rem;display:flex;align-items:center;justify-content:center}.driver-insights-icon svg{width:1.25rem;height:1.25rem;color:#2563eb}.driver-insights-title{font-size:1.05rem;font-weight:700;color:#111827;margin:0}.driver-insights-subtitle{font-size:.85rem;color:#6b7280;margin:.15rem 0 0}.driver-insights-grid{display:grid;grid-template-columns:1fr;gap:.75rem}@media (min-width: 768px){.driver-insights-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.driver-insights-item{padding:.65rem .9rem;border-radius:.75rem;background-color:#f9fafb;border:1px solid #E5E7EB}.driver-insights-item-title{font-size:.9rem;font-weight:600;margin:0 0 .25rem;color:#111827}.driver-insights-item-text{font-size:.78rem;color:#6b7280;margin:0;line-height:1.4}.animation-delay-200{animation-delay:.2s}.animation-delay-400{animation-delay:.4s}.animation-delay-600{animation-delay:.6s}.button-pulse-indicator{width:.5rem;height:.5rem;background-color:#fefefe;border-radius:9999px;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.passenger-arrival-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:1100;padding:1rem;animation:fadeIn .2s ease}.passenger-arrival-modal{background:linear-gradient(180deg,#fff,#f8fafc);border-radius:1rem;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #f8717133;width:100%;max-width:min(32rem,100%);max-height:90vh;overflow-y:auto;padding:1.75rem 1.75rem 1.35rem;border-top:4px solid #f87171;animation:slideUp .3s ease}.passenger-arrival-modal-icon-wrap{width:3.75rem;height:3.75rem;border-radius:.85rem;background:linear-gradient(135deg,#fecaca,#fee2e2);color:#b91c1c;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}.passenger-arrival-modal-title{font-size:clamp(1.35rem,4.5vw,1.65rem);font-weight:800;color:#0f172a;margin:0 0 1rem;letter-spacing:-.02em;line-height:1.25}.passenger-arrival-modal-body{font-size:clamp(1.05rem,3.2vw,1.25rem);line-height:1.45;color:#334155}.passenger-arrival-line{margin:0 0 .85rem;font-size:clamp(1.1rem,3.4vw,1.35rem);font-weight:600;color:#0f172a}.passenger-arrival-hint{margin:0 0 .75rem}.passenger-arrival-hint:last-child{margin-bottom:0}.passenger-arrival-countdown{margin:1rem 0 0;padding-top:1rem;border-top:1px solid #e2e8f0;text-align:center;font-size:clamp(1rem,2.8vw,1.15rem);font-weight:600;color:#475569;letter-spacing:.02em}.passenger-arrival-countdown-value{display:inline-block;min-width:1.25ch;font-variant-numeric:tabular-nums;font-size:clamp(1.35rem,4vw,1.75rem);font-weight:800;color:#0f172a;vertical-align:baseline}.expenses-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.expenses-modal-content{background-color:#fff;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease;display:flex;flex-direction:column}.expenses-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #E5E7EB}.expenses-modal-title{font-size:1.5rem;font-weight:700;color:#111827;margin:0;letter-spacing:-.02em}.expenses-modal-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.5rem;transition:all .2s ease}.expenses-modal-close:hover{background-color:#f3f4f6;color:#111827}.expenses-modal-body{padding:1.5rem;flex:1;overflow-y:auto}.expenses-input-group{margin-bottom:1.5rem}.expenses-input-group:last-child{margin-bottom:0}.expenses-input-wrapper{position:relative;display:flex;align-items:center}.expenses-currency-prefix{position:absolute;left:1rem;font-size:1rem;font-weight:600;color:#6b7280;pointer-events:none;z-index:1}.expenses-input-with-prefix{padding-left:2.5rem!important}.expenses-label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.625rem;letter-spacing:.01em}.expenses-input{width:100%;padding:.875rem 1rem;border:2px solid #E5E7EB;border-radius:.75rem;font-size:1rem;color:#111827;background-color:#fff;transition:all .2s ease;box-sizing:border-box;font-family:inherit}.expenses-input::-moz-placeholder{color:#9ca3af}.expenses-input::placeholder{color:#9ca3af}.expenses-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f61a;background-color:#fff}.expenses-input:disabled{background-color:#f9fafb;border-color:#e5e7eb;cursor:not-allowed;opacity:.7;color:#6b7280}.expenses-input[type=number]{-moz-appearance:textfield}.expenses-input[type=number]::-webkit-outer-spin-button,.expenses-input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.expenses-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid #E5E7EB;flex-shrink:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.absolute{position:absolute}.sticky{position:sticky}.block{display:block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.h-28{height:7rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.w-28{width:7rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.items-center{align-items:center}.justify-center{justify-content:center}.border{border-width:1px}.object-contain{-o-object-fit:contain;object-fit:contain}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--text-primary: #1a1a1a;--text-secondary: #666666;--border-color: #e0e0e0;--accent-primary: #1e88e5;--accent-success: #4caf50;--accent-warning: #ff9800;--accent-error: #f44336}[data-theme=dark]{--bg-primary: #000000;--bg-secondary: #111111;--text-primary: #ffffff;--text-secondary: #b0b0b0;--border-color: #333333}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-secondary);color:var(--text-primary);min-height:100vh}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@keyframes spin{to{transform:rotate(360deg)}}
