/*
 * Theme Name: Wootstrap BS5
 * Theme URI: http://mehne.biz
 * Description: Template von Kai Meinhardt. Keine Kopien erlaubt. Von niemandem. :-)
 * Author: Kai Meinhardt
 * Author URI: http://mehne.biz
 * Version: 5.3.2
 * Template Version: 5.3.2-2022-05-12
 * Text-Domain: web-definer
 *
 */

/*
 * Copyright (C) Kai Meinhardt (mehne.biz) - All Rights Reserved
 * Unauthorized copying of this file, via any medium is strictly prohibited
 * Proprietary and confidential
 * Written by Kai Meinhardt <info@mehne.biz>, 2016 - 2022
 */

/* kleiner reset */
*:focus,
.btn.active.focus,
.btn.active:focus,
.btn.focus,
.btn:active.focus,
.btn:active:focus,
.btn:focus,
button:focus {
	outline: none;
	box-shadow: none;
}


html {
	font-size: 10px;
	line-height: 1.667em;
}

/* Safari Problem mit horizontalem Scrollen */
html, body {
	max-width: 100vw;
	overflow-x: hidden;
}
/**/


body {
	/***/
	--main-color: var(--wp--preset--color--orange);
	--main-typo-color: var(--wp--preset--color--typograu);
	--main-font-size: 1.5rem;

		
	margin: 0;
	padding: 0;
	font-family: 'Comfortaa', Arial, sans-serif !important; /*  */
	/* font-family muss important sein für überschriften da diese in type.css von BS sonst überschrieben werden */
	font-weight: 300;
	color: #000;


	background-color: #fff;
	overflow-x: hidden;
	/**/
	--max-site-width: 1200px;

	font-size: var(--main-font-size);

	--main-line-height: 2.053em;
	line-height: var(--main-line-height);

	opacity: 1;
	transition: opacity 1.4s ease-in-out;
}

@media (min-width: 992px) {
	body {
		--main-font-size: 1.7rem;
		font-size: var(--main-font-size);;
		line-height: var(--main-line-height);
	}
}

/* Arno Anfang (weitere an den entsprechenden Stellen */

p, main ol li, main ul li {
	hyphens: auto;
}
div.a {hyphens: none;}

.mindestbreiteschnellzugriff {min-width: 33rem !important;}
.wpcf7-checkbox .wpcf7-list-item { margin: 15px auto;} /* damit sich Checkboxen in den grauen Formularen am Raster ausrichten */

.wp-block-table td {padding-right: 1.4rem;}
.bg-orange p {font-variant: bold;}

.wp-block-table td, .wp-block-table th {border: 0px !important;} /* stand irgendwann im November plötzlich in der style.min als 1px ??? */
.tabelle-ohne-hg table > tbody > tr:nth-of-type(2n+1) > * {
    background-color: transparent;
}
.tabelle-ohne-hg table > tbody > tr >td:first-child {
	padding-left: 0;
}
.tabelle-ohne-hg td {vertical-align: top;}

.tabelle-mit-hg table > tbody > tr:nth-of-type(n) > * {
	background-color: var(--bs-table-striped-bg);
}

.kopfzeilegrau th {background-color: var(--wp--preset--color--dunkelgrau) !important;}
.flachezeilen td, .flachezeilen th {padding-top: 0px; padding-bottom: 0px;}

.linkespalteklein table > tbody > tr >td:first-child {width: 35%;}
.linkespalte15 table > tbody > tr >td:first-child {width: 15%; min-width: 7em;}
.rechtespalteklein table > tbody > tr >td:last-child {width: 35%;}

.bg-dunkelgrau .tabelle-ohne-hg tbody {background-color: transparent; color: white;}
.fieldset-cf7mls p {margin-bottom: 0px;} /* damit in Formularen die Spalten sauber übereinanderstehen und mobil beim übereinanderklappen nicht zuviel Abstand haben, da in einer Spalte alle Elemente tw. in einem einzigen p sitzen */

.wp-block-image a:hover {filter: brightness(87%);}

.weisser-text {color: white;}

table a:hover img {opacity: 0.85;}

.wpcf7-list-item {display: block !important; width: 100% !important;}


/* Arno Ende */

p {
	line-height: var(--main-line-height); /* irgendwie klappt sonst das inline-verändern von schriftgrößen nicht */
	margin-bottom: 1rem;
}

@media(max-width:767px) {
	p {
		-moz-hyphens: auto;
		-webkit-hyphens: auto;
		-ms-hyphens: auto;
		hyphens: auto;
	}
}


b, strong {
	font-weight: 900;
}


/* BS5 reset */
/* verursacht mobil einen rand - der ist aber bei bildern nicht gewollt bei vielen Kunden
bei anderen seiten schon weil es die lesbarkeit verbessert mit mehr rand */

.row {
	--bs-gutter-x: 15px!important;
}
@media (max-width:991px) {
	/* den verursachten rand muss ich anders beheben, da sonst der abstand einfach wirklich viel zu gering ist */
	.row {
		margin-right: calc(-1 * var(--bs-gutter-x));
		margin-left: calc(-1 * var(--bs-gutter-x));
	}

	.row > * {
		
		padding-right: var(--bs-gutter-x);
		padding-left: var(--bs-gutter-x);

		/*
		padding-right: calc(var(--bs-gutter-x) * 1.5);
		padding-left: calc(var(--bs-gutter-x) * 1.5);
		*/
	}
}
@media (min-width:991px) {
	.row {
		--bs-gutter-x: 2.5rem!important;
	}
}


.container-fluid.max-width-true {
	max-width: var(--max-site-width);
}

/* GBO spezifisch */
.wp-block-web-definer-column-container {
	padding-left: max(2.4rem, 4%);
	padding-right: max(2.4rem, 4%);
}
.wp-block-web-definer-column-container .wp-block-web-definer-column-container {
	padding-left: 0;
	padding-right: 0;
	position: static;
}

@media (min-width: 992px) {

	.navbar, /* sehr spezielles gbo zeug */
	.wp-block-web-definer-column-container {
		padding-left: calc(3rem + 16px);
		padding-right: calc(3rem + 16px);
		position: relative;
	}

	.container-fluid.max-width-true {
		/*
		box-shadow: 0px 0px 20px 0px rgba(0,0,0,.5);
		clip-path: inset(0px -20px 0px -20px);
		*/
		/*
		box-shadow: 0px -20px 0px 0px #fff, 0px 20px 0px 0px #fff, 0px 0px 20px 0px rgba(0,0,0,.5);
		*/
		/*box-shadow: 0px 20px 20px 0px rgba(0,0,0,.85);*/
		/*box-shadow: 0px 21px 10px 12px rgba(0,0,0,.25);*//* schatten versuchen wir über grafik zu lösen*/
		background: #fff;

	}

	.container-fluid.max-width-true:before,
	.container-fluid.max-width-true:after {
		content: "";
		background-image: url(images/schatten.png);
		background-size: 16px 3px;
		opacity: .6;
		display: block;
		width: 16px;
		background-repeat: repeat-y;
		height: 100%;
		position: absolute;
		top: 0;
		right: 3rem;
	}

	.container-fluid.max-width-true:before {
		/*transform: rotate(180deg);*/
		background-image: url(images/schatten-links.png);
		left: 3rem;
	}


	/* GBO reset für nested */
	footer .container-fluid.max-width-true,
	.max-width-true .max-width-true {
		box-shadow: none;
		background: transparent;
	}

	.max-width-true .max-width-true:before,
	.max-width-true .max-width-true:after {
		content: normal;
		display: none;
	}

	.wp-block-web-definer-column-container > .max-width-true {
		padding-right: 0;
		padding-left: 0;
		margin-left: auto;
		margin-right: auto;

		overflow: hidden; /* da sonst bei justify-content:end die hintergrundfarbe das elternelement überlappt */
	}

	.h-100-recursive, .h-100-recursive * {
		height: 100%;
	}
	.h-100-recursive img {
		object-fit: cover;
	}
}
@media (min-width: 1290px) {
	.container-fluid.max-width-true:before {
		left: calc(50% - calc(var(--max-site-width) / 2) - 16px);
	}
	.container-fluid.max-width-true:after {
		right: calc(50% - calc(var(--max-site-width) / 2) - 16px);
	}
}
/**/

.navbar > .container, .navbar > .container-fluid, .navbar > .container-lg, .navbar > .container-md, .navbar > .container-sm, .navbar > .container-xl, .navbar > .container-xxl {
	display: block;
	padding-left: max(2.4rem, 4%);
	padding-right: max(2.4rem, 4%);
}

@media (min-width:992px) {
	.navbar > .container, .navbar > .container-fluid, .navbar > .container-lg, .navbar > .container-md, .navbar > .container-sm, .navbar > .container-xl, .navbar > .container-xxl {
		padding-right: var(--bs-gutter-x,.75rem);
		padding-left: var(--bs-gutter-x,.75rem);
	}
}


.container-fluid .container-fluid {
	padding-right: 0;
	padding-left: 0;
}

.is-content-justification-center > .container-fluid > .row {
	justify-content: center;
}
.is-content-justification-right > .container-fluid > .row {
	justify-content: right;
}


.modal-body {
	padding: 0;
}

img {
	max-width: 100%;
	height: auto;
}
img.img-responsive {
	width: 100%;
	height: auto;
}

.wp-block-image {
	margin: 0; /* WP reset */
}

.wp-block-embed figcaption,
.wp-block-video figcaption,
.wp-block-image figcaption {
	color: var(--main-color);
	font-size: 1.6rem;
	line-height: 1.4em;
	padding-left: 1em; /* Arno */
	padding-right: 1em; /* Arno */
	text-align: right; /* Arno */
}




/* wordpress klassen */
.alignright {
	float: right;
	margin-left: 15px;
	margin-bottom: 10px;
}

.alignleft {
	float: left;
	margin-right: 15px;
	margin-bottom: 10px;
}

.aligncenter {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

/**/
@media (max-width:992px) {
	.full-size-mobile,
	.full-size-mobile > .container-fluid {
		padding-left: 0;
		padding-right: 0;
	}
}

/* WP 6.2 reset */
body .is-layout-flex {
	align-items: normal;
}

/* bootstrap heading-reset */
h1,
h2,
h3,
h4,
h5,
h6 {
	margin: 0;
	font-weight: 400;
	font-family: "Comfortaa", Arial, sans-serif;
}
@media (max-width: 767px) {
	h1,
	h2,
	h3,
	h4,
	h5,
	h6 {
		-moz-hyphens: auto;
		-webkit-hyphens: auto;
		-ms-hyphens: auto;
		hyphens: auto;
	}
}

h1,
h1 a, h1 a:is(:hover, :focus, :active, :visited) {
	font-weight: 400;
	color: #000;
	font-size: 2.8rem;
	line-height: 1.2em;
	text-decoration: none;	
}
h1 { margin-bottom: 1.05rem; }

@media(min-width:992px) {
	h1,
	h1 a, h1 a:is(:hover, :focus, :active, :visited) {	
		font-size: 5rem;
		line-height: 1.2em;
	}
}


h2,
h2 a, h2 a:is(:hover, :focus, :active, :visited) {
	font-weight: 600;
	color: #000;

	font-size: 2.4rem;
	line-height: 1.3em;
	text-decoration: none;
}
h2 { margin-bottom: 1rem; }

@media(min-width:992px) {
	h2,
	h2 a, h2 a:is(:hover, :focus, :active, :visited) {
		font-size: 3.8rem;
		line-height: 1.3em;
	}
}


h3,
h3 a, h3 a:is(:hover, :focus, :active, :visited) {
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.3em;
	color: #000;
	position: relative;
	text-decoration: none;
}
h3 { margin-bottom: 1rem; }

@media (min-width: 992px) {
	h3,
	h3 a, h3 a:is(:hover, :focus, :active, :visited) {
		font-size: 2.8rem;
		line-height: 1.3em;
	}
}

/* unnötig für GBO
h1 + h2,
h2 + h3,
h1 + h3 {
	margin-top: -1rem;
}
*/


h4,
h4 a, h4 a:is(:hover, :focus, :active, :visited) {
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.3em;
	color: #000;
	text-decoration: none;
	position: relative;
}
h4 { margin-bottom: 1rem; }


@media (min-width: 992px) {
	h4,
	h4 a {
		font-size: 2rem;
	}
}


h5,
h5 a, h5 a:is(:hover, :focus, :active, :visited) {
	font-size: 1.6em;
	font-weight: 400;
	color: var(--main-typo-color);
	text-decoration: none;
	margin-bottom: .4em;
}


h6,
h6 a, h6 a:is(:hover, :focus, :active, :visited) {
	font-size: 1.167em;
	font-weight: 900;
	color: var(--main-typo-color);
}


p + h1,
p + h2,
p + h3,
p + h4,
p + ul,
ul + h1,
ul + h2,
ul + h3,
ul + h4,
p + ol,
ol + h1,
ol + h2,
ol + h3,
ol + h4,
p + blockquote,
blockquote + h1,
blockquote + h2,
blockquote + h3,
blockquote + h4,
.standard-block + .standard-block h2:first-of-type {
	margin-top: 2rem;
}


.btn-info a {
	position: relative;
}



/* Nur wenn Bootstrap-Slider verwendet wird: */
.carousel {
	/*overflow: hidden;*//* muss weg - sonst ist schatten aus .carousel-inner oben und unten abgeschnitten */
    margin: auto;
	z-index: 99;

	--vier-plus-siebenfuenf: calc(4% + 0.75rem);
	--zweivier-plus-siebenfuenf: calc(2.4rem + 0.75rem);
	padding-left: max(var(--zweivier-plus-siebenfuenf), var(--vier-plus-siebenfuenf));
	padding-right: max(var(--zweivier-plus-siebenfuenf), var(--vier-plus-siebenfuenf));
}
@media (min-width:1260px) {
	.carousel {
		padding-right: 3rem;
		padding-left: 3rem;
	}
}

.carousel.max-width-true {
	max-width: var(--max-site-width);
}

.carousel-inner {
	box-shadow: 0px 0px 13px 0px black;
}
@media (min-width:992px) { .carousel-inner { box-shadow: none;} }



.carousel-fade .carousel-item {
	transition: opacity 0.5s linear;
}

.carousel-inner .carousel-item > *,
.carousel-inner .carousel-item img,
.carousel-inner .carousel-item > a img {
	width: 100%;
	margin: auto;
	object-fit: cover;
	/*individuell*/
	min-width: 100%;
	max-height: 90vh; /*  Arno 70vh */
	object-position: center center;
}


.carousel-item .wp-block-video,
.carousel-item .is-type-video {
	display: flex;
    align-items: center;
    justify-content: center;
}

.carousel-item video,
.carousel-item .is-type-video * {
	width: 100%;
	height: 100%; 
}

/* nur wenn font awesome icon genutzt wird nötig */
/*
.carousel-control-prev i,
.carousel-control-next i {
	font-size: 2.5rem;
	opacity: 0.6;
}
@media(min-width:992px){
	.carousel-control-prev i,
	.carousel-control-next i {
		font-size: 6.8rem;
	}
}
*/
/* ende nur wenn font awesome icon genutzt wird nötig */

.carousel-control-prev,
.carousel-control-next {
	width: 10%;
}

.carousel-control-next-icon,
.carousel-control-prev-icon {
	width: 6rem;
	height: 6rem;
}


.carousel-indicators {
	bottom: 15px;
    margin-left: auto;
    margin-right: auto;
    width: 100%;

	display: none;
}

.carousel-indicators li {
	background-color: #fff;
	height: 12px;
	width: 12px;
	margin-left: 4px;
    margin-right: 4px;
	border-radius: 50%;
}

.carousel-indicators li.active {
	background-color: var(--main-color);
}

.carousel-caption {
	font-size: 1.8rem;
	line-height: 1.364em;
	font-weight: 400;
	color: var(--wp--preset--color--dunkelgrau);
	text-align: left;
	
	position: absolute;
	top: 0;
	left: 0;
    right: 0;
	bottom: 0;

	width: 100%;
	margin: 0;
	padding: 5% 0 0 0;
}


@media (min-width: 768px) {
	.carousel-caption {	
		font-size: 2rem;
	}
}
@media (min-width: 992px) {
	.carousel-caption {
		max-width: calc(100vw - 60px);
		margin-left: auto;
		margin-right: auto;
	}
}

@media (min-width: 1660px) {
	.carousel-caption {
		max-width: var(--max-site-width);
	}
}

.carousel-caption a,
.carousel-caption a:is(:hover, :focus, :active, :visited) {
	text-decoration: none;
}



.slider-headline {
	font-weight: 800;
	font-size: 2.5rem;
	line-height: 1.1em;

	border: 0;
    width: calc(100% - 20%); /* 100% abzüglich Platz für Pfeile */
    border-radius: 0;

	margin: auto;
	padding: 20px 20px 0 20px;
	
	background-color: #fff;
}
.slider-headline::first-line {
	font-weight: 300;
}

@media (min-width: 768px) {
	.slider-headline {
		font-size: 6rem;
		width: calc(75% - 20%); /* 100% abzüglich Platz für Pfeile */
		padding: 20px 90px 0 20px;
		margin: 0;
	}
}

.slider-subline {
	width: calc(100% - 20%);
	padding: 0 10px 20px 20px;
	margin: auto;

	background-color: #fff;
	hyphens: auto;
}
@media (min-width: 768px) {
	.slider-subline {
		display: block;
		width: calc(75% - 20%); /* 100% abzüglich Platz für Pfeile */
		padding: 0 90px 20px 20px;
		margin: 0;
		hyphens: none;
	}
}
/* Ende Bootstrap Slider */

/* Anpassungen individuell für ??? Seite */
.page-header {
	border: 0;
	padding-bottom: 0;
	margin-top: 0px; /* BS reset */
	margin-bottom: 0px; /* BS reset */
	width: 100%; /* for position-fixed cases */
	position: relative;
	z-index: 9970;

	box-shadow: none;
	/*overflow: hidden;*/
}


.navbar {
	/* BS5 resets */
	background-color: transparent;
	padding-top: 0;
	padding-bottom: 0;
}

@media (min-width:992px) {
	.navbar {
		background-color: transparent;
	}
}

.navbar > .row {
	width: calc(100% + 30px);
}

/* mobiler Button */
.navbar-toggler {
	background-color: transparent;
	border: 0px;
	border-radius: 0px;
	padding-right: 2rem;
}

.navbar-toggler:focus,
.navbar-toggler:hover {
	background-color: transparent;
	box-shadow: none; /* BS5 reset */
}

.navbar-toggler .navbar-toggler-icon {
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28112, 112, 111, 1%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='4' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
	width: 100%;
	height: 100%;
	background-position: center top 60%;

	max-width: 40px;
}




/* Ende mobiler Button */
.navbar-brand {
	/* bootstrap resets */
	line-height: 100%;
	height: auto;
	/* individuell */
	display: block;
	max-width: 100%; /* damits nicht über rahmen ragt */
	width: 169px; 
	padding: 35px 0 40px 2.4rem;
}
@media (min-width:992px) {
	.navbar-brand {
		width: 149px;
		padding: 10px 0 20px 0;
	}
}
@media (min-width:1200px) {
	.navbar-brand {
		width: 169px;
		padding: 84px 0 20px 0;/* die 84 bei margin top weil es auf der karriereseite keinen mitgliederbereich gibt */
	}
}

.logo {
	display: block;
	
	text-indent: 0px;
	width: 100%;
	height: 100%;
	object-fit: contain;
	/* individuell */
	width: 100%; /* weil navbar brand die größe vorgibt*/
}




.navbar-collapse {
	position: absolute;
	width: calc(100%);
	z-index: 100;

	/* individuell */
	left: 0; /*wegen fixer navbar - sonst hängt menü nicht links */
	top: 100%; /*wegen fixer navbar - sonst hängt menü am oberen bildschirmrand*/
	background-color: rgba(0,0,0,.8);
	padding-bottom: 15px;
}



@media (min-width: 992px) {
	.navbar-collapse {
		position: static;
		width: auto;
		padding: 0;
		/* individuell */
		background-color: transparent;
		padding-bottom: 0;
	}
}



/* Menü - Ebene 1 und tiefer */
.wp-block-navigation-item a, 
.nav > li a {
	color: #fff;
	font-size: 1.8rem;
	line-height: 1em;
	font-weight: 400;

    text-transform: none;
	text-decoration: none;

	display: block;

	padding-top: 8px;
	padding-bottom: 8px;
	padding-left: 20px;
	padding-right: 20px;

}

@media (min-width: 992px) {
	.wp-block-navigation-item a, 
	.nav > li a {
		color: #000;
		font-size: 1.9rem;
		font-weight: 700;
		text-align:center;

		background: transparent;

		padding-top: 0px;
		padding-bottom: 0px;
		padding-left: 10px;
		padding-right: 10px;

		
	}
}
@media (min-width: 1200px) {
	.wp-block-navigation-item a, 
	.nav > li a {
		padding-left: 15px;
		padding-right: 15px;
	}
}

/* Menü - Ebene 1 */
.wp-block-navigation-item > a, 
.nav > li > a {
	font-size: 2.5rem;
}

.wp-block-navigation-item a:is(:hover, :focus), /* since WP5.9 */
.nav > li.current-menu-item > a,
.nav > li.current-menu-parent > a,
.nav > li.current-menu-ancestor > a,
.nav > li > a:focus,
.nav > li > a:hover,
.nav .show > a,
.nav > li:focus > a:not([href]):not([tabindex]),
.nav > li:hover > a:not([href]):not([tabindex]) {
	/*reset*/
	text-decoration: none;
	position: relative;
	/*individuell*/
	font-weight: 400;
	color: var(--main-color);
	font-size: 2.5rem;
}



@media (min-width: 992px) {
	#main-nav {
		padding-top:6px;
	}
	.nav > li {
		/*flex: 1 1 auto !important;*/ /* verteilt menüpunkte je nach platz */
		flex: 0 1 auto !important; /* verteilt menüpunkte nicht - padding im a nötig */
	}

	/* nur nötig wenn flex nicht 1 1 auto */
	.wp-block-navigation-item:last-child a, 
	.nav > li:last-child a {
		padding-right: 0px;
	}
	/**/
	
	.nav > li > a {
		font-weight: 700;
		font-size: 2rem;
	}

	.nav > li.current-menu-item > a,
	.nav > li.current-menu-parent > a,
	.nav > li.current-menu-ancestor > a,
	.nav > li > a:focus,
	.nav > li > a:hover,
	.nav .show > a,
	.nav > li:focus > a:not([href]):not([tabindex]),
	.nav > li:hover > a:not([href]):not([tabindex]) {
		font-weight: 700;
		font-size: 2rem;
	}

}

@media (min-width:1200px) {
	#main-nav {
		padding-top:0px;
	}

	.nav > li.current-menu-item > a,
	.nav > li.current-menu-parent > a,
	.nav > li.current-menu-ancestor > a,
	.nav > li > a:focus,
	.nav > li > a:hover,
	.nav .show > a,
	.nav > li:focus > a:not([href]):not([tabindex]),
	.nav > li:hover > a:not([href]):not([tabindex]),
	.nav > li > a {
		font-size: 2.21rem;
	}
}


.menu-item-has-children {
	cursor: pointer;
	position: relative; /*for position of menu level 3*/
	background: transparent; /*mobile*/
}

.dropdown-toggle::after {
	/* BS4 reset*/
	display: none;
}

/* Untermenüs */

/* ============ ab BS5 Hauptmenü auch bei hover zeigen ============ */
@media all and (min-width: 992px) {
	.navbar .menu-item>.dropdown-menu{ display: none; }
	.navbar .menu-item:hover>.dropdown-menu{ display: block; }
}	
/* ============ desktop view .end// ============ */


.wp-block-navigation:not(.has-background) .wp-block-navigation__submenu-container, /* neuer WP5.9 selektor */
.dropdown-menu[data-bs-popper], /*neuer bs5 selektor */
.dropdown-menu {
	/*resets*/
	list-style: none;
	padding: 0;
	margin: 0;
	border: 0;
	border-radius: 0;
	font-size: 100%;

	/*mobile*/
	width: 100%;
	background-color: transparent;
	padding: 0 0 0 40px;

	/* WP5.9 reset */
	left: 0 !important;

}

@media (min-width: 992px) {
	.dropdown-menu[data-bs-popper],
	.dropdown-menu {
		white-space: nowrap;
		top: 100%;
		font-size: 0;

		padding: 10px 15px 10px 19px; /* letztes Arno - Original 15 */
		background-color: rgba(0,0,0,.8);

		border-top: solid 12px transparent; /* px Arno - Original 20 */

		width: auto;
	}

}


/*
.wp-block-navigation :where(.wp-block-navigation__submenu-container) .wp-block-navigation-item__content,
.dropdown-menu li a {
	color: var(--main-typo-color);
	background-color: #fff;
	font-weight: 200;
	text-transform: uppercase;
}
*/
.dropdown-menu li.current-menu-item > a,
.dropdown-menu li.current-menu-parent > a,
.dropdown-menu li.current-menu-ancestor > a,
.dropdown-menu li > a:focus,
.dropdown-menu li > a:hover,
.dropdown-menu .show > a,
.dropdown-menu li:focus > a:not([href]):not([tabindex]),
.dropdown-menu li:hover > a:not([href]):not([tabindex]) {
	color: var(--main-color);
	background-color: transparent;
}


@media (min-width: 992px) {

	.wp-block-navigation :where(.wp-block-navigation__submenu-container) .wp-block-navigation-item__content,
	.dropdown-menu li a {
		color: #fff;
		padding: 8px 0;
		text-align: left;
	}

	.dropdown-menu li.current-menu-item > a,
	.dropdown-menu li.current-menu-parent > a,
	.dropdown-menu li.current-menu-ancestor > a,
	.dropdown-menu li > a:focus,
	.dropdown-menu li > a:hover,
	.dropdown-menu .show > a,
	.dropdown-menu li:focus > a:not([href]):not([tabindex]),
	.dropdown-menu li:hover > a:not([href]):not([tabindex]) {
		/*individuell*/
		color: var(--main-color);
		background-color: transparent;
	}
}



/* Menü dritte ebene */
.dropdown-menu .dropdown-menu li::before {
	display: inline;
	color: var(--main-color);
	padding-right: 10px;
}
@media (min-width: 992px) {.dropdown-menu .dropdown-menu li::before {display: none;}}


.dropdown-menu .dropdown-menu li a {
	font-weight: 200;
	text-transform: none;
	letter-spacing: 0;
}

/* end menü dritte ebene */




/* polylang custom stuff */
/*
.pll-switcher {
	max-width: 100%;
}


.pll-switcher .btn {
	padding: 0;
	width: 100%;
	background:transparent;
}

.pll-switcher .btn img {
	width: 55px;
}


.pll-switcher .dropdown-menu {
	left: auto;
	right: 0;
	min-width: 170px;
	background-color: var(--main-color);
	background-image: none;
    border-radius: 4px;
}

.lang-item a img {
    margin-right: 10px;
}


.pll-switcher .dropdown-menu li a {
	display: flex;
	align-items: center;
	padding: 8px 16px 0px 8px;
	background-color: transparent;
	color: #fff;
}
.pll-switcher .dropdown-menu li a img {
	width: 55px;
	height: auto;
}
*/
/* end polylang custom stuff */




/* Breadcrumb */
.breadcrumb {
	/* BS reset */
	background: none;
	padding: 0;
	/* individuell */
	font-weight: 600;
}

.breadcrumb > span:after {
	content: '>';
	display: inline-block;
	padding-left: 15px;
	padding-right: 15px;
}
.breadcrumb > span:last-child:after {
	content: normal;
}


/* MAIN */
main {
	/* für den parallax */
	position: relative;
	/* individuell */
	/*z-index: 9980;*/ /* mehr als header, damit schatten verschwindet*/
	/* is großer mist, weil dadurch das mobile menü unsichtbar ist und auch die untermenüs auf desktop*/
}



a,
a:is(:hover, :focus, :active, :visited) {
	color: var(--main-color);
	text-decoration: none;
	font-weight: inherit;
	text-decoration: underline;
}

/* Arno */
a:hover {color: var(--wp--preset--color--dunkelgrau);}


.post-password-form {
	margin-top: 35vh;
	margin-left: 15%;
}


/* LISTEN */

/* 2022 - ein neuer versuch ::marker zum laufen zu bringen */
/* geht noch nicht in safari version 14 - erst ab 15 und die haben viele noch nicht */
/* dieser teil kann später einfach getauscht werden also ::before wird zu ::marker */
main ul, main ol {
	padding-left: 8px; /* BS5 hat 20px aber das passt nur für OL nicht für UL */
}

main ol li,
main ul li {
	list-style-type: none;
	list-style-position: outside;
	padding-left: 2rem; /* Abstand zu den Aufzählungszeichen */
	/*margin-bottom: 1em;*/
}

main ol:not(.carousel-indicators) li::before {
	content: counter(list-item) ".";

	color: #000;
	font-size: inherit;
	font-weight: 400;

	text-align: right;
}

main ul:not(.slick-dots):not(.pagination):not(.blocks-gallery-grid):not(.pll):not(.tribe-events-sub-nav):not(.tribe-events-c-nav__list):not(.tribe-events-c-top-bar__nav-list):not(.google-visualization-tooltip-item-list) li::before {
	content: "";

	color: var(--main-color);
	font-size: inherit;
	font-weight: 700;

	background-image: url(images/ul.svg);
	background-repeat: no-repeat;
	background-size: 11.6px 22.8px; /* Arno - Original: 5.8px 11.4px */
	display: inline-block;
	width: 1.16rem; /* Arno - Original: 0.58rem */
	height: 2.28rem; /* Arno - Original:  11.4px */
	position: relative; top: 5px; /* Arno */
}
/* ENDE dieser teil kann später einfach getauscht werden also ::before wird zu ::marker */
/* diese anpassungen sind nötig weil sich before anders verhällt als marker und wir marker wegen safari nicht nehmen dürfen */
main ol:not(.carousel-indicators) li::before {
	margin-left: calc(-15px - 1rem);
	padding-right: 1rem;
}
@media (min-width:992px) {
	main ol:not(.carousel-indicators) li::before {
		margin-left: calc(-15px - 1rem);
		padding-right: 1rem;
	}
}
/* scheint für ul un ol unterschiedlich zu sein */
main ul:not(.slick-dots):not(.pagination):not(.blocks-gallery-grid):not(.pll):not(.tribe-events-sub-nav):not(.tribe-events-c-nav__list):not(.tribe-events-c-top-bar__nav-list):not(.google-visualization-tooltip-item-list) li::before {
	margin-left: calc(-2rem);
	padding-right: 2rem;
}
/**/

/* ENDE LISTEN */



main img {
	max-width: 100%;
	height: auto;
}

figure {
	max-width: 100%;
	margin: 0;
}

figure.h-100 > * {
	height: 100%;
}

.size-full:not(.is-resized),
.size-full:not(.is-resized) img {
	width: 100%;
}

figure.wp-block-image.h-100 img {
	object-fit: cover;
}



main .wp-caption-text {
	background: #fff;
	color: rgb(70, 70, 70);
	padding-bottom: 24px;
	padding-left: 28px;
	padding-right: 27px;
	font-size: 0.833em;
}


.img-round, .img-round img {
	border-radius: 50%; /* only works on square images */
}

.size-square {
	max-width: 370px;
	margin-left: auto;
	margin-right: auto;
}



.has-small-font-size,
.has-small-font-size a,
.editor-styles-wrapper .has-small-font-size, 
.editor-styles-wrapper .has-small-font-size a {
	font-size: 90%;
	text-decoration: none;
	font-weight: 300; /* individuell */
}

.has-huge-font-size,
.has-huge-font-size a,
.has-larger-font-size,
.has-larger-font-size a,
.editor-styles-wrapper .has-huge-font-size,
.editor-styles-wrapper .has-huge-font-size a,
.editor-styles-wrapper .has-larger-font-size,
.editor-styles-wrapper .has-larger-font-size a {
    font-size: 2rem;
	line-height: 1.4em;
	font-weight: 400;
	text-decoration: none;
}
@media(min-width:992px) {
	.has-huge-font-size,
	.has-huge-font-size a,
	.has-larger-font-size,
	.has-larger-font-size a,
	.editor-styles-wrapper .has-huge-font-size,
	.editor-styles-wrapper .has-huge-font-size a,
	.editor-styles-wrapper .has-larger-font-size,
	.editor-styles-wrapper .has-larger-font-size a {
		font-size: 4.2rem;
	}
}


/* Hintergründe */
.has-orange-background-color .container-fluid.max-width-true,
.bg-orange {
	background: var(--wp--preset--color--orange);
}

.bg-orange-versetzt {
	background: linear-gradient(180deg, transparent 0%, transparent 15px, var(--wp--preset--color--orange) 15.01px, var(--wp--preset--color--orange) calc(100% - 15.01px), #fff calc(100% - 15px))
}
@media (min-width:992px) {
	.bg-orange-versetzt {
		background: linear-gradient(180deg, transparent 0%, transparent 35px, var(--wp--preset--color--orange) 35.01px, var(--wp--preset--color--orange) calc(100% - 35.01px), #fff calc(100% - 35px))
	}
}

.bg-orange-rechts {
	background: linear-gradient(180deg, #fff 0%, #fff 15px, transparent 15.01px, transparent calc(100% - 15.01px), #fff calc(100% - 15px)), linear-gradient(90deg, transparent 0%, transparent 15%, var(--wp--preset--color--orange) 15.01%, var(--wp--preset--color--orange) 100%);
}
@media (min-width:992px) {
	.bg-orange-rechts {
		background: linear-gradient(180deg, #fff 0%, #fff 50px, transparent 35.01px, transparent calc(100% - 35.01px), #fff calc(100% - 35px)), linear-gradient(90deg, transparent 0%, transparent 50%, var(--wp--preset--color--orange) 51%, var(--wp--preset--color--orange) 100%);
	}
}



.has-dunkelgrau-background-color .container-fluid.max-width-true, 
.bg-dunkelgrau,
.bg-dunkelgrau-schatten { 
	background-color: var(--wp--preset--color--dunkelgrau);	
	color: #fff; 
}

.bg-dunkelgrau-schatten {	box-shadow: 5px 0px 20px 0px black; }
@media (min-width:992px) { .bg-dunkelgrau-schatten { box-shadow: none;} }


.has-dunkelgrau-background-color h1, 
.bg-dunkelgrau h1,
.bg-dunkelgrau-schatten h1 {
	color: var(--wp--preset--color--peach);
}
.has-dunkelgrau-background-color h2, 
.bg-dunkelgrau h2,
.bg-dunkelgrau-schatten h2 {
	color: #fff;
}

.has-dunkelgrau-background-color h3, 
.bg-dunkelgrau h3,
.bg-dunkelgrau-schatten h3,
.has-dunkelgrau-background-color h4, 
.bg-dunkelgrau h4,
.bg-dunkelgrau-schatten h4,
.has-dunkelgrau-background-color h5, 
.bg-dunkelgrau h5,
.bg-dunkelgrau-schatten h5 {
	color: #fff;
}

.has-dunkelgrau-background-color a, 
.bg-dunkelgrau a,
.bg-dunkelgrau-schatten a {
	color: var(--wp--preset--color--peach);
}


.bg-dunkelgrau-versetzt {
	background: linear-gradient(180deg, transparent 0%, transparent 15px, var(--wp--preset--color--dunkelgrau) 15.01px, var(--wp--preset--color--dunkelgrau) calc(100% - 15.01px), #fff calc(100% - 15px));
}
@media (min-width:992px) {
	.bg-dunkelgrau-versetzt {
		background: linear-gradient(180deg, transparent 0%, transparent 35px, var(--wp--preset--color--dunkelgrau) 35.01px, var(--wp--preset--color--dunkelgrau) calc(100% - 35.01px), #fff calc(100% - 35px));
	}
}

.bg-dunkelgrau-rechts {
	background: linear-gradient(180deg, #fff 0%, #fff 15px, transparent 15.01px, transparent calc(100% - 15.01px), #fff calc(100% - 15px)), linear-gradient(90deg, transparent 0%, transparent 50%, var(--wp--preset--color--dunkelgrau) 51%, var(--wp--preset--color--dunkelgrau) 100%);
}
@media (min-width:992px) {
	.bg-dunkelgrau-rechts {
		background: linear-gradient(180deg, #fff 0%, #fff 35px, transparent 35.01px, transparent calc(100% - 35.01px), #fff calc(100% - 35px)), linear-gradient(90deg, transparent 0%, transparent 50%, var(--wp--preset--color--dunkelgrau) 51%, var(--wp--preset--color--dunkelgrau) 100%);
	}
}


.bg-hellgrau {
	background-color: #F1F1F1;
}


.bg-hellgrau-striped > *:nth-child(2n+2) {
	background-color: #F1F1F1;
}

/* Ende Hintergründe */


/* BUTTONS */
button {
	cursor: pointer;
}

button:focus {
	outline: none;
}

.btn {
	cursor: pointer;
	display: inline-block;
	text-decoration: none;
	max-width: 100%;
	text-align: center;
	border-radius: 0;
	font-weight: 400;
	border: none;
	font-size: inherit;

}

.w-100>.btn,
.wp-block-web-definer-bs5-button.w-100 .btn-primary {
	width: 100% !important;
}


/*

.btn-primary,
.btn-primary:hover,
.btn-primary:not(:disabled):not(.disabled):active,
.btn-primary:focus,
main a.btn-primary,
main a.btn-primary:not(:disabled):not(.disabled):active,
main a.btn-primary:hover,
main a.btn-primary:focus  {
	padding: 10px 25px;
	background: var(--wp--preset--color--dunkelgrau);
	color: #fff;
	border: 1px solid var(--wp--preset--color--dunkelgrau);
	font-weight: 400;
	font-size: 2.1rem;
}
*/
/* sind die ganzen klassen mit main noch nötig? */
.btn-primary,
.btn-primary:is(:hover, :focus, :active, :visited) {
	/* reset */
	text-decoration: none;

	/**/
	padding: 10px 12px;
	background: var(--wp--preset--color--dunkelgrau);
	color: #fff;
	border: 1px solid var(--wp--preset--color--dunkelgrau);
	font-size: 2.1rem;
	margin-bottom: .7em;
}

.alignright .btn-primary,
.text-end .btn-primary {
	text-align: right;
	margin-bottom: 0;
    padding-right: 18px;
}


.btn-secondary,
.btn-secondary:is(:hover, :focus, :active, :visited) {
	/* reset */
	text-decoration: none;

	/**/
	padding: 10px 12px;
	background: var(--wp--preset--color--orange);
	color: #fff;
	border: 1px solid var(--wp--preset--color--orange);
	font-size: 2.1rem;
	margin-bottom: .7em;
}





.text-semibold {
	font-weight: 600;
}

#fixed-sidebar {
	position: fixed;
	z-index: 99999;
    right: 0;
    top: 33%;
	overflow: auto;
	
	/*box-shadow:0 0 13px 8px rgba(109,111,111,.8);*/
	/*box-shadow:0 0 7px 0 rgba(109,111,111,.8);*/
	/*background-color: var(--main-color);*/
}



.social-icon {
	display: inline-block;
    margin: 15px;
}
    

.search-form-container {
	padding-top: 0;
	z-index: 1;
	width: auto;
}

input[type="search"].search-field {
	height: 43px;
    box-shadow: 0 0 7px 3px rgba(0,0,0,.27);
    border-radius: 0;
}
@media(min-width:768px){
	input[type="search"].search-field {
		height: 56px;
	}
}

.header-search input[type="submit"] {
	font-family: "Font Awesome 5 Free";
	font-size: 1.333em;
	font-weight: 900;
	padding: 7px;
    background: transparent;
    border: none;
    margin-left: -41px;
    border-radius: 4px;
    cursor: pointer;
    color: lightgray;
}


/* Allgemeine FORMS STYLES */

input[type="number"],
input[type="date"],
input[type="text"],
input[type="email"],
input[type="search"],
input[type="tel"],
input[type="password"],
select,
textarea,
.form-control, .form-select {
	display: block;
    max-width: 100%;
    padding: 15px 5px;
    height: auto;
    margin: 0;
    border: none;
    box-shadow: none;
    border-radius: 0px;

	font-size: var(--main-font-size);
	width: 100%;
	font-weight: 300;
}


input[type="checkbox"] {
	/*
	-webkit-appearance: none;
	-moz-appearance: none;*/
	/* appearance muss weg sonst sieht man keine haken in checkboxen etc.*/
	cursor: pointer;

	margin-right: 15px;

	border: 0;
	width: 32px;
	height: 32px;
	background-color: #fff;
}

label {
	width: 100%;
}

textarea {
	width: 100%;
}


@media(min-width:768px) { .form-group { margin-bottom: 2rem; } }

/* login form im frontend */
.login-username input[type="text"],
.login-password input[type="password"] {
	border: 1px solid #000;
}

/* contact form 7 */
.wpcf7-list-item {
	display: flex !important;
	width: 100%;
}

#wpcf7-f326-p579-o1 .wpcf7-checkbox .wpcf7-list-item,
.wpcf7-radio .wpcf7-list-item {
	display: inline-block; 
	width: 95px;
	/* margin: 0; Arno rausgenommen */
}
.wpcf7-radio .wpcf7-list-item input[type="radio"] {
	margin-right: 10px;
}

.wpcf7-list-item label {
	display: flex;
	align-items: flex-start;
	flex-wrap: nowrap;
	align-items: center;
}

/* verhindere multiples senden von mails indem button inactiv wird wenn gesendet */
.wpcf7-form.submitting .wpcf7-submit,
.wpcf7-form.sent .wpcf7-submit {
    pointer-events: none;
}

/* ENDE FORMS STYLES */



/* erstmal die infos zu pflichtfeld von oben nach unten */
.nf-form-layout > form > div {
	display: flex;
	flex-direction: column;
}
.nf-form-layout > form > div > .nf-before-form-content {
	order: 3;
	width: 100%;
	background-color: var(--wp--preset--color--orange);
	padding-left: 15px;
	padding-right: 15px;
}
.nf-form-layout > form > div > .nf-before-form-content nf-section {
	display: block;
	width: 100%;
	max-width: var(--max-site-width);
	margin: 15px auto 15px auto;

}

/**/

.nf-field {
	display: flex;
	flex-direction: row;

	width: 100%;
	max-width: var(--max-site-width);
	margin: auto;
}

nf-field > .nf-field-container,
nf-field > .field-wrap {
	display: flex;
	flex-flow: row wrap !important;
	flex: 1 1 auto;
	padding-left: 15px;
	padding-right: 15px;
}
@media (min-width:992px) {
	nf-field > .nf-field-container,
	nf-field > .field-wrap {
		padding-left: 0;
		padding-right: 0;
	}
}

.nf-field .table > :not(caption) > * > * {
	padding-left: 0;
}



/* reset */
#ninja_forms_required_items, .nf-field-container {
	margin: 0!important;
	padding-top: 45px;
	padding-bottom: 10px;
}
@media (min-width:992px) {
	#ninja_forms_required_items, .nf-field-container {
		padding-bottom: 50px;
	}
}


.list-checkbox-wrap .nf-field-element li::before, 
.list-image-wrap .nf-field-element li::before, 
.list-radio-wrap .nf-field-element li::before {
	content: normal;
	display: none;
}

/* Beschreibung soll rechts neben den feldern stehen */
.label-above .field-wrap, 
.label-hidden .field-wrap, 
.label-below .field-wrap { width: 100%;}



.zweispaltig .nf-field-description {
	order: 16!important;
	margin-top: 35px;
}
@media (min-width:992px) {
	.zweispaltig .nf-field-description {
		width: 41.6%!important;
		order: 2!important;

		margin-top: 0px;
	}
	
	.zweispaltig .nf-field-element {
		width: 25%!important;
		margin-right: 8.33% !important;
		order: 1!important;
	}
}



/* titel darüber */
.listcheckbox-wrap .nf-field-label {
	width: 100%;
	order: 0!important;

	font-weight: 700;
	color: var(--wp--preset--color--orange);

	font-size: 2.7rem;
	line-height: 3rem;
	text-decoration: none;

	margin-bottom: 1rem;
}

@media(min-width:992px) {
	.listcheckbox-wrap .nf-field-label {
		font-size: 4.7rem;
		line-height: 5.5rem;
	}
}

/* ENDE Beschreibung soll rechts neben den feldern stehen */

.nf-field-label label {
	margin-bottom: .5em !important;
}

.list-checkbox-wrap .nf-field-element li, 
.list-image-wrap .nf-field-element li {
	clear: both;
}

/* listen mit checkboxen bekommen rand */
.list-checkbox-wrap li {
	border-top: 1px solid #ecb664;
}
.list-checkbox-wrap li:last-child {
	border-bottom: 1px solid #ecb664;
}

.list-checkbox-wrap li input {
	margin-top: 12px !important;
	margin-bottom: 8px !important;
}
.list-checkbox-wrap li label {
	margin-top: 6px !important;
	margin-bottom: 8px !important;
}
/*********/





/* tabellen  */
.table, table {
	--bs-table-striped-bg: #f9efeb;
}

.table-bordered > :not(caption) > * {
	border-color: #ecb664;
	border-width: 1px 0px 1px 0px;
}

.table-bordered > :not(caption) > * > * {
	border-width: 0px;
}
/* gbo speziefisch */
table {
	width: 100%;
	margin-bottom: 1rem;
	color: #212529;
	vertical-align: top;
	border-color: #dee2e6;
}
table tr > th {
	padding: .5rem 1rem;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
	background-color: var(--wp--preset--color--dunkelgrau)!important;
	border-bottom-width: 1px;
	color: #fff;
  }

table > tbody > tr > td {
	padding-left: 1rem;
	padding-right: 1rem;
}

table > tbody > tr:nth-of-type(2n+1) > * {
	background-color: var(--bs-table-striped-bg);
}

/* abstand checkbox zu label */
.list-checkbox-wrap .nf-field-element li input, .list-checkbox-wrap .nf-field-element ul input, .list-image-wrap .nf-field-element li input, .list-image-wrap .nf-field-element ul input, .list-radio-wrap .nf-field-element li input, .list-radio-wrap .nf-field-element ul input {
	margin-right: 17px!important;
}
.list-checkbox-wrap .nf-field-element li label, .list-image-wrap .nf-field-element li label, .list-radio-wrap .nf-field-element li label {
	margin-left: 0!important;
}
/**/



/* fehler und hinweise */
.nf-after-field {
	width: 100%;
}
.nf-after-field>* {
	display: block;
}

.nf-after-form,
.nf-after-form-content {
	margin: auto;
	width: 100%;
	max-width: var(--max-site-width);
}

/* spezielle felder anpassen */



/*
 * end caldera / ninja forms
 */


blockquote {
	background-color: var(--wp--preset--color--dunkelgrau);
	padding: 35px 35px 25px 15px; /* Arno 45px 55px 40px 30px; */
	position: relative;
	/* WP5+ erzwingt word-break daher ergänzen wir wenigstens bindestriche */
	hyphens: auto;
}
@media (min-width:992px) {
	blockquote {
		padding: 65px 55px 55px 65px; /* Arno 85px 95px 80px 60px */
	}
}

blockquote:before {
	content: "";
	color: var(--wp--preset--color--gbograu);
	font-size: 45rem; /* Arno 65rem */
	position: absolute;
	top: 16px;
	left: 16px;
	display: block;
	width: 100px; /* Arno 150px */
	height: 106px; /* Arno 160px */
	background-image: url(images/blockquote.png);
	background-repeat: no-repeat;
	background-size: contain;
}

.wp-block-pullquote p,
.wp-block-pullquote.alignleft p, 
.wp-block-pullquote.alignright p, 
.wp-block-pullquote.has-text-align-left p, 
.wp-block-pullquote.has-text-align-right p,
blockquote p {
	color: var(--wp--preset--color--peach);
	font-size: 1.4rem; 
    line-height: 1.4em; 
	text-transform: uppercase;
	position: relative;
	margin-top: 0;
	margin-bottom: 1rem;
}
@media (min-width:992px) {
	.wp-block-pullquote p,
	.wp-block-pullquote.alignleft p, 
	.wp-block-pullquote.alignright p, 
	.wp-block-pullquote.has-text-align-left p, 
	.wp-block-pullquote.has-text-align-right p,
	blockquote p {
		font-size: 2.2rem; /* Arno 3.2rem */
		letter-spacing: 1px;
	}
}



.wp-block-pullquote.alignleft, 
.wp-block-pullquote.alignright, 
.wp-block-pullquote.has-text-align-left, 
.wp-block-pullquote.has-text-align-right {
	max-width: none;
}

cite {
	color: var(--wp--preset--color--gbograu);
	font-style: normal;
	font-size: 1em;
	text-transform: uppercase;
	letter-spacing: .05em;
	font-weight: 300;
	position: relative;
	display: block;
	text-align: right;
}


/* individual stuff */


.hide-if-open[aria-expanded=true] {
	display: none;
}

.wp-block-web-definer-read-more-toggle-with-preview {
	margin-bottom: 15px;
	position: relative;
}

.wp-block-web-definer-read-more-toggle-with-preview .nummerierung {
	font-weight: 700;
	font-size: 7rem;
	line-height: 7rem;
	color: var(--wp--preset--color--gbograu);

	position: absolute;
	top: 0;
	left: calc(var(--bs-gutter-x) * 0.5);
}
@media (min-width:992px) {
	.wp-block-web-definer-read-more-toggle-with-preview .nummerierung {
		font-size: 22.5rem;
		line-height: 22.5rem;
	}
}

.wp-block-web-definer-read-more-toggle-with-preview .col-12.col-lg-6:first-child {
	padding-top: 3.5rem;
}
@media (min-width:992px) {
	.wp-block-web-definer-read-more-toggle-with-preview .col-12.col-lg-6:first-child,
	.wp-block-web-definer-read-more-toggle-with-preview .col-12.col-lg-6 {
		padding-top: 11.25rem;
	}
}



/* ende individual stuff */


/* slick stuff */




.add-shadow .slick-track {
	padding-top: 15px;
    padding-bottom: 15px;
}

.slick-slider .slick-list {
	width: 100%; /* macht den slider volle breite auch wenn alle bilder viel zu schmal wären */
}

.slick-slide {
	padding-left: 15px; /* nötig für schlagschatten */
	padding-right: 15px; /* nötig für schlagschatten */
}

.no-shadow .slick-slide {
	padding-left: 0px; 
	padding-right: 0px; 
}


.slick-slide > * {
	background: #fff;
	border-radius: 4px;
	box-shadow: 0 0 7px 0px rgba(0,0,0,.27);

	
}
@media (min-width:576px) {
    .slick-slide > * {
        padding: 10px;
    }
    .slick-slider .slick-list {
        width: calc(100% + 20px);
        margin-left: -10px;
        margin-right: -10px;
    }
}

@media (min-width:992px) {
    .slick-slide > * {
        padding: 25px;
    }
    .slick-slider .slick-list {
        width: calc(100% + 50px);
        margin-left: -25px;
        margin-right: -25px;
    }
}



.no-shadow .slick-slide > * {
	border-radius: 0;
	box-shadow: none;
}



.slick-left,
.slick-right {
	display: inline-block;
	position: relative;
	top: 0%;
	transform: translateY(-50%);
	margin: 0;
	padding: 0;
	overflow: hidden;
    max-width: 100%;
	cursor: pointer;
	background: transparent;
	background-repeat: no-repeat;
	border: none;
	color: transparent;
	transition: all 0.3s ease-in-out;

	width: 40px; /* hängt von der pfeilgrafik ab */
	height: 50px; /* hängt von der pfeilgrafik ab */
	background-size: 40px 50px; /* hängt von der pfeilgrafik ab */
}
@media (min-width:576px) {
	.slick-left,
	.slick-right {
		top: 0%;
	
		width: 66px;
        height: 35px;
        background-size: 66px 35px;
        
	}
}


.slick-right {
	left: auto;
	right: 0;
    float: right;

	background-image: url(images/Pfeile_ZW.svg);
	background-position: right;
}
@media (min-width:576px) {
	.slick-right {
		right: 0;
	}
}
.slick-left {
	background-image: url(images/Pfeile_ZW.svg);
    transform: translateY(-50%) rotateZ(180deg);
}
@media (min-width:576px) {
	.slick-left {
		left: 0; 
	}
}



.slick-item img { width: 100%;}

/* end slick stuff */

/* individual slick stuff */
@media(min-width:1400px) {
	.bg-news .container-fluid,
	.wp-block-mehne-slick-slider .container-fluid {
		max-width: calc( ( (var(--max-site-width) * 100) / ( (10 / 12) * 100 ) ) + 30px ); /* 1476px */
	}
}

.slick-slider blockquote {

	color: var(--main-color);
	font-size: 1.7rem;
	line-height: 1.375em;
	font-style: italic;
	font-weight: 300;
	padding: 0;
}
@media(min-width: 768px) {
	.slick-slider blockquote {
		font-size: 1.8rem;
		line-height: 1.278em;
	}
}
@media(min-width: 992px) {
	.slick-slider blockquote {
		font-size: 2.2rem;
		line-height: 1.273em;
	}
}

.slick-slider blockquote:before {
    position: relative;
    content: "”";
	font-size: 145px;
	margin-top: -10px;
	margin-bottom: -65px;

    line-height: .9em;
	color: var(--main-color);
	font-weight: 500;
    width: auto;
	text-align: center;
	
	display: block;
	top: 0;
}
@media(min-width: 768px) {
	.slick-slider blockquote:before {
		font-size: 150px;
		margin-bottom: -55px;
	}
}
@media(min-width: 992px) {
	.slick-slider blockquote:before {
		font-size: 180px;
		margin-bottom: -75px;
	}
}

.slick-slider blockquote cite {
	color: var(--main-color);

	font-style: normal;
	font-size: 1.3rem;
	line-height: 1.3em;
	letter-spacing: 0;
	text-transform: none;
	font-weight: 400;
}

@media(min-width: 768px) {
	.slick-slider blockquote cite {
		font-size: 1.4rem;
	}
}
@media(min-width: 992px) {
	.slick-slider blockquote cite {
		font-size: 1.7rem;
	}
}


/* end individual slick stuff */

/* news slick slider stuff */


.news-post {
	padding: 0 15px 0 15px;
}

.news-post > * {
	padding:0;
}

.news-image {
	max-height: 200px;
	object-fit: cover;
	min-width: 100%;
}

/*@media(min-width:576px) { .news-image-container,.news-image-container img { height: 194px; } }*/
@media(min-width:768px) { .news-image { height: 200px; } }


.post-category {
	text-transform: uppercase;
	font-weight: 600;
    margin-bottom: .3em;
}


.news-post h1 {
	color: var(--main-color);
	font-size: 1.9rem;
	text-align: left;
	font-weight: 700;
}

@media(min-width:768px) {
	.news-post {
		font-size: 1.6rem;
	}

	.news-post h1 {
		font-size: 2rem;
	}
}

@media(min-width:768px) {
	.news-post {
		font-size: 1.7rem;
	}

	.news-post h1 {
		font-size: 2.1rem;
	}
}

/* end news slick slider stuff */

/* */
hr {
    margin-top: 0rem;
    margin-bottom: 0rem;
    border: 0 !important;
	border-top: 1px solid var(--main-color) !important;
	background-color: transparent;
}

.page-footer hr {
	border-color: #f7e1be!important;
	margin-bottom: 1rem;
}


/* BS4 Card (Accordeon / Aufklappkarten) */
.accordion {
	margin-bottom: 35px;
}

.card {
	border: 0;
	border-radius: 0px!important; /* bs muss übertrumpft werden */
	background-color: transparent;
	padding: 0;

	border-top: 2px solid #E7A287;
}

.wp-block-web-definer-card:last-child .card {
	border-bottom: 2px solid #E7A287;
}


.card-header {
	padding: 0;
	border: 0;
	border-radius: 0!important; /* bs muss übertrumpft werden */
	background-color: transparent;
}


.card-header h3 {
	margin: 0;
}

.card-header button {
	/* reset */
	width: 100%;
    border: 0;
    background: transparent;
	text-align: left;
}

.card-header h3 button {
	/* individuell */
	/*font-size: 1.3rem;*/
	line-height: 1.2em;
	color: #000;
	background-color: white;
	font-weight: 600;
	padding: 0;
	display: flex;
	align-items: center;
	padding: 12px 15px 12px 0px;
}
@media (min-width:992px) {
	.card-header h3 button {
		font-size: 2.5rem;
	}
}


.card-header h3 button[aria-expanded="true"] {
    background-color: white;
	color: #000;
}



.card-header h3 button[aria-expanded="true"] > span {
	flex: 1;
	background: transparent;
}


.card-header button:after {
	content: url(images/accordion-right.svg);

    display: inline-block;
    min-width: 14.5px;
    height: 36.1px;
    text-align: center;
    padding-top: 0;
    border-radius: 0;
    margin: 0px 0px 0px auto;

	transition: all .3s ease-out;
}
.card-header button[aria-expanded="true"]:after {
	transform: rotate(90deg);
	transition: all .3s ease-out;
}


.card-body {
	padding: 0 0 35px 0px;
	background-color: #fff;
}


.card-body > .wp-block-web-definer-column-container {
	padding-left: 10px;
}


/* 
 * ACCORDION VARIANTE 
 */

.accordion-variant .card {
	border: none;
}

.accordion-variant .card-header h3 button,
.accordion-variant .card-header h3 button[aria-expanded="true"] {
	background-color: transparent;
	color: inherit;

	font-size: 3.2rem;
	line-height: 1.1em;
}

.accordion-variant .card-header button:after {
	display: none;
}

.accordion-variant .card-body {
	background-color: transparent;
}

/* zählt mit und packt zahl an anfang der div */
.accordion-variant {
	counter-reset: accordionsection; 
}
.accordion-variant .wp-block-web-definer-card::before {
	counter-increment: accordionsection; 
	content: counter(accordionsection)".";

	font-size: 225px;
	font-weight: 700;
	color: #5C5C5C;

	position: relative;
	display: block;
	line-height: 225px;
	margin-bottom: -85px;
}



/**/


/*
 * Wordpress Gallery
 */
.wp-block-gallery img {
	align-self: center;
}

.blocks-gallery-grid .blocks-gallery-image, 
.blocks-gallery-grid .blocks-gallery-item, 
.wp-block-gallery .blocks-gallery-image, 
.wp-block-gallery .blocks-gallery-item {
	flex-grow: 0;
}
/*
.blocks-gallery-grid .blocks-gallery-item:nth-child(1n+10) {
	display: none;
}
*/
 
/* fancybox */
.fancybox-container {
	width: 95%; /* Arno 90% */
	height: 90%; /* Arno 80% */
	left: 2.5%; /* Arno 5% */
	right: 2.5%; /* Arno 5% */
	top: 5%; /* Arno 10% */
	bottom: 5%; /* Arno 10% */

	box-shadow: 0 0 13px 7px rgba(0,0,0,.27);
}

.fancybox-bg {
	background: #fff;
}

.fancybox-is-open .fancybox-bg {
	opacity: 1;
}

.fancybox-slide--image {
	padding: 3% 0 3% 0; /* Arno 7% 0 7% 0 */
}

.fancybox-button {
	background: transparent;
}

.fancybox-button,
.fancybox-button:link,
.fancybox-button:hover,
.fancybox-button:visited {
	color: var(--main-color);
}

.fancybox-navigation .fancybox-button {
	opacity: 1;
}

.fancybox-navigation .fancybox-button--arrow_left {
	left: 30px;
}
.fancybox-navigation .fancybox-button--arrow_right {
	right: 30px;
}

.fancybox-close-small {
	background: var(--main-color);
	color: #fff;
	opacity: 1;
	top: 0;
	right: 0;
}
@media(min-width:992px) {
	.fancybox-close-small {
		top: -44px;
		right: -44px;
	}
}


/* widgets in sidebar und footer */
li.widget {
	list-style: none;
}


/* Modales Fenster */
.modal-dialog-scrollable .modal-content {
	padding: 0 35px 35px 35px;
	background-color: rgba(0,0,0,.8);
	color: #fff;

	font-size: larger;
	font-weight: 700;
}

.btn-close {
	color: #fff;
}

.modal-header  {
	border: none;
}

/*
 * PAGINATION
 */
 .pagination {
	margin-bottom: 40px;
}

.pagination li:before {
	content: "";
	display: none;
}

/* standard-status */
.pagination li a,
.pagination > li.inactive > a:focus,
.pagination > li.inactive > a:hover,
.pagination > li.inactive > span:focus,
.pagination > li.inactive > span:hover {
	color: var(--main-color);
	font-weight: 600;
	background-color: #fff;
	border-color: #fff;
	margin-right: 3px;

	-webkit-box-shadow: none;
	-moz-box-shadow: none;
	box-shadow: none;

	padding: 0.9rem;
	text-align: center;
}

.pagination li.inactive a,
.pagination > li.inactive > a:focus,
.pagination > li.inactive > a:hover,
.pagination > li.inactive > span:focus,
.pagination > li.inactive > span:hover {
	cursor: default;
	color: var(--main-color);
}

/* hover-status */
.pagination > li > a:focus,
.pagination > li > a:hover,
.pagination > li > span:focus,
.pagination > li > span:hover {
	background-color: var(--main-color);
	border-color: var(--main-color);
	color: #fff;
	/*
	-webkit-box-shadow: 0 0 29px 5px rgba(0,255,77,.51);
	-moz-box-shadow: 0 0 29px 5px rgba(0,255,77,.51);
	box-shadow: 0 0 29px 5px rgba(0,255,77,.51);*/
}

/* active-status */
.pagination > .active > a,
.pagination > .active > a:focus,
.pagination > .active > a:hover,
.pagination > .active > span,
.pagination > .active > span:focus,
.pagination > .active > span:hover {
	background-color: var(--main-color);
	border-color: var(--main-color);
	color: #fff;
	cursor: pointer;
	
}

/* inactive-status */
.pagination .inactive a {
	pointer-events: none;
}



/* isotope masonry */
.isotope-grid-item {
	padding: 25px;
	display: flex;
	justify-content: space-around;
}




/* custom post type (CPT)
 * Bei GBO: "Angebote"
 */
.angebot {
	margin-bottom: 30px;
	
}
/*
@media (max-width:768px) {
	.angebote {
		
		padding-left: 0;
		padding-right: 0;
	}
}
*/










/* FOOTER */
.page-footer {
	position: relative;
	z-index: 9990; /* höher als main damit schatten nicht überlagert */

	background: linear-gradient(180deg, transparent 0%, transparent 15px, var(--wp--preset--color--dunkelgrau) 15.01px, var(--wp--preset--color--dunkelgrau) 100%);

	color: #fff;
	font-size: 1.0rem;
	line-height: 1.7em;
	font-weight: 400;

	padding: 0;
	margin: 0px;
}
@media (min-width:992px) {
	.page-footer {
		background: linear-gradient(180deg, transparent 0%, transparent 35px, var(--wp--preset--color--dunkelgrau) 35.01px, var(--wp--preset--color--dunkelgrau) 100%);
		font-size: 1.0rem;
		line-height: 1.7em;
	}
}


/*.page-footer .container-fluid.max-width-true { */
.page-footer-shadow {
	background-color: var(--wp--preset--color--dunkelgrau);
	box-shadow: 0px 0px 13px 0px black;
}
.page-footer .container-fluid.max-width-true .container-fluid { 
	box-shadow: none;
}
@media (min-width:992px) {
	.page-footer .container-fluid.max-width-true { 
		box-shadow: none;
	}
}


.page-footer a,
.page-footer a:is(:hover, :focus, :active, :visited) {
	color: #fff;
	text-decoration: none;
}


.page-footer h2 {
	font-weight: 400;
	color: #fff;
	font-size: 1.2rem;
	line-height: 1.7em;

	margin-bottom: .7em;
	letter-spacing: 0;
}

@media (min-width:992px) {
	.page-footer h2 {
		font-size: 1.2rem;
		line-height: 1.7em;
	}
}


.page-footer .menu {
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	list-style: none;
}

.page-footer .menu li::before{
	content: none;
}


.page-footer .menu > li a,
.page-footer .menu > li a:is(:hover, :focus, :active, :visited) {
	color: #fff;
	font-size: 1.2rem;
	line-height: 1.7em;
	text-transform: none;
	text-decoration: none;

	padding: 0;

	display: inline-block;
	margin-bottom: 10px;
}


/* ENDE FOOTER */


#scrolltop {
	position: fixed;
	bottom: 60px;
	right: 10%;
	cursor: pointer;

	background-image: url(images/bildmarke_klein_80x80px.svg);
	background-repeat: no-repeat;
	background-size: 80px 80px;
	width: 80px;
	height: 80px;
}





/* eigene Abstände */
.mb5 {
	margin-bottom: 5px;
}
.mb10 {
	margin-bottom: 10px;
}
.mb15 {
	margin-bottom: 15px;
}
.mb20 {
	margin-bottom: 20px;
}
.mb25 {
	margin-bottom: 25px;
}
.mb30 {
	margin-bottom: 30px;
}
.mb35 {
	margin-bottom: 35px;
}
.mb40 {
	margin-bottom: 40px;
}
.mb45 {
	margin-bottom: 45px;
}
.mb50 {
	margin-bottom: 50px;
}
.mb55 {
	margin-bottom: 55px;
}
.mb60 {
	margin-bottom: 60px;
}
.mb65 {
	margin-bottom: 65px;
}
.mb70 {
	margin-bottom: 70px;
}
.mb75 {
	margin-bottom: 75px;
}
.mb80 {
	margin-bottom: 80px;
}
.mb85 {
	margin-bottom: 85px;
}
.mb90 {
	margin-bottom: 90px;
}
.mb95 {
	margin-bottom: 95px;
}
.mb100 {
	margin-bottom: 100px;
}
.mb110 {
	margin-bottom: 110px;
}
.mb120 {
	margin-bottom: 120px;
}
.mb165 {
	margin-bottom: 165px;
}
.mb125 {
	margin-bottom: 125px;
}
.mb165 {
	margin-bottom: 165px;
}


/* seit BS 4 gibt es von Bootstrap Klassen für margin: */
/* https://getbootstrap.com/docs/4.1/utilities/spacing/ */

/**/
.pt5 {
	padding-top: 5px;
}
.pt10 {
	padding-top: 10px;
}
.pt15 {
	padding-top: 15px;
}
.pt20 {
	padding-top: 20px;
}
.pt25 {
	padding-top: 25px;
}
.pt30 {
	padding-top: 30px;
}
.pt35 {
	padding-top: 35px;
}
.pt40 {
	padding-top: 40px;
}
.pt45 {
	padding-top: 45px;
}
.pt50 {
	padding-top: 50px;
}
.pt55 {
	padding-top: 55px;
}
.pt60 {
	padding-top: 60px;
}
.pt65 {
	padding-top: 65px;
}
.pt70 {
	padding-top: 70px;
}
.pt75 {
	padding-top: 75px;
}
@media(min-width:768px) {
	.pt-md-75 {
		padding-top: 75px;
	}	
}