/* Custom SweetAlert Styles for Bassap Design */

/* Main Modal Container */
.swal2-popup {
    font-family: var(--bassap-font) !important;
    background-color: var(--bassap-white) !important;
    border-radius: var(--border-radius-lg) !important;
    box-shadow: 0 10px 25px var(--bassap-shadow-lg) !important;
    border: 1px solid var(--bassap-border-color) !important;
    padding: 2rem !important;
}

/* Title Styling */
.swal2-title {
    font-family: var(--bassap-heading-font) !important;
    color: var(--bassap-text-dark) !important;
    font-size: 1.5rem !important;
    font-weight: 600 !important;
    margin-bottom: 1rem !important;
}

/* Content Text */
.swal2-html-container {
    font-family: var(--bassap-font) !important;
    color: var(--bassap-text) !important;
    font-size: 1rem !important;
    line-height: 1.6 !important;
    margin-bottom: 1.5rem !important;
}

/* Input Fields */
.swal2-input {
    font-family: var(--bassap-font) !important;
    background-color: var(--bassap-white2) !important;
    border: 1px solid var(--bassap-border-color) !important;
    border-radius: var(--border-radius) !important;
    color: var(--bassap-text-dark) !important;
    padding: 0.75rem 1rem !important;
    font-size: 1rem !important;
    transition: all 0.3s ease !important;
}

.swal2-input:focus {
    border-color: var(--bassap-primary) !important;
    box-shadow: 0 0 0 3px rgba(var(--bassap-primary-rgb), 0.1) !important;
    outline: none !important;
}

.swal2-input::placeholder {
    color: var(--bassap-text-gray) !important;
}

/* Button Styling */
.swal2-actions {
    gap: 1rem !important;
    margin-top: 1.5rem !important;
}

/* Confirm Button (Primary) */
.swal2-confirm {
    background-color: var(--bassap-primary) !important;
    border: none !important;
    border-radius: var(--border-radius) !important;
    color: var(--bassap-white) !important;
    font-family: var(--bassap-font) !important;
    font-weight: 500 !important;
    padding: 0.75rem 1.5rem !important;
    font-size: 1rem !important;
    transition: all 0.3s ease !important;
    cursor: pointer !important;
}

.swal2-confirm:hover {
    background-color: var(--bassap-base) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(var(--bassap-primary-rgb), 0.3) !important;
}

.swal2-confirm:focus {
    box-shadow: 0 0 0 3px rgba(var(--bassap-primary-rgb), 0.3) !important;
    outline: none !important;
}

/* Cancel Button */
.swal2-cancel {
    background-color: var(--bassap-gray2) !important;
    border: 1px solid var(--bassap-border-color) !important;
    border-radius: var(--border-radius) !important;
    color: var(--bassap-text-dark) !important;
    font-family: var(--bassap-font) !important;
    font-weight: 500 !important;
    padding: 0.75rem 1.5rem !important;
    font-size: 1rem !important;
    transition: all 0.3s ease !important;
    cursor: pointer !important;
}

.swal2-cancel:hover {
    background-color: var(--bassap-gray3) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px var(--bassap-shadow) !important;
}

.swal2-cancel:focus {
    box-shadow: 0 0 0 3px rgba(var(--bassap-gray-rgb), 0.3) !important;
    outline: none !important;
}

/* Deny Button */
.swal2-deny {
    background-color: var(--bassap-error) !important;
    border: none !important;
    border-radius: var(--border-radius) !important;
    color: var(--bassap-white) !important;
    font-family: var(--bassap-font) !important;
    font-weight: 500 !important;
    padding: 0.75rem 1.5rem !important;
    font-size: 1rem !important;
    transition: all 0.3s ease !important;
    cursor: pointer !important;
}

.swal2-deny:hover {
    background-color: #c0392b !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(var(--bassap-error-rgb), 0.3) !important;
}

/* Icon Styling */
.swal2-icon {
    margin: 1rem auto 1.5rem !important;
}

.swal2-icon.swal2-success {
    border-color: var(--bassap-success) !important;
    color: var(--bassap-success) !important;
}

.swal2-icon.swal2-success .swal2-success-ring {
    border-color: rgba(var(--bassap-success-rgb), 0.3) !important;
}

.swal2-icon.swal2-success [class^='swal2-success-line'] {
    background-color: var(--bassap-success) !important;
}

.swal2-icon.swal2-error {
    border-color: var(--bassap-error) !important;
    color: var(--bassap-error) !important;
}

.swal2-icon.swal2-error .swal2-x-mark {
    color: var(--bassap-error) !important;
}

.swal2-icon.swal2-warning {
    border-color: var(--bassap-warning) !important;
    color: var(--bassap-warning) !important;
}

.swal2-icon.swal2-info {
    border-color: var(--bassap-info) !important;
    color: var(--bassap-info) !important;
}

.swal2-icon.swal2-question {
    border-color: var(--bassap-primary) !important;
    color: var(--bassap-primary) !important;
}

/* Progress Bar */
.swal2-timer-progress-bar {
    background-color: var(--bassap-primary) !important;
}

/* Close Button */
.swal2-close {
    color: var(--bassap-text-gray) !important;
    font-size: 1.5rem !important;
    transition: all 0.3s ease !important;
}

.swal2-close:hover {
    color: var(--bassap-error) !important;
    transform: scale(1.1) !important;
}

/* Loading Spinner */
.swal2-loader {
    border-color: var(--bassap-primary) transparent var(--bassap-primary) transparent !important;
}

/* Backdrop */
.swal2-container {
    /*background-color: rgba(var(--bassap-black-rgb), 0.8) !important;*/
}

/* Toast Positioning */
.swal2-toast {
    background-color: var(--bassap-white) !important;
    border: 1px solid var(--bassap-border-color) !important;
    border-radius: var(--border-radius) !important;
    box-shadow: 0 4px 12px var(--bassap-shadow) !important;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.swal2-toast .swal2-title {
    color: var(--bassap-text-dark) !important;
    font-family: var(--bassap-font) !important;
    margin: auto !important;
    font-size: 0.9rem !important;
}

.swal2-toast .swal2-html-container {
    color: var(--bassap-text) !important;
    font-family: var(--bassap-font) !important;
    font-size: 0.8rem !important;
}

/* Responsive Design */
@media (max-width: 768px) {
    .swal2-popup {
        padding: 1.5rem !important;
        margin: 1rem !important;
    }

    .swal2-title {
        font-size: 1.25rem !important;
    }

    .swal2-html-container {
        font-size: 0.9rem !important;
    }

    .swal2-confirm,
    .swal2-cancel,
    .swal2-deny {
        padding: 0.6rem 1.25rem !important;
        font-size: 0.9rem !important;
    }
}

/* Custom Classes for Different Alert Types */
.bassap-success-alert .swal2-popup {
    border-left: 4px solid var(--bassap-success) !important;
}

.bassap-error-alert .swal2-popup {
    border-left: 4px solid var(--bassap-error) !important;
}

.bassap-warning-alert .swal2-popup {
    border-left: 4px solid var(--bassap-warning) !important;
}

.bassap-info-alert .swal2-popup {
    border-left: 4px solid var(--bassap-info) !important;
}
