/* Global Modal Styles */
/* Modal Overlay - Full screen overlay */
.modal-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: rgba(0, 0, 0, 0.5) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 9999 !important;
    animation: fadeIn 0.2s ease;
}

/* Modal Dialog */
.modal-dialog {
    position: relative !important;
    background: white !important;
    border-radius: 8px !important;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04) !important;
    width: 90% !important;
    max-width: 500px !important;
    max-height: 90vh !important;
    overflow: hidden !important;
    animation: slideUp 0.3s ease;
}

/* Modal Header */
.modal-header {
    padding: 20px !important;
    border-bottom: 1px solid var(--border-color, #e5e7eb) !important;
    background: white !important;
}

.modal-header h3 {
    margin: 0 !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    color: var(--text-primary, #1f2937) !important;
}

/* Modal Body */
.modal-body {
    padding: 20px !important;
    overflow-y: auto !important;
    max-height: calc(90vh - 160px) !important;
}

.modal-body p {
    margin: 0 0 12px 0 !important;
    color: var(--text-primary, #1f2937) !important;
}

.modal-body p:last-child {
    margin-bottom: 0 !important;
}

.modal-body .text-warning {
    color: #d97706 !important;
    font-size: 13px !important;
}

/* Modal Actions */
.modal-actions {
    display: flex !important;
    justify-content: flex-end !important;
    gap: 12px !important;
    padding: 16px 20px !important;
    border-top: 1px solid var(--border-color, #e5e7eb) !important;
    background: white !important;
}

.modal-actions button {
    padding: 10px 20px !important;
    border-radius: 6px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    border: none !important;
}

.modal-actions .btn-danger {
    background: #dc2626 !important;
    color: white !important;
}

.modal-actions .btn-danger:hover:not(:disabled) {
    background: #b91c1c !important;
}

.modal-actions .btn-danger:disabled {
    background: #fca5a5 !important;
    cursor: not-allowed !important;
}

.modal-actions .btn-secondary {
    background: white !important;
    border: 1px solid var(--border-color, #e5e7eb) !important;
    color: var(--text-primary, #1f2937) !important;
}

.modal-actions .btn-secondary:hover:not(:disabled) {
    background: var(--bg-secondary, #f9fafb) !important;
}

.modal-actions .btn-secondary:disabled {
    opacity: 0.5 !important;
    cursor: not-allowed !important;
}

/* Spinner in button */
.modal-actions button .spinner-small {
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: white;
    border-radius: 50%;
    animation: spin 0.6s linear infinite;
    margin-right: 8px;
    vertical-align: middle;
}

/* Animations */
@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

@keyframes slideUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

/* Responsive */
@media (max-width: 768px) {
    .modal-dialog {
        width: 95% !important;
        max-width: 95% !important;
    }

    .modal-header {
        padding: 16px !important;
    }

    .modal-body {
        padding: 16px !important;
    }

    .modal-actions {
        padding: 12px 16px !important;
        flex-direction: column-reverse !important;
    }

    .modal-actions button {
        width: 100% !important;
    }
}
