/* =====================================================================
   WC Category List Widget
   Variables controlables desde Elementor (ver class-wc-category-list-widget.php)
   ===================================================================== */
.wccl-list {
    --wccl-align: flex-start;
    --wccl-line-color: currentColor;
    --wccl-line-size: 2px;
    --wccl-speed: 350ms;
    --wccl-divider-color: rgba(0, 0, 0, .12);
    --wccl-divider-weight: 1px;
    --wccl-count-box: 2.1em;
    --wccl-count-radius: 6px;
    --wccl-gap-label: .5em;
    --wccl-gap-arrow: .5em;

    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    align-items: var(--wccl-align);
    gap: 10px;
}

/* ---- Orientación ---------------------------------------------------- */
.wccl-list--horizontal {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: var(--wccl-align);
}

.wccl-item {
    margin: 0;
    line-height: 1.4;
    max-width: 100%;
}
.wccl-list:not(.wccl-list--horizontal) .wccl-item {
    width: 100%;
}

/* ---- Elemento clicable (a / span) ----------------------------------- */
.wccl-trigger {
    position: relative;
    display: flex;
    align-items: center;
    text-decoration: none;
    color: inherit;
    border-radius: 6px;
    box-sizing: border-box;
    transition: color var(--wccl-speed) ease,
                background-color var(--wccl-speed) ease,
                transform var(--wccl-speed) ease,
                padding var(--wccl-speed) ease;
}
.wccl-list:not(.wccl-list--horizontal):not(.wccl-list--tree) .wccl-trigger {
    width: 100%;
}

.wccl-label {
    flex: 0 1 auto;
    min-width: 0;
    margin-right: auto;
}
/* "Junto al texto": contador e icono pegados a la palabra (sin empujar a la derecha) */
.wccl-list--group .wccl-label {
    margin-right: 0;
}
.wccl-list--horizontal .wccl-label {
    flex: 0 0 auto;
    margin-right: 0;
}

/* ---- Contador ------------------------------------------------------- */
.wccl-count {
    flex: 0 0 auto;
    margin-left: var(--wccl-gap-label, .5em);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    font-size: .78em;
    font-weight: 600;
    line-height: 1;
}
/* Píldora: ancho según contenido */
.wccl-count--pill {
    padding: .25em .65em;
    border-radius: 999px;
}
/* Círculo / Cuadrado / Personalizado: caja cuadrada de tamaño fijo */
.wccl-count--circle,
.wccl-count--square,
.wccl-count--custom {
    min-width: var(--wccl-count-box);
    height: var(--wccl-count-box);
    padding: 0 .35em;
}
.wccl-count--circle { border-radius: 50%; }
.wccl-count--square { border-radius: 6px; }
.wccl-count--custom { border-radius: var(--wccl-count-radius); }

/* ---- Flecha --------------------------------------------------------- */
.wccl-arrow {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    margin-left: var(--wccl-gap-arrow, .5em);
    transition: transform var(--wccl-speed) ease, opacity var(--wccl-speed) ease;
}
.wccl-arrow svg,
.wccl-arrow img {
    width: 1em;
    height: 1em;
    fill: currentColor;
}
.wccl-arrow i {
    font-size: inherit;
    line-height: 1;
}
.wccl-item:hover .wccl-arrow,
.wccl-item.is-active .wccl-arrow {
    transform: translateX(.3em);
}

/* ---- Separadores ----------------------------------------------------
   El separador va en el borde inferior del propio ítem clicable, así
   coincide con la línea del hover (en vez de quedar separados). El
   espacio texto↔línea lo controla el padding inferior del ítem. */
.wccl-list--divided:not(.wccl-list--horizontal) .wccl-item:not(:last-child) .wccl-trigger {
    border-bottom: var(--wccl-divider-weight) solid var(--wccl-divider-color);
}
.wccl-list--divided.wccl-list--horizontal .wccl-item:not(:last-child) .wccl-trigger {
    border-right: var(--wccl-divider-weight) solid var(--wccl-divider-color);
}
/* El subrayado del hover se dibuja justo encima del separador. */
.wccl-list--divided.wccl-list--anim-underline .wccl-trigger::after,
.wccl-list--divided.wccl-list--anim-underline-center .wccl-trigger::after {
    bottom: calc(-1 * var(--wccl-divider-weight));
}

/* ---- Estado vacío --------------------------------------------------- */
.wccl-empty {
    margin: 0;
    opacity: .6;
    font-style: italic;
}

/* =====================================================================
   ANIMACIONES HOVER (estilo "line draw")
   Cada variante se activa con la clase .wccl-list--anim-*
   ===================================================================== */

/* 1) Subrayado: se dibuja de izquierda a derecha ---------------------- */
.wccl-list--anim-underline .wccl-trigger::after,
.wccl-list--anim-underline-center .wccl-trigger::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: var(--wccl-line-size);
    background: var(--wccl-line-color);
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform var(--wccl-speed) ease;
    pointer-events: none;
}
.wccl-list--anim-underline-center .wccl-trigger::after {
    transform-origin: center;
}
.wccl-list--anim-underline .wccl-item:hover .wccl-trigger::after,
.wccl-list--anim-underline .wccl-item.is-active .wccl-trigger::after,
.wccl-list--anim-underline-center .wccl-item:hover .wccl-trigger::after,
.wccl-list--anim-underline-center .wccl-item.is-active .wccl-trigger::after {
    transform: scaleX(1);
}

/* 2) Línea lateral + sangría ------------------------------------------ */
.wccl-list--anim-border-line .wccl-trigger::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: var(--wccl-line-size);
    background: var(--wccl-line-color);
    border-radius: var(--wccl-line-size);
    transform: scaleY(0);
    transform-origin: center top;
    transition: transform var(--wccl-speed) ease;
    pointer-events: none;
}
.wccl-list--anim-border-line .wccl-item:hover .wccl-trigger,
.wccl-list--anim-border-line .wccl-item.is-active .wccl-trigger {
    transform: translateX(.4em);
}
.wccl-list--anim-border-line .wccl-item:hover .wccl-trigger::before,
.wccl-list--anim-border-line .wccl-item.is-active .wccl-trigger::before {
    transform: scaleY(1);
}

/* 3) Borde dibujado (caja): 4 lados que se trazan --------------------- */
.wccl-list--anim-box .wccl-trigger {
    background-image:
        linear-gradient(90deg, var(--wccl-line-color), var(--wccl-line-color)),
        linear-gradient(90deg, var(--wccl-line-color), var(--wccl-line-color)),
        linear-gradient(0deg,  var(--wccl-line-color), var(--wccl-line-color)),
        linear-gradient(0deg,  var(--wccl-line-color), var(--wccl-line-color));
    background-repeat: no-repeat;
    background-size:
        0% var(--wccl-line-size),
        0% var(--wccl-line-size),
        var(--wccl-line-size) 0%,
        var(--wccl-line-size) 0%;
    background-position: 0 0, 100% 100%, 0 100%, 100% 0;
    transition: background-size var(--wccl-speed) ease, color var(--wccl-speed) ease;
}
.wccl-list--anim-box .wccl-item:hover .wccl-trigger,
.wccl-list--anim-box .wccl-item.is-active .wccl-trigger {
    background-size:
        100% var(--wccl-line-size),
        100% var(--wccl-line-size),
        var(--wccl-line-size) 100%,
        var(--wccl-line-size) 100%;
}

/* 4) Relleno deslizante ----------------------------------------------- */
.wccl-list--anim-fill .wccl-trigger {
    z-index: 0;
    overflow: hidden;
    isolation: isolate;
}
.wccl-list--anim-fill .wccl-trigger::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background: var(--wccl-line-color);
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform var(--wccl-speed) ease;
    pointer-events: none;
}
.wccl-list--anim-fill .wccl-item:hover .wccl-trigger::before,
.wccl-list--anim-fill .wccl-item.is-active .wccl-trigger::before {
    transform: scaleX(1);
}

/* 5) Deslizar texto --------------------------------------------------- */
.wccl-list--anim-slide .wccl-item:hover .wccl-trigger,
.wccl-list--anim-slide .wccl-item.is-active .wccl-trigger {
    transform: translateX(.4em);
}

/* =====================================================================
   MODO ÁRBOL (acordeón)
   ===================================================================== */
.wccl-list--tree {
    --wccl-tree-indent: 16px;
}
/* Fila: enlace + botón de despliegue, uno al lado del otro */
.wccl-list--tree .wccl-row {
    display: flex;
    align-items: center;
    width: 100%;
}
.wccl-list--tree .wccl-trigger {
    flex: 1 1 auto;
    width: auto;
}
/* Botón para desplegar/colapsar los hijos */
.wccl-toggle {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0;
    padding: .25em .4em;
    background: none;
    border: 0;
    color: inherit;
    cursor: pointer;
    line-height: 1;
    font: inherit;
}
.wccl-toggle-icon {
    display: inline-flex;
    transition: transform var(--wccl-speed) ease;
}
.wccl-toggle-icon svg {
    width: 1em;
    height: 1em;
}
.wccl-item.is-open > .wccl-row .wccl-toggle-icon {
    transform: rotate(90deg);
}
/* Contenedor animable de los hijos: grid 0fr -> 1fr (altura suave, sin números mágicos) */
.wccl-sub {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows var(--wccl-speed) ease;
}
.wccl-item.is-open > .wccl-sub {
    grid-template-rows: 1fr;
}
.wccl-sub > .wccl-sublist {
    overflow: hidden;
    min-height: 0;
}
/* Sublista anidada */
.wccl-sublist {
    list-style: none;
    margin: 0;
    padding: var(--wccl-gap, 10px) 0 0 var(--wccl-tree-indent, 16px);
    display: flex;
    flex-direction: column;
    gap: var(--wccl-gap, 10px);
}
/* Línea guía opcional a la izquierda de cada subnivel */
.wccl-list--tree-guide .wccl-sublist {
    border-left: var(--wccl-divider-weight, 1px) solid var(--wccl-divider-color);
    padding-left: calc(var(--wccl-tree-indent, 16px) - var(--wccl-divider-weight, 1px));
    margin-left: 2px;
}

/* =====================================================================
   Accesibilidad: respeta "reducir movimiento"
   ===================================================================== */
@media (prefers-reduced-motion: reduce) {
    .wccl-trigger,
    .wccl-trigger::before,
    .wccl-trigger::after,
    .wccl-arrow,
    .wccl-sub,
    .wccl-toggle-icon {
        transition-duration: .01ms !important;
    }
}
