/********************
	Part - before-footer
********************/
.before-footer {
    background : white;
}

/********************
	Part - newsletter
********************/
.section__title-content.newsletter .section__title-content__inner {
    padding : 3vh 0;
}

.block_newsletter form .input__wrapper {
    max-width       : 40%;
    margin          : 0 auto;
    display         : flex;
    justify-content : center;
}

.block_newsletter .conditions__wrapper {
    text-align : center;
}

@media (max-width : 767px) {
    .block_newsletter {
        padding-bottom : .625rem;
        border-bottom  : 1px solid #f6f6f6
    }

    .block_newsletter form .input__wrapper {
        max-width : 100%;
    }
}

/********************
	Part - main-footer
********************/
.footer-container {
    overflow : hidden;
    margin   : 0;
    padding  : 0;
}

* + .footer-container .footer {
    /*border-top : 1px solid #ACACAC;*/
}



.footer-legal{
  text-align: right;
}


.links .collapse {
    display : inherit
}

.block-contact-title, .blockcms-title, .myaccount-title, .myaccount-title a {
    font-weight : 700;
    font-size   : 1rem
}

/********************
	Part - account-list
********************/
#block_myaccount_infos .myaccount-title a {
    color : var(--color-black-default)
}

.account-list a {
    color : var(--color-grey-font-default)
}

.account-list a:hover {
    color : #2fb5d2
}

/*********************
	Part - after footer
*********************/
.after-footer-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0;
}

.after-footer-container .after-footer-mention {
  font-size: 14px;
  color: var(--color-grey-font-default);
  text-transform: uppercase;
  margin-bottom: 2em;
}

.after-footer-img-container {
  background-color: var(--color-white-default);
  color: var(--color-black-default);
  border: solid var(--color-black-default) 3px;
  display: flex;
  align-items: center;
  padding: 15px;
  min-height: 60px;
}

.after-footer-img-container img {
  width: 100px;
  height: 70px;
  padding-bottom: 10px;
  margin-right: 15px;
  border: solid var(--color-black-default) 1px;
  image-rendering: -moz-crisp-edges;
  image-rendering: -o-crisp-edges;
  image-rendering: -webkit-optimize-contrast;
  image-rendering: crisp-edges;
  -ms-interpolation-mode: nearest-neighbor;
}

/********************
	Part - copyright
********************/


.footer-copyright a, .footer-legal a{
  color: white;
}

.footer-copyright a:hover, .footer-legal a:hover{
  color: white;
  text-decoration: underline;
}


#footer{
  background: var(--color-primary);
  color: white;
  position: relative;
  overflow: hidden;
}

.footer__devis{
  display: flex;
  justify-content: center;
  align-items: center;
}

.footer__filigrane{
  position: absolute;
  right: -175px;
  top: 100px;

}

.footer__badge{
  display: none;
  flex-direction: column;
  background : white;
  color: black;
  width: 330px;
  margin-bottom: 75px;
}

.footer__logo{
  background: var(--color-tertiary);
  padding: 22px;
}

.footer__logo svg{
  width: 262px;
  height: 74px;
}

.footer__badge-bottom{
  padding: 8px;
  color: var(--color-primary);
  text-transform: uppercase;
  font-size: 14px;
  font-weight: 600;
}

.footer__badge-bottom svg{
  margin-left: 11px;
}

.footer__badge-bottom,.footer__logo{
  display: flex;
  justify-content: center;
  align-items: center;

}

.footer-container .footer {
  display   : grid;
  grid-template-columns: 1fr 1fr;
}

.footer-container{
  padding   : 0 20px;
}

.footer__links{
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  flex-wrap: wrap;
}

.footer__links-title{
  text-transform: uppercase;
  font-size: 15px;
  font-style: normal;
  font-weight: 800;
  margin-bottom: 8px;
  display: block;
}

.footer__links-item button{
  all: unset;
}

.footer__links-item *,
.footer__links-item button{
  font-size: 15px;
  line-height: 1.75;
  font-style: normal;
  font-weight: 400;
  color: white;
}

.footer__links-item.links-phone{
  margin-top: 20px;
}

.footer__links-item a:hover,
.footer__links-item button:hover{
  color: white;
  text-decoration: underline;
  cursor: pointer;
}


.footer__first{
  border-bottom: 1px solid rgba(255,255,255,0.2);
  padding-top: 45px;
  padding-bottom: 45px;
}



.footer__logo-mobile{
  margin: 40px auto;
}

#steavisgarantisFooterText a{
  color: var(--color-secondary)
}

#steavisgarantisFooterText a:hover{
  text-decoration: underline;
}



.contact-form-footer__form .form-group{
  margin-bottom: 0;
}

.contact-form-footer__title:before, .contact-form-footer__title:after{
  content: '';
  display: inline-block;
  width: 28px;
  margin: 0 22px;
  height: 2px;
  background: var(--color-secondary);
}

.contact-form-footer__title{
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 23px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.7;
  text-transform: uppercase;
  margin-bottom: 30px;
  color: white;
}

.contact-form-footer__right{
  display: grid;
  grid-template-columns: calc(50% - 5px) calc(50% - 5px);
  grid-gap: 10px;
}

.contact-form-footer__right .full{
  grid-column: 1/-1;
}

.contact-form-footer .form-control{
  max-height: 118px;
}

.label-special-token {
  pointer-events : none;
  opacity        : 0;
  height         : 0;
  width: 50px;
}

.float-label-field {
  position: relative;
  box-sizing: border-box;
}

.float-label-field input {
  outline: none;
  width: 100%;
  font-size: 15px;
  font-family: var(--typo-primary);
  border: 1px solid #D9D9D9;
  padding: 15px 10px 5px;
}

.float-label-field .form-control-label {
  top: -5px;
  height: 100%;
  position: absolute;
  transition: all 0.2s ease;
  font-size: 15px;
  color: var(--color-primary);
  font-weight: 500;
  padding: 15px 10px 5px;
  text-transform: initial;
  cursor: text;
  pointer-events: none;
  z-index: 4;
  margin-bottom: 0;
}

.float-label-field.float .form-control-label, .float-label-field.focus .form-control-label  {
  top: -14px;
  font-size: 12px;
  transition: all 0.2s ease;
  color : var(--color-primary);
  font-weight: 500;

}

.contact-form-footer .form-control-select{
  height: 40.75px!important;
  font-size: 15px;
  padding-top: 15px;
}

.contact-form-footer textarea{
  padding-top: 20px;
}

.contact-form-footer{
  color: #292929!important;
  font-size: 16px!important;
  max-width: 100%;
  width: 530px;
}

.contact-form-footer .input-group .input-group-btn > .btn-default{
  background: var(--color-secondary)
}

.form-footer.full .btn-primary{
  display: flex;
  margin: auto;
  justify-content: center;
  align-items: center;
  padding: 11px 30px;
  background: white;
  color: var(--color-primary);
  font-size: 14px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  text-transform: uppercase;
}

.form-footer.full .btn-primary:hover{
  background: var(--color-secondary);
  color: white;
}

.form-footer.full .btn-primary svg{
  margin-left: 10px;
  margin-top: 2px;
}


@media (max-width: 434px){
  .footer-container{
    padding: 0 15px;
  }
  .footer-copyright,.footer-legal{
    grid-column: 1/-1;
    text-align: center;
  }
  .contact-form-footer__title:before, .contact-form-footer__title:after{
    display: none;
  }
  .contact-form-footer .optional-comment{
    display: none;
  }

}

@media (max-width: 499px){
  .contact-form-footer__right {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 967px){
  .footer__first,
  .footer__devis,
  .footer__logo-mobile{
    grid-column: 1/-1;
  }
  .footer__logo-mobile svg{
    max-width: 100%;
  }
  .footer__devis{
    border-bottom: 1px solid rgba(255,255,255,0.2);
    padding-top: 45px;
    padding-bottom: 45px;
  }
  .footer__links-container{
    margin-top: 40px;
  }
  .footer-copyright,.footer-legal{
    margin-bottom: 20px;
    font-size: 12px;
  }


}

@media (min-width: 968px){
  .footer__devis{
    justify-content: flex-end;
  }
  .contact-form-footer__form{
    padding-left: 20px;
  }
  .footer__logo-mobile{
    display: none;
  }
  .footer__first{
    border-right: 1px solid rgba(255,255,255,0.2);
    padding-top: 80px;
    padding-bottom: 95px;
    border-bottom: none;
  }

  body#contact .footer__first{
    border-right: 0;
  }

  .footer__badge{
    display: flex;
  }
  .footer__links{
    padding-right: 40px;
    flex-direction: row;
  }
  .footer-copyright {
    text-align : left;
  }

  .footer-copyright, .footer-legal{
    border-top: 1px solid rgba(255,255,255,0.2);
    margin-bottom: 15px;
    padding-top: 15px;
  }
  .footer__filigrane{
    left: -175px;
    bottom: 50px;
    top: unset;
    right: unset;
    transform: rotate(180deg);
  }
}

@media (min-width: 968px) and (max-width: 1199px){
  .footer__links-container:last-child{
    margin-top: 20px;
    width: 100%;
  }
}

@media (min-width: 1200px){
  .footer__links{
    padding-right: 20px;
  }
}

@media (min-width: 1400px){
  .footer__links{
    padding-right: 40px;
  }
}

@media (min-width: 1600px){
  .footer__links{
    padding-right: 80px;
  }
  .footer-container{
    padding: 0 40px;
  }

}
