.apf-filter-wrapper{
    /*border:1px solid #ccc;*/
    height: auto !important;
    min-height: 0 !important;
    padding: 0 !important;
}

.apf-filter-wrapper .child-items{
    list-style: none;
    margin-left: 0px;
    /*height: 200px;
    overflow-y: auto;*/
}
.apf-filter-wrapper .child-items label{
    word-break: keep-all;
}
.apf-filter-wrapper .apf-filter-item {
    margin-bottom: 20px;
    border-bottom: 1px solid #eee;
    padding-bottom: 10px;
    max-height: 300px;
    overflow-y: auto;
}

.apf-filter-wrapper .apf-filter-item h4{
    font-size: 16px;
    font-weight: bold;
    height: 25px;
    color: inherit;
    line-height: inherit;
    font-family: 'Montserrat', sans-serif;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 5px 0;
    margin: 0;
}
.apf-filter-wrapper .apf-filter-item h4::after,
.apf-filter-wrapper .apf-trigger-sub::after
{
    font-size: 20px;
    font-weight: bold;
    content: '\002B'; /* Signo + */
    transition: transform 0.3s ease;
}
.apf-trigger-sub::after {
    cursor: pointer;
    display: inline-block;
    margin-left: 10px;
}
.apf-filter-wrapper .apf-filter-item.is-collapsed h4::after {
    content: '\002B'; /* Mantiene el + o puedes cambiarlo */
}
.apf-filter-wrapper .apf-filter-item.is-active h4::after {
    content: '\2212'; /* Signo - */
    transform: rotate(180deg);
}
.apf-filter-content {
    display: grid;
    grid-template-rows: 0fr; /* Cerrado por defecto */
    transition: grid-template-rows 0.4s ease-out, opacity 0.3s ease;
    opacity: 0;
    overflow: hidden;
}
/* Cuando está activo, expandimos el grid */
.apf-filter-item.is-active .apf-filter-content {
    grid-template-rows: 1fr; /* Abierto */
    opacity: 1;
    margin-top: 10px; /* Espaciado solo cuando se ve */
}

/* Este div interno es obligatorio para que el grid calcule el alto */
.apf-filter-inner {
    min-height: 0;
}

.apf-filter-wrapper .apf-filter-button{
    display: block;
    width: 100%;
    margin-top: 10px;
    padding: 10px;
    background-color: #0073aa;
    color: #fff;
    border: none;
    cursor: pointer;
}
.apf-filter-wrapper .apf-filter-button:hover{
    background-color: #005169;
}
.apf-filter-wrapper select{
    width: 100%;
    padding: 10px;
    margin-top: 10px;
    border: 1px solid #ccc;
    border-radius: 5px;
    background-color: #fff;
    color: #333;
    cursor: pointer;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    -ms-overflow-style: none;
    -webkit-tap-highlight-color: transparent;
}
/* Opacidad para el UL */
.products.apf-is-loading {
    opacity: 0.3;
    filter: blur(2px);
    pointer-events: none;
}

/* Contenedor del Spinner */
.apf-loader-container {
    position: absolute;
    z-index: 100;
    left: 50%;
    transform: translate(-50%, 50px); /* Aparece un poco abajo del inicio */
    text-align: center;
}

.apf-spinner {
    width: 50px;
    height: 50px;
    border: 5px solid #f3f3f3;
    border-top: 5px solid #A02021; /* Tu color vino */
    border-radius: 50%;
    animation: apf-spin 1s linear infinite;
}

@keyframes apf-spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}
/**
Boton
 */
.apf-filter-wrapper .show-apf-filter-button, .apf-filter-wrapper .apf-filter-button-reset{
    box-shadow: 2px 4px 10px 0px rgba(0,0,0,0.5);
    font-weight: 400;
    text-transform: uppercase;
    border-width: 2px !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
    background-color: #d45d37;
    color: #fff;
    border-color: #d45d37;
    margin: auto;
    display: block;
    font-size: 14px;
}
.apf-filter-wrapper .show-apf-filter-button:hover, .apf-filter-wrapper .apf-filter-button-reset:hover{
    color: #d45d37;
    background-color: #fff;
}
/* Estado Activo para el Padre (H4) */
.apf-filter-item.is-active h4::after {
    content: '\2212'; /* Signo - */
}
.apf-subfilter-header{
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.apf-parent:indeterminate{
    background-color: #415161; /* Color de Vinópolis */
    border-color: #415161;
}
/* Estado Activo para el Sub-filtro */
.apf-subfilter-header.is-active .apf-trigger-sub::after {
    content: '\2212'; /* Signo - */
}

/* Contenedor del sub-deslizamiento */
.apf-subfilter-content {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows 0.4s ease-out, opacity 0.3s ease;
    opacity: 0;
    overflow: hidden;
    padding-left: 25px; /* Sangría para jerarquía */
}

.apf-subfilter-header.is-active + .apf-subfilter-content {
    grid-template-rows: 1fr;
    opacity: 1;
    margin-bottom: 10px;
}

.apf-subfilter-inner {
    min-height: 0;
}
@media (max-width: 921px) {
    .apf-form {
        /*V1 no funciona*/
        /*display: grid;
        grid-template-rows: 0fr;
        opacity: 0;
        visibility: hidden;
        transition: all 0.4s ease-out;

        padding-top: 0 !important;
        padding-bottom: 0 !important;
        margin-top: 0 !important;
        overflow: hidden;*/
        /*V2 funciona pero se ve un poco mal*/

        /*height: 0;
        max-height: 0;
        overflow: hidden;
        opacity: 0;
        visibility: hidden;
        margin: 0;
        padding: 0;
        border: 0;
        transition: max-height 0.5s ease-in-out, opacity 0.3s ease, margin 0.3s ease;*/
        /*V3*/
        display: grid;
        grid-template-rows: 0fr;

        max-height: 0;

        opacity: 0;
        visibility: hidden;

        overflow: hidden;

        transition:
                grid-template-rows 0.4s ease,
                max-height 0.4s ease,
                opacity 0.3s ease;
    }
    /*v3*/
    .apf-form > * {
        overflow: hidden;
    }

    .apf-form.is-open {
        /*v1 no funciona*/
        /*grid-template-rows: 1fr;
        opacity: 1;
        visibility: visible;
        margin-top: 20px;
        padding: 15px;
        background: #fdfdfd;
        border: 1px solid #eee;*/
        /*v2 funciona pero un poco mal*/
        /*height: auto;
        max-height: 2000px;
        opacity: 1;
        visibility: visible;
        margin-top: 20px;
        padding: 15px;
        border: 1px solid #eee;*/
        /*v3    */
        grid-template-rows: 1fr;

        max-height: 1000px;

        opacity: 1;
        visibility: visible;
    }
    .apf-form.is-open {
        transform: translateY(0);
    }

    .apf-form {
        transform: translateY(-5px);
        transition: transform 0.3s ease;
    }
}

@media (min-width: 922px) {
    .btn-movil {
        display: none;
    }
}