/* raleway-regular - latin */
@font-face {
  font-family: 'Raleway';
  font-style: normal;
  font-weight: 400;
  src: url('_fonts/raleway-v27-latin-regular.eot'); /* IE9 Compat Modes */
  src: 
       url('_fonts/raleway-v27-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('_fonts/raleway-v27-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */
       url('_fonts/raleway-v27-latin-regular.woff') format('woff'), /* Modern Browsers */
       url('_fonts/raleway-v27-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */
       url('_fonts/raleway-v27-latin-regular.svg#Raleway') format('svg'); /* Legacy iOS */
}

/* raleway-600 - latin */
@font-face {
  font-family: 'Raleway';
  font-style: normal;
  font-weight: 600;
  src: url('_fonts/raleway-v27-latin-600.eot'); /* IE9 Compat Modes */
  src: url('_fonts/raleway-v27-latin-600.eot'); /* IE9 Compat Modes */
  src: 
       url('_fonts/raleway-v27-latin-600.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('_fonts/raleway-v27-latin-600.woff2') format('woff2'), /* Super Modern Browsers */
       url('_fonts/raleway-v27-latin-600.woff') format('woff'), /* Modern Browsers */
       url('_fonts/raleway-v27-latin-600.ttf') format('truetype'), /* Safari, Android, iOS */
       url('_fonts/raleway-v27-latin-600.svg#Raleway') format('svg'); /* Legacy iOS */
}




* {
	margin:0;
	padding:0;
}
img { border:0;border-style: none;}
html, body {
	margin:0;
	padding:0;
	height:100%;
	font-family: 'Raleway', sans-serif;
	text-decoration: none;

	color:#000000;
	font-size: 18px;
	line-height:26px;
	font-weight:400;
	letter-spacing:0px;
}
body {
	background-color:#ffffff;
	background-repeat:no-repeat;
	background-size:cover;
	background-image: url(gfx/verlauf_hg.jpg?v=1);
	background-position:50% 50%;
	background-attachment: fixed;
}
@media all and (max-width:450px) {
	html, body {
		font-size: 14px;
		line-height:20px;
	}
}
#container {
	min-height:100%;
	position:relative;
}


.hor_details {
	position:relative;
	margin:0 auto;
	max-width:1100px;

	clear:left;
	max-height:50000px;
}

.hor {
	position:relative;
	margin-left:3%;
	margin-right:3%;
}
.hor2 {
	position:relative;
	margin-left:30px;
	margin-right:80px;
}
@media all and (max-width:490px) {
	.hor2 {
		margin-left:20px;
		margin-right:20px;
	}
}
/* -------------------------------------------------- */
.fotobreit {
	width:100%;
	height:auto;
	border-radius:8px;
	overflow:hidden;
}
/* -------------------------------------------------- */
#log {
	position:fixed;
	left:0px;
	bottom:0px;

	text-decoration: none;
	font-size: 12px;
	color: #ffffff;
	background-color:#000000;
	line-height:14px;
	padding:0px;
	padding-left:4px;
	padding-right:4px;
	z-index:40040;
}
.ku {
	white-space:nowrap;
}
.fett {
	font-weight:600;
}
/* -------------------------------------------------- */
#abstand_unten {
	position:relative;
	height:400px;
}
#unten {
	position:absolute;

	width:100%;
	bottom:0px;
	overflow:hidden;

	padding-top:20px;
	padding-bottom:20px;
	color:#071c7e;
		
	background-repeat:repeat-x;
	background-size:100% 2px;
	background-position:0px 0%;
	background-image: url(gfx/verlauf4.png);
	
	font-weight:400;
	font-size:36px;
	line-height:42px;
	text-align:right;
}
#unten1 {
	position:absolute;
	left:0px;
	bottom:6px;
	font-size:14px;
	line-height:16px;
}
#unten1 a {
		color:#000000;
		text-decoration:none;
}
@media all and (max-width:640px) {
	#unten {
		font-size:26px;
		line-height:29px;	
	}
	#unten1 {
		bottom:4px;
	}
}
@media all and (max-width:470px) {
	#unten {
		font-size:22px;
		line-height:25px;	
	}
	#unten1 {
		position:relative;
		bottom:auto;
		left:auto;
		padding-top:12px;
	}
}
/* -------------------------------------------------- */
/* -------------------------------------------------- */
.abstand {
	position:relative;
	height:0px;
	padding-top:0px;
}
/* -------------------------------------------------- */
/* -------------------------------------------------- */
/* -------------------------------------------------- */
#slogan {
	position:fixed;
	right:0px;
	top:0px;
	height:100%;
	background-repeat:no-repeat;
	background-size:100% 100%;
	background-image: url(gfx/verlauf1.png);
	width:0px;
}
#slogan img {
	height:100%;
	width:auto;
}
/* -------------------------------------------------- */
/* -------------------------------------------------- */
.mitte h1,.mitte2 h1,.details h1 {
	font-weight:400;
	font-size:44px;
	line-height:46px;
	color:#071c7e;
	margin-bottom:30px;
	text-transform: uppercase;
	letter-spacing:1px;
	
	padding-bottom:4px;
	background-repeat:repeat-x;
	background-size:100% 2px;
	background-position:0px 100%;
	background-image: url(gfx/verlauf4.png);
}
.mitte h1 img,.mitte2 h1 img,.details h1 img {
	width:40px;
	height:auto;
	position:absolute;
	transform: translateX(6px) translateY(6px);
}
.mitte2 h1 {
	background-image: none;
}
@media all and (max-width:650px) {
	.mitte h1,.mitte2 h1,.details h1 {
		font-size:30px;
		line-height:32px;
	}
	.mitte h1 img,.mitte2 h1 img,.details h1 img {
		width:30px;
		transform: translateX(6px) translateY(4px);
	}
}

@media all and (max-width:490px) {
	.details h1 {
		padding-top:15px;
		padding-bottom:15px;
		font-size:24px;
		line-height:26px;
	}
}
/* -------------------------------------------------- */
.details h2 {
	font-size:18px;
	line-height:22px;
	font-weight:600;
	margin-bottom:10px;
}
/* -------------------------------------------------- */
.team {
	position:relative;
	float:left;
	width:29%;
	margin-right:4%;
}
.team img {
	width:100%;
	height:auto;
	position:absolute;
	border-radius:8px;
	overflow:hidden;
}
.team h2 {
	font-weight:400;
	font-size:25px;
	line-height:26px;
	margin-bottom:10px;
	color:#071c7e;
	margin-top:300px;
}
.team p {
	font-size:14px;
	line-height:18px;	
}
/* -------------------------------------------------- */
.ref {
	position:relative;
	float:left;
	width:29%;
	margin-right:4%;
	cursor:pointer;
}
.ref:hover>img {
	box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.7);
}
.ref img {
	width:100%;
	height:auto;
	position:absolute;
	border-radius:8px;
	overflow:hidden;
}
.ref h2 {
	font-weight:400;
	font-size:18px;
	line-height:21px;
	margin-bottom:10px;
	color:#071c7e;
	margin-top:300px;
}
.ref p {
	position:absolute;
	top:0px;
	font-size:14px;
	line-height:18px;
	font-weight:600;
	color:#ffffff;
	width:100%;
	border-top-left-radius:8px;
	border-top-right-radius:8px;
	padding-top:2px;
	padding-bottom:2px;
	background-repeat:repeat;
	background-image: url(gfx/schwarz60.png);
	letter-spacing:2px;
}
/* -------------------------------------------------- */
.einschub {
	background-repeat:repeat;
	border:1px solid #a0a0a0;
	color:#000000;
	text-align:center;
	padding:30px;
	border-radius:8px;
	padding-top:36px;
	line-height:32px;
	margin-left:12%;
	margin-right:12%;
}
ul {
	 list-style-type: none;
}
li {
	border-bottom:1px dotted #404040;
	padding-top:4px;
	padding-bottom:4px;
}
#leistungen {
	font-size: 24px;
	line-height:45px;
	font-weight:600;
}
@media all and (max-width:1000px) {
	#leistungen {
		font-size: 20px;
		line-height:35px;
	}
}
@media all and (max-width:420px) {
	#leistungen {
		font-size: 17px;
		line-height:26px;
	}
}

.leistungen_norm {
	display:block;
	transform: scale(1.0);
	animation: anim0 60s;
	animation-timing-function: ease-in-out;
	animation-iteration-count: infinite;
}
@keyframes anim0 {
  0% {
	transform: scale(1.0);
  }
  100% {
	transform: scale(1.10001);
  }
}
.leistungen_plus {
	transform: scale(1.0);
	animation: anim1 6s;
	animation-timing-function: ease-in-out;
	animation-iteration-count: infinite;
}
@keyframes anim1 {
  0%, 30% {
	transform: scale(1.0);
  }
  12% {
	transform: scale(1.1);
  }
}


.einschub a {
	text-decoration:none;
	color:#071c7e;
}
.einschub a:hover {
	text-decoration:underline;
}
@media all and (max-width:650px) {
	.einschub {
		margin-left:0%;
		margin-right:0%;
		padding:10px;
		padding-top:26px;
		max-height:10000px;
	}
}
/* -------------------------------------------------- */
/* -------------------------------------------------- */
#logo {
	position:fixed;
	width:25%;
	top:0px;
	left:1%;
	height:auto;
	z-index:40039;
}
#firmendaten {
	position:fixed;
	width:25%;
	top:300px;
	left:5%;
	height:auto;
	z-index:40039;
}
@media all and (max-width:1050px) {
	#firmendaten {
		left:3%;
	}
}
@media all and (max-height:570px) {
	#firmendaten1 {
		display:none;
	}
}
#firmendaten h1 {
	font-size: 18px;
	line-height:26px;
	color:#000000;
}
#firmendaten a {
	text-decoration:none;
	color:#071c7e;
}
#firmendaten a:hover {
	text-decoration:underline;
}
.icon {
		width:25px;
		height:auto;
		padding-top:20px;
		padding-right:10px;
}
.mitte {
	position:relative;
	margin-left:30%;
	max-height:20000px;
}
.mitte2 {
	position:relative;
	margin-left:30%;
	margin-right:3.5%;
	max-height:20000px;
}
.mitte2 a {
	color:#071c7e;
}
.mitte2 a:hover {
	color:#000000;
}
#icons_mobil {
	position:absolute;
	right:20px;
	top:0px;
	display:none;
}
@media all and (max-width:979px) {
	#icons_mobil {
		display:block;
	}
	.mitte {
		margin-left:4%;
	}
	.mitte2 {
		margin-left:4%;
		margin-right:4.9%
	}
	#logo {
		position:relative;
		width:300px;
		left: 50%;
		transform: translateX(-50%);
	}
	#firmendaten {
		display:none;
	}
}
@media all and (max-width:650px) {
	.mitte {
		margin-left:6%;
	}
	.mitte2 {
		margin-left:6%;
		margin-right:6%
	}
	.team {
		margin-right:6%;
		width:44%;
	}
	.ref {
		margin-right:6%;
		width:44%;
	}
}
@media all and (max-width:530px) {
	#icons_mobil {
		right:0px;
	}
	#logo {
		transform: none;
		left:50px;
	}
}
@media all and (max-width:440px) {
	#logo {
		transform: none;
		left:10px;
		width:250px;
	}
}
@media all and (max-width:350px) {
	#logo {
		transform: none;
		left:10px;
		width:220px;
	}
}
@media all and (max-width:400px) {
	.mitte {
		
	}
	.team {
		margin-right:6%;
		width:94%;
	}
	.ref {
		margin-right:6%;
		width:94%;
	}
}
/* -------------------------------------------------- */
#maske {
	position:fixed;
	left:0px;
	top:0px;
	width:100%;
	height:100%;
	z-index:41000;
	background-color:#ffffff;
	background-repeat:repeat;
	display:none;
}
#maske1 {
	position:relative;
	overflow:auto;
	height:100%;
	color:#000000;
}
/* -------------------------------------------------- */
#maske_x {
	position:absolute;
	right:10px;
	top:10px;
	width:80px;
	height:80px;
	background-size:40px 40px;
	background-position: 20px 20px;
	background-image: url(gfx/x_schwarz.png);
	background-repeat:no-repeat;
	cursor:pointer;
}
/* -------------------------------------------------- */
/* -------------------------------------------------- */
/* -------------------------------------------------- */
.vn {
	position:relative;

	background-color:#e0e0e0;
	overflow:hidden;
}
.vn1,.vn2 {
	position:absolute;
	left:0px;
	top:0px;
	width:100%;
	height:100%;
}
.vn1 {
	clip-path: inset(0% 0% 0% 0%);
}
.vn2 {
	clip-path: inset(0% 0% 0% 100%);
}
.vn_schieber {
	position:absolute;
	left:100%;
	top: 50%;
	cursor:col-resize;
	cursor:e-resize;
	width:2.9vw;
	width:5.27vw;
	height:auto;
}
/* -------------------------------------------------- */
/* -------------------------------------------------- */