/* Text Elements */

h1 {
  font-family: 'Inter', sans-serif;
}

h1.hero-heading {
  margin-top: 0;
  margin-bottom: 24px;
  color: #fff;
  text-align: center;
  font-size: 62px;
  line-height: 1;
}

h2 {
  margin-top: 0;
  margin-bottom: 16px;
  font-weight: 500;
  font-family: 'Inter', sans-serif;
}

h2.hero-subheading {
  margin-top: 16px;
  margin-bottom: 16px;
  color: #fff;
  text-align: center;
  font-size: 36px;
  line-height: 1.14;
}

h2.title-heading {
  max-width: 600px;
  font-size: 36px;
  font-family: 'Inter', 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

p.paragraph.hero-action-message {
  display: block;
  margin-right: auto;
  margin-left: auto;
  color: #fff;
  text-align: center;
  line-height: 24px;
}

p.paragraph {
  max-width: 800px;
  font-family: 'Inter', 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

p.paragraph.region-description {
  color: #666;
  font-weight: 300;
  line-height: 25px;
}

/* Layout Elements */

.container.hero-section {
  display: -webkit-box;
  display: -webkit-flex;
  display:    -moz-box;
  display: -ms-flexbox;
  display:         flex;
  -webkit-flex-direction: row;
      -ms-flex-direction: row;
          flex-direction: row;
  -ms-flex-pack: center;
  float: none;
  -ms-flex-align: center;
  padding: 48px 24px;
  min-height: 80vh;
  background-color: #000;
  background-image: url('../images/IMG_7552.jpg');
  background-attachment: scroll;
  background-position: center center;
  background-clip: border-box;
  background-origin: padding-box;
  background-size: auto auto;
  background-repeat: repeat;

  background-blend-mode: normal;
  -webkit-box-align: center;
  -webkit-align-items: center;
     -moz-box-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
     -moz-box-pack: center;
          justify-content: center;
  -webkit-flex-wrap: wrap-reverse;
      -ms-flex-wrap: wrap-reverse;
          flex-wrap: wrap-reverse;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
     -moz-box-orient: horizontal;
     -moz-box-direction: normal;
}

.container.hero-content-region {
  padding-top: 48px;
  padding-bottom: 48px;
  max-width: 800px;
}

.container.project-region-1 {
  padding: 48px 24px;
  min-height: 50vh;
  background-color: #fff;
}

.container.picture-wrapper {
  float: none;
  overflow: hidden;
  margin-top: 24px;
  margin-bottom: -6px;
  border-radius: 8px;
}

.container.project-region-2 {
  padding: 48px 24px;
  min-height: 50vh;
  background-color: #fff;
}

.container.container-3 {
  display: -webkit-box;
  display: -webkit-flex;
  display:    -moz-box;
  display: -ms-flexbox;
  display:         flex;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -ms-flex-pack: center;
  padding-top: 24px;
  padding-bottom: 24px;

  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
     -moz-box-orient: vertical;
     -moz-box-direction: normal;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
     -moz-box-pack: center;
          justify-content: center;
}

.container.container-4 {
  display: -webkit-box;
  display: -webkit-flex;
  display:    -moz-box;
  display: -ms-flexbox;
  display:         flex;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -ms-flex-pack: center;
  padding-top: 24px;
  padding-bottom: 24px;

  -webkit-box-pack: center;
  -webkit-justify-content: center;
     -moz-box-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
     -moz-box-orient: vertical;
     -moz-box-direction: normal;
}

div.responsive-picture.picture {
  width: 100%;
}

div.responsive-picture#picture-1 {
  position: static;
  width: 40%;
  vertical-align: middle;
}

div.responsive-picture.picture:hover {
  -webkit-transform: scaleX(1.08) scaleY(1.08);
     -moz-transform: scaleX(1.08) scaleY(1.08);
       -o-transform: scaleX(1.08) scaleY(1.08);
          transform: scaleX(1.08) scaleY(1.08);
}

@media screen and (max-width: 60rem) {
  /* Text Elements */

  h1.hero-heading {
    font-size: 48px;
  }

  h2.hero-subheading {
    font-size: 24px;
  }

  /* Layout Elements */

  .container.container-1 {
    grid-template-columns: auto;
    grid-template-rows: repeat(2 , auto);
  }

  .container.container-2 {
    grid-template-columns: auto;
    grid-template-rows: repeat(2 , auto);
  }
}