/* /Components/BookingCard.razor.rz.scp.css */
/* Booking Card */
.booking-card[b-03va2wfthr] {
    background: #fff;
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,0.07);
    transition: box-shadow 0.2s;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    border: 1px solid transparent;
    border-left: 6px solid;;
    margin-bottom: 18px;
    position: relative;
    border-color: #bdbdbd;
}

.booking-card:active[b-03va2wfthr] {
    box-shadow: 0 1px 3px rgba(0,0,0,0.10);
}

/* Border color by status */
.status-1[b-03va2wfthr] { border-color: #eed484; } /* In progress - MSC yellow */
.status-2[b-03va2wfthr] { border-color: #22c55e; } /* At Stop - Blue */
.status-3[b-03va2wfthr] { border-color: #f59e42; } /* Expecting Delay - Green */
.status-4[b-03va2wfthr] { border-color: #3b82f6; } /* Started - Teal */
.status-5[b-03va2wfthr] { border-color: #14b8a6; } /* On schedule - Orange */
.status-6[b-03va2wfthr] { border-color: #ef4444; } /* Delayed - Red */
.status-7[b-03va2wfthr] { border-color: #6b7280; } /* Completed - Gray */
.status-8[b-03va2wfthr] { border-color: #a855f7; } /* New - MSC yellow */


.card-content[b-03va2wfthr] {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.card-header[b-03va2wfthr] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 0;
    padding: 1rem;
}

.header-left[b-03va2wfthr] {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.booking-transportinfoid[b-03va2wfthr] {
    font-size: 11px;
    color: #bdbdbd;
    font-weight: 600;
    letter-spacing: 0.04em;
    margin-bottom: 2px;
}

.booking-refid[b-03va2wfthr] {
    font-size: 19px;
    font-weight: 700;
    color: #222;
    margin-bottom: 6px;
    letter-spacing: 0.01em;
    font-family: monospace;
    margin-top: -10px;
}

.company-name[b-03va2wfthr] {
    font-size: 15px;
    font-weight: 600;
    color: #222;
}

.booking-meta[b-03va2wfthr] {
    display: flex;
    gap: 8px;
    margin-bottom: 0;
}

.meta-badge[b-03va2wfthr] {
    background: #f3f4f6;
    color: #222;
    font-size: 12px;
    font-weight: 500;
    border-radius: 8px;
    padding: 2px 10px;
    letter-spacing: 0.01em;
    margin-right: 0;
}

.header-right[b-03va2wfthr] {
    display: flex;
    align-items: flex-start;
}

.status-badge[b-03va2wfthr] {
    padding: 2px 4px;
    border-radius: 0.25rem;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-left: 8px;
    margin-top: 2px;
    color: #fff;
    background: #bdbdbd;
}

.status-1 .status-badge[b-03va2wfthr] { background: #eed484; } /* In progress - MSC yellow */
.status-2 .status-badge[b-03va2wfthr] { background: #22c55e; } /* At Stop - Blue */
.status-3 .status-badge[b-03va2wfthr] { background: #f59e42; } /* Expecting Delay - Green */
.status-4 .status-badge[b-03va2wfthr] { background: #3b82f6; } /* Started - Teal */
.status-5 .status-badge[b-03va2wfthr] { background: #14b8a6; } /* On schedule - Orange */
.status-6 .status-badge[b-03va2wfthr] { background: #ef4444; } /* Delayed - Red */
.status-7 .status-badge[b-03va2wfthr] { background: #6b7280; } /* Completed - Gray */
.status-8 .status-badge[b-03va2wfthr] { background: #a855f7; } /* New - MSC yellow */


.divider[b-03va2wfthr] {
    border-bottom: 1px solid #f0f0f0;
    margin: 16px 0 10px 0;
}

.stop-section[b-03va2wfthr] {
    margin-top: 0;
}
.stop-header[b-03va2wfthr] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 2px;
}
.stop-label[b-03va2wfthr] {
    display: flex;
    align-items: center;
    gap: 6px;
}
.stop-badge[b-03va2wfthr] {
    display: flex;
    align-items: center;
    background: #f3f4f6;
    color: #222;
    font-size: 12px;
    font-weight: 700;
    border-radius: 8px;
    padding: 2px 12px;
    letter-spacing: 0.01em;
    text-transform: uppercase;
    gap: 6px;
}
.status-1 .stop-badge[b-03va2wfthr] { background: #ede9fe; color: #7c3aed; }
.status-2 .stop-badge[b-03va2wfthr] { background: #dbeafe; color: #2563eb; }
.status-3 .stop-badge[b-03va2wfthr] { background: #dcfce7; color: #22c55e; }
.status-4 .stop-badge[b-03va2wfthr] { background: #ccfbf1; color: #14b8a6; }
.status-5 .stop-badge[b-03va2wfthr] { background: #fef3c7; color: #f59e42; }
.status-6 .stop-badge[b-03va2wfthr] { background: #fee2e2; color: #ef4444; }
.status-7 .stop-badge[b-03va2wfthr] { background: #f3f4f6; color: #6b7280; }

.stop-icon[b-03va2wfthr] {
    margin-right: 4px;
    color: inherit;
}

.time-info[b-03va2wfthr] {
    font-size: 13px;
    font-weight: 600;
    color: #bdbdbd;
    margin-left: 12px;
    min-width: 48px;
    text-align: right;
}

.stop-name[b-03va2wfthr] {
    font-size: 15px;
    font-weight: 700;
    color: #222;
    margin-bottom: 2px;
    margin-top: 2px;
}

.stop-address[b-03va2wfthr] {
    font-size: 13px;
    color: #888;
    font-weight: 500;
    margin-bottom: 12px;
    flex-wrap: wrap;
}

.detail-item[b-03va2wfthr] {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.detail-label[b-03va2wfthr] {
    font-size: 11px;
    color: #999;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.detail-value[b-03va2wfthr] {
    font-size: 13px;
    font-weight: 600;
    color: #000;
}

.transporter-name[b-03va2wfthr] {
    font-size: 12px;
    color: #666;
    font-weight: 500;
}

.card-actions[b-03va2wfthr] {
    display: flex;
    border-top: 1px solid #f0f0f0;
}

.action-btn[b-03va2wfthr] {
    flex: 1;
    background: none;
    border: none;
    padding: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.2s;
    border-right: 1px solid #f0f0f0;
}

.action-btn:last-child[b-03va2wfthr] {
    border-right: none;
}

.action-btn:hover[b-03va2wfthr] {
    background: #f8f9fa;
}

.action-btn:active[b-03va2wfthr] {
    background: #e9ecef;
}

.action-btn svg[b-03va2wfthr] {
    color: #666;
}

/* Tablet and up - cleaner cards */
@media (min-width: 768px) {
    .booking-card:hover[b-03va2wfthr] {
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
        transform: translateY(-2px);
    }

    .booking-card:active[b-03va2wfthr] {
        transform: translateY(0);
    }

    .booking-number[b-03va2wfthr] {
        font-size: 20px;
    }

    .detail-value[b-03va2wfthr] {
        font-size: 14px;
    }
}

/* Touch optimization */
@media (hover: none) and (pointer: coarse) {
    .booking-card:hover[b-03va2wfthr] {
        transform: none;
        box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    }

    .action-btn:hover[b-03va2wfthr] {
        background: none;
    }
}
/* /Components/InfiniteScrollList.razor.rz.scp.css */
/* Infinite scroll container */
.infinite-scroll-container[b-sogpnxw1fs] {
    position: relative;
    height: 100%;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    padding: 0;
}

/* List wrapper with responsive layout */
.booking-list-wrapper[b-sogpnxw1fs] {
    display: flex;
    flex-direction: column;
    gap: 0px;
    padding: 24px 20px;
}

@media (min-width: 768px) {
    .booking-list-wrapper[b-sogpnxw1fs] {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
        gap: 24px;
        padding: 32px 40px;
    }
}

/* Loading states */
.loader[b-sogpnxw1fs] {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 80px;
}

.loader-spinner[b-sogpnxw1fs] {
    width: 40px;
    height: 40px;
    border: 3px solid #f0f0f0;
    border-top: 3px solid #eed484;
    border-radius: 50%;
    animation: spin-b-sogpnxw1fs 1s linear infinite;
}

.loading-more[b-sogpnxw1fs] {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 20px;
    margin: 10px 0;
}

.loading-more-spinner[b-sogpnxw1fs] {
    width: 30px;
    height: 30px;
    border: 2px solid #f0f0f0;
    border-top: 2px solid #eed484;
    border-radius: 50%;
    animation: spin-b-sogpnxw1fs 1s linear infinite;
}

/* Empty state */
.empty-list[b-sogpnxw1fs] {
    text-align: center;
    color: #888;
    margin-top: 40px;
    font-size: 1.1em;
}

/* Animations */
@keyframes spin-b-sogpnxw1fs {
    0% { 
        transform: rotate(0deg); 
    }
    100% { 
        transform: rotate(360deg); 
    }
}
/* /Components/LanguageSwitcher.razor.rz.scp.css */
.language-switcher[b-4wfnmt5qwy] {
    position: relative;
    display: inline-block;
}

.language-btn[b-4wfnmt5qwy] {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    background: transparent;
    border: 1px solid rgba(0, 0, 0, 0.2);
    border-radius: 6px;
    color: #333;
    cursor: pointer;
    transition: all 0.3s ease;
    font-size: 14px;
    font-weight: 500;
}

.language-btn:hover[b-4wfnmt5qwy] {
    background: rgba(0, 0, 0, 0.1);
    border-color: rgba(0, 0, 0, 0.3);
}

.language-btn svg[b-4wfnmt5qwy] {
    flex-shrink: 0;
}

.current-language[b-4wfnmt5qwy] {
    font-weight: 600;
    min-width: 24px;
    text-align: center;
}

.language-dropdown[b-4wfnmt5qwy] {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    background: white;
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
    overflow: hidden;
    min-width: 180px;
    z-index: 1000;
    animation: slideDown-b-4wfnmt5qwy 0.2s ease;
}

@keyframes slideDown-b-4wfnmt5qwy {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.language-option[b-4wfnmt5qwy] {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    padding: 12px 16px;
    background: white;
    border: none;
    color: #333;
    cursor: pointer;
    transition: background 0.2s ease;
    font-size: 14px;
    text-align: left;
}

.language-option:hover[b-4wfnmt5qwy] {
    background: #f5f5f5;
}

.language-option.active[b-4wfnmt5qwy] {
    background: #EED484;
    color: #333;
    font-weight: 600;
}

.language-option.active:hover[b-4wfnmt5qwy] {
    background: #EED484;
}

.flag-icon[b-4wfnmt5qwy] {
    font-size: 20px;
    line-height: 1;
}

/* Mobile responsive */
@media (max-width: 768px) {
    .language-btn[b-4wfnmt5qwy] {
        padding: 10px;
        background: rgba(255, 255, 255, 0.1);
        border: none;
        color: white;
        border-radius: 50%;
        width: 40px;
        height: 40px;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0;
        font-size: 0;
    }

    .current-language[b-4wfnmt5qwy] {
        display: none;
    }

    .language-btn:hover[b-4wfnmt5qwy] {
        background: rgba(255, 255, 255, 0.15);
        border-color: transparent;
    }

    .language-dropdown[b-4wfnmt5qwy] {
        min-width: 160px;
    }

    .language-option[b-4wfnmt5qwy] {
        padding: 10px 14px;
        font-size: 13px;
    }
}
/* /Components/Modals/ArrivalDepartureModal.razor.rz.scp.css */
.datetime-modal-content[b-snwd64c1sl] {
    padding: 20px;
}

.datetime-modal-content .form-group[b-snwd64c1sl] {
    margin-bottom: 20px;
}

.datetime-modal-content label[b-snwd64c1sl] {
    display: block;
    margin-bottom: 8px;
    font-weight: 500;
    color: #333;
}

.datetime-modal-content .form-control[b-snwd64c1sl] {
    width: 100%;
    padding: 10px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-size: 16px;
}

.datetime-modal-content .form-control:focus[b-snwd64c1sl] {
    outline: none;
    border-color: #0066cc;
}

.datetime-modal-content .modal-actions[b-snwd64c1sl] {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    margin-top: 24px;
}

.datetime-modal-content .btn[b-snwd64c1sl] {
    padding: 10px 20px;
    border: none;
    border-radius: 4px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: background-color 0.2s;
}

.datetime-modal-content .btn-secondary[b-snwd64c1sl] {
    background-color: #f5f5f5;
    color: #333;
}

.datetime-modal-content .btn-secondary:hover[b-snwd64c1sl] {
    background-color: #e0e0e0;
}

.datetime-modal-content .btn-primary[b-snwd64c1sl] {
    background-color: #0066cc;
    color: white;
}

.datetime-modal-content .btn-primary:hover[b-snwd64c1sl] {
    background-color: #0052a3;
}
/* /Components/Modals/ConfirmationModal.razor.rz.scp.css */
/* Generic Confirmation Modal */
.confirmation-overlay[b-xnrt7kpfjv] {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    z-index: 1000;
    animation: fadeIn-b-xnrt7kpfjv 0.2s ease-out;
}

@keyframes fadeIn-b-xnrt7kpfjv {
    from { opacity: 0; }
    to { opacity: 1; }
}

.confirmation-modal[b-xnrt7kpfjv] {
    background: white;
    border-radius: 1rem;
    width: 100%;
    max-width: 360px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    animation: slideUp-b-xnrt7kpfjv 0.3s ease-out;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
}

@keyframes slideUp-b-xnrt7kpfjv {
    from {
        transform: translateY(100px);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

.confirmation-header[b-xnrt7kpfjv] {
    background: #EED484;
    padding: 20px 24px;
    display: flex;
    align-items: center;
    gap: 12px;
    color: #000;
    font-size: 18px;
    font-weight: 700;
    border-radius: 1rem 1rem 0 0;
}

.confirmation-header .fa-solid[b-xnrt7kpfjv] {
    font-size: 18px;
}

.confirmation-content[b-xnrt7kpfjv] {
    padding: 24px;
    font-size: 14px;
    color: #666;
    line-height: 1.5;
}

.confirmation-actions[b-xnrt7kpfjv] {
    display: flex;
    gap: 12px;
    padding: 20px 24px;
    background: #f8f9fa;
}

.btn-cancel[b-xnrt7kpfjv],
.btn-accept[b-xnrt7kpfjv] {
    flex: 1;
    padding: 12px 20px;
    border-radius: 0.75rem;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    border: none;
    transition: all 0.2s ease;
}

.btn-cancel[b-xnrt7kpfjv] {
    background: #e5e7eb;
    color: #6b7280;
}

.btn-cancel:hover:not(:disabled)[b-xnrt7kpfjv] {
    background: #d1d5db;
}

.btn-accept[b-xnrt7kpfjv] {
    background: #EED484;
    color: #000;
}

.btn-accept:hover:not(:disabled)[b-xnrt7kpfjv] {
    opacity: 0.9;
}

.btn-accept:disabled[b-xnrt7kpfjv] {
    opacity: 0.5;
    cursor: not-allowed;
}

.btn-cancel:disabled[b-xnrt7kpfjv] {
    opacity: 0.5;
    cursor: not-allowed;
}
/* /Components/Modals/LicensePlateSelectModal.razor.rz.scp.css */
/* License Plate Selection Modal Styles */
.license-plate-list[b-v66fpo29hm] {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 24px;
    max-height: 280px;
    overflow-y: auto;
}

.license-plate-item[b-v66fpo29hm] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px;
    background: #f5f5f5;
    border-radius: 12px;
    cursor: pointer;
    transition: all 0.2s;
    border: 2px solid transparent;
    min-height: 60px;
}

.license-plate-item:hover[b-v66fpo29hm] {
    background: #e9ecef;
}

.license-plate-item.selected[b-v66fpo29hm] {
    background: #fff;
    border-color: #EED484;
}

.plate-info[b-v66fpo29hm] {
    flex: 1;
}

.plate-number[b-v66fpo29hm] {
    font-size: 16px;
    font-weight: 700;
    color: #333;
    font-family: 'Courier New', monospace;
    letter-spacing: 1px;
}

.selected-indicator[b-v66fpo29hm] {
    width: 24px;
    height: 24px;
    background: #EED484;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #000;
    font-size: 12px;
    font-weight: 700;
    flex-shrink: 0;
}

/* Scrollbar styling */
.license-plate-list[b-v66fpo29hm]::-webkit-scrollbar {
    width: 6px;
}

.license-plate-list[b-v66fpo29hm]::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 3px;
}

.license-plate-list[b-v66fpo29hm]::-webkit-scrollbar-thumb {
    background: #c1c1c1;
    border-radius: 3px;
}

.license-plate-list[b-v66fpo29hm]::-webkit-scrollbar-thumb:hover {
    background: #a8a8a8;
}
/* /Components/Modals/Modal.razor.rz.scp.css */
/* Modal Styles */
.modal-overlay[b-93h27pwz3a] {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4);
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding: 16px;
    z-index: 1000;
    animation: fadeIn-b-93h27pwz3a 0.15s ease-out;
}

@media (min-width: 414px) {
    .modal-overlay[b-93h27pwz3a] {
        align-items: center;
        padding: 20px;
    }
}

@keyframes fadeIn-b-93h27pwz3a {
    from { opacity: 0; }
    to { opacity: 1; }
}

.modal-container[b-93h27pwz3a] {
    background: white;
    border-radius: 1rem;
    width: 100%;
    max-width: 414px;
    position: relative;
    animation: slideUp-b-93h27pwz3a 0.2s ease-out;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    margin-bottom: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    max-height: 90vh;
}

@media (min-width: 414px) {
    .modal-container[b-93h27pwz3a] {
        margin-bottom: 0;
    }
}

@keyframes slideUp-b-93h27pwz3a {
    from {
        transform: translateY(50px);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

.modal-small[b-93h27pwz3a] {
    max-width: 280px;
}

.modal-medium[b-93h27pwz3a] {
    max-width: 380px;
}

.modal-large[b-93h27pwz3a] {
    max-width: 400px;
}

.modal-header[b-93h27pwz3a] {
    background: #f8f8f8;
    padding: 16px 20px;
    display: flex;
    align-items: center;
    gap: 12px;
    color: #333;
    font-size: 16px;
    font-weight: 600;
    position: relative;
    border-bottom: 1px solid #e0e0e0;
}

.modal-header .fa-solid:not(.modal-close-btn .fa-solid)[b-93h27pwz3a] {
    font-size: 20px;
}

.modal-close-btn[b-93h27pwz3a] {
    position: absolute;
    top: 50%;
    right: 16px;
    transform: translateY(-50%);
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 8px;
    color: #000;
    border-radius: 50%;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    transition: all 0.2s;
}

.modal-close-btn:hover[b-93h27pwz3a] {
    background: rgba(0, 0, 0, 0.1);
}

.modal-content[b-93h27pwz3a] {
    padding: 20px;
    overflow-y: auto;
    flex: 1;
}

.modal-subtitle[b-93h27pwz3a] {
    font-size: 14px;
    color: #666;
    margin: 0 0 20px 0;
    line-height: 1.4;
}

.modal-body[b-93h27pwz3a] {
    /* Content styling handled by child components */
}

/* Form Styles for Modal Content - using ::deep to style child components */
[b-93h27pwz3a] .modal-form-group {
    margin-bottom: 20px;
}

[b-93h27pwz3a] .modal-form-group label {
    display: block;
    font-size: 11px;
    font-weight: 700;
    color: #666;
    letter-spacing: 0.5px;
    margin-bottom: 8px;
}

[b-93h27pwz3a] .modal-input-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    background: #f5f5f5;
    border-radius: 12px;
    padding: 0 16px;
    min-height: 48px;
}

[b-93h27pwz3a] .modal-input-wrapper .fa-solid {
    color: #999;
    flex-shrink: 0;
    font-size: 16px;
    margin-right: 12px;
}

[b-93h27pwz3a] .modal-input-wrapper input {
    flex: 1;
    border: none;
    background: transparent;
    padding: 14px 0;
    font-size: 15px;
    color: #000;
    outline: none;
}

[b-93h27pwz3a] .modal-input-wrapper input::placeholder {
    color: #999;
}

[b-93h27pwz3a] .modal-input-wrapper input:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Select Styles */
[b-93h27pwz3a] .modal-select {
    width: 100%;
    padding: 12px 16px;
    background: #f5f5f5;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    font-size: 15px;
    color: #333;
    outline: none;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23666' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 36px;
}

[b-93h27pwz3a] .modal-select:focus {
    border-color: #999;
    background-color: #fff;
}

[b-93h27pwz3a] .modal-select:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Modal Buttons - using ::deep to style child components */
[b-93h27pwz3a] .modal-buttons {
    display: flex;
    gap: 12px;
    margin-top: 20px;
}

[b-93h27pwz3a] .modal-btn {
    flex: 1;
    padding: 12px 20px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    border: none;
    cursor: pointer;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    transition: all 0.2s ease;
    min-height: 44px;
}

[b-93h27pwz3a] .modal-btn-primary {
    background: #EED484;
    color: #000;
}

[b-93h27pwz3a] .modal-btn-primary:hover:not(:disabled) {
    background: #e6cc7a;
}

[b-93h27pwz3a] .modal-btn-primary:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

[b-93h27pwz3a] .modal-btn-secondary {
    background: #f5f5f5;
    color: #666;
}

[b-93h27pwz3a] .modal-btn-secondary:hover:not(:disabled) {
    background: #e9ecef;
}

[b-93h27pwz3a] .modal-error-message {
    background: #fee;
    color: #c00;
    padding: 12px;
    border-radius: 8px;
    font-size: 13px;
    margin-bottom: 16px;
}

/* Form Styles for Modal Content */
.modal-form-group[b-93h27pwz3a] {
    margin-bottom: 20px;
}

.modal-form-group label[b-93h27pwz3a] {
    display: block;
    font-size: 11px;
    font-weight: 700;
    color: #666;
    letter-spacing: 0.5px;
    margin-bottom: 8px;
}

.modal-input-wrapper[b-93h27pwz3a] {
    position: relative;
    display: flex;
    align-items: center;
    background: #f5f5f5;
    border-radius: 12px;
    padding: 0 16px;
    min-height: 48px;
}

.modal-input-wrapper .fa-solid[b-93h27pwz3a] {
    color: #999;
    flex-shrink: 0;
    font-size: 16px;
    margin-right: 12px;
}

.modal-input-wrapper input[b-93h27pwz3a] {
    flex: 1;
    border: none;
    background: transparent;
    padding: 14px 0;
    font-size: 15px;
    color: #000;
    outline: none;
}

.modal-input-wrapper input[b-93h27pwz3a]::placeholder {
    color: #999;
}

.modal-input-wrapper input:disabled[b-93h27pwz3a] {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Modal Buttons */
.modal-btn[b-93h27pwz3a] {
    width: 100%;
    padding: 14px;
    border-radius: 8px;
    font-size: 15px;
    font-weight: 600;
    border: none;
    cursor: pointer;
    letter-spacing: 0.5px;
    margin-bottom: 12px;
    text-transform: uppercase;
    transition: all 0.2s ease;
}

.modal-btn:last-child[b-93h27pwz3a] {
    margin-bottom: 0;
}

.modal-btn-primary[b-93h27pwz3a] {
    background: #EED484;
    color: #000;
}

.modal-btn-primary:hover:not(:disabled)[b-93h27pwz3a] {
    background: #e6cc7a;
}

.modal-btn-primary:disabled[b-93h27pwz3a] {
    opacity: 0.6;
    cursor: not-allowed;
}

.modal-btn-secondary[b-93h27pwz3a] {
    background: #f5f5f5;
    color: #666;
}

.modal-btn-secondary:hover:not(:disabled)[b-93h27pwz3a] {
    background: #e9ecef;
}

.modal-error-message[b-93h27pwz3a] {
    background: #fee;
    color: #c00;
    padding: 12px;
    border-radius: 8px;
    font-size: 13px;
    margin-bottom: 16px;
}
/* /Components/Modals/SignInModal.razor.rz.scp.css */
/* Sign In Modal */
.signin-overlay[b-y8zwgp2ya9] {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding: 20px;
    z-index: 1000;
}

.signin-modal[b-y8zwgp2ya9] {
    background: white;
    border-radius: 1rem;
    width: 100%;
    max-width: 340px;
    padding: 32px 24px;
    position: relative;
    margin-bottom: 80px;
}

.close-btn[b-y8zwgp2ya9] {
    position: absolute;
    top: 16px;
    right: 16px;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 4px;
    color: #999;
}

.close-btn:hover[b-y8zwgp2ya9] {
    color: #666;
}

.signin-content h2[b-y8zwgp2ya9] {
    font-size: 24px;
    font-weight: 700;
    color: #000;
    margin: 0 0 8px 0;
    text-align: left;
}

.signin-subtitle[b-y8zwgp2ya9] {
    font-size: 14px;
    color: #666;
    margin: 0 0 32px 0;
    text-align: left;
}

.form-group[b-y8zwgp2ya9] {
    margin-bottom: 20px;
}

.form-group label[b-y8zwgp2ya9] {
    display: block;
    font-size: 11px;
    font-weight: 700;
    color: #666;
    letter-spacing: 0.5px;
    margin-bottom: 8px;
}

.input-wrapper[b-y8zwgp2ya9] {
    position: relative;
    display: flex;
    align-items: center;
    background: #f5f5f5;
    border-radius: 12px;
    padding: 0 16px;
}

.input-wrapper svg[b-y8zwgp2ya9] {
    color: #999;
    flex-shrink: 0;
}

.input-wrapper input[b-y8zwgp2ya9] {
    flex: 1;
    border: none;
    background: transparent;
    padding: 14px 12px;
    font-size: 15px;
    color: #000;
    outline: none;
}

.input-wrapper input[b-y8zwgp2ya9]::placeholder {
    color: #999;
}

.input-wrapper input:disabled[b-y8zwgp2ya9] {
    opacity: 0.6;
    cursor: not-allowed;
}

.error-message[b-y8zwgp2ya9] {
    background: #fee;
    color: #c00;
    padding: 12px;
    border-radius: 8px;
    font-size: 13px;
    margin-bottom: 16px;
}

.btn-signin[b-y8zwgp2ya9] {
    width: 100%;
    padding: 12px 20px;
    border-radius: 0.5rem;
    background: #EED484;
    color: #000;
    font-size: 14px;
    font-weight: 700;
    border: none;
    cursor: pointer;
    letter-spacing: 1px;
    text-transform: uppercase;
    transition: all 0.2s ease;
    min-height: 44px;
}

.btn-signin:hover:not(:disabled)[b-y8zwgp2ya9] {
    opacity: 0.9;
}

.btn-signin:disabled[b-y8zwgp2ya9] {
    opacity: 0.6;
    cursor: not-allowed;
}
/* /Components/Modals/TermsOfServiceModal.razor.rz.scp.css */
/* Terms Modal */
.terms-overlay[b-7fcmdz9n8m] {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding: 20px;
    z-index: 1000;
}

.terms-modal[b-7fcmdz9n8m] {
    background: white;
    border-radius: 1rem;
    width: 100%;
    max-width: 400px;
    max-height: 90vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    margin-bottom: 80px;
}

.terms-header[b-7fcmdz9n8m] {
    background: #EED484;
    padding: 20px;
    display: flex;
    align-items: center;
    gap: 12px;
    color: #000;
    font-size: 18px;
    font-weight: 700;
}

.terms-content[b-7fcmdz9n8m] {
    padding: 20px;
    overflow-y: auto;
    flex: 1;
}

.terms-section[b-7fcmdz9n8m] {
    margin-bottom: 20px;
}

.terms-section h3[b-7fcmdz9n8m] {
    font-size: 15px;
    font-weight: 700;
    color: #000;
    margin: 0 0 8px 0;
}

.terms-section p[b-7fcmdz9n8m] {
    font-size: 13px;
    color: #666;
    line-height: 1.5;
    margin: 0;
}

.terms-checkbox[b-7fcmdz9n8m] {
    margin-top: 24px;
    padding-top: 16px;
    border-top: 1px solid #eee;
}

.terms-checkbox label[b-7fcmdz9n8m] {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    cursor: pointer;
}

.terms-checkbox input[type="checkbox"][b-7fcmdz9n8m] {
    margin-top: 2px;
    width: 18px;
    height: 18px;
    cursor: pointer;
    accent-color:#EED484;
}

.terms-checkbox span[b-7fcmdz9n8m] {
    font-size: 13px;
    color: #333;
    line-height: 1.4;
}

.terms-actions[b-7fcmdz9n8m] {
    display: flex;
    gap: 12px;
    padding: 16px 20px;
    border-top: 1px solid #eee;
    background-color: rgb(243 244 246);
}

.btn-decline[b-7fcmdz9n8m],
.btn-accept[b-7fcmdz9n8m] {
    flex: 1;
    padding: 12px 20px;
    border-radius: 0.5rem;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    border: none;
    letter-spacing: 1px;
    text-transform: uppercase;
    transition: all 0.2s ease;
    min-height: 44px;
}

.btn-decline[b-7fcmdz9n8m] {
    background: #dfdfdf;
    color: #666;
}

.btn-decline:hover[b-7fcmdz9n8m] {
    background: #e0e0e0;
}

.btn-accept[b-7fcmdz9n8m] {
    background: #EED484;
    color: #000;
}

.btn-accept:hover:not(:disabled)[b-7fcmdz9n8m] {
    opacity: 0.9;
}

.btn-accept:disabled[b-7fcmdz9n8m] {
    opacity: 0.5;
    cursor: not-allowed;
}
/* /Components/NotificationPopup.razor.rz.scp.css */
.notification-container[b-dz5gb3nbvc] {
    position: fixed;
    top: 80px;
    right: 20px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 12px;
    max-width: 400px;
    pointer-events: none;
}

.notification[b-dz5gb3nbvc] {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 16px;
    border-radius: 12px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
    background: #fff;
    pointer-events: auto;
    animation: slideIn-b-dz5gb3nbvc 0.3s ease-out;
    min-width: 320px;
}

@keyframes slideIn-b-dz5gb3nbvc {
    from {
        transform: translateX(100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

.notification-icon[b-dz5gb3nbvc] {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.notification-info[b-dz5gb3nbvc] {
    border-left: 4px solid #0ea5e9;
}

.notification-info .notification-icon[b-dz5gb3nbvc] {
    color: #0ea5e9;
}

.notification-warning[b-dz5gb3nbvc] {
    border-left: 4px solid #f59e0b;
}

.notification-warning .notification-icon[b-dz5gb3nbvc] {
    color: #f59e0b;
}

.notification-error[b-dz5gb3nbvc] {
    border-left: 4px solid #ef4444;
}

.notification-error .notification-icon[b-dz5gb3nbvc] {
    color: #ef4444;
}

.notification-content[b-dz5gb3nbvc] {
    flex: 1;
    min-width: 0;
}

.notification-message[b-dz5gb3nbvc] {
    margin: 0;
    font-size: 14px;
    line-height: 1.5;
    color: #333;
    word-wrap: break-word;
}

.notification-close[b-dz5gb3nbvc] {
    flex-shrink: 0;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    color: #999;
    transition: color 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
}

.notification-close:hover[b-dz5gb3nbvc] {
    color: #333;
}

@media (max-width: 768px) {
    .notification-container[b-dz5gb3nbvc] {
        right: 10px;
        left: 10px;
        max-width: none;
    }

    .notification[b-dz5gb3nbvc] {
        min-width: 0;
    }
}
/* /Components/Sidebar.razor.rz.scp.css */
.sidebar[b-cmxequ2ug0] {
    display: none;
}

@media (min-width: 768px) {
    .sidebar[b-cmxequ2ug0] {
        display: flex;
        flex-direction: column;
        width: 156px;
        background: #1a1a1a;
        color: white;
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        padding: 20px 0;
        z-index: 100;
    }

    .sidebar-header[b-cmxequ2ug0] {
        padding: 0 16px;
        margin-bottom: 24px;
    }

    .sidebar-brand[b-cmxequ2ug0] {
        display: flex;
        align-items: flex-start;
        gap: 12px;
    }

    .sidebar-icon[b-cmxequ2ug0] {
        width: 40px;
        height: 40px;
        flex-shrink: 0;
    }

    .sidebar-text[b-cmxequ2ug0] {
        display: flex;
        flex-direction: column;
    }

    .sidebar-logo[b-cmxequ2ug0] {
        font-size: 11px;
        font-weight: 700;
        letter-spacing: 2px;
        color: #eed484;
    }

    .sidebar-title[b-cmxequ2ug0] {
        font-size: 22px;
        font-weight: 600;
        margin: 0;
        color: white;
        line-height: 30px;
    }

    .sidebar-nav[b-cmxequ2ug0] {
        flex: 1;
        padding: 0 12px;
        display: flex;
        flex-direction: column;
        gap: 8px;
    }

    [b-cmxequ2ug0] .sidebar-nav .sidebar-nav-item {
        display: flex;
        align-items: center;
        gap: 4px;
        width: 100%;
        border: none;
        background: rgba(255, 255, 255, 0.15);
        color: #999;
        font-size: 13px;
        font-weight: 500;
        border-radius: 8px;
        cursor: pointer;
        transition: all 0.2s;
        text-align: left;
        font-size: 12px;
        padding: 8px;
        line-height: 21px;
    }

    [b-cmxequ2ug0] .sidebar-nav .sidebar-nav-item:hover {
        background: rgba(255, 255, 255, 0.3);
        color: white;
    }

    [b-cmxequ2ug0] .sidebar-nav .sidebar-nav-item.active {
        background: #eed484;
        color: #1a1a1a;
        font-weight: 600;
    }

    [b-cmxequ2ug0] .sidebar-nav .sidebar-nav-item.active:hover {
        background: #e5c76e;
    }

    [b-cmxequ2ug0] .sidebar-nav .sidebar-nav-item svg {
        flex-shrink: 0;
        width: 20px;
        height: 20px;
    }

    [b-cmxequ2ug0] .sidebar-nav .sidebar-nav-item .sidebar-nav-text {
        flex: 1;
    }

    [b-cmxequ2ug0] .sidebar-nav .sidebar-nav-item .sidebar-tab-count {
        flex: 0 0 auto;
        min-width: 20px;
        padding: 0 4px;
        border-radius: 4px;
        background: rgba(255, 255, 255, 0.15);
        color: inherit;
        text-align: center;
        font-size: 11px;
        line-height: 18px;
        font-weight: 600;
    }

    [b-cmxequ2ug0] .sidebar-nav .sidebar-nav-item.active .sidebar-tab-count {
        background: rgba(0, 0, 0, 0.12);
    }

    .sidebar-footer[b-cmxequ2ug0] {
        padding: 0 16px;
        border-top: 1px solid rgba(255, 255, 255, 0.1);
        padding-top: 12px;
    }

    .sidebar-logout[b-cmxequ2ug0] {
        display: flex;
        align-items: center;
        gap: 10px;
        width: 100%;
        padding: 10px 12px;
        border: none;
        background: transparent;
        color: #999;
        font-size: 14px;
        border-radius: 6px;
        cursor: pointer;
        transition: all 0.2s;
        text-align: left;
    }

    .sidebar-logout:hover[b-cmxequ2ug0] {
        background: rgba(255, 255, 255, 0.05);
        color: white;
    }

    .sidebar-logout svg[b-cmxequ2ug0] {
        flex-shrink: 0;
        width: 18px;
        height: 18px;
    }

    /* Booking detail sidebar content */
    .sidebar-booking-info[b-cmxequ2ug0] {
        padding: 16px 12px;
        margin-top: 16px;
        border-top: 1px solid rgba(255, 255, 255, 0.1);
    }

    .sidebar-booking-id[b-cmxequ2ug0] {
        font-size: 11px;
        font-weight: 700;
        letter-spacing: 1px;
        color: #eed484;
        margin-bottom: 8px;
    }

    .sidebar-booking-client[b-cmxequ2ug0] {
        font-size: 13px;
        color: #999;
        line-height: 1.4;
    }
}
/* /Components/StatusFilter.razor.rz.scp.css */
.filter-dropdown[b-ykegdmmj8n] {
    position: relative;
}

.filter-button[b-ykegdmmj8n] {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    background: white;
    border: none;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    color: #666;
    cursor: pointer;
    font-size: 18px;
    transition: all 0.2s ease;
}

.filter-button:hover[b-ykegdmmj8n] {
    background: #f8f8f8;
    color: #333;
}

.filter-button.active[b-ykegdmmj8n] {
    background: #eed484;
    color: #000;
}

.filter-button.active:hover[b-ykegdmmj8n] {
    background: #e5ca70;
}

.filter-button:active[b-ykegdmmj8n] {
    transform: scale(0.95);
}

.filter-backdrop[b-ykegdmmj8n] {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 99;
    background: transparent;
}

.filter-menu[b-ykegdmmj8n] {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    background: white;
    border-radius: 12px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
    min-width: 200px;
    z-index: 100;
    overflow: hidden;
    animation: slideDown-b-ykegdmmj8n 0.2s ease;
}

@keyframes slideDown-b-ykegdmmj8n {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.filter-menu-header[b-ykegdmmj8n] {
    padding: 12px 16px;
    font-weight: 600;
    font-size: 13px;
    color: #666;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-bottom: 1px solid #f0f0f0;
}

.filter-option[b-ykegdmmj8n] {
    display: block;
    width: 100%;
    padding: 12px 16px;
    background: white;
    border: none;
    text-align: left;
    font-size: 12px;
    color: #333;
    cursor: pointer;
    transition: background 0.15s ease;
}

.filter-option:hover[b-ykegdmmj8n] {
    background: #f8f8f8;
}

.filter-option.active[b-ykegdmmj8n] {
    background: #eed484;
    color: #000;
    font-weight: 600;
}
/* /Components/StopCard.razor.rz.scp.css */
.delay-btn[b-pvvx5i8u3p] {
    color: rgb(202, 138, 4);
    background-color: rgb(254, 252, 232);
    border: 1px solid rgb(253, 230, 138);
}

.depart-btn[b-pvvx5i8u3p] {
    color: rgb(30, 64, 175);
    background-color: rgb(239, 246, 255);
    border: 1px solid rgb(191, 219, 254);
}
.arrival-btn[b-pvvx5i8u3p] {
    color: rgb(21, 128, 61);
    background-color: rgb(240, 253, 244);
    border: 1px solid rgb(187, 247, 208);
}
.stop-buttons-row[b-pvvx5i8u3p] {
    display: flex;
    flex-direction: row;
    margin-top: 8px;
    width: 100%;
}
/* Timeline container for stop cards */
.timeline[b-pvvx5i8u3p] {
    position: relative;
    padding-left: 48px;
}

.btn[b-pvvx5i8u3p]{
    font-size: 10px;
    flex: 1;
}

/* Vertical line connecting the stops */
.timeline[b-pvvx5i8u3p]::before {
    content: "";
    position: absolute;
    top: 16px;
    left: 16px;
    width: 3px;
    height: calc(100% - 32px);
    background: #eed484;
    border-radius: 2px;
    z-index: 0;
}

/* Position the stop-indicator outside and overlapping the timeline */
.timeline .stop-indicator[b-pvvx5i8u3p] {
    z-index: 2;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
    background: white;
}

.timeline .stop-content[b-pvvx5i8u3p] {
    background: white;
    border-radius: 12px;
    padding: 16px;
    margin: 0 0 12px 0px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    display: flex;
    align-items: flex-start;
    gap: 12px;
    flex-direction: column;
}
/* Stop Card Component Styles */
.stop-card[b-pvvx5i8u3p] {
    display: flex;
    position: relative;
    margin-bottom: 12px;
}

.stop-card.selected .stop-content[b-pvvx5i8u3p]{
    background: #FFFBEb;
    border: 1px solid #eed484;
    box-sizing: border-box;
}

.stop-indicator[b-pvvx5i8u3p] {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    font-size: 12px;
    flex-shrink: 0;
    position: absolute;
    left: -48px;
    top: 8px;
    z-index: 2;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
}

.stop-card.completed .stop-indicator[b-pvvx5i8u3p] {
    background-color: #4caf50;
    color: white;
}

.stop-card.current .stop-indicator[b-pvvx5i8u3p] {
    background-color: #ffd200;
    color: #333;
}

.stop-card.upcoming .stop-indicator[b-pvvx5i8u3p] {
    background-color: #e0e0e0;
    color: #999;
}

.stop-content[b-pvvx5i8u3p] {
    flex: 1;
}

.stop-header[b-pvvx5i8u3p] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 8px;
    width: 100%;
}

.stop-status[b-pvvx5i8u3p] {
    font-size: 10px;
    font-weight: bold;
    letter-spacing: 0.5px;
    margin-bottom: 4px;
    display: block;
}

.stop-status.completed[b-pvvx5i8u3p] {
    color: #4caf50;
}

.stop-status.current[b-pvvx5i8u3p] {
    color: #ff9800;
}

.stop-name[b-pvvx5i8u3p] {
    font-size: 14px;
    font-weight: bold;
    color: #333;
    margin: 0 0 2px 0;
}

.stop-action[b-pvvx5i8u3p] {
    color: #666;
    margin: 0;
    text-transform: uppercase;
    font-weight: 700;
    font-size: 10px;
}

.stop-time[b-pvvx5i8u3p] {
    text-align: right;
    display: flex;
    flex-direction: column;
    gap: 4px;
    align-items: flex-end;
    min-width: fit-content;
}

.notification-badge[b-pvvx5i8u3p] {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    color: #666;
    background-color: #f0f0f0;
    padding: 4px 8px;
    border-radius: 12px;
    flex: 1;
    justify-content: center;
}

.notification-badge .fa-check[b-pvvx5i8u3p] {
    color: rgb(21, 128, 61);
}

.notification-badge .fa-arrow-right[b-pvvx5i8u3p] {
    color: rgb(30, 64, 175);
}

.notification-badge .fa-clock[b-pvvx5i8u3p] {
    color: rgb(202, 138, 4);
}

.notification-time[b-pvvx5i8u3p] {
    font-weight: 600;
    font-size: 10px;
}

.delay-minutes[b-pvvx5i8u3p] {
    font-weight: 700;
    color: rgb(202, 138, 4);
    font-size: 10px;
}

.eta-delay[b-pvvx5i8u3p] {
    background-color: orange;
    color: white;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: bold;
    display: flex;
    align-items: end;
    gap: 4px;
    flex-direction: column;
}

.notification-badges-row[b-pvvx5i8u3p] {
    display: flex;
    gap: 8px;
    margin-top: 8px;
    flex-wrap: wrap;
}

.time-text[b-pvvx5i8u3p] {
    font-size: 12px;
    font-weight: bold;
    color: #333;
}

.stop-address[b-pvvx5i8u3p] {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: #666;
    background-color: #f8f8f8;
    padding: 8px;
    border-radius: 6px;
}

.stop-reference[b-pvvx5i8u3p] {
    font-size: 12px;
    color: #666;
    margin-bottom: 0px;
}

.stop-address .fa-location-dot[b-pvvx5i8u3p] {
    color: #999;
}
/* /Components/TabToggle.razor.rz.scp.css */
.tab-toggle[b-jhh3b2mmxr] {
    display: flex;
    gap: 12px;
    margin-bottom: 14px;
    padding: 5px;
    background: rgb(229 231 235 / 0.5);
    border-radius: 10px;
    margin-left: 20px;
    margin-right: 20px;
}

.tab-button[b-jhh3b2mmxr] {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 8px 8px;
    border: none;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    background: transparent;
    color: #666;
}

.tab-button.active[b-jhh3b2mmxr] {
    background: #EED484;
    color: #000;
}

.tab-button:hover:not(.active)[b-jhh3b2mmxr] {
    background: #e5e5e5;
}

.tab-label[b-jhh3b2mmxr] {
    white-space: nowrap;
}

.tab-count[b-jhh3b2mmxr] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 2px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 700;
}

.tab-button.active .tab-count[b-jhh3b2mmxr] {
    background: rgba(0, 0, 0, 0.15);
    color: #000;
}

.tab-button:not(.active) .tab-count[b-jhh3b2mmxr] {
    background: rgba(0, 0, 0, 0.1);
    color: #666;
}
/* /Components/TopBar.razor.rz.scp.css */
.top-bar[b-6b4f22a2zs] {
    background: rgb(26 26 26);
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
}

.top-bar-content[b-6b4f22a2zs] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 26px 20px;
    max-width: 100%;
    margin: 0 auto;
}

.header-left[b-6b4f22a2zs] {
    flex: 1;
}
.header-left.centered[b-6b4f22a2zs] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.header-left.centered .brand[b-6b4f22a2zs],
.header-left.centered .page-title[b-6b4f22a2zs] {
    text-align: center;
    width: 100%;
}


.btn-back[b-6b4f22a2zs] {
    background: rgba(255,255,255,0.1);
    border: none;
    padding: 8px 10px 8px 4px;
    margin-right: 10px;
    border-radius: 50%;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s;
    color: #fff;
}
.btn-back:hover[b-6b4f22a2zs] {
    background: rgba(255,255,255,0.18);
}
.btn-back svg[b-6b4f22a2zs] {
    display: block;
    stroke: #fff;
}

.brand[b-6b4f22a2zs] {
    font-size: 10px;
    font-weight: 700;
    color: #EED484;;
    letter-spacing: 1px;
    margin-bottom: 4px;
    text-transform: uppercase;
}

.page-title[b-6b4f22a2zs] {
    font-size: 20px;
    font-weight: 700;
    color: #fff;
    margin: 0 0 12px 0;
}

.welcome-message[b-6b4f22a2zs] {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.8);
    margin: 0;
}

.header-right[b-6b4f22a2zs] {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    gap: 12px;
}

.btn-logout[b-6b4f22a2zs] {
    background: rgba(255, 255, 255, 0.1);
    border: none;
    padding: 10px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: background-color 0.2s;
    color: #fff;
    position: relative;
}

.btn-logout:hover[b-6b4f22a2zs] {
    background: rgba(255, 255, 255, 0.15);
}

.btn-logout:active[b-6b4f22a2zs] {
    background: rgba(255, 255, 255, 0.2);
}

.btn-logout:disabled[b-6b4f22a2zs] {
    opacity: 0.5;
    cursor: not-allowed;
}

.notification-dot[b-6b4f22a2zs] {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 8px;
    height: 8px;
    background: #ff4444;
    border-radius: 50%;
    border: 2px solid #2d1b69;
}
/* /Layout/MainLayout.razor.rz.scp.css */
.page[b-oqcsujspol] {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    background: linear-gradient(to bottom, rgb(245 245 245) 0%, rgb(255 255 255) 100%);
    overflow: hidden;
}

@media (min-width: 768px) {
    .topbar-home[b-oqcsujspol] {
        display: none;
    }

    .page > div:not(.topbar-home)[b-oqcsujspol] {
        display: none;
    }
}

main[b-oqcsujspol] {
    flex: 1;
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
}

main > article[b-oqcsujspol] {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: visible;
}


/* /Pages/BookingDetail.razor.rz.scp.css */
/* Mobile-First Booking Detail Design */
.booking-detail-container[b-wnqmugsuzv] {
    min-height: 100vh;
    background-color: #f5f5f5;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    padding-top: 112px;
    padding-bottom: 80px;
    touch-action: pan-y pinch-zoom;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

/* Content Styles */
.booking-content[b-wnqmugsuzv] {
    padding: 16px;
}

.detail-grid[b-wnqmugsuzv] {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.detail-left[b-wnqmugsuzv] {
    width: 100%;
    order: 2;
}

.detail-right[b-wnqmugsuzv] {
    width: 100%;
    order: 1;
}

.detail-attachments[b-wnqmugsuzv] {
    width: 100%;
    order: 3;
}

.attachment-link[b-wnqmugsuzv] {
    border: 0;
    border-radius: 8px;
    padding: 6px 10px;
}

@media (min-width: 768px) {
    .booking-detail-container[b-wnqmugsuzv] {
        padding-top: 0;
        margin-left: 156px;
        padding-bottom: 0;
    }

    .booking-content[b-wnqmugsuzv] {
        padding: 32px 40px;
    }

    .detail-grid[b-wnqmugsuzv] {
        display: grid;
        grid-template-columns: 1fr 320px;
        grid-template-rows: auto auto;
        gap: 32px;
        align-items: start;
    }

    .detail-left[b-wnqmugsuzv] {
        width: 100%;
        min-width: 0;
        order: 0;
        grid-column: 1;
        grid-row: 1 / 3;
    }

    .detail-right[b-wnqmugsuzv] {
        width: 100%;
        position: sticky;
        top: 32px;
        order: 0;
        grid-column: 2;
        grid-row: 1;
    }

    .detail-attachments[b-wnqmugsuzv] {
        width: 100%;
        order: 0;
        grid-column: 2;
        grid-row: 2;
    }

    /* When there are no stops, show details/attachments on the left in single column */
    .detail-grid.no-stops[b-wnqmugsuzv] {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto;
    }

    .detail-grid.no-stops .detail-left[b-wnqmugsuzv] {
        display: none;
    }

    .detail-grid.no-stops .detail-right[b-wnqmugsuzv] {
        grid-column: 1;
        grid-row: 1;
        position: static;
    }

    .detail-grid.no-stops .detail-attachments[b-wnqmugsuzv] {
        grid-column: 1;
        grid-row: 2;
    }
}

@media (min-width: 1200px) {
    .detail-grid[b-wnqmugsuzv] {
        grid-template-columns: 1fr 400px;
    }
}

/* Warning Banner */
.warning-banner[b-wnqmugsuzv] {
    background-color: #fff3cd;
    border: 1px solid #ffc107;
    border-left: 4px solid #ff9800;
    border-radius: 8px;
    padding: 12px 16px;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 12px;
}

@media (min-width: 768px) {
    .warning-banner[b-wnqmugsuzv] {
        margin-bottom: 24px;
    }
}

.warning-icon[b-wnqmugsuzv] {
    color: #ff9800;
    font-size: 18px;
    flex-shrink: 0;
}

.warning-text[b-wnqmugsuzv] {
    color: #856404;
    font-size: 14px;
    font-weight: 600;
    flex: 1;
}

/* Client Section */
.client-section[b-wnqmugsuzv] {
    background: white;
    border-radius: 12px;
    padding: 16px;
    margin-bottom: 0;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

@media (min-width: 768px) {
    .client-section[b-wnqmugsuzv] {
        padding: 24px;
    }
}

.client-info[b-wnqmugsuzv] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 16px;
}

.client-label[b-wnqmugsuzv] {
    font-size: 11px;
    color: #999;
    font-weight: 600;
    letter-spacing: 1px;
    margin-bottom: 4px;
    display: block;
}

.client-name[b-wnqmugsuzv] {
    font-size: 16px;
    font-weight: bold;
    color: #333;
    margin: 0 0 4px 0;
}

.client-ref[b-wnqmugsuzv] {
    font-size: 13px;
    color: #666;
    margin: 0;
}

.status-info[b-wnqmugsuzv] {
    text-align: right;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
}

.status-badge[b-wnqmugsuzv] {
    background-color: #bdbdbd;
    color: #FFF;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: bold;
    letter-spacing: 0.5px;
    min-width: max-content;
}

/* Info Grid */
.info-grid[b-wnqmugsuzv] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.info-card[b-wnqmugsuzv] {
    background: #f8f8f8;
    padding: 12px;
    border-radius: 8px;
    position: relative;
}

.info-card-seal[b-wnqmugsuzv] {
    grid-column: span 2;
}

.info-header[b-wnqmugsuzv] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
    height: 26px;
}

.info-icon-label[b-wnqmugsuzv] {
    display: flex;
    align-items: center;
    gap: 6px;
}

.edit-btn[b-wnqmugsuzv] {
    background: transparent;
    border: none;
    color: #999;
    padding: 4px;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.2s;
    font-size: 12px;
}

.edit-btn:hover[b-wnqmugsuzv] {
    color: #eed484;
    background: rgba(255, 210, 0, 0.1);
}

.info-icon[b-wnqmugsuzv] {
    color: #999;
    font-size: 12px;
}

.info-label[b-wnqmugsuzv] {
    font-size: 10px;
    font-weight: bold;
    color: #666;
    letter-spacing: 1px;
}

.info-value[b-wnqmugsuzv] {
    font-size: 14px;
    font-weight: bold;
    color: #333;
    margin: 0 0 4px 0;
}

.info-detail[b-wnqmugsuzv] {
    font-size: 11px;
    color: #999;
    margin: 0;
}

/* Section Titles */
.section-title[b-wnqmugsuzv] {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    font-weight: bold;
    color: #333;
    letter-spacing: 1px;
    margin: 16px 0px 12px 0px;
    padding: 0;
}

@media (min-width: 768px) {
    .section-title[b-wnqmugsuzv] {
        margin: 0px 0px 20px 0px;
        font-size: 13px;
    }

    .client-section + .section-title[b-wnqmugsuzv] {
        margin-top: 32px;
    }
}

.section-icon[b-wnqmugsuzv] {
    color: #eed484;
    font-size: 14px;
}

/* Timeline container for stop cards */
[b-wnqmugsuzv] .timeline {
    position: relative;
    padding-left: 50px;
}

/* Vertical line connecting the stops */
[b-wnqmugsuzv] .timeline .stop-card:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 40px;
    left: -33px;
    width: 3px;
    height: calc(100% + 12px);
    background: #eed484;
    border-radius: 2px;
    z-index: 0;
}

/* Attachments Section */
.attachments-header[b-wnqmugsuzv] {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    font-weight: 600;
    color: #EED484;
    margin-bottom: 16px;
    padding: 0 16px;
}

.attachment-count[b-wnqmugsuzv] {
    color: #333;
    font-weight: 600;
}

@media (min-width: 768px) {
    .attachments-header[b-wnqmugsuzv] {
        padding: 0;
        margin-bottom: 20px;
        font-size: 13px;
    }
}

.attachments-section[b-wnqmugsuzv] {
    background: white;
    border-radius: 12px;
    padding: 16px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

@media (min-width: 768px) {
    .attachments-section[b-wnqmugsuzv] {
        padding: 24px;
        margin: 0;
    }
}

.attachments-list[b-wnqmugsuzv] {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.attachment-item[b-wnqmugsuzv] {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    background: #f8f8f8;
    border-radius: 8px;
    margin-bottom: 8px;
    transition: background 0.2s;
}

@media (min-width: 768px) {
    .attachment-item[b-wnqmugsuzv] {
        padding: 16px;
        margin-bottom: 0;
    }
    
    .attachment-item:hover[b-wnqmugsuzv] {
        background: #f0f0f0;
    }
}

.attachment-icon[b-wnqmugsuzv] {
    width: 40px;
    height: 40px;
    background-color: #f8f8f8;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #eed484;
    font-size: 16px;
}

.attachment-info[b-wnqmugsuzv] {
    flex: 1;
}

.attachment-name[b-wnqmugsuzv] {
    font-size: 14px;
    font-weight: bold;
    color: #333;
    margin: 0 0 2px 0;
}

.attachment-time[b-wnqmugsuzv] {
    font-size: 11px;
    color: #999;
    margin: 0;
}

.attachment-download[b-wnqmugsuzv] {
    background: #f5f5f5;
    border: none;
    border-radius: 6px;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: #666;
    font-size: 14px;
    flex-shrink: 0;
}

.attachment-download:hover[b-wnqmugsuzv] {
    background: #e5e5e5;
}

.attachment-download:active[b-wnqmugsuzv] {
    background: #d5d5d5;
}

/* Take Photo Button */
.photo-button-container[b-wnqmugsuzv] {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    padding: 16px;
    background: linear-gradient(to top, rgba(245,245,245,1) 70%, rgba(245,245,245,0));
    z-index: 50;
}

@media (min-width: 768px) {
    .photo-button-container[b-wnqmugsuzv] {
        display: none;
    }
}

.take-photo-btn[b-wnqmugsuzv] {
    width: 100%;
    background-color: #eed484;
    color: #333;
    border: none;
    border-radius: 50px;
    padding: 16px;
    font-size: 14px;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    cursor: pointer;
    transition: all 0.2s;
}

@media (min-width: 768px) {
    .take-photo-btn[b-wnqmugsuzv] {
        max-width: 280px;
        margin-left: auto;
        padding: 18px 32px;
        font-size: 15px;
    }
}

.take-photo-btn:hover[b-wnqmugsuzv] {
    background-color: #e5c76e;
    transform: translateY(-2px);
}

.take-photo-btn:active[b-wnqmugsuzv] {
    transform: translateY(0);
}

/* Sidebar Photo Button (Desktop Only) */
.sidebar-photo-btn[b-wnqmugsuzv] {
    display: none;
}

@media (min-width: 768px) {
    .sidebar-photo-btn[b-wnqmugsuzv] {
        display: flex;
        align-items: center;
        gap: 10px;
        width: 100%;
        border: none;
        background: transparent;
        color: #999;
        font-size: 12px;
        font-weight: 500;
        border-radius: 8px;
        cursor: pointer;
        transition: all 0.2s;
        margin-top: 24px;
        text-align: left;
        padding: 8px;
        line-height: 21px;
    }

    .sidebar-photo-btn:hover[b-wnqmugsuzv] {
        background: rgba(255, 255, 255, 0.05);
        color: white;
    }

    .sidebar-photo-btn i[b-wnqmugsuzv] {
        flex-shrink: 0;
        width: 20px;
        height: 20px;
        font-size: 16px;
    }

    .sidebar-photo-btn span[b-wnqmugsuzv] {
        flex: 1;
    }
}

/* Sidebar Upload Button (Desktop Only) */
.sidebar-upload-btn[b-wnqmugsuzv] {
    display: none;
}

@media (min-width: 768px) {
    .sidebar-upload-btn[b-wnqmugsuzv] {
        display: flex;
        align-items: center;
        gap: 10px;
        width: 100%;
        border: none;
        background: transparent;
        color: #999;
        font-size: 12px;
        font-weight: 500;
        border-radius: 8px;
        cursor: pointer;
        transition: all 0.2s;
        margin-top: 4px;
        text-align: left;
        padding: 8px;
        line-height: 21px;
    }

    .sidebar-upload-btn:hover[b-wnqmugsuzv] {
        background: rgba(255, 255, 255, 0.05);
        color: white;
    }

    .sidebar-upload-btn i[b-wnqmugsuzv] {
        flex-shrink: 0;
        width: 20px;
        height: 20px;
        font-size: 16px;
    }

    .sidebar-upload-btn span[b-wnqmugsuzv] {
        flex: 1;
    }
}

/* Loading Spinner */
.loading-container[b-wnqmugsuzv] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    color: #666;
}

.spinner[b-wnqmugsuzv] {
    width: 40px;
    height: 40px;
    border: 3px solid #f0f0f0;
    border-top: 3px solid #eed484;
    border-radius: 50%;
    animation: spin-b-wnqmugsuzv 1s linear infinite;
    margin-bottom: 16px;
}

@keyframes spin-b-wnqmugsuzv {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

.status-1 .status-badge[b-wnqmugsuzv] { background: #eed484; }
.status-2 .status-badge[b-wnqmugsuzv] { background: #22c55e; }
.status-3 .status-badge[b-wnqmugsuzv] { background: #f59e42; }
.status-4 .status-badge[b-wnqmugsuzv] { background: #3b82f6; }
.status-5 .status-badge[b-wnqmugsuzv] { background: #14b8a6; }
.status-6 .status-badge[b-wnqmugsuzv] { background: #ef4444; }
.status-7 .status-badge[b-wnqmugsuzv] { background: #6b7280; }
.status-8 .status-badge[b-wnqmugsuzv] { background: #a855f7; }
/* /Pages/Home.razor.rz.scp.css */
/* Home page layout */
.home-page[b-pwv9mffooq] {
    position: fixed;
    top: 130px;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    padding: 0;
}

/* Page header */
.home-header[b-pwv9mffooq] {
    flex-shrink: 0;
}

.booking-list-shadow[b-pwv9mffooq] {
    position: fixed;
    width: 100%;
    height: 6px;
    z-index: 10;
    padding: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0.10) 0%, rgba(0,0,0,0.03) 60%, rgba(0,0,0,0) 100%);
}

/* Search */
.search-container[b-pwv9mffooq] {
    margin-bottom: 14px;
    padding: 20px 20px 0 20px;
}

.search-filter-row[b-pwv9mffooq] {
    display: flex;
    gap: 8px;
    align-items: center;
}

.search-box[b-pwv9mffooq] {
    position: relative;
    display: flex;
    flex: 1;
    align-items: center;
    background: white;
    border-radius: 12px;
    padding: 0 16px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.search-icon[b-pwv9mffooq] {
    color: #999;
    flex-shrink: 0;
}

.search-input[b-pwv9mffooq] {
    flex: 1;
    border: none;
    background: transparent;
    padding: 14px 12px;
    font-size: 15px;
    color: #333;
    outline: none;
}

.search-input[b-pwv9mffooq]::placeholder {
    color: #999;
}

/* View toggle buttons */
.view-toggle[b-pwv9mffooq] {
    display: flex;
    gap: 4px;
    background: white;
    border-radius: 12px;
    padding: 4px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    margin-left: auto;
}

.view-toggle-btn[b-pwv9mffooq] {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: transparent;
    border: none;
    border-radius: 8px;
    color: #666;
    cursor: pointer;
    font-size: 16px;
    transition: all 0.2s ease;
}

.view-toggle-btn:hover[b-pwv9mffooq] {
    background: #f8f8f8;
    color: #333;
}

.view-toggle-btn.active[b-pwv9mffooq] {
    background: #eed484;
    color: #000;
}

.view-toggle-btn:active[b-pwv9mffooq] {
    transform: scale(0.95);
}

/* Greeting (hidden on mobile) */
.page-greeting[b-pwv9mffooq] {
    display: none;
}

.home-header-row[b-pwv9mffooq] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.greeting-content[b-pwv9mffooq] {
    flex: 1;
    min-width: 0;
}

.home-header-actions[b-pwv9mffooq] {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-left: auto;
}

.home-header-actions :deep(.language-btn)[b-pwv9mffooq] {
    color: #1a1a1a;
    border: 1px solid #ddd;
    background: #fff;
}

.home-header-actions :deep(.language-btn:hover)[b-pwv9mffooq] {
    background: #f5f5f5;
    border-color: #ccc;
}

.greeting-title[b-pwv9mffooq] {
    font-size: 28px;
    font-weight: 600;
    color: #1a1a1a;
    margin: 0 0 4px 0;
}

.greeting-subtitle[b-pwv9mffooq] {
    font-size: 15px;
    color: #666;
    margin: 0;
}

/* Booking lists container and animations */
.booking-lists-wrapper[b-pwv9mffooq] {
    position: relative;
    flex: 1;
    overflow: hidden;
}

.lists-static-loader[b-pwv9mffooq] {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 20;
    display: flex;
    justify-content: center;
    align-items: center;
    padding-top: 24px;
    pointer-events: none;
}

.lists-static-loader-spinner[b-pwv9mffooq] {
    width: 40px;
    height: 40px;
    border: 3px solid #f0f0f0;
    border-top: 3px solid #eed484;
    border-radius: 50%;
    animation: home-lists-spin-b-pwv9mffooq 1s linear infinite;
}

@keyframes home-lists-spin-b-pwv9mffooq {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}

.booking-list-container[b-pwv9mffooq] {
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100%;
    transition: transform 0.4s cubic-bezier(0.4,0,0.2,1), opacity 0.4s cubic-bezier(0.4,0,0.2,1);
    will-change: transform, opacity;
}

/* New bookings animations */
.booking-list-container.new[b-pwv9mffooq] {
    z-index: 3;
}

.booking-list-container.new.slide-in[b-pwv9mffooq] {
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
}

.booking-list-container.new.slide-out[b-pwv9mffooq] {
    transform: translateX(-100vw);
    opacity: 0;
    pointer-events: none;
}

/* In progress bookings animations */
.booking-list-container.inprogress[b-pwv9mffooq] {
    z-index: 2;
}

.booking-list-container.inprogress.slide-in[b-pwv9mffooq] {
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
}

.booking-list-container.inprogress.slide-out[b-pwv9mffooq] {
    transform: translateX(-100vw);
    opacity: 0;
    pointer-events: none;
}

/* Completed bookings animations */
.booking-list-container.completed[b-pwv9mffooq] {
    z-index: 1;
}

.booking-list-container.completed.slide-in[b-pwv9mffooq] {
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
}

.booking-list-container.completed.slide-out[b-pwv9mffooq] {
    transform: translateX(-100vw);
    opacity: 0;
    pointer-events: none;
}

/* Desktop layout with sidebar */
@media (min-width: 768px) {
    .home-page[b-pwv9mffooq] {
        left: 156px;
        top: 0;
    }

    .home-header[b-pwv9mffooq] {
        background: white;
        padding-top: 32px;
    }

    .page-greeting[b-pwv9mffooq] {
        display: block;
        padding: 0 40px 16px 40px;
        background: white;
        border-bottom: 1px solid #f5f5f5;
    }

    .search-container[b-pwv9mffooq] {
        padding: 20px 40px 20px 40px;
        width: 100%;;
        margin-bottom: 0 !important;
    }

    .search-box[b-pwv9mffooq] {
        max-width: 600px;
    }

    .mobile-only[b-pwv9mffooq] {
        display: none;
    }

    .booking-list-container[b-pwv9mffooq] {
        width: 100%;
    }

    /* Grid view for desktop */
    [b-pwv9mffooq] .booking-list-wrapper.grid-view {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
        gap: 20px;
        padding: 20px 20px 20px 40px;
    }

    [b-pwv9mffooq] .booking-list-wrapper.list-view {
        display: flex;
        flex-direction: column;
        gap: 0;
        padding: 20px 20px 20px 40px;
    }
}
/* /Pages/Login.razor.rz.scp.css */
/* Logo top center on MSC yellow background */
.logo-top-bg[b-2j7j6xlz3h] {
    width: 100vw;
    background: linear-gradient(0deg, rgba(0,0,0,0.10), rgba(0,0,0,0)), #EED484;
    padding-top: 20px;
    padding-bottom: 20px;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 3000;
}
.logo-top-content[b-2j7j6xlz3h] {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 0 20px;
    position: relative;
}
.login-language[b-2j7j6xlz3h] {
    position: absolute;
    right: 20px;
}
.login-language :deep(.language-btn)[b-2j7j6xlz3h] {
    color: #1a1a1a;
    border: 1px solid rgba(0, 0, 0, 0.2);
    background: rgba(255, 255, 255, 0.6);
}
.login-language :deep(.language-btn:hover)[b-2j7j6xlz3h] {
    background: rgba(255, 255, 255, 0.85);
    border-color: rgba(0, 0, 0, 0.3);
}
.logo[b-2j7j6xlz3h] {
    max-width: 180px;
    width: 70%;
    height: auto;
    display: block;
}
/* Login Page */
.login-page[b-2j7j6xlz3h] {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0.5) 100%), url(../images/msc_truck.png) center / cover no-repeat;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding: 20px;
}

.login-container[b-2j7j6xlz3h] {
    width: 100%;
    max-width: 320px;
    text-align: center;
}

.content-container[b-2j7j6xlz3h] {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 80px;
}

.subtitle[b-2j7j6xlz3h] {
    margin-top: 0;
    margin-bottom: 1rem;
    color: white;
    text-shadow: 2px 2px 10px rgba(0, 0, 0, 0.95), 0px 0px 20px rgba(0, 0, 0, 0.8);
    font-family: Roboto, sans-serif;
}

.btn-login[b-2j7j6xlz3h] {
    width: 100%;
    background:#EED484;
    border: none;
    border-radius: 1rem;
    padding: 18px;
    font-size: 16px;
    font-weight: 700;
    color: #000;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    letter-spacing: 1.5px;
    margin-bottom: 16px;
}

.btn-login .arrow[b-2j7j6xlz3h] {
    font-size: larger;
    transition: transform 300ms;
}

.btn-login:hover .arrow[b-2j7j6xlz3h] {
    transform: translateX(5px);
}

/* Loading State */
.loading-container[b-2j7j6xlz3h] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    padding: 20px;
}

.spinner[b-2j7j6xlz3h] {
    width: 50px;
    height: 50px;
    border: 4px solid rgba(238, 212, 132, 0.3);
    border-top: 4px solid #EED484;
    border-radius: 50%;
    animation: spin-b-2j7j6xlz3h 1s linear infinite;
}

@keyframes spin-b-2j7j6xlz3h {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

.loading-text[b-2j7j6xlz3h] {
    color: white;
    font-size: 16px;
    font-weight: 500;
    text-shadow: 2px 2px 10px rgba(0, 0, 0, 0.95);
    margin: 0;
}
