/* Modale générique */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(8px);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1000;
    animation: fadeIn 0.3s ease-out;
}

.modal-overlay.hidden {
    display: none;
}

.modal-overlay.closing {
    animation: fadeOut 0.3s ease-in forwards;
}

.modal-content {
    width: 95%;
    max-width: 600px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    padding: 24px !important;
    animation: zoomIn 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
}

.modal-content.closing {
    animation: zoomOut 0.3s cubic-bezier(0.6, -0.28, 0.735, 0.045) forwards;
}

.modal-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: var(--spacing-md);
    color: var(--color-primary);
}

.modal-header i {
    font-size: 1.5rem;
}

.modal-header h3 {
    font-family: var(--font-heading);
    font-size: 1.25rem;
}

.modal-body {
    margin-bottom: var(--spacing-lg);
    line-height: 1.6;
    color: var(--color-text-main);
}

.modal-footer {
    display: flex;
    justify-content: flex-end;
}

.modal-footer .btn {
    width: auto;
    padding: 10px 24px;
}
