.subsectionOverlayer {
    width: calc(var(--singleUserWindowWidth) - (var(--singleUserWindowBorderSize) * 2));
    height: calc(var(--singleUserWindowHeight) - (var(--singleUserWindowBorderSize) * 2));
    top: 0;
    left: 0;
    padding: 0px;
    margin: 0px;
    box-sizing: border-box;
    overflow: hidden;
    z-index: 81;
    display: block;
    position: absolute;
}

.overlayerBackground {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    padding: 0px;
    margin: 0px;
    box-sizing: border-box;
}

@supports ((-webkit-backdrop-filter: blur(20px)) or (backdrop-filter: blur(20px))) {
    .blurring {
        opacity: 0.99;
        -webkit-backdrop-filter: blur(20px);
        backdrop-filter: blur(20px);
        z-index: -1;
    }

    .darkening {
        background-color: var(--bmwi_black_100);
        opacity: 0.75;
    }
}

@supports not ((-webkit-backdrop-filter: blur(20px)) or (backdrop-filter: blur(20px))) {
    .darkening {
        background-color: var(--bmwi_black_80);
        opacity: 0.98;
    }
}

.overlayerContentContainer {
    width: 100%;
    height: 100%;
    z-index: 1;
    backdrop-filter: blur(1px); //is only here to fix z-index problems
}

.overlayerContent {
    width: calc(100% - var(--overlayerMarginLeft) - var(--overlayerMarginRight));
    height: calc(100% - var(--overlayerMarginTop) - var(--overlayerFooterHeight) - var(--spacerUnit));
    position: absolute;
    top: var(--overlayerMarginTop);
    left: var(--overlayerMarginLeft);
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-between;
    padding: 0px;
    margin: 0px;
}

.overlayerColumn {
    width: var(--overlayerColumnWidth);
    height: 100%;
    position: relative;
    padding: 0px;
    margin: 0px;
}

.overlayerFooter {
    width: calc(100% - var(--overlayerMarginLeft) - var(--overlayerMarginRight));
    height: var(--overlayerFooterHeight);
    position: absolute;
    bottom: 0px;
    left: var(--overlayerMarginLeft);
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-between;
}

.overlayerFooterLink {
    width: 100%;
    height: var(--overlayerQRIconSize);
    position: absolute;
    top: var(--overlayerQRLinkTop);
    display: flex;
    flex-flow: row wrap;
    align-items: center;
    overflow: hidden;
}

.overlayerMapIcon {
    width: var(--overlayerMapIconWidth);
    height: var(--overlayerMapIconHeight);
    position: relative;
    padding: 0px;
    margin: 0px;
    margin-right: var(--overlayerIconMarginRight);
}

.overlayerMapIcon:hover {
    cursor: pointer;
}

.overlayerQRIcon {
    width: var(--overlayerQRIconSize);
    height: var(--overlayerQRIconSize);
    position: relative;
    padding: 0px;
    margin: 0px;
    margin-right: var(--overlayerIconMarginRight);
    background-color: var(--bmwi_white_100);
    /* DEBUG:  */
}

.overlayerQRIcon img {
    width: var(--overlayerQRIconSize);
    height: var(--overlayerQRIconSize);
}

h5.overlayerQRLinkText {
    font-size: var(--overlayerQRLinkFontSize);
    line-height: : var(--overlayerQRLinkFontSize);
    font-weight: normal;
    padding: 0px;
    margin: 0px;
    color: var(--bmwi_white_100);
    cursor: default;
}

h4.overlayerMapLinkText {
    font-size: var(--overlayerMapLinkFontSize);
    line-height: : var(--overlayerMapLinkFontSize);
    font-weight: bold;
    padding: 0px;
    margin: 0px;
    color: var(--bmwi_white_100);
}

h4.overlayerMapLinkText:hover {
    cursor: pointer;
}

.overlayerInteractiveGraphic {
    width: 100%;
    height: 450px;
    position: absolute;
    top: var(--overlayerInteractiveGraphicMarginTop);
    left: 0px;
    padding: 0px;
    margin: 0px;
}

img.overlayerImageLeft {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

h2.overlayerHeadline {
    font-size: var(--chapterHeaderSize);
    line-height: var(--chapterHeaderLineHeight);
    font-weight: bold;
    padding: 0;
    margin-left: auto;
    margin-right: auto;
    margin-top: 0;
    margin-bottom: 0;
    text-align: center;
    color: var(--bmwi_white_100);
}

.overlayerTextBox {
    width: 100%;
    position: relative;
    padding: 0;
    margin: 0;
    margin-top: var(--overlayerTextBoxMarginTop);
}

h3.overlayerTextBoxText {
    font-size: var(--mainFontSize);
    line-height: var(--mainLineHeight);
    font-weight: normal;
    padding: 0;
    margin: 0;
    color: var(--bmwi_white_100);
}

.overlayerScrollIcon {
    width: calc(var(--scrollDownIconWidth) * 1.5);
    position: absolute;
    left: calc((var(--overlayerColumnWidth) / 2) - (var(--scrollDownIconWidth) * 0.75));
    padding: calc(var(--scrollDownIconWidth) * 0.25);
    margin: 0;
    z-index: 80;
    box-sizing: border-box;
}

.overlayerScrollIcon.top {
    top: calc(var(--spacerUnit) * -1.5);
}

.overlayerScrollIcon.bottom {
    bottom: calc(var(--spacerUnit) * -1.125);
}

.subsectionOverlayMediaSlider {
    width: 755px;
}

.subsectionOverlayMediaSlider.slider {
    --slider-margin-between-items: 25px;
    --slider-slide-width: 235px;
    --slider-slide-height: 129px;
    --slider-slide-background-color: rgba(0, 0, 0, 1);
    margin-top: 70px;
}

.subsectionOverlayMediaSlider.sliderDots {
    --slider-dot-color: var(--bmwi_white_100);
    margin-bottom: 25px;
}
