@charset "utf-8";
/* CSS Document */

:root
{
	--contentWidth: 1048px;
	--teaserHeight: 400px;
	--maxTeaserWidth: 1980px;
	--headerHeight: 5rem;
	--footerHeight: 35px;
	--textColour: #394350;
	--bgColour: #023199;
	--brownClr: #aa9c82;
	--greyClr: #e9eaee;
	--blueClr: #3E3E8E;
	--mobileMenuBG1: #a6b6c2;
	--mobileMenuBG2: #b6c6d2;
	--linkClr: #007bff;
}

html *
{
	position: relative;
	margin: 0px;
	padding: 0px;
	z-index: 1;
}

body
{
	font-family: 'Source Sans Pro', Helvetica, Arial, sans serif;
	font-size: 1rem;
}

body#page
{
	color: var(--textColour);
	background-position: top center;
	background-size: cover;
	background-repeat: no-repeat;
	background-color: var(--bgColour);
}

@media screen and (min-width: 1250px)
{
	body#page
	{
		/*background-image: url("/fileadmin/templates/images/image.caspx.jpg?d=1");
		background-color: transparent;*/
	}
}

body.narrowContent
{
	--maxTeaserWidth: var(--contentWidth);
}

a, a:visited
{
	font-weight: bold;
	color: #3E3E3E;
	text-decoration: none;
}

a.btn,
button.btn
{
	color: #F0F0F0;
}

.csc-textpic-text a
{
	display: block;
	width: fit-content;
	padding-block: 0.3em;
	padding-inline: 0.6em;
	background-color: white;
	color: var(--blueClr);
	border-radius: 0.5em;
	font-size: 1rem;
}

.text-right a
{
	margin-left: auto;
}

.csc-textpic-text a:hover
{
	box-shadow: 10px 10px 10px rgba(0,0,0,0.4);
}

.btn-info
{
	background-color: var(--blueClr);
	border-color: var(--blueClr);
}

.btn-info:hover,
.btn-info:focus
{
	box-shadow: 0.2rem 0.2rem 0 0 rgba(0, 40, 120, 0.3);
}

a:hover
{
	text-decoration: underline;
}

a img
{
	text-decoration: none;
	border: none;
}

.csc-header h1,
.csc-header h2
{
	letter-spacing: 1px;
}

.csc-header h1,
.csc-header h2, 
.csc-header h3,
.tx-powermail h3
{
	font-size: 1.1em;
	font-family: 'Domine', serif;
	font-weight: 500;
	color: var(--blueClr);
	text-transform: uppercase;
	text-wrap: balance;
	hyphens: auto;
	margin-bottom: 0.8em;
	height: auto;
}

#mainContent p
{
	text-wrap: pretty;
	hyphens: auto;
}

#mainContent.threeColumn
{
	font-size: 0.85em;
}
	/*
    #centreArea p, ul, ol
    {
        padding-top: 3px;
        padding-bottom: 5px;
    }


    #centreArea ul,ol
    {
        margin-left: 10px;
        padding-left: 5px;
    }
    */
ul
{
	list-style: square;
}

ul ul
{
	list-style: disc;
}

ul.menu
{
	display: flex;
	justify-content: space-between;
}

ul.menu,
ul.menu ul
{
	margin: 0;
	padding: 0;
	list-style: none;
}

div#outerWrapper,
div#footerWrapper
{
	max-width: 100dvw;
	overflow: clip;
}
div#headerWrapper,
div#topBarWrapper,
div#topBar,
div#centreAreaWrapper,
div#lowerContentWrapper
{
	width: 100%;
}

div#centreArea,
div#header,
div#footer,
div#lowerContent,
div#topBanner,
.narrowContent div#topBarWrapper
{
	max-width: var(--contentWidth);
	width: auto;
	margin-left: auto;
	margin-right: auto;
}

#page div#mainContent
{
	padding-left: 3.5em;
	padding-right: 3.5em;
	max-width: 98vw;
	min-height: calc(90vh - var(--headerHeight) - var(--teaserHeight) - var(--footerHeight));
	border-bottom-left-radius: 1rem;
	border-bottom-right-radius: 1rem;
}

#mainMenu ul.level1
{
	font-family: 'Domine', serif;
}

/*ul.menu li.menuItem,*/
div#mainContent,
div.column
{
	display: block;
	float: left;
}

div#rightColumn
{
	float: right;
}

div#topBanner
{
	height: 55px;
}

div#headerWrapper
{
	background: #F0F0FF;
	border-top: 3px var(--brownClr) solid;
	z-index: 10;
}

div#header
{
	height: var(--headerHeight);
	z-index: 20;
}

div#logo
{
	position: absolute;
	left: 5px;
	top: 3px;
	height: calc(100% - 5px);
	width: auto;
	overflow: hidden;
	text-align: right;
}

#logo img
{
	height: 100%;
	width: auto;
	object-fit: cover;
	object-position: center;
}

div#slogan
{
	position: absolute;
	top: 50%;
	left: 50%;
	color: var(--blueClr);
	font-size: 2.3rem;
	font-family: 'Domine', serif;
	font-weight: 700;
	white-space: nowrap;
	transform: translate(-50%,-50%);
}

div#search
{
	position: absolute;
	right: 5px;
	top: 50%;
	width: 9rem;
	transform: translateY(-30%);
	overflow: hidden;
}

#search div.tx-indexedsearch-form
{
	width: 100%;
	box-sizing: content-box;
}

#search legend,
#search label
{
	display: none;
}

#search input#search_item
{
	position: absolute;
	top: 0px;
	right: 0px;
	-webkit-appearance: none;
	height: 1.2rem;
	border: none;
	padding: 2px 4px;
	border: 2px #E3E3E3 inset;
}

input[type=search] 
{
    /* the webkit overrides need to stay at the top */
    -webkit-appearance: textfield;
    -webkit-box-sizing: content-box;
	border-radius: 0.5rem;
	border-color: var(--greyClr);
  /* your styles here */
}

#search input[type=search]
{
	width: calc(100% - 0.5rem);
}

::-webkit-input-placeholder 
{
	padding-left: 0.5rem;
    color: #3e4e5e;
	text-transform: lowercase;
}

#search input#searchSubmit
{
	position: absolute;
	z-index: 10;
	top: 50%;
	right: 0px;
	width: 16px;
	height: /*calc(100% - 2px)*/100%;
	text-indent: -1000px;
	border: none;
	background-color: var(--blueClr);
	background-image: url(/fileadmin/templates/images/search-button.svg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: 15px 15px;
	border-radius: 0.5rem;
	transform: translateY(-50%);
	cursor: pointer;
}

#search input#searchSubmit:hover,
#search input#searchSubmit:focus
{
	box-shadow: 0.08rem 0.08rem 0.1rem 0.1rem rgba(0, 20, 140, 0.3);
}

div#mainMenu
{
	padding-top: 10px;
	width: 100%;
	min-width: 670px;
	font-size: 1.1em;
	overflow: visible;
	border-bottom: 3px #aa9c82 solid;
	border-top-left-radius: 5px;
	border-top-right-radius: 5px;
	background: #FFFFFF;
	z-index: 20;
}

#mainMenu ul.level1
{
	z-index: 23;
	height: auto;
	width: 98%;
	margin-left: auto;
	margin-right: auto;
	overflow: visible;
}

#mainMenu li.clear
{
	display: none;
}

#mainMenu li.level1
{
	height: 25px;
	width: auto;
	margin-right: 10px;
	white-space: nowrap;
	text-transform: uppercase;
	z-index: 24;
}

#mainMenu li.last-item
{
	margin-right: 0px;
}

#mainMenu .menu li.level1 a,
#mainMenu .menu li.level1 a:visited
{
	font-weight: 700;
	color: var(--blueClr);
}

#mainMenu .menu li.level1 a:hover
{
	text-decoration: none;
	color: #000;
}

#mainMenu .menu li.level1 ul.level2
{
	position: absolute;
	display: none;
	top: 1.3em;
	left: 0;
	min-width: 100%;
	padding-top: 0.4em;
	text-align: left;
	font-size: 1em;
	font-family: 'Source Sans Pro', Helvetica, Arial, sans serif;
	border-left: 1px #aa9c82 outset;
	border-right: 1px #aa9c82 outset;
	z-index: 25;
}

#mainMenu .menu li.level1:hover ul.level2,
#mainMenu .menu li.level1.clicked ul.level2
{
	display: block;
}

#mainMenu .level2 li.level2
{
	float: none;
	background-color: #FFF;
	min-width: 100%;
	padding-left: 15px;
	padding-right: 15px;
	padding-top: 3px;
	padding-bottom: 3px;
	white-space: nowrap;
	border-bottom: 1px #888 dotted;
	font-size: 90%;
	text-transform: none;
	z-index: 26;
}

#mainMenu .level2 li.level2:hover
{
	background-color: #F0F0F0;
}

#mainMenu .level2 li:first-child
{
	padding-top: 4px;
	border-top: 2px #aa9c82 solid;
}

#mainMenu .level2 li.last-item
{
	padding-bottom: 8px;
	border-bottom: 3px #aa9c82 solid;
}

.menuContent div#leftSubMenu
{
	width: 13%;
	margin-right: 15px;
}

#leftSubMenu a,
#leftSubMenu a:visited
{
	color: #486875;
	font-weight: 400;
}

#leftSubMenu ul#subMenu
{
}

#leftSubMenu #subMenu li.level1
{
	padding-left: 20px;
	/*background-image: url(/fileadmin/templates/images/blue-box.png);*/
	background-position: left center;
	background-repeat: no-repeat;
	text-transform: uppercase;
}

.menuContent div#menuContent
{
	max-width: 85%;
}

#topBarWrapper
{
	z-index: 2;
}

#teaser
{
	overflow: hidden;
	height: var(--teaserHeight);
	max-width: var(--maxTeaserWidth);
	margin-left: auto;
	margin-right: auto;
	/*margin-bottom: 0.1rem;*/
	border-bottom: 0.2rem var(--brownClr) solid;
	box-sizing: border-box;
	box-shadow: 0 0.2rem 0.3rem 0.1rem rgba(0, 0, 0, 0.3);
}

#teaser div.teaserImg
{
	position: absolute;
	left: 0;
	top: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%;
	width: 100%;
	overflow: hidden;
	opacity: 0;
	transition: 2s opacity ease-in-out;
	transition-delay: 2s;
}

.teaserImageEl
{
	width: auto;
	min-width: 100%;
	height: auto;
	min-height: 100%;
	object-fit: cover;
}

#teaser div.teaserImg[data-active]
{
	opacity: 1;
	transition-delay: 0ms;
}
#teaser.init div.teaserImg[data-active]
{
	transition: 0s opacity;
}

#teaser .teaserImg img.teaserImage
{
	display: block;
	min-width: var(--maxTeaserWidth);
	width: auto;
	min-height: var(--teaserHeight);
	height: auto;
	object-fit: cover;
	object-position: center;
	inset: 0;
	z-index: 1;
}

.narrowContent #teaser .teaserImg img.teaserImage
{
	min-width: var(--contentWidth);
}

.narrowContent:not(.indexPage) #teaser .teaserImg img.teaserImage
{
	min-height: 100%;
}

div#centreAreaWrapper
{
	padding-bottom: 65px;
}

div#mainContent
{
	margin-top: 0px;
	padding-top: 3em;
	padding-bottom: 3em;
	/*padding-left: 2%;
	padding-right: 2%;*/
	width: 100%;
	min-height: 300px;
	background-color: #FFF;
}

.twoColumn div.column
{
	width: 47%;
}

.twoColumn article
{
	background-color: #FDFEFF;
	padding-bottom: 10px;
	padding-top: 5px;
	padding-right: 5px;
	padding-left: 5px;
}

.twoColumn hr.infoBottom
{
	margin-top: 10px;
	color: #000;
}

.threeColumn hr.infoBottom
{
	display: none;
}

.threeColumn div.column
{
	width: 32%;
	margin-right: 1.4%;
}

.threeColumn div#rightColumn
{
	margin-right: 0%;
}

.newsPage .column article
{
	border-bottom: 1px #444 solid;
	margin-bottom: 20px;
	padding-bottom: 10px;
}

.column article
{
	margin-bottom: 10px;
	margin-top: 20px;
	padding-bottom: 10px;
	border-bottom: 1px #444 dotted;
}

.indexPage .column article
{
	padding-left: 0.75em;
	padding-right: 0.75em;
	padding-top: 1em;
	margin-top: 0px;
}

.indexPage .column article:first-child
{
	min-height: 33.1em;
}

.indexPage .column article:nth-child(2)
{
	min-height: 30em;
}

.narrowContent .csc-header-n2 h2,
.narrowContent .csc-header-n3 h2,
.narrowContent .csc-header-n1 h2
{
	padding-top: 1.5em;
	margin-bottom: 0.2em;
}

.indexPage .column article div.csc-header
{
	min-height: 48px;
}

.column article:last-child
{
	border-bottom: none;
	margin-bottom: 0px;
}

.indexPage #leftColumn article:nth-child(even),
.indexPage #centreColumn article:nth-child(odd),
.indexPage #rightColumn article:nth-child(even)
{
	background-color: #F0F2F9;
}

div#lowerContentWrapper
{
	border-top: 5px var(--greyClr) solid;
	background-color: var(--brownClr);
	color: #000;
	position: fixed;
	bottom: var(--footerHeight);
}

div#lowerContent
{
	height: 15px;
	padding-top: 2px;
	padding-bottom: 2px;
}

#textAboveFooter
{
	padding-block: 2rem;
	max-width: 100vw;
	overflow-y: clip;
}

#textAboveFooter > .csc-frame
{
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(400px,1fr));
	grid-column-gap: 1.5rem;
	grid-row-gap: 2rem;
	width: min(var(--contentWidth, 98vw));
	max-width: 98%;
	padding-inline: 2rem;
	padding-block: 2rem;
	margin-inline: auto;
	border-radius: 1rem;
	background-color: white;
}

#textAboveFooter .csc-header
{
	grid-column: 1 / -1;
	grid-row: 1;
}

@media screen and (max-width: 500px)
{
	#textAboveFooter > .csc-frame
	{
		grid-template-columns: 1fr;
	}
}

div#footerWrapper
{
	background-color: #534c44;
	position: fixed;
	width: 100%;
	bottom: 0;
	left: 0;
	padding-bottom: 5px;
}

div#footer
{

	display: flex;
	justify-content: space-between;
	align-items: center;
	height: max(100%, var(--footerHeight));
	padding-top: 10px;
	color: #FFF;
}

#footer > div
{
	margin-left: 1rem;
}

#footer a,
#footer a:visited
{
	color: #FFF;
}

#footer div#copyright
{
	float: left;
}

#footer #copyright p,
#lowerContent p
{
	margin: 0px;
	padding: 0px;
}

.footerLogo > img
{
	height: 60px;
	width: auto;
}

div#bottomMenu
{
	width: auto;
	display: block;
	float: left;
	margin-left: 15px;
}

#bottomMenu a,
#bottomMenu a:visited
{
	font-weight: normal;
}

.contenttable td
{
	padding-left: 2px;
	padding-right: 8px;
	padding-top: 2px;
	padding-bottom: 2px;
}

.tx-fsnd-maplinks div#imageMap
{
	width: 100%;
	height: auto;
	overflow: hidden;
	text-align: right;
}

#bottomMenu .menu li.menuItem
{
	margin-left: 15px;
	padding-left: 15px;
	border-left: 1px #FFF solid;
}

.tx-indexedsearch h3,
.tx-indexedsearch-res h3
{
	font-size: 1em !important;
}

p.tx-indexedsearch-description
{
	margin-left: 1.5rem;
	font-size: 0.9rem;
}

.tx-indexedsearch-title > a,
.tx-indexedsearch-title a:visited
{
	color: var(--linkClr);
}

ul.tx-indexedsearch-browsebox
{
	list-style: none;
}

.tx-indexedsearch-browsebox li
{
	display: inline-block;
	margin-right: 15px;
}

#mailform div.tx-indexedsearch-browsebox
{
	min-height: 28px;
}

#mailform div.tx-indexedsearch-searchbox div.tx-indexedsearch-form,
#mailform div.tx-indexedsearch-searchbox div.tx-indexedsearch-search-submit
{
	display: block;
	position: relative;
	float: left;
	width: auto;
	max-width: 50%;
}

#mailform div.tx-indexedsearch-searchbox p
{
	clear: both;
	float: none;
}

.tx-indexedsearch-searchbox legend
{
	display: none;
}

div.tx-indexedsearch-form,
div.tx-indexedsearch-search-submit
{
	display: inline-block;
}

.csc-frame
{
	max-width: 100%;
}

nav.csc-frame
{
	width: 100%;
}

ul.csc-menu-1
{
	/*display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	grid-column-gap: 2em;
	grid-row-gap: 2em;*/
	margin-left: 0;
	margin-bottom: 2.5em;
	list-style: none;
}

.csc-menu-1 > li
{
	padding-left: 2em;
	background-image: url("/fileadmin/templates/images/nemu48.png");
	background-repeat: no-repeat;
	background-size: 1.2em;
	background-position: 0 0.15em;
}
/*
.csc-menu-1 a
{
	display: block;
	width: 100%;
	text-align: center;
	white-space: nowrap;
	vertical-align: middle;
	border: 1px solid var(--blueClr);
	padding: 0.375rem 0.75rem;
	font-size: 1rem;
	line-height: 1.5;
	border-radius: 0.25rem;
	color: #F0F0F0;
	background-color: var(--blueClr);
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;

	cursor: pointer;
	transition: color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;
}

.csc-menu-1 a:hover
{
	color: #fff;
	background-color: #138496;
	border-color: #117a8b;
	box-shadow: 0.2rem 0.2rem 0 0 rgb(0 40 120 / 30%);
}
*/
.csc-mailform form ol li.csc-form-element-checkbox label
{
   display: inline-block;
   float: none;
   width: auto;
   margin-right: 0px;
}

.csc-mailform form ol li.csc-form-element-checkbox input
{
   display: inline-block;
   margin-left: 5px;
   margin-top: 5px;
}

div.powermail_fieldwrap
{
   margin-top: 2px;
   margin-bottom: 8px;
	margin-left: -15px;
	margin-right: -15px;
}

div.csc-mailform li label,
.powermail_fieldwrap.layout1 label
{
   display: block;
   float: none;
   /*width: 23%;*/
	max-width: 100%;
   margin-right: 2%;
	margin-bottom: 0px;
   vertical-align: top;
}

.powermail_fieldwrap.layout2 label
{
   margin-right: 5px;
}

div.powermail_fieldwrap_type_check
{
	display: flex;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: flex-start;
}

[type=reset], [type=submit], button, html [type=button]
{
	cursor: pointer;
}

div.csc-mailform li input[type=text],
div.csc-mailform li textarea,
.powermail_fieldwrap.layout1 input[type=text],
.powermail_fieldwrap.layout1 textarea
{
   /*display: inline-block;
   width: 290px;
   float: none;
   padding-left: 1px;
   padding-right: 1px;
   padding-top: 2px;
   padding-bottom: 2px;*/
}

.powermail_fieldwrap.layout1 div.col-sm-10,
.powermail_fieldwrap.layout2 div.col-sm-10
{
   display: inline-block;
}

div.powermail_fieldwrap_type_submit.layout1
{
	display: flex;
	flex-wrap: nowrap;
	justify-content: flex-end;
	align-items: flex-end;
}

.powermail_fieldwrap_type_submit.layout1 div.col-sm-offset-2
{
	text-align: right;
	margin-right: 16%;
}

div.csc-mailform input[type=submit],
.powermail_fieldwrap.layout1 input[type=submit]
{
   /*width: 290px;
   padding-top: 5px;
   padding-bottom: 5px;*/
   margin-left: 1px;
   /*text-align: center;
   cursor: pointer;*/
}

div.tx-indexedsearch-whatis
{
	margin-bottom: 10px;
	margin-top: 10px;
	font-weight: bold;
}

section.row
{
	justify-content: space-between;
	align-items: flex-start;
}

:not(.indexPage) section.row article.typeheader:first-child,
:not(.indexPage) section.row article.typeshortcut
{
	width: 100%;
	flex-basis: var(--contentWidth);
}

#page:not(.indexPage) section.row article
{
	min-width: calc(var(--contentWidth)/2 - 3em);
	/*flex-basis: calc(var(--contentWidth)/2 - 3em);*/
}

ul.browsebox
{
	list-style: none;
	padding-left: 0px;
	margin-left: 0px;
	margin-top: 5px;
	height: 24px;
}

ul.browsebox li
{
	float: left;
	position: relative;
	display: block;
	margin-left: 10px;
	margin-right: 5px;
}

div.tx-indexedsearch-res
{
	clear: both;
	float: none;
	margin-top: 0.8rem;
	margin-bottom: 0.8rem;
	padding: 0.5rem 0.2rem;
	background: #f4f6f8;
}

dl.tx-indexedsearch-info
{
	display: none;
}

div.csc-sitemap
{
	margin-left: 10px;
}

.csc-sitemap h3
{
	padding-bottom: 2px;
	font-size: 1em;
	color: #3E3E3E;
	display: block;
	width: 80%;
	border-bottom: #3E3E3E 1px dotted;
}

.csc-sitemap ul.sitemap-level2
{
	list-style: none;
}

.csc-sitemap ul
{
	margin-top: 0px;
	margin-bottom: 5px;
	padding-top: 2px;
	margin-left: 10px;
	padding-left: 5px;
}

.csc-sitemap ul.sitemap-level2 li.level2
{
	font-size: 0.8em;
	padding-top: 4px;
	margin-left: 0px;
}

.csc-sitemap a,
.csc-sitemap a:visited
{
	color: #3E3E3E;
}

.csc-sitemap ul.sitemap-level3
{
	font-size: 0.8em;
	margin-left: 12px;
}

.csc-sitemap a:hover
{
	color: #000;
}


.csc-space-before-extra-small,
.frame-space-before-extra-small
{
   padding-top: 10px;
}

.csc-space-before-small,
.frame-space-before-small
{
   padding-top: 20px;
}

.csc-space-before-medium,
.frame-space-before-medium
{
   padding-top: 30px;
}

.csc-space-before-large,
.frame-space-before-large
{
   padding-top: 40px;
}

.csc-space-before-extra-large,
.frame-space-before-extra-large
{
   padding-top: 55px;
}

.csc-space-after-extra-small,
.frame-space-after-extra-small
{
   padding-bottom: 10px;
}

.csc-space-after-small,
.frame-space-after-small
{
   padding-bottom: 20px;
}

.csc-space-after-medium,
.frame-space-after-medium
{
   padding-bottom: 30px;
}


.csc-space-after-large,
.frame-space-after-large
{
   padding-bottom: 40px;
}

.csc-space-after-extra-large,
.frame-space-after-extra-large
{
   padding-bottom: 55px;
}


.align-justify
{
	text-align: justify;
}

.align-center,
.csc-header-alignment-center
{
	text-align: center;
}

.align-right,
.csc-header-alignment-right
{
	text-align: right;
}

fieldset
{
	border: none !important;
}

.csc-mailform fieldset ol li.csc-form-element-textline
{
	display: block;
	float: left;
	width: 250px;
	height: 40px;
	padding: 0px;
}

.csc-mailform fieldset
{
	width: 540px;
}

.csc-mailform fieldset legend
{
	width: 490px;
	border-bottom: 1px #888 solid;
	padding-bottom: 3px;
	padding-left: 0px !important;
	margin-left: 0px !important;
	margin-bottom: 10px;
	font-weight: normal;
	text-transform: uppercase;
}

.csc-mailform fieldset ol
{
	padding-left: 0px !important;
	padding-bottom: 30px;
}

.csc-mailform fieldset ol li.csc-form-element label
{
	float: none;
	display: block;
	text-transform: uppercase;
	font-size: 0.7em;
	width: 240px;
}

.csc-mailform fieldset ol li.csc-form-element input[type=text],
.csc-mailform fieldset ol li.csc-form-element input[type=email],
.csc-mailform fieldset ol li.csc-form-element input[type=tel]
{
	width: 230px;
	padding: 2px 5px;
}

.csc-mailform fieldset ol li.csc-form-element label em
{
	font-size: inherit;
	display: inline-block;
}

.csc-mailform fieldset ol li.csc-form-element label strong
{
	display: block;
	float: right;
	font-size: 0.65em;
}

.csc-mailform fieldset ol li.csc-form-element-textarea
{
	float: none !important;
	clear: both !important;
	padding: 0px;
}

.csc-mailform fieldset ol .csc-form-element-textarea textarea
{
	width: 482px;
	padding: 2px 5px;
}

.csc-mailform fieldset ol li.csc-form-element-submit,
.csc-mailform fieldset ol li.csc-form-element-reset
{
	display: block;
	float: left;
	padding-left: 0px !important;
}

.csc-mailform fieldset ol li.csc-form-element-submit input,
.csc-mailform fieldset ol li.csc-form-element-reset input
{
	color: #ED007C;
	text-transform: uppercase;
	font-size: 0.8em;
	font-weight: bold;
	padding-right: 12px;
	padding-left: 4px;
	height: 22px;
	/*background-image: url(/fileadmin/templates/images/pfeil-rosa.png);*/
	background-position: 99% 3px;;
	background-repeat: no-repeat;
     -moz-border-radius: 5px;
    -webkit-border-radius: 5px;
    -khtml-border-radius: 5px;
    border-radius: 5px;
	border-style: outset;
}

.csc-mailform fieldset ol li.csc-form-element-submit input:hover,
.csc-mailform fieldset ol li.csc-form-element-reset input:hover
{
	border-color: #666;
	border-style: outset;
}

.csc-mailform fieldset ol li.csc-form-element-submit input:active,
.csc-mailform fieldset ol li.csc-form-element-reset input:active
{
	border-style: inset;
}

div.csc-mailform ol
{
	list-style: none;
}

div.csc-mailform ol li
{
	margin-bottom: 5px !important;
}

label em, legend em
{
	display: inline-block;
	padding-left: 5px;
	width: 10px;
	height: 10px;
	overflow: hidden;
}

li.csc-form-element-submit
{
	padding-top: 10px !important;
}

p.phone,
p.fax,
p.email
{
	background-position: left 2px;
	background-repeat: no-repeat;
	padding-left: 22px;
}

p.phone
{
	/*background-image: url(/fileadmin/templates/images/tel.png);*/
}

p.fax
{
	/*background-image: url(/fileadmin/templates/images/fax.png);*/
}

p.email
{
	/*background-image: url(/fileadmin/templates/images/mail-icon.png);*/
}

span.address
{
	color: #2222CC;
}

span.important
{
	color: #CC2222;
}

div.csc-textpic-imagewrap
{
	z-index: 10;
}

.csc-textpic-intext-left div.csc-textpic-imagewrap
{
	margin-right: 15px;
	margin-bottom: 10px;
	float: left;
}

.csc-textpic-intext-right div.csc-textpic-imagewrap
{
	margin-left: 15px;
	margin-bottom: 10px;
	float: right;
}

.csc-textpic-intext-left div.csc-textpic-imagewrap,
.csc-textpic-intext-right div.csc-textpic-imagewrap
{
	max-width: 50%;
}

.csc-textpic-imagewrap img
{
	max-width: 100%;
	height: auto;
}

.noDisplay
{
	display: none;
}

div.csc-header
{
	height: auto;
	min-height: 35px;
   padding-bottom: 3px;
}

.clear
{
	float: none !important;
	clear: both !important;
	height: 0px;
	width: 0px;
}

@media only screen and (max-width: 2000px)
{
	body
	{
		--maxTeaserWidth: 100vw;
	}
}

/* ######## media queries ############ */
@media only screen and (max-width: 1280px)
{	
	body
	{
		font-size: 0.85rem;
		--teaserHeight: 300px;
	}

	body:not(.narrowContent) #teaser div.teaserImg
	{
		width: 1280px;
		height: 300px;
		overflow: hidden;
	}
	
	#teaser .teaserImg img.teaserImage
	{
		min-height: 100%;
	}
	
	div#mainMenu
	{
		font-size: 1.15em;
	}
	/*
	#mainMenu ul.level1 
	{
		width: auto;
	}
	*/
	li.first-item ul.level2
	{
		margin-left: 0px !important;
	}

	div#centreArea
	{
		padding-left: 10px;
		padding-right: 10px;
	}
}

@media only screen and (max-width: 1240px)
{
	body
	{
		--contentWidth: 98vw;
	}

	div#mainMenu
	{
		font-size: 1rem;
	}
}

@media only screen and (max-width: 960px)
{
	body
	{
		--teaserHeight: 260px;
	}

	div#footerWrapper,
	div#lowerContentWrapper
	{
		position: static;
	}
}

@media only screen and (max-width : 1280px) and (-webkit-device-pixel-ratio:2)
{
	div#footerWrapper,
	div#lowerContentWrapper
	{
		position: static;
	}
}

@media only screen and (orientation: landscape)
{
}

@media screen and (orientation: portrait)
{
	body
	{
		font-size: 1rem;
	}
	div#mainMenu
	{
		width: 100%;
		min-width: 99%;
		font-size: 0.64em;
		margin-left: auto;
		margin-right: auto;
	}
	.threeColumn div.column 
	{
		margin-right: 0px;
		width: 98%;
		padding-left: 2%;
		padding-bottom: 10px;
		margin-bottom: 10px;
		border-bottom: 1px #E3E3E3 dotted;
	}
	
	.twoColumn div.column 
	{
		width: 98%;
		padding-left: 2%;
		padding-bottom: 10px;
		margin-bottom: 10px;
		border-bottom: 1px #E3E3E3 dotted;
		float: left !important;
	}
	
	article
	{
		font-size: 1.1em;
	}
	
	.indexPage .column article 
	{
		min-height: 110px;
	}
	.indexPage .column article:first-child,
	.indexPage .column article:nth-child(2)
	{
		min-height: 0;
	}
}

@media only screen and (max-width: 960px)
{
	div#header,
	div#centreArea,
	div#footer
	{
		max-width: 98vw;
	}
	div#mainMenu
	{
		font-size: 1rem;
	}
	body p.bodytext
	{
		font-size: 0.7rem;
	}
	.twoColumn p.bodytext,
	.threeColumn p.bodytext
	{
		font-size: 0.9rem;
	}

	div#search
	{
		top: 100px;
	}
}

@media only screen and (max-width: 840px)
{
	div#logo
	{
		top: 0px;
		left: 0px;
		height: calc(100% - 3px);
	}
}

@media only screen and (max-width: 800px) 
{
	body
	{
		font-size: 0.75rem;
		--teaserHeight: 220px;
	}

	div#mainMenu
	{
		font-size: 0.85rem;
	}
	
	.indexPage .column article 
	{
		min-height: 200px;
	}
	div#slogan
	{
		transform: translate(-40%, -50%);
	}
}

@media only screen and (max-width: 680px) 
{
	body
	{
		font-size: 0.8rem;
	}
	
	strong, b
	{
		font-weight: 900;
		font-size: 110%;
	}
	
	.csc-header h1
	{
		margin-bottom: 0.6em;
		font-size: 140%;
	}
	.csc-header h2,
	.csc-header h3
	{
		margin-bottom: 0.4em;
		font-size: 120%;
	}
	
	article a
	{
		font-size: 110%;
	}
	
	div#mainMenu
	{
		width: 95%;
		min-width: 95%;
		margin-left: 2%;
		display: none;
	}
	
	div#mainContent
	{
		padding-top: 0.6rem;
	}
	
	#mainMenu .menu li.level1 ul.level2
	{
		margin-left: -15px;
	}

	div#centreArea
	{
		padding-left: 0;
		padding-right: 0;
	}

	#teaser,
	div#topBarWrapper,
	div#topBar
	{
		height: 11em;
		max-width: 99vw;
		overflow: clip;
	}
	
	.twoColumn div.column 
	{
		width: 98%;
		padding-left: 2%;
		padding-bottom: 10px;
		margin-bottom: 10px;
		border-bottom: 1px #E3E3E3 dotted;
	}
	.threeColumn div.column 
	{
		margin-right: 0.5%;
		margin-bottom: 1em;
		margin-top: 0;
		padding-left: 1%;
		padding-top: 0;
		width: 98%;
	}
	.indexPage .column article:first-child,
	.indexPage .column article:nth-child(2)
	{
		min-height: 0;
	}
	.column
	{
		float: none;
	}
	.indexPage .column article 
	{
		min-height: 180px;
	}
	div#slogan
	{
		font-size: 4.5vw;
	}
}

@media only screen and (max-width: 620px)
{
	#footer
	{
		flex-direction: column;
		gap: 1em;
	}
}

@media only screen and (max-width: 580px)
{
	body
	{
		font-size: 0.8em;
	}
	div#mainMenu
	{
		min-width: 98%;
		margin-left: 2%;
		font-size: 1rem;
	}
	.indexPage .column article 
	{
		min-height: 140px;
	}
	article
	{
		font-size: 1.1em;
	}
	div#lowerContentWrapper
	{
		display: none;
	}
	div#footerWrapper
	{
		margin: 0;
		padding: 0;
		border: none;
	}
	div#footer
	{
		padding: 0;
		margin: 0;
		padding-top: 0.6rem;
		line-height: 2;
	}
	#footer div#copyright
	{
		font-size: 0.5rem;
	}
	div#bottomMenu
	{
		float: right;
		margin-right: 0.5rem;
		margin-left: 0px;
		margin-top: 0px;
		margin-bottom: 1rem;
		font-size: 0.8rem;
	}
	#bottomMenu .menu li.first-item
	{
		border-left: none;
	}
}

@media only screen and (max-width: 480px) 
{
	body
	{
		font-size: max(12px, 0.65em) !important;
	}
	.tx-indexedsearch-form,
	.tx-indexedsearch-form > *
	{
		font-size: 12px;
	}
	div#mainMenu
	{
		width: 95%;
		min-width: 95%;
		font-size: 0.80rem;
	}
	.threeColumn div.column 
	{
		margin-right: 0px;
		width: 95%;
		padding-left: 2%;
		padding-bottom: 10px;
		margin-bottom: 10px;
		border-bottom: 1px #E3E3E3 dotted;
	}
	.indexPage .column article 
	{
		min-height: 110px;
	}
	.csc-textpic-intext-left div.csc-textpic-imagewrap, 
	.csc-textpic-intext-right div.csc-textpic-imagewrap
	{
		max-width: 100%;
	}
	div.powermail_fieldwrap_type_check
	{
		display: block;
	}
}

/*************************************
**************************************
****
****	flexnav mobile Navigation
****
**************************************
*************************************/

/* Flexnav Base Styles */

.flexnav
{
	-webkit-transition: none;
	-moz-transition: none;
	-ms-transition: none;
	transition: none;
	-webkit-transform-style: preserve-3d;
	overflow: hidden; 
	margin: 0 auto;
	width: 100%;
	max-height: 0;
	position: absolute;
}

#mainMenuMobile
{
	position: absolute;
	top: 0;
	right: 5px;
	height: 3em;
	width: 100%;
	max-width: 320px;
	opacity: 0.95;
	z-index: 3;
}

.flexnav.opacity
{
	opacity: 0;
}

.flexnav.flexnav-show 
{
	display: flex;
	flex-direction: column;
	max-height: 2000px;
	opacity: 1;
	border-bottom-left-radius: 0.5rem;
	border-bottom-right-radius: 0.5rem;

	-webkit-transition: all .8s ease-in-out;
	-moz-transition: all .8s ease-in-out;
	-ms-transition: all .8s ease-in-out;
	transition: all .8s ease-in-out;
}

.flexnav.one-page {
	position: fixed;
	top: 50px;
	right: 5%;
	max-width: 200px;
}

.flexnav li
{
	font-size: 1em;
	position: relative;
	overflow: hidden;
	
}

.flexnav li a
{
	position: relative;
	display: block;
	padding: 0.7em;
	overflow: hidden;
	color: #222222;
	background-color: var(--mobileMenuBG1);
	border-bottom: 1px solid rgba(0, 0, 0, 0.15);
	font-weight: 400;
	font-style: normal;
	z-index: 2;
}

.flexnav li ul
{
	width: 100%;
}

.flexnav li ul li
{
	font-size: 1em;
	position: relative;
	overflow: hidden;
}

.flexnav li ul.flexnav-show li
{
	overflow: visible;
}

.flexnav li ul li a
{
	display: block;
	background-color: var(--mobileMenuBG2);
}

.flexnav ul li ul li a
{
	background: #bfbfbc;
}

.flexnav ul li ul li ul li a
{
	background: #cbcbc9;
}

.flexnav .touch-button
{
	position: absolute;
	top: 0;
	right: 0;
	width: 3rem;
	height: 2.6rem;
	background: rgba(0, 0, 0, 0.075);
	text-align: center;
	z-index: 999;
}

.flexnav .touch-button:hover
{
	cursor: pointer;
}

.flexnav .touch-button .navicon
{
	position: relative;
	top: 0.8rem;
	font-size: 2rem;
	color: var(--textColour);
	font-family: verdana !important;
	/*font-style: normal;*/
}

.flexnav .touch-button .navicon::after
{
	display: block;
	content:'▼';	
	font-style: normal;
	font-size: 0.8rem;

	transition: all 1s ease-in-out;
}

.flexnav .touch-button.active .navicon::after
{
	transform: rotate(180deg);
	color: var(--blueClr);
}

.menu-button
{
	position: relative;
	display: block;
	padding: 1em;
	background: transparent /*#a6a6a2*/;
	color: transparent /*#222222*/;
	cursor: pointer;
	border-bottom: none;
	width: 3em;
	float: right;
	font-family: Helvetica, Arial, sans-serif;
	font-size: 1.35em;
}

.menu-button.active
{
	width: auto;
	float: none;
	font-family: Helvetica, Arial, sans-serif;
	font-size: 1em;
	background: var(--brownClr);
	color: #FFF;
	border-bottom: 1px solid rgba(0, 0, 0, 0.2);
	border-top-left-radius: 0.8rem;
}

span.touch-button
{
	font-family: Helvetica, Arial, sans-serif;
}

.menu-button.one-page
{
	position: fixed;
	top: 0;
	right: 5%;
	padding-right: 45px;
}

.menu-button .touch-button
{
	background: transparent;
	position: absolute;
	z-index: 999;
	top: 0;
	right: 0;
	/*width: 60px;*/
	height: 100%;
	display: inline-block;
	text-align: center;
}

.menu-button .touch-button .navicon
{
	position: relative;
	top: 0.2em;
	right: 0.5em;
	color: #666;
	font-family: verdana !important;
	font-style: normal;
	font-size: 2em;
}
.menu-button .touch-button .navicon:after
{
	content:'\2261';	
}

.fsndImgGalWrapper,
.fsndEasySliderLegend,
.fsndGalPrev,
.fsndGalNext

{
	display: none !important;
}

#mainContent div.fsndThumbGal
{
	padding: 0 !important;
	background-color: transparent !important;
}

/*************************************
**************************************
****
****	Änderungen
****
**************************************
*************************************/

	#mainMenu li.level1 li.last-item
	{
		float: none;
	}
	
	ul.flexnav li.menuItem,
	.pagesMenu div.menuItem
	{
		display: block;
		float: none;
		padding: 0 !important;
		margin: 0 !important;
	}
	
	.flexnav-show
	{
		padding: 0;
		margin: 0;
		background-color: #a6a6a2;
	}
	.flexnav li
	{
		height: auto;	
	}
	.flexnav .clear
	{
		display: none;	
	}
	
@media all and (min-width: 800px) {
	
	#contentWrapper
	{
		padding-top: 0;
	}
	
	#mainMenuMobile
	{
		display: none;
	}
	
}

#header, #headerWrapper, .rmm-toggled, ul.level1, li.level1, ul.level2, li.level2
{
	z-index: 2;
}
