/**
 * Global Modal Styles
 * Ensures consistent modal behavior across the application
 */

.modal {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 1050 !important;
    background-color: rgba(0, 0, 0, 0.5) !important;
    overflow-x: hidden;
    overflow-y: auto;
    outline: 0;
    display: none; /* Default state is hidden */
}

.modal.show {
    display: flex !important; /* Force flex display when shown */
    align-items: center !important;
    justify-content: center !important;
    opacity: 1 !important;
    visibility: visible !important;
}

.modal-dialog {
    position: relative !important;
    width: auto !important;
    margin: 0.5rem auto !important;
    pointer-events: auto !important;
    max-width: 500px !important;
    z-index: 1051 !important; /* Higher than modal backdrop */
    transform: translate(0, 0) !important; /* Reset any transforms */
}

.modal-dialog.modal-lg {
    max-width: 800px !important;
}

.modal-dialog.modal-xl {
    max-width: 1140px !important;
}

.modal-content {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    pointer-events: auto !important;
    background-color: #fff !important;
    background-clip: padding-box !important;
    border: 1px solid rgba(0, 0, 0, 0.2) !important;
    border-radius: 0.3rem !important;
    outline: 0 !important;
    box-shadow: 0 0.25rem 0.5rem rgba(0, 0, 0, 0.15) !important;
    transform: none !important; /* Prevent any transform issues */
    opacity: 1 !important; /* Ensure visibility */
}

.modal-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 1rem !important;
    border-bottom: 1px solid #e9ecef !important;
    border-top-left-radius: 0.3rem !important;
    border-top-right-radius: 0.3rem !important;
    z-index: 1052 !important; /* Ensure header is above content */
}

.modal-header h3, 
.modal-header h4,
.modal-header h5 {
    margin: 0 !important;
    line-height: 1.5 !important;
    font-weight: 500 !important;
}

.modal-close {
    float: right !important;
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    color: #000 !important;
    text-shadow: 0 1px 0 #fff !important;
    opacity: 0.5 !important;
    padding: 0 !important;
    background-color: transparent !important;
    border: 0 !important;
    appearance: none !important;
    cursor: pointer !important;
    z-index: 1053 !important; /* Ensure close button is clickable */
}

.modal-close:hover {
    color: #000 !important;
    text-decoration: none !important;
    opacity: 0.75 !important;
}

.modal-body {
    position: relative !important;
    flex: 1 1 auto !important;
    padding: 1rem !important;
    overflow-y: auto !important; /* Allow scrolling in the body if needed */
    z-index: 1052 !important; /* Ensure body content is above backdrop */
}

.modal-footer {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: flex-end !important;
    padding: 0.75rem !important;
    border-top: 1px solid #e9ecef !important;
    border-bottom-right-radius: 0.3rem !important;
    border-bottom-left-radius: 0.3rem !important;
    z-index: 1052 !important; /* Ensure footer is above backdrop */
}

.modal-footer > * {
    margin: 0.25rem !important;
}

body.modal-open {
    overflow: hidden !important;
    padding-right: 17px !important; /* Compensate for scrollbar disappearance */
}

@media (min-width: 576px) {
    .modal-dialog {
        margin: 1.75rem auto !important;
        max-width: 500px !important;
    }
    
    .modal-dialog.modal-lg {
        max-width: 800px !important;
    }
    
    .modal-dialog.modal-xl {
        max-width: 1140px !important;
    }
}

.invoice-modal .modal-dialog,
#viewInvoiceModal .modal-dialog {
    max-width: 850px !important;
}

.payment-modal .modal-dialog,
#updatePaymentModal .modal-dialog {
    max-width: 650px !important;
}

#viewInvoiceModal.modal {
    display: none;
}

#viewInvoiceModal.modal.show {
    display: flex !important;
}

#updatePaymentModal.modal {
    display: none;
}

#updatePaymentModal.modal.show {
    display: flex !important;
}

.modal-backdrop {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 1040 !important; /* Below modal but above everything else */
    background-color: #000 !important;
    opacity: 0.5 !important;
}

@supports (display: flex) {
    .modal.show {
        display: flex !important;
    }
}

@supports not (display: flex) {
    .modal.show {
        display: block !important;
    }
    
    .modal-dialog {
        margin: 10vh auto !important; /* Center vertically without flex */
    }
}
