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

body {
	font-size: 18px;
	line-height: 1.65;
}
p, ul, ol, form, table { margin: 0 0 25px 0; }
h1, h2, h3 { margin: 0 0 0.5em; line-height: 1.4; }
h1 { font-size: 1.6em; color: #880101; }
h2 { font-size: 1.4em; color: #990101; }
h3 { font-size: 1.2em; color: #aa0101; }
ol, ul { padding: 0 0 0 .5em; }
ol { list-style: decimal inside; }
ul { list-style: disc inside; }
ol li, ul li { margin-bottom: 8px; }
hr { border: 0; border-top: 1px solid #f4f5f6; margin: 1.6em 0; }
mark { background: #ff0; }
small { font-size: .65em; }
.t-center { text-align: center; }
.t-right { text-align: right; }

.hide { display: none; }
td.nowrap { white-space: nowrap; }

ul.truncate li {
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
}

.lead {
	font-size: 1.2em;
}

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

.feather-heart {
	width: 80px;
	height: 80px;
	stroke: #960101;
	margin: 0 auto;
	display: inline-block;
}

.protip {
	background-color: #FEF9E7;
	padding: 12px;
	margin: 20px 0;
	text-align: center;
}

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

.button.blue { background-color: #2874A6; }
.button.blue:hover { background-color: #2E86C1; }

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

.aligncheck {
	display: flex;
	align-items: center;
	gap: 10px;
}

.aligncheck input, .aligncheck label {
	margin: 0;
}

.countpage {
	text-align: center;
	font-size: 1.6em;
	line-height: 1.3em;
	font-weight: bold;
}

.markets {
	height: 400px;
	margin: 0 0 2em 0;
}

lite-youtube {
	margin: 0 0 25px 0;
}

/* ###
# CONTAINER
### */

.container {
	margin: 0 auto;
	max-width: 740px;
	padding: 0 1.2rem;
	position: relative;
	width: 100%;
}

/* ###
# 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: 320px;
	}

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

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

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

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

table th:first-child, table td:first-child {
	padding-left: 16px;
}

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

table th {
	background-color: #019595;
	color: #fff;
}

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

table caption {
	color: #666;
	background-color: #dbf2f2;
	border-radius: 10px 10px 0 0;
	padding: 5px 10px;
	font-size: .8em;
}

/* ###
# 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;
	margin-bottom: .5rem;
}

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

input[type=number], input[type=email], input[type=text], select, textarea {
	appearance: none;
	background-color: #fff;
	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: #9A6F0F;
	border-radius: 4px;
	border: none;
	color: #fff;
	padding: 11px 18px;
	text-transform: uppercase;
	white-space: nowrap;
	cursor: pointer;
	font-weight: bold;
	font-size: .9em;
}

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

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

select:focus {
	outline: none;
}

.label-inline {
	display: inline-block;
	font-weight: normal;
	margin-left: .5rem;
}

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

header {
	overflow: hidden;
	background-color: #960101;
	color: #fff;
	padding: 10px 10px;
	margin: 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(150, 1, 1, 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: #960101;
	background-image: linear-gradient(to top, #960101 0%, #bb0101 100%);
	margin: 60px 0 0 0;
	padding: 10px 10px 50px 10px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 20px;
}

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

footer a:hover {
	color: #fff;
	text-decoration: underline;
}

footer ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

footer ul > li {
	margin: 0;
	background-color: rgba(207, 51, 51, 0.6);
	padding: 2px 5px;
}

@media (min-width: 600px) {
	footer ul {
		width: 50%;
	}
}

/* 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: "";
}

/* ###
# 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: 325px;
	max-width: 1080px;
	text-align: center;
	width: 100%;
	background-image: url('/img/pattern.svg');
}

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

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

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

.products {
	list-style: none;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 20px;
}

.products > li {
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	text-align: center;
}

.products > li img {
	border: solid 10px #f8f7f3;
}

.products > li a {
	background-color: #f8f7f3;
	border-radius: 0 0 10px 10px;
	display: inline-block;
	padding: 0 5px 5px 5px;
}

@media (max-width: 600px) {
	.products {
		gap: 5px;
	}

	.products > li img {
		border-radius: 10px 10px 0 0;
		border-width: 0px;
		width: 100px;
		height: 100px;
	}

	.products > li a {
		border-radius: 0 0 5px 5px;
	}
}

/* ###
# SNOWFLAKE
### */

#snowflake {
	position: fixed;
	bottom: 10px;
	right: 10px;
	background-color: #5DADE2;
	border-radius: 100%;
	width: 50px;
	height: 50px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
}

#snowflake svg {
	width: 42px;
	height: 42px;
	fill: #fff;
	transition: all 1s;
}

#snowflake svg:hover {
	transform: rotate(360deg);
}

/* ###
# RUDOLF
### */

.rudolf {
	display: none;
}

@media (min-width: 1280px) {
	.rudolf {
		position: absolute;
		display: inline-block;
		width: 160px;
		height: 600px;
	}

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

	.rudolf.left {
		top: 0px;
		left: -200px;
	}

	.rudolf.right {
		top: 0px;
		right: -200px;
	}
}

/* ###
# SUBHEADER
### */

.subheader {
	background-color: #bb0101;
	padding: 5px;
	color: #fff;
	margin: 0 0 2rem 0;
	font-size: .75em;
	font-weight: bold;
	display: flex;
	justify-content: space-between;
}

.subheader a {
	color: #fff;
}

.subheader a:hover {
	text-decoration: underline;
}

.subheader .container {
	display: flex;
	flex-direction: row;
	justify-content: center;
}

@media (max-width: 45rem) {
	.subheader {
		justify-content: center;
	}
}

/* ###
# LIST
### */

.list {
	display: flex;
	justify-content: space-evenly;
	flex-wrap: wrap;
	margin: 0 0 2em 0;
	gap: 10px;
}

.list .item {
	background-color: #E9F7EF;
	padding: 10px;
	cursor: pointer;
	width: 100%;
}

.list .item:nth-child(odd) {
	background-color: #e4f4eb;
}

.list .item:hover {
	background-color: #ecd592;
}

@media (min-width: 45em) {
	.list .item {
		flex-grow: 1;
		width: 33%;
	}
}

/* ###
# POSTCARDS
### */

.postcards {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-evenly;
}

.postcards img {
	border: 10px solid #fff;
	cursor: pointer;
	width: 33%;
	flex-grow: 1;
}

.postcards img:hover {
	border-color: #ecd592;
}

@media (max-width: 45rem) {
	.postcards img {
		width: 50%;
	}
}

/* ###
# SONGS
### */

.song {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 20px;
}

.song p {
	text-align: center;
}

/* @media (min-width: 45rem) {
	.song p {
		margin: 2rem;
	}
} */

/* ###
# STICKYBAR
### */

.stickybar {
	background-color: #046414;
	transition: 0.6s cubic-bezier(0, 1, 0.5, 1);
	position: fixed;
	bottom: -200px;
	z-index: 20;
	overflow: hidden;
	width: 100%;
	height: 80px;
}

.stickybar .container {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	padding: 10px;
	color: #fff;
}

.stickybar small {
	margin: 0;
	display: block;
}

.stickybar .container form {
	margin: 0;
	display: flex;
	flex-direction: row;
}

.stickybar form input::placeholder {
	color: #fff;
	opacity: .4;
}

.stickybar .container form input {
	margin-right: 5px;
	color: #fff;
	border-color: #fff;
}

.stickybar svg {
	cursor: pointer;
}

@media (max-width: 800px) {
	.stickybar .container div:first-child {
		display: none;
	}

	.stickybar .container {
		justify-content: space-around;
	}
}

/* ###
# ANDROID
### */

.adbstick {
	background: #00b09b;
	background: linear-gradient(to right, #00b09b, #96c93d);
	transition: 0.6s cubic-bezier(0, 1, 0.5, 1);
	position: fixed;
	bottom: -200px;
	z-index: 20;
	overflow: hidden;
	width: 100%;
	height: 160px;
	text-align: center;
	color: #fff;
	padding: 20px 0;
}

.adbstick span {
	display: block;
}

.adbstick .title {
	font-size: 1.4em;
	font-weight: bold;
}

.adbstick .download {
	background-color: #f25588;
	text-decoration: underline;
	padding: 5px 0;
	margin: 5px 0;
}

/* ###
# NOTIFIER
### */

.notifier {
	transition: all 0.6s cubic-bezier(0, 1, 0.5, 1);
	background-color: #388a29;
	display: block;
	overflow-y: hidden;
	position: fixed;
	bottom: -80px;
	width: 100%;
	z-index: 99;
	padding: 10px 0;
	text-align: center;
	color: #fff;
}

@media (min-width: 45rem) {
	.notifier {
		width: auto;
		padding: 10px;
		right: 0px;
	}
}

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

.card {
	position: relative;
	overflow: hidden;
	margin: 10px 0 10px;
	box-shadow: 0 1px 2px 0 rgba(0,0,0,.12), 0 2px 10px 0 rgba(0,0,0,.10);
	border-radius: 2px;
	padding: 15px;
}

.cards {
	margin-bottom: 2em;
}

@media (min-width: 45rem) {
	.cards.two, .cards.three {
		display: flex;
		flex-direction: row;
		flex: 1;
		flex-wrap: wrap;
	}
	
	.cards.two .card {
		width: calc(50% - 20px);
		margin: 10px;
	}

	.cards.three .card {
		width: calc(33.3333% - 20px);
		margin: 10px;
	}
}

/* ###
# Movies
### */

.movies {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-evenly;
	gap: 10px;
	margin: 0 0 2em 0;
}

.movies lite-youtube {
	flex-grow: 1;
	width: 40%;
	margin: 0;
}

/* ###
# Reminders
### */

.reminder {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	background-color: #960101;
	color: #fff;
	text-align: center;
	padding: 10px;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
	transform: translateY(-100%);
	transition: transform 0.3s ease-in-out;
	z-index: 1000;
}

.reminder.active {
	transform: translateY(0);
}

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

.links::before {
	content: 'Hop til:';
	color: #999;
}

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

.links li {
	background-color: rgba(82, 165, 255, 0.1);
	padding: 2px 8px;
	border-radius: 10px;
	white-space: nowrap;
	margin: 0;
}

/* ###
# TV SHOWS
### */

ul.tvshows {
	list-style: none;
	padding: 0;
}

ul.tvshows .imdb {
	color: #999;
	font-size: .8em;
}

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

p.info {
	padding: 10px;
	background-color: #F6EFD2;
}

p.info.green {
	border-left: 5px solid #347433;
}