@charset "utf-8";
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
body {
	margin: 0;
	padding: 0;
}

/* ~~ Element-/Tag-Selektoren ~~ */
ul, ol, dl {
	padding: 0;
	margin: 0;
}

.contentbox p {
	margin-bottom: 25px;
	clear: both;
}
.contentbox p + ul,
.contentbox p + ol {
	margin-top: -20px;
}
.contentbox hr {
	border: 0;
  	height: 1px;
  	margin: 30px 0;
}
img { 
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}
a img { 
	border: none;
}
a {
	text-decoration: underline;
}
a:hover, a:active, a:focus { 
	text-decoration: none;
}
.container {
	width: 90%;
	max-width: 1100px;
	margin: 0 auto; 
}
.contentbox .container {
	margin: 30px auto 40px; 
}
.contentbox {
	display: block;
	clear: both;
	padding: 10px 0;
}
/* ~~ Kopfbereich ~~ */
.header {
	z-index: 99;
	overflow: visible;
}
.header .container{
	width: 100%;
}
/* ~~ Navigation ~~ */
.navigation.desktop {
	display: none;
}
.navigationmobile {
	position: absolute;
	width: 100%;
	right: 0;
	padding: 10px 0;
	z-index: 90;	
}
.navi {
	position: absolute;
}
.logo {
	position: absolute;
	width: 130px;
	left: 3vw;
	top: 5px;
	z-index: 98;
}
/* ~~ Slider ~~ */
.sliderbox {
	position: relative;
	display: block;
	overflow: hidden;
}
.ccm-toolbar-visible .sliderbox {
		padding-top: 75px;
}
.ccm-image-slider-inner ul.rslides {
	height: 65vh;
	overflow: hidden;
	margin: 0;
}
.ccm-image-slider-inner ul.rslides li {
	height: 65vh;
	overflow: hidden;
	margin: 0;
}
.ccm-image-slider-inner li img {
    position: relative;
    object-fit: cover;
    width: 100%;
	max-width: none;	
    height: 100%;
	margin-bottom: 0;
    transition: transform 10s;
    transform-origin: center;
	transform: scale(1.2);	
}
.ccm-image-slider-inner li.rslides1_on img {
    transform: scale(1.0);
}
ul.rslides_tabs {
	position: relative;
	text-align: center;
	z-index: 2;
	margin-top: -50px !important;
}
ul.rslides_tabs li {
	display: inline-block;
	text-align: center;
	z-index: 2;
	margin-top: 10px !important;
	aspect-ratio: inherit;
}
.rslides_tabs li a {
    background: transparent !important;	
	border: #FFF 2px solid;
}
.rslides_tabs li.rslides_here a {
    background: #FFF !important;
}

a.rslides_nav {
	display: none;
}
section.banner div.player div.YTPOverlay {
    opacity: 0 !important;
}

/* ~~ Seitenliste Kachelbox~~ */
.kachelbox {
	display: -webkit-flex;
 	display: flex;
	flex-wrap: wrap;
  	justify-content: flex-start;
	margin: 0 5px;
}
.auswahl {
	flex: 0 0 calc(50%);
	padding: 5px;
}
.ccm-edit-mode .kachelbox {
	display: block;
}
.ccm-edit-mode .auswahl {
	max-width: 350px;
}
.auswahl a {
	position: relative;
	display: table;	
	text-decoration: none;
}
.auswahl a::after {
  display: block;
  position: relative;
  margin-top: -100px;
  height: 100px;
  width: 100%;
  content: '';
}
.auswahl a img {
	display: block;
	height: auto;
	margin: 0;
}
.seitennamewrapper {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	z-index: 30;	
}
.seitenname {
	display: table;
	width: 100%;
	height: 100%;
}
.seitentitel {
	font-family: 'Oswald', sans-serif;
	font-weight: 500;
  	text-transform: uppercase;	
	display: table-cell;
	width: 100%;
	height: 100%;	
	padding-bottom: 5%;
	vertical-align: bottom;
	text-align: center;
	letter-spacing: 1px;
	font-size: 120%;
	text-decoration: none;
	text-shadow: 0px 0px 2px #000;
    -webkit-transition: font 0.3s;
    -moz-transition: font 0.3s;
    -ms-transition: font 0.3s;
    -o-transition: font 0.3s;
    transition: font 0.3s;
}
.seitentitel:hover {
	font-size: 150%;
}

/* ~~ Inhaltbereich ~~ */
.contentbox ul, .contentbox ol, .cke_contents ul, .cke_contents ol { 
	padding: 0 15px 15px 18px; 
}
.container img { 
	display: block;
	margin: 0 auto 25px; 
}
.firmenlogo img {
	display: block;
	height: 90px;
	width: auto;
	max-width: 100%; 
	margin: 0 0 25px;
}
.firmenlogo:hover {
    opacity: 0.6;
    filter: alpha(opacity=60); /* For IE8 and earlier */
}
/* ~~ Flex Mehrfarbenboxen~~ */
.flex {
	display: -webkit-flex;
 	display: flex;
	flex-wrap: wrap;
}
.flex.farbbox {
  	justify-content: flex-start;
}
.aussen {
	margin: 0 -5px;
}
.flex.farbbox .item {
	width: 100%;
}
.flex .item.drei {
	margin: 0 0 10px;
}
.flex .item.zwei .bild, .flex .item.vier .bild, .flex .item.zwei .textbox, .flex .item.vier .textbox {
	width: calc(100% - 10px);
	margin: 5px;
}
.flex .item.drei .bild, .flex .item.drei .textbox {
	width: 100%;
}
.flex.farbbox .item .bild {
	overflow: hidden;	
}
.flex.farbbox.drei .item .bild {
	aspect-ratio: 4 / 3;	
}
.flex .item .bild img {
	margin: 0;
	object-fit: cover;
	object-position: center;	
}
.flex .item .textbox {
	display: -webkit-flex;
 	display: flex;
	flex-direction: column;
	padding: 30px 20px 20px;
	text-align: center;
}
.flex .item .textbox .text.bildtext {
	text-align: left;
}
.flex .item.zwei .textbox, .flex .item.vier .textbox {
	justify-content: center !important;	
}
.flex .item.drei .textbox {
	justify-content: flex-start !important;	
}
.flex .item .textbox h3 {
	margin-bottom: 20px;
	text-transform: uppercase;
    font-style: normal;
}
.flex .item .textbox .text {
	display: block;
	width: 100%;
	text-align: center;
}
.flex .item .textbox .text p {
	margin-bottom: 10px;
}
.flex .item .textbox .text s {
	display: none;
}
.flex .item .textbox p a {
	color: #FFF;
}
.flex .item .textbox.weiss p a, .flex .item.rahmen .textbox p a {
	color: #000;
}
.flex .item .textbox img {
	width: 50%;
	max-width: 100px;
}
.flex.farbbox ul {
  	padding-left: 10px;
}
.flex.farbbox li {
  	text-align: left;
}
.linkbox a {
	font-size: 90%;
	font-weight: 700;
	letter-spacing: 1px;
  	padding: 10px 20px;
	margin: 10px 0;
  	display: inline-block;
  	text-decoration: none;
  	text-transform: uppercase;
  	transition: color 0.25s ease-in,background-color 0.25s ease-in;
  	white-space: nowrap;
}
.linkbox a:hover, .linkbox a:active, .linkbox a:focus {
  	transition: color 0.25s ease-in,background-color 0.25s ease-in;
  	white-space: nowrap;
}
.textbreit {
	padding: 0 5px;
}
/* ~~ Linkbutton ~~ */
.flex.linkbutton {
  	justify-content: center;
	padding: 30px 0;
}
.flex.linkbutton .item {
  	margin: 2px;
}

/* ~~ Gallery ~~ */
.ccm-block-gallery {
	margin: -5px -5px 25px;
}
.ccm-block-gallery .row {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
}
.ccm-block-gallery a {
  	width: 50%;
	border: transparent 5px solid;
	overflow: hidden;
}
.ccm-block-gallery .ccm-block-gallery-image-overlay-color {
  	background-color: rgba(0,0,0,.5) !important;
}
.ccm-block-gallery .ccm-block-gallery-image {
  	padding-top: 0 !important;
	aspect-ratio: 5 / 3;
}
.ccm-block-gallery .ccm-block-gallery-image img {
  	padding-top: 0 !important;
	aspect-ratio: 5 / 3;
	bottom: 0 !important;
  	left: 0 !important;
	right: 0 !important;
  	top: 0 !important;
	margin-bottom: 0;
}
.ccm-block-gallery .ccm-block-gallery-image-overlay-text {
	text-align: center;
	font-weight: 400 !important;
	padding: 10px;
}
.ccm-block-gallery a:before {
  content: url(img/lupe.svg);
	position: absolute;
	top: calc(50% - 15px);
	left: calc(50% - 15px);
	z-index: 2;
	scale: 0.2;
	opacity: 0;
	 -webkit-transition: all 0.3s;
  	transition: all 0.3s;
}
.ccm-block-gallery a:hover:before {
	scale: 1;
	opacity: 1;
}
.mfp-title {
  text-align: center !important;
}

/* ~~ Accordion ~~ */
ul.nav-tabs {
	padding: 0 0 15px;
	margin-bottom: 0 !important;
}
.ccm-ui {
    font-family: inherit !important;
    font-size: inherit !important;
    line-height: inherit !important;
    color: inherit !important;
}
.ccm-ui .nav-tabs > li > a {
	line-height: 1.0 !important;
	padding-top: 13px !important;
}
.ccm-ui ul.nav-tabs > li > a, 
.ccm-ui ul.nav-tabs > li > a:hover, 
.ccm-ui ul.nav-tabs > li > a:focus {
	font-weight: 700;
	text-transform: uppercase;
	text-decoration: none;
}
.ccm-ui ul.nav-tabs > li.active::after {
    content: "" !important;
}
.ccm-ui .nav-tabs {
    border-bottom: none !important;
	border-width: 0 !important;	
}
.ccm-ui.jl_magic_tabs_default.jl_magic_tabs_controls.jl_magic_tabs.jl_magic_tabs_accordion > ul.nav-tabs.nav.jl_magic_tabs > li > a::after {
    margin-top: -2px;
}

/* ~~ You Tube ~~ */
.youtubeBlock {
	margin: 30px 0;
}
/* ~~ iframe ~~ */
.iframe iframe {
  width: 100%;
  height: 600px;
  border: #666666 1px solid;
  padding: 20px;
  scroll: auto;
  margin-bottom: 25px;
}
/* ~~ Formidable ~~ */
.formidable {
	display: block;
	overflow: hidden;
	max-width: 600px;
	margin: 0 auto 30px;
	padding: 20px;
}
.formidable h3, .formidable h4 {
	font-style: normal;
}
.formidable .form-group {
	margin-bottom: 20px;
}
.formidable label {
	font-weight: 700;
}
.formidable label.form-check-label {
	font-weight: 400;
	margin-left: 10px;
}
.formidable br {
	line-height: 2.0;
}
.formidable .checkbox label, .formidable .radio label {
	font-weight: 400;	 
}
.formidable .form-control, .formidable .file_upload {
	width: 100%;
	padding: 5px !important;
	margin: 5px 0;
	opacity: 1.0 !important;	
}
.formidable input::placeholder {
  opacity: 1.0;
	color: #000;
}
.formidable .form1 {
	max-width: 200px;
}
.formidable .captcha_input {
    font-size: 100% !important;
}
.formidable .file_upload .dz-preview .dz-image {
    border-radius: 0 !important;
}
.formidable .form-control.ccm-input-captcha {
	margin-bottom: 0;	
	border: none;
}
.formidable .ccm-captcha-image {
	padding: 5px 0;	
}
.formidable textarea.form-control {	
	height: 120px;
}
.formidable .form-control:focus {
	outline: none;
}
.formidable .required {
    font-size: 100% !important;
}
.formidable .btn {
	padding: 10px 15px;
    border: none;	
	text-transform: uppercase;
	font-size: 100%;
	font-weight: 700; 
	cursor: pointer;
}
.formidable .form-control.error, 
.formidable  .datepicker.error, 
.formidable .captcha_input.error .ccm-input-captcha {
	border: none;
}
.formidable_message.hide {
	display: none;
}
div.alert-success {
	font-size: 120%;
}
div.alert-success p {
    margin: 10px 0;
}

/* ~~ Formular ~~ */
.ccm-block-express-form {
	max-width: 600px;
	margin: 0 auto;	
}
fieldset {
	border: none;		
}
.ccm-dashboard-express-form .mb-3 {
  	width: 100%;
	padding-bottom: 20px;
}
.ccm-dashboard-express-form input, 
.ccm-dashboard-express-form textarea, 
.ccm-dashboard-express-form select {
   	appearance: none;	
    display: block;
    padding: 5px 10px;
	width: 100%;
	border-radius: 0;
	color: #000;
}
.ccm-dashboard-express-form .form-control:focus {
	outline: none;
}
.ccm-dashboard-express-form .form-check {
	display: flex;
	flex-direction: row;
	margin-top: 3px;
}
.ccm-dashboard-express-form input[type="checkbox"] {
	display: inline-block;
   	width: 20px; 
   	height: 20px; 
	border-radius: 40px;
}
input[type=checkbox]:checked {
   	background-image: url(img/haekchen.svg);
	background-size:cover;	
}
.ccm-dashboard-express-form .mb-3 label.form-check-label {
  	display: inline-block;
	margin-left: 10px;
}
.ccm-dashboard-express-form .fields {
    display: flex;
    flex-wrap: wrap;
	justify-content: space-between;
}
.ccm-dashboard-express-form .mb-3 label.form-label {
  font-weight: 700;
}
.ccm-dashboard-express-form .mb-3:first-of-type label.form-label {
  display: none;
}
.ccm-block-express-form .alert {
	margin-bottom: 25px;	
}
.alert.alert-success {
	text-align: center;
} 
textarea {
	height: 150px;
	font-weight: 400;
	font-size: 110%;
	resize: vertical;
}
span.text-muted {
	display: inline-block;
	color: transparent;
	opacity: 1.0;
}
span.text-muted:before {
	content: "*";
	font-weight: 400;
}
div.text-muted {
	display: none;
	
}
img.ccm-captcha-image {
	margin: 10px 0;
}
input.ccm-input-captcha {
	width: 190px;
}
.ccm-block-express-form .btn.btn-primary {		
	padding: 10px 15px;
    border: none;	
	text-transform: uppercase;
	font-size: 100%;
	font-weight: 700; 
	cursor: pointer;
}

::-webkit-input-placeholder {
  font-style: normal !important;
}
::-moz-placeholder {
  font-style: normal !important;
}
::placeholder {
  font-style: normal !important;	
}

/* ~~ Bild & Text / Galerie & Logo ~~ */
.floatblock, .galeriefloatblock {
	display: block;
	margin-bottom: 25px;
}
.floatblock .galeriebox {
	display: block;
}
.galeriefloatblock {
	display: block;
	margin: 0 -5px 25px;
}
.galeriefloatblock .galeriebox, .galeriefloatblock .logobox {
	display: inline-table;
	width: 49%;
	padding: 0 5px;
	vertical-align: middle;
}
.logobox img {
	margin: 0;
}
.galeriebox a {
	display: block;
}
.galeriebild {
	max-width: 350px;
    margin: 0 auto 10px;
}
.galeriebild img {
    opacity: 0;
    filter: alpha(opacity=0);	
	transition: all 0.5s ease;
	margin: 0;
	padding: 0;
}
.galeriebox a img:hover {
    opacity: 1.0;
    filter: alpha(opacity=100);
}
.text {
	display: block;
	text-align: center;
}
.text h3 {
	font-size: 150%;
}
.logobox img {
	-webkit-transition: -webkit-transform 0.2s ease-out;
	-moz-transition: -moz-transform 0.2s ease-out;
	-o-transition: -o-transform 0.2s ease-out;
	-ms-transition: -ms-transform 0.2s ease-out;
	transition: transform 0.2s ease-out;
}
.logobox img:hover {
	-webkit-transform: scale(0.95);
	-moz-transform: scale(0.95);
	-o-transform: scale(0.95);
	-ms-transform: scale(0.95);
	transform: scale(0.95);
}
/* ~~ Google Kalender ~~ */
.kalender {
	  overflow: auto;
}

/* ~~ Fusszeile ~~ */
.footer {
	padding: 10px 0 0;
	font-size: 90%;
}
.footer .container .flex {
	display: -webkit-flex;
 	display: flex;
	flex-wrap: wrap;
  	justify-content: flex-start;
	margin: 0 -20px;
}
.footerbox {
    width: 100%;
	padding: 20px;
	overflow: hidden;
}
.footerbox:last-of-type {
    text-align: right;
}
.footer a{
	text-decoration: none;
}
.footer a:hover, .footer a:active, .footer a:focus { 
	text-decoration: underline;
}
.footer p { 
	margin-bottom: 10px;
}
.footer li { 
	list-style: none;
}
.ccm-block-social-links {
	font-size: 150%;
}

/* ~~ Verschiedene float/clear-Klassen ~~ */
.fltrt {
	float: right;
	margin-left: 8px;
}
.fltlft {
	float: left;
	margin-right: 8px;
}
.clearfloat { 
	clear:both;
	height:0;
	font-size: 1px;
	line-height: 0px;
}
@media (min-width: 600px) {	

/* ~~ Seitenliste ~~ */
.ccm-block-page-list-page-entry-grid-item {
    width: inherit !important;
	flex-basis: calc(50%);
	flex: 0 0 calc(50%);	
}
}
@media (min-width: 920px) {	
/* ~~ Flex Mehrfarbenboxen~~ */
.flex.farbbox.drei .item {
	flex-direction: column; 
}
.flex.farbbox.drei.aussen .item {
	width: calc(50% - 10px);
	margin: 5px;
}	
.flex.vier.aussen .item:nth-of-type(4n + 2), .flex.zwei.aussen .item:nth-of-type(4n + 2) {
	flex-direction: row-reverse;
}
.flex.vier.aussen .item:nth-child(4n + 4), .flex.zwei.aussen .item:nth-child(4n + 4) {
	flex-direction: row-reverse;
}
.flex .item.zwei .bild, .flex .item.vier .bild, .flex .item.bildtext .bild, .flex .item.zwei .textbox, .flex .item.vier .textbox, .flex .item.bildtext .textbox {
	width: calc(50% - 10px);
	margin: 5px;
	display: -webkit-flex;
 	display: flex;
}
.flex.farbbox .item.zwei .textbox, .flex.farbbox .item.vier .textbox  {
	aspect-ratio: 4 / 3;
}
.reverse .item  {
	flex-direction: row-reverse;
}	
.flex.vier.aussen.reverse .item:nth-of-type(4n + 2), .flex.zwei.aussen.reverse .item:nth-of-type(4n + 2) {
	flex-direction: row;
}
.flex.vier.aussen.reverse .item:nth-child(4n + 4), .flex.zwei.aussen.reverse .item:nth-child(4n + 4) {
	flex-direction: row;
}	
/* ~~ Seitenliste Kachelbox~~ */
.auswahl {
	flex: 0 0 calc(25%);
}	
}
@media (min-width: 1000px) {	
.inhaltlinks {
	clear: both;
	max-width: 800px;
}
.inhaltrechts {
	float: right;
	max-width: 800px;
	text-align: right;
}

/* ~~ Bild & Text / Galerie & Logo ~~ */
.floatblock {
	display: table;
	margin-bottom: 25px;
}
.floatblock .galeriebox {
	display: table-cell;
	vertical-align: middle;
	width: 26%;
	padding-right: 2%;	
}
.galeriefloatblock {
	display: table;
	margin: 0 -5px 25px;
}
.galeriefloatblock .galeriebox, .galeriefloatblock .logobox {
	display: table-cell;
	vertical-align: middle;
	width: 25%;
}
.text {
	display: table-cell;
	vertical-align: middle;	
	width: 75%;
	padding-left: 2%;
	text-align: left;	
}
/* ~~ Fusszeile ~~ */
.footer {
	padding: 10px 0;
	font-size: 90%;
}
.footer .container .flex {
	display: -webkit-flex;
 	display: flex;
	flex-wrap: wrap;
  	justify-content: flex-start;
	margin: 0 -20px;
}
.footerbox {
    width: 33.333%;
	padding: 20px;
	overflow: hidden;
}
/* ~~ Seitenliste ~~ */
.ccm-block-page-list-page-entry-grid-item {
    width: inherit !important;
	flex-basis: calc(25%);
	flex: 0 0 calc(25%);	
}
/* ~~ Gallery ~~ */
.ccm-block-gallery a {
  	width: 33.333%;
}
}
@media (min-width: 1200px) {
/* ~~ Kopfbereich ~~ */
.header {
	position: fixed;
	width: 100vw;
}
/* ~~ Navigation ~~ */
.navigationmobile {	
	display: none;
}
.navigation.desktop {	
	display: block;
	position: relative;
	margin: 15px auto 0;
	overflow: visible;
}	
.sliderbox {;
	padding-top: 75px;
	min-height: 50px;
}	
/* ~~ Flex Mehrfarbenboxen~~ */	
.flex.farbbox.drei.aussen .item {
	width: calc(33.333% - 10px);
}
}
@media (min-width: 1300px) {	
/* ~~ Slider~~ */
.ccm-image-slider-inner ul.rslides {
	height: 70vh;
}
.ccm-image-slider-inner ul.rslides li {
	height: 70vh;
}	
/* ~~ Flex Mehrfarbenboxen~~ */
.aussen {
	margin-left: -5%;
	margin-right: -5%;
	width: 110%;
}
/* ~~ Gallery ~~ */
.ccm-block-gallery a {
  	width: 25%;
}
}
@media (min-width: 1400px) {	
/* ~~ Flex Mehrfarbenboxen~~ */
.aussen {
	margin-left: -10%;
	margin-right: -10%;
	margin-bottom: 40px;
	width: 120%;
}
.flex.farbbox.vier .item {
	width: 50%;
}	
.flex.farbbox.vier .item .bild, .flex.farbbox.vier .item .textbox {
	aspect-ratio: 1 / 1;
}
.flex.farbbox.vier .item .bild img {
	max-width: none;
	height: 100%;
	width: 100%;
	object-fit: cover;
	object-position: center;	
}	
.flex.farbbox.vier.aussen .item:nth-of-type(4n + 2) {
	flex-direction: row;
}
.flex.farbbox.vier.aussen .item:nth-of-type(4n + 3) {
	flex-direction: row-reverse;
}
.flex.farbbox.vier.aussen .item:nth-of-type(4n + 4) {
	flex-direction: row-reverse;
}
.flex.farbbox.vier.aussen.reverse .item:nth-of-type(4n + 2) {
	flex-direction: row-reverse;
}
.flex.farbbox.vier.aussen.reverse .item:nth-of-type(4n + 3) {
	flex-direction: row;
}
.flex.farbbox.vier.aussen.reverse .item:nth-of-type(4n + 4) {
	flex-direction: row;
}		
}
@media (min-width: 1500px) {	
/* ~~ Flex Mehrfarbenboxen~~ */
.aussen {
	margin-left: -15%;
	margin-right: -15%;
	width: 130%;
}
}
@media (min-width: 1600px) {	
/* ~~ Flex Mehrfarbenboxen~~ */
.aussen {
	margin-left: -20%;
	margin-right: -20%;
	width: 140%;
}
}	