:root {
    --black: #000000;
    /* --red: #e40039;
  --red-lighter: rgb(228, 0, 57, .9); */
    --red: #e2011b;
    --red-lighter: rgb(226, 1, 27, 0.9);
    /* --red: #e2001a;
  --red-lighter: rgb(226, 0, 26, .9); */
    --white: #ffffff;
    --lightgrey: #eae7e7;
    --largeFontSize: 5rem;
    --mediumFontSize: 3rem;
    --semimediumFontSize: 2.8rem;
    --smallFontSize: 2rem;
    --smallerFontSize: 1.6rem;
    --font: 'Open Sans', sans-serif;
    --transition: all 0.3s ease;
    --bold: 700;
    --v-gap: 10rem;
    --shadow: 0px 3px 6px rgba(0, 0, 0, 0.3);
}

body {
    background: #eae7e7;
    font-family: var(--font);
}

body {
    background: #fff;
    margin: 0 auto;
    min-height: 100%;
    position: relative;
    width: calc(100vw - var(--padding) * 2);
    font-size: var(--smallFontSize);
    line-height: 1.5;
}

html {
    background: #eae7e7;
    height: 100%;
}

::-webkit-scrollbar {
    width: 12px;
}

::-webkit-scrollbar-track {
    background: var(--white);
}

::-webkit-scrollbar-thumb {
    background: var(--red);
}

ul ul {
    margin-left: 1em;
}

ul + ul {
    margin-top: 1em;
}

main .content ul {
    margin-left: 0.5em;
}

main .content ul ul {
    margin-left: 1em;
}

main .content ul li:before {
    /* content: '»';
  color: var(--red);
  margin-right: .3em; */
}

main .content ul li {
    list-style-type: '»';
    list-style-type: '•';
    padding-left: 0.5em;
}

main .content ul li::marker {
    color: var(--red);
}

main .content ul li > a:only-child {
    /* color: inherit; */
}

#sitemap_container a[href='#'] {
    cursor: default;
    pointer-events: none;
    /* font-weight: var(--bold, 700); */
}

nav {
    font-size: var(--smallerFontSize);
}

nav ul {
    margin-left: 0;
    display: flex;
    gap: 0 1rem;
    flex-wrap: wrap;
}

header nav a:hover {
    font-weight: var(--bold);
    text-transform: uppercase;
}

a {
    text-decoration: none;
}

.ref_desc p a,
.content p a,
label a {
    color: var(--red);
}

.ref_desc p a.btn,
.content p a.btn,
label a.btn {
    color: var(--white);
}

.content ul a {
    color: var(--red);
    /* text-decoration: underline;
  text-decoration-color: var(--red);
  text-decoration-thickness: 1px; */
}

#sitemap_container ul a {
    text-decoration: none;
    color: inherit;
}

.content p strong a {
    color: inherit;
}

.content h2:not(:first-child),
.content h3:not(:first-child),
.content h4:not(:first-child),
.content h6:not(:first-child) {
    margin-top: 1em;
}

li {
    list-style: none;
}

header {
    background-color: rgba(255, 255, 255, 0.8);
    justify-content: space-between;
    padding: 1em var(--module-padding, var(--column));
    align-items: center;
    z-index: 10;

    display: grid;
    grid-template-columns: 1fr auto 1fr;
    column-gap: 2em;
}

/* header-icons */
.header-icons {
    display: flex;
    gap: var(--gap);
    justify-content: flex-end;
}

.header-icons a {
    display: flex;
    width: 6rem;
    height: 6rem;
    box-shadow: var(--shadow);
    background-color: var(--white);
    border-radius: 50%;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}

.header-icons a:hover {
    transform: scale(1.05);
}

.header-icons a img {
    object-fit: contain;
    object-position: center;
    max-height: 50%;
    max-width: 75%;
}

header .logo img {
    max-height: 4rem;
    max-height: 6rem; /* 30 Jahre Logo */
    width: 100%;
    object-fit: contain;
    object-position: center;
    max-width: 40vw;
    height: revert-layer;
}

footer .logo img {
    max-height: 8rem;
    width: 100%;
    object-fit: contain;
    object-position: center;
}

#row_content {
    gap: var(--gap) 0;
    gap: var(--v-gap) 0;
    margin-bottom: var(--v-gap);
}

section {
    position: relative;
    z-index: 1;
}

.content-wrapper {
    padding-left: var(--column);
    padding-right: var(--column);
}

.intro-header .content-wrapper {
    position: relative;
    z-index: 3;
}

/* Headline */
.headline:not(.content_block) {
    color: var(--red);
    font-weight: var(--bold);
    font-size: var(--largeFontSize);
    position: relative;
    line-height: 1;
}

.headline:not(.content_block):before,
.headline:not(.content_block):after {
    content: '';
    background-color: var(--red);
    clip-path: polygon(
        7.5% 0%,
        42.5% 0%,
        100% 46.5%,
        42.5% 100%,
        0% 100%,
        63.5% 46.5%
    );
    /* width: 4rem; */
    height: var(--column);
    min-height: 1.75em;
    aspect-ratio: 0.5;
    position: absolute;
    top: 50%;
    left: calc(0px - (var(--column) - var(--overlapping)));
    transform: translate(0%, -50%);
}

.headline:not(.content_block):after {
    transform: translate(66%, -50%);
}

.small_headline {
    font-size: var(--mediumFontSize);
    color: var(--red);
    line-height: 1;
    font-weight: var(--bold);
    margin: 0;
}

.small_headline:empty {
    display: none;
}

.content {
    display: flex;
    flex-direction: column;
    gap: 0.5em;
    align-items: flex-start;
    hyphens: auto;
}

.content:not(:first-child) {
    margin-top: var(--largeFontSize);
}

/* Subline */
.subline {
    font-size: var(--mediumFontSize);
    line-height: 1.25;
}

.headline + .subline {
    margin-top: 0.25em;
}

/* Intro Header */
.intro-header {
    padding-right: 50%;
    padding-top: 7.5rem;
    z-index: 0;
}

.intro-header:before {
    content: '';
    position: absolute;
    right: 0;
    top: 0;
    width: 15vmin;
    height: 30vmin;
    background-color: var(--red);
    z-index: 0;
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%);
    transform: translateY(-50%);
    z-index: 0;
    pointer-events: none;
}

.intro-header:after {
    content: '';
    position: absolute;
    right: 0;
    top: calc(90vmin * 0.8);
    width: 15vmin;
    height: 30vmin;
    background-color: var(--red);
    z-index: 0;
    clip-path: polygon(0% 100%, 100% 0%, 100% 100%);
    transform: translateY(-100%);
    z-index: 0;
    pointer-events: none;
}

.intro-header .media_wrapper {
    position: absolute;
    right: 0;
    top: 0;
    width: 50%;
    height: 90vmin;
    aspect-ratio: 0.5;
    background-color: var(--red);
    display: flex;
    align-items: stretch;
    transform: translate(0%, -20%);
    clip-path: polygon(
        0% 0%,
        calc(90% - 20vmin) 0%,
        90% 50%,
        calc(90% - 20vmin) 100%,
        0% 100%,
        20vmin 50%
    );
    z-index: 0;
    pointer-events: none;
}

.intro-header .media_wrapper:not(:empty):before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: var(--red);
    mix-blend-mode: multiply;
    z-index: 2;
    display: block;
}

.media_wrapper > * {
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 1;
    color: var(--white);
}

.intro-header > .white {
    position: absolute;
    top: 100%;
    width: 100%;
    height: 90vmin;
    background-color: var(--white);
    z-index: 2;
}

/* CALL2ACTION */
.call-to-action {
    position: fixed;
    right: 0;
    top: 50vh;
    transform: translate(100%, -50%);
    -webkit-transform: translate(100%, -50%);
    -ms-transform: translate(100%, -50%);
    transition: transform 0.4s ease;
    -webkit-transition: transform 0.4s ease;
    will-change: transform;
    z-index: 999;
}

.call-to-action .small_headline {
    color: inherit;
    margin-top: 0;
}

.call-to-action:focus-within,
.call-to-action.active {
    transform: translate(0, -50%);
    -webkit-transform: translate(0, -50%);
    -ms-transform: translate(0, -50%);
}

.call-to-action a {
    background: var(--white);
    color: var(--red);
    display: inline-block;
    line-height: 1;
}

.call-to-action a:not(.btn) {
    padding: 1rem 2rem;
}

.call-to-action a:hover {
    opacity: 0.9;
}

.call-to-action .social a,
.page-7066 .call-to-action a {
    padding: 0;
}

.call-to-action .field-icon,
.call-to-action .field-icon-ref {
    align-items: center;
    background: var(--red);
    border: 0 solid #000;
    color: #fff;
    cursor: pointer;
    display: flex;
    font-size: 2.3rem;
    height: 5rem;
    justify-content: center;
    width: 5rem;
    transform: translate(-100%, 100%);
}

.call-to-action .field-icon {
    top: 0;
    right: 100%;
    position: absolute;
    transform: none;
}

.call-to-action .field-content,
.call-to-action .field-content-ref {
    background: var(--red-lighter);
    color: #fff;
    padding: 3rem;
    width: 42rem;
    max-width: calc(100vw - 6rem);
    margin: 0;
    max-height: 90vh;
    overflow: auto;
}

.call-to-action .field-content p b {
    display: block;
}

.call-to-action .field-content h4,
.call-to-action .field-content-ref h4 {
    margin-bottom: 2rem;
}

.reference-wrapper {
    position: relative;
    z-index: 2;
}

.reference-wrapper > .flex {
    /* margin-top: var(--largeFontSize); */
    gap: var(--column);
}

.reference-wrapper .desc {
    margin-top: var(--largeFontSize);
}

.ref_desc {
    width: 100%;
    max-width: calc(var(--column) * 7);
    flex-shrink: 0;
}

.teaser-ref-img-wrapper,
.teaser-ref-img-wrapper > div {
    width: 100%;
    display: flex;
    gap: var(--gap);
    flex-wrap: wrap;
    flex-grow: 0;
}

.ref_img_wrapper#slider > div {
    display: block;
}

.ref_img_wrapper#slider {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    margin: -1rem -1rem 4rem 0;
    gap: 0;
}

.teaser-ref-img-wrapper > div {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: stretch;
    grid-auto-flow: dense;
}

.teaser-ref-img-wrapper > div > * {
    display: flex;
    align-items: stretch;
    object-fit: cover;
}

.teaser-ref-img-wrapper > div > :only-child {
    grid-column-end: span 2;
}

.teaser-ref-img-wrapper img {
    object-fit: cover;
}

.reference-wrapper [data-fullwidth='full-width'] {
    grid-column-end: span 2;
}

@media screen {
    .reference-wrapper .only_print {
        display: none;
    }
}

.teaser-ref-img-wrapper > img,
.teaser-ref-img-wrapper > video {
    box-shadow: var(--shadow);
}

.reference-wrapper,
.reference-wrapper .contents {
    margin: 0 0 5rem;
}

.reference-wrapper .contents {
    /* color: #757575 */
}

.reference-wrapper a {
    /* color: #002c76 */
}

.reference-wrapper a:first-child:nth-last-child(2) {
    grid-column-end: span 2;
}

.back_arrow {
    display: flex;
    align-items: center;
    gap: var(--gap);
}

.back_arrow p {
    display: block;
    margin: 0;
}

.reference-wrapper .ref_desc p:empty {
    margin-top: 1em;
    display: none;
}

.reference-wrapper .ref_desc p.empty:empty {
    display: none;
}

.reference-wrapper img {
    height: auto !important;
    max-width: 100%;
}

.reference-wrapper img.link-arrow {
    width: auto;
    height: 2rem !important;
}

.ref_img_wrapper {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    margin: -1rem -1rem 4rem 0;
}

.ref_img_wrapper img,
.ref_img_wrapper video {
    cursor: pointer;
    margin: 1rem 1rem 0 0;
}

.ref_img_wrapper img:first-child,
.ref_img_wrapper video:first-child {
    margin-left: 0;
}

.ref_img {
    height: auto;
}

.ref_desc .content > p:last-of-type {
    margin-bottom: 2rem;
}

.logo-wrapper {
    align-items: center;
    background: #eae7e7;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding-top: 4rem;
    padding-bottom: 4rem;
}

.reference-logo {
    filter: brightness(0) invert(1);
    -webkit-filter: brightness(0) invert(1);
    width: 16rem;
    margin: 1rem 2rem;
    opacity: 1;
    transition: all 0.4s ease;
}

.ref_img_wrapper#slider {
    position: relative;
}

.ref_img_wrapper#slider .arrows {
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    pointer-events: none;
    transform: translateY(-50%);

    display: flex;
    justify-content: space-between;
    align-items: center;
}

.ref_img_wrapper#slider .arrows span {
    pointer-events: all;
    height: 4rem;
    width: 3rem;
    /* background-color: blue; */
    cursor: pointer;
    display: flex;
    justify-content: center;
    align-items: center;
}

.ref_img_wrapper#slider .arrows img {
    margin: 0;
}

.ref_img_wrapper#slider .arrows .next {
    transform-origin: center;
    transform: rotate(180deg);
}

.ref_img_wrapper#slider .pagination {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--gap);
    margin-top: 1em;
}

.ref_img_wrapper#slider .pagination span {
    height: 1rem;
    width: 1rem;
    background-color: var(--black);
    border-radius: 50%;
    cursor: pointer;
    opacity: 0.5;
    transition: all 0.3s ease;
}

.ref_img_wrapper#slider .pagination .active {
    opacity: 1;
    cursor: default;
    pointer-events: none;
}

.ref_img_wrapper#slider .media {
    position: relative;
    overflow: hidden;
    width: 100%;
}

.ref_img_wrapper#slider .media:before {
    content: '';
    width: 100%;
    padding-bottom: 75%;
    display: block;
}

.ref_img_wrapper#slider .media > * {
    position: absolute;
    max-height: 100%;
    max-width: 100%;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    margin: 0;
    opacity: 1;
    visibility: visible;
    pointer-events: all;
    cursor: default;
    transition: all 0.3s ease;
}

.ref_img_wrapper#slider .media > :not(.active) {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

/* MOBILE */

#slider.layout_mobile {
    max-width: 350px;
    margin: 2rem auto;
}

@media (min-width: 769px) {
    #slider.layout_none:first-child,
    #slider.layout_mobile:first-child {
        margin-top: -10rem;
    }
}

#slider.layout_mobile .media::before {
    padding-bottom: 150%;
}

#slider.layout_mobile .media:after {
    content: '';
    background-image: url(../images/mobile_mockup.png);
    background-position: center;
    background-size: contain;
    position: absolute;
    z-index: 10;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    pointer-events: none;
}

#slider .media > * {
    object-fit: contain;
}

#slider.layout_mobile .media > * {
    max-height: 71%;
    transform: translate(calc(-50% - -1px), -50%);
}

/* LAPTOP */

#slider.layout_laptop {
    /* max-width: 350px; */
    margin: 2rem auto;
}

@media (min-width: 769px) {
    #slider.layout_none:first-child,
    #slider.layout_laptop:first-child {
        margin-top: -5rem;
    }
}

#slider.layout_laptop .media::before {
    padding-bottom: 65%;
}

#slider.layout_laptop .media:after {
    content: '';
    background-image: url(../images/laptop_mockup.png);
    background-position: center;
    background-size: contain;
    position: absolute;
    z-index: 10;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    pointer-events: none;
}

#slider.layout_laptop .media > * {
    width: 67%;
    max-height: none;
    left: 46%;
    top: 42%;
    transform: translate(calc(-50% - -1px), -50%);
}

/* LAPTOP */

#slider.layout_pc {
    /* max-width: 350px; */
    margin: 2rem auto;
}

@media (min-width: 769px) {
    #slider.layout_none:first-child,
    #slider.layout_pc:first-child {
        margin-top: -5rem;
    }
}

#slider.layout_pc .media:after {
    content: '';
    background-image: url(../images/pc_mockup.png);
    background-position: center;
    background-size: contain;
    position: absolute;
    z-index: 10;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    pointer-events: none;
}

#slider.layout_pc .media > * {
    width: 77.2%;
    max-height: none;
    left: 50%;
    top: 35.2%;
    transform: translate(calc(-50% - -1px), -50%);
}

.highlight {
    color: var(--red);
}

/* 404 */

.page-404 .intro-header .media_wrapper {
    overflow: hidden;
}

.errorpage {
    align-items: stretch;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.errorpage h1 strong {
    font-size: 5em;
}

.errorpage img {
    width: 100%;
    max-width: 20rem;
    height: auto;
}

.errorpage .lg_6 {
    width: calc(100vw / 12 * 6);
}

.errorpage_img {
    position: relative;
    background: radial-gradient(
        circle,
        rgba(0, 0, 0, 0.2) 0%,
        rgba(255, 255, 255, 0) 60%
    );
    /* min-height: 40rem; */
    /* max-width: 50rem; */
    width: 100%;
}

.errorpage_img .mond {
    position: absolute;
    left: 12.5%;
    top: 20%;
    z-index: 1;
    width: 40%;
    height: auto;
}

.errorpage_img .astronaut {
    position: absolute;
    right: 12.5%;
    bottom: 10%;
    z-index: 2;
    width: 40%;
    height: auto;
    transform: rotate(0deg);
    animation-duration: 10s;
    animation-name: rotate;
    animation-iteration-count: infinite;
    animation-timing-function: linear;
}

@-webkit-keyframes rotate {
    from {
        transform: rotate(0);
    }

    to {
        transform: rotate(360deg);
    }
}

@keyframes rotate {
    from {
        transform: rotate(0);
    }

    to {
        transform: rotate(360deg);
    }
}

/*********************/

.intro-header.special h1 span {
    display: block;
    font-weight: normal;
    color: var(--black);
    font-size: 0.75em;
    margin-top: 0.25em;
}

/* .content_block li > a,
.content_block p a {
  text-decoration: underline;
  text-decoration-color: #585858;
}  */

/* html .contact-section .contact-text p > a, */
.content_block li > a:not(.btn),
.content_block p a:not(.btn) {
    text-decoration: none;
}

/* html .contact-section .contact-text p>a:after, */
.video_site a:before,
.content_block li > a:not(.btn):before,
.content_block p a:not(.btn):before {
    content: '»';
    margin: 0 0.25em 0 0;
    color: var(--red);
    /* display: inline-block; */
}

.grid_block .more a:before {
    content: none !important;
}

.content_block li > a:only-child {
    /* color: inherit; */
}

/*****************************/

.wrapper.video_site > hgroup {
    transform: translateY(calc(var(--v-gap) / 2));
}

.wrapper.video_site figcaption {
    margin-top: 1em;
}

.wrapper.video_site figcaption .note {
    font-size: 0.8em;
    margin-top: 1em;
}

.wrapper.video_site figcaption > * {
    margin: 0;
}

.wrapper.video_site .overlapping video {
    background-color: var(--black);
    object-fit: contain;
    max-height: 90vh;
    width: 100%;
    /* aspect-ratio: 1920 / 1080; */
}

.wrapper.video_site .overlapping video:not(:playing) {
    object-fit: cover;
}

.btn.back {
    clip-path: polygon(
        1rem 0%,
        100% 0%,
        calc(100% - 1rem) 50%,
        100% 100%,
        1rem 100%,
        0% 50%
    );
}

@media screen and (max-width: 768px) {
    .btn.back {
        font-size: 0.75em;
        padding: 0.75rem 3rem;
    }

}

.content_block.overview .content .content {
    margin: .5em 0;
}

/* Anpassungen für Job-Seiten */
@media screen and (min-width: 1181px) {
    .page-11192 .content_block.overview {
        gap: var(--gap);
    }
}

.page-11192 .content {
    hyphens: manual;
}