/* 
Theme Name: Hello Elementor Child
Theme URI: https://github.com/elementor/hello-theme-child/
Description: Hello Elementor Child is a child theme of Hello Elementor, created by Elementor team
Author: Elementor Team
Author URI: https://elementor.com/
Template: hello-elementor
Version: 2.0.0
Text Domain: hello-elementor-child
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/

/* Add your custom styles here */

/* This adds a hover color to the icon with text element on the Top Header */
div.elementor-element.top_header_icon_text.elementor-widget-icon-box .elementor-icon-box-title a:hover {
	color: var( --e-global-color-14ef391 );
	transition: 0.4s;
}

/* This fixes the position for the icon and the description on the icon with text element on the Top Header */
div.elementor-element.top_header_icon_text.icon_fix.elementor-widget-icon-box .elementor-icon-box-icon {
	margin-top: 5px;
}
div.elementor-element.top_header_icon_text.elementor-widget-icon-box .elementor-icon-box-description {
	margin: -3px 0px 0px 5px;
}

/* This changes the margin Top Header section for Mobile resolutions */
@media only screen and (max-width: 767px) {
	header.elementor section.elementor-section.top_header_section .elementor-container {
		margin-left: 0px;
	}
}

/* This slightly adjusts the Facebook icon on the Top Header */
div.elementor-element.top_header_social a.elementor-social-icon-facebook-f i.fab.fa-facebook-f::before {
	margin-top: -2px;
}

/* This hides the Instagram icon on the Top Header */
div.top_header_social div.elementor-social-icons-wrapper span.elementor-grid-item:last-child {
	display: none;
}

/* This aligns the social icons on the Top Header for Tablet and Mobile resolutions */
@media (min-width: 768px) and (max-width: 1024px) {
	div.elementor-element.top_header_social {
		position: absolute;
		top: 3px;
		right: 6px;
	}
}
@media only screen and (max-width: 767px) {
	div.elementor-element.top_header_social {
		position: absolute;
		top: 3px;
		right: 2px;
	}
}

/* This sets the width and height for the Header Logo element */
div.elementor-element.header_logo {
	width: auto;
	height: auto;
}
@media only screen and (max-width: 359px) {
		div.elementor-element.header_logo {
		margin-left: -19px;
	}
	div.elementor-element.header_logo img {
		transform: scale(0.85);
	}
}

/* This styles the drop-down underline for the Header Navigation */
div.elementor-element.header_nav nav.elementor-nav-menu--main  ul.elementor-nav-menu li.menu-item  a.elementor-item::after {
	background-color: #4A83FD9E !important;
	transform: rotate(90deg);
	height: 2px;
	width: 20px;
	bottom: -15px;
	transition: .5s;
	left: 0px;
	right: 0px;
	margin: auto;
}

/* This changes the font-weight on the active tab for the Header Navigation */
div.elementor-element.header_nav nav.elementor-nav-menu--main  ul.elementor-nav-menu li.menu-item  a.elementor-item.elementor-item-active {
	font-weight: 800;
}

/* This changes the padding on the Top Header section and on the Header Section for small resolution Laptop screens */
@media (min-width: 1025px) and (max-width: 1200px) {
	header.elementor section.elementor-section.top_header_section {
		padding: 0px 30px 0px 20px;
	}
}
@media (min-width: 1025px) and (max-width: 1200px) {
	header.elementor section.elementor-section.header_section {
		padding: 0px 30px 0px 40px;
	}
}

/* This styles the Burger Menu toogle icon for the Header Menu on Tablet and Mobile resolutions */
@media (min-width: 768px) and (max-width: 1024px) {
	.header_nav {
    	--gap: 8px;
    	--width: 38px;
	}
}
@media only screen and (max-width: 767px) {
	.header_nav {
    	--gap: 8px;
    	--width: 30px;
	}
}
.header_nav .elementor-menu-toggle {
    position: relative;
    background-color: transparent;
}
.header_nav .elementor-menu-toggle:before {
        --weight: 1px;
}
.header_nav .elementor-menu-toggle:after {
        --weight: 3px;
}
.header_nav .elementor-menu-toggle i:after {
        --weight: 2px;
}
.header_nav .elementor-menu-toggle:before,
.header_nav .elementor-menu-toggle:after,
.header_nav .elementor-menu-toggle i:after {
    content: "";
    height: var(--weight);
    width: var(--width);
    position: absolute;
    background: currentColor;
    top: 50%;
    left: 50%;
    transform: translate(-50%,calc(-50% + var(--gap)));
    transition: all 0.3s ease-in-out;
}
.header_nav .elementor-menu-toggle.elementor-active:before {
    transform: translate(-50%,-50%) rotate(-45deg);
    --weight: 2px;
}
.header_nav .elementor-menu-toggle:after {
    transform: translate(-50%,calc(-50% - var(--gap)));
}
.header_nav .elementor-menu-toggle.elementor-active:after {
    transform: translate(-50%,-50%) rotate(45deg);
    --weight: 2px;
}
.header_nav .elementor-menu-toggle i:after {
    transform: translate(-50%,-50%);
}
.header_nav .elementor-menu-toggle i:before,
.header_nav .elementor-menu-toggle.elementor-active i:after {
    opacity: 0;
}

/* This makes the Drop-Down Header Menu take up the full screen and hides the scrollbar on Tablet and Mobile resolutions */
.header_nav.elementor-nav-menu--toggle .elementor-menu-toggle.elementor-active + .elementor-nav-menu__container {
	position: fixed;
    height: 100%;
    max-height: 100%;
	top: auto !important;
    scroll-behavior: smooth;
	-ms-overflow-style: none;
	scrollbar-width: none;
}
.header_nav.elementor-nav-menu--toggle .elementor-menu-toggle.elementor-active + .elementor-nav-menu__container::-webkit-scrollbar {
  display: none;
}

/* This changes the animation speed for the Drop-Down Header Menu on Tablet and Mobile resolutions */
.header_nav nav.elementor-nav-menu--dropdown.elementor-nav-menu__container {
	transition: max-height .6s,transform .0s;
}

/* This changes the hover speed, width and positions the Drop-Down Header Menu tabs on Tablet and Mobile resolutions */
.header_nav nav.elementor-nav-menu--dropdown.elementor-nav-menu__container .elementor-nav-menu a {
	transition: .3s ease-in-out;
	width: fit-content;
	margin: auto;
}

/* This adds padding to the Drop-Down Header Menu on Tablet and Mobile resolutions */
@media only screen and (max-width: 1024px) {
	.header_nav nav.elementor-nav-menu--dropdown.elementor-nav-menu__container {
		z-index: -1;
	}
}
@media (min-width: 768px) and (max-width: 1024px) {
	.header_nav nav.elementor-nav-menu--dropdown.elementor-nav-menu__container .elementor-nav-menu {
		padding-top: 105px;
		padding-bottom: 150px;
	}
}
@media only screen and (max-width: 767px) {
	.header_nav nav.elementor-nav-menu--dropdown.elementor-nav-menu__container .elementor-nav-menu {
		padding-top: 165px;
		padding-bottom: 180px;
	}
}

/* This changes the font-weight for the Drop-Down Header Menu Tabs on Tablet and Mobile resolutions */
@media only screen and (max-width: 1024px) {
	.header_nav nav.elementor-nav-menu--dropdown.elementor-nav-menu__container .elementor-nav-menu .menu-item .elementor-item {
		font-weight: 700;
	}
}

/* This adds a background to the Drop-Down Header Menu on Tablet and Mobile resolutions */
@media (min-width: 768px) and (max-width: 1024px) {
	.header_nav nav.elementor-nav-menu--dropdown.elementor-nav-menu__container .elementor-nav-menu {
		background-image: url("/wp-content/uploads/2023/05/Logo-Symbol-Background.png");
		background-position: 0% 16%;
		background-repeat: no-repeat;
		background-size: 90% auto;
	}
}
@media only screen and (max-width: 767px) {
	.header_nav nav.elementor-nav-menu--dropdown.elementor-nav-menu__container .elementor-nav-menu {
		background-image: url("/wp-content/uploads/2023/05/Logo-Symbol-Background.png");
		background-position: 0% 32%;
		background-repeat: no-repeat;
		background-size: 90% auto;
	}
}

/* This changes the navigation chevron on the Header Menu */
.header_nav nav.elementor-nav-menu--main .elementor-nav-menu li.menu-item.menu-item-has-children .elementor-item .sub-arrow {
	padding: 10px 0 8px 2px;
}
.header_nav nav.elementor-nav-menu--main .elementor-nav-menu li.menu-item.menu-item-has-children .elementor-item .sub-arrow i.fa-chevron-down:before {
	content: url(/wp-content/uploads/2023/07/navigation_chevron.svg);
}

/* This styles the TranslatePress Language Switcher */
.header_section .lang_switcher .trp-language-switcher {
	border: 1px solid #E0E0E0;
	border-radius: 30px;
	max-width: 59.53px;
	height: auto;
}
@media only screen and (max-width: 767px) {
	.header_section .lang_switcher .trp-language-switcher {
		max-width: 49.53px;
	}
}
.header_section .lang_switcher .trp-language-switcher > div {
	background-image: url(/wp-content/uploads/2023/07/navigation_chevron.svg);
	background-position: 35px 10px;
	background-size: 12px;
	background-color: transparent;
	padding: 0px;
	border: none;
	border-radius: 0px;
	max-width: 59.53px;
}
@media only screen and (max-width: 767px) {
	.header_section .lang_switcher .trp-language-switcher > div {
		background-position: 29px 10px;
		background-size: 11px;
		max-width: 49.53px;
	}
}
.header_section .lang_switcher .trp-language-switcher > div > a {
	font-weight: var( --e-global-typography-df98961-font-weight );
	text-transform: var( --e-global-typography-df98961-text-transform );
	font-style: var( --e-global-typography-df98961-font-style );
	text-decoration: var( --e-global-typography-df98961-text-decoration );
	letter-spacing: var( --e-global-typography-df98961-letter-spacing );
	word-spacing: var( --e-global-typography-df98961-word-spacing );
	font-family: var( --e-global-typography-df98961-font-family ), Sans-serif;
	color: var( --e-global-color-primary );
	font-size: 14px;
	line-height: 24px;
	padding: 4px 0px 3px 15px;
	border-radius: 0px;
	cursor: pointer;
}
@media only screen and (max-width: 767px) {
	.header_section .lang_switcher .trp-language-switcher > div > a {
		font-size: 13px;
		line-height: 23px;
		padding: 3px 0px 2px 11px;
	}
}
.header_section .lang_switcher .trp-language-switcher > div > a:hover {
	background: none;
	color: #262626;
}

/* This applies a hover color to the text elements on the Footer */
div.elementor-element.bottom_footer_text_hover a {
	color: #838383;
	transition: 0.5s;
}
div.elementor-element.bottom_footer_text_hover a:hover {
	color: var( --e-global-color-c696dce );
}
div.elementor-element.footer_text_hover a {
	color: #d0d0d0;
	transition: 0.5s;
}
div.elementor-element.footer_text_hover a:hover {
	color: var( --e-global-color-14ef391 );
}

/* This changes the padding on the Footer section and on the Bottom Footer section for small resolution Laptop screens */
@media (min-width: 1025px) and (max-width: 1381px) {
	footer.elementor section.elementor-section.footer_section {
		padding: 0px 50px 0px 50px;
	}
}
@media (min-width: 1025px) and (max-width: 1381px) {
	footer.elementor section.elementor-section.bottom_footer_section {
		padding: 0px 50px 0px 50px;
	}
}

/* This changes the margin on the Footer section and on the Bottom Footer section for Mobile resolutions */
@media only screen and (max-width: 767px) {
	footer.elementor section.elementor-section.footer_section .elementor-container {
		margin-left: 0px;
	}
}
@media only screen and (max-width: 767px) {
	footer.elementor section.elementor-section.bottom_footer_section .elementor-container {
		margin-left: 0px;
	}
}

/* This changes the aligment on the Footer Seal element for Tablet and Mobile resolutions */
@media only screen and (max-width: 1024px) {
	div.elementor-element.footer_seal {
		left: 0;
	}
}

/* This applies a hover color to the standard text elements */
div.elementor-element.link_text_hover a {
	color: var( --e-global-color-14ef391 );
	transition: 0.5s;
}
div.elementor-element.link_text_hover a:hover {
	color: var( --e-global-color-primary );
}

/* This styles the Logo Carousel element */
div.elementor-element.logo_carousel .elementor-main-swiper .elementor-carousel-image {
	height: 114px;
	width: 100%;
	transition: 0.3s ease-in-out;
}
div.elementor-element.logo_carousel .elementor-main-swiper a .elementor-carousel-image:hover {
	opacity: 0.7;
}
div.elementor-element.logo_carousel .swiper .elementor-swiper-button-prev {
	left: 0px;
	background: linear-gradient(90deg, #fff 37.1%, rgba(255, 255, 255, 0) 95.57%);
	padding: 57px 107px 57px 27px;
}
@media only screen and (max-width: 767px) {
	div.elementor-element.logo_carousel .swiper .elementor-swiper-button-prev {
		padding: 57px 47px 57px 10px;
	}
}
div.elementor-element.logo_carousel .swiper .elementor-swiper-button-next {
	right: 0px;
	background: linear-gradient(270deg, #fff 37.1%, rgba(255, 255, 255, 0) 95.57%);
	padding: 57px 27px 57px 107px;
}
@media only screen and (max-width: 767px) {
	div.elementor-element.logo_carousel .swiper .elementor-swiper-button-next {
		padding: 57px 10px 57px 47px;
	}
}

/* This styles the Testimonial Carousel element */
@media only screen and (max-width: 767px) {
	div.elementor-element.testimonial_carousel .elementor-swiper .swiper-slide {
		padding: 20px 0px 20px 0px;
	}
}
@media only screen and (max-width: 767px) {
	div.elementor-element.testimonial_carousel .elementor-swiper .elementor-main-swiper {
		width: auto !important;
		max-width: 390px;
	}
}
div.elementor-element.testimonial_carousel .elementor-swiper .swiper-slide .elementor-testimonial .elementor-testimonial__image img {
	height: 3px;
}
div.elementor-element.testimonial_carousel .elementor-swiper .swiper-slide .elementor-testimonial .elementor-testimonial__cite {
	margin-top: 7px;
}
div.elementor-element.testimonial_carousel .elementor-swiper .elementor-swiper-button.elementor-swiper-button-prev {
	left: -5px;
	margin-top: 13px;
}
@media only screen and (max-width: 767px) {
	div.elementor-element.testimonial_carousel .elementor-swiper .elementor-swiper-button.elementor-swiper-button-prev {
		display: none;
	}
}
div.elementor-element.testimonial_carousel .elementor-swiper .elementor-swiper-button.elementor-swiper-button-next {
	right: -5px;
	margin-top: 13px;
}
@media only screen and (max-width: 767px) {
	div.elementor-element.testimonial_carousel .elementor-swiper .elementor-swiper-button.elementor-swiper-button-next {
		display: none;
	}
}
div.elementor-element.testimonial_carousel .elementor-swiper .swiper-pagination {
	bottom: 7px;
}
div.elementor-element.testimonial_carousel .elementor-swiper .swiper-pagination .swiper-pagination-bullet {
	width: 20px;
	border-radius: 0px;
	margin: 0 7px;
}

/* This styles the Hero Slider element */
div.elementor-element.hero_slider .elementor-swiper .swiper-slide {
	margin-right: 0px;
}
div.elementor-element.hero_slider .elementor-swiper .swiper-slide .elementor-carousel-image {
	background-repeat: no-repeat;
	background-position: center 50%;
	background-blend-mode: multiply;
	background-color: rgba(0, 0, 0, 0.44);
}
div.elementor-element.hero_slider .elementor-swiper .swiper-pagination {
	bottom: 180px;
}
div.elementor-element.hero_slider .elementor-swiper .swiper-pagination .swiper-pagination-bullet {
	width: 20px;
	border-radius: 0px;
	margin: 0 7px;
}
@media only screen and (max-width: 396px) {
	section.elementor-section.elementor-inner-section.home_h1_title {
		margin-top: -425px;
	}
}

/* This styles and positions the Product Icon Box element */
div.elementor-element.product_icon_box img:hover {
	filter: contrast(80%) brightness(190%);
}
div.elementor-element.product_icon {
	pointer-events: none;
}
@media (min-width: 768px) and (max-width: 1024px) {
	section.elementor-section.product_section div.elementor-column.product_col {
		max-width: 347px;
		margin: 0px 2.5px 6px 2.5px;
	}
}
@media only screen and (max-width: 767px) {
	section.elementor-section.product_section div.elementor-column.product_col {
		max-width: 317px;
		margin: 0px 2.5px 6px 2.5px;
	}
}

/* This aligns the 3x3 columns inside of the section */
section.elementor-section.three_col_section {
	display: inline-block;
	text-align: center;
}
@media only screen and (max-width: 1024px) {
	section.elementor-section.three_col_section {
		text-align: start;
	}
}
section.elementor-section.three_col_section div.elementor-container {
	display: block;
}
@media only screen and (max-width: 1024px) {
	section.elementor-section.three_col_section div.elementor-container {
		margin-left: 0px;
	}
}

/* This styles the Service Box columns */
div.elementor-column.service_box {
	display: inline-flex;
	width: 335px;
	height: 312px;
	margin: 0px 10px 0px 10px;
	transition-duration: .3s;
	transition-property: transform;
	transition-timing-function: ease-out;
}
@media (min-width: 1025px) and (max-width: 1200px) {
	div.elementor-column.service_box {
		width: 315px;
	}
}
@media (min-width: 768px) and (max-width: 1024px) {
	div.elementor-column.service_box {
		width: 315px;
		margin: 0px 5px 15px 5px;
	}
	div.elementor-column.service_box.elementor-hidden-tablet {
		display: none;
	}
}
@media only screen and (max-width: 767px) {
	div.elementor-column.service_box {
		width: auto;
		max-width: 295px;
		height: 282px;
		margin: 0px 5px 15px 5px;
	}
	div.elementor-column.service_box.elementor-hidden-mobile {
		display: none;
	}
}
div.elementor-column.service_box:hover {
	transform: translateY(-8px);
}

/* This styles the pointer for the Textual CTA element */
div.elementor-element.textual_cta .elementor-align-icon-right {
	margin: 4px 0px 0px 5px;
}
div.elementor-element.textual_cta .elementor-button-icon svg {
	width: auto;
	height: 16px;
}

/* This styles the Team Box columns */
div.elementor-column.team_box {
	display: inline-flex;
	width: 330px;
	margin: 0px 14.5px 60px 14.5px;
	transition-duration: 0.3s;
	transition-property: transform;
	transition-timing-function: cubic-bezier(.25,.46,.45,.94);
}
@media (min-width: 1025px) and (max-width: 1200px) {
	div.elementor-column.team_box {
		width: 310px;
	}
}
@media (min-width: 768px) and (max-width: 1024px) {
	div.elementor-column.team_box {
		width: 300px;
		margin: 0px 10px 50px 10px;
	}
	div.elementor-column.team_box.elementor-hidden-tablet {
		display: none;
	}
}
@media only screen and (max-width: 767px) {
	div.elementor-column.team_box {
		width: auto;
		max-width: 280px;
		margin: 0px 5px 40px 5px;
	}
	div.elementor-column.team_box.elementor-hidden-mobile {
		display: none;
	}
}
div.elementor-column.team_box:hover {
	transform: scale(1.03);
}

/* This styles the Team linkedin icon */
div.elementor-element.team_social .elementor-social-icon.elementor-repeater-item-83244e8 {
	--icon-size: 18px;
}

/* This styles the Full Width image + Boxed text columns */
div.elementor-column.full_width_col {
	height: 745px;
}
@media (min-width: 768px) and (max-width: 1024px) {
	div.elementor-column.full_width_col {
		height: 625px;
	}
}
@media only screen and (max-width: 767px) {
	div.elementor-column.full_width_col {
		height: 475px;
	}
}
div.elementor-column.boxed_text_col {
	height: 551px;
	width: 720px !important;
	margin: 95px 0px 0px -165px;
}
@media (min-width: 1201px) and (max-width: 1367px) {
	div.elementor-column.boxed_text_col {
		margin: 95px 0px 0px -185px;
	}
}
@media (min-width: 768px) and (max-width: 1024px) {
	div.elementor-column.boxed_text_col {
		margin: -265px 30px 0px auto;
	}
}
@media (min-width: 768px) and (max-width: 1200px) {
	div.elementor-column.boxed_text_col {
		width: 620px !important;
	}
	div.elementor-column.boxed_text_col div.elementor-widget-wrap.elementor-element-populated {
		padding: 65px 45px 80px 45px;
	}
}
@media only screen and (max-width: 767px) {
	div.elementor-column.boxed_text_col {
		height: auto;
		width: 400px !important;
		margin: -145px 0px 0px 0px;
	}
	div.elementor-column.boxed_text_col div.elementor-widget-wrap.elementor-element-populated {
		padding: 36px 40px 46px 40px;
	}
}

/* This positions the Banner Title column for Laptop resolutions */
@media (min-width: 1025px) and (max-width: 1200px) {
	section.elementor-section.intro_banner div.elementor-widget-wrap.elementor-element-populated {
		padding: 0px 0px 0px 70px;
	}
}

/* This styles the bullet points */
div.elementor-element.custom_bullets div.elementor-widget-container ul {
  	list-style-type: none;
	margin-block-start: 18px;
	padding-inline-start: 0px;
}
div.elementor-element.custom_bullets div.elementor-widget-container ul li {
	background-image: url(/wp-content/uploads/2023/05/bullet.svg);
	background-position: 0 12px;
	background-size: 6px 6px;
	background-repeat: no-repeat;
	padding: 0px 0px 4px 23px;
}
div.elementor-element.custom_bullets_v2 div.elementor-widget-container ul {
  	margin-block-start: -4px;
	margin-block-end: 0px;
	padding-inline-start: 22px;
}
div.elementor-element.custom_bullets_v2 div.elementor-widget-container ul li {
	padding-bottom: 12px;
	padding-left: 1px;
}

/* This styles the Individual Profile section on the About us Page */
@media only screen and (min-width: 1441px) {
	section.elementor-section.about_profile div.elementor-column.about_profile_img {
		width: 674px;
	}
}
@media (min-width: 1025px) and (max-width: 1440px) {
	section.elementor-section.about_profile div.elementor-column.about_profile_img {
		width: 535px;
	}
}
@media only screen and (min-width: 1025px) {
	section.elementor-section.about_profile div.elementor-column.about_profile_text {
		width: min-content;
	}
}
@media (min-width: 1025px) and (max-width: 1200px) {
	section.elementor-section.about_profile div.elementor-column.about_profile_text div.elementor-widget-wrap.elementor-element-populated {
		padding: 150px 3px 135px 63px;
	}
}

/* This styles the Stacked Image element */
div.elementor-element.stacked_img figure.gallery-item {
	width: fit-content;
	text-align: start;
}
div.elementor-element.stacked_img figure.gallery-item:first-child {
	max-width: 511px;
	margin-left: 85px;
	transition-duration: 0.3s;
	transition-property: transform;
	transition-timing-function: cubic-bezier(.25,.46,.45,.94);
}
div.elementor-element.stacked_img figure.gallery-item:first-child:hover {
	transform: scale(.97);
}
@media (min-width: 1025px) and (max-width: 1200px) {
	div.elementor-element.stacked_img figure.gallery-item:first-child {
		margin-left: 1px;
	}
}
@media only screen and (max-width: 1024px) {
	div.elementor-element.stacked_img figure.gallery-item:first-child {
		max-width: 411px;
		margin-left: 0px;
	}
}
@media only screen and (max-width: 767px) {
	div.elementor-element.stacked_img figure.gallery-item:first-child {
		padding-right: 25px;
	}
}
div.elementor-element.stacked_img figure.gallery-item:nth-child(2) {
	position: absolute;
	bottom: -65px;
	right: 0px;
	z-index: 2;
	max-width: 362px;
	transition-duration: 0.3s;
	transition-property: transform;
	transition-timing-function: cubic-bezier(.25,.46,.45,.94);
}
div.elementor-element.stacked_img figure.gallery-item:nth-child(2):hover {
	transform: scale(.97);
}
@media (min-width: 768px) and (max-width: 1024px) {
	div.elementor-element.stacked_img figure.gallery-item:nth-child(2) {
		max-width: 262px;
		left: 250px;
	}
}
@media only screen and (max-width: 767px) {
	div.elementor-element.stacked_img figure.gallery-item:nth-child(2) {
		right: -25px;
		max-width: 262px;
		left: 165px;
	}
}
@media (min-width: 1025px) and (max-width: 1200px) {
	section.elementor-section.stacked_img_section div.elementor-column.stacked_img_text div.elementor-widget-wrap.elementor-element-populated {
		padding: 60px 60px 0px 60px;
	}
}

/* This styles the 3x3 Text columns */
div.elementor-column.text_box {
	display: inline-flex;
	width: 368px;
	margin: 0px 14.5px 50px 14.5px;
}
@media (min-width: 1025px) and (max-width: 1200px) {
	div.elementor-column.text_box {
		width: 308px;
		margin: 0px 12.5px 50px 12.5px;
	}
}
@media (min-width: 768px) and (max-width: 1024px) {
	div.elementor-column.text_box {
		width: 308px;
		margin: 0px 12px 50px 12px;
	}
	div.elementor-column.text_box.elementor-hidden-tablet {
		display: none;
	}
}
@media only screen and (max-width: 767px) {
	div.elementor-column.text_box {
		width: auto;
		max-width: 368px;
		margin: 0px 5px 45px 5px;
	}
	div.elementor-column.text_box.elementor-hidden-mobile {
		display: none;
	}
}

/* This styles the Image element on the Product sub-pages */
section.elementor-section.main_product_img_section div.elementor-element.main_product_img img {
	object-fit: contain;
}
@media (min-width: 1025px) and (max-width: 1200px) {
	section.elementor-section.main_product_img_section div.elementor-element.main_product_img img {
		width: 1140px;
	}
}
div.elementor-element.main_product_img img {
	transition-duration: 0.3s;
	transition-property: transform;
	transition-timing-function: cubic-bezier(.25,.46,.45,.94);
}
div.elementor-element.main_product_img img:hover {
	transform: scale(.99);
}

/* This styles the Zig-Zag Product element */
@media only screen and (max-width: 767px) {
	div.elementor-element.produto_zig_zag .elementor-cta__content .elementor-cta__button-wrapper .elementor-cta__button {
		padding: 15px 30px 15px 0px;
	}
}
div.elementor-element.produto_zig_zag .elementor-cta__content .elementor-cta__button-wrapper .elementor-cta__button::after {
	position: relative;
	display: inline-flex;
	content: '';
	width: 14.47px;
	height: 14.47px;
	top: 3px;
	left: 2px;
	background-image: url('/wp-content/uploads/2023/05/produtos_cta_arrow.svg');
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
}
@media (min-width: 1025px) and (max-width: 1142px) {
	div.elementor-element.produto_zig_zag div.elementor-cta .elementor-cta__content {
		padding: 0px 36px 0px 36px;
	}
}
@media (min-width: 768px) and (max-width: 1024px) {
	div.elementor-element.produto_zig_zag div.elementor-cta {
		flex-direction: column-reverse;
		cursor: inherit;
		max-width: 549px;
	}
}
@media only screen and (max-width: 767px) {
	div.elementor-element.produto_zig_zag div.elementor-cta {
		flex-direction: column-reverse;
		cursor: inherit;
		max-width: 449px;
	}
}
@media only screen and (max-width: 767px) {
	div.elementor-element.produto_zig_zag div.elementor-cta div.elementor-cta__bg-wrapper {
		min-width: auto;
	}
}
div.elementor-element.produto_zig_zag div.elementor-cta .elementor-cta__bg-wrapper .elementor-cta__bg  {
	background-repeat: no-repeat;
}
@media only screen and (max-width: 1024px) {
	div.elementor-element.produto_zig_zag div.elementor-cta .elementor-cta__bg-wrapper .elementor-cta__bg  {
		background-position: center 40%;
	}
}

/* This styles the iframe Map */
iframe.custom_map {
	width: 100%;
	height: 672px;
	border: 0;
	margin-bottom: -6px;
}
@media (min-width: 768px) and (max-width: 1024px) {
	iframe.custom_map {
		height: 472px;
	}
}
@media only screen and (max-width: 767px) {
	iframe.custom_map {
		height: 372px;
	}
}

/* This applies a hover color to the text elements on the Contacts page */
div.elementor-element.contacts_text_hover a {
	color: var( --e-global-color-accent );
	line-height: 20px !important;
	transition: 0.5s;
}
div.elementor-element.contacts_text_hover a:hover {
	color: var( --e-global-color-14ef391 );
}

/* This adjusts the columns for Tablet and Mobile on the Contacts page */
@media only screen and (max-width: 1024px) {
	section.elementor-section.contacts_section .elementor-container {
		margin: 0;
	}
}

/* This adjusts the width for the Divider and Icon List elements on the Services page for Laptop resolutions */
@media (min-width: 1025px) and (max-width: 1200px) {
	div.elementor-element.service_icon_divider div.elementor-divider span.elementor-divider-separator {
		width: 400px;
	}
}
@media (min-width: 1025px) and (max-width: 1200px) {
	div.elementor-column.service_icon_col div.elementor-element.service_icon_list {
		max-width: 400px;
		--container-widget-width: 400px;
	}
}

/* This increases the paragrath margin for the text element on the Services page */
div.elementor-element.service_text div.elementor-widget-container p {
	margin-block-end: 27px;
}

/* This styles the WhatsApp popup */
div.elementor-popup-modal.whatsapp_popup {
	z-index: 5;
}
div.elementor-popup-modal.whatsapp_popup .dialog-widget-content {
	background-color: transparent;
	width: fit-content;
}
@media only screen and (max-width: 767px) {
	div.elementor-popup-modal.whatsapp_popup div.elementor-element.whatsapp_popup_icon a.elementor-icon {
		padding: 9px;
	}
}

/* This sets a width for the Text element on the 404 Page */
@media only screen and (max-width: 767px) {
	section.elementor-section.main_section_404 div.elementor-element.custom_404_text {
		width: 225px;
		max-width: 225px;
	}
}

/* This styles the Weather Widget */
div.elementor-element.weather_widget div.elementor-shortcode {
	font-family: var( --e-global-typography-b2deeae-font-family ), Sans-serif;
	font-weight: var( --e-global-typography-397e168-font-weight );
	color: var( --e-global-color-text );
	font-size: 15px;
	line-height: 20px;
}
div.elementor-element.weather_widget div.elementor-shortcode .simple-weather {
	line-height: 20px;
}
div.elementor-element.weather_widget div.elementor-shortcode .simple-weather .sw {
	margin: 0 3px 0 4px;
}
div.elementor-element.weather_widget div.elementor-shortcode .simple-weather .sw::before {
	color: var( --e-global-color-14ef391 );
	font-size: 22px;
}
div.elementor-element.weather_widget div.elementor-shortcode .simple-weather .simple-weather__temp {
	font-weight: var( --e-global-typography-8668056-font-weight );
	color: var( --e-global-color-d6cea4e );
	font-size: 15px;
	line-height: 20px;
}

/* This styles the Elementor Forms */
div.elementor-element.form_contacts form.elementor-form .elementor-mark-required .elementor-field-label::after {
	padding-left: 0px;
	font-size: 10px;
}
div.elementor-element.form_contacts form.elementor-form .elementor-form-fields-wrapper .elementor-field-textual.elementor-size-xs {
	min-height: 44px;
	padding: 11px 12px;
}
div.elementor-element.form_contacts form.elementor-form .elementor-form-fields-wrapper .elementor-field-group .elementor-field:focus {
	border-color: var( --e-global-color-14ef391 );
	box-shadow: inset 0 0 0 1px var( --e-global-color-14ef391 );
}
div.elementor-element.form_contacts form.elementor-form .elementor-form-fields-wrapper .elementor-field-group:last-child {
	margin-bottom: 0px;
}
@media only screen and (max-width: 767px) {
	div.elementor-element.form_contacts form.elementor-form .elementor-form-fields-wrapper .elementor-field-group > label {
		padding-bottom: 4px;
	}
}
div.elementor-element.form_contacts form.elementor-form .elementor-form-fields-wrapper .elementor-field-group textarea#form-field-contacts_message {
	scrollbar-width: none;
}
div.elementor-element.form_contacts form.elementor-form .elementor-form-fields-wrapper .elementor-field-group textarea#form-field-contacts_message::-webkit-scrollbar {
	display: none;
}
@media only screen and (max-width: 767px) {
	div.elementor-element.form_contacts form.elementor-form .elementor-form-fields-wrapper .elementor-field-group textarea#form-field-contacts_message {
		height: 102px;
	}
}
div.elementor-element.form_contacts form.elementor-form .elementor-form-fields-wrapper button#submit_cta {
	margin-top: 16px;
}
div.elementor-element.form_contacts form.elementor-form .elementor-message {
	margin: 22px 0px;
}
@media only screen and (max-width: 1024px) {
	div.elementor-element.form_contacts form.elementor-form .elementor-message.elementor-help-inline {
		margin: 22px 8px;
	}
}
div.elementor-element.form_contacts form.elementor-form .elementor-message-success {
	margin: 40px 0px 0px 0px;
	text-align: center;
}
@media only screen and (max-width: 1024px) {
	div.elementor-element.form_contacts form.elementor-form .elementor-message-success {
		text-align: left;
	}
}
div.elementor-element.form_contacts form.elementor-form .elementor-message::before {
	margin-right: 4px;
	margin-top: -4px;
}
div.elementor-element.form_contacts form.elementor-form .elementor-form-fields-wrapper .elementor-field-type-recaptcha {
	margin-top: 16px;
	padding: 0px;
}
@media only screen and (max-width: 1024px) {
	div.elementor-element.form_contacts form.elementor-form .elementor-form-fields-wrapper .elementor-field-type-recaptcha {
		padding: 0px 0px 0px 8px;
	}
}
div.elementor-element.form_contacts form.elementor-form .elementor-form-fields-wrapper .elementor-field-type-recaptcha div#form-field-form_recaptcha {
	margin: auto;
	border: 0px solid transparent;
	border-radius: 0px;
	background-color: transparent;
	transform: scale(0.95);
}
@media only screen and (max-width: 1024px) {
	div.elementor-element.form_contacts form.elementor-form .elementor-form-fields-wrapper .elementor-field-type-recaptcha div#form-field-form_recaptcha {
		margin-left: 0px;
	}
}

/* This aligns the inner Form section for Tablet and Mobile resolutions */
@media only screen and (max-width: 1024px) {
	section.elementor-section.inner_form_section div.elementor-container {
		margin-left: 0px;
	}
}

/* This styles the Read More CTA's on the Archive Page */
div.elementor-element.search_archive div.elementor-post__read-more-wrapper {
	display: inline-flex;
}
div.elementor-element.search_archive a.elementor-post__read-more {
	background-color: var( --e-global-color-accent );
	border-style: solid;
	border-width: 1px 1px 1px 1px;
	border-color: #0000000D;
	border-radius: 5px 5px 5px 5px;
	padding: 12px 32px 12px 32px;
	transition: all .3s;
}
div.elementor-element.search_archive a.elementor-post__read-more:hover {
	color: var( --e-global-color-accent );
	background-color: var( --e-global-color-c696dce );
	border-color: var( --e-global-color-accent );
}

/* This sets the width on the Archive Page for Tablet and Mobile resolutions */
div.elementor-element.search_archive nav.elementor-pagination {
	margin-bottom: -5px;
}
@media (min-width: 768px) and (max-width: 1024px) {
	div.elementor-element.search_archive {
		max-width: 620px;
	}
}
@media only screen and (max-width: 767px) {
	div.elementor-element.search_archive {
		max-width: 480px;
	}
}

/* This styles the Search CTA for the Header Menu */
div.elementor-element.menu_search_tab form.elementor-search-form .elementor-search-form__toggle {
	transition: .3s;
}
div.elementor-element.menu_search_tab form.elementor-search-form .elementor-search-form__toggle:hover {
	filter: brightness(0.6);
}
div.elementor-element.menu_search_tab form.elementor-search-form .elementor-search-form__toggle .fas.fa-search::before {
	content: url(/wp-content/uploads/2023/06/search-button.svg);
}
@media only screen and (max-width: 767px) {
	div.elementor-element.menu_search_tab form.elementor-search-form .elementor-search-form__toggle .fas.fa-search::before {
		transform: scale(0.8);
	}
}
@media only screen and (min-width: 768px) {
	div.elementor-element.menu_search_tab form.elementor-search-form .elementor-search-form__toggle .fas.fa-search::after {
		content: "Procurar";
		position: absolute;
		margin: -2px 0px 0px 17px;
		color: #8E8E8E;
		font-family: "Mulish", Sans-serif;
		font-size: 12px;
		font-weight: 400;
		text-transform: none;
		font-style: normal;
		text-decoration: none;
		line-height: 24px;
		letter-spacing: 0px;
	}
}
@media only screen and (min-width: 768px) {
	div.elementor-element.menu_search_tab.en_search form.elementor-search-form .elementor-search-form__toggle .fas.fa-search::after {
		content: "Search";
	}
}

/* This styles the full-screen Search overlay for Mobile resolutions */
@media only screen and (max-width: 767px) {
	div.elementor-element.menu_search_tab form.elementor-search-form div.elementor-search-form__container.elementor-search-form--full-screen.elementor-lightbox {
		padding: 0 20%;
	}
}
@media only screen and (max-width: 767px) {
	div.elementor-element.menu_search_tab form.elementor-search-form div.elementor-search-form__container.elementor-search-form--full-screen.elementor-lightbox .elementor-search-form__input {
		font-size: 36px;
	}
}

/* This applies a box-shadow and a z-index on the Cookie Notice popup element so that it doesn't overlap when the Header Mobile Menu is expanded */
div.elementor-popup-modal.cookie_notice_popup div.dialog-widget-content {
	box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.25);
}
div.elementor-popup-modal.cookie_notice_popup {
	z-index: 10;
}
