/* --- STYLE GLOBAL DU FORMULAIRE --- */
.form {
  /* Correction de l'ombre (rgba max alpha est 1) */
  box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.2);
  margin: 50px auto;
  padding: 10px;
  /* Plus adapté au mobile par défaut */
  box-sizing: border-box;
  border-radius: 20px;
  background-color: rgb(243, 247, 252);
  font-size: var(--font-size-menu);
  width: 95%;
  /* Largeur mobile */
}

#container-login,
#container-inscri {
  margin: auto;
}

/* --- GROUPES ET INPUTS --- */
.form .form-group {
  margin-bottom: 15px;
}

.form .form-group input,
.form .form-group select,
.form .form-group textarea {
  width: 100%;
  padding: 10px;
  box-sizing: border-box;
  border-radius: 5px;
  transition: all 0.3s ease;
}

/* Survol des champs (Exclut le bouton submit pour éviter les conflits) */
.form input:not([type='submit']):hover,
.form select:hover,
.form textarea:hover {
  background-color: white;
  color: var(--primary-color);
  border-color: var(--primary-color);
}

/* --- ETATS D'ERREUR ET SUCCÈS --- */
.form .form-group.error input {
  border-color: red !important;
  box-shadow: 0px 0px 8px rgba(255, 0, 0, 0.3);
}

.form-group.error label,
.form-group.error .error-message {
  color: red;
}

.form .form-group li.success {
  color: rgb(0, 189, 47);
}

/* --- LE BOUTON SUBMIT --- */
.form .submit {
  display: flex;
  justify-content: center;
  align-items: center;
}

.form input[type='submit'],
.container input[type='button']:not(.linkInscription) {
  background-color: var(--primary-color);
  color: var(--secondary-text-color);
  width: max-content;
  margin-top: 20px;
  border: 3px solid var(--secondary-text-color);
  font-size: larger;
  cursor: pointer;
  border-radius: 10px;
}

.linkInscription,
.linkLogin {
  background: none;
  border: none;
  padding: 0;
  color: var(--primary-color);
  text-decoration: underline;
  cursor: pointer;
  font: inherit;
}

.form input[type='submit'] {
  padding: 12px 30px;
}

.form input[type='submit']:hover,
.container input[type='button']:hover:not(.linkInscription) {
  background-color: white;
  color: var(--primary-color);
  border: 3px solid var(--primary-color);
}

#linkInscription {
  text-align: center;
  margin-top: 15px;
}

.link-form,
h2 {
  text-align: center;
}

/* --- RESPONSIVE : DESKTOP (À partir de 768px) --- */
@media (min-width: 768px) {
  main .container {
    width: 718px;
  }

  .form {
    width: 80%;
    padding: 50px;
  }

  .form .form-group {
    display: flex;
    align-items: center;
  }

  .form .form-group label {
    text-align: right;
    padding-right: 15px;
    box-sizing: border-box;
    width: 25%;
    /* Augmenté légèrement pour la lisibilité */
  }

  .form .form-group label+div {
    width: 75%;
  }

  /* Style spécifique demandé pour le Desktop au survol */
  .form input:not([type='submit']):hover {
    border: 2px solid red;
    background-color: white;
  }
}

/* --- LARGE ÉCRAN --- */
@media (min-width: 991px) {
  main .container {
    width: 941px;
  }
}