/* montserrat-200 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 200;
  src: url('fonts/montserrat-v31-latin-200.eot'); /* IE9 Compat Modes */
  src: url('fonts/montserrat-v31-latin-200.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('fonts/montserrat-v31-latin-200.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('fonts/montserrat-v31-latin-200.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
       url('fonts/montserrat-v31-latin-200.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
       url('fonts/montserrat-v31-latin-200.svg#Montserrat') format('svg'); /* Legacy iOS */
}
/* montserrat-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  src: url('fonts/montserrat-v31-latin-regular.eot'); /* IE9 Compat Modes */
  src: url('fonts/montserrat-v31-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('fonts/montserrat-v31-latin-regular.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('fonts/montserrat-v31-latin-regular.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
       url('fonts/montserrat-v31-latin-regular.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
       url('fonts/montserrat-v31-latin-regular.svg#Montserrat') format('svg'); /* Legacy iOS */
}
/* montserrat-500 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  src: url('fonts/montserrat-v31-latin-500.eot'); /* IE9 Compat Modes */
  src: url('fonts/montserrat-v31-latin-500.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('fonts/montserrat-v31-latin-500.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('fonts/montserrat-v31-latin-500.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
       url('fonts/montserrat-v31-latin-500.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
       url('fonts/montserrat-v31-latin-500.svg#Montserrat') format('svg'); /* Legacy iOS */
}


:root {
	--farbe1: #FFF;
	--farbe2: #86246b;
	--farbe3: #ebebeb; 
	--farbe4: #000;
	--farbe5: #acacac;
	--farbe6: #7accc8;
	--farbe7: #e6007e;
}


::selection {
	background: var(--farbe4);
	color: var(--farbe1);
}

/* -- Beispiel-Farbcodes: --
color: var(--farbe1);
background: var(--farbe2); */

/* -- Größe des Logos in der gescrollten Ansicht anpassen -- */
#header.scrolled .logo img, #header.mobile .logo img {
	width: 200px !important;
	height: auto !important;
}

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

html {
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
}

body {
	font-family: 'Montserrat', sans-serif;
	font-weight: 400;
	font-size: 14px;
	line-height: 1.2em;
	color: var(--farbe4);
	margin: 0;
	padding: 0;
    width: 100%;
    height: 100%;
}

.navtrigger {
	display: block;
	width: 100%;
	height: 10px;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 10;
}

.logo {
	margin: 0 0 0 0;
}

*:focus {
	outline: none;
}

a {
	color: var(--farbe2);
	text-decoration: none;
}

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

h1, h2, h3, h4, h5 {
	margin: 0 0 0.8em 0;
	line-height: 1em;
}

h1, h2{
	color: var(--farbe2)
}

h1, h2{
	font-family: 'Montserrat', sans-serif;
	font-size: 40px;
	font-weight: 200;
	text-transform: uppercase;
	margin: 0;
	padding: 0
}

h1 + h2, h3{
	font-size: 20px;
	font-weight: 200;
	color: var(--farbe2);
	margin-top: 5px;
}

#header, #inhaltsbereich, #footer {
    float: left;
    clear: both;
    width: 100%;
}

#header {
	z-index: 99;
	background: var(--farbe1);
	padding: 20px 0;
}

#header::after {
	content: '';
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	border-bottom: 2px solid var(--farbe1);
	margin-top: 5px;
}

#header.scrolled {
	padding: 10px 0;
}

body[data-toggled="on"] #header {
	padding: 15px 0 0 0;
}

.symbol {
	display: inline-block;
}

.symbol::before {
	content: "\0040";
}

.frame {
    float: left;
    clear: both;
    width: 100%;
}

.mob_button {
	position: absolute;
    right: 2%;
    top: 22px;
    z-index: 5;
    margin: 0;
    width: 60px;
    height: 60px;
    cursor: pointer;
	display: none;
}

.mob_button span {
	background-color: var(--farbe2);
	height: 2px;
	left: 7px;
	margin-top: -1px;
	position: absolute;
	top: 50%;
	width: 40px;
	transition: all 0.3s ease 0.3s;
	display: none;
}

.mobile .mob_button span {
	display: block;
}

.mob_button span::after, .mob_button span::before {
	backface-visibility: hidden;
	background-color: var(--farbe2);
	content: "";
	height: 2px;
	position: absolute;
	transform: translateZ(0px);
	transition: all 0.3s ease 0.3s;
	width: 100%;
	display: block;
}

.mob_button span::before {
	transform: translateY(-11px);
}

.mob_button span::after {
	transform: translateY(11px);
}

.mobnavvisible.mob_button span {
	background-color: transparent;
}

.mobnavvisible.mob_button span::before {
	transform: translateY(0px) rotate(-45deg);
}

.mobnavvisible.mob_button span::after {
	transform: translateY(0px) rotate(45deg);
}

.opnavi, .unavi {
    margin: 0;
}

#hauptnavi ul {
	list-style: none;
	margin:  0;
	padding: 0;
}

#hauptnavi ul li {
	float: none;
	margin: 0 15px;
	padding: 0;
	display: inline-block;
	vertical-align: top;
	text-transform: uppercase;
	font-size: 16px;
}

#hauptnavi ul li:first-child {
	margin-left: 0;
}

#hauptnavi ul li a {
	display: block;
	padding: 5px 0;
	border-bottom: 2px solid transparent;
	color: var(--farbe4) !important;
	font-weight: 500;
	vertical-align: bottom;
	position: relative;
	transition: 0.3s;
}

#hauptnavi ul li.act a, #hauptnavi ul li a:hover {
	color: var(--farbe2) !important;
}

#hauptnavi ul li a::before{
	content: "";
	background: url(../fileadmin/templatefiles/images/navi-act-logo.png) no-repeat;
	background-size: contain;
	display: block;
	height: 27px;
	width: 26px;
	position: absolute;
	top: 0px;
	left: calc(50% - 13px);
	opacity: 0;
	transition: 0.3s;
}

#hauptnavi ul li.act a::before, #hauptnavi ul li a:hover::before {
	top: -30px;
	opacity: 1;
}

.bereiche, .bereiche .inhalt, .bereiche .inhaltsheader {
	float: left;
	clear: both;
	width: 100%;
}

.inhaltsheader .ce-border img {
	border: 0;
}

.inhaltsheader.ih_fixed {
	height: 500px;
	background-position: center top;
	background-attachment: fixed;
	background-size: cover;
}

.inhaltsheader .ce-border {
	max-height: 500px;
	overflow: hidden;
}

.bereiche .inhalt > .frame {
	padding: 70px 0;
}

#header .rahmen, #inhaltsbereich .rahmen, #footer .rahmen {
	float: none;
	clear: both;
	width: 80%;
	margin: 0 auto;
}

#inhaltsbereich .inhaltsheader .rahmen, 
#header .rahmen .rahmen, 
#inhaltsbereich .rahmen .rahmen, 
#footer .rahmen .rahmen, #karte .rahmen {
	max-width: 100%;
	width: 100%;
	margin: 0;
}

#inhaltsbereich {
	float: left;
	clear: both;
	width: 100%;
}

#inhaltsbereich > .bereiche > .inhalt > div:first-child {
	padding: 100px 0 100px 0;
}

#inhaltsbereich > .bereiche > .inhalt > div {
	padding: 0 0 100px 0;
}

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

#inhaltsbereich.onepageinhalt img {
	opacity: 0;
}

#inhaltsbereich.onepageinhalt .bereiche:last-child img, #inhaltsbereich .inhaltsheader img {
	opacity: 1;
}

.inhaltsheader .ce-gallery {
	margin-bottom: 0;
}

#inhaltsbereich.onepageinhalt > .bereiche:first-child .inhaltsheader {
	width: 100%;
	max-height: 100vh;
	overflow: hidden;
	position: relative;
}

#inhaltsbereich.onepageinhalt > .bereiche:first-child .inhaltsheader .scrollicon {
	display: none;
	position: absolute;
	bottom: 20px;
	left: 50%;
	margin-left: -50px;
	width: 100px;
	z-index: 2;
}

#inhaltsbereich.onepageinhalt > .bereiche:first-child .inhaltsheader.fullsize .scrollicon {
	display: block;
	cursor: pointer;
}

#inhaltsbereich.onepageinhalt > .bereiche:first-child .inhaltsheader.fullsize::after {
	content: '';
	bottom: 0;
	top: 0;
	left: 0;
	right: 0;
	position: absolute;
	z-index: 1;
	background: none;
	background: linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(0,0,0,0.5) 100%);
}

#inhaltsbereich.onepageinhalt > .bereiche:first-child .inhaltsheader .ce-bodytext {
	position: absolute;
	left: 5%;
	right: 5%;
	bottom: 40px;
	z-index: 5;
}

#inhaltsbereich.onepageinhalt > .bereiche:first-child .inhaltsheader .ce-bodytext,
#inhaltsbereich.onepageinhalt > .bereiche:first-child .inhaltsheader .ce-bodytext h2 {
	color: var(--farbe1);
	line-height: 1em;
}

#inhaltsbereich.onepageinhalt > .bereiche:first-child .inhaltsheader .ce-bodytext h2 {
	font-size: 100px;
}

#inhaltsbereich.onepageinhalt > .bereiche:first-child .inhaltsheader .ce-bodytext p {
	margin-top: 40px;
	letter-spacing: 10px;
	line-height: 1.5em;
}

#inhaltsbereich.unterseite {
    margin: 150px 0 100px 0;
    background: var(--farbe1);
    padding: 30px 0;
}

#inhaltsbereich .inhalt header {
	margin-bottom: 50px;
}

.buttons {
	position: fixed;
	right: 15px;
	bottom: 30px;
	background: var(--farbe1);
	display: block;
	width: 25px;
	overflow: hidden;
	z-index: 4;
	padding: 2px 3px 2px 3px;
	opacity: 0;
	/* padding: 5px 5px;
	box-shadow: 0 0 3px rgba(0,0,0,0.3);
	border-radius: 15px 0 15px 0; */
}

.buttons.reset {
	bottom: 30px !important;
}

.buttons.showbuttons, .buttons:hover div {
	opacity: 0.6;
}

.buttons:hover, .buttons div:hover {
	opacity: 1;
}

.buttons div {
	display: block;
	cursor: pointer;
	background-position: center center;
	background-repeat: no-repeat;
	width: 24px;
	height: 24px;
	margin: 4px 0 4px 0;
	padding: 0;
	float: left;
	clear: both;
	background-color: rgba(0,0,0,0.3);
}

.buttons div:hover {
	background-color: var(--farbe2);
 }

.buttons div.button_rauf {
	background-image: url(../fileadmin/templatefiles/images/arrow-top.png);
}

.buttons div.button_runter {
	background-image: url(../fileadmin/templatefiles/images/arrow-bottom.png);
}

.button_sprache {
	border-bottom: 1px dotted #aaa;
	padding: 0 0 5px 0 !important;
	background: none !important;
	height: auto !important;
}

.social {
	float: left;
}

.smartstyle {
    position: absolute;
    right: 1%;
	bottom: 0;
	z-index: 5;
}

.smartstyle img {
    width: 60px;
	height: auto;
	float: left;
}

.mediaconsent {
    margin: 0;
    position: relative;
	overflow: hidden;
	color: var(--farbe2);
}

#footer .mediaconsent a {
	color: var(--farbe2);
	text-decoration: underline;
}

.mediaconsent iframe {
    position: relative;
    z-index: 1;
}

iframe[data-src] {
    background: rgba(245,245,245,1);
}

.mapsoverlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2;
    background: rgba(245,245,245,1);
    cursor: pointer;
	text-align: center;	
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: stretch;
	align-content: stretch;
}

.cookie_only-this {
    background: var(--farbe3);
    color: var(--farbe2);
    border-radius: 3px;
    -webkit-appearance: none;
	padding: 11px 20px 10px;
	margin: 0 10px 0 0;
    border: 0;
    cursor: pointer;
    font-family: inherit;
    font-size: 16px;
}

div[data-type="maps"] {
	display: none;
}

.mapsoverlay div[data-type="maps"] {
	display: block;
}

.ce-gallery figcaption {
	display: block;
}

.frame-bildslider {
	float: left;
	clear: both;
	width: 100%;
	position: relative;
}

.frame-bildslider img {
	transition: all .5s ease-in-out; 
}

.frame-bildslider .image a {
	display: block;
	overflow: hidden;
}

.frame-bildslider .image:hover img {
	transform: scale(1.01); 
}

.ce-gridgallery > a {
	display: block;
	overflow: hidden;
}

.ce-gridgallery a:hover img {
	transform: scale(1.1);
}

.inhalt .ce-gallery .image a {	
	display: block;
	overflow: hidden;
}

.inhalt .ce-gallery .image a img {
	transition: all .5s ease-in-out;
}

.inhalt .ce-gallery .image a:hover img {
	transform: scale(1.1);
}

.navibereich{
	margin-top: 55px
}

.inhaltsheader .rahmen .ce-gallery, .inhaltsheader  .rahmen .ce-column, .inhaltsheader  .rahmen .image, .inhaltsheader  .rahmen picture, .inhaltsheader  .rahmen img{
	width: 100%
}

#inhaltsbereich .inhaltsheader {
	max-height: 400px;
	overflow: hidden;
}

#inhaltsbereich .inhaltsheader > .frame {
	position: relative;
}

#inhaltsbereich > .bereiche:first-child .inhaltsheader > .frame {
	position: static;
}

#inhaltsbereich .inhaltsheader .ce-bodytext {
	position: absolute;
	left: 5%;
	right: 5%;
	bottom: 20px;
	letter-spacing: 10px;
	z-index: 5;
	color: var(--farbe1);
	text-transform: uppercase;
	font-weight: 500;
	text-shadow: 0 0 5px var(--farbe4);
}

#inhaltsbereich .inhaltsheader .ce-bodytext p {
	margin: 0 0 0 0;
}

#inhaltsbereich .inhaltsheader > .frame::after {
	content: '';
    bottom: 0;
    top: 0;
    left: 0;
    right: 0;
    position: absolute;
    z-index: 1;
    background: none;
    background: linear-gradient(180deg, rgba(0,0,0,0) 20%, rgba(0,0,0,0.5) 100%);
}

/*~ Inhalt ~*/
#inhaltsbereich .inhalt header,
#inhaltsbereich .inhalt .ce-textpic,
#inhaltsbereich .inhalt .ce-bodytext,
#inhaltsbereich .inhalt .ce-gallery {
	float: left;
	clear: both;
	width: 100%;
}

#inhaltsbereich .frame-type-header {
	padding-bottom: 30px !important;
}

#inhaltsbereich .inhalt ul {
	margin: 0 0 0 0;
	padding: 0 0 0 0;
}

#inhaltsbereich .inhalt ul li {
	padding-left: 15px;
	position: relative;
	list-style: none;
	margin-bottom: 5px;
}

#inhaltsbereich .inhalt ul li:last-child {
	margin-bottom: 0;
}

#inhaltsbereich .inhalt ul li::before {
	content: '';
	position: absolute;
	top: 3px;
	left: 0;
	height: 10px;
	width: 10px;
	background: url(../fileadmin/templatefiles/images/li-before.png) no-repeat;
	background-size: cover;
}

#inhaltsbereich .inhalt p + ul {
	margin: 10px 0;
}

#inhaltsbereich .frame-type-header h3 {
	font-weight: 500;
	color: var(--farbe4);
}

#inhaltsbereich .frame-type-header h2 + h3 {
	font-weight: 200;
    color: var(--farbe2);
}

.frame-type-header header {
	margin: 0 0 0 0;
}

#inhaltsbereich .frame-werbetechnik-li > .rahmen {
	width: 100%;
	float: left;
	clear: both;
	max-width: unset;
}

#inhaltsbereich .frame-werbetechnik-li > .rahmen > header,
#inhaltsbereich .frame-werbetechnik-li > .rahmen > .ce-textpic > .ce-bodytext {
    width: 80%;
    margin: 0 10%;
}

.frame-werbetechnik-li.frame-layout-1 {
	background: var(--farbe3);
	padding-top: 100px !important;
	margin-bottom: 100px;
	border-bottom: 4px solid #86246b;
	border-top: 4px solid #86246b;
	position: relative;
}

.frame-werbetechnik-li.frame-layout-1::before {
	content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: 4px;
    z-index: 1;
    border-bottom: 2px solid #e6007e;
}

.frame-werbetechnik-li.frame-layout-1::after {
	content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: -10px;
    z-index: 1;
    border-bottom: 2px solid #e6007e;
}

.frame-werbetechnik-li.frame-layout-1 + .frame-werbetechnik-li + .frame-werbetechnik-li.frame-layout-1 {
	border-bottom: 4px solid rgba(134, 36, 107, 0.7);
}

.frame-werbetechnik-li.frame-layout-1 + .frame-werbetechnik-li + .frame-werbetechnik-li.frame-layout-1::after {
	border-bottom: 2px solid rgba(230, 0, 126, 0.6);
}

/* .frame-werbetechnik-li.frame-layout-1 + .frame-werbetechnik-li.frame-layout-0 + .frame-werbetechnik-li.frame-layout-1 {
	border-top: 4px solid #86246b;
}

.frame-werbetechnik-li.frame-layout-1 + .frame-werbetechnik-li.frame-layout-0 + .frame-werbetechnik-li.frame-layout-1::before {
	content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: 4px;
    z-index: 1;
    border-top: 2px solid #e6007e;
} */

#inhaltsbereich .frame-werbetechnik-li ul {
	margin: 40px 0;
	padding: 0 0 0 0;
	float: left;
	clear: both;
	width: 100%;
	margin: 40px 0;
}

#inhaltsbereich .frame-werbetechnik-li ul li {
	float: left;
	display: inline-block;
	margin: 0 10px 10px 0;
	padding: 5px 10px;
	background: var(--farbe3);
	transition: 0.3s;
	letter-spacing: 5px;
}

#inhaltsbereich .frame-werbetechnik-li ul li a {
	display: block;
	transition: 0.3s;
}

.frame-werbetechnik-li ul li::before {
	display: none;
}

#inhaltsbereich .frame-werbetechnik-li.frame-layout-1 ul li {
	background: var(--farbe1);
}

#inhaltsbereich .frame-werbetechnik-li ul li:hover {
	background: var(--farbe2);
	color: var(--farbe1);
}

#inhaltsbereich .frame-werbetechnik-li ul li:hover a {
	color: var(--farbe1);
}

.frame-icons > .rahmen {
	position: relative;
	z-index: 1;
	display: flex;
	justify-content: space-around;
	padding-bottom: 20px;
}

.frame-icons > .rahmen::after {
	content: '';
	background: var(--farbe5);
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 100px;
	z-index: -1;
}

.frame-icons > .rahmen > .frame {
	width: 22%;
}

.frame-icons .frame .ce-textpic {
	position: relative;
	overflow: visible;
}

.frame-icons .frame .ce-row {
	margin: 0 0 0 0;
}

.frame-icons .frame .ce-row * {
	width: 100%;
}

.frame-icons .frame .ce-bodytext {
	position: absolute;
	left: 10px;
	right: 10px;
	text-align: center;
	bottom: 10px;
	width: auto !important;
	letter-spacing: 5px;
	font-weight: 500;
}

.frame-icons .frame .ce-bodytext p {
	margin-bottom: 0;
}

.frame-icons .frame:hover .ce-bodytext a {
	color: var(--farbe4);
}

.frame-icons .frame .ce-gallery {
	margin: 0 0 0 0;
}

.frame-icons .frame .ce-gallery .ce-row:first-child {
	position: absolute;
	left: 0;
	top: 0;
	right: 0;
	opacity: 0;
	transition: transform 0.3s;
}

.frame-icons .frame:hover .ce-row {
	opacity: 0;
}

.frame-icons .frame:hover .ce-row:first-child {
	transform: translateY(-20px) !important;
	opacity: 1;
}

.frame-icons .frame:hover .ce-bodytext {
	margin-bottom: 20px;
	transition: margin 0.3s;
}

.frame-icons .frame:hover .ce-bodytext a {
	color: var(--farbe1);
}

#inhaltsbereich .frame-bildslider > .rahmen {
	width: 100%;
	float: left;
	clear: both;
}

#inhaltsbereich .frame-bildslider > .rahmen > header,
#inhaltsbereich .frame-bildslider > .rahmen .ce-bodytext {
	width: 80%;
	margin-left: 10%;
	margin-right: 10%;
}

#inhaltsbereich .frame-bildslider > .rahmen .ce-bodytext {
	margin-bottom: 50px;
}

#inhaltsbereich .frame-bildslider.frame-layout-1 {
	background: var(--farbe3);
	padding-top: 100px !important;
}

#inhaltsbereich .frame-bildslider.frame-layout-2 {
	background: var(--farbe2);
	padding-top: 100px !important;
}

#inhaltsbereich .frame-bildslider.frame-layout-2 .owl-carousel .owl-nav button.owl-next {
	background: url(../fileadmin/templatefiles/images/owl-navi-right-white.png) center center no-repeat;
}

#inhaltsbereich .frame-bildslider.frame-layout-2 .owl-carousel .owl-nav button.owl-prev {
	background: url(../fileadmin/templatefiles/images/owl-navi-left-white.png) center center no-repeat;
}

#inhaltsbereich .frame-bildslider.frame-layout-2,
#inhaltsbereich .frame-bildslider.frame-layout-2 h1,
#inhaltsbereich .frame-bildslider.frame-layout-2 h2,
#inhaltsbereich .frame-bildslider.frame-layout-2 h3,
#inhaltsbereich .frame-bildslider.frame-layout-2 a {
	color: var(--farbe1);
}

#inhaltsbereich .frame-bildslider.frame-layout-2 a {
	text-decoration: underline;
}

.frame-bg-lila {
	background: var(--farbe7);
	padding-top: 100px !important;
}

.frame-bg-lila,
.frame-bg-lila h1,
.frame-bg-lila h2,
.frame-bg-lila h3,
.frame-bg-lila a {
	color: #FFF;
}

.frame-bg-lila a {
	text-decoration: underline;
}

#inhaltsbereich .frame-bg-lila + .frame-bildslider.frame-layout-1 {
	background: none;
	padding-top: 0 !important;
	position: relative;
	z-index: 1;
}

#inhaltsbereich .frame-bg-lila + .frame-bildslider.frame-layout-1::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	height: 100px;
	background: var(--farbe7);
	z-index: -1;
}

a.pdf {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding-left: 140px;
	position: relative;
	height: 120px;
	max-width: calc( 100% - 140px);
	float: left;
	clear: both;
	margin: 20px 0;
}

a.pdf br {
	display: none;
}

a.pdf::before, a.pdf::after {
	content: '';
	width: 118px;
	height: 118px;
	background: url(../fileadmin/templatefiles/images/pdf-icon-hover.png) center center no-repeat;
	background-size: 100% 100%;
	position: absolute;
	top: 1px;
	left: 1px;
	transition: 0.3s;
}

a.pdf::after {
	background: url(../fileadmin/templatefiles/images/pdf-icon.png) left top no-repeat;;
	background-size: 100% 100%;
	width: 120px;
	height: 120px;
	top: 0;
	left: 0;
}

a.pdf:hover::after {
	opacity: 0;
}

.frame-kontakt {
	position: relative;
}

.frame-kontakt::after {
	content: '';
	position: absolute;
	left: 50%;
	top: 0;
	bottom: 0;
	right: 0;
	background: url(../fileadmin/user_upload/Kontakt/kontakt-firmengelaende.jpg) center center no-repeat;
	background-size: cover;
}

#inhaltsbereich .frame-kontakt > .rahmen > * {
	width: 45% !important;
}

.frame-type-div {
	padding: 0 0 0 0 !important;
	margin-bottom: 100px;
	border-bottom: 2px solid #e6007e;
}

#inhaltsbereich .frame-type-div > .rahmen {
	width: 100%;
	float: left;
	clear: both;
	margin: 0 0 0 0;
}

.frame-type-div hr {
	border: none;
	border-bottom: 4px solid #86246b;
	margin: 0 0 4px 0;
	float: left;
	clear: both;
	width: 100%;
}

/*~ Accordion ~*/
.ui-accordion-header {
	background: rgba(0,0,0,0.15);
	margin: 5px 0 0 0;
	position: relative;
}

.ui-accordion-header a {
	color: var(--farbe4);
}

.ui-accordion-header.ui-state-active, .ui-accordion-header:hover {
	background: var(--farbe7);
}

.ui-accordion-header.ui-state-active a, .ui-accordion-header a:hover {
	color: var(--farbe1);
	font-weight: 400;
	text-transform: uppercase;
}

.ui-accordion-header a {
	display: block;
	padding: 10px 3em 10px 1em;
	font-weight: 400;
	text-transform: uppercase;
	font-size: 16px;
}

.ui-accordion-content {
	margin: 0 0 10px 0;
	padding: 30px 20px 10px 20px;
	width: calc(100% - 40px);
}

.ui-accordion-header-icon {
	display: block;
	width: 24px;
	height: 24px;
	background: url(../fileadmin/templatefiles/images/plus.png) left top no-repeat;
	position: absolute;
	right: 0.5em;
	top: 50%;
	margin-top: -12px;
}

.ui-accordion-header.ui-state-active .ui-accordion-header-icon {
	background-image: url(../fileadmin/templatefiles/images/minus.png);
}

.ui-accordion-content header{
	display: none
}

.ui-accordion-content{
	border-left: 6px solid var(--farbe6);
	margin-top: 6px;
	margin-bottom: 0
}

/*~ Owl ~*/
.owl-stage-outer {
	width: 100%;
	margin-left: 0%;
}

.owl-carousel {
	padding-bottom: 30px;
	width: 100%;
	overflow: hidden;
}

.owl-carousel .owl-nav {
	position: absolute;
	left: 10%;
    bottom: 0;
}

.owl-carousel .owl-nav button.owl-next, .owl-carousel .owl-nav button.owl-prev {
    background: url(../fileadmin/templatefiles/images/owl-navi-left.png) center center no-repeat;
	background-size: cover;
    width: 20px;
    height: 20px;
    display: block;
    text-indent: 999px;
    overflow: hidden;
	float: left;
}

.owl-carousel .owl-nav button.owl-next {
    background: url(../fileadmin/templatefiles/images/owl-navi-right.png) center center no-repeat;
	background-size: cover;
	margin-left: 5px;
}

/* .frame-werbetechnik-li.frame-layout-1 .owl-carousel .owl-nav button.owl-prev,
#inhaltsbereich .frame-bildslider.frame-layout-2 .owl-carousel .owl-nav button.owl-prev {
    background: url(../fileadmin/templatefiles/images/owl-navi-left-white.png) center center no-repeat;
}

.frame-werbetechnik-li.frame-layout-1 .owl-carousel .owl-nav button.owl-next,
#inhaltsbereich .frame-bildslider.frame-layout-2 .owl-carousel .owl-nav button.owl-next {
    background: url(../fileadmin/templatefiles/images/owl-navi-right-white.png) center center no-repeat;
} */

.owl-item * {
	width: 100%;
}

.owl-carousel .owl-dots {
	float: left;
	clear: both;
	width: 100%;
	text-align: center;
	margin-top: 10px;
}

.owl-carousel .owl-dots .owl-dot {
	display: inline-block;
	width: 10px;
	height: 10px;
	border-radius: 100%;
	background: var(--farbe7);
	border: 2px solid var(--farbe7);
	margin: 0 2px;
}

.owl-carousel .owl-dots .owl-dot.active {
	background: var(--farbe1);
}

/*~ Footer ~*/
#footer {
	float: left;
	clear: both;
	width: 100%;
	background: var(--farbe2);
	color: var(--farbe1);
	position: relative;
	z-index: 3;
}

.box {
    width: 100%;
    min-height: 100%;
    position: relative;
    float: left;
    clear: both;
    display: block;
}

.box #footer {
	position: absolute;
	bottom: 0px;
    left: 0px;	
}

#footer a {
	color: var(--farbe1);
}

#footerinhalt {
	float: left;
	clear: both;
	width: 100%;
	padding: 15px 0 20px;
}

#footerinhalt .frame-type-menu_subpages ul {
	float: right;
	margin: 0;
	padding: 0;
	list-style: none;
}

#footerinhalt .frame-type-menu_subpages ul li {
	float: left;
	clear: both;
	width: 100%;
	text-align: right;
}

#footerunten {
	float: left;
	clear: both;
	width: 100%;
	position: relative;
}

/*~ SlideIn */
.slidein {
	z-index: 80;
}

.slidein .ce-textpic {
	max-height: 50vh;
	overflow-y: auto;
}

.slidein .ce-bodytext a[href$="pdf"] {
	padding-left: 25px;
	position: relative;
	margin: 5px 0;
}

.slidein .ce-bodytext a[href$="pdf"]::after {
	content: '';
	position: absolute;
	left: 0;
	top: -2px;
	background: url(../fileadmin/templatefiles/images/pdf.png) center center no-repeat;
	width: 19px;
	height: 24px;
}

.slidein .button h3 a {
	color: #FFF;
}

/*~ Fancybox ~*/
.fancybox-content,
.fancylight {
	width: 20px;
}
/* ------------------------------------------------------------------ */
/* -- IE11-Fallback fuer Farb-Variablen -- */
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
	#header.scrolled, 
	.slidein > .frame > .rahmen, 
	.pin span::before,
	.slideinrespinhalt {
		background: var(--farbe4);
	}
	
	.slidein > .frame > .button, 
	.slideinmob .button {
		background: #666;
	}
	
	.slidein > .frame > header.button > *, 
	.slideinmob header.button > *, 
	#footer a,
	.ui-accordion-header.ui-state-active a, 
	.ui-accordion-header:hover a {
		color: var(--farbe4)
	}
	
	body, a, .mediaconsent, #footer .mediaconsent a {
		color: #666;
	}
	
	a {
		text-decoration: underline;
	}
	
	#header a, 
	.ui-accordion-header a, 
	.article a, 
	#footer a {
		text-decoration: none;
	}
	
	#header {
		top: 0 !important;
		background: var(--farbe4) !important;
		box-shadow: 0 0 5px 0 rgba(0,0,0,0.1) !important;
		padding: 15px 0 !important;
	}
	
	#header .logo img {
		display: block !important;
		width: 120px !important;
		height: auto !important;
	}
	
	#hauptnavi ul li.act a, 
	#hauptnavi ul li a:hover {
		border-bottom: 2px solid #666;
	}
	
	#inhaltsbereich.onepageinhalt img, 
	.frame-hochzaehlen > .rahmen > .frame .ce-bodytext strong, 
	.frame-hochzaehlen > .rahmen > .frame .ce-bodytext em {
		opacity: 1;
	}
	
	.news .article .news-img-wrap img, 
	#inhaltsbereich img {
		width: 100% !important;
		height: auto !important;
	}
	
	.ui-accordion-header.ui-state-active, 
	.ui-accordion-header:hover {
		background: #666;
		color: var(--farbe4);
	}
	
	#footer, 
	.mobnavvisible + #hauptnavi ul li a, 
	.pin span, 
	#karte::before,
	.cookie_only-this {
		background: #999;
		color: var(--farbe4);
	}

	.frame-hintergrundfarbe1 {
		background: #f1f1f1;
	}

	.bereiche .inhalt > .frame-layout-1, .bereiche .inhalt > .frame-layout-2, .bereiche .inhalt > .frame-layout-3 {
		padding: 0;
	}	

	.bereiche .inhalt > .frame-layout-1::before, .bereiche .inhalt > .frame-layout-2::before, .bereiche .inhalt > .frame-layout-3::before,
	.bereiche .inhalt > .frame-layout-1::after, .bereiche .inhalt > .frame-layout-2::after, .bereiche .inhalt > .frame-layout-3::after {
		margin: 0;
	}
}

/*~ Slidein ~*/
.slideinmob {
    top: 120px !important;
}

.slideinmob > .frame .button {
    bottom: auto !important;
	margin: 0 0 0 0 !important;
}

.slideinmob > .frame .button h3 a {
	color: #FFF;
}

.inhaltsheader > .frame-default.frame-layout-3 {
	background: var(--farbe2);
	margin-bottom: 4px;
}

#inhaltsbereich .inhaltsheader > .frame-default.frame-layout-3 .ce-bodytext {
    position: static;
	padding: 5px 30px;
	text-shadow: none;
	width: calc(100% - 60px);
	display: block;
}

#inhaltsbereich .inhaltsheader > .frame-default.frame-layout-3::after {
	display: none;
}

#inhaltsbereich .inhaltsheader > .frame-default.frame-layout-3::before {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: -4px;
    z-index: 1;
    border-bottom: 2px solid #e6007e;
}


#c108 {
	background: var(--farbe7) !important;
}
/*
     FILE ARCHIVED ON 06:15:01 Jan 17, 2024 AND RETRIEVED FROM THE
     INTERNET ARCHIVE ON 07:13:11 Feb 27, 2026.
     JAVASCRIPT APPENDED BY WAYBACK MACHINE, COPYRIGHT INTERNET ARCHIVE.

     ALL OTHER CONTENT MAY ALSO BE PROTECTED BY COPYRIGHT (17 U.S.C.
     SECTION 108(a)(3)).
*/
/*
playback timings (ms):
  captures_list: 0.77
  exclusion.robots: 0.023
  exclusion.robots.policy: 0.011
  esindex: 0.013
  cdx.remote: 6.737
  LoadShardBlock: 117.257 (3)
  PetaboxLoader3.datanode: 113.414 (5)
  PetaboxLoader3.resolve: 395.391 (2)
  load_resource: 411.377
  loaddict: 28.867
*/