/*
Theme Name: Divi Child Template
Version: 1.0
Description: A customized version of Divi which adds a number of tiny features you need.
Template: Divi
*/


body {
	font-size: 1.0625rem;
	font-family: 'Noto Sans', Verdana, Arial, sans-serif;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizelegibility;
	font-feature-settings: "liga";
	color: #cccccc;
	font-weight: 400;
	overflow-x: hidden;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: 'Montserrat', Arial, sans-serif;
	font-weight: 700;
	color: #fff
}

p strong {
	font-family: 'Montserrat', Arial, sans-serif;
	font-size: 18px;
	font-weight: 700;
}

div#page-container {
	overflow: hidden;
	/* padding-top: 303px !important; */
}

.home div#page-container {
	padding-top: 120px !important;
}

.et_pb_row {
	width: 95% !important;
}

.et_pb_section {
	background: #1d1d1d;
	padding-bottom: 0;
}

/*HEADER STYLES*/
header#main-header {
	background: transparent !important;
	box-shadow: none;
}

.main-header-info-container {
	background: transparent;
	position: relative;
	display: flex;
	font-size: 16px;
	align-items: center;
	justify-content: center;
	padding: 5px 0;
}

.ws-header-booking {
	display: flex;
	position: relative;
	justify-content: center;
	align-items: center;
	background: transparent;
	z-index: 999;
	margin: 5px;
}

.top_button {
	background: transparent;
	color: #ffffff;
	padding: 5px 10px;
	border: 2px solid #ffffff;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.5s;
	font-size: 16px;
	display: none;
}

.top_button:hover {
	background: #ffffff;
	color: #000;
	border-color: #ffffff;
	transition: all 0.5s;
}

.header-menu-container {
	width: 100%;
	max-width: 100%;
	background: transparent;
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	padding: 10px 0;
}

.header-info-holder {
	max-width: 1080px;
	width: 79%;
	margin: 0 auto;
}

.logo_container {
	position: relative !important;
	text-align: center;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	width: 100%;
	margin-left: 10px;
}

img#logo {
	min-height: 60px !important;
	max-height: 75px !important;
	width: auto !important;
	max-width: 280px !important;
}

.text-logo {
	font-family: 'Montserrat', sans-serif;
	color: #fff;
	line-height: 1.1;
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	text-align: left;
}

.text-logo span {
	width: 100%;
}

.text-logo-icon {
	width: 34%;
}

.text-logo-icon img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
	max-height: 100px;
}

.main-header-napinfo-block {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	flex-direction: row;
	align-content: center;
}

.main-header-email-btn {
	display: flex;
	justify-content: center;
	align-items: center;
	line-height: 1;
	padding: 10px;
	font-size: 16px;
	color: #ffffff;
	background: #e23045;
	position: relative;
	left: 0;
	bottom: 0px;
	z-index: 999;
	margin: 5px;
	border: 2px solid #ffffff;
	transition: all 0.5s;
}

.main-header-email-btn:hover {
	background: transparent;
	color: #ffffff;
	transition: all 0.5s;
}

.main-header-email-btn:hover .fa {
	color: #ffffff;
	transition: all 0.5s;
}

.main-header-email-btn .fa {
	margin-right: 5px;
	color: #ffffff;
	transition: all 0.5s;
}

a.hours-box {
	padding: 0 !important;
	pointer-events: none;
}

.main-header-napinfo-block a.hours-box {
	pointer-events: none;
}

.hours {
	border: none;
	height: auto;
	box-shadow: none;
	background: transparent !important;
}

.hours img {
	display: none;
}

.hours p {
	padding: 0 !important;
	font-size: 16px !important;
	text-shadow: none;
	color: #fff;
}

.add-info-btn {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	background: #000000;
	width: 50px;
	padding: 10px;
	cursor: pointer;
	border: 1px solid #ffffff;
}

.add-info-block {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	width: 270px;
	position: fixed;
	right: -220px;
	-webkit-transition: right 0.4s ease-in-out;
	transition: right 0.4s ease-in-out;
	/* top: 163px; */
	margin-top: 35px;
	z-index: 97;
}

.open-info {
	right: 0;
	z-index: 9999;
}

.open-info #add-info-open-icon {
	display: none;
}

.open-info #add-info-close-icon {
	display: block;
}

.add-info-container {
	background: #e23045;
	display: flex;
	flex-direction: column;
	padding: 20px;
	width: 220px;
	height: auto;
}

.add-info-btn .fa {
	color: #ffffff;
}

#add-info-close-icon {
	display: none;
}

.add-info-btn span {
	line-height: 1;
	color: #ffffff;
	margin-top: 5px;
	font-size: 12px;
}

.add-info-container a,
.header-location-container {
	color: #fff;
	font-size: 15px;
	display: flex;
	justify-content: space-between;
	font-weight: 400;
	text-align: right;
	width: 100%;
}

.email-btn {
	margin: 10px 0;
}

.add-info-container .fa {
	margin-right: 5px;
	margin-top: 2px;
}

div#et-top-navigation {
	width: 20%;
	padding: 0px !important;
	display: flex !important;
	align-items: center;
	justify-content: flex-end;
	height: 80px;
	margin-right: 10px;
}

span.select_page {
	display: none !important;
}

.floating-cta-btn {
	position: fixed;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	background: #e23045;
	width: 50px;
	padding: 10px;
	cursor: pointer;
	border: 1px solid #000;
	border-right: none;
	right: 0;
	margin-top: 100px;
	z-index: 98;
}

.floating-cta-btn a .fa {
	animation: ringing 5s ease-in-out infinite;
	color: #fff;
	font-size: 24px;
}

.et-fixed-header.sticky-menu .add-info-block,
.et-fixed-header.sticky-menu .floating-cta-btn {
	top: -15px;
}

div#et_mobile_nav_menu {
	/* width: 20%; */
}

.mobile_menu_bar {
	padding-bottom: 0 !important;
}

.et_mobile_menu {
	background-color: #0d0d0d!important;
	border-color: #e23045 !important;
	height: auto !important;
	top: 100%;
}

.et_mobile_menu li a {
	color: #fff !important;
}

.mobile_nav ul#mobile_menu ul.sub-menu li a:not(.mobile-toggle) {
	position: relative;
}

ul.et_mobile_menu li.menu-item-has-children .mobile-toggle::after {
	background: #e23045 !important;
}

.mobile_nav ul#mobile_menu ul.sub-menu li a:not(.mobile-toggle):before {
	content: '\f149';
	position: absolute;
	left: 0;
	font-family: 'FontAwesome';
	-webkit-transform: scaleX(-1) rotate(90deg);
	transform: scaleX(-1) rotate(90deg);
	color: #e23045;
}

.et_mobile_menu .current_page_item a {
	color: #e23045 !important;
}

/*change Divi opened hamburger menu to X*/
.mobile_nav.opened .mobile_menu_bar:before {
	content: '\4d';
}

/*rotate the Divi Menu icon on click*/
.mobile_menu_bar:before {
	transition: all .4s ease;
	transform: rotate(0deg);
	display: block;
	color: #fff;
	text-align: center;
	font-size: 50px;
}

.booking-button-switch {
	/* display:none !important;
*/
}

/*rotate the Divi Menu icon on click*/
/*END HEADER STYLES*/
/*PAGE STYLES*/
section.et_pb_module.et_pb_fullwidth_header.et_pb_fullwidth_header_0.et_pb_text_align_center.et_pb_bg_layout_dark.et_pb_fullscreen {
	max-height: 550px !important;
	min-height: 500px !important;
	height: calc(100vh - 303px) !important;
	background-position: 41%;
	position: relative;
}

.et_pb_fullscreen .et_pb_fullwidth_header_container {
	max-height: 550px !important;
	min-height: 500px !important;
	height: calc(100vh - 303px) !important;
	width: 100%;
	position: relative;
	overflow: hidden;
	padding: 0 10%;
	align-items: flex-start;
	display: flex !important;
	justify-content: center;
}

.et_pb_fullscreen .et_pb_fullwidth_header_container {
	position: relative;
}

.et_pb_fullscreen .et_pb_fullwidth_header_container::before {
	content: '';
	position: absolute;
	background: url(https://ca-mobilemechanicsvc.com/wp-content/uploads/2025/03/header-car.webp);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	width: 500px;
	height: 370px;
	bottom: 36px;
	right: -125px;
	filter: brightness(0.8);
	z-index: 2;
}

.et_pb_fullscreen .et_pb_fullwidth_header_container::after {
	content: '';
	width: 90%;
	height: 58%;
	position: absolute;
	border: 2px solid #ffffffa8;
	border-top: none;
	bottom: 22%;
	z-index: 1;
}

.header-content-container {
	height: 100%;
	z-index: 3;
	margin-top: 130px;
}

.header-content {
	margin: 0 auto !important;
	padding: 0px !important;
	width: 95% !important;
	max-width: 1080px !important;
}

.et_pb_fullwidth_header .et_pb_fullwidth_header_scroll a .et-pb-icon {
	margin-left: -5px !important;
}

.header-btns {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: center;
}

.ws-slogan h1 {
	font-family: 'Montserrat', sans-serif;
	line-height: 1.1;
	color: #ffffff;
	font-weight: bold;
	font-size: 25px;
	text-transform: capitalize;
	max-width: 400px;
	width: 80%;
	text-align: left;
	text-shadow: 0 0 5px #000;
}

.button {
	color: #e23045;
	display: inline-block;
	line-height: 1;
	margin-top: 10px;
	margin-left: 20px;
	padding: 15px 25px;
	border: 2px solid #e23045;
	position: relative;
	overflow: hidden;
	background-color: transparent;
	text-align: center;
	text-transform: uppercase;
	transition: .3s;
	z-index: 1;
	font-family: inherit;
	font-weight: 700 !important;
	font-size: 18px;
	text-shadow: 0 0 5px #000, 0 0 5px #000;
	backdrop-filter: blur( 2px );
	-webkit-backdrop-filter: blur( 2px );
	text-decoration: none !important;
}

.button::before {
    content: '';
    width: 0;
    height: 405%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(45deg);
    background: #e23045;
    transition: .5s ease;
    display: block;
    z-index: -1;
}

.button:hover::before {
    width: 105%;
}

.button:hover {
    color: #fff;
	font-weight: 400 !important;
	text-shadow: none;
}

.header-button-quote > br {
	display: none;
}

.header-button-quote {
	color: #ffffff;
	display: inline-block;
	line-height: 1;
	margin-top: 10px;
	/* margin-left: 20px; */
	padding: 15px 25px;
	border: 2px solid #ffffff;
	position: relative;
	overflow: hidden;
	background-color: transparent;
	text-align: center;
	text-transform: uppercase;
	transition: .3s;
	z-index: 1;
	font-family: inherit;
	font-weight: 700;
	display: none;
	font-size: 18px;
	text-shadow: 0 0 5px #000, 0 0 5px #000;
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
}

.header-button-quote::before {
    content: '';
    width: 0;
    height: 470%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(45deg);
    background: #ffffff;
    transition: .5s ease;
    display: block;
    z-index: -1;
}

.header-button-quote:hover::before {
    width: 105%;
}

.header-button-quote:hover {
    color: #000;
	font-weight: 400;
	text-shadow: none;
}

.entry-title {
	text-align: center;
	font-size: 26px !important;
	font-weight: bold;
	font-family: 'Montserrat', sans-serif;
	line-height: 1.1;
}

.home .entry-title {
	color: #fff;
	padding: 0;
}

div#home-title-block {
	background-color: #1d1d1d !important;
}

div#home-title-block-container {
	display: flex;
	align-items: center;
	padding: 0;
	justify-content: center;
}

.section-title-heading {
	text-align: center;
	font-size: 18px;
}

div#home-title-block-container .et_pb_column {
	margin-bottom: 0 !important;
}

/* BADGES SECTION STYLE */
div#css-badges-section {
	background-color: #1d1d1d !important;
	padding: 30px 0;
	z-index: 3;
}

.badges-container {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	box-shadow: 2px -2px 5px #000, -2px -2px 5px #000;
	border-radius: 20px;
	margin-top: -150px;
	background: #e23045;
	flex-direction: row;
	align-items: center;
	align-content: center;
}

.badge-holder {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 44%;
	padding: 15px 5px 22px 5px;
	position: relative;
	color: #ffffff;
	margin: 10px;
	transition: all 0.5s;
	background: black;
}

.badge-holder:hover {
	transform: scale(1.2);
	filter: drop-shadow(2px 4px 6px black);
	transition: all 0.5s;
}

p.badge-content {
	text-align: center;
	line-height: 1;
	text-transform: capitalize;
	font-size: 17px;
	min-height: 34px;
	padding-bottom: 10px !important;
	padding-top: 10px;
	font-family: 'Montserrat', sans-serif;
}

.badge-holder img {
	width: 150px;
	height: auto;
	padding-bottom: 5px;
	opacity: 1;
}

.badge-title {
	font-size: 15px;
	text-align: center;
	line-height: 1.2;
	min-height: 36px;
	display: flex;
	justify-content: center;
	align-items: center;
}

.badge-title span {
	font-size: 17px;
}

/*FIRST PARAGRAPH STYLE*/
#home-first-paragraph-section {
	background: #1d1d1d;
}

#home-first-paragraph-row {
	border-radius: 20px;
	padding-top: 0;
	background-position-x: 48%;
	background-position-y: bottom;
	background-size: cover;
	box-shadow: 0 0 5px #000;
}

#home-first-paragraph-text {
	background: #2d2d2d;
	border-radius: 20px 20px 0 0;
	padding: 30px 15px 100px;
	clip-path: polygon(0% 0%, 100% 0%, 100% 80%, 0% 100%);
}

#home-first-paragraph-subtitle {
	margin-bottom: 5px;
}

.subtitle {
	color: #e23045;
	font-size: 18px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 1px;
}

#home-first-paragraph-text h2 {
	margin-bottom: 10px;
	padding: 0;
}

#home-first-paragraph-image {
	display: block;
	height: 100%;
	width: 100% !important;
	min-height: 350px;
}

/* SERVICES SECTION STYLE */
div#home-section-title {
	background-color: #1d1d1d !important;
	display: flex;
	justify-content: center;
	position: relative;
}

#srvBlockSubtitle {
	margin-bottom: 5px;
	display: flex;
	align-items: center;
	justify-content: center;
}

div#services-blocks-section {
	background-color: #1d1d1d !important;
	padding-top: 0;
	overflow: hidden;
}

div#services-blocks-section > div > div {
	width: 85% !important;
}

.srvBlockTitle p {
	text-align: center;
	font-size: 26px;
	color: #ffffff;
	line-height: 1.2;
	padding: 0;
	font-family: 'Montserrat', sans-serif;
	font-weight: bold;
}

.srvElement {
	margin: 0 auto;
	margin-top: 25px;
	position: relative;
	max-width: 485px;
	transition: all 1s;
}

.srvElementHeader h2 {
	text-align: center;
	color: #ffffff;
	font-weight: bold;
	font-family: 'Montserrat', sans-serif;
	padding-bottom: 5px;
	padding-top: 10px;
	font-size: 22px;
	min-height: 59px;
	display: flex;
	justify-content: center;
	align-items: center;
}

.srvElementImg {
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	clip-path: polygon(0% 0%, 90% 0%, 100% 100%, 0% 100%);
	margin-right: -57px;
	max-width: 540px;
	transition: all 1s;
}

.srvElementImg::before {
	content: "";
	position: absolute;
	width: 10%;
	height: 130%;
	background: #1d1d1d;
	left: -14px;
	top: 0;
	box-shadow: inset -6px 0px 10px 0px #000;
	transform: rotate(-6.5deg);
	transition: all 1s;
}

.srvElementImg img {
	width: 100%;
	object-fit: cover;
	object-position: center;
}

.srvElementBody {
	padding: 20px;
	z-index: 2;
	position: relative;
	margin-right: calc(7% - 44px);
	max-width: 500px;
	transition: all 1s ease;
	overflow: hidden;
}

.srvElementBody::before, .srvElementBody::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: transform 1s ease;
}

.srvElementBody::before {
	background: #1d1d1d;
	transform: translateX(0);
	z-index: 2;
}

.srvElementBody::after {
	background: #2d2d2d;
	transform: translateX(100%);
	z-index: 1;
  }

.srvElementBody a {
	color: #e23045;
}

.srvElementHeader {
	background: #e23045;
	clip-path: polygon(0% 0%, 100% 0%, 90% 100%, 0% 100%);
	margin-right: -57px;
	position: relative;
	padding: 0 37px;
	transition: all 1s;
}

.srvElementHeader::before {
	content: '';
	position: absolute;
	width: 10%;
	height: 170%;
	background: #1d1d1d;
	left: -12px;
	bottom: 0;
	box-shadow: inset -6px 0px 10px 0px #000;
	transform: rotate(28deg);
	transition: all 1s;
}

.srvElementContent {
	text-align: justify;
	font-size: 16px;
	line-height: 1.6;
	color: #fff;
	z-index: 3;
	position: relative;
}

.srvElement:hover .srvElementBody {
	margin-right: 0;
}
.srvElementFullWidth:hover .srvElementBody {
	margin: 0;
	width: 100%;
	padding: 5px 5px 5px 15px;
}
.srvElementFullWidth:hover .srvElementText {
	width: auto;
}
.srvElement:hover .srvElementBody::before {
	transform: translateX(-100%);
}
.srvElement:hover .srvElementBody::after {
	transform: translateX(0);
}
.srvElement:hover .srvElementImg {
	margin-right: 0;
	transition: all 1s;
	clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
}
.srvElement:hover .srvElementImg::before {
	transition: all 1s;
	width: 0;
}
.srvElement:hover .srvElementHeader {
	margin-right: 0;
	transition: all 1s;
	clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
}
.srvElement:hover .srvElementHeader::before {
	transition: all 1s;
	width: 0;
}

/*LAST PARAGRAPHS STYLE*/
#home-first-content-section {
	background: #1d1d1d;
	/* padding-top: 0; */
}

#home-first-content-images {
	display: flex;
	justify-content: center;
	width: 100%;
	position: relative;
	align-items: center;
}
#home-first-content-images > div {
	width: 100%;
	max-width: 600px;
}
.home-first-content-images {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 100%;
	position: relative;
	transition: all 1s;
}
.home-first-content-image-1 {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 100%;
	position: relative;
	margin-bottom: 10px;
	z-index: 1;
	transition: all 1s;
}
.home-first-content-text {
	position: relative;
	width: 100%;
	font-size: 23px;
	font-weight: 600;
	color: #e23045;
	letter-spacing: 1px;
	margin-bottom: 10px;
	text-align: center;
	transition: all 1s;
}
.home-first-content-image {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 200px;
	clip-path: polygon(10% 0%, 100% 0%, 100% 100%, 0% 100%);
	transition: all 1s;
}
.home-first-content-icon {
	position: absolute;
	width: 90px;
	height: 90px;
	z-index: 2;
	right: 0;
	top: calc(50% - 75px);
	background: #e23045;
	border-radius: 50%;
	padding: 5px;
	box-shadow: 0 0 5px #000;
	transition: all 1s ease;
}
.home-first-content-icon > img {
	position: relative;
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
	filter: brightness(0) invert(1);
}
.home-first-content-image > img {
	position: absolute;
	object-fit: cover;
	object-position: center;
	width: 100%;
	height: 100%;
	z-index: 1;
	box-shadow: 0 0 5px #000;
}
.home-first-content-image-2 {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	position: relative;
	height: 300px;
	border-radius: 20px;
	z-index: 0;
	transition: all 1s;
}
.home-first-content-image-2 > img {
	position: absolute;
	object-fit: cover;
	object-position: center;
	width: 100%;
	height: 100%;
	border-radius: 20px;
	box-shadow: 0 0 5px #000;
}

.home-first-content-images:hover .home-first-content-image {
	transform: scaleX(-1);
}

.home-first-content-images:hover .home-first-content-icon {
	right: calc(100% - 50px);
}

.home-first-content-images:hover .home-first-content-text {
	margin-bottom: 0;
	margin-top: 10px;
}

.home-first-content-images:hover .home-first-content-image-1 {
	transform: translateY(105%);
	flex-direction: column-reverse;
}

.home-first-content-images:hover .home-first-content-image-2 {
	transform: translateY(-105%);
}

div#home-content-section {
	background-color: #1d1d1d !important;
	padding-top: 0;
}

.gallery-btn {
	text-shadow: 0 0 5px #000;
	margin-left: 0;
	margin-top: 10px;
}

.nap-grid-areas {
	display: flex;
	flex-direction: row;
	justify-content: flex-start;
	align-items: flex-start;
	align-content: center;
	flex-wrap: wrap;
	width: 100%;
	margin-bottom: 15px;
}

.nap-grid-item {
	width: 46%;
	text-align: left;
	margin: 5px;
}

.nap-grid-item::before {
	content: "\f7d9" !important;
	font-family: 'FontAwesome';
	display: inline-block;
	background-size: contain;
	background-repeat: no-repeat;
	margin-right: 5px !important;
	color: #e23045;
	animation: pulse 1.5s infinite ease-in-out;
}

@keyframes pulse {
    0%, 100% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.2);
    }
}

/*HOME PAGE GALLERY STYLE*/
#home-gallery-section {
	background: #1d1d1d !important;
	padding-top: 0;
	z-index: 999999;
}

#home-gallery-titles {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
}

#home-gallery-subtitle{
	text-align: center;
	margin-bottom: 5px;
}

#home-gallery-content {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
}

#home-gallery-content > div {
	position: relative;
}

.home-gallery {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 100%;
	position: relative;
}

.home-gallery img {
	object-fit: cover;
	object-position: center;
	position: relative;
	width: 100%;
	height: 100%;
	transition: transform 0.3s ease-in-out;
}

.home-gallery-left {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 100%;
	position: relative;
}

.home-gallery-holder-1 {
	position: relative;
	width: 100%;
}
.home-gallery-holder-2 {
	position: relative;
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
	width: 100%;
}

.home-gallery-image-1 {
	position: relative;
	width: 49%;
}

.home-gallery-image-2 {
	position: relative;
	width: 49%;
}

.home-gallery-holder-3 {
	position: relative;
	width: 100%;
}

.home-gallery-right {
	position: relative;
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

.home-gallery-holder-4 {
	width: 100%;
	position: relative;
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: stretch;
	height: 100%;
}

.home-gallery-image-3 {
	width: 49%;
	display: flex;
	align-items: stretch;
	justify-content: center;
	margin-bottom: 8px;
}

.home-gallery-holder-5 {
	width: 49%;
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: center;
	height: 100%;
}

.home-gallery-image-4 {
	height: 49%;
	position: relative;
	width: 100%;
}

.home-gallery-image-5 {
	height: 49%;
	width: 100%;
	position: relative;
}

.home-allery-holder-6 {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
}

.modal {
	display: none;
	position: fixed;
	z-index: 9999999;
	left: 0;
	top: 0;
	width: 100vw;
	height: 100vh;
	overflow: auto;
	background-color: rgba(0, 0, 0, 0.7);
	margin: 0;
	top: 0;
	left: 0;
	z-index: 9999999999;
}

.ModalOpen {
	display: flex;
	align-items: center;
	justify-content: center;
}

.ModalOpen > div {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	max-width: 1080px;
	width: 95%;
	position: relative;
}

.modal-content {
	position: relative;
	background-color: #1d1d1d;
	display: block;
	overflow: hidden;
}

.modal-content img {
	max-width: 100%;
	max-height: 70vh;
	margin: auto;
	display: block;
}

.close {
	color: white;
	position: relative;
	font-size: 35px;
	font-weight: bold;
	cursor: pointer;
	display: block;
	margin-bottom: 10px;
	align-self: flex-start;
	}
  
.demo {
	width: 100%;
	padding: 4px;
	cursor: pointer;
	transition: opacity 0.3s ease;
}

.mySlides {
	display: none;
	position: relative;
	width: 100%;
	height: auto;
}

.numbertext {
	background: #2d2d2d;
	padding-left: 10px;
}

.prev, .next {
	cursor: pointer;
	position: absolute;
	top: 50%;
	padding: 16px;
	margin-top: -50px;
	color: white;
	font-weight: bold;
	font-size: 20px;
	transition: 0.6s ease;
	border-radius: 0 3px 3px 0;
	user-select: none;
	-webkit-user-select: none;
}

.prev {
	left: 0;
	border-radius: 3px 0 0 3px;
}

.next {
	right: 0;
}

home-gallery img {
	cursor: pointer;
	transition: transform 0.3s ease-in-out;
}
  
.home-gallery img:hover {
	transform: scale(1.05);
}

.demo:hover, .active {
	opacity: 1;
}

.close:hover,
.close:focus {
  color: #999;
  text-decoration: none;
}

.prev:hover,
.next:hover {
  background-color: rgba(0, 0, 0, 0.8);
}

/* SERVICES LIST SECTION STYLE */
div#services-list-section {
	background-color: #ffffff !important;
}

.homepage-services {
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
}

.homepage-services #servcss {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-content: center;
	justify-content: flex-start;
	align-items: flex-start;
	list-style-type: none;
	padding: 0;
}

.homepage-services #servcss li {
	position: relative;
	color: #ffffff;
	text-align: left;
	margin: 5px;
	width: 100%;
	display: flex;
	flex-direction: row;
	align-items: flex-start;
	justify-content: flex-start;
}

.homepage-services #servcss li:before {
	text-align: center;
	margin-right: 10px;
	content: "";
	color: #fff;
	background-color: #e23045;
	border-radius: 50%;
	width: 35px;
	height: 35px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-image: url(https://ca-mobilemechanicsvc.com/wp-content/uploads/2025/03/auto-repair-icon.webp);
	background-size: 80%;
	background-position: center;
	background-repeat: no-repeat;
    animation: shadowPulse 1.5s infinite ease-in-out;
}

@keyframes shadowPulse {
    0%, 100% {
        box-shadow: 0 0 5px #2d2d2d;
    }
    50% {
        box-shadow: 0 0 20px #e23045;
    }
}

/* NAP SECTION STYLE */
div#homepage-nap-section {
	overflow: hidden;
	padding: 0;
	background: #1d1d1d;
}

#homepage-nap-row {
	width: 100% !important;
	padding: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background: #2d2d2d;
	box-shadow: 0 0 5px #000;
}

#homepage-nap-image1-col {
	position: relative;
	padding-top: 50px;
	max-width: 450px;
	align-self: flex-start;
}

#homepage-nap-col {
	width: 95% !important;
}

#homepage-nap-image1-col::before {
	content: '';
	background: #e23045;
	position: absolute;
	width: 100%;
	height: 100%;
	bottom: 32px;
	clip-path: polygon(0% 0%, 60% 0%, 100% 100%, 0% 100%);
	z-index: 0;
}

#homepage-nap-image2-col {
	position: relative;
	margin-top: 30px;
	padding-top: 30px;
	max-width: 450px;
	align-self: flex-end;
}

#homepage-nap-image2-col::before {
	content: '';
	background: #e23045;
	position: absolute;
	width: 100%;
	height: 100%;
	bottom: 40px;
	right: -9px;
	clip-path: polygon(40% 0%, 100% 0%, 100% 100%, 0% 100%);
	z-index: 0;
}

#homepage-nap-image-1 {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
}

#homepage-nap-image-1 img {
	object-fit: contain;
	object-position: center;
	width: 100%;
	height: 100%;
	position: relative;
}

#homepage-nap-image-2 {
	position: relative;
}

#homepage-nap-image-2 img {
	object-fit: contain;
	object-position: center;
	width: 100%;
	height: 100%;
	position: relative;
}

.homepage-nap h3 {
	text-align: center;
	color: #ffffff;
	line-height: 1.2;
	padding: 0;
	font-size: 18px;
	text-shadow: -1px -1px 0 rgb(0 0 0 / 40%), 1px -1px 0 rgb(0 0 0 / 40%), -1px 1px 0 rgb(0 0 0 / 40%), 1px 1px 0 rgb(0 0 0 / 40%);
}

.homepage-nap h3 strong {
	color: #e23045;
	font-size: 26px;
	line-height: 1.2;
	display: inline-block;
	padding-bottom: 10px;
}

/* NAP Google listing button */

#main-footer .listing-rev-btn .fa {
	display: block;
	margin-right: 5px;
}

#main-footer .listing-rev-btn img {
	display: none;
}

#main-footer .listing-rev-btn {
	border: 1px solid #000;
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
	background: #e23045;
	color: #fff;
	bottom: 10px;
	padding: 5px 38px 5px 38px;
	font-weight: normal;
	font-size: 16px !important;
	display: flex;
	justify-content: center;
	align-items: center;
	position: fixed;
	z-index: 999;
}

/* Floating Quote Button button */
.floating-quote-btn {
	display: inline-block;
	position: fixed;
	left: 0;
	background: #ffffff;
	color: #000;
	border: 1px solid #000;
	border-left: 0;
	bottom: 58px;
	padding: 5px 15px 5px 15px;
	font-weight: normal;
	display: none;
	z-index: 9999;
}

/* TESTIMONIALS SECTION STYLE */
div#home-testimonials {
	background-color: #1d1d1d !important;
	overflow: hidden;
	padding-top: 0;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

#testimonials-block {
	border-radius: 20px;
	padding: 60px 0;
	box-shadow: 0 0 5px #000;
}

.testimonials-section-title {
	text-align: center;
	font-size: 26px !important;
	font-weight: bold;
	font-family: 'Montserrat', sans-serif;
	line-height: 1.1;
	color: #333333;
}

div#testimonials-txt {
	text-align: center;
}

.home .wpcr3_respond_1 {
	padding: 15px !important;
	color: #333333;
}

.home .wpcr3_dotline {
	display: none !important;
}

.home .wpcr3_review {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
}

.home .wpcr3_review_ratingValue {
	width: 100%;
	text-align: center;
	margin: 0 !important;
}

.home .wpcr3_review_author {
	margin-left: 5px;
	text-align: center;
}

.home .wpcr3_review_title.wpcr3_caps {
	width: 100%;
	text-align: center;
	margin: 0 !important;
	font-size: 18px;
	color: #388e3c;
	font-weight: bold;
}

.home span.wpcr3_item_name a {
	color: #333333;
}

div.wpcr3_review blockquote.wpcr3_content {
	border-color: #e23045;
	padding-bottom: 0;
	text-align: justify;
}

.home div.wpcr3_review blockquote.wpcr3_content {
	text-align: center;
	border: none;
	margin-bottom: 0;
	line-height: 1.7em;
	order: 1;
	background: #323232;
	padding: 10px;
	color: #fff;
}

div.wpcr3_review blockquote.wpcr3_content p {
	font-size: 16px;
}

.home .wpcr3_reviews_holder {
	position: relative;
}

.home div.wpcr3_review blockquote.wpcr3_content p {
	font-style: italic;
}

.testimonials-btn {
	background: #388e3c;
	color: #ffffff;
	padding: 10px 25px;
	display: inline-block;
	line-height: 1;
	margin-top: 10px;
	border: 1px solid #ffc107;
}

.testimonials-btn:hover {
	color: #fff;
	background: #646464;
}

/* reviews */

.review-title {
	text-align: center;
	font-size: 36px !important;
	font-weight: bold;
	font-family: 'Montserrat', sans-serif;
	line-height: 1.1;
	color: #333333;
}

.external-reviews-holder {
	z-index: 99;
	position: relative;
	width: 100%;
	max-width: 500px;
	height: 100%;
	padding: 20px 10px;
	text-align: center;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.sliding-review-container {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
}

.review-origin-brand {
	background: #fff;
	padding: 10px;
	width: 120px;
	display: flex;
	justify-content: center;
	align-items: center;
	top: 20px;
	left: 10px;
}

.review-origin-brand img {
	margin: 0;
	height: 35px;
	object-fit: contain;
}

.external-review-title {
	text-align: center;
	font-size: 20px !important;
	color: #000;
	font-weight: 600;
	line-height: 1.1em;
	margin-top: 20px;
	text-transform: uppercase;
}

.external-review-credentials {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	margin-top: 20px;
	color: #000;
}

.external-review-author {
	margin: 0 5px;
}

.external-review-date {
	margin: 0 5px;
}

.external-review-text {
	overflow: hidden;
	-webkit-line-clamp: 3;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	margin: 10px auto;
	text-align: center;
	padding: 0 25px;
	width: 95%;
	color: #000;
	font-weight: 300;
	font-style: italic;
	position: relative;
}

.external-review-text:before {
	content: '\f10e';
	font-family: 'FontAwesome';
	position: absolute;
	left: 5px;
	top: 0;
	opacity: 0.5;
}

.external-review-text:after {
	content: '\f10d';
	font-family: 'FontAwesome';
	position: absolute;
	right: 5px;
	bottom: 0;
	opacity: 0.5;
}

.external-reviews-holder a {
	width: 200px;
	background: #388e3c;
	color: #ffffff;
	padding: 10px 25px;
	display: inline-block;
	line-height: 1;
	margin-top: 10px;
	border: 1px solid #ffc107;
}

.external-reviews-holder a:hover {
	background-color: #646464;
}

div#external-reviews {
	padding: 0 !important;
	background: #63d471;
}

div#external-reviews .et_pb_row {
	padding: 0 !important;
}

.static-external-review-container {
	width: 100%;
	display: flex;
	justify-content: center;
}

.static-external-review-container .external-reviews-holder {
	min-height: 380px;
	justify-content: flex-end;
}

@media (min-width: 1025px) {
	.static-external-review-holder {
		display: flex;
		position: relative;
		justify-content: center;
	}

	.static-external-review-container {
		width: 50%;

	}

	.static-external-review-container .external-reviews-holder {
		min-height: 420px;
		justify-content: center;
	}

	.review-origin-brand {
		position: absolute;
	}


}

/* end reviews */
/* CONTACT FORM STYLE */
#contact-form-row {
	width: 100% !important;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

#contact-form-content {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
}

#contact-form-image {
	align-items: stretch;
	height: 300px;
	display: flex;
	justify-content: center;
	width: 600px;
	border-radius: 20px
}

#contact-section {
	width: 95%;
}

p.free-estimate-title {
	font-size: 26px !important;
	font-weight: bold;
	font-family: 'Montserrat', sans-serif;
	line-height: 1.1;
	color: #ffffff;
	margin-bottom: 15px;
	padding-bottom: 2px;
	text-align: center;
}

div#contact-form-section {
	padding-top: 0;
	background: #1d1d1d;
	display: flex;
	align-items: stretch;
	justify-content: center;
}

input#customer_name {
	width: calc(50% - 5px);
	float: left;
}

input#phone-cf {
	width: calc(50% - 5px);
	float: left;
	margin-left: 10px;
}

textarea#message {
	margin-bottom: 20px;
}

#contact img {
	float: left;
	width: 120px;
	height: 40px;
	min-height: 40px;
	border-radius: 5px;
	filter: grayscale(1);
}

input#vercode {
	width: calc(100% - 130px);
	margin: 0;
	margin-left: 10px;
	float: left;
	padding: 7px 10px 7px;
	height: 40px;
}

form#contactForm {
	text-align: center;
}

input#submitter {
	font-size: 16px;
	font-weight: 400;
	text-transform: capitalize;
	transition: 500ms;
	position: relative;
	z-index: 1;
	height: 39px;
	background: #e23045;
	color: #ffffff;
	border-color: #e23045;
	padding: 11px 20px;
	display: inline-block;
	line-height: 1;
	width: 210px;
	text-align: center;
	border-radius: 0;
	transition: all 0.5s;
}

input#submitter:hover {
	color: #000;
	background: #f9f9f7;
	border-color: #f9f9f7;
}

input.text,
input.title,
input[type=email],
input[type=password],
input[type=tel],
input[type=text],
select,
textarea {
	max-width: 100%;
	padding: 7px 5px 7px;
	height: auto;
	display: block;
	line-height: 1;
	font-weight: 300;
	color: #fff !important;
	background-image: none;
	margin-bottom: 10px !important;
	background: transparent;
	box-shadow: 0px 0px 5px #000;
	backdrop-filter: blur( 3px );
	-webkit-backdrop-filter: blur( 3px );
	border-color: #1d1d1d;
}

#contactForm input[type=text]::placeholder,
#contactForm input[type=password]::placeholder,
#contactForm input[type=tel]::placeholder,
#contactForm input[type=email]::placeholder,
#contactForm input.text::placeholder,
#contactForm input.title::placeholder,
#contactForm textarea::placeholder,
#contactForm select {
	color: #fff !important;
}

#contactForm input[type=text]:focus,
#contactForm input[type=password]:focus,
#contactForm input[type=tel]:focus,
#contactForm input[type=email]:focus,
#contactForm input.text:focus,
#contactForm input.title:focus,
#contactForm textarea:focus,
#contactForm select:focus {
	color: #fff !important;
	border-color: #000000;
}

#contact {
	padding: 0;
	max-width: 600px;
	margin: 0 auto;
}

.link-button {
	width: 210px;
	text-align: center;
	background: #388e3c;
	color: #ffffff;
	padding: 10px 25px;
	display: inline-block;
	line-height: 1;
	margin-top: 10px;
	border: 1px solid #ffc107;
}

.link-button:hover {
	color: #fff;
	background: #646464;
}

/* FOOTER STYLE */
#main-footer {
	background: #0a0a0a;
	background-size: contain;
	background-repeat: repeat;
}

#main-footer .container {
	width: 95%;
}

div#footer-bottom {
	padding: 15px;
	color: #ffffff;
	background: #e23045 !important;
}

.paymentsbox {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}

.footer-widget h4 {
	color: #ffffff;
	font-size: 22px;
	margin-bottom: 20px;
	margin-top: 30px;
	font-weight: bold;
	line-height: 1.5em;
	text-align: center;
	border-bottom: 1px solid #e23045;
	text-transform: uppercase;
	font-family: 'Montserrat', sans-serif;
}

.footer-widget .textwidget {
	color: #efefef;
}

#footer-widgets .footer-widget a {
	background-color: #fff;
}

table.openinghours {
	max-width: 350px;
	margin: 0 auto !important;
	width: 100%;
}

table.openinghours tr {
	display: flex;
	justify-content: space-between;
	line-height: 2;
	font-family: 'Open Sans', sans-serif;
	color: #cccccc;
}

#current-day {
	background-color: #e23045;
	padding: 0 2px;
}

#current-day td {
	color: #fff;
	text-shadow: none;
}

#closed-day {
	color: #efefef;
}

.menu-footer-menu-container {
	display:flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

#menu-footer-menu {
	display:flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
}

ul#menu-footer-menu li {
	text-align: left;
}

ul#menu-footer-menu li a {
	background: transparent !important;
}


ul#menu-footer-menu li:before {
	font-family: 'FontAwesome' !important;
	border: none !important;
	content: "\f7d9" !important;
	display: inline-block;
	margin-right: 5px !important;
	color: #e23045 !important;
	position: relative !important;
	top: 0 !important;
	left: 0 !important;
}

/* SIDEBAR, BLOG PAGE, BLOG POST STYLES */
.et_pb_sidebar_0 h4.widgettitle {
	font-size: 26px;
	font-weight: 400;
	color: #fff;
	position: relative;
	margin-bottom: 10px;
	line-height: 1.2;
	text-align: center;
	border-bottom: 1px solid #e23045;
}

#sidebar h4.widgettitle {
	font-size: 26px;
	font-weight: 400;
	color: #062d5b;
	position: relative;
	margin-bottom: 10px;
	line-height: 1.2;
	text-align: center;
	border-bottom: 1px solid #062d5b;
}

.et_pb_sidebar_0 .textwidget {
	text-align: center;
}

#sidebar .textwidget {
	text-align: center;
}

.single-post div#main-content,
.blog div#main-content {
	background-color: #ffffff;
	min-height: 50vh;
}

.single-post .et_pb_post .entry-content {
	text-align: justify;
}

.single-post div#main-content .container {
	padding: 0px 0 !important;
}

.et_pb_title_meta_container,
.post-meta {
	text-align: center;
}

.post-content-inner {
	text-align: justify;
}

.single-post div#main-content .post {
	padding-bottom: 0 !important;
	margin-bottom: 0 !important;
}

.single-post div#main-content .container {
	padding: 0px 0 !important;
	width: 95%;
}

.single-post .et_pb_row {
	width: 100% !important;
}

#left-area .post-meta a {
	color: #16bae1;
}

#left-area .post-meta {
	text-align: center;
}

.blog .et_pb_post {
	text-align: justify;
}

/*MEDIA QUERIES*/
@media only screen and (min-width: 460px) {
	.srvElementImg::before {
		left: -21px;
	}
	.srvElementHeader::before {
		left: -19px;
		transform: rotate(31deg);
	}
}

@media only screen and (min-width: 600px) {
	.home div#page-container {
		padding-top: 80px !important;
	}
	
	.main-header-napinfo-block {
		padding-right: 0;
	}

	.srvElementImg img {
		height: 300px;
	}

	.homepage-services {
		max-width: 100%;
	}

	.homepage-services #servcss li {
	    width: 48%;
	}

	input#customer_name {
		width: calc((100%/3) - 7px);
	}

	input#phone-cf {
		width: calc((100%/3) - 7px);
	}

	input#customer_email {
		width: calc((100%/3) - 6px);
		float: left;
		margin-left: 10px;
	}

	div#services-blocks-section > div > div {
		width: 100% !important;
	}

	.srvElementImg::before {
		left: -21px;
		transform: rotate(-9.5deg);
	}

	.srvElementHeader::before {
		left: -19px;
		transform: rotate(40deg);
	}

	.nap-grid-item {
		width: 30%;
	}

	/*HOME GALLERY DESKTOP*/
	.home-gallery {
		flex-direction: row;
		justify-content: space-between;
		align-items: stretch;
		max-width: 600px;
	}

	.home-gallery-left {
		width: 49%;
	}

	.home-gallery-holder-1 {
		margin-bottom: 7px;
	}

	.home-gallery-right {
		width: 49%;
	}

	.home-gallery-holder-4 {
		margin-bottom: 7px;
	}

	.home-gallery-image-3 {
		margin-bottom: 0;
	}

	/*NAP SECTION STYLE*/
	div#homepage-nap-section {
		padding-bottom: 30px;
	}
	#homepage-nap-row {
		flex-direction: row;
		align-items: flex-start;
	}

	#homepage-nap-image1-col {
		align-self: flex-end;
		margin: 0;
	}

	#homepage-nap-image1-col::before {
		bottom: 0;
		height: 180%;
		clip-path: polygon(0% 0%, 30% 0%, 100% 100%, 0% 100%);
	}

	#homepage-nap-col {
		margin: 0;
		align-self: center;
		padding: 30px 0;
	}

	#homepage-nap-image2-col {
		margin-top: 0;
	}

	#homepage-nap-image2-col::before {
		bottom: 0;
		height: 180%;
		clip-path: polygon(70% 0%, 100% 0%, 100% 100%, 0% 100%);
	}

	#homepage-nap-image-1 {
		bottom: -25px;
	}

	#homepage-nap-image-2 {
		bottom: -25px;
	}
}

@media screen and (max-width: 981px) {

	/* ADDITIONAL STYLES FOR MOB. RES. */
	.et_pb_sidebar_0 .et_pb_widget {
		width: 100%;
	}

	.footer-widget:nth-child(n) {
		width: 100% !important;
		text-align: center;
		margin: 0 !important;
	}

	.et_pb_text {
		text-align: center !important;
	}

	#footer-widgets .footer-widget .fwidget {
		width: 100% !important;
		margin-bottom: 30px !important;
	}
}

@media screen and (min-width: 981px) {
	div#page-container {
		padding-top: 175px !important;
	}

	.home div#page-container {
		padding-top: 60px !important;
	}

	/*HEADER STYLES*/
	.logo_container {
		min-height: 50px !important;
		padding: 0 10px;
		justify-content: flex-start;
	}

	.logo-link {
		max-height: 100%;
	}

	.main-header-napinfo-block {
		padding-bottom: 0;
	}
	.top_button {
		padding: 8px 10px;
	}
	.main-header-email-btn {
		position: relative;
		margin: 5px;
		padding: 5px 10px;
	}

	.header-menu-container {
		padding: 5px 0;
		max-width: 1280px;
	}

	.header-info-holder {
		display: flex;
		justify-content: flex-start;
		align-items: center;
		width: 400px;
		margin: 0;
	}

	.main-header-info-container {
		justify-content: center;
	}

	.main-header-napinfo-block span {
		line-height: 24px !important;
		font-weight: normal;
	}

	.main-header-email-btn .fa {
		font-size: 30px;
	}

	#main-header.et-fixed-header {
		background: #0d0d0d!important;
		height: auto;
		box-shadow: 0px 3px 4px #0000005e !important;
		z-index: 10;
	}

	#top-menu li {
		padding: 0 !important;
	}

	#top-menu .menu-item-has-children::after {
	   font-family: 'ETmodules';
	   content: '3';
	   font-size: 16px;
	   position: absolute;
	   right: -1px;
	   top: 19px;
	   font-weight: 800;
	   z-index: 3;
	   color: #fff;
	}

	#top-menu-nav ul.sub-menu li::before {
	font-family: 'FontAwesome';
	content: '\f149';
	font-size: 16px;
	position: absolute;
	left: 10px;
	font-weight: 800;
	z-index: 3;
	color: #fff;
	-webkit-transform: scaleX(-1) rotate(90deg);
	transform: scaleX(-1) rotate(90deg);
	}


	nav#top-menu-nav ul#top-menu li a {
		color: #fff !important;
		overflow: hidden;
		background-color: transparent;
		transition: .5s;
		position: relative;
		cursor: pointer;
		z-index: 1;
		padding: 18px 15px !important;
	}

	nav#top-menu-nav ul#top-menu li a::after, nav#top-menu-nav ul#top-menu li a::before {
		content: '';
		display: block;
		height: 100%;
		width: 105%;
		transform: skew(90deg) translate(-50%, -50%);
		position: absolute;
		inset: 50%;
		left: 40%;
		z-index: -1;
		transition: .5s ease-out;
		background-color: #e23045;
 }
	
	nav#top-menu-nav ul#top-menu li a::before {
		top: -50%;
		left: -55%;
		transform: skew(90deg) rotate(180deg) translate(-50%, -50%);
		}
  	nav#top-menu-nav ul#top-menu li a:hover::before {
    	transform: skew(45deg) rotate(180deg) translate(-50%, -50%);
  	}
  	nav#top-menu-nav ul#top-menu li a:hover::after {
    	transform: skew(45deg) translate(-50%, -50%);
  	}

	nav#top-menu-nav ul#top-menu li:hover a {
		opacity: 1 !important;
	}

	div#et-top-navigation {
		padding: 0px 10px !important;
		width: calc(100% - 300px);
	}

	nav#top-menu-nav {
		width: 100%;
		display: flex;
		align-items: center;
		justify-content: flex-end;
	}

	nav#top-menu-nav ul#top-menu .current-menu-item {
		background: #e23045;
		border-radius: 0;
		padding: 0;
	}

	ul.sub-menu {
		filter: drop-shadow(0px 1px 3px #5b5b5b);
		top: 50px;
		background-color: #0d0d0d !important;
		border-color: #e23045 !important;
	}

	nav#top-menu-nav #top-menu ul.sub-menu a {
		color: #fff !important;
		position: relative;
		padding: 6px 6px 6px 28px !important;
		line-height: 1.2;
	}

	nav#top-menu-nav #top-menu ul.sub-menu .current-menu-item a {
		color: #000 !important;
	}

	#top-menu-nav ul.sub-menu a:before {
		content: '\f149';
		position: absolute;
		left: 0;
		font-family: 'FontAwesome';
		-webkit-transform: scaleX(-1) rotate(90deg);
		transform: scaleX(-1) rotate(90deg);
	}

	ul.sub-menu li {
		padding: 0 10px !important;
		width: 100%;
	}

	ul.sub-menu li a {
		padding: 5px 0px !important;
		width: 100% !important;
	}

	/*END HEADER STYLES*/
	/*PAGE STYLES*/
	section.et_pb_module.et_pb_fullwidth_header.et_pb_fullwidth_header_0.et_pb_text_align_center.et_pb_bg_layout_dark.et_pb_fullscreen {
		max-height: 900px !important;
		min-height: 600px !important;
		height: calc(100vh - 184px) !important;
		background-position: center;
		background-position-y: calc(100% - 50px);
	}

	.et_pb_fullscreen .et_pb_fullwidth_header_container {
		max-height: 900px !important;
		min-height: 600px !important;
		height: calc(100vh - 184px) !important;
	}

	.header-content-container {
		margin-top: 150px
	}

	.et_pb_fullscreen .et_pb_fullwidth_header_container::before {
		width: 650px;
		height: 500px;
		bottom: 20px;
	}

	.ws-slogan h1 {
		font-size: 30px;
		max-width: 600px;
	}

	div#first-par-img,
	div#first-par-img span {
		height: 100%;
	}

	div#first-par-img img {
		height: 100%;
		object-fit: cover;
		object-position: left;
	}

	.entry-title {
		text-align: left;
	}

	/*FIRST PARAGRAPH STYLE DESKTOP*/
	#home-first-paragraph-text {
		border-radius: 20px 0 0 20px;
		clip-path: polygon(0% 0%, 100% 0%, 85% 100%, 0% 100%);
		padding: 30px 80px 30px 15px;
	}

	#home-first-paragraph-row {
		padding-bottom: 0;
		background-position-y: 80%;
	}

	#home-first-paragraph-image {
		min-height: 0;
	}

	/* BADGES STYLE DESKTOP*/
	.badge-holder {
		width: 22%;
	}

	.badge-holder:nth-child(3) {
		order: unset;
	}

	/* SERVICES STYLE DESKTOP*/
	.srvElement {
		width: 43%;
		display: flex;
		flex-direction: column;
		margin: 15px 65px 15px 0;
	}
	.srvElementImg::before {
		left: -29px;
		transform: rotate(-9.5deg);
	}

	.srvElementHeader::before {
		left: -27px;
		transform: rotate(33deg);
	}
	.srvElementFullWidth .srvElementImg::before {
		display: none;
	}

	.srvElementFullWidth .srvElementHeader::before {
		display: none;
	}
	.srvElementImg img {
		height: 200px;
	}

	.srvElementFullWidth .srvElementImg img {
		height: 100%;
	}

	.srvBlock {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		max-width: 1200px;
		margin: 0;
		align-items: center;
		margin-right: -130px;
		align-content: center;
		flex-direction: row;
		width: 100%;
	}

	.srvElementBody {
		height: 100%;
	}

	.srvElementHeader h2 {
		min-height: 54px;
		display: flex;
		justify-content: center;
		align-items: center;
	}

	.srvElementContent {
		height: 100%;
	}

	.srvElementFullWidth .srvElementContent {
		height: auto;
	}

	.srvElement.srvElementFullWidth {
		width: 100%;
		max-width: 1080px;
		flex-direction: row;
	}

	.srvElementFullWidth .srvElementHeader {
		width: 100%;
		clip-path: polygon(10% 0%, 100% 0%, 90% 100%, 0% 100%);
	}

	.srvElementFullWidth .srvElementImg {
		width: 40%;
		margin: 0;
		clip-path: polygon(10% 0%, 100% 0%, 90% 100%, 0% 100%);
	}

	.srvElementFullWidth .srvElementText {
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		width: 60%;
		transition: all 1s ease;
	}

	.srvElementFullWidth .srvElementBody {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		margin: 20px 20px 20px 30px;
		height: auto;
		padding: 0;
		width: 100%;
	}

	/*LAST CONTENT DESKTOP*/
	#home-first-content-images > div {
		align-items: stretch;
	}
	.home-first-content-images {
		flex-direction: row;
		justify-content: space-between;
		align-items: flex-end;
	}
	.home-first-content-image-1 {
		margin-bottom: 0;
		width: 49%;
	}
	.home-first-content-text {
		text-align: left;
		margin-left: -10px;
		margin-bottom: 30px;
		width: 150px;
	}
	.home-first-content-icon {
		right: calc(50% - 45px);
		top: 55px;
	}
	.home-first-content-image-2 {
		width: 49%;
		align-items: stretch;
	}

	.home-first-content-images:hover .home-first-content-image {
		transform: scaleX(-1);
	}

	.home-first-content-images:hover .home-first-content-icon {
		top: calc(100% - 50px);
		right: calc(50% - 45px);
	}

	.home-first-content-images:hover .home-first-content-text {
		margin-left: 0;
		width: auto;
		margin-top: 0;
		margin-bottom: 30px;
	}

	.home-first-content-images:hover .home-first-content-image-1 {
		transform: translateX(105%) !important;
		flex-direction: column;
	}

	.home-first-content-images:hover .home-first-content-image-2 {
		transform: translateX(-105%);
	}

	.nap-grid-item {
		width: 23%;
	}

	.home-gallery {
		max-width: none;
	}

	/* NAP SECTION DESKTOP */
	#homepage-nap-col {
		width: 50% !important;
	}

	/* CONTACT SECTION DESKTOP */
	div#contact-form-section {
		padding: 0;
	}
	#contact-form-row {
		flex-direction: row;
		padding: 0;
		align-items: stretch;
		height: 100%;
	}
	#contact-form-image {
		max-width: none;
		border-radius: 0;
		align-items: stretch;
		height: 100%;
		min-height: 420px;
	}
	#contact-form-content {
		padding: 50px 0;
		height: 100%;
	}

	/* TESTIMONIALS SECTION DESKTOP */
	.home .wpcr3_review {
		justify-content: flex-start;
		text-align: left;
	}

	.home .wpcr3_review_ratingValue {
		text-align: left;
		width: auto;
	}

	p.testimonials-section-title {
		text-align: left;
	}

	div#testimonials-txt {
		text-align: left;
		display: flex;
		flex-direction: column;
		justify-content: center;
	}

	.home .wpcr3_review_title.wpcr3_caps {
		text-align: left;
	}

	.home div.wpcr3_review blockquote.wpcr3_content {
		text-align: left;
	}

	.home .wpcr3_respond_1 {
		padding-left: 0 !important;
	}

	/* SERVICES LIST SECTION DESKTOP */
	.homepage-services #servcss li {
		width: 32%;
	}


	/* FOOTER STYLES DESKTOP */
	.footer-widget .et_pb_widget {
		width: 100%;
		margin-bottom: 0 !important;
	}

	.paymentsbox {
		justify-content: flex-start;
	}

	div#social-icons {
		text-align: left;
	}

	.footer-widget h4 {
		text-align: left;
	}

	#footer-widgets {
		padding-top: 20px;
	}

	.menu-footer-menu-container {
		align-items: flex-start;
	}

	/* SIDEBAR, BLOG, BLOGPOST STYLES DESKTOP */
	.et_pb_sidebar_0 h4.widgettitle {
		text-align: left;
	}

	#sidebar h4.widgettitle {
		text-align: left;
	}

	.et_pb_sidebar_0 .textwidget {
		text-align: left;
	}

	#sidebar .textwidget {
		text-align: left;
	}

	.et_pb_sidebar_0.et_pb_widget_area_right {
		border-left: 1px solid #e23045;
	}

	#left-area .post-meta {
		text-align: left;
	}

	#main-content .container:before {
		background-color: rgb(6 45 91 / 20%);
	}

	.et_pb_title_meta_container,
	.post-meta {
		text-align: left;
	}
}

/***** TESTIMONIALS FORM *****/
.wpcr3_respond_2 input[type="text"] {
	margin: 3px 0;
}

.wpcr3_respond_2 input[type="text"],
.wpcr3_in_content textarea {
	background: #ffffff !important;
	color: #000 !important;
	border-color: #000 !important;
}

.wpcr3_respond_2 input[type="text"]:focus,
.wpcr3_in_content textarea:focus {
	color: #fff;
	border-color: #ffffff;
}

.wpcr3_table_2 td {
	font-size: 1em !important;
}

.wpcr3_leave_text {
	font-size: 1.1em;
}

.wpcr3_leave_text {
	margin-bottom: 20px;
	color: #fff;
}

.wpcr3_button_1 {
	margin-top: 10px;
	border-radius: 0px;
	color: #e23045;
	display: inline-block;
	line-height: 1;
	padding: 10px 10px;
	border: 2px solid #e23045;
	position: relative;
	overflow: hidden;
	background: transparent;
	text-align: center;
	text-transform: uppercase;
	transition: .3s;
	z-index: 1;
	font-weight: 600;
	font-size: 16px;
	text-shadow: 0 0 5px #000;
	backdrop-filter: blur( 2px );
	-webkit-backdrop-filter: blur( 2px );
}

.wpcr3_button_1::before {
	content: '';
	width: 0;
	height: 565%;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) rotate(45deg);
	background: #e23045;
	transition: .5s ease;
	display: block;
	z-index: -1;
}

.wpcr3_button_1:hover::before {
	width: 105%;
}

.wpcr3_button_1:hover {
	color: #fff;
	font-weight: 400 !important;
	text-shadow: none;
	border-color: #e23045;
	background: transparent;
}

@media (min-width: 981px) {

	.wpcr3_respond_2 input[type="text"],
	.wpcr3_respond_2 textarea {
		min-width: 100%;
	}

	.wpcr3_table_2 td {
		text-align: left !important;
	}

	.wpcr3_review_form_rating_field label {
		margin: 6px 0 !important;
	}
}

@media (max-width: 980px) {
	.review-title {
		font-size: 26px !important;
	}

	.wpcr3_respond_3,
	.wpcr3_aggregateRating,
	.wpcr3_table_2 td {
		text-align: center !important;
	}

	.wpcr3_div_2 {
		width: 100%;
	}

	.wpcr3_table_2 tr:last-of-type td {
		margin: 20px auto 0 !important;
	}

	.wpcr3_table_2 td {
		display: block;
		padding: 0 !important;
	}

	.wpcr3_table_2 td:first-child {
		margin-top: 10px !important;
	}

	.wpcr3_rating_style1_status {
		width: 85px !important;
	}

	.wpcr3_respond_2 input[type="text"],
	.wpcr3_in_content textarea {
		width: 100% !important;
		min-width: unset !important;
	}

	.wpcr3_submit_btn,
	.wpcr3_cancel_btn {
		width: 40%;
	}
}

@keyframes ringing {
	20% {
		transform: rotate(0deg);
	}

	21% {
		transform: rotate(10deg);
	}

	22% {
		transform: rotate(-10deg);
	}

	23% {
		transform: rotate(12deg);
	}

	24% {
		transform: rotate(-12deg);
	}

	25% {
		transform: rotate(12deg);
	}

	26% {
		transform: rotate(-12deg);
	}

	28% {
		transform: rotate(10deg);
	}

	30% {
		transform: rotate(-10deg);
	}

	32% {
		transform: rotate(5deg);
	}

	34% {
		transform: rotate(-5deg);
	}

	36% {
		transform: rotate(2deg);
	}

	38% {
		transform: rotate(0deg);
	}
}

/* TESTIMONIALS PLUGIN CSS*/

.testimonials-container {
	max-width: 1280px;
	/*padding: 1rem 2rem;*/
	margin-right: auto;
	margin-left: auto;
	text-align: center;
}

.testimonials-title {
	text-align: center;
	font-weight: 800;
	font-size: 2.25rem;
	line-height: 2.5rem;
	margin-bottom: 0.5rem;
	letter-spacing: -0.025em;
	color: #1a202c;
}

.testimonials-info {
	margin-bottom: 1rem;
}

.testimonial-item {
	border: 1px solid rgb(201, 201, 201);
	border-radius: 0px;
	padding: 1rem;
	min-height: 100%;
	break-inside: avoid;
	background: transparent;
	backdrop-filter: blur( 2px );
	-webkit-backdrop-filter: blur( 2px );
	border-radius: 10px;
	border-color: transparent;
}

.testimonials-grid .testimonial-item {
	margin-bottom: 1rem;
}

.testimonial-item:hover {
	background: transparent;
}

.testimonial-item a {
	height: 100%;
	display: grid;
}

.testimonial-subject {
	font-size: 1rem;
	font-weight: 700;
	text-align: center;
	color: #fff;
	text-shadow: 0 0 5px #000, 0 0 5px #000;
}

.rating {
	display: flex;
	justify-content: center;
	margin: 0.5rem;
}

.star {
	width: 1rem;
	height: 1rem;
	color: #ffc956;
	margin: 2px;
}

.testimonial-content {
	font-size: 1rem;
	line-height: 1rem;
	font-weight: 500;
	color: #ffffff;
	text-align: center;
	font-style: italic;
	text-shadow: 0 0 5px #000, 0 0 5px #000;
}

.testimonial-footer {
	margin-top: 1rem;
	display: flex;
	align-items: center;
	justify-content: center;
}

.reviewer-details {
	font-size: 14px;
	background: #f9f9f7;
	padding: 7px 25px;
	border: 1px solid #000;
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: center;
}

.review-from-logo {
	width: 5rem;
	height: auto;
}

.reviewer-name {
	font-weight: 500;
	color: #000;
	line-height: 1.5rem;
	font-size: 14px;
	padding-right: 0.75rem;
	font-size: 14px;
	border-right: 2px solid #1a202c;
}

/* Small devices (portrait tablets and large phones, 600px and up) */
@media only screen and (min-width: 600px) {
	.testimonials-grid {
		column-fill: balance;
		columns: 2;
		gap: 1.5rem;
	}
}

/* Large devices (laptops/desktops, 992px and up) */
@media only screen and (min-width: 992px) {
	.testimonials-grid {
		columns: 3;
	}

	.testimonial-subject {
		font-size: 1.25rem;
	}

	.testimonial-content {
		line-height: 1.5rem;
	}

	.testimonial-footer {
		display: flex;
		align-items: center;
		justify-content: center;
		background: transparent;
		padding: 0;
	}

	.reviewer-details {
		display: flex;
		align-items: center;
	}

	.reviewer-name {
		padding-right: 0.75rem;
		font-size: 14px;
		border-right: 2px solid #1a202c;
	}

	.review-from-logo {
		padding-left: 1em;
	}
}

.nav-arrows {
	display: flex;
	justify-content: center;
	gap: 1rem;
	margin-top: 1rem;
}

.nav-arrows button {
	color: #000;
	padding: 0.5rem;
	border-width: 1px;
	border-color: #f9f9f7;
	border-radius: 0px;
	cursor: pointer;
	background: #f9f9f7;
	display: flex;
	justify-content: center;
	align-items: center;
}

.nav-arrows button:hover {
	background: #e23045;
	color: #fff;
	border-color: #e23045;
}

.nav-arrows button svg {
	height: 1.25rem;
	width: 1.25rem;
	margin-right: 0;
}

.rotate-180 {
	rotate: 180deg;
}

/* END TESTIMONIALS PLUGIN CSS*/

/* ADDITTIONAL SERVICES STYLE */


#additionalServices {
	list-style: none;
	text-align: center;
	padding: 0;
	list-style-type: none;
	margin-top: 10px;
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
	align-content: center;
	flex-direction: row;
	align-items: center;
}

#additionalServices li {
	break-inside: avoid;
	padding: 5px 3px;
	font-size: 18px;
	color: #ffffff;
	position: relative;
	text-align: left;
	margin-bottom: 0 !important;
	width: 100%;
}

#additionalServices li a {
	color: #fff;
	text-decoration: underline;
}

#additionalServices li::before {
	content: "\f7d9";
	font-family: 'FontAwesome';
	display: inline-block;
	background-size: contain;
	background-repeat: no-repeat;
	margin-right: 5px;
	color: #e23045;
	animation: pulse 1.5s infinite ease-in-out;
}


@media (min-width: 600px) {
	#additionalServices li {
		break-inside: avoid;
		padding: 10px 5px;
		text-align: left;
		width: 50%;
	}
}

@media (min-width: 981px) {
	#additionalServices {
		width: 100%;
	}
	#additionalServices li {
		width: 33%;
	}
}

.nav-arrows>button.slider-previous>svg>path {
	transition: 0.1s;
}

.nav-arrows>button.slider-next>svg>path {
	transition: 0.1s;
}

#mobile_menu li a {
	line-height: 1.2em;
}

.floating-estimate-btn {
	z-index: 9999;
}

#main-footer .listing-rev-btn {
	display: flex;
	align-items: baseline;
	position: fixed;
	z-index: 9999;
}

.modalHolder {
	display: none;
}

body:not(.et_pb_page) #main-content .container {
	padding: 80px 0px !important;
}

@media only screen and (min-width: 768px) {
  .et_pb_gallery_grid .et_pb_gallery_image {
      padding-top: 100%; 
      display: block;
  }
}
@media only screen and (min-width: 480px) {
  .et_pb_gallery_grid .et_pb_gallery_image {
      padding-top: 100%; 
      display: block;
  }
}

@media only screen and (max-width: 479px) {
  .et_pb_gallery_grid .et_pb_gallery_image {
      padding-top: 100%; 
      display: block;
  }
}
  .et_pb_gallery_grid .et_pb_gallery_item img {
      position: absolute;
      height: 100%;
      width: 100%;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      object-fit: cover;
  }


@media (min-width: 1300px) {
	section.et_pb_module.et_pb_fullwidth_header.et_pb_fullwidth_header_0.et_pb_text_align_center.et_pb_bg_layout_dark.et_pb_fullscreen {
		background-position-y: calc(100% - 30px);
	}
}

.single-post div#main-content, .blog div#main-content {
	background-color: #1d1d1d;
}