/**
 * Styles pour le système de popups d'erreur
 * Améliore l'apparence des popups et des erreurs de formulaire
 */

/* Styles pour les popups SweetAlert2 */
.swal2-popup {
    border-radius: 15px !important;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15) !important;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif !important;
}

.swal2-title {
    font-size: 1.5rem !important;
    font-weight: 600 !important;
    margin-bottom: 1rem !important;
}

.swal2-content {
    font-size: 1rem !important;
    line-height: 1.6 !important;
    color: #555 !important;
}

.swal2-confirm {
    border-radius: 8px !important;
    font-weight: 500 !important;
    padding: 0.75rem 2rem !important;
    font-size: 1rem !important;
    transition: all 0.3s ease !important;
}

.swal2-confirm:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2) !important;
}

.swal2-cancel {
    border-radius: 8px !important;
    font-weight: 500 !important;
    padding: 0.75rem 2rem !important;
    font-size: 1rem !important;
    transition: all 0.3s ease !important;
}

.swal2-cancel:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2) !important;
}

/* Styles pour les icônes */
.swal2-icon {
    width: 4rem !important;
    height: 4rem !important;
    margin: 1rem auto !important;
}

.swal2-icon.swal2-success {
    border-color: #a5dc86 !important;
}

.swal2-icon.swal2-error {
    border-color: #f27474 !important;
}

.swal2-icon.swal2-warning {
    border-color: #f8bb86 !important;
}

.swal2-icon.swal2-info {
    border-color: #3fc3ee !important;
}

/* Styles pour les erreurs de formulaire */
.form-error {
    border: 2px solid #f27474 !important;
    background-color: #fef2f2 !important;
    box-shadow: 0 0 0 3px rgba(242, 116, 116, 0.1) !important;
    transition: all 0.3s ease !important;
}

.form-error:focus {
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(242, 116, 116, 0.2) !important;
}

.form-success {
    border: 2px solid #a5dc86 !important;
    background-color: #f0f9f0 !important;
    box-shadow: 0 0 0 3px rgba(165, 220, 134, 0.1) !important;
    transition: all 0.3s ease !important;
}

.form-success:focus {
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(165, 220, 134, 0.2) !important;
}

/* Styles pour les messages d'erreur inline */
.error-message {
    color: #f27474 !important;
    font-size: 0.875rem !important;
    margin-top: 0.5rem !important;
    display: block !important;
    font-weight: 500 !important;
}

.success-message {
    color: #a5dc86 !important;
    font-size: 0.875rem !important;
    margin-top: 0.5rem !important;
    display: block !important;
    font-weight: 500 !important;
}

/* Styles pour les labels d'erreur */
label.error {
    color: #f27474 !important;
    font-weight: 600 !important;
}

label.success {
    color: #a5dc86 !important;
    font-weight: 600 !important;
}

/* Animation pour les erreurs */
@keyframes shake {
    0%, 100% { transform: translateX(0); }
    10%, 30%, 50%, 70%, 90% { transform: translateX(-5px); }
    20%, 40%, 60%, 80% { transform: translateX(5px); }
}

.form-error.animate-shake {
    animation: shake 0.5s ease-in-out !important;
}

/* Styles pour les popups de chargement */
.swal2-loading {
    border: 4px solid #f3f3f3 !important;
    border-top: 4px solid #3498db !important;
    border-radius: 50% !important;
    width: 40px !important;
    height: 40px !important;
    animation: spin 1s linear infinite !important;
    margin: 1rem auto !important;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Styles pour les popups de confirmation */
.swal2-popup .swal2-actions {
    margin-top: 2rem !important;
}

.swal2-popup .swal2-actions button {
    margin: 0 0.5rem !important;
}

/* Styles pour les popups avec HTML */
.swal2-html-container {
    text-align: left !important;
    white-space: pre-line !important;
}

/* Styles pour les popups de validation */
.validation-error-popup .swal2-html-container {
    background-color: #fef2f2 !important;
    border: 1px solid #fecaca !important;
    border-radius: 8px !important;
    padding: 1rem !important;
    margin: 1rem 0 !important;
}

.validation-error-popup .swal2-html-container ul {
    margin: 0 !important;
    padding-left: 1.5rem !important;
}

.validation-error-popup .swal2-html-container li {
    margin-bottom: 0.5rem !important;
    color: #dc2626 !important;
}

/* Styles pour les popups de succès */
.success-popup .swal2-html-container {
    background-color: #f0f9f0 !important;
    border: 1px solid #bbf7d0 !important;
    border-radius: 8px !important;
    padding: 1rem !important;
    margin: 1rem 0 !important;
}

/* Styles pour les popups d'avertissement */
.warning-popup .swal2-html-container {
    background-color: #fffbeb !important;
    border: 1px solid #fed7aa !important;
    border-radius: 8px !important;
    padding: 1rem !important;
    margin: 1rem 0 !important;
}

/* Styles pour les popups d'information */
.info-popup .swal2-html-container {
    background-color: #eff6ff !important;
    border: 1px solid #bfdbfe !important;
    border-radius: 8px !important;
    padding: 1rem !important;
    margin: 1rem 0 !important;
}

/* Styles responsifs */
@media (max-width: 768px) {
    .swal2-popup {
        width: 90% !important;
        margin: 0 auto !important;
    }
    
    .swal2-title {
        font-size: 1.25rem !important;
    }
    
    .swal2-content {
        font-size: 0.9rem !important;
    }
    
    .swal2-confirm,
    .swal2-cancel {
        padding: 0.6rem 1.5rem !important;
        font-size: 0.9rem !important;
    }
}

/* Styles pour les thèmes sombres */
@media (prefers-color-scheme: dark) {
    .swal2-popup {
        background-color: #2d3748 !important;
        color: #e2e8f0 !important;
    }
    
    .swal2-title {
        color: #e2e8f0 !important;
    }
    
    .swal2-content {
        color: #cbd5e0 !important;
    }
    
    .form-error {
        background-color: #2d1b1b !important;
        border-color: #f56565 !important;
    }
    
    .form-success {
        background-color: #1a2e1a !important;
        border-color: #68d391 !important;
    }
}
