/*
	Theme Name:  Europe Luxury Cars
	Description: Custom WordPress Theme
	Author:      Dimitry Barabash
	Version:     1.0.0
	License:     GPL-2.0+
	License URI: http://www.gnu.org/licenses/gpl-2.0.html
	Text-domain: cars
*/

html {
	margin: 0;
	padding: 0;
	scroll-behavior: smooth;
}

body {
    padding-top: calc(84px + var(--admin-bar-height, 0px));

    @media only screen and (max-width: 1400px) {
        padding-top: calc(118px + var(--admin-bar-height, 0px));
    }

    @media only screen and (max-width: 1000px) {
        padding-top: calc(68px + var(--admin-bar-height, 0px));
    }
} 

/* Admin bar adjustment */
html.admin-bar {
    --admin-bar-height: 32px; /* Default WP admin bar height */
}

@media only screen and (max-width: 782px) {
    html.admin-bar {
        --admin-bar-height: 46px; /* Admin bar height on smaller screens */
    }
}

.cars-site-message {
	background: #a71523;
	position: sticky;
	text-align: center;
	font-size: 90%;
	color: #fff;
	padding: 24px;
	z-index: 999;
}

.site-header,
.site-header .header-mobile-hamburger,
.site-header-nav-col,
.site-header-contact-col,
.main-menu > li,
.site-footer-nav-item{
	-webkit-transition: all 0.2s ease-in-out;
	-moz-transition: all 0.2s ease-in-out;
	transition: all 0.2s ease-in-out;
}

.site-header-logo img{
	-webkit-transition: all 0.5s ease-in-out;
	-moz-transition: all 0.5s ease-in-out;
	transition: all 0.5s ease-in-out;
}

.site-header,
.site-header-mobile{
	position: fixed;
	z-index: 500;
	top: 0;
	left: 0;
	right: 0;
}

.site-header-container,
.site-header-mobile-container{
	padding: 10px 15px;
}

/* .site-header-container > .flex > [class^='col-']{
	position: relative;
} */

.site-header-nav-col,
.site-header-contact-col{
	padding-top: 0.5%;
}

.site-header-logo img{
	display: block;
	width: 130px;
	max-width: 100%;
	height: auto;
}

.sticky-header .site-header,
.sticky-header .site-header-mobile{
	background-color: #FFF;
	
	-webkit-box-shadow: 0 -5px 15px rgba(0, 0, 0, 0.3);
	-moz-box-shadow: 0 -5px 15px rgba(0, 0, 0, 0.3);
	box-shadow: 0 -5px 15px rgba(0, 0, 0, 0.3);
}

.main-menu > li{
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	align-items: center;
}

.main-menu > li:not(:last-child){
	margin-right: 50px;
}

.main-menu > li > a{
	position: relative;
	display: block;
	text-decoration: none;
	color: #3f3d56;
	font-size: 18px;
	line-height: 1.2;

	-webkit-tap-highlight-color: transparent;
	outline: none;
}

.main-menu > li.menu-item-has-children > a{
	position: relative;
	padding-right: 25px;
}

.main-menu > li.menu-item-has-children > a:after{
	content: "";
	display: block;
	position: absolute;
	top: 0;
	bottom: 4px;
	right: 0;
	width: 10px;
	height: 10px;
	border: solid currentColor;
	border-width: 0 2px 2px 0;
	display: inline-block;
	padding: 0;
	margin: auto;
	cursor: pointer;

	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	transform: rotate(45deg);
}

@media only screen and (min-width: 1001px) {
	.main-menu > li > .sub-menu{
		display: none;
		position: absolute;
		z-index: 100;
		top: calc(100% + 10px);
		left: 0;
		right: 0;
		margin: 0;
		padding: 50px;
		width: 1240px;
		max-width: calc(100% - 40px);
		margin: auto;
		background-color: #F5F7FB;
		
		-webkit-border-radius: 34px;
		-moz-border-radius: 34px;
		border-radius: 34px;

		-webkit-box-shadow: 0px 5px 20px -10px rgba(0, 0, 0, 0.2);
		-moz-box-shadow: 0px 5px 20px -10px rgba(0, 0, 0, 0.2);
		box-shadow: 0px 5px 20px -10px rgba(0, 0, 0, 0.2);
	}

	.locations-menu .location-buttons-grid > .flex{
		justify-content: space-between;
	}

	.locations-menu .location-buttons-grid .all-button-col{
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		flex: 1;
		justify-content: flex-end;
	}

	.brands-menu .brand-logos-grid > .flex{
		justify-content: center;
	}

	.brands-menu .all-brands-button,
	.categories-menu .all-categories-button{
		padding-left: 30px;
		padding-right: 30px;
	}
}

.site-header-contact .link-type-whatsapp a:before{
	display: block;
	content: "\0047";
	font-family: Social;
	font-size: 160%;
	font-style: normal;
	font-weight: 400;
	line-height: 1;
	-webkit-font-smoothing: antialiased;
}

.header-search-icon:before{
	display: block;
	content: "\0062";
	font-family: Social;
	font-size: 100%;
	font-style: normal;
	font-weight: 700;
	line-height: 1;
	-webkit-font-smoothing: antialiased;

	-webkit-transform: scaleX(-1);
	-moz-transform: scaleX(-1);
	transform: scaleX(-1);
}

@media only screen and (max-width: 1400px) and (min-width: 1001px) {
	.site-header-nav-col{
		padding-top: 15px;
	}

	.site-header-logo img{
		width: 120px;
	}

	.main-menu > li:not(:last-child){
		margin-right: 20px;
	}

	.main-menu > li > a,
	.site-header-contact .cars-button{
		font-size: 20px;
	}

	.main-menu > li.menu-item-has-children > a {
		padding-right: 15px;
	}

	.main-menu > li.menu-item-has-children > a:after {
		width: 9px;
		height: 9px;
	}
}

@media only screen and (max-width: 1000px) {
	.site-header-contact .link-type-whatsapp a:before{
		font-size: 150%;
	}
}

@media only screen and (max-width: 540px) {
	.site-header-contact .cars-button:not(.same-width){
		min-width: 200px;
	}
}

.site-header-mobile,
.site-header .header-mobile-hamburger{
	display: none;
}

.header-mobile-hamburger{
	position: relative;
	display: block;
	width: 30px;
	height: 30px;
}

.site-header .header-mobile-hamburger{
	position: absolute;
	top: 14px;
	right: 30px;
}

.header-mobile-hamburger:before,
.header-mobile-hamburger:after,
.header-mobile-hamburger span{
	display: block;
	width: 100%;
	height: 4px;
	position: absolute;
	background-color: #1A1A1A;
	
	-webkit-border-radius: 100px;
	-moz-border-radius: 100px;
	border-radius: 100px;
}

.header-mobile-hamburger:before,
.header-mobile-hamburger:after{
	content: "";

	-webkit-transition: transform .3s,top .3s .3s,bottom .3s .3s;
	-moz-transition: transform .3s,top .3s .3s,bottom .3s .3s;
	transition: transform .3s,top .3s .3s,bottom .3s .3s;
}

.header-mobile-hamburger:before{
	top: 4px;
}

.header-mobile-hamburger:after {
	bottom: 4px;
}

.header-mobile-hamburger span {
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;

	-webkit-transition: opacity .3s .3s;
	-moz-transition: opacity .3s .3s;
	transition: opacity .3s .3s;

	-webkit-opacity: 1;
	-moz-opacity: 1;
	opacity: 1;
}

.mobile-menu-active .header-mobile-hamburger:before,
.mobile-menu-active .header-mobile-hamburger:after{
	transition: top .3s,bottom .3s,transform .3s .3s;
}

.mobile-menu-active .header-mobile-hamburger:before {
	top: calc(50% - 2px);
	transform: rotate(45deg);
}

.mobile-menu-active .header-mobile-hamburger:after {
	bottom: calc(50% - 2px);
	transform: rotate(-45deg);
}

.mobile-menu-active .header-mobile-hamburger span {
	opacity: 0;
}

@media only screen and (max-width: 1000px) {
	.site-header-mobile,
	.site-header .header-mobile-hamburger{
		display: block;
	}

	.site-header{
		position: fixed;
		z-index: 700;
		top: 0;
		bottom: 0;
		right: 0;
		left: auto;
		width: 100%;
		max-width: 400px;
		background: #FFF;
	}
	
	.site-header-container, .site-header-mobile-container {
		padding: 10px 30px;
	}

	body:not(.mobile-menu-active) .site-header{
		-webkit-transform: translateX(100%);
		-moz-transform: translateX(100%);
		transform: translateX(100%);
	}

	body.mobile-menu-active .site-header{
		-webkit-box-shadow: 0 -5px 15px rgba(0, 0, 0, 0.3);
		-moz-box-shadow: 0 -5px 15px rgba(0, 0, 0, 0.3);
		box-shadow: 0 -5px 15px rgba(0, 0, 0, 0.3);
	}

	body.mobile-menu-active{
		overflow: hidden;
	}

	.site-header-inner,
	.site-header-container,
	.site-header-container > .flex{
		height: 100%;
	}

	.site-header-nav-col{
		overflow: auto;
		padding-top: 20px !important;
		padding-bottom: 20px !important;
	}

	.site-header-menu{
		overflow: auto;
		height: 100%;
	}

	.site-header-logo img{
		width: 80px;
		margin: 0;
	}

	.main-menu{
		flex-direction: column;
	}

	.main-menu > li{
		flex-direction: column;
		align-items: flex-start;
		height: auto;
		padding: 5px 0;
	}

	.main-menu > li:not(:last-child){
		margin: 0 0 5px;
	}

	.main-menu > li > a{
		font-size: 22px;
		margin-bottom: 10px;
	}

	.main-menu > li.menu-item-has-children > a:after{
		right: 3px;
	}

	.main-menu > li.menu-item-has-children.active > a:after{
		bottom: -7px;
		-webkit-transform: rotate(-135deg);
		-moz-transform: rotate(-135deg);
		transform: rotate(-135deg);
	}

	.main-menu > li > .sub-menu{
		background-color: #F5F7FB;
		padding: 15px;

		-webkit-border-radius: 18px;
		-moz-border-radius: 18px;
		border-radius: 18px;
	}

	.locations-menu .location-buttons-grid .cars-button,
	.brands-menu .brand-logos-grid .cars-button.all-brands-button,
	.categories-menu .car-categories-grid .cars-button.all-categories-button{
		height: 40px;
		padding: 0 15px;
		font-size: 14px;
	}

	.locations-menu .location-buttons-grid .cars-button:not(.all-locations-button){
		justify-content: flex-start;
		text-align: left;
	}

	.locations-menu .location-buttons-grid .cars-button .icon svg{
		width: 18px;
		height: 18px;
		margin-right: 5px;
	}

	.locations-menu .location-buttons-grid > .flex > [class^='col-']:not(.all-button-col){
		width: 50%;
	}

	.locations-menu .location-buttons-grid > .flex > [class^='col-'].all-button-col,
	.locations-menu .location-buttons-grid .cars-button:not(.all-locations-button),
	.categories-menu .car-categories-grid > .flex > [class^='col-']{
		width: 100%;
	}
}

@media only screen and (max-width: 767px) {
	.site-header-container, .site-header-mobile-container {
		padding: 10px 20px;
	}

	.site-header .header-mobile-hamburger{
		right: 20px;
	}
}

.site-footer{
	padding: 0 30px 30px;
}

.site-footer-inner{
	background: #000000;
	padding: 75px 20px 30px;
	overflow: hidden;

	-webkit-border-radius: 18px;
	-moz-border-radius: 18px;
	border-radius: 18px;
}

@media only screen and (max-width: 1000px) {
	.site-footer-inner{
		padding: 60px 20px 30px;
	}
}

@media only screen and (max-width: 767px) {
	.site-footer{
		padding: 0 20px 30px;
	}

	.site-footer-inner{
		padding: 50px 10px 60px;
	}
}

@media only screen and (max-width: 540px) {
	.site-footer-inner{
		padding: 40px 0 60px;
	}
}

.site-footer-menus-wrap{
	margin: 0 0 60px;
}

.site-footer-nav > .menu-item:not(:last-child){
	margin: 0 0 25px;
}

.site-footer-nav > .menu-item{
	font-size: 15px;
	line-height: 1.15;
	text-decoration: none;
	color: rgba( 255, 255, 255, 0.6 );
}

.site-footer-nav > .menu-item > a{
	text-decoration: none;
	color: currentColor;
}

.site-footer-nav > .menu-item .icon{
	flex-shrink: 0;
	width: 32px;
	height: 32px;
	margin-right: 10px;
	background-color: #FFF;

	-webkit-border-radius: 100px;
	-moz-border-radius: 100px;
	border-radius: 100px;
}

.site-footer-nav > .menu-item .icon svg{
	width: 50%;
	height: 50%;
	fill: #000;
}

.site-footer-nav > .menu-item .label{
	align-self: center;
}

.site-footer-nav > .menu-item > a:focus,
.site-footer-nav > .menu-item > a:hover{
	color: #FFF
}

.site-footer-menu-title{
	font-size: 18px;
	font-weight: 500;
	color: #FFF;
	margin: 0 0 30px;
}

.site-footer-nav#menu-footer-brands{
	column-count: 2;
	column-gap: 20px;
}

@media only screen and (max-width: 1200px) {
	.site-footer-menus-wrap{
		margin: 0 0 50px;
	}

	.site-footer-nav > .menu-item .icon{
		width: 30px;
		height: 30px;
		margin-right: 8px;
	}

	.site-footer-menu-title{
		font-size: 17px;
		margin: 0 0 20px;
	}
}

@media only screen and (max-width: 767px) {
	.site-footer-menus-wrap{
		margin: 0 0 40px;
	}

	.site-footer-social-nav{
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
	}
	
	.site-footer-nav > .menu-item:not(:last-child) {
		margin: 0 0 20px;
	}

	.site-footer-social-nav > .menu-item:not(:last-child){
		margin: 0 15px 0 0 !important;
	}
	
	.site-footer-social-nav > .menu-item .icon{
		margin: 0;
	}

	.site-footer-social-nav > .menu-item .label{
		display: none;
	}
}

@media only screen and (max-width: 480px) {
	.site-footer-menus-wrap{
		margin: 0 0 30px;
	}

	.site-footer-nav > .menu-item:not(:last-child) {
		margin: 0 0 15px;
	}

	.site-footer-nav > .menu-item .icon {
		width: 25px;
		height: 25px;
		margin-right: 6px;
	}

	.site-footer-nav > .menu-item {
		font-size: 14px;
	}

	.site-footer-menu-title{
		font-size: 16px;
	}
}

.site-footer-copy-text,
.site-footer-copy-menu ul.menu > li > a{
	font-size: 16px;
	line-height: 1;
	text-decoration: none;
	color: rgba( 255, 255, 255, 0.6 );
}

.site-footer-copy-text p{
	margin: 0;
}

/* .site-footer-tripadvisor img{
	display: block;
	width: 200px;
	max-width: 100%;
	height: auto;
	margin: auto;
} */

.site-footer-tripadvisor-badges{
	gap: 10px;
	justify-content: center;
}

.site-footer-tripadvisor-badges img{
	flex-shrink: 0;
	width: auto;
	max-width: 100px;
	height: auto;
	max-height: 90px;
}

.site-footer-copy-menu ul.menu > li > a:focus,
.site-footer-copy-menu ul.menu > li > a:hover{
	color: #FFF
}

.site-footer-copy-menu ul.menu{
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	align-items: center;

	list-style-type: none;
	margin: 0;
	padding: 0;
}

.site-footer-copy-menu ul.menu > li:not(:last-child){
	position: relative;
	margin-right: 25px;
	padding-right: 25px;
}

.site-footer-copy-menu ul.menu > li:not(:last-child):after{
	content: "";
	position: absolute;
	top: 5px;
	bottom: 0;
	right: 0;
	width: 1px;
	height: 15px;
	margin: auto;
	background-color: rgba(255, 255, 255, 0.2);
}

@media only screen and (max-width: 1240px) {
	.site-footer-tripadvisor-badges img{
		max-height: 70px;
	}
}

@media only screen and (max-width: 1000px) {
	.site-footer-copy-text,
	.site-footer-copy-menu ul.menu > li > a{
		font-size: 15px;
	}

	.site-footer-copy-menu ul.menu > li:not(:last-child){
		margin-right: 20px;
		padding-right: 20px;
	}

	.site-footer-copy-menu ul.menu > li:not(:last-child):after{
		top: 7px;
		height: 15px;
	}
}

@media only screen and (max-width: 767px) {
	.site-footer-tripadvisor-badges img{
		max-height: 60px;
	}

	.site-footer-copy{
		text-align: center;
	}

	.site-footer-copy-menu ul.menu{
		justify-content: center;
	}
}

@media only screen and (max-width: 540px) {
	.site-footer-copy-text,
	.site-footer-copy-menu ul.menu > li > a{
		font-size: 14px;
	}

	.site-footer-copy-menu ul.menu > li:not(:last-child){
		margin-right: 15px;
		padding-right: 15px;
	}

	.site-footer-copy-menu ul.menu > li:not(:last-child):after{
		height: 12px;
	}
}

@media only screen and (max-width: 360px) {
	.site-footer-copy-text,
	.site-footer-copy-menu ul.menu > li > a{
		font-size: 12px;
	}

	.site-footer-copy-menu ul.menu > li:not(:last-child){
		margin-right: 10px;
		padding-right: 10px;
	}

	.site-footer-copy-menu ul.menu > li:not(:last-child):after{
		top: 5px;
		height: 10px;
	}
}

.dotted-pattern-top,
.dotted-pattern-bottom{
	position: relative;
}

.dotted-pattern-top:before,
.dotted-pattern-bottom:after{
	content: "";
	position: absolute;
	z-index: -1;
	left: 0;
	right: 0;
	height: 1700px;
	max-height: 40%;
	background: url('assets/images/dots-bg.png') center center repeat-x;

	-webkit-background-size: auto 100%;
	-moz-background-size: auto 100%;
	background-size: auto 100%;
}

.dotted-pattern-top:before{
	top: 0;
}

.dotted-pattern-bottom:after{
	bottom: 0;
}

@media only screen and (max-width: 1600px) {
	.dotted-pattern-top:before,
	.dotted-pattern-bottom:after{
		height: 1400px;
	}
}

@media only screen and (max-width: 1400px) {
	.dotted-pattern-top:before,
	.dotted-pattern-bottom:after{
		height: 1200px;
	}
}

/** fix for not styling the single about us page */

.about-us{
	padding: 24px 6vw;
	background-color: #f9eaea;

	-webkit-border-radius: 24px;
	-moz-border-radius: 24px;
	border-radius: 24px;
}

.about-us-content{
	padding: 30px 0;
}

.about-us-text{
	margin: 0 0 20px;
}

.about-us-text p{
	margin: 0 0 20px;
}

.about-us-text p:last-child{
	margin: 0;
}

.about-us-cta{
	padding-top: 15px;
}

.about-us-video{
	background-color: #FFF;
	overflow: hidden;

	-webkit-border-radius: 10px;
	-moz-border-radius: 10px;
	border-radius: 10px;

	-webkit-box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.3);
	-moz-box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.3);
	box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.3);
}

.about-us-video video{
	display: block;
	width: 102%;
	height: auto;
}

.about-us-image img{
	display: block;
	width: auto;
	max-width: 100%;
	height: auto;
	margin: auto;
}

@media only screen and (max-width: 1000px) {
	.about-us-content{
		text-align: center;
	}

	.about-us-cta .cars-button{
		margin: auto;
	}

	.about-us-image img{
		width: 340px;
		max-width: 90%;
	}
}

@media only screen and (max-width:  767px) {
	.about-us{
		padding: 20px 0;

		-webkit-border-radius: 18px;
		-moz-border-radius: 18px;
		border-radius: 18px;
	}

	.about-us-text p:not(:last-child){
		margin: 0 0 10px;
	}

	.about-us-cta{
		padding-top: 5px;
		display: flex;
		justify-content: center;	
	}

	.about-us-cta .cars-button{
		padding: 0 50px;
	}

	.about-us-content{
		padding: 0;
	}
}