/* IMPORT THE FRAMEWORK */
.map, .contact-details, .sidebar, .content, .main-content h2, .main-content {
  position: relative;
}

.contact-details li, .contact-details a, .contact-details p, .contact-details h3, .main-content h2 {
  display: block;
}

.contact-details, .sidebar, .content {
  box-sizing: border-box;
}

.main-content {
  margin-left: auto;
  margin-right: auto;
}

.contact-details h3, .main-content h2 {
  text-transform: uppercase;
}

.contact-details, .main-content {
  display: flex;
  flex-wrap: wrap;
}

.contact-details h3, .main-content h2 {
  font-family: "neurial_grotesk", sans-serif;
}

.main-content {
  padding-left: 5%;
  padding-right: 5%;
}
@media screen and (max-width: 1921px) {
  .main-content {
    padding-left: 4.5em;
    padding-right: 4.5em;
  }
}
@media screen and (max-width: 960px) {
  .main-content {
    padding-left: 5%;
    padding-right: 5%;
  }
}

.main-content {
  padding-top: 120px;
  padding-bottom: 120px;
}
@media screen and (min-width: 451px) and (max-width: 1200px) {
  .main-content {
    padding-top: 4.5em;
    padding-bottom: 4.5em;
  }
}
@media screen and (max-width: 450px) {
  .main-content {
    padding-top: 3em;
    padding-bottom: 3em;
  }
}

.main-content h2 {
  font-size: 1.5em;
}
@media screen and (min-width: 1200px) and (max-width: 1919px) {
  .main-content h2 {
    font-size: 1.4em;
  }
}
@media screen and (min-width: 451px) and (max-width: 1199px) {
  .main-content h2 {
    font-size: 1.3em;
  }
}
@media screen and (max-width: 450px) {
  .main-content h2 {
    font-size: 1.2em;
  }
}

.contact-details h3 {
  font-size: 1.2em;
}
@media screen and (min-width: 1200px) and (max-width: 1919px) {
  .contact-details h3 {
    font-size: 1.1em;
  }
}
@media screen and (min-width: 451px) and (max-width: 1199px) {
  .contact-details h3 {
    font-size: 1em;
  }
}
@media screen and (max-width: 450px) {
  .contact-details h3 {
    font-size: 1em;
  }
}

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

.contact-details h3, .main-content h2 {
  font-weight: bold;
  line-height: 1.4em;
  margin-bottom: 1.5em;
}

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

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

.main-content {
  max-width: 1400px;
}
.main-content h2 {
  padding-left: 5%;
  border-left: 3px solid #229780;
}

.content {
  width: 70%;
  padding-right: 3em;
}

.sidebar {
  width: 30%;
  border-left: 1px solid #97c1b3;
  padding-left: 3em;
}

.contact-details {
  width: 95%;
  margin-left: 5%;
  color: #000000;
}
.contact-details h2 {
  color: #000000;
  margin-bottom: 3em;
}
.contact-details h3 {
  margin-bottom: 0.2em;
  color: #97c1b3;
}
.contact-details p {
  margin-bottom: 0;
}
.contact-details a {
  margin-bottom: 0;
  color: #000000;
}
.contact-details a:hover {
  color: #229780;
}
.contact-details li {
  width: 100%;
  border-bottom: 1px solid #229780;
  padding: 1em 0;
}
.contact-details li:first-of-type {
  border-top: 1px solid #229780;
}

.basagent {
  width: 80px;
  margin: 1.5em 0;
}

.map {
  width: 100%;
  height: 550px;
}

@media screen and (max-width: 1280px) {
  .content {
    width: 60%;
  }

  .sidebar {
    width: 40%;
  }
}
@media screen and (max-width: 760px) {
  .content {
    width: 100%;
  }

  .sidebar {
    width: 100%;
    border-left: none;
    padding-left: 0;
  }

  .contact-details {
    margin-left: 0;
  }
}
