/**
 * ANCHOR Customising
 *
 */
body {
    font-size: 1.1rem;
}

h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4 {
    font-family: 'Amaranth', system-ui, sans-serif;
    font-style: normal;
    font-weight: 400;
    color: var(--clx-color-primary);
}

h1,
.h1 {
    font-size: 3rem;
}

h2,
.h2 {
    font-size: 2.5rem;
}

h3,
.h3 {
    font-size: 1.9rem;
}

h4,
.h4 {
    font-size: 1.6rem;
}

h5,
.h5 {
    font-size: 1.3rem;
}

h6,
.h6 {
    font-size: 1.1rem;
    font-weight: 600;
}

p {
    line-height: 1.3;
    -webkit-hyphens: auto;
    -moz-hyphens: auto;
    hyphens: auto;
}

strong {
    font-weight: var(--clx-font-bolder);
}

header {
    background-color: transparent;
    transition: all 0.5s ease;

    &.view {
        background-color: #165F77;
    }

    & .logo {
        max-width: 220px;
    }

    & .logo-main {
        display: none;

        &.view {
            display: inline-block;
        }
    }
}

main {

    & section {
        background-color: var(--clx-color-tertiary);

        & .clx-wrapper {
            & img {
                max-width: 100%;
            }
        }
    }

    &.home,
    &.erlebniszauber {
        & .clx-fullscreen {
            height: fit-content;
            overflow: inherit;

            & .clx-fullscreen-image {
                height: 90dvh;
            }

            & .clx-fullscreen-content {
                position: inherit;
                margin-top: 65dvh;
                background: linear-gradient(to bottom, transparent 0, transparent 20dvh, var(--clx-color-tertiary) 20dvh, var(--clx-color-tertiary) 100%);

                & .clx-subgrid {
                    background-color: var(--clx-color-secondary);
                    outline: 3px solid var(--clx-color-secondary);
                    outline-offset: 2px;

                    & div {
                        padding-bottom: 20px;
                    }

                    & h2 {
                        position: relative;

                        &::before {
                            position: absolute;
                            box-sizing: border-box;
                            content: "";
                            display: block;
                            bottom: 12px;
                            left: 50%;
                            width: 18px;
                            height: 18px;
                            border-radius: 50%;
                            border: solid 4px var(--clx-color-secondary);
                            background-color: var(--clx-color-primary);
                            transform: translateX(-50%);
                        }

                        &::after {
                            content: "";
                            display: block;
                            width: 140px;
                            height: 2px;
                            background-color: var(--clx-color-primary);
                            margin: 25px auto 20px;
                        }
                    }
                }
            }
        }

        & .clx-fullscreen-logo {
            position: absolute;
            display: flex;
            justify-content: center;
            align-items: center;
            top: 0;
            width: 100%;
            height: 55dvh;

            & img {
                display: inline-block;
                width: 500px;
                max-width: 70dvw;
            }
        }
    }

    &.erlebniszauber {
        & .clx-fullscreen {

            & .clx-fullscreen-image {
                height: 100dvh;
            }

            & .clx-fullscreen-content {
                min-height: 50dvh;
                margin-top: 50dvh;
                background: transparent;

                & .clx-subgrid {
                    background-color: #ccb9a2;
                    outline: 3px solid #ccb9a2;
                    outline-offset: 2px;

                    & h2 {
                        &::before {
                            border-color: #ccb9a2;
                        }
                    }
                }


            }
        }
    }

    &.content {
        & .clx-fullscreen {
            height: 70dvh;
        }
    }

    & .clx-fullscreen {
        & .clx-fullscreen-image::after {
            position: fixed;
            display: block;
            content: '';
            top: 0;
            width: 100%;
            height: 35dvh;
            background: linear-gradient(to bottom, rgba(0, 0, 0, 0.35) 0, transparent 100%);
        }
    }
}

footer {
    position: relative;

    &>* {
        color: var(--clx-color-white);
    }

    & .logo {
        max-width: 200px;
    }
}

.clx-navigation ul ul {
    margin-left: -5px;
    padding-left: 5px;
    padding-right: 5px;
}


/**
 * ANCHOR Media Queries
 *
 */
@media (max-width: 960px) {

    .clx-navigation {
        display: none;
    }

    .clx-navigation-burger {
        display: block;
    }

    h1,
    .h1,
    h2,
    .h2,
    h3,
    .h3,
    h4,
    .h4 {
        hyphens: auto;
    }
}

@media (max-width: 640px) {

    header {

        & .clx-grid {
            flex-wrap: nowrap;
            justify-content: space-between;
            align-items: center;

            & .clx-width-1-4,
            & .clx-width-3-4 {
                width: auto;
            }
        }

        & .logo {
            width: 280px;
            max-width: 45dvw;
        }
    }

    .clx-fullscreen-content {

        & .clx-maingrid {
            grid-template-columns: 1fr;

            &.clx-padding-xxsmall {
                padding: 0;
            }

            & .clx-subgrid {
                &.clx-padding-large {
                    padding: 20px;
                }
            }
        }
    }

    h1,
    .h1 {
        font-size: 2.0rem;
    }

    h2,
    .h2 {
        font-size: 1.75rem;
    }

    h3,
    .h3 {
        font-size: 1.5rem;
    }

    h4,
    .h4 {
        font-size: 1.25rem;
    }

    h5,
    .h5 {
        font-size: 1.1rem;
    }

}

@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: #165F77;
    --clx-color-secondary: #CACD86;
    --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: #E1E2B9;


    /* 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-secondary);
    --clx-nav-a-weight: 400;
    --clx-nav-a-size: 18px;
    --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-secondary);
    --clx-card-aspect-ratio: 16 / 10;

    /* 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: var(--clx-color-primary);
    --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: 1180px;
    --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: 'Figtree', 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: 300;
    --clx-font-normal: 400;
    --clx-font-bold: 500;
    --clx-font-bolder: 600;
    --clx-font-color: var(--clx-color);
    --clx-line-height: 1;

}


/**
 * ANCHOR @fonts
 *
 */
@font-face {
    font-family: 'Amaranth';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('../fonts/Amaranth/Amaranth-Regular.ttf') format('truetype');
}

@font-face {
    font-family: 'Figtree';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('../fonts/Figtree/Figtree-Regular.ttf') format('truetype');
}

@font-face {
    font-family: 'Figtree';
    font-style: italic;
    font-weight: 400;
    font-display: swap;
    src: url('../fonts/Figtree/Figtree-Italic.ttf') format('truetype');
}

@font-face {
    font-family: 'Figtree';
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url('../fonts/Figtree/Figtree-Medium.ttf') format('truetype');
}

@font-face {
    font-family: 'Figtree';
    font-style: italic;
    font-weight: 500;
    font-display: swap;
    src: url('../fonts/Figtree/Figtree-MediumItalic.ttf') format('truetype');
}

@font-face {
    font-family: 'Figtree';
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url('../fonts/Figtree/Figtree-SemiBold.ttf') format('truetype');
}

@font-face {
    font-family: 'Figtree';
    font-style: italic;
    font-weight: 600;
    font-display: swap;
    src: url('../fonts/Figtree/Figtree-SemiBoldItalic.ttf') format('truetype');
}