@import url(https://fonts.googleapis.com/css?family=Nunito+Sans:300,400,600,700|Montserrat:400,600,700);

@keyframes changemargin {
    from {
        margin-left: 5px;
    }

    to {
        margin-left: 8px;
    }
}

/* Holiday Link color override */
.holiday-colored-link,
a.holiday-colored-link,
.holiday > a {
  color: #cc0033 !important;
}

@media screen and (max-width: 999px) {
    .visually-hidden {
        display: none;
    }
    /* fade image in after load */
    .lazyload,
    .lazyloading {
        opacity: 0;
    }
    .lazyloaded {
        opacity: 1;
        transition: opacity 250ms ease;
    }
    .mobile-nav-open {
        overflow: hidden;
    }
    .mobile-nav-open .field--name-field-landing-banner {
        position: relative;
        z-index: -1;
    }
    #block-storelocator {
        display: none;
    }
    .mobile-flyout-wrap {
        background: #FFF;
        display: flex;
        padding: 15px;
    }
    .menu--main .menu-level--0 .login-mobile .logout-link-mobile,
    .menu--main .menu-level--0 .menu-item-mobile.my-account {
        display: none;
    }
    .toggle-nav {
        margin: 0 15px 0 0;
        position: relative;
        width: 22px;
        height: 22px;
    }
    .toggle-nav a {
        position: absolute;
        text-decoration: none;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        height: 3px;
        background: #532D6D;
        top: 50%;
        display: block;
        margin-top: -2px;
        width: 100%;
    }
    .toggle-nav a:after,
    .toggle-nav a:before {
        content: '';
        display: block;
        position: absolute;
        height: 3px;
        width: 100%;
        background: #532D6D;
    }
    .toggle-nav a:after {
        bottom: -8px;
        transition: bottom .1s ease-in .1s,transform .1s cubic-bezier(.55,.055,.675,.19) 0s;
    }
    .toggle-nav a:before {
        top: -8px;
        transition: top .1s ease-in .1s,transform .1s cubic-bezier(.55,.055,.675,.19) 0s;
    }
    .toggle-nav.is-active a {
        transition: transform .1s cubic-bezier(.215,.61,.355,1) 0s,background-color 0s linear .22s;
        transform: rotate(90deg);
        background-color: transparent;
    }
    .toggle-nav.is-active a:before {
        top: calc(50% - 1px);
        transition: top .1s ease-out .12s,transform .1s cubic-bezier(.215,.61,.355,1) .22s;
        transform: rotate(-45deg);
    }
    .toggle-nav.is-active a:after {
        bottom: calc(50% - 2px);
        transition: bottom .1s ease-out .12s,transform .1s cubic-bezier(.215,.61,.355,1) .22s;
        transform: rotate(45deg);
    }
    header {
        padding: 0;
        position: relative;
        z-index: 15;
        background: #FFF;
        border-bottom: 1px solid #D8D8D8;
    }
    header .region-header {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row;
        padding: 1rem;
        position: relative;
    }
    header .cart-container {
        display: none;
    }
    header .region-header .site-name {
        display: none;
    }
    .menu--main {
        position: absolute;
        width: 85%;
        top: 0;
        left: -100%;
        transition: left 500ms ease-in-out;
        z-index: auto;
    }
    .menu--main.show-nav {
        display: block;
        position: absolute;
        left: 0;
        transition: left 250ms ease-in-out;
        z-index: 2;
    }
    .menu--main:after {
        content: '';
        width: 18%;
        height: 100%;
        background: rgba(0, 0, 0, 0.75);
        display: block;
        position: absolute;
        right: -18%;
        top: 0;
        opacity: 0;
        transition: opacity 250ms ease-in-out;
    }
    .menu--main.show-nav:after {
        opacity: 1;
    }
    .menu--main .menu-level--0 {
        -webkit-box-direction: normal;
        display: block;
        overflow-y: scroll;
        height: 88vh;
        margin: 0;
        background: #FFF;
    }
    .menu--main .menu-level--0 {
        padding: 15px;
    }
    .menu--main .menu-level--0 li {
        padding: 15px 0;
        border-bottom: 1px solid #d8d8d8;
    }
    .menu--main .menu-level--0 li li {
        border: 0;
    }
    .menu--main .menu-level--1 li.by-roast,
    .menu--main .menu-level--1 li.by-tea-type,
    .menu--main .menu-level--1 li.serving-type,
    .menu--main .menu-entity-block .menu-level--0 {
        padding: 0;
    }
    .menu--main .menu-entity-block .menu-level--0 .menu-item span {
        font-family: 'Nunito Sans', sans-serif;
        font-size: 14px;
        line-height: 18px;
        color: #505054;
        text-transform: none;
        font-weight: 300;
    }
    .menu--main .menu-level--0 .menu-item {
        list-style: none;
    }
    .menu--main .menu-level--1 li.by-roast a,
    .menu--main .menu-level--1 li.by-tea-type a,
    .menu--main .menu-level--0 .shop .menu-level--1,
    .menu--main .menu-level--0 .shop .menu-entity-block .sub-menu-wrap,
    .menu--main .menu-level--1 li.serving-type > a {
        display: none;
    }
    .menu--main .menu-level--1 li:first-child,
    .menu--main .menu-level--1 .sub-menu-wrap li,
    .menu--main .menu-level--1 li.by-roast .sub-menu-wrap a,
    .menu--main .menu-level--1 li.by-tea-type .sub-menu-wrap a,
    .menu--main .menu-level--0 .shop .sub-menu-wrap .menu-entity-block .menu-level--1,
    .menu--main .menu-level--0 .sub-menu-wrap .menu-entity-block li {
        display: block;
    }
    .menu--main .menu-level--1 .sub-menu-wrap li.shop-all {
        display: none;
    }
    .menu--main .menu-level--0 .sub-menu-wrap .menu-entity-block li {
        flex-basis: 0;
        flex-grow: 1;
        margin: 0;
    }
    .menu--main .menu-level--0 .sub-menu-wrap .menu-entity-block li:first-child {
        margin-left: 0;
    }
    .menu--main .menu-level--0 .sub-menu-wrap .menu-entity-block li:last-child {
        margin-right: 0;
    }
    .menu--main .menu-level--0 .sub-menu-wrap .menu-entity-block li li {
        margin: 0;
    }
    .menu--main .menu-level--1 li a {
        font-family: 'Nunito Sans', sans-serif;
        font-size: 14px;
        line-height: 18px;
        color: #505054;
        text-decoration: none;
        font-weight: 300;
    }
    .menu--main .menu-level--0 .product-container,
    .menu--main .menu-level--0 .overflow-wrap {
        display: none;
    }
    .menu--main .menu-level--0 .menu {
        margin: 0;
        padding: 0;
    }
    .menu--main .menu-level--0 .menu{
        overflow: visible;
        height: auto;
        padding: 0;
    }
    .menu--main .menu.menu-level--1,
    .menu--main .menu-entity-block .menu-level--0 {
        padding-top: 5px;
    }
    header .region-header .site-logo img {
        width: 20px;
        margin: 0;
    }
    .menu--main .menu-level--0 > li > a {
        text-decoration: none;
        text-transform: uppercase;
        font-family: 'Montserrat', sans-serif;
        font-size: 14px;
        font-weight: 700;
        line-height: 18px;
        color: #505054;
        display: block;
        position: relative;
    }
    .menu--main .menu-level--0 > .menu-item--expanded > a:after,
    .menu--main .menu-level--0 > .menu-item--expanded > a:before {
        content: "";
        position: absolute;
        background-color: #505054;
        transition: transform 250ms ease-in;
    }
    .menu--main .menu-level--0 > .menu-item--expanded.expanded > a:after {
        transform: rotate(180deg);
        transition: transform 250ms ease-out;
    }
    .menu--main .menu-level--0 > .menu-item--expanded.expanded > a:before {
        transform: rotate(90deg);
        transition: transform 250ms ease-out;
    }
    .menu--main .menu-level--0 > .menu-item--expanded > a:after {
        width: 10px;
        height: 2px;
        right: 0;
        top: calc(50% - 1px);
    }
    .menu--main .menu-level--0 > .menu-item--expanded > a:before {
        height: 10px;
        width: 2px;
        right: 4px;
        top: calc(50% - 5px);
    }
    .menu--main .menu-entity-block .menu-level--0 > li > a:before,
    .menu--main .menu-entity-block .menu-level--0 > li > a:after{
        display: none;
    }
    .menu-level--0 .sub-menu-wrap-level--0 {
        max-height: 0;
        overflow: hidden;
        transition: all 500ms ease-in-out;
    }
    .menu-level--0 > li.expanded .sub-menu-wrap-level--0 {
        max-height: 600px;
        transition: all 500ms ease-in-out;
    }
    .menu--main .menu-level--1 > li > a {
        font-family: 'Nunito Sans', sans-serif;
        font-size: 14px;
        line-height: 18px;
        color: #505054;
        text-transform: none;
        font-weight: 300;
    }
    /* START Magento Specific Styles */
    .header-default .page-header header {
        z-index: 20;
    }
    .header-default .page-header header .menu--main {
        padding: 0;
        width: 85% !important;
    }
    .header-default .page-header header .menu--main .container {
        margin: 0 auto;
        max-width: 1220px;
    }
    .header-default .page-header header .navigation,
    .header-default .page-header header .navigation a,
    .header-default .page-header header .toggle-nav a{
        padding: 0;
    }
    .header-default div.page-header {
        margin-bottom: 0;
    }
    /* END Magento Specific Styles */
}

@media screen and (min-width: 1000px)  {
    body:before{
        content: '';
        position: absolute;
        bottom: 0;
        width: 100%;
        height: calc(100% - 95px);
        opacity: 0;
        visibility: hidden;
        z-index: 2;
        background: #000;
        transition: opacity 500ms ease-out, visibility 500ms ease-out;
        transition-delay: 250ms;
    }
    /*body.submenu-active {*/
        /*overflow: hidden;*/
    /*}*/
    body.submenu-active:before {
        background: #000;
        opacity: .60;
        visibility: visible;
        transition: opacity 500ms ease-out, visibility 500ms ease-out;
        transition-delay: 250ms;
    }
    .mobile-flyout-wrap {
        display: none;
    }
    .menu-item-mobile {
        display: none !important;
    }
    #block-logo {
        display: flex;
        flex-direction: column;
        justify-content: center;
        padding-left: 1rem;
    }
    #block-storelocator {
        display: block;
    }
    header {
        padding: 0;
        border-bottom: 1px solid #D8D8D8;
        text-rendering: optimizeLegibility;
    }
    header nav {
        width: auto;
        height: auto;
        position: static;
    }
    header .region-header {
        padding: 0;
        display: flex;
        justify-content: space-between;
        width: 100%;
    }
    header .cart-container {
        display: block;
    }
    header .region-header .site-logo img {
        width: 80px;
    }
    header .branding {
        margin-top: 0;
    }
    #block-mobiletogglemenu {
        display: none;
    }
    .menu--main .login-mobile {
        display: none;
    }
    .menu--main .menu-level--1 .sub-menu-wrap li.shop-all {
        display: block;
    }

    /* START Refactored Mega menu (Desktop only) */
    /* Standard Drupal Menu block */
    /* We turn it into a mega menu with the following styles */
    .menu--main ul.menu {
        margin: 0;
        padding: 0;
        list-style: none;
    }

    .menu--main ul.menu li {
        list-style: none;
        padding: 0;
    }
    /* Linking menu items */
    .menu--main ul.menu li a {

    }
    /* Non-linking menu items */
    .menu--main ul.menu li span {

    }
    /* Menu item with children */
    .menu--main ul.menu li.menu-item--expanded {

    }
    /* First level main menu items ------------------------- */
    .menu--main > ul.menu  {
        display: flex;
        position: relative;
    }
    .menu--main > ul.menu > li {

    }
    .menu--main > ul.menu > li > a > span {
        position: relative;
    }
    .menu--main > ul.menu > li > a > span:after {
        content: '';
        opacity: 0;
        display: block;
        height: 3px;
        background: #3E2252;
        position: absolute;
        bottom: -16px;
        width: 0;
    }
    .menu--main > ul.menu > li > a:hover span:after {
        opacity: 1;
        width: 100%;
        transition: all 500ms ease;
        transition-delay: 250ms;
    }
    /* Linking menu items */
    .menu--main > ul.menu > li > a {
        display: block;
        padding: 15px;
        text-transform: uppercase;
        font-family: 'Montserrat', sans-serif;
        font-size: 14px;
        font-weight: 600;
        line-height: 18px;
        color: #505054;
        letter-spacing: .01rem;
        text-decoration: none;
    }
    .menu--main > ul.menu > li.menu-item--expanded:hover > .sub-menu-wrap {
        max-height: 1000px;
        transition: max-height 500ms ease-out;
        transition-delay: 250ms;
    }
    .menu--main > ul.menu > li.menu-item--expanded:hover > .sub-menu-wrap > .container {
        opacity: 1;
        transition: opacity 250ms ease;
        transition-delay: 350ms;
    }
    /* Second level main menu items ------------------------- */
    .menu--main > ul.menu > li > .sub-menu-wrap {
        position: absolute;
        right: 0;
        top: 49px;
        width: 100vw;
        max-height: 0;
        z-index: 20;
        background: #FFF;
        transition: max-height 750ms ease-out;
        transition-delay: 250ms;
        overflow: hidden;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap.sibling-menu-open {
        z-index: 15;
    }
    .menu--main > ul.menu > li.menu-item--expanded > .sub-menu-wrap.sibling-menu-open > .container {
        opacity: 0;
        transition: opacity 250ms ease;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container {
        display: flex;
        padding: 30px 0;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > .product-container {
        display: flex;
        width: 70%;
        border-right: 1px solid #EBEBED;
        padding: 0 30px 0 0;
        margin-right: 45px;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > .product-container .product-description p {
        font-family: 'Nunito Sans', sans-serif;
        font-size: 12px;
        line-height: 18px;
        color: #505054;
        font-weight: normal;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > ul.menu {
        display: flex;
        width: 30%;
        justify-content: space-between;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > .product-container .product-image {
        min-width: 350px;
        max-width: 350px;
        margin-right: 30px;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > .product-container .product-link a {
        display: flex;
        justify-content: flex-start;
        font-size: 12px;
        font-weight: 700;
        line-height: 16px;
        color: #532D6D;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > .product-container .product-link img {
        max-width: 16px;
        min-width: inherit;
        margin: 4px 5px;
        transition: margin 500ms ease-out;
        max-height: 8px;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > .product-container .product-link a:hover img {
        transition: margin 500ms ease-out;
        margin-left: 10px;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > .product-container .product-content > div:not(:last-child) {
        margin-bottom: 15px;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > .product-container .product-title h3 {
        margin: 0;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > ul.menu .menu-item--expanded > a,
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > .menu-entity-block .menu-item--expanded > a {
        font-family: 'Montserrat', sans-serif;
        font-size: 12px;
        font-weight: 700;
        line-height: 15px;
        color: #111820;
        text-transform: uppercase;
        letter-spacing: .05rem;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > ul.menu .menu-item--expanded ul.menu li > a {
        font-family: 'Nunito Sans', sans-serif;
        font-size: 14px;
        line-height: 32px;
        color: #505054;
        font-weight: normal;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > ul.menu .menu-item--expanded ul.menu li.shop-all > a,
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > .menu-entity-block .menu-item--expanded ul.menu li.shop-all > a{
        display: flex;
        flex-direction: row-reverse;
        justify-content: flex-end;
        align-items: center;
        font-family: 'Nunito Sans', sans-serif;
        font-size: 12px;
        font-weight: 700;
        line-height: 32px;
        color: #532D6D;
        font-weight: 700;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > .menu-entity-block .menu-item--expanded ul.menu li.shop-all > a {
        line-height: 20px;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > ul.menu .menu-item--expanded ul.menu li.shop-all > a > .overflow-wrap,
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > .menu-entity-block .menu-item--expanded ul.menu li.shop-all > a > .overflow-wrap{
        display: flex;
        justify-content: center;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > ul.menu .menu-item--expanded ul.menu li.shop-all > a img,
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > .menu-entity-block .menu-item--expanded ul.menu li.shop-all > a img{
        margin-left: 5px;
        transition: margin 500ms ease-out;
        min-width: inherit;
        width: auto;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > ul.menu .menu-item--expanded ul.menu li.shop-all > a:hover img,
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > .menu-entity-block .menu-item--expanded ul.menu li.shop-all > a:hover img{
        margin-left: 10px;
        transition: margin 500ms ease-out;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > .menu-entity-block {
        margin: 15px 30px 0;
        padding: 30px 0 0;
        border-top: 1px solid #EBEBED;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap li {

    }
    /* Linking menu items */
    .menu--main > ul.menu > li > .sub-menu-wrap li > a {
        font-family: 'Nunito Sans', sans-serif;
        font-size: 14px;
        line-height: 32px;
        color: #505054;
        font-weight: normal;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap .menu-entity-block li > a {
        line-height: 20px;
        display: block;
        margin-bottom: 15px;
    }
    .menu--main > ul.menu > li.shop > .sub-menu-wrap > .container {
        max-width: inherit;
        display: flex;
        flex-direction: column;
        width: auto;
    }
    .menu--main > ul.menu > li.shop > .sub-menu-wrap > .container > ul.menu,
    .menu--main > ul.menu > li.cafe-menu > .sub-menu-wrap > .container > ul.menu,
    .menu--main > ul.menu > li.our-story > .sub-menu-wrap > .container > ul.menu {
        width: auto;
        padding: 0 15px;
    }
    .menu--main > ul.menu > li.shop > .sub-menu-wrap > .container > ul.menu > li {
        flex-grow: 1;
        width: 100%;
    }
    .menu--main > ul.menu > li.shop > .sub-menu-wrap > .container > ul.menu > li,
    .menu--main > ul.menu > li.cafe-menu > .sub-menu-wrap > .container > ul.menu > li,
    .menu--main > ul.menu > li.our-story > .sub-menu-wrap > .container > ul.menu > li {
        padding: 0 15px;
        text-align: center;
        flex-basis: 0;
        flex-grow: 1;
    }
    .menu--main > ul.menu > li > .sub-menu-wrap > .container > ul.menu > li > a .overflow-wrap {
        overflow: hidden;
    }
    .menu--main > ul.menu > li.shop > .sub-menu-wrap > .container > ul.menu > li > a,
    .menu--main > ul.menu > li.cafe-menu > .sub-menu-wrap > .container > ul.menu > li > a,
    .menu--main > ul.menu > li.our-story > .sub-menu-wrap > .container > ul.menu > li > a {
        font-family: 'Montserrat', sans-serif;
        font-size: 18px;
        font-weight: 700;
        line-height: 22px;
        color: #532D6D;
        text-transform: uppercase;
        letter-spacing: .01rem;
        display: block;
    }
    .menu--main > ul.menu > li.shop > .sub-menu-wrap > .container > ul.menu > li > a img,
    .menu--main > ul.menu > li.cafe-menu > .sub-menu-wrap > .container > ul.menu > li > a img,
    .menu--main > ul.menu > li.our-story > .sub-menu-wrap > .container > ul.menu > li > a img {
        transform: scale(1.0);
        transition: all 1500ms ease;
    }
    .menu--main > ul.menu > li.shop > .sub-menu-wrap > .container > ul.menu > li > a:hover img,
    .menu--main > ul.menu > li.cafe-menu > .sub-menu-wrap > .container > ul.menu > li > a:hover img,
    .menu--main > ul.menu > li.our-story > .sub-menu-wrap > .container > ul.menu > li > a:hover img {
        transform: scale(1.1);
        transition: all 1500ms ease;
    }
    .menu--main > ul.menu > li.shop > .sub-menu-wrap > .container > ul.menu > li > a > span,
    .menu--main > ul.menu > li.cafe-menu > .sub-menu-wrap > .container > ul.menu > li > a > span,
    .menu--main > ul.menu > li.our-story > .sub-menu-wrap > .container > ul.menu > li > a > span {
        padding: 15px 15px 0;
        display: block;
    }
    .menu--main > ul.menu > li.shop > .sub-menu-wrap > .container > .menu-entity-block nav > ul.menu {
        display: flex;
        width: 100%;
        justify-content: space-between;
    }
    .menu--main > ul.menu > li.shop > .sub-menu-wrap > .container > .menu-entity-block nav > ul.menu > li {
        max-width: 160px;
    }
    .menu--main > ul.menu > li.cafe-menu > .sub-menu-wrap > .container,
    .menu--main > ul.menu > li.our-story > .sub-menu-wrap > .container,
    .menu--main > ul.menu > li.our-story > .sub-menu-wrap > .container > ul.menu,
    .menu--main > ul.menu > li.cafe-menu > .sub-menu-wrap > .container > ul.menu {
        width: 100%;
        max-width: inherit;
    }
    .menu--main > ul.menu > li.our-story > .sub-menu-wrap > .container > ul.menu > li,
    .menu--main > ul.menu > li.cafe-menu > .sub-menu-wrap > .container > ul.menu > li {
        padding: 0 15px;
    }
    /* MAGENTO OVERRIDES */
    div.page-header header .navigation {
        padding: 0;
    }
    div.page-header header .navigation .container {
        width: 1220px;
    }
    div.page-header header .navigation .container .container {
        width: auto;
        max-width: inherit;
        padding: 0;
    }
    div.page-header header .navigation .shop .container .container {
        width: 1220px;
    }
    div.page-header header .navigation .shop .container .container .container {
        width: auto;
    }
    div.page-header header .navigation a {
        text-decoration: none;
    }
    /* END Refactored Mega menu (Desktop only) */
}