/**
 * Adjust inherited grid & layout settings
 */

:root {
    --blue: #2cbbed;
    --green: #0bc500;
}

/**
 * Webshop buttons
 */

.ws-button-pri,
.ws-button-sec {
	display: block;
	padding: 5px 10px;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	border-radius: 3px;
	font-weight: bold;
	text-decoration: none;
}

.ws-button-pri {
	border: 1px solid #000;
	color: #fff;
	background: #656565; /* Old browsers */
	/* IE9 SVG, needs conditional override of 'filter' to 'none' */
	background: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiA/Pgo8c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgeDE9IjAlIiB5MT0iMCUiIHgyPSIwJSIgeTI9IjEwMCUiPgogICAgPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iIzY1NjU2NSIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiMwMDAwMDAiIHN0b3Atb3BhY2l0eT0iMSIvPgogIDwvbGluZWFyR3JhZGllbnQ+CiAgPHJlY3QgeD0iMCIgeT0iMCIgd2lkdGg9IjEiIGhlaWdodD0iMSIgZmlsbD0idXJsKCNncmFkLXVjZ2ctZ2VuZXJhdGVkKSIgLz4KPC9zdmc+);
	background: linear-gradient(top,  #656565 0%,#000000 100%); /* W3C */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#656565', endColorstr='#000000',GradientType=0 ); /* IE6-8 */
}

.ws-button-sec {
	border: 1px solid #ccc;
	color: #666;
	background: #ffffff; /* Old browsers */
	/* IE9 SVG, needs conditional override of 'filter' to 'none' */
	background: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiA/Pgo8c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgeDE9IjAlIiB5MT0iMCUiIHgyPSIwJSIgeTI9IjEwMCUiPgogICAgPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2ZmZmZmZiIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiNlZWVlZWUiIHN0b3Atb3BhY2l0eT0iMSIvPgogIDwvbGluZWFyR3JhZGllbnQ+CiAgPHJlY3QgeD0iMCIgeT0iMCIgd2lkdGg9IjEiIGhlaWdodD0iMSIgZmlsbD0idXJsKCNncmFkLXVjZ2ctZ2VuZXJhdGVkKSIgLz4KPC9zdmc+);
	background: linear-gradient(top,  #ffffff 0%,#eeeeee 100%); /* W3C */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#eeeeee',GradientType=0 ); /* IE6-8 */
}

.ws-button-pri:hover,
.ws-button-sec:hover {
	box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.2);
	filter: none;
}

.ws-button-pri:hover {
	background: #000;
}

.ws-button-sec:hover {
	background: #fff;
}

/**
 * 	Product reviews
 */

#ws-review-form {
	margin-bottom: 1.5em;
	padding: 1em;
	background: #f2f2f2;
}

.ws-rc-header {
	clear: both;
	overflow: hidden;
	margin-bottom: 1em;
	padding: 1em 0;
}

.ws-rc-header h2 {
	float: left;
}

.ws-rc-button {
	float: right;
}

#ws-review-form input[type='text'],
#ws-review-form textarea {
	padding: 3px 5px;
	border: 1px solid #aaa;
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
	font: normal 12px/1.5em Verdana, Geneva, Helvetica, sans-serif;
}

/**
 * 	Reviews list
 */

.ws-rcrl-item {
	padding: 1em 0;
	border-top: 1px dotted #ccc;
}

.ws-rcrli-details {
	margin: 0;
	color: #666;
	line-height: 1em;
}

.ws-rcrli-details dt {
	position: absolute;
	left: -999em;
}

.ws-rcrli-details div.field {
	padding-bottom: 0;
}

.ws-rcrlid-since {
	position: static;
	float: left;
	border: 0;
	font-weight: normal;
}

.ws-rcrli-details dd {
	float: left;
	margin-right: .5em;
	padding-right: .5em;
	border-right: 1px solid #ccc;
}

.ws-rcrli-text {
	clear: left;
	margin-bottom: .5em;
}

.ws-rcrli-replylink {
	display: block;
	margin-bottom: 1em;
}

.ws-rcrli-reply {
	padding-left: 15px;
}

/**
 * Review form
 */

.ws-review-form label.field {
	float: none;
	padding: 0;
}

.ws-review-form .fieldinput {
	margin-left: 0;
}

.ws-review-f-count {
	display: block;
	width: 95%;
	text-align: right;
	font-size: 1.5em;
}

.ws-rcrli-details .pbuic-ferr-score-number {
	font-size: 14px;
}

/**
 * 	.webshop-categories
 */

.webshop-categories .content .article {
	margin-bottom: 0;
	padding-bottom: 0;
}

/**
 * Move filter to top on smaller screens
 */

.webshop-categories {
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	position: relative;
}

.webshop-categories li {
	position: relative;
	min-height: 2em;
	margin: 0 0 20px;
	background-color: #fff;
}

@media screen and (min-width: 480px) {
	.webshop-categories li {
		float: left;
		margin-right: 10px;
		flex: 0 calc(50% - 10px);
	}
}

@media screen and (min-width: 768px) {
	.webshop-categories li:nth-child(1n),
	.webshop-categories li {
		flex-basis: calc(33% - 10px);
	}
}

@media screen and (min-width: 1024px) {
	.webshop-categories li:nth-child(1n),
	.webshop-categories li {
		flex-basis: calc(20% - 10px);
	}
}

.webshop-categories li::after {
	content:'';
	pointer-events: none;
	box-shadow: 0 0 0 200px rgba(0, 0, 0, .03) inset, 0 0 1px rgba(0, 0, 0, 0);
	transition: box-shadow .2s ease-in-out;
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
}

.webshop-categories li:hover:after {
	box-shadow: 0 0 50px rgba(0, 0, 0, 0) inset, 0 0 10px rgba(0, 0, 0, .1);
}

/* .mw-category-image img, */

.mw-category-image img {
	width: 100%;
	display: block;
}

.mw-category-link {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

.mw-category-link h3 {
    display: inline-block;
    position: absolute;
    bottom: 0;
	margin-bottom: 0;
    padding: 0.4em .6em;
	font-size: 1em;
    text-decoration: none;
	color: initial;
    background: #fff;
    z-index: 5;
}

.search .category {
	display: table;
	width: 100%;
	border-radius: 3px;
	border: 1px solid #f2f2f2;
	transition: border-color .3s ease-out;
}

.search li:hover .category {
	border-color: #46baec;
}

.search .category__text {
	display: table-cell;
	height: 100px;
	text-align: center;
	vertical-align: middle;
}

.category__text img {
	display: inline-block;
	width: 100%;
}

.search .categoryLink {
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	text-indent: -99em;
}

.search .wci__description p:last-of-type {
	margin-bottom: 0;
	color: #029de0;
}

.search .category__title {
	margin-bottom: 0;
}

.search a + .category__title {
	display: none;
}

/**
 * webshop-category-introduction
 */

.webshop-category-introduction--hasImage {
	margin-bottom: 20px;
	background-size: cover;
	min-height: 37vh;
}

.webshop-breadcrumbs ~ div[id*='webshop'] .webshop-category-introduction--hasImage {
	margin-top: -1em;
}

.wci__text {
	position: relative;
	max-width: 50%;
	padding: .7em 1.5em 1.3em;
	background: #fff;
}

.webshop-category-introduction--hasImage .wci-category-title {
	display: inline-block;
	margin: 0;
}

.wci__description p {
	margin-bottom: 0;
}

.wci__highlight {
	padding: 0 1rem;
	background: hsla(51, 84%, 74%, 1)
}

.webshop-products-nav .pages {
	display: none;
}

.webshop-productoverview .content .article {
	margin-bottom: 0;
	padding-bottom: 0;
}

.search .content .article {
	margin-bottom: 1em;
	padding-bottom: 1em;
}

/**
 * 	.product-list
 */

.product-list {
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin: 0;
}

.product-list li {
	position: relative;
	display: block;
	width: 100%;
	margin: 0 0 1.625em;
    padding-bottom: .5em;
}

.product-list li .product {
	vertical-align: top;
	border: 1px solid transparent;
	border-bottom-color: #efefef;
	background-color: #fff;
	box-shadow: none;
	transition: box-shadow .3s ease-out, border-color .3s ease-out;
}

.product-list li .product:hover {
	border-color: #46baec;
	box-shadow: 0 0 5px rgba(0, 0, 0, .2);
}

.link-to-product {
	position: relative;
	padding: 75% 10px 10px;
}

.link-to-product .product-image {
	display: block;
	position: absolute;
	top: 37px;
	right: 5px;
	bottom: 5px;
	left: 5px;
	overflow: hidden;
	width: calc(100% - 10px);
}

.product-number,
.productProperty {
	font-size: .9em;
	color: #5b6061;
}

.product-information {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.product-information a {
	display: block;
	position: relative;
	text-decoration: none;
    flex-basis: 20%;
    top: 0;
}

.is-grandvision-product {
	border-left: 20px solid transparent;
	border-top: 20px solid #00a18f;
	border-bottom: 20px solid transparent;
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	width: 0;
	height: 0;
	z-index: 100;
}

.is-grandvision-product--eyewish {
	border-top-color: #ffdd00;
}

.product-information h3 {
	margin-bottom: 0;
	font-size: 1em;
	color: initial;
}

/** Product prices */

.webshop-products .product-price,
.product-list .product-price {
	display: block;
	flex-grow: 1;
	padding: 0 10px;
}

.product-price .regular {
	font-size: 12px;
	font-weight: normal;
	text-decoration: line-through;
}

/** Add to shopping cart button */

.add-to-shopping-cart {
	display: block;
	padding-right: 10px;
	text-align: right;
}

.add-to-shopping-cart input {
	margin-right: 5px;
	width: 50px;
	border: 1px solid #ddd;
	text-align: center;
	vertical-align: top;
}

.add-to-shopping-cart a {
	position: relative;
	display: inline-block;
	width: 26px;
	height: 22px;
	overflow: hidden;
	white-space: nowrap;
	text-decoration: none;
	text-indent: -999em;
	text-align: left;
	vertical-align: top;
	color: #005f84;
}

.add-to-shopping-cart a:before {
	position: absolute;
	right: 2px;
	margin: 0;
	font-size: 1.3em;
	text-indent: 0;
	color: #005f84;
	top: 1px;
}

@media screen and (min-width: 480px) {
	.product-list li {
		float: left;
		margin: 0 0 1.6% 1.6%;
		width: 49.2%;
	}

	.product-list > li::after {
		content:'';
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		display: block;
		pointer-events: none;
		box-shadow: 0 0 0 200px rgba(0, 0, 0, .03) inset, 0 0 1px rgba(0, 0, 0, 0);
		transition: box-shadow .2s ease-in-out;
	}

	.product-list > li:hover:after {
		box-shadow: 0 0 50px rgba(0, 0, 0, 0) inset, 0 0 10px rgba(0, 0, 0, .1);
	}

	.product-list li:nth-of-type(2n+1) {
		margin-left: 0;
	}
}

@media screen and (min-width: 1024px) {
	.product-list li:nth-child(1n),
	.product-list li {
		width: 32.26%;
		margin-left: 1.6%;
	}

	.product-list li:nth-of-type(3n+1) {
		margin-left: 0;
	}
}

@media screen and (min-width: 1200px) {
	.product-list li:nth-child(1n),
	.product-list li {
		width: 23.8%;
		margin-left: 1.6%;
	}

	.content .product-list li:nth-of-type(4n+1) {
		margin-left: 0;
	}

	.sidebar + .content .product-list li:nth-child(1n),
	.sidebar + .content .product-list li {
		width: 23.8%;
		margin-left: 1.6%;
	}

	.sidebar + .content .product-list li:nth-of-type(4n+1) {
		margin-left: 0;
	}

	.sidebar + .content .product-list li:nth-child(1n),
	.sidebar + .content .product-list li {
		width: 32.26%;
		margin-left: 1.6%;
	}

	.sidebar + .content .product-list li:nth-of-type(3n+1) {
		margin-left: 0;
	}
}

@media screen and (min-width: 1600px) {
	.sidebar + .content .product-list li:nth-child(1n),
	.sidebar + .content .product-list li {
		width: 23.8%;
		margin-left: 1.6%;
	}

	.sidebar + .content .product-list li:nth-of-type(4n+1) {
		margin-left: 0;
	}
}

/** order product */

.order-product {
    display: flex;
    align-items: center;
    margin-top: auto;
}

.wpd-order .order-product {
	display: none;
}

.product-actions {
	display: block;
	margin: 0;
}

.product-actions li:nth-child(1n),
.product-actions li {
	display: block;
	width: 100%;
	padding: 0;
	margin: 0;
	background-color: #fff;
	border-width: 0;
	box-shadow: none;
}

.product-information .show-product-details {
	position: relative;
	display: block;
	float: right;
	overflow: hidden;
	padding: 2px 6px 2px 6px;
	line-height: 1.5em;
	white-space: nowrap;
	font-size: .9em;
}

.product-information .show-product-details:hover {
	cursor: pointer;
}

.product-list .product-add-to-favorites,
.product-list .product-remove-from-favorites {
    position: absolute;
    top: -1em;
    right: 0;
    margin: 0;
}

/**
 * compact product list
 */

.webshopList .product-list,
.search .product-list {
	display: block;
	margin: 1em 0;
}

.webshopList .product-list > li,
.search .product-list > li {
	display: block;
	float: none;
	margin: 0;
	padding: 0;
	width: 100%;
	white-space: nowrap;
}

.webshopList .product-list > li .product:hover,
.search .product-list > li .product:hover,
.webshopList .product-list > li .product,
.search .product-list > li .product {
	border: 1px solid transparent;
	border-bottom-color: #efefef;
	text-overflow: ellipsis;
	overflow: hidden;
	box-shadow: none;
	transition: none;
}

.webshopList .product-list > li .product:hover,
.search .product-list > li .product:hover,
.webshopList .product-list > li .product--showFullDescription,
.search .product-list > li .product--showFullDescription {
	background-color: #f6f6f6;
	border-top-color: #fc290f;
	border-bottom-color: #fc290f;
	cursor: pointer;
}

.search .product-list .product__properties {
	display: table;
	table-layout: fixed;
	width: 100%;
}

.product__column {
	display: table-cell;
	padding: 3px 10px 3px 0;
	width: 130px;
	text-overflow: ellipsis;
	overflow: hidden;
}

.product__number {
	width: 160px;
	font-size: 15px;
}

.search .product-list li .product-actions {
	position: static;
	display: inline-block;
	width: auto;
	vertical-align: middle;
	border-bottom-width: 0;
}

.search .product-list .product__title {
	width: auto;
}

.search input.product-quantity {
	display: none;
}

.product__price {
	width: 80px;
}

.product__description {
	width: auto;
}

.product__descriptionText {
	max-width: 700px;
	white-space: normal;
	overflow: hidden;
}

.product__descriptionImage {
	margin: 20px;
	vertical-align: top;
}

.product__descriptionImage .product-image {
	max-height: 250px;
	border: 1px solid #ccc;
	border-radius: 7px;
	width: auto;
}

@media screen and (min-width: 1024px) {
	.product__descriptionText {
		width: 70%;
		display: inline-block;
	}
	.product__descriptionImage {
		width: 30%;
		display: inline-block;
		vertical-align: top;
		margin: 0;
	}
}

.product__link {
	display: block;
	height: 1.5em;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.product__orderAction {
	padding-right: 0;
	width: 50px;
	text-align: right;
}

.product__orderAction .show-product-details {
	display: none;
}

.webshop-products .product__orderAction .add-to-shopping-cart {
	padding-right: 0;
}

/* Full product description */

.product__description--full {
	max-height: 0;
}

.product--showFullDescription .product__description--full {
	max-height: 800px;
	margin: .3em 0 0;
	padding: 20px;
	border-radius: 2px;
	background-color: #f7f7f7;
}

.product__descriptionText ul {
	list-style: inherit;
	margin: 0;
	overflow: hidden;
}

.product__descriptionText li:nth-child(1n) {
	position: relative;
	width: 100%;
	list-style: circle;
	margin: 0;
	padding: 0 0 0 20px;
	vertical-align: top;
	border-width: 0;
	background-color: transparent;
	box-shadow: none;
}

.product__descriptionText li:before {
	position: absolute;
	content: '\e808';
	top: 3px;
	left: 0;
	margin: 0;
}

/**
 * new products
 */

.product-list .banner-new {
	position: absolute;
	left: 0;
	top: 0;
	font-size: .9em;
}

/**
 * .webshop-breadcrumbs
 */

.webshop-breadcrumbs {
	margin-bottom: 15px;
	font-size: .85em;
}

.no-webshop-breadcrumbs .webshop-breadcrumbs,
.hideFirstBreadcrumb .webshop-breadcrumbs dd:first-of-type {
	display: none;
}

.webshop-breadcrumbs dt {
	position: absolute;
	left: -999em;
}

.webshop-breadcrumbs dl {
	width: 100%;
	overflow: hidden;
	clear: both;
	color: #666;
}

.webshop-breadcrumbs dd {
	float: left;
	margin-right: 0;
}

.ie7 .webshop-breadcrumbs dd {
	background-position: 4px -665px;
}

.webshop-breadcrumbs a {
	text-decoration: none;
	color: initial;
}

.webshop-breadcrumbs a:hover {
	opacity: .8;
}

.webshop-breadcrumbs .last:after {
	display: none;
}

/**
 * 	.webshop-product-detail
 */

.webshop-product-details {
	margin-bottom: 2em;
	overflow: hidden;
}

.product-details {
	position: relative;
}

.product-details-list {
	line-height: 1.2;
}

.product-details-list dt {
	display: block;
	font-size: 12px;
	color: #5b6061;
}

.product-details-list dd {
	margin-bottom: .5em;
}

#webshop-product-details .product-price {
	display: block;
	float: left;
	width: 35%;
	text-align: left;
	font-size: 2em;
	font-weight: 200;
	line-height: 1em;
	vertical-align: middle;
}

#webshop-product-details .product-unavailable {
	clear: left;
	display: inline-block;
	margin: 1em 0;
    text-align: left;
    font-size: 1.1em;
    line-height: 1.4;
    font-weight: bold;
	color: #2a698b;
}

#webshop-product-details .add-to-shopping-cart {
	position: relative;
	display: -ms-flexbox;
	display: flex;
	clear: right;
	height: 44px;
	margin-top: .5em;
	padding: 3px 0;
	text-align: right;
	vertical-align: middle;
}

@media screen and (min-width: 460px) {
	#webshop-product-details .add-to-shopping-cart {
		max-width: 20em;
	}
}

.order-variant-block  .add-to-shopping-cart a,
#webshop-product-details .add-to-shopping-cart a {
	width: auto;
	height: auto;
	padding: .7em 2em .7em 1em;
	border: 1px solid transparent;
	border-radius: 3px;
	line-height: 1;
	text-align: left;
	text-indent: 0;
	vertical-align: middle;
	color: #fff;
	background: #52595c none;
}

.order-variant-block  .add-to-shopping-cart a:before,
#webshop-product-details .add-to-shopping-cart a:before {
	right: 6px;
	margin-top: -.55em;
	color: #fff;
	font-size: 1.3em;
	background-color: inherit;
}

.order-variant-block  .add-to-shopping-cart a:hover:before,
#webshop-product-details .add-to-shopping-cart a:hover:before,
#empty .add-to-shopping-cart a:hover {
	background-color: inherit;
}

#webshop-product-details .add-to-shopping-cart a.product-add-success {
    padding: 1.1rem 1.5rem;
}

#webshop-product-details .add-to-shopping-cart a.product-add-success img {
    display: none;
}

.webshop-products .add-to-shopping-cart a.product-add-success::after,
.add-to-shopping-cart a.product-add-success::after {
    position: absolute;
    right: -1px;
    top: 4px;
    width: 16px;
    height: 16px;
    content: '';
    background: no-repeat url('../img/check-white.svg') center;
    background-size: contain;
}

.webshop-products .add-to-shopping-cart a.product-add-success::after {
    top: -3px;
    margin: 0;
    font-size: 1.3em;
    text-indent: 0;
    background: no-repeat url('../img/check.svg') center;
}

.order-variant-block .add-to-shopping-cart input {
	width: 50px;
	padding: 4px;
}

.order-variant-block  .add-to-shopping-cart a {
	font-size: 1em;
}

.order-variant-block .add-to-shopping-cart a:hover,
#webshop-product-details .add-to-shopping-cart a:hover {
	box-shadow: 0 2px 6px -2px #000;
}

#webshop-product-details .product-quantity {
	width: 3.5em;
	padding: .2em 4px;
	flex-grow: 0;
	font-size: 1em;
	line-height: 1;
}

.product-add-to-favorites,
.product-remove-from-favorites {
    display: flex;
    width: 3em;
    flex-shrink: 0;
    margin: .5em 0 0 .5em;
    padding: 0;
    border: 0;
    overflow: hidden;
    text-decoration: none;
    text-indent: -999em;
    background-color: transparent;
}

.product-add-to-favorites::after,
.product-remove-from-favorites::after {
    display: block;
    width: 2em;
    margin-left: 0;
    font-size: 1.5em;
    text-indent: 0;
    content: '\e84d';
    overflow: hidden;
    color: #eb539e;
}

.product-add-to-favorites:after {
    content: '\e84c';
}

.product-add-to-favorites::before,
.product-remove-from-favorites::before {
	color: #fff;
	transition: color .2s;
}

.no-touch .product-remove-from-favorites:hover::after,
.no-touch .product-add-to-favorites:hover,
.no-touch .product-remove-from-favorites:hover {
	opacity: .8;
}

.no-touch .product-add-to-favorites:hover::after {
	color: #eb539e;
}

.product-remove-from-favorites::before {
	font-size: .85em;
	color: #eb539e;
}

.product-remove-from-favorites:hover::before {
	font-size: .85em;
	color: #666;
}

.wpdt-summary .product-add-to-favorites,
.wpdt-summary .product-remove-from-favorites {
    display: none;
}

.wpd-titleBlock {
    display: flex;
}

.wpd-titleBlock h2 {
    margin-bottom: 0;
}

.webshop-description {
	min-height: 150px;
	text-indent: -999em;
	clear: left;
	margin-bottom: 3em;
}

.productSupplier {
	font-weight: bold;
	color: #029de0;
}

.wpdt-summary {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin: 1em 0 2em 0;
	overflow: hidden;
}

.wpd-bottom p {
	display: flow-root;
}

.webshop-description ul {
	text-indent: 0;
	margin: 0 0 1em;
	list-style: none;
}

.webshop-description li {
	position: relative;
	padding-left: 20px;
}

.webshop-description li:before {
	position: absolute;
	top: 3px;
	left: 0;
	margin: 0;
}

.wpd-primary-image {
    border: 1px solid #ddd;
}

.wpd-primary-image img {
    display: block;
	width: 100%;
}

/**
 * Related products
 */

.related-products {
	clear: both;
}

/**
 * .webshop-back-link
 **/

.webshop-back-link {
	margin-bottom: .4em;
}

.webshop-back-link a {
	display: inline-block;
	padding: 3px 8px 3px 3px;
	border-radius: 2px;
	font-size: 14px;
	color: var(--blue);
	text-decoration: none;
	background-color: #fff;
}

.webshop-back-link a:hover {
	color: #fff;
    background-color: var(--blue);
}

.wpd-order {
	position: relative;
}

.wpd-order .productProperty + .productProperty:before {
    content: '|';
    padding-right: .4em;
    opacity: .4;
}

@media screen and (min-width: 768px) {
	.wpd-order {
		float: left;
		width: 50%;
		padding-left: 30px;
	}

	.wpd-images {
		float: left;
		width: 50%;
		padding-right: 30px;
	}
}

@media screen and (min-width: 1024px) {
	#webshop-product-details .add-to-shopping-cart a {
	}
}

.ProductDetailUsp {
	display: none;
	margin: 1em 0;
	padding: 8px 10px;
	border-radius: 3px;
	background-color: #f7f7f7;
}

.showUspList .ProductDetailUsp {
	display: flex;
}

.ProductDetailUsp__title {
	display: none;
}

.ProductDetailUsp__uspList {
	margin: 0;
	list-style: none;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-line-pack: justify;
	justify-content: space-evenly;
	width: 100%;
	flex-wrap: wrap;
}

.ProductDetailUsp__uspListItem {
	position: relative;
	padding-left: 19px;
	font-size: 16px;
}

.ProductDetailUsp__uspListItem:before {
	content: '\e809';
	display: inline-block;
	position: absolute;
	top: 0;
	left: 0;
	font-family: 'icons';
	font-size: 16px;
	color: #0bc500;
}

/**
 * new products
 */

.webshop-productdetails .banner-new {
	font-size: 14px;
}

/**
 * add-to-shopping-cart
 */

.webshop-productdetails .add-to-shopping-cart a {
	flex-grow: 1;
	align-self: center;
	font-size: 1em;
}

.webshop-productdetails .add-to-shopping-cart input {
	flex-grow: 1;
}

.webshop-productdetails .add-to-shopping-cart a:before {
	top: 1em;
}

.webshop-related-products {
    margin-top: 3em;
}

/**
 * Webshop (products) navigation
 */

.webshop-products-nav,
.per-page {
	text-align: center;
}

.webshop-products-nav.top {
	display: none;
}

.webshop-products-nav ol {
	margin: 1em 0;
}

.webshop-products-nav li,
.per-page li {
	display: inline-block;
	width: auto;
	margin: 0 .5em .5em 0;
	padding: 0;
	border: 0;
	background-image: none;
}

.webshop-products-nav a,
.per-page a {
	display: inline-block;
	min-width: 1.4em;
	padding: .2em .7em;
	margin: 0;
	text-align: center;
	border: 1px solid #eee;
	border-color: rgba(0,0,0,0.1);
	color: #333;
	text-decoration: none;
	border-radius: 2px;
	/** for firefox 3.6+ */
	background: #eee linear-gradient(top, #f8f8f8, #eee);
	border-color: #dfdfdf;
}

/** Hover state */

.webshop-products-nav a:hover,
.per-page a:hover {
	color: #000;
	border-color: rgba(0,0,0,0.3);
	box-shadow: 0 0 2px 0 rgba(0,0,0,0.2);
}

/** Active state */

.webshop-products-nav .current a,
.per-page .current,
.webshop-products-nav .current a:hover,
.per-page .current:hover {
	border-color: #eee;
	font-weight: bold;
	color: #025f84;
	background: #fff;
	cursor: default;
	box-shadow: none;
}

/**
 * 	.related-product-list
 */

.related-product-list {
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
    margin: 0 0 0 -10px;
    padding: 0;
    list-style: none;
}

.related-product-list li {
	position: relative;
    flex: 0 calc(50% - 10px);
    margin: 10px 0 0 10px;
	box-shadow: 0 0 0 1px #dbe3e6;
}

.related-product-list li:hover {
	box-shadow: 0 2px 6px -2px rgba(0, 0, 0, 0.5);
}

.related-product-list .link-to-product {
	padding-bottom: 5px;
}

.related-product-list .product-price {
	display: block;
	float: left;
	width: 40%;
	padding: 0 10px;
}

.related-product-list .add-to-shopping-cart {
	display: block;
	float: right;
	padding-right: 10px;
	text-align: right;
}

h3.relatedProduct__title {
	font-size: .85em;
	color: initial;
}

.related-product-list .product-add-to-favorites,
.related-product-list .product-remove-from-favorites {
	display: none;
}

@media screen and (min-width: 480px) {
	ul.related-product-list {
		margin-left: -10px;
		padding: 0 0 1em 0;
	}
	.related-product-list li {
		flex: 0 calc(33.3% - 10px);
		margin: 10px 0 0 10px;
		overflow: hidden;
	}
}

@media screen and (min-width: 768px) {
    .webshop-related-products--linked .related-product-list li { /* Linked products must be slightly smaller then regular related products */
        flex: 0 calc(16.6% - 10px);
    }
}

/**
 *     Searchbox in sidebar
 */

#webshop-product-search {
    max-width: 100%;
}

#webshop-product-search {
    display: block;
    position: relative;
    width: 100%;
    margin: 0;
}

.webshop-product-search fieldset {
    margin-bottom: 0;
}

.webshop-searchresults .webshop-product-search fieldset {
    margin-bottom: 1.5em;
}

#webshop-product-search input {
    width: 100%;
    padding: 8px 44px 8px 14px;
    border: 1px solid #ccc;
    border-radius: 5px;
    font-size: 16px;
    line-height: 26px;
    font-weight: lighter;
    color: #999;
    text-overflow: ellipsis;
    overflow: hidden;
    transition: box-shadow 0.2s linear;
    box-shadow: none;
}

#webshop-product-search input[placeholder] {
    text-overflow: ellipsis;
}

#webshop-product-search ::-moz-placeholder {
    text-overflow: ellipsis;
}

#webshop-product-search input:-moz-placeholder {
    text-overflow: ellipsis;
}

@media screen and (min-width: 480px) {
    #webshop-product-search input {
        padding-right: 52px;
        font-size: 19px;
        line-height: 35px;
    }
}

#webshop-product-search input:focus {
    color: #000;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.3);
}

#webshop-product-search button {
    position: absolute;
    top: 0;
    right: 0;
    width: 44px;
    height: 44px;
    padding: 0;
    border-radius: 0 5px 5px 0;
    text-indent: -999em;
    overflow: hidden;
    filter: none;
    border: 0;
    box-shadow: none;
    background: #46baec url(/ui/optiplus-2015/img/icon--search.png) no-repeat 50% 50%;
    background-size: 20px;
    transition: background-color .3s;
}

@media screen and (min-width: 480px) {
	#webshop-product-search button {
        width: 53px;
        height: 53px;
        background-size: 24px;
    }
}

#webshop-product-search button:hover {
    background-color: #fc290f;
}

/** Remove searchbox from main content */

.webshop-category .content-container .article_1,
.webshop-productoverview .content-container .article_1,
.webshop-productdetails .content-container .article_1 {
    margin: 0;
    padding: 0;
}

form#webshop-product-search {
	position: absolute;
	left: -999em;
}

.webshop-searchresults #webshop-product-search + h3 {
    display: none;
}

.webshop-product-search p {
    display: block;
    margin: 1.5em auto 0;
    padding: 1em;
    border-radius: 3px;
    max-width: 700px;
    text-align: center;
    font-size: 2em;
    font-style: italic;
    font-weight: 100;
    background-color: #f0f0f0;
}

#webshop h1 {
	position: absolute;
	left: -999em;
}

#webshop-product-search label,
#webshop-product-search-sidebar label {
	position: absolute;
	top: -999em;
	left: -999em;
}

/**
 * Defaults & layout of re-usable classes throughout the webshop
 */

/** Remove the default layout of list elements */

.per-page,
.webshop-categories,
.webshop-category-tree ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

/** Product images */

.webshop-productdetails .product-image {
	top: 18px;
	height: auto;
}

.product-image-container,
.image-container {
	float: left;
	margin: 2px 15px 0 0;
}

.product-image-container {
	position: relative;
	z-index: 2; /** place image over favorites star */
}

/**
 *     Buttons
 */

#ws-review-form button {
	border: 1px solid;
	border-color: #444 #444 #000;
	color: #fff;
	vertical-align: baseline; /** is browser default */
	background-color: #444444;
	background-image: linear-gradient(to bottom, #666666, #444444);
	border-radius: 2px;
	text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.5);
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.1) inset;
}

#ws-review-form button:hover {
	border-color: #111 #111 #000;
	background-color: #444444;
	background-image: linear-gradient(to bottom, #444444, #363636);
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.2) inset, 0 0 1px rgba(0, 0, 0, 0.5);
}

/**
 * webshop favorites
 **/

.clear-favourites .fieldinput {
	margin-left: 0;
}

/**
 * .webshop-category-tree
 */

.webshop-category-tree,
.webshop-category-tree ul {
	display: contents;
}

/**
 * Hide page title and first article with search
 */

.webshop-productdetails .pageTitle,
.webshop-productoverview .pageTitle,
.webshop-category h1 {
	position: absolute;
	left: -999em;
}

.body--showTitle h1 {
	position: static !important;
}

/**
 * new products
 */

.banner-new {
	color: #fff;
	padding: .2em .7em;
	vertical-align: 0.2em;
	background: var(--green);
}
