footer {
  background-color: #001e41;
  box-sizing: border-box;
  color: #64b5e5;
  font-family: sansSemiBold;
  font-size: 0.875em;
  line-height: normal;
  overflow: hidden;
  position: relative;
  width: 100%;
  margin-top: 120px;
}

footer.no-margin-top {
  margin-top: 0;
}

@media (max-width: 1040px) {
  footer.no-margin-top {
    margin-top: 0;
  }
}

@media (max-width: 1040px) {
  footer {
    margin-left: 0;
    margin-top: 80px;
  }
}

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

footer .footer-inner-container hr {
  background-color: #64b5e5;
  margin: 35px 0 50px;
  height: 1px;
  opacity: 0.5;
}

footer .footer-inner-container a {
  transition: 0.1s opacity ease-out;
}

footer .footer-inner-container a:hover {
  opacity: 0.5;
}

@media (max-width: 1040px) {
  footer .footer-inner-container {
    padding: 20px 0 0 0;
  }
}

footer .footer-top {
  display: flex;
  width: 100%;
  justify-content: space-between;
}

footer .footer-top > div {
  display: flex;
}

footer .footer-top > div > * {
  padding-right: 33px;
  display: flex;
  align-items: center;
  justify-content: center;
}

footer .footer-top > div a:last-of-type {
  padding-right: 0;
}

footer .footer-top > div p {
  line-height: 24px;
  max-width: 115px;
}

footer .footer-top > div a {
  transition: 0.2s opacity ease-out;
}

footer .footer-top > div a:hover {
  opacity: 0.5;
}

@media (max-width: 1040px) {
  footer .footer-top {
    display: block;
  }
  footer .footer-top > div {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-flow: row wrap;
  }
  footer .footer-top > div p {
    padding: 40px 0 20px;
    flex: 1 100%;
    max-width: unset;
  }
  footer .footer-top > div p .mobile-br {
    display: none;
  }
  footer .footer-top > div:first-of-type p {
    padding: 0px 0 20px;
  }
  footer .footer-top > div a {
    align-self: center;
    justify-content: center;
  }
}

footer .footer-middle {
  color: #ffffff;
  justify-content: space-between;
  display: flex;
  flex-flow: row wrap;
}

footer .footer-middle > div {
  display: flex;
  flex-direction: column;
}

footer .footer-middle > div a, footer .footer-middle > div p {
  color: #ffffff;
  padding-bottom: 17px;
}

footer .footer-middle > div p:first-of-type {
  color: #64b5e5;
}

@media (max-width: 1040px) {
  footer .footer-middle > div {
    flex: 1 calc(50% - 40px);
    padding-bottom: 30px;
    margin-left: 40px;
  }
}

footer .footer-bottom {
  color: #ffffff;
}

footer .footer-bottom .copyright-banner {
  height: 70px;
  /*width: 100vw;*/
  background-color: #007dbd;
  display: flex;
  align-items: center;
  justify-content: center;
}

footer .footer-bottom .copyright {
  text-align: center;
}

footer .footer-bottom .copyright .mobile-br {
  display: none;
}

@media (max-width: 1440px) {
  footer .footer-bottom {
    background-color: #007dbd;
    border-top: 1px solid rgba(100, 181, 229, 0.49);
    padding: 8px 0px;
  }
  footer .footer-bottom .copyright-banner {
    padding: 15px 5px;
    background-color: #007dbd;
  }
  footer .footer-bottom .copyright-banner .copyright .mobile-br {
    display: block;
  }
}
