/************************
	Reset styles for editor
************************/
html, body, body div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, asmall, strong, sub, sup, b, i, dl, ul, li, fieldset, tbody, tfoot, thead, tr, th, td  {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}

body
{
  background: #231f20;
  font-size: 14px;
	font-family: 'Montserrat', sans-serif, "Helvetica Neue", Arial, sans-serif;
	color: #313131;
	line-height: 1.2;
}

#editor {background: #fff;}
.cke_panel_frame {background:#fff;}

.middle {
	display: flex;
	align-content: center;
	align-items: center;
}


ul.dividers li:not(:first-child):before {
	content: " | ";
	margin-right: .5em;
}

ul.dividers li {
	text-align: center;
}

/************************
	Default styles
************************/

h1, .h1 {
	font-size: 3em;
	margin-top: 20px;
	margin-bottom: 20px;
	padding-bottom: 0px;
	font-weight: 800;
}

h2 {
	font-size: 1.3em;
	margin: 0 0 10px;
	padding: 0;
	font-weight: 800;
}

h3 {
	font-size: 1.2em;
	margin: 10px 0;
	font-weight: 600;
}

h4 {
  font-size: 1em;
	margin: 0 0 5px 0;
	font-weight: normal;
}

hr {
	margin: 5px 0px 10px;
}

a {
  color: #8AC53F;
  text-decoration: none;
}

a:hover {
	color: #39b54a;
  text-decoration: underline;
}

p {
  padding-bottom: 10px;
  margin: 0;
}

.no_padding_right {padding-right: 0;}
.no_padding_left {padding-left: 0;}
.no_padding {padding-left: 0; padding-right: 0;}

.body {position: relative;}
.whiteBG {background: #fff;}
.imgMax img {max-width: 100%;}

figure { position: relative; width: 100%; height: 100%; overflow: hidden; }
figure figcaption { position: absolute; top: 0; left: 0; bottom: 0; right: 0; opacity: 0; width: 100%; height: 100%; transition: all 0.5s ease; background-color: rgba(0, 0, 0, 0.8); }
figure:hover > figcaption { opacity: 1; }
.figure-icon {margin-bottom: 0;font-size: 36px;text-align: center;color: white;}

.middle {
    width: 100%;
    height: 100%;
    display: table;
}
.middle .middle-inner {
    width: 100%;
    height: 100%;
    display: table-cell;
    vertical-align: middle;
}
.abstop {position: absolute; top: 0; left:0; right: 0;}
.abstop {position: absolute; bottom: 0; left:0; right: 0;}
.silverline {width: 100%; height: 5px; background: url(/images/silverLine.png) repeat-x;}

/************************
	buttons
************************/

a:hover.greenButton {
	background: url(/images/buttonGreenActive.png) no-repeat center center;
	text-decoration: none;
}

a.greenButton {
	background: url(/images/buttonGreen.png) no-repeat center center;

	padding: 20px 20px;
	text-align: center;
	color: #fff;
	width: auto;
	margin: 30px auto 0;
	display: inline-block;
	font-size: 1.2em;
	font-style: italic;
}




/************************
	Header
************************/

.header {background: #231f20 url(/images/blackroof.jpg) no-repeat center center;background-size: cover;}

.phone {color: #8AC53F; font-size: 1.8em;  font-weight: 500;}
.headerText {margin: 20px 0 0;font-size: 1.2em; color: #fff;}
.logoRow img {max-width: 100%; margin: 5px 0 0x;}
.logo { display: flex; align-content: center; align-items: center;}

.stuck .sticky-lg-top .container {padding: .5% 0;}
.stuck .sticky-lg-top .logo img {height: 90px; margin-top: -10px;}
.stuck .sticky-lg-top .headerText {
    display: none;
}

/************************
	Header Images
************************/

section.slider, #slider {
	position: relative;
	padding: 0;
}
.slick-next {right: 0;}
.slick-prev {left: 0;}

.slick-prev, .slick-next {
	width: 43px;
	height: 92px;
	color: #fff;
	z-index: 1000;
	display: block;
	background: url(/images/arrowLeft.png) no-repeat;
}

.slick-prev {background: url(/images/arrowLeft.png) no-repeat;}
.slick-next {background: url(/images/arrowRight.png) no-repeat;}

.slick-prev:before,
.slick-next:before
{
	content: '';
}

.slick-dots {bottom: 0px;}
.slick-dots li.slick-active button::before {line-height: 10px;}
#projects .slick-dots {bottom: -25px;}



.slick-dots li button:before {
	color: #8AC53F;
}
.slick-dots li.slick-active button:before {
	color: #009343;
}
.slick-prev:active, .slick-prev:focus, .slick-prev:hover {background: url(/images/arrowLeftActive.png) no-repeat;}
.slick-next:active, .slick-next:focus, .slick-next:hover {background: url(/images/arrowRightActive.png) no-repeat;}

.slick-slide {max-height: 617px;position: relative;}

.slick-slide img {
	width: 100%;
	height: 100%;
	margin: 0 auto;
}

.overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, .6);
	color: #FFF;
}

.graphicBox {position: absolute; bottom: 25%; left: 0; right: 0; margin: 0 auto;}
.header_title {font-size: 3em; color: #fff;text-align: center;font-weight: 800; margin-bottom: 20px; }
.header_text {color: #fff;text-align: center; }

.slick-slide .header_logos img {max-width: 100%; width:unset; margin: 0px 0;}
.header_logos {z-index: 1000; position: absolute; top: 10px; left:0; width: 100%;}

/************************
	Footer
************************/

.footer {
  background-image: url(/images/blackroof.jpg);
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center top;
	padding: 40px 0;
	color:#fff;
	font-size: 11px;
}
.footer .footerLogo img {max-width: 100%;}

.footerLinks li {
	font-weight: bold;
	font-size: 1.5em;
	text-transform: uppercase;
}

.footer a {color: #fff;}
.footerContact {padding: 10px 0 30px;}
.footerText {padding-bottom: 30px;}
.footerTypes {font-weight: bold; margin: 5px 0 30px; font-size:  1.2em;}
.footerLogos li {padding-right: 30px;}

.footerLogos {
	width: 75%;
}
/************************
	sitemap
************************/
ul.sitemap {margin: 20px 0}
ul.sitemap li {
	margin-left: 20px;
	padding-bottom: 10px;
	list-style: none;
}

/************************
	Nav
************************/

.nav_container {position: absolute;bottom: 10px;right: 0;}
.nav_container_content {display: table-cell; vertical-align: bottom;}

.navbar-nav>li>a {padding: 5px 10px; font-size: 1.3em; line-height: 1.2; font-weight: 500;}

.navbar {min-height: auto; margin-bottom: 0;}

.navbar  { background: transparent; border: none; border-color: transparent;}
.navbar-collapse {border-color: #fff;}
.navbar-nav>.active>a:hover,.navbar-nav>li>a:hover, .navbar-nav>li>a:focus { border-color: #8AC53F; color: #fff;}

.navbar-brand { color: #979898; height: auto;padding: 4px 5px 0;font-size: 1em;line-height: 1em;}
.navbar-brand:hover { color: #979898}

.navbar-toggler {
	background-color: #8AC53F;
	border: 1px solid #8AC53F;
	border-radius: .25rem;
}

.navbar-nav>li>a { color: #fff;}
.navbar-nav>li>a:hover, .navbar-nav>li>a:focus { color: #fff}
.navbar-nav>.active>a,.navbar-nav>.open>a, .navbar-nav>.open>a:hover, .navbar-nav>.open>a:focus { color: #fff; background-image: none;border-color: #8AC53F; border-bottom: none;box-shadow: none;}

.navbar-nav>.active>a:hover, .navbar-nav>.active>a:focus { background: transparent; color: #FFFFFF}
.dropdown-menu>li { text-indent: 10px; padding: 5px 0; font-size: 1.2em;}
.dropdown-menu>li a { text-indent: 10px; padding: 3px 0;}
.navbar-toggle {margin-right: 0; }
.navbar-toggle .icon-bar {background-color: #8AC53F;}


/************************
	Page Details
************************/
.pageTitleTop {font-size: 3em;text-align: center;font-weight: 800;margin-bottom: 20px;}
.body img {max-width: 100%;}

#videoModal .close {
	font-size: 3em;
	padding: 0 .5em 0 .0;
}

#videoModal .modal-content {
	background: #454543;
}

#videoModal .modal-header {
	background: #454543;
}

#videoModal .modal-body {
	padding: 0 1em;
}

#fbVideoSection {
	background: #fff;
}



/************************
Icon Sections
************************/
.iconBox {text-align: center;padding: 20px; margin: 15px;}
.boxIcon { margin: 20px auto; }
.boxIcon img {max-width: 100%;}

.boxTitle {font-size: 1.1em; line-height: 1.5em; margin: 0px 0 15px; font-weight: bold; display: flex; justify-content: center; align-items: center;flex-direction: column;}


.boxText {margin-bottom: 10px; line-height: 1.4em;}

.boxTitle .smallText {
	color: #313131;
	font-size: 1.1rem;
	line-height: 1.3;
	font-weight: normal;
}

.boxButtons {
	clear: both;
	margin-bottom: 10px;
}

#homeBoxes {background: #fff; z-index: 1000; padding-bottom: 60px; }
#homeBoxes .boxTitle {font-size: 1.5em; margin: 10px 0;}
#homeBoxes .boxText {text-align: center; padding: 0 5px; line-height: 1.3em;}


/************************
Advantages Section
************************/
#advantagesSection {
	padding: 40px 0;
  color: #fff;
  background: url(/images/advantagesbkgd.jpg) no-repeat fixed;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center top;
}

.advantageTitle {font-size: 1.3em;}

/************************
Projects Section
************************/
#projectSection {
	padding: 60px 0;
	background: #fff;
}

.projectsTitleText {padding: 0 10%; color: #39b54a;font-style: italic;}

#fancybox-title {margin-left: 0 !important; margin-right: 0 !important;}

#gallery .slick-slide {margin: 0 8px;}
#gallery { margin: 40px -8px; position: relative;}
#gallery .item {background: #fefefe;border: solid 1px #ededed;}
#gallery .slick-prev {left: -35px;}
#gallery .slick-next {right: -41px;}
#gallery .slick-dots {bottom: -30px;}
/************************
Testimonials Section
************************/

.testimonialsSection {
	position: relative;
  color: #000;
	background: url(/images/greenbox.jpg) no-repeat;
	background-size: 100%;
  width: 100%;
  height: 100%;
	background-size: cover;
}
.testimonialsSection .h1 {font-weight: 800; margin-bottom: 20px; padding-top: 40px;}
.testimonial_text {text-align: center; font-style: italic; font-size: 1.1em; line-height: 1.4em; padding: 25px 0; }
.testimonial_author {text-align: center; font-weight: 700; padding-top: 10px; font-size: .9em;}
#testimonials {margin-bottom: 80px;}

#testimonials .slick-prev {left: -30px;}
#testimonials .slick-next {right: -30px;}

#frmFeedback input[type="text"],
#frmFeedback textarea {
	font-size: 1.3em;
	text-indent: 20px;
	border: none;
	padding: 10px 5px;
	background: #fff;
	color: #39b54a;
	border-radius: 5px;
	margin-bottom: 5px;
}

#frmFeedback input.submitButton {
	border: solid 2px #fff;
	border-radius: 0;
	background: transparent;
	padding: 10px 0;
	text-align: center;
	color: #fff;
	width: 90%;
	float: right;
	margin: 15px 0;
	font-size: 1.3em;
}

#frmFeedback input:hover.submitButton {
	background: #fff;
	color: #39b54a;
}

#frmFeedback ::-webkit-input-placeholder {
	color: #39b54a;
}

#frmFeedback ::-moz-placeholder {
	color: #39b54a;
}

#frmFeedback :-ms-input-placeholder {
	color: #39b54a;
}

#frmFeedback :-moz-placeholder {
	color: #39b54a;
}

#frmFeedback .valError {color: red;}
/************************
About Page
************************/
#aboutBottom {
	padding: 20px 0 40px;
}

/************************
Services Page
************************/
.serviceSection {padding: 0px 10% 60px;}
#service2 {padding-top: 40px;}
#service2, #service3 {background: #f1f1f2;}
#service2 .row {border-bottom: solid 1px #ccc; padding-bottom: 20px;}
#service4 {padding: 40px 0; }
#service4 .row {color: #8AC53F;}
#service4 .serviceSection {padding: 0;}
#service4 .boxIcon {margin: 0 auto;}
/************************
FAQs Section
************************/

.faqs__info {padding: 0 10% ;}

.tab__info-block {
  border-bottom: solid 1px #d4d4d4;
  overflow: hidden;
  margin-bottom: 20px;
}

tab__info-block .row {
  margin-top: 10px;
}

.tab__title{
  margin: 0 0 0 ;
  padding:10px 20px;
  position: relative;
	overflow: hidden;
	color: #39b54a;
	font-weight: bold;
	line-height: 1.8;
}

.tab__info-block:first-child .faq__title:before{
  margin-left: 20px;
}

.tab__title a:first-child {
  margin-top: 5px;
}

.tab__text{
  margin:0 0 0 0;
  padding: 35px 20px;
  line-height:1.5;
  display:none;
}

.tab__icon {
  padding-right: 10px;
}

.tab__info-block--active {
	background: #e4e3e3;
}

.tab__info-block--active .tab__text{
  display: block;
}

.tab__info-block--active .tab__title a:first-child{
  font-weight: bold;
}

a.square.square--toggle {
	color: #666;
	fill: #666;
}

.square--toggle {
    background-color: #ddd;
    border: none;
    padding-top: 7.5px;
    font-size: 12px;
}

.square {
    display: block;
    width: 30px;
    height: 30px;
    border: 1px solid #ddd;
    text-align: center;
    padding-top: 3px;
    cursor: pointer;
}


a.square,
a.square:active,
a.square:focus,
a.square:visited
{
    color:#ccc;
}

.tab__info-block--active .square--toggle {background: #8AC53F;}

.tab__info-block--active a.square,
.tab__info-block--active a.square:active,
.tab__info-block--active a.square:focus,
.tab__info-block--active a.square:visited {
	color: #fff;
}

/************************
Contact Page
************************/
.contactIcons {color: #8AC53F; font-size: 1.3em;line-height: 1.3em; padding-bottom: 40px;}
.contactText {font-size: 1.3em;font-weight: 500;}
#contactForm {
	padding: 40px 0;
  color: #fff;
  background: url(/images/formparallax.jpg) no-repeat fixed;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center top;
}

#contactForm .h1 {margin-bottom: 40px;}

#contactForm input[type="text"], #contactForm select {
	font-size: 1.3em;
	text-indent: 20px;
	border: none;
	padding:10px 5px;
	background: #fff;
	color: #39b54a;
	border-radius: 5px;
	margin-bottom: 5px;
}

#contactForm input.submitButton {
    border: solid 2px #fff;
    border-radius: 0;
    background: transparent;
    padding: 10px 0;
    text-align: center;
    color: #fff;
    width: 90%;
    float: right;
    margin: 15px 0;
    font-size: 1.3em;
}

#contactForm input:hover.submitButton {
    background: #fff;
    color: #39b54a;
}

#contactForm ::-webkit-input-placeholder {color: #39b54a;}
#contactForm ::-moz-placeholder {color: #39b54a;}
#contactForm :-ms-input-placeholder {color: #39b54a;}
#contactForm :-moz-placeholder { color: #39b54a;}


/************************
Photos
************************/
.photoItem {background: #dadada; }
.photoImage {background-repeat: none; background-position: center center; background-size: contain;}
.photoCaption {padding: 15px 10px; text-align: center;}
a .photoCaption {color: #000; }
a.grouped_elements:hover {text-decoration: none; border-bottom: none;}

/************************
Misc
************************/
.content {margin: 40px 0;}
.mainText {background: #fff; padding: 40px 0 0;}

.mainText ul li, #editor ul li {margin-left: 25px;}
.mainTextText {margin-bottom: 40px;}


/************************
News
************************/
#newsSection {
	background: #fff;
}

#newsSlider .slick-slide {margin: 0 8px;}
#newsSlider { margin: 40px -8px; position: relative;}
#newsSlider .item {background: #fefefe;border: solid 1px #ededed;}
#newsSlider .slick-prev {left: -35px;}
#newsSlider .slick-next {right: -41px;}
#newsSlider .slick-dots {bottom: -30px;}

/************************
	Home Video Details
************************/

.vimeo-wrapper {
   position: relative;
  padding-bottom: 56.25%; /* proportion value to aspect ratio 16:9 (9 / 16 = 0.5625 or 56.25%) */
  height: 0;
  overflow: hidden;
  z-index: -1;
  pointer-events: none;
  overflow: hidden;
}
.vimeo-wrapper iframe {
   position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
