@charset "utf-8";

@font-face {
	font-display: swap;
	font-family: 'Noto Sans';
	font-style: normal;
	font-weight: 400;
	src: url('../fonts/noto-sans-v39-latin-regular.eot');
	src: url('../fonts/noto-sans-v39-latin-regular.eot?#iefix') format('embedded-opentype'), url('../fonts/noto-sans-v39-latin-regular.woff2') format('woff2'), url('../fonts/noto-sans-v39-latin-regular.woff') format('woff'), url('../fonts/noto-sans-v39-latin-regular.ttf') format('truetype'), url('../fonts/noto-sans-v39-latin-regular.svg#NotoSans') format('svg');
}

@font-face {
	font-display: swap;
	font-family: 'Noto Sans';
	font-style: normal;
	font-weight: 600;
	src: url('../fonts/noto-sans-v39-latin-600.eot');
	src: url('../fonts/noto-sans-v39-latin-600.eot?#iefix') format('embedded-opentype'), url('../fonts/noto-sans-v39-latin-600.woff2') format('woff2'), url('../fonts/noto-sans-v39-latin-600.woff') format('woff'), url('../fonts/noto-sans-v39-latin-600.ttf') format('truetype'), url('../fonts/noto-sans-v39-latin-600.svg#NotoSans') format('svg');
}

@font-face {
	font-display: swap;
	font-family: 'Noto Sans';
	font-style: normal;
	font-weight: 700;
	src: url('../fonts/noto-sans-v39-latin-700.eot');
	src: url('../fonts/noto-sans-v39-latin-700.eot?#iefix') format('embedded-opentype'), url('../fonts/noto-sans-v39-latin-700.woff2') format('woff2'), url('../fonts/noto-sans-v39-latin-700.woff') format('woff'), url('../fonts/noto-sans-v39-latin-700.ttf') format('truetype'), url('../fonts/noto-sans-v39-latin-700.svg#NotoSans') format('svg');
}

:root {
	font-size: 16px;
}

* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body {
	color: #333;
	font-family: "Noto Sans", "Arial", sans-serif;
	font-size: .937rem;
	line-height: 1.4;
	font-weight: 400;
	background: linear-gradient(180deg, rgba(239, 239, 239, 0.3) 300px, rgba(239, 239, 239, 1) 800px), url(../images/spiraltreppe.jpg) no-repeat top center;
}

img {
	max-width: 100%;
	height: auto;
}

#wrapper {
	position: relative;
	max-width: 50rem;
	margin: 1rem auto;
	overflow: hidden;
	background: transparent;
}

:is(a:link, a:visited, a:hover, a:active) {
	color: inherit;
	text-decoration: none;
	white-space: nowrap;
}

h1 {
	color: #22bbea;
	font-size: 25px;
	line-height: 1.3;
}

h2 {
	padding: 14px 26px 10px 26px;
	background-color: #eee;
	font-size: 18px;
	color: #22bbea;
}

strong {
	font-weight: 600;
}

p {
	margin: 0 0 1.625rem;
}

p,
ul {
	-moz-hyphens: auto;
	-webkit-hyphens: auto;
	-ms-hyphens: auto;
	hyphens: auto;
}

ul {
	list-style: none;
	margin: 0 0 0.625rem;
	padding: 0;
}

ul li {
	margin-left: 17px;
	position: relative;
	margin-bottom: 8px;
}

ul li:before {
	content: " ";
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background-color: #333;
	position: absolute;
	top: 9px;
	left: -17px;
}

header {
	margin-bottom: 10px;
	background-color: #fff;
	border: 1px solid rgb(220 223 226 / 80%);
	border-radius: 5px;
	box-shadow: 0 0 26px rgba(0, 0, 0, .44);
	overflow: hidden;
}

.slider {
	position: relative;
}

.slider img {
	display: block;
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	animation: imageAnimation 18s linear infinite 0s;
}

.slider img:nth-of-type(1) {
	position: static;
	opacity: 1;
}

.slider img:nth-of-type(2) {
	animation-delay: 6s;
}

.slider img:nth-of-type(3) {
	animation-delay: 12s;
}

@keyframes imageAnimation {
	4% {
		opacity: 1;
	}

	33% {
		opacity: 1;
	}

	38% {
		opacity: 0;
	}
}

.section {
	margin-bottom: 10px;
	background-color: #fff;
	border: 1px solid rgb(220 223 226 / 80%);
	border-radius: 5px;
	box-shadow: 0 0 26px rgba(0, 0, 0, .44);
}

.box {
	padding: 12px 26px 26px;
}

a.btn {
	color: #22bbea;
	text-decoration: underline 1px dotted #22bbea;
}

a.btn:hover {
	color: #333;
	text-decoration: underline 1px solid #22bbea;
}

.smallspan {
	font-size: 13px;
}

.smallspan p:nth-of-type(1) {
	margin-bottom: 8px;
}

.smallspan p:last-of-type {
	margin: 0;
}

footer {
   display: flex;
   justify-content: center;
   margin: 2rem 0;
}

a.apply {
    background: #009ee0;
    font-size: 1.1rem;
    text-align: center;
    color: #fff;
    border: solid 0.125rem #009ee0;
    padding: 0.5rem 5rem;
    display: block;
    width: fit-content;
    margin: 2rem auto 1rem;
    border-radius: 5px;
    font-weight: 700;
}

a.apply:hover {
    background: #fff;
    color: #009ee0;
}


@media only screen and (max-width: 49.938rem) {
	#wrapper {
		border: none;
		margin: 0 auto;
		padding: .5rem;
	}

	body {
		background: rgba(239, 239, 239);
	}
}

@media only screen and (max-width: 480px) {

	.box,
	h2 {
		padding: 1rem;
	}

	h1 {
		hyphens: auto;
	}
}