#map, .social, .contact, .contact-form-wrapper {
  position: relative;
}

.social a, .contact a:before, .contact p {
  display: inline-block;
  zoom: 1;
}

.contact, .form-wrapper {
  box-sizing: border-box;
}

.contact h2, .contact-form-wrapper h2 {
  text-transform: uppercase;
}

.contact span, .contact-form-wrapper, .hero {
  display: flex;
  flex-wrap: wrap;
}

.social a, .contact a {
  background-repeat: no-repeat;
}

.social a {
  background-position: center center;
}

.contact h2, .contact-form-wrapper h2 {
  font-family: "Weekly", sans-serif;
}

.contact-form-wrapper {
  padding-left: 5%;
  padding-right: 5%;
}
@media screen and (min-width: 1921px) {
  .contact-form-wrapper {
    padding-left: 7.5%;
    padding-right: 7.5%;
  }
}

.form-wrapper {
  border-radius: 5px;
}

.contact h2, .contact-form-wrapper h2 {
  margin-bottom: 3em;
  color: #8d8d8d;
}

.contact p {
  font-size: 1.4em;
}
@media screen and (min-width: 1200px) and (max-width: 1919px) {
  .contact p {
    font-size: 1.3em;
  }
}
@media screen and (min-width: 451px) and (max-width: 1199px) {
  .contact p {
    font-size: 1.15em;
  }
}
@media screen and (max-width: 450px) {
  .contact p {
    font-size: 1.1em;
  }
}

.contact a {
  font-size: 1.05em;
}
@media screen and (min-width: 1200px) and (max-width: 1919px) {
  .contact a {
    font-size: 1.05em;
  }
}
@media screen and (min-width: 451px) and (max-width: 1199px) {
  .contact a {
    font-size: 0.95em;
  }
}
@media screen and (max-width: 450px) {
  .contact a {
    font-size: 0.9em;
  }
}

.contact h2, .contact-form-wrapper h2 {
  font-size: 0.9em;
}
@media screen and (min-width: 1200px) and (max-width: 1919px) {
  .contact h2, .contact-form-wrapper h2 {
    font-size: 0.9em;
  }
}
@media screen and (min-width: 451px) and (max-width: 1199px) {
  .contact h2, .contact-form-wrapper h2 {
    font-size: 0.85em;
  }
}
@media screen and (max-width: 450px) {
  .contact h2, .contact-form-wrapper h2 {
    font-size: 0.8em;
  }
}

.contact h2, .contact-form-wrapper h2 {
  font-weight: normal;
  line-height: 1.6em;
  margin-bottom: 1.5em;
}

.contact a, .contact p {
  font-weight: normal;
  line-height: 1.8em;
  margin-bottom: 1.5em;
}

.hero {
  background-image: url("/app/images/contact/hero.jpg");
}

.hero-text {
  width: 30%;
}

@media screen and (max-width: 760px) {
  .hero-text {
    width: 100%;
  }
}
.contact-form-wrapper {
  align-items: flex-start;
}
.contact-form-wrapper h2 {
  width: 100%;
}

.form-wrapper, .contact {
  width: 50%;
}

.form-wrapper {
  margin-top: -600px;
  padding: 4.5em 6em 3em 6em;
  background-color: #FFFFFF;
  z-index: 10;
}

@media screen and (max-width: 1200px) {
  .form-wrapper {
    padding: 3em;
  }
}
@media screen and (max-width: 760px) {
  .form-wrapper, .contact {
    width: 100%;
  }

  .form-wrapper {
    order: 1;
    margin-top: -380px;
    padding: 1.5em;
    margin-bottom: 200px;
  }

  .contact {
    order: 2;
  }

  .contact-form-wrapper {
    background-position: center bottom;
    background-size: 100%;
  }
}
.contact {
  background-color: #151515;
  padding: 3em 5% 6em 5%;
  z-index: 99;
  border-top: 15px solid #02BBED;
  margin-top: -100px;
}
.contact span {
  align-items: center;
  width: 100%;
}
.contact h2, .contact a {
  color: #02BBED;
}
.contact h2 {
  width: 100%;
  margin-top: 4.5em;
}
.contact p {
  width: 55%;
  color: #FFFFFF;
  margin-bottom: 0;
  white-space: nowrap;
}
.contact a {
  width: 30%;
  color: #02BBED;
  padding-right: 3em;
  background-image: url("/app/images/contact/contact-sprite.png");
  background-size: 28px;
  margin-bottom: 0.2em;
  white-space: nowrap;
}
.contact a:hover {
  color: #FFD600;
}
.contact a:before {
  content: "";
  width: 50px;
  background-color: #F62971;
  height: 2px;
  margin-right: 0.8em;
}
.contact .map {
  background-position: right 0;
}
.contact .call {
  background-position: right -84px;
}
.contact .email {
  background-position: right -192px;
}

@media screen and (max-width: 1330px) {
  .contact p {
    width: 60%;
  }
}
@media screen and (max-width: 960px) {
  .contact p, .contact a {
    width: 100%;
  }
  .contact a {
    margin: 1.5em 0;
  }
}
@media screen and (max-width: 760px) {
  .contact a {
    width: 40%;
  }
}
.social {
  margin: 1.5em 0;
  width: 100%;
}
.social a {
  background-size: 50px;
  width: 80px;
  height: 64px;
  margin-right: 1.5em;
}
.social a:hover {
  opacity: 0.5;
}
.social a:before {
  display: none;
}
.social .twitter {
  background-image: url("/app/images/contact/twitter.png");
}
.social .linkedin {
  background-image: url("/app/images/contact/linkedin.png");
}

#map {
  width: 100%;
  height: 1000px;
  margin-top: -550px;
}

@media screen and (max-width: 760px) {
  #map {
    margin-top: -200px;
  }
}
