@charset "UTF-8";
/* CSS Document */

body {
	margin:0;
	padding:0;
	font-size:16px;
	font-family:Segoe, "Segoe UI", "DejaVu Sans", "Trebuchet MS", Verdana, "sans-serif";
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	scroll-behavior:smooth;
	background-color:#eee;
	animation-name:seite;
	animation-duration:2s;
}
@keyframes seite {
	from {opacity:0}
	to {}
}

a,
a:link,
a:visited,
a:hover,
a:focus {
	text-decoration:none;
	outline:none;
	transition:all 0.2s;
	border-bottom:1px solid #516FA3;
	color:#000;
}

a:hover {
	color:#4d6389;
}

.mainframe {
	width:100%;
	max-width:1260px;
	margin:auto;
	height:auto;
}

.mainframe.header {
	width:100%;
	max-width:1260px;
	margin:auto;
	height:auto;
	padding:0 5%;
	box-sizing:border-box;
}

.clearer {
	clear:both;
}

h1 {
	font-size:3.5rem;
	color:#4d6389;
	font-family:"Helvetica Neue", Helvetica, Arial, "sans-serif";
	margin-top:0;
}

h2 {
	font-size:2.2rem;
	color:#444;
	font-family:"Helvetica Neue", Helvetica, Arial, "sans-serif";
	margin-top:-20px;
	margin-bottom:30px;
}

h3 {
	font-size:2.2rem;
	color:#4d6389;
	font-family:"Helvetica Neue", Helvetica, Arial, "sans-serif";
	margin-top:0;
}

h3::after {
	content:'';
	position:absolute;
	width:70px;
	height:5px;
	border-bottom:2px solid #4d6389;
	display:block;
	padding-top:5px;
}

.logo {
	width:170px;
	float:left;
}

.logo img {
	width:100%;
	height:auto;
}

header {
	position:fixed;
	background-color:#fff;
	box-shadow:0px 20px 40px rgba(0,0,0,0.1);
	width:100%;
	padding: 15px 0;
	box-sizing:border-box;
	z-index:2;
	box-shadow:0px 20px 40px rgba(0,0,0,0.2);
}

.close-btn {
	float:right;
	font-size:3rem;
	font-family:"Helvetica Neue", Helvetica, Arial, "sans-serif";
	font-weight:300;
	margin-top:-7px;
	padding:0 20px;
	margin-right:-20px;
}

section {
	background-color:#fff;
	padding:50px 5% 50px 5%;
	width:100%;
	max-width:1260px;
	margin:auto;
	box-sizing:border-box;
}

.banner {
	width:100%;
	max-width:1260px;
	height:400px;
	overflow:hidden;
	margin:auto;
	padding-top:70px;
}

.banner img {
	width:100%;
	height:auto;
	margin-top:-150px;
}

.banner img.top {
	width:100%;
	height:auto;
	margin-top:0;
}
.impressum {
	margin-right:15px;
}

footer {
	width:100%;
	background-color:#ddd;
	max-width:1260px;
	margin:auto;
	padding:20px 5%;
	box-sizing:border-box;
	text-align:right;
}

.datenschutz a {
	border-bottom:0;
}

@media (max-width:1260px) {
	.mainframe {
		padding:0 5%;
		box-sizing:border-box;
	}
	
	.mainframe.header {
		padding:0 5%;
		box-sizing:border-box;
	}
	
	section {
		padding:50px 0 50px 0;
	}
	
	header {
		padding:15px 0;
	}
}

@media (max-width:860px) {
	.banner img {
		margin-top:0;
	}
}

@media (max-width:605px) {
	.banner img.top {
		width:120%;
		margin-top:17px;
		margin-left:-10%;
	}
	
	.banner img {
		width:120%;
		margin-top:0;
		margin-left:-10%;
	}
}

@media (max-width:505px) {
	.banner {
		height:250px;
	}
}

@media (max-width:400px) {
	h3 {
		font-size:1.7rem;
	}
}