@font-face {
    font-family:"HelveticaNeue";
    src:url("../fonts/HelveticaNeueLTStd-LtCn.woff2") format("woff2"),url("../fonts/HelveticaNeueLTStd-LtCn.woff") format("woff"),url("../fonts/HelveticaNeueLTStd-LtCn.otf") format("opentype");
    font-style:normal;font-weight:400;
}

@font-face {
    font-family:"HelveticaNeue";
    src:url("../fonts/HelveticaNeueLTStd-MdCn.woff2") format("woff2"),url("../fonts/HelveticaNeueLTStd-MdCn.woff") format("woff"),url("../fonts/HelveticaNeueLTStd-MdCn.otf") format("opentype");
    font-style:normal;font-weight:600;
}

* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-smoothing: antialiased;
	text-rendering: optimizelegibility;
}

html {
	min-height: 100vh;
}

body {
	margin: 0;
	font-family:"HelveticaNeue", sans-serif;
	font-size: 22px;
	background: url("../img/stars-only.png"), linear-gradient(147deg, rgba(255, 51, 51, 1), rgba(150, 7, 38, 1));
	min-height: 100vh;
}

.page {
	position: relative;
	min-height: 100vh;
	max-width: 100vw;
	overflow: hidden;
}

.logo {
	position: absolute;
	z-index: 9999;
	top: 3vw;
	left: 3vw;
	width: 8vw;
	min-width: 50px;
	max-width: 140px;
}

.wir-sind-die-guten {
	position: absolute;
	z-index: 999;
	bottom: 0;
	right: 3vw;
	width: 8vw;
	min-width: 120px;
}

p {
	margin: 0;
}

p.for-input {
	margin: 15px 0 0 0;
}

.email-input {
	display: inline-block;
	padding-left: 4px;
	max-width: calc(100% - 4px);
}

strong {
	font-weight: 600;
}

.stylish-small {
	font-family: mono45-headline, monospace;
	font-size: 18px;
	line-height: 1.2;
	margin-top: 15px;
}

.stylish {
	font-family: mono45-headline, monospace;
	font-size: 26px;
	line-height: 1.2;
}

.standard-small {
	font-family:"HelveticaNeue", sans-serif;
	font-size: 18px;
	line-height: 1.2;
}

.red {
	color: #de2930;
}

.merry-xmas {
	font-size: 36px;
}

.p-top-m {
	padding-top: 2vw;
}

.m-top-25 {
	margin-top: 25px;
}

.nowrap {
	white-space: nowrap;
}

.centered-div {
	display: inline-block;
	position: relative;
	left: 50%;
	transform: translateX(-50%);
}

.signature {
	width: 200px;
}

.redbox {
	position: relative;
	background: #dc271e;
	border: 6px solid #fff;
}

.redbox img {
	opacity: 0;
}

.redbox p {
	position: absolute;
	top: 10%;
	left: 10%;
	font-family: mono45-headline, monospace;
	font-weight: 500;
	font-size: 7vw;
	line-height: 1;
	color: #fff;
}

@media (min-width: 768px) {
	.redbox p {
		font-size: 3vw;
	}
}

@media (min-width: 1600px) {
	.redbox p {
		font-size: 48px;
	}
}

.item {
	margin-bottom: 24px;
}

.select-overlay {
	position: absolute;
	z-index: 999999;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background: rgba(255,255,255,.9);
	background: rgb(255,255,255);
	background: -moz-radial-gradient(center, ellipse cover,  rgba(255,255,255,1) 38%, rgba(234,234,234,1) 100%);
	background: -webkit-radial-gradient(center, ellipse cover,  rgba(255,255,255,1) 38%,rgba(234,234,234,1) 100%);
	background: radial-gradient(ellipse at center,  rgba(255,255,255,1) 38%,rgba(234,234,234,1) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#eaeaea',GradientType=1 );
	cursor: pointer;
	opacity: 0;
	transition: opacity .35s ease-in-out;
}

.select-overlay:hover {
	opacity: 1;
}

.scale.selected .select-overlay:hover {
	opacity: 0;
}

p.select-it {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-family: mono45-headline, monospace;
	font-weight: 500;
	font-size: 24px;
	line-height: 1;
	text-align: center;
	color: #dc271e;
}

.wrapper {
	position: relative;
}

.content-wrapper {
	background: #fff;
	margin-top: -6vw;
	border-radius: 35px;
	-webkit-box-shadow: 5px 5px 17px 5px rgba(0,0,0,0.24);
	box-shadow: 5px 5px 17px 5px rgba(0,0,0,0.24);
}

.master-content {
	padding: 100px 3vw 170px;
}

.bottom-image {
	position: relative;
	z-index: 999;
	top: -20vw;
	margin-bottom: -15vw;
}

@media (min-width: 1100px) {
	.content-wrapper {
		margin-top: -95px;
	}

	.master-content {
		padding: 100px 50px 260px 50px;
	}

	.bottom-image {
		top: -240px;
		margin-bottom: -180px;
	}
}

.btn {
	position: relative;
	z-index: 999999;
	font-family: mono45-headline, monospace;
	font-size: 20px;
	line-height: 1.5;
	margin-top: 25px;
	background: #fff;
	border: 1px solid #de2930;
}

.btn.btn-info {
	margin-top: 0;
	background: #fff;
	border: 2px solid #de2930;
	color: #de2930;
	transition: all .35s ease-in-out;
	padding: 4px 16px 3px;
	vertical-align: top;
}

.btn.btn-info:hover {
	background: #de2930;
	border: 2px solid #de2930;
	color: #fff;
}

.btn.btn-onred {
	margin-top: 0;
	background: transparent;
	border: 2px solid #fff;
	color: #fff;
	transition: all .35s ease-in-out;
}

.btn.btn-onred:hover {
	background: #fff;
	border: 2px solid #fff;
	color: #de2930;
}

input#user-ID,
input#user-mail {
	border: 2px solid #de2930;
	font-family: mono45-headline, monospace;
	font-size: 22px;
	text-align: center;
	color: #de2930;
	letter-spacing: 4px;
	width: 140px;
}

input#user-mail {
	font-size: 20px;
	text-align: left;
	color: #de2930;
	letter-spacing: 1px;
	padding: 4px 12px 3px;
	margin-bottom: 15px;
	width: 300px;
	max-width: 100%;
}

@media (min-width: 996px) {
	input#user-mail {
		width: 335px;
	}
}

input#user-ID:focus,
input#user-mail:focus {
	outline: none;
}

label.user-ID {
	position: relative;
}

button#do-order {
	width: 300px;
	max-width: 100%;
}

@media (min-width: 400px) {
	button#do-order {
	}
}

@media (min-width: 642px) {
	button#do-order {
		width: 240px;
		margin-left: 25px;
	}
}

.email-text {
	display: inline-block;
	margin: 0 15px 15px 0;
}

.error-message {
	background: #de2930;
	margin-top: 35px;
	padding: 15px;
}

.error-message p {
	color: #fff;
	font-family: mono45-headline, monospace;
	font-size: 22px;

}

/*label.user-ID:before {
	position: absolute;
	content: '';
	bottom: -5px;
	left: 0;
	width: 2px;
	height: 15px;
	background: #de2930;
}

label.user-ID:after {
	position: absolute;
	content: '';
	bottom: -5px;
	right: 0;
	width: 2px;
	height: 15px;
	background: #de2930;
}*/

.result {
	display: none;
}

.scale {
	position: relative;
	z-index: 99999;
	transition: all .35s ease-in-out;
	overflow: hidden;
	border: 3px solid #fff;
}

.scale img {
	transition: all .35s ease-in-out;
	cursor: pointer;
	border: 3px solid #fff;
}

.scale.selected {
	border: 3px solid #dc271e;
}

.scale.selected img {
	border: 3px solid #dc271e;
}

/*.scale img:hover {
	transform: scale(1.1);
}*/

.hohoho {
	position: relative;
	z-index: 999;
	max-width: 1600px;
	margin: -90px auto 0;
	background: url(../img/hohohoho-line.png);
	background-size: cover;
	margin-left: -45%;
	margin-right: -45%;
	transition: all .35s ease-in-out;
}

.hohoho img {
	opacity: 0;
}

.hohoho .upwords {
	position: absolute;
	top: 42%;
	left: 49%;
	transform: translate(-50%, -0%);
	width: 40%;
}

.hohoho .upwords.wrong-code {
	top: 42%;
	left: 50%;
	width: 44%;
}

.hohoho .upwords.already-code {
	top: 44%;
	left: 50%;
	width: 44%;
}

.upwords h1 {
	font-family: mono45-headline, monospace;
	font-weight: 500;
	font-style: normal;
	font-size: 7vw;
	line-height: 1.2;
	transform: skew(0deg, -16deg);
	text-align: center;
	margin: 0;
	color: #fff;
}

.upwords h1 .small-gap {
	font-size: 4px;
}

.upwords h1.user-name {
	margin: 25px 0 0 0;
}

.upwords h1.wrong-code,
.upwords h1.already-code {
	margin: 10px 0 0 0;
}

.form-wrapper {
	position: absolute;
	top: 55%;
	left: 50%;
	transform: translate(-50%, -0%) skew(0deg, -16deg);
}

@media (min-width: 400px) {
	.upwords h1 {
		font-size: 6vw;
	}

	p.select-it {
		font-size: 24px;
	}
}

@media (min-width: 600px) {
	p.select-it {
		font-size: 30px;
	}

	.upwords h1 .small-gap {
		font-size: 8px;
	}
}

@media (min-width: 800px) {
	.hohoho {
		margin-left: -30%;
		margin-right: -30%;
	}

	.upwords h1 {
		font-size: 5.5vw;
	}

	.form-wrapper {
		top: 60%;
	}
}

@media (min-width: 1000px) {
	.hohoho {
		margin-left: -20%;
		margin-right: -20%;
	}

	.upwords h1 {
		font-size: 5vw;
	}

	.upwords h1 .small-gap {
		font-size: 12px;
	}
}

@media (min-width: 1150px) {
	.hohoho {
		margin-left: -15%;
		margin-right: -15%;
	}

	.upwords h1 {
		font-size: 5vw;
	}
}

@media (min-width: 1250px) {
	.hohoho {
		margin-left: -10%;
		margin-right: -10%;
	}

	.upwords h1 {
		font-size: 56px;
	}

	p.select-it {
		font-size: 36px;
	}
}

@media (min-width: 1350px) {
	.hohoho {
		margin-left: -5%;
		margin-right: -5%;
	}
}

@media (min-width: 1450px) {
	.hohoho {
		margin-left: -2%;
		margin-right: -2%;
	}

	.upwords h1 {
		margin-top: 25px;
	}
}

@media (min-width: 1550px) {
	.hohoho {
		margin-left: auto;
		margin-right: auto;
	}
}

@media (min-width: 1600px) {
	.hohoho {
		margin-left: auto;
		margin-right: auto;
	}

	.upwords h1 {

	}
}


/*Radio*/
	/* The label-container */
	.label-container {
		display: none;
		position: relative;
		padding-left: 35px;
		margin-bottom: 12px;
		cursor: pointer;
		font-size: 22px;
		-webkit-user-select: none;
		-moz-user-select: none;
		-ms-user-select: none;
		user-select: none;
	}

	/* Hide the browser's default radio button */
	.label-container input {
		position: absolute;
		opacity: 0;
		cursor: pointer;
	}

	.label-container input ~ .checkmark {
		transition: all .35s ease-in-out;
	}

	/* Create a custom radio button */
	.checkmark {
		position: absolute;
		top: 5px;
		left: 50%;
		transform: translateX(-50%);
		height: 25px;
		width: 25px;
		background-color: #efefef;
		border: 1px solid #555;
		border-radius: 50%;
		margin-top: 5px;
	}

	/* On mouse-over, add a grey background color */
	.label-container:hover input ~ .checkmark {
		background-color: #ddd;
		border: 1px solid #de2930;
	}

	/* When the radio button is checked, add a blue background */
	.label-container input:checked ~ .checkmark {
		background-color: #de2930;
		border-color: #de2930;
	}

	/* Create the indicator (the dot/circle - hidden when not checked) */
	.checkmark:after {
		content: "";
		position: absolute;
		display: none;
	}

	/* Show the indicator (dot/circle) when checked */
	.label-container input:checked ~ .checkmark:after {
		display: block;
	}

	/* Style the indicator (dot/circle) */
	.label-container .checkmark:after {
	 	top: 6px;
	 	left: 6px;
	 	width: 11px;
	 	height: 11px;
		border-radius: 50%;
		background: white;
	}

/* Arrows */

	.chevron-wrapper {
		display: -webkit-box;
		display: flex;
		-webkit-box-pack: center;
		justify-content: center;
		-webkit-box-align: center;
		align-items: center;
		width: 100%;
		height: 50px;
		transition: all .35s ease-in-out;
		transform: translateY(-30%);
	}

	.chevron-wrapper.unvisible {
		opacity: 0;
	}

	.chevron {
	  position: absolute;
	  width: 1.5rem;
	  height: 0.34rem;
	  opacity: 0;
	  -webkit-transform: scale(0.3);
	          transform: scale(0.3);
	  -webkit-animation: move-chevron 3s ease-out infinite;
	          animation: move-chevron 3s ease-out infinite;
	}

	@media (min-width: 1000px) {
		.chevron {
			width: 2.1rem;
			height: 0.48rem;
		}
	}

	.chevron:first-child {
	  -webkit-animation: move-chevron 3s ease-out 1s infinite;
	          animation: move-chevron 3s ease-out 1s infinite;
	}

	.chevron:nth-child(2) {
	  -webkit-animation: move-chevron 3s ease-out 2s infinite;
	          animation: move-chevron 3s ease-out 2s infinite;
	}

	.chevron:before,
	.chevron:after {
	  content: '';
	  position: absolute;
	  top: 0;
	  height: 100%;
	  width: 50%;
	  background: #ffffff;
	}

	.chevron:before {
	  left: 0;
	  -webkit-transform: skewY(30deg);
	          transform: skewY(30deg);
	}

	.chevron:after {
	  right: 0;
	  width: 50%;
	  -webkit-transform: skewY(-30deg);
	          transform: skewY(-30deg);
	}

	@-webkit-keyframes move-chevron {
	  25% {
	    opacity: 1;
	  }
	  33.3% {
	    opacity: 1;
	    -webkit-transform: translateY(2.28rem);
	            transform: translateY(2.28rem);
	  }
	  66.6% {
	    opacity: 1;
	    -webkit-transform: translateY(3.12rem);
	            transform: translateY(3.12rem);
	  }
	  100% {
	    opacity: 0;
	    -webkit-transform: translateY(4.8rem) scale(0.5);
	            transform: translateY(4.8rem) scale(0.5);
	  }
	}

	@keyframes move-chevron {
	  25% {
	    opacity: 1;
	  }
	  33.3% {
	    opacity: 1;
	    -webkit-transform: translateY(2.28rem);
	            transform: translateY(2.28rem);
	  }
	  66.6% {
	    opacity: 1;
	    -webkit-transform: translateY(3.12rem);
	            transform: translateY(3.12rem);
	  }
	  100% {
	    opacity: 0;
	    -webkit-transform: translateY(4.8rem) scale(0.5);
	            transform: translateY(4.8rem) scale(0.5);
	  }
	}


