.container {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  /* Grille flexible */
  gap: 20px;
  max-width: 1000px;
  margin: auto;
  padding: 20px;
}

.card {
  background: white;
  padding: 20px;
  border-radius: 10px;
  box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1);
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 350px;
  /* Hauteur minimale */
  max-height: auto;
  /* Hauteur maximale pour éviter les cartes trop grandes */
  margin-top: 20px;
}

.card img {
  /* Taille réduite du logo */
  height: 120px;
  margin: 0 auto 10px;
}

.card h2 {
  font-size: 34px;
  margin: 5px 0;
}

.card p {
  flex-grow: 1;
  /* Le texte s'étire pour uniformiser les cartes */
  font-size: 15px;
  display: flex;
  align-items: center;
  text-align: center;
  justify-content: center;
}

.container li {
  padding-top: 20px;
  text-align: left;
}

.container ul h3 {
  text-align: left;
}

.card-2 {
  min-height: 590px;
}

.bigger p {
  font-size: 20px;
  display: flex;
  align-items: center;
  text-align: center;
}

.card-3 {
  min-height: 1300px;
}

.bigger-2 p {
  font-size: 26px;
  display: flex;
  align-items: center;
  text-align: center;
}

.bigger-3 p {
  font-size: 20px;
}

a {
  text-decoration: none;
  color: black;
}

footer h3 {
  text-align: center;
}
