/* Campuspoint Custom CSS Version 1.01.004 */

/* Style Fix */

.\[.logo-container.\].absolute.top-10.left-7.z-10.w-a.md\:top-2\.5.md\:left-2\.5 {
	top: -0.3rem;
	left: 0.5rem;
}

/* Style Fix */

/* Group Slider */
.GS-scroller-container {
    display: grid;
    gap: 1rem;
    grid-auto-flow: column;
    grid-auto-columns: 22%;
    padding: 10px 0px 15px 0px;
    overflow-x: auto;
    overscroll-behavior-inline: contain;
}

.GS-element {
    display: grid;
    grid-template-rows: min-content;
    gap: 0.5rem;
    padding: 0px;
    border-radius: 0px;
    overflow: hidden;
}

.GS-element > div {
    min-height: 400px;
}

.snaps-inline {
    scroll-snap-type: inline mandatory;
    scroll-padding-inline: 1rem;
    scrollbar-width: none;
}

.snaps-inline > * {
    scroll-snap-align: start;
}

.GS-scroller_wrapper {
    margin: 0 auto;
    position: relative;
}

.GS_prev_button {
    background: transparent;
    border-radius: 0;
    bottom: 0;
    height: 100%;
    max-height: 240px;
    outline: none !important;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 75px;
    z-index: 1;
    left: 20px;
}

.GS_next_button {
    background: transparent;
    border-radius: 0;
    bottom: 0;
    height: 100%;
    max-height: 240px;
    outline: none !important;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 75px;
    z-index: 1;
    right: 20px;
}

.slider_button {
    background-color: #f0f0f0;
    opacity: 0;
    transition: all .15s ease;
    font-size: xx-large;
    color: #000000;
}

.GS-scroller_wrapper:hover > .slider_button {
    opacity: 0.7;
    transition: all .15s ease;
}

.GS-scroller_wrapper .slider_button:hover {
    opacity: 1;
    transition: all .15s ease;
    color: #ba0d3b;
}

@media (max-width: 640px) {
    .GS-scroller-container {
        display: grid;
        gap: 1rem;
        grid-auto-flow: column;
        grid-auto-columns: 90%;
        padding: 10px 0px 15px 0px;
        overflow-x: auto;
        overscroll-behavior-inline: contain;
    }
    .slider_button {
        display: none;
    }
}

.GS_nav {
    cursor: pointer;
    user-select: none;
    text-decoration: none;
    display: inline-block;
    color: #ba0d3b;
    transition: border 0.2s;
    padding: 3px 2px;
}

.GS-Wrapper {
    display: grid;
    width: 100%;
    overflow: hidden;
    grid-template-rows: 40px 1fr;
    grid-template-columns: min-content min-content min-content min-content;
}

input[type="radio"] {
    display: none;
}

.GS_label-container {
    display: flex;
    flex-direction: row;
}

.GS_nav {
    display: flex;
    justify-content: center;
    cursor: pointer;
    background: #fff;
    user-select: none;
    transition: background 0.4s, padding-left 0.2s;
    padding-left: 0;
    flex-direction: column;
    gap: 10px;
    text-align: left;
}

.GS_nav img {
    width: 40px;
}

.GS-Container {
    grid-column-start: 1;
    grid-row-start: 2;
    grid-column-end: span 5;
    padding: 0px 00px;
    display: flex;
    background-color: #ffffff;
}

input[type="radio"] + .GS-Container {
    transition: transform 0.2s;
    transform: translateX(100%);
}

input[type="radio"]:checked + .GS-Container {
    transform: translateX(0%);
}

.GS-Container > div {
    max-width: 100%;
    width: 100%;
    padding: 0 0 20px 0;
}

.GS_nav p {
    margin: 0 0 0 0;
    font-weight: 700;
    padding: 0 10px;
    font-size: 1rem;
    text-wrap-mode: nowrap;
    width: fit-content;
}
.GS_nav p:hover {
    border-bottom: 3px solid #d1d1d1;
}

.GS_label-container .GS_nav.active p {
    border-bottom: 3px solid black;
    color: #000;
}

input[type="radio"]:checked + .GS-Container + .GS_nav .GS_nav p {
    border-bottom: 3px solid #000;
}

@media (max-width: 1225px) {
    .SiS-element {
        display: grid;
        gap: .5rem;
        padding: 0;
        border-radius: 0;
        overflow: hidden;
        min-width: unset;
    }
    .GS_label-container {
        flex-wrap: wrap;
        justify-content: left;
        gap: 5px;
    }

    .GS-Wrapper {
        display: flex;
        width: 100%;
        overflow: hidden;
        flex-direction: column;
    }

    .GS_nav {
        display: flex;
        flex-grow: 1;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        background: #fff;
        user-select: none;
        transition: background 0.4s, padding-left 0.2s;
        flex-direction: row;
        position: relative;
        padding: 0;
    }

    input[type="radio"]:checked + .GS-Container + .GS_nav {
        background: #ffffff;
        color: #000000;
    }

    .GS_nav img {
        width: 50px;
        display: block;
        margin: 0 0 0 -70px;
    }

    .GS-Container {
        grid-column-start: 1;
        grid-row-start: 2;
        grid-column-end: span 4;
        padding: 0px 0px;
        display: none;
    }

    input[type="radio"] + .GS-Container {
        transition: transform 0.2s;
        transform: translateX(100%);
    }

    input[type="radio"]:checked + .GS-Container {
        transform: translateX(0%);
        display: block;
    }

    .GS_nav > div {
        margin: 0 0 0 0;
        font-weight: bold;
        padding: 10px;
        margin-bottom: 0 !important;
        background: #f5f5f5;
        flex-grow: 1;
        justify-content: center;
        display: flex;
    }

    .GS_nav p {
        margin: 0 0 0 0;
        font-weight: bold;
        padding: 10px;
        margin-bottom: 0 !important;
    }
    .GS_nav p:hover {
        border-bottom: 0px solid #d1d1d1;
    }

    .GS_nav.active > div {
        background: #ba0d3b;
    }

    .GS_label-container .GS_nav.active p{
        border-bottom: 0px solid black;
        color: #fff;
    }
    .GS_nav {
        cursor: pointer;
        text-align: center;
    }
}

/* Gallery Slider */

.gallery-container {
	position: relative;
	display: flex;
	flex-direction: row;
	margin: .5rem 0 0 0;
	min-height: 86.9px;
}

.thumb-link img:not([src]) {
    visibility: hidden;
    display: none;
}

.tile__wrap {
    padding: 0;
}

.media-scroller {
    display: grid;
    gap: 0.5rem;
    grid-auto-flow: column;
    grid-auto-columns: 25%;
    padding: 0px 0px 0px 0px;
    overflow-x: auto;
    overscroll-behavior-inline: contain;
}

.media-element {
    display: grid;
    grid-template-rows: min-content;
    gap: 0;
    padding: 0px;
    border-radius: 0px;
    overflow: hidden;
}


.media-element > div {
	max-width: 150px;
	min-height: 86.9px;
}

.snaps-inline {
    scroll-snap-type: inline mandatory;
    scroll-padding-inline: 1rem;
    scrollbar-width: none;
}

.snaps-inline > * {
    scroll-snap-align: start;
}

.media-scroller_wrapper {
    position: relative;
    padding: 0 0 0 0;
}

.media_next_button, .media_prev_button {
    background: 0 0;
    border-radius: 0;
    bottom: 0;
    max-height: 240px;
    outline: 0 !important;
    width: 8em;
    z-index: 1;
}

.media_slider_button {
    background-color: #ba0d3b;
    opacity: 1;
    transition: all .15s ease;
    font-size: xx-large;
    color: #fff;
    border: 1px solid #ba0d3b;
    max-width: 80px;
}

.media_slider_button:hover {
    background-color: #f0f0f0;
    opacity: 1;
    transition: all .15s ease;
    font-size: xx-large;
    color: #ba0d3b;
    border: 1px solid #d1d1d1;
}

.media-scroller_wrapper:hover > .slider_button {
    opacity: 0.7;
    transition: all .15s ease;
}

.media-scroller_wrapper .slider_button:hover {
    opacity: 1;
    transition: all .15s ease;
    color: #ba0d3b;
}

@media (max-width: 640px) {
    .media-scroller {
        display:grid;
        gap:1rem;
        grid-auto-flow:column;
        grid-auto-columns:80%;
        padding:0 0 15px;
        overflow-x:auto;
        overscroll-behavior-inline:contain
    }

    .media_slider_button {
        display: none;
    }

    .media-element > div {
        max-width: unset;
    }
}

/* Label */
.tabs {
    display: flex;
    flex-wrap: wrap;
}

.tabs label {
    order: 1;
    display: block;
    padding: 1rem 2rem;
    margin-right: 0.2rem;
    cursor: pointer;
    background: #ffffff;
    font-weight: bold;
    transition: background ease 0.2s;
}

.tabs .tab {
    order: 99;
    flex-grow: 1;
    width: 100%;
    display: none;
    padding: 1rem;
    background: #ffffff;
    background-color: #216afc;
}

.tabs input[type="radio"] {
    display: none;
}

.tabs input[type="radio"]:checked + label {
    background: #ba0d3b;
    color: #ffffff;
}

.tabs input[type="radio"]:checked + label + .tab {
    display: block;
}

.nav {
    cursor: pointer;
    user-select: none;
    text-decoration: none;
    display: inline-block;
    color: #ba0d3b;
    transition: border 0.2s;
    padding: 3px 2px;
}

.layout {
    display: grid;
    width: 100%;
    overflow: hidden;
    grid-template-rows: 40px 1fr;
    grid-template-columns: min-content min-content min-content min-content;
}

input[type="radio"] {
    display: none;
}

.label-container {
    display: flex;
    flex-direction: row;
}

.nav {
    display: flex;
    justify-content: center;
    cursor: pointer;
    background: #fff;
    user-select: none;
    transition: background 0.4s, padding-left 0.2s;
    padding-left: 0;
    flex-direction: column;
    gap: 10px;
    text-align: left;
}

.nav img {
    width: 40px;
}

.page {
    grid-column-start: 1;
    grid-row-start: 2;
    grid-column-end: span 5;
    padding: 0px 00px;
    display: flex;
    background-color: #ffffff;
}

input[type="radio"] + .page {
    transition: transform 0.2s;
    transform: translateX(100%);
}

input[type="radio"]:checked + .page {
    transform: translateX(0%);
}

.page-contents {
    max-width: 100%;
    width: 100%;
    padding: 0 0 20px 0;
}

.labelheading p {
    margin: 0 0 0 0;
    font-weight: 700;
    padding: 0 10px;
    font-size: 1rem;
    text-wrap-mode: nowrap;
    width: fit-content;
}

.label-container .nav.active p{
    border-bottom: 3px solid black;
    color: #000;
}


/* Neuer Stil für aktives Label */
input[type="radio"]:checked + .page + .nav .labelheading p {
    border-bottom: 3px solid #000;
}

@media (max-width: 640px) {
    .label-container {
        flex-wrap: wrap;
        justify-content: left;
        gap: 5px;
    }

    .tabs .tab,
    .tabs label {
        order: initial;
    }

    .tabs label {
        width: 100%;
        margin-right: 0;
        margin-top: 0.2rem;
    }

    .layout {
        display: flex;
        width: 100%;
        overflow: hidden;
        flex-direction: column;
    }

    .nav {
        display: flex;
        align-items: center;
        justify-content: left;
        cursor: pointer;
        background: #fff;
        user-select: none;
        transition: background 0.4s, padding-left 0.2s;
        /* padding-left: 20px; */
        flex-direction: row;
        /* height: 30px; */
        position: relative;
        padding: 0;
    }

    input[type="radio"]:checked + .page + .nav {
        background: #ffffff;
        color: #000000;
    }

    .nav img {
        width: 50px;
        display: block;
        margin: 0 0 0 -70px;
    }

    .page {
        grid-column-start: 1;
        grid-row-start: 2;
        grid-column-end: span 4;
        padding: 0px 0px;
        display: none;
    }

    input[type="radio"] + .page {
        transition: transform 0.2s;
        transform: translateX(100%);
    }

    input[type="radio"]:checked + .page {
        transform: translateX(0%);
        display: block;
    }

    .labelheading {
        margin: 0 0 0 0;
        font-weight: bold;
        padding: 10px;
        margin-bottom: 0 !important;
        background: #f5f5f5;
    }

    .labelheading p {
        margin: 0 0 0 0;
        font-weight: bold;
        padding: 10px;
        margin-bottom: 0 !important;
    }

    .nav.active > div {
        background: #ba0d3b;
    }

    .label-container .nav.active p{
        border-bottom: 0px solid black;
        color: #fff;
    }
}

/* Upsell / Similar Slider */

/* Slider */
.SiS-scroller-container {
    display: grid;
    gap: 1rem;
    grid-auto-flow: column;
    grid-auto-columns: 22%;
    padding: 10px 0px 15px 0px;
    overflow-x: auto;
    overscroll-behavior-inline: contain;
    align-items: stretch;
}

.SiS-element {
    display: grid;
    gap: .5rem;
    padding: 0;
    border-radius: 0;
    overflow: hidden;
    min-width: 200px;
}

.SiS-element > div {
    min-height: 400px;
}

.SiS-element img {
    height: unset !important;
}

.snaps-inline {
    scroll-snap-type: inline mandatory;
    scroll-padding-inline: 1rem;
    scrollbar-width: none;
}

.snaps-inline > * {
    scroll-snap-align: start;
}

.SiS-scroller_wrapper {
    margin: 10px auto;
}

.SiS_prev_button {
    background: transparent;
    border-radius: 0;
    bottom: 0;
    height: 100%;
    max-height: 50px;
    outline: none !important;
    position: absolute;
    top: 0;
    width: 50px;
    z-index: 1;
    left: 0px;
}

.SiS_next_button {
    background: transparent;
    border-radius: 0;
    bottom: 0;
    height: 100%;
    max-height: 50px;
    outline: none !important;
    position: absolute;
    top: 0;
    width: 50px;
    z-index: 1;
    left: 60px;
}

.SiS_slider_button {
    background-color: #f0f0f0;
    opacity: 1;
    transition: all .15s ease;
    font-size: large;
    color: #000000;
}


.SiS-scroller_wrapper .slider_button:hover {
    opacity: 1;
    transition: all .15s ease;
    color: #ba0d3b;
}

@media (max-width: 640px) {
    .SiS-scroller-container {
        display: grid;
        gap: 1rem;
        grid-auto-flow: column;
        grid-auto-columns: 90%;
        padding: 10px 0px 15px 0px;
        overflow-x: auto;
        overscroll-behavior-inline: contain;
        align-items: stretch;
    }
    .SiS_slider_button {
        display: none;
    }

    .SiS-element {
        display: grid;
        gap: .5rem;
        padding: 0;
        border-radius: 0;
        overflow: hidden;
        min-width: unset;
    }
}


.SiS-Wrapper {
    display: grid;
    width: 100%;
    overflow: hidden;
    grid-template-rows: 40px 1fr;
    grid-template-columns: min-content min-content min-content min-content;
    position: relative;
}


.SiS-Wrapper > div {
    grid-column-start: 1;
    grid-row-start: 2;
    grid-column-end: span 5;
    padding: 0px 00px;
    display: flex;
    background-color: #ffffff;
}


@media (max-width: 640px) {
    .SiS-Wrapper {
        display: flex;
        width: 100%;
        overflow: hidden;
        flex-direction: column;
    }

    .SiS-Wrapper > div {
        grid-column-start: 1;
        grid-row-start: 2;
        grid-column-end: span 4;
        padding: 0px 0px;
    }

}

