/* -----------------------------------------  HEADER  ----------------------------------------- */



.intro {
  font-size: 22px;
  line-height: 30px;
  font-weight: 200;
  color: white;
}
@media only screen and (max-width: 800px) {
  .intro {
    font-size: 21px;
    line-height: 24px;
    margin-bottom: 20px;
  }
}

.copy {
  font-size: 14px;
  line-height: 24px;
  font-weight: 300;
  color: rgb(14, 14, 14);
  font-family: 'Nunito', sans-serif;
  margin-bottom: 6px;
}


.copy-wrapper {
  width: 100%;
}

.services-wrapper {
  width: 100%;
  margin: 40px 0 30px 0;
}


/* -----------------------------------------  ARCHIVE  ----------------------------------------- */

.archive {
  margin-bottom: 40px;
}

@media only screen and (max-width: 800px) {
  .archive {
    margin-bottom: 20px;
  }
}

.archive h2{
  margin-top: 40px;
}

/* -----------------------------------------  CONTACT PAGE  ----------------------------------------- */
.flex-item-30 .address h4 {
  padding-bottom: 0px;
  line-height: 28px;  
}

.flex-item-30 .address h2 {
  color: #73CC33;
  margin-bottom: 10px;
}

.flex-item-30 .form h2 {
  color: #73CC33;
  margin-bottom: 10px;
}


.map {
  width: 100%;
  height: 350px;
  object-fit: cover;
  overflow: hidden;
  margin-top: 20px;
  border: 1px solid #768B7A;
}

.map-responsive{
  overflow:hidden;
  padding-bottom: 20px;
  position:relative;
  width: 100%;
  height: auto;
  object-fit: cover;
  margin: 40px 0 -10px 0;
}

.content-rule {
  width: 100%;
  height: 1px;
  border-bottom: 1px solid #B0BAB2; 
  margin-top: 40px;
}
@media only screen and (max-width: 800px) {
  .content-rule {
    border-bottom: 0px; 
    margin-top: 0px;
    height: 0px;
  }
}


.stroke-content {
    width: 100%;
    height: 1px;
    border-bottom: 1px solid #B0BAB2; 
    margin: 46px 0 20px 0;
}

/* -----------------------------------------  COLOURS  ----------------------------------------- */

.white {
  color: white;
}
.pale-green {
  color: #DEE2DF;
}
.light-grey {
  color: #B0BAB2
}

.mid-green {
  color: #496A4F;
}

.dark-green {
  color: #071209e6;
}
/* -----------------------------------------  SIZES  ----------------------------------------- */ 

.dark-green-wrapper h2 {
  font-size: 30px;
  margin-bottom: 20px;
  color: #B0BAB2;
}

.dark-green-wrapper .button {
  margin-top: 100px;
}

@media only screen and (max-width: 800px) {
  .thirtyeight {
    font-size: 30px;
    margin-bottom: 20px;
  }
}

.top-10 {
  margin-top: 10px;
}

.top-20 {
  margin-top: 20px;
}

.top-30 {
  margin-top: 30px;
}

.top-36 {
  margin-top: 36px;
}

.top-40 {
  margin-top: 40px;
}

.bottom-20 {
  margin-bottom: 20px;
}

.bottom-40 {
  margin-bottom: 40px;
}

.bottom-10 {
  padding-bottom: 10px;
}
/* -----------------------------------------  NAV BAR  ----------------------------------------- */ 


.nav-wrapper {
    width: 100%;
    height: 98px;
    top: 0;
    left: 0;
    z-index: 1000;
    border-bottom: 1px solid rgba(176, 186, 178,0.5);
    position: fixed;    
    background: rgb(101,145,109);
    background: linear-gradient(180deg, rgba(101,145,109,0.8) 0%, rgba(167,207,174,0.2) 100%);
}
.nav-bar {
    height: 76px;
}

#gradient {
  background: rgb(101,145,109);
  background: linear-gradient(180deg, rgba(101,145,109,0.47524947478991597) 0%, rgba(167,207,174,0) 100%);
  width: 100%;
  height: 98px;
  top: 0;
  left: 0;
  position: absolute;
  position: fixed;
  z-index: -1;
}

.site-logo {
    padding: 10px 20px 20px 0px;
    position: fixed;
    cursor: pointer;
    transition: ease-in-out 0.3s;
    position: fixed;
}

.site-logo:hover {
  opacity: 0.75;
}

.nav-bar {
    z-index: 1000;
  }
  
    .nav {
    /*  position: fixed; */
      z-index: 1000;
      width: 100%;
      height: 64px;
    }
  
  .main-nav {
    padding: 0px 20px 20px 20px;
  
  }
    .main-navigation {
      cursor: pointer;
      height: 100%;
      width: 0;
      position: fixed;
      z-index: 1;
      top: 0;
      right: 0;
      background-color: rgba(7, 18, 9, 0.95);
      overflow-x: hidden;
      transition: 0.1s ease-in;
      padding-top: 110px;
    }
    
    .main-navigation a {
      padding: 8px 1px 8px 10px;
      text-decoration: none;
      font-size: 25px;
      color: white;
      transition: 0.3s;
      
    }

    .main-navigation a:hover {
      color: #73CC34;
      transition: 0.3s;
    }
    .main-navigation ul li a:hover {
      color: #73CC34;
      transition: 0.3s;
    }

    .main-navigation ul ul li a:hover {
      color: #5a9033;
      transition: 0.3s;
    }


  .main-navigation ul li {
      font-weight: 500;
      font-size: 24px;
      line-height: 30px;
      color: #FFFFFF;
      padding: 2px 0 4px 10px;
      transition: ease-in-out 0.3s;
  }
  .main-navigation ul li:hover {
    color: #73CC34;
    transition: ease-in-out 0.3s;
  }

  .main-navigation ul ul li {
    font-weight: 500;
    font-size: 15px;
    line-height: 22px;
    color: #B7B7B7;
    padding: 2px 0 0 10px;
    transition: ease-in-out 0.3s;  
  }


  .main-navigation ul ul li a {
    font-weight: 500;
    font-size: 15px;
    line-height: 16px;
    color: #B7B7B7;
    padding: 0px 0px 0 10px;
    transition: ease-in-out 0.3s;  
  }

  .main-navigation ul ul ul li {
    font-weight: 500;
    font-size: 15px;
    line-height: 26px;
    color: #B7B7B7;
    padding: 16px 0px 2px 0;
    transition: ease-in-out 0.3s;

  }
    .main-navigation a:hover {
      color: #f1f1f1;
    }
    
    .main-navigation .closebtn {
      position: absolute;
      top: 0;
      right: 18px;
      z-index: 1000;
      padding: 24px 0 0 0;
    }
  #hambuger {
    position: fixed;
    right: 0;
  
  }
  
    .openbtn {
      padding: 24px 18px 8px 10px;
      z-index: 20;
      right: 0;
      top: 0;
      position: absolute;
      z-index: 1;
      cursor: pointer;
      transition: ease-in-out 0.3s;
    }

    .openbtn:hover {
      opacity: 0.75;
    }

    .closebtn:hover {
      opacity: 0.75;
    }
  
    @media screen and (max-height: 450px) {
      .primary-menu {padding-top: 15px;}
      .primary-menu a {font-size: 18px;}
    }
  
    .scroll-shadows {
      max-height: 200px;
      overflow: auto;
      -webkit-overflow-scrolling: touch;
      background: rgb(163,163,163);
      background: linear-gradient(180deg, rgba(163,163,163,0.5466780462184874) 0%, rgba(255,255,255,0) 100%);
    }
  

    .closebtn {
      background: none;
      border: none;
      padding: 0;
  }
  

/* -----------------------------------------  SLIDER  ----------------------------------------- */





.banner-wrapper {
  display: flex;
  flex-wrap: wrap;
  width: 100vw;
  height: 100vh;
  background-color: #071209e6;
}

@media only screen and (max-width: 800px) {
  .banner-wrapper  {
    height: 780px;
  }
}

.container-front {
  position:relative; /* bind coordonates to this element */
  width:50vw;
  background-color: none;
  height: 100vh;
}

.banner-image {
  width:50vw; 
  height: 100vh;
  object-fit: cover;
  overflow: hidden;
}
@media only screen and (max-width: 800px) {
  .banner-image  {
    height: 390px;
  }
}
@media only screen and (max-width: 800px) {
  .container-front {
    width: 100vw;
  }
}
@media only screen and (max-width: 800px) {
  .container {
    height: 600px;
  }
}
@media only screen and (max-width: 800px) {
  .banner-image {
    width: 100vw;
  }
}

.bannerleft {
  position:absolute; /* let content overlap */
  top: 0;
  left: 0;
  transition: opacity 2s;
  height:100%;
  width:100%;
  color:#000;
  overflow:hidden;
  background-color: #000;
}

@media only screen and (max-width: 800px) {
  .bannerleft  {
    height: 400px;
  }
}

@media only screen and (max-width: 800px) {
	.bannerleft .text {
	  margin-top: 55px;
	}
  }
.bannerleft.two {
  color:#fff;
}

.bannerleft.visible {
  opacity:1;
  background-color: #000;
}

.bannerleft, .bannerright {
  visibility: hidden;
  opacity: 0; /* for transition */
  transition: opacity 2s, visibility 2s;
}

.bannerleft.visible, .bannerright.visible {
  visibility: visible;
  opacity: 1;
}

.bannerright {
  position:absolute; /* let content overlap */
  top: 0;
  left: 50vw;
  transition: opacity 2s;
  height:100%;
  width:50%;
  color:#000;
  overflow: hidden;
  background-color: #000;
}

@media only screen and (max-width: 800px) {
  .bannerright  {
    height: 390px;
    width: 100%;
    visibility: visible;
    margin-top: 390px;
    left: 0;
    overflow: hidden;
  }
}
.bannerright.two {
  color:#fff;
  background-color: #000;
}

.bannerright.visible {
  opacity:1;
  background-color: #000;
}

.text-wrapper {
  position: absolute;
  top: 40%;
  width: 40vw;
  padding: 0 0 0 50px;
  height: 270px;
}

@media only screen and (max-width: 1420px) {
  .text-wrapper {
    height: 260px;
  }
}

@media only screen and (max-width: 1100px) {
  .text-wrapper {
    height: 286px;
  }
}

@media only screen and (max-width: 950px) {
  .text-wrapper {
    height: 300px;
  }
}

@media only screen and (max-width: 800px) {
  .left {
    height: 400px;
  }
}

@media only screen and (max-width: 800px) {
  .text-wrapper {
    width: 80%;
    padding: 0 100px 0 20px;
    top: 26%;
    height: 286px;
  }
}

.text-wrapper-right {
  position: absolute;
  top: 40%;
  width: 40vw;
  padding: 0 0 0 50px;
  height: 270px;
}

@media only screen and (max-width: 1420px) {
  .text-wrapper-right {
    height: 260px;
  }
}

@media only screen and (max-width: 1100px) {
  .text-wrapper-right {
    height: 286px;
  }
}

@media only screen and (max-width: 950px) {
  .text-wrapper-right {
    height: 300px;
  }
}

@media only screen and (max-width: 800px) {
  .left {
    height: 400px;
  }
}

@media only screen and (max-width: 800px) {
  .text-wrapper-right {
    width: 80%;
    padding: 0 100px 0 20px;
    top: 26%;
    height: 246px;
  }
}





@media only screen and (max-width: 800px) {
  .text-wrapper-2 {
    top: 16%;
  }
}
@media only screen and (max-width: 800px) {
  .right {
    top: 16.5%;
  }
}

.text {
  color: #ffffff;
  font-size: 38px;
  padding: 0px 0px 10px 0;
  width: 100%;
  text-align: left;
  margin-bottom: 20px;
  line-height: 36px;
  font-weight: 500;
  font-family: 'Nunito', sans-serif;
}

@media only screen and (max-width: 800px) {
  .text  {
    font-size: 28px;
    line-height: 26px;
  }
}
.sub-text {
  color: #B0BAB2;
  font-size: 18px;
  line-height: 24px;
  padding: 0px 0px;
  width: 100%;
  text-align: left;
}

@media only screen and (max-width: 800px) {
  .sub-text  {
    font-size: 16px;
    line-height: 18px;
  }
}

/* -----------------------------------------  BUTONS  ----------------------------------------- */

.but-btm {
    position: absolute;
    bottom: 0;
}

.button-container {
  position: absolute;
}

.arhive .button {
  margin-top: 20px;
}

.button {
  display: inline-block;
  border-radius: 3px;
  background-color: transparent;
  border: 1px solid #73CC34;
  color: #73CC34;
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  letter-spacing: 1.5px;
  text-align: center;
  font-size: 12px;
  padding: 14px;
  width: 130px;
  transition: ease-in-out 0.5s;
  cursor: pointer;
  margin: 0px 0 20px 0;
  text-transform: uppercase;
  position: absolute;
  bottom: 0;
}

.button-2 {
  display: inline-block;
  border-radius: 3px;
  background-color: transparent;
  border: 1px solid #73CC34;
  color: #73CC34;
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  letter-spacing: 1.5px;
  text-align: center;
  font-size: 12px;
  padding: 14px;
  width: 92%;
  transition: ease-in-out 0.5s;
  cursor: pointer;
  margin: 2px 0 20px 0;
  text-transform: uppercase;
  align-self: flex-end;
  
}

.leftonly  {
  height: 100px;
}

@media only screen and (max-width: 800px) {
  .button  {
  }
}

.local {
  position: relative;
}

.flex-50-team .button {
  bottom: auto;
}

.btn-wide {
  width: 180px;

}

.button span {
  cursor: pointer;
  display: inline-block;
  position: relative;
  transition: 0.5s;
}

.button span:after {
  content: '\00bb';
  position: absolute;
  opacity: 0;
  top: 0;
  right: -20px;
  transition: ease-in-out .5s;
}

.button:hover span {
  padding-right: 14px;
  letter-spacing: 2px;
  color: #5a9033;
}

.button:hover {
  border: 1px solid #5a9033;
}

.button:hover span:after {
  opacity: 1;
  right: 0;
  color: #5a9033;
}







.button-2 span {
  cursor: pointer;
  display: inline-block;
  position: relative;
  transition: 0.5s;
}

.button-2 span:after {
  content: '\00bb';
  position: absolute;
  opacity: 0;
  top: 0;
  right: -20px;
  transition: ease-in-out .5s;
}

.button-2:hover span {
  padding-right: 14px;
  letter-spacing: 2px;
  color: #5a9033;
}

.button-2:hover {
  border: 1px solid #5a9033;
}

.button-2:hover span:after {
  opacity: 1;
  right: 0;
  color: #5a9033;
}



.btn-slider {
  position: absolute;
  margin-top: 30px;
}

@media only screen and (max-width: 800px) {
  .btn-slider  {
    margin-top: 20px;
    bottom: none;
  }
}
@media only screen and (max-width: 800px) {
  .btn-slider  {
    margin-top: 20px;
    bottom: none;
  }
}

/*
@media only screen and (max-width: 1550px) {
  .btn-slider  {
    top: 55%;
  }
}
@media only screen and (max-width: 800px) {
  .btn-slider  {
    top: 60%;
  }
}
*/
.button-white {
  display: inline-block;
  border-radius: 3px;
  background-color: transparent;
  border: 1px solid #ffffff;
  color: #ffffff;
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  letter-spacing: 1.5px;
  text-align: center;
  font-size: 12px;
  padding: 14px;
  width: 130px;
  transition: ease-in-out 0.5s;
  cursor: pointer;
  margin: 0px 0 20px 0;
  text-transform: uppercase;
}

.button-white span {
  cursor: pointer;
  display: inline-block;
  position: relative;
  transition: 0.5s;
}

.button-white span:after {
  content: '\00bb';
  position: absolute;
  opacity: 0;
  top: 0;
  right: -20px;
  transition: ease-in-out .5s;
}

.button-white:hover span {
  padding-right: 14px;
  letter-spacing: 2px;
  color: #071209e6;
}

.button-white:hover {
  border: 1px solid #071209e6;
}

.button-white:hover span:after {
  opacity: 1;
  right: 0;
  color: #071209e6;
}

.button-wapper {
  margin-top: 24px;
}

.blog-btn {
  margin: -30px 0 90px 0;
}

@media only screen and (max-width: 800px) {
  .blog-btn {
    padding: 16px 0 0 0;
  }
}

.button-btm {
  position: relative;
  bottom: 0;
}

.button-wrapper-2 {
  margin-bottom: 50px;
  margin-top: -20px;
  
}

/* -----------------------------------------  PAGE HEADER  ----------------------------------------- */

.site-header {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  height: 300px;
  background-color: #496A4F;
  
}
 
.page-title-wrapper {
  padding: 20px 40px 40px 20px;
  
}
@media only screen and (max-width: 800px) {
  .page-title-wrapper{
    padding: 20px 0 10px 0;
  }
}

.container {
  height: 200px;
  position: relative;
  margin-top: 78px;
  padding-left: 20px;
  width: 90%;
}

.vertical-center {
  margin: 0;
  position: absolute;
  top: 50%;
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
}

.wide-100 {
  width: 95%;
  margin-top: 20px;
}

/* -----------------------------------------  IMAGES  ----------------------------------------- */

.images {
  max-width: 100%;
  height: 300px;
  object-fit: cover;
  box-shadow: 10px 10px 0 rgba(176, 186, 178, 0.14);
  margin-bottom: 10px;
  border-radius: 4px;
  overflow: hidden;
}



@media only screen and (max-width: 800px) {
  .images {
    width: 100%;
    margin-bottom: 10px;
  }
}
.images-med {
  width: 100%;
  height: 300px;
  object-fit: cover;
  box-shadow: 10px 10px 0 rgba(176, 186, 178, 0.14);
  border-radius: 3px;
  margin-bottom: 20px;
  overflow: hidden;
}
@media only screen and (max-width: 800px) {
  .images-med {
    height: 280px;
    
    margin-bottom: 20px;
  }
}

.flex-50-team .images-med {
  max-width: 300px;
}

.images-med img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.height-360 {
  height: 360px;
}

.white-div h2 {
  padding-top: 0px;
}

.white-div p {
  padding-bottom: 10px;
}

.images-services {
  margin: 20px 0 30px 0;
  width: 100%;
  height: 300px;
  object-fit: cover;
  box-shadow: 10px 10px 0 rgba(176, 186, 178, 0.14);
  border-radius: 3px;
  overflow: hidden;
}

.images-x-sml {
  width: 100%;
  object-fit: cover;
  box-shadow: 10px 10px 0 rgba(176, 186, 178, 0.2);
  border-radius: 3px;
}
@media only screen and (max-width: 800px) {
  .images-x-sml{
    height: 200px;
    margin-bottom: 20px;
    width: 90vw;
  }
}
.blog-image {
  width: 500px;
  height: 500px;
  object-fit:stretch;
}
.content-images {
    box-shadow: 10px 10px 0 rgba(176, 186, 178, 0.14); 
    object-fit: cover; 
    overflow: hidden;
}
.content-images img {
    height: 550px;
    width: 100% ;
    object-fit: cover;
    object-fit: cover; 
    overflow: hidden;
    border-radius: 3px;
    display:block;
}
@media only screen and (max-width: 800px) {
    .content-images img {
        height: 320px;
    }
}
.content-images li {
    padding-left:0 !important;
    background:transparent;
}
.content-images li:after {
    display:none;
    height:0;
}

.content-images-sml img {
  height: 200px;
  width: 50%;
  object-fit: cover;
}

.portrait-images {
  object-fit: cover; 
  overflow: hidden;
  box-shadow: 10px 10px 0 rgba(176, 186, 178, 0.14);
  border-radius: 3px;
}

.caption {
  font-size: 12px;
  font-weight: 200;
  color: #071209e6;
  margin: 30px 0 20px 0;
}

.property-image-container {
  width: 100%;
  height: 400px
  
}

.property-image img  {
  object-fit: cover;
  overflow: hidden;
  width: 100%;
  height: 100%;

}
/* -----------------------------------------  FLEXBOX  ----------------------------------------- */

.flex-1 {
  flex: 1;
}

.flex-1-5 {
  flex: 1.5;
}

.flex-2 {
  flex: 2;
}

.flex-3 {
  flex: 3;
}

.flex-4 {
  flex: 4;
}

.flex-p-1 {
  flex: 1;
}
@media only screen and (max-width: 800px) {
  .flex-p-1 {
    max-width: 100%; 
  }
}






.child {
  margin-top: auto;
}

.flex-col-2 {
  display: flex;
  flex-direction: column;
  height: auto;
  justify-content: flex-start;
  flex: 1;
  flex-wrap: wrap;
}

@media only screen and (max-width: 800px) {
.flex-col-2 {
  min-width: 260px; 
}
}

.flex-col {
    display: flex;
    flex-direction: column; /* Aligns the elements vertically */
    justify-content: space-between; /* Distributes space evenly between the elements */
    height: 100%; /* Takes the full height of the flex container */
    min-height: 100%;
}

@media only screen and (max-width: 800px) {
  .flex-col {
    min-width: 240px; 
  }
}

.flex-col-item {
  flex-grow: 1; /* Grow to fill available space */
  flex-shrink: 1; /* Shrink if needed */
  flex-basis: auto; /* Default size before growing and shrinking */
  border: 1px solid black; /* Just for visualization */
}
.flex-container {
  display: flex;
  flex-wrap: wrap;
  gap: 6%;
  position: relative;
  align-items: stretch;
}

.flex-container-contact h2 {
  margin-bottom: 16px;
}

.flex-container-contact h5 {
  margin-top: 0;
}

.flex-container-cont {
  display: flex;
  flex-wrap: wrap;
  gap: 10%;
}

.flex-container-prop {
  display: flex;
  flex-wrap: wrap;
  gap: 5%;
  width: 100%;
}

.flex-container-contact  {
  display: flex;
  flex-wrap: wrap;
  gap: 5%;
  width: 100%;
}

.flex-item-70c {
  width: 70%;
}

.flex-item-60c {
  max-width: 55%;
}

@media only screen and (max-width: 800px) {
  .flex-item-60c {
    max-width: 100%;
    margin-right: 20%
  }
}

.flex-item-50c {
  max-width: 34%;
}
.flex-item-40c {
  max-width: 35%;
}

.flex-item-25c {
  max-width: 25%;
}

@media only screen and (max-width: 800px) {
  .flex-item-25c {
    min-width: 100%;
  }
}

@media only screen and (max-width: 800px) {
  .flex-item-40c {
    max-width: 100%;
    margin-top: 20px;
  }
}
.item {
  display: flex;
  width: 100%;
  flex-direction: column;
}


.flex-item-half {
  max-width: 47%;
}
@media only screen and (max-width: 800px) {
  .flex-item-half {
    max-width: 100%;
  }
}
.flex-item-30 {
  width: 29.33%;
}

@media only screen and (max-width: 800px) {
  .flex-item-30 {
    width: 100%;
  }
}
.flex-item-40 {
  max-width: 37%;
}

.flex-20 {
  width: 25%;
}
@media only screen and (max-width: 870px) {
  .flex-20 {
    width: 100%;
  }
}
.flex-30 {
  max-width: 30%;
}

.flex-40 {
  width: 40%;
}
@media only screen and (max-width: 870px) {
  .flex-40 {
    width: 100%;
  }
}
.flex-50 {
  max-width: 45%;
}

.flex-60 {
  max-width: 60%;
}

.flex-item-50 {
  max-width: 47%;
}

.flex-item-60 {
  max-width: 57%;
}


@media only screen and (max-width: 800px) {
  .flex-item-50 {
    max-width: 100%;
  }
}

.flex-50-team {
  width: 47%;
}

.flex-50-portait {
  width: 47%;
}

@media only screen and (max-width: 800px) {
  .flex-50-team {
    flex-wrap: wrap;
    width: 100%;
    margin-bottom: 40px;

  }
}

.flex-70 {
  width: 70%;
}
@media only screen and (max-width: 870px) {
  .flex-70 {
    width: 100%;
  }
}



@media only screen and (max-width: 800px) {
  .flex-small {
    max-width: 100%;
  }
}

.flex-item-20 {
  width: 20%
}
.flex-p-20 {
  width: 20%
}
@media only screen and (max-width: 870px) {
  .flex-p-20 {
    width: 100%;
  }
}



.flex-p-30 {
  width: 30%
}
@media only screen and (max-width: 870px) {
  .flex-p-30 {
    width: 100%;
  }
}



.flex-item-72 {
  width: 65%
}

.flex-item-60 {
  width: 64.66%
}

.flex-item-70 {
  width: 70%
}
@media only screen and (max-width: 870px) {
  .flex-item-30 {
    width: 100%;
  }
}

.flex-p-65 {
  width: 65%
}
@media only screen and (max-width: 870px) {
  .flex-p-65 {
    width: 100%;
  }
}


.flex-p-70 {
  width: 75%
}
@media only screen and (max-width: 870px) {
  .flex-p-70 {
    width: 100%;
  }
}


.flex-100 {
  width: 100%;
}

.flex-small {
  display: flex;
  flex-wrap: wrap;
  gap: 6%;
}
@media only screen and (max-width: 800px) {
  .flex-item-30 {
    max-width: 100%;
  }
}
.flex-small .stroke {
  margin-top: 20px;
}

.pull-quote {
  margin: 40px 0 30px 0;
  font-size: 20px;
  line-height: 24px;
  color:#768B7A;
  border-top: 1px solid #c1cec3;
  border-bottom: 1px solid #c1cec3;
  padding: 20px 0 20px 0;
}

.form-box {
  box-shadow: 10px 10px 0 rgba(176, 186, 178, 0.14);
  margin-bottom: 10px;
  border-radius: 4px;
  padding: 20px 20px 10px 20px;
  background-color: #fafbfa;
}
  
.agent-box {
  box-shadow: 10px 10px 0 rgba(176, 186, 178, 0.14);
  margin-bottom: 40px;
  border-radius: 4px;
  padding: 20px 20px 10px 20px;
  background-color: #fafbfa;
}






