/* ###
# COMMON
### */

body {
	font-family: 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
    line-height: 1.6;
	font-size: 18px;
	line-height: 1.6;
	color: #333;
	background-color: #fffbf5;
}
p, ul, ol, form, table { margin: 0 0 1.2em 0; }
h1, h2, h3 {
    color: #2c3e50;
    margin-top: 1em 0 .8em 0;
    font-weight: 600;
}
h1 {
    font-size: 2em;
    border-bottom: 2px solid #eaecef;
    padding-bottom: 0.3em;
}
h2 {
    font-size: 1.5em;
}
h3 { font-size: 1.1em; line-height: 1.1em; }
ol, ul { padding: 0 0 0 .6em; }
ol { list-style: decimal inside; }
ul { list-style: disc inside; }
ol li, ul li { margin-bottom: 5px; }
dt { background-color: #fff; border-left: 6px solid #55a8f6; padding: 0 0 0 10px; }
dd { margin: 20px 0 40px 20px }
hr { border: 0; border-top: 1px solid #f4f5f6; margin: 1.6em 0; }
mark { background: #ff0; }
small { font-size: .65em; display:block; margin-bottom:3em; }
.t-center { text-align: center; }
.t-right { text-align: right; }
body.noscroll { margin: 0; height: 100%; overflow: hidden; }

@media (max-width: 600px) {
	h1 { font-size: 1.3em; line-height: 1.2em; }
	h2 { font-size: 1.2em; line-height: 1.2em; }
	h3 { font-size: 1.1em; line-height: 1.2em; }
}

a {
	color: currentColor;
	text-decoration-color: #2A78C1;
	text-decoration-thickness: 2px;
	text-underline-offset: .2ex;
}

a:hover {
	text-decoration-color: #089ce7;
}

/* DEBUG */
/* * { outline: 3px solid red; } */

svg {
	width: 20px;
	height: 20px;
	display: inline-block;
}

.hide {
	display: none;
}

iframe {
	border: none;
	width: 1px;
	min-width: 100%;
	overflow: hidden;
}

iframe.map {
	margin: 0 0 20px 0;
}

#map {
	height: 230px;
	width: 100%;
	margin: 0 0 2em 0;
}

.wave {
	width: 100%;
	height: 50px;
	overflow: hidden;
	padding: 0px;
	margin: 0 0 1em 0;
}

.desktop { display: none; }
@media (min-width: 45rem) {
	.desktop { display: table-cell; }
}

.chart {
	height: 250px;
	margin: 0 0 1.6em 0;
}

.disclaimer {
    font-size: 0.8em;
    font-style: italic;
    color: #7f8c8d;
    background-color: #f5f5f5;
    padding: 12px;
    border-radius: 4px;
    margin: 1.5em 0;
}

.callout-box {
	background: #f9f9f9;
	padding: 20px;
	border-left: 5px solid #2ecc71;
	margin-top: 20px;
}


/* ###
# IMAGES
### */

.img {
	display: block;
	max-width: 100%;
	margin: 0 auto 2em auto;
}

@media (min-width: 45rem) {
	.img.left {
		float: left;
		margin: 0 1.6em 1.6em 0;
		max-width: 360px;
	}

	.img.right {
		float: right;
		margin: 0 0 1.6em 1.6em;
		max-width: 360px;
	}
}

/* ###
# TABLE
### */

table {
	border-collapse: collapse;
	border-spacing: 0;
	width: 100%;
	display: table;
	border: 1px solid #ccc;
	background-color: #fff;
}

table tr {
	border-bottom: 1px solid #ddd;
}

table td, table th {
	padding: 8px;
	display: table-cell;
	text-align: left;
	vertical-align: top;
}

table th {
	background-color: #4CAF50;
	color: #fff;
}

table tr:nth-child(odd) {
	background-color: #f8fff8;
}

/* ###
# GRID
### */

.row {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	width: 100%;
}

.row.nowrap {
	flex-wrap: nowrap;
	margin-left: -.6rem;
	width: calc(100% + 1.2rem);
}

.row .col {
	display: block;
	margin-left: 0;
	max-width: 100%;
	min-width: 0;
	width: 100%;
}

.row.nowrap .col {
	padding: 0 .6rem;
}

@media (min-width: 880px) {
	.row {
		flex-direction: row;
		margin-left: -1.0rem;
		width: calc(100% + 2.0rem);
	}

	.row .col {
		flex: 1;
		width: 0;
		margin-bottom: inherit;
		padding: 0 1.0rem;
	}
}

/* ###
# FORMS
### */

label, legend {
	display: block;
	font-weight: bold;
	margin-bottom: .5rem;
}

input, select, textarea {
	margin-bottom: 1rem;
}

input[type=number], input[type=email], input[type=text], select, textarea {
	appearance: none;
	background-color: transparent;
	border: 1px solid #d1d1d1;
	border-radius: .4rem;
	box-shadow: none;
	box-sizing: inherit;
	height: 2.6rem;
	padding: .6rem 0.65rem;
	width: 100%;
}

.button, button, input[type=button], input[type=submit] {
	appearance: none;
	background-color: #28b463;
	border-radius: 4px;
	border: none;
	color: #fff;
	padding: 10px 12px;
	text-transform: uppercase;
	white-space: nowrap;
	cursor: pointer;
	font-weight: bold;
	font-size: .9em;
	text-decoration: none;
}

.button:hover, button:hover, input[type=button]:hover, input[type=submit]:hover {
	background-color: #23a85b;
}

.button.slim {
	padding: 6px 8px;
}

select {
	background: url("data:image/png;base64,R0lGODlhDwAUAIABAAAAAP///yH5BAEAAAEALAAAAAAPABQAAAIXjI+py+0Po5wH2HsXzmw//lHiSJZmUAAAOw==") no-repeat 98% center;
	padding-right: 2rem;
}

select:focus {
	outline: none;
}

/* ###
# HEADER
### */

header {
	overflow: hidden;
	background-color: #2A78C1;
	color: #fff;
	padding: 10px 10px;
	margin: 0 0 20px 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

header .brand {
	text-decoration: none;
	font-size: 1.1em;
}

header a {
	color: #fff;
	white-space: nowrap;
}

header a:hover {
	opacity: 0.8;
	color: #fff;
}

header nav {
	display: none;
	gap: 16px;
}

@media (min-width: 900px) {
	header .brand {
		font-size: 1.5em;
	}

	header nav {
		display: flex;
	}
}

/* ###
# SIDENAV
### */

#sidenav-btn {
	position: relative;
	z-index: 22;
	cursor: pointer;
	font-size: 2em;
	line-height: 1em;
	user-select: none;
	-webkit-tap-highlight-color: transparent;
}

#sidenav-menu {
	position: fixed;
	left: 0;
	top: 0;
	height: 100%;
	width: 100%;
	z-index: 20;
	background: rgba(42, 120, 193, 0.98);
	overflow: hidden;
	display: none;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 20px;
}

#sidenav-menu.open {
	display: flex;
}

@media (min-width: 900px) {
	.sidenav { display: none; }
}

/* ###
# FOOTER
### */

footer {
	overflow: hidden;
	background-color: #464646;
	padding: 10px 10px 50px 10px;
	margin: 20px 0 0 0;
	color: #fff;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 20px;
}

footer ul, footer ol {
	list-style: none;
	padding: 0;
	margin: 0;
}

footer a {
	color: #fff;
}

footer ul {
	display: flex;
	gap: 10px;
}

/* ###
# BREADCRUMB
### */

.breadcrumb {
	list-style: none;
	display: inline-block;
	margin: 0;
	padding: 0;
}

.breadcrumb li {
	float: left;
	margin: 0;
}

.breadcrumb li::after {
	content: "› ";
	white-space: pre;
}

.breadcrumb li:last-child:after {
	content: "";
}

/* ###
# RATING
### */

.rating-info {
	margin: 0 0 2rem 0;
}

.rating-info p {
	margin: 0;
}

.rating {
	unicode-bidi: bidi-override;
	direction: rtl;
	text-align: left;
}

.rating > span {
	display: inline-block;
	position: relative;
	width: 1.1em;
	cursor: pointer;
}

.rating > span:hover:before, .rating > span:hover ~ span:before {
	content: "\2605";
	position: absolute;
}

/* ###
# NOWRAP
### */

p.nowrap, ul.nowrap li, ol.nowrap li {
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* ###
# LOADING
### */

.loading {
	position: fixed;
	z-index: 999;
	height: 2em;
	width: 2em;
	margin: auto;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
}

.loading:before {
	content: '';
	display: block;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(255, 255, 255, 0.8);
}

.loading:not(:required) {
	font: 0/0 a;
	color: transparent;
	text-shadow: none;
	background-color: transparent;
	border: 0;
}

.loading:not(:required):after {
	content: '';
	display: block;
	width: 40px;
	height: 40px;
	margin-top: -20px;
	margin-left: -20px;
	border-radius: 50%;
	border: 5px solid #ccc;
	border-top-color: #07d;
	animation: spinner .6s linear infinite;
}

@keyframes spinner {
	to { transform: rotate(360deg); }
}

/* ###
# FLYER
### */

.flyer {
	margin: 3rem auto;
	min-height: 53px;
	max-width: 1080px;
	text-align: center;
	width: 100%;
}

.flyer.border {
	border-top: 1px solid #f4f5f6;
	border-bottom: 1px solid #f4f5f6;
	padding: 10px 0;
	margin: 1.5rem 0 2rem 0;
	min-height: 75px;
}

.flyer .link {
	background-color: #FEF9E7;
	display: block;
	padding: 12px;
}

/* ###
# THEBAR
### */

.thebar {
	margin: 0 0 2em 0;
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
}

.thebar > section {
	width: 100%;
	background-color: #fff;
	padding: 20px;
	border-radius: 10px;
}

.thebar > section ul {
	margin: 0px;
}

@media (min-width: 600px) {
	.thebar > section {
		flex: 1;
	}
}

/* ###
# TABLE
### */

table.list .cta {
    background: linear-gradient(146deg,rgba(40,180,99,1) 0,rgba(46,204,113,1) 100%);
    border-radius: 5px;
    padding: 4px 5px;
    color: #fff;
}

table.list .logo {
	text-align: center;
	width: 200px;
}

table.list .logo img {
	height: 25px;
	max-width: 75px;
}

/* ###
# INFO
### */

ul.info {
	margin-bottom: 2em;
	list-style: none;
	padding: 0;
	display: flex;
	gap: 20px;
	flex-wrap: wrap;
	justify-content: center;
}

ul.info li {
	box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 50px;
	background-color: #fff;
	width: 300px;
	margin: 0;
	padding: 10px;
	text-align: center;
}

ul.info p:last-child {
	margin: 0;
}

@media (max-width: 600px) {
	ul.info li {
		width: 100%;
	}
}

/* ###
# TOP
### */

.top {
	background-image: linear-gradient(to right, #ff758c 0%, #ff7eb3 100%);
	padding: 16px 10px;
	margin: -1rem 0 1rem 0;
	text-align: center;
	color: #fff;
}

/* ###
# CARDS
### */

.cards {
	margin-bottom: 2em;
	list-style: none;
	padding: 0;
}

.cards > li {
	box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
	background-color: #fff;
	border-radius: 2px;
	padding: 15px;
	margin-bottom: 1em;
	overflow: hidden;
}

.cards .logo {
	max-width: 160px;
	height: 40px;
	display: block;
	margin: 1em auto;
}

.cards .cta {
	display: block;
	background: linear-gradient(146deg, rgba(40,180,99,1) 0%, rgba(46,204,113,1) 100%);
	border-radius: 5px;
	padding: 6px;
	color: #fff;
	text-align: center;
}

.cards .cta:hover {
	background-color: #2ECC71;
}

.cards ul.check {
	padding: 0;
	margin: 0 0 1em 0;
}

.cards ul.check li {
	margin: 0;
}

@media (min-width: 45rem) {
	.cards {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-evenly;
	}

	.cards > li {
		width: 250px;
	}
}

/* ###
# PRODUCTS
### */

ul.products {
	margin-bottom: 2em;
	list-style: none;
	padding: 0;
}

ul.products li {
	box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 10px;
}

ul.products .logo {
	width: 90px;
	display: flex;
	align-items: center;
}

ul.products .logo img {
	max-width: 80px;
	height: 20px;
}

ul.products .details {
	flex-grow: 1;
	color: #666;
	font-style: italic;
	font-size: .7em;
}

ul.products .cta {
	display: block;
	background: linear-gradient(146deg, rgba(40,180,99,1) 0%, rgba(46,204,113,1) 100%);
	border-radius: 5px;
	padding: 0 6px;
	color: #fff;
	text-align: center;
}

ul.products .cta:hover {
	background-color: #2ECC71;
}

@media (min-width: 45rem) {
	ul.products .logo {
		width: 110px;
	}

	ul.products .details {
		font-size: .8em;
	}
}


/* OFFERS */
ul.offers {
	margin-bottom: 2em;
	list-style: none;
	padding: 0;
}

ul.offers li {
	box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 50px;
	background-color: #fff;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 10px;
	padding: 10px;
	margin: 0 0 10px 0;
}

ul.offers li:hover {
	background-color: #fffdee;
	cursor: pointer;
}

/* ul.offers li:nth-child(even) { background-color: #ffffff76; } */
ul.offers .logo { height: 25px; max-width: 55px; }
ul.offers .name { flex: 1 1 auto; white-space: nowrap; }
ul.offers .score { width: 80px; white-space: nowrap; font-size: .9em; color: #555; }
ul.offers .brand { min-width: 60px; display: flex; align-items: center; justify-content: center; }

/* ul.offers .brand { display: none; } */
@media (min-width: 600px) {
	ul.offers .brand { flex-basis: 120px; }
	ul.offers .logo { max-width: 75px; }
	ul.offers .score { width: 160px; }
}

ul.offers .cta {
	background-color: #28b463;
	border-radius: 5px;
	padding: 2px 5px;
	color: #fff;
	text-align: center;
	white-space: nowrap;
}

ul.offers .details {
	color: #888;
	font-size: .8em;
	flex-grow: 1;
	line-height: 1.3em;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 400px;
}

ul.offers .price {
	white-space: nowrap;
	font-size: .8em;
	color: #666;
	line-height: 1.3em;
}

ul.offers .price .old {
	text-decoration: line-through;
	color: #CD5C5C;
}

ul.offers .price .new {
	color: #3498db;
	font-size: 1.2em;
}

ul.offers .extra {
	color: #fff;
	border-radius: 10px;
	padding: 8px;
	font-size: .6em;
	display: flex;
	align-items: center;
	text-align: center;
	font-weight: bold;
	line-height: 1;
}

ul.offers .extra.bestprice {
background-image: linear-gradient(91.2deg, #8850e2 4%, #28249f 96.5%);
}

ul.offers .extra.recommend {
background-image: linear-gradient(113.9deg, #f16a38 13%, #d52027 48.8%, #aa4127 85.9%);
}

ul.offers .choose {
	background-color: #28b463;
	color: #fff;
	border-radius: 10px;
	font-size: .8em;
	padding: 7px 8px;
}

@media (max-width: 600px) {
	ul.offers .extra { display: none; }
	ul.offers .choose { font-size: .6em; padding: 10px 6px; }
}

/* ###
# RIBBON
### */

.ribbon {
	position: absolute;
	left: -5px; top: -5px;
	z-index: 1;
	overflow: hidden;
	width: 75px; height: 75px;
	text-align: right;
}

.ribbon span {
	font-size: 10px;
	font-weight: bold;
	color: #FFF;
	text-transform: uppercase;
	text-align: center;
	line-height: 20px;
	transform: rotate(-45deg);
	width: 100px;
	display: block;
	background: linear-gradient(#9BC90D 0%, #79A70A 100%);
	box-shadow: 0 3px 10px -5px rgba(0, 0, 0, 1);
	position: absolute;
	top: 19px; left: -21px;
}

.ribbon span.gold {
	background: linear-gradient(#fcd100 0%, #ffa900 100%);
}

.ribbon span.silver {
	background: linear-gradient(#B6BAC9 0%, #808080 100%);
}

.ribbon span.bronze {
	background: linear-gradient(#db8a2b 0%, #e06737 100%);
}

/* ###
# CHECK
### */

ul.check {
	list-style: none;
}

ul.check li:before {
	content: '✅ ';
}

ul.check.cons li:before {
	content: '❌ ';
}

/* ###
# FACTS
### */

.facts {
	background-color: #F2F4F4;
	padding: .5em 1em;
	margin: 0 0 1em 0;
}

@media (min-width: 45rem) {
	.facts {
		width: 380px;
	}

	.facts.left {
		margin-right: 1em;
		float: left;
	}
	
	.facts.right {
		margin-left: 1em;
		float: right;
	}
}

/* ###
# RIO
### */

.rio {
	display: none;
}

@media (min-width: 1280px) {
	.rio {
		position: absolute;
		display: inline-block;
		width: 200px;
		height: 600px;
		text-align: center;
		background: repeating-linear-gradient(45deg, transparent 0 10px, #fff7f9 10px 20px);
	}

	.rio::before {
		content: 'Advertisement';
		color: #999;
		text-transform: uppercase;
		font-size: .7em;
		display: block;
	}

	.rio.left {
		top: 0px;
		left: -250px;
	}

	.rio.right {
		top: 0px;
		right: -250px;
	}
}

/* ###
# Reviews
### */

.reviews {
	list-style: none;
	padding: 0;
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.reviews li {
	box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 50px;
	background-color: #fff;
	padding: 10px;
	border-radius: 10px;
	min-width: 300px;
	flex: 1;
}

.reviews li p:last-child {
	margin: 0;
}

.reviews .text {
	/* font-size: .8em; */
	color: #666;
}

.reviews .text.truncate {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.reviews .logo {
	width: 120px;
	height: 60px;
	float: right;
	display: flex;
	justify-content: center;
	align-items: center;
}

.reviews .logo img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}


/* grid */

.multicol {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	margin: 0 0 20px 0;
	
}

.multicol > section {
	flex: 1;
	min-width: 300px;
}

.multicol > section.green {
	border-top: solid 5px #63da70;
}

.multicol > section.orange {
	border-top: solid 5px #ff8934;
}

.multicol > section.purple {
	border-top: solid 5px #7532c7;
}

@media screen and (min-width: 640px) {
	.multicol > section {
		min-width: 500px;
	}
}

main {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
}

@media screen and (min-width: 640px) {
	main {
		padding: 0;
	}
}

article {
	max-width: 700px;
	margin: 0 auto;
}

/* topbar */

.topbar {
	background-color: #fff;
	display: flex;
	justify-content: space-evenly;
	align-items: center;
	height: 80px;
	margin: -20px 0 20px 0;
}

.topbar .logo {
	width: 150px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.topbar .logo img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}

/* ###
# TOPBG
### */

.topbg {
	background-color: #d4efdf;
	padding: 20px 0 10px 0;
	margin-top: -16px;
}

.topbg .container {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	height: 80px;
}

.topbg .container img {
	height: 40px;
	max-width: 200px;
}

.topbg .review {
	font-size: 1.2em;
}

@media screen and (max-width: 640px) {
	.topbg .container {
		justify-content: center;
	}
}

/* pros cons */

.pros-cons {
	display: flex;
	gap: 20px;
	flex-wrap: wrap;
	margin-bottom: 30px;
}

.pros, .cons {
	flex: 1;
	padding: 15px;
	border-radius: 5px;
}

.pros {
	background-color: #e6f7e6;
}

.cons {
	background-color: #f7e6e6;
}

/* ###
# LINKS
### */

.links {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	padding: 0;
	margin: 5px 0 1.6em 0;
}

.links li {
	background-color: #fff;
	padding: 2px 8px;
	border-radius: 10px;
	white-space: nowrap;
	margin: 0;
}

.links::before {
	content: 'Hop til:';
	color: #999;
	margin: 6px 0 0 0;
	font-size: .8em;
}

/* ###
# SECTION STYLING
### */

section.info {
	background-color: #fff;
	border-radius: 10px;
	padding: 20px;
	margin: 0 0 2em 0;
}

section.info p:last-child {
	margin: 0;
}