@charset "UTF-8";
/* CSS Document */
/* open-sans-300 - 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: 'Open Sans';
  font-style: normal;
  font-weight: 300;
  src: url('../Fonts/open-sans-v35-latin-300.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-300italic - 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: 'Open Sans';
  font-style: italic;
  font-weight: 300;
  src: url('../Fonts/open-sans-v35-latin-300italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-600 - 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: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  src: url('../Fonts/open-sans-v35-latin-600.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-600italic - 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: 'Open Sans';
  font-style: italic;
  font-weight: 600;
  src: url('../Fonts/open-sans-v35-latin-600italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-700 - 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: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  src: url('../Fonts/open-sans-v35-latin-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

@font-face{
    font-family:"Kelson";
    src:url("../Fonts/5202638/f4788719-465a-45cf-84f5-c3d2a1035858.eot?#iefix");
    src:url("../Fonts/5202638/f4788719-465a-45cf-84f5-c3d2a1035858.eot?#iefix") format("eot"),url("../Fonts/5202638/46373535-3412-4fff-be9e-2d0e35f472b1.woff2") format("woff2"),url("../Fonts/5202638/92f439b6-c18b-4793-b184-b8b8ca0051b4.woff") format("woff"),url("../Fonts/5202638/508501df-e918-4152-94c0-bbf09c2d6586.ttf") format("truetype");
}

/*** RESET ***/

* {
	margin:0px;
	padding:0px;
	border:none;
	box-sizing: border-box;
	}


optgroup
{
	padding-top:3px;
	padding-bottom:3px;
	}
	
table {
	border-collapse:collapse;
	}
th, td {
	text-align:left;
	vertical-align:top;
	}
.clear {
    clear: both;
}
/* visually hidden */
.vihi {
    position: absolute;
    display: block;
    margin: -1px;
    height: 1px;
    width: 1px;
    overflow: hidden;
}
/** LAYOUT BLOCKS **/

body {
	width:100%;
	background-color: #fff;
    font-family: 'Open Sans', Arial, sans-serif;
	font-size: 18px;
	font-weight: 300;
	line-height: 28px;
	color: #333;
}
header {
    display: block;
    position: relative;
}
#header {
	height: 100px;
    width: 100%;
    position: fixed;
    background-color: black;
    top: 0;
    z-index: 55
}
#homelink a {
    background-size: contain;
    background-repeat: no-repeat;
    background-position: top right;
    width: 280px;
    height: 55px;
    display: block;
    position: absolute;
    left: 20px;
    top: 25px;
}
#search {
    position: absolute;
    top: 20px;
    right: 20px;
}

#content {
	background: white;
    width: 1024px;
    margin: 40px auto 0;
}
body.level_0 .content_main {
    display: none;
}
#content > div > div {
    float: left;
    margin-right: 24px;
}
body.layout_pagets__home #content > div > div,
body.layout_pagets__subleft #content > div > div,
body.layout_pagets__subright #content > div > div,
body.layout_pagets__subleftright #content > div > div {
    width: 300px;
}
body.layout_pagets__home #content > div > div.content_main,
body.layout_pagets__subleft #content > div > div.content_main,
body.layout_pagets__subright #content > div > div.content_main {
    width: 728px;
}
body.layout_pagets__sub #content > div > div {
    width: 1024px;
}
#content > div > div:last-of-type {
	margin-right: 0;
}
section {
    clear: left;
}
footer {
	clear: both;
    display: block;
    height: 100px;
    font-size: 14px;
    line-height: 18px;
    text-align: center;
}
footer h1, footer h2, footer h3, footer h4, footer h5 {
    font-family: 'Kelson', 'OpenSans', 'Open Sans', Arial, sans-serif;
    font-weight: normal;
    margin: 0;
}
footer h3 {
    font-size: 32px;
    line-height: 52px;
}
footer > div {
	padding: 4px 12px;
}
footer a {
    color: #333;
}
p.nojs {
    position: absolute;
    background: #c00;
    padding: 40px;
    color: white;
    font-size: 32px;
    bottom: 0;
    width: 100%;
    line-height: 36px;
    font-weight: bold;
    text-align: center;
}
#headerimage,
#headerimage > div,
#headerimage > div > div {
    height: 30vh;
    width: 100%;
}
#headerimage {
    margin: 100px auto 0;
    position: relative;
    top: 0;
    z-index: 2;
    overflow: hidden;
    background-color: #333;
    display: block;
}
body.level_0 #headerimage {
}
#headerimage > div {
}
#headerimage > div > div {
    position: absolute;
    display: block;
    background-position: center bottom 15%;
    background-repeat: no-repeat;
    background-size: cover;
    top: 0;
    box-sizing: content-box;
}
#headerimage > ul {
    position: absolute;
    bottom: 0;
    padding-bottom: 20px;
    text-align: center;
    width: 100%;
}
#headerimage > ul > li {
    display: inline-block;
    width: 16px;
    height: 16px;
    margin: 10px;
    border-radius: 16px;
    background: rgba(255,255,255,0.4);
    border: 1px solid white;
    transition-duration: 0.5s;
}
#headerimage > ul > li:hover {
    cursor: pointer;
}
#headerimage > ul > li.act {
    background: rgba(0,0,0,0.6);
}
h1#subheader {
    display: none;
    position: absolute;
    margin: 0;
    width: 100%;
    text-align: center;
    top: 50%;
    z-index: 2000;
}
h1#subheader span {
    display: inline-block;
    padding: 13px 20px;
    font-size: 12vw;
    margin: 0;
    color: black;
    line-height: 36px;
    font-weight: normal;
}
h1#subheader span em {
    color: #c00;
    font-style: normal;
}


.promibox {
    position: absolute;
    width: 60vw;
    left: 20vw;
    top: 20vh;
    padding: 2vw;
    background: rgba(255,255,255,0.95);
    z-index: 2000;
}
.promibox .closer {
    width: 32px;
    height: 32px;
    border-radius: 32px;
    border: 3px solid #888;
    color: #888;
    text-align: center;
    line-height: 29px;
    font-size: 34px;
    font-family: Arial;
    position: absolute;
    right: 2vw;
    cursor: pointer;
}
.promibox .closer:hover {
    background-color: #ddd;
}


input#mailformsubmit {
    width: 20px;
    height: 20px;
    display: block;
    position: absolute;
    right: 0;
    top: 0;
}

.supernav {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    padding-right: 21px;
    padding-top: 7px;
}
#navi_main {
	position: absolute;
	bottom: -2px;
    right: 5px;
}
#navi_meta {
}
#navi_lang {
    padding-left: 20px;
    padding-right: 30px;
    padding-bottom: 1px;
}
#navi_social {
}
#navi_social a,
#navi_contact a {
    color: white;
    font-size: 24px;
    padding: 3px;
}
#navi_social a:hover,
#navi_contact a:hover {
    color: rgb(205,25,25);
}
.content_main {
    margin-bottom: 80px;
}
/* start page */
#curtain {display: none;}
body.level_0 #content {
    margin-top: 0;
    margin-bottom: 0;
}
body.level_0 #curtain {
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #000;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9000;
    opacity: 1;
}
body.level_0 #headerimage, 
body.level_0 #headerimage > div, 
body.level_0 #headerimage > div > div {
    height: calc(100vh - 200px);
}
/* loader */
@-webkit-keyframes scale {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1; }
  50% {
    -webkit-transform: scale(0.25);
            transform: scale(0.25);
    opacity: 0.7; }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1; } }
@keyframes scale {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1; }
  50% {
    -webkit-transform: scale(0.25);
            transform: scale(0.25);
    opacity: 0.7; }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1; } }
.ball-pulse {
    width: 100%;
    text-align: center;
    padding-top: 250px;
}
.news .article .ball-pulse {
    padding-top: 40px;
    height: 120px;
}

.ball-pulse > div:nth-child(1) {
  -webkit-animation: scale 1.5s -0.48s infinite cubic-bezier(0.25, 0.1, 0.25, 1);
          animation: scale 1.5s -0.48s infinite cubic-bezier(0.25, 0.1, 0.25, 1); }

.ball-pulse > div:nth-child(2) {
  -webkit-animation: scale 1.5s -0.24s infinite cubic-bezier(0.25, 0.1, 0.25, 1);
          animation: scale 1.5s -0.24s infinite cubic-bezier(0.25, 0.1, 0.25, 1); }

.ball-pulse > div:nth-child(3) {
  -webkit-animation: scale 1.5s 0s infinite cubic-bezier(0.25, 0.1, 0.25, 1);
          animation: scale 1.5s 0s infinite cubic-bezier(0.25, 0.1, 0.25, 1); }

.ball-pulse > div {
  background-color: #333;
  width: 40px;
  height: 40px;
  border-radius: 100%;
  margin: 8px;
  -webkit-animation-fill-mode: both;
          animation-fill-mode: both;
  display: inline-block;
}






/** GENERAL **/
p {
  -ms-hyphens: auto;
  -webkit-hyphens: auto;
    hyphens: auto;
}
p + p {
	padding-top:16px;
	}
#content table {
	width: 100%;
}
#content tr:nth-of-type(even) {
    background: rgba(0,0,0,0.1);
}
thead tr {
    background: #E42313;
}
th {
    font-weight: bold;
    white-space: nowrap;
    color: white;
}
td, th {
    padding-left: 10px;
    padding-right:10px;
}
td:first-of-type {
    padding-left: 0;
}
td:last-of-type {
    padding-right: 0;
}
#content td:first-of-type {
	padding-left: 2px;
}
#content td:last-of-type {
	padding-right: 2px;
}
dl {
}
dt {
    float: left;
    clear: left;
    width: 110px;
    font-size: 12px;
    color: #888;
    padding-right: 9px;
}
dd {
    font-size: 12px;
}
.align-center, .text-center {
    text-align: center;
}

/** Titles */
h1,
h2,
h3,
h4,
h5,
h6 {
    color: #444;
    font-style: normal;
    font-weight: 600;
    clear: left;
}

h1 {
    margin-bottom: 30px;
    font-size: 52px;
    line-height: 58px;
    font-weight: 300;
}
h2 {
    margin: 80px 0px 20px 0px;
    font-size: 32px;
    line-height: 36px;
}
h3 {
    margin:30px 0px 8px 0px;
    font-size: 24px;
    line-height: 28px;
}
h4 {
    font-size: 20px;
    line-height: 23px;
    margin-bottom: 5px;
    margin-top: 30px;
}
h5, h6 {
    font-size: 18px;
    line-height: 20px;
}
.content_main > div:first-of-type h2 {
    margin-top: 0;
}
.content_main section > h2:before {
    content: '/';
    color: rgb(205,25,25);
    padding-right: 7px;
    font-size: 56px;
    font-weight: 300;
    display: inline-block;
    transform-origin: bottom left;
}
.content_right h2 {
    font-size: 28px;
    line-height: 33px;
}
footer h2 {
    font-size: 22px;
    margin: 16px 0 16px 0;
    line-height: 24px;
}
hr {
    border-width: 0 0 1px 0;
    border-style: solid;
    border-color: #aaa;
    }
div.divider {
    margin-bottom: 10px;
}


/*
main > div:first-of-type h2,
aside > div:first-of-type h2,
div.frame-borderyellow h2,
div.frame-bordergrey h2 {
    margin-top: 0;
}
*/
time {
    font-size: 11px;
    color: #999;
}

/** Lists */
li {
	margin:0; 
	padding:0; 
	text-indent: -18px;
	list-style: none;
}
ul, .csc-textpic-intext-left ul, .csc-textpic-intext-left ol {
	margin:0; 
	padding:4px 0 8px 0;
}
.frame {
    clear: both;
}
.frame li {
  margin: 5px 0 5px 22px;
}
.frame li:before {
    content: '•';
    font-weight: bold;
    color: rgb(205,25,25);
    padding-right: 10px;
}


/* frame classes */
div.frame-borderyellow {
    border: 1px solid #fa8600;
    padding: 13px;
    margin-top: 40px;
}


.frame-space-before-extra-large {
	margin-top: 10em;
}


/** Links */
a {
	text-decoration:none;
	color: rgb(205,25,25);
    -webkit-transition: 1s; /* Safari */
    transition: 1s;
	}

a:hover {
	text-decoration:none;
	color:rgb(255,60,60);
    -webkit-transition: 0s; /* Safari */
    transition: 0s;
	}



.question {
    font-style: italic;
}
.author {
    font-size: 12px;
    text-transform: uppercase;
}
.quotes {
    color: rgb(205,25,25);
    font-size: 30px;
    line-height: 40px;
}
.quotes:before {
    color: #aaa;
    display: inline-block;
    content: '«';
    font-size: 50px;
    transform: scale(1,1.5);
}
.quotes:after {
    color: #aaa;
    display: inline-block;
    content: '»';
    font-size: 50px;
    transform: scale(1,1.5);
    margin-left: 8px;
}

.ce-gallery img {
    display: block;
    max-width: 100%;
    width: 100%;
    height: auto;
}
.ce-gallery[data-ce-columns="2"] .ce-column {
    width: calc(50% - 9px);
}
.ce-gallery[data-ce-columns="3"] .ce-column {
    width: calc(33.3% - 12px);
}
.ce-gallery[data-ce-columns="4"] .ce-column {
    width: calc(25% - 13.5px);
}
.ce-gallery[data-ce-columns="5"] .ce-column {
    width: calc(20% - 14.4px);
}
.ce-gallery[data-ce-columns="6"] .ce-column {
    width: calc(16.66% - 15px);
}
.ce-gallery[data-ce-columns="7"] .ce-column {
    width: calc(14.28% - 15.43px);
}
.ce-gallery[data-ce-columns="8"] .ce-column {
    width: calc(12.5% - 15.75px);
}
.ce-gallery figcaption {
    font-size: 80%;
    line-height: 130%;
}
/*
.frame-type-textmedia.frame-layout-1 .ce-gallery img {
    max-width: initial;
    width: auto;
    height: unset !important;
}

.frame-type-textmedia.frame-layout-1 .ce-gallery .ce-column {
    width: auto;
}
*/
.sf-filecollection-gallery-image-container img {
    display: block;
    max-width: 100%;
    height: auto;
}
.sf-filecollection-gallery-image-container a {
    vertical-align: left;
    display: inline;
    height: auto;
}
.sf-filecollection-gallery-image-container {
    padding: 0;
    margin-right: 10px;
    margin-bottom: 10px;
    float: left;
    display: inline-block;
    width: calc(25% - 7.5px);
}
.sf-filecollection-gallery-image-container:nth-of-type(4n+1) {
    margin-right: 0;
}

p.redline {
    border-bottom: 1px solid rgb(205,25,25);
}
p.redline + p.redline {
    padding-top: 5px;
}
li.list-checked {
    display: inline-block;
    float: left;
    width: 49%;
    font-size: 16px;
    border-bottom: 1px solid rgb(205,25,25);
    text-indent: 0;
    margin: 0;
    padding: 8px 0 0;
}
li.list-unchecked {
    display: inline-block;
    float: left;
    width: 49%;
    font-size: 16px;
    border-bottom: 1px solid rgb(205,25,25);
    text-indent: 0;
    margin: 0;
    padding: 8px 0 0;
}
li.list-checked:before {
    content: ' ';
    display: inline-block;
    height: 18px;
    width: 18px;
    box-sizing: border-box;
    padding-right: 0px;
    margin-right: 6px;
    background-color: rgb(205,25,25);
}
li.list-unchecked:before {
    content: ' ';
    display: inline-block;
    height: 18px;
    width: 18px;
    box-sizing: border-box;
    padding-right: 0px;
    margin-right: 6px;
    border: 1px solid #555;
}




/* sections and columns */
section h2.section-title {
    animation-duration: 2s;
    animation-fill-mode: both;
}
/* animation */
@keyframes pulse {
  from {
    text-shadow: 0 0 0 #000;
  }

  15%,45% {
    text-shadow: 0 0 12px #000;
  }

  30% {
    text-shadow: 0 0 0 #000;
  }

  to {
    text-shadow: 0 0 0 #000;
  }
}

.pulse {
  /*animation-name: pulse;*/
}

section h2.section-title:before {
    animation-duration: 2s;
    animation-fill-mode: both;
}
/* animation */
@keyframes hitit {
  from {
    transform: rotate(0);
  }

  15%,45% {
    transform: rotate(20deg);
  }

  30% {
    transform: rotate(0);
  }

  to {
    transform: rotate(0);
  }
}

section.pagets__subgreen > h2.section-title {
    padding: 16px 380px 16px 16px;
    background: rgb(39,93,22);
    color: white;
    line-height: 42px;
    height: 250px;
    margin-bottom: 60px;
    position: relative;
}
section.pagets__subgreen > h2.section-title:before {
    display: none;
}
section.pagets__subgreen > h2.section-title:after {
    display: block;
    background-repeat: no-repeat;
    background-position: right 20px top;
    background-image: url(/fileadmin/Umwelt/umwelt-light.svg);
    width: 294px;
    height: 250px;
    position: absolute;
    top: 0;
    right: 0;
    content: ' ';
    background-size: contain;
    transform: scale(1.2);
    transform-origin: right center;
}
section.pagets__subgreen > h2.section-title > span {
    display: block;
    font-size: 24px;
    font-weight: normal;
    line-height: 32px;
    margin-top: 12px;
}

.pulse:before {
  animation-name: hitit;
}


.content_main .ce-bodytext {
    max-width: 770px;
}


/* vsd tiles */
.ge-grid-3-float > div > div,
.ge-grid-3-float .tt_address_list .vcard {
    width: calc(33.32% - 12px);
    display: inline-block;
    margin-left: 18px;
    float: left;
    clear: none;
}
.ge-grid-4-float > div > div,
.ge-grid-4-float .tt_address_list .vcard {
    width: calc(24.98% - 13.5px);
    display: inline-block;
    margin-left: 18px;
    float: left;
    clear: none;
}
.ge-grid-3-float > div > div:nth-of-type(3n+1),
.ge-grid-3-float .tt_address_list .vcard:nth-of-type(3n+1) {
    clear: left;
    margin-left: 0;
}
.ge-grid-4-float > div > div:nth-of-type(4n+1),
.ge-grid-4-float .tt_address_list .vcard:nth-of-type(4n+1) {
    clear: left;
    margin-left: 0;
}
.vsdtile,
.ge-grid-3-float > div > div > header ,
.ge-grid-4-float > div > div > header {
    width: 100%;
    transition-duration: 0.3s;
    cursor: pointer;
    text-align: center;
    border-bottom: 18px solid white;
    background: #bbb;
}
.vsdtile h4,
.ge-grid-3-float > div > div > header h4 ,
.ge-grid-4-float > div > div > header h4 {
    margin: 0;
    padding: 6px 2px;
    transition-duration: 0.4s
}
.tile-image {
    line-height: 0px;
}
.vsdtile img {
    width: 100%;
    height: auto;
    border-color: #bbb;
    border-style: solid;
    border-width: 1px 1px 0 1px;
}
.vsdtile-detail,
.ge-grid-3-float .tx-ttaddress,
.ge-grid-4-float .tx-ttaddress {
    display: none;
    width: 1024px;
    transform-origin: top;
    position: relative;
    margin-bottom: 18px;
    /*
    transform: scaleY(0);
    transition-duration: 0.5s;
    */
}
.vsdtile-detail {
    background-color: #eee;
    padding: 8px;
}
.vsdtile-detail h4 {
    font-size: 28px;
    margin-bottom: 20px;
}

.frame-type-vsdenvironment {
    text-align: center;
}
.frame-type-vsdenvironment h4 {
    font-size: 18px;
    line-height: 28px;
}
.frame-type-vsdenvironment h5 {
    font-size: 16px;
    line-height: 22px;
    color: rgb(66,102,27);
}

.tt_address_list .vcard {
    background-color: #eee;
    height: 330px;
    margin-bottom: 18px;
}
.tt_address_list .vcard .col-md-10 {
    padding: 8px;
}
p.position {
    line-height: 20px;
    font-size: 14px;
    margin-bottom: 4px;
}
.vcard ul {
    padding: 0;
}
.tt_address_list .vcard li {
    list-style: none;
    text-indent: 0;
    margin: 0;
    font-size: 14px;
    line-height: 20px;
}
.tt_address_list .vcard li:before {
    display: none;
}
.tx-ttaddress:after {
    content: ' ';
    display: block;
    clear: left;
}
.tile-detailimages {
    float: right;
}
.vsdtile-detail .ce-bodytext {
    width: calc(100% - 250px);
    float: left;
}
.vsdtile-close {
    margin-top: 20px;
}
.frame-type-vsdtile.expanded .vsdtile h4,
.ge-grid-3-float > div > div.expanded > header h4,
.ge-grid-4-float > div > div.expanded > header h4,
.frame-type-vsdtile .vsdtile h4:hover,
.ge-grid-3-float > div > div > header h4:hover,
.ge-grid-4-float > div > div > header h4:hover,
.frame-type-vsdtile .vsdtile .tile-image:hover + h4 {
    background-color: rgb(205,25,25);
    color: white;
}
.ge-grid-3-float .frame-type-vsdtile:nth-of-type(3n+2) .vsdtile-detail,
.ge-grid-3-float > div > div:nth-of-type(3n+2) .tx-ttaddress {
    left: calc(-100% - 18px);
}
.ge-grid-3-float .frame-type-vsdtile:nth-of-type(3n+0) .vsdtile-detail,
.ge-grid-3-float > div > div:nth-of-type(3n+0) .tx-ttaddress {
    left: calc(-200% - 36px);
}
.ge-grid-4-float .frame-type-vsdtile:nth-of-type(4n+2) .vsdtile-detail,
.ge-grid-4-float > div > div:nth-of-type(4n+2) .tx-ttaddress {
    left: calc(-100% - 18px);
}
.ge-grid-4-float .frame-type-vsdtile:nth-of-type(4n+3) .vsdtile-detail,
.ge-grid-4-float > div > div:nth-of-type(4n+3) .tx-ttaddress {
    left: calc(-200% - 36px);
}
.ge-grid-4-float .frame-type-vsdtile:nth-of-type(4n+0) .vsdtile-detail,
.ge-grid-4-float > div > div:nth-of-type(4n+0) .tx-ttaddress {
    left: calc(-300% - 54px);
}
.tt_address_list .addressImage img {
    width: 100%;
    height: auto;
}
.fa, .fas {
    margin-right: 5px;
}


/* file icons in links */
p a[href$=".pdf"]:before, li a[href$=".pdf"]:before {
    content: '';
    display: inline-block;
    width: 16px;
    height: 16px;
    background-image: url('../Icons/FileExt/pdf.png');
    background-repeat: no-repeat;
    background-size: 100%;
    margin-right: 3px;
    top: 2px;
    position: relative;
}
p a[href$=".zip"]:before, li a[href$=".zip"]:before {
    content: '';
    display: inline-block;
    width: 16px;
    height: 16px;
    background-image: url('../Icons/FileExt/zip.png');
    background-repeat: no-repeat;
    background-size: 100%;
    margin-right: 3px;
    top: 2px;
    position: relative;
}
p a[href$=".doc"]:before,  li a[href$=".doc"]:before,
p a[href$=".docx"]:before, li a[href$=".docx"]:before,
p a[href$=".dot"]:before,  li a[href$=".dot"]:before,
p a[href$=".dotm"]:before, li a[href$=".dotm"]:before {
    content: '';
    display: inline-block;
    width: 16px;
    height: 16px;
    background-image: url('../Icons/FileExt/doc.png');
    background-repeat: no-repeat;
    background-size: 100%;
    margin-right: 3px;
    top: 2px;
    position: relative;
}
p a[href$=".xls"]:before,  li a[href$=".xls"]:before,
p a[href$=".xlsx"]:before, li a[href$=".xlsx"]:before,
p a[href$=".xlt"]:before,  li a[href$=".xlt"]:before,
p a[href$=".xltm"]:before, li a[href$=".xltm"]:before {
    content: '';
    display: inline-block;
    width: 16px;
    height: 16px;
    background-image: url('../Icons/FileExt/xls.png');
    background-repeat: no-repeat;
    background-size: 100%;
    margin-right: 3px;
    top: 2px;
    position: relative;
}
p a[href$=".jpg"]:before,  li a[href$=".jpg"]:before,
p a[href$=".jpeg"]:before, li a[href$=".jpeg"]:before {
    content: '';
    display: inline-block;
    width: 16px;
    height: 16px;
    background-image: url('../Icons/FileExt/jpg.png');
    background-repeat: no-repeat;
    background-size: 100%;
    margin-right: 3px;
    top: 2px;
    position: relative;
}
p a[href^="https://www.google.com/maps/place/"]:before, li a[href^="https://www.google.com/maps/place/"]:before {
    content: '';
    display: inline-block;
    width: 29px;
    height: 29px;
    background-image: url(/fileadmin/ic_place_24px_red.svg);
    background-repeat: no-repeat;
    background-size: 100%;
    margin-right: 3px;
    top: 2px;
    position: relative;
    margin-top: -9px;
}




/* powermail, form, search, login, buttons */
.tx-powermail,
.tx-felogin-pi1,
.tx-femanager,
.cleverreach-form,
form.registration  {
    background-color: #e3e3e3;
    padding: 12px;
}
.tx-powermail label,
.tx-felogin-pi1 label {   
    display: block;
}
.tx-powermail div.powermail_fieldwrap.nolabel > label {
    display: none;
}
.powermail_fieldwrap,
.tx-felogin-pi1 fieldset > div,
.femanager_fieldset,
.news-search-form .form-group,
.tx-indexedsearch-search-submit,
.cleverreach-field {
    margin-top: 8px;
}
.tx-powermail div.checkbox label, .tx-powermail div.radio label {
    margin-top: 0px;
    margin-bottom: 1px;
}
.powermail_fieldwrap_type_text {
    margin-top: 14px;
}
input, 
select, 
textarea {
    border-width: 0px 0px 1px 0px;
    border-color: rgb(205,25,25);
    border-style: solid;
    padding: 3px 5px;
    font-size: 16px;
    background: transparent;
}
input[type=text], 
input[type=tel], 
input[type=date], 
input[type=datetime-local], 
input[type=email], 
input[type=url], 
input[type=number], 
input[type=password], 
input[type=submit],
select, 
textarea {
    border-radius: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}
input#mailformsword {
    border: none;
    background: #e3e3e3;
    width: 197px;
    height: 22px;
    font-size: 16px;
    text-align: right;
    padding-right: 28px;
    width: 0;
    transform: scaleX(0);
}
input[required], 
select[required], 
textarea[required],
input[data-validation*=required],
input.required,
select.required,
textarea.required {
    /* border-left-color: rgb(205,25,25); */
}
input[type=text], 
input[type=tel], 
input[type=date], 
input[type=datetime-local], 
input[type=email], 
input[type=url], 
input[type=number], 
input[type=password], 
select, 
textarea {
    width: 100%;
}
textarea {
    border-width: 1px 1px 1px 1px;
}
.powermail_fieldwrap_type_textarea {
    margin-top: 28px;
}
/* custom checkboxes */
input[type=checkbox] {
    position: absolute;
    cursor: pointer;
    width: 16px;
    height: 16px;
    margin-right: 5px;
    border: none;
}
label > input[type=checkbox] {
    position: relative;
}
input[type=checkbox] + label {
    position: relative;
    padding-left: 25px;
}
input[type=checkbox] + label:before {
    content: ' ';
    position: absolute;
    top: 0;
    left: 0;
    width: 16px;
    height: 16px;
    background-color: #ccc;
    border: 1px solid #aaa;
}
.frame-layout-1 input[type=checkbox] + label:before {
    background-color: rgb(205,25,25);
}
input[type=checkbox]:hover + label:before {
    background-color: #ddd;
}
input[type=checkbox]:checked + label:before {
    background-color: rgb(205,25,25);
}
input[type=checkbox] + label {
    margin-right: 10px;
}
input[type=file] {
    font-size: 12px;
    border: none;
    padding: 0;
    line-height: 1px;
    width: 100%;
}
input#mailformsubmit {
    width: 20px;
    height: 20px;
    display: block;
    position: absolute;
    right: 0;
    top: 0;
    border: none;
    padding: 0;
}

ul.parsley-errors-list li:before {
    display: block;
    content: ' ';
    width: 0;
    height: 0;
    border-width: 12px;
    border-color: transparent transparent rgb(205,25,25);
    border-style: solid;
    margin-top: -16px;
    padding-right: 0;
}
ul.parsley-errors-list,
.tx-femanager .alert  {
    color: rgb(205,25,25);
    font-weight: bold;
    padding: 0;
}
.tx-femanager .alert button,
.tx-femanager .alert h4 {
    display: none;
}
ul.powermail_message_error {
    background: #fcc;
    font-weight: bold;
    color: #a00;
    border: 1px solid #f66;
    border-radius: 12px;
    padding: 15px;
    font-size: 16px;
}
ul.powermail_message_error li {
    text-indent: 0;
}

div.powermail_fieldwrap_text,
div.powermail_fieldwrap_submit {
    margin-top: 20px;
}

a.button, a.button-block,
button,
input[type=submit] {
    width: auto;
    min-width: 20px;
    cursor: pointer;
    display: inline-block;
    padding: 3px 10px 1px;
    border: 1px solid rgb(205,25,25);
    background-color: rgb(205,25,25);
    transition: 0.5s;
    font-size: 16px;
    line-height: 25px;
    font-weight: 300;
    color: white;
    text-transform: uppercase;
    user-select: none;
}
a.button-block,
button.button-block {
    display: block;
}
a.button:hover, a.button-block:hover,
button:hover,
input[type=submit]:hover {
    background-color: white;
    color: rgb(205,25,25);
}
a.button:active, a.button-block:active,
button:active,
input[type=submit]:active {
    color: rgb(205,25,25);
    background-color: rgb(250,120,120);
}
input[type=submit][disabled] {
    opacity: 0.4 !important;
    cursor: not-allowed;
}
a.button.btn-secondary, a.button-block.btn-secondary,
button.btn-secondary {
    border: 1px solid #666;
    background-color: #666;
    color: white;
}
a.button.btn-secondary:hover, a.button-block.btn-secondary:hover,
button:hover,
input[type=submit]:hover {
    background-color: white;
    color: #666;
}
a.button.btn-secondary:active, a.button-block.btn-secondary:active,
button.btn-secondary:active {
    color: #666;
    background-color: #ccc;
}
a.button + a.button,
button + button {
    margin-left: 10px;
}
.tx-powermail fieldset.nolabel legend {
    display: none;
}
fieldset {
    margin-bottom: 40px;
}
fieldset:last-of-type {
    margin-bottom: 0;
}
.tx-powermail h3 {
    display: none;
}
legend.powermail_legend {
    font-weight: 600;
}
input#mailformsubmit {
    width: 20px;
    height: 20px;
    display: block;
    position: absolute;
    right: 0;
    top: 0;
    border: none;
    padding: 0
}
.femanager_submit {
    margin-top: 20px;
}

.frame-layout-2 .tx-femanager,
.frame-layout-2 .cleverreach-form {
    padding: 0;
    background-color: transparent;
}

/* indexed search */
.tx-indexedsearch-searchbox {
    margin-bottom: 30px;
}
.tx-indexedsearch-percent {
    float: right;
    font-family: OpenSans, 'Open Sans', Arial, sans-serif;
    font-size: 16px;
    color: #999;
}
.tx-indexedsearch-res {
    border-bottom: 1px solid #ccc;
    padding-bottom: 10px;
}
ul.tx-indexedsearch-browsebox li:before {
    content: '';
    display: none;
}
ul.tx-indexedsearch-browsebox li {
    float: left;
    border-left: 2px solid rgb(205,25,25);
    margin: 0;
    text-indent: 0;
    padding: 0px 8px;
}
ul.tx-indexedsearch-browsebox li:first-of-type {
    border-left: none;
}
ul.tx-indexedsearch-browsebox li.tx-indexedsearch-browselist-currentPage {
    font-weight: bold;
    background-color: rgb(205,25,25) !important;
}




/* fileuploads */
.ce-uploads li {
    margin: 0 0 10px 0;
    text-indent: 0;
}
.ce-uploads-2 li {
    margin: 0 0 10px 10px;
    width: 148px;
    float: left;
}
.ce-uploads-2 li:nth-of-type(4n+1) {
    clear: left;
    margin: 0 0 10px 0;
}
.ce-uploads li:before {
    display: none;
}
.ce-uploads img {
    padding-right: 8px;
    float: left;
}
.ce-uploads-2 img {
    border: 1px solid #ccc;
    padding: 0;
    box-sizing: content-box;
    float: none;
}
.ce-uploads span {
    font-size: 13px;
    line-height: 15px;
    font-weight: normal;
    padding-top: 4px;
    display: inline-block;
}
.ce-uploads-filesize {
    padding-left: 8px;
    font-size: 11px;
    color: #999;
}
.ce-uploads img.icon {
    width: 32px;
}

.csc-textpic-intext-left-nowrap h1,
.csc-textpic-intext-right-nowrap h1 {
    margin-top: 0;
}


/* events */
.event-list-item {
    margin-bottom: 15px;
}
.event-list-title {
    border-bottom: 1px solid #ccc;
    padding-bottom: 2px;
}
.event-list-date {
    font-size: 0.9rem;
    line-height: 1rem;
    color: #999;
    margin-top: 3px;
}
div.event-location > span {
    white-space: nowrap;
}
div.event-location > span:not(:last-of-type):after {
    content: ', ';
    letter-spacing: 2px;
    white-space: normal;
}
.event-detail-row {
    margin-top: 36px;
}
.event-date,
.event-location {
    font-size: 1rem;
    line-height: 1.2rem;
    color: #999;
    margin-top: 3px;
}
a.icalDownload {
    width: 20px;
    height: 20px;
    margin-left: 10px;
    overflow: hidden;
    display: inline-block;
    font-size: 1px;
    color: white !important;
    margin-bottom: -1px;
}
a.icalDownload:before {
    content: "\f073";
    left: 1px;
    top: 1px;
    font-family: 'Font Awesome 5 Free';
    font-size: 18px;
    color: hsl(0deg 0% 37%);
    position: relative;
}
a.icalDownload:hover:before {
    color: rgb(205,25,25);
}
.event-files li {
    margin: 2px 0;
    text-indent: 0;
}
.event-files li:before {
    content: '';
    display: none;
}
.event-registration-row.error-class {
    background-color: #fee;
    color: #900;
}



#colorbox, #cboxOverlay, #cboxWrapper {
    overflow: visible;
}
#cboxTitle  {
    left: 5px;
    top: 100%;
}
.webcam a {
    position: relative;
}
.webcam a span {
    color: #fff;
    font-size: 12px;
    line-height: 16px;
    position: absolute;
    bottom: 6px;
    left: 5px;
}


/* f.... lightbox */

#sd-lightbox {
    display: none;
}

#sd-lightbox.open {
    display: block;
}



/* jarallax */
.jarallax {
    position: relative;
    z-index: 0;
}
.jarallax > .jarallax-img {
    position: absolute;
    object-fit: cover;
    /* support for plugin https://github.com/bfred-it/object-fit-images */
    font-family: 'object-fit: cover;';
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
}

/* slick and tabslider */
.grid-tabslide ul {
    padding: 0;
}
.grid-tabslide li {
    margin: 0;
    text-indent: 0;
}
.grid-tabslide li:before {
    display: none;
}
.grid-tabslide > ul {
    display: flex;
    justify-content: space-between;
    margin: 0 -12px;
}
.grid-tabslide > ul > li {
    background-color: #bbb;
    padding: 12px;
    margin: 0 12px;
    flex: 1 1 0px;
}
.grid-tabslide > ul > li.act {
    background-color: #eee;
}
.grid-tabslide > ul > li a {
    color: white;
}
.frame-type-vsdtabslider{
    opacity: 1;
    transition-duration: 0.5s
}
.frame-type-vsdtabslider:not(.act) {
    height: 0;
    overflow: hidden;
    opacity: 0;
}
.frame-type-vsdtabslider > h5 {
    display: none;
}
.tabslider-icon {
    padding: 20px 70px 15px;
}
.tabslider-text {
    color: white;
    font-family: 'Kelson';
    hyphens: auto;
    text-align: center;
}
.tabslider-slide {
    padding: 8px;
}
.slick-slider {
    background-color: #eee;
    padding-top: 24px;
}
.slick-track {
    display: flex;
}
.slick-slide {
    margin: 0 12px;
    float: none;
    height: auto;
}
.slick-list {
    margin: 0 -12px;
}
ul.slick-dots {
    background-color: #eee;
    bottom: -33px;
}
.slick-dots li {
    bottom: 3px;
}
.slick-dots li,
.slick-dots li button {
    width: 24px;
    height: 24px;
}
.slick-dots li button:before {
    font-size: 16px;
    line-height: 24px;
    height: 24px;
    width: 24px;
}
.slick-prev, .slick-next {
    top: calc(100% + 18px);
}
.slick-prev {
    left: 5px;
    z-index: 1;
}
.slick-next {
    right: 5px;
    z-index: 1;
}
.slick-prev:before, .slick-next:before {
    color: black;
}