/* Container principal du formulaire */
.form-container {
    max-width: 800px;
    margin: 100px auto;
    padding: 20px;
    background-color: var(--white2);
    border-radius: var(--border-radius);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

/* Groupe de champs dans le formulaire */
.form-group {
    margin-bottom: 15px;
}

.form-group label {
    display: block;
    margin-bottom: 5px;
    font-weight: bold;
    color: var(--black);
    font-family: 'Montserrat', sans-serif;
}

/* Pied de page du formulaire (soumission, boutons d'action) */
.form-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 20px;
}

.form-footer .btn {
    padding: 10px 20px;
    background-color: var(--dark-green);
    color: var(--white2);
    border-radius: var(--border-radius);
    cursor: pointer;
    border: none;
    transition: background-color 0.3s ease;
}

.form-footer .btn:hover { 
    background-color: var(--white2);
}

/* Champs de contrôle de formulaire (input, textarea, select) */
.form-control {
    width: 100%;
    padding: 10px;
    border: 1px solid var(--black);
    border-radius: var(--border-radius);
    font-size: var(--font-size-medium);
    color: var(--black);
    box-sizing: border-box;
    margin-bottom: 10px;
}

.form-control:focus {
    border-color: var(--dark-gray);
    outline: none;
    box-shadow: 0 0 5px var(--dark-gray);
}

/* Section de profil (formulaires liés aux informations de profil) */
.profile-section {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 20px;
    background-color: var(--white2);
    border-radius: var(--border-radius);
}

/* Conteneur de l'image de profil */
.profile-image-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 20px;
}

.profile-image {
    width: 150px;
    height: 150px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--dark-green);
    margin-bottom: 20px;
}

.profile-image-container button {
    display: block;
    width: 100%;
    max-width: 200px;
    margin: 10px 0;
    padding: 10px;
    font-size: var(--font-size-medium);
}

/* Formulaires d'informations */
.info-forms {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* Formulaires alternatifs (comme switch entre deux sections de formulaire) */
.toggle-forms {
    display: flex;
    flex-direction: column;
    margin-bottom: 20px;
}

.toggle-header {
    font-size: var(--font-size-large);
    color: var(--black);
    font-weight: bold;
    cursor: pointer;
}

.toggle-header.active {
    color: var(--dark-gray);
}

/* Sections du formulaire (peut être utilisé pour diviser les grandes parties du formulaire) */
.form-section {
    margin-bottom: 25px;
}

/* Champs d'entrée de formulaire (input texte, email, etc.) */
.form-input {
    width: 100%;
    padding: 12px;
    border: 1px solid var(--black);
    border-radius: var(--border-radius);
    font-size: var(--font-size-medium);
    margin-bottom: 15px;
}

.form-input:focus {
    border-color: var(--dark-gray);
    outline: none;
}

/* Sélection de formulaire (dropdown) */
.form-select {
    width: 100%;
    padding: 12px;
    border: 1px solid var(--black);
    border-radius: var(--border-radius);
    font-size: var(--font-size-medium);
    color: var(--black);
}

.form-select:focus {
    border-color: var(--dark-gray);
    outline: none;
}

.input-with-eye {
    position: relative;
}

.toggle-password {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.2em;
}

.mdp {
    width: 24px;
    height: 24px;
    fill: var(--dark-green);
}

.toggle-symbol {
    font-size: 1.5rem;
    font-weight: bold;
    color: var(--dark-green);
    margin-left: 5px;
    transition: transform 0.2s;
}

.toggle-header:hover .toggle-symbol {
    transform: scale(1.2);
}

.form-container label{
    font-family: 'Montserrat', sans-serif;
}

label.required::after {
    content: ' *';
    color: var(--dark-gray);
    font-weight: bold;
}

/* Cible les messages d'erreur pour leur donner un style distinct */
.form-error-message {
    color: red;
    font-size: 0.9rem;
    margin-top: 5px;
}

/* Style personnalisé pour les champs de formulaire en erreur */
input.is-invalid,
select.is-invalid,
textarea.is-invalid {
    border-color: red;
    background-color: #ffe6e6;
}
