/* Basics für diese Seite */
.headline-md {
    font-size: max(18px, 14.2px + 0.4vw);
}
.headline-lg {
    font-size: max(42px, 30px + 1.25vw);
}

/* Subpage Hero */
.subpage-hero .subpage-hero-container {
    padding-block: calc(25px + 7vh) calc(35px + 7vh);
}
.subpage-hero .subpage-hero-container .section-title-wrapper {
    display: block;
}
.subpage-hero .subpage-hero-container .section-title-wrapper .section-title {
    margin-bottom: 65px;
}

/* About */
.about {
    background-color: #f7f8fa;
    scroll-margin-top: 75px;
}
.about .split-section-50 {
    display: flex;
    align-items: flex-start;
    width: 100%;
}
.about .split-section-50 .col-img {
    width: 55.5%;
    overflow-x: hidden;
    overflow-y: auto;
}
.about .split-section-50 .col-img .img-wrapper {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    height: inherit;
    list-style-type: none;
}
.about .split-section-50 .col-img .img-wrapper li {
    width: 100%;
    height: 70vh;
}
.about .split-section-50 .col-txt {
    position: sticky;
    top: 9%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 40px;
    width: calc(44.5%);
    max-width: calc(560px + 22vw);
    height: calc(100vh - var(--header-height));
    padding: 90px 9vw 90px 4rem;
}
.about .split-section-50 .col-txt.left {
    padding-inline: 9vw 4rem;
}
.about .info-container {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: white;
    padding-block: 95px;
}
.about .info-container .info {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    width: calc(560px + 22vw);
    max-width: 90vw;
    margin-inline: auto;
    text-align: center;
}
.about .info-container .info .headline-md {
    color: var(--primary-color);
}
.about .info-container .info .info-text {
    line-height: 1.66;
}
@media only screen and (max-width: 992px) {
    .subpage-hero .subpage-hero-container {
        padding: 48px 0 80px;
    }
    .subpage-hero .subpage-hero-container .section-title-wrapper {
        display: none;
    }
    .about .info-text {
        font-size: 16.4px;
    }
    .about .split-section-50 {
        flex-direction: column-reverse;
    }
    .about .split-section-50.reverse {
        flex-direction: column;
    }
    .about .split-section-50 .col-img {
        width: 100%;
        padding-bottom: 50px;
    }
    .about .split-section-50 .col-img .img-wrapper {
        gap: 8px;
    }
    .about .split-section-50 .col-img .img-wrapper li {
        width: 90%;
        height: 220px;
        margin-inline: auto;
    }
    .about .split-section-50 .col-img .img-wrapper .bg-img {
        border-radius: 6px;
    }
    .about .split-section-50 .col-txt {
        position: unset;
        width: 100%;
        height: unset;
        gap: 35px;
        padding: 35px 5vw 40px;
    }
    .about .split-section-50 .col-txt.left {
        padding: 35px 5vw 40px;
    }
    .about .info-container {
        padding-block: 40px 45px;
    }
    .subpage-info-container {
        padding-bottom: 80px;
    }
    .subpage-info-container .img-wrapper {
        padding-top: 20px;
        flex-direction: row;
        scale: 0.45;
    }
    .subpage-info-container .img-wrapper {
        gap: 2.5rem;
    }
    .subpage-info-container .img-wrapper img {
        height: 44px !important;
    }
}

/* Reference Section */
.reference {
    background: linear-gradient(to bottom, #fff, #f2f4f8 50%, #fff);
}
.reference-container {
    padding: 20px 0 0 0;
}
.scroll-area {
    display: grid;
    grid-template-rows: repeat(2, 120px) 155px;
    justify-content: space-around;
    overflow: hidden;
}
.scroll-parent {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-around;
    min-width: calc(6 * 315px);
    width: 100%;
    padding-bottom: 10px;
}
.scroll-element {
    position: absolute;
    display: flex;
    width: inherit;
    height: inherit;
    inset: 1vh 0;
    column-gap: 15px;
}
.artist-card {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 300px;
    height: 100px;
    background-color: #fff;
    opacity: 0.95;
    border-radius: 6px;
    border: 0.7px solid #eeeeee;
    box-shadow: 0 4px 10px -1px rgba(0, 0, 0, 0.1),
        0 2px 6px -2px rgba(0, 0, 0, 0.2);
    transition: all 0.3s ease;
}
@media (hover: hover) {
    .artist-card:hover {
        box-shadow: -1px 5px 15px 5px rgba(0, 0, 0, 0.1);
        filter: invert(90%);
    }
}
.artist-card img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: 6px 0 0 6px;
    filter: grayscale(1);
    transition: all 0.3s ease-out;
}
@media (hover: hover) {
    .artist-card img:hover {
        cursor: pointer;
        border-color: rgb(255, 255, 255);
    }
}
.artist-card .artist-logos {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
        Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue",
        sans-serif;
    font-size: 36px;
    font-weight: 700;
    text-align: center;
    line-height: 1;
    white-space: nowrap;
    user-select: none;
}
.artist-card .artist-logos.two-rows {
    font-weight: 700;
    font-size: 35px;
    padding: 0 30px;
    white-space: normal;
    display: flex;
    flex-direction: column;
    user-select: none;
}
.artist-card .artist-logos span {
    font-size: 17px;
    font-weight: 400;
    user-select: none;
}
.primary {
    animation: primary 90s linear infinite;
}
@media (hover: hover) {
    .primary:hover {
        animation-play-state: paused;
    }
}
.secondary {
    animation: secondary 90s linear infinite;
}
@media (hover: hover) {
    .secondary:hover {
        animation-play-state: paused;
    }
}
.primary.pause,
.secondary.pause {
    animation-play-state: paused;
}
.primary.late {
    animation: primary-late 90s linear infinite;
}
.secondary.late {
    animation: secondary-late 90s linear infinite;
}
@media (hover: hover) {
    .primary.late:hover,
    .secondary.late:hover {
        animation-play-state: paused;
    }
}
.primary.late.pause,
.secondary.late.pause {
    animation-play-state: paused;
}
.primary-rev {
    animation: primary 110s linear infinite;
    animation-direction: reverse;
}
@media (hover: hover) {
    .primary-rev:hover {
        animation-play-state: paused;
    }
}
.secondary-rev {
    animation: secondary 110s linear infinite;
    animation-direction: reverse;
}
@media (hover: hover) {
    .secondary-rev:hover {
        animation-play-state: paused;
    }
}
.primary-rev.pause,
.secondary-rev.pause {
    animation-play-state: paused;
}
@keyframes primary {
    from {
        left: 0%;
    }
    to {
        left: -100%;
    }
}
@keyframes primary-late {
    from {
        left: -8%;
    }
    to {
        left: -108%;
    }
}

@keyframes secondary {
    from {
        left: 100%;
    }
    to {
        left: 0%;
    }
}
@keyframes secondary-late {
    from {
        left: 92%;
    }
    to {
        left: -8%;
    }
}