footer {
  position: relative;
  width: 100%;
  overflow: hidden;
  background-color: black;
  height: 318px;
  z-index: 8;
}

.footer-main {
  position: relative;
  height: 100%;
  width: 100%;
  display: flex;
  flex-direction: row;
  justify-content: space-around;
  align-items: flex-start;
  padding: 30px 4% 60px 4%;
}

.footer-column-1 {
  width: 387px;
  height: 100%;
  position: relative;
  overflow: hidden;
}

.footer-column-1 img {
  width: 387px;
  height: 100%;
  position: relative;
  height: auto;
  margin-bottom: 20px;
}

.footer-column-1 p, .footer-column-1 a {
  text-align: left;
  font: normal normal 400 16px/19px Montserrat;
  letter-spacing: 0px;
  color: white;
  opacity: 1;
  margin: 3px 0;
  padding: 0 0 0 58px;
}

.footer-column-2 {
  width: 217px;
  height: 100%;
  position: relative;
  overflow: hidden;
  padding: 24px 0 0 0;
}

.footer-column-2 img {
  object-fit: scale-down;
}

.footer-column-3 {
  width: 24%;
  height: 100%;
  position: relative;
  overflow: hidden;
}

.footer-column-title {
  text-align: left;
  font: normal normal 300 22px/25px Montserrat;
  letter-spacing: 0px;
  color: #FFFFFF;
  opacity: 1;
  padding: 0 0 12px 0;
  margin: 0 0 12px 0;
  border-bottom: 1px solid #808080b5;
}

.footer-column-3 .footer-column-textarea {
  text-align: left;
  font: normal normal 400 16px/19px Montserrat;
  letter-spacing: 0px;
  color: white;
  opacity: 1;
  margin: 3px 0 32px 0;
}

.footer-column-3 a {
  background-color: #930424;
  color: #FFFFFF;
  font: normal normal 800 14px/18px Montserrat;
  letter-spacing: 0px;
  color: #FFFFFF;
  text-transform: uppercase;
  opacity: 1;
  text-align: center;
  padding: 15px 26px;
  position: relative;
  transition: 0.22s;
}

.footer-column-3 a:hover {
  background-color: white !important;
  color: #930424 !important;
  transition: 0.2s;
}

.footer-column-4 {
  width: 220px;
  height: 100%;
  position: relative;
  overflow: hidden;
}

.footer-column-4-pictos {
  position: relative;
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap; wrap;
}

.footer-column-4-pictos a {
  width: 51px;
  height: 51px;
  position: relative;
  display: block;
  margin: 10px 2% 4px 0;
}

.footer-column-4-pictos a img {
  height: 100%;
  width: 100%;
}

.footer-endline {
  position: absolute;
  height: 54px;
  width: 100%;
  padding: 0 8%;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  flex-wrap: nowrap;
  border-top: 2px solid #5a5a5a6b;
  left: 0;
  bottom: 0;
}

.footer-endline-a {
  text-align: left;
  font: normal normal 300 15px/17px Montserrat;
  letter-spacing: 0px;
  color: #ffffff9e;
  opacity: 1;
  margin: 0 3px;
}

.footer-endline-separator {
  text-align: left;
  font: normal normal 500 16px/19px Montserrat;
  letter-spacing: 0px;
  color: #ffffff9e;
  opacity: 1;
  margin: 0 4px;
}

body:not(.home) .footer-endline .footer-endline-separator:last-of-type {
  display: none;
}

body:not(.home) .idlink-footer {
    display: none;
}

@media screen and (max-width: 1500px) {
  .footer-endline {
    padding: 0 1%;
  }
  .footer-main {
    padding: 24px 3% 60px 3%;
  }
}

@media screen and (max-width: 1239px) {
  .footer-endline-a, .footer-endline-separator {
    text-align: left;
    font: normal normal 300 14px/14px Montserrat;
    letter-spacing: 0px;
    color: #ffffff9e;
    opacity: 1;
    margin: 0 2px;
  }
  .footer-endline {
    flex-wrap: wrap;
  }
}

@media screen and (max-width: 1199px) {
  .footer-column-4 {
    width: 50%;
    height: 160px;
    padding: 0 0 0 20px;
  }
  .footer-column-3 {
    width: 50%;
    height: 160px;
    padding: 0 20px 0 0;
  }
  .footer-column-2 {
    width: 50%;
    height: 210px;
    padding: 0 0 0 8px;
  }
  .footer-column-1 {
    width: 50%;
    height: 210px;
    padding: 0 8px 0 0;
  }
  .footer-main {
    flex-wrap: wrap;
  }
  footer {
    height: 448px;
  }
  .footer-column-3 .footer-column-textarea {
    font: normal normal 400 15px/17px Montserrat;
  }
  .footer-column-title {
    font: normal normal 300 20px/22px Montserrat;
    padding: 0 0 10px 0;
    margin: 0 0 10px 0;
  }
  .footer-column-1 p, .footer-column-1 a {
    padding: 0;
    font: normal normal 400 15px/17px Montserrat;
  }
}

@media screen and (max-width: 959px) {

}

@media screen and (max-width: 767px) {
  .footer-column-3, .footer-column-4 {
    height: 175px;
  }
  footer {
    height: 462px;
  }
}

@media screen and (max-width: 575px) {
  .footer-column-3 a {
    padding: 12px 22px;
  }
  .footer-column-3 .footer-column-textarea {
    font: normal normal 400 14px/16px Montserrat;
  }
  .footer-column-title {
    font: normal normal 300 18px/20px Montserrat;
  }
  .footer-column-3 {
    width: 65%;
    padding: 0 10px 0 0;
  }
  .footer-column-4 {
    width: 35%;
    padding: 0 0 0 10px;
  }
  .footer-column-1 p, .footer-column-1 a {
    font: normal normal 400 14px/16px Montserrat;
  }
}

@media screen and (max-width: 480px) {
  .footer-endline-a, .footer-endline-separator {
    font: normal normal 300 13px/13px Montserrat;
    margin: 0 1px;
  }
  .footer-column-3 a {
    font: normal normal 800 13px/15px Montserrat;
    padding: 10px 16px;
  }
}
