/*
Theme Name: Custom Builder Child Theme
Theme URI: http://405mediagroup.com/
Description: Custom Builder child theme for client sites.
Author: 405 Media Group
Author URI: http://405mediagroup.com/
Template: Builder
*/

/*********************************************
Default font settings and typography.
The font-size percentage is of 16px. (0.875 * 16px = 14px)
*********************************************/

@import url('https://fonts.googleapis.com/css?family=Open+Sans');
@font-face {
	font-family: 'Futura Bold';
	src: url('fonts/Futura Bold.ttf');
}
@font-face {
	font-family: 'Futura Medium';
	src: url('fonts/Futura Medium BT.ttf');
}

html {
	font-size: 100%;
}
body {
	color: #222222;
	font-family: 'Open Sans', Arial, sans-serif;
	line-height: 1.625;
}
/*input, select, textarea {
font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
}*/
pre, code, tt, kbd {
	font-family: 'andale mono', 'lucida console', monospace;
	font-size: 1em;
	line-height: 1.5;
}
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
address, dfn, img, samp, ul, ol, dl {
	/*margin-top: 1.5em;
	margin-bottom: 1.5em;*/
}
a img {
	margin: 0;
}


/*********************************************
Constrain table and input widths
*********************************************/
table, input, textarea, select {
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	height: auto;
	max-width: 100%;
}


/*********************************************
Main Background
*********************************************/
body {
	background: #FFFFFF;
}


/*********************************************
Universal Link Styles
*********************************************/
a {
	color: #AAAAAA;
	text-decoration: underline;
	transition: .2s;
}
a:hover {
	color: #666666;
	text-decoration: none;
}
a:focus {
	color: #AAAAAA;
}


/*********************************************
Headings
*********************************************/
h1, h2, h3, h4, h5, h6 {
	/*color: #111111;*/
	font-weight: bold;
}
h1 {
	font-size: 2em;
	letter-spacing: -1px;
	line-height: 1.5;
	/*margin-top: 0.75em;
	margin-bottom: 0.75em;*/
}
h2 {
	font-size: 1.7em;
	line-height: 1.75;
	/*margin-top: 0.9em;
	margin-bottom: 0.9em;*/
}
h3 {
	font-size: 1.5em;
	line-height: 1;
	/*margin-top: 1em;
	margin-bottom: 1em;*/
}
h4 {
	font-size: 1.2em;
	line-height: 1.25;
	/*margin-top: 1.25em;
	margin-bottom: 1.25em;*/
}
h5, h6 {
	font-size: 1em;
}
h6 {
	font-style: italic;
}
h1 img, h2 img, h3 img, h4 img, h5 img, h6 img {
	margin: 0;
}


/*********************************************
Container Div
*********************************************/
.builder-container-outer-wrapper {
	background: transparent;
	border: none;
	display: block;
	/*margin: 1.5em auto;*/
}


/*********************************************
Default Module Styling
*********************************************/
.builder-module-background-wrapper {
	margin-bottom: 0;
}
.builder-module-last {
	margin-bottom: 0;
}
.builder-module-element {
	padding: 1.5em;
}


/*********************************************
All Sidebars
*********************************************/
.builder-module-sidebar {
	display: block;
	margin: 0;
	padding: .75em 0;
	width: 100%;
}
.builder-module-sidebar.right {
	margin-right: 0;
}
.builder-module-sidebar.left {
	margin-left: 0;
}
.builder-module-sidebar .widget-wrapper {
	width: 100%;
}
.builder-module-sidebar .widget {
	color: #333333;
	margin: 0;
	/*padding: .75em 1em;*/
}
.builder-module-sidebar .widget-section-wrapper {
	padding: 0 .75em;
}
.builder-module-sidebar .widget-section-wrapper .widget {
	padding: .75em;
}
.builder-module-block-outer-wrapper {
	overflow: visible !important;
}
.builder-module-block-outer-wrapper .widget-wrapper-left .widget,
.builder-module-block-outer-wrapper .widget-wrapper-middle .widget,
.builder-module-block-outer-wrapper .widget-wrapper-right .widget {
	/*padding-right: .75em;*/
}
.builder-module-sidebar .widget-title {
	background: none;
	color: #333333;
	font-size: 1.5em;
	line-height: 1.25;
	margin: 0 0 1em 0;
	padding: 0;
}
.builder-module-sidebar .widget-title a {
	color: #333333;
}
/*.builder-module-sidebar .widget-title + * {
margin-top: 0;
}
.builder-module-sidebar .widget *:first-child {
margin-top: 0;
}
.builder-module-sidebar .widget *:last-child {
margin-bottom: 0;
}*/
.builder-module-sidebar .widget a.rsswidget img {
	display: none;
}


/*********************************************
Header Module
*********************************************/
.builder-module-header {
	padding: .75em 0;
}
.builder-module-header .builder-module-sidebar {
	background: none;
	padding: 0;
}
.builder-module-header .builder-module-element {
	padding: .75em 1.5em;
}

.site-title,
.site-title a,
.site-title a:hover,
.site-tagline,
.site-tagline a,
.site-tagline a:hover {
	color: #262626;
	font-size: 1em;
	font-weight: bold;
	line-height: 1;
	height: auto;
	margin: 0;
	padding: 0;
	text-decoration: none;
}
.site-title a:hover,
.site-tagline a:hover {
	color: #000000;
}

.site-title {
	font-size: 2em;
	letter-spacing: -1px;
	line-height: 1;
	margin: 0;
}

.site-tagline {
	font-size: 1em;
	font-weight: bold;
	line-height: 1;
	margin: .5em 0 0 0;
}
.site-tagline,
.site-tagline a {
	color: #666666;
}


/*********************************************
Navigation Module
*********************************************/
.builder-module-navigation {
	display: block;
	font-size: 1em;
	line-height: 2;
	width: 100%;
}
.builder-module-navigation .builder-module-element {
	padding: 0;
}
.builder-module-navigation ul {
	display: block;
	float: left;
	margin: 0;
	padding: 0;
}
.builder-module-navigation ul * {
	margin: 0;
}
.builder-module-navigation li {
	padding: 0;
}
.builder-module-navigation li a,
.builder-module-navigation .current_page_item li a,
.builder-module-navigation .current-cat li a {
	background: #EDEDED;
	color: #333333;
	font-size: 1em;
	font-weight: bold;
	padding: .5em 1em;
	text-decoration: none;
}
.builder-module-navigation .current_page_item a,
.builder-module-navigation .current-cat a,
.builder-module-navigation .current-menu-item a {
	background: #333333;
	color: #FFFFFF;
}
.builder-module-navigation li a:hover {
	background: #333333;
	color: #FFFFFF;
}
/* second level stuff */
.builder-module-navigation li ul {
	border: 1px solid #AAAAAA;
	border-bottom: 0;
	width: 14em;
}
.builder-module-navigation li li {
	border-bottom: 1px solid #AAAAAA;
	width: 100%;
}
.builder-module-navigation li li a {
	float: none;
}
.builder-module-navigation li li a:hover,
.builder-module-navigation li li a.sfhover {
}
.builder-module-navigation li ul ul {
	margin: -3.1em 0 0 14em;
}

/* *** Uncomment for auto-width sub-menu ***
.builder-module-navigation li ul {
width: auto;
}
.builder-module-navigation li li {
clear: both;
width: 100%;
max-width: 600px;
}
*/

#it-mobile-menu {
	display: none;
}


/*********************************************
Widget Bar Module
*********************************************/
.builder-module-widget-bar-background-wrapper.builder-module-before-widget-bar-background-wrapper {
	/*padding-bottom: 0;
	margin-bottom: 0;*/
}
.builder-module-widget-bar-background-wrapper.builder-module-after-widget-bar-background-wrapper {
	/*padding-top: 0;*/
}

.builder-module-widget-bar-outer-wrapper,
.builder-module-widget-bar,
.builder-module-widget-bar .widget-wrapper {
	overflow: visible;
}

.builder-module-widget-bar .builder-module-sidebar {
	padding: 0;
}
.builder-module-widget-bar .widget {
	/*padding: 1em;*/
}

.builder-module-block-outer-wrapper .widget-wrapper-left .widget,
.builder-module-block-outer-wrapper .widget-wrapper-middle .widget,
.builder-module-block-outer-wrapper .widget-wrapper-right .widget {
	/*padding-right: 1em;*/
}


/*********************************************
Footer Module
*********************************************/
.builder-module-footer-background-wrapper {
	background: transparent;
}
.builder-module-footer .single .builder-module-element,
.builder-module-footer .left .builder-module-element {
	padding-top: 0;
}
.builder-module-footer .single .builder-module-element,
.builder-module-footer .right .builder-module-element {
	padding-bottom: 0;
}
.builder-module-footer .builder-module-element .alignright {
	text-align: right;
}


/*********************************************
Image Module
*********************************************/
.builder-module-image-background-wrapper {
	background: transparent;
}
.builder-module-image .builder-module-element {
	font-size: 0;
	margin: 0;
}
.builder-module-image .builder-module-element img {
	margin: 0;
}


/*********************************************
HTML Module
*********************************************/
.builder-module-html .builder-module-element>*:first-child {
	margin-top: 0;
}
.builder-module-html .builder-module-element>*:last-child {
	margin-bottom: 0;
}


/*********************************************
Content Module
*********************************************/
.builder-module-content .builder-module-element {
	overflow: hidden;
}
.builder-module-content .hentry {
	margin-bottom: 1.5em;
}

.entry-title,
.entry-title * {
	margin: 0;
	padding: 0;
}
.hentry .thumbnail-wrap {
	display: none;
}
.hentry .date {
	display: none!important;
}

.entry-title {
	clear: both;
	color: #262626;
	font-size: 1.9em;
	font-weight: bold;
	letter-spacing: -1px;
	line-height: 1;
	margin-bottom: .56em;
}
.entry-title a {
	color: #262626;
	font-size: 1em;
	text-decoration: none;
}
.entry-title a:hover {
	color: #AAAAAA;
}
.hentry .entry-meta {
	display: block;
}
.hentry .entry-meta a {
	font-style: italic;
	text-decoration: none;
}
.hentry .entry-meta a:hover {
	text-decoration: underline;
}
.hentry .entry-footer {
	display: none;
}
.hentry .entry-footer img {
	max-width: none;
}

.hentry .entry-attachment .attachment {
	text-align: center;
}

.hentry .edit-entry-link {
	display: none;
	clear: both;
	margin: 0 0 1.5em 0;
}

.entry-content {
	clear: both;
	margin-top: 1.5em;
}
.loop-title {
	font-size: 1.75em;
	line-height: 1.7;
	margin-top: 0;
	margin-bottom: .875em;
}


/*********************************************
Style images and galleries
.hentry is used instead of .page or .post
as it applies to all content types
*********************************************/

.hentry .gallery a,
.hentry .gallery dt,
.hentry .gallery img {
	font-size: 0;
	line-height: 0;
	margin: 0;
}
.hentry .gallery-item {
	display: inline-block;
	margin: 0 1.5em 1.5em 0;
	text-align: left;
	vertical-align: top;
	width: 150px;
}
.hentry .gallery-item img {
	border: 0;
	margin: 0;
	padding: 0;
}
.hentry .gallery-caption {
	line-height: 1;
	margin: 0;
	padding: 10px 5px 5px 5px;
}
.hentry .gallery + * {
	margin-top: 0;
}

.hentry .alignright {
	margin: 0 0 1.5em 1.5em;
}
.hentry .alignleft {
	margin: 0 1.5em 1.5em 0;
}
.hentry .aligncenter {
	margin: 0 auto 1.5em auto;
}

.hentry .wp-caption {
	background: #F3F3F3;
	border: 1px solid #CFCFCF;
	padding: 5px;
}
.hentry .wp-caption img {
	background: transparent;
	border: none;
	padding: 0;
}

.hentry .wp-caption-text {
	line-height: 1;
	margin: 0;
	padding: 10px 5px 5px 5px;
}


/*********************************************
Post Meta Styles, if needed
*********************************************/

.entry-header {
	clear: both; /* we need this so floats in the post are cleared */
}

.entry-footer {
	clear: both; /* we need this so floats in the post are cleared */
	margin-bottom: 3em;
	padding-top: 1.4em;
}
.entry-footer .alignright {
	margin-bottom: 1.5em;
}
.entry-footer .categories,
.entry-footer .tags {
	background: url( 'images/category-bg.png' ) -2px 3px no-repeat;
	padding: 0 0 0 1.5em;
}
.entry-footer .comments {
	background: url( 'images/comments-bg.png' ) -2px 2px no-repeat;
	padding: 0 0 0 1.5em;
}

.EXIF table {
	margin: 1.5em auto;
}
.photometa h4 {
	margin: 0;
	padding: 0;
	text-align: center;
}
.photometa ul {
	list-style-type: none;
}


/*********************************************
Previous/Next Page Navigation
*********************************************/
.loop-utility {
	clear: both; /* To clear any floats */
}


/*********************************************
Comment Styles
*********************************************/

#comments {
	margin: 3em 0 1.5em 0;
	padding: 0;
}
#comments ol.commentlist {
	background: transparent;
	margin: 1.5em 0;
	padding: 0;
}
#comments ul.children {
	margin: 0 1.5em;
}
#comments .vcard {
	line-height: 1;
	margin-bottom: .5em;
}
#comments .vcard .avatar {
	display: block;
	float: left;
	margin: 0 .75em 0 0;
}
#comments .comment-meta {
	margin-bottom: 1.5em;
}
#comments li.comment {
	border: 1px solid #999999;
	clear: both;
	list-style-type: none;
	margin: 1.5em 0;
	overflow: hidden;
}
#comments li .comment-body {
	margin: 1.5em;
}
#comments blockquote {
	margin: 1.5em;
}

#respond {
	margin-top: 3em;
	overflow: visible !important;
}
.comment #respond {
	border: 1px solid #999999;
	margin: 1.5em 1.5em 1.5em 1.5em;
	padding: 0 1.5em 1.5em 1.5em;
}
#respond h3 {
	margin-bottom: 0;
}
#respond .cancel-comment-reply a {
	display: block;
	margin: 0;
}
#commentform label {
	margin-left: 1em;
}
#commentform input[type="text"] {
	width: 20em;
}
#commentform input,
#commentform textarea {
	margin: 0;
}
#commentform #comment {
	width: 100%;
}
#commentform .comment-submit-wrapper {
	margin-bottom: 0;
}


/*********************************************
Text elements
*********************************************/

p {
}
p img.left {
	float: left;
	margin: 1.5em 1.5em 1.5em 0;
	padding: 0;
}
p img.right {
	float: right;
	margin: 1.5em 0 1.5em 1.5em;
}
blockquote {
	color: #666666;
	font-size: 1.2em;
	font-style: italic;
	margin: 1.5em;
	padding: 0;
}
/* To prevent nested blockquotes from increasing in size */
blockquote blockquote {
	font-size: 100%;
}
strong {
	font-weight: bold;
}
em, dfn {
	font-style: italic;
}
dfn {
	font-weight: bold;
}
sup, sub {
	height: 0;
	line-height: 1.5;
	position: relative;
	vertical-align: baseline;
}
sup {
	bottom: 1ex;
}
sub {
	top: .5ex;
}
abbr, acronym {
	border-bottom: 1px dotted #666;
}
address {
	font-style: italic;
}
del {
	color: #666666;
}
pre {
	margin: 1.5em 0;
	white-space: pre;
}
big {
	font-size: 1.2em;
	line-height: 1;
}


/*********************************************
Lists
*********************************************/

ul, ol {
	list-style-position: outside;
	margin: 0 0 0 3em;
	padding: 0;
}
.entry-content > ul,
.entry-content > ol {
	margin-top: 1.5em;
	margin-bottom: 1.5em;
}
ul ul, ul ol, ol ul, ol ol {
	margin-left: 1.6em;
}
li {
	margin: 0;
	padding: 0;
}
li > * {
	margin-top: 0;
}
li *:last-child {
	margin-bottom: 0;
}
li > p + ul {
	margin-top: -1.5em;
}
ul {
	list-style-type: disc;
}
ol {
	list-style-type: decimal;
}
dl {
	margin: 0 0 1.5em 0;
}
dl dt {
	font-weight: bold;
}
dd {
	margin-left: 1.5em;
}
dd + dd {
	margin-top: 1.5em;
}


/*********************************************
Tables
*********************************************/

table {
	background: #F3F3F3;
	margin-bottom: 1.5em;
}
table, td, th {
	border: 1px solid #CFCFCF;
	border-collapse: collapse;
}
th {
	background: #E8E8E8;
	font-weight: bold;
	line-height: 1.5;
}
th, td, caption {
	padding: .75em;
}
tr:nth-child(2n) th {
	background: #F6F6F6;
}
tr:nth-child(2n) td {
	background: #FFFFFF;
}
tfoot {
	font-style: italic;
}
caption {
	background: #EEEEEE;
}


/*********************************************
Misc classes
*********************************************/

.small {
	font-size: .8em;
	line-height: 1.875;
	margin-top: 1.875em;
	margin-bottom: 1.875em;
}
.large {
	font-size: 1.2em;
	line-height: 2.5;
	margin-top: 1.25em;
	margin-bottom: 1.25em;
}
.hide {
	display: none;
}
.quiet {
	color: #666666;
}
.loud {
	color: #000000;
}
.highlight {
	background: #FFFF00;
}
.added {
	background: #006600;
	color: #FFFFFF;
}
.removed {
	background: #990000;
	color: #FFFFFF;
}
.first {
	margin-left: 0;
	padding-left: 0;
}
.last {
	margin-right: 0;
	padding-right: 0;
}
.top {
	margin-top: 0;
	padding-top: 0;
}
.bottom {
	margin-bottom: 0;
	padding-bottom: 0;
}


/*********************************************
Default styling for forms
*********************************************/

label {
	font-weight: bold;
}
fieldset {
	border: .1em solid #CCCCCC;
	margin: 0 0 1.5em 0;
	padding: 1.4em;
}
legend {
	font-size: 1.2em;
	font-weight: bold;
}

/*#gform_wrapper_1 {
background: #ccc;
margin: 0;
padding: 1em;
}
#gform_wrapper_1 .custom-form-header {
text-align: center;
}
#gform_wrapper_1 .custom-form-header img {
margin: 0;
}
#gform_wrapper_1 .gform_title {
font-size: 1.5em;
margin-top: 0.5em;
}*/


/*********************************************
Form fields
*********************************************/

input[type=text], input[type=password], input.text, input.title, textarea, select {
	font-size: 1em;
	margin-top: .5em;
	margin-bottom: .5em;
}
input[type=text], input[type=password], input.text, input.title, textarea {
	background-color: #FFFFFF;
	border: 1px solid #999999;
	padding: 5px;
}
input[type=text]:focus, input[type=password]:focus, input.text:focus, input.title:focus, textarea:focus {
	border-color: #666666;
}
textarea {
	width: 30em;
	height: 20em;
}
input[type=checkbox], input[type=radio], input.checkbox, input.radio {
	/*	position: relative;
	top: .25em;*/
}
.search-text-box {
	margin-bottom: 0;
}
.search-submit-button {
	margin: 0 !important;
	padding: .2em .5em;
}

/*body .gform_wrapper input[type=text],
body .gform_wrapper input[type=url],
body .gform_wrapper input[type=email],
body .gform_wrapper input[type=tel],
body .gform_wrapper input[type=number],
body .gform_wrapper input[type=password] {
font-size: 1em;
}
#gform_wrapper_1 input[type=text] {
line-height: 1.3;
}
#gform_wrapper_1 .gform_footer input[type=submit] {
background: #333;
border: none;
color: #fff;
cursor: pointer;
padding: 0.5em 1em;
}*/

/* Error messages */
.gform_wrapper div.validation_error,
.gform_wrapper .validation_message {
	display: none;
}
/*#gform_wrapper_1 li.gfield.gfield_error.gfield_contains_required,
#gform_wrapper_1 li.gfield.gfield_error.gfield_contains_required label.gfield_label, 
#gform_wrapper_1 li.gfield.gfield_error.gfield_contains_required div.ginput_container {
margin-top: 0;
}*/


/*********************************************
Success, notice and error boxes
*********************************************/

.error, .notice, .success {
	border: 2px solid #ddd;
	margin-bottom: 1em;
	padding: .8em;
}
.error {
	background: #FBE3E4;
	border-color: #FBC2C4;
	color: #8a1f11;
}
.notice {
	background: #FFF6BF;
	border-color: #FFD324;
	color: #514721;
}
.success {
	background: #E6EFC2;
	border-color: #C6D880;
	color: #264409;
}
.error a {
	color: #8a1f11;
}
.notice a {
	color: #514721;
}
.success a {
	color: #264409;
}


/*********************************************
Widget Styling
*********************************************/

.widget_rss li {
	margin-bottom: 1.5em;
}
.widget_rss .rsswidget {
	display: block;
	margin: 0;
}
.widget_rss .rss-date {
	display: block;
	font-style: italic;
	margin-bottom: 1.5em;
}
.widget_rss .rssSummary {
	margin: 1.5em 0;
}


/*********************************************
The Obligatory WP Styles
*********************************************/

.alignright {
	margin-left: 1.5em;
}
.alignleft {
	margin-right: 1.5em;
}
.hentry img.wp-smiley {
	border: none;
}


/*********************************************
Slider
*********************************************/

.custom-slider-background-wrapper {
	padding-left: 0 !important;
	padding-right: 0 !important;
}

/*********************************************
Mobile
*********************************************/

.custom-mobile-only-background-wrapper {
	display: none;
}

@media 
	screen and (max-device-width: 760px) and (-webkit-min-device-pixel-ratio: 1.5), /* Higher dpr/newer phones */
	screen and (max-device-width: 760px) and (min-resolution: 144dpi),				/* Higher resolution/newer phones */
	screen and (max-device-width: 400px) {											/* Lower resolution/older phones (pre-iPhone4) */
		.custom-mobile-only-background-wrapper {
			display: block;
		}
		.custom-desktop-only-background-wrapper {
			display: none;
		}
}

@media all and (max-width: 1024px) {
	/*********************************************
	Navigation Module (Mobile)
	*********************************************/
	.builder-module-navigation.mobile .builder-module-navigation-menu-wrapper {
		display: block;
		margin: 0;
	}
	.builder-module-navigation.mobile ul {
		background: #FFFFFF;
		margin-top: .5em;
	}
	.builder-module-navigation.mobile li {
		position: relative;
		width: 100%;
	}
	/* second level stuff */
	.builder-module-navigation.mobile li ul {
		display: none;
		position: relative !important;
		left: 0 !important;
		border: 0;
		margin: 0;
		width: 100%;
	}
	.builder-module-navigation.mobile li a,
	.builder-module-navigation.mobile .current_page_item li a,
	.builder-module-navigation.mobile .current-cat li a,
	.builder-module-navigation.mobile .current-menu-item li a {
		background: transparent;
		border-bottom: 1px solid rgba(0,0,0,0.1);
		border-radius: 0;
		color: #333333;
		margin: 0;
		padding: .5em 1em;
	}
	.builder-module-navigation.mobile li a:hover,
	.builder-module-navigation.mobile .current_page_item li a:hover,
	.builder-module-navigation.mobile .current-cat li a li a:hover,
	.builder-module-navigation.mobile .current-menu-item li a:hover {
		background: #333333;
		color: #FFFFFF;
	}
	.builder-module-navigation.mobile li li {
		border: 0;
		width: 100%;
	}
	.builder-module-navigation.mobile li ul ul {
		margin: 0;
	}
	.builder-module-navigation.mobile li li a {
		border-radius: 0;
		line-height: inherit;
		/*padding: .25em 0 .25em 2em;*/
		padding-left: 2em;
	}
	.builder-module-navigation.mobile li li li a {
		padding-left: 4em;
	}
	.builder-module-navigation .menu.hidden {
		display: none;
		width: 100%;
	}
	.builder-module-navigation #it-mobile-menu {
		background: #FFFFFF;
		border-radius: 2px;
		color: #333333;
		cursor: pointer;
		display: block;
		font-size: 1em;
		font-weight: bold;
		padding: .25em .75em;
		-webkit-font-smoothing: antialiased;	
	}
	.builder-module-navigation.mobile.borderless {
		border: 0;
	}
}

@media all and (max-width: 500px) {
	.builder-module-footer .builder-module-element .alignleft,
	.builder-module-footer .builder-module-element .alignright {
		float: none;
		margin: 0;
		text-align: left;
	}
	.builder-module-content .builder-module-element .alignleft,
	.builder-module-content .builder-module-element .alignright {
		float: none;
		margin: 0;
		text-align: left;
	}
}


:root {
	--color-primary: #2892d0;
	--color-secondary: #ce8f28;
}

* {
	box-sizing: border-box;
}

h1, h2, h3, h4, h5, h6 {
	font-family: 'Futura Bold';
}

.color-brown {
	color: var(--color-secondary);
}
.color-blue {
	color: var(--color-primary);
}
.color-dark-blue {
	color: #146db9;
}
.color-black {
	color: #000;
}
.color-white {
	color: #fff;
}

.bg-dark-blue {
	background-color: #146db9;
}
.bg-gray {
	background-color: #dcdee0;
}
.bg-black {
	background-color: #000;
}

.custom-topheader-background-wrapper {
	z-index: 3;
	background-color: #ebebeb;
	padding: 5px 0;
	top: 0;
	transition: .3s all;
}
.top-header {
	text-align: right;
	font-size: 48px;
	line-height: 1;
}
.top-header a {
	display: inline-block;
	margin-left: 15px;
}

.custom-header-background-wrapper {
	z-index: 2;
	background-color: #fff;
	padding: 20px 0;
	top: 0;
	transition: .3s all;
}
.header-phone {
	font-size: 40px;
	line-height: 100px;
	text-align: right;
}
.header-phone a {
	color: #2d2d2d;
	text-decoration: none;
}
.header-phone a:hover {
	color: var(--color-secondary);
}
.home:not(.sticky) .header-phone a {
	color: #fff;
}
.home:not(.sticky) .header-phone a:hover {
	color: var(--color-secondary);
}
.custom-mobile-menu-background-wrapper {
	z-index: 2;
	background-color: #146db9;
	top: 0;
	transition: .3s all;
}
.custom-mobile-menu .menu {
	float: right;
	margin-right: -15px;
}
.sticky .custom-mobile-menu .menu {
	margin-right: -10px;
}
.custom-mobile-menu .menu > li {

}
@media (min-width: 1025px) {
	.custom-mobile-menu .menu > li > a {
		position: relative;
		padding: 20px 15px;
		font-size: 24px;
		font-weight: 400;
		line-height: 1;
		text-transform: uppercase;
		background-color: transparent;
		color: #fff;
	}
	.sticky .custom-mobile-menu .menu > li > a {
		padding: 12px;
		font-size: 16px;
	}
	.custom-mobile-menu .menu > li:not(:last-child) > a:after {
		content: "";
		position: absolute;
		right: 0;
		width: 3px;
		height: 25px;
		background-color: var(--color-secondary);
	}
	.sticky .custom-mobile-menu .menu > li:not(:last-child) > a:after {
		width: 2px;
		height: 16px;
	}
	.custom-mobile-menu .menu > li.current-menu-item > a,
	.custom-mobile-menu .menu > li > a:hover {
		color: var(--color-secondary);
	}
}

.gform_wrapper {
	margin-bottom: 0 !important;
}
.gform_wrapper .gform_body ul.gform_fields li.gfield {
	padding-right: 0;
}
.gform_wrapper .gform_body .top_label .gfield_label {
	display: none;
}
.gform_wrapper .gform_body .field_sublabel_below .ginput_complex.ginput_container label {
	display: none;
}
.gform_wrapper .gform_body .top_label .field_description_below.check-list .gfield_label {
	display: block;
	font-size: 30px;
	font-weight: 300;
}
.gform_wrapper .gform_body .top_label .field_description_below.check-list li {
	float: left;
	width: 25%;
}
.gform_wrapper .gform_body .top_label .field_description_below.check-list li:last-child {
	width: 50%;
}
.gform_wrapper .gform_body input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
.gform_wrapper .gform_body textarea {
	margin-top: 0;
	margin-bottom: 0;
	padding: 10px 5px 10px 5px;
	font-size: 14px;
	line-height: 1.5;
}
.gform_wrapper .gform_body .gfield[class*=icon] input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
.gform_wrapper .gform_body .gfield[class*=icon] textarea {
	padding-left: 45px;
}
.gform_wrapper .gform_body textarea.medium {
	height: 190px;
}
.gform_wrapper .gfield[class*=icon] .ginput_container {
	position: relative;
	margin-top: 0;
}
.gform_wrapper .gfield[class*=icon] .ginput_container:before {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: 8px;
	font-family: "Font Awesome 5 Free";
	font-size: 30px;
	font-weight: 900;
	line-height: 1;
	color: #000;
}
.gform_wrapper .gfield[class*=icon] .ginput_container_textarea:before {
	top: 5px;
	transform: none;
}
.gform_wrapper .icon-user .ginput_container:before {
	content: "\f007";
}
.gform_wrapper .icon-phone .ginput_container:before {
	content: "\f095";
}
.gform_wrapper .icon-at .ginput_container:before {
	content: "\f1fa";
}
.gform_wrapper .icon-comments .ginput_container:before {
	content: "\f086";
}

.gform_wrapper .gform_body li.gfield.gfield_error.gfield_contains_required div.ginput_container,
.gform_wrapper .gform_body li.gfield.gfield_error.gfield_contains_required label.gfield_label {
	margin-top: 0;
}
.gform_wrapper.gform_validation_error .gform_body ul.gform_fields li.gfield.gfield_error:not(.gf_left_half):not(.gf_right_half) {
	max-width: 100% !important;
	padding: 0;
	border: none;
}
.gform_wrapper .gform_footer {
	text-align: right !important;
}
.gform_wrapper .gform_footer input[type=submit] {
	margin-right: 0 !important;
	padding: 10px 40px !important;
	background-color: var(--color-secondary);
	color: #fff;
	border: none;
	font-family: 'Open Sans';
	font-size: 18px !important;
	line-height: 1;
	text-transform: uppercase;
	cursor: pointer;
	-webkit-appearance: none;
}

@media only screen and (min-width: 641px) {
	.gform_wrapper .gform_body .ginput_complex .ginput_left,
	.gform_wrapper .gform_body .ginput_complex .ginput_right {
		width: 33.33%;
		margin-top: 16px;
		margin-right: 0 !important;
		padding-right: 8px !important;
	}
	.gform_wrapper .gform_body .ginput_complex.ginput_container_address span.ginput_right+span.ginput_left {
		padding-right: 0 !important;
	}
}

@media (min-width: 1200px) {
	.custom-mobile-contact-background-wrapper {
		position: absolute;
		z-index: 1;
		top: 210px;
		right: calc(50% - 585px);
		max-width: 320px;
	}
	.custom-mobile-contact .builder-module-block {
		padding: 10px;
		border: 5px solid #fff;
		border-radius: 10px;
	}
	.custom-mobile-contact .widget-wrapper {
		padding: 15px;
		border: 1px solid #fff;
		border-radius: 10px;
	}
	.contact-title-wrapper {
		border-bottom: 1px solid #fff;
		margin-bottom: 15px;
	}
	.contact-title-icon {
		padding: 5px 10px;
	}
}
@media (max-width: 1199px) {
	.custom-mobile-contact-background-wrapper {
		background-color: #000;
	}
	.custom-mobile-contact-outer-wrapper {
		max-width: 320px !important;
		padding: 40px 0;
	}
}
.builder-module-content .widget-title,
.custom-mobile-contact .widget-title {
	display: none;
}

.custom-about-background-wrapper {
	position: relative;
	margin: 20px 0;
	padding: 20px 0;
}
.custom-about-background-wrapper:before {
	content: "";
	position: absolute;
	left: 41%;
	top: 0;
	width: 50%;
	height: 100%;
	background-image: url(https://southshorepaving.com/wp-content/uploads/2018/02/bg-about.jpg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: 551px;
}
.about-wrapper {
	width: 50%;
	padding-right: 20px;
}
.about-wrapper h1 {
	font-size: 36px;
	line-height: 1;
}
.about-wrapper h1 span {
	font-family: 'Open Sans';
	font-size: 30px;
	font-weight: 100;
}
.about-wrapper h3,
.about-wrapper h4,
.about-wrapper p {
	margin: 0;
}
.about-wrapper ul {
	margin: 20px 0;
	list-style: none;
}
.about-wrapper ul li {
	float: left;
	width: 50%;
	padding: 10px 0;
}

.custom-feature-background-wrapper {
	position: relative;
	padding: 40px 0;
	background-image: url(https://southshorepaving.com/wp-content/uploads/2022/07/bg-feature-22.jpg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}
.custom-feature-background-wrapper:before {
	content: "";
	position: absolute;
	width: 50%;
	height: 100%;
	top: 0;
	background-color: rgba(0, 0, 0, .7);
}
.custom-feature-outer-wrapper {
	position: relative;
}
.feature-title-wrapper {
	padding-top: 40px;
}
.feature-title-wrapper p {
	color: #fff;
	font-size: 30px;
	line-height: 1.2;
}
.feature-num {
	float: left;
	width: 100px;
	height: 100px;
	margin: 15px 10px;
	font-family: 'Futura Bold';
	font-size: 48px;
	border: 7px solid #fff;
	border-radius: 50px;
}
.feature-num p {
	text-align: center;
}
.feature-content {
	float: left;
	width: calc(100% - 120px);
	height: 148px;
	padding: 10px 60px 10px 20px;
	background-image: url(https://southshorepaving.com/wp-content/uploads/2018/02/bg-feature-list1.png);
	background-repeat: no-repeat;
	color: #fff;
}
.feature-list:nth-child(2n) .feature-content {
	background-image: url(https://southshorepaving.com/wp-content/uploads/2018/02/bg-feature-list2.png);
}
.feature-content h3 {
	margin-bottom: 10px;
}
.feature-content p {
	font-size: 14px;
}

.title-wrapper {
	margin: 20px 0;
	padding: 30px 15px;
	color: var(--color-primary);
}
.title-large {
	max-width: 1170px;
	margin: 0 auto 10px;
	font-family: 'Futura Medium';
	font-size: 48px;
	font-weight: 400;
}
.title-large .font-bold {
	font-family: 'Futura Bold';
}
.title-large .bottom-border {
	position: relative;
}
.title-large .bottom-border:before {
	content: "";
	position: absolute;
	width: 125%;
	max-width: 90vw;
	height: 8px;
	bottom: -10px;
	background-image: url(https://southshorepaving.com/wp-content/uploads/2018/02/bottom-border.png);
}
.title-small {
	max-width: 1170px;
	margin: 0 auto;
	font-family: 'Futura Medium';
	font-size: 32px;
	font-weight: 400;
}

.custom-services-outer-wrapper {
	max-width: 100% !important;
}
.service-item {
	float: left;
	position: relative;
	margin-bottom: 10px;
	padding: 10px;
	height: 400px;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}
.service-item:before {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	transition: .2s;
}
.service-item:hover:before {
	background-color: rgba(0, 91, 127, .7);
}
.col6 {
	width: calc(50% - 5px);
}
.col4 {
	width: calc(33.33% - 7px);
}
.mrg-left-10 {
	margin-left: 10px;
}
.service-inner {
	position: relative;
	width: 100%;
	height: 100%;
	border: 3px solid #fff;
}
.service-item:hover .service-inner {
	border-color: transparent;
}
.service-title {
	position: absolute;
	width: 100%;
	top: 50%;
	transform: translateY(-50%);
	color: #fff;
	font-size: 36px;
	text-align: center;
}
.service-title i {
	color: var(--color-secondary);
}
.service-item:hover .service-title i {
	color: #fff;
}
.service-button {
	position: absolute;
	width: 100%;
	bottom: 40px;
	font-size: 18px;
	text-align: center;
}
.service-button a {
	padding: 20px 40px;
	color: #fff;
	background-color: #005b7f;
	border: 1px solid #fff;
	text-decoration: none;
}
.service-item:hover .service-button a {
	background-color: transparent;
}

.custom-video-background-wrapper {
	position: relative;
	padding: 40px 0;
	height: 41.67vw;
	background-image: url(https://southshorepaving.com/wp-content/uploads/2022/07/bg-service1-22.jpg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}
.custom-video-background-wrapper:before {
	content: "";
	position: absolute;
	width: 41%;
	height: 100%;
	top: 0;
	background-color: rgba(0, 0, 0, .4);
}
.video-wrapper {
	position: absolute;
	top: 11.4%;
	left: 49%;
	width: 41.8%;
	height: 61.7%;
}
.video-frame {
	display: none;
	width: 100%;
	height: 100%;
	position: relative;
}
.video-frame video {
	width: 100%;
	height: 100% !important;
	object-fit: cover;
	object-position: center;
}
.video-frame .fluid-width-video-container {
	width: 100%;
	height: 100%;
	max-width: 100% !important;
	max-height: 100% !important;
}
.video-frame .fluid-width-video-wrapper {
	height: 100%;
}
.video-button-wrapper {
	position: absolute;
	width: 100%;
	top: 50%;
	transform: translateY(-50%);
}
.video-button-wrapper h3 {
	font-size: 36px;
	text-align: center;
}
.video-button-wrapper img {
	display: block;
	margin: 40px auto 30px;
	width: 100px;
	cursor: pointer;
}
.video-button-wrapper p {
	font-size: 36px;
	font-style: italic;
	line-height: 1;
	text-align: center;
}

.custom-value-outer-wrapper {
	max-width: 100% !important;
}
.value-wrapper {
	position: relative;
	height: 494px;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}
.value-wrapper:not(:last-child) {
	margin-bottom: 20px;
}
.value-wrapper:before {
	content: "";
	position: absolute;
	width: 50%;
	height: 100%;
	background-image: url(https://southshorepaving.com/wp-content/uploads/2018/02/bg-value-overlay1.png);
	background-position: right;
	background-repeat: no-repeat;
}
.value-wrapper:nth-child(2n):before {
	width: calc(50% + 140px);
	right: 0;
	background-image: url(https://southshorepaving.com/wp-content/uploads/2018/02/bg-value-overlay2.png);
	background-position: left;
}
.value-content {
	position: absolute;
	margin-top: 40px;
	padding-right: 60px;
	right: 50%;
	width: 50%;
	max-width: 585px;
	color: #fff;
}
.value-wrapper:nth-child(2n) .value-content {
	left: calc(50% - 40px);
	right: auto;
}
.value-title h2 {
	display: inline-block;
	margin-bottom: 20px;
	font-size: 36px;
	border-bottom: 1px solid #fff;
}
.value-title h2:before {
	content: "\f005";
	margin-right: 10px;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
}

.custom-testimonial-background-wrapper {
	position: relative;
	margin: 20px 0;
	padding: 80px 0;
	height: 400px;
	background-image: url(https://southshorepaving.com/wp-content/uploads/2018/02/bg-testimonial.jpg);
	background-position: bottom;
	background-repeat: no-repeat;
	background-size: cover;
}
.custom-testimonial-background-wrapper:before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: calc(50% - 100px);
	height: 100%;
	background-image: url(https://southshorepaving.com/wp-content/uploads/2018/02/bg-testimonial-overlay.png);
	background-repeat: no-repeat;
}
.review-content {
	float: left;
	width: calc(50% + 100px);
	font-size: 24px;
	line-height: 2;
	color: #fff;
}
.review-meta {
	float: right;
	width: calc(50% - 200px);
	text-align: center;
	color: #fff;
}
.review-reviewer {
	margin-top: 60px;
	margin-bottom: 10px;
	font-size: 72px;
	line-height: 1.2;
	border-bottom: 2px solid #000;
}
.reviewer-info {
	font-size: 30px;
}
@media (max-width: 767px) {
	.review-reviewer {
		font-size: 36px;
	}
	.reviewer-info {
		font-size: 20px;
	}
}

.custom-map-outer-wrapper {
	max-width: 100% !important;
}
.custom-map iframe {
	display: block;
	width: 100%;
}

.custom-footer-background-wrapper {
	position: relative;
	padding: 20px 0 100px;
	background-image: url(https://southshorepaving.com/wp-content/uploads/2018/02/bg-footer.jpg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}
.custom-footer-background-wrapper:before {
	content: "";
	position: absolute;
	top: 0;
	width: 50%;
	height: 100%;
	background-color: rgba(0, 0, 0, .6);
}
.footer-about {
	position: relative;
	padding-right: 40px;
}
.footer-logo {
	text-align: center;
}
.footer-address {
	margin-top: 20px;
}
.footer-address-icon {
	float: left;
	width: 100px;
	height: 100px;
	font-size: 48px;
	line-height: 100px;
	text-align: center;
	background-color: #1D6EB6;
	border: 1px solid #fff;
	border-radius: 50px;
}
.footer-address-text {
	float: left;
	margin-top: 15px;
	margin-left: 20px;
	line-height: 2;
}
.footer-address-text.phone {
	font-size: 30px;
}
.footer-contact {
	position: relative;
	padding-left: 40px;
	text-align: center;
}
.footer-contact .title-large .bottom-border:before {
	left: -12.5%;
}
.footer-contact h3 {
	font-size: 32px;
}
@media (max-width: 1024px) {
	.custom-footer-background-wrapper {
		background-image: none;
		background-color: #000;
	}
}

.custom-subfooter-background-wrapper {
	padding: 20px 0;
	background-color: #000;
	border-top: 1px solid #464646;
}
.text-copy {
	font-size: 12px;
	line-height: 3;
	color: #fff;
}
.footer-social {
	text-align: right;
}
.footer-social a {
	margin-left: 10px;
	font-size: 24px;
	color: var(--color-seoncdary);
}

@media (min-width: 1170px) {
	#builder-layout-5358add06a772 .entry-content {
		max-width: 686px;
	}
	#builder-layout-5358add06a772 .builder-module-content-last-background-wrapper {
		position: relative;
		margin-top: 20px;
	}
	#builder-layout-5358add06a772 .builder-module-content-last-background-wrapper:before {
		content: "";
		position: absolute;
		top: 0;
		left: calc(50% + 150px);
		width: calc(50% - 150px);
		height: 100%;
		background-image: url(https://southshorepaving.com/wp-content/uploads/2018/02/img-contact-page.jpg);
		background-repeat: no-repeat;
		background-size: auto 100%;
	}
}
/********
.builder-module-content .entry-header {
display: none;
}
********/
.builder-module-content .widget-wrapper {
	background-color: #146db9;
	padding: 20px;
}

.custom-page-header-background-wrapper {
	background-color: rgba(0, 0, 0, .7);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
.custom-page-header {
	padding: 80px 0;
}
.custom-page-header .entry-title {
	margin: 0;
	font-size: 48px;
	line-height: 1;
	text-transform: uppercase;
	color: #fff;
}
@media (max-width: 500px) {
	.custom-page-header {
		padding: 20px 0;
	}
	.custom-page-header .entry-title {
		font-size: 24px;
		line-height: 1.2;
		text-align: center;
	}
}
.custom-page-header .entry-subtitle {
	margin: 0;
	font-size: 28px;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
	color: #fff;
}
.page-template-default .loop-content .entry-header {
	display: none;
}
.page-template-default .loop-content .entry-content p {
	font-size: 18px;
}

.sticky .top-header {
	font-size: 24px;
}
.sticky .header-logo img {
	height: 60px !important;
}
.sticky .header-phone {
	font-size: 30px;
	line-height: 60px;
}
@media (min-width: 1025px) {
	.sticky .custom-topheader-background-wrapper {
		position: fixed;
		top: 0;
		width: 100%;
	}
	.sticky .custom-header-background-wrapper {
		position: fixed;
		padding: 10px 0;
		top: 34px;
		width: 100%;
	}
	.sticky .custom-mobile-menu-background-wrapper {
		position: fixed;
		top: 121px;
		width: 100%;
	}
	.home:not(.sticky) .custom-topheader-background-wrapper,
	.home:not(.sticky) .custom-header-background-wrapper,
	.home:not(.sticky) .custom-mobile-menu-background-wrapper {
		position: absolute;
		top: 0;
		width: 100%;
		background-color: transparent;
	}
	.home:not(.sticky) .custom-header-background-wrapper {
		top: 10px;
	}
	.home:not(.sticky) .header-logo {
		display: none;
	}
	.home:not(.sticky) .header-phone {
		color: #fff;
	}
	.home:not(.sticky) .custom-mobile-menu-background-wrapper{
		top: 100px;
	}
	.home:not(.sticky) .custom-mobile-menu .menu {
		margin-right: -10px;
	}
}

.mobile-menu-open {
	overflow: hidden;
}
.mobile-menu-open .builder-container:after {
	content: "";
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 0;
	background-color: rgba(255,255,255,.8);
	z-index: 3;
}

#it-mobile-phone,
#it-mobile-menu-close {
	display: none;
}
@media (max-width: 1170px) {
	.builder-module-widget-bar-background-wrapper.builder-module-after-widget-bar-background-wrapper,
	.builder-module-widget-bar-background-wrapper.builder-module-middle-background-wrapper {
		padding-left: 0;
		padding-right: 0;
	}

	.about-wrapper {
		padding: 0 20px;
	}

	.custom-feature#builder-module-5a8e19176becc .builder-module-column-1-outer-wrapper,
	.custom-feature#builder-module-5a8e19176becc .builder-module-column-2-outer-wrapper {
		float: none !important;
		width: 100%;
		margin: 0 auto;
	}
	.custom-feature#builder-module-5a8e19176becc .builder-module-column-1-outer-wrapper {
		padding: 40px 20px 60px;
		background-color: #000;
	}
	.custom-feature-background-wrapper:before {
		display: none;
	}
	.feature-list {
		max-width: 585px;
		margin: 0 auto;
	}
}
.visible-phone {
	display: none;
}
@media (max-width: 1024px) {
	.visible-phone {
		display: block;
	}

	.custom-header#builder-module-5244708dea1f3 .builder-module-column-1-outer-wrapper,
	.custom-header#builder-module-52449ac680e79 .builder-module-column-1-outer-wrapper,
	.custom-header#builder-module-5358add06a828 .builder-module-column-1-outer-wrapper {
		width: 100%;
		margin: 0 auto;
	}
	.custom-header#builder-module-5244708dea1f3 .builder-module-column-2-outer-wrapper,
	.custom-header#builder-module-52449ac680e79 .builder-module-column-2-outer-wrapper,
	.custom-header#builder-module-5358add06a828 .builder-module-column-2-outer-wrapper {
		display: none;
	}
	.header-logo {
		text-align: center;
	}

	.mobile-menu-open .custom-mobile-menu-background-wrapper {
		background-color: transparent;
		z-index: 4;
		transition: unset;
	}
	.builder-module-navigation #it-mobile-menu {
		background: transparent;
		border-radius: 0;
		color: #fff;
		display: inline-block;
		font-size: 72px;
		font-weight: bold;
		line-height: 1.2;
		padding: 0;
	}
	.builder-module-navigation #it-mobile-menu i {
		padding-right: 10px;
		border-right: 1px solid #fff;
	}
	.builder-module-navigation #it-mobile-phone {
		float: right;
		display: inline-block;
		font-size: 60px;
		font-weight: bold;
		line-height: 80px;
		color: #fff;
	}
	.builder-module-navigation #it-mobile-phone a {
		color: inherit;
		text-decoration: none;
	}
	.builder-module-navigation .menu.hidden {
		display: none;
		position: fixed;
		top: 0;
		left: 0;
		margin-top: 0;
		width: 0;
		height: 100vh;
		background-color: #1367b0;
		transition: .3s all;
	}
	.mobile-menu-open .builder-module-navigation .menu.hidden {
		width: 75%;
	}
	.mobile-menu-open #it-mobile-phone {
		display: none;
	}
	.mobile-menu-open #it-mobile-menu-close {
		display: block;
		position: fixed;
		top: 10px;
		right: 10px;
		width: 40px;
		font-size: 40px;
		line-height: 1;
		text-align: center;
		color: #000;
		border: 1px solid #000;
		cursor: pointer;
		z-index: 9;
	}
	.builder-module-navigation.mobile li a {
		color: #fff;
	}
	.builder-module-navigation.mobile li ul {
		background-color: transparent;
	}

	.feature-title-wrapper {
		text-align: center;
	}

	.title-wrapper {
		text-align: center;
	}
	.title-large .bottom-border:before {
		left: -12.5%;
	}

	.custom-about-background-wrapper:before {
		display: none;
	}
	.about-wrapper {
		width: 100%;
		padding: 0 20px;
	}

	.custom-video-background-wrapper {
		height: 70vw;
		background-position: right;
	}
	.custom-video-background-wrapper:before {
		display: none;
	}
	.video-wrapper {
		left: 14.2%;
		width: 70%;
	}

	.value-wrapper {
		height: auto;
		padding: 60px 0;
		background-image: none !important;
		background-color: #000;
	}
	.value-wrapper:before,
	.value-wrapper:nth-child(2n):before {
		background-image: none;
		background-color: rgba(0,0,0,.7);
		width: 100%;
		top: 0;
	}
	.value-content,
	.value-wrapper:nth-child(2n) .value-content {
		position: relative;
		width: 100%;
		max-width: 100%;
		left: auto;
		right: auto;
		padding: 0 20px;
		margin-bottom: 40px;
	}

	.reviews-background-wrapper {
		padding: 0 20px;
	}

	.custom-testimonial-background-wrapper {
		height: auto;
		background-image: none;
		background-color: #000;
	}
	.custom-testimonial-background-wrapper:before {
		display: none;
	}
	.review-content {
		float: none;
		width: 100%;
	}
	.review-meta {
		float: none;
		width: 100%;
	}

	.footer-about {
		padding-left: 20px;
	}
	.footer-contact {
		padding-right: 20px;
	}

	.text-copy {
		padding-left: 20px;
	}
	.footer-social {
		padding-right: 20px;
	}
}
@media (max-width: 640px) {
	.builder-module-navigation #it-mobile-menu {
		font-size: 48px;
	}
	.builder-module-navigation #it-mobile-phone {
		font-size: 24px;
		line-height: 60px;
	}

	.custom-feature-background-wrapper {
		padding: 0;
	}
	.title-large {
		font-size: 24px;
	}
	.feature-title-wrapper p {
		font-size: 18px;
	}
	.feature-num {
		display: none;
	}
	.feature-content {
		float: none;
		width: 100%;
		padding-left: 20px;
		background-image: none;
		background-color: #000;
	}
	.feature-list:nth-child(2n) .feature-content {
		background-image: none;
		background-color: #146db9;
	}

	.col6, .col4 {
		width: 100%;
	}
	.mrg-left-10 {
		margin-left: 0;
	}
	.service-item {
		height: 300px;
	}
	.service-title {
		font-size: 24px;
	}
	.service-button a {
		padding: 10px 30px;
	}

	.video-button-wrapper h3 {
		font-size: 24px;
	}
	.video-button-wrapper img {
		margin: 20px auto 10px;
		width: 60px;
	}
	.video-button-wrapper p {
		font-size: 18px;
	}

	.custom-footer-background-wrapper:before {
		width: 100%;
	}
	.custom-footer#builder-module-5244708dea33e .builder-module-column-1-outer-wrapper,
	.custom-footer#builder-module-5244708dea33e .builder-module-column-2-outer-wrapper,
	.custom-footer#builder-module-52449ac6811f3 .builder-module-column-1-outer-wrapper,
	.custom-footer#builder-module-52449ac6811f3 .builder-module-column-2-outer-wrapper,
	.custom-footer#builder-module-5358add06ab60 .builder-module-column-1-outer-wrapper,
	.custom-footer#builder-module-5358add06ab60 .builder-module-column-2-outer-wrapper {
		float: none !important;
		width: 100%;
		margin: 0 auto;
	}
	.footer-about, .footer-contact {
		padding: 0 20px;
	}

	.footer-address-icon {
		width: 60px;
		height: 60px;
		font-size: 24px;
		line-height: 60px;
	}
	.footer-address-text {
		margin-top: 0;
	}
	.text-copy,
	.footer-social {
		padding: 0;
		text-align: center;
	}
}

.flexslider .slides > li {
	position: static !important;
}

.org-info ul {
	list-style: none;
	margin-left: 0;
}

.custom-slider-background-wrapper {
	background-image: url(https://southshorepaving.com/wp-content/uploads/2018/02/bg-home.jpg);
	background-size: cover;
	background-position: center;
}
.banner-wrap {
	max-width: 100%;
	width: 800px;
	height: 900px;
	padding-left: 15px;
	padding-right: 15px;
	padding-top: 200px;
}
.banner-service-wrap {
	margin-top: 20px;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
}
.banner-badge,
.banner-service {
	text-align: center;
}
.banner-service-title {
	color: #fff;
	font-size: 24px;
	font-weight: 700;
}
.banner-service-link a {
	margin-top: 20px;
	display: inline-block;
	background-color: var(--color-secondary);
	color: #fff;
	text-transform: uppercase;
	text-decoration: none;
	font-size: 14px;
	padding: 5px 25px;
}
@media (max-width: 1024px) {
	.banner-wrap {
		height: auto;
		padding-top: 100px;
		padding-bottom: 100px;
	}
	.banner-service-wrap {
		display: none;
	}
}