/*
* === HELPERS ===
*/

.no-margin {
	margin: 0 !important;
}

.no-padding {
    padding: 0 !important;
}

.no-border {
    border: none !important;
}

.gradient-background {
	background-color: #2e9bda;
    background-image: linear-gradient(135deg, rgb(35, 117, 164), rgb(46, 155, 218), rgb(54, 181, 255));
}

/*
* === NAV===
*/

.navbar-brand {
    padding-top: 0 !important;
    padding-right: 1rem;
}

/*
* === FOOTER ===
*/

html {
  position: relative;
  min-height: 100%;
  
}

body {
	color: #555555 !important;
}

.footer {
	text-align: center;
  	position: absolute;
  	bottom: 0;
  	width: 100%;
  	background-color: #f5f5f5;
  	padding-top: 1rem;
}

.footer a {
    color: #999 !important;
    text-decoration: none;
}

.footer a:hover {
    color: #2e9bda !important;
    text-decoration: none;
}

th {
	border-top: none !important;	
}

td {
	vertical-align:middle !important;
}

/*
* === SLIDER ===
*/

.slider {
	width: 50vw;
	max-width: 420px;
	margin-left: auto;
    margin-right: auto;
    margin-top: 4rem;
    margin-bottom: 4rem;
}

.slick-dots {
	bottom: -2rem !important;
}

.slick-dots li button:before {
    color: #2e9bda !important;
    font-size: 10px !important;
    line-height: 10px !important;
}

a {
    color: #2e9bda;
}

a:hover {
    color: #2e9bda;
    text-decoration: underline;
}
 
/*
* === ELEMENTS ===
*/

.nav-link.active {
	color:#2e9bda !important;
}

.nav-link.active:hover {
	color:#2e9bda !important;
}

.nav-link {
	color:#999;
}

.nav-link:hover {
	color:#2e9bda !important;
}

/*
* === IMAGES ===
*/

.adapter-image {
    width:200px;
    margin-bottom:2rem;
}

.bimmer-image {
    width:250px;
    margin-bottom:2rem;
}

.logo-image-small {
	height: 20px;
	width: auto;
}

.logo-image {
	max-width: 320px;
	display: block;
	margin-left: auto;
    margin-right: auto;
    margin-top: 2rem;
    margin-bottom: 2rem;
}

.background-image {
	background-color: #2e9bda;
	background: url(img/background-xs.jpg) no-repeat left center; 
  	background-size: cover;
}

@media
  	screen and (-webkit-min-device-pixel-ratio: 2),
  	screen and (min-resolution: 192dpi),
  	screen and (min-resolution: 2dppx) {

  	.background-image {
  		background-color: #2e9bda;
		background: url(img/background-xs@2x.jpg) no-repeat left center; 
  		background-size: cover;
	}
}

@media (min-width: 576px) {
	.background-image {
		background-color: #2e9bda;
		background: url(img/background-s.jpg) no-repeat left center;
  		background-size: cover;
	}
}

@media
  	screen and (min-width: 576px) and (-webkit-min-device-pixel-ratio: 2),
  	screen and (min-width: 576px) and (min-resolution: 192dpi),
  	screen and (min-resolution: 2dppx) {

  	.background-image {
  		background-color: #2e9bda;
		background: url(img/background-s@2x.jpg) no-repeat left center;
  		background-size: cover;
	}
}

@media (min-width: 768px) {
	.background-image {
		background-color: #2e9bda;
		background: url(img/background-m.jpg) no-repeat center center;
		background-size: cover;
	}
}

@media
  	screen and (min-width: 768px) and (-webkit-min-device-pixel-ratio: 2),
  	screen and (min-width: 768px) and (min-resolution: 192dpi),
  	screen and (min-resolution: 2dppx) {

  	.background-image {
		background: url(img/background-m@2x.jpg) no-repeat center center;
		background-size: cover;
	}
}

@media (min-width: 992px) {
	.background-image {
		background-color: #2e9bda;
		background: url(img/background-l.jpg) no-repeat center center; 
		background-size: cover;
	}
}

@media
  	screen and (min-width: 992px) and (-webkit-min-device-pixel-ratio: 2),
  	screen and (min-width: 992px) and (min-resolution: 192dpi),
  	screen and (min-resolution: 2dppx) {

  	.background-image {
  		background-color: #2e9bda;
		background: url(img/background-l@2x.jpg) no-repeat center center; 
		background-size: cover;
	}
}

@media (min-width: 1200px) {
	.background-image {
		background-color: #2e9bda;
		background: url(img/background-xl.jpg) no-repeat center center; 
		background-size: cover;
	}
}

@media
  	screen and (min-width: 1200px) and (-webkit-min-device-pixel-ratio: 2),
  	screen and (min-width: 1200px) and (min-resolution: 192dpi),
  	screen and (min-resolution: 2dppx) {

  	.background-image {
  		background-color: #2e9bda;
		background: url(img/background-xl@2x.jpg) no-repeat top center; 
		background-size: cover;
	}
}

.navbar {
		padding-left: 0rem !important;
		padding-right: 0rem !important;
	}
	
@media (min-width: 768px) {
    .navbar {
		padding-left: 0.5rem !important;
		padding-right: 0.5rem !important;
	}
}
	
/*
* === TYPO ===
*/

.text-white {
    color: #fff !important;
}

.text-white-light {
    color: #fff; 
    color: rgba(255, 255, 255, 0.8);
}

.display-4 {
    color: #2e9bda;
    font-size: 3rem;
    padding-bottom: 0.5rem;
}

@media (min-width: 768px) {
    .display-4 {
        font-size: 4rem;
        padding-bottom: 1rem;
    }
}

.lead-hero {
	margin-bottom: 2rem;
}

.display-5 {
    margin-top: 3rem;
}

/*
* === GRID ===
*/

@media (min-width: 768px) {
    .jumbotron .row {
		margin-top: 4rem;
		margin-bottom: 4rem;
	}
}

.row {
    padding-top: 4rem;
    padding-bottom: 4rem;
}

@media (min-width: 768px) {
    .row {
        padding-top: 6rem;
        padding-bottom: 6rem;
    }
}

/*
* === BUTTONS ===
*/

.btn-cars {
    background-color: none !important;
    border-color: #2e9bda !important;
    color: #2e9bda !important;
    margin: 0.5rem !important;
    display: block;
}

.btn-cars:hover {
    color: #ffffff !important;
    background-color: #2e9bda !important;
    border-color: #2e9bda !important;
}

.btn-cars:focus,
.btn-cars:active {
    color: #ffffff !important;
    background-color: #2e9bda !important;
    border-color: #2e9bda !important;
}

.btn-buy { 
    color: white !important;
    background-color: #2e9bda !important;
    border-color: #2e9bda !important;
}

.btn-buy:hover {
    background-color: white !important;
    border-color: #2e9bda !important;
    color: #2e9bda !important;
}

.btn-buy:focus,
.btn-buy:active,
.btn-buy.active {
    background-color: white !important;
    border-color: #2e9bda !important;
    color: #2e9bda !important;
}

.btn-download {
    background-color: none !important;
    border-color: #fff !important;
    color: #fff !important;
    margin: 0.5rem !important;
    display: block;
}

.btn-download:hover {
    color: #2e9bda !important;
    background-color: white !important;
    border-color: white !important;
}

.btn-download:focus,
.btn-download:active {
    color: white !important
    background-color: #2e9bda !important;
    border-color: #2e9bda !important;
}

@media (min-width: 768px) {
    .btn-download {
        display: inline-block;
        min-width: 200px;
    }
    
    .btn-cars {
        display: inline-block;
        min-width: 200px;
    }
}

.option-list {
    padding-left: 20px;
}

/*
* === ACCORDION ===
*/

.accordion .card-header[aria-expanded="true"], .accordion .card-header[aria-expanded="true"]:hover {
	border-radius: 8px 8px 0 0 !important;
    cursor: pointer;
    color: #ffffff;
    border: 1px solid #2e9bda;
    background: #2e9bda;
    margin-top: 1rem;
}

.accordion .card-header {
    border-radius: 8px !important;
    cursor: pointer;
    color: #2e9bda;
    border: 1px solid #cccccc;
    background: #ffffff;
    margin-top: 1rem;
}

@media not all and (hover: none) {
	.accordion .card-header:hover {
    	border-radius: 8px !important;
    	cursor: pointer;
    	color: #ffffff;
    	border: 1px solid #2e9bda;
    	background: #2e9bda;
    	margin-top: 1rem;
	}
}

.accordion .card {
    border-radius: 0;
    border: none;
}

.accordion .list-group-item {
    border: 1px solid #cccccc;
    border-radius: 0px !important;
}

.border {
 	border: 1px solid #cccccc;
}

.no-break-out {

  /* These are technically the same, but use both */
  overflow-wrap: break-word;
  word-wrap: break-word;

  -ms-word-break: break-all;
  /* This is the dangerous one in WebKit, as it breaks things wherever */
  word-break: break-all;
  /* Instead use this non-standard one: */
  word-break: break-word;

  /* Adds a hyphen where the word breaks, if supported (No Blink) */
  -ms-hyphens: auto;
  -moz-hyphens: auto;
  -webkit-hyphens: auto;
  hyphens: auto;

}

.fa-star {
	color: #2e9bda !important;
}

.star-disabled {
	color: #cccccc !important;
}


.fa-circle {
	color: #2e9bda !important;
}

.fa-star-half {
	color: #2e9bda !important;
}

body {
    margin-bottom: 4rem;
}

.product-card {
    width: 100%;
    border: 1px solid #dddddd;
}

.product-card-header {
    padding: 1rem;
    background-color: #f5f5f5;
    position: relative;
}

.product-card-col {
    padding-top:1rem;
    padding-bottom:1rem;
}

.no-top-padding {
    padding-top: 0 !important;
}

.fa-plus-circle {
	color: green;
}

.fa-minus-circle {
	color: red;
}

.product-card-text{
	font-size: 1rem;
}

.privacy-policy h1 {
	color: #2e9bda;
}

.privacy-policy h2 {
	color: #2e9bda;
}

.privacy-policy h3 {
	font-size: 1.5rem;
}

.privacy-policy h4 {
	font-size: 1rem;
}

/*
* === COMPATIBILITY CHECK ===
*/

.main-option {
	padding: 1rem;
   	display: block;
   	border: 1px solid #cccccc;
   	border-radius: 8px;
   	margin-bottom: 1rem;
   	text-decoration: none !important;
}

.no-touch .main-option:hover,
.main-option:focus, 
.main-option:active {
    color: #ffffff;
    text-decoration: none;
    background-color: #2e9bda;
    border: 1px solid #2e9bda;
    text-decoration: none !important;
}

.main-option-subtitle {
	font-size: 1rem;
	display: block;
	color: #999;
}

.main-option-title {
	font-size: 1.5rem;
	font-weight: 500;
	display: block;
	color: #2e9bda;
}

.no-touch .main-option:hover .main-option-subtitle,
.no-touch .main-option:hover .main-option-title,
.main-option:focus .main-option-subtitle, 
.main-option:active .main-option-subtitle,
.main-option:focus .main-option-title, 
.main-option:active .main-option-title {
    color: #ffffff !important;
}

.main-option.selected {
    color: #ffffff;
    text-decoration: none;
    background-color: #2e9bda;
    border: 1px solid #2e9bda;
    border-radius: 8px 8px 0 0;
    margin: 0;
}

.main-option.selected .main-option-subtitle, 
.main-option.selected .main-option-title {
    color: #ffffff !important;
}

.option {
	background-color: #fff !important;
	padding: 1rem;
   	display: block;
   	border-left-style: solid;
   	border-left-width: 1px;
   	border-left-color: #ccc;
   	border-right-style: solid;
   	border-right-width: 1px;
   	border-right-color: #ccc;
   	border-bottom-style: solid;
   	border-bottom-width: 1px;
   	border-bottom-color: #ccc;
   	text-decoration: none !important;
}

.option:last-child {
  	border-radius: 0 0 8px 8px !important;
}

.no-touch .option:hover,
.option:focus, 
.option:active {
    color: #ffffff;
    text-decoration: none;
    background: #2e9bda !important;
   	border-left-color: #2e9bda;
   	border-right-color: #2e9bda;
   	border-bottom-color: #2e9bda;
   	text-decoration: none !important;
}

.option-title {
	display: block;
}


.no-touch .option:hover .option-subtitle,
.option:focus .option-subtitle, 
.option:active .option-subtitle{
    color: #ffffff;
}

.option-subtitle {
	display: block;
	color: #999;
}

.result-negative {
	text-align: center;
	color: #ffffff;
    text-decoration: none;
    background: #FF332E;
    border-radius: 8px;
    padding: 2rem;
}

.result-positive {
	text-align: center;
    padding: 2rem;
   	display: block;
   	border: 1px solid #cccccc;
   	border-radius: 8px;
   	margin-bottom: 1rem;
}

.result-neutral {
	text-align: center;
    padding: 2rem;
   	display: block;
   	border: 1px solid #cccccc;
   	border-radius: 8px;
   	margin-bottom: 1rem;
}

.btn-result {
    background-color: none !important;
    border-color: #49DA68 !important;
    color: #49DA68 !important;
    margin-top: 1rem;
    display: block;
}

.btn-result:hover {
    color: #49DA68 !important;
    background-color: white !important;
    border-color: white !important;
}

.btn-result:focus,
.btn-result:active {
    color: white !important
    background-color: #49DA68 !important;
    border-color: #49DA68 !important;
}

@media (min-width: 768px) {
    .btn-result {
        display: inline-block;
        min-width: 200px;
    }
}

.result-title {
	display: block;
	padding-top: 1rem;
	padding-bottom: 1rem;
	font-size: 1.5rem;
}

.positive {
	color: #49DA68;
}

.negative {
	color: #FF332E;
}

.fa-check-circle {
	color: #49DA68;
}

.fa-times-circle {
	color: #FF332E;
}

.fa-stopwatch {
	color: #49DA68;
}

.result-message {
	display: block;
	padding: 1rem;
	font-size: 1rem;
}

/*
* === CARS ===
*/

.car-link {
	padding: 1rem;
   	display: block;
   	border: 1px solid #cccccc;
   	border-radius: 8px;
   	margin-bottom: 1rem;
}

.car-link:hover {
    color: #ffffff;
    text-decoration: none;
    background: #2e9bda;
    border: 1px solid #2e9bda;
}

.car-link:hover .car-description{
    color: #ffffff !important;
}

.car-link.selected {
    color: #ffffff;
    text-decoration: none;
    background: #2e9bda;
    border: 1px solid #2e9bda;
    border-radius: 8px 8px 0 0;
}

.car-header-link {
    padding: 1rem;
   	display: block;
   	text-decoration: none;
    border-radius: 8px 8px 0 0;
    border: 1px solid #cccccc;
   	border-bottom: none;
   	background: #ffffff;
}

.car-header-link:hover {
	text-decoration: none;
    background: #2e9bda;
    border: 1px solid #2e9bda;
    border-bottom: none;
}

.car-header-link:hover h5, .car-header-link:hover h6 {
    color: #ffffff !important;
}

.car-header-link h5, .car-header-link h6 {
	color: #2e9bda !important;
}

.values {
	list-style-type:disc !important;
	padding-left: 1.1rem;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
}

.car-content {
	padding: 1rem; 
	border: 1px solid #ccc; 
	border-radius: 0 0 8px 8px;
	background: #efefef;
}

.video-container {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
}

.video-container iframe,
.video-container object,
.video-container embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.fa-amazon {
	transform:translateY(10%) !important;
}

.adapter-table td, .adapter-table th {
 	padding-left: 0 !important;
 	padding-right: 0 !important;
 	padding-bottom: 1rem !important;
 	padding-top: 1rem !important;
}

.adapter-table .btn-buy {
	display: block !important;
	width: 100% !important;
} 

.adapter-table img {
	width: 100px;
	height: 100px;
	border: 1px solid #ccc;
	margin-right: 1rem;
} 

.adapter-title {
	width: 100%;
	
}

.no-top-border {
	border-top-width: 0 !important;
}

.rating {
 	width: 5rem;
}

.promo {
	font-size: 0.8rem;
	color: #666;
}

.dropdown-item.active, .dropdown-item:active {
	background-color: #2e9bda !important;
}

.trademark {
	color:#fff; 
	opacity:0.7; 
	font-size:0.8rem; 
	text-transform: uppercase;
}

/* 
.navbar-nav li:hover>.dropdown-menu {
  display: block;
}
 */

.dropdown-menu {
	min-width: 0 !important;
}

.dropdown-toggle::after {
    display:none;
}

.bootstrap-select .dropdown-toggle:focus {
    outline: none!important;
}

.slick-prev:before {
  color: #2e9bda !important;
}

.slick-next:before {
  color: #2e9bda !important;
}

.rating {
	margin-left: 1rem;
	margin-right: 1rem;
}