/*
 * Developed by Erik at www.toolparadise.nl
*/

.image-grid nav,
.review-list > nav {
	position: absolute;
	width: 3em;
	height: 3em;
	border-radius: .8em;
	background-color: rgba(0, 0, 0, .3);
	cursor: pointer;
	z-index: 1;

	-webkit-transition: background-color .5s ease 0s;
	-moz-transition: background-color .5s ease 0s;
	-ms-transition: background-color .5s ease 0s;
	-o-transition: background-color .5s ease 0s;
	transition: background-color .5s ease 0s;
}

.image-grid nav {
	top: 50%;
	transform: translateY(-50%);
}

.review-list > nav {
	top: 2em;
}

.image-grid nav:hover,
.review-list > nav:hover {
	background-color: rgba(0, 0, 0, .5);
}

.image-grid nav.previous,
.review-list > nav.previous {
	left: -.8em;
}

.image-grid nav.next,
.review-list > nav.next {
	right: -.8em;
}

.image-grid nav svg,
.review-list > nav svg {
	position: relative;
	left: 10%;
	top: 10%;
	width: 80%;
	height: 80%;
	fill: none;
	stroke: rgba(255, 255, 255, .3);
	stroke-width: 3px;
	stroke-linecap: round;
	stroke-linejoin: round;

	-webkit-transition: stroke .5s ease 0s;
	-moz-transition: stroke .5s ease 0s;
	-ms-transition: stroke .5s ease 0s;
	-o-transition: stroke .5s ease 0s;
	transition: stroke .5s ease 0s;
}

.image-grid nav:hover svg,
.review-list > nav:hover svg {
	stroke: rgba(255, 255, 255, 1);
}

.two-columns .image-grid nav,
.two-columns .review-list > nav {
	display: block;
}

.two-columns .image-grid .image-container {
	display: none;
}

.two-columns .image-grid .image-container.selected {
	display: block;
}

.two-columns .review-list li {
	display: none;
}

.two-columns .review-list li.selected {
	display: block;
	width: 100%;
}

@media only screen and (min-width: 600px) {
	.image-grid nav,
	.review-list > nav {
		width: 4em;
		height: 4em;
	}
	.two-columns .image-grid .image-container {
		width: 100%;
		padding-top: 100%;
		left: 0;
		margin-top: 0;
	}
}

@media only screen and (max-width: 767px) {
	.image-grid nav,
	.review-list > nav {
		display: block;
	}
	/* Use enough explicit CSS selectors for higher specificity (without need to resort to !important) */
	.image-grid > div.image-container {
		display: none;
		width: 100%;
		padding-top: 100%;
		left: 0;
		margin-top: 0;
	}
	.image-grid > div.image-container.selected {
		display: block;
	}
}

@media only screen and (min-width: 768px) {
	.review-list:not(.full) li .review {
		width: calc((80vw - 60px) / 3);
		margin-left: 10px;
		margin-right: 10px;
	}
	.review-list:not(.full) li.selected,
	.review-list:not(.full) li.selected + li,
	.review-list:not(.full) li.selected + li + li {
		width: 33.333%;
	}
	.review-list:not(.full) li.selected + li .review,
	.review-list:not(.full) li.selected + li + li .review {
		color: #606060;
		background-color: #f0f0f0;
	}
	.image-grid nav,
	.review-list > nav {
		width: 6em;
		height: 6em;
	}
	.review-list > nav.previous {
		left: -6em;
	}

	.review-list > nav.next {
		right: -6em;
	}
}
@media only screen and (min-width: 940px) {
	.review-list:not(.full) li .review {
		width: calc((70vw - 60px) / 3);
	}
}
