footer#site-footer {
  background: #fff !important;
  margin-bottom: -10px;
  overflow: hidden;
}

/* Info Container */
.footer-infos .info-container {
  display: table;
  width: 100%;
  table-layout: fixed;
  padding: 20px 0;
}

/* Info Columns */
.footer-infos .info-col {
  display: table-cell;
  text-align: center;
  width: 20%;
  vertical-align: middle;
  padding: 20px 30px;

  /* Logo styles */
  &.logo img {
    width: 10vw;
  }

  .logotitle {
    font-family: 'Libre Baskerville';
    color: #222;
    font-size: 2.5em;
    padding-top: 16px;

    #logofooter svg {
      width: 16vw !important;
      margin: -40px 0;
    }
  }

  /* Icon styles */
  .info-icon {
    width: 31px;
    margin: 0 auto 20px;

    svg {
      path,
      rect {
        transition: all 0.2s ease-in;
      }
    }
  }

  /* Text styles */
  .info-text {
    font-family: 'Open sans';
    color: #222;
    font-size: 1.3em;
    font-weight: 500;
    transition: all 0.2s ease-in;
  }

  /* Hover effects */
  &:hover {
    .info-text {
      color: #808080;
    }

    .info-icon svg path.st0 {
      fill: #0a5c84;
    }
  }

  /* Animation hover effects */
  &.adresse:hover .info-icon svg {
    animation: pulsate-bck 0.5s ease-in-out infinite both;
  }

  &.tel:hover .info-icon svg {
    animation: shake-horizontal 0.8s cubic-bezier(0.455, 0.03, 0.515, 0.955)
      both;
  }

  &.mail:hover .info-icon svg {
    animation: slide-out-top 0.5s cubic-bezier(0.55, 0.085, 0.68, 0.53)
      backwards;
  }

  /* Social media */
  .social {
    display: inline-block;
    width: 39px;

    &:first-of-type {
      margin-right: 20px;
    }

    svg circle {
      fill: #0a5c84;
      transition: all 0.2s ease-in;
    }

    &:hover svg circle {
      fill: #1977f5;
    }
  }
}

/* Footer Bottom */
#footer-bottom {
  background: #dbdbdb;
  padding: 0 5vw;
  width: 100%;
  height: 70px;
  position: relative;

  .container {
    width: 100%;
    max-width: unset;
    padding: 0;
    position: relative;
    height: 70px;
  }

  /* Logo nbp */
  .nbp img {
    width: 3vw;
    display: block;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 0;
  }

  /* Texte nbp */
  .nbprod {
    font-family: 'Montserrat';
    font-size: 1em;
    font-weight: 400 !important;
    display: block;
    float: left;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    color: #000;

    span {
      font-weight: 300;
    }
  }
}

/* Menu Footer */
.footermenu {
  display: block;
  text-align: center;
  background: #6a6a6a;
  padding: 13px 0;

  a {
    color: #f4f4f4 !important;
    font-weight: 400 !important;
    padding: 0 10px;
    font-family: 'Montserrat';
    font-size: 1.2em;
  }

  .point {
    font-size: 1.3em;
    color: #f4f4f4;
    position: relative;
    top: 0;
  }
}

/* Copyright */
.copyrights {
  display: block;
  text-align: left;
  background: #3d3d3d;
  padding: 15px 5vw;
  color: #fff;
  font-family: 'Montserrat';

  #footer-info {
    color: #dbdbdb !important;
    font-weight: 400 !important;
    padding-left: 5vw;
    font-family: 'Montserrat';
    font-size: 1.2em;
    text-transform: none;
  }
}

/* Spécifique page d'accueil */
body.home {
  #footer-bottom {
    padding: 0 7vw;
  }
}

/* Content */
#site-content {
  width: 100%;
  padding: 0;
}
