/**
 * ANCHOR Customising
 *
 */
body {
    font-size: 1.25rem;
}

h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4 {
    color: var(--clx-color-primary);
}

h2,
.h2 {
    font-size: 1.2em;
}

.main-image {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: transparent url(../images/placeholder.jpg) center no-repeat;
    background-size: cover;
    z-index: -1;
}

.backdrop-filter {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    backdrop-filter: blur(4px);
    z-index: -1;
}

.content-button {
    position: fixed;
    top: 0;
    right: 0;
    width: 60px;
    height: 60px;
    padding: 0;
    background-color: var(--clx-color-secondary);
    cursor: pointer;

    &::before,
    &::after {
        display: block;
        position: relative;
        content: '';
        width: 28px;
        height: 2px;
        top: 29px;
        left: 16px;
        background-color: var(--clx-color-white);
        transition-duration: 0.5s;
    }

    &::after {
        width: 2px;
        height: 28px;
        top: 14px;
        left: 29px;
    }

    &:hover,
    &.highlight {

        background-color: var(--clx-color-primary);
    }

    &.highlight {

        &::before,
        &::after {
            transform: rotate(225deg);
        }
    }
}

.label {
    position: fixed;
    bottom: 30px;
    right: 40px;
    width: fit-content;
    height: fit-content;
    padding: 0;

    & p,
    & a,
    & img {
        display: block;
        padding: 0;
        margin: 0;
    }
}

header {
    width: 320px;
    background: transparent;
    display: grid;
    max-width: 100%;

    & .logo {
        margin-bottom: 15px;
        max-width: 100%;
        background-color: var(--clx-color-primary);

        & img {
            display: flex;
            max-width: 100%;
        }
    }

    & .clx-navigation-skyscraper {
        margin: 0;
        width: 100%;

        & ul {
            display: grid;
            grid-template-columns: 1fr;
            gap: 15px;
            margin: 0;

            & li {
                margin: 0;

                a {
                    text-transform: uppercase;
                    box-sizing: border-box;
                    padding: 12px 20px 12px 85px;
                    background: var(--clx-color-secondary) url(../images/icon_navigation2.png) 18px -20px no-repeat;
                    background-size: 52px auto;

                    &:hover,
                    &.starter_active {
                        background-color: var(--clx-color-primary);
                    }
                }

                &.proposal a {
                    background-position-y: -106px;
                }

                &.team a {
                    background-position-y: -280px;
                }

                &.jobs a {
                    background-position-y: -538px;
                }

                &.practice a {
                    background-position-y: -452px;
                }

                &.emergency a {
                    background-position-y: -193px;
                }

                &.contact a {
                    background-position-y: -367px;
                }
            }
        }
    }

    & .contactdetail {
        padding: 0 0 5px 85px;
        background-color: var(--clx-color-secondary);
        color: var(--clx-color-white);
        font-size: 0.85em;
    }

    & .imprint {
        margin-top: 15px;
        padding: 12px 30px 0 20px;
        text-align: right;
        background-color: var(--clx-color-secondary);
        color: var(--clx-color-white);
        font-size: 0.85em;

        & a {
            color: var(--clx-color-white);

            &:hover {
                color: var(--clx-color-primary);
            }
        }
    }

    & .navigation-burger {
        display: none;
        position: fixed;
        top: 10px;
        right: 20px;
        padding: 0;
        background-color: var(--clx-color-primary);
        cursor: pointer;


        & .clx-navigation-burger {
            display: block;
        }
    }
}

main {
    box-sizing: border-box;
    height: fit-content;
    padding-top: 135px;
    padding-bottom: 60px;

    &.home {


        & .clx-container,
        & .clx-wrapper {
            margin-left: 350px;

            & h1 {
                max-width: 400px;
                margin-top: 0;
                font-size: 3.5em;
                line-height: 1.1;
                color: var(--clx-color-white);
                text-shadow: 2px 2px 6px rgba(0, 0, 0, 0.75);
            }

        }
    }

    &.content {

        & .clx-container,
        & .clx-wrapper {
            margin-left: 350px;
            background-color: #fff;
        }
    }

    & .oeffnungszeiten mark {
        background-color: transparent;
        color: initial;
        display: inline-block;
        width: 40px;
    }
}


/**
 * ANCHOR Media Queries
 *
 */
@media (max-width: 1100px) {

    h1,
    .h1,
    h2,
    .h2,
    h3,
    .h3,
    h4,
    .h4 {
        hyphens: auto;
    }

    h1,
    .h1 {
        font-size: 1.6em;
    }


    #navigation,
    #contact,
    #imprint,
    #contentButton,
    #label {
        display: none;
    }


    header {
        width: 100dvw;

        & .logo {

            & img {
                width: 200px;
                max-width: 50dvw;
                margin-left: 15px;
            }
        }

        & .navigation-burger {
            display: block;
        }
    }

    main {
        padding-top: 50px;
        padding-bottom: 0;

        &.home,
        &.content {

            & .clx-container,
            & .clx-wrapper {
                margin-left: auto;
                margin-right: auto;
            }
        }

        &.home {
            & .clx-wrapper {
                padding-top: 100px;

                & h1 {
                    max-width: 250px;
                    font-size: 2.1em;
                    hyphens: none;
                }
            }
        }
    }


}

@media only screen and (orientation: portrait) {}

@media print {

    p {
        font-size: 12px;
    }

    nav {
        display: none !important;
    }

    .clx-container {
        padding-left: 0;
        padding-right: 0;
    }

}

:root {

    interpolate-size: allow-keywords;

    /* Color */
    --clx-color-black: #000000;
    --clx-color-white: #ffffff;
    --clx-color-darkwhite: #F9F9F9;

    --clx-color: #000000;
    --clx-color-muted: #F2F2F2;
    --clx-color-primary: #005BBB;
    --clx-color-secondary: #89BA27;
    --clx-color-tertiary: #EAEBCF;

    --clx-color-success: #2e8d00;
    --clx-color-warning: #faa05a;
    --clx-color-danger: #d20000;
    --clx-color-header: var(--clx-color-primary);
    --clx-color-footer: var(--clx-color-primary);
    --clx-color-primary-rev: var(--clx-color-white);
    --clx-color-secondary-rev: var(--clx-color-white);
    --clx-section-light: var(--clx-color-tertiary);
    --clx-section-dark: var(--clx-color-tertiary);


    /* Navigation */
    --clx-nav-float: right;
    --clx-nav-ul-ul-height: 50rem;
    --clx-nav-ul-ul-bgcolor: var(--clx-color-primary);
    --clx-nav-color-burger: var(--clx-color-white);
    --clx-nav-color-a: var(--clx-color-white);
    --clx-nav-color-a-hover: var(--clx-color-white);
    --clx-nav-a-weight: 400;
    --clx-nav-a-size: 23px;
    --clx-nav-a-a-weight: 400;
    --clx-nav-a-a-size: 16px;
    --clx-nav-margin-correction-right: 15px;
    --clx-nav-padding-top: 5px;
    --clx-nav-padding-bottom: 5px;
    --clx-nav-padding-left: 15px;
    --clx-nav-padding-right: 15px;
    --clx-nav-padding-first-child: 5px;
    --clx-nav-padding-last-child: 10px;
    --clx-nav-margin-top: 2px;
    --clx-nav-margin-bottom: 2px;
    --clx-nav-margin-left: 0;
    --clx-nav-margin-right: 0;
    --clx-nav-lang-padding-left: 15px;
    --clx-nav-lang-padding-right: 15px;
    --clx-nav-burger-margin-top: 0;
    --clx-nav-burger-margin-bottom: 0;
    --clx-nav-burger-padding-top: 10px;
    --clx-nav-burger-padding-bottom: 10px;
    --clx-nav-burger-padding-right: 40px;
    --clx-nav-burger-padding-left: 0;
    --clx-nav-mobile-bgcolor: var(--clx-color-primary);
    --clx-nav-mobile-padding-top: 100px;
    --clx-nav-mobile-padding-horizontal: 10px;
    --clx-nav-mobile-padding-vertical: 5px;
    --clx-nav-mobile-sub-padding: 20px;
    --clx-nav-mobile-font-size: larger;
    --clx-nav-mobile-color-a: var(--clx-color-white);
    --clx-nav-mobile-color-a-hover: var(--clx-color-secondary);
    --clx-nav-mobile-a-weight: 400;
    --clx-nav-mobile-a-size: 20px;
    --clx-nav-mobile-a-a-weight: 400;
    --clx-nav-mobile-a-a-size: 17px;

    /* to down */
    --clx-todown-color: var(--clx-color-black);

    /* to top */
    --clx-totop-color: var(--clx-color-primary);
    --clx-totop-arrow-color: var(--clx-color-white);

    /* Text */
    --clx-color-title: var(--clx-color-black);
    --clx-color-a: var(--clx-color-primary);
    --clx-color-a-hover: var(--clx-color-secondary);
    --clx-decoration-a: none;
    --clx-decoration-a-hover: none;
    --clx-button-color: var(--clx-color-black);
    --clx-button-color-hover: var(--clx-color-primary);
    --clx-button-bg-primary: var(--clx-color-primary);
    --clx-button-bg-primary-hover: var(--clx-color-black);
    --clx-button-color-primary: var(--clx-color-white);
    --clx-button-color-primary-hover: var(--clx-color-white);

    --clx-button-bg-secondary: var(--clx-color-secondary);
    --clx-button-bg-secondary-hover: var(--clx-color-black);
    --clx-button-color-secondary: var(--clx-color-white);
    --clx-button-color-secondary-hover: var(--clx-color-white);
    --clx-button-bg-muted: var(--clx-color-muted);
    --clx-button-bg-muted-hover: var(--clx-color-black);
    --clx-button-color-muted: var(--clx-color-white);
    --clx-button-color-muted-hover: var(--clx-color-white);

    /* Table */
    --clx-color-hover: #ffffdd;
    --clx-color-divider: var(--clx-color-muted);
    --clx-color-striped: var(--clx-color-darkwhite);

    /* Shadow */
    --clx-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px;

    /* Radius */
    --clx-radius: 4px;

    /* Background Color */
    --clx-card-color: var(--clx-color-darkwhite);
    --clx-card-aspect-ratio: 8 / 6;

    /* Border/Form */
    --clx-border-color: #B5B5B5;
    --clx-border-color-focus: var(--clx-color-black);
    --clx-border-style: solid;
    --clx-border-width: 1px;
    --clx-border-radius: 6px;
    --clx-input-height: 50px;
    --clx-textarea-height: 120px;
    --clx-input-bg-color: var(--clx-color-white);
    --clx-placeholder-color: #B5B5B5;
    --clx-submit-bg-color: #666666;
    --clx-submit-bg-hover-color: var(--clx-color-black);
    --clx-submit-color: var(--clx-color-white);
    --clx-submit-hover-color: var(--clx-color-white);

    /* Picture Gallery counter */
    --clx-picture-gallery-font-size: 40px;
    --clx-picture-gallery-font-weight: 400;

    /* Grid */
    --clx-grid-gap: 30px;
    --clx-grid-bottom: var(--clx-grid-gap);


    /* Distance */
    --clx-container-width-max: 1780px;
    --clx-container-width: 660px;
    --clx-indented-width: 578px;
    --clx-distance-xxsmall: 5px;
    --clx-distance-xsmall: 10px;
    --clx-distance-small: 20px;
    --clx-distance-medium: 30px;
    --clx-distance-large: 45px;
    --clx-distance-xlarge: 60px;
    --clx-distance-xxlarge: 80px;
    --clx-distance-xxxlarge: 100px;

    /* Font */
    --clx-font-family: 'Source Sans 3', system-ui, sans-serif;
    --clx-font-size-small: calc(.8rem + .2vw);
    --clx-font-size-micro: calc(.6rem + .2vw);
    --clx-font-size: calc(1rem + .2vw);
    --clx-font-size-medium: calc(1.1rem + .2vw);
    --clx-font-size-large: calc(1.4rem + .2vw);

    --clx-font-light: 400;
    --clx-font-normal: 400;
    --clx-font-bold: 600;
    --clx-font-bolder: 600;
    --clx-font-color: var(--clx-color);
    --clx-line-height: 1;

}


/**
 * ANCHOR @fonts
 *
 */
@font-face {
    font-family: 'Source Sans 3';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('../fonts/Source_Sans_3/SourceSans3-Regular.ttf') format('truetype');
}

@font-face {
    font-family: 'Source Sans 3';
    font-style: italic;
    font-weight: 400;
    font-display: swap;
    src: url('../fonts/Source_Sans_3/SourceSans3-Italic.ttf') format('truetype');
}

@font-face {
    font-family: 'Source Sans 3';
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url('../fonts/Source_Sans_3/SourceSans3-SemiBold.ttf') format('truetype');
}

@font-face {
    font-family: 'Source Sans 3';
    font-style: italic;
    font-weight: 600;
    font-display: swap;
    src: url('../fonts/Source_Sans_3/SourceSans3-SemiBoldItalic.ttf') format('truetype');
}