/* Bit Modal Component Styles */

/* Base modal styles */
.modal.bit-modal {
    --modal-border-radius: 12px;
}

.modal.bit-modal .modal-content {
    border-radius: var(--modal-border-radius);
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
    border: 1px solid #e2e8f0;
    overflow: hidden;
    position: relative;
}

/* Base modal header */
.modal.bit-modal .modal-header {
    padding: 0.75rem 1.25rem;
    background: white;
    position: relative;
    display: flex;
    align-items: flex-start;
    border-bottom: 1px solid #e9ecef;
}

.modal.bit-modal .modal-header .modal-title-wrapper {
    display: flex;
    flex-direction: column;
    gap: 0;
    flex: 1;
}

.modal.bit-modal .modal-header .modal-title {
    font-weight: 600;
    color: #1a202c;
    line-height: 1.2;
    margin: 0;
    display: block;
}

.modal.bit-modal .modal-header .modal-title i {
    font-size: 1.25rem;
    margin-right: 0.5rem;
}

.modal.bit-modal .modal-header .modal-subtitle {
    font-size: 0.875rem;
    color: #718096;
    margin-top: 0.25rem;
    font-weight: 400;
    line-height: 1.4;
}

.modal.bit-modal .modal-header small {
    font-size: 0.875rem;
    color: #718096;
    margin-top: 0.25rem;
    font-weight: 400;
}

.modal.bit-modal .modal-body {
    padding: 1.5rem;
    background: #ffffff;
}

.modal.bit-modal .modal-footer {
    padding: 1rem 1.5rem;
    background: #f9fafb;
    border-top: 1px solid #e9ecef;
}

/* Generic variant styling using local CSS variables */
.modal.bit-modal[class*="bit-modal-"] {
    /* Default values that will be overridden by each variant */
    --modal-color: var(--bit-primary, #0d6efd);
    --modal-fg-color: white;
    --modal-icon-color: var(--modal-color);
    --header-light-mix: 8%;
    --header-lighter-mix: 3%;
    --border-mix: 15%;
    --border-bottom-mix: 15%;
    --accent-width: 4px;
}

/* Apply variant styles */
.modal.bit-modal[class*="bit-modal-"] .modal-content {
    border: 1px solid color-mix(in srgb, var(--modal-color) var(--border-mix), white);
}

.modal.bit-modal[class*="bit-modal-"] .modal-header {
    background: linear-gradient(135deg, 
        color-mix(in srgb, var(--modal-color) var(--header-light-mix), white) 0%, 
        color-mix(in srgb, var(--modal-color) var(--header-lighter-mix), white) 100%);
    border-bottom: 1px solid color-mix(in srgb, var(--modal-color) var(--border-bottom-mix), #e9ecef);
}

/*!* Left accent bar for modal *!*/
/*.modal.bit-modal[class*="bit-modal-"] .modal-content::before {*/
/*    content: '';*/
/*    position: absolute;*/
/*    left: 0;*/
/*    top: 0;*/
/*    width: var(--accent-width);*/
/*    height: 100%;*/
/*    background: linear-gradient(180deg, */
/*        var(--modal-color) 0%, */
/*        color-mix(in srgb, var(--modal-color) 40%, transparent) 100%);*/
/*    border-radius: var(--modal-border-radius) 0 0 var(--modal-border-radius);*/
/*    z-index: 1;*/
/*}*/

/* Icon color in header */
.modal.bit-modal[class*="bit-modal-"] .modal-header .modal-title i {
    color: var(--modal-icon-color);
}

/* Close button styling */
.modal.bit-modal[class*="bit-modal-"] .modal-header .btn-close {
    opacity: 0.6;
    transition: opacity 0.2s ease;
}

.modal.bit-modal[class*="bit-modal-"] .modal-header .btn-close:hover {
    opacity: 1;
}

/* Define variant-specific variables */
.modal.bit-modal.bit-modal-primary {
    --modal-color: var(--bit-primary, #0d6efd);
    --modal-icon-color: var(--bit-primary, #0d6efd);
}

.modal.bit-modal.bit-modal-secondary {
    --modal-color: var(--bit-secondary, #6c757d);
    --modal-icon-color: var(--bit-secondary, #6c757d);
}

.modal.bit-modal.bit-modal-success {
    --modal-color: var(--bit-success, #198754);
    --modal-icon-color: var(--bit-success, #198754);
}

.modal.bit-modal.bit-modal-danger {
    --modal-color: var(--bit-danger, #dc3545);
    --modal-icon-color: var(--bit-danger, #dc3545);
}

.modal.bit-modal.bit-modal-warning {
    --modal-color: var(--bit-warning, #ffc107);
    --modal-icon-color: color-mix(in srgb, var(--bit-warning, #ffc107) 90%, black);
    --header-light-mix: 12%;
    --header-lighter-mix: 5%;
    --border-mix: 20%;
    --border-bottom-mix: 25%;
}

.modal.bit-modal.bit-modal-info {
    --modal-color: var(--bit-info, #0dcaf0);
    --modal-icon-color: color-mix(in srgb, var(--bit-info, #0dcaf0) 80%, black);
}

.modal.bit-modal.bit-modal-light {
    --modal-color: var(--bit-light, #f8f9fa);
    --modal-icon-color: #6c757d;
    --header-light-mix: 50%;
    --header-lighter-mix: 80%;
    --border-mix: 100%;
    --border-bottom-mix: 60%;
}

/* Light variant special cases */
.modal.bit-modal.bit-modal-light .modal-content {
    border: 1px solid var(--bit-light, #f8f9fa);
}

.modal.bit-modal.bit-modal-light .modal-header {
    background: linear-gradient(135deg, 
        color-mix(in srgb, var(--bit-light, #f8f9fa) 50%, #e9ecef) 0%, 
        color-mix(in srgb, var(--bit-light, #f8f9fa) 80%, white) 100%);
    border-bottom: 1px solid color-mix(in srgb, var(--bit-light, #f8f9fa) 60%, #dee2e6);
}

.modal.bit-modal.bit-modal-light .modal-content::before {
    background: linear-gradient(180deg, 
        #adb5bd 0%, 
        color-mix(in srgb, #adb5bd 40%, transparent) 100%);
}

.modal.bit-modal.bit-modal-dark {
    --modal-color: var(--bit-dark, #212529);
    --modal-icon-color: var(--bit-dark, #212529);
    --header-light-mix: 8%;
    --header-lighter-mix: 3%;
    --border-bottom-mix: 20%;
}

.modal.bit-modal.bit-modal-default {
    --modal-color: var(--bit-default, #2d3748);
    --modal-icon-color: var(--bit-default, #2d3748);
    --border-bottom-mix: 20%;
}

.modal.bit-modal.bit-modal-accent {
    --modal-color: var(--bit-accent, #805ad5);
    --modal-icon-color: var(--bit-accent, #805ad5);
    --border-bottom-mix: 20%;
}

/* Modal sizes enhancement */
.modal.bit-modal .modal-dialog.modal-sm .modal-content {
    --accent-width: 3px;
}

.modal.bit-modal .modal-dialog.modal-lg .modal-content,
.modal.bit-modal .modal-dialog.modal-xl .modal-content {
    --accent-width: 5px;
}

/* Animation enhancements */
.modal.bit-modal.fade .modal-dialog {
    transition: transform 0.3s ease-out;
}

.modal.bit-modal.show .modal-dialog {
    transform: none;
}

/* Responsive adjustments */
@media (max-width: 576px) {
    .modal.bit-modal .modal-header {
        padding: 1rem;
    }
    
    .modal.bit-modal .modal-body {
        padding: 1rem;
    }
    
    .modal.bit-modal .modal-footer {
        padding: 0.75rem 1rem;
    }
}

/* Utility classes for modal states */
.modal.bit-modal.bit-modal-loading .modal-body {
    position: relative;
    min-height: 150px;
}

.modal.bit-modal.bit-modal-loading .modal-body::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255, 255, 255, 0.8);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
}

/* Footer button styling consistency */
.modal.bit-modal .modal-footer .btn {
    min-width: 100px;
}

.modal.bit-modal .modal-footer .btn + .btn {
    margin-left: 0.5rem;
}