footer {
  margin-top: 100px;
}

footer a {
  color: white;
}

#footer1 {
  background-color: white;
  border-radius: 20px 20px 0px 0px;
}

#footer1 .ctn {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 20px;
  padding: 30px 0px 30px 0px;
  justify-content: space-between;
}

#footer1 .col {
  display: inline-flex;
  gap: 10px;
  align-items: center;
}

.trait-vertical {
  border-right: 2px solid var(--gris);
  height: 52px;
}

#footer2 {
  background-color: var(--bleu);
  color: white;
}

#footer2 .ctn {
  display: flex;
  flex-direction: revert;
  justify-content: space-between;
  padding: 20px 0px 20px 0px;
}

#footer2 .col {
  display: inline-flex;
  flex-direction: revert;
  align-items: center;
  gap: 10px;
}

#footer2 .col-1,
#footer2 .col-2 .col {
  gap: 10px;
}

#footer2 .col-2 {
  gap: 20px;
}

#footer1 p,
#footer2 p {
  margin: 0px;
}

/*********** RESPONSIF ***********/

@media screen and (max-width: 1150px) {
  #footer2 .col-1 {
    justify-content: center;
  }

  #footer2 .ctn {
    flex-direction: column;
    gap: 12px;
  }

  #footer2 .col-2 {
    flex-direction: column;
    gap: 7px;
  }
}

@media screen and (max-width: 1046px) {
  #footer1 .ctn {
    justify-content: center;
  }

  #footer1 .col {
    gap: 10px;
    justify-content: center;
  }

  .trait-vertical {
    display: none;
  }
}

@media screen and (max-width: 654px) {
  #footer1 .ctn {
    flex-wrap: wrap;
  }
}

@media screen and (max-width: 654px) {
  #footer1 .ctn {
    gap: 10px;
    padding: 20px 0px 20px 0px
  }

  #footer1 .col {
    gap: 5px;
    width: 37%;
    justify-content: start;
  }
}

@media (max-width: 600px) {
  footer {
    margin-top: 50px;
  }

}

@media (max-width: 460px) {
  #footer1 .col {
    width: 100%;
    justify-content: center;
  }
}