#contact .s1 {
  position: relative;
  overflow: hidden;
}

#contact .s1 .logo-mark {
  width: 95%;
  height: 800px;
  position: absolute;
  background: url(/i/svg/logo-mark.svg) no-repeat left/contain;
  top: 57%;
  transform: translateY(-50%);
  left: 0;
  opacity: 0;
}

#contact .s1 .two-col {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
  max-width: 1240px;
  margin-left: auto;
  align-items: flex-start;
}

#contact .s1 .two-col .left {
  width: 690px;
}

#contact .s1 .two-col .left h1 {
  color: #0A1831;
  font-family: "raleway";
  font-style: normal;
  font-weight: 250;
  font-size: 3.5rem;
}

#contact .s1 .two-col .right {
  padding-top: 1rem;
}

#contact .s1 .two-col .right .tagline {
  max-width: 525px;
  color: #3C3C3C;
  font-family: "raleway";
  font-style: normal;
  font-weight: 250;
  font-size: 1.4rem;
  line-height: 1.36;
  letter-spacing: 1.08px;
  padding-bottom: 2rem;
}

#contact .s1 .two-col .right > div p:not(:last-child) {
  margin-bottom: 1.25rem;
}

#contact .s1 .two-col .right > div p {
  color: #3C3C3C;
  font-family: "raleway";
  font-style: normal;
  font-weight: 300;
  font-size: 0.9rem;
  letter-spacing: 0.72px;
}

#contact .s1 .two-col .right > div p a {
  color: #3C3C3C;
  font-family: "raleway";
  font-style: normal;
  font-weight: 300;
  font-size: 0.9rem;
  letter-spacing: 0.72px;
  transition: color 0.3s ease;
}

#contact .s1 .two-col .right > div p a:hover {
  color: #427bbf;
}

#contact .s1 .two-col .right > div p a.blue {
  color: #427BBF;
}

#contact .s1 .two-col .right .firm-name {
  color: #0A1831;
  font-family: "raleway";
  font-style: normal;
  font-weight: 700;
  font-size: 0.85rem;
  text-transform: uppercase;
  margin-bottom: 0.75rem;
}

#contact .s2 {
  overflow: hidden;
}

#contact .s2 .locations-wrap .city-name,
#contact .s2 .locations-wrap .city-address {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);
}

#contact .s2 .grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}

#contact .s2 .grid .city {
  text-align: center;
  height: 274px;
  padding: 3.9rem 0.8rem 0;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  display: -webkit-flexbox;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  border-top: 1px solid #d9d9d9;
}

#contact .s2 .grid .city .city-name {
  color: #0A1831;
  font-family: "raleway";
  font-style: normal;
  font-weight: 700;
  font-size: 0.85rem;
  margin-bottom: 1.5rem;
  text-transform: uppercase;
}

#contact .s2 .grid .city .city-address a {
  color: #3C3C3C;
  font-family: "raleway";
  font-style: normal;
  font-weight: 300;
  font-size: 0.9rem;
  line-height: 1.38;
  letter-spacing: 0.72px;
  display: inline-block;
  transition: color 0.3s ease;
}

#contact .s2 .grid .city .city-address a:hover {
  color: #427bbf;
}

#contact .s2 .grid .city.nyc {
  display: none;
}

#contact .s2 .grid div.city:not(:last-child) {
  border-right: 1px solid #d9d9d9;
}

@media (max-width: 1100px) {
  #contact .s1 .two-col {
    grid-template-columns: 1fr;
  }
  #contact .s1 .two-col .left,
  #contact .s1 .two-col .right {
    width: 100%;
    max-width: 100%;
  }
  #contact .s2 .grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 767px) {
  #contact .s1 .two-col {
    grid-template-columns: 1fr;
  }
  #contact .s1 .two-col .left h1 {
    font-size: 2.1rem;
  }
  #contact .s1 .two-col .right > div {
    display: none;
  }
  #contact .s1 .two-col .right .tagline {
    padding-bottom: 0;
  }
  #contact .s1 .logo-mark {
    height: 45vw;
    top: 70%;
    bottom: -20vw;
    transform: none;
  }
  #contact .s2 .grid {
    grid-template-columns: 1fr;
  }
  #contact .s2 .grid .city {
    padding: 3.9rem 0.8rem 3.9rem;
    height: auto;
  }
  #contact .s2 .grid .city.nyc {
    display: block;
  }
  #contact .s2 .grid .city.nyc p {
    color: #3C3C3C;
    font-family: "raleway";
    font-style: normal;
    font-weight: 300;
    font-size: 0.9rem;
    letter-spacing: 0.72px;
  }
  #contact .s2 .grid .city.nyc p a {
    color: #3C3C3C;
    font-family: "raleway";
    font-style: normal;
    font-weight: 300;
    font-size: 0.9rem;
    letter-spacing: 0.72px;
    transition: color 0.3s ease;
  }
  #contact .s2 .grid .city.nyc p a:hover {
    color: #427bbf;
  }
  #contact .s2 .grid .city.nyc p a.blue {
    color: #427BBF;
  }
  #contact .s2 .grid .city.nyc .firm-phone {
    margin: 1rem 0;
  }
}
