
.formulaire-contact-wrapper { max-width: 600px; margin: 20px auto; padding: 20px; }
.form-header-event { text-align: center; margin-bottom: 30px; padding: 20px; background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); color: white; border-radius: 8px; }
.form-header-event h3 { margin: 0 0 10px 0; font-size: 24px; }
.form-header-event p { margin: 0; opacity: 0.9; }
.formulaire-contact .form-group { margin-bottom: 20px; }
.formulaire-contact .form-row { display: flex; gap: 15px; }
.formulaire-contact .form-col-2 { flex: 1; }
.formulaire-contact label { display: block; margin-bottom: 5px; font-weight: 600; color: #333; }
.formulaire-contact .required { color: #e74c3c; }
.formulaire-contact .recommended { color: #3498db; font-weight: normal; font-size: 0.9em; }
.formulaire-contact input[type='text'], .formulaire-contact input[type='email'], .formulaire-contact input[type='tel'], .formulaire-contact input[type='date'], .formulaire-contact input[type='url'], .formulaire-contact select, .formulaire-contact textarea { width: 100%; padding: 10px; border: 1px solid #ddd; border-radius: 4px; font-size: 14px; transition: border-color 0.3s; box-sizing: border-box; font-family: inherit; }
.formulaire-contact input:focus, .formulaire-contact select:focus, .formulaire-contact textarea:focus { outline: none; border-color: #3498db; box-shadow: 0 0 0 2px rgba(52, 152, 219, 0.1); }
.formulaire-contact input[type='file'] { padding: 8px; border: 2px dashed #ddd; border-radius: 4px; cursor: pointer; transition: border-color 0.3s; }
.formulaire-contact input[type='file']:hover { border-color: #3498db; }
.form-help { display: block; margin-top: 5px; font-size: 12px; color: #666; }
.image-preview { margin-top: 15px; position: relative; border: 2px solid #ddd; border-radius: 4px; padding: 10px; background: #f9f9f9; }
.image-preview img { max-width: 100%; height: auto; display: block; border-radius: 4px; }
/* --- CORRECTION CSS --- */
.image-preview .remove-image { 
    position: absolute; 
    top: 8px; 
    right: 8px; 
    background: #e74c3c; 
    color: white; 
    border: none; 
    border-radius: 50%; 
    width: 30px; 
    height: 30px; 
    cursor: pointer; 
    font-size: 20px; 
    font-weight: bold;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    transition: background-color 0.2s;
}
.image-preview .remove-image:hover { background: #c0392b; }
/* --- FIN CORRECTION CSS --- */
.formulaire-contact .btn-submit { background-color: #3498db; color: white; padding: 12px 30px; border: none; border-radius: 4px; font-size: 16px; cursor: pointer; transition: background-color 0.3s; width: 100%; }
.formulaire-contact .btn-submit:hover { background-color: #2980b9; }
.formulaire-contact .btn-submit:disabled { background-color: #95a5a6; cursor: not-allowed; }
.form-message { padding: 15px; margin-bottom: 20px; border-radius: 4px; display: none; }
.form-message.success { background-color: #d4edda; color: #155724; border: 1px solid #c3e6cb; display: block; }
.form-message.error { background-color: #f8d7da; color: #721c24; border: 1px solid #f5c6cb; display: block; }
.recaptcha-info { margin-top: 15px; font-size: 12px; color: #666; text-align: center; }
.recaptcha-info a { color: #3498db; text-decoration: none; }
.recaptcha-info a:hover { text-decoration: underline; }
@media (max-width: 600px) { .formulaire-contact-wrapper { padding: 10px; } .formulaire-contact .form-row { flex-direction: column; gap: 0; } }