/* roboto-regular - latin */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: 'Roboto';
    font-style: normal;
    font-weight: 400;
    src: url('../fonts/roboto-v30-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* roboto-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: 'Roboto';
    font-style: normal;
    font-weight: 700;
    src: url('../fonts/roboto-v30-latin-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
  
:root {
    --weiss: #fff;
    --schwarz: #000;
    /* --grau: #F1F8FF; */
    --grau: #F1F9FE;
    /* --linkfarbe: #5096DC; */
    --linkfarbe: #4A96D2;
    /* --akzentfarbe: #F8B736; */
    --akzentfarbe: #FAB833;
    --pin: rgb(228, 163, 34);
    --lightblue: #F1F8FF;
    /* --font: #414141; */
    --font: #424242;
    --schwarztrans07: rgba(0,0,0,0.7);

    --standardtransition: all 0.3s ease;
}

html, body {
    margin: 0;
    padding: 0;
    width: 100%;
    float: left;
    clear: both;
    font-family: 'Roboto',arial,sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 16px;
    line-height: 1.4em;
    color: var(--font);
}

* {
    outline: none;
}

a, a:hover, a:active, a:visited {
    color: var(--linkfarbe);
    text-decoration: none;
}

figure.image > a {
    display: table;
}

.audio-embed, .audio-caption {
    float: left;
    clear: both;
    width: 100%;
}

p {
    margin: 0 0 10px 0;
}

.text-right {
    text-align: right;
}

.text-left {
    text-align: left;
}

.text-center {
    text-align: center;
}

.text-justify {
    text-align: justify;
}

.ce-center .ce-outer {
    position: relative;
    float: left;
    clear: both;
    right: auto;
    left: 50%;
    transform: translateX(-50%);
    max-width: 100%;
}

img {
    max-width: 100%;
    height: auto;
}

ul:last-child {
    margin-bottom: 0;
}

.video[data-type="external"] .video-embed {
    padding-top: 0;
    aspect-ratio: 16/9;
    overflow: hidden;
}

.videobox,
.video-embed {
    position: relative;
}

.videoiframelink {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2;
    overflow: hidden;
    text-indent: -9999px;
    color: transparent;
} 

.ce-gallery.videocontainer {
    width: 100%;
	float: left;
	clear: both;  
}

.ce-gallery.videocontainer .video-column {
    max-width: 100%;
    float: left;
}

.ce-gallery.videocontainer figure.video {
	display: block;
}

/* -- Headervideo -- */
.frame-type-textmedia.frame-layout-11 > .rahmen {
    width: 100% !important;
    max-width: none !important;
    float: left !important;
    clear: both !important;
    margin: 0 !important;
    display: block !important;
}

.frame-type-textmedia.frame-layout-11 .ce-gallery {
    margin: 0;
    width: 100%;
    float: left;
    clear: both;
    position: relative;
}

.frame-type-textmedia.frame-layout-11 .ce-gallery::before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
}

.frame-type-textmedia.frame-layout-11 .video-embed .video-preview {
    height: 100%;
}

.frame-type-textmedia.frame-layout-11 .video-embed .video-preview img {
    width: 100%;
    max-width: none;
    height: auto;
}

.frame-type-textmedia.frame-layout-11.loadingok .video-embed .video-preview {
    display: none;
}

.frame-type-textmedia.frame-layout-11 .video[data-type="internal"] .video-embed .video-embed-item {
    width: 100%;
}

body.lb_body {
    height: auto !important;
    max-width: 800px;
    width: 90vw;
}

#lightbox {
    width: 96%;
    margin: 10px 2%;    
}
/* -------------------------------------------------------------- */

/*~ Standard Smarty ~*/
/* -- oben -- */
#oben {
    width: 100%;
    float: left;
    clear: both;
    box-shadow: 0 0 5px #aaa;
    position: fixed;
    min-height: 60px;
    z-index: 5;
}
/* -- Footer -- */
#footer {
    width: 100%;
    float: left;
    clear: both;
    position: relative;
}
#footer > .rahmen {
    margin-top: 30px;
}
#footer > .rahmen > .frame {
    width: 70%;
    float: left;
}
#footer > .rahmen > .qnavi {
    width: 30%;
    float: right;
    text-align: right;
    margin: 0;
    padding: 0;
    list-style: none;
}

#footer .mapsoverlay {
    color: var(--font);
}

#footer .mapsoverlay a {
    color: var(--linkfarbe);
}


.smarty {
    clear: right;
    float: right;
    display: inline-block;
    width: 30px;
    margin: 10px 0px 10px 0;
}
.smarty img {
    width: 100%;
    height: auto;
    float: left;
    clear: both;
}
.progressbox {
    width: 100%;
    float: left;
    clear: both;
    margin: 0;
    padding: 0;
    display: block;
    position: absolute;
    top: 100%;
}
.progressbar {
    width: 0;
    height: 5px;
    background: var(--linkfarbe);
    background: linear-gradient(90deg, var(--akzentfarbe) 0%, var(--linkfarbe) 100%);
    transition: all linear 0.1s;
}
.funktionen {
    position: fixed;
    right: 15px;
    bottom: 30px;
    background: #FFFFFF;
    display: block;
    width: 30px;
    overflow: hidden;
    z-index: 4;
    opacity: 0.8;
}
.totop, .tobottom {
    display: block;
    cursor: pointer;
    background-position: center center;
    background-repeat: no-repeat;
    width: 24px;
    height: 24px;
    margin: 5px 3px 5px 3px;
    float: left;
    clear: both;
    background-color: rgba(0,0,0,0.3);
    background-image: url(../images/arrow-top.png);
    background-position: left top;
    background-repeat: no-repeat;
}
.tobottom {
    background-image: url(../images/arrow-bottom.png);
}
.totop:hover, .tobottom:hover {
    background-color: var(--font);
    /* background-color: #aaa; */
}

/*~ Individuelle Anpassungen ~*/
/*~ Navi ~*/
.mob_button {
    display: none;
}

#oben {
    padding: 10px 0;
    background: var(--weiss);
    z-index: 99;
}

.logo {
    width: 275px;
}

#oben .logo * {
    width: 100%;
    margin: 0 0 0 0;
    height: auto;
}

#oben > .rahmen {
    width: 90%;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

ul.onepagenavi {
    margin: 0 0 0 0;
    padding: 0 0 0 0;
    list-style: none;
}

ul.onepagenavi li {
    float: left;
    clear: none;
    position: relative;
}

ul.onepagenavi li a {
    display: block;
    padding: 20px;
    transition: 0.3s;
    color: var(--font);
}

ul.onepagenavi li:hover a {
    color: var(--akzentfarbe)
}

ul.onepagenavi li::after {
    content: '';
    position: absolute;
    right: 0;
    width: 1px;
    height: 20px;
    top: calc(50% - 10px);
    background: var(--font);
}

ul.onepagenavi li:last-child a {
    padding-right: 0;
}

ul.onepagenavi li:last-child::after {
    display: none;
}

/*~ Zwischenheader ~*/
.frame-layout-20 > .rahmen > p {
    display: none;
}

.frame-layout-20 .ce-gallery.ce-border.zw_fixed {
    background-size: cover !important;
    background-position: center;
}

/*~ Inhaltsbereich ~*/
::selection {
    background: var(--akzentfarbe);
    color: var(--weiss);
}

.frame-calc ::selection,
#inhaltsbereich > div > div > div > .row > div:last-child ::selection {
    background: var(--linkfarbe);
}

#inhaltsbereich {
    margin-top: 150px;
    min-height: calc(100vh - 309px);
}

#inhaltsbereich > div > div > div > .row > div > div {
    margin-top: 100px;
}

.frame-space-before-11 {
    margin-top: 100px !important;
}

#inhaltsbereich > div > div > div > .row > div > .frame-type-header + div {
    margin-top: 0;
}

#inhaltsbereich > div > div > div > .row > div > .frame-icons + .frame-bg-blau,
#inhaltsbereich > div > div > div > .row > div > .frame-layout-20 + div {
    margin-top: 2px;
}

#inhaltsbereich > div > div > div > .row > div > .frame > .rahmen > header > * {
    max-width: 800px;
}

#inhaltsbereich .col-100 .rahmen,
#inhaltsbereich > .frame-type-textmedia > .rahmen,
#inhaltsbereich > .frame-type-html > .rahmen {
    margin: 0 auto;
    width: 90%;
}

#inhaltsbereich > .frame-type-textmedia > .rahmen,
#inhaltsbereich > .frame-type-html > .rahmen {
    max-width: 900px;
}

#inhaltsbereich > .frame-type-textmedia,
#inhaltsbereich > .frame-type-html {
    margin-top: 50px;
}

#inhaltsbereich > .frame-type-textmedia .ce-bodytext a {
    padding: 0 0 0 0;
    /* display: inline; */
    display: inline-block;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    vertical-align: bottom;
}

#inhaltsbereich > .frame-type-textmedia .ce-bodytext a::before {
    display: none;
}

#inhaltsbereich > .frame-type-textmedia:last-child {
    margin-bottom: 100px;
}

#inhaltsbereich .col-100 .rahmen .rahmen {
    width: 100%;
    margin: 0 0 0 0;
    float: left;
    clear: both;
}

h1, h2 {
    font-size: 40px;
    color: var(--linkfarbe);
    margin: 0 0 20px 0;
    line-height: 1em;
}

h3, h4, h5 {
    font-size: 30px;
    color: var(--akzentfarbe);
    margin: 0 0 20px 0;
    line-height: 1em;
}

h2.zweizeilig,
h3.zweizeilig {
    font-size: 20px;
    color: var(--font);
    font-style: italic;
    font-weight: normal;
    margin: 0 0 20px 0;
    position: relative;
}

.zweizeilig::after {
    content: '';
    position: absolute;
    left: 0;
    width: 400px;
    top: calc(100% + 10px);
    background: var(--akzentfarbe);
    height: 2px;
}

#inhaltsbereich > div > div > div > .row > div:first-child > .frame:first-child header {
    width: calc(100% - 10px);
    margin-left: 10px;
    position: relative;
    margin-bottom: 50px;
}

#inhaltsbereich > div > div > div > .row > div:first-child > .frame:first-child header .zweizeilig {
    position: static;
}

#inhaltsbereich > div > div > div > .row > div:first-child > .frame:first-child header .zweizeilig::after {
    left: -10px;
    width: 2px;
    top: 0;
    bottom: 0;
    height: auto;
    background: var(--font);
}

#inhaltsbereich .ce-bodytext p {
    margin: 0 0 10px 0;
}

#inhaltsbereich .ce-gallery.ce-border .ce-column {
    border-radius: 50%;
    border-top-right-radius: 0;
    overflow: hidden;
}

#inhaltsbereich .ce-right .ce-gallery.ce-border .ce-column {
    border-radius: 50%;
    border-top-left-radius: 0;
}

#inhaltsbereich a.more,
#inhaltsbereich a.ankerlink {
    padding: 5px 5px 3px 5px;
    text-transform: uppercase;
    color: var(--weiss);
    background: var(--linkfarbe);
    transition: 0.3s;
    margin: 20px 0 0 0;
    display: inline-block;
    position: relative;
    margin-left: 6px;
}

#inhaltsbereich a.more:hover,
#inhaltsbereich a.ankerlink:hover {
    background: var(--akzentfarbe);
}

#inhaltsbereich a.more::after,
#inhaltsbereich a.ankerlink::after {
    content: '';
    position: absolute;
    left: -6px;
    width: 3px;
    top: 0;
    bottom: 0;
    background: var(--linkfarbe);
}

a.link-phone,
a.link-mobile,
a.link-web,
a.link-mail {
    padding: 5px 0 5px 25px;
    position: relative;
    display: block;
}

a.link-phone::before,
a.link-mobile::before,
a.link-web::before,
a.link-mail::before {
    content: '';
    position: absolute;
    left: 0;
    width: 20px;
    height: 20px;
    background: url('../../../fileadmin/cn_website/images/telefon.svg') center center no-repeat;
    background-size: contain;
}

a.link-mail::before {
    background: url('../../../fileadmin/cn_website/images/email.svg') center center no-repeat;
    background-size: contain;
}

a.link-mobile::before {
    background: url('../../../fileadmin/cn_website/images/mobile.svg') center center no-repeat;
    background-size: contain;
}

a.link-web::before {
    background: url('../../../fileadmin/cn_website/images/web.svg') center center no-repeat;
    background-size: contain;
}

/* #footer ul:last-child li:nth-child(2)::before {
    background: url('../../../fileadmin/cn_website/images/fax.svg') center center no-repeat;
} */

/*~ Rahmen ~*/
#inhaltsbereich > div > div > div > .row > div:first-child > .frame:first-child {
    margin-top: 0;
}

#inhaltsbereich > div > div > div > .row > div:first-child > .frame:first-child .ce-gallery {
    width: 45%;
    margin: 60px 5% 0 0;
    float: left;
    clear: none;
    text-align: center;
}

#inhaltsbereich > div > div > div > .row > div:first-child > .frame:first-child .ce-gallery .ce-row {
    width: 80%;
    display: inline-block;
}

#inhaltsbereich > div > div > div > .row > div:first-child > .frame:first-child .ce-bodytext {
    width: 50%;
    float: left;
    clear: none;
    padding-top: 30px;
    position: relative;
    z-index: 1;
}

#inhaltsbereich > div > div > div > .row > div:first-child > .frame:first-child .ce-bodytext::before {
    content: '';
    background: var(--lightblue);
    z-index: -1;
    position: absolute;
    left: -20px;
    top: 0;
    width: 80%;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    border-top-left-radius: 0;
    max-width: 600px;
}

#inhaltsbereich > div > div > div > .row > div:first-child > .frame:first-child .ce-bodytext strong {
    text-transform: uppercase;
    color: var(--linkfarbe);
}

#inhaltsbereich > div > div > div > .row > div:first-child > .frame:first-child .ce-bodytext p:first-child {
    font-size: 30px;
    line-height: 1.2em;
}

#inhaltsbereich > div > div > div > .row > div:first-child > .frame:first-child .ce-bodytext h3 {
    margin: 30px 0 10px 0;
}

#inhaltsbereich > div > div > div > .row > div:first-child > .frame:first-child .ce-bodytext i {
    margin-top: 50px;
    display: block;
}

.frame-icons {
    background: var(--linkfarbe);
    padding: 50px 0;
}

.frame-icons,
.frame-icons h2,
.frame-icons h3,
.frame-icons h4,
.frame-icons h5,
.frame-icons a {
    color: var(--weiss)
}

.frame-icons .ce-gallery {
    margin: 0 0 0 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    float: left;
    clear: both;
    width: 100%;
}

.frame-icons .ce-gallery .ce-row {
    width: 22%;
}

.frame-icons .ce-gallery .ce-row:nth-last-child(n + 5) {
    display: none;
}

.frame-icons .ce-gallery .ce-row * {
    width: 100%;
}

.frame-icons .ce-gallery figcaption {
    margin: 10px 0 0 0;
    text-align: center;
}

.frame-bg-blau {
    background: var(--linkfarbe);
    padding: 50px 0;
}

.frame-bg-blau,
.frame-bg-blau h2,
.frame-bg-blau h3,
.frame-bg-blau h4,
.frame-bg-blau h5,
.frame-bg-blau a {
    color: var(--weiss)
}

.frame-bg-blau .zweizeilig::after {
    background: var(--weiss);
}

.frame-bg-blau.frame-type-header header *:last-child {
    margin-bottom: 0;
}

.frame-bg-blau.frame-type-header {
    margin-bottom: 50px;
}

.frame-ul-check,
.frame-ul-check * {
    overflow: visible;
}

.frame-ul-check ul {
    margin: 40px 0 0 40px;
    padding: 10px 0;
    list-style: none;
    position: relative;
    z-index: 1;
    width: calc(100% - 40px);
}

/* .frame-ul-check ul::before {
    content: '';
    background: var(--lightblue);
    z-index: -1;
    position: absolute;
    left: 50px;
    top: -10px;
    width: 60%;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    border-top-left-radius: 0;
    max-width: 290px;
} */

.frame-ul-check ul li {
    float: left;
    clear: both;
    font-size: 30px;
    color: var(--linkfarbe);
    margin-bottom: 30px;
    padding-left: 60px;
    position: relative;
    font-weight: bold;
    line-height: 1.1em;
    width: calc(100% - 60px);
}

.frame-ul-check ul li:last-child {
    margin-bottom: 0;
}

.frame-ul-check ul li::before {
    content: '';
    left: 0;
    top: calc(50% - 20px);
    width: 40px;
    height: 40px;
    background: var(--linkfarbe);
    position: absolute;
    border-radius: 10px;
    background: url(../images/haken.svg) center center no-repeat;
    background-size: contain;
}

.frame-man {
    overflow: hidden;
    position: relative;
    padding-bottom: 50px;
}

.frame-man header {
    position: relative;
    z-index: 1;
    padding: 50px 0;
    margin-bottom: 30px;
    max-width: 75%;
}

.frame-man header::before {
    content: '';
    width: 120vw;
    left: -10vw;
    background: var(--linkfarbe);
    position: absolute;
    z-index: -1;
    top: 0;
    bottom: 0;
}

.frame-man header *:last-child {
    margin-bottom: 0;
}

.frame-man header,
.frame-man header h2,
.frame-man header h3,
.frame-man header h4,
.frame-man header h5,
.frame-man header a {
    color: var(--weiss);
}

.frame-man .zweizeilig::after {
    background: var(--weiss)
}

.frame-man .ce-bodytext {
    float: left;
    clear: both;
    width: 50%;
}

.frame-man .ce-gallery {
    display: inline-block;
    margin: 0 0 0 0;
    position: absolute;
    right: 5%;
    top: 20px;
    bottom: 0;
    z-index: 5;
}

.frame-man .ce-gallery .ce-row,
.frame-man .ce-gallery .ce-column,
.frame-man .ce-gallery .image {
    width: auto;
    height: 100%;
    display: block;
}

.frame-man .ce-gallery img {
    width: auto;
    height: 100%;
    float: right;
}

#inhaltsbereich > div > div > div > .row > div > .frame-man + .frame-calc {
    margin-top: -20px;
}

.frame-calc ul {
    float: left;
    clear: both;
    width: calc(100% - 10px);
    margin: 0 0 0 0;
    padding: 5px 5px 7px 5px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    list-style: none;
}

.frame-calc ul li {
    text-align: center;
}

.frame-calc ul li:nth-child(even) {
    font-size: 50px;
    color: var(--akzentfarbe);
    text-shadow: 0 0 5px rgba(0,0,0,0.2);
}

.frame-calc ul li:nth-child(odd) {
    width: calc(28% - 40px);
    background: var(--akzentfarbe);
    padding: 20px;
    border-top-left-radius: 20px;
    border-bottom-right-radius: 20px;
    font-size: 20px;
    color: var(--weiss);
    line-height: 1.1em;
    text-transform: uppercase;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
}

#inhaltsbereich .frame-blau-50 .rahmen {
    margin: 0 0 0 0;
    width: 100%;
    float: left;
    clear: both;
}

.frame-blau-50 .row > div:first-child .ce-gallery {
    width: 80%;
    margin: 0 10%;
}

.frame-blau-50 .row > div:first-child header {
    padding: 50px 0 0 0;
}

.frame-blau-50 .row > div:first-child header h2,
.frame-blau-50 .row > div:first-child header h3,
.frame-blau-50 .row > div:first-child header h4,
.frame-blau-50 .row > div:first-child header h5 {
    color: var(--weiss);
}

.frame-blau-50 .row > div:first-child .zweizeilig::after {
    background: var(--weiss);
}

.frame-blau-50 .tx_cn-columns .row > div {
    position: relative;
    z-index: 1;
    width: 45%;
    padding: 0 0 0 5%;
}

.frame-blau-50 .tx_cn-columns[data-cols="2"] .row > div > div {
    float: left;
    clear: both;
    width: 90%;
    margin: 0 0 0 10%;
}

.frame-blau-50 .tx_cn-columns[data-cols="2"] .row > div:nth-child(odd) > div {
    margin: 0 10% 0 0;
}

.frame-blau-50 .tx_cn-columns .row > div:last-child {
    padding: 0 5% 0 0;
}

.frame-blau-50 .row > div::before {
    content: '';
    background: var(--linkfarbe);
    left: 0;
    top: 0;
    right: 0;
    height: 80%;
    position: absolute;
    z-index: -1;
}

.frame-blau-50 .row > div:last-child::before {
    background: var(--grau);
}

.frame-blau-50 .row > div:last-child header {
    text-align: right;
}

.frame-blau-50 .row > div:last-child header h3 {
    font-size: 60px;
    color: var(--linkfarbe);
    padding-top: 50px;
    position: relative;
    z-index: 1;
    display: inline-block;
    padding: 50px 25px;
}

.frame-blau-50 .row > div:last-child header h3::before {
    content: '';
    background: rgba(80, 150, 220, 0.25);
    z-index: -1;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    border-top-left-radius: 0;
    max-width: 290px;
}

#inhaltsbereich > div > div > div > .row > div > .frame.frame-default.frame-type-textmedia.frame-layout-0 .ce-bodytext {
    max-width: 700px;
}

.frame-icons-text .rahmen {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

.frame-icons-text .rahmen .frame:nth-child(n + 4) {
    margin-top: 40px;
}

.frame-icons-text .rahmen .frame {
    width: calc(30% - 80px);
    padding: 20px;
    margin: 0 20px;
    background: var(--grau);
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    border-top-left-radius: 30px;
    border-bottom-right-radius: 30px;
}

.frame-icons-text .rahmen .frame .ce-gallery,
.frame-icons-text .rahmen .frame .ce-bodytext {
    float: left;
    clear: both;
    width: 100%;
    margin: 0 0 0 0;
    text-align: center;
}

.frame-icons-text .rahmen .frame .ce-gallery {
    margin: 0 0 20px 0;
}

.frame-icons-text .rahmen .frame .ce-gallery .ce-row {
    width: 100px;
    display: inline-block;
    max-width: 80%;
}

.frame-icons-text .rahmen .frame .ce-gallery .ce-row * {
    width: 100%;
}

.frame-icons-text .rahmen .frame .ce-bodytext header * {
    font-size: 16px;
    text-transform: uppercase;
    color: var(--font);
}

.frame-img-50 .ce-bodytext,
.frame-img-50 .ce-gallery {
    float: left;
    clear: none;
}

.frame-img-50 .ce-right .ce-gallery {
    float: right;
}

.frame-img-50 .ce-bodytext {
    width: 50%;
    position: relative;
    z-index: 1;
    padding-top: 10px;
}

/* .frame-img-50 .ce-bodytext::before {
    content: '';
    background: var(--lightblue);
    z-index: -1;
    position: absolute;
    left: -10px;
    top: -10px;
    width: 80%;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    border-top-left-radius: 0;
    max-width: 290px;
} */

.frame-img-50 .ce-textpic .ce-gallery {
    width: 45%;
    margin: 0 5% 0 0;
    text-align: center;
}

.frame-img-50 .ce-textpic.ce-right .ce-gallery {
    margin: 0 0 0 5%;
}

.frame-img-50 .ce-gallery .ce-row {
    width: 80%;
    margin: 0 10%;
}

.frame-bg-blau.frame-type-header.frame-layout-1 {
    background: none;
}

.frame-bg-blau.frame-type-header.frame-layout-1 header {
    position: relative;
    z-index: 1;
    width: 90%;
    padding: 0 5%;
}

#inhaltsbereich .col-100 .frame-bg-blau.frame-type-header.frame-layout-1 .rahmen {
    margin: 0 0 0 0;
    float: left;
    clear: both;
    width: 100%;
}

.frame-bg-blau.frame-type-header.frame-layout-1,
.frame-bg-blau.frame-type-header.frame-layout-1 * {
    overflow: visible;
}

.frame-bg-blau.frame-type-header.frame-layout-1 header::before {
    content: '';
    width: 100%;
    left: 0;
    background: var(--linkfarbe);
    position: absolute;
    z-index: -1;
    top: -50px;
    bottom: -50px;
}

.frame-bg-blau.frame-type-header.frame-layout-1 header::after {
    content: '';
    background: rgba(241, 248, 255, 0.50);
    z-index: -1;
    position: absolute;
    top: 0;
    right: 5%;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    border-top-left-radius: 0;
    width: 300px;
}

#inhaltsbereich > div > div > div > .row > div:last-child {
    background: var(--akzentfarbe);
    margin-top: 100px;
    padding: 50px 0;
}

#inhaltsbereich > div > div > div > .row > div:last-child,
#inhaltsbereich > div > div > div > .row > div:last-child h2,
#inhaltsbereich > div > div > div > .row > div:last-child h3,
#inhaltsbereich > div > div > div > .row > div:last-child h4,
#inhaltsbereich > div > div > div > .row > div:last-child h5,
#inhaltsbereich > div > div > div > .row > div:last-child a {
    color: var(--weiss);
}

#inhaltsbereich > div > div > div > .row > div:last-child .zweizeilig::after {
    background: var(--weiss);
}

#inhaltsbereich > div > div > div > .row > div:last-child > div:first-child {
    margin-top: 0;
}

/*~ Kontaktformular ~*/
.tx-powermail h3 {
    display: none;
}

.tx-powermail .powermail_fieldset {
    margin: 0 0 0 0;
    padding: 0 0 0 0;
    border: none;
}

.tx-powermail .powermail_fieldset > legend {
    display: none;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap {
    float: left;
    clear: both;
    width: 100%;
    margin-bottom: 5px;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap > * {
    float: left;
    clear: none;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap > label {
    width: 140px;
    margin: 5px 20px 0 0;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap > .powermail_field {
    width: calc(100% - 160px);
    position: relative;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap > .powermail_field > * {
    float: left;
    clear: both;
    width: calc(100% - 10px);
    padding: 5px;
    border: none;
    font-family: 'Roboto',arial,sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 14px;
    line-height: 1.4em;
    -webkit-appearance: none;
    -webkit-border-radius: 0px;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap_type_check > label {
    display: none;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap_type_check > .powermail_field {
    width: 100%;
    margin-top: 20px;
    font-size: 14px;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap_type_submit > .powermail_field {
    width: auto;
    margin-top: 40px;
    position: relative;
    float: right;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap_type_submit .powermail_field input {
    padding: 5px 5px 3px 5px;
    text-transform: uppercase;
    color: var(--weiss);
    background: var(--linkfarbe);
    transition: 0.3s;
    margin-left: 6px;
    width: auto;
    float: right;
    cursor: pointer;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap_type_submit .powermail_field::after {
    content: '';
    position: absolute;
    left: 0;
    width: 3px;
    top: 0;
    bottom: 0;
    background: var(--linkfarbe);
}

.tx-powermail .powermail_fieldwrap_type_text.powermail_fieldwrap_marker_01 {
    margin: 30px 0 5px 0;
    width: calc(100% - 160px);
    margin-left: 160px;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap_type_text.powermail_fieldwrap_marker_01 > * {
    float: left;
    clear: both;
    width: 100%;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap_type_captcha .powermail_field {
    display: flex;
    justify-content: space-between;
    flex-direction: row-reverse;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap_type_captcha .powermail_field input {
    margin-left: 10px;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap_type_captcha .powermail_field > img {
    padding: 0 0 0 0;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap_type_captcha > label {
    margin-top: 0px;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap > .powermail_field .powermail-errors-list {
    float: left;
    clear: both;
    width: calc(100% - 10px);
    padding: 2px 5px;
    background: #a83232;
    list-style: none;
    margin: 0 0 10px 0;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap > .powermail_field .powermail-errors-list li {
    float: left;
    clear: both;
    width: 100%;
    font-size: 14px;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap > .powermail_field .powermail-errors-list li::before {
    content: '»';
    transform: rotate(-90deg);
    transform-origin: center;
    display: inline-block;
    margin: 0 5px 0 0;
    position: relative;
    top: -1px;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap_type_captcha > .powermail_field .powermail_field_error_container {
    position: absolute;
    left: 0;
    right: 0;
    top: 32px;
    width: auto;
    padding: 0 0 0 0;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap_type_captcha > .powermail_field .powermail_field_error,
.tx-powermail .powermail_fieldset .powermail_fieldwrap_type_captcha > .powermail_field .powermail_field_error + img {
    margin-bottom: 20px;
}

.tx-powermail .powermail_fieldset .powermail_fieldwrap_type_captcha > .powermail_field img {
    height: 32px;
    width: auto;
    background: red;
}

.mediaconsent.maps .blockedcontentbox {
    padding-top: 0;
    height: 100%;
}

/* ++s++ */
.powermail_field_error {
    scroll-margin-top: 110px;   
    scroll-padding-top: 0;
    }

.tx-powermail .powermail_fieldset textarea {
    resize: none;
}

/*~ Footer ~*/
#footer {
    margin-top: 2px;
    background: var(--linkfarbe);
    padding: 0 0 40px 0;
}

#footer,
#footer h2,
#footer h3,
#footer h4,
#footer h5,
#footer a {
    color: var(--weiss);
}

#footer > .rahmen {
    width: 90%;
    margin: 20px auto 0;
}

#footer ul {
    margin: 0 0 0 0;
    padding: 0 0 0 0;
    list-style: none;
    float: left;
    clear: none;
}

#footer ul:first-child {
    margin: 0 50px 0 0;
}

#footer hr {
    display: none;
}

#footer #karte.offen {
    margin-bottom: 20px;
}

#footer .pin span {
    background: var(--pin);
}

/* ++ Anpassung Cookie Buttons ++ */
.btn:hover, .btn-secondary:hover,
.btn:not(:disabled):not(.disabled):active,
.btn:not(:disabled):not(.disabled).active,
.show > .btn.dropdown-toggle  {
    background-color: var(--linkfarbe);
    border-color: var(--linkfarbe);
}
