*, *:before, *:after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

html {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
  min-height: 100%; }

body, body:before, body:after {
  margin-bottom: 90px;
  font-family: 'Roboto', sans-serif; }
  @media only screen and (min-width: 400px) {
    body, body:before, body:after {
      margin-bottom: 90px; } }
  @media only screen and (min-width: 480px) {
    body, body:before, body:after {
      margin-bottom: 69px; } }
  @media only screen and (min-width: 520px) {
    body, body:before, body:after {
      margin-bottom: 96px; } }
  @media only screen and (min-width: 768px) {
    body, body:before, body:after {
      margin-bottom: 108px; } }

.container__section {
  padding: 4rem 2rem; }
  @media only screen and (min-width: 520px) {
    .container__section {
      padding: 4rem 3rem; } }
  @media only screen and (min-width: 768px) {
    .container__section {
      padding: 6rem 6rem; } }
.container--no-bottom {
  padding-bottom: 0; }
.container--half-top {
  padding-top: 2rem; }
  @media only screen and (min-width: 520px) {
    .container--half-top {
      padding-top: 2rem; } }
  @media only screen and (min-width: 768px) {
    .container--half-top {
      padding-top: 3rem; } }
.container--small-top {
  padding-top: 1rem; }
  @media only screen and (min-width: 520px) {
    .container--small-top {
      padding-top: 2rem; } }
  @media only screen and (min-width: 768px) {
    .container--small-top {
      padding-top: 2rem; } }
.container--sub {
  padding: 4rem 2rem; }
  @media only screen and (min-width: 520px) {
    .container--sub {
      padding: 4rem 3rem; } }
  @media only screen and (min-width: 768px) {
    .container--sub {
      padding: 6rem 1rem; } }
.container--header {
  padding: 0 2rem; }
  @media only screen and (min-width: 520px) {
    .container--header {
      padding: 0 3rem; } }
  @media only screen and (min-width: 768px) {
    .container--header {
      padding: 0 6rem; } }
.container--breadcrumb {
  padding: 0 2rem; }
  @media only screen and (min-width: 520px) {
    .container--breadcrumb {
      padding: 0 3rem; } }
  @media only screen and (min-width: 768px) {
    .container--breadcrumb {
      padding: 0 6rem; } }
.container--footer {
  padding-top: 0;
  padding-bottom: 0; }
  @media only screen and (min-width: 768px) {
    .container--footer {
      padding-top: 0;
      padding-bottom: 0; } }
.container--banner {
  padding: 4rem 2rem; }
  @media only screen and (min-width: 520px) {
    .container--banner {
      padding: 4rem 4rem; } }
  @media only screen and (min-width: 768px) {
    .container--banner {
      padding: 8rem 8rem; } }
  @media only screen and (min-width: 992px) {
    .container--banner {
      padding: 10rem 8rem; } }
.container--no-sides {
  padding-left: 0;
  padding-right: 0;
  padding-bottom: 0;
  overflow: hidden; }
.container--small {
  padding: 2rem 2rem; }
  @media only screen and (min-width: 768px) {
    .container--small {
      padding: 3.5rem 6rem; } }

.section-header {
  text-align: center;
  font-weight: 300;
  font-size: 1.8rem; }
  @media only screen and (min-width: 768px) {
    .section-header {
      font-size: 2.7rem; } }
  .section-header--extra-bottom {
    margin-bottom: 6rem; }
  .section-header--large {
    font-size: 3.9rem; }
  .section-header--left {
    text-align: left; }
  .section-header--no-bottom {
    padding-bottom: 0;
    margin-bottom: 0; }

.section-subheader {
  font-size: 2.7rem;
  text-align: center;
  padding-bottom: 2rem;
  font-weight: 300; }

.underline {
  width: 75px;
  border-top: 3px solid #ffc942;
  margin-top: 20px;
  margin-bottom: 20px; }
  .underline--thin {
    border-top: 1.4px solid #ffc942; }
  .underline--centered {
    margin: 0 auto;
    margin-top: 1rem;
    margin-bottom: 2rem; }
  .underline--extra {
    margin-bottom: 40px; }

.no-padding {
  padding: 0; }

.btn {
  border-radius: 0; }

.btn-sub {
  padding: 10px 35px;
  background-color: #2e5da7;
  color: white;
  cursor: pointer;
  margin-top: 10px; }
  .btn-sub:hover {
    background-color: #ffc942;
    color: black;
    -webkit-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out; }

.btn-main {
  float: right;
  position: relative;
  margin-top: 25px; }

.fa-angle-right:before {
  content: "\f105";
  position: relative;
  left: 8px;
  top: 1px;
  font-size: 1.2rem; }

.header {
  background-color: white;
  border-bottom: 2px solid #cdcdcd;
  padding: 0 1rem; }
  @media only screen and (min-width: 520px) {
    .header {
      padding: 0 2rem; } }
  @media only screen and (min-width: 768px) {
    .header {
      padding: 0 6rem; } }
  .header__brand {
    color: #333333;
    text-decoration: none;
    font-size: 1.2rem; }
    @media only screen and (min-width: 520px) {
      .header__brand {
        font-size: 1.8rem; } }
    .header__brand:hover {
      text-decoration: none;
      color: #333; }
    .header__brand__text {
      position: relative;
      font-weight: 100;
      top: 4px;
      left: -3px; }
      .header__brand__text .main {
        font-weight: bold;
        color: #333; }
      .header__brand__text .sub {
        font-weight: 300;
        color: #333; }
    .header__brand__logo {
      position: relative;
      height: 46px;
      padding: 5px; }
      @media only screen and (min-width: 520px) {
        .header__brand__logo {
          height: 56px;
          padding: 5px; } }
      .header__brand__logo--alt {
        height: 56px; }
        @media only screen and (min-width: 520px) {
          .header__brand__logo--alt {
            height: 66px;
            padding: 5px; } }
  .header__item {
    display: inline-block;
    margin: 0; }
  .header__item:after {
    display: block;
    content: '';
    border-bottom: solid 3px #ffc942;
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transition: -webkit-transform 250ms ease-in-out;
    transition: -webkit-transform 250ms ease-in-out;
    transition: transform 250ms ease-in-out;
    transition: transform 250ms ease-in-out, -webkit-transform 250ms ease-in-out; }
  .header__item:hover:after {
    -webkit-transform: scaleX(1);
    transform: scaleX(1); }
  .header__item.fromLeft:after {
    -webkit-transform-origin: 0% 50%;
    transform-origin: 0% 50%; }
  .header__item__link {
    text-decoration: none;
    color: #333;
    display: block;
    width: 120px;
    text-transform: uppercase;
    text-align: left;
    font-size: 1rem; }
    .header__item__link--dropdown {
      background-color: transparent !important;
      border-color: transparent !important;
      position: relative;
      top: 1px; }
      .header__item__link--dropdown:hover {
        color: #3156b3; }
    @media only screen and (min-width: 768px) {
      .header__item__link {
        padding-top: 2.5rem;
        padding-bottom: 1.5rem;
        text-align: center; } }

.dropdown-toggle::after {
  display: none; }

.dropdown-menu {
  margin-top: -.2px; }

.footer {
  text-align: center;
  font-size: .9rem;
  bottom: 0;
  width: 100%;
  position: absolute;
  background-color: #333;
  color: #868e96;
  padding-top: 1.5rem;
  padding-bottom: 1.5rem; }
  @media only screen and (min-width: 520px) {
    .footer {
      font-size: 1rem;
      padding-top: 1.5rem;
      padding-bottom: 1.5rem; } }
  @media only screen and (min-width: 768px) {
    .footer {
      text-align: left;
      line-height: 60px;
      height: 108px;
      font-size: 1rem; } }
  .footer a {
    text-decoration: none;
    color: #868e96; }
    .footer a:hover {
      -webkit-transition: all .3s ease-in-out;
      transition: all .3s ease-in-out;
      color: #ffc942; }

.features {
  font-family: "Open Sans", sans-serif;
  margin-bottom: 40px; }
  .features__content {
    display: block !important;
    height: auto !important;
    background-color: #ebebeb;
    min-height: 476.05px;
    margin-bottom: 20px; }
    @media only screen and (min-width: 1024px) {
      .features__content {
        margin-bottom: 0; } }
  .features__image {
    overflow: hidden; }
    .features__image img {
      display: block;
      height: auto;
      max-width: 100%; }
      @media only screen and (min-width: 768px) {
        .features__image img {
          max-height: 180.25px;
          width: 100%; } }
  .features__text {
    padding: 2rem;
    min-height: 344.39px; }
    .features__text__main {
      color: #4d4d4d;
      letter-spacing: 0px;
      font-style: normal;
      line-height: 27px;
      font-size: 18px;
      font-weight: normal; }
    .features__text__sub {
      color: #8b8b8b;
      line-height: 29px;
      letter-spacing: 0px;
      font-style: normal;
      font-size: 14px;
      font-weight: normal; }
      @media only screen and (min-width: 1248px) {
        .features__text__sub {
          min-height: 145px; } }
    .features__text__button {
      padding: 0px;
      color: #4d4d4d;
      font-size: 11px;
      letter-spacing: 1px;
      color: black;
      border: 0px;
      text-decoration: none;
      cursor: pointer; }
      .features__text__button:hover {
        -webkit-transition: all .3s ease-in-out;
        transition: all .3s ease-in-out;
        color: #ffc942;
        text-decoration: none; }
      @media only screen and (min-width: 1248px) {
        .features__text__button {
          position: absolute;
          bottom: 25px; } }
  @media only screen and (min-width: 768px) {
    .features {
      margin-bottom: 10px; } }

.carousel .d-none {
  display: block !important; }
.carousel img {
  min-height: 500px; }
  @media only screen and (min-width: 520px) {
    .carousel img {
      min-height: 600px; } }
  @media only screen and (min-width: 768px) {
    .carousel img {
      max-height: 670px; } }
.carousel-caption {
  text-align: left;
  background-color: rgba(0, 0, 0, 0.56);
  padding: 2rem;
  position: absolute;
  width: 100%;
  left: 0;
  padding-top: 6rem;
  top: 0;
  bottom: 0;
  border-top: 3px solid #ffc942; }
  @media only screen and (min-width: 520px) {
    .carousel-caption {
      padding-top: 8rem; } }
  @media only screen and (min-width: 768px) {
    .carousel-caption {
      right: 13%;
      bottom: auto;
      left: auto;
      z-index: 10;
      color: #fff;
      width: auto;
      top: 3rem;
      max-width: 550px;
      padding-top: 2rem; } }
  .carousel-caption__header {
    font-weight: bold;
    text-shadow: 2px 2px 2px black;
    font-size: 2rem; }
    @media only screen and (min-width: 520px) {
      .carousel-caption__header {
        font-size: 2.5rem; } }
    @media only screen and (min-width: 768px) {
      .carousel-caption__header {
        font-size: 2.7rem; } }
@media only screen and (min-width: 768px) {
  .carousel-indicators {
    -webkit-box-sizing: border-box;
    box-sizing: border-box; } }
@media only screen and (min-width: 1024px) {
  .carousel-indicators {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: absolute;
    right: 0;
    bottom: 6%;
    left: 0;
    z-index: 15;
    display: -ms-flexbox;
    display: -webkit-box;
    display: flex;
    -ms-flex-pack: center;
    -webkit-box-pack: center;
    justify-content: center;
    padding-left: 0;
    margin-right: 13%;
    margin-left: 13%;
    list-style: none; } }
.carousel-indicators li {
  width: 25%;
  cursor: pointer; }
  @media only screen and (min-width: 768px) {
    .carousel-indicators li {
      -webkit-box-sizing: border-box;
      box-sizing: border-box;
      position: relative;
      -ms-flex: 0 1 auto;
      -webkit-box-flex: 0;
      flex: 0 1 auto;
      min-width: 209px;
      height: 50px;
      text-align: center;
      line-height: 13px;
      padding: 1rem 0;
      margin-right: 0rem;
      margin-left: 1rem;
      text-indent: 0px;
      background-color: rgba(0, 0, 0, 0.56);
      text-transform: uppercase;
      color: white;
      border: 2px solid white; }
      .carousel-indicators li:first-child {
        margin: 0; } }
  @media only screen and (min-width: 1024px) {
    .carousel-indicators li {
      -webkit-box-sizing: border-box;
      box-sizing: border-box;
      position: relative;
      -ms-flex: 0 1 auto;
      -webkit-box-flex: 0;
      flex: 0 1 auto;
      height: 50px;
      text-align: center;
      line-height: 13px;
      padding: 1rem 0;
      margin-right: 0rem;
      margin-left: 3rem;
      text-indent: 0px;
      background-color: rgba(0, 0, 0, 0.56);
      text-transform: uppercase;
      color: white;
      border: 2px solid white;
      cursor: pointer; } }
  @media only screen and (min-width: 768px) {
    .carousel-indicators li {
      min-width: 185.52px; } }
.carousel-indicators .active {
  background-color: #ffc942;
  color: white; }

.form-control {
  border-radius: 0; }

.banner {
  background-size: cover;
  background-repeat: no-repeat;
  color: white;
  font-weight: 300; }
  .banner__content {
    background-color: rgba(0, 0, 0, 0.45);
    width: auto;
    padding: 1rem 2rem;
    display: inline-block;
    border-top: 4px solid #ffc942;
    font-size: 1.4rem; }
    @media only screen and (min-width: 520px) {
      .banner__content {
        font-size: 36px;
        text-align: center;
        min-width: 240px; } }

.about__image {
  overflow: hidden; }
  .about__image img {
    width: 100%; }
    @media only screen and (min-width: 1024px) {
      .about__image img {
        max-height: 400px;
        width: auto; } }
.about__content {
  overflow: hidden;
  color: #104A81;
  display: block;
  position: relative;
  padding-bottom: 20px; }
  @media only screen and (min-width: 768px) {
    .about__content {
      padding: 15px 30px 31px 30px !important; } }
  @media only screen and (min-width: 1248px) {
    .about__content {
      padding: 10px 30px 31px 30px !important; } }
.about__title {
  color: black;
  letter-spacing: 0px;
  font-style: normal;
  line-height: 27px;
  font-size: 1.7rem;
  font-weight: 300; }
.about__text {
  line-height: 29px;
  letter-spacing: 0px;
  font-style: normal;
  font-size: 16px;
  color: black;
  font-weight: 300; }

.services__item {
  height: 300px;
  margin-bottom: 20px;
  cursor: pointer; }
  @media only screen and (min-width: 520px) {
    .services__item {
      height: 300px; } }
  @media only screen and (min-width: 768px) {
    .services__item {
      height: 300px; }
      .services__item--1 {
        background: -webkit-gradient(linear, left bottom, left top, from(black), color-stop(30%, rgba(0, 0, 0, 0.4)), color-stop(50%, rgba(0, 0, 0, 0.1)), to(transparent)), url("../../assets/images/stream2.jpeg");
        background: linear-gradient(to top, black 0%, rgba(0, 0, 0, 0.4) 30%, rgba(0, 0, 0, 0.1) 50%, transparent 100%), url("../../assets/images/stream2.jpeg");
        background-size: cover;
        background-repeat: no-repeat; }
      .services__item--2 {
        background: -webkit-gradient(linear, left bottom, left top, from(black), color-stop(30%, rgba(0, 0, 0, 0.4)), color-stop(50%, rgba(0, 0, 0, 0.1)), to(transparent)), url("../../assets/images/wetland5.jpg");
        background: linear-gradient(to top, black 0%, rgba(0, 0, 0, 0.4) 30%, rgba(0, 0, 0, 0.1) 50%, transparent 100%), url("../../assets/images/wetland5.jpg");
        background-size: cover;
        background-repeat: no-repeat; }
      .services__item--3 {
        background: -webkit-gradient(linear, left bottom, left top, from(black), color-stop(30%, rgba(0, 0, 0, 0.4)), color-stop(50%, rgba(0, 0, 0, 0.1)), to(transparent)), url("../../assets/images/civi.jpg");
        background: linear-gradient(to top, black 0%, rgba(0, 0, 0, 0.4) 30%, rgba(0, 0, 0, 0.1) 50%, transparent 100%), url("../../assets/images/civi.jpg");
        background-size: cover;
        background-repeat: no-repeat; }
      .services__item--4 {
        background: -webkit-gradient(linear, left bottom, left top, from(black), color-stop(30%, rgba(0, 0, 0, 0.4)), color-stop(50%, rgba(0, 0, 0, 0.1)), to(transparent)), url("../../assets/images/tank2.jpg");
        background: linear-gradient(to top, black 0%, rgba(0, 0, 0, 0.4) 30%, rgba(0, 0, 0, 0.1) 50%, transparent 100%), url("../../assets/images/tank2.jpg");
        background-size: cover;
        background-repeat: no-repeat; }
      .services__item--5 {
        background: -webkit-gradient(linear, left bottom, left top, from(black), color-stop(30%, rgba(0, 0, 0, 0.4)), color-stop(50%, rgba(0, 0, 0, 0.1)), to(transparent)), url("../../assets/images/reser.jpg");
        background: linear-gradient(to top, black 0%, rgba(0, 0, 0, 0.4) 30%, rgba(0, 0, 0, 0.1) 50%, transparent 100%), url("../../assets/images/reser.jpg");
        background-size: cover;
        background-repeat: no-repeat; }
      .services__item--6 {
        background: -webkit-gradient(linear, left bottom, left top, from(black), color-stop(35%, rgba(0, 0, 0, 0.4)), color-stop(50%, rgba(0, 0, 0, 0.1)), to(transparent)), url("../../assets/images/planting.jpeg");
        background: linear-gradient(to top, black 0%, rgba(0, 0, 0, 0.4) 35%, rgba(0, 0, 0, 0.1) 50%, transparent 100%), url("../../assets/images/planting.jpeg");
        background-size: cover;
        background-repeat: no-repeat; } }
  .services__item__title {
    font-weight: bold;
    text-shadow: 2px 2px 2px black;
    font-size: 2rem;
    color: white;
    position: absolute;
    bottom: 20px;
    padding: 10px 20px 10px 10px; }
    @media only screen and (min-width: 520px) {
      .services__item__title {
        font-size: 1.8rem; } }
    @media only screen and (min-width: 768px) {
      .services__item__title {
        font-size: 1.9rem; } }

.projects-home__content {
  display: block !important;
  height: auto !important;
  background-color: #ebebeb;
  cursor: pointer; }
  .projects-home__content--dark {
    background-color: #e2e2e2; }
.projects-home__image {
  overflow: hidden; }
  .projects-home__image img {
    display: block;
    height: auto;
    max-width: 100%; }
.projects-home__text {
  padding: 2rem; }
  .projects-home__text__main {
    color: #4d4d4d;
    letter-spacing: 0px;
    font-style: normal;
    line-height: 27px;
    font-size: 18px;
    font-weight: normal; }
  .projects-home__text__sub {
    color: #4D4D4D;
    font-size: 13px;
    letter-spacing: 0px; }
  .projects-home__text__button {
    padding: 0px;
    color: #4d4d4d;
    font-size: 11px;
    letter-spacing: 1px;
    color: black;
    border: 0px; }
.projects-home .btn-main {
  float: right;
  position: relative;
  margin-top: 25px;
  left: 15px; }

.projects__title {
  font-size: 2rem;
  font-weight: 300; }

.team__container {
  margin-top: 30px;
  margin-bottom: 70px; }
.team__photo {
  overflow: hidden;
  margin: 0 auto; }
  @media only screen and (min-width: 768px) {
    .team__photo {
      margin-top: 1px; } }
.team__title {
  margin-top: 15px;
  font-size: 1.7rem;
  font-weight: 300; }
  .team__title__sub {
    color: gray;
    font-size: 1.2rem; }

.well {
  padding: 2rem 3rem;
  background-color: #2e5da7; }
  @media only screen and (min-width: 768px) {
    .well {
      padding: 3.6rem; } }
  .well__text {
    color: #ffffff;
    font-size: 22px;
    line-height: 30px;
    font-weight: 300;
    text-align: center; }
    @media only screen and (min-width: 520px) {
      .well__text {
        font-size: 25px; } }
    @media only screen and (min-width: 768px) {
      .well__text {
        font-size: 30px;
        line-height: 50px; } }
  .well .btn-well {
    text-align: center;
    margin: 20px auto 0;
    padding: 10px 25px;
    border: 2px solid white; }
    .well .btn-well:hover {
      color: black;
      background-color: #ffc942;
      border: 2px solid #ffc942;
      -webkit-transition: all 0.3s ease-in-out;
      transition: all 0.3s ease-in-out; }

.btn-transparent {
  background-color: red; }

.breadcrumb {
  margin: 10px 0;
  background-color: transparent;
  padding-left: 0; }
  .breadcrumb a {
    text-decoration: none;
    color: #1a118e; }

.breadcrumb-item + .breadcrumb-item::before {
  display: inline-block;
  padding-right: 1rem;
  padding-left: 1rem;
  content: "/"; }
