/*
Theme Name: Divi Child
Theme URI: https://www.elegantthemes.com/gallery/divi/
Description: Divi child theme via FreshySites
Author: FreshySites
Author URI: https://freshysites.com/
Template: Divi
Version: 3.0.1
*/
/* Add your own styles at the bottom */

/* -- COLORS -- */

.white,
.white h1,
.white h2,
.white h3,
.white h4,
.white h5,
.white h6,
.white li,
.white a,
h1.white,
h2.white,
h3.white,
h4.white,
h5.white,
h6.white,
li.white,
a.white,
p.white {
	color: #fff;
}

.black,
.black h1,
.black h2,
.black h3,
.black h4,
.black h5,
.black h6,
.black li,
.black a,
h1.black,
h2.black,
h3.black,
h4.black,
h5.black,
h6.black,
li.black,
a.black,
p.black {
	color: #000;
}

.primary,
.primary h1,
.primary h2,
.primary h3,
.primary h4,
.primary h5,
.primary h6,
.primary li,
.primary a,
h1.primary,
h2.primary,
h3.primary,
h4.primary,
h5.primary,
h6.primary,
li.primary,
a.primary,
p.primary {
	color: #32a709;
}

.secondary,
.secondary h1,
.secondary h2,
.secondary h3,
.secondary h4,
.secondary h5,
.secondary h6,
.secondary li,
.secondary a,
h1.secondary,
h2.secondary,
h3.secondary,
h4.secondary,
h5.secondary,
h6.secondary,
li.secondary,
a.secondary,
p.secondary {
	color: #daf238;
}

.tertiary,
.tertiary h1,
.tertiary h2,
.tertiary h3,
.tertiary h4,
.tertiary h5,
.tertiary h6,
.tertiary li,
.tertiary a,
h1.tertiary,
h2.tertiary,
h3.tertiary,
h4.tertiary,
h5.tertiary,
h6.tertiary,
li.tertiary,
a.tertiary,
p.tertiary {
	color: #e4debe;
}

/* background colors */
.bg-white,
a.bg-white {
	background-color: #fff;
}

.bg-black,
a.bg-black {
	background-color: #000;
}

.bg-primary,
a.bg-primary {
	background-color: #32a709;
}

.bg-secondary,
a.bg-secondary {
	background-color: #daf238;
}

.bg-tertiary,
a.bg-tertiary {
	background-color: #e4debe;
}

/* -- END COLORS -- */

/* -- TYPOGRAPHY -- */

.text-lowercase,
.text-lowercase h1,
.text-lowercase h2,
.text-lowercase h3,
.text-lowercase h4,
.text-lowercase h5,
.text-lowercase h6,
.text-lowercase li,
.text-lowercase a {
	text-transform: lowercase !important;
}

.text-uppercase,
.text-uppercase h1,
.text-uppercase h2,
.text-uppercase h3,
.text-uppercase h4,
.text-uppercase h5,
.text-uppercase h6,
.text-uppercase li,
.text-uppercase a {
	text-transform: uppercase !important;
}

.text-capitalize,
.text-capitalize h1,
.text-capitalize h2,
.text-capitalize h3,
.text-capitalize h4,
.text-capitalize h5,
.text-capitalize h6,
.text-capitalize li,
.text-capitalize a {
	text-transform: capitalize !important;
}

.text-transform-none,
.text-transform-none h1,
.text-transform-none h2,
.text-transform-none h3,
.text-transform-none h4,
.text-transform-none h5,
.text-transform-none h6,
.text-transform-none li,
.text-transform-none a {
	text-transform: none !important;
}

.font-weight-bold,
.font-weight-bold h1,
.font-weight-bold h2,
.font-weight-bold h3,
.font-weight-bold h4,
.font-weight-bold h5,
.font-weight-bold h6,
.font-weight-bold li,
.font-weight-bold a {
	font-weight: 700;
}

.font-weight-normal,
.font-weight-normal h1,
.font-weight-normal h2,
.font-weight-normal h3,
.font-weight-normal h4,
.font-weight-normal h5,
.font-weight-normal h6,
.font-weight-normal li,
.font-weight-normal a {
	font-weight: 400;
}

.font-italic {
	font-style: italic;
}

.text-underline-none,
.text-underline-none a {
	text-decoration: none !important;
}

.text-underline,
.text-underline a {
	text-decoration: underline !important;
}

.text-nowrap,
.text-nowrap a {
	white-space: nowrap !important;
}

.text-wrap-normal,
.text-wrap-normal a {
	white-space: normal !important;
}

/* -- END TYPOGRAPHY -- */

/* -- TEMPLATE -- */

/* -- END TEMPLATE -- */

/* -- HEADER -- */

/* helps logo to not be pixelated when scaled down */
#logo {
	transform: none !important;
}

/* when mobile menu is open, change hamburger icon to x icon */
#et_mobile_nav_menu .mobile_nav.opened .mobile_menu_bar::before {
	content: "\4d";
}

/* makes sub sub menu icon be right arrow instead of down arrow */
#top-menu .menu-item-has-children .menu-item-has-children>a:first-child::after,
#et-secondary-nav .menu-item-has-children .menu-item-has-children>a:first-child::after {
	content: "5";
}

/* if parent link of child menu is a deadlink, then make it not clickable */
#main-header #mobile_menu.et_mobile_menu .menu-item-has-children>a[href="#0"] {
	pointer-events: none;
}

/* - mobile menu toggling elements, injected via jQuery - */

/* make menu list item be relative, to be able to position toggle within this item */
#main-header #mobile_menu.et_mobile_menu .menu-item-has-children {
	position: relative;
}

/* the new toggle element, which is added via jQuery */
#main-header #mobile_menu.et_mobile_menu .sub-menu-toggle {
	position: absolute;
	background-color: rgba(0, 0, 0, 0.03);
	z-index: 1;
	width: 36px;
	height: 36px;
	line-height: 36px;
	border-radius: 50%;
	top: 4px;
	right: 4px;
	cursor: pointer;
	text-align: center;
}

/* the new toggle element when popped */
#main-header #mobile_menu.et_mobile_menu .sub-menu-toggle.popped {
	background-color: rgba(0, 0, 0, 0.1);
}

/* toggle icon */
#main-header #mobile_menu.et_mobile_menu .sub-menu-toggle::before {
	font-family: "ETmodules" !important;
	font-weight: normal;
	font-style: normal;
	font-variant: normal;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	line-height: 36px;
	font-size: 24px;
	text-transform: none;
	speak: none;
	content: "\33";
}

/* toggle icon when triggered */
#main-header #mobile_menu.et_mobile_menu .sub-menu-toggle.popped::before {
	content: "\32";
}

/* hide sub menus by default */
#main-header #mobile_menu.et_mobile_menu .sub-menu-toggle~ul.sub-menu {
	display: none !important;
	padding-left: 0;
}

/* show sub menu when triggered via jQuery toggle, and add slight bg color */
#main-header #mobile_menu.et_mobile_menu .sub-menu-toggle.popped~ul.sub-menu {
	display: block !important;
	background-color: rgba(0, 0, 0, 0.03);
}

/* remove sub menu list item left padding, since padding will be on anchors */
#main-header #mobile_menu.et_mobile_menu li li {
	padding-left: 0;
}

/* adjust mobile menu anchors side paddings */
#main-header #mobile_menu.et_mobile_menu li a {
	padding-left: 20px;
	padding-right: 20px;
}

/* indent sub menu */
#main-header #mobile_menu.et_mobile_menu li li a {
	padding-left: 40px;
	padding-right: 20px;
}

/* indent sub sub menus further */
#main-header #mobile_menu.et_mobile_menu li li li a {
	padding-left: 60px;
	padding-right: 20px;
}

/* if mobile menu anchor has toggle, make room for it to fit next to the link */
#main-header #mobile_menu.et_mobile_menu .menu-item-has-children .sub-menu-toggle+a {
	padding-right: 44px;
}

/* - end mobile menu toggling elements - */

/* undo Divi's default styling of mobile menu links that have children */
#main-header #mobile_menu.et_mobile_menu .menu-item-has-children>a {
	background-color: transparent;
	font-weight: inherit;
}

/* make the current page's mobile menu link be different */
#main-header #mobile_menu.et_mobile_menu li.current-menu-item>a {
	font-weight: bolder;
}

/* -- END HEADER -- */

/* -- FOOTER -- */

/* - Bottom Bar - */

/* if the bottom bar has equal column height setting, then make it always be flex, and stack the columns initially (for mobile use)
 * and make the columns vertical aligned to be vertically centered too */
#fs-footer-bottom-bar>.et_pb_row.et_pb_equal_columns {
	display: flex;
	align-items: center;
}

/* copyright wrapper */
#freshy_copyright {
	display: flex;
	flex-direction: column;
	align-items: center;
	color: white;
	font-size: 13px;
	line-height: 1.25em;
}

/* vertical pipe divider */
#freshy_copyright span.copyright_via {
	width: 33.33333%;
	height: 1px;
	overflow: hidden;
	white-space: nowrap;
	text-indent: 200%;
	background: rgba(255, 255, 255, 0.25);
	vertical-align: middle;
	margin: 10px auto 15px;
	display: block;
}

/* add an FS logo via background */
#freshy_copyright a.copyright_fs {
	display: block;
	width: 42px;
	height: 20px;
	background-image: url("/wp-content/uploads/fs-lettermark-white.svg");
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	text-indent: 200%;
	white-space: nowrap;
	overflow: hidden;
	margin: 0;
	flex-shrink: 0;
	transition: all 0.4s ease-in-out;
}

/* FS logo link hover */
#freshy_copyright a.copyright_fs:hover {
	opacity: 0.8;
}

/* remove the bottom margin that Divi adds to the social media follow icons */
#fs-footer-bottom-bar .et_pb_social_media_follow li {
	margin-bottom: 0;
}

@media (min-width: 600px) {

	/* make the copyright elements be side by side at wider screens */
	#freshy_copyright {
		flex-direction: row;
	}

	/* change horizontal pipe divider to vertical on wider screens */
	#freshy_copyright span.copyright_via {
		width: 1px;
		height: 20px;
		margin: 0 10px;
	}
}

@media (max-width: 980px) {

	/* make sure the row has columns going side by side instead of stacked */
	#fs-footer-bottom-bar>.et_pb_row.et_pb_equal_columns {
		flex-direction: column;
	}

	/* when stacked, adjust the gap between stacked columns */
	#fs-footer-bottom-bar>.et_pb_row.et_pb_equal_columns>.et_pb_column {
		margin-bottom: 1rem;
	}

	/* swap the order of columns when stacked, to the first column is the last one 
	 * and give no bottom margin to the first column, since we re-ordered it to the bottom */
	#fs-footer-bottom-bar>.et_pb_row.et_pb_equal_columns>.et_pb_column:first-child {
		order: 1;
		margin-bottom: 0;
	}

	/* center the copyright stuff when columns are stacked */
	#freshy_copyright {
		justify-content: center;
	}

	/* remove left margin on first social icon in regular Divi footer (when not using Theme Builder) when stacked */
	#footer-bottom .et-social-icons li:first-child {
		margin-left: 0;
	}
}

/* -- END FOOTER -- */

/* -- RESPONSIVE -- */

/* do for mobile */
@media screen and (max-width: 767px) {

	/* hide on mobile */
	.hide-mobile {
		display: none;
	}
}

/* do for desktop */
@media screen and (min-width: 768px) {

	/* hide on desktop */
	.hide-desktop {
		display: none;
	}
}

/* -- END RESPONSIVE -- */

/* -- CHECKLIST -- */

.checklist ul {
	margin: 0;
	padding: 0 !important;
	list-style: none;
}

.checklist ul li {
	position: relative;
	padding-left: 30px;
	margin: 0 0 6px !important;
}

.checklist-columns-2 ul li,
.checklist-columns-3 ul li,
.checklist-columns-4 ul li {
	margin-bottom: 30px !important;
}

@media (max-width: 638px) {

	.checklist-columns-2 ul li,
	.checklist-columns-3 ul li,
	.checklist-columns-4 ul li {
		margin-bottom: 20px !important;
	}

	.checklist-columns-2 ul li:last-child,
	.checklist-columns-3 ul li:last-child,
	.checklist-columns-4 ul li:last-child {
		margin-bottom: 0 !important;
	}
}

/* create columns of list items with this class */
@media (min-width: 639px) {

	.checklist-columns-2 ul::after,
	.checklist-columns-3 ul::after,
	.checklist-columns-4 ul::after {
		content: "";
		clear: both;
		display: table;
	}

	.checklist-columns-2 ul li,
	.checklist-columns-3 ul li,
	.checklist-columns-4 ul li {
		float: left;
		width: 50%;
		padding-right: 30px;
	}

	.checklist-columns-2 ul li:nth-child(odd),
	.checklist-columns-3 ul li:nth-child(odd),
	.checklist-columns-4 ul li:nth-child(odd) {
		clear: both;
	}

	.checklist-columns-2-alt>ul,
	.checklist-columns-3-alt>ul,
	.checklist-columns-4-alt>ul {
		column-count: 2;
		column-gap: 20px;
	}

	.checklist-columns-2-alt ul li,
	.checklist-columns-3-alt ul li,
	.checklist-columns-4-alt ul li {
		break-inside: avoid-column;
	}
}

@media (min-width: 981px) {

	.checklist-columns-3 ul li,
	.checklist-columns-4 ul li {
		float: left;
		width: 33.333333%;
	}

	.checklist-columns-3 ul li:nth-child(odd),
	.checklist-columns-4 ul li:nth-child(odd) {
		clear: none;
	}

	.checklist-columns-3 ul li:nth-child(3n + 1),
	.checklist-columns-4 ul li:nth-child(3n + 1) {
		clear: both;
	}

	.checklist-columns-3-alt ul,
	.checklist-columns-4-alt ul {
		column-count: 3;
	}
}

@media (min-width: 1199px) {
	.checklist-columns-4 ul li {
		float: left;
		width: 25%;
	}

	.checklist-columns-4 ul li:nth-child(odd) {
		clear: none;
	}

	.checklist-columns-4 ul li:nth-child(3n + 1) {
		clear: none;
	}

	.checklist-columns-4 ul li:nth-child(4n + 1) {
		clear: both;
	}

	.checklist-columns-4-alt ul {
		column-count: 4;
	}
}

.checklist ul li::before {
	font-family: "ETModules";
	content: "\4e";
	width: 20px;
	margin: 0;
	display: inline-block;
	text-align: center;
	position: absolute;
	top: 0;
	left: 0;
	color: #32a709;
	/* set font size helps make icon sharper */
	font-size: 22px;
	font-weight: normal;
}

.pluslist ul li::before {
	content: "\e050";
}

.externallist ul li::before {
	content: "\e906";
}

/* -- END CHECKLIST -- */

/* -- DIVI HACKS -- */

/* make parallax image be centered at the start */
.et_parallax_bg {
	background-position: center center;
}

/* Divi was turning off bottom padding on last paragraphs, when it should be only if it's the last child */
p:last-of-type,
p:not(.has-background):last-of-type {
	padding-bottom: 1em;
}

p:last-child,
p:not(.has-background):last-child {
	padding-bottom: 0;
}

/* if there are more than one paragraphin the Fullwidth Header module, they should have padding */
.et_pb_fullwidth_header p:not(:last-child) {
	padding-bottom: 1em;
}

/* -- END DIVI HACKS -- */

/* -- PASSWORD PROTECTED -- */

/* set a max width to make it only as wide as most content */
.post-password-required .et_password_protected_form {
	width: 80%;
	margin: 10% auto;
	max-width: 1140px;
}

/* give the input a border */
.post-password-required .et_password_protected_form p input {
	border: 1px solid !important;
}

/* remove the arrow on hover of the submit button */
.post-password-required .et_password_protected_form .et_submit_button::after {
	display: none;
}

/* -- END PASSWORD PROTECTED -- */

/* -- TESTIMONIALS PLUGIN -- */

/* flip quote so it's an opening quote icon for grid and slider versions */
.b3_archive_testimonials_grid article .b3_quote.grid_quote::before,
.et_pb_module.et_pb_testimonial_slider .et_pb_slides_testi::before {
	transform: scale(-1, -1);
}

/* -- END TESTIMONIALS PLUGIN -- */

/* -- GRAVITY FORMS -- */

/* confirmation (success) message */
.gform_confirmation_wrapper .gform_confirmation_message {
	font-size: 1.2rem;
	line-height: 1.5em;
	padding: 2rem;
	background: rgba(90, 90, 90, 0.1);
	text-align: center;
}

/* -- END GRAVITY FORMS -- */

/* -- HELPERS -- */

/* use the "fullwidth-section" class on a SECTION to make a "standard" SECTION truly be fullwidth 
(NOTE: the SECTION needs THIS class) */
.fullwidth-section.et_pb_section {
	padding: 0;
}

.fullwidth-section.et_pb_section>.et_pb_row {
	width: 100% !important;
	max-width: 100% !important;
	padding: 0;
}

/* use the "fullwidth-row" class on a SECTION to make a "full width" ROW truly be fullwidth 
(NOTE: the ROW module settings needs to be Gutter Width 1, and the SECTION needs THIS class,
and unlike the class above, THIS class will auto-add padding to the columns) */
.fullwidth-row.et_pb_section {
	padding: 0;
}

.fullwidth-row.et_pb_section .et_pb_row {
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
}

/* helps add padding to each column */
.fullwidth-row.et_pb_section .et_pb_row>.et_pb_column {
	padding: 50px 10%;
}

@media (min-width: 767px) {
	.fullwidth-row.et_pb_section .et_pb_row>.et_pb_column {
		padding: 80px 6%;
	}
}

/* for some reason Divi removes bottom margin from modules if in column with no gutters, 
so we need to add margins back */
.fullwidth-row.et_pb_section .et_pb_row.et_pb_gutters1>.et_pb_column .et_pb_module:not(:last-child) {
	margin-bottom: 30px;
}

@media (min-width: 981px) {
	.fullwidth-row.et_pb_section .et_pb_row.et_pb_gutters1>.et_pb_column_2_3 .et_pb_module:not(:last-child) {
		margin-bottom: 4.242%;
	}

	.fullwidth-row.et_pb_section .et_pb_row.et_pb_gutters1>.et_pb_column_1_3 .et_pb_module:not(:last-child) {
		margin-bottom: 9.27%;
	}
}

/* reduce gap between toggles if in fullwidth row */
.fullwidth-row.et_pb_section .et_pb_row.et_pb_gutters1>.et_pb_column .et_pb_module.et_pb_toggle:not(:last-child) {
	margin-bottom: 3px;
}

@media (max-width: 980px) {

	/* use the "stacked-flex" class on a ROW to make it be flexbox when stacked, to help with adjusting order of stacked columns */
	.stacked-flex {
		display: flex;
		flex-wrap: wrap;
	}

	/* add the desired class to COLUMNS to designate their order when stacked within a "stacked-flex" ROW */
	.stacked-order-negative-4 {
		order: -4;
	}

	.stacked-order-negative-3 {
		order: -3;
	}

	.stacked-order-negative-2 {
		order: -2;
	}

	.stacked-order-negative-1 {
		order: -1;
	}

	.stacked-order-1 {
		order: 1;
	}

	.stacked-order-2 {
		order: 2;
	}

	.stacked-order-3 {
		order: 3;
	}

	.stacked-order-4 {
		order: 4;
	}

	/* adds margin to former "last" column that otherwise wouldn't have it */
	.stacked-flex:last-child .et_pb_column:last-child {
		margin-bottom: 30px;
	}
}

/* -- END HELPERS -- */

/* -- BLOG -- */

/* sidebar recent posts */
.et_pb_widget.widget_recent_entries ul li {
	margin-bottom: 1em;
}

/* sidebar recent posts dates */
.et_pb_widget.widget_recent_entries ul li span.post-date {
	display: table;
	font-size: 0.85em;
}

/* -- END BLOG -- */

/*********** Custom CSS ************/

/* Global CSS */

.container {
	width: 90%;
}

.et_pb_row {
	width: 90%;
}

/* column align middle */
@media (min-width: 981px) {
	.center-align {
		display: flex;
		align-items: center;
	}

	.bottom-align {
		display: flex;
		align-items: flex-end;
	}
}

/* Column reverse on tab and mobile devices */
@media (max-width: 980px) {
	.column-reverse {
		display: flex;
		flex-direction: column-reverse;
	}

	.column-reverse .et_pb_column:first-child {
		margin-bottom: 0;
	}

	.column-reverse .et_pb_column:last-child {
		margin-bottom: 30px;
	}
}

@media (max-width: 479px) {
	.column-reverse .et_pb_column:last-child {
		margin-bottom: 30px !important;
	}
}

body {
	font-weight: 400;
}

@media all and (min-width: 981px) and (max-width: 1280px) {
	body #page-container .font_fix_resp h1 {
		font-size: 38px;
	}

	.font_fix_resp h2 {
		font-size: 34px;
	}

	body #page-container .font_fix_resp h3 {
		font-size: 30px;
	}

	.font-scnd-facility p {
		font-size: 24px;
	}

	body #page-container .font_fix_resp h3.et_pb_module_header {
		font-size: 28px;
	}

	body #page-container .get_resp h3 {
		font-size: 28px;
	}

	body #page-container .estimate_resp h3 {
		font-size: 32px;
	}

	.font_fix_resp .et_pb_text_inner {
		font-size: 18px;
	}

	body #page-container .font_fix_resp .et_pb_blurb_description p {
		font-size: 18px;
	}

	.blurb_we_are .et_pb_blurb_description {
		font-size: 16px;
	}

	.quote_text {
		font-size: 20px;
	}

	body .gform_wrapper input:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not([type="button"]):not([type="image"]):not([type="file"]),
	body .gform_wrapper textarea.textarea,
	body div.form_saved_message div.form_saved_message_emailform form input[type="text"] {
		font-size: 14px !important;
	}

	body .gform_wrapper .gform_footer input.button {
		font-size: 18px;
	}
}

.estimate_form_fix .gform_wrapper.gravity-theme #field_submit,
.estimate_form_fix .gform_wrapper.gravity-theme .gform_footer {
	justify-content: center;
}

@media all and (min-width: 981px) {
	.estimate_form_fix .gform_wrapper.gravity-theme .gfield_label {
		font-size: 18px;
	}
}

/*— Scroll to top fix —*/
.et_pb_scroll_top.et-pb-icon {
	background: #e9301c;
	border-radius: 0;
	padding: 25px 0;
}

/****** Header fix ******/

body #page-container #top-menu .menu_btn a {
	background: #e9301c;
	color: #fff !important;
	border-radius: 10px;
	font-size: 18px;
	line-height: 20px !important;
	height: 18px;
	padding-bottom: 30px !important;
	padding-top: 13px;
	padding-left: 20px;
	padding-right: 20px;
	font-weight: 700 !important;
	text-transform: uppercase;
}

#top-menu li a {
	font-weight: 500 !important;
}

#et-secondary-nav li {
	margin-right: 20px;
}

#top-header .container {
	margin-left: 0 !important;
	padding-right: 0px !important;
}

body #page-container #top-header {
	/*width: 284px;*/
	width: 550px;
	right: 7% !important;
	left: auto !important;
	border-radius: 0 0 10px 10px;
}

@media all and (min-width: 1481px) {
	#top-menu li {
		padding-right: 2.1vw;
	}
}

@media all and (min-width: 1281px) and (max-width: 1480px) {
	body #page-container #top-menu li a {
		font-size: 18px;
	}
}

@media all and (min-width: 981px) and (max-width: 1280px) {
	body #page-container #top-menu li a {
		font-size: 14px;
	}

	body #page-container #top-menu li {
		padding-right: 14px;
	}

	body #page-container #et-top-navigation {
		/*padding-left: 0px !important;*/
	}

	img#logo {
		max-height: 56%;
	}
}
/*@media all and (min-width: 1281px) {
    #et-top-navigation {
        background-color: rgba(255,255,255,0.6);
        padding-left: 30px !important;
        padding-right: 30px !important;
}
}
@media all and (min-width: 981px) and (max-width: 1280px) {
	#et-top-navigation {
        background-color: rgba(255,255,255,0.6);
        padding-left: 10px !important;
        padding-right: 10px !important;
}
}*/
#main-header {
    background-image: linear-gradient(-108deg,rgba(255,255,255,0.5) 70%,rgba(0,0,0,0.9) 70%);
}
/*Header icon*/

.icon-search input.et_pb_searchsubmit,
.widget_search input#searchsubmit {
	background: transparent;
	color: transparent;
	border: none;
	width: 55px;
	z-index: 2;
}

.icon-search .et_pb_searchform:before,
.widget_search::before {
	content: "\55";
	position: absolute;
	font-family: "ETModules";
	z-index: 1;
	right: 0;
	font-size: 20px;
	padding: 8px 20px;
}

.search_icon .fa-magnifying-glass:before,
.search_icon .fa-search:before {
	font-size: 12px;
	border: 2px solid #fff;
	padding: 4px;
	border-radius: 50%;
}

.asl_w_container {
	width: 100% !important;
}

/***** Footer fix  ****/

.hide-mobile-menu.et_pb_menu .et_pb_menu__menu,
.lwp-hide-mobile-menu.et_pb_fullwidth_menu .et_pb_menu__menu {
	display: flex !important;
}

.hide-mobile-menu .et_mobile_nav_menu {
	display: none;
}

.vert_menu .menu-item {
	width: 100%;
	display: block !important;
}

.bot_footer ul li a {
	font-weight: 500;
}

.bot_footer ul li:after {
	content: "";
	background: #e9301c;
	width: 1px;
	height: 14px;
	display: inline;
	position: absolute;
	right: 0;
}

.bot_footer ul li:last-child:after {
	display: none !important;
}

.bot_footer .et-menu>li {
	padding-left: 6px;
	padding-right: 8px;
}

body #page-container .vert_menu .et_pb_menu__wrap {
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: start;
}

@media all and (max-width: 980px) {
	body #page-container .bot_footer .et_pb_menu__wrap {
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
	}

	.menu_btn a {
		background: red;
		border-radius: 8px;
		padding-bottom: 9px !important;
	}
}

.footer_mail_blrb {}

@media all and (min-width: 981px) {
	.footer_row_fix .et_pb_column:nth-child(2) {
		width: 38%;
	}

	.footer_row_fix .et_pb_column:nth-child(3) {
		width: 17%;
		margin-right: 1%;
	}

	.footer_row_fix .et_pb_column:last-child {
		width: 11%;
	}
}

#top-menu .menu_btn a:hover {
	opacity: 1 !important;
	background: #a20f10 !important;
}

@media all and (min-width: 1281px) and (max-width: 1620px) {
	.footer_row_fix .et_pb_column:nth-child(2) {
		width: 34%;
	}

	.footer_row_fix .et_pb_column:nth-child(3) {
		width: 22%;
		margin-right: 1%;
	}
}

@media all and (min-width: 981px) and (max-width: 1280px) {
	.footer_row_fix .et_pb_column:nth-child(2) {
		width: 36%;
		margin-right: 3%;
	}

	.footer_row_fix .et_pb_column:nth-child(3) {
		width: 21%;
		margin-right: 1%;
	}

	.footer_row_fix .et_pb_column:last-child {
		width: 12%;
	}

	body #page-container .footer_btn_fix {
		font-size: 17px !important;
	}
}

/*Form fix*/

.estimate_form_fix .gform_heading {
	display: none;
}

body .gform_wrapper input:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not([type="button"]):not([type="image"]):not([type="file"]),
body .gform_wrapper textarea.textarea,
body div.form_saved_message div.form_saved_message_emailform form input[type="text"] {
	background-color: #fff;
	border: 1px solid #e0e0e0;
	font-size: 18px;
	border-radius: 5px;
	color: #afafaf;
	padding: 16px;
	line-height: initial;
	height: initial;
	font-style: italic;
}

.estimate_form_fix .gform_wrapper.gravity-theme .gfield textarea.small {
	height: 142px;
}

body .gform_wrapper #field_submit input,
body .gform_wrapper .gform_footer input.button,
body .gform_wrapper .gform_page_footer input.button,
body div.form_saved_message div.form_saved_message_emailform form input[type="submit"] {
	padding: 0.4vw 3.3vw;
	text-transform: uppercase;
}

@media all and (min-width: 1281px) {

	body .gform_wrapper #field_submit input,
	body .gform_wrapper .gform_footer input.button,
	body .gform_wrapper .gform_page_footer input.button,
	body div.form_saved_message div.form_saved_message_emailform form input[type="submit"] {
		font-size: 24px;
	}
}

@media all and (max-width: 980px) {

	body .gform_wrapper input:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not([type="button"]):not([type="image"]):not([type="file"]),
	body .gform_wrapper textarea.textarea,
	body div.form_saved_message div.form_saved_message_emailform form input[type="text"] {
		font-size: 16px;
	}
}

@media all and (max-width: 767px) {

	body .gform_wrapper #field_submit input,
	body .gform_wrapper .gform_footer input.button,
	body .gform_wrapper .gform_page_footer input.button,
	body div.form_saved_message div.form_saved_message_emailform form input[type="submit"] {
		width: 100%;
	}
}

/* .gform_wrapper.gravity-theme #field_submit,
.gform_wrapper.gravity-theme .gform_footer {
    justify-content: left;
} */

.estimate_form_fix .gform_footer.top_label {
	padding: 1em 0 2em 0 !important;
}

/*** Home page****/

.home_banner_fix .et_pb_slide_description {
	max-width: 560px;
	margin-left: 0 !important;
}

body #page-container .home_banner_fix .et_pb_container {
	max-width: 1640px;
}

@media all and (min-width: 981px) {
	.home_banner_fix .et_pb_slide_content {
		max-width: 423px;
	}

	.home_banner_fix .et_pb_slide_content {
		font-size: 21px;
	}
}

@media all and (min-width: 981px) and (max-width: 1280px) {

	/* 	body #page-container .home_banner_fix .et_pb_slide{
    background-image: linear-gradient(72deg,rgba(0,0,0,0.9) 46%,rgba(255,255,255,0) 40%),url(/wp-content/uploads/home-banner-img.jpg);
} */
	.home_banner_fix .et_pb_slide_content {
		max-width: 330px;
		font-size: 20px;
	}

	body #page-container .home_banner_fix .et_pb_slide_title {
		font-size: 40px !important;
	}

	body #page-container .who_we_row .et_pb_column:nth-child(3) {
		margin-right: 0 !important;
	}

	body #page-container .who_we_row .et_pb_column:nth-child(4) {
		width: 24%;
	}

	body #page-container .estimate_form_fix {
		padding-right: 1vw !important;
		padding-left: 1vw !important;
	}
}

@media all and (min-width: 981px) and (max-width: 1600px) {
	.quote_section {
		padding-top: 5% !important;
	}
}

@media all and (max-width: 1366px) {
	.after_icon h2:after {
		transform: scale(0.5);
		margin-left: -5px !important;
	}
}

@media all and (max-width: 1280px) {
	.after_icon h2:after {
		margin-top: -3px !important;
	}
}

@media all and (max-width: 450px) {
	.after_icon h2:after {
		transform: scale(0.3);
		margin-left: -21px !important;
		margin-top: -7px !important;
	}
}

@media all and (min-width: 1981px) {
	body #page-container .after_icon h2 {
		font-size: 48px;
	}
}

.clr_chng {
	color: #e9301c;
	font-weight: 700;
}

.blurb_we_are .et_pb_main_blurb_image .et_pb_image_wrap img {
	margin-top: -14%;
}

@media all and (max-width: 980px) {
	body #page-container .quote_author {
		margin-bottom: -1.5em !important;
	}

	.blurb_we_are .et_pb_main_blurb_image .et_pb_image_wrap img {
		margin-top: -7%;
	}

	.blurb_we_are .et_pb_blurb_description {
		padding: 0 1.2em;
	}
}

@media all and (max-width: 767px) {
	body #page-container .quote_author {
		font-size: 19px;
	}

	body #page-container .quote_desig {
		font-size: 18px;
	}
}

.quote_author {
	font-size: 21px;
	color: #000;
	margin-bottom: -2.5em !important;
	display: block;
	margin-top: -5px;
}

.quote_desig {
	font-size: 21px;
}

.after_icon h2:after {
	content: url(/wp-content/uploads/icon-right.svg);
	display: inline;
	margin-left: 0.5em;
	position: absolute;
	margin-top: 3px;
}

/* @media all and (min-width: 981px){
	.m_pack_diff_row .et_pb_column:nth-child(1){
	width: 42.25%;
}

.m_pack_diff_row .et_pb_column:nth-child(2){
width: 52%	
}
} */

.home #top-menu li a {
	color: #000 !important;
}

.search #top-menu li a {
	color: #fff !important;
}

.locations_row .et_pb_column:last-child {}

.form_fix_style .gform_required_legend {
	display: none;
}

body .gform_wrapper input:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not([type="button"]):not([type="image"]):not([type="file"]),
body .gform_wrapper textarea.textarea,
body div.form_saved_message div.form_saved_message_emailform form input[type="text"] {
	border: 1px solid #adadad;
}

.form_fix_style .gform_wrapper.gravity-theme .gfield_label {
	margin-bottom: 0;
}

.form_fix_style .gform_wrapper.gravity-theme .gform_fields {
	grid-column-gap: 5%;
}

@media all and (min-width: 981px) and (max-width: 1280px) {
	body #page-container .inner_banner_style {
		background-image: linear-gradient(180deg,
				rgba(0, 0, 0, 0.8) 36%,
				rgba(0, 0, 0, 0) 36%),
			url(/wp-content/uploads/inner-banner-img.jpg) !important;
	}
}

/***Update 12-9-22 ****/

.mobile_nav.opened #mobile_menu {
	display: flex;
	flex-direction: column;
}

li.menu_btn {
	order: 6;
}

.menu_btn a:hover {
	background: #e8301c !important;
	opacity: 1 !important;
}

.location_info_fix .et_pb_blurb_description {
	font-weight: 500;
}

body #page-container .form_fix_style .gform_wrapper .ginput_container input {
	border-radius: 8px;
	padding: 10px;
}