@charset "UTF-8";.toast-container{position:fixed;top:auto;bottom:max(1rem,env(safe-area-inset-bottom,0px));right:max(1rem,env(safe-area-inset-right,0px));z-index:99999;display:flex;flex-direction:column;gap:.75rem;max-width:min(400px,calc(100vw - 2rem));pointer-events:none}.toast{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;pointer-events:auto;cursor:pointer;animation:slideIn .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-content{display:flex;align-items:center;gap:.75rem;flex:1}.toast-icon{font-size:1.25rem;font-weight:700;flex-shrink:0}.toast-message{flex:1;word-wrap:break-word;line-height:1.5}.toast-close{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:0;margin-left:.75rem;opacity:.7;transition:opacity .2s;flex-shrink:0;width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;line-height:1}.toast-close:hover{opacity:1}.toast-success{background:#22c55ef2;color:#fff}.toast-success .toast-icon,.toast-success .toast-close{color:#fff}.toast-error{background:#ef4444f2;color:#fff}.toast-error .toast-icon,.toast-error .toast-close{color:#fff}.toast-warning{background:#fbbf24f2;color:#fff}.toast-warning .toast-icon,.toast-warning .toast-close{color:#fff}.toast-info{background:#3b82f6f2;color:#fff}.toast-info .toast-icon,.toast-info .toast-close{color:#fff}@media(prefers-color-scheme:dark){.toast{border:1px solid rgba(255,255,255,.2)}}.admin-layout{display:flex;min-height:100vh;background:var(--bg-primary);color:var(--text-primary);transition:background .3s ease,color .3s ease}.admin-sidebar{width:260px;background:var(--card-bg);border-right:1px solid var(--card-border);display:flex;flex-direction:column;position:fixed;height:100vh;overflow-y:auto;transition:all .3s ease;z-index:1000}.admin-sidebar.closed{width:60px;overflow-x:hidden}.admin-sidebar.closed.hovering,.admin-sidebar.closed:hover{width:260px;z-index:1001;box-shadow:4px 0 12px #00000026}.admin-sidebar.closed.hovering .nav-label,.admin-sidebar.closed:hover .nav-label{opacity:1;width:auto}.admin-sidebar.closed.hovering .sidebar-logo,.admin-sidebar.closed:hover .sidebar-logo{width:auto;max-width:180px}.admin-sidebar.open{width:260px}.sidebar-header{padding:1rem 1.5rem;border-bottom:1px solid var(--card-border);display:flex;justify-content:flex-start;align-items:center;gap:1rem;height:70px;box-sizing:border-box}.sidebar-logo{height:40px;width:auto;max-width:100px;object-fit:contain;object-position:center;transition:opacity .2s ease,width .2s ease;flex-shrink:0;display:block}.admin-sidebar.closed .sidebar-logo{opacity:1;width:40px;height:40px}.admin-sidebar.open .sidebar-logo{opacity:1;width:auto;max-width:180px}.sidebar-toggle-btn{background:transparent;border:1px solid var(--card-border);color:var(--text-primary);border-radius:.375rem;cursor:pointer;padding:.5rem;font-size:.875rem;transition:all .2s;flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;margin-left:auto}.sidebar-toggle-btn:hover{background:var(--bg-tertiary);border-color:var(--accent-color)}.sidebar-nav{flex:1;padding:1rem 0}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:var(--text-secondary);text-decoration:none;transition:all .2s ease;border-left:3px solid transparent}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:var(--accent-light);color:var(--accent-color);border-left-color:var(--accent-color);font-weight:500}.nav-icon{font-size:1.2rem;display:flex;align-items:center;justify-content:center;min-width:1.2rem}.nav-icon-svg{width:1.2rem;height:1.2rem;object-fit:contain}.nav-label{font-size:.95rem;white-space:nowrap;transition:opacity .3s ease,width .3s ease}.admin-sidebar.closed .nav-label{opacity:0;width:0;overflow:hidden;transition:opacity .2s ease,width .2s ease}.admin-sidebar.closed .nav-item{justify-content:center;padding:.75rem}.admin-sidebar.closed.hovering .nav-item,.admin-sidebar.closed:hover .nav-item{justify-content:flex-start;padding:.75rem 1.5rem}.admin-main{flex:1;display:flex;flex-direction:column;min-height:0;height:100vh;max-height:100dvh;overflow:hidden;transition:margin-left .3s ease}.admin-main.sidebar-open{margin-left:260px}.admin-main.sidebar-closed{margin-left:60px}.admin-sidebar.closed.hovering,.admin-sidebar.closed:hover{position:fixed}.admin-header{background:var(--card-bg);border-bottom:1px solid var(--card-border);padding:1rem 2rem;position:sticky;top:0;z-index:100;transition:background .3s ease,border-color .3s ease;height:70px;box-sizing:border-box;display:flex;align-items:center}.header-content{display:flex;justify-content:space-between;align-items:center;width:100%}.header-left{display:flex;align-items:center;gap:1rem;flex:1}.mobile-sidebar-toggle{display:none;background:transparent;border:1px solid var(--card-border);color:var(--text-primary);border-radius:.375rem;cursor:pointer;padding:.5rem .75rem;font-size:1.25rem;transition:all .2s}.mobile-sidebar-toggle:hover{background:var(--bg-tertiary);border-color:var(--accent-color)}.page-title{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.header-actions{display:flex;align-items:center;gap:1rem;margin-left:auto}.theme-toggle-btn{padding:.5rem 1rem;background:transparent;border:1px solid var(--accent-color);color:var(--accent-color);border-radius:.5rem;cursor:pointer;transition:all .2s;font-size:1.2rem;display:flex;align-items:center;justify-content:center;min-width:2.5rem}.theme-toggle-btn:hover{background:var(--accent-light);color:var(--accent-hover);border-color:var(--accent-hover)}.logout-btn{padding:.5rem 1rem;background:transparent;border:1px solid var(--accent-color);color:var(--accent-color);border-radius:.5rem;cursor:pointer;transition:all .2s;font-size:.9rem}.logout-btn:hover{background:var(--accent-light);color:var(--accent-hover);border-color:var(--accent-hover)}.admin-content{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:2rem;background:var(--bg-primary)}@media(max-width:768px){.admin-sidebar{width:260px;transform:translate(-100%)}.admin-sidebar.open{transform:translate(0)}.admin-sidebar.closed{transform:translate(-100%);width:260px}.admin-sidebar.closed:hover{width:260px;transform:translate(-100%)}.admin-main{margin-left:0!important}.admin-main.sidebar-open,.admin-main.sidebar-closed{margin-left:0}.mobile-sidebar-toggle{display:block}.sidebar-toggle-btn{display:none}.header-content{flex-direction:row;align-items:center}.page-title{font-size:1.25rem}.nav-label{font-size:.85rem}}.home{min-height:100vh;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#020617);color:#e5e7eb;padding:2rem 1.5rem 3rem;box-sizing:border-box}.home-hero{text-align:center;max-width:36rem;width:100%}.home-hero__title{margin:0 0 1rem;font-size:clamp(1.75rem,4vw,2.75rem);font-weight:700;color:#e5e7eb}.home-hero__lead{margin:0 0 1.75rem;font-size:1.125rem;line-height:1.6;color:#cbd5f5}.home-btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;font-size:1rem;border-radius:.5rem;font-weight:500;text-decoration:none;background:transparent;border:1px solid #6366f1;color:#a5b4fc;cursor:pointer;transition:background .2s,color .2s,border-color .2s}.home-btn:hover{background:#6366f11f;color:#e5e7eb}.login{min-height:100dvh;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:clamp(1rem,4vw,2rem);box-sizing:border-box;background:radial-gradient(ellipse 100% 60% at 70% 110%,rgba(99,102,241,.14),transparent 60%),radial-gradient(ellipse 80% 50% at 10% -10%,rgba(139,92,246,.1),transparent 55%),linear-gradient(160deg,#080e1e,#020617,#0b1120);color:#e5e7eb}.login--busy{flex-direction:column}.login-shell{width:100%;max-width:980px;display:grid;grid-template-columns:1fr;align-items:stretch;border-radius:1.5rem;overflow:hidden;box-shadow:0 32px 64px -16px #0000008c,0 0 0 1px #6366f124,inset 0 1px #ffffff0a;animation:login-in .45s cubic-bezier(.22,1,.36,1) both}@keyframes login-in{0%{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media(min-width:840px){.login-shell{grid-template-columns:minmax(0,1fr) minmax(0,1.1fr)}}.login-brand{position:relative;overflow:hidden;min-height:220px;border-bottom:1px solid rgba(99,102,241,.12)}@media(min-width:840px){.login-brand{min-height:540px;border-bottom:none;border-right:1px solid rgba(99,102,241,.12)}}.login-brand__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block}.login-panel{display:flex;flex-direction:column;justify-content:center;padding:clamp(1.75rem,5vw,2.75rem) clamp(1.5rem,5vw,2.5rem);background:#0a1224d1;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.login-panel__header{margin-bottom:1.75rem}.login-panel__title{margin:0 0 .3rem;font-size:1.6rem;font-weight:700;letter-spacing:-.025em;color:#f8fafc;line-height:1.2}.login-panel__subtitle{margin:0;font-size:.9rem;color:#64748b}.login-panel__banner{margin-bottom:1.25rem}.login-panel__banner .state-banner{margin-bottom:0}.login-footer{margin:1.5rem 0 0;text-align:center}.login-footer__link{font-size:.82rem;color:#475569;text-decoration:none;transition:color .2s}.login-footer__link:hover{color:#a5b4fc}.login-form{display:flex;flex-direction:column;gap:1.1rem}.login-form__banner .state-banner{margin-bottom:0}.login-form__field{display:flex;flex-direction:column;gap:.45rem}.login-form__label{font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#64748b;transition:color .2s}.login-form__field:focus-within .login-form__label{color:#a5b4fc}.login-form__input-wrap{position:relative;display:flex;align-items:center}.login-form__icon{position:absolute;left:.9rem;width:1rem;height:1rem;color:#475569;pointer-events:none;flex-shrink:0;transition:color .2s}.login-form__field:focus-within .login-form__icon{color:#818cf8}.login-form__input{width:100%;padding:.875rem 1rem .875rem 2.6rem;border-radius:.75rem;border:1px solid rgba(148,163,184,.15);background:#02061780;color:#f1f5f9;font-size:.97rem;line-height:1.4;box-sizing:border-box;transition:border-color .2s,box-shadow .2s,background .2s}.login-form__input--pw{padding-right:3rem}.login-form__input::placeholder{color:#334155}.login-form__input:hover:not(:disabled){border-color:#6366f14d}.login-form__input:focus{outline:none;border-color:var(--accent-color, #6366f1);box-shadow:0 0 0 3px var(--accent-light, rgba(99, 102, 241, .18));background:#020617b3}.login-form__input:disabled{opacity:.5;cursor:not-allowed}.login-form__toggle{position:absolute;right:.75rem;background:none;border:none;padding:.25rem;cursor:pointer;color:#475569;display:flex;align-items:center;border-radius:.375rem;transition:color .2s}.login-form__toggle:hover{color:#a5b4fc}.login-form__toggle:focus-visible{outline:2px solid var(--accent-color, #6366f1);outline-offset:1px}.login-form__toggle-icon{width:1.1rem;height:1.1rem}.login-form__submit{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.5rem;width:100%;padding:.9rem 1.25rem;font-size:.97rem;font-weight:600;letter-spacing:.01em;border-radius:.75rem;cursor:pointer;border:none;background:linear-gradient(135deg,var(--accent-color, #6366f1) 0%,var(--accent-hover, #4f46e5) 100%);color:#fff;box-shadow:0 4px 14px #6366f159,inset 0 1px #ffffff1a;transition:transform .15s ease,box-shadow .2s,opacity .2s}.login-form__submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 24px #6366f173,inset 0 1px #ffffff1a}.login-form__submit:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #6366f14d}.login-form__submit:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.login-form__spinner{display:inline-block;width:1rem;height:1rem;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:login-spin .65s linear infinite;flex-shrink:0}@keyframes login-spin{to{transform:rotate(360deg)}}.users-page{width:100%}.recap-section{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:stretch;gap:1rem;margin-bottom:1.25rem;min-width:0;overflow-x:auto;overflow-y:hidden;padding-bottom:.25rem;-webkit-overflow-scrolling:touch}.recap-card{flex:1 1 0;min-width:9rem;background:var(--card-bg);border:1px solid var(--card-border);border-radius:.875rem;padding:1rem 1.1rem;display:flex;align-items:flex-start;gap:.85rem;box-shadow:0 1px 3px var(--shadow);transition:box-shadow .2s ease;box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.recap-card:hover{box-shadow:0 4px 14px var(--shadow)}.recap-icon{flex-shrink:0;width:2.25rem;height:2.25rem;border-radius:.6rem;display:flex;align-items:center;justify-content:center;margin-top:.1rem;box-sizing:border-box}.recap-icon svg{width:1.1rem;height:1.1rem}.recap-icon svg.recap-icon-svg--fill{width:1.2rem;height:1.2rem;display:block;flex-shrink:0}.recap-icon--blue{background:#3b82f61f;color:#3b82f6}.recap-icon--orange{background:#f973161f;color:#f97316}.recap-icon--green{background:#22c55e1f;color:#22c55e}.recap-icon--purple{background:#a855f71f;color:#a855f7}.recap-icon--red{background:#ef44441f;color:#dc2626}.recap-icon--amber{background:#f59e0b1f;color:#f59e0b}.recap-icon--teal{background:#10b9811f;color:#10b981}.recap-icon--indigo{background:#6366f11f;color:#6366f1}.recap-body{flex:1;min-width:0}.recap-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);margin-bottom:.25rem}.recap-value{font-size:.95rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.page-header{margin-bottom:2rem}.users-page__header{margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--card-border)}.users-page .ride-bill-toolbar.users-toolbar{align-items:flex-start;flex-wrap:wrap;justify-content:space-between;gap:.75rem}.users-page .ride-bill-toolbar.users-toolbar .ride-bill-toolbar__search-wrap{flex:1 1 12rem;min-width:min(100%,10rem);max-width:min(100%,26rem)}.users-toolbar__right{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:.5rem .75rem;flex:1 1 auto;min-width:0;margin-left:auto}.users-toolbar__segment-block{flex:0 1 auto;min-width:0}.user-modal-expiry-datepicker{display:block;width:100%;max-width:100%}.user-modal-expiry-datepicker .react-datepicker-wrapper{display:block;width:100%}.ride-bill-date-picker-input.user-modal-expiry-datepicker--error{border-color:#ef4444}.ride-bill-date-picker-input.user-modal-expiry-datepicker--error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441f}.filter-select{padding:.75rem;border:1px solid var(--card-border);border-radius:.5rem;background:var(--bg-tertiary);color:var(--text-primary);font-size:.95rem;cursor:pointer;transition:border-color .2s,background-color .2s,color .2s}:root[data-theme=dark] .filter-select{background:var(--bg-tertiary)!important;color:var(--text-primary)!important;border-color:var(--card-border)!important}:root[data-theme=dark] .filter-select:focus{background:var(--bg-tertiary)!important;color:var(--text-primary)!important;border-color:var(--accent-color)!important}:root[data-theme=dark] .filter-select option{background:var(--bg-tertiary)!important;color:var(--text-primary)!important}.filter-select:focus{outline:none;border-color:var(--accent-color);background:var(--bg-tertiary);color:var(--text-primary)}.filter-select option{background:var(--bg-tertiary);color:var(--text-primary)}.users-table-container{background:var(--card-bg);border:1px solid var(--card-border);border-radius:1rem;overflow-x:auto;overflow-y:visible;box-shadow:0 1px 3px var(--shadow)}.users-table{width:100%;border-collapse:collapse;table-layout:auto;min-width:fit-content}.users-table thead{background:var(--bg-secondary)}.users-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--text-primary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;vertical-align:middle;border-bottom:1px solid var(--card-border)}.users-table th:first-child{width:60px;min-width:60px}.users-table th:nth-child(2),.users-table th:nth-child(3){min-width:120px}.users-table th:nth-child(4){min-width:180px}.users-table th:nth-child(5){min-width:100px}.users-table th:nth-child(6){min-width:100px}.users-table th:last-child{min-width:200px;max-width:250px}.users-table td{padding:.75rem 1rem;border-top:1px solid var(--card-border);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px;vertical-align:middle;background:transparent}.users-table tbody tr:first-child td{border-top:none}.users-table tbody tr:nth-child(2n){background:color-mix(in srgb,var(--bg-tertiary) 35%,transparent)}:root[data-theme=dark] .users-table tbody tr:nth-child(2n){background:color-mix(in srgb,var(--bg-tertiary) 25%,transparent)}.users-table td:last-child{white-space:normal;overflow:visible;max-width:250px}.users-table td:first-child{width:60px;min-width:60px}.users-table td:nth-child(4){max-width:250px}.users-table tbody tr{transition:background .2s}.users-table tbody tr:hover{background:color-mix(in srgb,var(--accent-color) 12%,var(--bg-tertiary))!important}:root[data-theme=dark] .users-table tbody tr:hover{background:color-mix(in srgb,var(--accent-color) 18%,var(--bg-secondary))!important}.role-badge{padding:.25rem .75rem;border-radius:.25rem;font-size:.875rem;font-weight:500;text-transform:capitalize}.role-admin{background:#ef44441a;color:#ef4444}.role-student{background:#3b82f61a;color:#3b82f6}.role-driver{background:#10b9811a;color:#10b981}.role-superadmin{background:#f59e0b1a;color:#f59e0b}.status-badge{padding:.25rem .75rem;border-radius:.25rem;font-size:.875rem;font-weight:500;text-transform:capitalize;transition:all .2s}.status-badge--interactive{position:relative;cursor:pointer;-webkit-user-select:none;user-select:none}.status-badge--interactive:hover{opacity:.8;transform:scale(1.05)}.status-badge--static{cursor:not-allowed;opacity:.6;-webkit-user-select:none;user-select:none}.status-active{background:#10b9811a;color:#10b981}.status-inactive{background:#6b72801a;color:#6b7280}.status-expired{background:#f59e0b1a;color:#f59e0b}.status-closed{background:#ef44441a;color:#ef4444}.action-buttons{display:flex;gap:.375rem;flex-wrap:wrap;align-items:center}.action-btn{padding:.4rem .75rem;border:none;border-radius:.375rem;cursor:pointer;font-size:.8125rem;font-weight:500;transition:all .2s;white-space:nowrap;flex-shrink:0}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn.edit{background:#3b82f61a;color:#3b82f6}.action-btn.edit:hover{background:#3b82f633}.action-btn.delete{background:#ef44441a;color:#ef4444}.action-btn.delete:hover{background:#ef444433}.action-btn.view{background:#3b82f6;color:#fff}.action-btn.view:hover{background:#2563eb}.users-pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0 0;margin-top:.25rem}.users-pagination__size{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.users-pagination__size label{white-space:nowrap}.users-pagination__size-select{min-width:4.5rem;padding:.5rem .65rem;font-size:.875rem}.users-pagination__nav{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:.5rem}.users-pagination .pagination-btn{padding:.5rem .75rem;border:1px solid var(--card-border);border-radius:.5rem;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;font-size:.875rem}.users-pagination .pagination-btn:disabled{opacity:.55;cursor:not-allowed}.users-pagination .pagination-btn.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.users-pagination .pagination-ellipsis{padding:.5rem .75rem;color:var(--text-secondary);-webkit-user-select:none;user-select:none}@media(max-width:768px){.recap-section{gap:.75rem}.recap-card{padding:.85rem .95rem;gap:.65rem}.recap-icon{width:2rem;height:2rem}.recap-value{font-size:.9rem}.users-table-container{overflow-x:auto}.users-table{min-width:800px}.filter-select{width:100%}.users-pagination{flex-direction:column;align-items:stretch}.users-pagination__nav{justify-content:center;flex-wrap:wrap}}@media(max-width:480px){.users-pagination .pagination-btn{padding:.45rem .6rem;font-size:.8125rem}.users-pagination__size{font-size:.8125rem}}.dashboard-page{width:100%;min-width:0}.dashboard-recap__currency{font-size:clamp(.85rem,2.5vw,.95rem);font-variant-numeric:tabular-nums}.dashboard-page .recap-section{margin-bottom:1.75rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:1.5rem}.dashboard-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:1rem;padding:1.5rem;box-shadow:0 1px 3px var(--shadow)}.db-card-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 1.25rem;text-transform:uppercase;letter-spacing:.06em}.status-bar-wrap{margin-bottom:1.25rem}.status-bar{height:10px;border-radius:999px;overflow:hidden;display:flex;background:var(--bg-tertiary);margin-bottom:.6rem}.status-bar-seg{height:100%;min-width:0;flex:0 0 auto;overflow:hidden;transition:flex-basis var(--bill-bar-ms, .58s) ease-out}.status-bar-seg__fill{height:100%;width:100%;transform-origin:left center;transform:scaleX(0);animation:bill-status-bar-fill var(--bill-bar-ms, .58s) ease-out forwards}@keyframes bill-status-bar-fill{to{transform:scaleX(1)}}.seg-active .status-bar-seg__fill{background:#10b981}.seg-pending .status-bar-seg__fill{background:#f59e0b}.seg-completed .status-bar-seg__fill{background:#3b82f6}.seg-cancelled .status-bar-seg__fill{background:#ef4444}.seg-empty{background:var(--bg-tertiary)}@media(prefers-reduced-motion:reduce){.status-bar-seg{transition:none}.status-bar-seg__fill{animation:none;transform:scaleX(1)}}.status-bar-legend{display:flex;align-items:center;gap:.35rem;font-size:.76rem;color:var(--text-secondary)}.sbl-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sbl-active{background:#10b981}.sbl-pending{background:#f59e0b}.sbl-completed{background:#3b82f6}.sbl-cancelled{background:#ef4444}.sbl-label{margin-right:.6rem}.status-chips{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem}.status-chip{display:flex;flex-direction:column;align-items:center;padding:.75rem .5rem;border-radius:.75rem;gap:.2rem}.chip-active{background:#10b9811a}.chip-pending{background:#f59e0b1a}.chip-completed{background:#3b82f61a}.chip-cancelled{background:#ef44441a}.chip-count{font-size:1.4rem;font-weight:700;line-height:1;font-variant-numeric:tabular-nums}.chip-active .chip-count{color:#10b981}.chip-pending .chip-count{color:#f59e0b}.chip-completed .chip-count{color:#3b82f6}.chip-cancelled .chip-count{color:#ef4444}.chip-label{font-size:.72rem;color:var(--text-secondary);font-weight:500}.summary-list{display:flex;flex-direction:column;gap:.6rem}.summary-item{display:flex;align-items:center;gap:.85rem;padding:.65rem .75rem;border-radius:.65rem;background:var(--bg-tertiary);transition:background .2s ease}.summary-item:hover{background:var(--bg-secondary)}.summary-icon-wrap{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0;border:none;box-sizing:border-box}.summary-icon-wrap--blue{background:#3b82f61f;color:#3b82f6}.summary-icon-wrap--orange{background:#f973161f;color:#f97316}.summary-icon-wrap--red{background:#ef44441f;color:#dc2626}.summary-icon-wrap--amber{background:#f59e0b1f;color:#f59e0b}.summary-icon-wrap--teal{background:#10b9811f;color:#10b981}.summary-icon-wrap svg{width:16px;height:16px}.summary-item-body{flex:1;display:flex;align-items:center;justify-content:space-between;min-width:0}.summary-item-label{font-size:.85rem;color:var(--text-secondary)}.summary-item-value{font-size:.95rem;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.summary-pending{color:#f59e0b}.summary-paid{color:#10b981}.summary-completed{color:#3b82f6}.summary-cancelled{color:#ef4444}.activity-card{margin-top:1.5rem}.activity-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.activity-header__title{margin:0}.activity-count-badge{font-size:.75rem;font-weight:500;color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid var(--card-border);border-radius:999px;padding:.2rem .65rem}.activity-timeline{display:flex;flex-direction:column}.activity-read-more-btn{margin:.5rem auto 0;padding:.4rem .85rem;border:1px solid var(--card-border);border-radius:999px;background:transparent;color:var(--text-secondary);font-size:.78rem;font-weight:600;cursor:pointer}.activity-read-more-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.activity-row{display:grid;grid-template-columns:24px 1fr auto;gap:0 .85rem;align-items:start;min-height:52px;position:relative}.activity-row-last .act-spine{display:none}.act-dot-col{display:flex;flex-direction:column;align-items:center;padding-top:4px}.act-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;border:2px solid var(--card-bg);box-shadow:0 0 0 1.5px currentColor}.act-dot-requested{color:#f59e0b;background:#f59e0b}.act-dot-arrived{color:#10b981;background:#10b981}.act-dot-in_progress{color:#6366f1;background:#6366f1}.act-dot-completed{color:#3b82f6;background:#3b82f6}.act-dot-cancelled{color:#ef4444;background:#ef4444}.act-spine{flex:1;width:1.5px;background:var(--card-border);margin-top:4px;margin-bottom:0;min-height:28px}.act-body{display:flex;flex-direction:column;gap:.2rem;padding-bottom:1rem}.act-route{display:flex;align-items:center;gap:.3rem;flex-wrap:wrap}.act-location{font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap}.act-arrow{width:14px;height:14px;color:var(--text-secondary);flex-shrink:0}.act-meta{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap;font-size:.775rem;color:var(--text-secondary)}.act-meta-sep{color:var(--card-border)}.act-user{color:var(--text-primary);font-weight:600}.act-driver{color:var(--text-primary);opacity:.78}.act-ride-no{flex:1 1 100%;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.76rem;font-weight:650;letter-spacing:.01em;color:var(--accent-color, #3b82f6);opacity:.9}.act-meta-bottom{flex:1 1 100%;display:inline-flex;align-items:baseline;gap:.45rem}.act-right{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem;padding-bottom:1rem;padding-top:2px}.act-fare{font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap}.act-badge{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:.15rem .5rem;border-radius:999px;white-space:nowrap}.act-badge-requested{background:#f59e0b1f;color:#d97706}.act-badge-arrived{background:#10b9811f;color:#10b981}.act-badge-in_progress{background:#6366f11f;color:#6366f1}.act-badge-completed{background:#3b82f61f;color:#2563eb}.act-badge-cancelled{background:#ef44441f;color:#ef4444}.act-time{font-size:.72rem;color:var(--text-secondary);white-space:nowrap}.activity-empty{text-align:center;padding:2rem 0;color:var(--text-secondary);font-size:.875rem}.activity-skeleton .act-skeleton-dot{width:10px;height:10px;border-radius:50%;background:var(--bg-tertiary);animation:act-shimmer 1.4s ease infinite}.act-skeleton-line{height:10px;border-radius:6px;background:var(--bg-tertiary);animation:act-shimmer 1.4s ease infinite}.act-skeleton-wide{width:60%;margin-bottom:6px}.act-skeleton-narrow{width:38%}.act-skeleton-time{width:44px;margin-top:2px}@keyframes act-shimmer{0%{opacity:.5}50%{opacity:1}to{opacity:.5}}@media(max-width:768px){.dashboard-grid{grid-template-columns:1fr}.status-chips{grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}}.ride-bill-page .recap-value.ride-bill-recap__currency{font-size:clamp(.85rem,2.5vw,.95rem);font-variant-numeric:tabular-nums}.ride-bill-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem}.ride-bill-toolbar__search-wrap{flex:1 1 14rem;min-width:min(100%,12rem)}.ride-bill-toolbar__search{display:block;width:100%;box-sizing:border-box;margin:0;border:none;background:transparent;padding:.5rem .75rem;font-size:.875rem;font-family:inherit;color:var(--text-primary);outline:none}.ride-bill-toolbar__search::placeholder{color:var(--text-secondary);opacity:.8}.ride-bill-toolbar__select-wrap{position:relative;flex:0 1 auto;min-width:0;max-width:16rem}.ride-bill-toolbar__select-wrap--driver{min-width:9.5rem}.ride-bill-toolbar__select{display:block;width:100%;max-width:100%;box-sizing:border-box;margin:0;appearance:none;-webkit-appearance:none;background:transparent;border:none;padding:.5rem 1.85rem .5rem .75rem;font-size:.875rem;font-weight:500;font-family:inherit;line-height:1.25;color:var(--text-primary);cursor:pointer;outline:none;text-overflow:ellipsis}.ride-bill-toolbar__select:focus-visible{border-radius:.35rem;box-shadow:0 0 0 2px color-mix(in srgb,var(--accent-color) 45%,transparent)}.ride-bill-toolbar__select-wrap:after{content:"";position:absolute;right:.6rem;top:50%;width:.4rem;height:.4rem;margin-top:-.2rem;border-right:2px solid var(--text-secondary);border-bottom:2px solid var(--text-secondary);transform:rotate(45deg);pointer-events:none;opacity:.75}.ride-bill-toolbar__time-range{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;flex:1 1 auto;min-width:0}.ride-bill-calendar-container{position:relative;display:inline-flex}.ride-bill-calendar-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:var(--card-bg);border:1px solid var(--card-border);border-radius:.75rem;padding:0;box-shadow:0 8px 24px #00000026;z-index:1000;min-width:360px;max-width:90vw;overflow:visible}.ride-bill-calendar-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--card-border)}.ride-bill-calendar-title{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.ride-bill-calendar-close-btn{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;line-height:1;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:background .15s ease,color .15s ease}.ride-bill-calendar-close-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.ride-bill-calendar-inputs{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:1.5rem;overflow:visible;width:100%;box-sizing:border-box}.ride-bill-date-input-group{display:flex;flex-direction:column;gap:.5rem;min-width:0;overflow:visible}.ride-bill-date-input-group label{font-size:.75rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.ride-bill-date-range-info{padding:.75rem 1.5rem;background:var(--hover-bg);border-top:1px solid var(--card-border);border-bottom:1px solid var(--card-border)}.ride-bill-date-range-info--error{background:#ef44441a;border-color:#ef44444d}.ride-bill-date-range-text{font-size:.875rem;color:var(--text-secondary);font-weight:500}.ride-bill-date-range-error{color:#ef4444;font-weight:600}.ride-bill-date-picker-input{width:100%;min-width:0;padding:.625rem .75rem;border:1px solid var(--card-border);background:var(--card-bg);color:var(--text-primary);border-radius:.5rem;font-size:.875rem;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease;box-sizing:border-box;font-family:inherit}.ride-bill-date-picker-input:hover{border-color:var(--accent-color, #3b82f6)}.ride-bill-date-picker-input:focus{outline:none;border-color:var(--accent-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.ride-bill-calendar-actions{display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem;border-top:1px solid var(--card-border);background:var(--hover-bg)}.ride-bill-calendar-cancel-btn,.ride-bill-calendar-apply-btn{padding:.625rem 1.25rem;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:opacity .15s ease,transform .15s ease,box-shadow .15s ease;border:1px solid transparent;min-width:80px}.ride-bill-calendar-cancel-btn{background:var(--card-bg);color:var(--text-primary);border-color:var(--card-border)}.ride-bill-calendar-cancel-btn:hover{background:var(--hover-bg)}.ride-bill-calendar-apply-btn{background:var(--accent-color, #3b82f6);color:#fff;border-color:var(--accent-color, #3b82f6)}.ride-bill-calendar-apply-btn:hover:not(:disabled){opacity:.92;box-shadow:0 2px 8px #3b82f64d}.ride-bill-calendar-apply-btn:disabled{opacity:.45;cursor:not-allowed}.ride-bill-toolbar__export-wrap{flex:0 0 auto}.ride-bill-toolbar__export-wrap .ride-bill-segments__btn{white-space:nowrap}.ride-bill-segments{display:inline-flex;flex-wrap:wrap;gap:.25rem;padding:.2rem;border-radius:.5rem;border:1px solid var(--card-border);background:var(--bg-tertiary)}.ride-bill-segments__btn{padding:.5rem .75rem;border:none;border-radius:.4rem;background:transparent;color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.ride-bill-segments__btn:hover{color:var(--text-primary);background:color-mix(in srgb,var(--accent-color) 12%,transparent)}.ride-bill-segments__btn--active{background:var(--accent-color);color:#fff}.ride-bill-segments__btn--active:hover{color:#fff;background:var(--accent-hover)}.ride-bill-segments__btn--calendar{display:inline-flex;align-items:center;gap:.45rem;white-space:nowrap;line-height:1}.ride-bill-calendar-icon{width:1.1rem;height:1.1rem;flex-shrink:0;display:block}.ride-bill-calendar-range-text{font-weight:500;font-size:.8rem;letter-spacing:.01em}.ride-bill-segments__btn:disabled{opacity:.55;cursor:not-allowed}.ride-bill-segments__btn:disabled:hover{color:var(--text-secondary);background:transparent}.ride-bills-table th:first-child,.ride-bills-table td:first-child{width:auto;min-width:5.5rem;max-width:none}.ride-bills-table th,.ride-bills-table td{white-space:normal;overflow:visible;max-width:none;font-size:.875rem}.ride-bills-table__mono{font-variant-numeric:tabular-nums}.ride-bills-table__route{min-width:10rem;max-width:14rem}.ride-bills-table__fare{font-weight:600;color:var(--accent-color);font-variant-numeric:tabular-nums;white-space:nowrap}.ride-bills-table__muted{color:var(--text-secondary);white-space:nowrap}.ride-bills-table__date-cell span{display:block;line-height:1.4}.ride-bills-table__reason{min-width:9rem;max-width:14rem;vertical-align:top}.ride-bills-table__route-line{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem .4rem;font-size:.8125rem;line-height:1.35}.ride-bills-table__route-arrow{color:var(--accent-color);font-weight:600;flex-shrink:0}.ride-bill-status-select{padding:.35rem .5rem;border-radius:.375rem;border:1px solid var(--card-border);background:var(--bg-tertiary);color:var(--text-primary);font-size:.875rem;cursor:pointer;max-width:100%}.ride-bill-status-select:focus{outline:none;border-color:var(--accent-color)}.ride-bill-status-select.status-requested{background:#f59e0b1f;border-color:#f59e0b8c}.ride-bill-status-select.status-arrived{background:#06b6d41f;border-color:#06b6d48c}.ride-bill-status-select.status-in_progress{background:#8b5cf61f;border-color:#8b5cf68c}.ride-bill-status-select.status-completed{background:#10b9811f;border-color:#10b9818c}.ride-bill-status-select.status-cancelled{background:#ef44441f;border-color:#ef44448c}.ride-bill-reason-select{width:100%;padding:.4rem .5rem;font-size:.8125rem}.ride-bill-reason-input{margin-top:.35rem;width:100%;box-sizing:border-box;padding:.4rem .5rem;border-radius:.375rem;border:1px solid var(--card-border);background:var(--card-bg);color:var(--text-primary);font-size:.8125rem}.ride-bill-reason-input:focus{outline:none;border-color:var(--accent-color)}@media(max-width:768px){.ride-bill-toolbar__search-wrap,.ride-bill-toolbar__select-wrap,.ride-bill-toolbar__export-wrap,.ride-bill-segments{flex:1 1 100%;width:100%;max-width:none;justify-content:stretch}.ride-bill-segments__btn{flex:1;text-align:center}.ride-bill-toolbar__export-wrap{display:flex}.ride-bill-toolbar__export-wrap .ride-bill-segments__btn{flex:1;text-align:center}.ride-bill-calendar-dropdown{right:auto;left:0;width:calc(100vw - 2rem);max-width:100%;min-width:auto}.ride-bill-calendar-inputs{grid-template-columns:1fr}.ride-bill-date-picker-input{min-width:0;width:100%}.users-table.ride-bills-table{min-width:920px}}.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker__sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}.react-datepicker-wrapper{display:inline-block;padding:0;border:0}.react-datepicker{font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;background-color:#fff;color:#000;border:1px solid #aeaeae;border-radius:.3rem;display:inline-block;position:relative;line-height:initial}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.375em;border-bottom-right-radius:.375em}.react-datepicker-popper{z-index:1;line-height:0}.react-datepicker-popper .react-datepicker__triangle{stroke:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle,.react-datepicker-popper--header-middle[data-placement^=bottom] .react-datepicker__triangle,.react-datepicker-popper--header-bottom[data-placement^=bottom] .react-datepicker__triangle{fill:#fff;color:#fff}.react-datepicker-popper--header-bottom[data-placement^=top] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker__header{text-align:center;background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select,.react-datepicker__header--middle,.react-datepicker__header--bottom){border-top-right-radius:.3rem}.react-datepicker__header--middle{border-top:1px solid #aeaeae;border-radius:0;margin-top:4px}.react-datepicker__header--bottom{border-bottom:none;border-top:1px solid #aeaeae;border-radius:0 0 .3rem .3rem}.react-datepicker__header-wrapper{position:relative}.react-datepicker__header-wrapper .react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:2px}.react-datepicker__year-dropdown-container--select,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--scroll{display:inline-block;margin:0 15px}.react-datepicker__month-select,.react-datepicker__year-select,.react-datepicker__month-year-select{background-color:transparent;border:1px solid #aeaeae;border-radius:.3rem;color:inherit;cursor:pointer;font-family:inherit;font-size:inherit;margin-top:5px;padding:2px 5px}.react-datepicker__month-select:focus-visible,.react-datepicker__year-select:focus-visible,.react-datepicker__month-year-select:focus-visible{outline:auto 1px}.react-datepicker__current-month,.react-datepicker-time__header,.react-datepicker-year-header{margin-top:0;color:#000;font-weight:700;font-size:.944rem}h2.react-datepicker__current-month{padding:0;margin:0}.react-datepicker-time__header{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.react-datepicker__navigation{align-items:center;background:none;display:flex;justify-content:center;text-align:center;cursor:pointer;position:absolute;top:2px;padding:0;border:none;z-index:1;height:32px;width:32px;text-indent:-999em;overflow:hidden}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{position:relative;top:0;display:block;margin-left:auto;margin-right:auto}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover *:before{border-color:#a6a6a6}.react-datepicker__navigation-icon{position:relative;top:-1px;font-size:20px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{transform:rotate(45deg);left:-7px}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{transform:rotate(225deg);right:-7px}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.5em;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;width:5em;margin:2px}.react-datepicker__month{margin:.5em;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;width:5em;margin:2px}.react-datepicker__input-time-container{clear:both;width:100%;float:left;margin:5px 0 10px 15px;text-align:left}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{margin-left:5px;display:inline-block}.react-datepicker__time-container{float:right;border-left:1px solid #aeaeae;width:85px}.react-datepicker__time-container--with-today-button{display:inline;border:1px solid #aeaeae;border-radius:.375em;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{position:relative;background:#fff;border-bottom-right-radius:.375em}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{width:85px;overflow-x:hidden;margin:0 auto;text-align:center;border-bottom-right-radius:.375em}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{list-style:none;margin:0;height:calc(195px + 1.0625em);overflow-y:scroll;padding-right:0;padding-left:0;width:100%;box-sizing:content-box}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{cursor:pointer;background-color:#f0f0f0}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{cursor:default;background-color:transparent}.react-datepicker__week-number{color:#ccc;display:inline-block;width:2.125em;line-height:2.125em;text-align:center;margin:.208em}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__week-number--selected{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__day-names{text-align:center;white-space:nowrap;margin-bottom:-8px}.react-datepicker__week{white-space:nowrap}.react-datepicker__day-name,.react-datepicker__day,.react-datepicker__time-name{color:#000;display:inline-block;width:2.125em;line-height:2.125em;text-align:center;margin:.208em}.react-datepicker__day-name--disabled,.react-datepicker__day--disabled,.react-datepicker__time-name--disabled{cursor:default;color:#ccc}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:not([aria-disabled=true]):hover,.react-datepicker__month-text:not([aria-disabled=true]):hover,.react-datepicker__quarter-text:not([aria-disabled=true]):hover,.react-datepicker__year-text:not([aria-disabled=true]):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{border-radius:.3rem;background-color:#3dcc4a;color:#fff}.react-datepicker__day--highlighted:not([aria-disabled=true]):hover,.react-datepicker__month-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__year-text--highlighted:not([aria-disabled=true]):hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{position:relative;border-radius:.3rem;background-color:#ff6803;color:#fff}.react-datepicker__day--holidays .overlay,.react-datepicker__month-text--holidays .overlay,.react-datepicker__quarter-text--holidays .overlay,.react-datepicker__year-text--holidays .overlay{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__day--holidays:not([aria-disabled=true]):hover,.react-datepicker__month-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__year-text--holidays:not([aria-disabled=true]):hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .overlay,.react-datepicker__month-text--holidays:hover .overlay,.react-datepicker__quarter-text--holidays:hover .overlay,.react-datepicker__year-text--holidays:hover .overlay{visibility:visible;opacity:1}.react-datepicker__day--selected,.react-datepicker__day--in-selecting-range,.react-datepicker__day--in-range,.react-datepicker__month-text--selected,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--selected,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--selected,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--in-range{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__day--selected:not([aria-disabled=true]):hover,.react-datepicker__day--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__day--in-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-range:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{border-radius:.3rem;background-color:#bad9f1;color:#000}.react-datepicker__day--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--keyboard-selected:not([aria-disabled=true]):hover{background-color:#1d5d90;color:#fff}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{cursor:default;color:#ccc}.react-datepicker__day--disabled .overlay,.react-datepicker__month-text--disabled .overlay,.react-datepicker__quarter-text--disabled .overlay,.react-datepicker__year-text--disabled .overlay{position:absolute;bottom:70%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__input-container{position:relative;display:inline-block;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{position:absolute;padding:.625em;box-sizing:content-box}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__year-read-view,.react-datepicker__month-read-view,.react-datepicker__month-year-read-view{border:1px solid transparent;border-radius:.3rem;position:relative}.react-datepicker__year-read-view:hover,.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover{cursor:pointer}.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{transform:rotate(135deg);right:-16px;top:0}.react-datepicker__year-dropdown,.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown{background-color:#f0f0f0;position:absolute;width:50%;left:25%;top:30px;z-index:1;text-align:center;border-radius:.3rem;border:1px solid #aeaeae}.react-datepicker__year-dropdown:hover,.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover{cursor:pointer}.react-datepicker__year-dropdown--scrollable,.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__year-option,.react-datepicker__month-option,.react-datepicker__month-year-option{line-height:20px;width:100%;display:block;margin-left:auto;margin-right:auto}.react-datepicker__year-option:first-of-type,.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__year-option:last-of-type,.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker__year-option:hover,.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover{background-color:#ccc}.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__year-option--selected,.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected{position:absolute;left:15px}.react-datepicker__close-icon{cursor:pointer;background-color:transparent;border:0;outline:0;padding:0 6px 0 0;position:absolute;top:0;right:0;height:100%;display:table-cell;vertical-align:middle}.react-datepicker__close-icon:after{cursor:pointer;background-color:#216ba5;color:#fff;border-radius:50%;height:16px;width:16px;padding:2px;font-size:12px;line-height:1;text-align:center;display:table-cell;vertical-align:middle;content:"×"}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{cursor:default;background-color:#ccc}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;cursor:pointer;text-align:center;font-weight:700;padding:5px 0;clear:left}.react-datepicker__portal{position:fixed;width:100vw;height:100vh;background-color:#000c;left:0;top:0;justify-content:center;align-items:center;display:flex;z-index:2147483647}.react-datepicker__children-container{width:17.25em;margin:.5em;padding-right:.25em;padding-left:.25em;height:auto}.react-datepicker__aria-live{position:absolute;clip-path:circle(0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;width:1px;white-space:nowrap}.react-datepicker__calendar-icon{width:1em;height:1em;vertical-align:-.125em}.react-datepicker-popper-offset{margin-top:-.7em}.view-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:view-modal-fade-in .2s ease}@keyframes view-modal-fade-in{0%{opacity:0}to{opacity:1}}.view-modal-content{background:var(--card-bg);border:1px solid var(--card-border);border-radius:1rem;padding:0;max-width:900px;width:90%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:view-modal-slide-up .3s ease}@keyframes view-modal-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.view-modal-header{padding:1.5rem 2rem;border-bottom:1px solid var(--card-border);display:flex;justify-content:space-between;align-items:center;background:var(--bg-tertiary)}.view-modal-header h2{margin:0;color:var(--text-primary);font-size:1.5rem;font-weight:600}.view-modal-close-btn{background:transparent;border:1px solid var(--card-border);border-radius:.5rem;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-primary);font-size:1.5rem;line-height:1;transition:all .2s ease;padding:0}.view-modal-close-btn:hover{background:var(--bg-secondary);border-color:var(--accent-color);transform:rotate(90deg)}.view-modal-body{padding:2rem;overflow-y:auto;flex:1}.view-modal-section{background:var(--bg-secondary);border:1px solid var(--card-border);border-radius:.75rem;padding:1.5rem;margin-bottom:1.5rem}.view-modal-section:last-child{margin-bottom:0}.view-modal-section-title{margin:0 0 1.25rem;color:var(--text-primary);font-size:1.1rem;font-weight:600;padding-bottom:.75rem;border-bottom:2px solid var(--card-border)}.view-modal-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem}.view-modal-info-item{display:flex;flex-direction:column;gap:.375rem}.view-modal-info-label{color:var(--text-secondary);font-size:.875rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.view-modal-info-value{color:var(--text-primary);font-size:1rem;font-weight:500;word-break:break-word}.view-modal-info-value--badge{display:block;width:fit-content;max-width:100%}.view-modal-image-container{text-align:center;margin-top:1rem}.view-modal-image{max-width:100%;max-height:400px;border-radius:.75rem;border:1px solid var(--card-border);box-shadow:0 4px 12px #0000001a;object-fit:contain;background:var(--bg-tertiary)}.view-modal-pdf-frame{width:100%;min-height:420px;border:1px solid var(--card-border);border-radius:.5rem;background:var(--bg-secondary)}.view-modal-pdf-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s ease;box-shadow:0 2px 8px #ef444440}.view-modal-pdf-btn:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 4px 16px #ef444459}.view-modal-pdf-btn:active{transform:translateY(0);box-shadow:0 2px 8px #ef444440}.view-modal-pdf-btn--spaced{margin-top:.75rem}.view-modal-empty-state{color:var(--text-secondary);font-style:italic;text-align:center;padding:1rem}.view-modal-footer{padding:1.5rem 2rem;border-top:1px solid var(--card-border);display:flex;justify-content:flex-end;background:var(--bg-tertiary)}.view-modal-close-button{padding:.75rem 2rem;background:var(--accent-color);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s ease}.view-modal-close-button:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 12px #6366f14d}@media(max-width:768px){.view-modal-content{width:95%;max-height:95vh}.view-modal-header,.view-modal-body,.view-modal-footer{padding:1.25rem}.view-modal-info-grid{grid-template-columns:1fr;gap:1rem}}.ride-location-page{width:100%;min-width:0;box-sizing:border-box}.ride-location-page__header{margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--card-border)}.ride-location-page .ride-bill-toolbar.ride-location-toolbar{align-items:stretch}.ride-location-bidirectional-icon{display:inline-flex;align-items:center;justify-content:center}.ride-location-wrap{overflow-x:auto;border:1px solid var(--card-border);border-radius:.875rem;box-shadow:0 1px 3px var(--shadow);-webkit-overflow-scrolling:touch;background:var(--card-bg)}.ride-routes-table{width:100%;min-width:640px;border-collapse:collapse;table-layout:auto}.ride-routes-table thead tr{background:var(--bg-secondary)}.ride-routes-table thead th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.03em;color:var(--text-primary);border-bottom:1px solid var(--card-border);white-space:nowrap;vertical-align:middle}.ride-routes-table td{padding:.75rem 1rem;border-top:1px solid var(--card-border);color:var(--text-primary);font-size:.95rem;vertical-align:middle;background:transparent}.ride-routes-table tbody tr:first-child td{border-top:none}.ride-routes-table tbody tr:nth-child(2n){background:color-mix(in srgb,var(--bg-tertiary) 35%,transparent)}:root[data-theme=dark] .ride-routes-table tbody tr:nth-child(2n){background:color-mix(in srgb,var(--bg-tertiary) 25%,transparent)}.ride-routes-table tbody tr{transition:background .2s}.ride-routes-table tbody tr:hover{background:color-mix(in srgb,var(--accent-color) 12%,var(--bg-tertiary))}:root[data-theme=dark] .ride-routes-table tbody tr:hover{background:color-mix(in srgb,var(--accent-color) 18%,var(--bg-secondary))}.ride-routes-table td:first-child{min-width:12rem;max-width:22rem}.ride-routes-table__fare{white-space:nowrap;font-weight:600}.ride-routes-table__muted{white-space:nowrap;color:var(--text-secondary);font-size:.875rem}.route-cell{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.route-cell__location{font-weight:500;color:var(--text-primary)}.route-cell__arrow{display:inline-flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;border-radius:50%;background:var(--accent-light);color:var(--accent-color);flex-shrink:0}.ride-location-confirm-overlay{position:fixed;inset:0;z-index:1002;display:flex;justify-content:center;align-items:flex-start;overflow-y:auto;overscroll-behavior:contain;padding:max(1.25rem,env(safe-area-inset-top)) 1rem max(1.5rem,env(safe-area-inset-bottom));background:#00000080}.ride-location-confirm{width:100%;max-width:22rem;margin-top:max(2rem,12vh);padding:1.35rem;border-radius:1rem;border:1px solid var(--card-border);background:var(--card-bg);box-shadow:0 12px 40px var(--shadow)}.ride-location-confirm__title{margin:0 0 .5rem;font-size:1.15rem;font-weight:600;color:var(--text-primary)}.ride-location-confirm__desc{margin:0 0 1rem;font-size:.875rem;line-height:1.5;color:var(--text-secondary)}.ride-location-confirm__preview{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem .5rem;margin-bottom:1.25rem;padding:.75rem .85rem;border-radius:.5rem;border:1px solid var(--card-border);background:var(--bg-tertiary);font-size:.875rem;font-weight:500;color:var(--text-primary)}.ride-location-confirm__stop{flex:1 1 5rem;min-width:0}.ride-location-confirm__icon{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border-radius:50%;background:var(--accent-light);color:var(--accent-color)}.ride-location-confirm__fare{flex-basis:100%;margin-top:.15rem;font-size:.8125rem;font-weight:600;color:var(--text-secondary)}.ride-location-confirm__actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.65rem}.ride-location-confirm__btn-secondary{padding:.6rem 1.1rem;border:1px solid var(--card-border);border-radius:.5rem;background:transparent;color:var(--text-primary);font-size:.9rem;font-weight:500;cursor:pointer}.ride-location-confirm__btn-secondary:hover:not(:disabled){background:var(--bg-tertiary)}.ride-location-confirm__btn-secondary:disabled{opacity:.5;cursor:not-allowed}.ride-location-confirm__btn-danger{padding:.6rem 1.1rem;border:none;border-radius:.5rem;background:#dc2626;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer}.ride-location-confirm__btn-danger:hover:not(:disabled){background:#b91c1c}.ride-location-confirm__btn-danger:disabled{opacity:.75;cursor:wait}:root[data-theme=dark] .ride-location-confirm__btn-danger{background:#dc2626}:root[data-theme=dark] .ride-location-confirm__btn-danger:hover:not(:disabled){background:#ef4444}.ride-location-modal-overlay{position:fixed;inset:0;z-index:1000;display:flex;justify-content:center;align-items:flex-start;overflow-y:auto;overscroll-behavior:contain;padding:max(1.25rem,env(safe-area-inset-top)) 1rem max(1.5rem,env(safe-area-inset-bottom));background:#00000080}.ride-location-modal{width:100%;max-width:26rem;flex-shrink:0;margin-top:max(1.25rem,6vh);margin-bottom:1.5rem;overflow:visible;padding:0;border-radius:1rem;border:1px solid var(--card-border);background:var(--card-bg);box-shadow:0 8px 32px var(--shadow)}.ride-location-modal__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.35rem 1.35rem .75rem;border-bottom:1px solid var(--card-border)}.ride-location-modal__header-text{min-width:0}.ride-location-modal__title{margin:0 0 .35rem;font-size:1.2rem;font-weight:600;color:var(--text-primary);line-height:1.3}.ride-location-modal__subtitle{margin:0;font-size:.8125rem;line-height:1.45;color:var(--text-secondary)}.ride-location-modal__close{flex-shrink:0;width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;margin:-.25rem -.25rem 0 0;border:none;border-radius:.5rem;background:transparent;color:var(--text-secondary);font-size:1.5rem;line-height:1;cursor:pointer;transition:background .15s,color .15s}.ride-location-modal__close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.ride-location-modal__callout{display:flex;align-items:flex-start;gap:.65rem;margin:0 1.35rem 1rem;padding:.7rem .85rem;font-size:.8125rem;line-height:1.45;color:var(--text-secondary);background:color-mix(in srgb,var(--accent-color) 8%,var(--bg-tertiary));border:1px solid color-mix(in srgb,var(--accent-color) 22%,var(--card-border));border-radius:.5rem}.ride-location-modal__callout-icon{flex-shrink:0;margin-top:.05rem;color:var(--accent-color)}.ride-location-modal__form{padding:0 1.35rem 1.35rem}.ride-location-modal__stops{margin:0 0 1.25rem;padding:1rem 1rem 1.05rem;border:1px solid var(--card-border);border-radius:.65rem;background:color-mix(in srgb,var(--bg-tertiary) 65%,var(--card-bg))}.ride-location-modal__stops-heading{margin-bottom:.85rem}.ride-location-modal__section-title{margin:0 0 .35rem;font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-secondary)}.ride-location-modal__legend-hint{margin:0;font-size:.78rem;line-height:1.45;color:var(--text-secondary)}.ride-location-modal__field{margin-bottom:.85rem}.ride-location-modal__field label{display:block;margin-bottom:.35rem;font-size:.8125rem;font-weight:600;color:var(--text-primary)}.ride-location-modal__field select,.ride-location-modal__field input{width:100%;box-sizing:border-box;padding:.65rem .75rem;border:1px solid var(--card-border);border-radius:.5rem;background:var(--bg-primary);color:var(--text-primary);font-size:.9375rem}.ride-location-modal__field select:focus,.ride-location-modal__field input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-color) 18%,transparent)}.ride-location-modal__swap-wrap{display:flex;justify-content:center;margin:.15rem 0 .85rem}.ride-location-modal__swap{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .75rem;border:1px dashed var(--card-border);border-radius:.5rem;background:var(--bg-tertiary);color:var(--accent-color);font-size:.8125rem;font-weight:600;cursor:pointer;transition:border-color .15s,background .15s}.ride-location-modal__swap:hover:not(:disabled){border-color:var(--accent-color);background:color-mix(in srgb,var(--accent-color) 10%,var(--bg-tertiary))}.ride-location-modal__swap:disabled{opacity:.45;cursor:not-allowed}.ride-location-modal__preview{margin-top:.35rem;padding:.75rem .85rem;border-radius:.5rem;background:var(--bg-tertiary);border:1px solid var(--card-border)}.ride-location-modal__preview-label{display:block;margin-bottom:.45rem;font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary)}.ride-location-modal__preview-pair{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem .5rem;font-size:.875rem;font-weight:500;color:var(--text-primary);line-height:1.35}.ride-location-modal__preview-stop{flex:1 1 6rem;min-width:0}.ride-location-modal__preview-icon{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:1.6rem;height:1.6rem;border-radius:50%;background:var(--accent-light);color:var(--accent-color)}.ride-location-modal__error{margin:.5rem 0 0;font-size:.8125rem;font-weight:500;color:#dc2626}:root[data-theme=dark] .ride-location-modal__error{color:#f87171}.ride-location-modal__field--fare{margin-bottom:.25rem}.ride-location-modal__fare-input{display:flex;align-items:stretch;border:1px solid var(--card-border);border-radius:.5rem;background:var(--bg-primary);overflow:hidden;transition:box-shadow .15s}.ride-location-modal__fare-input:focus-within{border-color:var(--accent-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-color) 18%,transparent)}.ride-location-modal__fare-prefix{display:flex;align-items:center;padding:0 .65rem 0 .75rem;font-size:1rem;font-weight:600;color:var(--text-secondary);background:var(--bg-tertiary);border-right:1px solid var(--card-border)}.ride-location-modal__fare-input input{border:none;border-radius:0;box-shadow:none;min-width:0;flex:1;padding:.65rem .75rem;font-variant-numeric:tabular-nums}.ride-location-modal__fare-input input:focus{outline:none;box-shadow:none}.ride-location-modal__field-hint{margin:.35rem 0 0;font-size:.75rem;color:var(--text-secondary)}.ride-location-modal__actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.ride-location-modal__btn-secondary{padding:.65rem 1.25rem;border:1px solid var(--card-border);border-radius:.5rem;background:transparent;color:var(--text-primary);font-size:.95rem;font-weight:500;cursor:pointer}.ride-location-modal__btn-secondary:hover{background:var(--bg-tertiary)}.ride-location-modal__btn-primary{padding:.65rem 1.25rem;border:none;border-radius:.5rem;background:var(--accent-color);color:#fff;font-size:.95rem;font-weight:500;cursor:pointer}.ride-location-modal__btn-primary:hover:not(:disabled){background:var(--accent-hover)}.ride-location-modal__btn-primary:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.ride-routes-table th,.ride-routes-table td{padding:.65rem .5rem;font-size:.85rem}}.analytics-page{width:100%;max-width:1680px;min-width:0;margin:0 auto;box-sizing:border-box;padding:1rem 1.25rem 1.5rem}.analytics-page>.edge-state{min-height:min(70vh,520px);width:100%}.analytics-page .recap-section{margin-bottom:1.35rem}.analytics-page .page-header.analytics-page__header{margin-bottom:1.25rem;padding-bottom:0;border-bottom:1px solid var(--card-border);transition:border-color .2s ease,box-shadow .2s ease}.analytics-page__header--filters-active{border-bottom-color:color-mix(in srgb,var(--accent-color, #3b82f6) 42%,var(--card-border));box-shadow:inset 0 -1px color-mix(in srgb,var(--accent-color, #3b82f6) 22%,transparent)}.analytics-page .ride-bill-toolbar.analytics-toolbar-strip{align-items:flex-start;flex-wrap:wrap;justify-content:space-between;gap:.75rem;padding-bottom:.75rem}.analytics-page .analytics-toolbar-period-block{flex:1 1 auto;min-width:0;max-width:100%}.analytics-page .analytics-toolbar-period-block .ride-bill-toolbar__time-range,.analytics-page .analytics-toolbar-period__inner{width:100%;min-width:0}.analytics-page .users-toolbar__right.analytics-toolbar-filters-row{display:flex;flex-wrap:nowrap;align-items:center;justify-content:flex-end;gap:.5rem .75rem;flex:0 1 auto;min-width:0;margin-left:auto}.analytics-toolbar__filter{position:relative;flex:0 0 auto;min-width:7.25rem;max-width:11rem}.analytics-toolbar__filter--route{flex:0 1 12rem;min-width:8.5rem;max-width:14rem}.analytics-toolbar__filter--chart-scope{min-width:6.75rem;max-width:9.75rem}.analytics-main-chart-span{grid-area:main;min-width:0}.analytics-sidebar--routes{grid-area:routes;min-width:0}.analytics-sidebar--drivers{grid-area:drivers;min-width:0}.analytics-sidebar--students{grid-area:students;min-width:0}.analytics-sidebar-mini-chart{width:100%;margin-top:.15rem;margin-bottom:.65rem;min-height:152px;border-radius:.5rem;overflow:hidden;background:color-mix(in srgb,var(--hover-bg) 65%,transparent)}.analytics-sidebar-mini-chart--empty{display:flex;align-items:center;justify-content:center;min-height:120px;margin-bottom:.75rem;padding:.75rem;font-size:.875rem;color:var(--text-secondary);border-radius:.5rem;border:1px dashed var(--card-border)}.analytics-filters-summary{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.5rem .75rem;margin-top:.35rem;padding:.55rem .75rem .65rem;border-radius:.5rem;border:1px solid var(--card-border);background:var(--hover-bg)}.analytics-page__header--filters-active .analytics-filters-summary{border-color:color-mix(in srgb,var(--accent-color, #3b82f6) 28%,var(--card-border));background:color-mix(in srgb,var(--accent-color, #3b82f6) 6%,var(--hover-bg))}.react-datepicker{font-family:inherit;border:1px solid var(--card-border);border-radius:.5rem;background:var(--card-bg);overflow:visible;width:100%;max-width:100%}.react-datepicker__month-container{overflow:visible;width:100%;max-width:100%;box-sizing:border-box}.react-datepicker__header{background:var(--card-bg);border-bottom:1px solid var(--card-border);border-radius:.5rem .5rem 0 0;padding:.5rem 0;overflow:visible;width:100%;box-sizing:border-box;position:relative}.react-datepicker__current-month{color:var(--text-primary);font-size:.875rem;font-weight:600;padding:.5rem 0;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.react-datepicker__day-names{display:flex;justify-content:space-around;margin:0;padding:.5rem 0;overflow:hidden;width:100%}.react-datepicker__day-name{color:var(--text-secondary);font-size:.75rem;font-weight:600;width:2rem;margin:0;padding:.5rem 0;text-align:center;overflow:hidden;text-overflow:ellipsis}.react-datepicker__month{margin:0;padding:.5rem;overflow:visible;width:100%;box-sizing:border-box}.react-datepicker__week{display:flex;justify-content:space-around;margin:0;width:100%}.react-datepicker__day{color:var(--text-primary);width:2rem;height:2rem;line-height:2rem;margin:.125rem;border-radius:.25rem;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;text-overflow:ellipsis}.react-datepicker__day:hover{background:var(--hover-bg);border-radius:.25rem}.react-datepicker__day--selected,.react-datepicker__day--in-selecting-range,.react-datepicker__day--in-range{background:var(--accent-color, #3b82f6);color:#fff;border-radius:.25rem}.react-datepicker__day--keyboard-selected{background:var(--accent-color, #3b82f6);color:#fff}.react-datepicker__triangle{display:none}.react-datepicker-popper{z-index:1001!important;overflow:visible!important}.react-datepicker__portal,.react-datepicker__month-dropdown-container,.react-datepicker__year-dropdown-container{overflow:visible}.react-datepicker__month-dropdown,.react-datepicker__year-dropdown{background:var(--card-bg);border:1px solid var(--card-border);border-radius:.5rem;overflow-y:auto;max-height:200px}.react-datepicker__month-option,.react-datepicker__year-option{color:var(--text-primary);padding:.5rem;cursor:pointer}.react-datepicker__month-option:hover,.react-datepicker__year-option:hover{background:var(--hover-bg)}.analytics-grid{display:grid;width:100%;min-width:0;box-sizing:border-box;grid-template-columns:minmax(0,1.22fr) minmax(0,.88fr);grid-template-rows:minmax(0,auto) minmax(0,auto);grid-template-areas:"main routes" "drivers students";gap:1.25rem 1.5rem;align-items:stretch}.analytics-grid>.analytics-card.small-card{min-height:0;display:flex;flex-direction:column}.analytics-grid>.analytics-card.big-card{min-width:0;min-height:0}.analytics-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:1rem;padding:1.5rem;box-shadow:0 1px 2px color-mix(in srgb,var(--shadow) 60%,transparent),0 6px 16px color-mix(in srgb,var(--shadow) 35%,transparent);transition:background .25s ease,border-color .25s ease,box-shadow .25s ease}@media(hover:hover){.analytics-card:hover{border-color:color-mix(in srgb,var(--card-border) 70%,var(--accent-color, #3b82f6) 18%);box-shadow:0 2px 4px color-mix(in srgb,var(--shadow) 50%,transparent),0 10px 28px color-mix(in srgb,var(--shadow) 40%,transparent)}}.analytics-card.small-card{padding:1.15rem 1.25rem 1.25rem}.analytics-card.small-card .card-title-group{margin-bottom:.85rem}.analytics-card.small-card h3{font-size:1.02rem;letter-spacing:-.02em}.analytics-sidebar-list{display:flex;flex-direction:column;gap:.55rem;min-height:0;max-height:min(220px,36vh);overflow-y:auto;overflow-x:hidden;padding-right:.2rem;margin-right:-.05rem;-webkit-overflow-scrolling:touch;scrollbar-gutter:stable;scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--text-secondary) 35%,transparent) transparent}.analytics-sidebar-list::-webkit-scrollbar{width:6px}.analytics-sidebar-list::-webkit-scrollbar-track{background:transparent;border-radius:999px}.analytics-sidebar-list::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--card-border) 85%,var(--text-secondary) 15%);border-radius:999px}.analytics-sidebar-list::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--card-border) 70%,var(--text-secondary) 30%)}.analytics-card.small-card .bar-list-item{padding:.6rem .7rem;gap:.65rem;border:1px solid transparent}.analytics-card.small-card .bar-list-item:hover{border-color:color-mix(in srgb,var(--card-border) 80%,var(--accent-color, #3b82f6) 14%)}.analytics-card h3{font-size:1.125rem;margin:0;color:var(--text-primary);font-weight:600}.analytics-card.big-card .card-title-group{margin-bottom:.65rem}.card-title-group{display:flex;flex-direction:column;gap:.2rem;margin-bottom:1.25rem}.card-subtitle{font-size:.8rem;color:var(--text-secondary);font-weight:400}.chart-placeholder{display:flex;align-items:center;justify-content:center;min-height:200px;padding:1rem;text-align:center;color:var(--text-secondary);font-size:.875rem;line-height:1.45}.analytics-card.big-card>.chart-placeholder{height:380px;box-sizing:border-box;border-radius:.65rem;background:color-mix(in srgb,var(--hover-bg) 90%,transparent);border:1px dashed color-mix(in srgb,var(--card-border) 85%,transparent)}.list-empty{padding:1rem;color:var(--text-secondary);font-size:.875rem}.chart-container{width:100%;margin-top:1rem}.analytics-card.big-card .chart-container{height:380px;min-height:0;margin-top:.75rem}.analytics-card.big-card .chart-container--combined{height:auto;display:flex;flex-direction:column;gap:.75rem;margin-top:.75rem}.chart-combined-row{display:flex;flex-direction:column;flex:1 1 0;min-height:160px;height:170px}.chart-combined-label{font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:4px}.chart-placeholder--inline{display:flex;align-items:center;justify-content:center;flex:1;font-size:.875rem;color:var(--text-secondary);padding:1rem 0}.list-placeholder{display:flex;flex-direction:column;gap:1rem}.list-placeholder.analytics-sidebar-list{gap:.55rem}.analytics-grid>.analytics-card.small-card .analytics-sidebar-list{flex:1 1 auto;min-height:8rem;max-height:none}.analytics-grid>.analytics-card.small-card .analytics-sidebar-mini-chart{flex-shrink:0}.bar-list-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--hover-bg);border-radius:.5rem;transition:background .2s ease;position:relative}.bar-list-item:hover{background:var(--card-border)}.bar-list-item .list-rank{min-width:1.5rem;font-size:.875rem;font-weight:700}.bar-list-body{flex:1;display:flex;flex-direction:column;gap:.35rem;min-width:0}.bar-list-top{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem}.bar-list-top .list-name{flex:1 1 auto;min-width:0;font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bar-list-top .list-value{font-size:.8rem;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.loc-view-btn{flex-shrink:0;padding:.25rem .6rem;font-size:.75rem;font-weight:600;border:1px solid var(--card-border);border-radius:.375rem;background:transparent;color:var(--accent-color, #3b82f6);cursor:pointer;transition:all .15s ease;white-space:nowrap}.loc-view-btn:hover{background:var(--accent-color, #3b82f6);color:#fff;border-color:var(--accent-color, #3b82f6)}.loc-view-btn:focus-visible{outline:2px solid var(--accent-color, #3b82f6);outline-offset:2px}.loc-modal-close:focus-visible{outline:2px solid var(--accent-color, #3b82f6);outline-offset:2px}.pair-clear-all-btn:focus-visible{outline:2px solid #ef4444;outline-offset:2px}.loc-modal-backdrop{position:fixed;inset:0;background:#00000073;z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.loc-modal{background:var(--card-bg);border:1px solid var(--card-border);border-radius:1rem;width:min(420px,calc(100vw - 2rem));box-shadow:0 16px 48px #00000038;animation:slideUp .18s ease;overflow:hidden}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.loc-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1.1rem 1.25rem .85rem;border-bottom:1px solid var(--card-border);gap:.75rem}.loc-modal-title-group{display:flex;align-items:flex-start;gap:.6rem}.loc-modal-pin{margin-top:2px;flex-shrink:0;color:var(--accent-color, #3b82f6)}.loc-modal-pin svg{width:1.2rem;height:1.2rem}.loc-modal-title-group h4{margin:0 0 .15rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.loc-modal-route-title{white-space:normal;word-break:break-word;line-height:1.35;max-width:min(100%,22rem)}.loc-modal-sub{font-size:.75rem;color:var(--text-secondary)}.loc-modal-close{background:none;border:none;font-size:1.4rem;line-height:1;color:var(--text-secondary);cursor:pointer;padding:0;border-radius:.25rem;transition:color .15s;flex-shrink:0}.loc-modal-close:hover{color:var(--text-primary)}.loc-stat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border-bottom:1px solid var(--card-border)}.loc-stat-item{display:flex;flex-direction:column;align-items:center;padding:.9rem .5rem;gap:.3rem;border-right:1px solid var(--card-border)}.loc-stat-item:last-child{border-right:none}.loc-stat-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);font-weight:600}.loc-stat-value{font-size:1.15rem;font-weight:700;color:var(--text-primary)}.loc-stat-pending .loc-stat-value{color:#f59e0b}.loc-stat-paid .loc-stat-value{color:#10b981}.loc-stat-cancelled .loc-stat-value{color:#ef4444}.loc-routes-section{padding:.85rem 1.25rem 1rem}.loc-routes-heading{margin:0 0 .6rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.loc-route-row{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;border-radius:.375rem;transition:background .15s}.loc-route-row:hover{background:var(--hover-bg)}.loc-route-arrow{color:var(--accent-color, #3b82f6);font-size:.85rem;font-weight:700;flex-shrink:0}.loc-route-name{flex:1;font-size:.875rem;color:var(--text-primary);font-weight:500}.loc-route-count{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.pair-scope-sub{font-weight:400;opacity:.9}.pair-scope-note{font-size:.75rem;color:var(--text-secondary);line-height:1.35}.pair-clear-all-btn{padding:.3rem .7rem;background:none;border:1px solid rgba(239,68,68,.4);color:#ef4444;border-radius:.4rem;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s ease;white-space:nowrap;flex-shrink:0}.pair-clear-all-btn:hover{background:#ef444414;border-color:#ef4444}.loc-modal--wide{width:min(520px,calc(100vw - 2rem))}.driver-modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--card-border)}.driver-modal-grid .loc-routes-section{border-right:1px solid var(--card-border)}.driver-modal-grid .loc-routes-section:last-child{border-right:none}@media(max-width:1024px){.analytics-grid{grid-template-columns:minmax(0,1fr);grid-template-areas:"main" "routes" "drivers" "students"}.analytics-grid>.analytics-card.small-card .analytics-sidebar-list{flex:0 1 auto;min-height:0;max-height:min(260px,42vh)}}@media(max-width:768px){.analytics-page .ride-bill-toolbar.analytics-toolbar-strip{flex-direction:column;align-items:stretch}.analytics-page .users-toolbar__right.analytics-toolbar-filters-row{flex-wrap:wrap;margin-left:0;justify-content:stretch;width:100%}.analytics-toolbar__filter,.analytics-toolbar__filter--route,.analytics-toolbar__filter--chart-scope{flex:1 1 auto;max-width:none;width:100%;min-width:0}.analytics-card.big-card .chart-container{height:280px}.analytics-card.big-card .chart-container--combined{height:auto}.chart-combined-row{height:130px;min-height:120px}.analytics-card.big-card>.chart-placeholder{height:280px;min-height:220px}.ride-bill-calendar-dropdown{right:auto;left:0;width:calc(100vw - 2rem);max-width:100%;min-width:auto}.ride-bill-calendar-inputs,.driver-modal-grid{grid-template-columns:1fr}.driver-modal-grid .loc-routes-section{border-right:none;border-bottom:1px solid var(--card-border)}.driver-modal-grid .loc-routes-section:last-child{border-bottom:none}}.settings-page{width:100%;padding:0;animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.settings-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid var(--card-border)}.header-content-wrapper{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;flex-wrap:wrap}.header-title-section{flex:1}.settings-header h1{margin:0 0 .5rem;font-size:2.25rem;font-weight:800;background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.settings-subtitle{margin:0;color:var(--text-secondary);font-size:1rem;line-height:1.6}.unsaved-changes-badge{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:linear-gradient(135deg,#fbbf2426,#fbbf241a);border:2px solid rgba(251,191,36,.4);border-radius:.75rem;color:#f59e0b;font-size:.875rem;font-weight:600;box-shadow:0 2px 8px #fbbf2433;animation:slideInRight .3s ease}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.badge-dot{font-size:.75rem;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}.settings-container{display:flex;gap:2rem;background:var(--card-bg);border:1px solid var(--card-border);border-radius:1.25rem;overflow:hidden;box-shadow:0 4px 20px #00000014;min-height:600px;transition:box-shadow .3s ease}.settings-container:hover{box-shadow:0 8px 30px #0000001f}.settings-sidebar{width:300px;padding:2rem 1.5rem;background:linear-gradient(180deg,var(--bg-tertiary),var(--bg-secondary));border-right:1px solid var(--border-color);flex-shrink:0;position:relative}.settings-sidebar:before{content:"";position:absolute;top:0;right:0;width:1px;height:100%;background:linear-gradient(180deg,transparent,var(--accent-color),transparent);opacity:.3}.settings-nav{display:flex;flex-direction:column;gap:.5rem}.settings-nav-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:transparent;border:none;border-radius:.75rem;color:var(--text-secondary);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);text-align:left;font-size:.95rem;width:100%;position:relative;overflow:hidden}.settings-nav-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent-color);transform:scaleY(0);transition:transform .3s ease}.settings-nav-item:hover{background:var(--bg-secondary);color:var(--text-primary);transform:translate(6px);box-shadow:0 2px 8px #0000000d}.settings-nav-item.active{background:linear-gradient(135deg,var(--accent-light),rgba(0,123,255,.1));color:var(--accent-color);font-weight:700;box-shadow:0 4px 12px #007bff26;transform:translate(4px)}.settings-nav-item.active:before{transform:scaleY(1)}.nav-icon{font-size:1.5rem;flex-shrink:0;width:2rem;text-align:center}.nav-content{display:flex;flex-direction:column;gap:.25rem;flex:1}.nav-label{font-size:.95rem;font-weight:inherit;line-height:1.4}.nav-description{font-size:.75rem;opacity:.7;display:none;line-height:1.3}.settings-nav-item.active .nav-description{display:block}.settings-content{flex:1;padding:2.5rem;overflow-y:auto;max-height:calc(100vh - 200px);scroll-behavior:smooth}.settings-content::-webkit-scrollbar{width:8px}.settings-content::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:4px}.settings-content::-webkit-scrollbar-thumb{background:var(--card-border);border-radius:4px}.settings-content::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.section-header{margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:2px solid var(--card-border)}.section-header h2{margin:0 0 .75rem;font-size:1.875rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.section-header p{margin:0;color:var(--text-secondary);font-size:1rem;line-height:1.6}.profile-picture-section{margin-bottom:3rem;display:flex;flex-direction:row;align-items:center;gap:2rem;padding:2rem;background:var(--bg-tertiary);border-radius:1rem;border:2px solid var(--card-border)}.profile-picture-wrapper{position:relative;flex-shrink:0}.profile-picture{position:relative;width:120px;height:120px;border-radius:50%;overflow:hidden;border:3px solid var(--card-border);cursor:pointer;box-shadow:0 2px 8px #0000001a;background:var(--card-bg)}.profile-picture img,.profile-picture .profile-picture-img{width:100%;height:100%;object-fit:cover;display:block}.profile-picture .profile-picture-img{border-radius:50%}.profile-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--accent-color);color:#fff;font-size:3rem;font-weight:700;position:absolute;top:0;left:0}.profile-placeholder-fallback{z-index:1}.profile-overlay{position:absolute;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;opacity:0;border-radius:50%}.profile-picture:hover .profile-overlay{opacity:1}.profile-upload-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600}.profile-upload-btn input{display:none}.upload-icon{font-size:1.5rem}.upload-text{font-size:.75rem}.upload-spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.profile-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.profile-name{margin:0;color:var(--text-primary);font-size:1.25rem;font-weight:700;line-height:1.4}.profile-hint{margin:0;color:var(--text-secondary);font-size:.875rem;font-weight:400;line-height:1.5}@media(max-width:768px){.profile-picture-section{flex-direction:column;text-align:center}.profile-info{align-items:center}}.settings-form{display:flex;flex-direction:column;gap:2rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.75rem}.form-group label{color:var(--text-primary);font-weight:600;font-size:.95rem;display:flex;align-items:center;gap:.5rem}.form-input{padding:.875rem 1rem;border:2px solid var(--card-border);border-radius:.5rem;background:var(--card-bg);color:var(--text-primary);font-size:.95rem;font-family:inherit;width:100%;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-input:hover{border-color:var(--accent-color)}.form-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-light);background:var(--card-bg);color:var(--text-primary)}.form-input.error{border-color:#ef4444}.form-input.error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-input::placeholder{color:var(--text-secondary);opacity:.7}.form-input:disabled,.form-input.disabled-input{background-color:var(--bg-tertiary);color:var(--text-secondary);cursor:not-allowed;opacity:.6}.form-input:disabled::placeholder,.form-input.disabled-input::placeholder{color:var(--text-secondary);opacity:.5}:root[data-theme=light] .form-input{background-color:#fff;color:#111827;border-color:#e5e7eb}:root[data-theme=light] .form-input:focus{background-color:#fff;color:#111827;border-color:var(--accent-color)}:root[data-theme=dark] .form-input{background-color:#0f172acc;color:#e5e7eb;border-color:#6366f133}:root[data-theme=dark] .form-input:focus{background-color:#0f172ae6;color:#e5e7eb;border-color:var(--accent-color)}.form-hint{margin:.25rem 0 0;color:var(--text-secondary);font-size:.8rem;display:flex;align-items:center;gap:.25rem}.form-error{margin:.25rem 0 0;color:#ef4444;font-size:.8rem;font-weight:500;display:flex;align-items:center;gap:.25rem}.form-error:before{content:"⚠";font-size:.875rem}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper .form-input{padding-right:3.5rem;flex:1}.password-toggle{position:absolute;right:1rem;background:none;border:none;cursor:pointer;font-size:1.25rem;color:var(--text-secondary);padding:.5rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease;border-radius:.5rem}.password-toggle:hover:not(:disabled){color:var(--text-primary);background:var(--bg-tertiary);transform:scale(1.1)}.password-toggle:disabled{opacity:.5;cursor:not-allowed}.password-requirement-hint{margin-top:.5rem;color:var(--text-secondary);font-size:.8rem;font-style:italic}.password-requirement-hint strong{color:var(--accent-color);font-weight:600}.otp-verification-section{margin-top:2rem;padding:2rem;background:var(--bg-tertiary);border-radius:1rem;border:2px solid var(--card-border)}.otp-header{margin-bottom:1.5rem;text-align:center}.otp-header h3{margin:0 0 .5rem;color:var(--text-primary);font-size:1.25rem;font-weight:700}.otp-header p{margin:.5rem 0;color:var(--text-secondary);font-size:.95rem}.otp-header strong{color:var(--accent-color);font-weight:600}.otp-timer{margin:.75rem 0 0;color:var(--accent-color);font-size:.9rem;font-weight:600}.otp-timer strong{color:var(--accent-color);font-size:1.1rem}.otp-input-wrapper{position:relative;display:flex;justify-content:center}.otp-input{width:100%;max-width:300px;padding:1rem 1.5rem;border:2px solid var(--card-border);border-radius:.75rem;background:var(--card-bg);color:var(--text-primary);font-size:1.5rem;font-weight:700;text-align:center;letter-spacing:.5rem;font-family:Courier New,monospace;transition:all .3s ease}.otp-input:hover:not(:disabled){border-color:var(--accent-color)}.otp-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 4px var(--accent-light)}.otp-input:disabled{background-color:var(--bg-tertiary);color:var(--text-secondary);cursor:not-allowed;opacity:.6}.otp-success-section{margin-top:2rem;padding:2rem;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-radius:1rem;border:2px solid #059669}.success-message{display:flex;align-items:center;justify-content:center;gap:1rem;color:#059669}.success-icon{font-size:2rem;font-weight:700}.success-message p{margin:0;font-size:1rem;font-weight:600}:root[data-theme=dark] .otp-success-section{background:linear-gradient(135deg,#10b98133,#10b9811a);border-color:#10b98166}:root[data-theme=dark] .success-message{color:#10b981}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.sessions-modal{background:var(--card-bg);border-radius:1rem;border:2px solid var(--card-border);width:100%;max-width:700px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.sessions-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem 2rem;border-bottom:2px solid var(--card-border);gap:1rem}.sessions-modal-header>div{flex:1}.sessions-modal-header h2{margin:0 0 .5rem;color:var(--text-primary);font-size:1.5rem;font-weight:700}.modal-subtitle{margin:0;color:var(--text-secondary);font-size:.875rem}.sessions-modal-tabs{display:flex;gap:.5rem;padding:0 2rem;border-bottom:2px solid var(--card-border);background:var(--bg-secondary)}.sessions-tab{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-secondary);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-bottom:-2px}.sessions-tab:hover{color:var(--text-primary);background:var(--bg-tertiary)}.sessions-tab.active{color:var(--accent-color);border-bottom-color:var(--accent-color);background:transparent}.sessions-tab span:first-child{font-size:1rem}.modal-close-btn{background:none;border:none;font-size:2rem;color:var(--text-secondary);cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.5rem;transition:all .2s ease}.modal-close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sessions-modal-body{padding:2rem;overflow-y:auto;flex:1}.sessions-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1rem}.sessions-loading .edge-state{min-height:0;padding:1rem}.sessions-empty{padding:1rem 0}.sessions-empty .edge-state{min-height:0;padding:1.5rem 1rem}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-hint{margin-top:.5rem;font-size:.875rem;opacity:.7}.sessions-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1.25rem;background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary));border-radius:.75rem;border:2px solid var(--card-border)}.sessions-summary{display:flex;align-items:center;gap:1rem}.summary-icon{font-size:2.5rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:var(--accent-light);border-radius:.75rem;flex-shrink:0}.summary-text{display:flex;flex-direction:column;gap:.25rem}.summary-title{margin:0;color:var(--text-primary);font-size:1.1rem;font-weight:700}.summary-count{margin:0;color:var(--text-secondary);font-size:.9rem}.summary-count strong{color:var(--accent-color);font-weight:700}.sessions-actions{display:flex;gap:.75rem;flex-shrink:0}.refresh-sessions-btn{padding:.625rem 1rem;background:var(--card-bg);color:var(--text-primary);border:2px solid var(--card-border);border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.refresh-sessions-btn:hover:not(:disabled){border-color:var(--accent-color);background:var(--bg-secondary)}.refresh-sessions-btn:disabled{opacity:.5;cursor:not-allowed}.revoke-all-btn{padding:.625rem 1rem;background:transparent;color:#ef4444;border:2px solid #ef4444;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.revoke-all-btn:hover:not(:disabled){background:#ef44441a}.revoke-all-btn:disabled{opacity:.5;cursor:not-allowed}.sessions-list{display:flex;flex-direction:column;gap:1rem}.sessions-footer{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--card-border);text-align:center}.sessions-more{margin:0;color:var(--text-secondary);font-size:.875rem;font-style:italic}.session-item{display:flex;align-items:flex-start;gap:1rem;padding:1.5rem;background:var(--bg-tertiary);border-radius:.75rem;border:2px solid var(--card-border);transition:all .2s ease;position:relative}.session-item:hover{border-color:var(--accent-color);box-shadow:0 4px 12px #0000001a}.session-item.current{border-color:var(--accent-color);background:linear-gradient(135deg,var(--accent-light),var(--bg-tertiary));box-shadow:0 4px 16px #3b82f626}.session-item.recent{border-left:4px solid #10b981}.session-icon-wrapper{position:relative;flex-shrink:0;width:56px;height:56px}.session-device-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;font-size:2rem;background:var(--card-bg);border-radius:.75rem;border:2px solid var(--card-border)}.session-browser-icon{position:absolute;bottom:-4px;right:-4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.875rem;background:var(--bg-secondary);border-radius:50%;border:2px solid var(--card-bg);box-shadow:0 2px 4px #0000001a}.session-info{flex:1;min-width:0}.session-header{margin-bottom:.75rem}.session-title-group{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.session-header h4{margin:0;color:var(--text-primary);font-size:1.05rem;font-weight:600}.current-badge{padding:.25rem .75rem;background:var(--accent-color);color:#fff;border-radius:.375rem;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.ping-indicator{width:8px;height:8px;border-radius:50%;display:inline-block;position:relative;flex-shrink:0}.ping-green{background-color:#10b981;box-shadow:0 0 #10b981b3;animation:ping-green 2s ease-in-out infinite}.ping-red{background-color:#ef4444;box-shadow:0 0 #ef4444b3;animation:ping-red 2s ease-in-out infinite}@keyframes ping-green{0%{box-shadow:0 0 #10b981b3}50%{box-shadow:0 0 0 6px #10b98100}to{box-shadow:0 0 #10b98100}}@keyframes ping-red{0%{box-shadow:0 0 #ef4444b3}50%{box-shadow:0 0 0 6px #ef444400}to{box-shadow:0 0 #ef444400}}.recent-badge{padding:.25rem .75rem;background:#10b981;color:#fff;border-radius:.375rem;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.inactive-badge{padding:.25rem .75rem;background:#6b7280;color:#fff;border-radius:.375rem;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.session-details{display:flex;flex-direction:column;gap:.625rem}.session-detail{display:flex;align-items:center;gap:.625rem;color:var(--text-secondary);font-size:.875rem}.detail-icon{font-size:1rem;width:20px;text-align:center;flex-shrink:0}.detail-text{flex:1;min-width:0;word-break:break-word}.detail-label{font-weight:600;color:var(--text-primary);margin-right:.25rem}.session-actions{display:flex;align-items:center;flex-shrink:0}.revoke-session-btn{padding:.625rem 1rem;background:transparent;color:#ef4444;border:2px solid #ef4444;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.revoke-session-btn:hover:not(:disabled){background:#ef44441a;transform:translateY(-1px)}.revoke-session-btn:disabled{opacity:.5;cursor:not-allowed}.current-indicator{padding:.625rem 1rem;background:var(--accent-color);color:#fff;border-radius:.5rem;font-size:.875rem;font-weight:600;display:flex;align-items:center;gap:.5rem}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.sessions-modal-footer{padding:1.5rem 2rem;border-top:2px solid var(--card-border);display:flex;justify-content:flex-end}@media(max-width:768px){.sessions-modal{max-width:100%;max-height:100vh;border-radius:0}.revoke-session-btn{width:100%}.sessions-info{flex-direction:column;align-items:stretch;gap:1rem}.sessions-actions{flex-direction:column;width:100%}.refresh-sessions-btn,.revoke-all-btn{width:100%;justify-content:center}.session-item{flex-direction:column;gap:1rem}.session-actions{width:100%}.revoke-session-btn{width:100%;justify-content:center}}.password-strength-container{margin-top:.75rem;display:flex;flex-direction:column;gap:.5rem}.password-strength{display:flex;align-items:center;gap:.75rem}.password-strength-text{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.password-strength-label{font-size:.875rem;font-weight:600;display:inline-block}.password-strength-bar{width:100%;height:8px;background:var(--bg-secondary);border-radius:4px;overflow:hidden;box-shadow:inset 0 1px 2px #0000001a}.password-strength-fill{height:100%;transition:all .4s cubic-bezier(.4,0,.2,1);border-radius:4px;box-shadow:0 1px 3px #0003}.password-requirements{margin-top:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:.5rem;border:1px solid var(--card-border)}.password-requirements-title{margin:0 0 .75rem;font-size:.875rem;font-weight:600;color:var(--text-primary)}.password-requirements-list{margin:0;padding-left:1.25rem;list-style:none;display:flex;flex-direction:column;gap:.5rem}.password-requirements-list li{font-size:.8rem;color:var(--text-secondary);position:relative;padding-left:1.5rem}.password-requirements-list li:before{content:"○";position:absolute;left:0;color:var(--text-secondary);font-size:.75rem}.password-requirements-list li.requirement-met{color:#059669}.password-requirements-list li.requirement-met:before{content:"✓";color:#059669;font-weight:700}.password-warning{margin-top:.75rem;padding:.75rem 1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;display:flex;align-items:flex-start;gap:.75rem;color:#991b1b}.password-warning .warning-icon{font-size:1rem;flex-shrink:0}.password-warning .warning-text{font-size:.875rem;line-height:1.5;flex:1}:root[data-theme=dark] .password-warning{background:#ef44441a;border-color:#ef44444d;color:#fca5a5}.form-actions{display:flex;gap:1rem;margin-top:2rem;padding-top:2rem;border-top:2px solid var(--card-border)}.save-btn{display:flex;align-items:center;gap:.75rem;padding:1rem 2rem;background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));color:#fff;border:none;border-radius:.75rem;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #007bff4d;position:relative;overflow:hidden}.save-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.save-btn:hover:not(:disabled):before{left:100%}.save-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #007bff66}.save-btn:active:not(:disabled){transform:translateY(0)}.save-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.cancel-btn{padding:1rem 2rem;background:transparent;color:var(--text-secondary);border:2px solid var(--card-border);border-radius:.75rem;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .3s ease}.cancel-btn:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--text-secondary);transform:translateY(-1px)}.cancel-btn:disabled{opacity:.5;cursor:not-allowed}.security-section{margin-top:3rem;padding-top:2.5rem;border-top:2px solid var(--card-border)}.security-section h3{margin:0 0 1.5rem;color:var(--text-primary);font-size:1.375rem;font-weight:700}.security-item{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary));border-radius:1rem;margin-bottom:1rem;border:2px solid var(--card-border);transition:all .3s ease}.security-item:hover{border-color:var(--accent-color);box-shadow:0 4px 12px #007bff1a;transform:translateY(-2px)}.security-info h4{margin:0 0 .5rem;color:var(--text-primary);font-size:1.05rem;font-weight:600}.security-info p{margin:0;color:var(--text-secondary);font-size:.875rem;line-height:1.5}.security-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));color:#fff;border:none;border-radius:.625rem;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .3s ease;flex-shrink:0;box-shadow:0 2px 8px #007bff33}.security-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #007bff4d}.security-btn.secondary{background:transparent;color:var(--accent-color);border:2px solid var(--accent-color);box-shadow:none}.security-btn.secondary:hover{background:var(--accent-light);box-shadow:0 2px 8px #007bff26}.appearance-options{display:flex;flex-direction:column;gap:2rem}.appearance-group{padding:2rem;background:var(--bg-tertiary);border-radius:1rem;border:2px solid var(--card-border)}.appearance-group-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--card-border)}.appearance-group-header h3{margin:0 0 .5rem;color:var(--text-primary);font-size:1.15rem;font-weight:600}.appearance-group-header p{margin:0;color:var(--text-secondary);font-size:.875rem;line-height:1.5}.theme-selector{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.theme-btn{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--card-bg);border:2px solid var(--card-border);border-radius:.75rem;color:var(--text-primary);cursor:pointer;font-size:.95rem;transition:all .2s ease;text-align:left}.theme-btn:hover{border-color:var(--accent-color);background:var(--bg-secondary)}.theme-btn.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color);font-weight:600}.theme-icon{font-size:2rem;flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.theme-btn-label{font-weight:700;margin-bottom:.25rem;font-size:1rem}.theme-btn-desc{font-size:.8rem;opacity:.85}.color-selector{display:grid;grid-template-columns:repeat(auto-fill,minmax(52px,1fr));gap:1rem;max-width:100%}.color-btn{position:relative;width:52px;height:52px;border-radius:50%;border:3px solid var(--card-border);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;background:transparent;padding:0}.color-btn:hover{border-color:var(--accent-color);transform:scale(1.05)}.color-btn.active{border-color:var(--text-primary);border-width:4px;box-shadow:0 0 0 2px var(--accent-light)}.color-swatch{width:100%;height:100%;border-radius:50%;display:block}.color-check{position:absolute;color:#fff;font-size:1.25rem;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.3);z-index:1}.notification-options{display:flex;flex-direction:column;gap:2.5rem}.notification-category{display:flex;flex-direction:column;gap:1rem}.notification-category h3{margin:0 0 .75rem;color:var(--text-primary);font-size:1.25rem;font-weight:700;padding-bottom:1rem;border-bottom:2px solid var(--card-border)}.notification-item{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary));border-radius:1rem;transition:all .3s ease;border:2px solid var(--card-border)}.notification-item:hover{background:var(--bg-secondary);border-color:var(--accent-color);transform:translate(4px);box-shadow:0 4px 12px #007bff1a}.notification-info h4{margin:0 0 .5rem;color:var(--text-primary);font-size:1.05rem;font-weight:600}.notification-info p{margin:0;color:var(--text-secondary);font-size:.875rem;line-height:1.5}.toggle-switch{position:relative;display:inline-block;width:56px;height:30px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--bg-secondary);transition:.4s cubic-bezier(.4,0,.2,1);border-radius:30px;border:2px solid var(--card-border)}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:2px;bottom:2px;background-color:#fff;transition:.4s cubic-bezier(.4,0,.2,1);border-radius:50%;box-shadow:0 2px 6px #0003}.toggle-switch input:checked+.toggle-slider{background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));border-color:var(--accent-color)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(26px)}.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}@media(max-width:1024px){.settings-container{flex-direction:column}.settings-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border-color)}.settings-nav{flex-direction:row;overflow-x:auto;padding-bottom:.5rem;scrollbar-width:thin}.settings-nav-item{white-space:nowrap;min-width:fit-content;flex-direction:column;gap:.5rem;padding:.875rem 1rem}.nav-description{display:none!important}.nav-icon{font-size:1.25rem}}@media(max-width:768px){.settings-header h1{font-size:1.75rem}.header-content-wrapper{flex-direction:column;gap:1rem}.settings-content{padding:1.5rem}.form-row,.theme-selector{grid-template-columns:1fr}.color-selector{justify-content:center}.notification-item,.security-item{flex-direction:column;align-items:flex-start;gap:1rem}.security-btn{width:100%}.login-history-section{margin-top:3rem;padding-top:2.5rem;border-top:2px solid var(--card-border)}.history-section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2.5rem;gap:2rem}.login-history-section h3{margin:0 0 .5rem;color:var(--text-primary);font-size:1.5rem;font-weight:700}.history-subtitle{margin:0;color:var(--text-secondary);font-size:.9rem}.history-stats{display:flex;align-items:center;gap:1.25rem;padding:.875rem 1.5rem;background:var(--bg-tertiary);border-radius:.875rem;border:2px solid var(--card-border);flex-shrink:0}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;min-width:50px}.stat-value{font-size:1.5rem;font-weight:700;color:var(--accent-color);line-height:1}.stat-label{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.stat-divider{color:var(--card-border);font-weight:300;font-size:1.25rem;opacity:.5}.login-history-count{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.9rem}.loading-text{color:var(--text-secondary);font-style:italic}.history-count{font-weight:600;color:var(--accent-color)}.history-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;gap:1rem}.history-loading p{margin:0;color:var(--text-secondary);font-size:.9rem}.history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;gap:1rem}.empty-icon{font-size:3rem;opacity:.5}.empty-title{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.empty-hint{margin:0;font-size:.9rem;color:var(--text-secondary);max-width:400px}.history-list{display:flex;flex-direction:column;gap:1.5rem}.history-item{display:flex;gap:1.5rem;padding:1.75rem;background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary));border-radius:1rem;border:2px solid var(--card-border);transition:all .3s ease;position:relative;overflow:hidden}.history-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--card-border);transition:all .3s ease}.history-item:hover{border-color:var(--accent-color);box-shadow:0 4px 16px #007bff1a;transform:translateY(-2px)}.history-item:hover:before{background:var(--accent-color)}.history-item.current{border-color:var(--accent-color);background:linear-gradient(135deg,rgba(0,123,255,.08),var(--bg-secondary))}.history-item.current:before{background:var(--accent-color)}.history-item.expired{opacity:.75}.history-item.expired:before{background:#ef4444}.history-icon-wrapper{position:relative;flex-shrink:0}.history-icon{font-size:2.25rem;display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--bg-primary);border-radius:.875rem;border:2px solid var(--card-border);transition:all .3s ease}.history-item:hover .history-icon{border-color:var(--accent-color);transform:scale(1.05)}.history-status-indicator{position:absolute;top:-2px;right:-2px;width:12px;height:12px;border-radius:50%;border:2px solid var(--bg-primary)}.active-indicator{background:#10b981;box-shadow:0 0 0 3px #10b98133;animation:pulse-green 2s ease-in-out infinite}.expired-indicator{background:#ef4444;box-shadow:0 0 0 3px #ef444433}@keyframes pulse-green{0%,to{box-shadow:0 0 0 3px #10b98133}50%{box-shadow:0 0 0 6px #10b98100}}.history-details{flex:1;display:flex;flex-direction:column;gap:1.25rem;min-width:0}.history-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.25rem}.history-title-group{display:flex;align-items:center;gap:.875rem;flex-wrap:wrap}.history-device{font-weight:700;color:var(--text-primary);font-size:1.15rem;line-height:1.3}.current-badge-small,.expired-badge-small{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:.5rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.current-badge-small{background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3)}.badge-dot{width:6px;height:6px;border-radius:50%;background:#10b981;display:inline-block;animation:pulse-green 2s ease-in-out infinite}.expired-badge-small{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.history-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem;padding:1.25rem;background:var(--bg-primary);border-radius:.875rem;border:1px solid var(--card-border)}.history-info-item{display:flex;align-items:flex-start;gap:.875rem}.info-icon{font-size:1.35rem;flex-shrink:0;margin-top:.125rem;opacity:.8}.info-content{display:flex;flex-direction:column;gap:.375rem;min-width:0;flex:1}.info-label{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.info-value{font-size:.9rem;color:var(--text-primary);font-weight:500;word-break:break-word;line-height:1.4}.history-timeline{display:flex;flex-direction:column;gap:.875rem;padding:1.25rem;background:var(--bg-primary);border-radius:.875rem;border:1px solid var(--card-border)}.timeline-item{display:flex;align-items:flex-start;gap:.875rem}.timeline-icon{font-size:1.2rem;flex-shrink:0;margin-top:.125rem;opacity:.8}.timeline-content{display:flex;flex-direction:column;gap:.375rem;flex:1}.timeline-label{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.timeline-value{font-size:.9rem;color:var(--text-primary);font-weight:500;line-height:1.4}.history-footer{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--card-border);text-align:center}.history-more{margin:0;color:var(--text-secondary);font-size:.875rem;font-style:italic}.history-section-header{flex-direction:column;align-items:stretch;gap:1rem}.history-stats{justify-content:center}.history-item{flex-direction:column;padding:1.25rem}.history-item:before{width:100%;height:4px;inset:0 0 auto}.history-icon-wrapper{align-self:flex-start}.history-info-grid{grid-template-columns:1fr;gap:.75rem}.history-timeline{gap:.625rem}.section-header h2{font-size:1.5rem}}@media(max-width:480px){.settings-header h1{font-size:1.5rem}.section-header h2{font-size:1.375rem}.form-actions{flex-direction:column}.save-btn,.cancel-btn{width:100%;justify-content:center}.profile-picture{width:120px;height:120px}.profile-placeholder{font-size:3rem}}.registrations-page{width:100%;padding:1rem;box-sizing:border-box}.registrations-page__header{margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--card-border)}.registrations-page .ride-bill-toolbar.registrations-toolbar{align-items:center;flex-wrap:wrap;justify-content:space-between;gap:.75rem}.registrations-page .ride-bill-toolbar.registrations-toolbar .ride-bill-toolbar__search-wrap{flex:1 1 12rem;min-width:min(100%,10rem);max-width:min(100%,26rem)}.registrations-page .ride-bill-toolbar.registrations-toolbar .registrations-toolbar__status{flex:0 0 auto;margin-left:auto;justify-content:flex-end}.registrations-wrap{overflow-x:auto;border:1px solid var(--card-border);border-radius:.75rem;box-shadow:0 1px 3px var(--shadow);-webkit-overflow-scrolling:touch;background:var(--card-bg)}.registrations-wrap .edge-state{min-height:12rem}.registrations-pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0 0;margin-top:.25rem}.registrations-pagination__size{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.registrations-pagination__size label{white-space:nowrap}.registrations-pagination__size-select{min-width:4.5rem;padding:.5rem .65rem;font-size:.875rem}.registrations-pagination__nav{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:.5rem}.registrations-pagination .pagination-btn{padding:.5rem .75rem;border:1px solid var(--card-border);border-radius:.5rem;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;font-size:.875rem}.registrations-pagination .pagination-btn:disabled{opacity:.55;cursor:not-allowed}.registrations-pagination .pagination-btn.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.registrations-pagination .pagination-ellipsis{padding:.5rem .75rem;color:var(--text-secondary);-webkit-user-select:none;user-select:none}.registrations-table{width:100%;min-width:680px;border-collapse:collapse;table-layout:auto}.registrations-table thead tr{background:var(--bg-secondary)}.registrations-table thead th{font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;border-bottom:1px solid var(--card-border)}.registrations-table th,.registrations-table td{padding:.65rem .75rem;vertical-align:middle;text-align:left}.registrations-table td{border-top:1px solid var(--card-border);color:var(--text-primary);background:transparent}.registrations-table tbody tr:first-child td{border-top:none}.registrations-table tbody tr:nth-child(2n){background:color-mix(in srgb,var(--bg-tertiary) 35%,transparent)}:root[data-theme=dark] .registrations-table tbody tr:nth-child(2n){background:color-mix(in srgb,var(--bg-tertiary) 25%,transparent)}.registrations-table tbody tr{transition:background .2s}.registrations-table tbody tr:hover{background:color-mix(in srgb,var(--accent-color) 12%,var(--bg-tertiary))!important}:root[data-theme=dark] .registrations-table tbody tr:hover{background:color-mix(in srgb,var(--accent-color) 18%,var(--bg-secondary))!important}.registrations-status-badge{display:inline-block;font-size:.8rem;font-weight:600;line-height:1.2;padding:.2rem .55rem;border-radius:.375rem;text-transform:capitalize;white-space:nowrap}.registrations-status-badge--pending{background:#f973161f;color:#f97316}.registrations-status-badge--approved{background:#22c55e1f;color:#22c55e}.registrations-status-badge--rejected{background:#ef44441f;color:#dc2626}.registrations-status-badge--neutral{background:var(--bg-tertiary);color:var(--text-secondary)}.registrations-table .cell-email{word-break:break-word;overflow-wrap:anywhere;max-width:18rem}.registrations-table .cell-name{word-break:break-word;max-width:12rem}.registrations-table .cell-created{font-size:.85rem;color:var(--text-secondary);white-space:nowrap}.registrations-table .cell-actions{width:1%;white-space:nowrap;padding-left:.4rem;padding-right:.4rem}.registrations-table .cell-actions-inner{display:inline-flex;flex-wrap:nowrap;align-items:center;gap:.4rem}.registrations-table .cell-actions .btn-view{padding:.3rem .55rem;font-size:.8rem;line-height:1.2;white-space:nowrap;min-width:unset;background:#3b82f6;color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-weight:500}.registrations-table .cell-actions .btn-view:hover:not(:disabled){background:#2563eb}.registrations-table .cell-actions .btn-view:disabled{opacity:.7;cursor:wait}.registrations-table .cell-actions .select-review{min-width:6.5rem;max-width:8rem;padding:.3rem .4rem;font-size:.8rem;cursor:pointer}.registrations-review-modal__content{max-width:440px}.registrations-review-modal__title{font-size:1.15rem;margin:0}.registrations-review-modal__label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-primary)}.registrations-review-modal__label--spaced{margin-top:1rem}.registrations-review-modal__optional{font-weight:500;color:var(--text-secondary);font-size:.9em}.registrations-review-modal__datepicker-wrap{display:block;width:100%;max-width:16rem}.registrations-review-modal__datepicker-wrap .react-datepicker-wrapper{display:block;width:100%}.registrations-review-modal__hint{margin:.35rem 0 0;font-size:.85rem;color:var(--text-secondary);line-height:1.4}.registrations-review-modal__textarea{width:100%;box-sizing:border-box;padding:.65rem;border-radius:.5rem;border:1px solid var(--card-border);background:var(--bg-tertiary);color:var(--text-primary);resize:vertical;font:inherit}.registrations-review-modal__textarea:focus{outline:none;border-color:var(--accent-color)}.registrations-review-modal__footer{display:flex;gap:.5rem;justify-content:flex-end}.registrations-review-modal__submit{border:none;border-radius:.5rem;padding:.5rem 1rem;font-weight:600;cursor:pointer;background:var(--accent-color);color:#fff}.registrations-review-modal__submit:hover:not(:disabled){filter:brightness(1.05)}.registrations-review-modal__submit:disabled{opacity:.7;cursor:not-allowed}.registrations-review-modal__submit--reject{background:#dc2626}.registrations-review-modal__submit--reject:hover:not(:disabled){filter:brightness(1.08)}@media(min-width:1280px){.registrations-page{padding:1rem clamp(1rem,2.5vw,1.75rem)}}@media(max-width:768px){.registrations-page{padding:.75rem;padding-left:max(.75rem,env(safe-area-inset-left,0px));padding-right:max(.75rem,env(safe-area-inset-right,0px));padding-bottom:max(.75rem,env(safe-area-inset-bottom,0px))}.registrations-page__header{margin-bottom:1rem;padding-bottom:.75rem}}@media(max-width:640px){.registrations-toolbar__status{width:100%}.registrations-pagination{flex-direction:column;align-items:stretch}.registrations-pagination__nav{justify-content:center;flex-wrap:wrap}}@media(max-width:480px){.registrations-page{padding:.5rem;padding-left:max(.5rem,env(safe-area-inset-left,0px));padding-right:max(.5rem,env(safe-area-inset-right,0px))}.registrations-wrap{border-radius:.5rem}.registrations-table th,.registrations-table td{padding:.5rem .55rem}.registrations-table thead th{font-size:.75rem;letter-spacing:.02em}.registrations-pagination .pagination-btn{padding:.45rem .6rem;font-size:.8125rem}.registrations-pagination__size{font-size:.8125rem}}html{width:100%;height:100%}#root{width:100%;height:100%;min-height:100vh;display:block}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:100%;color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root,:root[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--text-primary: #111827;--text-secondary: #6b7280;--text-tertiary: #9ca3af;--border-color: #e5e7eb;--border-color-light: #f3f4f6;--accent-color: #6366f1;--accent-hover: #4f46e5;--accent-light: rgba(99, 102, 241, .1);--card-bg: #ffffff;--card-border: #e5e7eb;--shadow: rgba(0, 0, 0, .1);color:var(--text-primary);background-color:var(--bg-primary)}:root[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #020617;--bg-tertiary: #1e293b;--text-primary: #e5e7eb;--text-secondary: #cbd5f5;--text-tertiary: #9ca3af;--border-color: rgba(99, 102, 241, .2);--border-color-light: rgba(99, 102, 241, .1);--accent-color: #6366f1;--accent-hover: #818cf8;--accent-light: rgba(99, 102, 241, .1);--card-bg: rgba(15, 23, 42, .8);--card-border: rgba(99, 102, 241, .2);--shadow: rgba(0, 0, 0, .3);color:var(--text-primary);background-color:var(--bg-primary)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]):not([data-theme=dark]){--bg-primary: #0f172a;--bg-secondary: #020617;--bg-tertiary: #1e293b;--text-primary: #e5e7eb;--text-secondary: #cbd5f5;--text-tertiary: #9ca3af;--border-color: rgba(99, 102, 241, .2);--border-color-light: rgba(99, 102, 241, .1);--accent-color: #6366f1;--accent-hover: #818cf8;--accent-light: rgba(99, 102, 241, .1);--card-bg: rgba(15, 23, 42, .8);--card-border: rgba(99, 102, 241, .2);--shadow: rgba(0, 0, 0, .3);color:var(--text-primary);background-color:var(--bg-primary)}}a{font-weight:500;color:var(--accent-color);text-decoration:inherit}a:hover{color:var(--accent-hover)}body{margin:0;padding:0;width:100%;height:100%;min-width:320px;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}html,#root{background-color:var(--bg-primary);transition:background-color .3s ease}h1{font-size:3.2em;line-height:1.1;color:var(--text-primary)}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;transition:all .25s ease}button:hover{border-color:var(--accent-color);background-color:var(--accent-light)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}:root{--state-error-fg: #b91c1c;--state-error-bg: rgba(239, 68, 68, .1);--state-error-border: rgba(239, 68, 68, .35);--state-success-fg: #047857;--state-success-bg: rgba(16, 185, 129, .12);--state-success-border: rgba(16, 185, 129, .35);--state-info-fg: var(--accent-color);--state-info-bg: var(--accent-light);--state-info-border: rgba(99, 102, 241, .35);--state-warning-fg: #b45309;--state-warning-bg: rgba(245, 158, 11, .12);--state-warning-border: rgba(245, 158, 11, .4)}:root[data-theme=dark]{--state-error-fg: #fca5a5;--state-error-bg: rgba(239, 68, 68, .15);--state-error-border: rgba(239, 68, 68, .4);--state-success-fg: #6ee7b7;--state-success-bg: rgba(16, 185, 129, .15);--state-success-border: rgba(16, 185, 129, .4);--state-warning-fg: #fbbf24;--state-warning-bg: rgba(245, 158, 11, .12);--state-warning-border: rgba(251, 191, 36, .35)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]):not([data-theme=dark]){--state-error-fg: #fca5a5;--state-error-bg: rgba(239, 68, 68, .15);--state-error-border: rgba(239, 68, 68, .4);--state-success-fg: #6ee7b7;--state-success-bg: rgba(16, 185, 129, .15);--state-success-border: rgba(16, 185, 129, .4);--state-warning-fg: #fbbf24;--state-warning-bg: rgba(245, 158, 11, .12);--state-warning-border: rgba(251, 191, 36, .35)}}.edge-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem 1.5rem;min-height:140px;text-align:center;box-sizing:border-box}.edge-state--page{min-height:min(56vh,420px);width:100%}.edge-state__icon{width:3.5rem;height:3.5rem;display:flex;align-items:center;justify-content:center;margin-bottom:.25rem;font-size:2.75rem;line-height:1}.edge-state__message{margin:0;padding:0 .5rem;min-width:0;max-width:36rem;font-size:1rem;line-height:1.5;color:var(--text-secondary)}.edge-state--error .edge-state__message{color:var(--text-primary)}.edge-state--loading .edge-state__message{color:var(--text-secondary)}.edge-state--success .edge-state__message{color:var(--text-primary)}.edge-state__action,.edge-state__retry{padding:.65rem 1.35rem;border-radius:.75rem;border:1px solid var(--accent-color);background:var(--accent-light);color:var(--accent-color);font-size:.95rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s ease,border-color .2s ease,opacity .2s ease}.edge-state__action:hover:not(:disabled),.edge-state__retry:hover:not(:disabled){background:#6366f12e;border-color:var(--accent-hover)}.edge-state__action:disabled,.edge-state__retry:disabled{opacity:.5;cursor:not-allowed}.edge-state--success .edge-state__action{border-color:var(--state-success-border);background:var(--state-success-bg);color:var(--state-success-fg)}.edge-state--success .edge-state__action:hover:not(:disabled){background:#10b9811f;border-color:var(--state-success-fg)}.edge-spinner{width:40px;height:40px;border:3px solid var(--card-border);border-top-color:var(--accent-color);border-radius:50%;flex-shrink:0}@keyframes edge-spinner-rotate{to{transform:rotate(360deg)}}.edge-spinner--animated{animation:edge-spinner-rotate .85s linear infinite}@media(prefers-reduced-motion:reduce){.edge-spinner--animated{animation:none;border-top-color:var(--accent-color);opacity:.85}}.state-banner{display:flex;align-items:flex-start;flex-wrap:wrap;gap:.75rem 1rem;padding:.85rem 1rem;margin-bottom:1rem;border-radius:.65rem;border:1px solid transparent;font-size:.95rem;line-height:1.45}.state-banner__message{flex:1 1 12rem;margin:0;min-width:0}.state-banner__actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-left:auto}.state-banner__btn{padding:.4rem .85rem;border-radius:.5rem;border:1px solid currentColor;background:transparent;color:inherit;font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;opacity:.95}.state-banner__btn:hover{opacity:1}.state-banner--error{border-color:var(--state-error-border);background:var(--state-error-bg);color:var(--state-error-fg)}.state-banner--success{border-color:var(--state-success-border);background:var(--state-success-bg);color:var(--state-success-fg)}.state-banner--info{border-color:var(--state-info-border);background:var(--state-info-bg);color:var(--state-info-fg)}.state-banner--warning{border-color:var(--state-warning-border);background:var(--state-warning-bg);color:var(--state-warning-fg)}
