/*  ==========================================================================
    Import Normalize
    ==========================================================================  */
@import "css/normalize.css";

/*  ==========================================================================
    General Styling & Resets, etc.
    ==========================================================================  */
body {}
html, body { margin: 0; padding: 0; font-weight: normal; font-style: normal; font-size: 100%; line-height: 1; }
*, *:before, *:after { box-sizing: border-box; outline: 0; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
/* *:focus { outline: 2px solid rgba(27,113,185,1); transition: none !important; } */

a, a:focus, a:hover { text-decoration: none !important; }

/*
rgba(15,19,56,1) main font color (dark blue)
rgba(0,149,72,1) green
rgba(212,241,252,1) or #d4f1fc is the color fade in the content sections
*/

/*  ==========================================================================
    Helper Classes/Styles
    ==========================================================================  */
/* self-clear floats if I even use floats */
.clear:before,
.clear:after { content: " "; display: table; }
.clear:after { clear: both; }
.invisible { visibility: hidden; } /* Hide visually and from screen readers, but maintain layout */
.hidden { display: none !important; }
.notransition { transition: none !important; }
.no-margin { margin: 0 10px; } // negate the negative margins on floated items

.text-left { text-align: left; }
.text-right { text-align: right; }
.text-center { text-align: center; }
.text-justify { text-align: justify; }

/*  ==========================================================================
    Begin Main Website Layout
    ==========================================================================  */
html, body { position: relative; height: 100%; margin: 0px; padding: 0px; }

/*  ==========================================================================
    Header Styles
    ==========================================================================  */
header.header { position: relative; margin: 0; padding: 0; }

/*.nav { position: relative; height: 80px; width: 100%; background: rgba(0,149,72,.75); }*/
header.header .nav { position: absolute; top: 0; left: 0; right: 0; width: 100%; background: rgba(0,149,72,.80); }
header.header .nav-primary { display: block; z-index: 1010; }
header.header .nav-primary-inner {position: relative; margin: 0 auto; padding: 0 20px; min-height: 80px; max-width: 1240px; }

header.header .nav-primary-inner .nav-primary-logo { position: absolute; margin: 10px 10px 10px 0; z-index: 1015; }
header.header .nav-primary-inner .nav-primary-logo img { margin: 0; padding: 0; width: 100%; max-width: 150px; height: auto; transition: all .15s ease; }
header.header .nav-primary-inner .nav-primary-logo img:hover { /*opacity: .5;*/ box-shadow: 0 5px 15px rgba(0,0,0,0); }

header.header .nav-primary-inner .nav-primary-menu { position: relative; top: 0; left: 0; right: 0; min-height: 80px; width: 100%; text-align: center; }
header.header .nav-primary-inner .nav-primary-menu>ul { position: relative; display: block; margin: 0 10px; padding: 0; min-height: 80px; list-style: none; text-align: center; }
header.header .nav-primary-inner .nav-primary-menu>ul>li { position: relative; display: inline-block; margin: 0; padding: 0; width: auto;
  color: rgba(2255,255,255,1); font-family: 'Oswald', sans-serif; font-size: 16px; font-weight: 400; letter-spacing: .15em; text-transform: uppercase;
}
header.header .nav-primary-inner .nav-primary-menu>ul>li>a { position: relative; display: inline-block; padding: 0 15px; min-height: 80px; line-height: 80px; vertical-align: middle;
  color: rgba(255,255,255,1); transition: all .15s ease;
}
header.header .nav-primary-inner .nav-primary-menu>ul>li>a:hover { color: rgba(255,255,255,1); }
header.header .nav-primary-inner .nav-primary-menu>ul>li>a span { position: relative; display: inline-block; margin-top: 2px; padding: 0 5px; min-height: 40px; line-height: 40px; }
header.header .nav-primary-inner .nav-primary-menu>ul>li>a span:after { position: absolute; display: block; content: ""; left: 0px; right: 0px; bottom: 0; height: 2px; opacity: .75;
  background: rgba(255,255,255,1);
  transform-origin: 50%;
  transform: scaleX(0);
  transition: all .3s ease;
}
header.header .nav-primary-inner .nav-primary-menu>ul>li>a:hover span:after { transform: scale(1); }
header.header .nav-primary-inner .nav-primary-menu>ul>li.current a,
header.header .nav-primary-inner .nav-primary-menu>ul>li.section a,
header.header .nav-primary-inner .nav-primary-menu>ul>li.section a:hover { color: rgba(233,215,123,1); }
header.header .nav-primary-inner .nav-primary-menu>ul>li.current a > span:after,
header.header .nav-primary-inner .nav-primary-menu>ul>li.section a > span:after { background: rgba(233,215,123,1); transform: scale(1); }

header.header .nav-primary-inner .nav-primary-button { position: absolute; top: 30px; right: 20px;
  color: rgba(233,215,123,1); font-family: 'Oswald', sans-serif; font-size: 16px; font-weight: 400; letter-spacing: .1em; text-transform: uppercase;
}
header.header .nav-primary-inner .nav-primary-button span { margin: 0; padding: 5px 15px 5px 15px;
  border: 2px solid rgba(233,215,123,1);
  border-top-left-radius: 10px;
  border-bottom-right-radius: 10px;
  transition: all .15s ease;
}
header.header .nav-primary-inner .nav-primary-button span:hover { color: #fff; background: rgba(233,215,123,1); /*opacity: .5; box-shadow: 0 5px 15px rgba(0,0,0,.2);*/ }

/* Mobile Navigation Tigger */
header.header .nav-primary-inner .nav-mobile-trigger { display: none; position: absolute; margin: 5px 20px; top: 5px; right: 5px; max-width: 30px; max-height: 50px;
  color: rgba(255,255,255,1);
  font-family: 'Oswald', sans-serif;
  font-weight: 400;
  letter-spacing: .07em;
  text-align: right;
  text-decoration: none;
  background: transparent;
  z-index: 1010;
}
header.header .nav-primary-inner .nav-mobile-trigger:hover { color: rgba(233,215,123,1); }
header.header .nav-primary-inner .nav-mobile-trigger span { display: block; text-transform: uppercase; }
header.header .nav-primary-inner .nav-mobile-trigger span:first-child { margin: 0; padding: 0; font-size: 40px; }
header.header .nav-primary-inner .nav-mobile-trigger span:last-child { font-size: 14px; font-weight: 400; }

/* Mobile Navigation */
header.header nav.nav-mobile { display: none; width: 100%; margin: 0; padding: 80px 0 0 0; font-family: 'Oswald', sans-serif; text-align: center; text-transform: uppercase; }
header.header nav.nav-mobile ul { margin: 0; padding: 0; list-style: none; background: rgba(233,215,123,1); }
header.header nav.nav-mobile ul li { position: relative; margin: 0; padding: 0; border-bottom: 1px solid rgba(0,149,72,.5); }
header.header nav.nav-mobile ul li:first-child { /*border-top: 1px solid rgba(255,255,255,.5);*/ }
header.header nav.nav-mobile ul li:last-child { border: none; }
header.header nav.nav-mobile ul li a { display: block; margin: 0; padding: 20px; color: rgb(0,149,72); font-size: 100%; text-decoration: none; }
header.header nav.nav-mobile ul li a:hover { margin: 0; padding: 20px; color: rgba(0,149,72,.75); text-decoration: none; }
header.header nav.nav-mobile ul li > span.has-children,
header.header nav.nav-mobile ul li > span.has-childrens { /*float: right;*/ position: absolute; right: 0; padding: 20px; color: rgb(255,255,255); cursor: pointer; border-left: 1px solid rgba(255,255,255,.5); }
header.header nav.nav-mobile ul li > span.has-children:hover,
header.header nav.nav-mobile ul li > span.has-childrens:hover { color: rgba(255,255,255, .75); }

.hero { position: relative; margin: 0; padding: 0; }
.hero .hero-container { position: relative; display: block; height: 800px; width: 100%; transition: all .15s ease; overflow: hidden; }
.hero .hero-container .hero-image { position: absolute; top: 0; left: 0; right: 0; bottom: 0; z-index: 0;
  background-repeat: no-repeat;
  background-position: 50%;
  background-size: cover;
}

.hero .hero-container .hero-overlay { display: block; position: absolute; top: 0; left: 0; right: 0; bottom: 0;
  z-index: 900;
  color: rgba(255,255,255,1);
}
.hero .hero-container .hero-overlay .hero-overlay-inner { position: relative; display: table; height: 100%; width: 100%;}
.hero .hero-container .hero-overlay .hero-overlay-inner .hero-text {
  position: absolute;
  top: 40%;
  left: 50%;
  padding: 50px;
  max-width: 400px;
  border-top-left-radius: 40px;
  border-bottom-right-radius: 40px;
  background: rgba(0,149,72,.80);
}
.hero .hero-container .hero-overlay .hero-overlay-inner .hero-text h3 {
  margin: 0 10px 10px 10px;
  padding: 0;
  font-family: 'Raleway', serif;
  font-weight: normal;
  font-size: 36px;
}
.hero .hero-container .hero-overlay .hero-overlay-inner .hero-text h1 {
  margin: 0 10px;
  padding: 0;
  color: rgba(233,215,123,1);
  font-family: 'Oswald', sans-serif;
  font-weight: normal;
  font-size: 40px;
  letter-spacing: .1em;
  text-transform: uppercase;
  line-height: 46px;
}

.sub-header {
  position: relative; margin: -70px 0 0 0; padding: 0; background: transparent; z-index: 3000;
}
.sub-header .sub-header-inner {
  margin: 0 auto; padding: 0 20px; max-width: 1240px;
}
.sub-header .sub-header-inner .sub-header-container {
  display: flex;
}
.sub-header .sub-header-inner .sub-header-container .sub-header-item {
  flex: 0 1 25%;
  margin: 0;
  padding: 0 40px;
  border-top-left-radius: 40px;
  border-bottom-right-radius: 40px;

  display: flex;
  flex-direction: column;
}
.sub-header .sub-header-inner .sub-header-container .sub-header-item h3 { margin: 0; padding: 20px 0 40px 0;
  color: #fff;
  font-size: 30px;
  font-family: 'Oswald', sans-serif;
  font-weight: 400;
  text-transform: uppercase;
  text-align: center;
}
.sub-header .sub-header-inner .sub-header-container .sub-header-item p {
  flex-grow: 1;
  margin: 0;
  padding: 0;
  font-family: 'Raleway', sans-serif;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 1px;
  text-align: left;
  line-height: 20px;
}
.sub-header .sub-header-inner .sub-header-container .sub-header-item a {
  display: block;
  margin: 30px 0 20px 0;
  text-align: right;
  color: #fff;
  font-family: 'Raleway', sans-serif;
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.sub-header .sub-header-inner .sub-header-container .sub-header-item.blue { background: rgba(0,174,239,.85); }
.sub-header .sub-header-inner .sub-header-container .sub-header-item.yellow { background: rgba(233,215,123,.85); }
.sub-header .sub-header-inner .sub-header-container .sub-header-item.red { background: rgba(250,87,93,.85); }
.sub-header .sub-header-inner .sub-header-container .sub-header-item.green { background: rgba(0,149,72,.85); }

.sub-header .sub-header-inner .sub-header-container-buttons { display: none; }
.sub-header .sub-header-inner .sub-header-container-buttons a {display: block;
  margin: 0; padding: 20px 0;
  color: #fff;
  font-size: 30px;
  font-family: 'Oswald', sans-serif;
  font-weight: 400;
  text-transform: uppercase;
  text-align: center;
 }
 .sub-header .sub-header-inner .sub-header-item-button { display: block; text-align: center; }

.sub-header .sub-header-inner .sub-header-container-buttons .sub-header-item-button.blue { background: rgba(0,174,239,1); }
.sub-header .sub-header-inner .sub-header-container-buttons .sub-header-item-button.yellow { background: rgba(233,215,123,1); }
.sub-header .sub-header-inner .sub-header-container-buttons .sub-header-item-button.red { background: rgba(250,87,93,1); }
.sub-header .sub-header-inner .sub-header-container-buttons .sub-header-item-button.green { background: rgba(0,149,72,1); }


/*  ==========================================================================
    Home Styles
    ==========================================================================  */
main.home { position: relative; margin: 0; padding: 0;
  background: #ffffff;
  /*background-image: -moz-linear-gradient(top, #ffffff 0%, #D4F1FC 100%);
  background-image: -webkit-linear-gradient(top, #ffffff 0%, #D4F1FC 100%);
  background-image: linear-gradient(to bottom, #ffffff 0%, #D4F1FC 100%);*/
  background-repeat: no-repeat, no-repeat;
  background-position: bottom right, bottom;
  background-size: 50% auto, 100%;
}

main.home .home-inner { margin: 0 auto; padding: 0; max-width: 1240px; }

.home-content-container {
  margin: 0 20px;
  padding: 100px 0;
  display: flex;
}

.home-content-item { flex: 0 1 50%; }

h2.no-dots,
h2.dotted {
  position: relative;
  margin: 0 0 20px 0;
  padding: 0;
  color: rgba(0,149,72,1);
  font-family: 'Oswald', sans-serif;
  font-weight: normal;
  font-size: 40px;
  letter-spacing: .1em;
  text-transform: uppercase;
  line-height: 46px;
  display: flex;
  width: 100%;
  justify-content: left;
  align-items: center;
  text-align: left;
}
h2.dotted:after {
  content: "";
  border-top: 1px dotted rgba(0,149,72,1);
  margin: 0 0 0 20px;
  flex: 1 0 20px;
}
h2 span.arrow {
  position: absolute;
  text-align: right;
  top: -2px;
  right: -5px;
  font-size: 18px;
  margin: 0;
  padding: 0;
  /*background: #fff;*/
}

.home-content-item p {
  margin: 0;
  padding: 0 50px 20px 0;
  color: rgba(15,19,56,1);
  font-family: 'Raleway', sans-serif;;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 1px;
  line-height: 24px;
}

.home-content-item a { display: inline-block; margin-top: 40px; color: rgba(0,149,72,1); font-family: 'Oswald', sans-serif; font-size: 18px; font-weight: 400; letter-spacing: .1em; text-transform: uppercase; }
.home-content-item a.button span {
  margin: 0; padding: 10px 30px 10px 30px;
  border: 2px solid rgba(0,149,72,1);
  border-top-left-radius: 10px;
  border-bottom-right-radius: 10px;
  transition: all .15s ease;
}
.home-content-item a.button span:hover { color: #fff; background: rgba(0,149,72,1); /*opacity: .5; box-shadow: 0 5px 15px rgba(0,0,0,.2);*/ }

main.home .home-sub { display: none; }
.home-sub { margin: 0; padding: 0; width: auto; background: rgba(0,149,72,.80); }
.home-sub .home-sub-inner { margin: 0 auto; padding: 0; max-width: 1240px; }
.home-sub .home-sub-content { padding: 40px 20px; }
.home-sub .home-sub-content span {
  margin-right: 20px;
  color: #fff;
  font-family: 'Raleway', sans-serif;;
  font-size: 30px;
  font-weight: 700;
  letter-spacing: 1px;
}
.home-sub .home-sub-content>a {
  color: rgba(233,215,123,1); font-family: 'Oswald', sans-serif; font-size: 16px; font-weight: 400; letter-spacing: .1em; text-transform: uppercase;
}

.home-sub .home-sub-content a span { margin: 0; padding: 5px 15px 5px 15px;
  color: rgba(233,215,123,1);
  font-weight: 500;
  border: 2px solid rgba(233,215,123,1);
  border-top-left-radius: 10px;
  border-bottom-right-radius: 10px;
  transition: all .15s ease;
}
.home-sub .home-sub-content a span:hover { color: #fff; background: rgba(233,215,123,1); /*opacity: .5; box-shadow: 0 5px 15px rgba(0,0,0,.2);*/ }


/*  ==========================================================================
    Page Styles
    ==========================================================================  */
.banner { position: relative; margin: 0; padding: 0; }
.banner .banner-container { position: relative; display: block; height: 500px; width: 100%; transition: all .15s ease; overflow: hidden; }
.banner .banner-container .banner-image { position: absolute; top: 0; left: 0; right: 0; bottom: 0; z-index: 0;
  background-repeat: no-repeat;
  background-position: 50%;
  background-size: cover;
}

main.main { position: relative; margin: 0; padding: 0;
  background: #ffffff;
  /*background-image: -moz-linear-gradient(top, #ffffff 0%, #D4F1FC 100%);
  background-image: -webkit-linear-gradient(top, #ffffff 0%, #D4F1FC 100%);
  background-image: linear-gradient(to bottom, #ffffff 0%, #D4F1FC 100%);*/
  background-repeat: no-repeat, no-repeat;
  background-position: bottom left, bottom;
  background-size: 50% auto, 100%;
}

main.main .main-inner { margin: 0 auto; padding: 0; max-width: 1240px; }

.main-content-container {
  margin: 0 20px;
  padding: 100px 0;
  display: flex;
}

.main-content-item { flex: 0 1 50%; }

.main-content-item h1 {
  color: rgba(0,174,239,1);
  font-family: 'Raleway', sans-serif;
  font-size: 18px;
  text-transform: uppercase;
}

.main-content-item p {
  margin: 0;
  padding: 0 50px 20px 0;
  color: rgba(15,19,56,1);
  font-family: 'Raleway', sans-serif;;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 1px;
  line-height: 24px;
}
.main-content-item p a { display: inline; margin: 0; padding: 0; font-size: inherit; color: rgba(15,19,56,1); text-decoration: underline !important; text-transform: lowercase;}
.main-content-item p a:hover { color: rgba(15,19,56,.75); }

.main-content-item a { display: block; margin-top: 40px; color: rgba(0,149,72,1); font-family: 'Oswald', sans-serif; font-size: 18px; font-weight: 400; letter-spacing: .1em; text-transform: uppercase; }
.main-content-item a.button span {
  margin: 0; padding: 10px 30px 10px 30px;
  border: 2px solid rgba(0,149,72,1);
  border-top-left-radius: 10px;
  border-bottom-right-radius: 10px;
  transition: all .15s ease;
}
.main-content-item a.button span:hover { color: #fff; background: rgba(0,149,72,1); }

.main-content-item .image-container { width: 100%; height: 100%; }
.main-content-item .image-container img { display: block; margin: 0 auto; max-width: 100%; height: auto; }

.page-sub { margin: 0; padding: 0; width: auto; background: rgba(0,149,72,.80); }
.page-sub .page-sub-inner { margin: 0 auto; padding: 0; max-width: 1240px; }
.page-sub .page-sub-content { padding: 30px 20px; }
.page-sub .page-sub-content span {
  margin-right: 20px;
  color: #fff;
  font-family: 'Raleway', sans-serif;;
  font-size: 30px;
  font-weight: 500;
  letter-spacing: 1px;
}
.page-sub .page-sub-content>a  {
  color: rgba(233,215,123,1);
  font-family: 'Oswald', sans-serif;
  font-size: 16px; font-weight: 400;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.page-sub .page-sub-content a span { margin: 0; padding: 5px 15px 5px 15px;
  color: rgba(233,215,123,1);
  font-family: 'Oswald', sans-serif;
  font-size: 24px;
  font-weight: 400;
  letter-spacing: .1em;
  text-transform: uppercase;
  border: 2px solid rgba(233,215,123,1);
  border-top-left-radius: 10px;
  border-bottom-right-radius: 10px;
  transition: all .15s ease;
}
.page-sub .page-sub-content a span:hover { color: #fff; background: rgba(233,215,123,1); }

/*  ==========================================================================
    Basic Content Styles
    ==========================================================================  */
.content-container { margin: -50px 0 50px 0; padding: 0 20px; }


/*  ==========================================================================
    Blog Styles
    ==========================================================================  */
.blog-container { margin: -50px 20px 0 20px; padding: 0 0 100px 0; }

.blog-container h2 {
  margin: 0 0 20px 0;
  padding: 0;
  color: rgba(0,149,72,1);
  font-family: 'Oswald', sans-serif;
  font-weight: normal;
  font-size: 40px;
  letter-spacing: .1em;
  text-transform: uppercase;
  line-height: 46px;
}

.blog-container .blog-post-container {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
}
.blog-container .blog-post-container .blog-post-item {
  display: none; margin: 0 0 50px 0;  max-width: 360px; height: 100%;
  flex: 1 1 360px;
}
.blog-container .blog-post-container .blog-post-item {  }
.blog-container .blog-post-container .blog-post-item img { display: block; margin: 0 auto; max-width: 100%; height: auto; }
.blog-container .blog-post-container .blog-post-item h5 {
  margin: 0;
  padding: 10px 0;
  color: rgba(15,19,56,1);
  font-family: 'Raleway', sans-serif;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 1px;
  line-height: 20px;
}
.blog-container .blog-post-container .blog-post-item a {
  color: rgba(0,149,72,1);
  font-family: 'Raleway', sans-serif;
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.blog-container .blog-post-container .blog-post-item a:hover { color: rgba(0,149,72,.75); }
.blog-container #loadMore {
  color: rgba(0,149,72,1);
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 400;
  letter-spacing: .1em;
  text-transform: uppercase;
  text-align: center;
  cursor:pointer;
}
.blog-container #showLess {
  color: rgba(250,87,93,1);
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 400;
  letter-spacing: .1em;
  text-transform: uppercase;
  text-align: center;
  cursor:pointer;
  display: none;
}

.blog-container .content p {}
.blog-container .content img { float: right; display: block; }

/*  ==========================================================================
    Footer Styles
    ==========================================================================  */
footer { position: relative; margin: 0; padding: 0; background: rgba(213,211,218,1); }
footer .footer-inner { margin: 0 auto; padding: 0; max-width: 1240px; }

.footer-container {
  margin: 0 20px;
  padding: 30px 0;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  align-content: stretch;
}

.footer-item {
  flex: 0 1 33.3333333333%;
  padding: 0 10%;
}

.footer-item:first-child {
  padding-left: 0;
  border-right: 2px dotted rgba(0,149,72,1);
}

.footer-item:last-child {
  padding-right: 0;
  border-left: 2px dotted rgba(0,149,72,1);
}

.footer-item h4 {
  margin: 0 0 20px 0;
  padding: 0;
  color: rgba(0,149,72,1);
  font-family: 'Oswald', sans-serif;
  font-weight: 400;
  font-size: 16px;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.footer-item p {
  margin: 0 ;
  padding: 0;
  color: rgba(15,19,56,1);
  font-family: 'Raleway', sans-serif;;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 1px;
  line-height: 24px;
}
.footer-item .social a {
  color: rgba(15,19,56,1);
  font-family: 'Raleway', sans-serif;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 1px;
}
.footer-item .social a:hover {
  color: rgba(15,19,56,.75);
}
.footer-item .social .fab { color: rgba(0,149,72,1); }

.footer-item .footer-menu {
  margin: 0;
  padding: 0;
  list-style: none;

}
.footer-item .footer-menu li {
  padding: 0 0 15px 0;
}
.footer-item .footer-menu li a {
  display: block;
  color: rgba(15,19,56,1);
  font-family: 'Raleway', sans-serif;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.footer-item .footer-menu li a:hover { color: rgba(15,19,56,.75); }

.footer-item .footer-blog img { max-height: 150px; width: auto }
.footer-item .footer-blog a {
  color: rgba(0,149,72,1);
  font-family: 'Raleway', sans-serif;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.footer-item .footer-blog a:hover { color: rgba(0,149,72,.75); }

footer .footer-inner .copyright {
  margin: 0 20px;
  padding: 10px 0;
  color: rgba(15,19,56,1);
  text-transform: uppercase;
  border-top: 1px solid rgba(15,19,56,.65);
}
footer .footer-inner .copyright p {
  margin: 0;
  padding: 0;
  font-family: 'Raleway', sans-serif;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 1px;
  text-align: center;
}
footer .footer-inner .copyright p a {
  color: rgba(15,19,56,1);
  text-decoration: underline !important;
}
footer .footer-inner .copyright p a:hover { color: rgba(15,19,56,.75); }

/*  ==========================================================================
    Form Styles
    ==========================================================================  */
input[type=color],
input[type=date],
input[type=datetime-local],
input[type=datetime],
input[type=email],
input[type=month],
input[type=number],
input[type=password],
input[type=search],
input[type=tel],
input[type=text],
input[type=time],
input[type=url],
input[type=week],
select,
textarea { display: block; margin: 0 0 15px 0; padding: 6px 12px; width: 100%; height: 40px; color: #83868b; font-size: 16px; line-height: 1.8;
  background-color: #fff;
  background-image: none;
  border: 2px solid #ded4cb;
  border-radius: none;
  box-shadow: none!important;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}

input:focus[type=color],
input:focus[type=date],
input:focus[type=datetime-local],
input:focus[type=datetime],
input:focus[type=email],
input:focus[type=month],
input:focus[type=number],
input:focus[type=password],
input:focus[type=search],
input:focus[type=tel],
input:focus[type=text],
input:focus[type=time],
input:focus[type=url],
input:focus[type=week],
select:focus,
textarea:focus {
  outline: 0;
  border-color: #877f7a;
}

input.error[type=color],
input.error[type=date],
input.error[type=datetime-local],
input.error[type=datetime],
input.error[type=email],
input.error[type=month],
input.error[type=number],
input.error[type=password],
input.error[type=search],
input.error[type=tel],
input.error[type=text],
input.error[type=time],
input.error[type=url],
input.error[type=week],
select.error,
textarea.error {
  border-color: rgba(202,51,59,1);
}

input[type=color]::-ms-expand,
input[type=date]::-ms-expand,
input[type=datetime-local]::-ms-expand,
input[type=datetime]::-ms-expand,
input[type=email]::-ms-expand,
input[type=month]::-ms-expand,
input[type=number]::-ms-expand,
input[type=password]::-ms-expand,
input[type=search]::-ms-expand,
input[type=tel]::-ms-expand,
input[type=text]::-ms-expand,
input[type=time]::-ms-expand,
input[type=url]::-ms-expand,
input[type=week]::-ms-expand,
select::-ms-expand,
textarea::-ms-expand {
    border: 0;
    background-color: transparent
}

input[type=date] { position: relative; }
input[type=date]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    display: none;
}
input[type=date]::-webkit-calendar-picker-indicator {
  color: #ded4cb;
  font-size: 30px;
  /*-webkit-appearance: none;
    display: none;*/
}
input[type=date]::-webkit-calendar-picker-indicator:hover {
  background-color: #fff;
  color: #ca333b;
  cursor: pointer;
}
input[type=date]::-webkit-calendar-picker-indicator:active {
  color: #ca333b;
}

textarea { resize: vertical; }

fieldset,
legend { margin: 0; padding: 0; border: 0; }

::-webkit-input-placeholder { color: #999; } /* Chrome/Opera/Safari */
::-moz-placeholder { color: #999; } /* Firefox 19+ */
:-ms-input-placeholder { color: #999; } /* IE 10+ */
:-moz-placeholder { color: #999; } /* Firefox 18- */
::placeholder { color: #999; } /* Everything */

/* Specific User Forms Styles */
form.userform { margin: 0 auto; max-width: 800px; font-size: 18px; line-height: 30px; color: rgba(0,174,239,1); font-family: 'Raleway', sans-serif; }
form.userform > p.message { margin: 0 10px 30px 10px; padding: 15px; color: #a94442; background-color: #f2dede; border: 2px solid #ebccd1; }

form.userform > div.userform-fields { margin: 0; }

form.userform > div.userform-fields div.form-step {}

form.userform > div.userform-fields div.form-step div.field.field-no-margin { margin: 0; }

form.userform > div.userform-fields div.form-step div.field { margin: 0 0 30px 0; }
form.userform > div.userform-fields div.form-step div.requiredField {}
form.userform > div.userform-fields div.form-step fieldset,
form.userform > div.userform-fields div.form-step fieldset.optionset,
form.userform > div.userform-fields div.form-step fieldset.checkboxset { margin: 0 0 30px 0; }



form.userform > div.userform-fields div.form-step fieldset.checkboxset > .middleColumn > div { margin-bottom: 15px; height: 24px; line-height: 24px; }
form.userform > div.userform-fields div.form-step fieldset.checkboxset > .middleColumn > div:last-child { margin-bottom: 0; }

form.userform > div.userform-fields div.form-step fieldset.checkboxset input[type=checkbox],
form.userform > div.userform-fields div.form-step fieldset.checkboxset input[type=radio],
form.userform > div.userform-fields div.form-step fieldset.optionset input[type=radio] { position: relative; margin: 0; padding: 0; height: 24px; width: 24px;
  border: 2px solid #ded4cb;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  transition: all .15s ease-in-out;
}

form.userform > div.userform-fields div.form-step fieldset.checkboxset input[type=radio],
form.userform > div.userform-fields div.form-step fieldset.optionset input[type=radio] { border-radius: 50%; }

form.userform > div.userform-fields div.form-step fieldset.checkboxset input[type=checkbox]:after,
form.userform > div.userform-fields div.form-step fieldset.checkboxset input[type=radio]:after,
form.userform > div.userform-fields div.form-step fieldset.optionset input[type=radio]:after {
  position: absolute;
  display: block;
  font-family: "Font Awesome 5 Free";
  height: 24px;
  width: 24px;
  line-height: 24px;
  top: -2px;
  left: -2px;
  color: #fff;
  text-align: center;
  opacity: 0;
  visibility: hidden;
  transform: scale(0);
  transition: all .15s ease-in-out;
}

form.userform > div.userform-fields div.form-step fieldset.checkboxset input[type=checkbox]:checked,
form.userform > div.userform-fields div.form-step fieldset.checkboxset input[type=radio]:checked,
form.userform > div.userform-fields div.form-step fieldset.optionset input[type=radio]:checked { border-color: #877f7a; background: #877f7a; }

form.userform > div.userform-fields div.form-step fieldset.checkboxset input[type=radio]:checked,
form.userform > div.userform-fields div.form-step fieldset.optionset input[type=radio]:checked { border-radius: 50%; }

form.userform > div.userform-fields div.form-step fieldset.checkboxset input[type=checkbox]:after { font-size: 16px; font-weight: 600; content: "\F00C"; }
form.userform > div.userform-fields div.form-step fieldset.optionset input[type=radio]:after { font-size: 14px; font-weight: 600; content: "\F111"; }

form.userform > div.userform-fields div.form-step fieldset.checkboxset input[type=checkbox]:checked:after,
form.userform > div.userform-fields div.form-step fieldset.checkboxset input[type=radio]:checked:after,
form.userform > div.userform-fields div.form-step fieldset.optionset input[type=radio]:checked:after { opacity: 1; visibility: visible; transform: scale(1); }

form.userform > div.userform-fields div.form-step fieldset.checkboxset label,
form.userform > div.userform-fields div.form-step fieldset.optionset label { display: inline-block; margin-left: 10px; line-height: 24px; vertical-align: top; }

form.userform > div.userform-fields div.form-step fieldset legend {}

form.userform > div.userform-fields div.form-step div.field label { display: inline-block; max-width: 100%; }
form.userform > div.userform-fields div.form-step div.field label span.required-red,
form.userform > div.userform-fields div.form-step fieldset.field legend span.required-red { color: rgba(202,51,59,1); }

form.userform > div.userform-fields div.form-step div.field div.middleColumn { margin: 0; padding: 0; }

form.userform > div.userform-fields div.form-step div.field div.middleColumn input[type=text],
form.userform > div.userform-fields div.form-step div.field div.middleColumn input[type=email],
form.userform > div.userform-fields div.form-step div.field div.middleColumn input[type=date],
form.userform > div.userform-fields div.form-step div.field div.middleColumn textarea,
form.userform > div.userform-fields div.form-step div.field div.middleColumn select { height: 60px; color: #303133; }

form.userform > div.userform-fields div.form-step div.field div.middleColumn input.requiredField[type=text] {  }
form.userform > div.userform-fields div.form-step div.field div.middleColumn input.error[type=text] {  }

form.userform > div.userform-fields div.form-step div.field div.middleColumn textarea { height: 200px; }

form.userform > div.userform-fields div.form-step div.field div.middleColumn span.message { display: block; }
form.userform > div.userform-fields div.form-step div.field div.middleColumn span.error,
form.userform > div.userform-fields div.form-step fieldset.field div.middleColumn span.error { display: block; margin: -10px 0 10px 0; padding: 0;
    text-align: left;
    color: rgba(202,51,59,1);
    font-size: 14px;
    line-height: 20px;
    letter-spacing: .02em;
}

form.userform > nav { text-align: center; }
form.userform > nav > input[type=submit] {
  display: inline-block;
  padding: 18px 30px 14px 30px;
  min-width: 200px;
  color: #fff;
  /*font-family: 'Trump Gothic Pro', sans-serif;*/
  font-size: 18px;
  font-weight: bold;
  letter-spacing: .075em;
  line-height: 19px;
  text-align: center;
  text-transform: uppercase;
  vertical-align: middle;
  cursor: pointer;
  border: 2px solid rgba(0,149,72,1);
  background: rgba(0,149,72,1);
  transition: all .15s ease;
}
form.userform > nav > input:hover[type=submit] { color: #fff; border-color: #877f7a; background: #877f7a; outline: none!important; box-shadow: none!important; }

select {
  background-image:
    linear-gradient(45deg, transparent 50%, gray 50%),
    linear-gradient(135deg, gray 50%, transparent 50%),
    linear-gradient(to right, #ccc, #ccc);
  background-position:
    calc(100% - 20px) calc(1em + 10px),
    calc(100% - 15px) calc(1em + 10px),
    calc(100% - 2.5em) 1em;
  background-size:
    5px 5px,
    5px 5px,
    1px 1.5em;
  background-repeat: no-repeat;
}

select:focus {
  background-image:
    linear-gradient(45deg, #ca333b 50%, transparent 50%),
    linear-gradient(135deg, transparent 50%, #ca333b 50%),
    linear-gradient(to right, #ccc, #ccc);
  background-position:
    calc(100% - 15px) calc(1em + 10px),
    calc(100% - 20px) calc(1em + 10px),
    calc(100% - 2.5em) 1em;
  background-size:
    5px 5px,
    5px 5px,
    1px 1.5em;
  background-repeat: no-repeat;
}

form.userform > div.userform-fields div.form-step > div.form-sentence { margin-bottom: 0;  }
form.userform > div.userform-fields div.form-step > div.form-sentence > label { float: none; display: inline-block; padding: 0 10px 0 0; width: auto; font-weight: normal; }
form.userform > div.userform-fields div.form-step > div.form-sentence > div.middleColumn { float: none; display: inline-block; width: 70px; height: 40px; }
form.userform > div.userform-fields div.form-step > div.form-sentence > div.middleColumn > input[type=text] { height: 40px; }
form.userform > div.userform-fields div.form-step > div.form-sentence > span.right-title { float: none; display: inline-block; padding: 0 0 0 10px; }

/*  ==========================================================================
    Responsive Styles.
    Inlined to avoid the additional HTTP request: See Print Styles Below.
    ==========================================================================  */
@media only screen and (min-width: 1600px) {

  main.home {
    background-repeat: no-repeat, no-repeat;
    background-position: bottom right, bottom;
    background-size: auto 100%, 100%;
  }
}
@media only screen and (min-width: 1200px) {
  main.main {
    background-repeat: no-repeat, no-repeat;
    background-position: bottom left, bottom;
    background-size: 45% auto, 100%;
  }
}
@media only screen and (min-width: 1300px) {
  main.main {
    background-repeat: no-repeat, no-repeat;
    background-position: bottom left, bottom;
    background-size: 40% auto, 100%;
  }
}
@media only screen and (min-width: 1400px) {
  main.main {
    background-repeat: no-repeat, no-repeat;
    background-position: bottom left, bottom;
    background-size: 35% auto, 100%;
  }
}
@media only screen and (min-width: 1700px) {
  main.main {
    background-repeat: no-repeat, no-repeat;
    background-position: bottom left, bottom;
    background-size: 25% auto, 100%;
  }
}

@media only screen and (min-width: 1000px) {

  header.header nav.nav-mobile { display: none !important; }

}

@media only screen and (max-width: 1050px) {

  .page-sub .page-sub-content span { font-size: 26px; }

}

@media only screen and (max-width: 1000px) {

  header.header .nav-primary-inner .nav-primary-menu,
  header.header .nav-primary-inner .nav-primary-button { display: none; }

  header.header .nav-primary-inner .nav-mobile-trigger { display: block; }

  .hero .hero-container { height: 750px; }
  .banner .banner-container { height: 450px; }

  .page-sub .page-sub-content span { font-size: 24px; }

  .footer-item { padding: 0 5%; }

}

@media screen and (min-width: 768px) and (max-width: 1024px) { /* If I need something between specific page/screen sizes */

}

@media only screen and (max-width: 950px) {

  .hero .hero-container { height: 700px; }

  .page-sub .page-sub-content span { font-size: 22px; }

}

@media only screen and (max-width: 900px) {
  .hero .hero-container .hero-overlay .hero-overlay-inner .hero-text {
    top: 50%;
    left: 40%;
    margin: 20px;
    padding: 40px;
  }
  .hero .hero-container { height: 650px; }

  .sub-header .sub-header-inner {
    margin: 0 auto; padding: 0; max-width: auto;
  }
  .sub-header .sub-header-inner .sub-header-container {
    display: none;
  }

  .sub-header .sub-header-inner .sub-header-container-buttons { display: block; }

  .banner .banner-container { height: 400px; }

  main.home {
    background-repeat: no-repeat, no-repeat;
    background-position: bottom right, bottom;
    background-size: auto 40%, 100%;
  }
  main.main {
    background-repeat: no-repeat, no-repeat;
    background-position: bottom left, bottom;
    background-size: 0, 100%;
  }

  .main-content-container.blog { padding-top: 100px; }
  .main-content-container,
  .home-content-container {
    padding: 50px 0;
    display: flex;
    flex-direction: column;
  }
  .main-content-item,
  .home-content-item { flex: 0 1 100%; }
  .home-content-item:last-child { min-height: 250px; }

  .main-content-container:last-child { padding-top: 0; }

  .main-content-item:nth-child(2) { margin-top: 50px; }

  h2.dotted:after { display: none; }
  .arrow { display: none; }

  .main-content-item p,
  .home-content-item p { padding: 0 0 20px 0; }

  .main-content-item a,
  .home-content-item a { display: inline-block; margin: 20px auto; color: rgba(0,149,72,1); font-family: 'Oswald', sans-serif; font-size: 18px; font-weight: 400; letter-spacing: .1em; text-transform: uppercase; }
  .home-content-item a.button span {
    margin: 0; padding: 10px 30px 10px 30px;
  }
  .button-holder { text-align: center; }

  .blog-container { margin: 0 20px; padding: 0 0 50px 0; }


  main.home .home-sub { display: block; }
  .page-sub .page-sub-content,
  .home-sub .home-sub-content { padding: 20px; text-align: center; }

  .page-sub .page-sub-content > span { display:none; }
  .page-sub {}

}

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

  .hero .hero-container { height: 600px; }
  .hero .hero-container .hero-image { position: absolute; top: 0; left: 0; right: 0; bottom: 0; z-index: 0;
    background-repeat: no-repeat;
    background-position: 0%;
    background-size: cover;
  }

  .hero .hero-container .hero-overlay .hero-overlay-inner .hero-text {
    top: 55%;
    left: 30%;
    margin: 20px;
    padding: 30px;
  }

  .banner .banner-container { height: 300px; }

  .blog-container .blog-post-container {
    justify-content: space-around;
  }

  .footer-container { flex-direction: column; }

  .footer-item { padding: 30px 0; text-align: center; }
  .footer-item:first-child {
    padding-top: 0;
    border-right: none;
    border-bottom: 2px dotted rgba(0,149,72,1);
  }
  .footer-item:last-child {
    padding-bottom: 0;
    border-left: none;
    border-top: 2px dotted rgba(0,149,72,1);
  }


}

@media only screen and (max-width: 700px) {
  .hero .hero-container .hero-overlay .hero-overlay-inner .hero-text {
    top: 50%;
    left: 25%;
    margin: 20px;
    padding: 50px;
  }

  .banner .banner-container { height: 250px; }


}

@media only screen and (max-width: 600px) {
  .hero .hero-container .hero-image { position: absolute; top: 0; left: 0; right: 0; bottom: 0; z-index: 0;
    background-repeat: no-repeat;
    background-position: 5%;
    background-size: cover;
  }

  .hero .hero-container .hero-overlay .hero-overlay-inner .hero-text {
    top: 60%;
    left: 20%;
    margin: 20px;
    padding: 20px;
  }
}

@media only screen and (max-width: 500px) {
  .hero .hero-container .hero-image { position: absolute; top: 0; left: 0; right: 0; bottom: 0; z-index: 0;
    background-repeat: no-repeat;
    background-position: 10%;
    background-size: cover;
  }

  .hero .hero-container .hero-overlay .hero-overlay-inner .hero-text {
    top: 50%;
    left: 5%;
    margin: 20px;
    padding: 20px;
  }

  .main-content-item a { font-size: 16px; }
}

@media only screen and (max-width: 450px) {

  .main-content-item a { font-size: 14px; }

}

@media only screen and (max-width: 400px) {

  .main-content-item a { font-size: 12px; }

}