/* pt-sans-regular - latin */
@font-face {
  font-family: 'PT Sans';
  font-style: normal;
  font-weight: 400;
  src: local(''),
       url('fonts/pt-sans-v12-latin-regular.woff2') format('woff2'), /* Chrome 26+, Opera 23+, Firefox 39+ */
       url('fonts/pt-sans-v12-latin-regular.woff') format('woff'); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
  font-display: swap;
}

/* pt-sans-700 - latin */
@font-face {
  font-family: 'PT Sans';
  font-style: normal;
  font-weight: 700;
  src: local(''),
       url('fonts/pt-sans-v12-latin-700.woff2') format('woff2'),
       url('fonts/pt-sans-v12-latin-700.woff') format('woff');
  font-display: swap;
}



/* rubik-regular - latin */
@font-face {
  font-family: 'Rubik';
  font-style: normal;
  font-weight: 400;
  src: local(''),
       url('fonts/rubik-v14-latin-regular.woff2') format('woff2'),
       url('fonts/rubik-v14-latin-regular.woff') format('woff');
  font-display: swap;
}

/* rubik-700 - latin */
@font-face {
  font-family: 'Rubik';
  font-style: normal;
  font-weight: 700;
  src: local(''),
       url('fonts/rubik-v14-latin-700.woff2') format('woff2'),
       url('fonts/rubik-v14-latin-700.woff') format('woff');
  font-display: swap;
}


/* --- undo --- */
html, body, div, span, a, h1, h2, h3, h4, h5, h6, p, blockquote, img, 
ol, ul, li, input, textarea, label, select, table, tbody, thead, tfoot, tr, th, 
td, footer, header, menu, nav, section, video { padding: 0; margin: 0; box-sizing: border-box; }

html, body, p, form, input, textarea { margin: 0; padding: 0; }
img, a img, :link img, :visited img, fieldset, button { border: none; outline: none; }
a:visited { text-decoration: none; }
img { margin: 0; padding: 0; vertical-align: bottom; }
table { margin: 0; padding: 0; border: none; border-spacing: 0; }
tr { margin: 0; padding: 0; border: none; border-spacing: 0; }
td { margin: 0; padding: 0; border: none; border-spacing: 0; vertical-align: top; }
hr { clear: both; }

ul { list-style-type: disc; list-style-image: none; margin: 0 0 1.0em 0; }
ul li { list-style-type: disc; margin: 0 0 0.5em 1em; padding: 0; }
ol { list-style-type: decimal; list-style-image: none; margin: 0 0 1.0em 0; }
ol li { list-style-type: decimal; margin: 0 0 0.5em 1em; padding: 0; }


html, body { 
min-height: 100%; /* Vertikalen Scrollbalken immer einblenden */ 
word-wrap:break-word; /* Woerter in die naechste Zeile umbrechen, wenn sie das umschliessende Element verlassen */
min-width: 300px;
}
html { overflow: scroll; overflow-x: auto; }


/* fuer responsive Webseiten */ 
img, object, iframe { max-width: 100%; height: auto; }

/*  Clearfix, um das Floating innerhalb der Container aufzuheben */ 
.clearfix:after,
.outer_box_inner:after { content: "."; display: block; height: 0; clear: both; visibility: hidden; font-size: 0; line-height: 0; }

/* Css-Formatierungen interne Module */ 
.flLeft { float: left; }
.flRight { float: right; }
.flClear { clear: both; }
.center { text-align: center; }
.small { font-size: small; }
.bold { font-weight: bold; }
.hide { display: none; }
.textLeft { text-align: left; }
.textCenter { text-align: center; }
.textRight { text-align: right; }


/* --- CSS-Einstellungen fuer das Addon Modulhelper (bzw. bw_modulhelper) --- */ 

/* Section */
.section_bg_none,
.section_bg_blue,
.section_bg_red,
.section_bg_black
{ clear: both; display: block; position: relative; top: 0; left: 0; width: 100%; height: auto; margin: 0; padding: 40px 0 10px 0; z-index: 1; }

.section_bg_none { background-color: transparent; }
.section_bg_blue { background-color: #283649; }
.section_bg_red { background-color: #c51112; }
.section_bg_black { background-color: #00090b; }


.section_full,
.section_1600,
.section_1200,
.section_980 { clear: both; display: block; position: relative; top: 0; left: 0; width: 100%; height: auto; margin: 0 auto; padding: 0; z-index: 1; }

.section_full { width: 100%; margin: 0 ; }
.section_1600 { width: 1600px; margin: 0 auto; }
.section_1200 { width: 1200px; margin: 0 auto; }
.section_980 { width: 980px; margin: 0 auto; }


@media all and (max-width:1600px) { .section_1600 { width: 100%; margin: 0; } }
@media all and (max-width:1200px) { .section_1200 { width: 100%; margin: 0; } }
@media all and (max-width:980px) { .section_980 { width: 100%; margin: 0; } }
@media all and (max-width:768px) { .section_768 { width: 100%; margin: 0; } }


.section_bg_image,
.section_bg_paroller { display: block; position: static; width: 100%; margin: 0; padding: 100px 0 80px 0; z-index: 1; 
background-color: #fff; background-position: center center; background-attachment: scroll; background-repeat: no-repeat; background-size: cover; }
.section_bg_image { width: 91.67%; max-width: 1467px; min-height: 300px; margin: 0 auto; }


/* ------------ Outer Box ------------ */
/* Ausgangswerte: (Seitenbreite: 1200px | Abstand: 50px) */
.outer_box { clear: both; display: block; float: left; width: 91.67%; margin: 0 0 20px 4.17%; padding: 0; }

.box_width_full { width: 100%; margin: 0 0 20px 0; }
.box_width_1_2 { clear: none; width: 43.75%; }
.box_width_1_3 { clear: none; width: 27.78%; }
.box_width_2_3 { clear: none; width: 59.73%; }
.box_width_1_4 { clear: none; width: 19.79%; }
.box_width_3_4 { clear: none; width: 67.71%; }



.outer_box .image { margin: 0 0 25px 0; }
.outer_box .image a { text-decoration: none !important; }
.outer_box .image a:hover { opacity: 0.8; }

.text_bild .flLeft { float: left; display: block; width: auto; max-width: 42.86%; margin: 0 15px 0 0; overflow: hidden; }
.text_bild .flRight { float: right; display: block; width: auto; max-width: 42.86%; margin: 0 0 0 15px; overflow: hidden; }
.text_bild .image span.small { display: block; }

.zweispalter { }
.zweispalter .flLeft { float: left; display: block; width: 47.37%; margin: 0; overflow: hidden; }
.zweispalter .flRight { float: right; display: block; width: 47.37%; margin: 0; overflow: hidden; }


.box_bg_white { background-color: #fff; }
.box_bg_blue { background-color: #283649; }
.box_bg_red { background-color: #c51112; }
.box_bg_black { background-color: #00090b; }



.outer_box_inner { padding: 20px 20px 1px 20px; }




/* --- Schriften + Generelle CSS-Anpassungen fuer diese Webseite --- */ 
html, body {
font-family: 'PT Sans', Arial, sans-serif; font-weight: 400;
font-size: 20px; line-height: 1.5; 
color: #00090b;
}

html { background-color: #fff; }

a { text-decoration: none; color: #c51112; }
a:hover { text-decoration: none; color: #00090b; }
a:active, a:focus { outline: 0; }
a:hover img { opacity: 0.8; }

a.link_as_button_white,
a.link_as_button_blue,
a.link_as_button_red,
a.link_as_button_black { display: inline-block; padding: 5px 50px 5px 20px; text-decoration: none; background-position: right center; background-repeat: no-repeat; background-image: url(link_as_button.png); }

a.link_as_button_white { background-color: #fff; color: #00090b; background-image: url(link_as_button_black.png); }
a.link_as_button_blue { background-color: #283649; color: #fff; }
a.link_as_button_red { background-color: #c51112; color: #fff; }
a.link_as_button_black { background-color: #00090b; color: #fff; }

a.link_as_button_white:hover,
a.link_as_button_blue:hover,
a.link_as_button_red:hover,
a.link_as_button_black:hover { color: #fff; text-decoration: none; background-image: url(link_as_button.png); }

a.link_as_button_white:hover { background-color: #00090b; }
a.link_as_button_blue:hover { background-color: #c51112; }
a.link_as_button_red:hover { background-color: #00090b; }
a.link_as_button_black:hover { background-color: #c51112; }


ul { margin: 0; padding: 0 0 10px 0; }
ul li { list-style-type: disc; list-style-position: outside; margin: 0 0 0 15px; padding: 0 0 10px 0; }

h1, h2, h3, h4, h5, h6,
.like_h1, .like_h2, .like_h3, .like_h4, .like_h5, .like_h6 { font-family: Rubik, 'PT Sans', Arial, sans-serif; font-weight: 400; font-style: normal; font-size: 20px; line-height: 1.5; margin: 0 0 10px 0; color: #00090b; }
h1, .like_h1 { font-size: 40px; line-height: 1.25; } 
h2, .like_h2 { font-size: 36px; line-height: 1.25; } 
h3, .like_h3 { font-size: 32px; line-height: 1.25; } 
h4, .like_h4 { font-size: 24px; } 
h5, .like_h5 { font-size: 20px; } 
h6, .like_h6 { font-size: 16px; } 

.headline { margin-bottom: 20px; }
.headline h1, .headline h2 {margin: 0; }

.headline h1 span.headline_line,
.headline h2 span.headline_line { display: block; width: 180px; height: 3px; margin: 0 0 10px -15px; padding: 0; background-color: #c51112;  }

.headline h1 span.headline_subline,
.headline h2 span.headline_subline { display: block; margin: 0 0 0 30px; line-height: 1.25; font-weight: 400; }

.headline h1 span.headline_subline { font-size: 30px; }
.headline h2 span.headline_subline { font-size: 26px; }

em { font-style: italic; }
strong { font-weight: 700; }



p { margin: 0 0 20px 0; padding: 0;}

table { margin: 0 0 20px 0; padding: 0;}
td { padding: 0 8px 6px 0; vertical-align: top; }

hr { clear: both; height: 1px; width: 100%; margin: 0 0 20px 0; border: none; background-color: #3d454c; } 

.small  { display: block; font-size: 13px; line-height: 16px; color: #333; font-style: italic; padding-top: 5px; } /* Bildunterschriften */



/* --- Menue-Button --- */ 
#main_nav_button, 
#main_nav_button_close {display: block; position: absolute; top: 46px; left: 0; width: 186px; height: 54px; margin: 0; padding: 0; z-index: 1001; color: #333; border: none; background-color: #fff; background-image: url(menue.png); background-position: center left; background-repeat: no-repeat; }

#main_nav_button_close { background-color: transparent; background-image: url(menue-close.png); }

#main_nav_button:hover, 
#main_nav_button_close:hover { opacity: 0.5; }



#main_nav_bg { display: none; position: fixed; top: 0; left: 0; width: 100%; height: auto; margin: 0; padding: 0; z-index: 1000; background-color: #00090b; background-image: url(kurvenlinie.png); background-position: center; background-repeat: no-repeat; background-size: contain; }

#main_nav_bg.active { display: block; height: 100%; overflow-y: auto; }

#main_nav { position: relative; top: 0; left: 0; width: 1600px; height: auto; min-height: 800px; margin: 0 auto; padding: 150px 0 0 0; z-index: 99; text-align: left; }

/* erste Ebene */
#main_nav ul { list-style: none; display: block; position: relative; top: 0; left: 0; margin: 0; padding: 0 0 0 50px; }
#main_nav li { list-style-type: none; display: block; position: relative; top: 0; left: 0; margin: 0 0 20px 0; padding: 0; }
#main_nav li a { display: block; width: auto; height: auto; margin: 0; padding: 5px 10px; 
font-size: 30px; line-height: 40px; color: #fff; text-decoration: none; transition: all 200ms ease-in-out; }
#main_nav li a::after { content: ""; display: block; width: 60px; height: 1px; margin: 0 0 10px -15px; padding: 0; background-color: #c51112;  }
#main_nav li a:hover { text-decoration: none; color: #c51112;  }
#main_nav li a.rex-current,
#main_nav li a.rex-active { text-decoration: none; color: #c51112; }

/* zweite Ebene */
#main_nav ul.rex-navi2 { display: none; }




#main_nav_sidebar,
#main_nav_sidebar_image,
#main_nav_sidebar_phone,
#main_nav_sidebar_oeffnungszeiten { display: block; position: absolute; top: 0; left: auto; right: 0; width: 100%; height: auto; margin: 0; padding: 0; z-index: 1; color: #fff; }	

#main_nav_sidebar a { color: #fff; text-decoration: none; background-color: #00090b; transition: all 200ms ease-in-out; }
#main_nav_sidebar a:hover { color: #fff; text-decoration: none; background-color: #c51112; }

#main_nav_sidebar { width: 634px; } 

#main_nav_sidebar_image,
#main_nav_sidebar_phone,
#main_nav_sidebar_oeffnungszeiten { border: 1px solid #fff; } 

#main_nav_sidebar_image { top: 60px; }
#main_nav_sidebar_phone { top: 500px; padding: 0; }
#main_nav_sidebar_oeffnungszeiten { top: 630px; }

#main_nav_sidebar_oeffnungszeiten,
#main_nav_sidebar_phone a { display: block; padding: 15px 20px 15px 80px; background-image: url(icon-oeffnungszeit-menue.png); background-position: 420px center; background-repeat: no-repeat; }

#main_nav_sidebar_phone a { background-image: url(icon-anrufen-menue.png); }




/* --- Ausrichtung der Seite und der <div>-Container (Reihenfolge von oben nach unten) --- */ 

#header_top_bg, #header_top, #header_bg, #header, #header_image, #header_bottom, #content, #footer_bg, #footer
{ display: block; position: relative; top: 0; left: 0; width: 100%; height: auto; margin: 0; padding: 0; z-index: 1; }


#header_top,
#header_image,
#header_bottom,
#footer { width: 1600px; margin: 0 auto; }

#header_top_bg { position: relative; background-color: #fff; z-index: 999; }

#header_logo { display: block; width: 281px; margin: 0 auto; padding: 10px 0; z-index: 100; }
#header_logo a:hover { opacity: 0.8; }

#header_phone { display: block; position: absolute; top: 43px; left:  auto; right: 30px; width: 75px; height: 60px; margin: 0; padding: 0; z-index: 100; }

#header_bg { padding: 150px 0 0 0; }
#header_bg { padding: 0; }



#header_title { display: block; padding: 10px 0; font-family: Rubik, 'PT Sans', Arial, sans-serif; color: #00090b; text-align: center; 
font-size: 50px; line-height: 1.2; }




.oeffnungszeiten_tag { display: inline-block; width: 80px; white-space: nowrap; }
.oeffnungszeiten_uhrzeit { display: inline-block; white-space: nowrap; }


#header_bottom {
  clear: both;
  display: flex; padding: 10px 0; background-color: #00090b; border-bottom: 5px solid #c51112; color: #fff;
  flex-flow: row wrap;
  justify-content: flex-start;
}


.header_bottom_box { display: block; width: 27.78%; margin: 0 0 0 4.17%; padding: 15px 0; font-size: 32px; line-height: 1.25; }

#header_bottom_box_3 { padding: 5px 0; }

#header_bottom_box_2 { border-right: 1px solid #fff; }
.header_bottom_box .oeffnungszeiten_title { text-transform: uppercase; }
.header_bottom_box .oeffnungszeiten_tag,
.header_bottom_box .oeffnungszeiten_uhrzeit { display: inline-block; white-space: nowrap; font-size: 24px; line-height: 1.25; }
.header_bottom_box .oeffnungszeiten_tag { width: 80px; }


/* ------------------- */


#content { padding: 0; min-height: 400px; z-index: 10; }


/* -----------footer--------------------------- */
#footer_bg { clear: both; padding: 30px 0 10px 0; background-color: #00090b; }
#footer { padding: 0; margin: 0 auto; color: #FFF; font-size: 22px; line-height: 1.5; }
#footer a { color: #fff; text-decoration: none; }
#footer a:hover { color: #c51112; text-decoration: none; }


.footer_box { display: block; float: left; width: 27.78%; margin: 0 0 20px 4.17%; padding: 0; }

.footer_headline { display: block; font-size: 24px; line-height: 1.5; font-weight: 700; text-transform: uppercase; }
.footer_headline::after { content: ""; display: block; width: 75px; height: 1px; margin: 0 0 10px -15px; padding: 0; background-color: #c51112;  }

#footer_box_2 span { display: inline-block; width: 60px; }

#footer_bottom { padding: 10px 0; text-align: center; font-size: 22px; line-height: 1.5; }
#footer_bottom a { display: inline-block; margin: 0 10px; color: #fff; text-decoration: none; }
#footer_bottom a:hover { color: #c51112; text-decoration: none; }



/* ---  Cookie-Hinweis ohne OK-Button - Datenschutzinfo --- */ 
#datenschutzinfo { clear: both; display: block; width: 100%; height: auto; margin: 0; padding: 15px 10px; background-color: #333; font-size: 14px; line-height: 20px; color: #fff; text-align: center; }
#datenschutzinfo a { color: #fff; text-decoration: underline; }
#datenschutzinfo a:hover { color: #fff; text-decoration: none; }





/* --- Module --- */ 

/* Video per YouTube */
.video { position:relative; padding: 0 0 56.25% 0; margin: 0 0 20px 0; /* 56.25% wegen 16:9 Format */ height:0; overflow:hidden; border: 1px solid #fff; }
.video iframe { position: absolute; top: 0; left: 0; width: 100% !important; height: 100% !important; border: none; }



.bildergalerie a { display: block; float: left; width: 26.98%; margin: 0 0 4.76% 4.76%; padding: 0; }


.button_telefon a { display: inline-block; min-width: 300px; color: #FFF; background-color: #00090b; text-decoration: none; transition: all 200ms ease-in-out; }
.button_telefon a span { display: block; width: 100%; padding: 5px 15px; }
.button_telefon a span.button_telefon_spruch { background-color: #c51112; }
.button_telefon a:hover { color: #FFF; background-color: #00090b; text-decoration: none; transform: scale(1.05); }



/* Redaxo Download Modul */ 
.download_box { width: auto; margin: 0 0 1.0em 0; padding: 5px 0; font-size: 0.9em; }
.download_box .download_hdl {  }
.download_icon { float: left; } 
.download_icon a { font-size: 0.9em; }
.download_icon a.extern { padding-right: 0; background: none; }
.download_text { margin-left: 50px; padding: 0 0 0 5px; }
.download_desc { color: #999; margin: 0; font-size: 0.7em; }
.download_without_desc { }


/* ------------------- */


.neuigkeiten_bg {
  clear: both;
  display: block; width: 91.67%; height: auto; margin: 0 auto 40px auto; padding: 0;
  background-color: #283649; color: #fff;
}

.neuigkeiten_headline { display: block; position: relative; top: 0; left: 0; width: 300px; margin: 0 auto; padding: 0 15px 5px 15px; z-index: 1; text-align: center; text-transform: uppercase; color: #253649; font-size: 36px; line-height: 1.0; }

.neuigkeiten_headline::after {
	content:'';
	display: block; position: absolute; top: -1px; left:0; width: 100%; height: 100%; z-index:-1;
	background-color: #fff; transform:skew(-45deg);
	
}

.neuigkeiten_flex { 
	clear: both;
	display: flex;
	flex-wrap: wrap;
	flex-direction: row;
	justify-content: space-around;
	width: 100%;
	margin: 0;
}

.neuigkeiten_box {
	display: block; width: 91.67%; margin: 0; padding: 20px 0; color: #fff;
}

.neuigkeiten_flex.anzahl_2 .neuigkeiten_box { width: 43.75%; }
.neuigkeiten_flex.anzahl_3 .neuigkeiten_box { width: 27.78%; }


@media all and (max-width:768px) {
	.neuigkeiten_flex.anzahl_2 .neuigkeiten_box,
	.neuigkeiten_flex.anzahl_3 .neuigkeiten_box { width: 91.67%; }
}

/* ------------------- */



.slidedown_box_button { display: block; width: 40px; height: 40px; margin: 0 auto; padding: 0; text-indent: -99999px; overflow: hidden; background-color: transparent; background-image: url(icon_slidedown_box_button.png); background-position: center; background-repeat: no-repeat; 
transition: all 200ms ease-in-out; }
.slidedown_box_button:hover { transform: scale(1.1); }
.slidedown_box.active .slidedown_box_button { transform: rotate(180deg); }

.slidedown_box_headline { font-size: 32px; line-height: 1.2; margin: 0 0 10px 0; }

.slidedown_box_text { display: none; padding: 0; overflow: hidden; }
.slidedown_box_text_inner { display: block; padding: 10px 0 0 0; }

.slidedown_box.active .slidedown_box_text { display: block; }

/* ---------------------- */

.slider_bg {
  clear: both;
  display: block; width: 91.67%; height: auto; margin: 0 auto 40px auto; padding: 0;
  background-color: #00090b; color: #fff;
}

.slider_bg .tns-slider { display: flex; 
  flex-flow: row wrap;
  justify-content: flex-start;
}

.slider_content { }

.slider_box { display: block; position: relative; top: 0; left: 0; width: 100%; height: 100%; margin: 0; padding: 0; z-index: 1; overflow: hidden; color: #fff; }

.slider_image { display: block; position: absolute; top: 0; left: 0; width: 50%; height: 100%; margin: 0; padding: 0; z-index: 1; background-position: center; background-size: cover; }

.slider_image img { display: none; margin: 0; padding: 0; }

.slider_text { display: block; width: 50%; height: auto; margin: 0 0 0 50%; padding: 40px 30px 20px 30px; }

.slider_text h1, .slider_text h2, .slider_text h3, .slider_text p { color: #fff; }
.slider_text a { color: #00090b; }
.slider_text a:hover { color: #fff; }


.slider_box_link { display: block; width: 98px; height: 34px; margin: 0 auto; padding: 0; text-indent: -99999px; overflow: hidden; background-color: transparent; background-image: url(icon_slider_box_link.png); background-position: center; background-repeat: no-repeat; 
transition: all 200ms ease-in-out; }
.slider_box_link:hover { transform: scale(1.1); }



@media all and (max-width:768px) {
	.slider_image { position: relative; width: 100%; height: auto; margin: 0; padding: 0;background-image: none; }
	.slider_image img { display: block; }

	.slider_text { width: 100%; margin: 0; padding: 30px 20px 10px 20px; }	
}

/* ------------------- */

.openstreetmap { display: block; position: relative; top: 0; left: 0; z-index: 1; }
.openstreetmap .leaflet-tile-pane { -webkit-filter: grayscale(100%); filter: grayscale(100%); }

.openstreetmap .leaflet-container { font-size: 14px; line-height: 20px; }

@media all and (max-width:480px) { 
	.openstreetmap #map { height: 65vh !important; min-height: 400px !important; }
	.openstreetmap .leaflet-control-minimap { display: none; }
}

.openstreetmap_reload
{ display: inline-block; width: auto; height: auto; margin: 20px 0 0 0; padding: 5px 10px; font-size: 14px; line-height: 20px; font-weight: normal; border: 0; text-decoration: none; color: #fff; background-color: #c51112; text-align: center; cursor: pointer; }
  
.openstreetmap_reload:hover { text-decoration: none; color: #fff; background-color: #00090b; }

	
#start_overlay { display: flex; align-items: center; justify-content: center; position: fixed; top: 0; left: 0; width: 100%; min-width: 300px; height: 100vh; margin: 0; padding: 30px; z-index: 100000; background-color: rgba(0,0,0,0.75); }	
	
#start_overlay_content { max-width: 768px; width: 100%; position: relative; padding: 60px 30px; background-color: #293649; color: #fff; border-top: 5px solid #c41013; border-bottom: 5px solid #c41013; text-align: center; background-image: url(pfeil_rot-schwarz.png); background-position: bottom right; background-repeat: no-repeat; font-size: 1.4rem; line-height: 1.5; }

#start_overlay_content a { color: #fff; text-decoration: none; border-bottom: 2px solid #c41013; }
#start_overlay_content a:hover { color: #c41013; text-decoration: none; border-bottom: 2px solid transparent; }
	
#start_overlay_headline { font-size: 1.75rem; line-height: 1.25; margin: 0 0 40px 0; }
#start_overlay_headline span { display: inline-block; position: relative; }
#start_overlay_headline span::after { content: ''; display: block; width: 200px; height: 2px; margin: 5px 0 0 -20px; background-color: #c41013; }
	
#start_overlay_link { margin: 40px 0 0 0; }
	
#close_overlay { position: absolute; top: 5px; right: 10px; width: 30px; height: 30px; margin: 0; padding: 0; background: none; border: none; color: #fff; font-size: 30px; cursor: pointer; line-height: 1; transition: color 0.3s ease; }
#close_overlay:hover { color: #c41013; }
	
@media (max-width: 768px) {
	#start_overlay { align-items: flex-start; padding: 125px 20px 20px 20px; }
	#start_overlay_content { padding: 40px 20px 120px 20px; font-size: 1.1rem; background-image: url(pfeil_rot-schwarz-mobil.png); background-position: bottom center; }
	#start_overlay_headline { font-size: 1.3rem; margin: 0 0 25px 0; }
	#start_overlay_headline span::after { width: 120px; margin: 5px 0 0 0; }
	#start_overlay_link { margin: 25px 0 0 0; }
}
@media (max-width: 480px) {
	#start_overlay { overflow-y: auto; padding: 110px 20px 20px 20px; }
	#start_overlay_content { font-size: 1rem; max-height: none; }
	#start_overlay_headline { font-size: 1.25rem; }	
	#start_overlay_content br.not_mobile { display: none; }
}
@media (max-height: 480px) and (orientation: landscape) {
	#start_overlay { padding: 20px; }
}



/* --- yForm --- */ 
.yform div.alert { padding: 15px 30px 5px 30px; margin-bottom: 20px; border-radius: 4px; }
.yform div.alert span { margin-right: 15px; }
.yform div.alert-danger { border: 2px solid #a94442; background-color: #f2dede; color: #a94442; }
.yform .alert ul { list-style-type: none; margin: 0; padding: 0; }
.yform .alert li { list-style-type: none; margin: 0 0 10px 0; padding: 0; color: #a94442; }

.has-error label { color: #a94442; }

.yform form { display: block; margin: 0 0 20px 0; padding: 0; }
.yform label { display: block; font-size: 14px; line-height: 20px; }
.yform form.hide-label label { display: none; }

.yform .form-control {
    box-sizing: border-box; 
	display: block;	width: 99%; height: auto; margin: 0 0 20px 0; padding: 5px 10px;
    font-family: inherit; font-size: 14px; line-height: 20px; color: #000;
	background-color: #fff; border: 1px solid #999; outline: none;
}
.yform .form-control:hover { border-color: #a8aeb5; }
.yform .form-control:focus { border-color: #37434f; outline: none; box-shadow: none; }

.yform textarea.form-control { height: 210px; }

.yform .formcheckbox label { display: block; float: none; width: auto; margin: 0 0 10px 0; padding: 0; }
.yform .formcheckbox label input { display: block; float: left; width: auto; margin: 0 10px 0 0; }
.yform .formcheckbox label span { display: block; float: none; width: auto; margin: 0 0 5px 30px; }

.yform .form-check-group { clear: both; margin: 0 0 20px 0; }
.yform .form-check-group .control-label { clear: both; display: block; margin: 0 0 10px 0; }

.yform .radio { display: block; float: none; width: auto; margin: 0 0 10px 0; padding: 0; }
.yform .radio label input { display: block; float: left; width: auto; margin: 5px 10px 0 0; }

.yform .checkbox { clear: both; margin: 0 0 20px 0; }
.yform .checkbox label input { display: block; float: left; width: auto; margin: 5px 10px 0 0; }


/* Button */
.yform .btn-primary {
	clear: both; display: block; width: 140px; height: auto; margin: 0 0 10px 0; padding: 5px;
    border: none; border-radius: 5px;
    text-align: center; font-weight: bold; 
    background-color: #c51112; color: #FFF; 
}
.yform .btn-primary:hover { background-color: #00090b; color: #FFF; }

.yform .pflichtfelder { font-size: 0.8em; }

/* Honeypot gegen SPAM */
#yform-contact_formular-email_betreff { display: block; width: 1px; height: 1px; margin: 0; padding: 0; overflow: hidden; }
#yform-contact_formular-email_betreff.has-error { display: block; width: auto; height: auto; margin: 0 0 20px 0; padding: 20px 20px 1px 20px; border: 1px solid #a94442; opacity: 1; background-color: #f0f0f0; color: #a94442; }
#yform-contact_formular-email_betreff.has-error label { display: block !important; margin-bottom: 10px !important; }


.yform strong { font-weight: bold; }

/* eigene CSS Klassen */
.form_clear { clear: both; }

.form_line { display: block; width: 100%; height: 2px; margin: 10px 0 30px; padding: 0; background-color: #c51112; }

.form_left,
.form_right { display: block; float: left; width: 49%; margin: 0; padding: 0; }
.form_left { clear: both; }
.form_right { float: right; }

.form_left label,
.form_right label,
.form_full label { display: none; }
.form-check-group label { display: inline-block; }


.yform .hinweis { font-size: 12px; line-height: 20px; }

/* Upload Feld */
	
.upload_felder .upload_box { display: block; margin: 0 0 20px 0; padding: 10px; border: 1px solid #999; background-color: #f9f9f9; }

.upload_felder .form-group { display: block; margin: 0; }
.upload_felder .input-group .form-control { margin: 0 0 5px 0; padding: 0; border: none; background-color: transparent; }
	

.upload_felder span.input-group-btn button.btn-default::after { display: inline-block; content: 'Datei löschen'; margin: 0 0 0 5px; }
.upload_felder label.control-label { display: block; margin: 0 0 10px 0; }
	

.upload_felder span.input-group-btn { display: none; }
.upload_felder span.input-group-btn.show { display: block; }
	

.upload_felder div.checkbox { font-size: 12px; line-height: 20px; margin: 0; }
.upload_felder div.checkbox label { display: block; margin: 0; }
	
	
	
.checkbox_ihr_anliegen .form-check-group { 
	display: flex; margin: 0 0 20px 0; padding: 0;
  flex-flow: row wrap;
  justify-content: flex-start;
}
	
.checkbox_ihr_anliegen .form-check-group .checkbox { 
display: block; width: 50%; margin: 0 0 10px 0; padding: 0 20px 0 0; font-size: 14px; line-height: 20px;
}

.checkbox_ihr_anliegen .form-check-group label.control-label { 
display: none; width: 100%; margin: 0; padding: 0;
}
	

	
.checkbox_kontaktaufnahme .form-check-group { display: block; margin: 0 0 20px 0; padding: 0; }
	
.checkbox_kontaktaufnahme .form-check-group .checkbox { 
display: inline-block; width: auto; margin: 0 0 10px 0; padding: 0 20px 0 0; font-size: 14px; line-height: 20px;
}

.checkbox_kontaktaufnahme .form-check-group label.control-label { display: none; }



#seite_kontakt .outer_box.box_width_1_3 { float: right; margin: 0 4.17% 20px 0;}


@media all and (max-width:768px) {
.form_left,
.form_right { float: none; width: auto; }
	
#seite_kontakt .outer_box.box_width_1_3,	
#seite_kontakt .outer_box { clear: both; float: none; width: auto; margin: 0 4.17% 20px 4.17%; }
	
#seite_kontakt .outer_box.box_width_1_3 { margin: 0 4.17% 40px 4.17%; padding: 0 0 20px 0; border-bottom: 1px solid #999; }
	
}
@media all and (max-width:480px) {
	.checkbox_ihr_anliegen .form-check-group .checkbox { width: 100%; margin: 0 0 10px 0; padding: 0; }
}






/* --------- Responsive ---------- */


@media all and (max-width:1600px) {
	
html, body { font-size: 1.25vw; } 
	
h1, .like_h1 { font-size: 2.5vw; } 
h2, .like_h2 { font-size: 2.25vw; } 
h3, .like_h3 { font-size: 2vw; } 
	
.headline h1 span.headline_subline { font-size: 1.88vw; }
.headline h2 span.headline_subline { font-size: 1.63vw; }	
	
#header_title { font-size: 3.13vw; }
	
.header_bottom_box { font-size: 2vw; }
.header_bottom_box .oeffnungszeiten_tag,
.header_bottom_box .oeffnungszeiten_uhrzeit { font-size: 1.5vw; }
.header_bottom_box .oeffnungszeiten_tag { width: 5vw; }

#footer,
#footer_bottom { font-size: 1.38vw; }
.footer_headline { font-size: 1.5vw; }

	
.neuigkeiten_headline { font-size: 2.25vw; } 	
.slidedown_box_headline { font-size: 2vw; }	
	
	
#main_nav,
#header_top,
#header_image,
#header_bottom,
#footer { width: 100%; margin: 0; min-width: 300px; overflow: hidden; }


	
}

@media all and (max-width:1200px) {
	html, body { font-size: 16px; } 
}

@media all and (max-width:980px) {
	
h1, .like_h1 { font-size: 30px; } 
h2, .like_h2 { font-size: 26px; } 
h3, .like_h3 { font-size: 21px; } 
	
.headline h1 span.headline_subline { font-size: 20px; }
.headline h2 span.headline_subline { font-size: 16px; }	 
	
#header_title { font-size: 21px; }
	
.header_bottom_box { font-size: 15px; }
/* display: none 	
.header_bottom_box .oeffnungszeiten_tag,
.header_bottom_box .oeffnungszeiten_uhrzeit { font-size: 1.5vw; }
.header_bottom_box .oeffnungszeiten_tag { width: 5vw; }
*/

#footer,
#footer_bottom { font-size: 16px; }
.footer_headline { font-size: 21px; }


.neuigkeiten_headline { font-size: 24px; width: 210px; } 	
.slidedown_box_headline { font-size: 20px; }	
	
	
#main_nav { min-height: 700px; }
	
#main_nav_sidebar { width: 480px; } 

#main_nav_sidebar_image { top: 60px; }
#main_nav_sidebar_phone { top: 390px; }
#main_nav_sidebar_oeffnungszeiten { top: 500px; }

#main_nav_sidebar_oeffnungszeiten,
#main_nav_sidebar_phone a { display: block; padding: 15px 10px 15px 40px; background-position: 360px center; }

#header_bottom { padding: 5px 0; }
	
}

@media all and (max-width:768px) {

#main_nav_button, 
#main_nav_button_close { top: 45px; left: -20px; width: 85px; height: 30px; background-size: cover; }	
#header_logo { display: block; width: 240px; margin: 0 auto; padding: 10px; text-align: center; }
	
#header_phone { display: none; }

	
#main_nav { padding: 100px 0 0 0; }
#main_nav ul { margin: 0 0 30px 0; padding: 0 0 0 20px; }	
#main_nav li a { font-size: 20px; line-height: 30px;  }
	

#main_nav_sidebar,
#main_nav_sidebar_image,
#main_nav_sidebar_phone,
#main_nav_sidebar_oeffnungszeiten { position: relative; top: 0; left: 0; right: auto;  }	

#main_nav_sidebar { width: 100%; } 

#main_nav_sidebar_image { display: none;}

#main_nav_sidebar_oeffnungszeiten,
#main_nav_sidebar_phone { width: auto; margin: 0 10px 30px 10px; }
	
#main_nav_sidebar_oeffnungszeiten,
#main_nav_sidebar_phone a { display: block; padding: 15px 10px 15px 60px; background-position: 10px center; }
#main_nav_sidebar_phone a { background-size: 38px 26px; }
#main_nav_sidebar_oeffnungszeiten { background-size: 30px 30px; }

#main_nav_sidebar_oeffnungszeiten .oeffnungszeiten_tag { width: 65px; }	
	

	
.header_bottom_box { width: 50%; margin: 0; padding: 7px 20px 7px 5px; }
#header_bottom_box_1 { border-right: 1px solid #fff; text-align: right; }
#header_bottom_box_2 { border-right: none; padding: 7px 5px 7px 20px; }
#header_bottom_box_3 { display: none; }

	
	
.footer_box { float: none; width: 91.66%; padding: 20px 0 0 0; border-top: 1px solid #fff; }
#footer_box_1 { padding: 0; border-top: none; }
	
#footer_bottom { width: 100%; padding: 10px 4.17%; text-align: left; }
#footer_bottom a { margin: 0 10px 0 0; }	

}

 

@media all and (max-width:480px) {
	
h1, .like_h1 { font-size: 28px; } 
h2, .like_h2 { font-size: 24px; } 

.text_bild .flLeft,
.text_bild .flRight { float: none; width: auto; max-width: none; margin: 0 0 15px 0; }

.zweispalter { background-image: none; }
.zweispalter .flLeft { float: none; width: auto; margin: 0 0 15px 0; }
.zweispalter .flRight { float: none; width: auto; margin: 0; }

.outer_box { clear: both; float: none; width: auto; margin: 0 4.17% 20px 4.17%; }
.box_width_full { width: 100%; margin: 0 0 20px 0; }
	
.footer_box { width: auto; margin: 0 4.17% 20px 4.17%; }
	
}

@media all and (max-width:420px) {

#header_logo { display: block; width: 100%; margin: 0; padding: 10px 40px 10px 100px; text-align: right; }
#header_logo a { display: inline-block; width: auto; max-width: 200px; }

}


@media all and (max-width:360px) {

#header_logo { padding: 10px 10px 10px 100px; }

}