/*    general    */


body {
    font-family: "Roboto",sans-serif !important;
    font-size: 15px !important;
    color: #6f6f6f !important;
    -webkit-font-smoothing: antialiased;
}

body p {line-height: 1.7}

@media (min-width: 1200px) {
    .container{
        max-width: 1180px !important;
    }
}

.hidden {display: none;}

.centered {text-align: center;}

h1, h2, h3, h4, h5, h6 { 
    font-family: "Questrial",sans-serif; 
    font-weight: 400;
    color: #383838;
    letter-spacing: 1px;
    line-height: 1.2;
}

h1.light, h2.light, h3.light, h4.light, h5.light, h6.light { 
    color: #fff !important; 
}
h1 {font-size: 55px !important;}
h3 {margin-bottom: 30px !important;}
h4 {font-size: 32px !important;}
h5 {font-size: 24px !important;}
h6 {font-size: 14px !important;
    letter-spacing:  1.5px !important; 
    font-weight: 700 !important;}
h4.img-title {font-size: 18px!important; font-weight: 400!important;}

h2 a {color: #383838 !important; }

.item-title {
    letter-spacing: 1px;
    margin-bottom: 60px;
}

.item-title.withsubtitle {margin-bottom: 10px;}

.sub-title {
    font-size: 22px !important;
    margin-bottom: 30px;}

.subtitle-above {
    font-size: 18px; 
    font-weight: 800;
    font-style: italic;
}
.icon-subtitle {
    font-size: 14px;
    color: #747474;
    margin-bottom: 15px;
}

h3.side-title {font-size: 26px !important;}
.side-subtitle { font-size: 16px; color: #008235;}

img + h3.side-title {margin: 15px 0 0 80px;}

.timeline-section-title h3 {font-size: 36px !important; font-weight: 600;}

a {color: #008235 !important;}
a:hover {color: #0089c6 !important;}
a {text-decoration: none !important;
moz-transition: background .3s,color .3s,border-color .3s;
    -o-transition: background .3s,color .3s,border-color .3s;
    -webkit-transition: background .3s,color .3s,border-color .3s;}
a.light {color: #fff;}
a.light:hover {color: #f15a29;}
a.dark {color: #383838;}
a.dark:hover {color: #0089c6; }

.no-link-style h6 a {color: #383838 !important;}
.no-link-style {color: #747474 !important;}

[type=button] {
    border: none;
    background-color: transparent;
    font-size: 20px;
}

[type=button]:hover {
    color: #008235;
}


h5 sup {
    font-size: .5em !important; 
    position: relative;
    top: -.9em !important;
}

.subtle {
    color: #818181;
    font-size: .9rem;}

.panel {padding:60px 0}
.panel.bottom {padding-bottom: 0;}

.panel-gray {background-color:#e7eae6;}
.panel-blue {background-color:#00416d; color: #fff;}
.panel-green {background-color:#008235; color: #fff;}
.panel-dark {color: #fff;}

.panel-img-bg {background-repeat: no-repeat;
background-size: cover;}

.extra-col-padding {padding: 60px 30px;}

a.button-green, button.btn-green {
    color: #ffffff !important;
    text-decoration: none;
    border-radius: 3px;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
    background: #008235;
    -webkit-transition: background .3s,color .3s,border-color .3s;
    letter-spacing: .5px;
    padding: 10px 25px;
    font-size: 13px;
    font-weight: 700;
    display: inline-block;
}

a.button-green:hover, button.btn-green:hover {
    background: #00416d;
    color: #fff;
}

button.btn-green { border: none;}



.zoom-on-hover img {
    transition: opacity .3s ease-out,transform .3s ease-out,filter .3s ease-out;
    -moz-transition: opacity .3s ease-out,-moz-transform .3s ease-out,-moz-filter .3s ease-out;
    -o-transition: opacity .3s ease-out,-o-transform .3s ease-out,-o-filter .3s ease-out;
    -webkit-transition: opacity .3s ease-out,-webkit-transform .3s ease-out,-webkit-filter .3s ease-out;
}

.zoom-on-hover:hover img {
    -webkit-transform: scale(1.1));
    transform: scale(1.1);
}

/* .btn-modal-img {vertical-align: middle;}
.btn-modal-img:hover {background-color: #e6e6e6; opacity: .5;  } */

.btn-modal-img {
    position: relative;
    vertical-align: middle;
}

.btn-modal-img img {
   width: 100%;
    height: auto;
}

/* The overlay effect (full height and width) - lays on top of the container and over the image */
.overlay {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  height: 100%;
  width: 100%;
  opacity: 0;
  transition: .3s ease;
  background-color: #e6e6e6;
}

/* When you mouse over the container, fade in the overlay icon*/
.btn-modal-img:hover .overlay {
  opacity: .75;
}

/* The icon inside the overlay is positioned in the middle vertically and horizontally */
.icon {
  color: #000;
  font-size: 25px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  text-align: center;
}


.btn-accordian {
    background-color:#008235;
    font-family: "Questrial",sans-serif;
    font-weight: 600;
    font-size: 13px;
    border-radius: 3px;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
    padding: 23px 25px 22px;
    line-height: 16px;
    letter-spacing: 1px;
    margin-bottom: 25px;
    width:100%;
    text-align: left;
    color: #fff;
    
}

.btn-accordian:hover {
    background-color:#00416d;
     color: #fff;
}

button[aria-expanded="false"]::before {
  content: "+ ";
}

button.btn-accordian[aria-expanded="true"]::before {
  content: "- ";
}

ul.checklist {
    list-style-type: none;
    padding-left: 0;
}

ul.aligned-padding { padding-left: 15px; }


.parallax {
  /* background-attachment: fixed;   
  background-size: cover; */
  background-position: center bottom;
  background-repeat: no-repeat;
   background-size: 150%;
}

.page-title-caption {
    font-size: 26px;
    margin-top: 25px;
    color: #fff;
    text-transform: none;
}

.page-title-caption i { display:block; margin-top: 10px; }

hr.mini {width: 60px; margin: 60px auto}


/*    navigation     */

#header-logo {
    padding: 60px 0 45px 0;
    width:325px;
    height: 100%;
}

.content-heading {
   padding: 155px 0 87px 0;
   text-transform: uppercase;
   background-size: cover;
}


/*    navigation     */


.navbar {
    background-color: rgba(255, 255, 255, .95);
}

.navbar-nav { 
    padding-top: 10px;
}

.navbar-nav li a, .navbar-nav li a:hover {color:#212529 !important; }

.navbar-nav li { 
    padding: 0 20px 13px 20px;
    text-transform: uppercase;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 0;
}

.navbar-nav li:first-child {
    padding-left: 0;
}

.navbar .nav-item .dropdown-menu {

    border:none;
    border-radius: 0;
}

.dropdown-menu  li {
     text-transform:none;
    font-weight: 300;
    padding-left: 0;
}

.navbar-nav li a {
    color: #1c1c1c;
}

.dropdown-item:focus, .dropdown-item:hover {
    color: #008235 !important;
    background-color: transparent !important;
}

.dropdown-toggle::after {
    margin-left: 13px !important;
    content: "\f107" !important;
    font-family: fontAwesome;
    border: 0 !important;
    vertical-align: 0 !important; 
}

#magic-line {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 55px;
  height: 4px;
  background: #008235;
}

li#magic-line {
    margin-bottom: 0;
    padding: 0;
}

 .navbar .nav-item .dropdown-menu{ display: none; }
	.navbar .nav-item:hover .nav-link{   }
	.navbar .nav-item:hover .dropdown-menu{ display: block; }
	.navbar .nav-item .dropdown-menu{ margin-top:10px; }

.mobile-nav-btns {
    margin-top: 30px;
    text-align: right;
}
.navbar-toggler { 
    border: 1px solid #ccc !important;
    margin-left: 20px;
}
button[aria-expanded="false"]::before {
    content: none;
}


/*    search    */

.main-menu-search {float: right;}

.modal-backdrop.show { opacity: .88 !important; }
.modal-header { background-color: #fff;}
.modal-content { background-color: #e6e6e6 !important;}

.body {margin-top: -75px;}

.btn-search {color: #1c1c1c;}
.btn-search:hover {color: #008235;}


.gsc-control-searchbox-only {padding: 10px 0px}





/*     footer    */

footer {
    color: #fff;
    background-image: url(../img/bg-water.jpg);
    background-position: bottom;
    background-size: cover;
    font-size: 13px;
    padding-top: 60px;
}

.copyright { 
    text-align: center;
    padding: 5px 0;
    background-color: #008235;
    margin-top: 40px;
}

.footer-title {
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin-bottom: 35px;
    font-weight: 700;
}

footer .mission-statement { padding-right: 30px; }

footer a { color: #fff !important; text-decoration: none;}
footer a:hover { color: #0989c5 !important;}

.recent-post-item {margin-bottom: 25px;}
.recent-post-item a {font-weight: 600;}
.recent-post-info {color: #a0a0a0; margin-top: 11px;}



/*     home      */

.home-infographic {
    background-image: url(../img/home-infographic_bg-line.png);
    background-repeat: no-repeat;
    background-position: center ;
}

.home-infographic img { 
    max-width: 350px;
    margin-top: 36px;
}

.home-infographic-info h5 {
    font-size: 25px;
    padding-bottom: 20px;
}
        
.adv-tiles {
    color: #fff;
}

 .adv-tile a {
    color: #fff;
    text-decoration: none;
}

 .adv-tile:hover {
    color: #fff;
    background-color: #00416d;
     cursor: pointer;
}

.link-tile {
    position:relative;
-webkit-transition: background .3s,color .3s,border-color .3s;
}

.link-tile:hover {
    cursor: pointer; 
    border-color: #bbb; 
    background-color: #efefef;
}

.adv-tile {
    padding: 50px 40px 40px;
    background-color: #008235;
    height: 100%;
    position: relative;
    -webkit-transition: background .3s,color .3s,border-color .3s;
}

.adv-tile img {
    margin-bottom: 37px; }

.adv-tile p {font-size:15px;}

.link-tile a,
.adv-tile a {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: rgba(0,0,0,0);
    z-index: 100;
 
}

.tile-box-background {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0; 
    background-position: center;
    background-size: cover;
    z-index: 10;
}

.adv-tile .tile-content {
    position: relative;
    z-index: 20;
}
.featured-content {text-align: center;}
.featuredProject-thumb { max-height: 335px; }
.featuredProject-thumb .overlay{ background-color: #00416d;}
.xp-project-thumb { max-height: 250px; }
.xp-project-thumb .overlay { background-color: #060606;}

.thumb-w-overlay { 
  position: relative;
  width: 100%;
  overflow: hidden}

.thumb-w-overlay img {
  display: block;
  width: 100%;
  height: auto;
}

.thumb-w-overlay .overlay {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  height: 100%;
  width: 100%;
  opacity: 0;
  transition: .5s ease;
}

.thumb-w-overlay:hover .overlay {
  opacity: .75;
}

.overlay-text {
  color: white;
  font-size: 16px;
  font-family: "Questrial",sans-serif; 
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  text-align: center; 
    text-transform: uppercase;
}

.featuredProject-info  {
    padding: 20px;
}

.featuredProject-info .sub-info {
    font-size: 
}

.featuredProject-title-container {
    padding: 50px 75px 0 0;
    float:right;
}

.blog-post-home-item {
    height: 100%;
    padding: 60px; 
}

.blog-post-home-item  .blog-summary {
    overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}


/*     Technology     */


.extend-sides {background: rgb(230,230,230);
background: linear-gradient(90deg, rgba(230,230,230,1) 54%, rgba(0,130,53,1) 54%);}

/*     Advantages     */

.brochure-block {
    max-width: 400px;
    background-color: #fff;
    color: #383838;
}

.brochure-block-content {
    padding: 30px;
}

.brochure-block img {
   width: 100%;
}

.brochure-block h5 {
    font-size: 21px !important;
    font-weight: 600;
    }

/*     Resource Recovery     */

button.green-box {
    font-size: 15px;
    color: #ffffff !important;
    padding: 15px 20px 20px 20px;
    background: #008235;
    text-align: left;
}

button.green-box:hover {
    background-color: #0089c6;
}

.case-study-box {
    border: 1px solid #e6e6e6;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.2); 
	-webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.2); 
	-moz-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.2); 
    height: 100%;
}

.case-study-box p {padding: 15px 35px;}
.case-study-box h6 {padding: 0 35px;}

.case-study-box .image-box { height: 275px; overflow: hidden;margin-bottom: 35px;}

.testimonial-preview {font-style: italic; color: #0089c6; margin: 10px 0 20px 0 !important; }


/*   FAQ   */

#accordionFAQ {margin-bottom: 30px;}

#accordionFAQ .accordion-item {
    border: none !important;
}

#accordionFAQ button[aria-expanded="false"]::before {
    content: "+";
    padding: 10px 17px;
    background-color: #f15a29;
    margin-right: 20px;
    font-size: 20px;
}

#accordionFAQ button[aria-expanded="true"]::before {
    content: "–";
    padding: 10px 17px;
    background-color: #fff;
    border: 1px solid #f15a29;
    margin-right: 20px;
    font-size: 20px;
}

#accordionFAQ .accordion-button::after {
    background-image:none !important;
}

#accordionFAQ .accordion-button:not(.collapsed) {
    color: #212529 !important;
    background-color: #fff !important;
    box-shadow: none !important;
}

#accordionFAQ .accordion-button:focus {
    z-index: 3;
    border-color: transparent !important;
    outline: 0;
    box-shadow: none !important;
}



/*     Services     */


table.compare-table tr td:first-child {
    padding: 15px;
}

table.compare-table th {background-color: #008235; color: #fff; font-family: "Questrial", sans-serif; font-size: 18px; border-left: 1px solid #00a346; border-right: 1px solid #00a346; border-bottom: 1px solid #00416d; border-top: 1px solid #008235;  
vertical-align: middle;}

table tr {color: #5b5b5b !important;}


table.compare-table th span {font-size: 14px;}

table.compare-table tr td {
    border: 1px solid #e2e2e2;
    padding: 15px 0;
}

table.compare-table tr.title-row {background-color: #00416d;
	text-align:left;color: #fff !important;
}

table.compare-table tr.title-row td:first-child {
  	padding: 5px 0 5px 15px;
	border:1px solid #00416d;
}

#structure-boom .gdlr-core-accordion-style-background-title-icon .gdlr-core-accordion-item-title {background-color: #008235; color: #fff;}

#structure-boom  .gdlr-core-accordion-style-background-title-icon.gdlr-core-icon-pos-left .gdlr-core-accordion-item-title:before {color: #fff}


/*     Experience    */

.quote-content { margin-top: 50px;}
.quote-content .fa { color: #1c9246; font-size: 40px; }
.quote-text .quote-hl { color: #1c9246;
    font-family: Questrial, sans-serif;
    font-size: 20px;
    font-weight: 500;}
.quote-person {padding-top: 10px;}

.project-thumb {
    height: 250px;
    overflow: hidden;
    position: relative;
}

.project-info {
    padding-top: 28px;
}

.project-info h6 {
    text-transform: uppercase;
}

#map {height: 300px; width: 100%;}


table.project-specs td { padding: 10px 0; }

.project-pdf {width: 80%;}
.project-pdf img, .project-pdf a  {width: 100%;}

.side-line { 
    border-right: 3px solid #fff; 
    text-align: right;
    padding-right: 25px;
    padding-bottom: 5px;
    margin-right: 5px;
}
.side-line h2 {margin-bottom: 5px;}
.blog-post-title {font-size: .8rem;}
.blog-post-title h2 {text-transform: none; margin-bottom: 20px; font-size: 3rem}

.blog-post-content img.full-width { width: 100%; margin-bottom: 15px;}
.blog-post-content img.left { float:left; margin: 0 30px 30px 0;}

.post-nav { 
    border-top: 1px solid #bcbcbc; 
    border-bottom: 1px solid #bcbcbc; 
    padding: 20px 0;
    margin-top: 60px !important;
    clear:both;
}

.post-nav a {color: #909090 !important;}

/*    About    */

.padded-content {padding: 60px 70px;}

.about-img {
    background-image: url("/img/leader-dave.jpg");
    background-size: auto 100%;
    background-repeat: no-repeat;
}

.timeline-content {margin: 60px 60px 85px 60px;}
.timeline-content ul {margin-bottom: 30px;}

.timeline-section-title {
    padding: 8% 0px 0px;
    background-color: #008235;
    color: #fff;
    position: relative;
}

.timeline-bg {
    background-repeat: no-repeat;
    background-size: 120%;
    height: 100%;
    width: 100%;
    position: absolute;
    top:0;
    left: 0;
    opacity: .1;
    
}

.timeline-section-title p {font-size: 18px;}



/*     News     */

.blog-date {margin: 17px 0 25px 0; }

.blog-date i.fa {color: #f1bf37; margin-right: 10px; font-size: 13px; opacity: .7;}

.blog-post-preview-item {margin-bottom: 90px;}
.blog-post-preview-item p {margin-bottom: 30px;}

.pagination .page-link {padding: 0.5rem 1rem;}
.pagination .page-item.active .page-link {
    background-color: #e7eae6;
    border-color: #dee2e6;
}
.pagination .page-item.disabled .page-link {color: #6c757d !important; }


.pagination .page-link:hover {
    color: #fff !important;
    background-color: #008235;
    border-color: #008235;
}


/*     Meet the Team    */

.team-member-block {background-color: #f9f9f9; height: 100%;}
.team-member-block h4 {text-transform: uppercase;}
.team-memer-block .member-photo a.blend {color: #000 !important;}
.member-photo {overflow: hidden; height: 250px;  }
.member-photo img {width: 100%;}
.member-info {padding: 35px 32px 25px; font-size: 13px;}



/*     Contact    */

.contact-icons i {
    display: inline-block;
    margin: 0 5px;
}


.confirmation-bar {
    background-color: #00a346;
    color: #fff;
    padding: 15px 15px 1px 15px; 
    margin-bottom: 30px;
}

.icon-large {
    font-size: 2.5em;
    margin-bottom: 30px;
}

.contact-icons i {font-size: 1.25em;}
.contact-icons a {color: #383838 !important;}
.contact-icons a:hover {color: #008235 !important;}

.company-email {
    position: absolute; 
    left: 100000px;
    display: none;
}


/*     Press     */

.press-menu {
    padding: 20px 0;
}

.press-menu a {
    color: #fff !important;
    display: inline-block;
    padding: 0 20px;
    border-left: 2px solid #1d71c7;
   
}

.press-menu a:hover {color:#00416d !important;}

.press-menu a:first-of-type {
    border-left: none;
}
#company, 
#team,
#gasification,
#testimonials,
#downloads,
#flexible,
#clean,
#proven,
#lowrisk,
.scroll-margin
{ scroll-margin-top: 75px;}

    
.mediaContact-box {
    background-image: url(/img/bg-square-equipment.jpg); 
    background-repeat: no-repeat; 
    background-size: cover; 
    padding: 30px; 
    color: white;
    margin-left: 20px;
}


.mediaContact-box p {margin-top: 25px;}
.side-subtitle a {font-size: .85em; font-weight: 500;}

#team .member-photo {height: 150px;}
#team .member-info {padding: 15px 0 0 0;}
#team .team-member-block {background: transparent;}
#team h4.img-title {font-size: 15px !important; text-transform: uppercase;}

.block-20 {width: 18%; margin: 15px; float:left; height: 250px;}

.green-hl-box {
    background-color: #008235;
    padding: 30px;
    color: white;
    font-size: 18px;
}


.press-quote {
    font-size: .85em;
    color: #666;
    font-style: italic;
    margin-top: 30px;
}

.press-quote i {
    color: #008235;
    font-size: 1.5em;
    float: left;
}

.press-quote p, .press-quote .quote-author {margin-left: 30px;}

.white-grid-box {
    background-color: #fff; 
    text-align: center;
    padding: 50px 30px;
    color: #0a0a0a;
    height: 100%;
}

.white-grid-box img {
    max-width: 80%;
    margin-bottom: 40px;
    height: auto;
}


/*     Kids Corner    */

ul.tight {
    padding-left: 15px;
    margin-bottom: 60px;
}

ul.tight li {margin: 5px 0}

.surfer-bg, .gardener-bg {background-size: contain;}

.surfer {
    width:250px;
    margin-top: 250px;
}

.parachute {
   margin-top: 50px;
}

.gardener {
     margin: 170px 0 30px 0;
}


/*    Careers   */

.accordion-button {display: initial !important;}
.accordion-button:not(.collapsed) {color: #000 !important;}

.pre-title {font-size: 14px; }
#jobOpenings h5 {margin: 5px 0 20px 0; font-size: 22px !important;}
#jobOpenings .job-info {margin-right: 30px; display: inline-block;}

#jobOpenings .job-toggle { float: right;
color: #008235; font-size: 14px;}
#jobOpenings .collapsed .job-toggle::before { content:"+";}
#jobOpenings .job-toggle::before { content:"-";}

#jobOpenings .accordion-button:hover  {background-color: #e7eae6;}
.career-values {padding-top:50px}
.career-values ol, .career-values ul {padding-left: 1rem !important; margin-top: 15px;}
.career-values li {margin-bottom: 7px !important;}

.career-values .tight-top {margin-top: 0 !important;}
