.mbx-catalog {
    --catalog-brand: #d29a67;
    --catalog-brand-strong: #b77a44;
    --catalog-ink: #2f2922;
    --catalog-muted: #7d6e5d;
    --catalog-soft: #fdf8f1;
    --catalog-stroke: #eadfce;
    position: relative;
    display: flex;
    align-items: center;
    z-index: 520;
}

.mbx-catalog .btn-categorias {
    display: inline-flex !important;
    align-items: center;
    gap: 7px;
    border: 1px solid rgba(247, 195, 121, 0.42);
    border-radius: 12px;
    padding: 8px 12px;
    background: rgba(255, 208, 142, 0.14);
    color: #ffd89f;
    font-weight: 650;
    letter-spacing: 0.02em;
    box-shadow: none;
    transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
    cursor: pointer;
}

.mbx-catalog .btn-categorias i {
    font-size: 14px;
}

.mbx-catalog .btn-categorias span {
    font-size: 15px;
    line-height: 1;
}

.mbx-catalog .btn-categorias small {
    background: rgba(255, 209, 143, 0.24);
    border: 1px solid rgba(247, 195, 121, 0.48);
    border-radius: 999px;
    padding: 3px 7px;
    font-size: 11px;
    font-weight: 700;
    color: #ffe4bc;
    line-height: 1;
}

.mbx-catalog .btn-categorias:hover,
.mbx-catalog .btn-categorias:focus-visible {
    border-color: rgba(255, 203, 128, 0.75);
    background: rgba(255, 214, 155, 0.22);
    box-shadow: 0 10px 22px -16px rgba(255, 186, 88, 0.55);
}

.mbx-catalog .contenedor-grid {
    position: relative;
}

.mbx-catalog .grid {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    width: min(940px, calc(100vw - 26px));
    max-height: min(78vh, 720px);
    background: #fff7e8;
    border-radius: 18px;
    border: 1px solid #e8d2ac;
    box-shadow: 0 24px 52px -34px rgba(119, 82, 41, 0.45);
    overflow: hidden;
    display: grid;
    grid-template-columns: 270px minmax(360px, 1fr);
    grid-template-rows: auto auto minmax(260px, 1fr);
    grid-template-areas:
        "head head"
        "featured featured"
        "categorias subcategorias";
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(10px) scale(0.985);
    transform-origin: top left;
    transition: opacity .2s ease, transform .2s ease, visibility .2s ease;
}

.mbx-catalog .grid.activo {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0) scale(1);
}

.mbx-catalog .grid-head {
    grid-area: head;
    display: grid;
    grid-template-columns: 1.25fr auto 1fr;
    gap: 12px;
    align-items: center;
    padding: 18px 18px 16px;
    background:
        radial-gradient(120% 120% at 100% 0%, rgba(255, 196, 118, 0.28) 0%, rgba(255, 255, 255, 0) 60%),
        radial-gradient(120% 120% at 0% 100%, rgba(255, 226, 171, 0.35) 0%, rgba(255, 255, 255, 0) 64%),
        linear-gradient(180deg, #fff9ec 0%, #f9ebcf 100%);
    border-bottom: 1px solid #ead5b2;
}

.mbx-catalog .grid-head__meta strong {
    display: block;
    color: var(--catalog-ink);
    font-size: 18px;
    line-height: 1.15;
}

.mbx-catalog .grid-head__meta small {
    display: block;
    margin-top: 4px;
    color: var(--catalog-muted);
    font-size: 13px;
}

.mbx-catalog .grid-head__shortcuts {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 6px;
}

.mbx-catalog .grid-head__shortcuts a {
    border: 1px solid #e7cfae;
    border-radius: 999px;
    padding: 6px 10px;
    color: #6b4f30;
    background: #fffaf1;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    transition: background .15s ease, border-color .15s ease, color .15s ease;
}

.mbx-catalog .grid-head__shortcuts a:hover {
    background: #fff2dd;
    border-color: #dab27f;
    color: #874910;
}

.mbx-catalog .grid-head__search {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 8px;
}

.mbx-catalog .grid-head__search input {
    width: 100%;
    border: 1px solid #e1c9a4;
    border-radius: 11px;
    height: 41px;
    padding: 0 12px;
    font-size: 14px;
    color: var(--catalog-ink);
    background: #fffaf2;
    outline: none;
    transition: border-color .15s ease, box-shadow .15s ease;
}

.mbx-catalog .grid-head__search input:focus {
    border-color: #d9af76;
    box-shadow: 0 0 0 3px rgba(217, 175, 118, 0.22);
}

.mbx-catalog .grid-head__search button {
    width: 41px;
    height: 41px;
    border: 1px solid #e2caab;
    border-radius: 11px;
    background: #ffffff;
    color: #7a5b3b;
    cursor: pointer;
}

.mbx-catalog .grid-head__search button:hover {
    color: #694724;
    border-color: #d9af76;
    background: #fff0db;
}

.mbx-catalog .grid-featured {
    grid-area: featured;
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    padding: 10px 16px 12px;
    background: #fff8ea;
    border-bottom: 1px solid #ead6b5;
}

.mbx-catalog .grid-featured > span {
    color: #7c6d5e;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.mbx-catalog .grid-featured__links {
    display: flex;
    gap: 7px;
    flex-wrap: wrap;
}

.mbx-catalog .grid-featured__links a {
    background: #fff3de;
    border: 1px solid #e3c6a0;
    color: #6b4f30;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    padding: 5px 10px;
    text-decoration: none;
}

.mbx-catalog .grid-featured__links a:hover {
    color: #84470d;
    border-color: #d9af76;
    background: #ffeccf;
}

.mbx-catalog .categorias {
    grid-area: categorias;
    border-right: 1px solid #e8d2ac;
    background: #f9edd7;
    overflow-y: auto;
    padding: 10px 8px;
}

.mbx-catalog .categorias a {
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    gap: 8px;
    color: #463a2f;
    font-size: 14px;
    text-decoration: none;
    border-radius: 10px;
    padding: 9px 10px;
    margin: 2px 0;
    transition: background .14s ease, color .14s ease;
}

.mbx-catalog .categorias a small {
    font-size: 11px;
    border-radius: 999px;
    background: #f7e8d2;
    border: 1px solid #e1c4a1;
    color: #6a5034;
    font-weight: 700;
    padding: 2px 6px;
}

.mbx-catalog .categorias a i {
    font-size: 12px;
    color: #9e7e5f;
}

.mbx-catalog .categorias a:hover {
    background: #ffe9c9;
    color: #7d430f;
}

.mbx-catalog .categorias a.is-active {
    background: linear-gradient(90deg, #efd1a6 0%, #f3dfbe 58%, #f9ecd9 100%);
    color: #6e3a0f;
    font-weight: 700;
}

.mbx-catalog .categorias a.is-hidden {
    display: none;
}

.mbx-catalog .contenedor-subcategorias {
    grid-area: subcategorias;
    padding: 14px 14px 16px;
    background: #fff7e8;
    overflow-y: auto;
}

.mbx-catalog .subcategoria-empty {
    border: 1px dashed #dfbf96;
    border-radius: 14px;
    padding: 20px;
    text-align: center;
    background: #fff2df;
    color: #7a6b5a;
}

.mbx-catalog .subcategoria-empty h4 {
    margin: 0 0 8px;
    color: #4f402f;
    font-size: 17px;
}

.mbx-catalog .subcategoria-empty p {
    margin: 0;
    font-size: 14px;
}

.mbx-catalog .subcategoria-empty--search {
    border-color: #dfba89;
    background: #ffefd8;
}

.mbx-catalog .subcategoria-empty[hidden] {
    display: none !important;
}

.mbx-catalog .subcategoria {
    display: none;
}

.mbx-catalog .subcategoria.activo {
    display: block;
}

.mbx-catalog .subcategoria-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 12px;
}

.mbx-catalog .subcategoria-head h4 {
    margin: 0;
    color: #413629;
    font-size: 20px;
}

.mbx-catalog .subcategoria-head a {
    color: #8b4b12;
    font-size: 13px;
    font-weight: 700;
    text-decoration: none;
}

.mbx-catalog .subcategoria-head a:hover {
    text-decoration: underline;
}

.mbx-catalog .enlaces-subcategoria {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 9px;
}

.mbx-catalog .enlaces-subcategoria a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    border: 1px solid #e5c9a8;
    border-radius: 10px;
    padding: 10px 11px;
    color: #4a3d31;
    text-decoration: none;
    background: #fff7eb;
    font-size: 13px;
    line-height: 1.25;
    transition: border-color .14s ease, background .14s ease, color .14s ease;
}

.mbx-catalog .enlaces-subcategoria a i {
    color: #9c7f5f;
    font-size: 11px;
}

.mbx-catalog .enlaces-subcategoria a:hover {
    background: #ffedd4;
    border-color: #d9ad73;
    color: #743d10;
}

.mbx-catalog .enlaces-subcategoria a.is-hidden {
    display: none;
}

.mbx-catalog .categorias::-webkit-scrollbar,
.mbx-catalog .contenedor-subcategorias::-webkit-scrollbar {
    width: 8px;
}

.mbx-catalog .categorias::-webkit-scrollbar-thumb,
.mbx-catalog .contenedor-subcategorias::-webkit-scrollbar-thumb {
    background: #d7b58e;
    border-radius: 999px;
}

@media (max-width: 1024px) {
    .mbx-catalog .grid {
        left: auto;
        right: 0;
        width: min(900px, calc(100vw - 20px));
        transform-origin: top right;
    }

    .mbx-catalog .grid-head {
        grid-template-columns: 1fr;
    }

    .mbx-catalog .grid-head__shortcuts {
        justify-content: flex-start;
    }
}

@media (max-width: 883px) {
    .mbx-catalog {
        margin-right: 0;
    }

    .mbx-catalog .btn-categorias {
        padding: 8px 10px;
        border-radius: 10px;
    }

    .mbx-catalog .btn-categorias small {
        display: none;
    }

    .mbx-catalog .grid {
        position: fixed;
        inset: 0;
        width: 100vw;
        max-height: 100dvh;
        border-radius: 0;
        border: 0;
        box-shadow: none;
        grid-template-columns: 1fr;
        grid-template-rows: auto auto minmax(170px, 0.9fr) minmax(0, 1fr);
        grid-template-areas:
            "head"
            "featured"
            "categorias"
            "subcategorias";
        transform: translateY(12px);
    }

    .mbx-catalog .grid.activo {
        transform: translateY(0);
    }

    .mbx-catalog .categorias {
        border-right: 0;
        border-bottom: 1px solid #e7edf7;
        padding-bottom: 12px;
    }

    .mbx-catalog .contenedor-subcategorias {
        padding-top: 12px;
    }
}

@media (max-width: 560px) {
    .mbx-catalog .grid-head {
        padding: 14px 12px 12px;
    }

    .mbx-catalog .grid-featured {
        padding: 8px 12px 11px;
    }

    .mbx-catalog .categorias {
        padding: 8px 7px;
    }

    .mbx-catalog .contenedor-subcategorias {
        padding: 10px 11px 14px;
    }

    .mbx-catalog .subcategoria-head h4 {
        font-size: 18px;
    }

    .mbx-catalog .enlaces-subcategoria {
        grid-template-columns: 1fr;
    }
}
