.banner {
  margin-top: 0;
  margin-bottom: 35px;
}

.banner__bg {
  padding: 12rem 0;
  background-repeat: no-repeat;
  background-size: cover;
}

.banner__caption {
  background: #21709a;
  color: white;
  padding: 30px;
  margin-top: -3rem;
  position: relative;
}
@media (min-width: 768px) {
  .banner__caption {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media (max-width: 768px) {
  .banner__caption {
    padding: 20px;
    margin-top: 0;
  }
}
.banner__caption h1 {
  font-family: "helveticaneuethin";
  color: #f1f2f2;
  margin: 0;
  line-height: 1.2;
}
@media (max-width: 768px) {
  .banner__caption h1 {
    font-size: 30px;
  }
}
.banner__caption p {
  font-size: 22px;
}

.banner__captitle,
h1.banner__captitle {
  font-family: "helveticaneuebold";
  font-size: 27px;
  margin-bottom: 0px;
  display: block;
}
@media screen and (min-width: 48em) {
  .banner__captitle,
h1.banner__captitle {
    font-size: 34px;
  }
}