/*
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(255,255,255,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(255,255,255,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';
	color:#fff;
}
/* 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(255,255,255,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: white;
	font-size: 16px;
	line-height: 1.25em;
	text-transform:uppercase;
}

/* 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: 68px;
	height: 20px;
	background-image: url("/wp-content/uploads/Freshy_Logo_White_RGB.svg");
	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;
}

.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: #0077C8;
	/* set font size helps make icon sharper */
	font-size: 22px;
	font-weight: 800;
}
.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*/
/* — 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;
}

#page-container{
	overflow:hidden;
}
.mp-vertical-align { 
    display: flex; 
    flex-direction: column; 
    justify-content: center;
}
.mp-vertical-align-bottom{ 
    display: flex; 
    flex-direction: column; 
    justify-content: flex-end;
}
.align-bottom{
    display: flex;
    flex-direction: column;
}
.inline-items{
	display: flex;
    flex-direction: row;
	 flex-wrap: wrap;
    justify-content: flex-start;
    align-items: center;
    align-content: stretch;
}
.inline-items-left{
	display: flex;
    flex-direction: row;
	 flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    align-content: stretch;
}
.inline-items .item-end{
    margin-left:auto;
}

/*--arrow change on menu on hover --*/
#top-menu .menu-item-has-children.et-show-dropdown>a:first-child:after, .et-menu .menu-item-has-children.et-show-dropdown>a:first-child:after {
    content: "2"!important;
	-webkit-transition: all .35s;
	transition: all .35s;
}
/*menu desktop*/
#main-header .container {
	width: 87%;
}
#top-menu li:hover li a {
     border-bottom:0;
}
@media only screen and (min-width:981px){
	#top-menu li li{
		display: block;
	}
	body #page-container .nav li ul {
		width: fit-content !important;
		display: flex;
		flex-direction: column;
	}
	.nav li li {
		white-space: nowrap;
	}
	#top-menu .menu-item-has-children>a:first-child:after, #et-secondary-nav .menu-item-has-children>a:first-child:after{
		top:auto;
		right: 2px;
	}
	#top-menu li li a {
        padding: 8px 0;
    }
}
/*active link*/
#top-menu li.current-menu-ancestor>a, #top-menu li.current-menu-item>a, #top-menu li.current_page_item>a, #top-menu li:hover a {
    color: #ffffff;
    border-bottom: 3px solid #fff;
        background: rgba(0, 0, 0, 0.4);
	-webkit-transition: all .35s;
		transition: all .35s;
}
#top-menu li li.current-menu-ancestor>a, #top-menu li li.current-menu-item>a, #top-menu li li.current_page_item>a, #top-menu li li a {
    background: rgba(255, 255, 255, 0) !important;
}
#top-menu li a {
    border-bottom: 3px solid transparent;
}

body.et_header_style_left #et-top-navigation nav>ul#top-menu>li>a {
    padding: 40px 11px 20px !important;
}
body.et_header_style_left #et-top-navigation nav>ul#top-menu>li.menu-item-has-children>a{
	padding: 40px 24px 20px 11px !important;
}
#top-menu li a {
    text-shadow: 0em 0em 0.4em #000000;
}
#top-menu-nav>ul>li>a:hover {
	opacity: 1;
}

@media only screen and (max-width:1280px) and (min-width:981px){
	#main-header .container {
    	width: 95%;
	}
	#top-menu li {
    	padding-right: 5px;
	}
}
@media only screen and (max-width:1040px) and (min-width:981px){
	#top-menu li a {
    	font-size: 14px !important;
	}
	body.et_header_style_left #et-top-navigation nav>ul#top-menu>li>a {
    	padding-left:8px !important;
		padding-right:8px !important;
	}
}
@media only screen and (min-width: 981px) {
	#main-header:not(.et-fixed-header){
		background-image: linear-gradient(180deg, rgb(0 0 0 / 56%) 0%, rgb(0 0 0 / 0%) 100%);
	}
   body.et_header_style_left #et-top-navigation, body.et_header_style_split #et-top-navigation {
        padding-top: 0 !important;
        padding-bottom: 56px !important;
	   -webkit-transition: all .35s;
		transition: all .35s;
    }
	body.et_header_style_left .et-fixed-header #et-top-navigation{
		 padding-top: 0 !important;
		 padding-bottom: 26px !important;
		-webkit-transition: all .35s;
		transition: all .35s;
	}
}
/*-- mobile menu --*/
@media only screen and (max-width: 980px){
	body .mobile_menu_bar:before {
    	font-weight: 600;
		color:#fff;
	}
	#logo {
    	max-height: 85%;
		max-width:68% !important;
	}
	#main-header #mobile_menu.et_mobile_menu li a, .et_pb_menu .et_mobile_menu {
    	text-align: center;
	}
	#main-header #mobile_menu.et_mobile_menu .menu-item-has-children .sub-menu-toggle + a {
    	padding-left: 44px;
	}
	#main-header #mobile_menu.et_mobile_menu li li a{
		padding-right: 40px;
	}
	#top-menu li li {
    	text-align: center;
	}
}
/*-- scroll up --*/
.et_pb_scroll_top.et-pb-icon:hover {
	background: #fff;
	border:2px solid #fff;
	color:#0077C8;
}
.et_pb_scroll_top.et-pb-icon {
	background: #0077C8;
	bottom: 50px;
	right: 10px;
	border-radius:50%;
	font-size: 30px;
	padding: 10px;
	color:#fff;
	border:2px solid #0077C8;
}
@media only screen and (max-width:760px){
	.et_pb_scroll_top.et-pb-icon {
		font-size:20px;
		font-weight:bold;
		bottom: 12px;
		right: 12px;
	}
}
@media only screen and (max-width:396px){
	body #page-container h1{
		font-size: 36px;
	}
	body #page-container .header-row h2{
		font-size: 33px;
	}
	h2{
		font-size:9vw !important;
	}
	body #page-container h3{
		font-size: 24px;
	}
	body #page-container h4{
		font-size: 24px;
	}
	body #page-container h5{
		font-size: 24px;
	}
	body #page-container h6{
		font-size: 22px;
	}
}
/*-- stack--*/
@media all and (max-width: 980px) {
	/*** wrap row in a flex box ***/
	.custom_row {
  		display: -webkit-box;
  		display: -moz-box;
  		display: -ms-flexbox;
  		display: -webkit-flex;
  		display: flex;
		-webkit-flex-wrap: wrap; /* Safari 6.1+ */
		flex-wrap: wrap;
	}
 
	/*** custom classes that will designate the order of columns in the flex box row ***/
	.first-on-mobile {
		-webkit-order: 1;
		order: 1;
	}
 
	.second-on-mobile {
		-webkit-order: 2;
		order: 2;
	}
 
	.third-on-mobile {
		-webkit-order: 3;
		order: 3;
	}
	.fourth-on-mobile {
		-webkit-order: 3;
		order: 4;
	}
	/*** add margin to last column ***/
	.custom_row .et_pb_column:last-child{
		margin-bottom: 30px !important;
	}
	/*stack specialty section*/
	.et_section_specialty.reverse-columns-mobile .et_pb_row {
        display: flex;
        flex-direction: column-reverse !important;
    }
	.et_section_specialty.reverse-columns-mobile .et_pb_row>.et_pb_column.et-last-child, .et_section_specialty.reverse-columns-mobile .et_pb_row>.et_pb_column.et_pb_column_single {
        padding-bottom: 40px !important;
    }
}

/*-- FORM --*/
body .gform_wrapper.gravity-theme .gform_fields {
    grid-row-gap: 8px !important;
}
.gform_wrapper.gravity-theme .gfield_required {
	color: red;
}
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], .gform_wrapper.gravity-theme .gfield input, .gform_wrapper.gravity-theme .gfield select  {
    color: #000 !important;
	border-bottom:2px solid #0077C8!important;
	background-color: #fff !important;
	padding: 15px;
	border-radius:10px;
}
body .gform_wrapper.gravity-theme .gfield_label:not(.gform-field-label--type-sub){
	margin-top: 20px;
}
.gform_wrapper.gravity-theme .gf_progressbar{
	margin-bottom:25px;
}

.gform_wrapper.gravity-theme .gform_footer, .gform_wrapper.gravity-theme .gform_page_footer {
    padding: 0;
}

.gform_wrapper.gravity-theme fieldset{
	margin-top:20px;
}
.gform_required_legend{
	display:none;
}
.gform_wrapper.gravity-theme .gfield_consent_description {
	max-height:100% !important;
	overflow-y: hidden;
}
body .gform_wrapper .hidden_label textarea.textarea {
	margin: 10px 0 0!important;
}
body .gform_wrapper.gravity-theme .gform_fields {
    grid-column-gap: 4%;
	grid-row-gap: 23px;
}
.gform_wrapper.gravity-theme .description, .gform_wrapper.gravity-theme .gfield_description, .gform_wrapper.gravity-theme .gsection_description, .gform_wrapper.gravity-theme .instruction {
	font-size: 12px;
}

.form-white .gform_wrapper.gravity-theme .gfield select option {
    color: #fff !important;
	font-size:12px !important;
}
.form-white .gform_wrapper.gravity-theme .gf_progressbar_title {
    color: #fff;
    font-size: 18px;
 }
.form-white .gform_wrapper.gravity-theme .gf_progressbar_percentage.percentbar_blue {
	background-color: #fff;
}
.form-white .gform_wrapper.gravity-theme .gf_progressbar_percentage span{
	color:#3A5575;
}
/* Other Fields */
.gform_wrapper .gform_fields .gfield input::-webkit-input-placeholder {color: #666;}

/* Paragraph Text Area */
.gform_wrapper .gform_body .gform_fields .gfield textarea::-webkit-input-placeholder {color: #666;}

body .gform_wrapper .gform_footer, body .gform_wrapper .gform_page_footer {
    text-align: center;
}
body .gform_wrapper .gform_footer, body .gform_wrapper .gform_page_footer {
    text-align: center;
}
/* form button footer effect*/
.gform_wrapper .gform_footer {
	background:#0077C8;
	margin: 4% auto 0 !important;
	-webkit-transition: 800ms ease all;
	transition: 800ms ease all;
	overflow: hidden !important;
	max-width:260px !important;
	position:relative;
	z-index:9;
	max-height: 67px;
	padding:0 !important;
	border:1px solid #0077C8 !Important;
}

.gform_footer::before {
	height: 20%;
	left: 20px;
	top: 40%;
	transform-origin: top left;
	width: 0px;
	background: #012544;
	content: '';
	z-index: -1;
	transition: all .3s !important;
	display:block !important;
	opacity: 1 !important;
	position:absolute;
}
.gform_footer:hover::before{
	width: 135%;
	height:100%;
	transform: none;
	top:0;
	left:0;
}
body .gform_wrapper .gform_footer input.button{
	min-width: 260px;
	max-width: 260px;
	max-height: 60px;
	text-align: center;
	-webkit-transition: all .35s;
	transition: all .35s;
	border-radius:0 !important;
	background-color:transparent !important;	
	margin-top: 0;
	border:0 !Important;	
	min-height:60px;
	color:#fff !important;
}
body .gform_wrapper .gform_footer input.button:hover{
	background-color: rgba(0,0,0,.05) !important;
	border: 2px solid transparent;
	color:#fff !important;
}
body .gform_wrapper .gform_footer input.button:hover{
	border-radius:0 !Important;
	-webkit-transition: all 300ms ease 0ms !important;
	transition: all 300ms ease 0ms !important;
}
/*Subscribe*/
.subscribe-form .gform_wrapper .gform_footer {
    margin: 1% auto 0 !important;
    max-width: 100% !important;
}
body .subscribe-form .gform_wrapper .gform_footer input.button {
    min-width: 100%;
	max-width: 100%;
}
.subscribe-form .gform-body.gform_body {
    flex: auto;
    margin-right: 30px;
}
@media only screen and (min-width:481px){
	.subscribe-form form#gform_2 {
    	display: flex;
    	flex-direction: row;
    	align-items: flex-end;
	}
}
body .subscribe-form .gform_wrapper .gform_footer input.button{
	font-size:14px !important;
}
/*-- Normal Buttons --*/
body #page-container .et_pb_module .et_pb_button:not(.clean-buttons), body #page-container .et_pb_module .et_pb_button_module_wrapper .et_pb_button:not(.clean-buttons), body #page-container .et_pb_module .et_button_no_icon .et_pb_button:not(.clean-buttons){
   min-width:264px;
	text-align:center;
	padding:1.1em 1em !important;
	transition: 700ms ease all;
	overflow: hidden;
	z-index: 9;
}
body #page-container .et_pb_module .et_pb_button:not(.clean-buttons):hover, body #page-container .et_pb_module .et_pb_button_module_wrapper .et_pb_button:not(.clean-buttons):hover, body #page-container .et_pb_module .et_button_no_icon .et_pb_button:not(.clean-buttons):hover{
	padding:1.1em 1em !important;
	color:#fff !important;
}
body #page-container .et_pb_module .et_pb_button:not(.clean-buttons):before, body #page-container .et_pb_module .et_pb_button_module_wrapper .et_pb_button:not(.clean-buttons):before, body #page-container .et_pb_module .et_button_no_icon .et_pb_button:not(.clean-buttons):before{
   height: 20%;
    left: 0;
    top: 40%;
    transform-origin: top left;
    width: 0;
    background: #012544;
    content: '';
    z-index: -1;
    transition: all .3s !important;
    display: block !important;
    opacity: 1 !important;
	position: absolute;
    margin-left: -1em;
}
body #page-container .et_pb_module .et_pb_button:not(.clean-buttons):hover:before, body #page-container .et_pb_module .et_pb_button_module_wrapper .et_pb_button:not(.clean-buttons):hover:before, body #page-container .et_pb_module .et_button_no_icon .et_pb_button:not(.clean-buttons):hover:before{
    width: 135% !Important;
	height:100% !important;
	transform: none;
	top:0;
}

@media only screen and (max-width:980px) and (min-width:480px){
	body #page-container #et-boc .et_pb_module .et_pb_button, body #page-container .et_pb_module .et_pb_button_module_wrapper .et_pb_button, body #page-container #et-boc .et-l .et_pb_module .et_pb_button.et_pb_promo_button, body #page-container .et_pb_module .et_button_no_icon .et_pb_button, body #page-container .et_pb_module .et_pb_button.long-button{
		line-height:1.4em !important;
		padding: 0.50em 1.3em !important;
		min-width:auto !important;
	}
	body #page-container #et-boc .et_pb_module .et_pb_button:hover, body #page-container .et_pb_module .et_pb_button_module_wrapper .et_pb_button:hover, body #page-container #et-boc .et-l .et_pb_module .et_pb_button.et_pb_promo_button:hover, body #page-container .et_pb_module .et_button_no_icon .et_pb_button:hover{
		padding: 0.50em 1.3em !important;
	}
}
@media only screen and (max-width:481px){
	body #page-container .et_pb_module .et_pb_button, body #page-container .et_pb_module .et_pb_button_module_wrapper .et_pb_button, body #page-container #et-boc .et-l .et_pb_module .et_pb_button.et_pb_promo_button, body #page-container .et_pb_module .et_button_no_icon .et_pb_button, body #page-container .et_pb_module .et_pb_button.long-button{
		min-width:auto !important;
	}
}
/*-- long button--*/
body #page-container .et_pb_module .et_pb_button.long-button{
	max-width: 439px !important;
    width: 100%;
}
/*--white--*/
.button-menu a:before{
	background:#fff !Important;
}
.et_pb_button_module_wrapper .et_pb_button.button-white{
	color:#1A1818 !Important;
	border-color:#00A1ED;
}
.et_pb_button_module_wrapper .et_pb_button.button-white:hover{
	color:#fff !Important;
}

/*footer*/

.footer-bottom .et_pb_column{
	display:flex;
	flex-direction:row;
	justify-content:space-between;
	align-items:center;
}
.et-db #et-boc .et-l .menu-footer .sub-menu{
	display:none;
}
.et-db #et-boc .et-l .menu-footer .fwidget.et_pb_widget{
	width:100% !important;
	margin-left:0;
	margin-bottom:0;
	margin-right:0;
}
.et-db #et-boc .et-l .menu-footer ul.menu{
	display:flex;
	flex-direction:row;
	justify-content: space-between;
	align-items: center;
}
.et-db #et-boc .et-l .menu-footer ul.menu li{
	padding-left:16px;
	padding-right:16px;
}
.et-db #et-boc .et-l .menu-footer ul.menu li::last-child{
	padding-right:0;
}
.et_pb_social_media_follow_0_tb_footer li a.icon, .et_pb_social_media_follow_0_tb_footer li a.icon:before {
    width: 56px !important;
}
@media only screen and (min-width:981px){
	.footer-copy{
    	flex: 1 1 30%;
	}
	.menu-footer.et_pb_widget_area{
    	flex: 1 1 46%;
	}
	.et_pb_widget ol li, .et_pb_widget ul li {
    margin-bottom: 0;
}
	.et_pb_module.footer-privacy{
    	flex: 1 1 20%;
	}
}
@media only screen and (max-width:1602px){
	.menu-footer li a, .copyright_text, .footer-privacy{
		white-space:auto;
	}
}
@media only screen and (max-width:1642px){
	.menu-footer li a, .copyright_text, .footer-privacy{
		font-size:16px !important;
		white-space:nowrap;
	}
}
@media only screen and (max-width:1310px){
	.menu-footer li a, .copyright_text, .footer-privacy{
		font-size:14px !important;
		white-space:nowrap;
	}
}
@media only screen and (max-width:1292px){
	footer .widget-text {
		font-size:16px !important;
		white-space:nowrap;
	}
	footer .widget-title{
		font-size:20px !important;
	}
	.widget-row{
		width:90% !important;
	}
}
@media only screen and (max-width:516px) and (min-width:481px){
	footer .widget-text {
		font-size:14px !important;
		white-space:nowrap;
	}
}
@media only screen and (max-width:1181px) and (min-width:981px){
	.footer-bottom{
		width:95% !important;
	}
	.et_pb_widget_area_left{
		padding-right:10px !important;
	}
	.et-db #et-boc .et-l .menu-footer ul.menu li {
    	padding-left: 10px;
   	 	padding-right: 10px;
	}
	.widget-row .et_pb_column{
		width: 47.25% !important;
		margin-right: 2% !important;
	}
	.widget-row {
		flex-wrap: wrap;
	}
	.widget-title, .widget-text{
		text-align:center !important;
	}
	.social-media-footer{
		text-align: center !important;
	}
	.custom_row.widget-row{
		display: -webkit-box;
        display: -moz-box;
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
        -webkit-flex-wrap: wrap;
        flex-wrap: wrap;
	}
	.custom_row.widget-row .first-on-mobile {
		-webkit-order: 1;
		order: 1;
	}
 
	.custom_row.widget-row .second-on-mobile {
		-webkit-order: 2;
		order: 2;
	}
	.custom_row.widget-row .third-on-mobile {
		-webkit-order: 3;
		order: 3;
	}
	.custom_row.widget-row .fourth-on-mobile {
		-webkit-order: 3;
		order: 4;
	}
	/*** add margin to last column ***/
	.custom_row.widget-row .custom_row .et_pb_column:last-child{
		margin-bottom: 30px !important;
	}
}
@media only screen and (max-width:1181px){
	.et-db #et-boc .et-l .menu-footer ul.menu{
    	justify-content: center;
 	}
	.et-db #et-boc .et-l .menu-footer ul.menu li.menu-button a{
		min-width:auto !important;
	}
	.footer-bottom .et_pb_column{
		flex-direction:column;
	}
	.et-db #et-boc .et-l .footer-privacy{
		margin-bottom:20px !important;
		order:2;
	}
	.et-db #et-boc .et-l .menu-footer{
		margin-bottom:20px !important;
		order:1;
	}
	.et-db #et-boc .et-l .footer-copy{
		order:3;
	}
}
@media only screen and (max-width:780px){
	.et-db #et-boc .et-l .menu-footer ul.menu{
    	flex-direction:column;
 	}
}
/*corners*/
.corner-top-right:after {
    border-right: 20px solid #0077C8;
    border-top: 20px solid #0077C8;
    right: -20px;
    top: -20px;
	width: 140px;
    height: 140px;
    content: "";
    display: block !important;
    position: absolute;
    opacity: 1 !important;
    margin: auto !important;
    -webkit-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
    transition: all 0.3s;
}
.corner-top-left:before {
    border-left: 20px solid #0077C8;
    border-top: 20px solid #0077C8;
    left: -20px;
    top: -20px;
	width: 140px;
    height: 140px;
    content: "";
    display: block !important;
    position: absolute;
    opacity: 1 !important;
    margin: auto !important;
    -webkit-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
    transition: all 0.3s;
}
.corner-bottom-left:before {
	border-left: 20px solid #0077C8;
    border-bottom: 20px solid #0077C8;
    left: -20px;
    bottom: -20px;
	width: 140px;
    height: 140px;
    content: "";
    display: block !important;
    position: absolute;
    opacity: 1 !important;
    margin: auto !important;
    -webkit-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
    transition: all 0.3s;
}

@media only screen and (max-width:980px){
	.corner-bottom-left:before {
		border-left: 20px solid #0077C8;
    	border-top: 20px solid #0077C8;
		border-bottom:0;
    	left: -20px;
    	top: -20px;
		bottom:auto;
	}
	.corner-top-right:after {
    	border-right: 20px solid #0077C8;
    	border-bottom: 20px solid #0077C8;
		border-top:0;
    	right: -20px;
		bottom: -20px;
		top:auto;
	}
	.corner-top-left:before{
		border-right: 20px solid #0077C8;
    	border-bottom: 20px solid #0077C8;
		border-top:0;
    	left: -20px;
		bottom: -20px;
		top:auto;
	}
}

.slim-corners:after {
   border-right: 5px solid #0077C8;
    border-top: 5px solid #0077C8;
    right: -5px;
    top: -5px;
    width: 100px;
    height: 100px;
    content: "";
    display: block !important;
    position: absolute;
    opacity: 1 !important;
    margin: auto !important;
    -webkit-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
    transition: all 0.3s;
} 
.slim-corners:before {
	border-left: 5px solid #0077C8;
    border-bottom: 5px solid #0077C8;
    left: -5px;
    bottom: -5px;
	width: 100px;
    height: 100px;
    content: "";
    display: block !important;
    position: absolute;
    opacity: 1 !important;
    margin: auto !important;
    -webkit-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
    transition: all 0.3s;
}
/* Home*/
.header-home .et_pb_module_header{
	margin-bottom:20px;
}
.header-home .et_pb_header_content_wrapper{
	margin-bottom:30px;
}
.header-home.et_pb_fullwidth_header .et_pb_fullwidth_header_container.center .header-content{
	max-width:702px;
}
@media only screen and (max-width:980px){
	.header-home.et_pb_fullwidth_header.et_pb_fullscreen, .header-home.et_pb_fullwidth_header.et_pb_fullscreen .et_pb_fullwidth_header_container {
		min-height: 50vh !important;
	}
}
@media only screen and (max-width:480px){
	.et_pb_fullwidth_header .et_pb_fullwidth_header_container.center .header-content {
    	width: 100%;
    max-width: 100%;
	}
}
/*quote row*/
@media only screen and (min-width:981px){
	.quote-flex{
		display:flex;
		flex-direction:row;
		justify-content:space-between;
		align-items:center;
	}
	.quote-image{
		flex: 1 1 15%;
		margin-right:5%;
	}
	.quote-text{
		flex: 1 1 80%;
	}
}
/*our work boxes*/
.image-boxes .et_pb_image_wrap{
	background:rgba(1,37,68,0.4);
	width: 100%;
}
@media only screen and (max-width:1320px){
	body #page-container .image-box-description{
		padding-left:15px !important;
		padding-right:15px !important;
	}	
}
@media only screen and (max-width:1154px) and (min-width:981px){
	body #page-container .image-boxes-row{
		-ms-flex-wrap: wrap;
        flex-wrap: wrap;
	}
	body #page-container .image-boxes-row .et_pb_column{
		width: 47.25%;
        margin-right: 5.5%;
		margin-bottom: 30px;
	}
	body #page-container .image-boxes-row .et_pb_column:nth-child(2n) {
        margin-right: 0;
    }
	body #page-container .image-boxes-row .et_pb_column:nth-last-child(-n+2) {
        margin-bottom: 0;
    }
	body #page-container .image-boxes-row .corner-bottom-left:before {
		border-left: 20px solid #0077C8;
    	border-top: 20px solid #0077C8;
		border-bottom:0;
    	left: -20px;
    	top: -20px;
		bottom:auto;
	}
	body #page-container .image-boxes-row .corner-top-right:after {
    	border-right: 20px solid #0077C8;
    	border-bottom: 20px solid #0077C8;
		border-top:0;
    	right: -20px;
		bottom: -20px;
		top:auto;
	}
}
/*featured video*/
.video-featured-skin:before{
	content:"";
	width:98%;
	max-width:1640px;
	margin-left:auto;
	margin-right:auto;
	height:100%;
	position:absolute;
	display:block;
	/*background:url(/wp-content/uploads/white-video-borders.png);*/
	background-size: 100% 86%;
    background-position: center;
	background-repeat: no-repeat;
	left:0;
	right:0;
	top:0;
	bottom:0;
}
.video-featured-skin{
    display: flex;
    flex-direction: column;
    justify-content: end;
    height: 100%;
}
.video-featured-skin .et_pb_blurb_content {
    max-width: 100%;
    height: calc(100% - 50%);
    display: flex;
    flex-direction: column;
   justify-content: space-between;
    align-items: stretch;
    align-items: stretch;
	margin-bottom:2vw;
}
.video-featured-skin .et_pb_module_header, .video-featured-skin .et_pb_blurb_description {
    margin-bottom: 0 !important;
	width: 80%;
    margin: auto;
}
.video-popup a{
	width:100%;
	height:100%;
}
@media only screen and (max-width:767px){
	.video-featured-skin .et_pb_blurb_content {
    	height: 50vw;
	}
	.video-featured-skin .et_pb_blurb_content {
		margin-bottom:4vh;
	}
}

/*Internals*/
/*@media only screen and (max-width:1564px) and (min-width:981px){
	.et_pb_column.header-content-column{
		width:50% !important;
	}
	.et_pb_column.header-image{
		width:50% !important;
	}
}*/
@media only screen and (max-width:1576px) and (min-width:981px){
	.header-content-column h1{
    	font-size: 5vw !important;
	}
}
/*page title two colors*/
body .accent-title.light h1 em, body .accent-title.light h2 em, body .accent-title.light h3 em, body .accent-title.light h4 em, body .accent-title.light h5 em, body .accent-title.light h6 em, body .accent-text.light em{
	color:#fff !important;
}
body .accent-title h1 em, .accent-title h2 em, body .accent-title h3 em, body .accent-title h4 em, body .accent-title h5 em, body .accent-title h6 em, body .accent-text em{
	color:#0077C8 !important;
}

/*bug transparent menu*/
.two-col-page-header.et_pb_section_first {
    padding-top: 0 !important;
}

/*internal pages header banner*/

.fullwidth-fullheight-image img {
 object-fit: cover; 
    height: 100%;
	width:100% !important;
}
.fullwidth-fullheight-image {
    width: 100%;
    height: 100%;
}
.fullwidth-fullheight-image .et_pb_image_wrap  {
    height: 100%;
}
.fullwidth-fullheight-image:before{
	content:"";
	display:block;
	position:absolute;
	width:100%;
	height:100%;
	background:#2D2926;
	opacity:0.1;
	z-index:1;
}
.about-timeline.dipi_content_slider .content-slider-gradations-wrapper:before{
	content:"";
	display:block;
	width: 16px;
    height: 16px;
    border-style: solid;
	border-radius: 50%;
    border: 3px solid #D9D9D9;
    background: #fff;
    display: block;
    position: absolute;
    top: -5%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    -webkit-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
	z-index: 1;
}
.about-timeline.dipi_content_slider .content-slider-item.active  .content-slider-gradations-wrapper:before{
	border-color:#0077C8;
}
@media only screen and (max-width:874px){
	.about-timeline.dipi_content_slider .content-slider-label {
		font-size: 12px;
		padding-right: 1px!important;
		padding-left: 1px!important;
	}
	.about-timeline.dipi_content_slider .dipi-content-slider{
		max-width:740px;
		width:90%;
		margin:auto;
	}
}
@media only screen and (max-width:674px){
	.about-timeline.dipi_content_slider .content-slider-label {
		font-size: 10px;
		padding-right: 1px!important;
		padding-left: 1px!important;
	}
	.about-timeline.dipi_content_slider .dipi-content-slider{
		max-width:440px;
		width:90%;
		margin:auto;
		overflow-x: auto;
        overflow-y: hidden;
        padding: 20px;
	}
}
@media only screen and (max-width:480px){
	.about-timeline.dipi_content_slider .content-slider-label {
		font-size: 9px;
		padding-right: 1px!important;
		padding-left: 1px!important;
	}
	.about-timeline.dipi_content_slider .dipi-content-slider{
		max-width:400px;
		width:90%;
		margin:auto;
		overflow-x: auto;
        overflow-y: hidden;
        padding: 20px;
	}
}
/*team*/
.vertical-team .et_pb_team_member_image{
	margin-left:auto;
	margin-right:auto;
}
.vertical-team .et_pb_module_header {
    margin-bottom: 0;
    margin-top: 20px;
}
.vertical-team{
    display: flex;
    flex-direction: column;
}
@media only screen and (min-width:361px){
.flex-row-container .et_pb_column{
    	display: flex;
    	flex-direction: row;
    	flex-wrap: wrap;
		justify-content:center;
		grid-column-gap: 2%;
		grid-row-gap: 30px;
	}
}
@media only screen and (min-width:1086px){
	.flex-row-container .et_pb_column .vertical-team{
		flex-basis: 14.75%;
		-webkit-box-align: center;
   		-ms-flex-align: center;
   		align-items: center;
		margin-bottom:20px !important;
		display: flex;
        flex-direction: column;
	}
	.flex-row-container .et_pb_column .logos{
		flex-basis: 15.75%;
		-webkit-box-align: center;
   		-ms-flex-align: center;
   		align-items: center;
		align-self:center;
		margin-bottom:20px !important;
		display: flex;
        flex-direction: column;
	}	
}
@media only screen and (max-width:1085px) and (min-width:981px){
	.flex-row-container .et_pb_column .vertical-team{
		flex-basis: 22.75%;
		-webkit-box-align: center;
   		-ms-flex-align: center;
   		align-items: center;
		margin-bottom:20px !important;
		display: flex;
        flex-direction: column;
	}
	.flex-row-container .et_pb_column .logos{
		flex-basis: 14.75%;
		-webkit-box-align: center;
   		-ms-flex-align: center;
   		align-items: center;
		align-self:center;
		margin-bottom:20px !important;
		display: flex;
        flex-direction: column;
	}	
}
@media only screen and (max-width:980px) and (min-width:552px){
		.flex-row-container .et_pb_column .vertical-team{
			flex-basis: 29.25%;
			-webkit-box-align: center;
   			-ms-flex-align: center;
   			align-items: center;
			margin-bottom:0 !important;
		}
		.flex-row-container .et_pb_column {
    		grid-column-gap: 5.5%;
		}
	.flex-row-container .et_pb_column .logos{
    	display: flex;
    	flex-direction: column;
    	justify-content: center;
    	align-items: center;
		align-self:center;
		 width: 14.75%;
        margin: 0 0 30px;
	}
}
@media only screen and (max-width:551px) and (min-width:361px){
		.flex-row-container .et_pb_column .vertical-team{
			flex-basis: 45.25%;
			-webkit-box-align: center;
   			-ms-flex-align: center;
   			align-items: center;
			margin-bottom:0 !important;
		}
		.flex-row-container .et_pb_column {
    		grid-column-gap: 5.5%;
	}
	.flex-row-container .et_pb_column .logos{
    	display: flex;
    	flex-direction: column;
    	justify-content: center;
    	align-items: center;
		align-self:center;
		 width: 33.33%;
        margin: 0 0 30px;
	}
}
@media only screen and (max-width:360px){
	.flex-row-container .et_pb_column .vertical-team{
    	display: flex;
    	flex-direction: column;
    	justify-content: center;
    	align-items: center;
		 width: 100%;
        margin: 0 0 30px;
	}
}
@media (max-width: 479px) {
	.flex-row-container .et_pb_column .logos{
    	display: flex;
    	flex-direction: column;
    	justify-content: center;
    	align-items: center;
		align-self:center;
		 width: 33.33%;
        margin: 0 0 30px;
	}
	.flex-row-container.logos-garden .et_pb_column{
    	display: flex;
    	flex-direction: row;
    	flex-wrap: wrap;
		justify-content:center;
		grid-column-gap: 3%;
		grid-row-gap: 30px;
	}
}
/*blurbs cta*/
.blurb-cta .et_pb_column{
	display:flex;
	flex-direction:column;
}
.blurb-cta .et_pb_button_module_wrapper{
	margin-top:auto !important;
}
body #page-container .blurb-cta .et_pb_button_module_wrapper .et_pb_button{
	min-width:80% !important;
}
/*CTA*/
.et_pb_promo .et_pb_module_header {
	margin-bottom: 25px;
}
.et_pb_promo .et_pb_button_wrapper{
	margin-top:25px;
}
@media only screen and (min-width:1120px){
	.two-cols ul {
    	columns: 2;
	}
}
@media only screen and (max-width:1120px) and (min-width:668px){
	.two-cols ul {
    	columns: 2;
	}
}
@media only screen and (max-width:1360px) and (min-width:1120px){
	.small-screen-adjust:not(.custom_row) .et_pb_column, .small-screen-adjust.custom_row .et_pb_column.et-last-child{
		width:57.5% !important;
	}
	.small-screen-adjust:not(.custom_row) .et_pb_column.et-last-child, .small-screen-adjust.custom_row .et_pb_column{
		width: 39.5% !important;
	}
	.small-screen-adjust{
		font-size:16px !important;
	}
}
@media only screen and (max-width:1120px) and (min-width:981px){
	.small-screen-adjust{
		flex-direction:column;
	}
	.small-screen-adjust.custom_row {
  		flex-direction:column-reverse;
	}
	.small-screen-adjust .second-on-mobile {
		-webkit-order: 2;
		order: 2;
		margin-bottom:0;
	}
	.small-screen-adjust:not(.custom_row) .et_pb_column, .small-screen-adjust.custom_row .et_pb_column.et-last-child{
		width:100% !important;
		margin-bottom: 30px;
	}
	.small-screen-adjust:not(.custom_row) .et_pb_column.et-last-child, .small-screen-adjust.custom_row .et_pb_column{
		width: 100% !important;
	}
	.small-screen-adjust .corner-bottom-left:before {
		border-left: 20px solid #0077C8;
    	border-top: 20px solid #0077C8;
		border-bottom:0;
    	left: -20px;
    	top: -20px;
		bottom:auto;
	}
	.small-screen-adjust .corner-top-right:after {
    	border-right: 20px solid #0077C8;
    	border-bottom: 20px solid #0077C8;
		border-top:0;
    	right: -20px;
		bottom: -20px;
		top:auto;
	}
	.small-screen-adjust .corner-top-left:before{
		border-right: 20px solid #0077C8;
    	border-bottom: 20px solid #0077C8;
		border-top:0;
    	left: -20px;
		bottom: -20px;
		top:auto;
	}
}
/*Featured project*/
.featured-project-module .et_pb_post .entry-featured-image-url{
	margin-bottom:0;
}
.featured-project-module .et_pb_post .post-media .et_overlay{
	background-image: url(/wp-content/uploads/white-featured-borders-1.png), linear-gradient(180deg, rgba(33, 31, 31, 0) 0%, rgba(1, 37, 68, 0.77) 92%);
	opacity: 1 !important;
	z-index:1 !important;
	border:0 !important;
    background-position: center;
    background-repeat: no-repeat;
	background-size:108% 100%;
	
}
/*overlay filtergrid*/
.featured-project-module .dp-dfg-item .dp-dfg-overlay{
	display: block !important;
    width: 100%;
    height: 100%;
    position: absolute ! IMPORTANT;
    top: 0;
    left: 0;
	background:rgba(0, 0, 0, 0.45);
	/*background-image: url(/wp-content/uploads/white-featured-borders-1.png), linear-gradient(180deg, rgba(33, 31, 31, 0) 0%, rgba(1, 37, 68, 0.80) 92%);*/
	opacity: 1 !important;
	border:0 !important;
    background-position: center;
    background-repeat: no-repeat;
	background-size:108% 100%;
}
/*end*/
.featured-project-module .et_pb_post .post-content-inner {
    margin-bottom: 30px;
}
body #page-container .featured-project-module .et_pb_post {
	margin-bottom: 0 !important;
}
.featured-project-module .et_pb_post a img, .featured-project-module .dp-dfg-primary{
    width: 100%;
	height:100%;
    max-height: 700px;
    overflow: hidden;
}
.featured-project-module .post-content-all, .featured-project-module .dp-dfg-secondary {
    position: absolute;
    bottom: 0;
	width:100%;
    padding: 30px 10px;
	text-align:center;
	left: 50%;
    transform: translate(-50%, 0);
	z-index:3;
	background:rgba(255,255,255,0) !important;
	height:auto !important;
 }
.featured-project-module a.more-link{
	color:#fff !important;
	font-weight:600;
	text-transform:uppercase;
}
.featured-project-module a.more-link:hover{
	color:#dbe2e9 !important;
}
.featured-project-module .dp-dfg-custom-content {
    margin-bottom: 20px !important;
}
@media only screen and (max-width:980px){
	.featured-project-module .dp-dfg-custom-content {
    	margin-bottom: 10px !important;
	}
}
@media only screen and (max-width:767px){
	.featured-project-module .dp-dfg-primary{
		min-height:400px;
	}
	.featured-project-module .dp-dfg-primary img{
		height:400px;
		object-fit:cover;
	}
}
/*project gallery*/

.et-l--body ul.slick-slider{
	padding:0 !important;
}
.sb-slider {
	transition: 0.2s all ease-in-out !important;
	margin-bottom:10px;
}
.sb-slider img {
     width: 100%;
}

ul.slick-dots {
    text-align: center;
	padding-top:20px;
}
.slick-dots li {
	position: relative;
	display: inline-block;
	margin: 0px;
	padding: 0;
	cursor: pointer;
}

.slick-dots li.slick-active button { 
	background-color: #000000; 
}

@media (min-width: 981px) {
	.slick-dots li button {
		font-size: 0;
		line-height: 0;
		display: block;
		width: 12px;
		height: 12px;
		padding: 0;
		cursor: pointer;
		color: transparent;
		border: 0;
		outline: none;
		background-color: #dddddd;
		border-radius: 0px;
		margin-left: 3px;
		margin-right: 3px;
	}
}

@media (max-width: 980px) {
	.slick-dots li button {
		font-size: 0;
		line-height: 0;
		display: block;
		width: 12px;
		height: 12px;
		padding: 0;
		cursor: pointer;
		color: transparent;
		border: 0;
		outline: none;
		background-color: #dddddd;
		border-radius: 0px;
		margin-left: 3px;
		margin-right: 3px;
	}
}

.slick-slider {
	max-width:980px;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -khtml-user-select: none;
  ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  display: block;
  overflow-x: hidden;
  margin: 0;
  padding: 0;
}

.slick-track:before, 
.slick-track:after {
  display: table;
  content: '';
}
  
.slick-slide {
  position: relative;
  float: left;
  height: 100%;
  min-height: 1px;
}

.slick-prev {
	display: block !important;
    padding: 0px;
    background-color: rgba(255,255,255,0.9);
    position: absolute;
    top: 37%;
    left: 0;
    margin: 0px;
    border: none;
    font-size: 0;
    line-height: 0;
    background-size: contain;
    background-position-x: center;
    border-radius: 0px;
    z-index: 999;
    cursor: pointer;
    transition: 0.2s all ease-in-out !important;
}

.slick-next {
	display: block !important;
    padding: 0px;
    background-color: rgba(255,255,255,0.9);
    position: absolute;
    top: 37%;
	right: 0;
	margin: 0px;
    border: none;
    font-size: 0;
	line-height: 0;
    background-size: contain;
    background-position-x: center;
    border-radius: 0px;
	z-index: 999;
	cursor: pointer;
	transition: 0.2s all ease-in-out !important;
}


.slick-prev:before {
	font-family: "ETmodules" !important;
	content: '\34';
	color: #000000 !important;
	font-size: 40px;
    line-height: 1;
    opacity: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
	transition: 0.2s all ease-in-out !important;
}

.slick-next:before {
	font-family: "ETmodules" !important;
	content: '\35';
	color: #000000 !important;
	font-size: 40px;
    line-height: 1;
    opacity: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
	transition: 0.2s all ease-in-out !important;
}
.slider-nav .slide.slick-slide:not(.slick-current) {
    opacity: 0.5;
}
.slider-nav img{
	padding:0 1px !important;
    /*height: 147px;*/
	height:100%;
    width: 100%;
    object-fit: cover;
}
.slider-nav video.nav-vid {
    padding: 0 1px !important;
    /*height: 250px;*/
	height:100%;
    width: 100%;
    object-fit: cover;
}
.slider-nav .video-wrapper:before{
	content: "";
    width: 2vw;
    height: 2vw;
    margin-right: auto;
	margin-left:auto;
    display: block;
    position: absolute;
  	left: 50%;
  	transform: translateX(-50%) translateY(-50%);;
	top: 50%;
    background: url(/wp-content/uploads/2024/11/play-icon.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    vertical-align: -3px;
}
.slick-track {
    display: flex;
    align-items: center;
}

.slick-track .slick-slide {
    display: flex;
       /*height: auto;*/
	height: inherit;
	justify-content: center;
	align-items:center;
}
.slick-slide {
    margin-bottom: 0;
    object-fit: cover;
}
.slider-nav  .slick-track .slick-slide div{
	height:100%;
}
.slick-track li.slide {
    height: 100%;
}
/*project video hide/show fullwidth if empty*/
/* Make the gallery column full-width */
.media-row.video-empty .gallery-column {
    width: 100% !important; /* Ensure it takes up the full width */
    max-width: 100% !important; /* Remove any max-width restrictions */
    margin-right: 0 !important; 
}

/* Optional: Adjust the other column to not conflict with the full-width gallery */
.media-row.video-empty .video-column {
    display: none !important; /* Keep it hidden if it's empty, or adjust as necessary */
}
.media-row.video-empty .slick-slider {
	max-width:100%;
}
/*-- NEWS HOVER --*/
.news-grid .dp-dfg-layout-grid .dp-dfg-item {
    display: flex;
    flex-direction: column;
}
.news-grid .dp-dfg-skin-default .dp-dfg-meta{
	padding: 30px 25px 5px;
}
.news-grid .dp-dfg-item .dp-dfg-header.entry-header{
    padding: 0 25px 0;
    margin-bottom: auto;
}
.news-grid .dp-dfg-item .et_pb_button_wrapper.read-more-wrapper {
    margin-left: 25px;
    margin-top: auto;
    margin-right: 25px;
}
body #page-container .news-grid .dp-dfg-item .et_pb_button.dp-dfg-more-button {
    min-width: auto !important;
    padding: 20px 0 0!important;
    text-align: left;
}
.news-grid .dp-dfg-item .et_pb_button_wrapper.read-more-wrapper {
    margin-top: auto;
}
.news-grid .dp-dfg-item:hover{
	border-bottom:0 !important;
	background: #012544 !important;
    color: #fff !important;
}
.news-grid .dp-dfg-item:hover .dp-dfg-secondary{
	background: #374e6a !important;
    color: #fff !important;
}
.news-grid .dp-dfg-item:hover .dp-dfg-header .entry-title, .news-grid .dp-dfg-item:hover .dp-dfg-content.entry-summary, body #page-container .news-grid.dpdfg_filtergrid .dp-dfg-item:hover .read-more-wrapper .et_pb_button.dp-dfg-more-button, .news-grid .dp-dfg-item:hover .et_pb_button.dp-dfg-more-button:after{
	color:#fff !important;
}
.news-grid .dp-dfg-item{
	box-shadow: 0px 2px 0px 0px rgba(255,255,255,0);
}
.news-grid .dp-dfg-item:hover{
    box-shadow: 0px 2px 0px 0px #fff;
}
.news-grid .dp-dfg-pagination {
    margin-top: 30px;
}
.newsletter .dp-dfg-item .dp-dfg-header.entry-header{
    padding: 25px;
    margin-bottom: auto;
}
.newsletter .dp-dfg-item:hover{
    box-shadow: 0px 2px 0px 0px #0077C8;
}
/*jump header fix*/
@media only screen and (min-width:981px){
	body:not(.admin-bar) #main-header{
		top:0;
	}
	.et_pb_section.header-internals.et_pb_section_first{
		padding-top:209px !important;
	}
}
/*sup*/
sup {
  font-size: 12px;
}
/*accordion*/
.accordion_content strong{
	color:#0077C8;
}
body:not(.et-fb) .rv_element { display: none; }
.et_pb_button.rv_button_opened:after { content:"\32"; }
.et_pb_button.rv_button_closed:after { content:"\33"; }
.accordion_content {
    -webkit-columns: 3;
    -moz-columns: 3;
    columns: 3;
    padding: 0;
}
@media screen and (max-width: 767px) {
    .accordion_content {
        -webkit-columns: 1;
        -moz-columns: 1;
        columns: 1;
    }
}

/*carousel*/
/*slick equal slides height*/
.fullwidth-carousel .slick-slide{
	height: inherit !important;
	min-height:100%;
}

.fullwidth-carousel .slick-list .slick-track {
    display: flex !important;
    flex-direction: row;
    align-items: center;
}
.fullwidth-carousel .et_pb_image{
	padding-left:10px;
	padding-right:10px;
	margin-left:auto;
	margin-right:auto;
	width:80% !important;
	text-align:center;
}
.fullwidth-carousel.slick-slider{
	max-width:1664px !important;
}
.logos {
    margin-bottom: 0 !important;
}
.logos .et_pb_image_wrap {
	max-width: 80%;
}
.logos img{
	width:auto !important;
	margin:auto !important;
}
.logos{
	margin-bottom:0 !important;
}
