@charset "utf-8";
/* CSS Document */
.min1024{
	display: none;
}
@media only screen and (max-width: 1440px){
	#logo img {	
		height: 205px;
	}
	#hometext #hometext-peek {   
		width: 48%;
	}
	#location {
		text-align: center;
	}
}
@media only screen and (max-width: 1215px){
	#nav ul li{
		margin:0;
	}
	#nav ul > li a{
		font-size:14px;
		padding:5px;
	}
}
@media only screen and (max-width: 1111px){
	#header #logo,
	#topnav #callus,
	#header #social-links,
	#header #offer2,
	#quote-cont,
	#owner-photo,
	#nav,
	#nav ul{
		float:none;
		margin:auto;
		/*padding:0 10px;*/
		text-align:center;
	}
	#nav{
		display:block;
		padding-top:0 !important;
	}
	body:not([page=index]) #body{
		padding-top:0 !important;
	}
	body:not([page=index]) #header{
		position:relative !important;	
	}
}
@media only screen and (max-width: 1024px){
	a {
		color: #ffffff;
		text-decoration: none;
	}
	#logo img {		
		height: 165px;
	}
	#hometext {	
		top: 40vh;
	}
	#hometext #hometext-peek {
		width:62%;
	}
	#hometext h3 {
    	font-size: 45px;
		line-height: 50px;
	}
	body:not([logo_banner=true]) .bannertext {
		top: 60vh;
	}
	ul.col5 > li {
		width:33%;
	}
	ul.col5 > li:nth-child(1),
	ul.col5 > li:nth-child(2) {
		width:50%;
	}
	.featured1 ul.col2 > li{
		width:100%;
		display: block;
	}
	
	.max1024{
		display: none;
	}
	.min1024{
		display: block;
	}
}
@media only screen and (max-width: 1023px){
	#mobilemenu-bottom-send {
		display: table;
		position: fixed;
		bottom: 105px;
		width: 100%;
		z-index: 6001;
	}
	#mobilemenu-bottom-send a {
		display: table;
		position: fixed;
		bottom: -34px;
		width: 100%;
		z-index: 6001;
	}
	#mobilemenu-bottom-send a {
		background: #44a610;
		max-width: 215px;
		padding: 20px 20px;
		margin: 0;
		margin-right: 10px!important;
		margin-bottom: 120px;
		border-radius: 90px;
		color: #FFF;
		text-align: center;
		letter-spacing: 1px;
		font-weight: bolder;
		font-family: 'Open Sans Bold';
		cursor: pointer;
		text-shadow: 1px 1px 4px rgb(0 0 0 / 80%);
		box-shadow: 1px 1px 4px rgb(0 0 0 / 80%);
	}
	#hometext {
		top:20vh;
	}
	body:not([page=index]) #banner {
		display:none !important;
		/*background: none;*/
	}
	body:not([page=index]) #body{
		padding-top:0px !important; 
	}
	#banner.fullheight{
		height:698px;
	}
	#fullwidth .slide .caption img{
		width:100%;	
	}
	#fullwidth .slide > img{
		width:auto;
		height:100%;	
	}
	#featured-nav{
		margin-top:10px;
	}
	#featured-nav .col2{
		text-align:center;	
	}			
	#featured-nav .col2 li{
		width:45% !important;
		display:inline-block;
	}
	#featured-nav .col2 li:last-child .butt2{
		margin:0 !important;	
	}

	body[page=contact-us] #body{
		padding:0;	
	}
	#header{
		height:auto;
		position:relative;
		padding:0;
		background-size: auto 100%;
		padding-bottom:10px;
	}
	#header > .wrapper{
		height:auto;
		overflow:inherit;
	}

	#header #offer2 h2{
		margin:0;
	}
	#topnav #callus{
		display:none;
		margin-bottom:20px;	
	}
	#header #logo{
		padding-top:60px;
		padding-bottom:10px;
		position:relative;
	}
		#header #logo img{
			height: auto;
    		width: calc(100% - 30px);
		}
	#header #nav a{
		padding:5px;
		/*
		padding-top:0;
		padding-bottom:5px;
		*/
	}
		#header #nav > li:first-child a{
			padding: 5px 0 10px 5px;
		}
		#header #nav > li:last-child a{
			padding-bottom:15px;
		}
	#header #social-links{
		text-align:center;
		margin-top:0;
	}
	#header #social-links a{
		display:inline-block;
	}

	.notmobile{
		display:none;	
	}
	#footer ul.col2 li,
	#footer .col2 li:last-child{
		width:100%;
		text-align:center;
	}
	ul.col2.alt > li,
	ul.col2.alt > li:first-child,
	ul.col2.alt > li:last-child{
		width:50%;
	}
	.section > .wrapper > .padding{
		padding:20px;	
	}
	
	.section.heading.alt{
		text-align:center;	
	}
	.section.heading.alt img{
		margin:0;
		float:none;
	}
	.section.heading{
		padding:6px;
	}
	.section.heading h3,
	.section.heading h1{
		font-size:18px;	
		line-height:24px;	
		font-weight:normal;
		font-family:'Open Sans Bold', sans-serif;
	}

	#topnav{
		display:none;
	}
	#mobile-calltoaction {
		display: block;
		z-index: 6002!important;
	}
	#mobilemenu{
		display:block;
		padding:10px 0;
		text-align:left;
		color:#FFF;
		font-weight:bolder;
		letter-spacing:2px;
		cursor:pointer;
		position:fixed;
		top:0;
		width:100%;
		z-index:6001;
	}
		#mobilemenu .mobilemenubutton{
			margin-right:10px;	
		}
	#mobilemenu-bottom{
		display:table;
		position:fixed;
		bottom:35px;
		width:100%;
		z-index:6001;
	}
		#mobilemenu-bottom a{
			background: #cf000f;
			padding: 20px 20px;
			margin: 0;
			margin-right: 10px!important;
			margin-bottom: 20px;
			border-radius: 90px;
			color: #FFF;
			text-align: center;
			letter-spacing: 1px;
			font-weight: bolder;
			font-family: 'Open Sans Bold';
			cursor: pointer;
			text-shadow: 1px 1px 4px rgba(0,0,0,0.8);
			box-shadow: 1px 1px 4px rgba(0,0,0,0.8);
		}
			#mobilemenu-bottom a:hover{
				background:#111;	
			}
	#quote-cont{

	}
	.testimonial > div{
		width:auto;
	}
	#footer{
		position:relative !important;	
	}
	#location{
		display:none!important;
	}
	
	body:not([page=index]) #banner.hide-on-child-pages + #body,
	body:not([page=index]) #banner.hide-on-child-pages + #banner-icons + #body{
		padding-top:0px;
	}
	
	/***********************************************************************************************/
		
	#header #nav:not(.sidemenu){
		position:fixed;
		padding:0;
		top:0;
		display:none;
		width:100%;
		margin-bottom:0;
		margin-top:47px;
		z-index:6000;
	}

		#header #nav:not(.sidemenu) ul li{
			border-bottom:1px solid rgba(255,255,255,0.1);	
		}

		#header #nav:not(.sidemenu) ul:not(.sub_menu) > li.selected > a{
			color:#FFF !important;
		}

		#header #nav:not(.sidemenu) ul:not(.sub_menu) li{
			display:block !important;
			font-size:20px;
			text-align:left;
			background:rgba(0, 0, 0, 0.9);
		}

			#header #nav:not(.sidemenu) ul:not(.sub_menu) li a{
				font-size:20px;
				color:#FFF;
				padding-left:10px;
			}

				#header #nav:not(.sidemenu) .sub_menu{
					width:auto !important;
					visibility:visible !important;
					position:relative !important;
					box-shadow:none !important;
					border:0 !important;
					background:none !important;
					padding-bottom:10px !important;
				}
		
					#header #nav:not(.sidemenu) .sub_menu li{
						height:auto !important;
						border:0 !important;
						padding:0 !important;
						display:block !important;
						background:none !important;
					}
					
					#header #nav:not(.sidemenu) .sub_menu li:first-child{
						display:none !important;
					}
		
					#header #nav:not(.sidemenu) .sub_menu li a{
						margin-bottom:0 !important;
						padding-bottom:0 !important;
						padding:5px 20px !important;
						text-align:left !important;
						color:rgba(255,255,255,0.8) !important;
					}
					
					#header #nav:not(.sidemenu) ul > li a i{
						display:none;
					}

	/***********************************************************************************************/
	#header #nav.sidemenu{
		position:fixed;
		display:block;
		bottom:0;
		top:0;
		max-width:320px;
		overflow-x:hidden;
		z-index:6003;		
		background:#FFF;
		width:90%;
		width:calc(100%-56px);		
		padding:0;		
		-webkit-box-sizing: inherit;
		box-sizing: inherit;
		-webkit-transform: translateX(-100%);
		transform: translateX(-100%);		
		will-change: transform;
	}
	#header #nav.sidemenu.is_open{
		-webkit-box-shadow: 0 8px 10px -5px rgba(0,0,0,0.2),0 16px 24px 2px rgba(0,0,0,0.14),0 6px 30px 5px rgba(0,0,0,0.12);
		box-shadow: 0 8px 10px -5px rgba(0,0,0,0.2),0 16px 24px 2px rgba(0,0,0,0.14),0 6px 30px 5px rgba(0,0,0,0.12);
		-webkit-transform: translateX(0);
		transform: translateX(0);
		transition:transform 200ms ease-in-out;
	}
	#header #nav.sidemenu ul > li{
		display:block;
		text-align:left;		
	}
	#header #nav.sidemenu ul > li > ul{
		width:auto !important;
		visibility:visible !important;
		position:relative !important;
		box-shadow:none !important;
		border:0 !important;
		background:none !important;
		display:none;
		padding:15px;
		padding-top:0;
		padding-bottom:0 !important;
	}
	#header #nav.sidemenu ul > li:not(.selected) a,
	#header #nav.sidemenu ul > li:not(.selected) > ul > li a{
		color:#333 !important;
		background: none;
	}
	#header #nav.sidemenu ul > li a,
	#header #nav.sidemenu ul > li > ul > li a{
		font-size:14px;
		padding:15px 15px 15px 20px !important;
		font-weight:500;
		text-shadow: none;
		background-image: none;
	}
	#header #nav.sidemenu ul > li.selected > a{
		background:#333;
		color:#FFF;
		border-radius:0;
	}
	#header #nav.sidemenu ul > li > a:hover{
		border:0 !important;
		box-shadow:none !important;
	}
	#header #nav.sidemenu ul li ul li.selected a,
	#header #nav.sidemenu ul li ul li:hover a{
		background:none !important;
		color: #2452b9 !important;
	}
	#header #nav.sidemenu i:not(dropdown-icon){
		display:inline-table;	
		width:15px;
		text-align:center;
		margin-right:5px;
	}		
	#review-peek .block1{
		margin-top:0;
	}
	/*************************************************************************************************/
	
	#mobile-text-slider{
		display:block;
		background:#b90c0c;
		color:#FFF;
	    width: 80%;
		height:62px;
		text-align:center;
	}
		#mobile-text-slider > div{
			overflow: hidden;
			position: relative;
			width: 100%;
		}
			#mobile-text-slider > div ul {
				list-style: none;
				width:100%;
				margin: 0;
				padding: 0;
				position: relative;
			}
				#mobile-text-slider > div ul li{
					width:100%;
					float:left;
					text-align: center;
					position: relative;
				}		
		#mobile-text-slider ul li{
			padding-top:15px;
		}
		#mobile-text-slider strong{
			font-family:'Open Sans Extra Bold', sans-serif;
		}
		
		#mobile-text-slider strong,
		#mobile-text-slider span,
		#mobile-text-slider h2{
			text-transform: uppercase;
			display:block;
		}
		#mobile-text-slider strong,
		#mobile-text-slider span{
			font-size:4.5vw;
			line-height:4.5vw;
			margin-right:15px;
		}
		#mobile-text-slider span{
			letter-spacing:2px;
			font-size:4vw;
		}
		#mobile-text-slider h2{
			color: #FFF;
			text-align: center;
			font-size: 9vw;
			margin-right: 15px;	
		}
	
}
@media only screen and (max-width: 960px){
}
@media only screen and (max-width: 815px){
	.slant:before, .reverse-slant:before {
		border-width: 0 0 30px 815px;
	}
	.bottom-slant:after, .bottom-reverse-slant:after{
		border-width: 30px 0 0 815px;
	}
	.gallery{
		text-align:center;
	}
	#body_body .wrapper > .col2.alt .padding{
		padding:20px;	
	}

	ul.col2.alt > li,
	ul.col2.alt > li:first-child,
	ul.col2.alt > li:last-child,
	ul.col2.alt2 > li,
	ul.col2.alt2 > li:first-child,
	ul.col2.alt2 > li:last-child,
	ul.col2.alt3 > li,
	ul.col2.alt3 > li:first-child,
	ul.col2.alt3 > li:last-child{
		width:100%;
		padding:0;
	}
	
	ul.reverse > li{
		width:100% !important;	
	}
	ul.reverse > li > .padding{
		padding:0 !important;
	}

	ul.col2 > li > .padding{
		padding:0 !important;
	}

	ul.col2 > li:nth-child(2) > .padding{

		padding-top:10px;	

	}

	ul.col3 > li:nth-child(2) ul.bullet,
	ul.col3 > li:nth-child(3) ul.bullet{
		float:none;
		display:block;
	}
	
	ul.col4 {
		margin:0;
		padding:0;
	}
	ul.col4 > li{
		width:100%;
		float:none;
	}
	#footer .col.col4 li:nth-child(2n+1){
		background:rgba(0,0,0,0.025);	
	}
	#footer2{
		padding-top:0;
		padding-bottom:90px;
	}
}
@media only screen and (max-width: 768px){
	#mobilemenu-bottom a.send {
		margin-bottom: 20px;
	}
	#header #logo img {
		max-width: 300px !important;
	}
	#hometext #hometext-peek {
		width: 71%;
	}
	#hometext h3 {
		font-size: 38px;
		line-height: 45px;
	}
	#hometext ol.fa-ul {
    	font-size: 22px;
	}
	.slant:before, .reverse-slant:before {
		border-width: 0 0 30px 768px;
	}
	.bottom-slant:after, .bottom-reverse-slant:after{
		border-width: 30px 0 0 768px;
	}
	#header {
   	 width: 100%;
	}
	.bannertext h4 {		
		font-size: 7vw;
		line-height: 7vw;
	}
	.thumb1 {   
    	margin-bottom: 20px;
	}
	.slant {		
		padding-top: 45px;
		padding-bottom: 50px;
	}
	body:not([logo_banner=true]) .bannertext h4 {		
		font-size: 9vw;
		line-height: 9vw;
	}
	body:not([logo_banner=true]) .bannertext {
    	top: 25vh;
	}
}
@media only screen and (max-width: 656px){
	.scroll-icon {
		display:none;
	}
}
@media only screen and (max-width: 640px){
	.slant:before, .reverse-slant:before {
		border-width: 0 0 30px 640px;
	}
	.bottom-slant:after, .bottom-reverse-slant:after{
		border-width: 30px 0 0 640px;
	}
	#hometext h3 {
		font-size: 30px;
	}
	#hometext h2 {
		font-size: 20px;
	}
	#hometext h2 span {
		font-size: 16px;
	}
	.section.highlight.alt{
		padding:10px;
	}
		.section.highlight.alt h3{
			font-size:20px;
		}
		.section.highlight.alt .text_group span{
			margin:0 2px;
		}
	
	ul.col3{
		margin:0;	
	}
	ul.col5 > li:nth-child(1),
	ul.col5 > li:nth-child(2),
	ul.col5 > li,
	ul.col4 > li,
	ul.col3 > li,
	ul.col2 > li{
		width:100%;	
		float:none;
	}
	
	#footer .col li{
		text-align:center !important;
	}

	.reverse > li:first-child{
		text-align: center;
	}
	.thumb1.left,
	.thumb1.right{
		float:none;
		margin:0;
		margin-bottom:10px;
	}
	.section .image .wrapper > div{
		width:auto;
		padding:0px 20px;
	}
	.section > .wrapper > .padding{
		padding:20px;
	}
	.parallax .padding{
		padding:20px;
	}
	.fullwidth h4{
		font-size:3vw;
		line-height:3vw;
	}
	.mobile-view{
		display:block;
	}
	#header{
		width: 100%;
		padding:0;
	}
	#testimonials .padding{
		padding:5px;
	}
	#testimonials .testimonial{
		padding:0;	
	}
	
	.section.heading h3{
		font-size:20px;	
	}
	h1{
		font-size:24px;	
		line-height:24px;
	}
	#specials_cont{
		margin-bottom:0px;
	}	
	.padding2,
	.padding3{
		padding:20px;
	}

}
@media only screen and (max-width: 550px){
	.slant:before, .reverse-slant:before {
		border-width: 0 0 30px 550px;
	}
	.bottom-slant:after, .bottom-reverse-slant:after{
		border-width: 30px 0 0 550px;
	}
	#mobilemenu-bottom-slider{
		display:table;
		position:fixed;
		bottom:20px;
		width:100%;
		z-index:6001;
	}
	#callus{
		padding-top:10px !important;
	}
	#callus h2,
	#callus h3{
		font-weight:900;
		font-size:18px;	
		line-height:18px;
	}
	.parallax.fullscreen h3,
	.parallax h3.big{
		font-size:30px;
		line-height:30px;
	}
	.parallax.fullscreen h2,
	.parallax h2{
		font-size:20px;
		line-height:20px;
	}
}
@media only screen and (max-width: 480px){
	.slant:before, .reverse-slant:before {
		border-width: 0 0 30px 480px;
	}
	.bottom-slant:after, .bottom-reverse-slant:after{
		border-width: 30px 0 0 480px;
	}
	#hometext {
		top:5vh;
	}
	#photo_uploader li{
		padding-bottom:30px !important;	
	}
	.text_group span{
		margin:0;
	}
}
@media only screen and (max-width: 425px){	
	#hometext #hometext-peek {
		width: 100%;
		background: none;
		text-shadow: rgb(0 0 0) 2px 2px 1px, rgb(0 0 0) 1px 1px 1px, rgb(0 0 0) 1px 1px 2px, rgb(0 0 0) 1px 2px 2px;
	}
	#hometext ol.fa-ul {
		font-size: 20px;
		line-height: 25px;
	}
	a.butt1.sched {
		display: none;
	}
	#hometext h3 {
		font-size: 25px;
		line-height: 30px;
	}
	.slant:before, .reverse-slant:before {
		border-width: 0 0 30px 425px;
	}
	.bottom-slant:after, .bottom-reverse-slant:after{
		border-width: 30px 0 0 425px;
	}
	#hometext {
		top: 2vh;
	}
	#banner.fullheight {
		height:283.333px;
	}
	.bannertext {
		top: 22vh;
	}	
	.fullwidth h4 {
		font-size: 6vw;
		line-height: 6vw;
	}
	#section_contact{
		padding-bottom: 100px;
		background-size: 200vw;
	}
	.parallax h2:not(.headingtext) {		
		font-size: 28px;
		letter-spacing:0px;
		line-height: 32px;
	}
	.slant {
		padding-top: 75px;
		padding-bottom: 80px;
	}
	.headingtext2 {		
		font-size: 80px;
		line-height: 78px;
	}
	#testimonial_scroller {
		padding: 90px 0;
	}
}
@media only screen and (max-width: 414px){	
	.slant:before, .reverse-slant:before {
		border-width: 0 0 30px 414px;
	}
	.bottom-slant:after, .bottom-reverse-slant:after{
		border-width: 30px 0 0 414px;
	}
	#callus h2, #callus h3{
		font-size:14px;	
		line-height:14px;
	}
	h2{
		text-shadow:none;	
	}
	.gallery a{
		margin:2px;
		width:100%;
		background:none;
	}
}
@media only screen and (max-width: 375px){	
	#hometext {
		top: 2vh;
	}
	#hometext ol.fa-ul {
		font-size: 18px;
		line-height: 25px;
	}
}
@media only screen and (max-width: 360px){
	.slant:before, .reverse-slant:before {
		border-width: 0 0 15px 360px;
	}
	.bottom-slant:after, .bottom-reverse-slant:after{
		border-width: 15px 0 0 360px;
	}
}
@media only screen and (max-width: 320px){
	#hometext {
		top: 2vh;
	}
	#hometext h3 {
		font-size: 20px;
		line-height: 25px;
	}
	.slant:before, .reverse-slant:before {
		border-width: 0 0 15px 320px;
	}
	.bottom-slant:after, .bottom-reverse-slant:after{
		border-width: 15px 0 0 320px;
	}	
	#mobile-text-slider{
		width: 75%;
	}
	#mobile-text-slider h2{
		font-size:8vw;
	}
	#mobile-text-slider ul li{
		padding:20px 0;
	}
	#mobilemenu-bottom a {
		padding: 20px 10px;
		margin-right: 5px!important;
	}
	.headingtext2 {
		font-size: 65px;
		line-height: 60px;
	}
}