@charset "UTF-8";

@font-face {
  font-family: 'roboto';
  font-style: normal;
  font-weight: normal;
  src: local(''),
       url('fonts/roboto-regular.woff2') format('woff2'),
       url('fonts/roboto-regular.woff') format('woff')      
}
@font-face {
  font-family: 'roboto';
  font-style: italic;
  font-weight: normal;
  src: local(''),
       url('fonts/roboto-regular-italic.woff2') format('woff2'),
       url('fonts/roboto-regular-italic.woff') format('woff')      
}
@font-face {
  font-family: 'roboto';
  font-style: normal;
  font-weight: bold;
  src: local(''),
       url('fonts/roboto-bold.woff2') format('woff2'),
       url('fonts/roboto-bold.woff') format('woff')      
}
@font-face {
  font-family: 'roboto';
  font-style: italic;
  font-weight: bold;
  src: local(''),
       url('fonts/roboto-bold-italic.woff2') format('woff2'),
       url('fonts/roboto-bold-italic') format('woff')      
}


@font-face {
  font-family: 'antonio';
  font-style: normal;
  font-weight: normal;
  src: local(''),
       url('fonts/antonio-regular.woff2') format('woff2'),
       url('fonts/antonio-regular.woff') format('woff')      
}
@font-face {
  font-family: 'antonio';
  font-style: normal;
  font-weight: bold;
  src: local(''),
       url('fonts/antonio-bold.woff2') format('woff2'),
       url('fonts/antonio-bold.woff') format('woff')      
}


html {
	min-height:100%;
	position:relative;
	-webkit-text-size-adjust: none;
}
body {
	position: relative;
    font-family: "roboto", sans-serif;
	font-size: 16px;
	line-height: 150%;
	font-weight: normal;
	padding: 0;
	margin: 0;
	color: #6f6f6f;
	
}
body#pageBody {
	position: absolute;
	width: 100%;
	min-height: 100%;
    min-width: 375px;
	
}
body.noscroll {
	overflow: hidden;
}
#loader_overlay {
	position: fixed;
	width: 100%;
	height: 100%;
	z-index: 21000;
	background-color: #fff;
}
h1 {
	font-family: "antonio", sans-serif;
	position: relative;
	font-weight: bold;
	font-size: 3em;
	line-height: 140%;
	color: #083047;
	padding: 0.75em 0 0em 0;
	margin: 0 0 0.5em 0;
}

h2 {
	font-family: "antonio", sans-serif;
	font-size: 1.8em;
	line-height: 140%;
	color: #083047;
	font-weight: normal;
	padding: 0;
	margin: 2em 0 1em 0;
}
h3 {
	font-size: 1.2em;
	line-height: 150%;
	font-weight: bold;
	padding: 0 0 0.5em 0;
	margin: 0;
}
h4 {
	font-size: 1em;
	line-height: 150%;
	font-weight: bold;
	padding: 0 0 0.25em 0;
	margin: 0;
}
h1.first,
h2.first,
h3.first,
h4.first {
    margin-top: 0;
    padding-top: 0;
    -moz-hyphens: none;
	-o-hyphens: none;
	-webkit-hyphens: none;
	-ms-hyphens: none;
	hyphens: none;
}
p {
	margin: 0 0 1em 0;
}


.smallfont {
    font-size: 0.86em;
    line-height: 140%;
}
em {
    font-style: italic;
}
ul {
	
}
li {
	
}



a {
	color: #083047;
	text-decoration: none;
}
a:hover {
	color: #083047;
	text-decoration: underline;
}



table {
	border-collapse: collapse;
	margin: 0 0 1em 0;
}
th, td {
	text-align: left;
	vertical-align: top;
	font-weight: normal;
	padding-right: 2em;
}



#content img {
	max-width: 100%;
}

.clear {
	clear: both;
	font-size: 0.1px;
}
.clearfix::after {
    content: "";
    display: block;
    clear: both;
    font-size: 0.1px;
}

.vcenter {
	position: relative;
	display: table;
	width: 100%;
	height: 100%;
	margin: 0;
}
.vcenter .vcenter_inner {
	display: table-cell;
	vertical-align: middle;
}
#pageContainer {
    right: 0px;
    margin: 0;
	padding-top: 0;
    padding-left: 0;
    padding-right: 0;
    position: absolute;
    width: 100%;
	transition: right 0.5s ease 0s;
}
#system_information {
    display: none;
}


body.menu_open #pageContainer {
	right: 280px;
}
body.menu_open #header_minified {
	left: -280px;
}
body.menu_open #nav_mobile {
	right: 0px;
}
body.menu_open a.menu_mobile,
body.menu_open a.menu_mobile:hover {
	background-position: 2px -30px;
}

.segment .segment_inner, #system_information .system_information_inner {
	margin: 0 auto;
	position: relative;
}
@media only screen and (max-width: 1023px) {
	.segment .segment_inner, #system_information .system_information_inner {
		max-width: none;
		padding: 40px 40px;
	}
}
@media only screen and (min-width: 1024px) {
	.segment .segment_inner, #system_information .system_information_inner {
		max-width: 900px;
		padding: 60px 40px;
	}
}
@media only screen and (min-width: 1440px) {
	.segment .segment_inner, #system_information .system_information_inner {
		max-width: 1320px;
		padding: 60px 40px;
	}
}

.header {
	position: relative;
	width: 100%;
    z-index: 100;
	font-size: 1.2em;
	line-height: 140%;
	background-color: #083047;
}
.header .header_inner {
	position: relative;
	padding: 0 40px 10px 40px;
}
.header .header_inner::after {
    content: "";
    display: block;
    clear: both;
    font-size: 0.1px;
}
.header a {
    color: #fff;
	text-decoration: none;
    transition: 0.5s ease;
    transition-property: color;
}
.header a:hover {
    color: #fff;
	text-decoration: none;
}


.header .logo {
	width: 360px; 
	height: auto;
	position: relative;
	margin: 10px 30px 0 0;
	float: left;
}

.header .logo img {
	width: 100%;
	position: relative;
	top: 4px;
}

@media only screen and (max-width: 1440px) {

}
@media only screen and (max-width: 1140px) {

}
.menu_container {
	float: right;
	margin-top: 24px;
}

body.home #header {
	display: none;
}


.socialmedia {
    position: relative;
}
.socialmedia a {
    display: inline-block;
    position: relative;
    width: 30px;
    height: 30px;
    margin: 0 5px;
    border-radius: 50%;
    background-color: #083047;
    color: #fff;
	text-align: left;
    text-indent: -1000px;
    overflow: hidden;
    transition: 0.5s ease;
    transition-property: background-color;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: 90% auto;
}
.socialmedia a:hover {
    background-color: #083047;
}
.socialmedia a.button_facebook {
    background-image: url("../images/socialmedia_facebook.png");
	background-position: center bottom;
    
}
.socialmedia a.button_instagram {
    background-image: url("../images/socialmedia_instagram.png");
}
.socialmedia a.button_twitter {
    background-image: url("../images/socialmedia_twitter.png");
}
.socialmedia a.button_youtube {
    background-image: url("../images/socialmedia_youtube.png");
}



#nav_mobile .socialmedia {
    margin: 2em 0;
    text-align: center;
}
#nav_mobile .socialmedia a {
    
}

.header .mainmenu {
    font-family: "antonio", sans-serif;
	font-weight: normal;
	font-size: 1em;
	line-height: 140%;
	float: right;
	margin-top: 20px;
	margin-right: 30px;
}
.header .mainmenu ul {
    display: inline-block;
	list-style: none;
    margin: 0;
    padding: 0;
    text-align: right;
}
.header .mainmenu li {
	display: inline-block;
	position: relative;
	padding: 0 5px;
}
.header .mainmenu a {
    display: inline-block;
	font-weight: normal;
    padding: 0.2em 0.5em 0.18em 0.5em;
	
}

.header .mainmenu a:hover, .header .mainmenu li.active a {
	
}

.header .mainmenu .only_mobile {
	display: none;
}




.header .menu_mobile, .header .menu_mobile:hover {
	float: right;
    position: relative;
    z-index: 100;
    display: none;
    margin: 0;
	background-size: 88%;
	background-position: 2px 3px;
	width: 36px;
	height: 36px;
	background-image: url(../images/mobile_menu_button.png);
	background-repeat: no-repeat;
    border-radius: 6px;
}
.header .menu_mobile:focus {
    outline: none;
}
.header .menu_mobile span.title {
	position: absolute;
	display: none;
	color: #253C50; /*#253C50;*/
	width: auto;
	right: 36px;
	top: 0px;
	padding: 10px;
    font-weight: bold;
	font-size: 14px;
	line-height: 140%;
}





#header_minified.header {
	position: fixed;
    top: -200px;
	left: 0px;
    z-index: 10000;
    width: 100%;
	-webkit-box-shadow: 2px 2px 5px 0px rgba(0,0,0,0.3);
    -moz-box-shadow: 2px 2px 5px 0px rgba(0,0,0,0.3);
    box-shadow: 2px 2px 5px 0px rgba(0,0,0,0.3);
    transition: 0.5s ease;
    transition-property: top left;
}
#header_minified.header .logo {
	
}

body.header_reduced #header_minified.header {
    top: 0px;
}



/* Header-Anpassungen */
.header .menu_mobile, .header .menu_mobile:hover {
	display: none;
}
@media only screen and (max-width: 1440px) {
	.header .header_inner {
	  padding-bottom: 10px;
	}
	.header .logo {
		width: 220px;
		margin-top: 15px;
	}
	.header .logo img {
		top: 0px;
	}
	.header .mainmenu {
	  	font-size: 0.9em;
	  	line-height: 140%;
		margin-top: 8px;
	}
	
}
@media only screen and (max-width: 1279px) {
	.header .logo {
		margin-right: 0;
	}
	
	.header .mainmenu {
	  	margin-right: 0;
	}
	.menu_container {
		float: right;
	}
	.header .mainmenu li {
	  	padding: 0 3px;
	}
	.header .mainmenu li a {
	  	padding-left: 0.4em;
		padding-right: 0.4em;
	}
}
@media only screen and (max-width: 1023px) {
    
	.header .menu_mobile, .header .menu_mobile:hover {
		display: block;
	}
	.header .mainmenu {
		display: none;
	}
	
	.header .logo {
		
	}

	
	#header_minified.header .logo {
		
		
	}
	#header_minified.header .menu_mobile {
		
	}
}


@media only screen and (max-width: 600px) {
    
    
}




#nav_mobile {
	display: block;
	font-size: 14px;
    line-height: 130%;
	position: fixed;
	top: 0px;
	right: -280px;
	z-index: 10000;
	width: 280px;
	background-color: #3A3A3A;
	padding: 0;
	height: 100%;
	overflow: scroll;
	-webkit-box-shadow: inset 4px 0px 2px 0px rgba(0,0,0,0.25);
	-moz-box-shadow: inset 4px 0px 2px 0px rgba(0,0,0,0.25);
	box-shadow: inset 4px 0px 2px 0px rgba(0,0,0,0.25);
	transition: right 0.5s ease;
}
#nav_mobile .inner {
	padding: 10px;
}
#nav_mobile ul {
	list-style:none;
	margin: 0;
	padding: 0;
}
#nav_mobile ul ul {
	font-size: 0.96em;
}
#nav_mobile li {
	position: relative;
	margin: 0;
	padding: 0;
	
}

#nav_mobile .main ul li {
    
}
#nav_mobile .main a {
	display: block;
	text-decoration: none;
	padding: 0.7em 0.5em;
	color: #fff;
	position: relative;
	border-radius: 4px;
}

#nav_mobile .main li.active a {
	color: #fff;
	font-weight: bold;
}
#nav_mobile .main a:hover, #nav_mobile .main li.active a:hover {
	color: #fff;
	background-color: #083047;
	text-decoration: none;
}


#nav_mobile .main {
    
}
#nav_mobile .add {
    margin-top: 2em;
}

#nav_mobile .add a {
    text-decoration: none;
    color: #fff;
    padding: 0.3em 0.5em;
    display: block;
}
#nav_mobile .add a:hover {
    color: #fff;
	text-decoration: underline;
    
}
#nav_mobile .add li.active a {
    color: #fff;
	text-decoration: underline;
    font-weight: bold;
}
#nav_mobile .add li.active a:hover {
    color: #fff;
	text-decoration: underline;
    font-weight: bold;
}


#content {
	overflow: hidden;
}
	
.segment {
	position: relative;
}
.color2 {
	background-color: #f3f3f3;
}


.segment img {
	display: block;
	
}
.segment a img {
	border: none;
}

.segment_background {
	min-height: 400px;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	background-attachment: fixed;
}
@media only screen and (max-width: 1023px) {
	.segment_background {
		min-height: 400px;
		background-attachment: scroll;
	}
}
@media only screen and (max-width: 680px) {
	.segment_background {
		min-height: 300px;
		background-attachment: scroll;
	}
}


#scrollToTop {
    z-index: 102;
    position: fixed;
    bottom: 0px;
    right: 20px;
	display: block;
    width: 50px;
    height: 40px;
    border-radius: 10px 10px 0 0;
    background: #083047;
    color: #fff;
	-webkit-box-shadow: 3px 3px 15px 0px rgba(0,0,0,0.2);
	-moz-box-shadow: 3px 3px 15px 0px rgba(0,0,0,0.2);
	box-shadow: 3px 3px 15px 0px rgba(0,0,0,0.2);
    border: none;
    cursor: pointer;
    text-indent: -1000px;
    overflow: hidden;
    
}

#scrollToTop::before {
    content: "";
    display: block;
    position: absolute;
    width: 50%;
    height: 0;
    padding-bottom: 50%;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
    margin: auto;
    left: 0;
    right: 0;
    opacity: 0.7;
    transition: 0.5s ease;
    transition-property: opacity;
}
#scrollToTop:hover::before {
    opacity: 1;
}

#scrollToTop::before {
    background-image: url("../images/arrow_up.png");
    top: 0;
    bottom: 2px;   
}


ul.columns2, .text_columns2, .liste_2cols ul {
	column-count: 2;
	column-gap: 40px;
	-moz-column-fill: balance;
    column-fill: balance;
}
ul.columns2 li, .liste_2cols ul li {
	-webkit-column-break-inside: avoid;
    page-break-inside: avoid;
    break-inside: avoid;
}

ul.columns3, .text_columns3 {
	column-count: 3;
	column-gap: 20px;
	-moz-column-fill: balance;
    column-fill: balance;
}
ul.columns3 li {
	-webkit-column-break-inside: avoid;
    page-break-inside: avoid;
    break-inside: avoid;
}


div.columns1,
div.columns2,
div.columns3,
div.columns4 {
	position: relative;
	margin: 0 -2%;
}


div.columns1 .column1,
div.columns2 .column1,
div.columns2 .column2,
div.columns3 .column1,
div.columns3 .column2,
div.columns3 .column3,
div.columns4 .column1,
div.columns4 .column2,
div.columns4 .column3,
div.columns4 .column4 {
	float: left;
	position: relative;
	margin: 0 2% 2% 2%;
}

div.columns1 .column1 {
	width: 96%;
}

div.columns2 .column1,
div.columns2 .column2 {
	width: 46%;
	
}

div.columns2.smaller_right .column1 {
	width: 60%;
	margin-right: 0;
}
div.columns2.smaller_right .column2 {
	width: 30%;
	float: right;
	margin-left: 0;
}

div.columns2.smaller_left .column1 {
	width: 30%;
	margin-right: 0;
}
div.columns2.smaller_left .column2 {
	width: 60%;
	float: right;
	margin-left: 0;
}

div.columns3 {
	
}
div.columns3 .column1,
div.columns3 .column2,
div.columns3 .column3 {
	width: 29.333%;
}

div.columns4 {
	
}
div.columns4 .column1,
div.columns4 .column2,
div.columns4 .column3,
div.columns4 .column4 {
	width: 21%;
}


div.columns2.smaller_right div.columns2 .column1,
div.columns2.smaller_right div.columns2 .column2,
div.columns2.smaller_left div.columns2 .column1,
div.columns2.smaller_left div.columns2 .column2 {
	width: 46%;
}


div.columns1 ul {
	column-count: 2;
	column-gap: 40px;
	-moz-column-fill: balance;
    column-fill: balance;
}
div.columns1 ul li {
	-webkit-column-break-inside: avoid;
    page-break-inside: avoid;
    break-inside: avoid;
}


.divtable {
    display: table;
}
.divtable .divrow {
    display: table-row;
}
.divtable .divcell {
    display: table-cell;
    padding-right: 1em;
}
.divtable .divth {
    font-weight: bold;
    padding-right: 1em;
}

.textbild-links {
	position: relative;
	display: block;
	float: left;
	margin: 0 2em 2em 0 !important;
	width: 30%;
}
.textbild-rechts {
	position: relative;
	display: block;
	float: right;
	margin: 0 0 2em 2em !important;
	width: 30%;
}
.textbild-links .bild,
.textbild-rechts .bild {
	position: relative;
}
.textbild-links .bild a,
.textbild-rechts .bild a {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
}
.textbild-links p,
.textbild-rechts p {
	padding-top: 0.5em;
	font-size: 0.92em;
	line-height: 130%;
	font-style: italic;
}
img.textbild-links,
.textbild-links img,
img.textbild-rechts,
.textbild-rechts img{
	border-radius: 4px;
	overflow: hidden;
}


.footer {
	position: relative;
    font-size: 0.9em;
    line-height: 140%;
}
.footer .inner {
	
	
}
.footer .logo {
	width: 80%;
}
.footer a {
	
}
.footer a:hover {
	
}
.footer .copyright {
    display: block;
	text-align: center;
	margin: 1em 0;
}
.footer .footermenu {
    text-align: center;
	display: block;
	margin-top: 2em;
}
.footer .footermenu a {
    
}
.footer .socialmedia {
    margin-top: 1em;
}
.spezialinfo {
	position: relative;
	text-align: center;
	margin: 0;
}
.spezialinfo .spezialinfo_inner {
	display: block;
	background-color: #eeece8;
	padding: 0.75em 1.5em;
	border-radius: 4px;
}
.spezialinfo p {
	display: inline;
	margin: 0 !important;
}
.spezialinfo a, .spezialinfo a:hover {
	color: inherit;
}



#start {
	position: relative;
	background-image: url("../images/content/willkommen.jpg");
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: cover;
	width: 100%;
	height: 0;
	padding-bottom: 40%;
}
#start .logo_home {
	width: 900px;
	position: absolute;
	left: 0;
	right: 0;
	top: -120px;
	margin: auto;
}
@media only screen and (max-width: 1023px) {
	#start {
		padding-bottom: 60%;
	}
	#start .logo_home {
		width: 800px;
		top: -60px;
	}
}
@media only screen and (min-width: 1800px) {
	#start .logo_home {
		width: 1200px;
		top: -160px;
	}
	#start {
		padding-bottom: 35%;
	}
}
#intro {
	
}
#intro .intro_text {
	width: 80%;
	margin: 0 auto;
	text-align: center;
}
#intro .intro_text h1 {
	
}
#intro .intro_text h1 span {
	display: block;
	font-size: 0.8em;
	line-height: 140%;
}
#intro .intro_text p {
	font-size: 1.3em;
	line-height: 140%;
}
@media only screen and (max-width: 1023px) {
	#intro .intro_text {
		width: auto;
		margin: 0;
	}
}
@media only screen and (max-width: 540px) {
	#intro .intro_text h1 span {
		margin-top: 10px;
	}
}

.leistungen {
	position: relative;
	margin: 0 -1%;
}
.leistungen .leistung {
	position: relative;
	width: 31.333%;
	margin: 1%;
	float: left;
}

.leistungen .leistung .leistung_inner {
	text-align: center;
}
.leistungen .leistung .leistung_text {
	padding-bottom: 2em;
}
.leistungen .leistung .leistung_symbol {
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
	width: 50%;
	height: 0;
	padding-bottom: 50%;
	position: relative;
	margin: 0 auto 1em auto;
}
.leistungen .leistung h2 {
	margin-top: 0;	
}

@media only screen and (max-width: 1023px) {
	.leistungen .leistung {
		width: 48%;
		margin: 1%;
	}
}
@media only screen and (max-width: 640px) {
	.leistungen .leistung {
		width: auto;
		float: none;
		margin: 0 0 2 0;
	}
}


#kontakt {
	text-align: center;
}

.kontakt_daten {
	position: relative;
	width: 80%;
	margin: 0 auto;
}
.kontakt_daten .kontakt_element {
	float: left;
	box-sizing: border-box;
	width: 46%;
	margin: 0 2%;
	padding: 20px;
	text-align: center;
	font-family: "antonio", sans-serif;
	border: 1px solid #083047;
	border-radius: 10px;
}
.kontakt_daten .kontakt_element a {
	display: block;
	font-size: 2em;
	font-weight: bold;
	font-family: "antonio", sans-serif;
	line-height: 130%;
}

@media only screen and (max-width: 1023px) {
	.kontakt_daten .kontakt_element {
		float: none;
		width: auto;
		margin: 0 0 2em 0;
	}
}