@font-face {
	font-family: 'my';
	src: url('/font.woff2') format('woff2');
	font-display: swap;
}
@font-face {
	font-family: 'myh';
	src: url('/fonth.woff2') format('woff2');
	font-display: swap;
}
* {
	box-sizing: border-box;
}
body {
	background: #700020;
	font-family: 'my', sans-serif;
	font-size: 1.1em;
	padding: 0;
}
#main {
	background: #fffbfb;
	color: #252525;
	max-width: 1024px;
	margin: 0 auto;
	padding: 1.5rem 0;
	min-height: calc(100vh - 4em);
	display: flex;
	flex-direction: column;
	border-radius: 1rem;
}

h1 {
	color: #913;
	font-family: 'myh';
	letter-spacing: .024em;
	text-align: center;
	min-height: 50px;
	padding: 0 1rem;
	margin: 1rem 0 0;
}
h2 {
	color: #913;
	font-family: 'myh';
	letter-spacing: .024em;
	text-align: center;
}

p {
	margin-top: 0;
}

a {
	color: #913;
}

.sharing {
	display: flex;
	justify-content: center;
	font-size: 1em;
}
.sharing svg {
	fill: #fff;
	height: 1em;
	margin: 0;
	vertical-align: bottom;
}
.sharing a {
	color: #fff;
	display: inline-block;
	max-width: 3em;
	text-decoration: none;
}
.sharing a > div {
	border-radius: 5px;
	padding: .5em .75em;
	transition: 25ms ease-out;
	display: flex;
	justify-content: center;
}
.sharing .facebook {
	background: #3b5998;
	border: #3b5998;
}
.sharing .facebook:active, .sharing .facebook:hover {
	background: #2d4373;
	border: #2d4373;
}
.sharing .twitter {
	background: #55acee;
	border: #55acee;
}
.sharing .twitter:active, .sharing .twitter:hover {
	background: #2795e9;
	border: #2795e9;
}
.sharing .email {
	background: #777;
	border: #777;
}
.sharing .email:active, .sharing .email:hover {
	background: #5e5e5e;
	border: #5e5e5e;
}
.sharing .reddit {
	background: #5f99cf;
	border: #5f99cf;
}
.sharing .reddit:active, .sharing .reddit:hover {
	background: #3a80c1;
	border: #3a80c1;
}
.sharing .whatsapp {
	background: #25d366;
	border: #25d366;
}
.sharing .whatsapp:active, .sharing .whatsapp:hover {
	background: #1da851;
	border: #1da851;
}
.sharing .instagram {
	background: #d37;
	border: #d37;
}
.sharing .instagram:active, .sharing .instagram:hover {
	background: #b15;
	border: #b15;
}
@media (any-hover: hover) {
	.sharing .whatsapp, .sharing .whatsapp-link {
		display: none;
	}
}

.sharing a {
	width: 50px;
	display: block;
}

.primenav {
	text-align: center;
	padding: 0 1em;
}

footer {
	text-align: center;
	margin-top: 1.5em;
	padding: 0 1em;
	display: flex;
	align-items: center;
}

ul, ol {
	line-height: 1.5em;
}

.flinks {
	flex: 1;
	display: flex;
	flex-wrap: wrap;
	gap: .3em;
	justify-content: space-around;
}
.flinks a, .flinks span {
	padding: .3em;
}

.content {
	padding: 0 1rem;
	flex: 1;
	margin-top: 1rem;
}
img.header-img {
	max-width: 100%;
	height: auto;
}

.primenav nav ul {
	display: flex;
	flex-wrap: wrap;
	padding-left: 0;
	justify-content: space-between;
	margin-top: 0;
	list-style: none;
	font-size: .9em;
	margin-right: 1.5em;
	position: relative;
}
.primenav nav li {
	margin-right: .68em;
}
.primenav ul li:first-child {
	position: absolute;
	right: -2.5em;
	width: 36px;
}
.primenav ul li:last-child {
	position: absolute;
	right: -2.5em;
	top: 3.2em;
	width: 36px;
	text-align: center;
}
.primenav nav li .age {
	font-size: 75%;
}

.main img {
	vertical-align: middle;
}

#menu-toggle {
	display: none;
}

.impressum .author-link img {
	vertical-align: middle;
}

.rechts {
	text-align: center;
	margin: 0;
}

.header-wrapper {
	position: relative;
	text-align: center;
	margin-top: 1rem;
}
.caption {
	position: absolute;
	bottom: .5em;
	right: .5em;
	color: #888;
	font-size: .6em;
	user-select: none;
}

.review-meta {
	display: flex;
	margin-bottom: 1em;
	border-bottom: 1px solid #700020;
	flex-wrap: wrap;
}
.review-meta > div {
	flex: 1;
	padding: .3em;
}
.review-meta > div:first-child {
	padding-left: 0;
}
.review-meta > div:last-child {
	padding-right: 0;
}
.review-meta > div.pm-link {
	text-align: center;
	order: 3;
	flex: 100%;
}
.review-date {
	text-align: right;
}
.text-and-box {
	display: flex;
	flex-direction: column;
	gap: .3em;
}
.text-and-box > div:first-child {
	flex: 3;
	margin-bottom: 1em;
}
.text-and-box > div:last-child {
	flex: 2;
	margin-bottom: 1em;
}

.box {
	border: 1px solid #ccc;
	border-radius: 1em;
}
.box > div {
	display: flex;
	flex-direction: row;
}
.box > div > div:first-child {
	flex: 1;
	padding: .3em .3em .3em .8em;
}
.box > div > div:last-child {
	flex: 2;
	padding: .3em .8em .3em .3em;
}
.box img {
	vertical-align: middle;
	margin-right: .3em;
}

.rates {
	display: flex;
	flex-wrap: wrap;
	margin-top: 1rem;
	gap: .5rem;
}
.rates > div {
	flex: 50%;
	text-align: center;
	background: #fff;
	padding: .5em;
	border: 1px solid #ccc;
	position: relative;
	border-radius: 1em;
}
.rates > div:not(:first-child) {
	margin-left: 5px;
}
.rates > div.selected {
	border: 1px solid #700020;
	flex: 16em;
}
.rates > div:not(.selected) {
	cursor: pointer;
}
.rate-name {
	padding: 1em;
}
.rate-wrapper {
	display: flex;
	position: relative;
	max-width: fit-content;
	margin: 0 auto;
	pointer-events: none;
	user-select: none;
}
.rate-num {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	font-size: 1.5em;
}
.rate-num-1 { color: #a00; }
.rate-num-2 { color: #b31; }
.rate-num-3 { color: #c53; }
.rate-num-4 { color: #d73; }
.rate-num-5 { color: #ea5; }
.rate-num-6 { color: #fc6; }
.rate-num-7 { color: #bb4; }
.rate-num-8 { color: #893; }
.rate-num-9 { color: #482; }
.rate-num-10 { color: #060; }
.rate-criteria {
	text-align: center;
	font-size: .8em;
	padding: .5em;
}
.rate-text {
	padding: .5em;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	max-height: 4.3em;
}
.rates > div.selected .rate-text {
	display: flex;
	max-height: fit-content;
}
.rates .expand:before {
	content: "+";
	position: absolute;
	top: .2em;
	right: .5em;
	font-size: 1.2em;
}
.rates .selected .expand:before {
	content: "-";
	cursor: pointer;
}

.group-list {
	margin-top: 0;
}

@media screen and (min-width: 640px) {
	body {
		padding: 0 1em; /* we have padding: 0 auto on #main, this ensures that there will be spacing even when "auto" leads to zero margin */
		margin: 0;
	}

	#main {
		padding: 2rem 0;
		margin: 2rem auto;
	}
	h1 {
		padding: 0 3rem;
	}
	.content {
		padding: 0 3rem;
	}
	.primenav {
		padding: 0 3rem;
	}

	footer {
		padding: 0 3rem;
	}

	.rechts {
		float: right;
		margin: 0 0 .3rem .3rem;
	}

	.primenav nav ul {
		font-size: 1rem;
		margin-right: 0;
	}
	.primenav ul li:first-child {
		position: static;
	}
	.primenav ul li:last-child {
		position: static;
		margin-right: 0;
		flex: 1;
		text-align: right;
	}
	.rates > div {
		flex: 1;
	}

	.text-and-box {
		flex-direction: row;
	}
	.review-meta > div.pm-link {
		order: initial;
		flex: 1;
	}
}