/* -----------------------------------------------------------
   Navigation overlay
----------------------------------------------------------- */


body.touch-mode-active .main-nav-column > ul > li.has-subnav-links > a {
    pointer-events: none;
}
body.nav-init {
    overflow: hidden;
}
.main-navigation-overlay,
.search-overlay {
    position: fixed;
    z-index: 100;
    top: 0px;
    right: 0;
    bottom: 0;
    width: 100%;
    display: none;
    overflow: hidden;
    display: none;
    opacity: 1;
    padding: 140px 60px 80px;
    box-sizing: border-box;
    transform-origin: top right;
    transition: opacity 0.5s ease;
    color: var(--foreground-color);
}
    .nav-init .main-navigation-overlay {
        opacity: 0;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .nav-init:not(.nav-overlay-open) .main-navigation-overlay {
        pointer-events: none;
    }
    .nav-init.nav-overlay-open .main-navigation-overlay {
        opacity: 1;
    }
    .nav-closing .main-navigation-overlay {
        opacity: 1;
    }
    
    
    /* 
        background
        ----------
    */
        .main-navigation-overlay::before,
        .search-overlay::before {
        content: '';
        position: absolute;
        top: 50%;
        right: 50%;
        transform: translate(5000px, -5000px);
        width: 10000px;
        height: 10000px;
        border-radius: 50%;
        transform-origin: top right;
        background-color: black;
        animation: nav-bg-animate-in 2.5s ease;
        z-index: -1;
        overflow: hidden;
    }
                .nav-closing .main-navigation-overlay::before,
                .search-closing .search-overlay::before {
            transform: scale(0);
            animation: nav-bg-animate-out 0.5s ease;
        }
        @keyframes nav-bg-animate-in {
            0% {
                transform: scale(0) translate(2500px, -2500px);
                top: 114px;
                right: 106px;
            }
            100% {
                transform: scale(1) translate(2500px, -2500px);
                top: 50%;
                right: 50%;
            }
        }
        @keyframes nav-bg-animate-out {
            0% {
                transform: scale(1) translate(2500px, -2500px);
                opacity: 1;
                top: 50%;
                right: 50%;
            }
            50% {
                opacity: 1;
            }
            100% {
                transform: scale(0) translate(2500px, -2500px);
                opacity: 0;
                top: 50px;
                right: 106px;
            }
        }
        @media (max-width: 1279px) {
            @keyframes nav-bg-animate-in {
                0% {
                    transform: scale(0) translate(2500px, -2500px);
                    top: 114px;
                    right: 70px;
                }
                100% {
                    transform: scale(1) translate(2500px, -2500px);
                    top: 50%;
                    right: 50%;
                }
            }
            @keyframes nav-bg-animate-out {
                0% {
                    transform: scale(1) translate(2500px, -2500px);
                    opacity: 1;
                    top: 50%;
                    right: 50%;
                }
                50% {
                    opacity: 1;
                }
                100% {
                    transform: scale(0) translate(2500px, -2500px);
                    opacity: 0;
                    top: 50px;
                    right: 70px;
                }
            }
        }
    
    /* 
        inner container
        ----------------
    */
    .main-navigation-overlay-inner {
        height: 100%;
        background: black;
        animation: nav-animate-in 1.5s ease;
    }
        .nav-init .main-navigation-overlay-inner {
            display: flex;
            justify-content: space-between;
            align-items: center;
            max-width: 1400px;
            margin: auto;
            max-height: 100%;
            height: auto;
        }
        .nav-closing .main-navigation-overlay-inner {
            opacity: 0;
            animation: nav-animate-out 0.2s ease;
        }
        
        @keyframes nav-animate-in {
            0% {
                opacity: 0;
            }
            30% {
                opacity: 0;
            }
            100% {
                opacity: 1;
            }
        }
        @keyframes nav-animate-out {
            from {
                opacity: 1;
            }
            to {
                opacity: 0;
            }
        }
    
    .main-navigation-overlay a, 
    .main-navigation-overlay a:visited, 
    .main-navigation-overlay a:hover, 
    .main-navigation-overlay .link_color, 
    .main-navigation-overlay .link_color:hover {
        color: var(--foreground-color);
    }
    
    
    /* 
        nav lists
        ---------
    */
    .main-navigation-overlay ul {
        margin: 0;
        padding: 0;
        list-style: none;
        
    }   
        
        .main-navigation-overlay ul li {
            width: 100%;
            display: block;
            overflow: hidden;
            padding: 0;
            margin: 0;
            margin-right: auto;
        }
            .main-navigation-overlay ul li a,
            .main-navigation-overlay ul li a:visited {
                display: inline-block;
                text-decoration: none;
                transition: transform 300ms cubic-bezier(.65,.06,.19,.96);
            }
        .main-nav-column > ul {
            display: flex;
            flex-direction: column;
        }
        .main-nav-column > ul > li {
            display: inline-block;
            width: auto;
        }
            
    /* 
        main nav column
        ----------------
    */
    .main-nav-column {
        flex-basis: 42%;
        width: 44vw;
    }
        .main-navigation-overlay.subnav-active .main-nav-column > ul > li:not(.active) {
            /* opacity: 0.75 !important; */
            /* animation: main-nav-active-animate-out 0.6s ease; */
        }
        .main-navigation-overlay.subnav-active .main-nav-column > ul > li.active {
            /* animation: main-nav-active-animate-in 0.6s ease; */
        }
        .main-nav-column li {
            /* font-size: 60px; */
            font-size: var(--step-4);
            letter-spacing: -1.25px;
            line-height: 1.1;
            margin-bottom: 20px !important;
        }
        .main-nav-column .menu-nested {
            display: none;
        }
        @keyframes main-nav-active-animate-in {
            from { opacity: 0.3; } to { opacity: 1; }
        }
        @keyframes main-nav-active-animate-out {
            from { opacity: 1; } to { opacity: 0.3; }
        }
        
        .main-nav-column li:not(.visible) {
            display: flex;
            opacity: 0;
        }
        .main-nav-column > ul > li.visible {
            transition: opacity .2s ease-out;
            animation: li-animate-in 2.5s ease;
        }
        @keyframes li-animate-in {
            from {
                transform: translateY(20px);
                opacity: 0;
            }
            to {
                transform: translateY(0);
                opacity: 1;
            }
        }

    /* 
        sub nav column
        ----------------
    */
    .sub-nav-column {
        flex-basis: 54%;
        width: 46vw;
        max-height: 100%;
        overflow: auto;
        animation: subnav-animate-in 1.5s ease;
    }
        .sub-nav-column li,
        .sub-nav-column li a,
        .sub-nav-column li a:visited,
        .sub-nav-column .member-login-link a {
            letter-spacing: -0.2px;
            /* line-height: 1.6em; */
            color: var(--foreground-color);
        }
        .sub-nav-column li.active a,
        .sub-nav-column li a:hover {
            color: var(--foreground-hover-color);
        }
        /* body.dark-theme-mode .sub-nav-column li,
        body.dark-theme-mode .sub-nav-column li a,
        body.dark-theme-mode .sub-nav-column li a:visited,
        body.dark-theme-mode .sub-nav-column .member-login-link a {
            color: #b7b5a9;
        } */
        /* body.dark-theme-mode .sub-nav-column i path {
            fill: #b7b5a9;
        } */
        /* body.dark-theme-mode .sub-nav-column li.active a,
        body.dark-theme-mode .sub-nav-column li a:hover {
            color: var(--foreground-hover);
        } */
        .sub-nav-column .menu-sub-item {
            font-size: var(--step-1);
            line-height: 2.2;
        }
        .sub-nav-column .default-navigation ul.topnav {
            columns: 2;
        }
        .sub-nav-column .default-navigation li {
            /* font-size: 22px; */
            font-size: var(--step-1);
        }
        @keyframes subnav-animate-in {
            from {
                transform: translateY(20px);
                opacity: 0;
            }
            to {
                transform: translateY(0);
                opacity: 1;
            }
        }
        
        /* 
            member login link
            -----------------
        */
        .sub-nav-column .member-login-link,
        .sub-nav-column .member-logout-link {
            padding-bottom: 10px;
            margin-bottom: 30px;
            position: relative;
        }
            .nav-overlay-open .sub-nav-column .member-login-link::after,
            .nav-overlay-open .sub-nav-column .member-logout-link::after {
                content: '';
                position: absolute;
                bottom: 0;
                width: 100%;
                height: 3px;
                display: block;
                background-color: var(--foreground-color);
                transform-origin: left;
                animation: member-login-btn-animate-in 4s cubic-bezier(.18, 1, .21, 1);
            }
            body.dark-theme-mode.nav-overlay-open .sub-nav-column .member-login-link::after, 
            body.dark-theme-mode.nav-overlay-open .sub-nav-column .member-logout-link::after {
                background-color: #b7b5a9;
            }
            @keyframes member-login-btn-animate-in {
                0% {
                    transform: scaleX(0);
                }
                100% {
                    transform: scaleX(1);
                    opacity: 1;
                }
            }
                .sub-nav-column .member-login-link a {
                    font-size: var(--step-1);
                    display: flex;
                    align-items: center;
                }
                .sub-nav-column .member-login-link a i,
                #top_nav_bar .member-login-link i,
                .sub-nav-column .member-logout-link a i,
                #top_nav_bar .member-logout-link i {
                    display: inline-block;
                    width: 24px;
                    height: 35px;
                    vertical-align: middle;
                    margin-left: 2px
                }
                .sub-nav-column .member-login-link span,
                 #top_nav_bar .member-login-link span,
                 .sub-nav-column .member-logout-link span,
                 #top_nav_bar .member-logout-link span {
                    display: inline-block;
                    vertical-align: middle;
                }
                .sub-nav-column .member-logout-link a i,
                .sub-nav-column .member-login-link a i {
                    margin-left: 7px;
                }                
                .sub-nav-column .member-logout-link a i svg *,
                .sub-nav-column .member-login-link a i svg * {
                    fill: var(--foreground-color);
                }
                
                
                
                /*.sub-nav-column .member-login-link a::after {*/
                /*    content: "\f090";*/
                    
                /*    margin-left: 12px;*/
                    
                /*    font: normal normal normal 14px/1 FontAwesome;*/
                /*    font-size: 22px;*/
                /*    font-weight: 400;*/
                /*    text-rendering: auto;*/
                /*    -webkit-font-smoothing: antialiased;*/
                /*    -moz-osx-font-smoothing: grayscale;*/
                /*}*/
        
        
        
        /* 
            sub nav in sub nav
            ------------------
        */
        .sub-nav-column .menu-sub-nav {
            position: relative;
            display: none;
            padding-left: 40px;
            opacity: 0;
            animation: menu-sub-nav-animate-in 0.6s ease-out;
        }
            .sub-nav-column .menu-sub-nav::before {
                content: '';
                position: absolute;
                display: block;
                width: 2px;
                height: 100%;
                left: 0;
                background-color: #999;
                animation: menu-sub-nav-line-animate-in 0.6s cubic-bezier(.18, 1, .21, 1);
            }
            body.dark-theme-mode .sub-nav-column .menu-sub-nav::before {
                background-color: #b7b5a9;
            }
            .sub-nav-column .menu-sub-nav.scrolls ul:not(.scrolled-to-bottom)::after {
                content: '\2193';
                background: linear-gradient(rgba(0,0,0,0) 0%, rgba(0,0,0,0.8) 40%, rgba(0,0,0,1) 100%);
                display: flex;
                position: absolute;
                width: 100%;
                height: 80px;
                bottom: 0;
                left: 0;
                align-items: flex-end;
                padding-left: 40px;
                padding-bottom: 10px;
                font-size: 25px;
                font-family: -apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji";
            }
            body.dark-theme-mode .sub-nav-column .menu-sub-nav.scrolls ul:not(.scrolled-to-bottom)::after {
                color: #b7b5a9;
            }
            .sub-nav-column .menu-sub-nav ul {
                overflow: auto;
            }
            .sub-nav-column div.active {
                display: block;
                opacity: 1;
            }
            @keyframes menu-sub-nav-animate-in {
                from { opacity: 0; } to { opacity: 1; }
            }
            @keyframes menu-sub-nav-line-animate-in {
                from { transform: scaleY(0); } to { transform: scaleY(1); }
            }
        
        /* 
            highlight links
            ---------------
        */
        .sub-nav-column .highlight-links {
            width: 100%;
            margin-top: 40px;
        }
            .sub-nav-column .highlight-links a {
                font-size: var(--step-2);
                padding-right: 70px;
                box-sizing: border-box;
                width: 50%;
            }
            .sub-nav-column .link-arrow {
                transform: scale(0.8);
                margin-bottom: 14px;
            }
            #mainNavigationOverlay .sub-nav-column .link-arrow::before,
            #mainNavigationOverlay .sub-nav-column .link-arrow::after {
                border-color: var(--foreground-color);
            }
    
    /* 
        main navigation
        ---------------
    */
    .main-navigation-overlay ul.main-navigation {
        transition: transform 600ms cubic-bezier(.65,.06,.19,.96), opacity 800ms ease-in-out;
        width: 100%;
        position: absolute;
        background: #fff;
        z-index: 1;
        top: 0;
        left: 0;
        max-height: 100%;
        overflow: auto;
        border-right: 1px solid #111;
        min-height: 100%;
    }
        .nav-init.nav-overlay-open.subnav-overlay-open .main-navigation-overlay ul.main-navigation {
            display: block;
        }
        .main-navigation-overlay ul.main-navigation li a {
            font-size: 2.2rem;
            line-height: 2.5rem;
        }
    
    /* 
        sub nav overlay
        ---------------
    */
    .sub-navigation-overlay {
        width: 100%;
        position: absolute;
        min-height: 100%;
        z-index: 2;
        max-height: 100%;
        background: #fff;
        overflow: auto;
        top: 0;
        left: 0;
        display: none;
        opacity: 1;
        transform: translateX(100%);
        transition: transform 600ms cubic-bezier(.65,.06,.19,.96), opacity 800ms ease-in-out;
    }
        .sub-navigation-overlay.active-init {
            display: block;
        }
        .sub-navigation-overlay.active-init.active {
            opacity: 1;
            transform: none;
        }
        .subnav-overlay-shortcut .sub-navigation-overlay {
            transition: none;
        }
    
    /* 
        powered by artlogic
        -------------------
    */
    .nav-artlogic-logo-container  {
        position: absolute;
        bottom: 30px;
        right: 50px;
    }
        .nav-artlogic-logo-container img {
            width: 110px;
        }


/* 
    header
    --------
*/
.nav-init .page-top #header {
    transform: translate3d(0px, -34px, 0px);
}

body.nav-init.nav-overlay-open:not(.dark-theme-mode) #main_header,
body.nav-init.nav-overlay-open:not(.dark-theme-mode) #main_header a,
body.nav-init.nav-overlay-open:not(.dark-theme-mode) #main_header button {
    /* transition: color 0.5s ease; */
    /* color: var(--foreground-color); */
}
.nav-init.nav-closing #main_header,
.nav-init.nav-closing #main_header a,
.nav-init.nav-closing #main_header button {
    /* transition: color 0.5s ease !important; */
    /*color: black;*/
}

    /* 
        menu btn
        --------
    */
    .overlay-init.overlay-open #menu button,
    .overlay-init.overlay-closing #menu button,
    .nav-init.nav-overlay-open #menu button,
    .nav-init.nav-closing #menu button{
        text-indent: 100%;
        position: relative;
        overflow: hidden;
    }
        .overlay-init.overlay-open #menu button::after,
        .nav-init.nav-overlay-open #menu button::after {
            content: 'Close';
            text-indent: 0;
            position: absolute;
            top: 0;
            left: 0;
            animation: close-btn-animate-in 0.5s ease;
        }
        .overlay-init.overlay-closing #menu button::after,
        .nav-init.nav-closing #menu button::after {
            content: 'Menu';
            text-indent: 0;
            position: absolute;
            top: 0;
            left: 0;
            animation: close-btn-animate-out 0.5s ease;
        }
        
        @keyframes close-btn-animate-in {
            from {
                transform: translateX(100%);
            }
            to {
                transform: translateX(0);
            }
        }
        @keyframes close-btn-animate-out {
            from {
                transform: translateX(-100%);
            }
            to {
                transform: translateX(0);
            }
        }



@media screen and (max-width: 1100px) {
    .main-navigation-overlay {
        padding-left: 40px;
        padding-right: 40px;
    }
    .main-nav-column {
        width: 47vw;
    }
}

@media screen and (max-width: 1023px) {
    
    .nav-init .main-navigation-overlay-inner {
        flex-direction: column;
        overflow: auto;
        padding-top: 20px;
        width: 100%;
        height: auto;
    }
    
    
    .main-nav-column,
    .sub-nav-column {
        width: 100% !important;
        margin-bottom: 60px;
    }
    
        .main-nav-column .menu-item.active .menu-nested {
            display: block;
            margin-top: 20px;
            animation: menu-nested-animate-in 1.5s ease;
            
        }
        .main-nav-column li {
            font-size: var(--step-3);
        }
        .main-nav-column li:hover {
            opacity: 1;
        }
        .main-nav-column .menu-sub-item {
            font-size: var(--step-2);
            line-height: 1.3;
            margin-bottom: 10px !important;
            letter-spacing: 0;
        }
        
    
    .sub-nav-column {
        margin-bottom: 60px;
        max-height: none;
        overflow: visible;
    }
        .sub-nav-column .menu-sub-nav {
            display: none !important;
        }
        .sub-nav-column .default-navigation ul.topnav {
            columns: 1;
        }
        .sub-nav-column .default-navigation li {
            line-height: 2em;
        }
        .sub-nav-column .default-navigation li:nth-child(n+7) {
            /*display: none;*/
        }
        .sub-nav-column .default-navigation .topnav::after {
            /*content: "...";*/
        }
        .sub-nav-column .highlight-links {
            /* flex-direction: column; */
        }
        .sub-nav-column .highlight-links a {
            /* font-size: 22px; */
            /* line-height: 1.3em; */
            margin-bottom: 20px;
        }
        .sub-nav-column .link-arrow {
            transform: scale(0.5);
            transform-origin: center left;
        }
}

@keyframes menu-nested-animate-in {
    from {
        max-height: 0px;
    }
    to {
        max-height: 100vh;
    }
}



.highlight-links {
    display: block;
    overflow: hidden;
}
    .highlight-links a {
        font-size: 42px;
        line-height: 1em;
    }
    .link-arrow::before {
        top: -4px;
        left: 0px;
        right: auto;
        bottom: auto;
        width: 60px;
        transform: rotate(45deg) scaleX(1);
        transform-origin: top left;
    }
    .ani-group.visible .link-arrow::before,
    #mainNavigationOverlay .link-arrow::before  {
        animation: link-arrow-animate-in 1.5s ease-in-out;
    }
    
    
    /*.link-arrow::after {*/
    /*    opacity: 1;*/
    /*    transform-origin: bottom right;*/
    /*    animation: link-arrow-2-animate-in 2s ease-in-out;*/
    /*}*/
    
    .ani-group.visible .link-arrow::after,
    #mainNavigationOverlay .link-arrow::after {
        opacity: 1;
        transform-origin: bottom right;
        animation: link-arrow-2-animate-in 2s ease-in-out;
    }
    
    
    @keyframes link-arrow-animate-in {
        0% { opacity: 0; transform: rotate(45deg) scaleX(0.5); } 50% { opacity: 0; transform: rotate(45deg) scaleX(0.5); } 70% { opacity: 1; } to { transform: rotate(45deg) scaleX(1); }
    }
    @keyframes link-arrow-2-animate-in {
        0% { opacity: 0; } 66% { opacity: 0; transform: scale(0.5); } to { opacity: 1; transform: scale(1); }
    }
    
  

    @media screen and (max-width: 459px) {
        .main-nav-column .menu-sub-item {
            font-size: var(--step-1)
        }
    }