@font-face {
    font-family: 'kfwregular';
    src: url('../Fonts/2019/kfw-book.eot');
    src: url('../Fonts/2019/kfw-book.eot?#iefix') format('embedded-opentype'),
         url('../Fonts/2019/kfw-book.woff2') format('woff2'),
         url('../Fonts/2019/kfw-book.woff') format('woff'),
         url('../Fonts/2019/kfw-book.ttf') format('truetype'),
         url('../Fonts/2019/kfw-book.svg#kfwregular') format('svg');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'kfwmedium';
    src: url('../Fonts/2019/kfw-medium.eot');
    src: url('../Fonts/2019/kfw-medium.eot?#iefix') format('embedded-opentype'),
         url('../Fonts/2019/kfw-medium.woff2') format('woff2'),
         url('../Fonts/2019/kfw-medium.woff') format('woff'),
         url('../Fonts/2019/kfw-medium.ttf') format('truetype'),
         url('../Fonts/2019/kfw-medium.svg#kfwmedium') format('svg');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'kfw_monoregular';
    src: url('../Fonts/2019/kfw-mono.eot');
    src: url('../Fonts/2019/kfw-mono.eot?#iefix') format('embedded-opentype'),
         url('../Fonts/2019/kfw-mono.woff2') format('woff2'),
         url('../Fonts/2019/kfw-mono.woff') format('woff'),
         url('../Fonts/2019/kfw-mono.ttf') format('truetype'),
         url('../Fonts/2019/kfw-mono.svg#kfw_monoregular') format('svg');
    font-weight: normal;
    font-style: normal;
}
*{
    line-height: 115%;
    box-sizing:border-box;
    -moz-box-sizing:border-box;
    -webkit-box-sizing:border-box;
}
html {
    font-size: 6px;
}
body {
    font-size: 2.5rem;
}
body,
html{
    margin: 0;
    padding: 0;
    background-color: #ffffff;
    font-family: kfwmedium;
    font-weight:normal;
    color:#000000;
    line-height:115%;
}
p,ul,h1,h2,h3,h4{
    padding:0;
    font-weight:normal;
}
h1,h2,h3,h4{
    margin:0;
}
b,strong{
    font-weight:400!important;
    font-family: kfwmedium;
}
li{
    list-style-type:none;
}
h1,h2,h3,h4,h5{
    font-family:kfwmedium;
    line-height:115%;
    font-weight:normal;
}
img,a{
    border:none;
    text-decoration:none;
}
a,
a:hover {
	color:black;
    text-decoration: none;
}
a:hover {
    text-decoration: none!important;
}
.detail .links .description a {
    text-decoration: underline;
}
input,
textarea{
    outline:none;
    border:none;
}
input{
    background-color:transparent;
}
button:focus {
    outline: none;
}
/* cookies start */
#cookie-teaser {
    position: fixed;
    bottom: 0;
    min-height: 50px;
    width: 100%;
    z-index: 999999999;
    color: white;
    background-color: rgba(0,0,0,0.9);
    padding: 20px 20px;
    font-size: 1.5rem;
    line-height: 28px;
    display: none;
}
#cookie-teaser #cookieOk {
    background-color: white;
    border-radius: 10em;
    padding: 7.5px 15px;
    margin-left: 20px;
    color: #333;
    height: 40px;
    line-height: 25px;
}
#cookie-teaser .cookie-text-text {
    max-width: calc(100% - 75px);
}
#cookie-teaser .cookie-text-text,
.cookie-datenschutz {
	display: inline-block;
}
#cookie-teaser .cookie-button {
    max-width: 75px;
}
.cookie-text {
	font-size: 1.8rem;
}
.cookie-datenschutz,
.cookie-text {
    width: auto;
}
.cookie-text a {
    color: white;
    text-decoration: underline;
}
#cookieOk {
    text-decoration: none;
}
h1 {    
    line-height: 100%;
    font-size: 3rem;
    padding: 0;
    font-family: kfwmedium;
}
h2 {
    font-size: 3rem;
    font-family: kfwmedium;
    padding-bottom: 2rem;
}
.joCol-md-12 {
    width: 100%;
    overflow: hidden;
}
#joCarousel {
    width: 100%;
}
#joCarousel img {
    width: 100%;
    height: auto;
}
.joCarousel {
    height: calc(100vh - 48px);
}
.joCarousel .carousel-inner,
.joCarousel .carousel-inner .carousel-item,
.joCarousel .carousel-inner .carousel-item .row {
    height: 100%;
}
.joCarousel .item-title {
    font-size: 6rem;
    line-height: 90%;
    font-family: kfwmedium;
}
.joCarousel .carousel-inner > .carousel-item:first-child .item-subtitle {
    font-size: 6rem;
    line-height: 85%;
    letter-spacing: -0.25rem;
    font-family: kfwmedium;
}
.joCarousel .carousel-inner > .carousel-item:first-child .item-title,
.joCarousel .carousel-inner > .carousel-item:first-child .item-subtitle {
    word-spacing: 100vw;
}
.joCarousel .item-subtitle {
    position: absolute;
    bottom: 15px;
    font-size: 4rem;
    line-height: 120%;
    font-family: kfw_monoregular;
}
/* .joCarousel .carousel-inner .carousel-item:nth-child(2n - 1) {
    background-color: rgb(255,0,74);
}
.joCarousel .carousel-inner .carousel-item:nth-child(2n) {
    background-color: rgb(0,132,255);
} */
.joCarousel .carousel-inner .carousel-item {
    background-color: rgb(0,132,255);
}
.joCarousel .carousel-inner .carousel-item:first-child {
    /*background-color: rgb(102, 204, 204);*/
    background-color: rgb(240, 0, 90);
    color: #ffffff;
}
.joCarousel a,
.joCarousel a:hover {
    color: black;
}
.joCarousel .item-img {
    height: 60%;
}
.joCarousel .item-text {
    height: 40%;
    padding-top: 10px;
    padding-left: 10px;
    padding-right: 5%;
}
.navigation {
    position: fixed;
    z-index: 55;
    width: 100%;
    background-color: white;
    top: 0px;
    /*transition: top 0.2s ease-in-out;*/
    border-bottom: 1px solid #000;
}
.navigation.joNavHide {
    top: -40px;
}
.navigation > .navigation-menu{
    height: 48px;
}
.navigation .navigation-menu {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.item-img {
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    height: 100%;
}
.nav-options-container {
    display: -webkit-box!important;
    display: -ms-flexbox!important;
    display: flex;
}
.nav-options-container img {
    width: 100%;
    height: auto;
}
.nav-options-container > div:not(.option-menu){
    display: none;
}
.nav-options-container > div {
    cursor: pointer;
    width: 48px;
}
.nav-options-container > div {
    background-color: rgb(170,170,170);
}
.nav-options-container > div.collapsed {
    background-color: rgb(255,255,255);
}
.logo-container .logo {
    padding: 8px 10px 10px 10px;
    cursor: pointer;
    display: block;
    width: 133.2px;
}
.logo-container .logo img {
    width: 100%;
    height: auto;
}
.navigation-menu-content .jobtn,
.navigation-menu-content input {
    font-size: 2.3rem;
}
.navigation-menu-content .social-btn-container,
.navigation-menu-content .search-container,
.navigation-menu-content .newsletter-container {
    background-color: rgb(170,170,170);
}
.navigation-menu-content .search-container .input-row {
    padding: 20px 0;
    text-align: center;
}
.navigation-menu-content .search-container .tx_indexedsearchSearchbox,
.navigation-menu-content .newsletter-container input#email {
    height: 40px;
    line-height: 40px;
    background-color: white;
    border-radius: 10em;
    padding: 0 15px;
    width: 50%;
}
.navigation-menu-content .newsletter-container form.error input#email {
    color: red;
    border: 1px solid red;
}
.navigation-menu-content .search-container .tx_indexedsearchSearchbox::placeholder,
.navigation-menu-content .newsletter-container #email::placeholder {
    opacity: .5;
}
.navigation-menu-content .newsletter-container form.error #email::placeholder {
    color: red;
}
.navigation-menu-content .newsletter-container input#email {
    vertical-align: middle;
}
.navigation-menu-content .newsletter-container .submit,
.navigation-menu-content .search-container .submit {
    color: white;
    background-color: black;
    border-radius: 10em;
    padding: 7.5px 15px;
    margin-left: 10px;
    display: inline-block;
    cursor: pointer;
	vertical-align: top;
	font-size: 2.3rem;
    height: 40px;
    line-height: 25px;
}
.navigation-menu-content .newsletter-container .menu-newsletter {
    padding: 20px 0;
}
.navigation-menu-content .newsletter-container .fieldrow {
    text-align: center;
}
.navigation-menu-content .newsletter-container .accept-datenschutz {
    display: inline-block;
    vertical-align: middle;
    font-size: 2rem;
}
.navigation-menu-content .newsletter-container .accept-datenschutz a {
    color: black;
    text-decoration: underline;
}
.navigation-menu-content .newsletter-container .checkbox-control {
    display: inline-block;
    vertical-align: middle;
    position: relative;
    padding-left: 30px;
    margin-bottom: 5px;
    padding-top: 15px;
    cursor: pointer;
}
.navigation-menu-content .newsletter-container .datenschutz-checkbox {
    display: none;
}
.navigation-menu-content .newsletter-container .control_show {
    position: absolute;
    top: 2px;
    left: 0;
    height: 20px;
    width: 20px;
    background: white;
}
.navigation-menu-content .newsletter-container .checkbox-control:hover input ~ .control_show,
.navigation-menu-content .newsletter-container .checkbox-control input:focus ~ .control_show {
    background: #cccccc;
}
.navigation-menu-content .newsletter-container .checkbox-control input:checked ~ .control_show {
    background: black;
}
.navigation-menu-content .newsletter-container .checkbox-control:hover input:not([disabled]):checked ~ .control_show,
.navigation-menu-content .newsletter-container .checkbox-control input:checked:focus ~ .control_show {
    background: #0e6647d;
}
.navigation-menu-content .newsletter-container .checkbox-control input:disabled ~ .control_show {
    background: #e6e6e6;
    opacity: 0.6;
    pointer-events: none;
}
.navigation-menu-content .newsletter-container .checkbox-control .control_show:after {
    box-sizing: unset;
    content: '';
    position: absolute;
    display: none;
    left: 8px;
    top: 4px;
    width: 3px;
    height: 8px;
    border: solid #ffffff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}
.navigation-menu-content .newsletter-container .checkbox-control input:checked ~ .control_show:after {
    display: block;
}
.navigation-menu-content .newsletter-container .checkbox-control input:disabled ~ .control_show:after {
    border-color: #7b7b7b;
}
.navigation-menu-content .social-btn {
    text-align: center;
    padding: 20px 0;
}
.navigation-menu-content .social-btn-container .jobtn {
    display: inline-block;
    height: 40px;
    line-height: 40px;
    padding: 0px 30px;
    border-radius: 3em;
    font-size: 2.3rem;
    line-height: 40px;
    cursor: pointer;
    color: black;
}
.navigation-menu-content .menu-container {
    position: absolute;
    right: 0;
    font-size: 3rem;
    z-index: 5;
    background-color: rgb(170,170,170);
    color: white;
    width: 100%;
}
.navigation-menu-content .menu-container .datenschutz-container {
    margin-top: auto;
}
.navigation-menu-content .menu-container .menu-container-holder {
    height: calc(100vh - 48px);
    overflow: scroll;
}
.navigation-menu-content .menu-container .menu-container-holder > .row {
    height: 100%;
}
.navigation-menu-content .menu-container li.active {
    background-color: rgb(210,210,210);
}
.navigation-menu-content .menu-container .datenschutz-container > div:hover {
    background-color: rgb(255,255,255);
}
.navigation-menu-content .menu-container a {
    padding: 9px 10px 12px 10px;
    display: block;
    color: black;
}
.navigation-menu-content .social-btn-container .jobtn:not(:last-child) {
    margin-right: 20px;
}
.jobtn.fc_btn {
    background-color: rgb(0,132,255);
}
.jobtn.tw_btn {
    background-color: rgb(120,240,255);
}
.jobtn.in_btn {
    background-color: rgb(255,169,140);
}
.joTriggerBar header h1,
.joTriggerBar header h2,
.joTriggerBar header h3 {
    padding: 0;
}
.joTriggerBar header {
    padding: 9px 30px 12px 10px;
    position: relative;
    cursor: pointer;
}
.joTriggerBar header h2 {
    font-size: 2.8rem;
    font-family: kfwmedium;
}
.joFliesstext {
    /* word-break: break-all;
    word-break: break-word; */
}
.joFliesstext a {
    word-break: break-all;
    word-break: break-word;
}
.joTriggerBar .joFliesstext,
.frame-type-text .joFliesstext {
    padding: 10px 10px 20px 10px;
    font-size: 2.5rem;
}
/* HEADER COLOR - START */
.joKfw.layout_4 .joTriggerBar header,
.joKfw.layout_4 .sub-collapse-header {
    background-color: rgb(120,240,255);
}
.joKfw.layout_4 .frame-type-header.frame-layout-5 {
    background-color: rgb(0,132,255);
}
.joKfw.layout_5 .joTriggerBar header,
.joKfw.layout_5 .sub-collapse-header {
    background-color: rgb(255,214,183);
}
.joKfw.layout_5 .frame-type-header.frame-layout-5 {
    background-color: rgb(255,102,40);
}
.joKfw.layout_6 .frame-type-header.frame-layout-5 {
    background-color: rgb(140,60,255);
}
.joKfw.layout_6 .row.clearfix.no-gutters.content > div:nth-child(2n - 1) .frame-type-header.frame-layout-5 {
    background-color: rgb(140,60,255);
}
.joKfw.layout_6 .row.clearfix.no-gutters.content > div:nth-child(2n) .frame-type-header.frame-layout-5 {
    background-color: rgb(188,167,255);
}
.joKfw.layout_6 .sub-collapse-header {
    background-color: rgb(188,167,255);
}
.joKfw.layout_7 .frame-type-header.frame-layout-5,
.joKfw.layout_7 .sub-collapse-header {
    background-color: rgb(255,223,0);
}
.joKfw.layout_8 .frame-type-header.frame-layout-5,
.joKfw.layout_8 .sub-collapse-header {
    background-color: rgb(55,225,155);
}
.joKfw.layout_9 .frame-type-header.frame-layout-5 {
    background-color: rgb(120,120,120);
}
.joKfw.layout_9 .joTriggerBar header,
.joKfw.layout_9 .sub-collapse-header {
    background-color: rgb(210,210,210);
}
.joKfw.layout_9 .row.clearfix.no-gutters.content > div:nth-child(2n - 1) .frame-type-header.frame-layout-5 {
    background-color: rgb(120,120,120);
}
.joKfw.layout_9 .row.clearfix.no-gutters.content > div:nth-child(2n) .frame-type-header.frame-layout-5 {
    background-color: rgb(210,210,210);
}
.joKfw.layout_10 .frame-type-header.frame-layout-5 {
    background-color: rgb(255,0,74);
}
.joKfw.layout_10 .joTriggerBar header,
.joKfw.layout_10 .sub-collapse-header {
    background-color: rgb(136,189,162);
}
.joKfw.layout_11 .frame-type-header.frame-layout-5 {
    background-color: rgb(136,189,162);
}
.joKfw.layout_11 .sub-collapse-header .joVaColOuter {
    background-color: rgb(136,189,162);
}
.joKfw.layout_11 .sub-collapse-header {
    background-color: #524792;
    color: #ffffff;
}
.joKfw.layout_11 .joVeranstaltungen .joHoversIt:hover .ticket_link::before,
.joKfw.layout_11 .joVeranstaltungen .joHoversIt:hover .ticket_link::after {
	background-color: #ffecf9;
}
#joVeranstaltungen .joColDay.joVeranstaltung .joEventCol {
    width: 100%;
}
.joDatumBox {
	font-family: kfw_monoregular;
}
/* HEADER COLOR - ENDE */
.frame-type-header.frame-layout-5 {
    height: 140px;
    padding: 0 0 15px 10px;
    position: relative;
}
.frame-type-header.frame-layout-5 header {
    position: absolute;
    bottom: 15px;
}
.frame-type-header.frame-layout-5 header h1 {
    font-size: 6rem;
    font-weight: 400;
    line-height: 85%;
    letter-spacing: -0.2rem;
}
.frame-type-image .ce-row {
	margin: 20px 0;
}
footer {
    background-color: rgb(210,210,210);
    font-size: 1.6rem;
    margin-top: 120px;
}
footer .left {
    padding: 0!important;
}
footer .left > .frame-type-image {
    padding: 15px 10px 0 10px;
}
footer .left .frame-type-image img {
    width: 100%;
    height: auto;
}
footer .left .frame-type-image .ce-gallery,
footer .left .frame-type-image .ce-gallery .ce-row,
footer .left .frame-type-image .ce-gallery .ce-column,
footer .left .frame-type-image .ce-gallery .image {
	width: 100%;
}
footer .left > .frame-type-text {
    padding: 30px 0 40px 10px;
}
footer .left > .frame-type-text .joFliesstext > p:first-child {
    margin-bottom: 15px;
}
footer .left > .frame-type-text a {
    color: #000000;
}
footer .frame-type-menu_subpages ul,
footer .frame-type-menu_pages ul {
    display: table;
    margin-left: auto;
    padding-right: 5rem;
    font-size: 1.9rem;
    padding-top: 30px
}
footer .frame-type-text .joFliesstext {
    padding: 0;
}
footer .frame-type-menu_subpages ul li,
footer .frame-type-menu_pages ul li {
    margin-bottom: 5px;
}
footer .frame-type-menu_subpages ul a,
footer .frame-type-menu_pages ul a {
    color: #000000;
}
footer .right {
    padding: 0 10px!important;
}
footer .right > div:not(:last-child) {
    margin-bottom: 10px;
}
footer .right > div:last-child {
    margin-bottom: 40px;
}
footer .right .ce-gallery {
    margin-bottom: 0;
}
footer .right .frame-type-image:not(:last-child) .ce-gallery,
footer .right .frame-type-image:not(:last-child) .image {
    width: 100%;
}
footer .right .frame-type-image img {
    width: 100%;
    height: auto;
}
footer .right .frame-type-image:last-child .ce-gallery,
footer .right .frame-type-image:last-child .image {
    width: 100%;
}
footer .frame-type-image .ce-row {
    margin: 0;
}
footer .right .frame-type-image .ce-row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
footer .right .frame-type-image .ce-row > .ce-column {
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    max-width: 100%;
    position: relative;
    width: 100%;
    min-height: 1px;
}
footer .middle {
	display: none;
}
.team_members {
    font-size: 1.5rem;
    padding-top: 30px;
    padding-right: 40%;
    padding-left: 10px;
}
.team_members img {
    width: 100%;
    height: auto;
}
.team_members h3 {
    font-size: 4rem;
}
.team_members header {
    padding: 0 0 15px 0;
    font-family: kfwmedium;
}
.team_members .joFliesstext {
    padding: 0 0 15px 0;
    font-size: 1.9rem;
}
.team_members a {
    color: black;
}
.team_members .ce-below .ce-gallery {
	margin-top: 0;
}
.joOrteOverview .joOrte-header {
    background-color: rgb(230,230,230);
    position: relative;
}
.joOrteOverview .joOrte-header .joOrte-title {
    font-size: 2.8rem;
    padding: 7px 10px 9px 10px;
    cursor: pointer;
    font-family: kfw_monoregular;
}
.joOrteOverview .joOrte-header .joOrte-title > div {
	padding-right: 78px;
}
.joOrte-header .link-container {
    position: absolute;
    right: 35px;
    top: 0;
    width: 35px;
}
.joOrte-header .link-container img {
	width: 35px;
	/* height: auto; */
    height: 35px;
}
.joOrte-header .joCloser {
    position: absolute;
    right: 0;
    top: 0;
    width: 35px;
    height: 35px;
    cursor: pointer;
}
.joOrte-header .joPlus {
    position: relative;
    left: calc(50% - 7px);
    top: calc(50% - 7px);
    width: 14px;
    height: 14px;
}
.joOrte-header .joPlus:before,
.joOrte-header .joPlus:after {
    position: absolute;
    left: 7px;
    content: ' ';
    height: 14px;
    width: 2px;
    background-color: black;
    transition: transform .5s ease-in-out;
}
.joPlus {
    position: relative;
    left: calc(50% - 7px);
    top: calc(50% - 7px);
    width: 14px;
    height: 14px;
}
.joPlus:before,
.joPlus:after {
    position: absolute;
    left: 7px;
    content: ' ';
    height: 14px;
    width: 2px;
    background-color: black;
    transition: transform .5s ease-in-out;
}
.joPlus:before {
    transform: rotate(45deg);
}
.joPlus:after {
    transform: rotate(-45deg);
}
.joOrte-header.collapsed .joPlus:before {
    transform: rotate(0deg);
}
.joOrte-header.collapsed .joPlus:after {
    transform: rotate(-90deg);
}
.joOrte-item .joOrte-sub-header {
    padding: 7px 10px 9px 10px;
    background-color: rgb(190,255,223);
    font-family: kfwmedium;
}
.joOrte-item .joOrte-events-content a {
    display: block;
    padding: 5px 10px;
    color: black;
    text-decoration: underline;
}
.joOrte-item .joOrte-tipps-content {
    padding: 10px 10px 20px 10px;
}
.joOrte-item .joOrte-content {
    padding: 0;
}
.joOrte-item .joOrte-img {
    margin-top: 30px;
    padding: 0 10px;
}
.joOrte-item .joOrte-img img {
    width: 100%;
    height: auto;
}
.joOrte-item .joOrte-bodytext {
    padding: 10px 10px 20px 10px;
}
.joOrte-item .joOrte-bodytext-en {
    position: relative;
}
.joOrte-item .joOrte-bodytext-en .joCloser {
    position: absolute;
    right: 10px;
    top: 0;
    padding: 6px;
}
.joOrte-item .joOrte-bodytext-en-header.collapsed .joPlus:before {
    transform: rotate(0deg);
}
.joOrte-item .joOrte-bodytext-en-header.collapsed .joPlus:after {
    transform: rotate(-90deg);
}
.joOrte-item .joOrte-bodytext-en-header {
    padding: 7px 10px;
    margin: 0 10px 20px;
    background-color: rgb(190,255,223);
    cursor: pointer;
    font-family: kfwmedium;
}
.joOrte-item .joOrte-bodytext-en-item {
    padding: 0px 10px 20px 10px;
}
.joOrte-item .joOrte-events-content {
    margin-bottom: 20px;
}
.joSlider_01{
	overflow: hidden;
}
.detail .links {
    margin-top: 30px;
    padding: 0
}
.detail .rechts > div {
    position: relative;
}
.detail .links .title {
    padding: 0 10px 15px 10px;
}
.detail .links .artist-header {
    padding: 0 10px 20px;
    font-size: 3rem;
    line-height: 100%;
    font-family: kfwregular;
}
.detail .title h2 {
    padding: 0;
    font-size: 6rem;
    line-height: 95%;
    letter-spacing: -0.2rem;
}
.detail .links .subtitle {
    padding: 20px 10px 15px 10px;
}
.detail .links .subtitle h3 {
    font-size: 3rem;
    line-height: 100%;
    font-family: kfwregular;
}
.genreAndType {
    padding-left: 10px;
}
.genreAndType .box,
.type-container .item,
.genre-container .item {
    display: inline-block;
    vertical-align: middle;
    border: 1px solid black;
    border-radius: 10em;
    font-size: 2rem;
    text-transform: uppercase;
}
.genreAndType .box a,
.joVeranstaltungen .genreAndType .box,
.results-container .genreAndType .box,
.genreAndType .box.d-md-none,
.type-container .item,
.genre-container .item {
    padding: 2px 20px;
}
.genreAndType .box a {
    display: block;
}
.type-container .item {
    padding: 2px 35px;
}
.genreAndType .auffuehrungstype_box,
.type-container .item {
    background-color: black;
    color: white;
}
.genreAndType .auffuehrungstype_box a,
.type-container .item a {
    color: white;
}
.genreAndType .genre_box a {
    color: black;
}
.genreAndType .box:not(:last-child) {
    margin-right: 10px;
}
.genreAndType .box {
    margin-top: 5px;
}
.detail .links .description {
    padding: 20px 10px;
}
.detail .joCloser {
    position: absolute;
    right: 10px;
    top: calc(50% - 8px);
}
.detail .sub-collapse-header {
    padding: 9px 10px 12px 10px;
    position: relative;
    cursor: pointer;
    font-size: 2.4rem;
    font-family: kfwmedium;
}
.detail .sub-collapse-header .joPlus {
    left: calc(50% - 7px);
    top: calc(50% - 7px);
    width: 14px;
    height: 14px;
}
.detail .sub-collapse-header .joPlus:before, 
.detail .sub-collapse-header .joPlus:after {
    height: 14px;
    left: 7px;
    width: 2px;
}
.detail .sub-collapse-header.collapsed .joPlus:before {
    transform: rotate(0deg);
}
.detail .sub-collapse-header.collapsed .joPlus:after {
    transform: rotate(-90deg);
}
.detail .description-en-item {
    padding: 0 10px 20px 10px;
    font-family: kfwmedium;
    line-height: 115%;
    font-size: 2.1rem;
}
.en-text,
.joOrte-bodytext-en-item {
    font-family: kfwmedium;
    font-size: 2.1rem;
}
.detail .info-content .info-item-container {
    padding: 10px 10px 0 10px;
}
.detail .info-content .info-item-container .info-item {
    padding-bottom: 20px;
}
.detail .info-content .short-lang {
    display: inline-block;
    margin-left: 5px;
}
.detail .sponsor-content .sponsor-item {
    padding: 20px 10px;
}
.detail .sponsor-content .sponsor-item .item:not(:last-child) {
    margin-bottom: 20px;
}
.detail .sponsor-content .sponsor-item img {
    height: 60px;
    width: auto;
}
.detail .begleitver-container .begleitver-item {
    padding: 10px 10px 20px 10px;
}
.detail .termine-content .termine-item-header {
    background-color: rgb(230,230,230);
    padding: 7px 10px 9px 10px;
    margin-bottom: 10px;
    font-size: 2.4rem;
    font-family: kfw_monoregular;
}
.detail .termine-content .termine-item-header > div {
    display: inline-block;
    vertical-align: middle;
}
.detail .begleitver-content .begleitver-time-container {
    background-color: rgb(210,210,210);
    padding: 7px 10px 9px 10px;
    font-size: 2.4rem;
    font-family: kfw_monoregular;
    display: flex;
}
.detail .begleitver-content .begleitver-time-container > div:first-child {
    margin-right: auto;
}
.detail .termine-content .event_day {
    margin-right: 15px;
}
.detail .termine-content .ticket_link {
    padding: 7px 10px 9px 10px;
    margin-bottom: 10px;
    line-height: 100%;
    background-color: rgb(230,230,230);
    position: relative;
    color: black;
    text-align: center;
    font-size: 2.4rem;
}
.detail .termine-content a.ticket_link {
    color: white;
    background-color: black;
    display: block;
    padding: 6px 20px 9px 20px;
}
.detail .termine-content .ticket_link::before,
.detail .termine-content .ticket_link::after {
    content: '';
    background-color: white;
    width: 15px;
    height: 15px;
    top: calc(50% - 8px);
    display: block;
    position: absolute;
    border-radius: 100%;
}
.detail .termine-content .ticket_link::before {
    left: -7px;
}
.detail .termine-content .ticket_link::after {
    right: -7px;
}
.detail .termine-content .event_dates_time {
    padding: 7px 10px 9px 10px;
    margin-bottom: 10px;
    line-height: 100%;
    background-color: rgb(230,230,230);
    display: table;
    font-size: 2.4rem;
    font-family: kfw_monoregular;
}
.detail .termine-content .event_dates_content {
    padding-left: 10px;
    padding-right: 10px;
}
.detail .spielorte-container .item a {
    display: block;
    padding: 20px 20px 40px 20px;
    color: black;
    text-decoration: underline;
    font-family: kfw_monoregular;
}
.detail .video_box_outer .responsive-video,
.joHomeNews .responsive-video {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
    width: 100%;
    height: auto;
}
.detail .video_box_outer .responsive-video iframe,
.joHomeNews .responsive-video iframe {
    max-width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.joVeranstaltungen .joDatumBox {
    padding: 10px;
}
.joVeranstaltungen .joEventDatumVeranstaltung > a {
    display: block;
    width: 100%;
    height: 100%;
}
.joVeranstaltungen .joVeranstaltung {
    /* margin-bottom: 20px; */
}
.joVeranstaltungen .joVeranstaltung .joVaColOuter.sub-collapse-header {
    padding-bottom: 20px;
}
.joVeranstaltungen .joVeranstaltungsTime {
    padding: 10px;
    background-color: rgb(230,230,230);
    font-family: kfw_monoregular;
}
.joVeranstaltungen .joVeranstaltungsTime > div {
    display: inline-block;
    vertical-align: middle;
}
.joVeranstaltungen .joFilterNew > .d-flex {
    padding: 0 0 10px 0;
}
/* .joVeranstaltungen .joVeranstaltung .joVaColOuter {
    margin-bottom: 20px;
} */
.joVeranstaltungen .joVaColOuter a {
    color: black;
}
.joVeranstaltungen .joVaColOuter .joVeranstaltungsArtist {
    padding-top: 10px;
    font-family: kfwregular;
}
.joVeranstaltungen .joVaColOuter a h2 {
    padding: 10px 0 15px 0;
    font-size: 5.5rem;
    line-height: 95%;
    letter-spacing: -0.2rem;
}
.joVeranstaltungen .joRahmenplan .joVaColOuter a h2 {
    font-size: 5.5rem;
    letter-spacing: -0.1rem;
    padding: 0 10px 15px 10px;
}
.joVeranstaltungen .joRahmenplan .joVeranstaltung .joDatumBox {
    font-size: 2.5rem;
}
.joVeranstaltungen .joRahmenplan .joVaColOuter .joVeranstaltungsArtist {
    font-size: 2.5rem;
    font-family: kfwregular;
    line-height: 100%;
    margin-bottom: 10px;
}
.joVeranstaltungen .joVaColOuter .description {
    padding: 10px 0 15px 0;
    font-family: kfwregular;
}
.joVeranstaltungen .genreAndType {
    padding-left: 0;
}
.joVeranstaltungen .ticket_link {
    padding: 9px 0px 12px 0px;
    line-height: 100%;
    background-color: rgb(230,230,230);
    position: relative;
    color: black;
    text-align: center;
    max-width: 200px;
    width: 100%;
    display: inline-block;
}
.joVeranstaltungen a.ticket_link {
    color: white;
    background-color: black;
}
.joVeranstaltungen .ticket_link::before,
.joVeranstaltungen .ticket_link::after {
    content: '';
    background-color: white;
    width: 15px;
    height: 15px;
    top: calc(50% - 8px);
    display: block;
    position: absolute;
    border-radius: 100%;
}
.joVeranstaltungen .ticket_link::before {
    left: -7px;
}
.joVeranstaltungen .ticket_link::after {
    right: -7px;
}
.joVeranstaltungen .joVaRightCol {
    padding: 0 10px 20px 10px;
}
.joVeranstaltungen .joFilterNew {
    padding: 58px 10px 10px 10px;
}
.joVeranstaltungen .joFilterNew .joVeranstaltungen-title {
    font-size: 2.5rem;
    line-height: 30px;
}
.joVeranstaltungen .icons > .icon-item {
    cursor: pointer;
    opacity: .2;
}
.joVeranstaltungen .icons > .icon-item.active,
.joVeranstaltungen .icons > .icon-item.joEventActive {
    opacity: 1;
}
.joVeranstaltungen .icons a {
    display: block;
}
.joVeranstaltungen .icons img {
    width: 60px;
    height: 60px;
}
.joVeranstaltungen .icons .jo-icon {
    width: 30px;
    height: 30px;
    background-size: 50px;
    background-position: center;
    background-repeat: no-repeat;
}
.joVeranstaltungen .icons .jo-icon-1 {
    background-image: url('../Images/2019/spielplan-icon.svg');
}
.joVeranstaltungen .icons .jo-icon-2 {
    background-image: url('../Images/2019/index-icon.svg');
}
.joVeranstaltungen .joRahmenplan .joDatumBox {
    padding: 10px;
}
.joVeranstaltungen .joRahmenplan .joVaColOuter .joVeranstaltungsArtist {
    padding: 0 10px;
}
.joVeranstaltungen .joRahmenplan .genreAndType {
    padding: 0 10px 15px 10px;
}
.joVeranstaltungen .joRahmenplan .sub-collapse-header.joVaColOuter:not(:hover) {
    background-color: white;
}
.joSearch-container .joRahmenplan .sub-collapse-header.joColDay:not(:hover) {
    background-color: white;
}
.joVeranstaltungen .joRahmenplan .joVaColOuter .description {
    padding: 0 10px;
    font-size: 2.5rem;
    font-family: kfwregular;
    line-height: 100%;
    margin-bottom: 20px;
}
.joVeranstaltungen .joRahmenplan .joVaColOuter a {
    display: block;
    padding-bottom: 20px;
}
.joVeranstaltungen .joRahmenplan .joVerImg {
    padding: 0 10px 0 10px;
}
.joVeranstaltungen .joRahmenplan .joVerImg img {
    width: 100%;
    height: auto;
}
.joVeranstaltungen .joRahmenplan .joVerImg.big img {
    width: 100%;
    height: auto;
}
.joNav-content .joNav-pane {
    display: none;
}
.joNav-content .joNav-pane.show {
    display: block;
}
.joHomeNews-content .joNav-item {
    text-align: center;
    padding: 9px 0 12px 0;
    cursor: pointer;
}
.joHomeNews .de {
    background-color: rgb(230,230,230);
}
.joHomeNews .en {

}
.joHomeNews-header {
    font-size: 3rem;
    padding: 15px 10px;
    position: relative;
    cursor: pointer;
}
.joHomeNews-header .joCloser {
    position: absolute;
    right: 20px;
    top: calc(50% - 11px);
    cursor: pointer;
}
.joHomeNews-header.collapsed .joPlus:before {
    transform: rotate(0deg);
}
.joHomeNews-header.collapsed .joPlus:after {
    transform: rotate(-90deg);
}
.joHomeNews-header .joPlus {
    left: calc(50% - 11px);
    top: calc(50% - 11px);
    width: 22px;
    height: 22px;
}
.joHomeNews-header .joPlus:before, 
.joHomeNews-header .joPlus:after {
    height: 22px;
    left: 11px;
}
.joHomeNews .joNewsBodyTitle {
    padding: 20px;
    padding-bottom: 15px;
}
.joHomeNews .joNewsBodyText {
    padding: 0 20px 20px 20px;
}
.joHomeNews .joHomeNews-item {
    padding: 10px;
}
.joHomeNews img {
    width: 100%;
    height: auto;
}
.joHomeNews .joTeaserBild {
    padding: 0 20px;
}
.joHomeNews .joTeaserBild > img {
    margin-bottom: 20px;
}
.joHomeNews .joVideoLi {
    width: 100%;
    padding: 0 20px;
}
.joHomeNews .joVideoLi .responsive-video {
    margin-bottom: 20px;
}
.newsletter-modal .modal-title {
    font-size: 2rem;
}
.newsletter-modal .modal-body {
    font-size: 1.8rem;
}
.newsletter-modal .modal-footer .btn {
    font-size: 1.6rem;
    border-radius: 10rem;
}
.newsletter-modal .modal-body > p {
    margin-bottom: 10px;
}
.newsletter-modal .modal-body a {
    color: black;
    text-decoration: underline;
}
.nav-options-container .option-menu {
    border: none;
    width: 48px;
    height: 48px;
    position: relative;
}
.nav-options-container .option-menu .icon-bar {
    display: block;
    width: 21px;
    transition: all 0.2s;
    height: 2px;
    margin: 4px auto;
    background-color: black;
}
.nav-options-container .option-menu .bar-first {
    transform: rotate(45deg);
    /* transform-origin: 10% 10%; */
    transform-origin: 17% 214%;
}
.nav-options-container .option-menu .bar-second {
    opacity: 0;
}
.nav-options-container .option-menu .bar-third {
    transform: rotate(-45deg);
    /* transform-origin: 10% 90%; */
    transform-origin: 15% -125%;}
.nav-options-container .option-menu.collapsed .bar-first {
    transform: rotate(0);
}
.nav-options-container .option-menu.collapsed .bar-second {
    opacity: 1;
}
.nav-options-container .option-menu.collapsed .bar-third {
    transform: rotate(0);
}
.nav-options-container .option-menu .icon-bar-controller {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.joVeranstaltung .joVaMiddleCol {
	padding: 0 10px; 
}
.joRahmenplan .joVeranstaltung .joVaMiddleCol {
	padding: 0; 
}
.joTriggerBar .joCloser {
    position: absolute;
    right: 0;
    top: 0;
    width: 39px;
    height: 39px;
    cursor: pointer;
}
.joTriggerBar .joPlus {
    left: calc(50% - 9px);
    top: calc(50% - 9px);
    width: 18px;
    height: 18px;
}
.joTriggerBar .joPlus:before, 
.joTriggerBar .joPlus:after {
    left: 9px;
    height: 18px;
}
.joTriggerBar.joClose .joPlus:before {
    transform: rotate(0deg);
}
.joTriggerBar.joClose .joPlus:after {
    transform: rotate(-90deg);
}
.joTriggerBar .joFliesstext a,
.frame-type-text .joFliesstext a {
	color: black;
	text-decoration: underline;
}
.layout_12 {
	display: none;
}
.joDateSelect-container {
	overflow-x: auto;
  	white-space: nowrap;
}
.joDateSelect-container .joMonthDay {
	display: inline-block;
	vertical-align: middle;
}
.joDateSelect-container .joMonthDay .joDateMonth {
	text-align: left;
    height: 30px;
    background-color: rgb(230,230,230);
    line-height: 30px;
    padding-left: 10px;
    margin-right: -1px;
    cursor: grab;
    font-family: kfw_monoregular;
}
.joDateSelect-container .grab .joMonthDay .joDateMonth,
.joDateSelect-container .grab .joDateItem a {
    cursor: grabbing;
}
.joDateSelect-container .joDateItem {
	display: inline-block;
}
.joDateSelect-container .joDateItem a {
	background-color: rgb(136,189,162);
	color: black;
	display: block;
	width: 30px;
    height: 30px;
    line-height: 30px;
    opacity: .5;
    cursor: grab;
    font-family: kfw_monoregular;
}
.joDateSelect-container .joDateItem.active a,
.joDateSelect-container .joDateItem a:hover {
    background-color: black;
    color: rgb(136,189,162);
}
.joDateSelect-container .joDateItem.show a {
	opacity: 1;
	cursor: pointer;
}
.joFilterNew.joFixed:not(.joView_2) {
    position: fixed;
    top: 0;
    z-index: 50;
    background-color: white;
    box-shadow: 0 4px 7px -2px gray;
    width: 100%;
    transition: all 0.2s ease-in-out;
}
.search-input-container {
    background-color: #e6e6e6;
    position: relative;
}
.search-input-container .input-row {
    padding: 20px 0;
    text-align: center;
}
.search-input-container .input-row input.tx_indexedsearchSearchbox {
    font-size: 3rem;
    height: 40px;
    line-height: 40px;
    background-color: white;
    border-radius: 10em;
    padding: 0 15px;
    width: 50%;
}
/* .search-input-container .search-icon {
    position: absolute;
    top: 0;
    cursor: pointer;
}*/ 
.tx-indexedsearch-searchbox-button {
    width: 80px;
    height: 80px;
    background-size: cover;
    position: absolute;
    padding: 0;
    top: 0;
    cursor: pointer;
}
.type-container,
.genre-container {
    padding-bottom: 20px;
}
.type-container .item,
.genre-container .item {
    cursor: pointer;
    margin-top: 8px;
}
.type-container .item.active,
.genre-container .item.active {
    color: black;
    background-color: rgb(188,167,255);
    border-color: transparent;
}
.genre-container .item {
    width: 100%;
    text-align: center;
    word-break: break-all;
}
.genre-container .row .col-3 {
    padding-right: 5px;
}
.genre-container .genre-label,
.type-container .type-label {
    font-size: 3rem;
    position: relative;
    padding-bottom: 10px;
    overflow: hidden;
}
.genre-container .row,
.type-container .row {
    padding-right: 70px;
}
.genre-container .refresh-btn,
.type-container .refresh-btn {
    cursor: pointer;
    width: 70px;
    height: 70px;
    position: absolute;
    right: 0;
    top: -20px;
}
/* ajax loader - start */
#joAjaxloader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.6);
    z-index: 10000;
}
#joAjaxloader .joLoader {
    border: 5px solid #f3f3f3;
    -webkit-animation: spin 1s linear infinite;
    animation: spin 1s linear infinite;
    border-top: 5px solid rgba(0,0,0,.2);
    border-radius: 50%;
    width: 50px;
    height: 50px;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    margin: auto;
}
@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}
/* ajax laoder - ende */
.searchResult {
    padding: 20px 35% 20px 20px;
}
.searchResult .tx-indexedsearch-redMarkup {
    color: rgb(140,60,255);
}
.searchResult h3 {
    font-size: 3rem;
}
.searchResult h3 a {
    color: black;
}
.searchResult .tx-indexedsearch-res {
    background-color: #e6e6e6;
    padding: 5px 10px 20px 10px;
    margin-bottom: 20px;
}
.searchResult .tx-indexedsearch-whatis {
    font-size: 3rem;
}
.searchResult > .joWrap {
    margin-bottom: 20px;
}
.joSearch-container:not(.input-form) {
    padding: 20px;
}
.joSearch-container .results-container {
    margin-left: -20px;
}
.tx-indexedsearch-browsebox li {
    display: inline-block;
}
.tx-indexedsearch-browsebox li a {
    color: black;
    display: block;
    padding: 5px 10px;
    background-color: #e6e6e6;
}
.tx-indexedsearch-browsebox li.tx-indexedsearch-browselist-currentPage a {
    background-color: rgb(140,60,255);
}
.navigation-menu-content .menu-container .social-btn-mobile-container {
    margin-top: auto;
    padding-bottom: 15px;
}
.navigation-menu-content .menu-container .social-btn-mobile a {
    min-width: unset;
    text-align: center;
    margin-right: 10px;
    border-radius: 4rem;
    font-size: 2rem;
    padding: 4px 0px;
}
.navigation-menu-content .menu-container .social-btn-mobile a:first-child {
    margin-left: 10px;
}
/*.slick-slide {*/
/*    height: 50vh;*/
/*}*/
.slick-slide img {
	height: auto;
	width: 100%;
}
.slick-slide > div,
.slick-slide > div .slider-item {
	height: 100%;
}
.detail .description-en-header {
	margin: 0 10px 10px;
}
.video_box_outer {
	/* padding: 0 10px; */
}
.detail .video_box_outer .video_box_text {
	font-family: kfw_monoregular;
	text-transform: uppercase;
	padding: 30px 10px;
    line-height: 110%;
    font-size: 2.5rem;
    letter-spacing: 0.15rem;
}
.detail .video_box_outer .video_box_text strong {
    font-family: kfw_monoregular;
}
img[alt='opacity0'] {
    display: none;
}
#joSlider {
	background-color: black;
}
.joSliderWrapper,
#joCarousel {
    margin-top: 48px;
}
.carousel-control-next-icon {
	position: absolute;
	right: 15px;
    display: none;
}
.carousel-control-prev-icon {
	position: absolute;
	left: 15px;
    display: none;
}
.en-text {
	display: inline-block;
}
.joTriggerBar .ce-gallery img {
    width: 100%;
    height: auto;
}
.tx-registeraddress {
    padding: 15px 10px;
}
.tx-registeraddress input#firstName, 
.tx-registeraddress input#lastName, 
.tx-registeraddress input#email, 
.tx-registeraddress select#gender {
    border: 1px solid rgb(55,225,155);
    width: 100%;
    height: 100%;
    line-height: 135%;
    font-size: 2.5rem;
    padding: 0.846rem 0.615rem;
    margin-bottom: 15px;
    color: #757575;
    display: inline-block;
    text-align: left;
    letter-spacing: 0.154rem;
}
.tx-registeraddress input.submit,
.tx-registeraddress input[type="submit"],
.tx-registeraddress > a {
    border: 1px solid rgb(55,225,155);
    color: #01be4d;
    background-color: #ffffff;
    font-size: 2rem;
    letter-spacing: 0.154rem;
    text-transform: uppercase;
    width: 100%;
    padding: 0.846rem 0.615rem;
    margin-bottom: 0.615rem;
    margin-top: 2rem;
    font-weight: bold;
    cursor: pointer;
}
.tx-registeraddress > a {
    color: red;
    border-color: red;
}
.tx-registeraddress input.submit:hover,
.tx-registeraddress input[type="submit"]:hover {
    background-color: rgb(55,225,155);
    color: #fff;
    cursor: pointer;
}
.tx-registeraddress label {
    width: 100%;
    margin-bottom: 5px;
    height: 100%;
    display: inline-block;
    font-size: 2.9rem;
    vertical-align: middle;
}
.tx-registeraddress > a {
    display: block;
    text-align: center;
}
.logo-container,
.nav-options-container img,
.nav-options-container .option-menu .icon-bar-controller,
.joVeranstaltungen .icons .joEventActive .jo-icon,
.sub-collapse-header .joCloser,
.frame-layout-2 header .joCloser,
.frame-layout-3 header .joCloser,
.joOrte-bodytext-en-header .joCloser,
.joOrte-header .joCloser,
.joOrte-header .link-container {
    opacity: 1;
    transition: opacity 0.2s ease-in-out;
} 
.logo-container:hover,
.nav-options-container img:hover,
.nav-options-container .option-menu .icon-bar-controller:hover,
.joVeranstaltungen .icons .joEventActive .jo-icon:hover,
.sub-collapse-header:hover .joCloser,
.frame-layout-2 header:hover .joCloser,
.frame-layout-3 header:hover .joCloser,
.joOrte-bodytext-en-header:hover .joCloser,
.joOrte-header .joCloser:hover,
.joOrte-header .link-container:hover {
    opacity: .5;
    transition: opacity 0.2s ease-in-out;
}
.newline:before {
    content: "\A";
    white-space: pre-line; 
}
.frame-layout-14 {
    margin-top: 49px;
    padding: 20px;
}
.frame-layout-14 header h1 {
    font-size: 3rem;
    padding-bottom: 15px;
}
.frame-layout-14.frame-type-text .joFliesstext {
    padding-left: 0;
}
.slider-title {
    position: absolute;
    bottom: 0;
    font-size: 3rem;
    padding: 5px;
}
.slider-title p {
    color: #ffffff;
    text-shadow: 0 0 2rem #000;
}
.slick-slide > div .slider-item {
    position: relative;
}
.col_def_1{
    columns: 3;
    display: flex;
    flex-flow: row wrap;
}
.joColDay.joVeranstaltung{
   
}
#c1100 {
	height: 255px;
}
#c1100 h2 {
    padding-bottom: 0rem;
    margin-top: 2rem;
}
.joSlider_01_slick .slider-item {
    background-color: black;
}
@media (min-width: 768px) {
    .slider-title {
        position: absolute;
        bottom: 0;
        font-size: 1.5rem;
    }
    .joOrte-img .img-description {
        opacity: 0.3;
        padding-top: 5px;
    }
    html {
        font-size: 8px;
    }
    body {
        font-size: 1.9rem;
    }
    .frame-layout-14 {
        margin-top: 80px;
    }
    .frame-layout-14 header h1 {
        font-size: 6rem;
        padding-bottom: 30px;
    }
    .navigation-menu-content .menu-container li:hover {
        background-color: rgb(255,255,255);
    }
    .cookie-text {
		font-size: 1.4rem;
	}
    .joKfw.layout_11 #joVeranstaltungen > .joVeranstaltung .joHoversIt:hover {
        background-color: rgba(136,189,162,.5);
    }
    .joCarousel .item-title {
        line-height: 120%;
    }
    .joCarousel .carousel-inner > .carousel-item:first-child .item-subtitle {
        font-size: 9rem;
    } 
    .genreAndType .box,
    .type-container .item,
    .genre-container .item {
        font-size: 1.2rem;
    }
    .en-text,
    .joOrte-bodytext-en-item {
        font-size: 1.5rem;
    }
    .joVeranstaltungen .joRahmenplan .joVaColOuter .description {
        padding: 0 20px;
        margin-bottom: 30px;
    }
    .joSliderWrapper,
    #joCarousel {
        margin-top: 80px;
    }
	.frame-type-header.frame-layout-5 header {
	    bottom: 30px;
	}
	.joOrte-header .link-container img {
		width: 56.6px;
	    height: 56.6px;
	}
    .tx-registeraddress {
        padding: 30px 20px;
        font-size: 2.2rem;
    }
    .tx-registeraddress input#firstName, 
    .tx-registeraddress input#lastName, 
    .tx-registeraddress input#email, 
    .tx-registeraddress select#gender {
        width: calc(75% - 6px);
        margin-bottom: 0.615rem;
        font-size: 2rem;
    }
    .tx-registeraddress label {
        width: 25%;
        margin-bottom: 0;
        font-size: 2.5rem;
    }
    .tx-registeraddress input.submit,
    .tx-registeraddress input[type="submit"],
    .tx-registeraddress > a {
        width: calc(75% - 6px);
        margin-left: calc(25% + 6px);
        font-size: 2rem;
    }
    .joTriggerBar .ce-gallery img {
        width: unset;
        height: unset;
    }
    .team_members h3 {
        font-size: 3rem;
    }
    .team_members .joFliesstext {
	    padding: 0 0 30px 0;
        font-size: 1.9rem;
    }
    .joKfw.layout_7 .row.content {
        margin-left: 20px;
        margin-right: 20px;
    }
    .joKfw.layout_7 footer .row.content {
        margin-left: 0;
        margin-right: 0;
    }
    .team_members {
        padding-top: 60px;
        padding-right: 20%;
        padding-left: 0;
    }
    .team_members header {
	    padding: 0 0 30px 0;
	}
    .team_members .ce-below .ce-gallery {
        margin-top: 0;
        padding-right: 20%;
    }
    .team_members .ce-gallery figcaption {
        display: table-caption;
        caption-side: bottom;
        opacity: 0.3;
        padding-top: 5px;
    }
    .team_members .joFliesstext a {
        text-decoration: underline;
    }
	.video_box_outer {
		padding: 0;
	}
	.detail .sub-collapse-header {
    	padding: 16px 20px 19px 20px;
    	font-size: 1.9rem;
	}
    /*.slick-slide {*/
    /*    height: 70vh;*/
    /*}*/
    .detail .video_box_outer .responsive-video iframe,
    .detail .video_box_outer .video_caption {
        padding-left: 20px;
    }
    .detail .video_box_outer .video_box_text {
        padding: 0 0 60px 20px;
        margin-top: 60px;
        font-size: 1.6rem;
    }
    .joVeranstaltungen .joFilterNew > .d-flex {
        padding: 0 0 30px 0;
    }
    .joVeranstaltungen .joFilterNew.joFixed:not(.joView_2) > .d-flex {
        transition: padding 0.5s ease-in-out;
        padding: 0 0 5px 0;
    }
    .joCarousel {
        height: calc(100vh - 80px);
    }
    .joCarousel .item-title {
        font-size: 9rem;
        line-height: 85%;
        padding-top: 2rem;
        letter-spacing: -0.25rem;
    }
    .joCarousel .item-subtitle {
        font-size: 3.5rem;
        line-height: initial;
        padding-bottom: 1rem;
    }
    .joCarousel .item-img {
        height: unset;
    }
    .joCarousel .item-text {
        height: unset;
        padding-left: 3rem;
        padding-top: 0;
        padding-right: 0;
    }
    .joDateSelect-container .joDateItem a {
        width: 3.125vw;
        height: 40px;
        line-height: 40px;
    }
    .joDateSelect-container .joMonthDay {
        padding-bottom: 10px;
    }
    .joDateSelect-container .joMonthDay .joDateMonth {
        height: 40px;
        line-height: 40px;
        margin-right: 0;
    }
	.layout_12 {
		display: flex;
	}
    .joCol-md-12 {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }
    .nav-options-container > div:not(.option-menu){
        display: block;
    }
    .logo-container .logo {
        padding: 14px 0 17px 20px;
        width: unset;
    }
    .navigation > .navigation-menu{
        height: 82px;
    }
    .nav-options-container > div {
        cursor: pointer;
        width: unset;
    }
    .navigation-menu-content .menu-container {
        width: auto;
    }
    .navigation-menu-content .menu-container .menu-container-holder {
        height: calc(100vh - 80px);
        width: 350px;
        overflow: auto;
    }
    .navigation-menu-content .menu-container a {
        padding: 9px 20px 12px 20px;
    }
    .navigation-menu-content .menu-container .datenschutz-container {
        padding-bottom: 30px;
    }
    .navigation-menu-content .menu-container .datenschutz-container a {
        padding: 0 0 0px 20px;
        font-size: 2rem;
    }
    .joHomeNews-header {
        padding: 30px 20px 30px 20px;
    }
    .nav-options-container .option-menu {
        width: 80px;
        height: 80px;
    }
    .nav-options-container .option-menu .icon-bar {
	    width: 38px;
	    height: 3px;
	    margin: 6px auto;
	}
	.nav-options-container .option-menu .bar-first {
	    transform-origin: 22% 210%;
	}
	.nav-options-container .option-menu .bar-third {
	    transform-origin: 22% -125%;
	}
	.joHomeNews .joHomeNews-item {
	    padding: 0 20px 10px;
	}
	.joVeranstaltungen .joFilterNew {
	    padding: 30px 20px 10px;
	}
	.joVeranstaltungen .joFilterNew.joFixed {
		padding: 20px 20px 10px;
	}
	.joHomeNews .joNewsBodyTitle {
	    font-size: 1.5rem;
	}
	.joHomeNews .joNewsBodyText {
	    font-size: 1.5rem;
	}
	.joVeranstaltungen .icons .jo-icon {
	    width: 50px;
	    height: 40px;
	    background-size: unset;
        transition: all 0.5s ease-in-out;
	}
    .joVeranstaltungen .joFilterNew.joFixed:not(.joView_2) .icons .jo-icon {
        width: 50px;
        height: 40px;
    }
	.joVeranstaltungen .joFilterNew .joVeranstaltungen-title {
	    font-size: 3rem;
        transition: all 0.5s ease-in-out;
        line-height: 115%;
	}
    .joVeranstaltungen .joFilterNew.joFixed:not(.joView_2)  .joVeranstaltungen-title {
        font-size: 2rem;
        line-height: 40px;
    }
	.joVeranstaltungen .joDatumBox {
	    padding: 16px 20px 19px 20px;
	    height: 60px;
        font-size: 2.5rem;
        line-height: 2.5rem;
	}
    .joVeranstaltungen .joVeranstaltung {
        padding-left: 20px;
        padding-right: 20px;
    }
    .joVeranstaltungen .joRahmenplan .joVeranstaltung {
        padding-left: 0;
        padding-right: 0;
    }
    .joVeranstaltungen .joRahmenplan .joVeranstaltung .joDatumBox,
    .joVeranstaltungen .joRahmenplan .joVeranstaltung .joVaColOuter {
        padding-left: 20px;
        padding-right: 20px;
    }
    .joSearch-container .joVeranstaltungen .joRahmenplan .joVeranstaltung .joVaColOuter {
    	padding-left: 0;
    }
	.joVeranstaltungen .joVeranstaltungsTime {
	    padding: 16px 20px 19px 20px;
	    height: 60px;
	}
	.joVeranstaltungen .joVaRightCol {
	    padding: 0 0 40px 0;
	}
	.joVeranstaltung .joVaMiddleCol {
		padding: 0; 
	}
	.frame-layout-13 #joVeranstaltungen > .joVeranstaltung .joVaMiddleCol,
	.frame-layout-13 #joVeranstaltungen > .joVeranstaltung .joVaRightCol {
	    -webkit-box-flex: 0;
	    -ms-flex: 0 0 75%;
	    flex: 0 0 75%;
	    max-width: 75%;
	}
	.joVeranstaltungen .joVaColOuter a h2 {
	    padding: 20px 0 25px 0;
        font-size: 6rem;
	}
	.joVeranstaltungen .joVaColOuter .joVeranstaltungsArtist {
	    padding-top: 20px;
        font-size: 3rem;
        line-height: 100%;
	}
	.joVeranstaltungen .joVaColOuter .description {
	    padding: 20px 0 30px 0;
        font-size: 3rem;
        line-height: 100%;
	}
	footer .left > .frame-type-image {
	    padding: 30px 0 0 20px;
	}
	footer .left .frame-type-image img {
	    max-width: 360px;
        width: 100%;
	    height: auto;
	}
	footer .left > .frame-type-text {
	    padding: 60px 0 40px 20px;
	}
	footer .middle {
		display: block;
	}
	footer .right {
	    padding: 30px 20px 0 0!important;
	}
	footer .right > div:not(:last-child) {
	    margin-bottom: 20px;
	}
	footer .right > div:last-child {
	    margin-bottom: 0;
	}
    footer .frame-type-text .joFliesstext p {
        font-size: 1.5rem;
    }
	.joVeranstaltungen .ticket_link {
	    max-width: 250px;
	    width: 20%;
    	min-width: 200px;
	}
	.frame-type-header.frame-layout-5 {
	    height: 280px;
	    padding: 0 0 30px 20px;
	}
	.joTriggerBar header {
	    padding: 16px 20px 19px 20px;
	}
	.joTriggerBar .joFliesstext,
	.frame-type-text .joFliesstext {
	    padding: 20px 20px 40px 20px;
	    font-size: 1.9rem;
	}
	.joTriggerBar header h2 {
	    font-size: 2rem;
	}
	.joTriggerBar .joCloser {
	    width: 60px;
	    /* height: 60px; */
	    height: 100%;
	}
	.joTriggerBar .joPlus {
	    left: calc(50% - 9px);
	    top: calc(50% - 9px);
	    width: 18px;
	    height: 18px;
	}
	.joTriggerBar .joPlus:before, 
	.joTriggerBar .joPlus:after {
	    height: 18px;
	    left: 9px;
	    width: 3px;
	}
	.joOrteOverview .joOrte-header {
	    /* height: 80px; */
	}
	.joOrteOverview .joOrte-header .joOrte-title {
		font-size: 1.9rem;
	    padding: 16px 20px 19px 20px;
	}
	.joOrteOverview .joOrte-header .joOrte-title > div {
	    /* line-height: 45px;*/ 
	}
	.joOrte-header .link-container {
	    width: auto;
	    right: 56px;
	}
	.joOrte-header .joCloser {
	    width: 80px;
	    height: 56.6px;
	}
	.joOrte-header .joPlus {
	    left: calc(50% - 11px);
	    top: calc(50% - 11px);
	    width: 22px;
	    height: 22px;
	}
	.joOrte-header .joPlus:before, 
	.joOrte-header .joPlus:after {
	    height: 22px;
	    left: 11px;
	    width: 3px;
	}
	.joPlus {
	    left: calc(50% - 16px);
	    top: calc(50% - 16px);
	    width: 32px;
	    height: 32px;
	}
	.joPlus:before,
	.joPlus:after {
	    left: 15px;
	    height: 33px;
	}
	.joOrte-item .joOrte-img {
	    margin-top: 60px;
	    padding: 0 0 0 20px;
	}
	.joOrte-item .joOrte-bodytext {
	    padding: 40px 0px 40px 20px;
	}
	.joOrte-item .joOrte-bodytext-en-item {
	    padding: 0px 0px 0 20px;
	}
	.joOrte-item .joOrte-bodytext-en {
	    width: 41.67vw;
	}
	.joOrte-item .joOrte-bodytext-en-header {
	    padding: 15px 20px;
	    margin: 0 0 15px;
	}
	.joOrte-item .joOrte-bodytext-en-header ~ .margin-helper {
		padding: 0 0 40px;
	}
	.joOrte-item .joOrte-bodytext-en-header.collapsed ~ .margin-helper {
		padding: 0 0 25px;
	}
	.joOrte-item .joOrte-bodytext-en .joCloser {
	    padding: 14px 10px;
	    right: 0;
	    top: 4px;
	}
    .joOrte-item .joOrte-events-content {
        margin-bottom: 0px;
    }
	.joOrte-item .joOrte-tipps-content {
	    padding: 20px 20px 40px 20px;
	}
	.joOrte-item .joOrte-events-content a {
	    padding: 10px 20px;
	}
	.joOrte-item .joOrte-sub-header {
	    padding: 16px 20px 19px 20px;
	}
	.joVeranstaltungen .joRahmenplan .joDatumBox {
	    padding: 20px 20px 0 20px;
	}
	.joVeranstaltungen .joRahmenplan .joVaColOuter .joVeranstaltungsArtist {
	    padding: 0 20px;
	}
	.joVeranstaltungen .joRahmenplan .joVaColOuter a h2 {
        font-size: 4rem;
	    padding: 0 20px 20px 20px;
	}
	.joVeranstaltungen .joRahmenplan .genreAndType {
	    padding: 0 20px 20px 20px;
	}
    .joVeranstaltungen .joRahmenplan .joVaColOuter a {
        padding-bottom: 80px;
    }
	.joVeranstaltungen .joRahmenplan .joVerImg {
	    padding: 0 20px 0 20px;
	}
	.joVeranstaltungen .joRahmenplan .joVerImg img {
	    width: 75%;
	    height: auto;
	}
	.detail .joCloser {
	    right: 20px;
	    top: calc(50% - 9px);
	}
	.detail .sub-collapse-header .joPlus {
	    left: calc(50% - 9px);
	    top: calc(50% - 9px);
	    width: 18px;
	    height: 18px;
	}
	.detail .sub-collapse-header .joPlus:before, 
	.detail .sub-collapse-header .joPlus:after {
        height: 18px;
	    left: 9px;
	    width: 3px;
	}
	.joOrte-bodytext-en .joCloser {
	    right: 20px;
	    top: calc(50% - 11px);
	}
	.joOrte-bodytext-en .joPlus {
	    left: calc(50% - 8px);
	    top: calc(50% - 8px);
	    width: 35px;
	    height: 16px;
	}
	.joOrte-bodytext-en .joPlus:before, 
	.joOrte-bodytext-en .joPlus:after {
	    height: 16px;
	    left: 8px;
	    width: 3px;
	}
	.detail .termine-content .termine-item-header {
	    padding: 9px 20px 12px 20px;
	    margin-bottom: 20px;
	    font-size: 1.9rem;
	}
    .detail .begleitver-content .begleitver-time-container {
        padding: 9px 20px 12px 20px;
        font-size: 1.9rem;
    }
	.detail .termine-content .event_dates_time {
		padding: 9px 20px 12px 20px;
	    margin-bottom: 20px;
	    font-size: 1.9rem;
	}
	.detail .termine-content .ticket_link {
	    padding: 7px 20px 8px 20px;
	    margin-bottom: 20px;
    	font-size: 1.9rem;
	}
	.detail .termine-content .event_dates_content {
		padding-left: 0;
	    padding-right: 20px;
	}
	.detail .links .title {
	    padding: 0 0 30px 20px;
	}
    .detail .links .artist-header {
        padding: 0 0 20px 20px;
    }
	.genreAndType {
	    padding-left: 20px;
	}
	.detail .links .subtitle {
	    padding: 20px 0 30px 20px;
	}
	.detail .links .description {
	    padding: 20px 0 40px 20px;
	}
	.detail .description-en-item {
	    padding: 0 0 40px 20px;
        font-size: 1.5rem;
	}
	.detail .description-en-header {
		margin: 0 0 20px;
	}
	.detail .begleitver-container .begleitver-item {
	    padding: 20px 20px 40px 20px;
	}
	.detail .sponsor-content .sponsor-item {
	    padding: 40px 20px;
	}
	.detail .sponsor-content .sponsor-item .item:not(:last-child) {
	    margin-bottom: 40px;
	}
	.detail .info-content .info-item-container {
    	padding: 20px 20px 0 20px;
	}
	.detail .info-content .info-item-container .info-item {
	    padding-bottom: 40px;
	}
	#c1100 {
		height: 300px;
	}
}
@media (min-width: 992px) {
    html {
        font-size: 10px;
    }
    .detail .links {
        margin-top: 60px;
    }
}
@media (min-width: 1200px) {
    html {
        font-size:10px;
    }
}


/* <p> with margin */
.joFliesstext p {
    margin-bottom: 1.8rem;
}

/* NEW LANGUAGE MENU 2021 MB */
.nav-options-container > div.option-menu.option-menu__language {
    background: none;
}
.option-menu.option-menu__language {
    width: auto;
}
.option-menu.option-menu__language ul.nav {
    height: 100%;
    width: 100%;
}
.option-menu.option-menu__language ul.nav li.nav-item a.nav-link,
.option-menu.option-menu__language ul.nav li.nav-item a.nav-link span.languagenav-item__label {
    display: block;
    height: 100%;
    width: 100%;
}
.option-menu.option-menu__language ul.nav li.nav-item a.nav-link span.languagenav-item__label {
    line-height: 40px;
}
.option-menu.option-menu__language ul.nav li.nav-item a.nav-link {
    padding: .5rem 1.8rem;
}
@media screen and (min-width: 768px) {
    .option-menu.option-menu__language ul.nav li.nav-item a.nav-link span.languagenav-item__label {
        line-height: 68px;
        font-size: 24px;
    }
}

/* EKKO LIGHTBOX PREV/NEXT */
.ekko-lightbox-nav-overlay a {
    color: #fff !important;
}
.ekko-lightbox .close {
    font-size: 2.5rem;
    color: #fff;
    text-shadow: none;
    opacity: 1;
    margin: 0;
    padding: 0;
}
.ekko-lightbox .close span {
    line-height: 100%;
}
.ekko-lightbox .modal-body {
    padding: 0;
}
.ekko-lightbox .modal-header {
    border-bottom: none;
    color: white;
}
.ekko-lightbox .modal-content {
    background: none;
    border: none;
}

/* NEW STICKY SOCIAL MENU */
.social-menu-wrap.fixed-top {
    top: 20%;
    left: auto;
    z-index: 4;
}
.socialmenu:not(.nav-fill) {
    background-color: #ffffff;
    border: 1px solid #000;
    border-right: none;
}
.socialmenu:not(.nav-fill) li.nav-item a {
    width: 50px;
    height: 50px;
    text-align: center;
    padding: 6px;
}
.socialmenu:not(.nav-fill) li.nav-item a img {
    margin-top: 3px;
}


/* NEW EVENT FILTER */
.genres {
    margin-top: 25px;
}
.genres .btn.btn-primary {
    font-size: 1.25rem;
    color: #fff;
    background: rgb(230,230,230);
    border-color: #f2f2f2;
    padding: .275rem 1.25rem;
    border-radius: 40px;
    margin-bottom: 5px;
    box-shadow: none;
    text-transform: uppercase;
}
.genres .btn.btn-primary:focus {
    background: #000;
    color: #fff;
    box-shadow: none !important;
    outline: 0;
}

.kfw-filter_grid.genres .btn.btn-primary {
    font-size: 2.4rem;
    margin-bottom: 20px;
    line-height: 300%;
}
@media screen and (min-width: 768px) and (max-width: 880px) {
    .kfw-filter_grid.genres .btn.btn-primary {
        font-size: 2.2rem;
    }
}
@media screen and (min-width: 991px) and (max-width: 1200px) {
    .kfw-filter_grid.genres .btn.btn-primary {
        font-size: 1.25rem;
    }
}
@media screen and (min-width: 1201px) and (max-width: 1439px) {
    .kfw-filter_grid.genres .btn.btn-primary {
        font-size: 1.6rem;
    }
}
@media screen and (min-width: 1440px) {
    .kfw-filter_grid.genres .btn.btn-primary {
        font-size: 2rem;
    }
}
@media screen and (min-width: 991px) {
    .kfw-filter_grid.no-gutters > .col, .kfw-filter_grid.no-gutters > [class*="col-"] {
        padding-right: 10px;
        padding-left: 10px;
    }
}

/* Genre colors */
a.genre-tanz,
a.genre-dance,
.genre-tanz:hover .joVaColOuter,
.genre-dance:hover .joVaColOuter
{
    background: #1269B0 !important;
}

a.genre-schauspiel,
a.genre-drama,
a.genre-schauspiel-drama,
.genre-schauspiel:hover .joVaColOuter,
.genre-drama:hover .joVaColOuter,
.genre-schauspiel-drama:hover .joVaColOuter{
    background: #C40046 !important;
}

a.genre-performance,
a.genre-partizipation,
a.genre-performance---partizipation,
a.genre-performance---participation,
.genre-performance:hover .joVaColOuter,
.genre-partizipation:hover .joVaColOuter,
.genre-performance---partizipation:hover .joVaColOuter,
.genre-performance---participation:hover .joVaColOuter
{
    background: #D0661C !important;
}

a.genre-musiktheater,
a.genre-music-theatre,
.genre-musiktheater:hover .joVaColOuter,
.genre-music-theatre:hover .joVaColOuter
{
    background: #524792 !important;
}

a.genre-konzert,
a.genre-concert,
.genre-konzert:hover .joVaColOuter,
.genre-concert:hover .joVaColOuter
{
    background: #88BDA2 !important;
}

a.genre-bildende-kunst,
a.genre-fine-art,
.genre-bildende-kunst:hover .joVaColOuter,
.genre-fine-art:hover .joVaColOuter
{
    background: #85C3DF !important;
}

a.genre-diskurs,
a.genre-discourse,
.genre-diskurs:hover .joVaColOuter,
.genre-discourse:hover .joVaColOuter
{
    background: #C4007A !important;
}

a.genre-literatur,
a.genre-literature,
.genre-literatur:hover .joVaColOuter,
.genre-literature:hover .joVaColOuter
{
    background: #E6AE3D !important;
}

a.genre-film,
.genre-film:hover .joVaColOuter {
    background: #BBC02F !important;
}

a.genre-theaterpaedagogik,
a.genre-rahmenprogram,
a.genre-theaterpaedagogik-rahmenprogram,
a.genre-theaterpaedagogik---rahmenprogramm,
a.genre-theatre-education---additional-program,
.genre-theaterpaedagogik:hover .joVaColOuter,
.genre-rahmenprogram:hover .joVaColOuter,
.genre-theaterpaedagogik-rahmenprogram:hover .joVaColOuter,
.genre-theaterpaedagogik---rahmenprogramm:hover .joVaColOuter,
.genre-theatre-education---additional-program:hover .joVaColOuter
{
    background: #78237E !important;
}

/*
.genre-neuer-name {
    background: #xyz;
}
*/

.joVeranstaltungen .genre-theaterpaedagogik---rahmenprogramm:hover .joVaColOuter a {
    color: white;
}
.joVeranstaltungen .genre-theaterpaedagogik---rahmenprogramm:hover .genreAndType .box {
    border-color: #ffffff;
}
.joVeranstaltungen .genre-theaterpaedagogik---rahmenprogramm:hover .genreAndType .auffuehrungstype_box {
    background-color: #ffffff;
    color: #78237E;
}

/*  NEWS  */
/** List view **/
.news-list-view .article {
    padding: 20px 20px 20px 0;
}
.news-list-view .article h3 {
    font-size: 2.4rem;
}

#joKfw-156 .news-list-view .article {
    background-color: rgb(230,230,230);
    padding: 20px;
    font-size: 1.5rem;
}
#joKfw-156 .news-list-view .article h3 {
    font-size: 1.75rem;
}
.news-list-view .article .header,
.news-list-view .article .news-img-wrap a {
    margin-bottom: 20px;
}
.news-list-view .article .news-img-wrap a {
    float: left;
    display: block;
    width: 100%;
}
.news-list-view .article a.more { margin-top: 10px; float: left; }

.news.news-single {
    padding: 20px;
}

/*  RESPONSIVE VIDEO  */
.video-embed {
    position: relative;
    padding-bottom: 55%;
    padding-top: 15px;
    height: 0;
    overflow: hidden;
}

.video-embed iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
