:root{--primary:#245b72;--primary-dark:#194051;--primary-light:#ddeff5;--background:#f8fafc;--card-bg:#fff;--text:#0f172a;--subtext:#64748b;--border:#e2e8f0;--input-bg:#f8fafc;--success:#10b981;--danger:#ef4444;--warning:#f59e0b;--white:#fff;--shadow-sm:0 2px 4px #00000005;--shadow-md:0 4px 12px #0000000d;--shadow-lg:0 10px 24px #0f172a14;--shadow-xl:0 20px 32px #0f172a1f;--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-xl:24px;--radius-xxl:32px}*{box-sizing:border-box;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;margin:0;padding:0}body{color:var(--text);background-color:#0b151a;justify-content:center;align-items:center;min-height:100dvh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;display:flex;overflow:hidden}#root{justify-content:center;align-items:center;width:100%;height:100dvh;display:flex}.app-container{background-color:var(--background);width:100%;max-width:450px;height:92vh;max-height:900px;box-shadow:var(--shadow-xl), 0 0 0 1px #ffffff0d;border:12px solid #1e293b;border-radius:40px;flex-direction:column;display:flex;position:relative;overflow:hidden}.screen-content{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden auto}.screen-content::-webkit-scrollbar{width:0;height:0}@media (width<=480px),(height<=550px){body{background-color:var(--background)}.app-container{border:none;border-radius:0;max-width:100%;height:100dvh;max-height:100%}}input,button,select,textarea{font-family:inherit;font-size:inherit}button{cursor:pointer;background:0 0;border:none;outline:none}a{color:inherit;text-decoration:none}.flex-row{flex-direction:row;display:flex}.flex-col{flex-direction:column;display:flex}.align-center{align-items:center}.justify-between{justify-content:space-between}.loader-container{background-color:var(--background);flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.spinner{border:4px solid #245b721a;border-left-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.slide-up{animation:.3s cubic-bezier(.16,1,.3,1) forwards slideUp}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:.2s ease-out forwards fadeIn}.pulse{animation:1.4s ease-in-out infinite pulseAnim}@keyframes pulseAnim{0%{opacity:.45}50%{opacity:1}to{opacity:.45}}.login-screen{background-color:var(--background);flex-direction:column;justify-content:flex-end;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.login-video-bg{object-fit:cover;z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}.login-overlay{z-index:2;pointer-events:none;background:linear-gradient(#0b1a2066 0%,#0b1a20d9 100%);width:100%;height:100%;position:absolute;top:0;left:0}.login-content{z-index:3;flex-direction:column;justify-content:flex-end;width:100%;padding:24px 24px 40px;display:flex;position:relative}.login-card{background-color:var(--white);border-radius:var(--radius-xxl);box-shadow:var(--shadow-xl);flex-direction:column;padding:28px 24px;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex}.login-title{color:var(--text);margin-bottom:8px;font-size:30px;font-weight:800}.login-subtitle{color:var(--subtext);margin-bottom:28px;font-size:15px;line-height:22px}.phone-input-row{background-color:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-lg);align-items:center;height:58px;margin-bottom:18px;padding:0 16px;transition:border-color .2s;display:flex}.phone-input-row:focus-within{border-color:var(--primary)}.country-code{color:var(--text);margin-right:12px;font-size:16px;font-weight:700}.phone-field{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-size:16px;font-weight:600}.phone-field::placeholder{color:#94a3b8;font-weight:400}.otp-input-row{background-color:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-lg);align-items:center;gap:12px;height:58px;margin-bottom:18px;padding:0 16px;display:flex}.otp-icon{color:var(--subtext);align-items:center;display:flex}.otp-field{color:var(--text);letter-spacing:4px;background:0 0;border:none;outline:none;flex:1;font-size:16px;font-weight:600}.otp-field::placeholder{color:#94a3b8;letter-spacing:normal;font-weight:400}.login-btn{background-color:var(--primary);border-radius:var(--radius-lg);height:58px;color:var(--white);justify-content:center;align-items:center;gap:10px;font-size:16px;font-weight:700;transition:background-color .2s;display:flex;box-shadow:0 4px 12px #245b7233}.login-btn:hover{background-color:var(--primary-dark)}.login-btn:disabled{opacity:.7}.resend-btn{border-radius:var(--radius-lg);border:1px solid var(--primary);height:50px;color:var(--primary);background-color:#e8eff5;justify-content:center;align-items:center;margin-top:12px;font-size:14px;font-weight:700;transition:all .2s;display:flex}.resend-btn:disabled{opacity:.5;cursor:not-allowed}.change-phone-btn{text-align:center;color:var(--primary);background:0 0;border:none;width:100%;margin-top:20px;font-size:14px;font-weight:700;display:block}.powered-by{text-align:center;color:#94a3b8;letter-spacing:.3px;z-index:3;margin-top:24px;font-size:11px}.powered-by-brand{color:var(--white);font-weight:700}.bypass-btn{color:var(--primary);border:1px dashed var(--primary);border-radius:var(--radius-md);text-align:center;cursor:pointer;background:#245b720d;width:100%;margin-top:12px;padding:8px;font-size:12px;font-weight:600}.bypass-btn:hover{background:#245b721a}.app-input-container{width:100%;margin-bottom:18px}.app-input{background-color:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;height:58px;color:var(--text);outline:none;padding:0 16px;font-size:16px;transition:border-color .2s}.app-input:focus{border-color:var(--primary)}.app-input::placeholder{color:#94a3b8}.app-button{background-color:var(--primary);border-radius:var(--radius-lg);width:100%;height:58px;color:var(--white);justify-content:center;align-items:center;font-size:16px;font-weight:700;transition:opacity .2s,background-color .2s;display:flex;box-shadow:0 4px 12px #245b7226}.app-button:hover:not(:disabled){background-color:var(--primary-dark)}.app-button:disabled{opacity:.6;cursor:not-allowed}.button-spinner{border:3px solid #ffffff4d;border-left-color:var(--white);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}.onboarding-screen{background-color:var(--background);flex-direction:column;min-height:100%;padding:24px;display:flex}.onboarding-header{flex-direction:column;align-items:center;margin-top:24px;margin-bottom:28px;display:flex}.onboarding-icon-box{width:100px;height:100px;color:var(--primary);background-color:#ddeff5;border-radius:50%;justify-content:center;align-items:center;margin-bottom:20px;display:flex}.onboarding-title{color:var(--text);text-align:center;margin-bottom:8px;font-size:28px;font-weight:800}.onboarding-subtitle{color:var(--subtext);text-align:center;font-size:15px;line-height:22px}.onboarding-card{background-color:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);margin-bottom:30px;padding:24px}.date-input-row{background-color:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;height:58px;color:var(--subtext);align-items:center;gap:12px;margin-bottom:18px;padding:0 16px;display:flex}.date-input-field{color:var(--text);cursor:pointer;background:0 0;border:none;outline:none;flex:1;font-size:16px}.date-input-field::-webkit-calendar-picker-indicator{cursor:pointer}.gender-title{color:var(--text);margin-top:4px;margin-bottom:12px;font-size:15px;font-weight:700}.gender-row{gap:8px;margin-bottom:18px;display:flex}.gender-btn{border-radius:var(--radius-md);border:1px solid var(--border);background-color:var(--white);height:52px;color:var(--text);text-transform:capitalize;flex:1;justify-content:center;align-items:center;font-size:14px;font-weight:700;transition:all .2s;display:flex}.gender-btn.active{background-color:var(--primary);border-color:var(--primary);color:var(--white)}.onboarding-btn-wrap{margin-top:10px}.bottom-nav-container{background-color:var(--white);border-top:1px solid var(--border);z-index:100;justify-content:space-around;align-items:center;height:80px;display:flex;position:absolute;bottom:0;left:0;right:0}.bottom-nav-item{color:var(--subtext);background:0 0;border:none;outline:none;flex-direction:column;justify-content:center;align-items:center;transition:color .2s,font-weight .2s;display:flex}.bottom-nav-item.active{color:var(--primary);font-weight:700}.bottom-nav-text{margin-top:4px;font-size:12px}.home-screen{flex-direction:column;width:100%;height:100%;display:flex;position:relative}.map-container{z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}.map-canvas{width:100%;height:100%}.home-locate-btn{background-color:var(--white);width:50px;height:50px;box-shadow:var(--shadow-lg);color:var(--primary);z-index:10;border-radius:50%;justify-content:center;align-items:center;transition:transform .2s;display:flex;position:absolute;bottom:310px;right:20px}.home-locate-btn:active{transform:scale(.9)}.home-bottom-sheet{background-color:var(--white);border-top-left-radius:var(--radius-xl);border-top-right-radius:var(--radius-xl);z-index:10;padding:24px 20px;position:absolute;bottom:80px;left:0;right:0;box-shadow:0 -8px 24px #00000014}.home-bottom-sheet-handle{background-color:var(--border);border-radius:10px;width:50px;height:5px;margin:0 auto 18px}.home-sheet-title{color:var(--text);margin-bottom:18px;font-size:24px;font-weight:700}.home-search-trigger{background-color:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;height:58px;color:var(--subtext);cursor:pointer;text-align:left;align-items:center;gap:12px;margin-bottom:24px;padding:0 18px;transition:border-color .2s;display:flex}.home-search-trigger:hover{border-color:var(--primary)}.home-search-placeholder{font-size:16px}.home-services-grid{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.home-service-card{background-color:var(--white);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;padding:12px 6px;transition:all .2s;display:flex}.home-service-card:hover{border-color:var(--primary);background-color:#245b7205}.home-service-img{object-fit:contain;width:44px;height:44px;margin-bottom:8px}.home-service-title{color:var(--text);font-size:13px;font-weight:600}.pwa-install-banner{-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:999;background:#ffffffd9;border:1px solid #fff6;flex-direction:column;gap:10px;padding:14px 16px;animation:.4s cubic-bezier(.16,1,.3,1) forwards slideDown;display:flex;position:absolute;top:16px;left:16px;right:16px}@keyframes slideDown{0%{transform:translateY(-120%)}to{transform:translateY(0)}}.pwa-install-text{color:var(--text);font-size:13px;font-weight:600;line-height:1.4}.pwa-install-actions{justify-content:flex-end;gap:8px;display:flex}.pwa-btn{border-radius:var(--radius-sm);cursor:pointer;border:none;padding:6px 14px;font-size:12px;font-weight:700;transition:all .2s}.pwa-install-btn{background-color:var(--primary);color:var(--white)}.pwa-install-btn:hover{background-color:var(--primary-dark)}.pwa-dismiss-btn{color:var(--subtext);border:1px solid var(--border);background-color:#0000}.pwa-dismiss-btn:hover{background-color:var(--input-bg);color:var(--text)}.map-ride-screen{flex-direction:column;width:100%;height:100%;display:flex;position:relative}.map-viewport{z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}.back-btn-float{background-color:var(--white);width:44px;height:44px;box-shadow:var(--shadow-md);color:var(--text);z-index:15;cursor:pointer;border-radius:12px;justify-content:center;align-items:center;display:flex;position:absolute;top:20px;left:20px}.map-ride-top-panel{z-index:12;flex-direction:column;gap:12px;display:flex;position:absolute;top:80px;left:16px;right:16px}.booking-profile-header{background:var(--white);box-shadow:var(--shadow-md);cursor:pointer;border:1px solid var(--border);border-radius:100px;justify-content:space-between;align-self:flex-end;align-items:center;gap:8px;padding:8px 16px;font-size:14px;font-weight:600;display:flex}.booking-dropdown{background:var(--white);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:20;width:160px;position:absolute;top:45px;right:0;overflow:hidden}.booking-dropdown-item{color:var(--text);text-align:left;align-items:center;gap:8px;width:100%;padding:12px 16px;font-size:14px;font-weight:600;display:flex}.booking-dropdown-item:hover{background:var(--input-bg)}.booking-dropdown-item.active{color:var(--primary);background:var(--primary-light)}.search-inputs-card{background-color:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid var(--border);padding:12px 16px}.search-input-row{align-items:center;gap:12px;height:48px;display:flex}.dot-green{background-color:var(--success);border-radius:50%;flex-shrink:0;width:10px;height:10px}.dot-red{background-color:var(--danger);border-radius:50%;flex-shrink:0;width:10px;height:10px}.search-input-field{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-size:15px;font-weight:600}.search-input-field::placeholder{color:var(--subtext);font-weight:400}.search-clear-btn{color:var(--subtext);cursor:pointer;align-items:center;display:flex}.search-divider{background-color:var(--border);height:1px;margin:2px 0}.suggestions-list-container{background-color:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-lg);max-height:220px;overflow-y:auto}.suggestion-row-item{border-bottom:1px solid var(--border);cursor:pointer;text-align:left;align-items:center;gap:12px;width:100%;padding:14px 16px;display:flex}.suggestion-row-item:last-child{border-bottom:none}.suggestion-row-item:hover{background-color:var(--input-bg)}.suggestion-row-text{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.map-ride-bottom-sheet{background-color:var(--white);border-top-left-radius:var(--radius-xxl);border-top-right-radius:var(--radius-xxl);z-index:10;flex-direction:column;max-height:85%;padding:18px 20px 30px;display:flex;position:absolute;bottom:0;left:0;right:0;box-shadow:0 -8px 28px #00000014}.accepted-sheet-scrollable-content{max-height:52vh;margin-top:4px;padding-right:4px;overflow-y:auto}.accepted-sheet-scrollable-content::-webkit-scrollbar{width:4px}.accepted-sheet-scrollable-content::-webkit-scrollbar-track{background:0 0}.accepted-sheet-scrollable-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.sheet-handle-bar{background-color:var(--border);border-radius:10px;width:60px;height:6px;margin:0 auto 16px}.route-summary-card{background-color:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-md);justify-content:space-around;margin-bottom:10px;padding:8px 12px;display:flex}.route-summary-item{flex-direction:column;align-items:center;display:flex}.route-summary-label{color:var(--subtext);text-transform:uppercase;margin-bottom:4px;font-size:11px;font-weight:700}.route-summary-value{color:var(--text);font-size:14px;font-weight:800}.rider-summary-badge{border-radius:var(--radius-md);background:var(--primary-light);border:1px solid var(--primary);cursor:pointer;justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px 16px;display:flex}.rider-summary-badge-error{border-color:var(--danger);color:var(--danger);background:#fef2f2}.rider-badge-text{font-size:13px;font-weight:600}.rider-badge-action{align-items:center;gap:4px;font-size:13px;font-weight:700;display:flex}.map-ride-quick-actions{gap:12px;margin-bottom:20px;display:flex}.quick-action-btn{background-color:var(--white);border:1px solid var(--border);border-radius:var(--radius-md);height:50px;color:var(--text);flex:1;justify-content:center;align-items:center;gap:8px;font-size:14px;font-weight:700;transition:border-color .2s;display:flex}.quick-action-btn:hover{border-color:var(--primary)}.action-submit-btn{background-color:var(--text);height:48px;color:var(--white);border-radius:var(--radius-lg);justify-content:center;align-items:center;width:100%;font-size:15px;font-weight:700;display:flex}.vehicle-selector-title{color:var(--text);margin-bottom:10px;font-size:16px;font-weight:700}.vehicles-scroll-list{flex-direction:column;gap:6px;max-height:none;margin-bottom:10px;display:flex;overflow-y:visible}.vehicle-card-item{border-radius:var(--radius-lg);background-color:var(--input-bg);cursor:pointer;border:2px solid #0000;justify-content:space-between;align-items:center;padding:8px 12px;transition:all .2s;display:flex}.vehicle-card-item.selected{border-color:var(--text);background-color:var(--white)}.vehicle-card-left{align-items:center;gap:14px;display:flex}.vehicle-card-img{object-fit:contain;width:38px;height:38px}.vehicle-card-title{color:var(--text);font-size:14px;font-weight:700}.vehicle-card-eta{color:var(--subtext);align-items:center;gap:4px;margin-top:4px;font-size:12px;display:flex}.vehicle-card-right{text-align:right}.vehicle-card-price{color:var(--text);font-size:15px;font-weight:800}.vehicle-card-dist{color:var(--subtext);margin-top:4px;font-size:12px}.finding-captain-loader{background-color:#245b721a;border-radius:100px;width:100%;height:4px;margin:18px 0;position:relative;overflow:hidden}.finding-captain-loader-bar{background-color:var(--primary);border-radius:100px;width:30%;height:100%;animation:1.2s ease-in-out infinite loadingWobble;position:absolute}@keyframes loadingWobble{0%{left:-30%}50%{left:100%}to{left:100%}}.finding-stats-row{justify-content:space-between;gap:12px;margin-top:16px;display:flex}.finding-stat-box{background-color:var(--input-bg);border-radius:var(--radius-md);flex-direction:column;flex:1;align-items:center;padding:14px;display:flex}.finding-stat-emoji{margin-bottom:6px;font-size:20px}.finding-stat-val{font-size:16px;font-weight:800}.finding-stat-lbl{color:var(--subtext);margin-top:4px;font-size:12px}.accepted-sheet-panel{flex-direction:column;padding-bottom:24px;display:flex}.accepted-header-row{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.cancel-compact-btn{color:#dc2626;border-radius:var(--radius-md);cursor:pointer;background-color:#fee2e2;border:none;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:700;transition:background-color .2s;display:flex}.cancel-compact-btn:hover{background-color:#fca5a5}.accepted-header-title{color:var(--text);font-size:22px;font-weight:800}.accepted-sub-label{color:var(--subtext);margin-bottom:16px;font-size:14px}.accepted-status-badge{background-color:var(--primary-light);color:var(--primary);border-radius:100px;align-self:flex-start;margin-bottom:18px;padding:6px 14px;font-size:13px;font-weight:700}.accepted-otp-card{background-color:var(--input-bg);border:1px dashed var(--primary);border-radius:var(--radius-md);text-align:center;margin-bottom:18px;padding:16px}.accepted-otp-code{color:var(--primary);letter-spacing:4px;margin:8px 0;font-size:28px;font-weight:800}.accepted-captain-card{border:1px solid var(--border);border-radius:var(--radius-lg);background-color:var(--white);margin-bottom:16px;padding:16px}.accepted-captain-row{align-items:center;gap:12px;display:flex}.accepted-captain-avatar{background-color:var(--input-bg);width:48px;height:48px;color:var(--text);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.accepted-captain-info{flex:1}.accepted-captain-name{color:var(--text);font-size:16px;font-weight:700}.accepted-captain-rating{color:var(--subtext);align-items:center;gap:4px;margin-top:4px;font-size:13px;display:flex}.accepted-captain-call-btn{background-color:var(--success);width:40px;height:40px;color:var(--white);border-radius:50%;justify-content:center;align-items:center;display:flex}.accepted-divider{background-color:var(--border);height:1px;margin:14px 0}.accepted-vehicle-row{justify-content:space-between;align-items:center;display:flex}.accepted-vehicle-left{align-items:center;gap:12px;display:flex}.accepted-vehicle-icon-wrap{color:#2563eb;background-color:#2563eb14;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.accepted-vehicle-plate{color:#b45309;background-color:#fef3c7;border:1px solid #f59e0b;border-radius:6px;padding:4px 10px;font-size:13px;font-weight:800}.accepted-cancel-btn{height:52px;color:var(--danger);border-radius:var(--radius-md);background-color:#fef2f2;border:1px solid #fca5a5;justify-content:center;align-items:center;width:100%;font-size:15px;font-weight:700;display:flex}.ride-identity-row{background:var(--input-bg,#f8fafc);border:1px solid var(--border);border-radius:var(--radius-lg);justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;padding:10px 14px;display:flex}.ride-identity-left{align-items:center;gap:10px;min-width:0;display:flex}.ride-identity-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.ride-identity-sub{color:var(--subtext);margin-top:2px;font-size:12px}.ride-expanded-details{flex-direction:column;gap:10px;margin-bottom:12px;display:flex}.ride-destination-row{border-radius:var(--radius-md);background:#fff5f5;border:1px solid #fecaca;align-items:flex-start;gap:8px;padding:10px 14px;display:flex}.ride-detail-label{color:var(--subtext);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;font-size:10px;font-weight:700;display:block}.ride-detail-value{color:var(--text);font-size:13px;font-weight:700;line-height:1.4;display:block}.ride-payment-pill{background:var(--input-bg,#f3f4f6);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);justify-content:space-around;align-items:center;gap:12px;padding:10px 16px;font-size:13px;display:flex}.ride-payment-divider{background:var(--border);flex-shrink:0;width:1px;height:20px;display:inline-block}.ride-cancel-btn{color:#dc2626;border-radius:var(--radius-md);cursor:pointer;background-color:#fef2f2;border:1px solid #fecaca;justify-content:center;align-items:center;width:100%;height:46px;margin-top:auto;font-size:14px;font-weight:700;transition:background-color .2s;display:flex}.ride-cancel-btn:hover{background-color:#fee2e2}.modal-overlay-backdrop{z-index:100;background-color:#0f172a80;justify-content:center;align-items:flex-end;display:flex;position:absolute;inset:0}.modal-dialog-content{background-color:var(--white);border-top-left-radius:var(--radius-xxl);border-top-right-radius:var(--radius-xxl);width:100%;box-shadow:var(--shadow-xl);padding:24px}.modal-dialog-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.modal-dialog-title{color:var(--text);font-size:20px;font-weight:700}.modal-dialog-close{color:var(--subtext)}.modal-dialog-desc{color:var(--subtext);margin-bottom:20px;font-size:14px;line-height:20px}.modal-field-container{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.modal-field-label{color:var(--subtext);font-size:12px;font-weight:700}.modal-field-input{background-color:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-md);height:52px;color:var(--text);outline:none;padding:0 14px;font-size:15px;font-weight:600}.modal-field-input:focus{border-color:var(--primary)}.modal-submit-btn{background-color:var(--primary);height:52px;color:var(--white);border-radius:var(--radius-md);justify-content:center;align-items:center;width:100%;margin-top:8px;font-size:15px;font-weight:700;display:flex}.compact-route-header-card{background-color:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border);z-index:12;align-items:center;gap:12px;height:56px;padding:10px 16px;display:flex;position:absolute;top:20px;left:80px;right:20px}.compact-route-line-indicator{flex-direction:column;flex-shrink:0;justify-content:space-between;align-items:center;height:32px;display:flex}.dot-green-small{background-color:var(--success);border-radius:50%;width:8px;height:8px}.dot-red-small{background-color:var(--danger);border-radius:50%;width:8px;height:8px}.line-dashed{border-left:1px dashed var(--subtext);width:1px;height:12px}.compact-route-info{flex-direction:column;flex:1;justify-content:space-between;height:100%;display:flex;overflow:hidden}.compact-route-address{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.recenter-btn-float{background-color:var(--white);color:var(--text);border:1px solid var(--border);cursor:pointer;box-shadow:var(--shadow-lg);z-index:12;border-radius:100px;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:700;transition:transform .2s,background-color .2s;display:flex;position:absolute;bottom:360px;right:16px}.recenter-btn-float:hover{background-color:var(--background)}.recenter-btn-float:active{transform:scale(.95)}.coupon-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0006;justify-content:center;align-items:flex-end;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.coupon-sheet{background-color:var(--white,#fff);box-sizing:border-box;border-top-left-radius:24px;border-top-right-radius:24px;flex-direction:column;width:100%;max-width:480px;max-height:75vh;padding:16px 20px 24px;animation:.25s cubic-bezier(.16,1,.3,1) slideUp;display:flex;box-shadow:0 -4px 24px #0000001a}.coupon-handle-bar{background-color:var(--border,#e5e7eb);border-radius:10px;align-self:center;width:40px;height:4px;margin-bottom:16px}.coupon-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.coupon-title{color:var(--text,#1f2937);margin:0;font-size:18px;font-weight:800}.coupon-close-btn{color:var(--subtext,#6b7280);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;transition:background-color .2s;display:flex}.coupon-close-btn:hover{background-color:var(--input-bg,#f3f4f6)}.coupon-error-banner{color:#dc2626;background-color:#fef2f2;border:1px solid #fee2e2;border-radius:12px;margin-bottom:16px;padding:10px 14px;font-size:13px;font-weight:600}.coupon-input-row{gap:10px;margin-bottom:16px;display:flex}.coupon-input-field{border:1px solid var(--border,#e5e7eb);height:48px;color:var(--text,#1f2937);background-color:var(--input-bg,#f9fafb);box-sizing:border-box;text-transform:uppercase;border-radius:12px;outline:none;flex:1;padding:0 14px;font-size:15px}.coupon-input-field:focus{border-color:var(--primary,#245b72)}.coupon-apply-btn{background-color:var(--primary,#245b72);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;min-width:80px;height:48px;padding:0 20px;font-size:14px;font-weight:700;transition:opacity .2s;display:flex}.coupon-apply-btn:disabled{cursor:not-allowed;background-color:#9ca3af}.coupon-applied-banner{background-color:#ecfdf5;border:1px solid #a7f3d0;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:10px 14px;display:flex}.coupon-applied-left{color:#065f46;align-items:center;gap:8px;font-size:13px;display:flex}.coupon-applied-text strong{font-weight:700}.coupon-remove-btn{color:#dc2626;cursor:pointer;background:0 0;border:none;padding:4px;font-size:13px;font-weight:700}.coupon-section-title{color:var(--subtext,#4b5563);text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px;font-size:14px;font-weight:700}.coupon-scroll-list{flex:1;padding-right:4px;overflow-y:auto}.coupon-empty-container{color:var(--subtext,#9ca3af);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:32px 16px;display:flex}.coupon-empty-icon{opacity:.7}.coupon-empty-text{font-size:13px;font-weight:500}.coupon-loading-container{flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:32px 16px;display:flex}.coupon-loading-text{color:var(--subtext,#6b7280);font-size:13px}.coupon-spinner-large{border:3px solid #245b7233;border-top:3px solid var(--primary,#245b72);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.coupon-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin}.coupon-card{background-color:var(--white,#fff);border:1px solid var(--border,#e5e7eb);border-radius:14px;margin-bottom:10px;padding:12px 14px;transition:box-shadow .2s,border-color .2s}.coupon-card:hover{border-color:#245b7266}.coupon-card-main{align-items:center;gap:12px;display:flex}.coupon-card-icon-wrap{background-color:var(--input-bg,#f1f5f9);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.coupon-card-details{flex-direction:column;flex:1;gap:2px;display:flex}.coupon-card-code{color:var(--text,#1f2937);font-size:15px;font-weight:800}.coupon-card-desc{color:var(--subtext,#4b5563);font-size:12px;font-weight:500;line-height:1.4}.coupon-card-meta{color:#9ca3af;margin-top:2px;font-size:10px}.coupon-card-select-btn{border:1px solid var(--primary,#245b72);color:var(--primary,#245b72);cursor:pointer;background-color:#fff;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:700;transition:all .2s}.coupon-card-select-btn:hover{background-color:var(--input-bg,#f8fafc)}.coupon-card-select-btn.selected{color:#10b981;background-color:#ecfdf5;border-color:#10b981}.profile-screen{background-color:var(--background);flex-direction:column;height:100%;display:flex}.profile-header{background-color:var(--primary);border-bottom-left-radius:var(--radius-xxl);border-bottom-right-radius:var(--radius-xxl);color:var(--white);box-shadow:var(--shadow-lg);padding:40px 24px 34px}.profile-user-row{align-items:center;gap:16px;display:flex}.profile-avatar{border:3px solid var(--white);object-fit:cover;border-radius:50%;width:80px;height:80px}.profile-user-info{flex-direction:column;display:flex}.profile-username{letter-spacing:-.5px;font-size:24px;font-weight:800}.profile-phone{color:var(--primary-light);margin-top:4px;font-size:14px}.profile-verified-badge{background-color:#fff3;border-radius:100px;align-self:flex-start;align-items:center;gap:6px;margin-top:8px;padding:4px 10px;font-size:12px;font-weight:700;display:flex}.profile-menu-container{flex-direction:column;flex:1;gap:12px;padding:24px 20px 110px;display:flex;overflow-y:auto}.profile-menu-item{background-color:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);cursor:pointer;text-align:left;justify-content:space-between;align-items:center;width:100%;padding:16px 20px;transition:transform .2s,background-color .2s;display:flex}.profile-menu-item:hover{background-color:var(--input-bg)}.profile-menu-left{align-items:center;gap:14px;display:flex}.profile-icon-box{width:42px;height:42px;color:var(--primary);background-color:#245b7214;border-radius:12px;justify-content:center;align-items:center;display:flex}.profile-menu-title{color:var(--text);font-size:15px;font-weight:700}.profile-menu-chevron{color:var(--subtext)}.profile-actions-panel{flex-direction:column;gap:10px;margin-top:14px;display:flex}.profile-btn-logout{background-color:var(--white);height:52px;color:var(--danger);border-radius:var(--radius-md);border:1px solid #fca5a5;justify-content:center;align-items:center;gap:8px;font-size:15px;font-weight:700;transition:all .2s;display:flex}.profile-btn-delete{background-color:var(--danger);height:52px;color:var(--white);border-radius:var(--radius-md);justify-content:center;align-items:center;gap:8px;font-size:15px;font-weight:700;transition:all .2s;display:flex}.profile-btn-logout:hover{background-color:#fef2f2}.profile-btn-delete:hover{background-color:#dc2626}.secondary-page{background-color:var(--background);flex-direction:column;height:100%;display:flex}.secondary-header{background-color:var(--primary);border-bottom-left-radius:var(--radius-xxl);border-bottom-right-radius:var(--radius-xxl);color:var(--white);box-shadow:var(--shadow-lg);padding:30px 24px 28px;position:relative}.secondary-back-btn{width:40px;height:40px;color:var(--white);cursor:pointer;background-color:#ffffff2e;border-radius:12px;justify-content:center;align-items:center;margin-bottom:16px;transition:opacity .2s;display:flex}.secondary-back-btn:hover{opacity:.8}.secondary-title{letter-spacing:-.5px;font-size:26px;font-weight:800}.secondary-subtitle{color:var(--primary-light);margin-top:4px;font-size:14px;font-weight:500}.secondary-content{flex-direction:column;flex:1;gap:16px;padding:24px 20px;display:flex;overflow-y:auto}.secondary-content::-webkit-scrollbar{width:0;height:0}.info-card{background-color:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:18px}.info-card-label{color:var(--subtext);margin-bottom:6px;font-size:13px;font-weight:700}.info-card-value{color:var(--text);align-items:center;gap:8px;font-size:16px;font-weight:700;display:flex}.rewards-banner{border-radius:var(--radius-lg);background-color:#ede9fe;border:1px solid #ddd6fe;flex-direction:column;gap:6px;padding:20px;display:flex}.rewards-banner-title{color:#5b21b6;font-size:18px;font-weight:800}.rewards-banner-text{color:#7c3aed;font-size:14px}.stats-grid-row{gap:12px;display:flex}.stat-card-box{background-color:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex:1;padding:18px}.stat-card-box-lbl{color:var(--subtext);font-size:13px;font-weight:700}.stat-card-box-val{color:var(--text);margin-top:8px;font-size:24px;font-weight:800}.rewards-items-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.reward-item-card{background-color:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-sm);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:24px 16px;transition:transform .2s,border-color .2s;display:flex}.reward-item-card:hover{border-color:var(--primary);transform:translateY(-2px)}.reward-item-card-text{color:var(--text);font-size:14px;font-weight:700}.history-ride-card{background-color:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:16px}.history-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.history-card-date{color:var(--text);font-size:14px;font-weight:700}.history-card-badge{text-transform:capitalize;border-radius:100px;padding:4px 10px;font-size:11px;font-weight:800}.history-route-block{gap:12px;min-width:0;margin:12px 0;display:flex}.history-timeline-bar{flex-direction:column;justify-content:space-between;align-items:center;width:12px;padding:4px 0;display:flex}.dot-timeline-green{background-color:var(--success);border-radius:50%;width:8px;height:8px}.dot-timeline-red{background-color:var(--danger);border-radius:50%;width:8px;height:8px}.line-timeline-connector{background-color:var(--border);flex:1;width:2px;margin:4px 0}.history-address-block{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.history-address-item{flex-direction:column;min-width:0;display:flex}.history-address-lbl{color:var(--subtext);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:700}.history-address-val{color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:13px;font-weight:600;display:block;overflow:hidden}.history-card-divider{background-color:var(--border);height:1px;margin:12px 0}.history-card-footer{justify-content:space-between;align-items:center;display:flex}.history-card-meta{color:var(--subtext);align-items:center;gap:4px;font-size:13px;font-weight:600;display:flex}.history-card-price{color:var(--primary);font-size:18px;font-weight:800}.history-empty-container{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.history-empty-icon{border-radius:var(--radius-lg);background-color:var(--primary-light);width:80px;height:80px;color:var(--primary);justify-content:center;align-items:center;margin-bottom:8px;display:flex}.history-empty-title{color:var(--text);font-size:18px;font-weight:800}.history-empty-text{color:var(--subtext);font-size:14px;line-height:20px}.history-empty-btn{background-color:var(--primary);color:var(--white);border-radius:var(--radius-md);margin-top:12px;padding:12px 24px;font-size:14px;font-weight:700}
