/* ==========================================================================
   RESET / BASIS
   ========================================================================== */

.mobile-cat-root ul,
.mobile-cat-root li,
.nav-desktop ul,
.nav-desktop li {
    margin: 0;
    padding: 0;
    list-style: none;
}

.mobile-cat-root a,
.nav-desktop a {
    text-decoration: none;
}

.navbar {
    padding: 0 !important;
}

.container.container-header {
    background: #503778;
}

.header-main .header-columns {
    width: 62.5vw;
}

.navbar-brand img {
    width: 8.5rem;
}

.nav-desktop a {
    color: #343a40;
    text-align: left;
}

/* ==========================================================================
   SEARCH
   ========================================================================== */

.header-search .input-text {
    color: #d3d3d3;
    background: #fdfdfd1c;
    border: 1px solid #ffffff1c;
    height: 2.4rem;
    font-weight: 400;
    transition: background 0.3s ease-in-out, color 0.3s ease-in-out, border-color 0.3s ease-in-out;
}

/* ==========================================================================
   PLACEHOLDER / HOVER PREVIEW
   ========================================================================== */

.placeholder-content,
.vmagicmenu .placeholder-content {
    border-radius: 1rem !important;
    background-size: cover;
    background-position: center;
}

.menu-hover-image-placeholder,
.vmagicmenu .menu-hover-image-placeholder {
    aspect-ratio: 4 / 3;
}

.placeholder-name.visible,
.vmagicmenu .placeholder-name.visible {
    opacity: 1;
}

.menu-hover-image-placeholder .placeholder-name {
    font-weight: 700 !important;
    color: #3e3169 !important;
}

/* ==========================================================================
   SHARED SCROLLBARS
   ========================================================================== */

.level-top-mega::-webkit-scrollbar,
.vmagicmenu-narrow::-webkit-scrollbar,
.minicart-items-wrapper::-webkit-scrollbar,
.search-autocomplete .mini-results::-webkit-scrollbar {
    width: 7px;
}

.level-top-mega::-webkit-scrollbar-track,
.vmagicmenu-narrow::-webkit-scrollbar-track,
.minicart-items-wrapper::-webkit-scrollbar-track,
.search-autocomplete .mini-results::-webkit-scrollbar-track {
    background: #c3c3c387;
    border-radius: 7px;
    border: 2px solid transparent;
    background-clip: padding-box;
    margin: 2px 2px 2px 0;
}

.level-top-mega::-webkit-scrollbar-thumb,
.vmagicmenu-narrow::-webkit-scrollbar-thumb,
.minicart-items-wrapper::-webkit-scrollbar-thumb,
.search-autocomplete .mini-results::-webkit-scrollbar-thumb {
    background: #3e3169;
    border-radius: 5rem;
    border: 2px solid transparent;
    background-clip: padding-box;
}

/* ==========================================================================
   TEXT TRUNCATION
   ========================================================================== */

.level0 .level1 > div a span,
.level2 > a span {
    display: block;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ==========================================================================
   HEADER SUB TOGGLE
   ========================================================================== */

.header-sub,
.header-sub--hidden {
    transition: max-height .3s ease-in-out, opacity .3s ease-in-out, transform .3s ease-in-out;
}

.header-sub--hidden {
    transform: translateY(-10px);
    opacity: 0;
    pointer-events: none;
    max-height: 0;
    margin: 0;
    padding-top: 0;
    padding-bottom: 0;
}

/* ==========================================================================
   HORIZONTAL MENU
   ========================================================================== */

.magicmenu.clearfix {
    height: 2.2rem;
    background: #503877ed;
    backdrop-filter: blur(8px);
    transform: translateY(0);
    padding: 0 2.25rem;
}

.magicmenu .nav-desktop > li.level0:hover > a.level-top {
    background: #fff;
    border-radius: .5rem .5rem 0 0;
    color: #3e3169;
    text-shadow: 0 0 0.5px currentColor;
}

.magicmenu .nav-desktop > li.level0.hasChild:not(:first-child):hover > a.level-top::before {
    content: "";
    position: absolute;
    left: -.5rem;
    bottom: 0;
    width: .5rem;
    height: .5rem;
    z-index: -1;
    background: transparent;
    border-bottom-right-radius: .5rem;
    box-shadow: .5rem .5rem 0 .5rem #fff;
}

.magicmenu .nav-desktop > li.level0.hasChild:not(:last-child):hover > a.level-top::after {
    content: "";
    position: absolute;
    left: 100%;
    bottom: 0;
    width: .5rem;
    height: .5rem;
    z-index: -1;
    background: transparent;
    border-bottom-left-radius: .5rem;
    box-shadow: -.5rem .5rem 0 .5rem #fff;
}

.nav-desktop > li.level0.ext:hover > a.level-top {
    background-color: #fff !important;
    padding-top: .25rem !important;
    padding-bottom: .25rem !important;
    border-radius: 10rem;
    color: #3e3169 !important;
    transition: ease-in-out .3s;
}

.magicmenu .nav-desktop .level0 .level-top {
    padding: .3rem .8rem .6rem !important;
    line-height: 1rem;
    font-weight: 400 !important;
    color: #f3f3f3;
}

.magicmenu .level0 .level-top img {
    display: none;
}

.level0.nav-item {
    list-style: none;
    width: auto !important;
}

.magicmenu .top-btn a {
    font-weight: 200;
    color: #ffffff;
    text-decoration: none;
    opacity: 0.6;
    transition: ease-in-out 0.3s;
}

.magicmenu .top-btn a:hover {
    opacity: 1;
}

.magicmenu .nav-desktop .level0 .level-top-mega {
    border-radius: 0 0 1rem 1rem;
    scrollbar-gutter: stable;
    max-height: 75vh;
    overflow-y: auto;
    -ms-overflow-style: none;
}

.magicmenu .level-top-mega {
    left: 50%;
    transform: translateX(-50%);
}

.magicmenu .nav-desktop .level0.over .level-top-mega,
.magicmenu .nav-desktop .level0:hover .level-top-mega,
.magicmenu .nav-desktop.click .level0.over .level-top-mega,
.magicmenu .nav-desktop.click .level0:hover .level-top-mega {
    opacity: 1 !important;
    visibility: visible !important;
    top: 2.2rem;
    transition: all .3s ease;
}

@media screen and (min-width: 992px) {
    .magicmenu .nav-desktop .level0 .level-top-mega {
        width: calc(100% - 1.05rem);
    }
}

/* ==========================================================================
   VERTICAL MENU
   ========================================================================== */

.vmagicmenu.vertical-menu {
    flex: 0 1 28.5%;
    max-width: 28.5%;
    z-index: 90;
}

.vmagicmenu .block-title {
    line-height: 2.4rem;
    z-index: 90;
    border-radius: .5rem;
}

.block-title-vmagicmenu {
    cursor: pointer;
}

.block-title-vmagicmenu.vmenu-active {
    border-radius: .5rem .5rem 0 0;
}

.vmenu-active::after {
    content: "";
    position: absolute;
    left: 100%;
    bottom: -1rem;
    width: 1rem;
    height: 1rem;
    z-index: -1;
    background: transparent;
    border-bottom-left-radius: 1rem;
    box-shadow: -1rem 1rem 0 1rem #fff;
}

.vmagicmenu .vmagicmenu-subtitle {
    font-weight: 500;
    color: #3e3169;
}

.vmagicmenu .block-vmagicmenu-content {
    display: none;
}

.vmagicmenu.is-vmenu-open .block-vmagicmenu-content {
    display: block;
}
 
.vmagicmenu .vmagicmenu-narrow {
    max-height: 85vh;
    border-radius: 0 0 0 1rem;
    overflow: auto;
}

.vmagicmenu .cat {
    line-height: 1rem;
    margin: 0 0.5rem;
}

.vmagicmenu .cat .level-top {
    position: relative;
    display: block;
    padding: .7rem .5rem;
    padding-left: 2.5rem !important;
    outline: medium;
    transform: translateX(0) !important;
    transition: transform .3s cubic-bezier(.65, 0, .35, 1) !important;
}

.vmagicmenu .cat:hover .level-top,
.vmagicmenu .nav-desktop .cat.over .level-top {
    color: rgb(62, 49, 105);
    font-weight: bolder;
    transform: translateX(.3rem) !important;
    padding-right: .2rem;
}
.vmagicmenu .cat .level-top,
.vmagicmenu .nav-desktop .cat .level-top {
    transform: translateX(.3rem);
    padding-right: 1rem!important;
}
.vmagicmenu .nav-desktop .cat.over .level-top {
    background-color: #f2f3f7;
    border-radius: .5rem;
    padding: .7rem .5rem .7rem 2.8rem;
    margin: 0;
    transition: background-color .2s ease-in-out, transform .3s cubic-bezier(.65, 0, .35, 1) !important;
}

.vmagicmenu .cat .level-top::before {
    border-radius: 10rem;
    z-index: 1;
}

.vmagicmenu .cat .level-top img,
.vmagicmenu .cat .level-top::before {
    content: "";
    position: absolute;
    left: .5rem;
    top: 50%;
    width: 1.6rem;
    height: 1.6rem;
    transform: translateY(-50%);
    transition: ease-in-out .2s;
}

.vmagicmenu .cat.over .level-top img,
.vmagicmenu .cat.over .level-top::before {
    width: 1.8rem;
    height: 1.8rem;
    margin-left: -.1rem;
}

.vmagicmenu .cat .level-top img {
    z-index: 2;
    padding: .4rem;
}

.vmagicmenu .cat.over .level-top::before {
    background: #3e3169 !important;
}

.vmagicmenu .level0.over .level-top img {
    filter: brightness(0) invert(1);
}

.vmagicmenu .level0 .level-top-mega {
    left: 100%;
    top: 0 !important;
    z-index: 999;
    opacity: 0;
    visibility: hidden;
    height: calc(100% - 1rem);
}

.vmagicmenu .nav-desktop .level0 .level-top-mega {
    background-color: #fff;
}

.vmagicmenu .nav-desktop .level0 .level-top-mega::before {
    content: "";
    position: absolute;
    left: 0;
    top: 5px;
    bottom: 5px;
    width: 1px;
    background: linear-gradient(to bottom, transparent, #ededed 10%, #ededed 90%, transparent);
}

.vmagicmenu .cat:hover .level-top-mega,
.vmagicmenu .cat.over .level-top-mega {
    opacity: 1;
    visibility: visible;
}

.vmagicmenu-narrow .level0 > .level-top :before {
    content: "";
    position: absolute;
    top: -1px;
    left: .7rem;
    right: .7rem;
    border-top: 1px solid #ededed;
    transition: ease-in-out 0.3s;
}

.vmagicmenu-narrow .level0.over > .level-top :before {
    border-color: transparent;
    transition: ease-in-out 0.3s;
}

.magicmenu .nav-desktop .level0:not(:hover):not(.over) > .level-top-mega,
.vmagicmenu .level0:not(:hover):not(.over) > .level-top-mega {
    display: none !important;
}

@media screen and (min-width: 992px) {
    .vmagicmenu .nav-desktop .level0 .level-top-mega {
        width: 49vw !important;
        border-radius: 0 0 1rem 0;
        overflow-y: auto;
        margin-top: 1rem;
        -ms-overflow-style: none;
    }
}

.navbar .vmagicmenu {
    opacity: 1;
    transition: opacity .3s ease-in-out;
}

.navbar:has(.magicmenu .nav-desktop .level0.over) .vmagicmenu {
    opacity: .5;
}

/* ==========================================================================
   ICON MENU
   ========================================================================== */

.icon-menu {
    width: 1rem;
    height: 2rem;
    cursor: pointer;
    transition: .5s ease-in-out;
    top: .7rem;
}

.icon-menu span {
    position: absolute;
    left: 0;
    display: block;
    width: 100%;
    height: 1.5px;
    background-color: #3e3169;
    opacity: 1;
    transition: .25s ease-in-out;
}

.icon-menu span:nth-child(1) {
    top: 0;
}

.icon-menu span:nth-child(2) {
    top: .3rem;
}

.icon-menu span:nth-child(3) {
    top: .6rem;
}

@media (min-width: 992px) {
    .vmagicmenu.is-vmenu-open .icon-menu span:nth-child(1) {
        transform: translateY(.3rem);
        width: 100% !important;
    }

    .vmagicmenu.is-vmenu-open .icon-menu span:nth-child(2) {
        opacity: 0;
    }

    .vmagicmenu.is-vmenu-open .icon-menu span:nth-child(3) {
        transform: translateY(-.3rem);
        width: 100% !important;
    }

    .icon-menu span {
        height: .1rem;
    }
}

@media (max-width: 991px) {
    .icon-menu {
        top: .5rem;
    }

    .header-mobile.is-open .icon-menu span:nth-child(1) {
        top: 6px;
        left: 50%;
        width: 0;
    }

    .header-mobile.is-open .icon-menu span:nth-child(2) {
        top: 6px;
        transform: rotate(45deg);
    }

    .header-mobile.is-open .icon-menu span:nth-child(3) {
        top: 6px;
        transform: rotate(-45deg);
    }

    .icon-menu span:nth-child(1) {
        top: 2px;
    }

    .icon-menu span:nth-child(2) {
        top: 6px;
    }

    .icon-menu span:nth-child(3) {
        top: 10px;
    }
}

/* ==========================================================================
   LABELS / LINK STATES
   ========================================================================== */

.cat_label {
    font-size: .7rem !important;
    padding: .15rem .5rem !important;
    background-color: #096;
    line-height: .8rem;
    border-radius: 10rem;
    margin-left: .3rem !important;
    white-space: nowrap;
}

.d-flex.align-items-center:has(.cat_label) a,
.level2:has(.cat_label) a {
    max-width: 70% !important;
}

.level-top-mega [class*=submenu] li a:has(.cat_label),
.level-top-mega [class*=submenu] li.level2.nav-item a {
    display: inline-flex !important;
}

.nav-desktop .level0 .level-top-mega .content-mega-horizontal ul li a:hover,
.nav-desktop .level0 .level-top-mega .force-products-only .products-submenu li.product-item a:hover,
.nav-desktop .level0 .level-top-mega [class*=submenu] li a:hover,
.vmagicmenu .level0 .level-top-mega [class*=submenu] li a:hover,
.vmagicmenu .vmagicmenu-narrow .level0.dropdown ul li a:hover {
    color: #3e3169 !important;
}

.level-top-mega [class*=submenu] li a span.cat-name,
.level-top-mega [class*=submenu] li.level2.nav-item a .cat-name {
    display: inline-block !important;
    width: auto !important;
    max-width: none !important;
    min-width: unset !important;
    box-sizing: border-box !important;
}

.level-top-mega [class*=submenu] li a span,
.level-top-mega [class*=submenu] li a span.cat-name {
    background: linear-gradient(to right, #453572 0, #453572 100%) no-repeat left bottom;
    background-size: 0 1px;
    padding-bottom: 1px;
    transition: background-size .35s ease;
}

.level-top-mega [class*=submenu] li a:hover span,
.level-top-mega [class*=submenu] li a:hover span.cat-name {
    background-size: 100% 1px;
}

.cat-mega .level1 > div > a {
    color: #343a40;
    font-weight: 700;
}

.more-products {
    opacity: .7;
    font-style: italic;
}

/* ==========================================================================
   QUOTE / CART
   ========================================================================== */

.showquote .minicart-counter-number {
    background-color: #ac91d6;
}

/* ==========================================================================
   FOOTER
   ========================================================================== */

.col-footer li a {
    display: inline-block;
    background: linear-gradient(to right, #d899da 0, #d899da 100%) no-repeat left bottom;
    background-size: 0 1px;
    transition: background-size .35s ease;
}

.col-footer li a:hover {
    background-size: 100% 1px;
    cursor: pointer;
    color: #d899da !important;
}

.copyright-container {
    background-color: #2E2452;
}

.copyright {
    opacity: 0.4;
    font-weight: 200;
}

/* ==========================================================================
   MOBILE
   ========================================================================== */

@media screen and (max-width: 991px) {
    .miniquote-wrapper .action.showquote {
        padding: 0 1rem 0 0.3rem;
    }

    .showquote .text,
    .cart-label,
    .header-main .header-columns,
    .header-sub,
    .nav-mobile {
        display: none !important;
    }

    .header-login .login-link:before {
        background-size: 1.3rem 1.3rem;
    }

    .miniquote-wrapper .ico.ico-quote {
        width: 2.4rem;
        height: 1.3rem;
        margin-right: -0.3rem;
    }
    .minicart-wrapper .ico.ico-cart {
        width: 1.4rem;
        height: 1.4rem;
    }
    .ico-cart:before {
        font-size: 1.6rem;
    }

    .minicart-counter-number {
        margin-left: -.75rem;
    }

    .header-right.d-flex.align-items-center {
        padding-right: 0;
        width: auto;
        justify-content: flex-end;
        top: .5rem;
    }

    .navbar-brand {
        width: 30vw;
    }

    .header-main .header-main {
        padding: 1rem 0;
    }

    .header-main {
        background: transparent;
        height: 5rem;
        z-index: 91;
    }
    @media (max-width: 992px) {
      .navbar-expand-lg > .container, .navbar-expand-lg > .container-fluid {
        padding-right: .5rem !important;
        padding-left: .5rem !important;
      }
    }
    .header-mobile {
        transition: background-color .3s ease;
    }

    .header-mobile .container {
        position: fixed;
        left: 0;
        z-index: 90;
        height: 4rem !important;
        margin-top: -1px;
        background: #503877de;
        -webkit-backdrop-filter: blur(8px);
        backdrop-filter: blur(8px);
    }

    .header-mobile.is-open .container {
        background-color: #f8f8f8;
    }

    .header-mobile .header-search {
        width: 50% !important;
        flex: 0 0 70vw;
        z-index: 1;
    }

    .header-mobile .header-search .input-text {
        color: #ffffffc4;
    }

    .header-search .input-text:focus,
    .header-mobile.is-open .control input::placeholder,
    .header-mobile.is-open .header-search .action {
        color: #453572 !important;
    }

    .header-mobile.is-open .header-search input {
        border: 1px solid #4535725e;
        background: #fefefe;
    }

    .header-mobile.is-open #mobile-menu-toggle {
        color: #453572;
        background: transparent;
    }

    .header-mobile .hamburger-icon span,
    .header-mobile.is-open .hamburger-icon span {
        background: #453572;
    }

    .navigation.mean-nav.navigation-mobile {
        display: block !important;
    }

    .header-mobile .search-products-list {
        overflow-x: auto;
        flex-wrap: nowrap;
        padding-right: 2rem;
        margin-bottom: 1rem;
        width: 110%;
    }

    #mobile-menu-toggle {
        display: flex;
        align-items: center;
        gap: 10px;
        width: auto;
        height: 3rem;
        margin-left: -1.1rem;
        padding-right: 2rem;
        background: #ffffffe8;
        border: 0;
        border-radius: 0 5px 5px 0;
        cursor: pointer;
        font-size: 1rem;
        color: #503877;
    }

    #mobile-accordion-wrapper,
    .mobile-cat-flow {
        background: #fff;
        -webkit-overflow-scrolling: touch;
    }

    #mobile-accordion-wrapper {
        display: none;
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 1;
        margin-top: -2px !important;
        overflow-y: hidden;
        padding-bottom: env(safe-area-inset-bottom, 0);
        box-sizing: border-box;
    }

    #mobile-accordion-wrapper.is-open {
        display: block;
        background: #fff;
    }

    .mobile-accordion-wrapper {
        left: 0;
        right: 0;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        background: #fff;
        padding-bottom: env(safe-area-inset-bottom, 0);
        box-sizing: border-box;
    }

    .mobile-cat-flow {
        position: relative;
        overflow: hidden;
        height: 100%;
    }

    .mobile-cat-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        height: 4rem;
        padding: .5rem 1rem;
        background: #f8f8f8;
        border-bottom: 1px solid #eee;
        font-size: 18px;
    }

    .mobile-cat-back {
        position: absolute;
        background: transparent;
        border: 0;
        cursor: pointer;
        font-size: 1.2rem;
        font-weight: 600;
        line-height: 1;
        color: #717171;
    }

    .mobile-cat-back:hover,
    .mobile-cat-back:active {
        opacity: 1;
    }

    .mobile-cat-title {
        flex: 1;
        margin: 0;
        padding: 0;
        font-size: 1.2rem;
        font-weight: 600;
        text-align: center;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .mobile-cat-slider {
        display: flex;
        width: 200%;
        height: 100%;
        transform: translateX(0);
        transition: transform .4s cubic-bezier(.25, .1, .25, 1);
        will-change: transform;
        touch-action: pan-y;
    }

    .mobile-cat-root,
    .mobile-cat-detail {
        width: 50%;
        max-width: 50%;
        flex: 0 0 50%;
        margin: 0;
        padding: 0 15px;
        box-sizing: border-box;
        overflow-x: hidden;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch;
        scroll-behavior: smooth;
    }

    .mobile-cat-root {
        padding: .3rem 1rem 1rem;
        height: 100%;
    }

    .mobile-cat-detail {
        height: 100%;
        padding: 1.2rem 1rem 6rem;
    }

    .mobile-cat-root .submenu {
        display: none !important;
    }

    .mobile-cat-root li,
    .mobile-cat-detail li {
        margin: 0;
        padding: 0;
        list-style: none;
    }

    .mobile-cat-root a,
    .mobile-cat-detail a {
        display: block;
        padding: .3rem;
        color: #333;
        text-decoration: none;
        font-size: 16px;
    }

    .mobile-cat-root a.level-top {
        font-weight: 400 !important;
        font-size: 1rem;
        padding: .5rem;
    }

    .mobile-cat-root .level0,
    .mobile-cat-root .level0:hover,
    .mobile-cat-root .level0:focus,
    .mobile-cat-root .level0:active {
        padding: .6rem 0;
        border-bottom: 1px solid #f3f3f3 !important;
    }

    .mobile-cat-root .level0:last-child {
        border-bottom: none !important;
    }

    .mobile-cat-root .img-responsive {
        width: 2rem;
    }

    .mobile-cat-root .level0 .level-top::before {
        content: "";
        position: absolute;
        left: .5rem;
        top: 50%;
        width: 2.6rem;
        height: 2.6rem;
        background: rgb(62, 49, 105);
        border-radius: 10rem;
        transform: translateY(-50%);
        z-index: 1;
    }

    .mobile-cat-root .level0 .level-top img {
        position: absolute;
        left: .65rem;
        top: 50%;
        z-index: 2;
        width: 2.2rem;
        height: 2.2rem;
        padding: .4rem;
        transform: translateY(-50%);
        filter: brightness(0) invert(1);
    }

    .mobile-cat-root .level0 .level-top span {
        margin-left: 3.5rem;
    }

    .mobile-cat-detail .submenu {
        padding: 0;
    }

    .mobile-cat-detail .submenu .level1 > a {
        font-weight: 500;
        font-size: 1.2rem !important;
    }

    .mobile-cat-detail .submenu .level2 a {
        font-size: 1rem !important;
    }

    .mobile-cat-detail .level1.submenu {
        margin-bottom: 2rem;
    }

    .mobile-cat-detail .nav-item {
        border: 0 !important;
    }

    .mobile-cat-detail *,
    .mobile-cat-root * {
        -webkit-tap-highlight-color: transparent !important;
        -webkit-touch-callout: none !important;
        -webkit-user-select: none !important;
        user-select: none !important;
        outline: 0 !important;
    }

    .mobile-cat-detail a,
    .mobile-cat-detail li,
    .mobile-cat-root a,
    .mobile-cat-root li {
        -webkit-appearance: none !important;
        appearance: none !important;
        background: transparent !important;
        border: 0 !important;
    }

    .mobile-cat-detail a:active,
    .mobile-cat-detail li:active,
    .mobile-cat-root a:active,
    .mobile-cat-root li:active {
        background: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
    }

    .mobile-cat-detail a:focus,
    .mobile-cat-root a:focus,
    #mobile-menu-toggle:active,
    #mobile-menu-toggle:focus {
        outline: 0 !important;
        box-shadow: none !important;
    }

    .mobile-cat-detail .cat_label,
    .mobile-cat-root .cat_label {
        font-size: .9rem !important;
        padding: .3rem .7rem !important;
    }
}

.mega-col--hover {
    position: relative;
}

.mega-col h3 {
    margin: 0 0 8px;
    padding: 0;
    line-height: 1.2;
}

.cat-mega a,
.cat-mega .level1 a,
.cat-mega .level2 a,
.cat-mega .level3 a,
.cat-mega .submenu a {
    line-height: 1.3;
}

.column-5-items {
    margin: 0;
    padding: 0;
    list-style: none;
}

.column-5-items li {
    margin: 0;
    padding: 4px 0;
}

.column-5-items a {
    margin: 0;
    padding: 0;
    line-height: 1;
}

.magicmenu .nav-desktop .level0 .level-top-mega .children.level1 > a,
.vmagicmenu .nav-desktop .level0 .level-top-mega .children.level1 > a {
    padding: 0;
}

.placeholder-name {
    height: 0;
}

