/*
Theme Name: Divi Child
Theme URI: https://www.elegantthemes.com/gallery/divi/
Description: Divi child theme via Freshy
Author: Freshy
Author URI: https://freshysites.com/
Template: Divi
Version: 4.2.0
*/
/* 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,
#et-boc header .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,
#et-boc header .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"],
#et-boc header .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,
#et-boc 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,
#et-boc header .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,
#et-boc header .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,
#et-boc 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,
#et-boc 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,
#et-boc 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,
#et-boc header .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,
#et-boc header .et_mobile_menu li li {
	padding-left: 0;
}

/* adjust mobile menu anchors side paddings */
#main-header #mobile_menu.et_mobile_menu li a,
#et-boc header .et_mobile_menu li a {
	padding-left: 20px;
	padding-right: 20px;
}
/* indent sub menu */
#main-header #mobile_menu.et_mobile_menu li li a,
#et-boc header .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,
#et-boc header .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,
#et-boc header .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,
#et-boc 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,
#et-boc header .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: #000;
	justify-content: center;
	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: #000;
	vertical-align: middle;
	margin: 10px auto 15px;
	display: block;
}

/* add an FS logo via background */
#freshy_copyright a.copyright_fs {
	display: block;
	width: 68px;
	height: 20px;
	background-image: url("/wp-content/uploads/Freshy-logo-svg.png");
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	text-indent: 200%;
	white-space: nowrap;
	overflow: hidden;
	margin: 4px 0 0 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;
}

ul li::marker{
	color:  #D02231!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;
}

#page-container{
	overflow-x: hidden;
}

/* -- 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;
	}
}

.et_pb_scroll_top.et-pb-icon {
  background: #d02231;
  padding: 17px 5px;
}

/* -- 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 -- */

.et_pb_social_media_follow li {
  display: inline-block;
  margin-bottom: 0;
}

#et-boc .left-icon-blurb .et_pb_blurb_content {
	display: flex;
	align-items: center;
}
#et-boc .left-icon-blurb .et_pb_main_blurb_image{
	margin-right: 15px!important;
	margin-bottom: 0!important;
	width: auto;
}

#et-boc .left-icon-blurb .et_pb_blurb_container {
	padding-left: 0!important;
}

#et-boc .et_pb_button {
	line-height: 1.2em!important;
}

.nav li ul {
  width: 280px;
	}
.nav li ul a{
	display: block;
	width: 100%;
}

/* Global  */

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

		.two-col-gutter .et_pb_column {
		width: calc(50% - 30px + 15px) !important;
		margin-right: 30px !important;
		}
		.two-col-gutter .et_pb_column:last-child {
			margin-right: 0 !important;
		}
	
	.three-col-gutter .et_pb_column {
		width: calc(33.33% - 30px + 10px) !important;
		margin-right: 30px !important;
	}
	.three-col-gutter .et_pb_column:last-child {
		margin-right: 0 !important;
	}

}

.strong-style strong{
	color: #ff006a!important;
	font-weight: 400;
}

h1, h2, h3, h4, h5, h6 {
  padding-bottom: 0;
}

.clr-heading h1 span,
.clr-heading h2 span,
.clr-heading h3 span{
	color: #D02231!important;
}

/* Header  */


#et-boc .custom-header-menu .et_pb_menu__logo{
	margin-right: 0!important;
}

#et-boc .custom-header-menu  .nav li li {
  padding: 00px;
  margin: 0;
  width: 100%;
}
#et-boc .custom-header-menu  .sub-menu{
	padding: 0!important;
}

.et_pb_menu--with-logo .et_pb_menu__menu > nav > ul > li > a {
  padding: 10px 0;
}

#et-boc  .inline-blurb{
	display: flex;
	align-items : center;
}

#et-boc  .inline-li ul{
	padding-left: 0!important;
	padding-bottom: 0em;
}

#et-boc  .inline-li ul li{
	display: inline-block;
	position: relative;
	display: inline-block;
	  position: relative;
	  padding-left: 10px;
	  padding-right: 10px;
}

#et-boc  .inline-li ul li::before{
	content: "";
	  display: block;
	  width: 5px;
	  height: 5px;
	  background: #D02231;
	  position: absolute;
	  left: 0;
	  border-radius: 50%;
	  top: 0;
	  bottom: 0;
	  margin: auto;
}

/* #et-boc  .inline-li ul li::marker{
	color: #D02231;
} */

/* Shape Blurb  */

#et-boc .shape-blurb .et_pb_module_header{
	margin-bottom: 30px;
	border-bottom: 3px solid #fff;
	padding-bottom: 20px;
}




/* News Single  */


.single-recent-post .entry-title::before{
	content: "- ";
 
}

.single-recent-post  article{
	padding-bottom: 15px!important;
}



/* Footer  */

#et-boc .footer-menu-style .et-menu{
	display: flex;
	flex-direction: column;
}


@media all and (min-width:981px) {
	.row-items-center {
		display: flex;
		align-items: center;
	}
}



@media (max-width: 980px) {
#et-boc .footer-menu-style .et_pb_menu__menu {
    display: block;
  }
	#et-boc .footer-menu-style .et_pb_menu__wrap{
		justify-content: start;
	}
	#et-boc .footer-menu-style .et_mobile_nav_menu{
		display: none;
	}
	
/* 	News  */
	
	#et-boc .overlay-grid-style .pagination {
	  margin-top: 10px;
	}
}


/* Hero slider  */

.hero-slider .et_pb_slide{
	padding: 0!important;
}

.gallery-item img{
	border: none!important;
}

.et_pb_slides .et_pb_slider_container_inner{
	vertical-align: bottom!important;
}

div#et-boc .dynamic-project-slider .n2-active .n2-caption-overlay{
	border: 4px solid #D02231!important;
}

.hero-slider  .et_pb_slide_description{
	background: rgba(0,0,0,.6);
	padding: 10px 0!important;
}
.hero-slider  .et_pb_slide_title{
	max-width: 1140px;
	  margin: auto;
	  width: 90%;
}
.hero-slider  .et_pb_slide_title span{
	display: block;
	color: rgba(255, 255, 255,0.3)!important;

}

#et-boc .et-pb-arrow-prev::before,
#et-boc .et-pb-arrow-next::before{
	font-weight: 900!important;
}

#et-boc .et-pb-arrow-prev {
  left: 0;
	opacity: 1 !important;
  background: #00000091;
  padding: 15px 00px;

}
#et-boc .et-pb-arrow-next{
	right: 0;
	opacity: 1 !important;
  background: #00000091;
   padding: 15px 00px;

}


/* Services Blurb  */

#et-boc .services-blurb .et_pb_blurb_content{
	position: absolute;
	bottom: 0;
	background: rgba(0,0,0,0.5);
	padding: 25px 10px;
}


/* Play Btn  */

/* div#page-container div#et-boc .play-btn::after{
	font-size: 30px !important;
	  background: #D02231 !important;
	  color: #fff !important;
	  width: 50px;
	  height: 50px;
	  display: flex;
	  justify-content: center;
	  align-items: center;
	  position: absolute;
	  top: 0;
	  right: 0;
	  bottom: 0;
	  border-radius: 50%;
}

.btn-full{
	display: block;
	width: 100%;
	text-align: center;
} */


/* Blog List style  */

#et-boc .blog-list-style article{
	padding: 0!important;
}
#et-boc .blog-list-style  .entry-header{
	padding-top: 0!important;
}
#et-boc .blog-list-style .dp-dfg-more-button{
	padding: 0!important;
}

/* Form style  */

.gform_required_legend{
	display: none!important;
}

body .gform_wrapper .hidden_label .ginput_container > * {
  margin-top: 0px !important;
}

body .gform_wrapper .hidden_label textarea.textarea {
  display: block;
  margin: 0 !important;
}

.gform_wrapper.gravity-theme .gfield textarea.medium {
  height: 160px;
  resize: none;
}

.gform_wrapper.gravity-theme .gform_fields {
  grid-column-gap: 20px;
  grid-row-gap: 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"] {
  background-color: #efecea;
  border: 2px solid #fff;
  font-size: 18px;
  color: #999;
  padding: 17px;
  line-height: initial;
  height: initial;
  outline: 1px solid #EFECEA !important;
}

body .gform_wrapper input:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not([type="button"]):not([type="image"]):not([type="file"]):focus, 
body .gform_wrapper textarea.textarea:focus, 
body div.form_saved_message div.form_saved_message_emailform form input[type="text"]:focus {
  border-color: #D02231!important;
}

.form-style  .gform_footer{
	margin: 6px 0 0;
  padding: 0;
	justify-content: end;
	padding: 0 !important;
}

.form-style  input[type="submit"],
.popup-form  input[type="submit"]{
	min-width: 200px;
	text-align: center;
	background: #D02231!important;
	color: #fff!important;
	font-weight: 700 !important;
	font-size: 17px;
}

.form-style  input[type="submit"]:hover,
.popup-form  input[type="submit"]:hover{
	background: #000!important;
	color: #fff!important;
}

.gform_description{
	display: none!important;
}


body .gform_wrapper .gfield_description.gfield_validation_message {
  display: none;
}

/* Placeholder styles for .form-style */
.form-style .gform_body input::placeholder,
.form-style .gform_body textarea::placeholder {
	color: #D02231;
	opacity: 1;
}

.form-style .gform_body input::-webkit-input-placeholder, 
.form-style .gform_body textarea::-webkit-input-placeholder {
	/* Chrome/Opera/Safari */
	color: #D02231;
	opacity: 1;
}

.form-style .gform_body input::-moz-placeholder, 
.form-style .gform_body textarea::-moz-placeholder {
	/* Firefox 19+ */
	color: #D02231;
	opacity: 1;
}

.form-style .gform_body input:-ms-input-placeholder, 
.form-style .gform_body textarea:-ms-input-placeholder {
	/* IE 10+ */
	color: #D02231;
	opacity: 1;
}

.form-style .gform_body input:-moz-placeholder, 
.form-style .gform_body textarea:-moz-placeholder {
	/* Firefox 18- */
	color: #D02231;
	opacity: 1;
}

/* Placeholder styles for .popup-form */
.popup-form .gform_body input::placeholder,
.popup-form .gform_body textarea::placeholder {
	color: #495057;
	opacity: 1;
}

.popup-form .gform_body input::-webkit-input-placeholder, 
.popup-form .gform_body textarea::-webkit-input-placeholder {
	/* Chrome/Opera/Safari */
	color: #495057;
	opacity: 1;
}

.popup-form .gform_body input::-moz-placeholder, 
.popup-form .gform_body textarea::-moz-placeholder {
	/* Firefox 19+ */
	color: #495057;
	opacity: 1;
}

.popup-form .gform_body input:-ms-input-placeholder, 
.popup-form .gform_body textarea:-ms-input-placeholder {
	/* IE 10+ */
	color: #495057;
	opacity: 1;
}

.popup-form .gform_body input:-moz-placeholder, 
.popup-form .gform_body textarea:-moz-placeholder {
	/* Firefox 18- */
	color: #495057;
	opacity: 1;
}

.popup-form .gform_fields {
  grid-row-gap: 2px!important;
}



body .popup-form  input:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not([type="button"]):not([type="image"]):not([type="file"]), 
body .popup-form  textarea.textarea, 
body .popup-form div.form_saved_message div.form_saved_message_emailform form input[type="text"] {
  background-color: transparent!important;
  border-bottom: 1px solid #D02231!important;
  font-size: 18px;
  color: #495057;
  padding: 15px;
  line-height: initial;
  height: initial;
  border-right: 0!important;
  border-left: 0!important;
  border-top: 0!important;
}


/* / up  /
/ end placeholder css updated 30-11-23  / */

.play-btn-width img{
	min-width: 50px;
}


/* Common Media query  */


@media (max-width: 980px) {
	#et-boc .et-pb-arrow-prev {
	  padding: 10px 00px;
	}
	#et-boc .et-pb-arrow-next{
	  padding: 10px 00px;
	}
	
	
#et-boc .services-blurb .et_pb_blurb_content{
	position: absolute;
	bottom: 0;
	background: rgba(0,0,0,0.5);
	padding: 15px 20px;
}
	
}

.gallery {
    position: relative;
    width: 100%;
    height: 450px;
    overflow: hidden;
	margin: 0!important;
}

.gallery .gallery-item {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%!important;
/*     height: 100%; */
    opacity: 0;
    transition: opacity 0.5s ease; /* Smooth transition for fading */
	margin-top: 0!important;
}

.gallery .gallery-item img{
	width: 100%;
	display: block;
}

.gallery-item a{
	width: 100%;
}

.gallery .gallery-item.active {
    opacity: 1; /* Only active slide is fully visible */
}

.gallery .bullets {
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    justify-content: center;
}

.gallery .bullets span {
    display: inline-block;
    width: 10px;
    height: 10px;
    margin: 0 5px;
    background-color: #ddd;
    border-radius: 50%;
    cursor: pointer;
    transition: background-color 0.3s;
}

.gallery .bullets span.active {
    background-color: #D02231; /* Active bullet color */
}


/* Dynamic Project slider  */

.dynamic-project-slider .n2-caption-overlay{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	margin: auto;
	    transition: opacity 0.3s ease;
}

.dynamic-project-slider .n2-caption-overlay div {
    opacity: 0;
	  padding: 10px 20px;
    transition: opacity 0.3s ease; /* Smooth transition */
}

.dynamic-project-slider .n2-caption-overlay:hover{
		background: rgba(0, 0, 0,0.6)!important;
}

.dynamic-project-slider .n2-caption-overlay:hover div {
    opacity: 1;
}

.dynamic-project-slider .n2-ss-slider-controls{
	margin-bottom: 50px!important;
}

.n2-active .n2-caption-overlay{
	background: rgba(0, 0, 0,0.6)!important;
	opacity: 1!important;
}
.n2-active .n2-caption-overlay div{
	opacity: 1!important;
}

/* News  */

.txt-btn{
	font-weight: bold;
  color: #fff;
  background: #D02231;
  padding: 13px 20px;
  border-radius: 20px;
  font-size: 18px;
  display: inline-block;
  text-align: center;
	line-height: 1.2em;
}


:not(.dp-dfg-layout-list, .dp-dfg-layout-fullwidth).dp-dfg-skin-default.dp-dfg-skin-itemsinoverlay .dp-dfg-item > * {
  opacity: 1;
/* 	background: #000; */
}

#et-boc .overlay-grid-style .dp-dfg-overlay{
	background-color: #cac8be66!important;
}
#et-boc .overlay-grid-style .dp-dfg-overlay:hover{
	background-color: #D02231!important;
}

#et-boc .overlay-grid-style .dp-dfg-meta,
#et-boc .overlay-grid-style  .dp-dfg-header,
#et-boc .overlay-grid-style  .et_pb_button_wrapper{
	z-index: 999;
	pointer-events: none;
}

#et-boc .overlay-grid-style .dp-dfg-meta .published {
	border-bottom: 3px solid #000;
	padding-bottom: 10px;
}

div#page-container div#et-boc .overlay-grid-style article:hover .et_pb_button_wrapper .dp-dfg-more-button{
	background: #fff!important;
	color: #000!important;
}

#et-boc .overlay-grid-style  .dp-dfg-header{
	padding: 20px 0;
}

#et-boc .overlay-grid-style .dp-dfg-item{
	padding: 0px 50px;
}

/* Pagination  */

 .dp-dfg-pagination ul.pagination li.pagination-item.active a {
  color: #FFFFFF !important;
  background: #232323;
}
#et-boc .overlay-grid-style .pagination a:hover, 
#et-boc .overlay-grid-style .pagination a:hover {
  background-color: #232323;
  color: #fff !important;
}

#et-boc .overlay-grid-style .pagination-link span{
	display: none!important;
}
#et-boc .overlay-grid-style  .pagination{
	margin-top: 30px;
}



/* Member Modules style  */

#et-boc .member-style .et_pb_team_member_image{
	  max-width: 100%;
	margin: 0!important;
}

#et-boc  .member-style .et_pb_team_member_description > div{
	position: absolute;
	  bottom: 18px;
	  right: 0;
	  z-index: 9999999;
}

#et-boc  .member-style .et_pb_team_member_description{
	margin-top: 20px;
	max-width: 80%;
}

#et-boc  .member-style  .et_pb_member_position{
	font-weight: 500;
}

#et-boc  .member-style .et_pb_team_member_description > div a{
	background: #D02231;
	  color: #fff;
	  padding: 10px;
	  font-weight: 700;
	  border-radius: 4px;
}

#et-boc  .member-style .et_pb_team_member_description p{
	padding-bottom: 0!important;
}

#et-boc  .member-style .et_pb_team_member_image {
    position: relative;
}

#et-boc  .member-style .et_pb_team_member_image::before {
    content: "Read Bio";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6); /* Dark overlay */
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.3s ease;
    font-size: 18px;
    text-align: center;
}

#et-boc  .member-style .et_pb_team_member_image:hover::before {
    opacity: 1;
}

.pum-theme-lightbox .pum-content {
  line-height: 1.6em;
}

.gallery-caption{
	display: none!important;
}

.pum-container .pum-title {
  margin-bottom: 10px;
}

iframe body{
	height: auto!important;
}

div#et-boc .single-recent-post article{
	padding: 0!important;
	margin: 0!important;
}
div#et-boc .single-recent-post article .entry-title {
	margin-bottom: 12px!important;
}



@media (max-width: 1200px) {
	div#et-boc .dynamic-project-slider .n2-thumbnail-dot img {
	  width: 220px!important;
	  height: 150px!important;
	}
	
	.gallery {
	  height: 350px;
	}
	.dynamic-project-slider .n2-caption-overlay div {
	  font-size: 16px !important;
	}
	
	.pum-theme-lightbox .pum-content {
	  font-size: 15px;
	}
	
/* 	News  */
	
	#et-boc .overlay-grid-style .dp-dfg-header {
	  padding: 10px 0;
	}
	#et-boc .overlay-grid-style .dp-dfg-item {
	  padding: 0px 20px;
	}
	
	.txt-btn{
	  font-size: 14px;
	}
}

@media (min-width: 981px) and (max-width: 1200px){
	#et-boc .blog-list-style .entry-title{
		font-size: 14px!important;
	}
	#et-boc .blog-list-style .footer-title {
		font-size: 16px!important;
	}
	#et-boc .hero-slider .et_pb_slide_title  {
	  font-size: 50px!important;
	}
	#et-boc  .services-blurb {
		height: 380px;
	  min-height: 380px;
	  max-height: 380px;
	}
	#et-boc .services-blurb .et_pb_blurb_content {
	  padding: 15px 20px;
	}
	
	#et-boc .shape-blurb {
		padding: 40px!important;
		transform: skewX(-5deg) skewY(0deg);
	}
	#et-boc .shape-blurb .et_pb_module_header {
  		font-size: 30px!important;
	}
	
	#et-boc .member-style .et_pb_module_header{
		font-size: 22px!important;
	}
	#et-boc .member-style .et_pb_member_position{
		font-size: 16px!important;
	}
}

@media (max-width: 767px){
	
		#et-boc .inline-blurb {
  flex-direction: column;
}
	#et-boc .inline-blurb .et_pb_blurb{
		margin-right: 0!important;
	}
	
	#et-boc .blog-list-style .entry-header {
	  padding-left: 20px;
	}
	#et-boc .blog-list-style  .et_pb_button_wrapper{
		padding-left: 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"] {
  background-color: #efecea;
  border: 2px solid #fff;
  font-size: 15px;
  color: #999;
  padding: 14px;
  line-height: initial;
  height: initial;
  outline: 1px solid #EFECEA !important;
}
}

@media (max-width: 900px) {
	.dynamic-project-slider .n2-ss-slider-controls {
	  margin-bottom: 10px !important;
	}

}

/* -- RECAPTCHA BADGE -- */
.grecaptcha-badge {
	width: 70px !important;
	overflow: hidden !important;
	transition: all 0.3s ease !important;
	left: 4px !important;
	z-index: 9;
}
.grecaptcha-badge:hover {
	width: 256px !important;
}

#et-boc .play-btn::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    height: 95px;
    width: 95px;
    border: 2px solid #fff;
    border-radius: 50%;
    transform: translate(-50%, -56%);
    -moz-transform: translateX(-50%) translateY(-55%);
    -webkit-transform: translateX(-50%) translateY(-56%);
    -ms-transform: translateX(-50%) translateY(-56%);
    -o-transform: translateX(-50%) translateY(-56%);
    transform: translateX(-50%) translateY(-56%);
    opacity: .3;
    animation: pulse-border 1500ms ease-out infinite;
	border-color: rgba(0, 0, 0, 0.1);
	height: 70px;
    width: 70px;
}

#et-boc .play-btn::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    height: 80px;
    width: 80px;
    border: 2px solid #fff;
    border-radius: 50%;
    transform: translate(-50%, -56%);
    -moz-transform: translateX(-50%) translateY(-56%);
    -webkit-transform: translateX(-50%) translateY(-56%);
    -ms-transform: translateX(-50%) translateY(-56%);
    -o-transform: translateX(-50%) translateY(-56%);
    transform: translateX(-50%) translateY(-56%);
    opacity: .3;
    animation: pulse-border 1500ms ease-out infinite;
	border-color: rgba(0, 0, 0, 0.1);
		height: 70px;
    width: 70px;
}
#et-boc .play-btn{
	position:relative;
	transform: translateX(-50%) translateY(-50%);
}
#et-boc  .play-btn .et_pb_icon_wrap{
	transform: none !important;
}

#et-boc .txt-play-btn {
	transform: none!important;
}

#et-boc .txt-play-btn{
	max-width: 60px!important;
	position: absolute;
	 right: 0;
	bottom: -5px;
}

/* #et-boc .txt-play-btn::before,
#et-boc .txt-play-btn::after{
	transform: none!important;
} */

@keyframes pulse-border {
  0% {
		transform: translateX(-50%) translateY(-56%) translateZ(0) scale(1);
		opacity: 1; 
	}
  100% {
		transform: translateX(-50%) translateY(-56%) translateZ(0) scale(1.5);
		opacity: 0; 
	} 
}
@-o-keyframes pulse-border {
  0% {
		transform: translateX(-50%) translateY(-56%) translateZ(0) scale(1);
		opacity: 1; 
	}
  100% {
		transform: translateX(-50%) translateY(-56%) translateZ(0) scale(1.5);
		opacity: 0; 
	} 
}
@-moz-keyframes pulse-border {
  0% {
		transform: translateX(-50%) translateY(-56%) translateZ(0) scale(1);
		opacity: 1; 
	}
  100% {
		transform: translateX(-50%) translateY(-56%) translateZ(0) scale(1.5);
		opacity: 0; 
	} 
}
@-webkit-keyframes pulse-border {
  0% {
		transform: translateX(-50%) translateY(-56%) translateZ(0) scale(1);
		opacity: 1; 
	}
  100% {
		transform: translateX(-50%) translateY(-56%) translateZ(0) scale(1.5);
		opacity: 0; 
	} 
}

@media (max-width: 980px){
	#et-boc .txt-play-btn {
	  right: auto;
	  bottom: -5px;
	  left: 100%;
	  left: 100px;
	}
}

@media only screen and (min-width: 1024px) {
 .pum-theme-hello-box .pum-container.pum-responsive.pum-responsive-small {
    margin-left: -15%;
    width: 30%;
    max-width: 600px;
  }
}


