/*!   Template by Seltice Systems LLC   Copyright 2019 SELTICE SYSTEMS LLC   Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:   The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.   THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.   License applies to reset.css, styles.css, styles-nav.css, main.js, slideshow.js, and index.html files.   jQuery and FontAwesome fall under their own respective licenses.   License does NOT apply to any 3rd party integrations, such as Fontawesome, or Google Fonts.   Images provided by UNSPLASH.COM  This license does NOT apply to images provided by UNSPLASH.COM.   */   

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, article, aside, canvas, details, embed,  figure, figcaption, footer, header, hgroup,  menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 16px;
  font: inherit;
  vertical-align: baseline;
  font-family: 'Roboto',sans-serif;
  -webkit-tap-highlight-color: rgba(0,0,0,0);
  -webkit-tap-highlight-color: transparent;
  }

  input {
  -webkit-appearance: none;
 }

  /* HTML5 display-role reset for older browsers */ 
article, aside, details, figcaption, figure,  footer, header, hgroup, menu, nav, section {
  display: block;
 }

 body {
  line-height: 1;
 }

 ol, ul {
  list-style: none;
 }

 blockquote, q {
  quotes: none;
 }

 blockquote:before, blockquote:after, q:before, q:after {
  content: '';
  content: none;
 }

 table {
  border-collapse: collapse;
  border-spacing: 0;
 }

 img {
  vertical-align: bottom;
 }

 html {
 overflow-y: scroll;
 }

 strong {
  font-weight: bold;
 }

 i {
  font-style: italic;
  }

 b {
   font-weight: bold;
 }

 strong {
   font-weight: bold;
 }

 div {
  display: block;
  overflow: hidden;
  box-sizing: border-box;
  }

 
              
html, body {
  max-width: 100%;
  overflow-x: hidden;
 }

  ul {
  margin-top: 20px;
  margin-bottom: 20px;
  list-style-type: disc;
 }

  ul li {
  margin-left: 50px;
   }

  h1 {
  font-weight: 500;
    margin-bottom: 20px;
    text-align: center;
    font-size: 2rem;
    line-height: 2.5rem;
    text-transform: none;
  }

  h2 {
  color: #222;
  font-weight: 600;
  margin-bottom: 30px;
  text-align: center;
  font-size: 1.75rem;
  line-height: 2.25rem;
    }

 
  h3 {
  color: #222;
    font-weight: 300;
    margin-bottom: 20px;
    /* text-transform: uppercase; */
    font-size: 2rem;
    line-height: 2.5rem;

  
  }

  p {
  margin-bottom: 20px;
  }

  a {
   color: #0085e4;
  text-decoration: underline;
  }

  a:hover {
   color: #0085e4;
  text-decoration: underline;
  }

  header {
  display: block;
  position: relative;
  }

  .underline {
  text-decoration: underline;
  }

  .italic {
  font-style: italic;
  }

  .bigquote {
  font-family: sans-serif;
  font-size: 2rem;
  }

 .center-text {
  text-align: center;
  }

.mobile-header-navlink {
	border: 0;
	}

.mobile-header-navlink:focus {
	border: 1px solid #FFFFFF;
	}

  .testimonial-block {
  min-height: 240px;
  }

 .testimonial {
  font-size: 1.5rem;
  line-height: 2rem;
  font-style: italic;
  min-height: 110px;
 }

 .testimonial-credit {
  display: block;
  line-height: 2.5rem;
  font-size: 2.5rem;
  font-style: italic;
 }

 .testimonial-image {
  display: block;
  float: left;
  width: 50px;
  height: 50px;
  border-radius: 25px;
  background-position: center center;
  background-size: 100% auto;
  background-repeat: no-repeat;
  overflow: hidden;
  margin-right: 20px;
  }

 .header-container {
  display: block;
  position: relative;
  background-color: #2575b8;
   overflow: visible;
  }

 .header-container-inner {
  display: block;
  position: relative;
  padding: 25px 25px;
   height: auto;
  max-width: 1500px;
  margin: 0 auto;
      overflow: visible;
    height: 140px;
  }

 .header-right {
  color: #EEE;
  font-size: 1.6rem;
  line-height: 1.75rem;
  font-weight: 600;
  float: right;
   }

 .header-left {
  color: #EEE;
  font-size: 1.5rem;
  line-height: 1.6rem;
  font-weight: 600;
  float: left;
  padding: 6px;
  box-sizing: border-box;
  }

 .header-left a {
  color: #EEE;
  font-size: 1.5rem;
  line-height: 1.6rem;
  font-weight: 600;
  text-decoration: none;
  }

   .pointerfinger {
  cursor: pointer;
  }

 .mainbody {
  display: block;
  position: relative;
  background-color: #FFF;
   }

 .mainbody-inner {
  display: block;
  position: relative;
  padding: 40px 40px 40px 40px;
  font-size: 1.5rem;
  line-height: 2.5rem;
  font-weight: 300;
  max-width: 1200px;
  margin: 0 auto;
  color: #666;
  }

   .heroimage-outer {
  display: block;
  position: relative;
  overflow: hidden;
   height: 500px;
  width: 100%;
  background-color: #000;
  }

  .heroimage {
  display: block;
  position: absolute;
  overflow: hidden;
   background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  width: 100%;
  height: 100%;
  }

  .heroimage-inner {
  display: block;
    position: relative;
    overflow: hidden;
    padding: 60px 40px;
    top: 48%;
    transform: translateY(-50%);
    max-width: 1200px;
    margin: 0 auto;
    background-color: #00000066;
	border-radius: 5px;
  }

 .heroimage-inner-text {
  display: block;
  position: relative;
  overflow: hidden;
   
  font-size: 2rem;
  line-height: 2.5rem;
  font-weight: 300;
  color: #FFF;
  text-align: center;
  }

  .align-left {
  display: block;
  position: relative;
  float: none;
  margin: 15px 0px;
  }

  .align-right {
  display: block;
  position: relative;
  float: none;
  margin: 15px 0px;
  }

  .align-default {
  display: block;
  position: relative;
  float: none;
  margin: 15px 0px;
  }

  .banner {
  display: block;
  position: relative;
  background-color: #2575b8;
   }

  .banner-inner {
  display: table;
  position: relative;
  padding: 30px 20px;
   max-width: 1200px;
  margin: 0 auto;
  }

  .banner-inner-text {
  display: block;
  position: relative;
  overflow: hidden;
   
  font-size: 2rem;
  line-height: 2.5rem;
  font-weight: 300;
  color: #FFF;
  padding: 0px 30px;
  text-align: center;
  }

  .banner-button {
  display: block;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  border-radius: 30px;
  background-color: #27ada7;
  color: #FFF !important;  
  font-size: 1.5rem;
  line-height: 2.5rem;
  font-weight: 600;
  text-align: center;
  padding: 10px 30px;
  white-space: nowrap;
  width: auto;
  margin: 0 auto;
  }

  .banner-button:hover {
  background-color: #27ada7;
  color: #FFF !important;
  text-decoration: none !important;
  }

  .inner-text {
  display: block;
  position: relative;
  overflow: hidden;
   
  font-size: 1.5rem;
  line-height: 2.5rem;
  font-weight: 300;
  color: #666;
  padding: 4px 4px;
  text-align: left;
  }

  .inner-image-static {
  display: block;
  position: relative;
  overflow: hidden;
  width: auto;
  height: auto;
  max-width: 500px;
  }

  .inner-map-static {
  display: block;
  position: relative;
  overflow: hidden;
  width: auto;
  height: auto;
  max-width: 500px;
  }

  .inner-image-static img {
  display: block;
  position: relative;
  overflow: hidden;
  width: 100%;
  }

  .inner-image {
  display: block;
  position: relative;
  overflow: hidden;
  width: auto;
  height: auto;
  max-width: none;
   }

 .inner-image img {
  display: block;
  position: relative;
  overflow: hidden;
  width: 100%;
  height: auto;
  top: auto;
  left: auto;
  transform: none;
  }

  .margin-left {
   margin-left: 0px;
   }

    .margin-right {
   margin-right: 0px;
   }

  .padding-left {
  padding-left: 0px;
  }

  .padding-right {
  padding-right: 0px;
  }

     .grid {
  display: block;
  position: relative;
  overflow: hidden;
  width: auto;
  max-width: 1200px;
  margin: 0 auto;
  margin-bottom: 20px;
  }

   .grid-elem {
  display: block;
  width: auto;
  float: none;
  margin: 0;
  }

   .grid-image {
  display: block;
  position: relative;
  width: 100%;
  height: auto;
  left: auto;
  top: auto;
  transform: none;
  cursor: pointer;
  }

   .cols {
  display: table;
  position: relative;
  overflow: hidden;
  width: 100%;
  max-width: 1500px;
  margin: 0 auto;
  margin-bottom: 20px;
  }

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

  .margin-sides {
  margin-left: 0px;
  margin-right: 0px;
  }

  input[type="button"],input[type="reset"],input[type="submit"] {
  display: inline-block;
    padding: 18px 40px;
    cursor: pointer;
    font-size: 1.6rem;
    border: 0;
    font-weight: 300;
    color: #FFF;
    font-family: sans-serif;
    width: auto;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    border-radius: 5px;
    background-color: #2fc1bb;
    margin-left: 4px;
    margin-right: 4px;
    border: 0;
	margin-bottom: 15px;
 }

  input[type="text"] {
   padding: 15px;
  font-size: 1rem;
  color: #333;
  font-family: sans-serif;
  width: 100%;
  -webkit-box-sizing: border-box;
 /* Safari/Chrome, other WebKit */  -moz-box-sizing: border-box;
 /* Firefox, other Gecko */  box-sizing: border-box;
  border: 0;
  }

  textarea {
   margin: 0 auto;
  padding: 15px;
  font-size: 1rem;
  color: #333;
  font-family: sans-serif;
  line-height: 25px;
  width: 100%;
  height: 300px;
  -webkit-box-sizing: border-box;
 /* Safari/Chrome, other WebKit */  -moz-box-sizing: border-box;
 /* Firefox, other Gecko */  box-sizing: border-box;
  border: 0;
  }

  .onlymobilebr {
  display: block;
  clear: both;
  margin: 0;
  }

  .onlydesktop {
  display: none;
  }

  .onlymobile {
  display: inline;
  }

  .icon-img {
  font-size: 6rem;
  }

  .col-inner {
  padding: 20px;
  }

  .col1of1 {
  display: block;
  float: none;
  position: relative;
  width: auto;
  max-width: none;
  margin: 0 auto;
  margin-top: 20px;
  text-align: center;
 }

  .col1of4 {
  display: block;
  float: none;
  position: relative;
  width: 100%;
  max-width: none;
  margin: 0 auto;
  text-align: center;
  }

  .col2of4 {
  display: block;
  float: none;
  clear: none;
  position: relative;
  width: 100%;
  max-width: none;
  margin: 0 auto;
  text-align: center;
  }

  .col3of4 {
  display: block;
  float: none;
  position: relative;
  width: 100%;
  max-width: none;
  margin: 0 auto;
  padding-top: 0px !important;
  text-align: center;
  }

  .col4of4 {
  display: block;
  float: none;
  position: relative;
  width: 100%;
  max-width: none;
  margin: 0 auto;
  padding-top: 0px !important;
  text-align: center;
  }

   .cols4 {
  padding-top: 30px !important;
  }

  .cols4 .inner-image {
  height: 160px;
  }

  .cols4 h3 {
  font-size: 1.4rem;
  }

  .cols4 p {
  font-size: 1rem;
  line-height: 1.2rem;
  }

  .col1of3 {
  display: block;
  float: none;
  position: relative;
  width: 100%;
  max-width: none;
  margin: 0 auto;
  }

  .col2of3 {
  display: block;
  float: none;
  position: relative;
  width: auto;
  max-width: none;
  margin: 0 auto;
  }

  .col3of3 {
  display: block;
  float: none;
  position: relative;
  width: auto;
  max-width: none;
  margin: 0 auto;
  padding-top: 0px !important;
  }

  .circlepic {
  border-radius: 50%;
  overflow: hidden;
   }

   .bg-lightgray {
  background-color: #EEE;
  border-bottom: 1px solid #777;
  padding: 20px 0px;
  }

  .bg-white {
  background-color: #FFF;
  border-bottom: 1px solid #777;
  padding: 20px 0px;
  }

  .bg-darkgray {
  background-color: #222;
  border-bottom: 1px solid #777;
  padding: 20px 0px;
  }

  .bg-darkblue {
  background-color: #2575b8;
  border-bottom: 1px solid #2c5678;
  padding: 20px 0px;
  }

  .no-border {
  border: none !important;
  }

  .no-padding-top {
  padding-top: 0px !important;
  }

  .no-padding-bottom {
  padding-bottom: 0px !important;
  }

  .text-align-center {
  text-align: center;
  }

  .col1of2 {
  display: block;
  float: none;
  position: relative;
  width: auto;
  max-width: none;
  margin: 0 auto;
  }

  .col2of2 {
  display: block;
  float: none;
  position: relative;
  width: auto;
  max-width: none;
  margin: 0 auto;
  }

  .no-max-width {
  max-width: none !important;
  }

  .smallerpic {
  max-width: 80% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  }

  .general-button {
  display: table;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  border-radius: 30px;
  background-color: #407db0;
  color: #FFF !important;
  
  font-size: 1.5rem;
  line-height: 2.5rem;
  font-weight: 600;
  text-align: center;
  padding: 10px 40px;
  white-space: nowrap;
  min-width: 100px;
  margin: 0 auto;
  }

  .general-button:hover {
  background-color: #0085e4;
  color: #FFF !important;
  text-decoration: none !important;
  }

  .darkoverlaycontainer {
  display: none;
  position: fixed;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  }

  .darkoverlay {
  display: block;
  position: fixed;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  background-color: #000;
  opacity: 0.85;
  }

  .hidedarkoverlay {
  display: block;
  position: fixed;
  left: 20px;
  top: 20px;
   color: #FFF;
  font-size: 2rem;
  cursor: pointer;
  }

  .lightbox {
  display: block;
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
  width: 90%;
  height: auto;
  }

  .lightbox img {
  display: block;
  width: auto;
  max-width: 100%;
  margin: 0 auto;
  }

  footer h3 {
  }

  footer p {
  }

    .footer-social {
  }

  .footer-inner-text {
   display: block;
   position: relative;
   overflow: hidden;
   font-size: 1rem;
   line-height: 1.7rem;
   font-weight: 300;
   color: #aaa;
   padding: 4px 4px;
   text-align: left;
   }

  .footer-inner-text h3 {
  display: block;
  position: relative;
  overflow: hidden;
  font-size: 1rem;
  line-height: 1.7rem;
  font-weight: 600;
  color: #EEE;
  padding: 0px 0px;
  text-align: left;
  text-transform: uppercase;
  }

 .footer-link {
  display: inline;
  color: #BBB;
 }

  .footer-link:hover {
  text-decoration: none;
  color: #FFF;
  }

   .footer-nav-link {
  display: block;
  position: relative;
  color: #BBB;
  border-bottom: 1px solid #555;
  padding: 10px 0px;
  float: none;
  text-decoration: none;
 }

  .footer-nav-link:hover {
  text-decoration: none;
  color: #FFF;
  }

  .footer-nav-links a:first-of-type {
  padding-top: 0px;
  text-decoration: none;
  }

  .footer-nav-links a:last-of-type {
  border-bottom: none;
  }

  .no-border {
  border: 0;
  }

  .footer-right {
  float: none;
   text-align: center;
  }

  .footer-col1of1 {
  display: block;
  float: none;
  position: relative;
  width: 100%;
  max-width: none;
  margin: 0 auto;
  margin-bottom: 20px;
  text-align: center;
  }

  .footer-col1of2 {
  display: block;
  float: none;
  position: relative;
  width: 100%;
  max-width: none;
  margin: 0 auto;
  margin-bottom: 20px;
  }

  .footer-col2of2 {
  display: block;
  float: none;
  position: relative;
  width: 100%;
  max-width: none;
  margin: 0 auto;
  margin-bottom: 20px;
  }

     .footer-col1of3 {
  display: block;
  float: none;
  position: relative;
  width: auto;
  max-width: none;
  margin: 0 auto;
  margin-bottom: 20px;
  }

  .footer-col2of3 {
  display: block;
  float: none;
  position: relative;
  width: auto;
  max-width: none;
  margin: 0 auto;
  margin-bottom: 20px;
  }

  .footer-col3of3 {
  display: block;
  float: none;
  position: relative;
  width: auto;
  max-width: none;
  margin: 0 auto;
  padding-top: 0px !important;
  margin-bottom: 20px;
  }

   .logo-container {
  display: block;
  position: relative;
  padding: 0px 0px;
  /* border-radius: 100%; */
  z-index: 100000;
  background-color: none;
  width: 100%;
  /* max-width: 75px; */
  /* margin-top: -20px; */
  }

 .logo-container img {
  display: block;
  margin: 0;
  height: 70px;
  /* max-width: 55px; */

  }

    #backtotopbutton {
  position:fixed;
  cursor:pointer;
  width:50px;
  height:50px;
  border-radius:10px;
  -webkit-border-radius:10px;
  -moz-border-radius:10px;
  right:15px;
  bottom:15px;
  background-color:#6b9ec9;
  /* text-indent:-9999px;
 */  display:none;
  color: #FFF;
  text-align: center;
  font-size: 1.2rem;
  line-height: 3rem;
  opacity: 0.5;
 }

   #backtotopbutton:hover {
  background-color:#3e79aa;
  }

       @media only screen and (min-width: 640px) {
       .slideshowleftarrow {
   display: block;
   position: absolute;
   left: 0;
   top: 50%;
   margin-top: -30px;
   font-size: 3rem;
   line-height: 3.5rem;
   margin-left: 20px;
   opacity: 0.3;
   z-index: 100000;
   color: #FFF;
   cursor: pointer;
  }

  .slideshowrightarrow {
   display: block;
   position: absolute;
   right: 0;
   top: 50%;
   margin-top: -30px;
   font-size: 3rem;
   line-height: 3.5rem;
   margin-right: 20px;
   opacity: 0.3;
   z-index: 100000;
   color: #FFF;
   cursor: pointer;
  }

   .slidedots {
   display: block;
   position: absolute;
   width: 100%;
   overflow: visible;
   margin: 0 auto;
   bottom: 0;
   margin-bottom: 20px;
   text-align: center;
  }

  .slidedots-inner {
   display: table;
   position: relative;
   width: auto;
   margin: 0 auto;
  }

  .slidedot {
   display: block;
   float: left;
   width: 20px;
   height: 20px;
   cursor: pointer;
   font-size: 1rem;
   line-height: 1.5rem;
   color: #FFF;
   opacity: 0.3;
   margin-left: 5px;
   margin-right: 5px;
   }

      .heroimage-outer {
   display: block;
   position: relative;
   overflow: hidden;
    height: 800px;
   width: 100%;
   margin-top: 0px;
   }

   .heroimage {
   height: 100%;
   }

   .heroimage-inner-text {
   display: block;
   position: relative;
   overflow: hidden;
   font-size: 4rem;
   line-height: 4.5rem;
   font-weight: 300;
   color: #FFF;
   text-align: center;
   }

   .mainbody-inner {
   display: block;
   position: relative;
   padding: 40px;
   font-size: 1.6rem;
   line-height: 2rem;
   font-weight: 300;
   max-width: 1200px;
   margin: 0 auto;
   }

   h1 {
   font-weight: 500;
    margin-bottom: 20px;
    text-align: center;
    font-size: 2rem;
    line-height: 3rem;
    text-transform: none;
   }

   h2 {
   font-weight: 600;
   margin-bottom: 30px;
   text-align: center;
   font-size: 2rem;
   line-height: 3rem;
   }

   .banner-inner-text {
   display: block;
   position: relative;
   overflow: hidden;
   font-size: 2.5rem;
   line-height: 3rem;
   font-weight: 300;
   color: #FFF;
   padding: 0px 30px;
   text-align: left;
   }

   .banner-button {
  display: block;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  border-radius: 30px;
  background-color: #27ada7;
  color: #FFF !important;  
  font-size: 1.5rem;
  line-height: 2.5rem;
  font-weight: 600;
  text-align: center;
  padding: 10px 30px;
  white-space: nowrap;
  width: auto;
  margin: 0 auto;
  }

  .banner-button:hover {
  background-color: #27ada7;
  color: #FFF !important;
  text-decoration: none !important;
  }

   .align-left {
   display: block;
   position: relative;
   float: left;
   margin: 0px 0px;
   }

   .align-right {
   display: block;
   position: relative;
   float: right;
   margin: 0px 0px;
   }

   .align-default {
   display: block;
   position: relative;
   float: none;
   margin: 0px 0px;
   }

   .inner-text {
   display: block;
   position: relative;
   overflow: hidden;
   font-size: 1.6rem;
   line-height: 2rem;
   font-weight: 300;
   color: #666;
   padding: 4px 4px;
   text-align: left;
   }

   .inner-image-static {
   display: block;
   position: relative;
   overflow: hidden;
   width: auto;
   height: auto;
   max-width: 300px;
   }

   .inner-map-static {
   display: block;
   position: relative;
   overflow: hidden;
   width: auto;
   height: auto;
   max-width: 500px;
   }

   .inner-image-static img {
   display: block;
   position: relative;
   overflow: hidden;
   width: 100%;
   }

   .inner-image {
   display: block;
   position: relative;
   overflow: hidden;
   width: auto;
   height: 250px;
   max-width: 300px;
    }

  .inner-image img {
   display: block;
   position: relative;
   overflow: hidden;
   width: auto;
   height: 120%;
   top: 50%;
   left: 50%;
   transform: translate(-50%,-50%);
   }

    .cols4 {
   padding-top: 30px !important;
   }

   .cols4 .inner-image {
   height: 160px;
   }

   .cols4 h3 {
   font-size: 1.2rem;
   }

   .cols4 p {
   font-size: 1rem;
   line-height: 2rem;
   }

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

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

    .padding-left {
   padding-left: 20px;
   }

    .padding-right {
   padding-right: 20px;
   }

    .col1of4 {
   display: block;
   float: left;
   position: relative;
   width: 48%;
   max-width: none;
   margin-right: 2%;
      }

   .col2of4 {
   display: block;
   float: right;
   clear: right;
   position: relative;
   width: 48%;
   max-width: none;
   margin-left: 2%;
   }

   .col3of4 {
   display: block;
   float: left;
   position: relative;
   width: 48%;
   max-width: none;
   margin: 0 auto;
   padding-top: 0px !important;
   margin-right: 2%;
   }

   .col4of4 {
   display: block;
   float: right;
   clear: right;
   position: relative;
   width: 48%;
   max-width: none;
   margin: 0 auto;
   padding-top: 0px !important;
   margin-left: 2%;
   }

   .col1of3 {
   display: block;
   float: left;
   position: relative;
   width: 100%;
   max-width: 48%;
   margin-left: 0%;
   margin-right: 2%;
   }

    .col2of3 {
   display: block;
   float: left;
   position: relative;
   width: 100%;
   max-width: 48%;
   margin-left: 2%;
   margin-right: 0%;
   }

    .col3of3 {
   display: block;
   float: none;
   position: relative;
   width: 48%;
   max-width: 48%;
   margin: 0 auto;
   padding-top: 40px !important;
   }

    .footer-right {
   float: right;
    text-align: right;
    }

      .footer-col1of1 {
   display: block;
   float: none;
   position: relative;
   width: 100%;
   max-width: none;
   margin: 0 auto;
   margin-bottom: 20px;
   text-align: center;
    }

   .footer-col1of2 {
   display: block;
   float: left;
   position: relative;
   width: 70%;
   max-width: none;
   margin: 0 auto;
   margin-bottom: 20px;
   }

   .footer-col2of2 {
   display: block;
   float: right;
   position: relative;
   width: 30%;
   max-width: none;
   margin: 0 auto;
   margin-bottom: 20px;
   text-align: right;
   }

   .footer-col1of3 {
   display: block;
   float: left;
   position: relative;
   width: 42%;
   margin: 0;
   margin-right: 2%;
   }

   .footer-col2of3 {
   display: block;
   float: left;
   position: relative;
   width: 29%;
   margin: 0;
   margin-left: 2%;
   margin-right: 2%;
   }

   .footer-col3of3 {
   display: block;
   float: left;
   position: relative;
   width: 21%;
   margin: 0;
   margin-left: 2%;
   }

     .col1of2 {
   display: block;
   float: left;
   position: relative;
   width: 48%;
   max-width: 48%;
   margin-left: 0%;
   margin-right: 2%;
   }

   .col2of2 {
   display: block;
   float: left;
   position: relative;
   width: 48%;
   max-width: 48%;
   margin-left: 2%;
   margin-right: 0%;
   }

   .smallerpic {
   max-width: 70% !important;
   margin-left: auto !important;
   margin-right: auto !important;
   }

   .grid-elem {
   display: block;
   position: relative;
   overflow: hidden;
   width: 33%;
   height: 160px;
   float: left;
   margin: 0;
   }

   .grid-image {
   display: block;
   position: relative;
   width: auto;
   height: 260px;
   left: 50%;
   top: 50%;
   transform: translate(-50%,-50%) !important;
    transition: 0.2s;
   }

    .grid-image:hover {
   cursor: pointer;
   transform: scale(1.5) translate(-33%,-33%) !important;
    }

       }

         @media only screen and (min-width: 940px) {
   .onlymobilebr {
   display: none;
  }

   .onlydesktop {
   display: inline-block;
   }

   .onlymobile {
   display: none;
   }

    .logo-container {
   display: block;
   position: relative;
   padding: 0px 0px;
   /* border-radius: 100%; */
   z-index: 100000;
   width: 100%;
   /* max-width: 150px; */
   /* margin-top: -25px; */
   }

  .logo-container img {
   display: block;
   margin: 0;
   width: auto;
   height: 70px;
   }

    .col1of4 {
   display: block;
   float: left;
   position: relative;
   width: 23%;
   max-width: none;
   margin-right: 2%;
   }

   .col2of4 {
   display: block;
   float: right;
   clear: none;
   position: relative;
   width: 23%;
   max-width: none;
   margin-left: 1%;
   margin-right: 1%;
   }

   .col3of4 {
   display: block;
   float: left;
   position: relative;
   width: 23%;
   max-width: none;
   margin: 0 auto;
   padding-top: 0px !important;
   margin-left: 1%;
   margin-right: 1%;
   }

   .col4of4 {
   display: block;
   float: right;
   clear: none;
   position: relative;
   width: 23%;
   max-width: none;
   margin: 0 auto;
   padding-top: 0px !important;
   margin-left: 2%;
   }

   .cols4 {
   padding-top: 30px !important;
   }

   .cols4 .inner-image {
   height: 160px;
   }

   .cols4 h3 {
   font-size: 1.2rem;
   }

   .cols4 p {
   font-size: 1rem;
   line-height: 1.5rem;
   }

    }

            @media only screen and (min-width: 1000px) {
   .heroimage-outer {
   display: block;
   position: relative;
   overflow: hidden;
    height: 750px;
   width: 100%;
   }

   .heroimage {
   height: 100%;
   }

   .heroimage-inner-text {
   display: block;
    position: relative;
    overflow: hidden;
    font-size: 4.2rem;
    line-height: 5rem;
    font-weight: 600;
    color: #ffffff;
    text-align: center;
    /* text-shadow: 2px 2px 2px #000000; */
   }

   .mainbody-inner {
   display: block;
   position: relative;
   padding: 120px 40px;
   font-size: 1.6rem;
   line-height: 2.5rem;
   font-weight: 300;
   max-width: 1500px;
   margin: 0 auto;
   }

   h1 {
   font-weight: 500;
    margin-bottom: 20px;
    text-align: center;
    font-size: 2.6rem;
    line-height: 3rem;
    text-transform: none;
   }

   h2 {
   font-weight: 600;
   margin-bottom: 30px;
   text-align: center;
   font-size: 2.2rem;
   line-height: 3rem;
   }

   .banner-inner-text {
   display: block;
   position: relative;
   overflow: hidden;
   font-size: 2.7rem;
   line-height: 3rem;
   font-weight: 300;
   color: #FFF;
   padding: 0px 30px;
   text-align: left;
   }

   .banner-button {
   display: inline-block;
   position: relative;
   overflow: hidden;
   text-decoration: none;
   border-radius: 30px;
   background-color: #2fc1bb;
   color: #FFF !important;
   font-size: 1.6rem;
   line-height: 3rem;
   font-weight: 600;
   text-align: center;
   padding: 0px 30px;
   
   }

   .banner-button:hover {
   color: #FFF !important;
   background-color: #1ea59f !important;
   }

   .inner-text {
   display: block;
    position: relative;
    overflow: hidden;
    font-size: 1.5rem;
    line-height: 2.5rem;
    font-weight: 300;
    color: #222222;
    padding: 4px 4px;
    text-align: left;
   }

   .inner-image-static {
   display: block;
   position: relative;
   overflow: hidden;
   width: 100%;
   height: auto;
   max-width: 500px;
   }

   .inner-map-static {
   display: block;
   position: relative;
   overflow: hidden;
   width: 100%;
   height: auto;
   max-width: 350px;
   }

      .inner-image-static img {
   display: block;
   position: relative;
   overflow: hidden;
   width: 100%;
   }

   .inner-image {
   display: block;
   position: relative;
   overflow: hidden;
   width: auto;
   height: 250px;
   max-width: 500px;
   }

   .inner-image img {
   display: block;
   position: relative;
   overflow: hidden;
   width: auto;
   height: 120%;
   top: 50%;
   left: 50%;
   transform: translate(-50%,-50%);
   }

   .margin-left {
   margin-left: 60px;
   }

    .margin-right {
   margin-right: 60px;
   }

   .padding-left {
   padding-left: 60px;
   }

    .padding-right {
   padding-right: 60px;
   }

   .col1of3 {
   display: block;
   float: left;
   position: relative;
   width: 100%;
   max-width: 31%;
   margin-left: 0%;
   margin-right: 2%;
   }

    .col2of3 {
   display: block;
   float: left;
   position: relative;
   width: 100%;
   max-width: 31%;
   margin-left: 1.5%;
   margin-right: 1.5%;
   }

    .col3of3 {
   display: block;
   float: right;
   position: relative;
   width: 100%;
   max-width: 31%;
   margin-left: 2%;
   margin-right: 0%;
   padding-top: 0px !important;
   }

   .smallerpic {
   max-width: 60% !important;
   margin-left: auto !important;
   margin-right: auto !important;
   }

   .grid-elem {
   display: block;
   position: relative;
   overflow: hidden;
   width: 33%;
   height: 250px;
   float: left;
   margin: 0;
   }

   .grid-image {
   display: block;
   position: relative;
   width: auto;
   height: 350px;
   left: 50%;
   top: 50%;
   transform: translate(-50%,-50%) !important;
    }

    }

         @media only screen and (min-width: 1300px) {
   .heroimage-outer {
   display: block;
   position: relative;
   overflow: hidden;
    height: 550px;
   width: 100%;
   }

   .heroimage {
   width: 100%;
   height: 100%;
   }

  }



  @media only screen and (min-width: 1400px) {
   .heroimage-outer {
   display: block;
   position: relative;
   overflow: hidden;
    height: 650px;
   width: 100%;
   }

   .heroimage {
   width: 100%;
   height: 100%;
   }

  }

  .recaptchablock {
   display: block;
 margin: 0 auto;
 margin-bottom: 30px;
  }

  @media screen and (min-width: 940px) {
  .recaptchablock {
   display: table;
 margin: 0 auto;
 margin-bottom: 30px;
  }

 }

             .header-navlink {
  color: #EEE !important;
  text-decoration: none;
  }

 .header-navlink:hover {
  color: #FFF !important;
  text-decoration: none;
  }

  .nav-x-mobile {
  display: block !important;
  text-align: right;
  }

  .nav-outer {
	  display: block;
	  position: absolute;
	  width: 100%;
	  height: 100%;
	  left: 0;
	  top: 0;
	  overflow: hidden;
   }

 .nav {
  display: block;
  position: absolute;
  right: -300px;
  top: 0;
   width: 300px;
  height: auto;
  min-height: 100%;
  z-index: 100000;
  transition: 0.5s;
    }

  .nav-inner {
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  background-color: #111;
  /* opacity: 0.9;
 */  width: 100%;
  height: 100%;
  z-index: 100001;
   }

  .nav-inner-2 {
  padding: 0px 30px;
  }

  .nav-link {
  display: block;
  position: relative;
  color: #EEE !important;
  padding: 0px; /* 18px 20px 17px 0px; */
  /* border-bottom: 1px solid #666; */
  font-size: 1.6rem;
  line-height: 5rem;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  text-align: left;
  z-index: 100002;
  }

  .nav-link:hover {
  color: #FFF !important;
  text-decoration: none;
  }

  .mobnav-header {
  display: block;
  }

  .nav-topright {
  display: block;
  position: fixed;
  right: -300px;
  top: 0;
   width: 300px;
  height: 100%;
  z-index: 100000;
  transition: 0.5s;
  background-color: #111;
  padding: 0px;
  }

  .nav-desktop-inner {
  display: block;
  padding: 0px 30px;
  }

  .nav-link-top {
  display: block;
  position: relative;
  color: #EEE !important;
  padding: 23px 20px 22px 0px;
  border-bottom: 1px solid #666;
  font-size: 1.5rem;
  line-height: 2rem;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  text-align: left;
  z-index: 100002;
  }

  .nav-link-top:hover {
  color: #FFF !important;
  text-decoration: none;
  }

  .nav-x {
  text-align: right;
  }

   .subnav {
   padding-left: 40px;
     }

  .subnav a {
   display: block;
  float: none;
  padding: 13px 10px 12px 0px;
  line-height: 16px;
  font-size: 1rem;
   }

    #header-right-desktop {
  display: none;
  }

  #header-right-mobile {
  display: block;
  }

     @media only screen and (min-width: 640px) {
   #header-right-desktop {
   display: none;
   }

   #header-right-mobile {
   display: block;
   }

     }

           @media only screen and (min-width: 940px) {
   .nav-topright {
   display: block;
   position: relative;
   right: auto;
   left: auto;
   top: auto;
   width: auto;
   height: auto;
   }

   .nav-x {
   display: none;
   }

    #header-right-desktop {
   display: block;
   position: relative;
   }

   #header-right-mobile {
   display: none;
   }

   #header-right-desktop .subnav-outer {
   display: inline-block;
   float: left;
   position: relative;
   overflow: visible;
   }

   #header-right-desktop .nav-link {
   position: relative;
   float: left;
   font-size: 1.6rem;
   line-height: 3rem;
   font-weight: 300;
   border: 0;
   padding-top: 0px;
   padding-right: 0px;
   padding-left: 0px;
   margin-left: 20px;
   }

   #header-right-desktop .nav-link a {
     font-weight: 300;
   border: 0;
   padding-top: 0px;
   padding-right: 0px;
   padding-left: 15px;
   position: relative;
   display: inline-block;
   }

   #header-right-desktop .nav-link a:hover {
   font-weight: 300;
   text-decoration: none;
   color: #FFF;
   }

    #header-right-desktop .subnav {
   display: none;
   position: fixed;
   z-index: 500000;
   margin: 40px 0px 0px 0px;
   padding: 20px 40px 20px 40px;
   background-color: #2575b8;
   width: 170px;
    }

   #header-right-desktop .subnav a {
   display: block;
   float: none;
   font-size: 1rem;
   line-height: 1.5rem;
   padding: 10px 0px;
   border-bottom: 0px solid #AAA;
   margin: 0;
   text-align: right;
   }

     #header-right-desktop .subnav a:last-of-type {
   border-bottom: 0;
   }

    }

.banner-inner-small-container {

	
	display: block;

	position: relative;


	width: 100%;

    max-width: 1300px;

    margin: 0 auto;

    margin-bottom: 30px;

	
}

.banner-inner-small {

	display: block;

	position: relative;

	font-size: 1.2rem;

    color: #ffffff;

    font-weight: bold;

    font-style: italic;

    line-height: 2rem;

    text-align: center;

  	padding: 0px 30px;

}




.header-right {
	
	}

.header-right-ham {
		display: block;
		position: relative;
		width: auto;
		height: auto;
		left: auto;
		top: auto;
		color: #EEE;
	  font-size: 3rem;
	  line-height: 3.5rem;
		font-weight: 600;
		  float: right;
		 padding: 4px 4px;

		  }

#header-right-desktop {
	display: none;
    position: absolute;
    z-index: 10000;
    width: 240px;
    height: 700px;
    background-color: #2575b8;
    padding: 30px;
    right: 0;
    left: auto;
    top: 110px;
    padding-top: 4px;

	}

	#header-right-desktop .nav-link {
		margin-left: 0px;
		}

.nomobnav {
	display: none;
	}

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

	.header-right {
		
		}

	#header-right-desktop {
		display: block;
		position: relative;
		width: auto;
		height: auto;
		top: auto;
		left: auto;
		right: auto;
		padding: 4px 4px;
		transition: none;
		height: 70px;
		margin-top: 6px;
	}

	#header-right-desktop .nav-link {
		    margin-left: 40px;
    line-height: 50px;
    margin-right: 15px;
    margin-top: 6px;
		}

	.nomobnav {
		display: block;
	}


}


.topslide {
	display: block; background-image: url(/images/headerbg1.jpg); background-repeat: no-repeat; 
}

.contacttop {
	color: #FFF; margin-bottom: 40px; font-size: 2.2rem; line-height: 3rem; text-align: center;
}

@media screen and (min-width: 940px) {
.contacttop {
	color: #FFF; margin-bottom: 60px; font-size: 3rem; line-height: 3.5rem; text-align: center;
}

}

header { position: relative;
    top: 0;
    width: 100%;
    z-index: 100000;
	}

@media screen and (min-width: 940px) {
	header { position: relative;
    top: 0;
    width: 100%;
    z-index: 100000;
	}
}







        /*!  * Font Awesome Free 5.8.1 by @fontawesome - https://fontawesome.com  * License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License)  */ .fa, .fas, .far, .fal, .fab {
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  display: inline-block;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  line-height: 1;
 }


 .fa-facebook-square:before {
  content: "\f082";
 }

.fa-phone-square:before {
  content: "\f098";
 }

.fa-angle-up:before {
  content: "\f106";
 }

.fa-bars:before {
  content: "\f0c9"; }

 .fa-arrow-alt-circle-right:before {
  content: "\f35a"; }

  

  .sr-only {
  border: 0;
  clip: rect(0, 0, 0, 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
 }

  .sr-only-focusable:active, .sr-only-focusable:focus {
  clip: auto;
  height: auto;
  margin: 0;
  overflow: visible;
  position: static;
  width: auto;
 }

 @font-face {
  font-family: 'Font Awesome 5 Brands';
  font-style: normal;
  font-weight: 300;
  font-display: auto;
  src: url("../webfonts/fa-brands-400.eot");
  src: url("../webfonts/fa-brands-400.eot?#iefix") format("embedded-opentype"), url("../webfonts/fa-brands-400.woff2") format("woff2"), url("../webfonts/fa-brands-400.woff") format("woff"), url("../webfonts/fa-brands-400.ttf") format("truetype"), url("../webfonts/fa-brands-400.svg#fontawesome") format("svg");
 }

  .fab {
  font-family: 'Font Awesome 5 Brands';
 }

 @font-face {
  font-family: 'Font Awesome 5 Free';
  font-style: normal;
  font-weight: 400;
  font-display: auto;
  src: url("../webfonts/fa-regular-400.eot");
  src: url("../webfonts/fa-regular-400.eot?#iefix") format("embedded-opentype"), url("../webfonts/fa-regular-400.woff2") format("woff2"), url("../webfonts/fa-regular-400.woff") format("woff"), url("../webfonts/fa-regular-400.ttf") format("truetype"), url("../webfonts/fa-regular-400.svg#fontawesome") format("svg");
 }

  .far {
  font-family: 'Font Awesome 5 Free';
  font-weight: 400;
 }

 @font-face {
  font-family: 'Font Awesome 5 Free';
  font-style: normal;
  font-weight: 900;
  font-display: auto;
  src: url("../webfonts/fa-solid-900.eot");
  src: url("../webfonts/fa-solid-900.eot?#iefix") format("embedded-opentype"), url("../webfonts/fa-solid-900.woff2") format("woff2"), url("../webfonts/fa-solid-900.woff") format("woff"), url("../webfonts/fa-solid-900.ttf") format("truetype"), url("../webfonts/fa-solid-900.svg#fontawesome") format("svg");
 }

  .fa, .fas {
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
 }

 


 .ssllc-cookieoverlay-container {
	display: none;
	position: fixed;
	overflow: hidden;
	bottom: 0;
	height: auto;
	background-color: #000000;
	width: 100%;
	padding: 0;
	margin: 0;
	z-index: 2000000;
	box-sizing: border-box;
	padding-bottom: 0px;
}
.ssllc-cookieoverlay-inner-container {
	box-sizing: border-box;
	padding: 30px;
	}
.ssllc-cookieoverlay-text {
	display: block;
	position: relative;
	float: none;
	}
.ssllc-cookieoverlay-text p {
	display: block;
	position: relative;
	color: #AAAAAA;
	font-size: 1.1rem;
	line-height: 1.5rem;
	margin: 0;
	padding: 0;
	margin-right: 0px;
	width: auto;
	}
.ssllc-cookieoverlay-button {
	display: block
	position: relative;
	overflow: hidden;
	float: none;
	margin: 10px 0px;
	width: auto;
	}
.ssllc-cookieoverlay-accept-button {
	display: table;
	position: relative;
	overflow: hidden;
	float: none;
	background-color: #336699;
	border-radius: 5px;
	color: #FFFFFF;
	text-align: left;
	padding: 10px 30px;
	font-size: 1.1rem;
	font-weight: normal;
	text-decoration: none;
	margin: 0 auto;
	margin-top: 10px;
	}

.ssllc-cookieoverlay-accept-button:focus {
color: #FFFFFF;
font-weight: normal;
}

.ssllc-cookieoverlay-accept-button:hover {
color: #FFFFFF;
font-weight: normal;
}

.ssllc-cookieoverlay-text p a {
	color: #AAAAAA;
	text-decoration: underline;
}
@media screen and (min-width: 768px) {

	.ssllc-cookieoverlay-container {
		padding: 30px;
		}

	.ssllc-cookieoverlay-text {
		float: left;		
		width: 74%;
		margin-right: 1%;
		padding: 0;
		}

	.ssllc-cookieoverlay-button {
		float: left;
		width: 25%;
		padding: 0;
		margin: 0;
		}

	.ssllc-cookieoverlay-accept-button {
		float: right;
		margin-top: 0px;
		}

}
@media screen and (min-width: 900px) {

	.ssllc-cookieoverlay-container {
		padding: 30px;
		}

	.ssllc-cookieoverlay-text {
		float: left;		
		width: 79%;
		margin-right: 1%;
		padding: 0;
		}

	.ssllc-cookieoverlay-button {
		float: left;
		width: 20%;
		padding: 0;
		margin: 0;
		}

	.ssllc-cookieoverlay-accept-button {
		float: right;
		margin-top: 0px;
		}

}




.skiptocontent-container {
	display: block;
	position: absolute;
	left: 5px;
	top: 5px;
	width: 1px;
	height: 1px;
	text-align: center;
	background-color: #2575b8;
	border: 0;
	overflow: hidden;
	z-index: 9999999;
	border-radius: 5px;
	transform: translateY(-100px);
}
.skiptocontent-container:focus-within {
	display: block;
	position: absolute;
	left: 5px;
	top: 5px;
	width: 200px;
	padding: 4px;
	height: auto;
	background-color: #ffffff;
	overflow: hidden;
	text-align: center;
	transform: translateY(0px);
}
.skiptocontent-container a {
	display: block;
	font-size: 1.5rem !important;
	line-height: 2.0rem !important;
	background-color: #FFFFFF;
	color: #000000;	
	
	text-decoration: underline;
	text-align: center;
	width: 100%;
	}

.skiptocontent-container a:focus {	
	color: #0000AA;	
	}

input:focus, textarea:focus {
background-color: #fdfbd0; color: #000000;	 box-sizing: border-box; }

*:focus {
  outline: 3px solid black !important;
  z-index: 1000000;
}

footer *:focus {
  outline: 1px solid gold !important;
  z-index: 1000000;
}

nav .header-right .nav-link:focus {
	outline: none !important;
	text-decoration: underline;
	}