.ui-alert{align-items:flex-start;animation:alert-slide-in .3s ease;border-radius:10px;box-shadow:0 2px 12px #0000001a;display:flex;font-size:14px;font-weight:500;gap:10px;line-height:1.5;margin:8px 0;overflow:hidden;padding:13px 14px 18px;position:relative}.ui-alert--leaving{animation:alert-slide-out .3s ease forwards}.ui-alert--success{background:#f0fdf4;border-left:4px solid #22c55e;color:#15803d}.ui-alert--error{background:#fef2f2;border-left:4px solid #ef4444;color:#b91c1c}.ui-alert--warning{background:#fffbeb;border-left:4px solid #f59e0b;color:#92400e}.ui-alert--info{background:#eff6ff;border-left:4px solid #3b82f6;color:#1d4ed8}.ui-alert-icon{flex-shrink:0;font-size:16px;margin-top:1px}.ui-alert-content{flex:1 1;min-width:0}.ui-alert-title{font-size:14px;font-weight:700;margin:0 0 2px}.ui-alert-message{font-size:13.5px;margin:0;opacity:.92}.ui-alert-close{background:#0000;border:none;color:inherit;cursor:pointer;flex-shrink:0;font-size:15px;line-height:1;opacity:.5;padding:0 2px;transition:opacity .15s}.ui-alert-close:hover{opacity:1}.ui-alert-progress{background:#00000014;bottom:0;height:3px;left:0;position:absolute;right:0}.ui-alert-progress-bar{height:100%;transition:width 50ms linear}.ui-alert--success .ui-alert-progress-bar{background:#22c55e}.ui-alert--error .ui-alert-progress-bar{background:#ef4444}.ui-alert--warning .ui-alert-progress-bar{background:#f59e0b}.ui-alert--info .ui-alert-progress-bar{background:#3b82f6}@keyframes alert-slide-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes alert-slide-out{0%{max-height:120px;opacity:1;transform:translateY(0)}to{margin:0;max-height:0;opacity:0;padding:0;transform:translateY(-8px)}}.ui-avatar{background-color:#eee;border:2px solid #f0f0f0;border-radius:8px;display:inline-block;object-fit:cover}.ui-avatar.rounded{border-radius:50%}.ui-badge{border-radius:8px;color:#fff;display:inline-block;font-size:12px;font-weight:600;padding:4px 10px}.ui-badge.default{background:#6c757d}.ui-badge.success{background:#28a745}.ui-badge.warning{background:#ffc107;color:#333}.ui-badge.error{background:#dc3545}.ui-badge.info{background:#17a2b8}.ui-breadcrumb{font-size:14px}.breadcrumb-item,.ui-breadcrumb{align-items:center;display:flex}.breadcrumb-item a{color:#007bff;text-decoration:none}.breadcrumb-item a:hover{text-decoration:underline}.breadcrumb-item .active{color:#555;font-weight:600}.separator{color:#666;margin:0 8px}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:15px;font-weight:700;gap:8px;justify-content:center;letter-spacing:.025em;line-height:1.4;min-height:44px;padding:12px 24px;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease,opacity .15s;white-space:nowrap}.btn:focus-visible{outline:3px solid #4f46e5;outline-offset:2px}.btn:disabled{box-shadow:none!important;cursor:not-allowed;opacity:.5;transform:none!important}.btn-full,.w-full{justify-content:center;width:100%}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 14px #667eea61;color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 8px 20px #667eea7a;transform:translateY(-2px)}.btn-primary:active:not(:disabled){box-shadow:0 3px 8px #667eea4d;transform:translateY(0)}.btn-success{background:linear-gradient(135deg,#1a8a4a,#27ae60);box-shadow:0 4px 14px #1a8a4a52;color:#fff}.btn-success:hover:not(:disabled){box-shadow:0 8px 20px #1a8a4a6b;transform:translateY(-2px)}.btn-danger{background:linear-gradient(135deg,#c0392b,#e74c3c);box-shadow:0 4px 14px #c0392b52;color:#fff}.btn-danger:hover:not(:disabled){box-shadow:0 8px 20px #c0392b6b;transform:translateY(-2px)}.btn-secondary{background:#f0f4fa;border:1px solid #d0d8e8;box-shadow:0 2px 6px #0000001a;color:#2c3e50}.btn-secondary:hover:not(:disabled){background:#dde6f5;box-shadow:0 4px 10px #0000001f;transform:translateY(-1px)}.btn-outline{background:#0000;border:2px solid #667eea;color:#667eea}.btn-outline:hover:not(:disabled){background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;box-shadow:0 6px 16px #667eea59;color:#fff;transform:translateY(-2px)}.btn-ghost{background:#0000;box-shadow:none;color:#667eea}.btn-ghost:hover:not(:disabled){background:#667eea1a;transform:translateY(-1px)}.btn-icon{align-items:center;display:flex;font-size:17px}.btn-sm{border-radius:6px;font-size:13px;padding:7px 14px}.btn-lg{border-radius:10px;font-size:16px;padding:14px 30px}.calendar-container{display:flex;flex-direction:column;gap:8px;width:100%}.calendar-label{align-items:center;color:#374151;display:flex;font-size:.875rem;font-weight:600;gap:2px}.calendar-label .required-star{color:#e53e3e;font-weight:700}.calendar-input{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#1f2937;font-size:.9375rem;height:2.875rem;outline:none;padding:.625rem .875rem;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.calendar-input:focus{background:#fafcff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626;outline:none}.calendar-input-error{background-color:#fdf2f2;border-color:#e74c3c}.calendar-input-valid{background-color:#f0fdf4;border-color:#22c55e}.calendar-hint{align-items:center;color:#666;display:flex;font-size:12px;justify-content:space-between}.calendar-preview{color:#2c5aa0;font-weight:500}.calendar-error{align-items:center;background:#fef2f2;border-left:3px solid #ef4444;border-radius:6px;color:#dc2626;display:flex;font-size:.8125rem;font-weight:500;gap:5px;margin-top:2px;padding:4px 8px}@media (max-width:768px){.calendar-hint{align-items:flex-start;flex-direction:column;gap:2px}}.ui-card{background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;margin-bottom:20px;padding:16px;transition:.2s ease}.ui-card:hover{box-shadow:0 4px 12px #0000001f}.ui-card-header{font-size:18px;font-weight:600;margin-bottom:14px}.ui-card-body{color:#333;font-size:14px}.ui-card-footer{border-top:1px solid #eee;color:#666;font-size:13px;margin-top:14px;padding-top:10px}.divider{align-items:center;display:flex;margin:16px 0}.divider:after,.divider:before{border-bottom:1px solid #ddd;content:"";flex:1 1}.divider-text{color:#666;font-size:14px;padding:0 10px}.error-msg{background:#fdecea;border-left:4px solid #d32f2f;border-radius:4px;color:#a32121;font-size:14px;margin-top:6px;padding:10px}.form-group{margin-bottom:14px}.form-label{color:#333;font-size:14px;font-weight:600;margin-bottom:4px}.grid{grid-gap:16px;display:grid;gap:16px;width:100%}.hourpicker-container{display:flex;flex-direction:column;gap:4px}.hourpicker-label{color:#333;font-size:14px;font-weight:500}.hourpicker-input{border:1px solid #cfcfcf;border-radius:6px;font-size:15px;padding:10px}.hourpicker-input:focus{border-color:#1976d2;box-shadow:0 0 0 2px #1976d233}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:1.1rem;width:100%}.form-group label{color:#374151;font-size:.875rem;font-weight:600;line-height:1.4}.required,.required-star{color:#e53e3e;font-weight:700;margin-left:2px}.input-wrapper{align-items:center;display:flex;position:relative}.input-wrapper--password .form-input{padding-right:2.75rem}.form-input{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#1f2937;font-family:inherit;font-size:.9375rem;height:3rem;outline:none;padding:.625rem .875rem;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;width:100%}.form-input::placeholder{color:#9ca3af;font-size:.875rem}.form-input:focus{background:#fafcff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.form-input.error{background:#fff5f5;border-color:#ef4444}.form-input.error:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26262e}.form-input.valid{background:#f0fdf4;border-color:#16a34a}.form-input.valid:focus{border-color:#15803d;box-shadow:0 0 0 3px #16a34a26}.form-input.disabled,.form-input:disabled{background:#f3f4f6;border-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}.password-toggle{align-items:center;background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:4px;position:absolute;right:.75rem;top:50%;transform:translateY(-50%);transition:color .15s ease;z-index:1}.password-toggle:hover{color:#374151}.password-toggle:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.password-toggle svg{flex-shrink:0;height:18px;width:18px}.password-strength{align-items:center;display:flex;gap:10px;margin-top:-2px}.strength-bar{display:flex;flex:1 1;gap:4px}.strength-segment{background:#e5e7eb;border-radius:2px;flex:1 1;height:4px;transition:background .25s ease}.strength-very-weak{background:#ef4444}.strength-weak{background:#f97316}.strength-medium{background:#eab308}.strength-strong{background:#22c55e}.strength-very-strong{background:#16a34a}.strength-label{font-size:.75rem;font-weight:600;min-width:70px;text-align:right;white-space:nowrap}.error-message{align-items:center;animation:fadeInError .2s ease;background:#fef2f2;border-left:3px solid #ef4444;border-radius:6px;color:#dc2626;display:flex;font-size:.8125rem;font-weight:500;gap:5px;padding:4px 8px}.error-message:before{content:"\26A0";flex-shrink:0;font-size:.75rem}.help-text{color:#6b7280;font-size:.8rem;line-height:1.4}@keyframes fadeInError{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.loader-wrapper{align-items:center;display:flex;flex-direction:column;gap:.75rem;justify-content:center;padding:2rem}.loader{animation:spin .9s linear infinite;border:4px solid #0000001a;border-radius:50%;border-top-color:#007bff;flex-shrink:0}.loader-text{color:#6c757d;font-size:.9rem;margin:0;text-align:center}@keyframes spin{to{transform:rotate(1turn)}}.modal-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;overflow:hidden;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-box{animation:modalAppear .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;max-width:500px;position:relative;width:100%}.modal-box-compact{display:flex;flex-direction:column;max-height:90vh;overflow:hidden}.modal-title{color:#2c3e50;font-size:1.5rem;font-weight:600;margin:0;padding:20px 20px 0;text-align:center}.modal-content{padding:20px}.modal-content-scrollable{flex:1 1;max-height:calc(90vh - 80px);overflow-y:auto;padding:15px 20px}.modal-close-x{align-items:center;background:#0000;border:none;border-radius:50%;color:#6c757d;cursor:pointer;display:flex;font-size:1.5rem;height:30px;justify-content:center;position:absolute;right:15px;top:15px;transition:all .3s ease;width:30px;z-index:10}.modal-close-x:hover{background:#f8f9fa;color:#dc3545;transform:scale(1.1)}@keyframes modalAppear{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-content-scrollable::-webkit-scrollbar{width:6px}.modal-content-scrollable::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.modal-content-scrollable::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.modal-content-scrollable::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (max-width:768px){.modal-overlay{align-items:flex-end;padding:15px 15px max(15px,env(safe-area-inset-bottom))}.modal-box{border-radius:12px 12px 0 0;max-height:min(85vh,85dvh);max-width:100%}.modal-box-compact{max-height:min(80vh,80dvh)}.modal-content-scrollable{max-height:calc(min(80vh, 80dvh) - 70px);padding:10px 15px}.modal-title{font-size:1.3rem;padding:15px 15px 0}}@media (max-width:480px){.modal-overlay{padding:10px}.modal-box{border-radius:8px 8px 0 0}.modal-content{padding:15px}.modal-content-scrollable{padding:8px 12px}}.navbar{background:#022a50;padding:1rem 1.5rem;position:relative;z-index:20}.nav-container{align-items:center;display:flex;justify-content:space-between}.nav-logo{color:#fff;font-size:1.6rem;font-weight:700;text-decoration:none}.nav-menu{display:flex;gap:2rem}.nav-menu a{color:#fff;font-size:1.1rem;text-decoration:none}.nav-toggle{background:none;border:none;color:#fff;font-size:2rem}@media (max-width:768px){.nav-toggle{display:block;z-index:30}.nav-menu{background:#022a50;flex-direction:column;gap:2rem;height:100vh;padding:4rem 2rem;position:fixed;right:-100%;top:0;transition:right .4s ease;width:75%;z-index:25}.nav-menu.open{right:0}.nav-menu a{font-size:1.5rem;text-align:left}}.cta-card-centered,.hero-content{align-items:center;display:flex;flex-direction:column;justify-content:center}.admin-topbar{align-items:center;background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 4px #0000000f;display:flex;height:60px;justify-content:space-between;padding:.75rem 1.5rem;position:-webkit-sticky;position:sticky;top:0;z-index:10}.admin-topbar-left{align-items:center;display:flex;gap:1rem}.admin-topbar-title{color:#1a202c;font-size:1.1rem;font-weight:600;margin:0}.admin-topbar-right{align-items:center;display:flex;gap:1rem}.admin-topbar-refresh{background:#0000;border:1px solid #e2e8f0;border-radius:6px;color:#4a5568;cursor:pointer;font-size:.85rem;padding:.4rem .9rem;transition:background .15s}.admin-topbar-refresh:hover{background:#f7fafc;color:#2c5aa0}.admin-topbar-user{align-items:center;display:flex;gap:.6rem}.admin-topbar-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:.95rem;font-weight:700;height:34px;justify-content:center;width:34px}.admin-topbar-info{display:flex;flex-direction:column;line-height:1.2}.admin-topbar-name{color:#2d3748;font-size:.875rem;font-weight:600}.admin-topbar-role{color:#718096;font-size:.75rem}.admin-topbar-logout{align-items:center;background:#fff1f0;border:1px solid #fca5a5;border-radius:6px;color:#dc2626;cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:6px;min-height:36px;padding:7px 14px;transition:background .2s,border-color .2s;white-space:nowrap}.admin-topbar-logout:hover{background:#fee2e2;border-color:#dc2626}.admin-topbar-hamburger{background:none;border:none;border-radius:6px;color:#374151;cursor:pointer;display:none;font-size:1.4rem;line-height:1;padding:4px 6px;transition:background .15s}.admin-topbar-hamburger:hover{background:#f3f4f6}@media (max-width:768px){.admin-topbar-hamburger{align-items:center;display:inline-flex;justify-content:center}.admin-topbar-info{display:none}.admin-topbar-right{gap:6px}.admin-topbar-refresh{display:none}}.pagination{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin:30px 0}.pagination-btn{background:#fff;border:2px solid #2e86ab;border-radius:8px;color:#2e86ab;cursor:pointer;font-weight:600;min-width:120px;padding:10px 20px;transition:all .3s ease}.pagination-btn:hover:not(.disabled){background:#2e86ab;color:#fff;transform:translateY(-2px)}.pagination-btn.disabled{border-color:#6c757d;color:#6c757d;cursor:not-allowed;opacity:.5}.page-info{align-items:center;display:flex;gap:10px}.page-text{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;color:#2e86ab;font-size:1.1rem;font-weight:600;padding:8px 16px}.page-numbers{display:flex;gap:5px}.page-number{background:#fff;border:1px solid #dee2e6;border-radius:6px;color:#495057;cursor:pointer;min-width:40px;padding:8px 12px;transition:all .3s ease}.page-number:hover{border-color:#2e86ab;color:#2e86ab}.page-number.active{background:#2e86ab;border-color:#2e86ab;color:#fff}@media (max-width:768px){.pagination{flex-direction:column;gap:10px}.page-numbers{order:-1}.pagination-btn{min-width:140px}}.searchbar{margin-bottom:10px;width:100%}.searchbar-input{border:1px solid #bbb;border-radius:6px;font-size:15px;padding:10px;width:100%}.form-select{-webkit-appearance:none;appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%236b7280' d='M6 8 1 3h10z'/%3E%3C/svg%3E");background-position:right .875rem center;background-repeat:no-repeat;border:1.5px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#1f2937;cursor:pointer;font-size:.9375rem;height:2.875rem;outline:none;padding:.625rem 2.25rem .625rem .875rem;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.form-select:focus{background-color:#fafcff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.form-select.error{background-color:#fff5f5;border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-select.disabled,.form-select:disabled{background-color:#f3f4f6;border-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}.form-select option[value=""]{color:#9ca3af}.switch{height:22px;position:relative;width:45px}.switch input{display:none}.slider{background:#ccc;border-radius:22px;cursor:pointer;height:100%;width:100%}.slider,.slider:before{position:absolute;transition:.3s}.slider:before{background:#fff;border-radius:50%;content:"";height:18px;left:2px;top:2px;width:18px}input:checked+.slider{background:#1976d2}input:checked+.slider:before{transform:translateX(22px)}.table-responsive{-webkit-overflow-scrolling:touch;overflow-x:auto;width:100%}.table{border-collapse:collapse;min-width:480px;width:100%}.table th{background:#1976d2;color:#fff;padding:10px;white-space:nowrap}.table td{border-bottom:1px solid #ddd;padding:10px}.table tr:hover td{background:#f5f5f5}.table-empty{color:#6c757d;font-style:italic;padding:2rem;text-align:center}@media (max-width:768px){.table td,.table th{font-size:.82rem;padding:8px 6px}}.tabs{display:flex;gap:10px;margin-bottom:15px}.tab-btn{background:#eee;border:none;border-radius:6px;cursor:pointer;padding:10px 18px}.tab-btn.active{background:#1976d2;color:#fff}.toast{align-items:center;animation:toastIn .3s cubic-bezier(.4,0,.2,1);border-radius:10px;bottom:1.5rem;box-shadow:0 6px 20px #0000002e;color:#fff;display:flex;font-size:.9rem;font-weight:500;gap:.6rem;line-height:1.4;max-width:360px;padding:.85rem 1.25rem;position:fixed;right:1.5rem;z-index:10000}.toast-success{background:linear-gradient(135deg,#1db954,#17a347)}.toast-error{background:linear-gradient(135deg,#e53e3e,#c62828)}.toast-warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#1a1a1a}.toast-info{background:linear-gradient(135deg,#667eea,#764ba2)}@keyframes toastIn{0%{opacity:0;transform:translateX(20px) scale(.95)}to{opacity:1;transform:translateX(0) scale(1)}}.tooltip-wrapper{display:inline-block;position:relative}.tooltip-text{background:#333;border-radius:6px;bottom:125%;color:#fff;font-size:13px;left:50%;padding:6px 10px;position:absolute;transform:translateX(-50%);visibility:hidden;white-space:nowrap}.tooltip-wrapper:hover .tooltip-text{visibility:visible}.textarea-group{display:flex;flex-direction:column;margin-bottom:15px}.textarea-label{color:#333;font-size:14px;font-weight:600;margin-bottom:6px}.textarea-control{border:1px solid #ccc;border-radius:6px;font-family:inherit;font-size:14px;min-height:110px;padding:12px;resize:vertical;transition:all .2s ease-in-out;width:100%}.textarea-control:focus{border-color:#3b82f6;box-shadow:0 0 4px #3b82f666;outline:none}.textarea-error{color:#e11d48;font-size:13px;margin-top:4px}.checkbox-wrapper{display:flex;flex-direction:column;gap:6px}.checkbox-wrapper--error .checkbox-container{background:#fff5f5;border:1.5px solid #ef4444;border-radius:8px;padding:8px 10px}.checkbox-container{align-items:flex-start;border-radius:8px;cursor:pointer;display:flex;gap:10px;padding:4px 0;transition:background .15s ease;-webkit-user-select:none;user-select:none}.checkbox-container:hover:not(.checkbox-container--disabled){background:#3b82f60a}.checkbox-container--disabled{cursor:not-allowed;opacity:.6}.checkbox-container input[type=checkbox]{height:0;opacity:0;position:absolute;width:0}.checkbox-custom{background:#fff;border:2px solid #d1d5db;border-radius:5px;flex-shrink:0;height:20px;margin-top:1px;position:relative;transition:all .2s ease;width:20px}.checkbox-container input[type=checkbox]:checked+.checkbox-custom{background:#3b82f6;border-color:#3b82f6}.checkbox-container input[type=checkbox]:checked+.checkbox-custom:after{border:solid #fff;border-width:0 2px 2px 0;content:"";height:10px;left:6px;position:absolute;top:2px;transform:rotate(45deg);width:5px}.checkbox-container input[type=checkbox]:focus-visible+.checkbox-custom{box-shadow:0 0 0 3px #3b82f64d}.checkbox-label{color:#374151;font-size:.9375rem;line-height:1.5}.checkbox-label .link{color:#3b82f6;font-weight:500;text-decoration:underline}.checkbox-label .link:hover{color:#2563eb}.checkbox-label .required-star{color:#e53e3e;font-weight:700}.checkbox-error{align-items:center;animation:fadeInCheckboxError .2s ease;background:#fef2f2;border-left:3px solid #ef4444;border-radius:6px;color:#dc2626;display:flex;font-size:.8125rem;font-weight:500;gap:5px;padding:4px 8px}.checkbox-error:before{content:"\26A0";flex-shrink:0;font-size:.75rem}@keyframes fadeInCheckboxError{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.form-field{display:flex;flex-direction:column;margin-bottom:16px}.form-field-label{color:#333;font-size:14px;font-weight:600;margin-bottom:6px}.form-field-error{color:#e11d48;font-size:13px;margin-top:4px}.radio-group{display:flex;flex-direction:column;gap:12px}.radio-group.inline{flex-direction:row;flex-wrap:wrap;gap:24px;justify-content:center}.radio-option{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:10px;padding:8px 12px;transition:background-color .2s ease}.radio-option:hover{background-color:#f8f9fa}.radio-option input[type=radio]{display:none}.radio-checkmark{border:2px solid #dee2e6;border-radius:50%;display:inline-block;height:20px;position:relative;transition:all .2s ease;width:20px}.radio-option input[type=radio]:checked+.radio-checkmark{background-color:#007bff;border-color:#007bff}.radio-option input[type=radio]:checked+.radio-checkmark:after{background:#fff;border-radius:50%;content:"";height:8px;left:4px;position:absolute;top:4px;width:8px}.radio-text{color:#495057;font-size:14px;font-weight:500}.radio-label{color:#343a40;display:block;font-size:16px;font-weight:600;margin-bottom:12px;text-align:center}.ss-wrapper{flex-direction:column;font-family:inherit;gap:4px;margin:0 auto;max-width:320px;-webkit-user-select:none;user-select:none}.ss-bus-front,.ss-wrapper{align-items:center;display:flex}.ss-bus-front{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px 16px 4px 4px;color:#fff;justify-content:space-between;padding:10px 16px;width:100%}.ss-driver-block{align-items:center;display:flex;flex-direction:column;gap:2px}.ss-driver-icon{font-size:1.4rem}.ss-driver-label{font-size:.6rem;opacity:.7}.ss-driver-label,.ss-front-door{letter-spacing:.05em;text-transform:uppercase}.ss-front-door{border:1px solid #ffffff4d;border-radius:4px;font-size:.65rem;opacity:.6;padding:2px 6px}.ss-col-headers{align-items:center;display:flex;gap:0;padding:0 4px;width:100%}.ss-row-num-spacer{flex-shrink:0;width:24px}.ss-col-label{color:#888;font-size:.7rem;font-weight:600;letter-spacing:.05em;text-align:center;text-transform:uppercase;width:44px}.ss-aisle-spacer{flex-shrink:0;width:20px}.ss-bus-body{background:#f8f9fa;border:2px solid #dee2e6;border-radius:4px;display:flex;flex-direction:column;gap:4px;padding:8px 4px;width:100%}.ss-row{align-items:center;display:flex;gap:0}.ss-row-num{color:#aaa;flex-shrink:0;font-size:.65rem;padding-right:4px;text-align:right;width:24px}.ss-row-left,.ss-row-right{display:flex;gap:3px}.ss-aisle{flex-shrink:0;width:20px}.ss-seat{align-items:center;border:2px solid #0000;border-radius:6px 6px 4px 4px;cursor:pointer;display:flex;font-size:.65rem;font-weight:600;height:36px;justify-content:center;position:relative;transition:all .15s ease;width:40px}.ss-seat:before{background:inherit;border-radius:3px 3px 0 0;content:"";filter:brightness(.85);height:4px;left:4px;position:absolute;right:4px;top:-4px}.ss-seat--available{background:#d4edda;border-color:#28a745;color:#155724}.ss-seat--available:hover{background:#28a745;box-shadow:0 3px 8px #28a74559;color:#fff;transform:translateY(-1px)}.ss-seat--occupied{background:#f8d7da;border-color:#dc3545;color:#721c24;cursor:not-allowed;opacity:.75}.ss-seat--selected{background:#007bff;border-color:#0056b3;box-shadow:0 3px 10px #007bff66;color:#fff;transform:translateY(-1px)}.ss-bus-back{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:4px 4px 12px 12px;display:flex;justify-content:center;padding:6px;width:100%}.ss-back-door{border:1px solid #ffffff40;border-radius:4px;color:#ffffff80;font-size:.6rem;letter-spacing:.05em;padding:2px 8px;text-transform:uppercase}.ss-footer{align-items:center;gap:8px;justify-content:space-between;margin-top:4px;width:100%}.ss-footer,.ss-legend{display:flex;flex-wrap:wrap}.ss-legend{gap:12px}.ss-legend-item{align-items:center;color:#555;display:flex;font-size:.7rem;gap:5px}.ss-legend-dot{border:1.5px solid #0000;border-radius:3px;height:12px;width:12px}.ss-legend-dot--available{background:#d4edda;border-color:#28a745}.ss-legend-dot--occupied{background:#f8d7da;border-color:#dc3545}.ss-legend-dot--selected{background:#007bff;border-color:#0056b3}.ss-stats{color:#666;font-size:.72rem;font-weight:500}.ss-selected-info{background:#e8f4fd;border:1px solid #bee3f8;border-radius:8px;color:#2b6cb0;font-size:.85rem;padding:8px 12px;text-align:center;width:100%}.ss-empty,.ss-loading{color:#888;font-size:.9rem;padding:24px;text-align:center}@media (max-width:400px){.ss-seat{font-size:.6rem;height:30px;width:34px}.ss-col-label{width:37px}}.admin-sidebar{background:#2c3e50;box-shadow:2px 0 5px #0000001a;color:#fff;height:100vh;left:0;position:fixed;top:0;transition:width .3s ease;z-index:1000}.admin-sidebar.open{width:250px}.admin-sidebar.closed{width:60px}.sidebar-toggle{align-items:center;background:#34495e;border-radius:50%;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;display:flex;font-size:12px;height:24px;justify-content:center;position:absolute;right:-12px;top:20px;width:24px;z-index:1001}.sidebar-toggle:hover{background:#3498db}.sidebar-content{display:flex;flex-direction:column;height:100%;overflow:hidden}.sidebar-header{border-bottom:1px solid #34495e;padding:20px 15px}.sidebar-logo h3{color:#ecf0f1;font-size:16px;font-weight:600;margin:0}.sidebar-nav{flex:1 1;overflow-y:auto;padding:20px 0}.nav-item{align-items:center;border-left:3px solid #0000;cursor:pointer;display:flex;min-width:0;overflow:hidden;padding:12px 15px;transition:all .3s ease}.nav-item:hover{background:#34495e}.nav-item.active{background:#3498db;border-left-color:#2980b9}.nav-icon{font-size:18px;min-width:30px;text-align:center}.nav-label{flex:1 1;font-size:14px;font-weight:500;margin-left:10px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-footer{background:#34495e;border-top:1px solid #34495e;display:flex;flex-direction:column;gap:10px;padding:15px}.sidebar-logout-btn{align-items:center;background:#e74c3c26;border:1px solid #e74c3c66;border-radius:6px;color:#e74c3c;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:8px;justify-content:center;min-height:36px;padding:8px;transition:background .2s,border-color .2s;width:100%}.sidebar-logout-btn:hover{background:#e74c3c4d;border-color:#e74c3c}.sidebar-logout-btn .logout-icon{flex-shrink:0;font-size:16px}.user-info{gap:10px}.user-avatar,.user-info{align-items:center;display:flex}.user-avatar{background:#3498db;border-radius:50%;font-size:16px;height:40px;justify-content:center;width:40px}.user-details{flex:1 1}.user-name{color:#ecf0f1;font-size:14px;font-weight:600}.user-role{color:#bdc3c7;font-size:12px}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:#34495e}.sidebar-nav::-webkit-scrollbar-thumb{background:#3498db;border-radius:2px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#2980b9}@media (max-width:768px){.admin-sidebar{transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1),width .3s ease}.admin-sidebar.open{transform:translateX(0);width:260px;z-index:1200}.admin-sidebar.closed{transform:translateX(-100%);width:260px}.sidebar-toggle{display:none}}.city-input{position:relative}.city-input__field{align-items:center;display:flex;position:relative}.city-input__field .form-input{box-sizing:border-box;min-width:0;padding-right:28px;width:100%}.city-input__clear{align-items:center;background:none;border:none;color:#9ca3af;cursor:pointer;display:flex;font-size:1.1rem;line-height:1;padding:0;position:absolute;right:8px;transition:color .1s}.city-input__clear:hover{color:#374151}.city-input__suggestions{background:#fff;border:1px solid #d1d5db;border-radius:10px;box-shadow:0 8px 24px #0000001f;left:0;list-style:none;margin:0;overflow:hidden;padding:4px 0;position:absolute;right:0;top:calc(100% + 3px);z-index:200}.city-input__option{align-items:center;border-bottom:1px solid #f3f4f6;color:#374151;cursor:pointer;display:flex;font-size:.9rem;gap:8px;padding:9px 14px;transition:background .1s}.city-input__option:last-child{border-bottom:none}.city-input__option:hover{background:#eef2ff;color:#667eea;font-weight:600}.city-input__pin{font-size:.85rem}.header{background:#00264d;box-shadow:0 2px 16px #0000002e;color:#fff;padding:0;position:-webkit-sticky;position:sticky;top:0;width:100%;z-index:9999}.header-container{gap:0;height:64px;margin:0 auto;max-width:1300px;padding:0 24px;position:relative}.header-container,.logo{align-items:center;display:flex}.logo{flex-shrink:0;gap:8px;margin-right:auto;text-decoration:none}.logo-icon{font-size:1.4rem;line-height:1}.logo-text{color:#fff;font-size:1.4rem;font-weight:800;letter-spacing:-.02em}.nav-links{align-items:center;display:flex;gap:4px}.nav-link{border-radius:6px;color:#ffffffd9;font-size:.9375rem;font-weight:500;padding:6px 12px;text-decoration:none;transition:color .15s ease,background .15s ease;white-space:nowrap}.nav-link:hover{background:#ffffff1a;color:#fff}.nav-link.active{background:#ffffff26;color:#fff;font-weight:600}.nav-divider{background:#fff3;flex-shrink:0;height:24px;margin:0 8px;width:1px}.nav-link--profile{gap:8px}.nav-cart,.nav-link--profile{align-items:center;display:flex}.nav-cart{font-size:1.25rem;padding:4px 8px!important;position:relative}.cart-badge{background:#e53e3e;border:1.5px solid #00264d;border-radius:50%;color:#fff;font-size:.65rem;height:18px;line-height:1;position:absolute;right:-4px;top:-4px;width:18px}.avatar-initials,.cart-badge{align-items:center;display:flex;font-weight:700;justify-content:center}.avatar-initials{background:#fff3;border:1.5px solid #ffffff80;border-radius:50%;flex-shrink:0;font-size:.75rem;height:28px;width:28px}.nav-link[href="/travels"],a.nav-link[href="/travels"]{color:#fff;font-weight:600}.nav-link[href="/travels"].active{background:#ffffff2e;color:#fff}.nav-btn{align-items:center;border-radius:50px;cursor:pointer;display:inline-flex;font-size:.88rem;font-weight:700;padding:7px 18px;text-decoration:none;transition:all .15s ease;white-space:nowrap}.nav-btn--login{background:#0000;border:1.5px solid #ffffff80;color:#ffffffeb}.nav-btn--login.active,.nav-btn--login:hover{background:#ffffff1f;border-color:#fff;color:#fff}.nav-btn--signup{background:#fff;border:none;box-shadow:0 2px 10px #0000002e;color:#00264d}.nav-btn--signup.active,.nav-btn--signup:hover{background:#e0eaff;box-shadow:0 4px 14px #0003;transform:translateY(-1px)}.nav-btn--logout{background:#0000;border:1.5px solid #ffffff40;color:#fffc;font-weight:600}.nav-btn--logout:hover{background:#ffffff14;border-color:#ffffff8c;color:#fff}.nav-toggle{display:none}.nav-toggle-label{border-radius:6px;cursor:pointer;display:none;flex-direction:column;flex-shrink:0;height:40px;justify-content:center;transition:background .15s ease;width:40px;z-index:10001}.nav-toggle-label:hover{background:#ffffff1a}.nav-toggle-label span,.nav-toggle-label span:after,.nav-toggle-label span:before{background:#fff;border-radius:2px;display:block;height:2.5px;margin:0 auto;position:relative;transition:all .3s ease;width:22px}.nav-toggle-label span:after,.nav-toggle-label span:before{content:"";left:0;position:absolute}.nav-toggle-label span:before{top:-7px}.nav-toggle-label span:after{top:7px}.nav-toggle:checked+.nav-toggle-label span{background:#0000}.nav-toggle:checked+.nav-toggle-label span:before{top:0;transform:rotate(45deg)}.nav-toggle:checked+.nav-toggle-label span:after{top:0;transform:rotate(-45deg)}.nav-overlay{background:#00000073;cursor:pointer;display:none;inset:0;opacity:0;pointer-events:none;position:fixed;transition:opacity .3s ease;z-index:9997}@media (max-width:900px){.nav-toggle-label{display:flex;order:3}.nav-overlay{display:block}.nav-toggle:checked~.nav-overlay{opacity:1;pointer-events:all}.nav-links{align-items:stretch;background:#00264d;box-shadow:-4px 0 24px #0000004d;flex-direction:column;gap:4px;height:100dvh;overflow-y:auto;padding:80px 20px 32px;position:fixed;right:-100%;top:0;transition:right .35s cubic-bezier(.4,0,.2,1);width:min(300px,80vw);z-index:9999}.nav-toggle:checked+.nav-toggle-label+.nav-overlay+.nav-links{right:0}.nav-link{border-radius:8px;font-size:1rem;padding:12px 16px}.nav-divider{height:1px;margin:8px 0;width:100%}.nav-btn--login,.nav-btn--logout,.nav-btn--signup{border-radius:8px;font-size:1rem;padding:12px 16px;text-align:center;width:100%}.nav-link--profile{padding:12px 16px}}@media (max-width:480px){.header-container{padding:0 16px}.logo-text{font-size:1.2rem}}.footer{background:#263648;color:#fff;font-family:Inter,sans-serif;margin-top:60px;padding:40px 0 25px}.footer-container{margin:auto;max-width:1200px;padding:0 25px}.footer-grid{grid-gap:35px;display:grid;gap:35px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.footer-brand h3{font-size:20px;font-weight:700;margin-bottom:4px}.footer-brand span{font-size:13px;opacity:.85}.footer-desc{font-size:13px;line-height:1.5;margin:10px 0 18px;opacity:.85}.footer-subtitle{color:#fff;font-size:15px;font-weight:600;margin-bottom:12px;text-transform:uppercase}.footer-link{color:#dce3ec;display:block;font-size:14px;margin:6px 0;transition:.3s}.footer-link:hover{color:#fff;transform:translateX(4px)}.social-logos{display:flex;gap:10px;margin-top:10px}.social-logo img{height:24px;object-fit:contain;opacity:.9;transition:.3s;width:24px}.social-logo img:hover{opacity:1;transform:scale(1.12)}.footer-bottom{border-top:1px solid #ffffff26;font-size:13px;margin-top:30px;opacity:.85;padding-top:15px;text-align:center}.footer a,.footer-brand,.footer-brand h3,.footer-brand span,.footer-link{color:#fff!important;text-decoration:none}.footer a:hover,.footer-brand:hover,.footer-link:hover{color:#dfe6f3!important}.inactivity-overlay{align-items:center;animation:fadeIn .25s ease;background:#0000008c;display:flex;inset:0;justify-content:center;position:fixed;z-index:99999}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.inactivity-modal{animation:slideUp .25s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:380px;padding:2.5rem 2rem;text-align:center;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.inactivity-icon{font-size:3rem;margin-bottom:.75rem}.inactivity-title{color:#1f2937;font-size:1.4rem;font-weight:700;margin:0 0 .75rem}.inactivity-text{color:#374151;font-size:1rem;margin-bottom:.5rem}.inactivity-countdown{color:#dc2626;font-size:1.4rem}.inactivity-subtext{color:#6b7280;font-size:.85rem;margin-bottom:1.25rem}.inactivity-progress{background:#e5e7eb;border-radius:3px;height:6px;margin-bottom:1.5rem;overflow:hidden}.inactivity-progress-bar{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px;height:100%;transition:width 1s linear}.inactivity-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:opacity .15s ease;width:100%}.inactivity-btn:hover{opacity:.9}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{background-color:#f8f9fa;color:#333;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6}.container{max-width:1200px}.container,.container-sm{margin:0 auto;padding:0 16px;width:100%}.container-sm{max-width:800px}.container-lg{margin:0 auto;max-width:1400px;padding:0 16px;width:100%}.row{display:flex;flex-wrap:wrap;margin:0 -8px}.col{flex:1 1;min-width:250px;padding:0 8px}.col-1{flex:0 0 8.333333%;max-width:8.333333%}.col-2{flex:0 0 16.666667%;max-width:16.666667%}.col-3{flex:0 0 25%;max-width:25%}.col-4{flex:0 0 33.333333%;max-width:33.333333%}.col-5{flex:0 0 41.666667%;max-width:41.666667%}.col-6{flex:0 0 50%;max-width:50%}.col-7{flex:0 0 58.333333%;max-width:58.333333%}.col-8{flex:0 0 66.666667%;max-width:66.666667%}.col-9{flex:0 0 75%;max-width:75%}.col-10{flex:0 0 83.333333%;max-width:83.333333%}.col-11{flex:0 0 91.666667%;max-width:91.666667%}.col-12{flex:0 0 100%;max-width:100%}@media (max-width:576px){html{font-size:14px}.container,.container-lg,.container-sm{padding:0 12px}.col{flex:0 0 100%;margin-bottom:16px;max-width:100%}}@media (min-width:576px){.container{max-width:540px}}@media (min-width:768px){.container{max-width:720px}.col-md-1{flex:0 0 8.333333%;max-width:8.333333%}.col-md-2{flex:0 0 16.666667%;max-width:16.666667%}.col-md-3{flex:0 0 25%;max-width:25%}.col-md-4{flex:0 0 33.333333%;max-width:33.333333%}.col-md-5{flex:0 0 41.666667%;max-width:41.666667%}.col-md-6{flex:0 0 50%;max-width:50%}.col-md-7{flex:0 0 58.333333%;max-width:58.333333%}.col-md-8{flex:0 0 66.666667%;max-width:66.666667%}.col-md-9{flex:0 0 75%;max-width:75%}.col-md-10{flex:0 0 83.333333%;max-width:83.333333%}.col-md-11{flex:0 0 91.666667%;max-width:91.666667%}.col-md-12{flex:0 0 100%;max-width:100%}}@media (min-width:992px){.container{max-width:960px}.col-lg-1{flex:0 0 8.333333%;max-width:8.333333%}.col-lg-2{flex:0 0 16.666667%;max-width:16.666667%}.col-lg-3{flex:0 0 25%;max-width:25%}.col-lg-4{flex:0 0 33.333333%;max-width:33.333333%}.col-lg-5{flex:0 0 41.666667%;max-width:41.666667%}.col-lg-6{flex:0 0 50%;max-width:50%}.col-lg-7{flex:0 0 58.333333%;max-width:58.333333%}.col-lg-8{flex:0 0 66.666667%;max-width:66.666667%}.col-lg-9{flex:0 0 75%;max-width:75%}.col-lg-10{flex:0 0 83.333333%;max-width:83.333333%}.col-lg-11{flex:0 0 91.666667%;max-width:91.666667%}.col-lg-12{flex:0 0 100%;max-width:100%}}@media (min-width:1200px){.container{max-width:1140px}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.d-none{display:none}.d-block{display:block}.d-flex{display:flex}.d-inline{display:inline}.d-inline-block{display:inline-block}.flex-column{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.align-start{align-items:flex-start}.align-center{align-items:center}.align-end{align-items:flex-end}.align-stretch{align-items:stretch}.w-100{width:100%}.h-100{height:100%}.m-0{margin:0}.mt-0{margin-top:0}.mr-0{margin-right:0}.mb-0{margin-bottom:0}.ml-0{margin-left:0}.m-1{margin:.5rem}.mt-1{margin-top:.5rem}.mr-1{margin-right:.5rem}.mb-1{margin-bottom:.5rem}.ml-1{margin-left:.5rem}.m-2{margin:1rem}.mt-2{margin-top:1rem}.mr-2{margin-right:1rem}.mb-2{margin-bottom:1rem}.ml-2{margin-left:1rem}.p-0{padding:0}.pt-0{padding-top:0}.pr-0{padding-right:0}.pb-0{padding-bottom:0}.pl-0{padding-left:0}.p-1{padding:.5rem}.pt-1{padding-top:.5rem}.pr-1{padding-right:.5rem}.pb-1{padding-bottom:.5rem}.pl-1{padding-left:.5rem}.p-2{padding:1rem}.pt-2{padding-top:1rem}.pr-2{padding-right:1rem}.pb-2{padding-bottom:1rem}.pl-2{padding-left:1rem}img{display:block;height:auto;max-width:100%}.responsive-img{height:auto;object-fit:cover;width:100%}.bg-cover{background-position:50%;background-repeat:no-repeat;background-size:cover}h1{font-size:2.5rem;line-height:1.2;margin-bottom:1rem}h2{font-size:2rem;line-height:1.3}h2,h3{margin-bottom:.75rem}h3{font-size:1.75rem;line-height:1.4}h4{font-size:1.5rem}h4,h5{line-height:1.4;margin-bottom:.5rem}h5{font-size:1.25rem}h6{line-height:1.4;margin-bottom:.5rem}h6,p{font-size:1rem}p{margin-bottom:1rem}@media (max-width:768px){h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.1rem}}@media (max-width:576px){h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.1rem}p{font-size:.9rem}}.btn-responsive{border-radius:6px;display:inline-block;font-size:1rem;padding:12px 24px;text-align:center;transition:all .3s ease}@media (max-width:768px){.btn-responsive{font-size:.9rem;padding:10px 20px}}@media (max-width:576px){.btn-responsive{font-size:.85rem;max-width:300px;padding:8px 16px;width:100%}}.hide-on-mobile{display:block}.show-on-mobile{display:none}@media (max-width:768px){.hide-on-mobile{display:none}.show-on-mobile{display:block}}.page-not-found{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:60vh;padding:2rem 1rem;text-align:center}.page-not-found h2{color:#1a2333;font-size:2rem}.page-not-found p{color:#7a8599;font-size:1.05rem}.link-home{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50px;box-shadow:0 4px 14px #667eea59;color:#fff;display:inline-block;font-size:.95rem;font-weight:700;margin-top:.5rem;padding:.8rem 2rem;text-decoration:none;transition:opacity .15s,transform .1s}.link-home:hover{opacity:.9;transform:translateY(-2px)}@media (hover:none) and (pointer:coarse){.btn,[role=button],button{min-height:44px;min-width:44px}input,select,textarea{font-size:16px}}
/*# sourceMappingURL=main.468587f3.css.map*/