:root {
    --color-fg: var(--lime);
    --color-bg: var(--rose);
    --color-text-dark: var(--black);
    --color-text-light: var(--white);
}

body {
    background-color: var(--color-bg);
}

@media (max-width: 991px) {
    .angebote-top {
        background-color: var(--color-bg);
        height: 705px;
        width: 100vw;
    }

    .angebote-bottom {
        background-color: var(--color-bg);
        width: 100vw;
        margin-top: 85px;
        margin-bottom: 50px;
    }

    .angebote-container {
        position: relative;
        width: 100vw;
    }


    .angebote-title-top {
        position: absolute;
        top: 85px;
        left: calc(50vw - 70px);
        z-index: 4;
        text-align: start;
        color: var(--color-text-dark);
        font-family: "Roboto", sans-serif;
        font-size: 58px;
        font-weight: 500;
        letter-spacing: 26.1px;

        transform-origin: top left;
        transform: rotate(90deg);
        /* Safari */
        -webkit-transform: rotate(90deg);
        /* Firefox */
        -moz-transform: rotate(90deg);
        /* IE */
        -ms-transform: rotate(90deg);
        /* Opera */
        -o-transform: rotate(90deg);
        /* Internet Explorer */
        filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=1);

    }

    .angebote-text-top {
        position: absolute;
        top: 210px;
        left: calc(50vw - 10px);
        z-index: 3;

        width: auto;

        font-family: "Roboto", sans-serif;
        color: var(--color-text-dark);
        font-size: 17px;
        font-weight: 400;
        line-height: 39px;
        letter-spacing: 2.55px;
        padding: 0px;
    }

    .angebote-background-left {
        position: absolute;
        top: 110px;
        left: 4.3vw;
        z-index: 1;

        background: var(--color-fg);
        width: calc(50vw + 100px);
        height: 342px;
    }

    .angebote-background-right {
        position: absolute;
        top: 190px;
        right: 4.3vw;
        z-index: 2;

        background: var(--white);
        width: calc(50vw + 100px);
        height: 455px;
    }

    .angebote-background-bottom-left {
        position: absolute;
        top: 1670px;
        left: 0px;
        z-index: 2;

        background: var(--color-fg);
        width: 373px;
        height: 351px;
    }

    .angebote-background-bottom-right {
        position: absolute;
        top: 870px;
        left: calc(50vw - 150px);
        right: 0px;
        z-index: 2;

        background: var(--color-fg);
        max-width: 425px;
        height: 692px;
    }

    .card-angebote {
        margin-bottom: 50px;
        z-index: 3;
    }

    .card-angebote-body {
        background-color: var(--white);
        width: 90vw;
        max-width: 425px;
        text-decoration: none;
        color: var(--color-text-dark)
    }

    .card-angebote-body:link {
        color: var(--color-text-dark);
        background-color: var(--white);
    }

    .card-angebote-body:visited {
        color: var(--color-text-dark);
        background-color: var(--white);
    }

    .card-angebote-body:hover {
        color: var(--color-text-dark);
        background-color: #F6F6F6;
    }

    .card-angebote-body:active {
        color: var(--color-text-dark);
        background-color: #F0F0F0;
    }

    .card-angebote-title {
        padding-top: 20px;
        padding-left: 20px;

        font-family: "Roboto", sans-serif;
        font-size: 20px;
        font-weight: 400;
        letter-spacing: 3px;
    }

    .card-angebote-img {
        margin-top: 20px;
        margin-bottom: 20px;
        max-width: 347px;
        width: 90vw;
    }

    .card-angebote-text {
        padding-top: 20px;
        padding-left: 20px;
        padding-right: 20px;

        font-family: "Roboto", sans-serif;
        font-size: 16px;
        font-weight: 400;
        letter-spacing: 2.4px;
        line-height: 28.8px;
    }

    .card-angebote-line {
        display: block;
        margin-top: 0px;
        margin-left: 20px;
        margin-right: 20px;
        border-bottom: var(--black) solid 1px;
    }

    .card-angebote-button {
        all: unset;
        width: 140px;
        height: 38px;

        margin-bottom: 20px;


        line-height: 38px;
        text-align: center;
        font-family: "Roboto", sans-serif;
        font-size: 15px;
        font-weight: 400;
        letter-spacing: 0.75px;

        background-color: var(--black);
        color: var(--white);
    }

    .card-angebote-body:hover .card-angebote-button {
        background-color: var(--white);
        color: var(--black);
        transition: background-color 0.2s ease;
    }

    .card-angebote-body:active .card-angebote-button {
        background-color: var(--white);
        color: var(--black);
        transition: background-color 0.2s ease;
    }
}

/* Large devices (desktops, 992px and up)*/
@media (min-width: 992px) {
    .navbar-link {
        color: var(--color-text-dark);
    }

    .navbar-link:link {
        color: var(--color-text-dark);
    }

    .navbar-link:visited {
        color: var(--color-text-dark);
    }

    .navbar-link:hover {
        color: #666666;
    }

    .navbar-link:active {
        color: #666666;
    }

    .footer-link {
        color: var(--color-text-dark);
    }

    .footer-link:link {
        color: var(--color-text-dark);
    }

    .footer-link:visited {
        color: var(--color-text-dark);
    }

    .footer-link:hover {
        color: #666666;
    }

    .footer-link:active {
        color: #666666;
    }

    .angebote-top {
        background-color: var(--color-bg);
        height: 705px;
    }

    .angebote-bottom {
        background-color: var(--color-bg);
        width: 980px;
        margin-top: 85px;
        margin-bottom: 50px;
    }

    .angebote-container {
        position: relative;
        width: 980px;
    }


    .angebote-title-top {
        position: absolute;
        top: 85px;
        left: 420px;
        z-index: 4;

        color: var(--color-text-dark);
        font-family: "Roboto", sans-serif;
        font-size: 58px;
        font-weight: 500;
        letter-spacing: 26.1px;

        transform-origin: top left;
        transform: rotate(90deg);
        /* Safari */
        -webkit-transform: rotate(90deg);
        /* Firefox */
        -moz-transform: rotate(90deg);
        /* IE */
        -ms-transform: rotate(90deg);
        /* Opera */
        -o-transform: rotate(90deg);
        /* Internet Explorer */
        filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=1);
    }

    .angebote-text-top {
        position: absolute;
        top: 210px;
        left: 480px;
        z-index: 3;

        width: 250px;

        font-family: "Roboto", sans-serif;
        color: var(--color-text-dark);
        font-size: 17px;
        font-weight: 400;
        line-height: 39px;
        letter-spacing: 2.55px;
        padding: 0px;
    }

    .angebote-background-left {
        position: absolute;
        top: 110px;
        right: 330px;
        z-index: 1;

        background: var(--color-fg);
        width: calc((100vw - 980px)/2 + 600px);
        height: 342px;
    }

    .angebote-background-right {
        position: absolute;
        top: 190px;
        left: 330px;
        z-index: 2;

        background: var(--white);
        width: calc((100vw - 980px)/2 + 600px);
        height: 455px;
    }

    .angebote-background-bottom-left {
        position: absolute;
        top: 1670px;
        left: -194px;
        z-index: 2;

        background: var(--color-fg);
        width: 373px;
        height: 351px;
    }

    .angebote-background-bottom-right {
        position: absolute;
        top: 870px;
        left: 330px;
        z-index: 2;

        background: var(--color-fg);
        width: 723px;
        height: 692px;
    }

    .card-angebote {
        margin-bottom: 50px;
        z-index: 3;
    }

    .card-angebote-body {
        background-color: var(--white);
        width: 425px;
        display: flex;
        flex-direction: column;
        text-decoration: none;
        color: var(--color-text-dark)
    }

    .card-angebote-body:link {
        color: var(--color-text-dark);
        background-color: var(--white);
    }

    .card-angebote-body:visited {
        color: var(--color-text-dark);
        background-color: var(--white);
    }

    .card-angebote-body:hover {
        color: var(--color-text-dark);
        background-color: #F6F6F6;
    }

    .card-angebote-body:active {
        color: var(--color-text-dark);
        background-color: #F0F0F0;
    }

    .card-angebote-title {
        padding-top: 20px;
        padding-left: 20px;

        font-family: "Roboto", sans-serif;
        font-size: 20px;
        font-weight: 400;
        letter-spacing: 3px;
    }

    .card-angebote-img {
        margin-top: 20px;
        margin-bottom: 20px;
        width: 347px;
    }

    .card-angebote-text {
        padding-top: 20px;
        padding-left: 20px;
        padding-right: 20px;

        font-family: "Roboto", sans-serif;
        font-size: 16px;
        font-weight: 400;
        letter-spacing: 2.4px;
        line-height: 28.8px;
    }

    .card-angebote-line {
        display: block;
        margin-top: 0px;
        margin-left: 20px;
        margin-right: 20px;
        border-bottom: var(--black) solid 1px;
    }

    .card-angebote-button {
        all: unset;
        width: 140px;
        height: 38px;

        margin-bottom: 20px;

        line-height: 38px;
        text-align: center;
        font-family: "Roboto", sans-serif;
        font-size: 15px;
        font-weight: 400;
        letter-spacing: 0.75px;

        background-color: var(--black);
        color: var(--white);
    }

    .card-angebote-body:hover .card-angebote-button {
        background-color: var(--white);
        color: var(--black);
        transition: background-color 0.2s ease;
    }

    .card-angebote-body:active .card-angebote-button {
        background-color: var(--white);
        color: var(--black);
        transition: background-color 0.2s ease;
    }
}