.user__contain {
	width: 100%;
	position: relative;
	font-size: 0;
	padding: 20px;
	background: #f9f9f9;
	-webkit-border-radius: 3px;
}

.user__block {
	width: calc(25% - 15px);
	margin: 20px 20px 0 0;
	display: inline-block;
	vertical-align: top;
	position: relative;
	background: #fff;
	border: 1px solid #f9f9f9 ;
	border-bottom: 1px solid #DBD6C5;
	cursor: pointer;
	overflow: hidden;
	color: #000;
	-webkit-border-radius: 2px;
	-webkit-transition: linear 50ms box-shadow, linear 50ms border;
	-webkit-box-shadow: 0 0 5px 0 rgba(0, 0, 0, .025);
}

.user__block:nth-of-type(-n+4) {
	margin-top: 0;
}

.user__block:nth-of-type(4n+4) {
	margin-right: 0;
}

.user__thumbnail {
	width: calc(100% - 60px);
	min-height: 100px;
	margin: 30px;
	display: inline-block;
	text-align: left;
	background: #fff url(../img/icons/icon-no-image.svg) no-repeat center / contain;
}

.user__thumbnail > img {
	width: 100%;
	height: 100px;
	object-fit: contain;
	display: inline-block;
	background: #fff;
}

.user__block_contain {
	width: 100%;
	min-height: 190px;
	padding: 30px 30px 35px;
	display: inline-block;
	border-top: 1px solid #eee;
}

.user__title {
	width: 100%;
	height: 56px;
	margin-bottom: 30px;
	vertical-align: top;
	display: inline-block;
	white-space: normal;
	-webkit-border-radius: 10px;
	font: 700 20px / 26px redhat, sans-serif;
}	

.user__title.loading {
	-webkit-animation-name: animation;
	-webkit-animation-duration: 2s;
	-webkit-animation-timing-function: ease-in-out;
	-webkit-animation-iteration-count: infinite;    
	-webkit-animation-play-state: running;
}

@-webkit-keyframes animation {
	0%     { background-color: #f9f9f9; }
	50.0%  { background-color: #eee; }
	100.0% { background-color: #f9f9f9; }
}

.user__address,
.user__postalcode,
.user__country {
	width: 100%;
	height: 32px;
	display: inline-block;
	vertical-align: top;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	font: 400 16px / 24px redhat, sans-serif;
}	

.user__cta {
	width: 100%;
	height: 42px;
	min-width: 170px;
	max-width: 230px;
	margin: 20px 0 0 0;
	padding: 0 50px 0 20px;
	display: inline-block;
	vertical-align: middle;
	font: 400 16px / 42px redhat, sans-serif;
	color: #000;
	background: #ebac15 url(../img/icons/icon-arrow-cta.svg) no-repeat calc(100% - 15px) center / 24px;
	-webkit-border-radius: 300px;
	-webkit-transition: ease 200ms all;
}

.user__cta:hover {
	background-color: #efa53d;
	background-position: calc(100% - 10px);
}

/*
 * Detail
 */

.user__detail {
	font-size: 0;
}

.user__detail_back {
	width: 100%;
	margin: 20px 0;
}

.user__detail_back a {
	width: auto;
	padding-left: 20px;
	display: inline-block;
	color: #000;
	font: 400 16px / 24px redhat, sans-serif;
	background: url(../img/icons/icon-arrow-left.svg) no-repeat left center / 14px;
}

.user__detail_back a:hover {
	text-decoration: underline;
}

.user__detail_header {
	position: relative;
	margin-bottom: 0;
}

.user__detail_cover {
	width: 100%;
	max-width: 100%;
	height: 400px;
	display: inline-block;
	vertical-align: top;
	-webkit-border-radius: 3px;
}

.user__detail_header:after {
	content: "";
	width: 100%;
	height: 250px;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 10;
	background: rgb(0,0,0);
	background: linear-gradient(0deg, rgba(0,0,0,.4) 0%, rgba(0,0,0,0) 100%);
	-webkit-border-radius: 0 0 3px 3px;
}

.user__detail_logo {
	position: absolute;
	bottom: 50px;
	left: 50px;
	z-index: 20;
}

.user__detail_logo > img {
	width: 150px;
	height: 150px;
	display: inline-block;
	vertical-align: middle;
	object-fit: contain;
	background: #fff;
	border: 5px solid #fff;
	-webkit-border-radius: 300px;
	-webkit-box-shadow: 0 0 15px 0 rgba(0, 0, 0, .1);
}

.user__detail_logo_company {
	width: calc(100% - 180px);
	margin-left: 30px;
	color: #fff;
	display: inline-block;
	vertical-align: middle;
	text-shadow: 1px 1px 2px rgba(0, 0, 0, .2);
	font: 700 30px / 38px redhat, sans-serif;
}

.user__detail_logo_company > span:nth-of-type(2) {
	width: 100%;
	display: inline-block;
	vertical-align: top;
	font: 400 20px / 28px redhat, sans-serif;
}

.user__detail_section {
	width: calc(100% - 60px);
	margin: 0 30px;
	padding: 50px 0;
	border-bottom: 1px solid #eee;
	font-size: 0;
}

.user__detail_section_introduction {
	font: 400 16px / 24px redhat, sans-serif;
}

user__detail_section_introduction h1 {
	width: 100%;
}

.user__detail_section:last-of-type {
	border-bottom: 0;
}

.user__detail_section h2:first-of-type,
.user__detail_section h3:first-of-type {
	padding-top: 0;	
	margin-top: 0;
}

.user__detail_cta {
	width: 100%;
}

.user__detail_cta.bottom {
	margin-bottom: 0;
}

.user__detail_cta.bottom > a {
	width: 100%;
	max-width: 300px;
	margin: 0 0 10px;
}

.user__detail_cta > a { 
	margin-right: 10px;
	padding: 0 20px;
	display: inline-block;
	vertical-align: middle;
	border: 3px solid #0860b8;
	color: #000;
	cursor: pointer;
	font: 700 16px / 40px redhat, sans-serif;
	-webkit-border-radius: 300px;
	-webkit-transition: ease 200ms all;
}

.user__detail_cta > a:first-of-type {
	background: #0860b8;
	color: #fff;
	margin-right: 20px;
}

.user__detail_cta > a:hover {
	background: #086cd0;
	border-color: #086cd0;
	color: #fff;
	text-decoration: none;
}

.user__detail_body {
	width: 100%;
	margin: 30px 0 0;
}

.user__detail_body h1,
.user__detail_body h2,
.user__detail_body h3,
.user__detail_body h4,
.user__detail_body h5,
.user__detail_body h6 { 
	width: 100%;
	margin-bottom: 10px;
	color: #00374e !important;
}

.user__detail_specializations,
.user__detail_brands {
	font-size: 0;
	margin-top: 20px;
}

.user__detail_specializations p,
.user__detail_brands p {
	padding: 5px 20px;
	margin-right: 10px;
	display: inline-block;
	vertical-align: middle;
	background: #f9f9f9;
	border: 1px solid #f9f9f9;
	font: 700 16px / 24px redhat, sans-serif;
	-webkit-box-shadow: 1px 1px 1px rgba(0, 0, 0, .15);
	-webkit-border-radius: 300px;
}

.user__detail_specializations p:last-of-type,
.user__detail_brands p:last-of-type {
	margin-right: 0;
}

.user__detail_contact {
	width: 40%;
	display: inline-block;
	vertical-align: top;
}

.user__detail_contact p {
	margin: 0;
	font-size: 14px;
}

.user__detail_contact p:last-of-type {
	margin-bottom: 30px;
}

.user__detail_map {
	width: 60%;
	height: 400px;
	margin-bottom: 50px;
}

.user__detail_alloffers {
	width: 100%;
	margin-top: 30px;
	display: inline-block;
	font: 700 16px / 24px redhat, sans-serif;
}

.user__detail_offers {
	width: 100%;
}

.user__detail_block {
	width: calc(25% - 11px);
	margin-right: 10px;
	display: inline-block;
	vertical-align: top;
	border: 1px solid #f9f9f9;
	color: #000;
	-webkit-border-radius: 6px;
	-webkit-box-shadow: 1px 1px 15px 0 rgba(0, 0, 0, .065);
}

.user__detail_block:last-of-type {
	margin-right: 0;
}

.user__detail_thumb {
	width: 100%;
	height: 184px;
	object-fit: contain;
	border-bottom: 1px solid #f9f9f9;
}

.user__detail_content {
	padding: 20px;
}

.user__detail_content_title {
	width: 100%;
	height: 58px;
	overflow: hidden;
	margin: 0 0 5px;
	display: inline-block;
	font: 700 22px / 30px redhat, sans-serif;
}

.user__detail_content_price {
	width: 100%;
	margin: 20px 0 0;
	display: inline-block;
	font: 500 20px / 24px redhat, sans-serif;
}

.user__detail_content_specs { 
	min-height: 135px;
}

.user__detail_content_spec {
	width: 100%;
	display: inline-block;
	vertical-align: middle;
	font: 400 14px / 24px redhat, sans-serif;
}

.user__detail_content_spec > span {
	width: 24px;
	height: 24px;
	margin-right: 10px;
	display: inline-block;
	vertical-align: bottom;
	background: no-repeat center / 18px;
}

.user__detail_content_spec > span[data-icon="fuel"] {
	background-image: url(../img/icons/icon-spec-fuel.svg);
}

.user__detail_content_spec > span[data-icon="transmission-manual"] {
	background-image: url(../img/icons/icon-spec-transmission-manual.svg);
}

.user__detail_content_spec > span[data-icon="transmission-automatic"] {
	background-image: url(../img/icons/icon-spec-transmission-automatic.svg);
}

.user__detail_content_spec > span[data-icon="mileage"] {
	background-image: url(../img/icons/icon-spec-mileage.svg);
}

.user__detail_content_spec > span[data-icon="buildyear"] {
	background-image: url(../img/icons/icon-spec-buildyear.svg);
}

.user__detail_content_spec > span[data-icon="seatbelts"] {
	background-image: url(../img/icons/icon-spec-seatbelts.svg);
}

.user__detail_content_cta { 
	width: 100%;
	margin-top: 20px;
	padding: 0 20px;
	display: inline-block;
	vertical-align: middle;
	background: #0860b8 url(../img/icons/icon-arrow-cta-white.svg) no-repeat calc(100% - 15px) center / 24px;
	color: #fff;
	cursor: pointer;
	font: 700 16px / 40px redhat, sans-serif;
	-webkit-border-radius: 300px;
	-webkit-transition: ease 200ms all;
}

.user__detail_block:hover .user__detail_content_cta {
	background-color: #086cd0;
	background-position: calc(100% - 10px);
}

/*
 * Listing
 */

.listing__found {
	min-width: 110px;
	margin-right: 20px;
	display: none;
	vertical-align: middle;
	font: 400 16px / 40px redhat, sans-serif;	
}

.listing__nothing {
	margin: 0;
	font: 400 16px / 40px redhat, sans-serif;	
}

.listing__reset-all-filters:hover {
	cursor: pointer;
	text-decoration: underline;
}
	
.listing__navigation {
	width: 100%;
	margin: 20px 0 20px;
	padding: 25px 20px 20px;
	font-size: 0;
	background: rgb(255,255,255);
	background: linear-gradient(180deg, rgba(246,246,246,.3) 0%, rgba(246,246,246,.5) 100%);
	border-bottom: 1px solid #eee;
	-webkit-border-radius: 3px;
}

.listing__navigation.bottom {
	margin: 20px 0 0;
	padding: 0;
	border: 0;
	background: transparent;
}

.listing__navigation div.contain {
	display: inline-block;
	vertical-align: middle;
}

.listing__button {
	min-width: 40px;
	height: 30px;
	padding: 0 10px;
	display: none;
	vertical-align: middle;
	color: #475166;
	font: 400 16px / 24px redhat, sans-serif;
	text-align: center;
	cursor: pointer;
	background: #fff no-repeat center / 14px;
	border: 1px solid transparent;
	border-bottom: 1px solid #DBD6C5;
	-webkit-border-radius: 3px;
	-webkit-transition: ease opacity 100ms;
	-webkit-user-select: none;
}

.listing__button.previous {
	margin-right: 3px;
	padding-left: 0;
	background-image: url('../img/icons/icon-arrow-left.svg');
}

.listing__button.next {
	margin-left: 3px;
	padding-right: 0;
	background-image: url('../img/icons/icon-arrow-right.svg');
}

.listing__button.disabled {
	opacity: .4;
	pointer-events: none;
}

.listing__button:hover:not(.disabled) {
	border-color: #1b8fcf;
	-webkit-box-shadow: 0 0 1px 2px #1b8fcf;
}

.listing__pagination {
	display: inline-block;
	vertical-align: middle;
}

.listing__item {
	min-width: 40px;
	height: 30px;
	margin: 5px 3px;
	padding: 0;
	display: inline-block;
	vertical-align: middle;
	text-align: center;
	cursor: pointer;
	background: #fff;
	border: 1px solid transparent;
	border-bottom: 1px solid #DBD6C5;
	color: #000;
	font: 400 16px / 30px redhat, sans-serif;	
	-webkit-user-select: none;
	-webkit-border-radius: 3px;
	-webkit-box-shadow: 0 0 15px 0 rgba(0, 0, 0, .025);
}

.listing__item:hover:not(.active) {
	border-color: #0860b8;
	-webkit-box-shadow: 0 0 1px 2px #0860b8;
}

.listing__item.active {
	color: #fff;
	font-weight: 700;
	border-color: #0860b8;
	background-color: #0860b8;
}

.listing__seperator {
	margin: 0 3px;
	display: inline-block;
	vertical-align: middle;
	font: 400 14px / 24px redhat, sans-serif;	
}

.listing-dealer-select {
	width: 100%;
	margin-bottom: 10px;
}

.listing-dealer-select > span {
	padding: 5px 40px 5px 15px;
	font: 400 14px / 24px redhat, sans-serif;	
	cursor: pointer;
	background: #ffcc04 url(../img/icons/icon-cross-dark.svg) no-repeat calc(100% - 15px) center / 16px;
	-webkit-border-radius: 300px;
	-webkit-transition: ease 100ms background;
}

.listing-dealer-select > span:hover {
	background-color: #ffd530;
	background-size: 14px;
	background-position: calc(100% - 16px) center;
}

.listing__keyword_contain {
	margin-right: 10px;
	display: inline-block;
	vertical-align: middle;
}

.listing__keyword_inner {
	max-width: 200px;
	position: relative;
}

.listing__keyword_label {
	position: absolute;
	top: 8px;
	left: 13px;
	font: 400 14px / 24px redhat, sans-serif;	
	-webkit-transition: ease 100ms all;
}

.listing__keyword_label.listing__keyword_focus {
	width: calc(100% - 26px);
	top: -24px;
	left: 5px;
	font-size: 12px;
}

.listing__keyword_input {
	background: #fff url('../img/icons/icon-search-dark.svg') no-repeat calc(100% - 10px) center / 14px; 
	-webkit-transition: ease 100ms all;
    -webkit-box-shadow: 1px 1px 3px 0 rgba(0, 0, 0, .1);
    -webkit-border-radius: 3px;
}

.listing__keyword_input:hover {
	border-color: #0860b8;
	-webkit-box-shadow: 0 0 1px 1px #0860b8;	
}

.map__user_listing {
	padding: 9px 40px 9px 15px;
	margin-right: 20px;
	display: inline-block;
	vertical-align: middle;
	font: 400 14px / 24px redhat, sans-serif;	
	color: #000;
	background: #fff url('../img/icons/icon-map.svg') no-repeat calc(100% - 10px) center / 24px; 
	cursor: pointer;
	-webkit-transition: ease 100ms all;
	-webkit-box-shadow: 1px 1px 3px 0 rgba(0, 0, 0, .1);
	-webkit-border-radius: 3px;
}

.map__user_listing:hover {
	background-color: #ebac15;
}

/*
 * Leaflet
 */

#map { 
	width: 1280px;
	height: 720px;
	margin: 70px 0;
	display: inline-block;
	vertical-align: top;
	z-index: 2;
	position: relative;
	background: #f9f9f9;
	-webkit-border-radius: 6px;
}

#map .user__popup_logo {
	width: 200px;
	height: auto;
	margin-top: 10px;
	vertical-align: top;
}

#map .user__popup_title {
	width: 100%;
	margin-top: 15px;
	display: inline-block;
	font: 700 18px / 24px redhat, sans-serif;
}

#map .user__popup_naw {
	width: 100%;
	margin-top: 5px;
	display: inline-block;
	font: 400 15px / 24px redhat, sans-serif;
}

#map .user__popup_cta {
	width: 100%;
	margin-top: 15px;
	display: inline-block;
	font: 400 16px / 24px redhat, sans-serif;
}

@media only screen and (min-width: 0) and (max-width: 1024px) {
	
	.user__block:nth-of-type(n) {
		width: calc(33.3333333333% - 15px);
		margin: 20px 20px 0 0;
	}

	.user__block:nth-of-type(-n+3) {
		margin-top: 0;
	}

	.user__block:nth-of-type(3n+3) {
		margin-right: 0;
	}

	.user__detail_contact {
		width: 100%;
		margin-bottom: 30px;
	}

	.user__detail_map {
		width: 100%;
	}

	.user__detail_block {
		width: 100%;
		margin: 0 0 20px;
	}
	
	.user__detail_block:last-of-type {
		margin-bottom: 0;
	}
	
	.user__detail_thumb {
		max-width: 200px;
		display: inline-block;
		vertical-align: middle;
	}
	
	.user__detail_content {
		width: calc(100% - 230px);
		margin-left: 30px;
		display: inline-block;
		vertical-align: middle;
	}
	
	.user__detail_content_title {
		height: auto;
	}
	
	.user__detail_content_price {
		margin-top: 0;
	}
	
	.user__detail_content_cta {
		max-width: 250px;
	}
	
}

@media only screen and (min-width: 0) and (max-width: 768px) {

	.user__block:nth-of-type(n) {
		width: calc(50% - 10px);
		margin: 20px 20px 0 0;
	}

	.user__block:nth-of-type(-n+2) {
		margin-top: 0;
	}

	.user__block:nth-of-type(2n+2) {
		margin-right: 0;
	}
	
}

@media only screen and (min-width: 0) and (max-width: 640px) {
	
	.user__list .content__contain h1,
	.user__list .content__contain p {
		padding: 0 20px;
	}
	
	.user__list .content__contain {
		padding: 0;
	}
	
	.user__list .listing__navigation {
		margin-bottom: 0;
		padding-bottom: 3px;
		border: 0;
	}
	
	.user__list .user__contain {
		padding: 20px;
	}
	
	.user__detail_logo {
		left: 0;
		text-align: center;
	}
	
	.user__detail_logo_company {
		width: 100%;
		margin: 30px 0 0 0;		
	}
	
	.user__detail_section {
		width: calc(100% - 20px);
		margin: 0 10px;
	}

	.user__detail_cta > a {
		width: 100%;
		margin: 0 0 10px;
	}
	
	.user__detail_cta > a:last-of-type {
		margin-bottom: 0;
	}
	
	.user__detail_thumb {
		max-width: 100%;
		display: inline-block;
		vertical-align: middle;
	}
	
	.user__detail_content {
		width: 100%;
		margin: 0;
	}

}

@media only screen and (min-width: 0) and (max-width: 500px) {

	.listing__keyword_contain {
		width: 100%;
	}
	
	.listing__keyword_inner {
		max-width: 100%;
		margin: 0;
	}
	
	.map__user_listing {
		width: 100%;
		margin: 10px 0 0;
	}
	
	.user__block:nth-of-type(n) {
		width: 100%;
		margin: 20px 20px 0 0;
	}
	
}