html {
}

body {
    background-repeat: repeat-x;
    margin-top: -4px;
}

h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: 'Source Sans Pro', sans-serif, Arial, serif;
    font-weight: 600;
}

body {
    font-family: 'Source Sans Pro', sans-serif, Arial, serif;
    font-weight: 400;
    font-size: 1.4em;
}

a, .a {
    font-family: 'Source Sans Pro', sans-serif, Arial, serif;
    font-weight: 300;
}

img#logo {
    margin: 10px 0;
    max-height: 54px;
    max-width: 211px;
}

p {
    margin-bottom: 20px;
}

/*
#logo.authenticated {
    width: 150px;
}
*/

#logo.notauthenticated {
    width: 211px;
}

.rot {
    color: #E52B36;
}

h1 {
    font-size: 2.0em;
    margin-top: 0;
    color: #e52b36;
}

h2 {
    font-size: 1.4em;
    margin-top: 15px;
}

h3 {
    font-size: 1.2em;
    margin-top: 10px;
}

p.bodytext {
    margin-bottom: 0px;
}

hr {
    border-color: #333;
}

ul.csc-bulletlist {
    margin-top: 10px;
    margin-bottom: 12px;
}

ul.csc-bulletlist li {
    margin-bottom: 4px;
}

@media (min-width: 767px) {
    .col-lg-2, .col-md-2, .col-sm-2 {
        width: 20%;
        float: left;
    }

    .col-lg-10, .col-md-10, .col-sm-10 {
        width: 80%;
    }

}

.col-lg-8 img,
.col-lg-3 img,
.col-lg-4 img {
    margin-bottom: 10px;
    box-shadow: 2px 2px 5px 2px #D9DADC;

}

.spacebar.links {
    border-left: dotted 2px #D9DADC;
}

.spacebar.rechts {
    border-right: dotted 2px #D9DADC;
}

@media (max-width: 767px) {
    ul.subnav {
        margin-bottom: 30px;
    }
}

.navbaricon {
    display: flex;
}

/* Bugfix der Icongröße für Safari */
@media screen and (-webkit-min-device-pixel-ratio: 0) {
    .navbaricon {
        width: 20px;
        height: 20px;
    }
}

.navbar-container {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
}

ul.nav.navbar-nav {
    display: flex;
}

ul.subnav {
    padding: 0;
    line-height: 1.8;
}

ul.subnav ul {
    margin-bottom: 20px;
}

ul.subnav li {
    list-style-type: none;
    margin-bottom: .5em;
    padding-bottom: .5em;
    line-height: 1.3;
    border-bottom: 1px solid #DDD;
}

ul.subnav li:last-child {
    border-bottom: 0;
}

ul.subnav li a,
ul.nav li a,
footer * a {
    text-decoration: none;
    font-style: normal;
    font-weight: 400;
}

ul.nav li a {
    font-size: 1.2em;
}

div.vcard .row {
    min-height: 190px;
}

footer .row.line1 {
    border-top: dotted 1px #4B4A4F;
    border-bottom: dotted 1px #4B4A4F;
    padding: 10px 0;
    margin-bottom: 20px;
}

footer ul {
    padding: 0;
}

footer ul li {
    list-style-type: none;
}

div#login {
    display: inline-block;
    float: right;
    /* width: 250px; */
    width: 200px;
}

div#loginstatusbox {
    text-align: right;
    height: 65px;
    padding: 5px;
    padding-right: 10px;
    background-color: #ebebeb;
    border-radius: 0px 0px 6px 6px;
}

div#loginstatusbox legend {
    font-size: 1.15em;
    border-bottom: 0;
    margin-bottom: 5px;
    color: #555;
}

/*ST 2014-10-23*/
@media (max-width: 767px) {

    div#login.authenticated {
        /* float: left; */
        /* width: 200px; */
        /* position: relative; */
        width: 100%;
        padding: 0 5px 5px 5px;
    }

    div#login.notauthenticated {
        float: left;
        width: 200px;
        position: relative;
        left: 130px;
    }

    img#logo.notauthenticated {
        float: left;
        position: relative;
        left: -190px;
    }
}


div#login a {
    text-decoration: none;
}

div#login label,
div#login .formrechts {
    min-height: 2.0em;
}

div#login label {
    text-align: left;
    color: #e52b36;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
}

div#login label.mitglied a {
    color: #E52B36;
}

div#login .formrechts {
    text-align: right;
    padding: 0 10px;
    margin-bottom: 1px;
}

/*div#login .form-control.input-sm {*/
/*font-size: 12px;*/
/*}*/

div#login .formbutton {
    text-align: right;
    padding: 0 10px;
}

div#login input[type=submit],
div#login button[type=submit] {
    background-color: #E52B36 !important;
    color: #ffffff !important;
    /*font-size: 1.1em;*/
    padding: .1em .6em;
}
button .fas {
    padding-left: .3em;
}

#logintoggle {
    padding: 1px 10px;
    border: solid 1px #D9DADC;
    background-image: linear-gradient(#D9DADC 0%, white 100%);
    border-radius: 2px;
    z-index: 9999;
}

a#logintoggle {
    position: relative;
}

div#loginform {
    margin: 0px 0 3px 0;
    background-color: #aaa;
    padding: 2px 10px;
    border-radius: 5px; /* CSS3 */
    border: solid 1px #D9DADC;
    background-image: linear-gradient(#D9DADC 0%, white 100%);
}


/*.accordion {*/
/*    width: 100%;*/
/*    cursor: pointer;*/
/*    margin-bottom: 10px;*/
/*}*/

/*.accordion h5 {*/
/*    background: #D9DADC url('../Images/arrowClosed.png') 5px 50% no-repeat;*/
/*    display: block;*/
/*    clear: both;*/
/*    height: auto;*/
/*    padding: 10px 0 10px 25px;*/
/*    color: #4B4A4F;*/
/*    margin: 10px 0 0 0;*/
/*    border-radius: 13px;*/
/*}*/

/*.accordion h5:first-child {*/
/*    margin-top: 0;*/
/*}*/

/*.accordion h5.opened {*/
/*    background: #E52B36 url('../Images/arrowOpen.png') 5px 50% no-repeat;*/
/*    color: white;*/
/*    border-radius: 15px 15px 4px 4px;*/
/*}*/

/*.accordion div {*/
/*    margin-bottom: 10px;*/
/*    background-color: #F8F8F8;*/
/*    padding: 0px;*/
/*}*/

/*.accordion p {*/
/*    clear: both;*/

/*}*/

/*.accordion dl {*/
/*    padding: 0;*/
/*}*/

/*.accordion dl dt {*/
/*    padding: 5px 10px;*/
/*    width: auto;*/
/*}*/

/*.accordion dl dd {*/
/*    padding: 5px 10px;*/
/*    margin-left: 0;*/
/*    border-bottom: solid 1px #A8A8A8;*/
/*}*/

div.teasertext p {
    color: #333;
}

.news .article h3 {
    margin-bottom: 5px;
}

.news .article h3 a {
    text-decoration: none;
    color: #333;
    font-weight: 600;
}

.news-single .teaser-text {
    color: #333;
    font-weight: 600;
}

.news-list-view.frontpage div.article {
    margin-bottom: 15px;
    border-bottom: 2px dotted #A8A8A8;
    border-bottom-style: dotted;
    padding-bottom: 5px;
}
.news-list-view .teaser-text {
    margin-bottom: 10px;
}

.news-list-view .teaser-text p {
    margin-bottom: 0;
}

.news-list-view.frontpage div.article a.more {
    float: right;
}

.slidertext {
    font-weight: bold;
    text-decoration: none;
    color: #333;
}

.slidertext:hover {
    text-decoration: underline;
}

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

a.link-emphasized {
    font-weight: 700;
    font-size: 1.3em;
}

/* Floating Menu */
.floating-menu {
    border-radius: 2px;
    z-index: 1050;
    padding-top: 5px;
    padding-bottom: 5px;
    top: 65px;
    right: 0;
    position: fixed;
    display: inline-block;
    /*top: 27%;*/
    /*-webkit-transform: translateY(-50%);*/
    /*-ms-transform: translateY(-50%);*/
    /*transform: translateY(-50%);*/
    margin-right: 20px;
}

/* customization for eWiki button */
.floating-menu .ewiki-button {
    padding: 0 10px;
}

.main-menu {
    margin: 0;
    padding-left: 0;
    list-style: none;
}

.main-menu li a {
    display: block;
    padding: 5px 10px 5px 10px;
    color: #fff;
    border-radius: 10px;
    position: relative;
    -webkit-transition: none;
    -o-transition: none;
    transition: none;
}

.main-menu li a:hover {
    /*background: rgba(244, 244, 244, .3); */
    transform: scale(1.05);
}

.menu-bg {
    background-color: #e52b36;
    position: absolute;
    width: 100%;
    height: 100%;
    border-radius: 15px;
    z-index: -1;
    top: 0;
    left: 0;
    -webkit-transition: .1s;
    -o-transition: .1s;
    transition: .1s;
    box-shadow: 4px 4px 5px 1px rgba(0, 0, 0, 0.4);
}

.ripple {
    position: relative;
    overflow: hidden;
    transform: translate3d(0, 0, 0)
}

.ripple:after {
    content: "";
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    right: 0;
    pointer-events: none;
    background-image: radial-gradient(circle, #000 10%, transparent 10.01%);
    background-repeat: no-repeat;
    background-position: 50%;
    transform: scale(10, 10);
    opacity: 0;
    transition: transform .5s, opacity 1s
}

.ripple:active:after {
    transform: scale(0, 0);
    opacity: .2;
    transition: 0s
}

div.buttoncontainer {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #ffffff;
}

div.buttonanabel {
    background-image: url('../Images/ebuch-button-anabel-belami.svg');
}

div.buttonevorschauplus {
    background-image: url('../Images/ebuch-button-evorschau-plus.svg');
}

div.quimus {
    background-image: url('../Images/ebuch-button-quimus.svg');
}

div.leistungskatalog {
    background-image: url('../Images/ebuch-button-leistungskatalog.svg');
}

/* Bildergalerie */
.ce-gallery {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}

.ce-row:not(.singleimage) {
    /*    width: 130px;
        height: 180px; */
    overflow: hidden;
}

.ce-gallery .ce-row:not(.singleimage) figure {
    /* display: table; */
    display: block;
    width: 130px;
    /* height: 130px; */
    overflow: hidden;
}

.do-not-crop-img {
    width: unset !important;
}

.singleimage-teaser {
    height: unset !important;
}

/* Korrektur für Leistungskatalog */
.ce-textpic.ce-left.ce-intext .ce-row {
    height: 85px;
}

.ce-textpic.ce-center .ce-gallery div.ce-outer {
    right: unset;
    float: unset;
}

figure.image a::after {
    content: unset;
}

/* Layoutfix für Galerien (Bsp. schönerlesen) mit data.layout = 1 */
figure.gridgallery {
    display: unset !important;
}

table tfoot > tr > td {
    font-size: 0.8em;
}


/***************************************************/
/* Custom buttons */
/***************************************************/
.txt--center {
    text-align: center;
}

/* call to action button (content element) */
.btn__cta--primary {
    margin: 1em auto;
    font-size: 1.1em;
    background-color: hsl(356, 72%, 57%);
    color: #FFF;
    padding: 0.3em 2.3em;
}
/* cta: spiegellist */
.btn__cta--smallprimary {
    margin: 0.5em auto 1.5em;
    font-size: 1.1em;
    background-color: hsl(356, 72%, 57%);
    color: #FFF;
}

.btn__cta--primary:hover, .btn__cta--primary:focus,
.btn__cta--smallprimary:hover, .btn__cta--smallprimary:focus {
    background-color: hsl(356, 75%, 61%);
    color: #FFF;
}

.btn__cta--primary:after,
.btn__cta--smallprimary:after {
    content: unset;
}

.btn__cta--primary:hover:after,
.btn__cta--smallprimary:hover:after {
    content: unset;
}


/***************************************************/
/* Custom styles template 1-col-100pct */
/***************************************************/

.width--100pct {
    width: 100%;
}

.article--font-size {
    font-size: 1.15em;
}

/***************************************************/
/* Custom styles: Spiegel lists */
/***************************************************/
.container__spiegellist strong {
    word-wrap: break-word;
}

/***************************************************/
/* Read more */
/***************************************************/
.readmore {
    position: relative;
    width: 100%;
    max-height: 60px;
    overflow: hidden;
    padding: 10px 0;
    transition:max-height 0.25s ease-out;
}

.frame-type-textpic .readmore {
    padding-bottom: 60px;
    margin-bottom: 30px;
}

.readmore.expand {
    max-height: 5000px !important;
    transition:max-height 0.35s ease-in-out;
}

.readmore-link {
    position: absolute;
    bottom: 0;
    right: 0;
    display: block;
    width: 100%;
    height: 60px;
    text-align: center;
    color: #666666;
    font-weight: bold;
    font-size: 16px;
    padding-top: 40px;
    background-image: linear-gradient(to bottom, transparent, white);
    cursor: pointer;
}

.readmore-link.expand {
    background-image: unset;
}

.readmore-link:after {
    color: #999999;
    font-family: "Font Awesome 6 Free";
    content:"\f078";
}
.readmore-link.expand:after{
    /*left: 50%;*/
    bottom: 0;
    position: absolute;
    content:"\f077";
    font-family: "Font Awesome 6 Free";
    color: #999999;
}

/***************************************************/
/* Media list (z. B. Spiegellisten) */
/***************************************************/
.medialist__size--1 .col-md-4 {
    min-height: 476px;
}

.medialist__size--1 .col-md-4 p {
    margin-bottom: 0;
}

.video-container video.img-responsive {
    margin: 0 auto;
    max-height: 350px;
    padding-bottom: 10px;
}

/***************************************************/
/* Vcard (neues Plugin)
/***************************************************/
.vcard__list {
    margin: 0 0 1em;
    padding: 0;
    list-style-type: none;
}
.vcard__list li.name {
    padding-bottom: 0.4em;
    font-size: 1.2em;
}
.vcard__list i {
    color: #666;
}
.vcard--name {
    padding-bottom: .3em;
    font-size: 1.1em;
    font-weight: bold;
}
.vcard .fa-ul {
    margin-top: .5em;
    margin-left: 0em;
}

/***************************************************/
/* Teaser (contentelement textpic)
/**************************************************/
.teaser__container--grey {
    padding-bottom: 1.2em;
    background-color: #ededed;
}
.teaser__container--grey h3 {
    margin: 0;
    font-size: 1.4em;
}
.teaser__container--grey p {
    margin-top: 15px;
    margin-bottom: 0;
    line-height: 1.3em;
}
.teaser__container--grey p.subtitle {
    margin-top: 0;
}

/***************************************************/
/* Teaser (multicolumn)
/**************************************************/
.multicolumnteaser__elment h3 {
    margin-bottom: 0;
    line-height: 1.3em;
}
.multicolumnteaser__elment .subtext {
    font-size: 0.9em;
    line-height: 0.9em;
}
.teaser__link {
    font-weight: 600;
    font-size: 0.9em;
    font-style: italic;
}

/***************************************************/
/* Global Layout
/**************************************************/
.align--left,.align--default {
    display: block;
    margin-left: 0;
    margin-right: auto;
    text-align: left;
}
.align--center {
    display: block;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}
.align--right {
    display: block;
    margin-left: auto;
    margin-right: 0;
    text-align: right;
}

.textcolumns--2 {
    column-count: 2;
}

.textcolumns--3 {
    column-count: 3;
}

.textcolumns--4 {
    column-count: 4;
}

/*.container {*/
/*    width: 100%;*/
/*    position: relative;*/
/*}*/

.item {
    position: absolute;
    overflow: hidden;
    /*margin-bottom: 1em;*/
    /*text-align: center;*/
    /*font-size: 2em;*/
    /*color: white;*/
    /*line-height: 1.5em;*/
    border-radius: 5px;
    box-shadow: 0px 2px 10px rgba(0, 0, 0, 0.2);
    /*background-image: linear-gradient( 135deg, #F761A1 10%, #AC46C8 100%);*/
    /*background: #E52B36;*/
    /*background: linear-gradient(90deg, rgba(229, 43, 54, 1) 0%, rgba(181, 40, 49, 1) 100%);*/
}

a.img-zoom {
    color: transparent !important;
}
a.img-zoom:after {
    content: unset;
}