 /* styles.css */
 body {
    background-color: #f3f4f6;
    font-family: 'Arial', sans-serif;
    margin: 0;
  }
  .main-container {
    background: linear-gradient(135deg, #1D1832, #5A9BD4);
    color: #ffffff;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100vh;
  }

  .form-container {
    background-color: #1D1832;
    border-radius: 15px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.5);
    width: 90%;
    max-width: 1000px;
    display: flex;
    flex-direction: column;
    clear: both;
  }

  .form-content {
    display: flex;
    flex-direction: row;
    width: 100%;
  }

  .text-section {
    background-color: #ffffff;
    color: #1D1832;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 40px;
    transition: transform 0.8s ease-in-out;
    flex-basis: 50%;
    border-radius: 10px 0px 0px 10px;
  }

  .text-section button {
    border: 2px solid #454F9D; /* Bordure bleu foncé */
    color: #454F9D; /* Texte bleu foncé */
    background-color: transparent; /* Fond transparent */
    font-weight: bold;
    padding: 10px 20px;
    border-radius: 25px;
    transition: all 0.3s ease-in-out; /* Transition fluide */
  }

  .text-section button:hover {
    background-color: #454F9D; /* Fond bleu foncé */
    color: #ffffff; /* Texte blanc */
  }

  #dynamic-text {
    text-align: center; /* Centre le texte horizontalement */
    width: 100%; /* Assure que le paragraphe prend toute la largeur disponible */
    word-wrap: break-word; /* Permet au texte de se mettre à la ligne lorsqu'il est trop long */
    margin-top: 20px; /* Espacement entre le texte et l'élément au-dessus */
    font-size: 1.1rem; /* Taille de police ajustée */
  }

  .form-section {
    padding: 50px;
    position: relative;
    transition: transform 0.8s ease-in-out;
    flex-basis: 70%;
  }

  .logo {
    width: 220px;
    margin-bottom: 20px;
  }

  .form {
    display: none;
    transition: opacity 0.8s ease-in-out;
  }

  form .btn {
    width: 50%; /* Réduit la largeur à 50% */
    margin: 0 auto; /* Centre le bouton */
    display: block; /* Assure l'alignement */
  }

  .active-form {
    display: block;
  }

  /* Labels stylisés */
  form label {
    font-size: 0.9rem;
    font-weight: bold;
    color: #ffffff;
    margin-bottom: 5px;
  }

  /* Champ "date picker" */
  input[type="date"] {
    color: #ffffff; /* Texte en blanc */
  }

  input[type="date"]::-webkit-calendar-picker-indicator {
    filter: invert(1); /* Inverse la couleur de l'icône du calendrier */
  }

  .input-field {
    background-color: #1D1832;
    border: 1px solid #454F9D;
    border-radius: 5px;
    padding: 10px;
    color: #ffffff;
    margin-bottom: 15px;
    font-size: 1rem;
    transition: all 0.3s ease-in-out; /* Transition fluide */
  }

  /* Placeholders ```html
  en blanc */
  .input-field::placeholder {
    color: #ffffff;
    opacity: 0.8; /* Ajuste la transparence si nécessaire */
  }

  /* Styles lorsque le champ est en focus */
  .input-field:focus {
    background-color: #1D1832; /* Fond blanc */
    color: #ffffff; /* Texte bleu foncé */
    border-color: #5a9bd4;
    outline: none;
    box-shadow: 0 0 5px rgba(90, 155, 212, 0.8);
  }

  .form-section .btn {
    border-radius: 30px; /* Arrondir les coins des boutons */
    background-color: white; /* Fond blanc */
    color: #1D1832; /* Texte bleu foncé */
    border: 2px solid #1D1832; /* Bordure bleu foncé */
    padding: 12px 24px; /* Ajuste l'espacement autour du texte pour une meilleure apparence */
    font-weight: bold; /* Met le texte en gras pour plus de lisibilité */
    transition: all 0.3s ease-in-out; /* Transition pour un effet fluide */
  }

  .form-section .btn:hover {
    background-color: #1D1832; /* Fond bleu foncé au survol */
    color: white; /* Texte blanc au survol */
    border: 2px solid #5A9BD4; /* Bordure bleue claire au survol */
  }


  #signup-form .input__icon_sign_up,
  #signup-form .password-toggle {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  }

#signup-form .input__icon_sign_up {
    left: 10px;
    color: #6c757d;
    opacity: 0.7;
    pointer-events: none;
}

#signup-form .password-toggle {
    right: 35px;
    color: #6c757d;
    cursor: pointer;
    opacity: 0.7;
}

#signup-form .error-message {
    position: absolute;
    bottom: -20px; /* Placez le message juste en-dessous de l'input */
    left: 0;
    width: 100%;
}

#signup-form .input-field {
    padding-left: 40px;
    padding-right: 40px;
}

    #signup-form .mb-3 {
      position: relative;
      margin-bottom: 30px;
    }

    h2, h4 {
      font-weight: bold;
      margin-bottom: 20px;
    }

    #toggle-btn {
      margin-top: 30px;
      border-radius: 25px;
    }

    @media (max-width: 768px) {
      .form-container {
        width: 90%;
      }

      .form-content {
        flex-direction: column;
      }

      .text-section {
        padding: 20px;
        flex-basis: auto;
      }

      .form-section {
        padding: 20px;
        flex-basis: auto;
      }

      #login-form .input__icon_login .password-toggle {
        background-color: blue;
      }
    }

    .position-relative {
      position: relative;
    }

    .password-toggle {
      position: absolute;
      right: 15px; /* Ajustez la valeur selon vos besoins */
      top: 70%;
      transform: translateY(-50%);
      cursor: pointer;
      color: #6c757d; /* Couleur de l'icône */
      opacity: 0.7; /* Opacité de l'icône */
      z-index: 1; /* Assurez-vous que l'icône est au-dessus du champ */
    }

    .error-message {
    color: #dc3545;
    font-size: 0.8rem;
    margin-top: 0.25rem;
    }

.is-invalid {
    border-color: #dc3545 !important;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25) !important;
}

.is-valid {
    border-color: #28a745 !important;
    box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25) !important;
}

.error-icon {
  position: absolute;
  left: 10px; /* Ajustez cette valeur pour décaler l'icône d'erreur */
  top: 50%;
  transform: translateY(-50%);
  color: #dc3545; /* Couleur rouge pour l'icône d'erreur */
  font-size: 1.2rem; /* Ajustez la taille de l'icône si nécessaire */
}
