/*
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 {
	-webkit-transform: none !important;
	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,  header .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,  header .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, header .et_mobile_menu .sub-menu-toggle{
	position: absolute;
	background-color: rgba(0,0,0,1);
	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, header .et_mobile_menu .sub-menu-toggle.popped {
	background-color: rgba(0,0,0,1);
}
/* toggle icon */
#main-header #mobile_menu.et_mobile_menu .sub-menu-toggle::before, header .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, header .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, header .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, header .et_mobile_menu .sub-menu-toggle.popped ~ ul.sub-menu  {
	display: block !important;
	background-color: rgba(0,0,0,0.1) !important;
}
/* 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, header .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: 86px;
	height: 20px;
	background-image: url("/wp-content/uploads/Freshy-AllWhite.png");
	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;
	}
}

body #page-container .checklist ul li::before {
	font-family: 'ETModules';
	content: '5';
	width: 20px;
	margin: 0;
	display: inline-block;
	text-align: center;
	position: absolute;
	top: 0;
	left: 0;
	color: #CD2415 !important;
	/* set font size helps make icon sharper */
	font-size: 22px;
	font-weight: 600;
}
.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 Start -------- */
/* -- Margin auto -- */
.m-auto {
	margin:auto;
}

/* -- Heading & Anchor text transform -- */
h1, h2, h3, h4, .et_pb_button {
	text-transform:capitalize;
}
/* -- headings & paragraph responsive from 1366 to 981 screen -- */
@media screen and (min-width:981px) and (max-width:1366px) {
	/* -- Section Heading h1 -- */
	.et_pb_text_inner h1 {
		font-size: 2.7rem!important;
	}
	/* -- Section Heading h2 -- */
	.et_pb_text_inner h2 {
		font-size: 2.4rem!important;
	}
	/* -- Section Heading h3 -- */
	.et_pb_text_inner h3 {
		font-size: 1.9rem!important;
	}

}

/* -- List global line height --*/
.entry-content ul {
	line-height: 34px!important;
}
/* -- List font size & line height from 1366px to 981px -- */
@media screen and (min-width:981px) and (max-width:1366px) {
	li {
		font-size: 1.1rem;
		line-height: 27px;
	}
}

/* -- Button circle style, necessary to use !important otherwise style not applicable -- */
.gl-button-style {
	border-radius: 0 33px!important;
}
/* -- Scroll to top design -- */
.et_pb_scroll_top.et-pb-icon {
	background: #CD2415;
	border-radius: 0 13px;
	right: 10px;
}
/* -- Vertically middle content css -- */
#v-middle {
	align-items:center;
}
/* -- Header items flex on tablet & mobile -- */
@media (max-width: 980px) {
	.h-flex {
		display:flex;
		align-items:center;
	}
}
/*-- Title section background top bottom space adjustment from 1366px to 981px --*/
@media screen and (min-width:981px) and (max-width:1366px) {
	#title-section {
		padding-top: 80px;
		padding-bottom: 80px;
	}
}

/* -- Menu custom style -- */
/* -- place border right for each nav, necessary to use !important on some part otherwise style not applicable -- */
header .menu-item {
	padding: 0px 20px!important;
	border-right: 1px solid #fff;
	line-height: 1.3em!important;
}
header .menu-item a {
	padding: 5px 0;
}
/* -- Remove border right from submenu --*/
header .sub-menu .menu-item {
	border-right: none;
}
/* -- Nav space adjustment from 1690 to 981 screen --*/
@media screen and (min-width:981px) and (max-width:1690px) {
	header .menu-item {
		padding: 0px 20px!important;
	}
}
header .menu-item:last-child {
	border-right: none;
}
/* -- Border bottom on current active menu -- */
header .current_page_item > a {
	border-bottom: 2px solid #CD2415;
}
/* -- Remove border bottom on sub active menu -- */
header .sub-menu .current_page_item a {
	border-bottom: none;
}
/* -- Menu center, necessary to use !important otherwise style not applicable -- */
header .et_pb_menu--style-centered .et_pb_menu__wrap {
	justify-content: center!important;
}

/* -- Responsiveness of above added code -- */
@media screen and (min-width:320px) and (max-width:980px) {
	/**Adding menu space & removing right border**/
	header .menu-item {
		padding: 7px!important;
		border-right: none;
	}
	/* -- Remove border bottom on current active menu -- */
	header .et_pb_menu_0_tb_header.et_pb_menu ul li.current-menu-item a {
		border: none;
	}
	/* -- Mobile toggle icon placement, necessary to use !important otherwise style not applicable -- */
	header .et_pb_menu--style-centered .et_pb_menu__wrap {
		justify-content: end!important;
	}
	/**Mobile menu fullwidth**/
	header .et_mobile_menu {
		width:90vw;
		left: 100%;
		transform: translate(-94%);
		margin-top: 20px;
	}
}
/* -- Menu font size from 1365px to 1216px screen --*/
@media screen and (max-width:1365px) and (min-width:1216px) {
	header .et_pb_menu_0_tb_header.et_pb_menu ul li a {
		font-size: 1em!important;
	}
	header #gl-button-style {
		font-size: 1rem !important;
	}
}
/* -- Menu font size from 1215px to 1141px screen -- */
@media screen and (max-width:1215px) and (min-width:1141px) {
	header .et_pb_menu_0_tb_header.et_pb_menu ul li a {
		font-size: 0.9em!important;
	}
	header .et-menu .menu-item-has-children>a:first-child:after {
		top: 3px;
	}
	header #gl-button-style {
		font-size: 0.9rem !important;
	}
}
/* -- from 1140px to 981px screen -- */
@media screen and (max-width:1140px) and (min-width:981px) {
	header .menu-item {
		padding: 0px 10px!important;
	}
	header .et_pb_menu_0_tb_header.et_pb_menu ul li a {
		font-size: 0.8em!important;
	}
	header .et-menu .menu-item-has-children>a:first-child:after {
		top: 3px;
	}
	header #gl-button-style {
		font-size: 0.8rem !important;
	}
}	
/* -- Dropdown menu items bottom space -- */
.sub-menu .menu-item {
	margin-bottom: 16px;
}
/* -- Dropdown last menu items no bottom space -- */
.sub-menu .menu-item:last-child {
	margin-bottom:0;
}
/* -- Dropdown menu items no unnecessary bottom space on mobile -- */
@media (max-width:767px) {
	.sub-menu .menu-item {
		margin-bottom: 0;
	}
}

/* -- footer-external-css -- */
/* -- Footer email text transform lowercase --*/
#menu-item-866 a {
	text-transform: lowercase;
}
/* -- Copyright text center -- */
#freshy_copyright {
	justify-content: center;
}
/* -- Footer social icon design match -- */
.et_pb_social_media_follow_0_tb_footer li a.icon {
	border-radius: 50%;
}
.et_pb_social_media_follow_0_tb_footer li.et_pb_social_icon a.icon::before {
	color: #000000;
	background: #fff;
	border-radius: 50%;
}
.et_pb_social_media_follow_0_tb_footer li.et_pb_social_icon a.icon:hover::before {
	color: #fff;
	background: #CD2415;
}
/* -- Footer menu right border remove --*/
.menu-item {
	padding: 0px 0px!important;
	border-right: none;
}
/* -- Footer menu checklist unwanted space remove -- */
#footer-top .checklist-columns-2 ul li, .checklist-columns-3 ul li, .checklist-columns-4 ul li {
	margin-bottom: 6px !important;
}
/* -- Footer mobile menu disable --*/
#footer-menus .mobile_menu_bar {
	display: none;
}
#footer-menus .et_pb_menu__menu {
	display: block;
}
/* -- Footer menu align left on tablet mobile -- */
@media (max-width: 980px) {
	.et_pb_menu--style-left_aligned .et_pb_menu__wrap {
		justify-content: flex-start!important;
	}
}
/* -- Footer menu font size adjustment to fit the width -- */
@media screen and (min-width:981px) and (max-width:1366px) {
	#footer-top .menu-item a {
		font-size: 14px !important;
	}
}
/* -- Footer quick links column width adjustment in 640 screen -- */
@media (max-width:640px) {
	.et_pb_menu_0_tb_footer {
		width: 35%!important;
	}
}
/* -- Footer quick links column width adjustment in 479 screen -- */
@media (max-width:479px) {
	.et_pb_menu_0_tb_footer {
		width: 22%!important;
	}
}

/* -- Homepage External css -- */
/* -- Hero section padding reduce from 1366 screen -- */
@media screen and (min-width:981px) and (max-width:1366px) {
	#hero-section.et_pb_section_0.et_pb_section {
		padding-top: 12%!important;
		padding-bottom: 12%!important;
	}
}
/* -- Outline --*/
.outline {
	outline: #151719 solid 1px;
}

.outline:hover {
	outline: #CD2415 solid 1px
}
/* -- Service section 3 heading font size adjustment from 1366 to 981 -- */
@media screen and (min-width:981px) and (max-width:1366px) {
	#v-info-section h3 {
		font-size:1.2rem!important;
	}
}
/* -- Why choose us section blurb image margin remove -- */
#why-choose-us .et_pb_main_blurb_image {
	margin-bottom: 0px;
}
/* --Why choose section right nested column width --*/
#custom-width-20 {
	width: 20%;
}
#custom-width-80 {
	width: 80%;
}
@media (max-width: 767px) {
	#custom-width-20 {
		width: 100%;
	}
	#custom-width-80 {
		width: 100%;
	}
}
/* -- Why choose us right trust points paragraph font -- */


/* -- Service page external css -- */
/* -- Service page font size -- */
#sr-h h2 {
	font-size: 1.7rem !important;
	font-weight: 700!Important;
	color: #151719;
	font-family: 'Libre Baskerville',Georgia,"Times New Roman",serif;
}
.et_pb_blurb_position_left .et_pb_blurb_container, .et_pb_blurb_position_right .et_pb_blurb_container {
	vertical-align: middle;
}
@media (max-width:981px) {
	#sr-h h2 {
		font-size: 1.2rem !important;
	}
}
@media (max-width:767px) {
	#sr-h h2 {
		font-size: 1.1rem !important;
	}
}
/* -- List bullet color change -- */
li::marker {
	color: #CD2415;
}
/* -- nested column width --*/
#custom-width-10 {
	width: 10%;
}
#custom-width-90 {
	width: 90%;
}
@media (max-width: 767px) {
	#custom-width-10 {
		width: 10%!important;
	}
	#custom-width-90 {
		width: 90%!important;
	}
}
/* -- Border before bullet point -- */
#service-page li::before {
	width: 16px;
	background: #000;
	height: 1px;
	content: "";
	position: absolute;
	left: -11px;
	transform: translate(-1px, 18px);
	z-index: -1;
}
/* -- Border before bullet point adjustment from 1366px to 981px --*/
@media screen and (min-width:981px) and (max-width:1366px) {
	#service-page li::before {
		transform: translate(5px, 14px);
	}
}

/* -- Projects page blog module style css -- */
.custom-grid .dp-dfg-container .dp-dfg-items .dp-dfg-item {
	padding: 20px !important;
}
.custom-grid .dp-dfg-item .dp-dfg-image{
	margin:0 auto 20px;
	width:100%;
}

.custom-grid  .et_pb_button_wrapper .et_pb_button{
	border-radius: 0 33px!important;
	padding:7px 32px !important;
}



/* -- Contact Page css --*/
/* -- Contact page contact link color --*/
#contact-info a {
	color:#fff;
}
/* -- Contact email text transform -- */
#email-info a {
	text-transform: lowercase;
}
/*-- Contact button alignment --*/
.gform_footer.top_label {
	justify-content: center;
}
/* -- Form fields color and font -- */
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"], 
body .gform_wrapper.gravity-theme select,
body .gform_wrapper .ach_fields iframe input {
	font-size: 16px;
	color: #161719;
	font-weight: 600;
	background-color: #F8F8F8;
	border: 0 ;
	padding: 16px;
	height: auto;
}
.gform_wrapper.gravity-theme .ginput_complex:not(.ginput_container_address) span:not([style*="display:none"]):not(.ginput_full)~span:not(.ginput_full) {
	margin-bottom: 8px;
}

/* -- PayPal Field -- */
.gform_wrapper.gravity-theme .ginput_container_custom_card_fields .ginput_card_field  {
	border: 0;
	/* padding: 16px; */
	margin-bottom: 0px !important;
	line-height: initial;
	font-weight: 600;
	font-size: 16px;
	color: #161719;
	background-color: #F8F8F8;
}
/* -- Contact button style to match design --*/
#gform_submit_button_1, .gform_button {
	color: #FFFFFF;
	letter-spacing: 0px;
	background-color: #cd2415;
	padding: 6px 32px;
	border-radius: 0 33px;
	border: 2px solid #cd2415;
}
#gform_submit_button_1:hover, .gform_button:hover {
	background-color: transparent;
	color:#000 !important;
}
/* -- Contact submission error font -- */
#gform_1_validation_container .gform_submission_error, .gform_submission_error {
	line-height: 1.2em;
	font-size: 2rem !important;
}

/* -- Blog page css -- */
/* -- Blog hide featured category from sidebar --*/
.cat-item.cat-item-30 {
	display: none;
}
/* -- Blog read more button style --*/
.post-content .more-link {   
	color: #FFFFFF;   
	letter-spacing: 0px;   
	background-color: #151719;   
	padding: 6px 32px;   
	border-radius: 0 33px;   
	border: 2px solid #151719;   
	display: inline!Important;
	transition:.3s;
}
.post-content .more-link:hover {
	background-color:transparent;
}
/*-- Blog excerpt margin bottom --*/
.post-content-inner p {
	margin-bottom: 35px;
}
/*-- Blog hover transition -- */
.et_pb_post {
	transition:.4s;
}
/* -- Post content spacing -- */
.post-content {
	padding-bottom: 15px;
}
/* -- featured post content spacing --*/
#featured-post .entry-title {
	margin-left: 30px;
}
#featured-post .post-content {
	padding: 0 30px 30px 30px;
}
/* -- featured post content spacing under 767 screen --*/
@media (max-width:767px) {
	#featured-post .entry-title {
		margin-left: 20px;
	}
	#featured-post .post-content {
		padding: 0 20px 30px 20px;
	}
}
.custom-widget .et_pb_widget.widget_categories ul{
	padding-left:20px !important;
}
/* -- Blog page sidebar width reduce from 1920 to 1370 -- */
@media screen and (min-width:1370px) and (max-width:1920px) {
	#blog-page .et_pb_gutters2 .et_pb_column_3_4, .et_pb_gutters2.et_pb_row .et_pb_column_3_4 {
		width: 94.25%;
	}
}

/*about*/
.mp-vertical-align{
	display:flex;
	flex-direction:column;
	justify-content:center;
}
p.dp-dfg-custom-field.dp-dfg-cf-member_position{
	padding-bottom: 0 !important;
}
.team-grid .dp-dfg-image img{
	border-radius:50%;
	filter: saturate(0%);
	backface-visibility: hidden;
}
.team-grid .dp-dfg-item:hover .dp-dfg-image img{
	filter: saturate(100%);
	backface-visibility: hidden;
}
.team-grid .dp-dfg-item{
	padding:20px;
}
.team-grid:not(.featured) .dp-dfg-item .dp-dfg-image{
	margin:20px auto;
	width:100%;
	max-width:200px;
}
.team-grid.featured .dp-dfg-item .dp-dfg-image{
	margin:20px auto;
	width:100%;
	max-width:300px;
}
.team-grid.featured .dp-dfg-container .dp-dfg-items .dp-dfg-item{
	display:flex;
	flex-direction:column;
}
.team-grid.featured .dp-dfg-custom-content{
	order: 3 !important;
}
.team-grid.featured .dp-dfg-content.entry-summary{
	order: 4;
}
.team-grid.featured .et_pb_button_wrapper.read-more-wrapper{
	order: 5;
}
.team-grid.featured .dp-dfg-content.entry-summary{
	padding-bottom:20px !important;
}
.team-grid.featured .et_pb_button_wrapper.read-more-wrapper{
	margin-bottom:20px;
}
.team-grid .et_pb_button_wrapper .et_pb_button{
	border-radius: 0 33px!important;
	padding:7px 32px !important;
}
.dp-dfg-meta.entry-meta:empty{
	display:none !important;
}
.team-grid .dp-dfg-custom-content{
	grid-row: 3 !important;
}
.team-grid .dp-dfg-content.entry-summary{
	grid-row: 4;
}
.team-grid .et_pb_button_wrapper.read-more-wrapper{
	grid-row: 5;
}
.team-grid:not(.featured) .dp-dfg-custom-field.dp-dfg-cf-member_position{
	margin-bottom:10px;
}
@media only screen and (max-width:1320px) and (min-width:981px){
	.mobile-row.et_pb_row.et_pb_equal_columns{
		display:block;
	}
	.mobile-row .et_pb_column{
		width:100% !important;
		margin-bottom: 30px;
	}
}

/*featured article*/
@media only screen and (max-width:980px){
	.dp-dfg-container.dp-dfg-layout-list .dp-dfg-item .dp-dfg-header.entry-header{
		grid-column: initial !important;
		grid-row: initial !important;
	}
	.dp-dfg-container.dp-dfg-layout-list  .dp-dfg-item {
		display: grid;
		grid-auto-rows: min-content;
	}
	.dp-dfg-container.dp-dfg-layout-list .dp-dfg-item {
		grid-template-columns: none !important;
		-ms-grid-columns: none !important;
	}
}

/*contact button mobile menu*/
@media only screen and (min-width:981px){
	.hide-desktop{
		display:none !important;
	}
	.last-desktop{
		border-right:0 !important;
	}
}

body .et-menu .et_pb_button.contact a,
body .et-menu .et_pb_button.contact a:hover,
body .et_mobile_menu .et_pb_button.contact a,
body .et_mobile_menu .et_pb_button.contact a:hover {
	color:#fff !important;
	padding-top: 5px!important;
	padding-right: 20px!important;
	padding-bottom: 5px!important;
	padding-left: 20px!important;
	line-height: 1.3em;
	opacity: 1;
	border-bottom: 0;
}
body .et-menu .et_pb_button.contact,
body .et_mobile_menu .et_pb_button.contact {
	border: 2px solid #cd2415 !important;
	border-radius: 0 33px!important;
	max-width:250px;
	margin: auto 0;
	padding:0 !important;
}
@media only screen and (max-width:980px) {
	body .et_mobile_menu .first-button.et_pb_button.contact {
		margin-bottom: 10px;
	}
	body .et_mobile_menu .et_pb_button.contact {
		max-width:250px;
		width:90%;
		margin: auto;
	}
	header .menu-item {
		text-align: center;
	}
}
#our-projects .dp-dfg-header.entry-header{
	margin-bottom:30px !important;
}
@media only screen and (max-width:1240px){
	.reverse-order-mobile.et_section_specialty .et_pb_row{
		display: flex;
		flex-direction: column-reverse !important;
	}
}
@media only screen and (max-width:1240px) and (min-width:981px){
	.special-section.et_section_specialty .et_pb_row{
		display:flex;
		flex-direction:column;	
	}
	.special-section.et_section_specialty .et_pb_row .et_pb_column {
		margin-right: 3%;
		width: 100%;
		margin-bottom: 30px;
	}
	.special-section .et_pb_image{
		width:40% !important;
	}
	.reverse-order-mobile.et_section_specialty .et_pb_row .et_pb_specialty_column:last-child{
		margin-bottom:30px !important;
	}
}

@media only screen and (min-width:981px){
	.horse-animation{
		animation: DVD 1.5s ease-in-out forwards;
		transform: scaleX(1.5) scaleY(1.5) !important;
		left: 0px;
		bottom: 0px;
	}
}
@keyframes DVD {
	to {
		left: 95%;
		bottom: 26%;

	}
}

/* ---------- Gravity Forms ---------- TA - 6/8/23 */
body .gform_wrapper .custom-form-paypal input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
body .gform_wrapper .custom-form-paypal input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]) {
	font-size: 16px;
	color: #161719;
	font-weight: 600;
	background-color: #F8F8F8 !important;
	border: 0 !important;
	padding: 16px !important;
}

/* ----- Required Legend ----- */
.custom-form-paypal_wrapper .gform_required_legend {
	display: none;
}

/* ----- Sections ----- */
.gform_wrapper.gravity-theme .custom-form-paypal .gsection {
	padding-bottom: 0;
	margin-top: 10px;
	margin-bottom: -10px;
	border-bottom: 3px solid #CD2415;
}
.gform_wrapper.gravity-theme .custom-form-paypal .gsection  h3.gsection_title {
	padding-bottom: 5px;
}

/* ----- Billing Address ----- */
.custom-form-paypal .ginput_address_state select option[value="State"] {
	color: #757575;
}

/* ----- Process Payment - PayPal Field ----- */
.gform_wrapper.gravity-theme .custom-form-paypal .gfield--type-paypal .gform-field-label {
	margin-bottom: 7px;
}
.gform_wrapper.gravity-theme .custom-form-paypal .gform_ppcp_custom_card_fields,
.gform_wrapper.gravity-theme .custom-form-paypal .gform_ppcp_custom_card_fields .ginput_container_custom_card_fields {
	display: block !important;
}
#page-container .gform_wrapper.gravity-theme .custom-form-paypal .gform_ppcp_custom_card_fields .ginput_container_custom_card_fields {
	margin-top: 0;
}
#page-container .gform_wrapper.gravity-theme .custom-form-paypal .gform_ppcp_custom_card_fields .ginput_container_custom_card_fields .ginput_cardextras {
	margin-bottom: 0;
}
/*Card Expiration*/
#page-container .gform_wrapper.gravity-theme .custom-form-paypal .gform_ppcp_custom_card_fields .ginput_container_custom_card_fields .ginput_card_expiration {
	min-width: 185px;
}
/*security code icon*/
#page-container .gform_wrapper.gravity-theme .custom-form-paypal .gform_ppcp_custom_card_fields .ginput_container_custom_card_fields .ginput_card_security_code_icon {
	height: 0;
	margin: 0;
}
/*hidden label screen reader text*/
#page-container .gform_wrapper.gravity-theme .custom-form-paypal .gform_ppcp_custom_card_fields .ginput_container_custom_card_fields .ginput_cardinfo_right .screen-reader-text {
	height: 0;
	padding: 0;
}
/*Credit Card Icons*/
#page-container .gform_wrapper.gravity-theme .custom-form-paypal .gform_ppcp_custom_card_fields .ginput_container_custom_card_fields > .ginput_full,
#page-container .gform_wrapper.gravity-theme .custom-form-paypal .gfield--type-creditcard .ginput_container_creditcard > .ginput_full {
	position: relative;
}
.gform_wrapper.gravity-theme .custom-form-paypal .gform_ppcp_custom_card_fields .gform_card_icon_container,
.gform_wrapper.gravity-theme .custom-form-paypal .gform_card_icon_container {
	margin-top: -4px;
}
@media (min-width: 806px) {
	.gform_wrapper.gravity-theme .custom-form-paypal .gform_ppcp_custom_card_fields .gform_card_icon_container,
	.gform_wrapper.gravity-theme .custom-form-paypal .gform_card_icon_container {
		position: absolute;
		top: -40px;
		left: 140px;
		margin: 0;
	}
}
@media (max-width: 640px) {
	.gform_wrapper.gravity-theme .custom-form-paypal .gform_ppcp_custom_card_fields .gform_card_icon_container,
	.gform_wrapper.gravity-theme .custom-form-paypal .gform_card_icon_container {
		position: absolute;
		top: -40px;
		left: 140px;
		margin: 0;
	}
}
/*Expiration Month and Year*/
.gform_wrapper.gravity-theme .custom-form-paypal select[data-chosen='Expiry Month'] {
	color: #757575;
}

/* ----- Use this class too make fields fullwidth on mobile ----- */
@media (max-width: 980px) {
	.gform_wrapper.gravity-theme .custom-form-paypal .fullwidth-field-mobile.gfield.gfield--width-half {
		grid-column: 1/-1;
	}
}

/* ---------- Top Menu ---------- TA - 06/23/2023 */
/* ----- Column ----- */
#page-container .top-menu-column {
	width: 80% !important;
	max-width: 1440px;
	text-align: center;
	margin-left: auto !important;
	margin-right: auto !important;
}
/* ----- Resize Columns ----- */
@media (min-width: 981px) {
	.top-menu-column-2 .et_pb_menu__menu,
	.top-menu-column-2 .et-menu-nav,
	.top-menu-column-2 .et-menu {
		width: 100% !important;
	}
	.first-button {
		margin-left: 20px !important;
		margin-right: 15px !important;
	}
	.top-menu-column-1 {
		width: 15% !important;
	}
	.top-menu-column-2 {
		width: 85% !important;
	}
}
/* ----- Resize Row ----- */
@media (max-width: 1675px) and (min-width: 981px) {
	#v-middle.top-menu-row {
		max-width: 1340px;
		width: 95%;
	}
}