﻿html, body, div, p, h1, h2, h3, span, a, table, td, form, input, textarea, select	
						{ margin: 0px; padding: 0px; font-family: 'Montserrat', sans-serif; font-size: 17px; line-height: 1.45em; font-weight: 400; color: #5A6063; }



h1						{ font-size: 38px; line-height: 1.05em; color: #9B2B29; font-weight: 600; margin: 10px 0px 25px 0px; text-transform: normal;}
body.folgeseite h1		{ font-size: 32px; line-height: 1.0em; color: #9B2B29; font-weight: 600;  text-transform: normal;}
h2						{ font-size: 26px; line-height: 1.05em; color: #5A6063; font-weight: 600; margin: 12px 0px 28px 0px; text-transform: normal; }
h2.sub					{ font-size: 24px; line-height: 1.05em; color: #9B2B29; font-weight: 600; margin: -18px 0px 15px 0px; text-transform: normal;}
h3						{ font-size: 22px; line-height: 1.1em; color: #5A6063; font-weight: 700; margin: 20px 0px 12px 0px; text-transform: normal;}
h4						{ font-size: 19px; line-height: 1.1em; color: #5A6063; font-weight: 500; margin: 18px 0px 10px 0px; text-transform: normal; }
h5						{ font-size: 18px; line-height: 1.1em; color: #5A6063; font-weight: 500; margin: 12px 0px 8px 0px; text-transform: normal; }

@media only screen and (min-width: 995px) {    
    h1						{ font-size: 48px; margin: 15px 0px 35px 0px; }
    body.folgeseite h1		{ font-size: 46px; }
    h2						{ font-size: 40px; margin: 20px 0px 35px 0px; }
    h2.sub					{ font-size: 34px; margin: -30px 0px 30px 0px; }
    h3						{ font-size: 32px; margin: 20px 0px 10px 0px; }
	h4						{ font-size: 22px; margin: 20px 0px 15px 0px; }
}


hr 						{ background-color: none; border: 0; height: 1px; border-bottom: 1px solid rgba(0,0,0,0.15); }		

.centered				{ text-align: center; }						  


body 					{ width: 100%; height: 100%; background-color: #fff; }

img						{ vertical-align: middle; outline: none; }
a 						{ outline: none; }
div, input, select, textarea, a		{ box-sizing: border-box; }

input, textarea, select	{ border-radius: 0; }
input[type=text], textarea	{ -webkit-appearance: none; } /* verhindert den Schatten-Effekt auf iOS-Geräten und im Safari*/

.clear					{ display: block; clear: both; }
.rounded				{ -moz-border-radius: 10px; border-radius: 10px; -webkit-border-radius: 10px; }
.shadow			        { -moz-box-shadow: 0px 0px 10px rgba(0,0,0,0.4); -webkit-box-shadow: 0px 0px 10px rgba(0,0,0,0.4); box-shadow: 0px 0px 10px rgba(0,0,0,0.4); } 

.opacity_25				{ opacity: 0.25; filter(opacity=0.25); }

.strtoupper				{ text-transform: uppercase; }
.lowercase				{ text-transform: none; }

strong 	                { font-weight: 600; }

.red                     { color: #9B2B29; }

.align_left				{ display: inline; float: left; }
.align_right			{ display: inline; float: right; }


/* Icons */
i 						{ color: inherit; }

/* ---- Links ---- */
a, a:link,	a:active, a:visited	{ text-decoration: none; color: #9B2B29; font-size: inherit; font-weight: 600; transition: all 0.40s ease-in-out 0.1s; }
a:hover						{ text-decoration: none; color: #e40500; font-size: inherit;  }

a.bn						{ padding: 10px 18px; background-color: #bbb; color: #fff; cursor: pointer; }
a.bn_small					{ padding: 7px 12px; font-size: 14px; }
a.bn_bg_ci					{ background-color: #9B2B29; color: #fff; font-size: 18px; font-weight: 700; padding: 12px 20px; text-align: center; text-transform: none; transition: all 0.35s ease-in-out 0s; }
a.bn_bg_ci:hover			{ background-color: #ba2c2a; text-decoration: none; }
	a.bn_bg_ci i.fa				{ color: #fff; margin-right: 8px;}
a.bn_border_ci				{ background-color: transparent; border: 1px solid #fff; color: #fff; transition: all 0.35s ease-in-out 0s;}
a.bn_border_ci:hover			{ background-color: transparent; border: 1px solid #fff; text-decoration: none; }
	a.bn_border_ci i.fa				{ color: red; margin-right: 8px; }
a.bn_border 				{ display: inline-block; border: 1px solid #d4d4d5; text-transform: uppercase; background-color: #fff; color: #58595b; padding: 8px 16px; text-align: center; box-sizing: border-box; transition: all 0.35s ease-in-out 0s; z-index: 10; }
	a.bn_border:hover 		{ border: 1px solid #58595b; color: #252525; text-decoration: none; }
		a.bn_border i 			{ color: inherit; font-size: 40px; line-height: 26px; font-weight: 100; }

a.bn_border_weiss 			{ display: inline-block; padding: 8px 30px; color: #fff; text-align: center; border: 1px solid rgba(255,255,255,1); }
a.bn_border_weiss:hover			{ background-color: rgba(255,255,255,0.7); }


/* ---- Tabellen, Formulare ---- */
table.width100 				{ width: 100%; margin: 20px 0px; }
table.widthmax 				{ width: 100%; max-width: 320px; margin: 20px 0px; }
th							{ font-weight: 900; text-align: left; }
td							{ font-weight: 400; text-align: left; }
table.border_ci				{ margin: 20px 0px; padding: 0px; border-spacing: 0; border-collapse: collapse; }
	table.border_ci	tr			{ background-color: #eaf1f7; }
	table.border_ci	tr:nth-child(odd)	{ background-color: #f3f8fa;  }
		table.border_ci	th			{ font-weight: 500; color: #000; padding: 10px 20px; }
		table.border_ci	td			{ font-weight: 200; color: #000; padding: 10px 20px; }


input.disabled				{ border: 1px solid #eee; background-color: #fefefe; color: #bbb; font-style: italic; }
.form-validation.alert-danger { margin-bottom: 20px; }
.form-validation.alert-success { margin: 20px 0px; padding: 10px 20px; color: #3FAB3A !important; background-color: rgba(217,249,217,1.00); }


/* --------------- Allgemeine Klassen für DIV-Aufbau ------------- */
.container				{ position: relative; align: center; width: 600px; height: auto; margin: 0px auto; padding: 0px 15px; margin-left: auto; margin-right: auto; box-sizing: border-box; background-color: transparent; }

.container-full			{ position: relative; align: center; width: 100%; height: auto; margin: 0px auto; padding: 0px 15px; margin-left: auto; margin-right: auto; box-sizing: border-box; background-color: transparent; }

.content-center		    { text-align: center; }
.content-right			{ text-align: right; }
.zentriert				{ align: center; margin: 0px auto; padding-top: 40px; width: 600px; height: auto; min-height: 400px; }

.section 				{ position: relative; color: inherit; padding: 30px 0; }

.section-std-padding	{ padding: 30px 0px; }
.section-big-padding	{ padding: 60px 0px; }

.first-section			{ padding-top: 180px; }

.a_sprung 				{ position: absolute; margin-top: -140px; width: 100%; /*height: 2px; border-top: 1px solid red;*/ }


/* Viertel-Box */
.content-col4-1			{ position: relative; display: inline-block; float: left; margin: 0px; width: 24%; margin-right: 0.6665%; margin-left: 0.6665%; height: auto; box-sizing: border-box; padding: 20px 20px; background-color: transparent; }
/* Drittel-Box */
.content-col3-1			{ position: relative; display: inline-block; float: left; margin: 0px; width: 32%; margin-right: 1%; margin-left: 1%; height: auto; box-sizing: border-box; padding: 20px 20px; background-color: transparent; }
/* Zwei-Drittel-Box */
.content-col3-2			{ position: relative; float: left; margin: 0px; width: 66%; margin-right: 1%; margin-left: 1%; height: auto; box-sizing: border-box; padding: 20px 20px; background-color: transparent; }
/* Halb-Box */
.content-col2-1			{ position: relative; float: left; margin: 0px; width: 48%; margin-right: 1%; margin-left: 1%; height: auto; box-sizing: border-box; padding: 20px 0px; background-color: transparent; }
/* Full-Row */
.content-full-row		{ position: relative; display: block; clear: both; width: 100%; height: auto; margin: 35px 0px; }
	.content-full-row img	{ position: relative; width: 100%; height: auto; }

.two-text-columns		{ -moz-column-count: 2; -webkit-column-count: 2; column-count: 2; -moz-column-gap: 4rem; -webkit-column-gap: 4rem; column-gap: 4rem; }
	@media only screen and (max-width: 780px) { 
		.two-text-columns		{ -moz-column-count: 1; -webkit-column-count: 1; column-count: 1; }
			.two-text-columns div { margin-bottom: 25px; }
	}

/* Box mit Bild links und Text rechts */
.box-img-text			{ position: relative; display: block; clear: both; width: 100%; height: auto; margin: 55px 0px; background-color: #fff; }
	.box-img-text .align_left	{ position: absolute; width: 40%; height: 100%; max-height: 360px; background-repeat: no-repeat; background-size: cover; background-position: center center; height: 100%; overflow: hidden; }	
	.box-img-text .align_right	{ width: 60%; height: auto; min-height: 280px; padding: 0px 60px; box-sizing: border-box; }
	@media only screen and (max-width: 1199px) { 
		.box-img-text .align_right	{ padding: 0px 50px; }
	}
	@media only screen and (max-width: 995px) { 
		.box-img-text .align_left	{ position: relative; display: block; clear: both; width: 100%; height: auto; min-height: 380px; }
		.box-img-text .align_right	{ display: block; clear: both; width: 100%; height: auto; min-height: auto; padding: 0px 40px; }
			.box-img-text .align_right h3	{ font-size: 21px; }
	}
	@media only screen and (max-width: 780px) { 
		.box-img-text .align_left	{ position: relative; display: block; clear: both; width: 100%; height: auto; min-height: 280px; }
		.box-img-text .align_right	{ display: block; clear: both; width: 100%; height: auto; min-height: auto; padding: 30px 25px; }
			.box-img-text .align_right h3	{ font-size: 20px; }
	}

	@media only screen and (min-width: 1200px) { 
		.box-img-text .align_right h2	{ margin-top: 0px; }
	}

/* Margins für Boxen in Zeilen */
.row 					{ width: 100%; height: auto; display: inline-block; padding: 0px; margin: 0px; box-sizing: border-box; }
	.row div.content-col4-1:first-child 	{ margin-left: 0; }
	.row div.content-col3-1:first-child 	{ margin-left: 0; }
	.row div.content-col3-2:first-child 	{ margin-left: 0; }
	.row div.content-col2-1:first-child 	{ margin-left: 0; }
	.row div.content-col4-1:last-child 		{ margin-right: 0; }
	.row div.content-col3-1:last-child 		{ margin-right: 0; }
	.row div.content-col3-2:last-child 		{ margin-right: 0; }
	.row div.content-col2-1:last-child 		{ margin-right: 0; }
	
	.row:after { content: ""; display: table; clear: both; float: none; width: 100%; height: 0px; }
	


/* Datensätze mit einzelnen Elementen (mehrspaltig und -zeilig dargestellt) */
.overview               { width: 100%; height: auto; margin: 20px auto; font-size: 0px;  }
    .element                { display: block; width: 100%; height: auto; padding: 20px 20px; margin: 0px; }

@media only screen and (min-width: 460px) {
    .element                { display: inline-block; width: 50%; min-height: 80px; }
}      
@media only screen and (min-width: 995px) {
    .element                { width: 33.33%; min-height: 90px; }
}
@media only screen and (min-width: 1200px) {
    .element                { width: 25%; min-height: 100px; }
}

				  
/* --------- Boxmodell ------- */
#head						{ position: absolute; margin: 0px; width: 100%; height: auto; padding: 0px 0px; box-sizing: border-box; background-color: transparent; z-index: 800; }
	
	#top_bar 					{ display: block; clear: both; height: 80px; padding: 28px 0px 5px 0px; width: 100%; background-color: #fff; text-align: right; color: #5A6063; }
		#top_bar a					{ color: #9B2B29; font-size: 17px; font-weight: 200; margin-left: 18px; }
		#top_bar a:hover			{ color: #e40500; }
			#top_bar a span 			{ color: inherit; }
			#top_bar a i.fa				{ font-size: 19px; margin-right: 4px; margin-top: -3px; vertical-align: middle; color: #9A9A9A; }
		#top_bar .align_left  			{ background-color: #fff; }
        #top_bar .align_left.on_index  			{ padding: 0px 20px 10px 20px; }
			#top_bar .align_left a 			{ margin-left: 0px; }
				#top_bar .align_left .head-logo 			{ margin-top: -22px; height: 70px; width: auto; }
		
	#nav_bar					{ position: relative; display: block; clear: both; width: 100%; height: 145px; padding: 0px; box-sizing: border-box; background-color: transparent;  /*transition: all 0.5s ease-in-out 0.5s;*/ }
		#nav_bar .container				{ z-index: 400; }
			#logo						{ display: inline-block; float: none; box-sizing: content-box; margin-top: -7px; padding: 0px 0px 10px 0px; transition: all 0.15s ease-in-out 0.15s; }
				#logo img					{ width: 100%; height: auto; vertical-align: middle; }
	
	#navigation					{ /* wird in den MediaQuerys definiert */ }
		#navigation ul li a			{ text-transform: none; }
	
	#toggle_mobile_navigation	{ display: block; float: right; padding: 0px; margin: 0px; font-size: 21px; margin-top: 0px; cursor: pointer; padding: 10px; transition: all 0.25s ease-in-out 0s; }
		#toggle_mobile_navigation  i	{ font-size: 38px; color: #fff; }
	    #toggle_mobile_navigation .menu { cursor: pointer; margin: 0 auto; padding-left: 1.25em; position: relative; width: 30px; height: 30px; }
            #toggle_mobile_navigation .menu-global { backface-visibility: hidden; position: absolute; left: 0; border-top: 4px solid #4b4b4b; width: 100%; transition: 0.45s; -moz-border-radius: 2px; border-radius: 2px; -webkit-border-radius: 2px;  }
            #toggle_mobile_navigation .menu-top { top: 0; }
            #toggle_mobile_navigation .menu-middle { top: 10px; }
            #toggle_mobile_navigation .menu-bottom { top: 20px; }
            #toggle_mobile_navigation .menu-top-click { backface-visibility: hidden; top: 12px; transform: rotate(50deg); transition: 0.45s 0.5s; }
            #toggle_mobile_navigation .menu-middle-click { opacity: 0; }
            #toggle_mobile_navigation .menu-bottom-click { backface-visibility: hidden; top: 12px; transform: rotate(-410deg); transition: 0.45s 0.5s; }
    
	@media only screen and (max-width: 998px) { 
		#head						{ height: auto; }
		#toggle_mobile_navigation	{ position: absolute; top: 8px; right: 8px; z-index: 9999;  }
			#toggle_mobile_navigation.active i	{ color: #ddd; }
		#navigation					{ position: fixed; display: none; overflow: auto; width: 100%; height: 100%; left: 0px; top: 126px; margin: 0px; right: 0; box-sizing: border-box; padding: 30px 0px 40px 0px; background-color: transparent; z-index: 890; -webkit-box-shadow: inset 0px 2px 1px 0px rgba(0,0,0,0.27); -moz-box-shadow: inset 0px 2px 1px 0px rgba(0,0,0,0.27); box-shadow: inset 0px 2px 1px 0px rgba(0,0,0,0.27); }
		#top_bar 					{ display: block; height: 50px; padding: 10px 6px 8px 0px; background-color: #fff; }
			#top_bar a					{ font-size: 13px; margin-top: 3px; }
		      #top_bar a i.fa				{ font-size: 23px; color: #9B2B29; }
			#top_bar .align_left .head-logo 	{ margin-top: -4px; height: 42px; width: auto; }
		#schnellkontakt 			{ display: none; }
		#nav_bar					{ display: block; clear: both; height: 100px; padding: 8px 0px; z-index: 970; }
			#logo						{ width: 136px; height: 80px; padding: 0px; margin: 0px 0px 0px 0px; z-index: 999; }
				#logo img						{ }
			#navigation > ul				{ display: block; clear: both; width: 100%; height: 100%; margin: 0px; padding: 0px; z-index: 900;  }
				#navigation > ul > li			{ display: block; clear: both; float: none; width: 100%; height: auto; margin: 2px 0px; padding: 1px 0px; box-sizing: border-box; border-bottom: 1px solid rgba(0,0,0,0.1); }
					#navigation ul li a 		{ display: block; float: none; text-align: center;  color: #fff; width: 100%; height: auto; padding: 15px 20px 10px 20px; box-sizing: border-box; text-transform: uppercase; font-size: 19px; line-height: 19px; font-weight: 400; }
					#navigation ul li a:hover	{ text-decoration: none; color: #fff; }
					#navigation > ul > li.active > a	{ color: var(--color-ci1); }
					#navigation > ul > li > ul > li.active > a	{ color: var(--color-ci1); }
				#navigation > ul > li > ul			{ display: block; clear: both; width: 100%; height: auto; margin: 0px; padding: 0px; }
		/* ---- Sticky-Darstellungen ---- */
		#head.sticky				{ position: fixed; height: 90px; padding: 0px 0px; top: 0; box-shadow: 0 0 5px 0 rgba(0,0,0,0.4); background-color: transparent; opacity: 1; transition-duration: 0.1s, 0.1s, 0.1s, 0.2s; transition-property: width, height, background-color, transform; transition-timing-function: ease, ease, ease, ease; }
			#head.sticky #top_bar	{ display: none; }
			#head.sticky #nav_bar		{ }
				#head.sticky #nav_bar #logo 		{ width: 128px; height: auto; }
					#head.sticky #nav_bar #logo img		{ height: auto; padding: 0; }
				#head.sticky #nav_bar .container	{ padding-top: 0px; }		
				#head.sticky #toggle_mobile_navigation	{ margin-top: 0px; }
				#head.sticky #navigation	{ top: 86px; padding-top: 80px; padding: 0px; }
	}
	@media only screen and (min-width: 999px) { 
		#head						{ }
		#toggle_mobile_navigation	{ display: none; }
		#top_bar 					{ display: block; }
        #logo						{ width: 240px; height: 113px; margin-top: -20px;  }
        #top_bar .align_left.on_index .head-logo { margin-top: -15px; height: 130px; width: auto; }
        
        #navigation					{ display: inline-block !important; float: right; width: auto; height: 100px; box-sizing: border-box; margin: 20px 0px 0px 0px; padding: 0px; text-align: right; z-index: 900; }
			#navigation ul				{ display: block; clear: both; float: right; width: 100%; height: 100%; margin: 0px auto 0px auto; align: center; padding: 0px; }
				#navigation ul li				{ display: inline-block; float: none; width: auto; height: 100%; margin: 0px 0px; padding: 0px 0px 0px 0px; }
					#navigation > ul > li > a			{ display: inline-block; float: none; width: auto; height: 100%; font-size: 18px; font-weight: 800; text-transform: uppercase; color: #fff; padding: 25px 10px 5px 10px; margin: 0px 0px 0px 15px; box-sizing: border-box; transition: all 0.25s ease-in-out 0s;  }
					#navigation ul li a:hover, #navigation ul li.hover a	{ text-decoration: none; color: rgba(255,255,255,0.6); }
					#navigation ul li.active a	{ color: rgba(255,255,255,0.6);  }						
		            #navigation ul li:last-child a		{ padding-right: 0px; }
			
		/* ---- Sticky-Darstellungen ---- */
		#head.sticky				{ position: fixed; height: 90px; padding: 0px 0px; top: 0; opacity: 1; /* für Coming-Soon-Version: ---->*/ opacity: 0; background-color: rgba(0,0,0,0.8); z-index: 810; transition-duration: 0.1s, 0.1s, 0.1s, 0.2s; transition-property: width, height, background-color, transform; transition-timing-function: ease, ease, ease, ease; }
			#head.sticky #top_bar	{ display: none; }
			#head.sticky #nav_bar		{ height: 120px; padding: 0px 0px; }
				#head.sticky #nav_bar #logo 		{ width: 153px; height: 90px; margin-top: 2px; padding-top: 0px; padding-bottom: 0px; }
					#head.sticky #nav_bar #logo img		{ height: auto; padding: 0; }
            #head.sticky #navigation	{ height: 90px; margin-top: 0px; padding: 0px 0px; }
			#head.sticky #navigation ul li a		{ padding: 35px 10px; color: rgba(255,255,255,0.7); text-shadow: none; }
			#head.sticky #navigation ul li a:hover		{ color: rgba(255,255,255,0.4); }
			#head.sticky #navigation li.active a	{ color: #e2bc56; }
            #head.sticky #navigation ul li:last-child a	{ padding-right: 0px; }
            #head.sticky #toggle_mobile_navigation	{ margin-top: 0px; }
	}



/* ------ Section-Formatierungen ------ */
#section-slideshow				{ position: relative; clear: both; width: 100%; min-height: 400px; height: 60vw; padding-top: 0px; padding-bottom: 0px; box-sizing: border-box; margin-bottom: 0px; background-color: transparent; overflow: hidden; z-index: 500;  }
	#section-slideshow .anim-slider 	{ min-height: 400px; height: 60vw; margin-top: 0px; background-color: transparent; }
	#section-slideshow .anim-slide 		{ opacity: 0; }
	#section-slideshow .anim-slide-this { opacity: 1;}
	#section-slideshow .anim-dots 		{ opacity: 0; bottom: 12px; }
		#section-slideshow .anim-dots span { width: 7px; height: 7px; margin: 1px 3px; background-color: transparent; border: 1px solid #fff; -moz-box-shadow: 0px 0px 3px rgba(0,0,0,0.4); -webkit-box-shadow: 0px 0px 3px rgba(0,0,0,0.4); box-shadow: 0px 0px 3px rgba(0,0,0,0.4); -moz-border-radius: 9px; border-radius: 9px; -webkit-border-radius: 9px; }
		#section-slideshow .anim-dots span.anim-dots-this { background-color: #fff; border: 1px solid #fff; }
		#section-slideshow .anim-dots span.anim-dots-this::after { background: transparent none repeat scroll 0 0; }
		
	#section-slideshow li.anim-slide 	{ background-color: transparent; background-size: cover; background-position: center center; }

        


		#section-slideshow li.anim-slide .slogan_wrapper	{ width: 90%; height: auto; top: 50%; left: 50%; transform: translate(-50%,-50%); padding: 0px; text-align: left; }
            #section-slideshow li.anim-slide .slogan_wrapper h1,
            #section-slideshow li.anim-slide .slogan_wrapper h2,
            #section-slideshow li.anim-slide .slogan_wrapper h3,
            #section-slideshow li.anim-slide .slogan_wrapper a,
            #section-slideshow li.anim-slide .slogan_wrapper i,
            #section-slideshow li.anim-slide .slogan_wrapper br,
            #section-slideshow li.anim-slide .slogan_wrapper span,
            #section-slideshow li.anim-slide .slogan_wrapper p 	{ position: relative; display: block; clear: both; text-align: center; color: #fff; font-size: inherit; line-height: inherit; }
            #section-slideshow li.anim-slide .slogan_wrapper h1 { font-size: 34px; line-height: 1.0em; font-weight: 600; text-shadow: 0px 0px 10px rgba(0,0,0,0.2); width: auto; }
            #section-slideshow li.anim-slide .slogan_wrapper h1 span { font-size: 32px; line-height: 1.0em; font-weight: 300; color: #003c91; text-transform: none; display: inline-block; text-shadow: 0px 0px 9px rgba(255,255,255,0.8);  }
                #section-slideshow li.anim-slide .slogan_wrapper h1 .svg-logo { width: auto; height: auto; max-width: 160px; }
                #section-slideshow li.anim-slide .slogan_wrapper h1 span br { position: relative; display: inline-block; clear: both; text-align: left; }
            #section-slideshow li.anim-slide .slogan_wrapper h2 { font-size: 28px; line-height: 30px; margin-bottom: 5px; text-transform: none; font-weight: 500; text-shadow: none; color: #000;}
            #section-slideshow li.anim-slide .slogan_wrapper h3 { font-size: 28px; color: #9B2B29; }
            #section-slideshow li.anim-slide .slogan_wrapper a 	{ display: inline-block; margin: 0px auto; width: auto; font-size: 20px; color: #fff; margin-top: 10px; margin-bottom: 10px; padding: 0.6em 1.8em; border: 1px solid #fff; -moz-border-radius: 99px; border-radius: 99px; -webkit-border-radius: 99px; transition: all 0.25s ease-in-out 0s; }
            #section-slideshow li.anim-slide .slogan_wrapper p 	{ width: auto; font-size: 20px; margin-top: 10px; margin-bottom: 10px; }
		
		#section-slideshow .anim-arrows-prev { visibility: hidden; top: 50%; transform: translateY(-50%); left: 0 !important; text-align: right; margin-left: -9px; padding: 0px 9px 0px 0px !important; background-color: #fff; z-index: 800; }
		#section-slideshow .anim-arrows-next { visibility: hidden; top: 50%; transform: translateY(-50%); right: 0 !important; text-align: left; margin-right: -9px; padding: 0px 0px 0px 9px !important; background-color: #fff; z-index: 800; }
			#section-slideshow .anim-arrows-prev i, #section-slideshow .anim-arrows-next i  { color: #003c91; width: 20px; height: 24px; vertical-align: middle; font-size: 22px; padding: 3px 0px 0px 0px; font-weight: 100; transition: all 0.25s ease-in-out 0s; }

        /*#section-slideshow::before { content: ""; position: absolute; height: 160px; width: 100%; top: 0px; opacity: 0.25; z-index: 710; background: -moz-linear-gradient(top,  rgba(0,0,0,1) 0%, rgba(0,0,0,1) 2%, rgba(5,5,5,0) 100%); background: -webkit-linear-gradient(top,  rgba(0,0,0,1) 0%,rgba(0,0,0,1) 2%,rgba(5,5,5,0) 100%); background: linear-gradient(to bottom,  rgba(0,0,0,1) 0%,rgba(0,0,0,1) 2%,rgba(5,5,5,0) 100%); filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#000000', endColorstr='#00050505',GradientType=0 ); }
		#section-slideshow::after { content: ""; position: absolute; height: 160px; width: 100%; bottom: 0px; opacity: 0.15; z-index: 710; background: -moz-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0.65) 100%); background: -webkit-linear-gradient(top, rgba(0,0,0,0) 0%,rgba(0,0,0,0.65) 100%); background: linear-gradient(to bottom, rgba(0,0,0,0) 0%,rgba(0,0,0,0.65) 100%); filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00000000', endColorstr='#a6000000',GradientType=0 ); }
        */

@media only screen and (min-width: 995px) { 
    #section-slideshow li.anim-slide .slogan_wrapper	{ margin-left: 5%; top: 50%; }
    #section-slideshow li.anim-slide .slogan_wrapper h1 { font-size: 44px;}
    #section-slideshow li.anim-slide .slogan_wrapper h1 span { font-size: 54px; }
    #section-slideshow li.anim-slide .slogan_wrapper h1 .svg-logo { max-width: 300px; }
    #section-slideshow li.anim-slide .slogan_wrapper h2 { font-size: 42px; margin-bottom: 30px; }
    #section-slideshow li.anim-slide .slogan_wrapper h3 { font-weight: 800; font-size: 43px; }
	#section-slideshow, #section-slideshow .anim-slider { min-height: 600px; height: 56vw; }
    #section-slideshow .anim-dots 		{ bottom: 36px; }
    #section-slideshow .anim-dots span { width: 12px; height: 12px; margin: 2px 6px; }
    #section-slideshow .anim-arrows-prev { margin-left: -12px; padding: 2px 12px 2px 0px !important;  }
    #section-slideshow .anim-arrows-next { margin-right: -12px; padding: 2px 0px 2px 12px !important;  }
    #section-slideshow .anim-arrows-prev i, #section-slideshow .anim-arrows-next i  { width: 30px; height: 36px; font-size: 31px; padding: 4px 0px 0px 0px; }
    #section-slideshow::before { height: 320px; }
		
}
@media only screen and (min-width: 1200px) { 
    #section-slideshow li.anim-slide .slogan_wrapper	{ margin-left: 6%; }
	#section-slideshow, #section-slideshow .anim-slider { min-height: 700px; height: 48vw; }
	#section-slideshow li.anim-slide .slogan_wrapper h1 { font-size: 52px; }
    #section-slideshow li.anim-slide .slogan_wrapper h1 span { font-size: 78px;  }
    #section-slideshow li.anim-slide .slogan_wrapper h2 { font-size: 46px; }
    #section-slideshow li.anim-slide .slogan_wrapper h3 { color: #9B2B29; font-weight: 800; font-size: 48px; }
}


/* ============ speziell für Coming-Soon ===================== */	
#section-slideshow li.anim-slide .slogan_wrapper h1 { display: inline-block; padding: 25px 30px; background-color: transparent; }
	
#section-slideshow, #section-slideshow .anim-slider { min-height: 300px; height: 300px; }
@media only screen and (max-width: 800px) {
    #section-slideshow, #section-slideshow .anim-slider { min-height: 400px; height: 400px; }
}
@media only screen and (max-width: 700px) {
    #section-slideshow, #section-slideshow .anim-slider { min-height: 360px; height: 360px; }
}
@media only screen and (max-width: 540px) {
    #section-slideshow, #section-slideshow .anim-slider { min-height: 330px; height: 330px; }
}
@media only screen and (max-width: 340px) {
    #section-slideshow, #section-slideshow .anim-slider { min-height: 310px; height: 310px; }
}

	#section-slideshow li.anim-slide .slogan_wrapper	{ width: 80%; height: auto; top: 50%; left: 50%; margin-left: auto; transform: translate(-50%,-50%); text-align: center; }
		#section-slideshow li.anim-slide .slogan_wrapper h1 { text-align: center; }
			#section-slideshow li.anim-slide .slogan_wrapper h1 img { position: relative; width: 320px; max-width: 90%; height: auto; text-align: center; }


#section-slideshow li.anim-slide .index_pic         { position: relative; display: block; width: 100%; height: 45vw; max-height: 260px; margin: 0px; background-repeat: no-repeat; background-size: cover; background-position: center center;   }
        #section-slideshow li.anim-slide .index_content     { position: relative; display: block; width: 100%; height: auto; margin: 0px;  }
            #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne     { width: 100%; padding: 20px; }
                #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne *     { position: relative; display: block; font-size: 1.05rem; }
                    #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne h1     { font-size: 1.6rem; color: #9B2B29; }
                    #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne h2     { font-size: 1.0rem; color: #5A6063; margin-top: -5px; }
                    #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne h3     { font-size: 1.2rem; color: #9B2B29; margin-top: 20px; }
                    #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne ul     { margin: 10px 0px; padding: 0px; }
                        #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne ul li    { margin: 5px 0px; font-weight: 600; font-size: 1.0rem; padding-left: 1.7em; }
                        #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne ul li:before {
                          content: "\f00c"; /* FontAwesome Unicode */
                          font-family: FontAwesome;
                          display: inline-block;
                          margin-left: -1.7em; /* same as padding-left set on li */
                          width: 1.5em; /* same as padding-left set on li */
                          color: #9B2B29;
                        }
                    #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne p     { margin-top: 20px; }


@media only screen and (min-width: 995px) { 
	#section-slideshow, #section-slideshow .anim-slider { min-height: 70vh; height: 70vh; }
		#section-slideshow li.anim-slide .slogan_wrapper	{ margin-left: auto; }
			#section-slideshow li.anim-slide .slogan_wrapper h1 img { width: 410px; height: auto; }
    
            #section-slideshow li.anim-slide .index_pic         { display: inline-block; float: left; width: 50%; height: 100%; max-height: none; margin: 0px; }
            #section-slideshow li.anim-slide .index_content     { display: inline-block; float: right; text-align: left; width: 50%; min-height: 580px; height: 70vw; margin: 0px; }
                #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne     { margin-top: 60px; padding: 10px 40px; }
                    #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne *     { font-size: 1.0rem; }
                    #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne h1     { font-size: 1.8rem;  }
                    #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne h2     { font-size: 1.0rem; margin-top: -15px; }
                    #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne h3     { font-size: 1.3rem; margin-top: 20px; }
                    #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne ul     { margin: 20px 0px; }
                        #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne ul li    {  font-size: 1.0rem; margin: 3px 0px; }
}
@media only screen and (min-width: 1200px) { 
	#section-slideshow, #section-slideshow .anim-slider { min-height: 80vh; height: 80vh; }
		#section-slideshow li.anim-slide .slogan_wrapper	{ margin-left: auto; }
    
            #section-slideshow li.anim-slide .index_pic         {  }
            #section-slideshow li.anim-slide .index_content     { }
                #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne     { margin-top: 10vh; padding: 50px 60px; }
                    #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne *     { font-size: 1.15rem; }
                    #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne h1     { font-size: 2.4rem;  }
                    #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne h2     { font-size: 1.25rem; margin-top: -15px; }
                    #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne h3     { font-size: 1.6rem; margin-top: 60px; }
                    #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne ul     { margin: 25px 0px; }
                        #section-slideshow li.anim-slide .index_content .slogan_wrapper_ohne ul li    {  font-size: 1.15rem; margin: 10px 0px; }
            
}



#section-content     { text-align: center; }
#section-content h1     { font-size: 34px; line-height: 1.0em; font-weight: 600; text-shadow: 0px 0px 10px rgba(0,0,0,0.2); width: auto; }
            #section-content h1 span { font-size: 32px; line-height: 1.0em; font-weight: 300; color: #003c91; text-transform: none; display: inline-block; text-shadow: 0px 0px 9px rgba(255,255,255,0.8);  }
                #section-content h1 .svg-logo { width: auto; height: auto; max-width: 160px; }
                #section-content h1 span br { position: relative; display: inline-block; clear: both; text-align: left; }
            #section-content h2 { font-size: 28px; line-height: 30px; margin-bottom: 5px; text-transform: none; font-weight: 500; text-shadow: none; color: #000;}
            #section-content h3 { font-size: 28px; color: #9B2B29; }
            #section-content a 	{ display: inline-block; margin: 0px auto; width: auto; font-size: 20px; color: #fff; margin-top: 10px; margin-bottom: 10px; padding: 0.6em 1.8em; border: 1px solid #fff; -moz-border-radius: 99px; border-radius: 99px; -webkit-border-radius: 99px; transition: all 0.25s ease-in-out 0s; }
            #section-content p 	{ width: auto; font-size: 20px; margin-top: 10px; margin-bottom: 10px; }
            #section-content ul     { margin: 10px 0px; padding: 0px; }
                        #section-content ul li    { margin: 5px 0px; font-weight: 600; font-size: 1.0rem; padding-left: 1.7em; }
                        #section-content ul li:before {
                          content: "\f00c"; /* FontAwesome Unicode */
                          font-family: FontAwesome;
                          display: inline-block;
                          margin-left: -1.7em; /* same as padding-left set on li */
                          width: 1.5em; /* same as padding-left set on li */
                          color: #9B2B29;
                        }
                    #section-content p     { margin-top: 20px; }
		


#section-leistungen {  }
	#section-leistungen .content-col3-1  {  }
		#section-leistungen .content-col3-1 .pic  { display: block; clear: both; width: 100%; height: auto; background-size: cover; background-position: center center; background-repeat: no-repeat; }
		#section-leistungen .content-col3-1 .desc  { display: block; clear: both; width: 100%; height: auto; padding: 12px 15px 8px 25px;  }
		   #section-leistungen .content-col3-1 .desc h3  { margin: 0px; color: #050505; font-family: 'Josefin Sans', sans-serif; font-size: 19px; line-height: 19px; font-weight: 500; text-transform: uppercase; }
	
@media only screen and (min-width: 995px) {
   
}
@media only screen and (min-width: 1200px) {
       
}



	

/* Formatierungen für Folgeseiten */
#abstand_folgeseiten { display: block; clear: both; width: 100%; height: 360px; padding: 0px 0px 0px 0px; background-size: cover; background-position: center center; background-color: #fcea92; }
#abstand_folgeseiten:after { content: ""; position: absolute; width: 100%; height: 14px; margin-top: 346px; background-color: rgba(252,234,146,0.7); }
@media only screen and (max-width: 994px) { 
	#abstand_folgeseiten { height: 200px; }
	#abstand_folgeseiten:after { height: 10px; margin-top: 190px; }
}


#section-intro-folgeseiten			{ position: relative; clear: both; width: 100%; height: 320px; height: 55vw; padding-top: 0px; padding-bottom: 0px; box-sizing: border-box; margin-bottom: 0px; background-image: url('../upload/mediapool/Headbilder/Mobile-Nachhilfe.jpg'); background-position: center center; background-size: cover; background-color: #eee; overflow: hidden; z-index: 700;  }
    #section-intro-folgeseiten .container     {  padding-top: 180px; padding-top: 40vw; }
        #section-intro-folgeseiten	h1           { margin-left: 0px; font-size: 24px; color: #fff; font-weight: 600; }

@media only screen and (min-width: 995px) { 
    #section-intro-folgeseiten			{ height: 420px; }
    #section-intro-folgeseiten .container   {  padding-top: 320px; }
    #section-intro-folgeseiten	h1           { font-size: 50px; }
} 

#section-inhalt		{ margin-top: 0px; margin-bottom: 50px; min-height: 400px; background-color: #fff; }	
			

/* WhatsApp-Button*/
#whatsapp_cta {
  position: fixed;
  float: none;
  width: 190px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  height: 50px;
  right: 0px;
  top: auto;
  bottom: 20px;
  margin: auto;
  z-index: 9999;
  visibility: visible; }

#whatsapp_cta .title {
  display: none; }

#whatsapp_cta .textwidget {
  width: 100%;
  padding: 0px;
  margin: 0px; }

#whatsapp_cta .textwidget a {
  position: relative;
  float: right;
  margin-right: -5px;
  -webkit-transition: all 0.25s ease-in-out 0s;
  transition: all 0.25s ease-in-out 0s;
  padding: 8px 12px 8px 20px;
  font-size: 15px;
  color: #fff;
  background: #a7d13a;
  background: -webkit-gradient(linear, left top, left bottom, from(#111), to(#444));
  background: linear-gradient(to bottom, #111 0%, #444 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#111', endColorstr='#444',GradientType=0 ); }

#whatsapp_cta .textwidget a:hover {
  margin-right: 0px; }

#whatsapp_cta a .wa_icon {
  position: absolute;
  margin-left: -58px;
  margin-top: -14px;
  width: 52px;
  height: 52px;
  line-height: 1.1;
  background-image: url("/images/whatsapp-icon.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover; }

#whatsapp_cta a .wa_title {
  font-size: inherit;
  color: inherit;
  line-height: inherit; }

@media only screen and (max-width: 899px) {
  #whatsapp_cta {
    width: 48px;
    height: 48px;
    bottom: 0px;
    background-color: transparent;
    background-image: url("/images/whatsapp-bg_mobile.png");
    background-size: cover;
    background-position: center center; }
  #whatsapp_cta .textwidget a {
    padding: 0px;
    margin: 0px 2px;
    background-color: transparent; }
  #whatsapp_cta a .wa_icon {
    margin-left: -44px;
    margin-top: 0px;
    width: 40px;
    height: 40px; }
  #whatsapp_cta a .wa_title {
    display: none; } }


					
/* ---- ENDE Section-Formatierungen ---- */
#foot					{ position: relative; width: 100%; min-height: 100px; height: auto; padding: 30px 0px 5px 0px; box-sizing: border-box; font-size: 0.90rem; line-height: 1.5rem; background-color: transparent; color: #5A6063; text-align: center; z-index: 500; }
    #foot .container		{ padding: 0px; }
    #foot .bigger         { font-size: 1.05rem; line-height: 1.5; }
        #foot .bigger strong        { font-size: 1.3rem; display: block; margin-top: 25px; margin-bottm: 15px; color: #9B2B29; }
		#foot div			{ color: inherit; }
		 #foot li a    		  {  }
		 #foot li a:hover     {  }
         #foot li.active a    { color: #e40500; }
         #foot a i.fa         { color: #9A9A9A; }

#foot ul               { margin: 25px auto; padding: 0px; }
    #foot ul li 		{ display: block; clear: both; text-align: center; list-style-type: none; margin-top: 10px; }
        #foot ul li a		{ list-style-type: none; float: none; display: inline-block; }

@media only screen and (min-width: 995px) { 
	#foot				{ padding: 30px 0px 10px 0px; }
        #foot .bigger         { font-size: 1.3rem; }
            #foot .bigger strong        { font-size: 1.35rem; }
		#foot ul.inline@m li		{ display: inline-block; } 
    	#foot ul li 		{ display: inline-block; margin-top: 0px; margin-left: 12px; margin-right: 12px; text-align: left; }
}



#back-top				{ position: fixed; right: 0px; bottom: 100px; margin-top: -68px; width: 38px; height: 38px; margin-right: -5px; z-index: 710; transition: all 0.25s ease-in-out 0s; }
#back-top:hover			{ margin-right: 0px; }
	#back-top a  			{ color: #fff; width: 38px; height: 38px; background-color: rgba(0,0,0,0.8); padding: 2px 8px; text-align: center; box-sizing: border-box; display: block; transition: all 0.35s ease-in-out 0s; z-index: 450; }
  	#back-top a:hover 		{ }
	  	#back-top a i.fa 		{ font-size: 32px; color: rgba(255,255,255,0.8); height: auto; transition: all 0.35s ease-in-out 0s; }
	  	#back-top a:hover i.fa  	{ color: #fff; }

@media only screen and (min-width: 995px) { 
    #back-top			{ width: 50px; height: 50px; }
    #back-top a  		{ width: 50px; height: 50px; padding: 2px 12px; }
    #back-top a i.fa 	{ font-size: 42px; }
}



/* --------------- Mobile-Darstellung bis zu 994px, aber einspaltige Inhaltsdarstellung bereits ab 780px nach unten --------------- */
@media only screen and (max-width: 994px) { 
	.hide4mobile 		{ display: none !important; }
	
	.container			{ width: 740px; }
	.content-col4-1				{ display: block; height: auto; max-width: 100%; width: 100%; margin-left: 0px; margin-right: 0px; padding: 0px; margin-bottom: 30px; }
	.content-col3-1				{ display: block; height: auto; max-width: 100%; width: 100%; margin-left: 0px; margin-right: 0px; padding: 0px; margin-bottom: 30px; }
	.content-col3-2				{ display: block; height: auto; max-width: 100%; width: 100%; margin-left: 0px; margin-right: 0px; padding: 0px; margin-bottom: 30px; }	
	.content-col2-1				{ display: block; height: auto; max-width: 100%; width: 100%; margin-left: 0px; margin-right: 0px; padding: 0px; margin-bottom: 30px;  }	
	
	a.a_sprung 					{ margin-top: -60px; }
	a.bn_bg_ci					{ width: 100%; padding: 12px 40px; box-sizing: border-box; } 
	
	table.border_ci	th			{ padding: 10px 10px; }
	table.border_ci	td			{ padding: 10px 10px; }
	
	img.img_responsiv_full		{ float: none; display: block; clear: both; width: 100% !important; max-width: 100%; height: auto; margin: 15px 0px 25px 0px !important; }
	img.img_responsiv_half		{ width: 50% !important; max-width: 100%; height: auto; }
}

@media only screen and (max-width: 780px) { 
	.container			{ width: 100%; box-sizing: border-box; padding-left: 10px; padding-right: 10px; }
	.content-col4-1			{ display: block; height: auto; max-width: 100%; width: 100%; margin-left: 0px; padding: 0px; margin-bottom: 30px; }	
	.content-col3-1			{ display: block; height: auto; max-width: 100%; width: 100%; margin-left: 0px; padding: 0px; margin-bottom: 30px; }	
	.content-col3-2			{ display: block; height: auto; max-width: 100%; width: 100%; margin-left: 0px; padding: 0px; margin-bottom: 30px; }	
	.content-col2-1			{ display: block; clear: both; width: 100%; height: auto; padding: 0px 0px; margin-bottom: 30px; }
}

@media only screen and (max-width: 560px) { 
	.hide4smartmobiles 		{ display: none !important; }
}

@media only screen and (min-width: 995px) { 
    .hide4desktop 		{ display: none; }
    
	.container			{ width: 980px; }
	#top_bar .container	{ padding-left: 0px; padding-right: 0px; }
	#nav_bar .container	{ padding-left: 0px; padding-right: 0px; }
	.content-col4-1			{ position: relative; float: left; width: 24%; height: auto; padding: 20px 0px; }
	.content-col3-1			{ position: relative; float: left; width: 32%; height: auto; padding: 20px 0px; }
	.content-col3-2			{ position: relative; float: left; width: 66%; height: auto; padding: 20px 0px; }	
	.content-col2-1			{ position: relative; float: left; width: 49%; height: auto; padding: 20px 0px; }
	
	img.img_responsiv_full	{ width: auto; max-width: 40%; height: auto; }
	img.img_responsiv_full.left	{ display: inline; float: left; margin: 0px 40px 35px 0px; }
	img.img_responsiv_full.right	{ display: inline; float: right; margin: 0px 0px 35px 40px; }
}

@media only screen and (min-width: 1200px) { 
	.container					{ /*margin: 0px 10px;*/ width: 1170px; }
}
