/* Drawers */

.drawer {
    position: fixed;
    z-index: 7;
    top: 0;
    padding: 132px 40px 60px;
    background: #fff;
    opacity: 0;

    /* Put into .scroller
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    */

    overflow: hidden;

    /*
    left: 0;
    width: 100%;
    transform: translateY(-100%);
    */
    left: auto;
    right: 0;

    width: 360px;

    /*
    height: 100%;
    max-height: 100%;*/
    height: 100%;
    max-height: 100vh;
    min-height: -webkit-fill-available;
    max-height: -webkit-fill-available;

    transform: translate(360px, 0);

    -webkit-box-shadow: 0 40px 40px 0px rgba(0, 0, 0, 0);
    -moz-box-shadow: 0 40px 40px 0px rgba(0, 0, 0, 0);
    box-shadow: 0 40px 40px 0px rgba(0, 0, 0, 0);
}

.site-header.collapsed ~ footer .drawer {
    padding: 102px 40px 60px;
}

body.single-bigcommerce_product .site-header.collapsed ~ footer .drawer {
    padding: 178px 40px 60px;
}

.drawer .scroller {
    position: relative;
    float: left;
    width: 100%;
    height: 100%;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.drawer .nav-scroller {
    float: left;
    position: relative;
    z-index: 7;
    top: 0;
    background: #fff;
    opacity: 1;
    left: auto;
    right: 0;
    width: 100%;
    height: auto;
    /*overflow-y: auto;
    -webkit-overflow-scrolling: touch;*/
}

.drawer.active {
    opacity: 1;
    /* transform: translateY(0); */
    transform: translate(0, 0);

    -webkit-box-shadow: 0 40px 40px 0px rgba(0, 0, 0, 0.1);
    -moz-box-shadow: 0 40px 40px 0px rgba(0, 0, 0, 0.1);
    box-shadow: 0 40px 40px 0px rgba(0, 0, 0, 0.1);
}

.drawer.close {
    opacity: 1;
    transform: translate(100%, 0);
}

.drawer a.button.close {
    position: fixed;
    z-index: 3;
    top: 160px;
    right: 20px;
    float: right;
    padding: 0 10px;
    background: #fff;
}

.drawer a.button.close svg {
    padding: 0;
    margin: 0;
    line-height: 64px;
}

.drawer a.button.close ~ .block-header h1:first-of-type,
.drawer a.button.close ~ .block-header h2:first-of-type,
.drawer a.button.close ~ .block-header h3:first-of-type,
.drawer a.button.close ~ .block-header h4:first-of-type,
.drawer a.button.close ~ .block-header h5:first-of-type,
.drawer a.button.close ~ .block-header h6:first-of-type,
.drawer a.button.close ~ .block-header p:first-of-type {
    padding: 0 48px 0 0;
}

.drawer a.button.close ~ .block-header h1 ~ p,
.drawer a.button.close ~ .block-header h2 ~ p,
.drawer a.button.close ~ .block-header h3 ~ p,
.drawer a.button.close ~ .block-header h4 ~ p,
.drawer a.button.close ~ .block-header h5 ~ p,
.drawer a.button.close ~ .block-header h6 ~ p {
    padding: 0 !important;
}


.drawer .center-xy {
    top: 45%;
}

.drawer .site-branding a,
.drawer .site-branding a img,
.drawer .site-branding a svg {
    width: 180px;
}


.drawer .main-navigation,
.drawer .site-nav,
.drawer ul.menu {
    position: relative;
    float: left;
    width: 100%;
}

.drawer ul.menu {
    width: auto;
    height: auto;
    padding: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.drawer ul.menu {
    width: 100%;
    float: left;
}

/* Drop a curtain to hide movement below -- NO TRANSITION! */
.drawer ul.sub-menu {
    z-index: 1;
}

.drawer ul.sub-menu.active:after {
    content: " ";
    position: fixed;
    z-index: -1;
    height: 100%;
    width: 100%;
    left: 0;
    top: 0;
    background: #fff;
}

.drawer ul.nav-social {
    position: relative;
    float: left;
    max-width: 540px;
    margin: 0;
    padding: 0 100px;
    bottom: 140px;
    left: 50%;
    right: auto;
    -moz-transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -o-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
}

.drawer + ul.nav-social {
    justify-content: space-between;
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 9;
    padding: 20px 10px;
    margin: 0;
    visibility: hidden;
    opacity: 0;
}

.drawer div.copyright {
    position: absolute;
    line-height: 24px;
    margin: 0;
    padding: 0 100px;
    bottom: 40px;
    left: 0;
    text-align: center;
}

span.terms-privacy {
    width: 100%;
}


/* xx Media queries xx */
@media screen and (max-width: 1023px) {

    .drawer {
        padding: 90px 0 0px;
        display: flex;
        flex-direction: column;
        justify-content: flex-start;
    }

    .site-header.collapsed ~ .drawer {
        padding: 60px 0 0px;
    }

    .drawer .main-navigation ul li {
        padding: 0 20px;
    }

    .drawer .nav-ancillary {
        position: relative;
        z-index: 1;
        float: left;
        width: 100%;
        height: auto;
        margin: 20px 0 0;
        padding: 20px 0;
        opacity: 1;
        visibility: visible;
    }

    .drawer .main-navigation.ancillary ul {
        display: block;
    }

    .drawer .main-navigation.ancillary ul li {
        width: 50%;
        margin: 0;
        padding: 0 20px;
    }

    .drawer .main-navigation.ancillary ul li.profile {
        width: 100%;
        text-align: center;
        margin: 40px 0 0;
    }

    .drawer ul.nav-social,
    .drawer div.copyright {
        height: auto;
        padding: 20px;
        bottom: 0;
        background: #fff;
        z-index: 2;
        opacity: 1;
        visibility: visible;

    }

    .drawer .copyright {
        display: none;
    }

    .drawer ul.nav-social {
        left: 0;
        -moz-transform: translateX(0);
        -webkit-transform: translateX(0);
        -o-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0);
        visibility: visible;
        opacity: 1;
    }

    .drawer + ul.nav-social {
        justify-content: space-between;
        -moz-transform: translateX(0);
        -webkit-transform: translateX(0);
        -o-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0);
        visibility: visible;
        opacity: 1;
    }

    /* Fade out to avoid fixed overlap bug */
    .drawer.submenu .nav-social,
    .drawer.submenu .nav-ancillary {
        opacity: 0;
        visibility: hidden;
        display: none;
    }


}

@media screen and (max-width: 480px) {
    .drawer {
        width: 100%;
        transform: translate(100%, 0);
    }

    .drawer.active {
        transform: translate(0%, 0);
    }
}
