.contact-section {
  margin-bottom: 0;
  margin-top: 3em;
  text-align: center;
}

.contact-section .col {
  padding: 0;
}

@media screen and (min-width: 769px) {
  .contact-section {
    display: flex;
  }
}

.footer {
  position: relative;
  background-color: #c11e49;
  color: white;
}

.footer .row {
    margin: 0.5em 0;
}

.footer a {
    color: white;
}

.footer li {
  list-style-type: none;
  margin-bottom: 0.5em;
}

.footer ul {
  padding-left: 0;
}

.footer .logo {
  margin-left: -7px;
  margin-bottom: 20px;
}

@media screen and (max-width: 768px) {
  .footer .logo {
    margin-bottom: -1em;
  }
}

.footer h2 a:hover {
  text-decoration-color: white;
}

.footer .address-line:not(:last-child)::after {
  content: ',';
  margin-right: .25em;
}

@media screen and (max-width: 768px) {
  .footer .left a,
  .footer .right a {
    display: block;
    margin: 0;
    margin-bottom: .5em;
    margin-top: .5em;
  }
}

@media screen and (min-width: 769px) {
  .footer .left a:first-child .icon,
  .footer .right a:first-child .icon {
    margin-left: 0;
  }

  .footer .left a .icon,
  .footer .right a .icon {
    margin-left: 1em;
  }
}

@media screen and (min-width: 769px) {
  .footer .left {
    float: left;
  }
}

@media screen and (min-width: 769px) {
  .footer .right {
    float: right;
  }
}

.footer .icon {
  margin-right: .5em;
}

.contact-button {
  margin-left: .5em;
  position: relative;
}

@media screen and (max-width: 768px) {
  .contact-button {
    margin-left: 0;
  }
}

.contact-button .tooltip {
  display: none;
  left: 50%;
  padding-top: .5em;
  position: absolute;
  top: 100%;
  transform: translateX(-50%);
  width: 20em;
  z-index: 110;
}

.contact-button .button {
  height: 100%;
  margin: 0;
}

@media screen and (min-width: 769px) {
  .contact-button .button {
    width: 2em;
  }
}

@media screen and (max-width: 768px) {
  .contact-button .button {
    margin-top: 1em;
    padding: .5em;
  }
}

.contact-button .button:hover + .tooltip {
  display: initial;
}
