:root {
	--color-light: rgb(255,255,255);
	--color-dark: rgb(64,22,18);
	--font-family-default: "Arsenal";
	--font-family-highlight: "Arsenal";

	--color-pink-gradient-from: rgb(194,75,137);
	--color-pink-gradient-to: rgb(164,14,95);
	--color-blue-gradient-from: rgb(1,76,150);
	--color-blue-gradient-to: rgb(1,94,182);

	--color-turkis: rgb(1,155,180);
}

html, body {
	padding: 0;
	margin: 0;
	color: var(--color-light);
	font-size: 16px;
	margin-bottom: -20px;
	font-family: var(--font-family-default);
	font-weight: lighter;
}

*:focus {
	outline: none;
}

.content {
	overflow: hidden;
}

.content-wrapper {
	width: 100%;
	max-width: 900px;
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
	padding-left: 20px;
	padding-right: 20px;
}

b {
	font-weight: 600;
}

a {
	color: inherit;
}

p {
	margin: 0px;
	margin-bottom: 16px;
}

h1, h2, h3 {
	font-weight: 600;
	margin-top: 0px;
	margin-bottom: 16px;
}

h2 {
	font-size: 36px;
}

h3 {
	font-size: 28px;
}

.bold {
	font-weight: bold;
}

/* BUTTON */
.button {
	box-sizing: border-box;
	padding: 10px 30px;
	background: rgb(253,235,164);
	background: -moz-linear-gradient(90deg, rgba(195,166,90,1) 0%, rgba(253,235,164,1) 50%, rgba(195,166,90,1) 100%);
	background: -webkit-linear-gradient(90deg, rgba(195,166,90,1) 0%, rgba(253,235,164,1) 50%,rgba(195,166,90,1) 100%);
	background: linear-gradient(90deg, rgba(195,166,90,1) 0%, rgba(253,235,164,1) 50%,rgba(195,166,90,1) 100%);
	text-transform: uppercase;
	text-decoration: none;
	color: var(--color-dark);
	border: none;
	cursor: pointer;
	font-size: 18px;
}

.button.blue {
	color: var(--color-blue-gradient-to);
}

.button.pink {
	color: var(--color-pink-gradient-to);
}


/* BOX */
.box {
	box-sizing: border-box;
	padding: 30px;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	background: var(--color-pink-gradient-from);
	background: linear-gradient(174deg, var(--color-pink-gradient-from) 0%, var(--color-pink-gradient-to) 100%);
	overflow: hidden;
}

.box.grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	list-style: none;
	column-gap: 30px;
}

.box.grid li {
	position: relative;
}

/* VISUAL */
.visual {
	background: var(--color-pink-gradient-from);
	background: linear-gradient(174deg, var(--color-pink-gradient-from) 0%, var(--color-pink-gradient-to) 100%);
	position: relative;
	padding-bottom: 40px;
	padding-top: 40px;
	text-align: center;
	-webkit-box-shadow: 0px 0px 13px 0px rgba(0,0,0,0.35);
	-moz-box-shadow: 0px 0px 13px 0px rgba(0,0,0,0.35);
	box-shadow: 0px 0px 13px 0px rgba(0,0,0,0.35);
}

.separator {
	height: 10px;
	width: 100%;
	position: absolute;
	bottom: 0px;
	left: 0px;
	background: rgb(253,235,164);
	background: -moz-linear-gradient(90deg, rgba(195,166,90,1) 0%, rgba(253,235,164,1) 50%, rgba(195,166,90,1) 100%);
	background: -webkit-linear-gradient(90deg, rgba(195,166,90,1) 0%, rgba(253,235,164,1) 50%,rgba(195,166,90,1) 100%);
	background: linear-gradient(90deg, rgba(195,166,90,1) 0%, rgba(253,235,164,1) 50%,rgba(195,166,90,1) 100%);
}

.visual a img {
	border: none;
	width: 200px;
}

.visual img.visual-image {
	width: 100%;
	max-width: 900px;
	margin-top: 40px;
}

.visual img {
	display: inherit;
	margin-left: auto;
	margin-right: auto;
}


/* INTRO */
.intro {
	padding-top: 40px;
	padding-bottom: 20px;
	background-color: var(--color-turkis);
}

.intro img {
	width: 100%;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: -30px;
	-webkit-box-shadow: 0px 0px 13px 0px rgba(0,0,0,0.35);
	-moz-box-shadow: 0px 0px 13px 0px rgba(0,0,0,0.35);
	box-shadow: 0px 0px 13px 0px rgba(0,0,0,0.35);
}

.intro .box1 {
	overflow: visible;
	background: transparent;
}

/* HOWTO */
.howto {
	padding-top: 20px;
	padding-bottom: 50px;
	background-color: var(--color-turkis);
	position: relative;
}

.howto img {
	width: 100%;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}

.howto .button {
	margin-top: 20px;
	display: inline-block;
}



/* PARTICIPATE */
.participate {
	padding-top: 40px;
	padding-bottom: 40px;
	color: var(--color-light);
	background: var(--color-blue-gradient-from);
	background: linear-gradient(120deg, var(--color-blue-gradient-from) 0%, var(--color-blue-gradient-to) 60%, var(--color-blue-gradient-from) 100%);
	text-align: center;
}

.participate .content-wrapper.thin {
	max-width: 800px;
}

.participate .subline {
	text-align: left;
	font-size: small;
	margin-top: 15px;
}

.form-wrapper {
	width: 100%;
	max-width: 500px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 40px;
}

.form-element {
	width: 100%;
	text-align: left;
	padding-bottom: 7px;
}

.form-element label {
	width: 100%;
	text-transform: uppercase;
	text-align: left;
	font-size: small;
}

input[type="email"],
input[type="text"] {
	width: 100%;
	margin-top: 4px;
	box-sizing: border-box;
	padding: 8px 15px;
	font-family: var(--font-family-default);
	font-size: 16px;
}

#code {
	text-align: center;
	font-size: x-large;
	text-transform: uppercase;
}

#btn-submit {
	margin-top: 20px;
}


/* RESULT */
.result-message a.button {
	margin-top: 10px;
	display: inline-block;
	margin-bottom: 20px;
}

.result-message .vouchercode {
	background-color: var(--color-light);
	color: var(--color-blue-gradient-from);
	display: inline-block;
	box-sizing: border-box;
	padding: 6px 15px;
	margin-bottom: 20px;
	font-size: large;
	text-transform: uppercase;
}

/* CHECKBOX */
.checkbox-wrapper {
	text-align: left;
	margin-bottom: 20px;
	position: relative;
}

.checkbox-wrapper input[type="checkbox"] {
	display: none;
}

.checkbox-wrapper input[type="checkbox"]:checked + label:before {
	content: "\2713";
	color: rgb(0,0,0);
	font-size: 24px;
	text-align: center;
	line-height: 18px;
	top: 2px;
}

.checkbox-wrapper label:before {
	content: "";
	display: inline-block;
	width: 15px;
	height: 15px;
	margin-right: 10px;
	position: relative;
	left: 0;
	top: 2px;
	background-color: rgb(255,255,255);
	font-weight: 800;
	-webkit-box-shadow: 0px 0px 13px 0px rgba(0,0,0,0.35);
	-moz-box-shadow: 0px 0px 13px 0px rgba(0,0,0,0.35);
	box-shadow: 0px 0px 13px 0px rgba(0,0,0,0.35);
}

.checkbox-wrapper label a {
	color: inherit;
}



/* FOOTER */
.footer {
	width: 100%;
	padding-bottom: 20px;
	padding-top: 40px;
	background-color: rgb(255,255,255);
	color: rgba(0,0,0,1);
	text-align: center;
	font-size: 18px;
	box-sizing: border-box;
	padding-left: 20px;
	padding-right: 20px;
}

.footer a {
	font-weight: 300;
	color: rgb(0,0,0);
	text-decoration: none;
}

.footer ul {
	width: 90%;
	padding: 0px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 0px;
	margin-bottom: 60px;
	font-size: 22px;
}

.footer ul li {
	list-style: none;
	display: inline;
}

.footer ul li:not(:last-child) {
	margin-right: 10px;
}

.footer h3 {
	text-align: left;
	margin-top: 0px;
	margin-bottom: 30px;
	font-weight: 300;
	font-size: 24px;
}

.footer p {
	font-size: 18px;
	line-height: 16px;
	font-weight: 400;
}

.footer .col {
	width: 100%;
	max-width: 1100px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 40px;
	column-count: 2;
	column-gap: 2em;
	column-width: 270px;
	-webkit-column-count: 2;
	-webkit-column-gap: 2em;
	-webkit-column-width: 270px;
	-moz-column-count: 2;
	-moz-column-gap: 2em;
	-moz-column-width: 270px;
	
}

.footer .col p {
	line-height: 16px;
	margin: 0 0 2.7ex 0;
	text-align: justify;
	hyphens: auto;
	font-family: "Optima";
	font-weight: 100;
	font-size: 12px;
}

.footer p a {
	font-weight: 700;
	text-decoration: none;
	font-family: "Optima";
	color: var(--color-dark);
}



/* RESPONSIVES */
@media all and (max-width: 700px) {

	.box.grid {
		grid-template-columns: 1fr;
		row-gap: 20px;
	}
	.intro img,
	.howto img {
		position: relative;
		transform: none;
		left: auto;
		top: auto;
		max-width: 400px;
		margin-left: auto;
		margin-right: auto;
	}
	.box.grid li {
		text-align: center;
	}
	.howto ul li:first-child {
		order: 2;
	}

	.footer ul li:not(.last-child) {
		display: block;
		margin-right: 0px;
	}

}

@media all and (max-width: 500px) {

	.visual {
		padding-top: 20px;
	}

	.visual a img {
		width: 140px;
	}

}