@charset "utf-8";

@font-face { font-display: swap; font-family: 'Lexend'; font-style: normal; font-weight: 200; src: url('../webfonts/lexend-v26-latin-200.woff2') format('woff2'); }
@font-face { font-display: swap; font-family: 'Lexend'; font-style: normal; font-weight: 300; src: url('../webfonts/lexend-v26-latin-300.woff2') format('woff2'); }
@font-face { font-display: swap; font-family: 'Lexend'; font-style: normal; font-weight: 400; src: url('../webfonts/lexend-v26-latin-regular.woff2') format('woff2'); }
@font-face { font-display: swap; font-family: 'Lexend'; font-style: normal; font-weight: 500; src: url('../webfonts/lexend-v26-latin-500.woff2') format('woff2'); }

html { 
	margin: 0px;
	min-height: 100%;
}
 
:focus {
	 outline:0; 
	 -moz-outline:0; 
} 

img {
	vertical-align: baseline;
}

span,div {
	zoom: 1;
}			   

input::-webkit-outer-spin-button, 
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type=number] {
  -moz-appearance: textfield;
}

img {
	display: block;
	width: 100%;
}

a {
	zoom: 1;
	color: inherit;
}
	
a img {
	border-width: 0px;
}	   

a:hover  {
	color: inherit;
}

form {
	margin: 0px;
	padding: 0px;
}
	
sup { 
	vertical-align: baseline;
	position: relative;
	top: -0.5em;
	font-size: 70%;
}

ul {
	padding-left: 1.5em;
}

body {	 
	position: relative;
	margin: 0;
	padding: 0px;
	-webkit-text-size-adjust: none;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-family: "Lexend",sans-serif;
	font-size: 1.1vw;
	line-height: 1.25;
	background-color: white;
	color: black;
	height: 100%;
	overflow-x: hidden;
}	 

strong, b, h1, h2, h3 { font-weight: 500; }
h1 p, h2 p, h3 p { margin: 0; }

.button {
	position: relative;
	background-color: black;
	color: white !important;
	font-size: 1vw;
	text-decoration: none;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	border: none;
	-webkit-appearance: none;
	height: 2.6vw;
	padding-left: 2vw;
	padding-right: 2vw;
	border-radius: 1.3vw;
	cursor: pointer;

}

.button.white { background-color: white; color: black !important; }
.button.grey { background-color: #4d4d4d; box-shadow: inset 0.07vw 0.07vw 0.04vw rgba(255,255,255,0.4); }

.button.grey::after {
	content: " ";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	border-radius: 1.3vw;
    box-shadow: inset -0.07vw -0.07vw 0.04vw rgba(255,255,255,0.1);
}

.button:hover { background-color: #4d4d4d; }
.button.grey:hover { background-color: #6d6d6d; }
.button.white:hover { background-color: #cdcdcd; }

h2, .textpage h1 {
	font-size: 2.75vw;
	line-height: 1.1;
	margin-top: 0;
	margin-bottom: 0.7em;
}

h3 {
	font-size: 1.6vw;
	line-height: 1.1;
	margin-top: 0;
	margin-bottom: 0.7em;
}

.image {
	border-radius: 1.6vw; 
	overflow: hidden;
	font-size: 0;
}

.anchor {
    display: block;
    position: relative;
    top: -5vw;
    visibility: hidden;
}

hr {
	border: none;
	border-bottom: 1px solid black;
	margin-top: 2vw;
	margin-bottom: 2vw;
}

.show-on-mobile { display: none !important; }	

/**** HEADER ****/

.header {
	position: fixed;
	z-index: 99;
	left: 4.5vw;
	top: 1vw;
	background-color: black;
	color: white;
	width: 90vw;
	height: 3.8vw;
	border-radius: 1.9vw;
}

.header .logo {
	display: inline-block;
	width: 8.8vw;
	position: absolute;
	left: 1.6vw;
	top: 1.4vw;
}	

.header .mainmenu {
	font-size: 0;
	position: absolute;
	left: 20vw;
	top: 1.3vw;
	width: 50vw;
	margin: 0px;
	padding: 0px;
	list-style-type: none;
	/* background-color: darkgray; */
}

.header .mainmenu .entry {
	display: inline-block;
	width: 25%;
	text-align: center;
	font-size: 1vw;
}

.header .mainmenu .entry a { text-decoration: none; }
.header .mainmenu .entry a:hover { text-decoration: underline; }

.header .kontakt {
	position: absolute;
	right: 0.6vw;
	top: 0.6vw;
}

/**** MAIN ****/

.main {
	position: relative;
}

/**** HERO ****/

.hero {
	position: relative;
}

.hero .text {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
}

.hero .text h1 {
	padding-top: 2vw;
	text-align: center;
	color: white;
	font-weight: 200;
	font-size: 4.2vw;
	text-shadow: 0px 0px 8vw black;
}

.hero .text h1 p { margin: 0; }


/**** INTRO ****/

.intro {
	background-color: black;
	color: white;
	padding: 11vw 61vw 8vw 5vw;
	min-height: 30vw;
	background-image: url(../img/bg-intro.webp);
	background-size: 64vw;
	background-repeat: no-repeat;
	background-position: top right;
}

.intro h2 { 
	font-weight: 200; 
	line-height: 1.05; 
}

/**** TECHNOLOGIE ****/

.technologie {
	position: relative;
	padding: 8vw 4.5vw 8vw 55.5vw;
	min-height: 44vw;
	display: flex;
	justify-content: center;
	align-items: center;
}

.technologie .button { margin-top: 0.8vw; }

.technologie .image {
	position: absolute;
	left: 4.6vw;
	top: 8vw;
	width: 44vw;
}

.ziel {
	padding-left: 15vw;
	padding-right: 15vw;
	padding-bottom: 8vw;
	font-size: 3.5vw;
	font-weight: 200;
	text-align: center;
}

.ziel p { margin: 0; }

.ziel h2 {
	text-align: center;
	font-size: 1.6vw;
}

/**** PRODUKT ****/

.produkt {
	background-color: black;
	color: white;
	padding: 7.5vw 5vw 5vw 5vw;
	overflow: hidden;
}

.produkt .text {
	position: relative;
	padding-left: 58vw;
	margin-bottom: 3vw;
}

.produkt h2 { 
	font-weight: 200; 
	line-height: 1.05; 
	position: absolute;
	left: 0;
	top: -0.1em;
}

.produkt .schritte {
	background-image: url(../img/bg-produkt.webp);
	background-size: cover;
	border-radius: 1.6vw; 
	padding: 4vw 1vw 4.5vw 5vw;
	font-size: 0;
	margin-bottom: 1.5vw;
}

.produkt .schritte .col {
	box-sizing: border-box;
	display: inline-block;
	vertical-align: top;
	width: 33.333%;
	padding-right: 4vw;
	font-size: 1.1vw;
}	

.produkt .bilder {
	position: relative;
	font-size: 0;
}

.produkt .img-1 {
	display: inline-block;
	vertical-align: top;
	width: calc(59.35% - 1.5vw);
	margin-right: 1.5vw;
}

.produkt .img-2 {
	display: inline-block;
	vertical-align: top;
	width: calc(40.65%);
}

.produkt .material {
	position: absolute;
	top: -6vw;
	left: 46vw; 
	width: 11.8vw;
	display: none;
}

.produkt .material.m1 { display: block; }
.produkt .material.m2 { margin-left: 13.2vw; }
.produkt .material.m3 { margin-left: -13.2vw; }
.produkt .material.m4 { margin-left: 26.4vw; }
.produkt .material.m5 { margin-left: -26.4vw; }
.produkt .material.m6 { margin-left: -39.8vw; }
.produkt .material.m7 { margin-left: -53.2vw; }

/**** PERSONAL ****/

.personal {
	position: relative;
	background-color: black;
	color: white;
	height: 42.5vw;
	background-image: url(../img/bg-personal.webp);
	background-size: cover;
}

.personal .text {
	position: absolute;
	left: 5vw;
	bottom: 8vw;
	width: 40vw;
}

.personal h2 { 
	font-weight: 200; 
	line-height: 1.05; 
}

/**** FAQ ****/

.faq {
	position: relative;
	padding: 6.5vw 5vw 5vw 35vw;
}

.faq h2 {
	position: absolute;
	left: 5vw;
	top: 6.5vw;
	margin-top: -0.1em;
}

.faq-frage {
	font-size: 1.5vw;
	padding-right: 28vw;
	background-image: url(../img/faq-plus.svg);
	background-size: 1.8vw;
	background-repeat: no-repeat;
	background-position: center right;
	cursor: pointer;
}

.faq-frage.expanded { background-image: url(../img/faq-minus.svg); }

.faq-antwort {
	display: none;
	padding-right: 11vw;
}

.faq-antwort p:last-child { margin-bottom: 0; }

/**** CTA ****/

.cta {
	position: relative;
	background-color: black;
	color: white;
	padding: 7vw 12vw 2vw 12vw;
	text-align: center;
}

.cta h2 { 
	font-size: 3.5vw;
	font-weight: 200; 
}

.cta .button { 
	font-size: 1.1vw; 
	height: 2.8vw;
	border-radius: 1.4vw;
}

.cta hr { 
	border-bottom: 1px solid #A2A2A2; 
	margin-top: 8vw;
}

/**** FOOTER ****/

.footer {
	position: relative;
	background-color: black;
	color: white;
	padding: 6vw 5vw 11vw 5vw;
	min-height: 25vw;
}

.footer .kontaktformular {
	padding-left: 50vw;
	font-size: 1vw;
	font-weight: 300;
	color: #A2A2A2;
}

.footer .kontaktformular h2 {
	font-weight: 200;
	font-size: 2.1vw;
	color: white;
	margin-bottom: 2vw;
}

.footer .kontaktformular .form-fields {
	font-size: 0;
	margin-right: -1vw;
}

.footer .kontaktformular input[type=text] {
	box-sizing: border-box;
	-webkit-appearance: none;
	border: none;
	color: white;
	border-bottom: 1px solid #A2A2A2;
	background-color: transparent;
	font-family: "Lexend",sans-serif;
	font-size: 1.1vw;
	font-weight: 300;
	padding: 0.5em 0;
	width: calc(50% - 2.5vw);
	margin-right: 2.5vw;
	margin-bottom: 1.5vw;
}

.footer .kontaktformular input[type=text]::placeholder { color: #808080; }

.footer .kontaktformular .legal {
	margin-top: 1vw;
	margin-bottom: 1.8vw;
	font-size: 1vw;
}	

.footer .kontaktformular .legal label {
	display: block;
	position: relative;
	padding-left: 2.2em;
	padding-top: 0.15em;
	margin-bottom: 1.7em;
}

.footer .kontaktformular .legal label input[type=checkbox] {
	position: absolute;
	left: 0;
	top: 0;
}

.footer .kontaktformular .message {
	font-size: 1.5vw; 
	font-weight: 500;
	color: white;
	margin-bottom: 1.2em;
}

.footer .mainfooter {
	position: absolute;
	left: 5vw;
	top: 6.5vw;
	font-weight: 200;
}

.footer .mainfooter .logo {
	width: 22vw;
	/* margin-bottom: 4.5vw; */
	margin-bottom: 6.5vw;
}

.footer .mainfooter .footermenu { margin-top: 3em; line-height: 2; }
.footer .mainfooter .footermenu a { text-decoration: none; }
.footer .mainfooter .footermenu a:hover { text-decoration: underline; }

/**** TEXTPAGE ****/

.textpage {
	padding: 11vw 30vw 8vw 5vw;
}

.intro h2 { 
	font-weight: 200; 
	line-height: 1.05; 
}

/**** SMALL SCREENS ****/

@media only screen and (max-width: 800px) {	
	body { font-size: 16px; }
	h2, .textpage h1 { font-size: 28px; }
	h3 { font-size: 20px; }
	hr { margin-top: 15px; margin-bottom: 15px; }
	.hide-on-mobile { display: none !important; }
	.show-on-mobile { display: block !important; }	
	.button { height: 26px; border-radius: 13px; padding-left: 20px; padding-right: 20px; font-size: 14px; }
	.header { left: 10px; top: 10px; width: calc(100% - 20px); height: 36px; border-radius: 18px; }
	.header .logo { width: 100px; left: 15px; top: 12px; }
	.header .mainmenu { display: none; }
	.header .kontakt { right: 5px; top: 5px; }
	.hero .text h1 { font-size: 6.7vw; padding-top: 30px; }
	.intro { padding: 40px 20px 70vw 20px; background-position: bottom right; background-size: contain; }
	.intro p { max-width: 420px; }
	.technologie { display: block; padding: 40px 20px 40px 20px; min-height: 0px; }
	.technologie p { max-width: 420px; }
	.technologie .image { position: relative; left: auto; top: auto; width: auto; margin-top: 40px; }
	.ziel { padding: 0px 20px 40px 20px; font-size: 30px; }
	.ziel h2 { font-size: 18px; }
	.produkt { padding: 40px 20px 40px 20px;  }
	.produkt .text { padding-left: 0; margin-bottom: 25px; }
	.produkt h2 { position: relative; top: 0; }
	.produkt p { max-width: 420px; }
	.produkt .schritte { padding: 30px 20px 10px 20px; margin-bottom: 12px; }
	.produkt .schritte .col { display: block; width: auto; padding-right: 0; font-size: 16px; margin-bottom: 25px; }
	.produkt .schritte .col p { max-width: 500px; }
	.produkt .img-1 { width: auto; margin-right: 0; margin-bottom: 12px; }
	.produkt .img-2 { width: auto; }
	.produkt .material { left: 57vw; top: calc(41.7% - 8vw); width: 24vw; }
	.produkt .material.m2 { margin-left: 26vw; }
	.produkt .material.m3 { margin-left: -26vw; }
	.produkt .material.m4 { margin-left: 52vw; }
	.produkt .material.m5 { margin-left: -52vw; }
	.produkt .material.m6 { margin-left: -78vw; }
	.produkt .material.m7 { margin-left: -104vw; }
	.personal { height: auto; background-image: url(../img/bg-personal-mobile.webp); background-position: center top; background-size: contain; background-repeat: no-repeat;}
	.personal .text { position: relative; left: auto; bottom: auto; width: auto; max-width: 420px; padding: 170px 20px 30px 20px; }
	.faq { padding: 30px 20px 40px 20px; }
	.faq h2 { position: relative; left: auto; top: auto; margin-top: 0; }
	.faq-frage { font-size: 18px; padding-right: 50px; background-size: 15px; }
	.faq-antwort { padding-right: 20px; max-width: 600px; }
	.cta { padding: 40px 20px 20px 20px; }
	.cta h2 { font-size: 30px; }
	.cta .button { font-size: 16px; height: 28px; border-radius: 14px; }
	.cta hr { margin-top: 40px; }
	.footer { padding: 20px 20px 80px 20px; }
	.footer .kontaktformular { padding-left: 0; margin-bottom: 80px; }
	.footer .kontaktformular h2 { font-size: 22px; margin-bottom: 20px; }
	.footer .kontaktformular .form-fields { margin-right: -2vw; }
	.footer .kontaktformular input[type=text] { font-size: 14px; margin-bottom: 15px; }
	.footer .kontaktformular .legal { font-size: 13px; margin-top: 11px; margin-bottom: 18px; }
	.footer .kontaktformular .message { font-size: 16px; }
	.footer .mainfooter { position: relative; left: auto; top: auto; text-align: center;}
	.footer .mainfooter .logo { width: 180px; margin: auto; margin-bottom: 40px; }
	.textpage { padding: 100px 20px 70vw 20px; }
}

@media only screen and (max-width: 420px) {	
	.footer .kontaktformular .form-fields { margin-right: 0; }
	.footer .kontaktformular input[type=text] { width: 100%; }
}

@media only screen and (max-width: 360px) {	
	h2 { font-size: 24px; }
}