O
/**
 * WooCommerce Category Page — Premium Redesign
 * Woodev Theme · Empório das Flores
 *
 * Design System (based on Quem Somos theme):
 *   --cat-primary:  var(--stem)   #ED3B4B  (vermelho principal)
 *   --cat-dark:     var(--leaf)   #a7212d   (hover escuro)
 *   --cat-accent:   var(--blush)  #d4937a  (rosado avermelhado)
 *   --cat-text:     var(--text)   #2a2420   (texto principal)
 *   --cat-muted:    var(--muted)  #7a6a60   (texto secundário)
 *   --cat-surface:  var(--cream)  #faf6f0   (fundo principal)
 *   --cat-gold:     var(--gold)   #c9a96e   (dourado)
 *   --cat-bg:       #f9fafb
 *   --cat-border:   #e5e7eb
 */

/* ============================================================
   0. VARIÁVEIS CSS
   ============================================================ */

/* Ocultar contagem de produtos no carousel de categorias */
.woodev-cat-count,
.shop-cat__count {
    display: none !important;
}

body.tax-product_cat,
body.tax-product_tag,
body.post-type-archive-product {
    overflow-x: hidden;
}

:root {
    --cat-primary: var(--stem);
    --cat-dark: var(--leaf);
    --cat-accent: var(--blush);
    --cat-text: var(--text);
    --cat-muted: var(--muted);
    --cat-surface: var(--cream);
    --cat-bg: #f9fafb;
    --cat-border: #e5e7eb;
    --cat-radius: 14px;
    --cat-shadow-sm: 0 1px 4px rgba(0, 0, 0, .06);
    --cat-shadow-md: 0 4px 16px rgba(0, 0, 0, .10);
    --cat-shadow-hover: 0 12px 32px rgba(201, 169, 110, .18);
    --cat-trans: .3s cubic-bezier(.4, 0, .2, 1);
}

/* ============================================================
   1. HERO BANNER DA CATEGORIA
   ============================================================ */
.cat-hero {
    position: relative;
    width: 100%;
    height: 300px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
}

.cat-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top,
            rgba(10, 5, 20, .75) 0%,
            rgba(10, 5, 20, .35) 55%,
            rgba(10, 5, 20, .10) 100%);
    z-index: 1;
}

.cat-hero__content {
    position: relative;
    z-index: 2;
    padding-bottom: 2.25rem;
}

/* Breadcrumb sobre hero */
.cat-hero .woocommerce-breadcrumb {
    display: block;
    color: rgba(255, 255, 255, .75) !important;
    font-size: .82rem;
    margin-bottom: .45rem;
    background: none;
    padding: 0;
}

.cat-hero .woocommerce-breadcrumb a {
    color: rgba(255, 255, 255, .85) !important;
    text-decoration: none;
}

.cat-hero .woocommerce-breadcrumb a:hover {
    color: #fff !important;
    text-decoration: underline;
}

.cat-hero .woocommerce-breadcrumb .separator {
    margin: 0 6px;
    opacity: .6;
}

/* Título no hero */
.cat-hero__title {
    font-family: var(--font-body);
    font-size: clamp(1.8rem, 4vw, 3rem);
    font-weight: 900;
    color: #fff;
    margin: 0 0 .5rem;
    line-height: 1.15;
    text-shadow: 0 2px 8px rgba(0, 0, 0, .3);
}

/* Título sem imagem */
.cat-hero__title--dark {
    color: var(--cat-text);
    text-shadow: none;
}

/* Descrição */
.cat-hero__desc {
    color: rgba(255, 255, 255, .88);
    font-size: .98rem;
    margin: 0 0 .75rem;
    max-width: 560px;
    line-height: 1.55;
}

.cat-hero__desc--dark {
    color: var(--cat-muted);
}

/* Meta (contagem de produtos) */
.cat-hero__meta {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
}

.cat-hero__count {
    display: inline-block;
    background: rgba(255, 255, 255, .18);
    backdrop-filter: blur(6px);
    border: 1px solid rgba(255, 255, 255, .3);
    color: #fff;
    padding: 3px 12px;
    border-radius: 50px;
    font-size: .82rem;
    font-weight: 600;
}

/* Hero sem imagem (variante) */
.cat-hero--no-image {
    height: auto;
    background: var(--cat-bg);
    border-bottom: 1px solid var(--cat-border);
    align-items: center;
    padding: 2rem 0;
}

/* ============================================================
   2. SUBCATEGORIAS (PILLS)
   ============================================================ */
.cat-subcats {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    padding: 1.5rem 0 .5rem;
}

.cat-subcat-pill {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .45rem .9rem .45rem .45rem;
    background: var(--cat-surface);
    border: 1.5px solid var(--cat-border);
    border-radius: 50px;
    text-decoration: none;
    color: var(--cat-text);
    font-size: .88rem;
    font-weight: 600;
    transition: var(--cat-trans);
    box-shadow: var(--cat-shadow-sm);
}

.cat-subcat-pill img {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    object-fit: cover;
}

.cat-subcat-pill small {
    color: var(--cat-muted);
    font-weight: 400;
}

.cat-subcat-pill:hover {
    border-color: var(--cat-primary);
    color: var(--cat-primary);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(237, 59, 75, .14);
}

/* ============================================================
   3. LAYOUT: PRODUTOS CENTRALIZADOS
   ============================================================ */
.cat-main {
    padding-top: 1.5rem;
    padding-bottom: 3rem;
}

.cat-products-center {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 15px;
    overflow-x: hidden;
}

/* Toolbar centralizado */
.cat-products-center .cat-toolbar {
    justify-content: center;
}

.cat-products-center .cat-toolbar__left,
.cat-products-center .cat-toolbar__right {
    flex: 0 1 auto;
}

.cat-products-center ul.products {
    margin: 0 auto !important;
}

/* Centraliza os produtos no desktop e tablet */
@media (min-width: 768px) {
    .cat-products-center ul.products {
        justify-content: center;
    }
}

/* Garante que não haja overflow */
body.tax-product_cat,
body.tax-product_tag,
body.post-type-archive-product {
    overflow-x: hidden;
}

@media (min-width: 992px) {
    .cat-products-center {
        max-width: 960px;
    }
}

@media (min-width: 1200px) {
    .cat-products-center {
        max-width: 1140px;
    }
}

@media (min-width: 1400px) {
    .cat-products-center {
        max-width: 1320px;
    }
}

/* ============================================================
   4. SIDEBAR DE FILTROS
   ============================================================ */
.cat-sidebar {
    position: sticky;
    top: 1rem;
    background: var(--cat-surface);
    border: 1px solid var(--cat-border);
    border-radius: var(--cat-radius);
    box-shadow: var(--cat-shadow-sm);
    overflow: hidden;
}

.cat-sidebar__body {
    padding: 1.25rem;
}

/* Widget dentro da sidebar */
.cat-sidebar .widget,
.cat-sidebar .widget_product_categories,
.cat-sidebar .woocommerce-widget-layered-nav,
.cat-sidebar .widget_price_filter {
    margin-bottom: 1.25rem;
    padding-bottom: 1.25rem;
    border-bottom: 1px solid var(--cat-border);
}

.cat-sidebar .widget:last-child,
.cat-sidebar .widget_product_categories:last-child,
.cat-sidebar .woocommerce-widget-layered-nav:last-child,
.cat-sidebar .widget_price_filter:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}

/* Títulos dos widgets */
.cat-sidebar .widgettitle,
.cat-sidebar .widget-title {
    font-size: .9rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--cat-text);
    margin-bottom: .8rem;
    padding-bottom: .5rem;
    border-bottom: 2px solid var(--cat-primary);
    display: flex;
    align-items: center;
    gap: .4rem;
}

/* Links das categorias/filtros */
.cat-sidebar .woocommerce-widget-layered-nav-list li,
.cat-sidebar .product-categories li {
    list-style: none;
    margin: 0;
}

.cat-sidebar .woocommerce-widget-layered-nav-list li a,
.cat-sidebar .product-categories li a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .4rem .6rem;
    border-radius: 8px;
    color: var(--cat-muted);
    font-size: .9rem;
    text-decoration: none;
    transition: var(--cat-trans);
}

.cat-sidebar .woocommerce-widget-layered-nav-list li a:hover,
.cat-sidebar .product-categories li a:hover,
.cat-sidebar .woocommerce-widget-layered-nav-list li.chosen a {
    background: rgba(237, 59, 75, .08);
    color: var(--cat-primary);
    font-weight: 600;
}

.cat-sidebar .woocommerce-widget-layered-nav-list .count,
.cat-sidebar .product-categories .count {
    background: var(--cat-bg);
    border-radius: 50px;
    padding: 1px 8px;
    font-size: .78rem;
    color: var(--cat-muted);
}

/* Price filter */
.cat-sidebar .price_slider_wrapper .ui-slider {
    height: 4px;
    background: var(--cat-bg);
    border: none;
    border-radius: 2px;
}

.cat-sidebar .price_slider_wrapper .ui-slider-range {
    background: var(--cat-primary);
}

.cat-sidebar .price_slider_wrapper .ui-slider-handle {
    width: 18px;
    height: 18px;
    background: #fff;
    border: 2.5px solid var(--cat-primary);
    border-radius: 50%;
    top: -7px;
    cursor: grab;
    transition: var(--cat-trans);
}

.cat-sidebar .price_slider_wrapper .ui-slider-handle:hover,
.cat-sidebar .price_slider_wrapper .ui-slider-handle:active {
    background: var(--cat-primary);
}

.cat-sidebar .price_slider_amount {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: .75rem;
    gap: .5rem;
}

.cat-sidebar .price_slider_amount input[type="text"] {
    font-weight: 700;
    color: var(--cat-primary);
    background: none;
    border: none;
    width: auto;
    font-size: .95rem;
}

.cat-sidebar .price_slider_amount button {
    padding: .4rem 1rem;
    background: var(--cat-primary);
    color: #fff;
    border: none;
    border-radius: 6px;
    font-size: .82rem;
    font-weight: 700;
    cursor: pointer;
    transition: var(--cat-trans);
}

.cat-sidebar .price_slider_amount button:hover {
    background: var(--cat-dark);
}

/* ============================================================
   5. TOOLBAR - Design Limpo e Moderno
   ============================================================ */
.cat-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 1rem;
    padding: 1rem 0;
    background: transparent;
    border: none;
    border-radius: 0;
    margin-bottom: 1.5rem;
    box-shadow: none;
    position: relative;
    top: 0;
    z-index: 50;
}

.cat-toolbar__left {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.cat-toolbar__left .woocommerce-result-count {
    font-size: .9rem;
    color: #6b7280;
    margin: 0;
    font-weight: 500;
}

.cat-toolbar__right {
    display: flex;
    align-items: center;
    gap: 1rem;
}

/* Select de ordenação - Estilo moderno */
.cat-toolbar .woocommerce-ordering {
    margin: 0 !important;
}

.cat-toolbar .woocommerce-ordering select {
    padding: 10px 36px 10px 14px;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    background-color: #fff;
    color: #374151;
    font-size: .875rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    min-width: 180px;
}

.cat-toolbar .woocommerce-ordering select:hover {
    border-color: #d1d5db;
}

.cat-toolbar .woocommerce-ordering select:focus {
    outline: none;
    border-color: #ED3B4B;
    box-shadow: 0 0 0 3px rgba(237, 59, 75, 0.1);
}

/* ============================================================
   6. GRID DE PRODUTOS — estilo ecommerce
   ============================================================ */

/* Grid padrão - 3 colunas no desktop */
.cat-products-center ul.products,
#catProductsArea ul.products,
.cat-products-area ul.products,
body.post-type-archive-product ul.products,
body.tax-product_cat ul.products,
body.tax-product_tag ul.products {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 20px !important;
    margin: 0 !important;
    padding: 5px 0 !important;
    border-top: none !important;
    list-style: none !important;
    float: none !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

/* Remove pseudo-elementos que podem causar espaço vazio */
.cat-products-center ul.products::before,
.cat-products-center ul.products::after,
#catProductsArea ul.products::before,
#catProductsArea ul.products::after,
.cat-products-area ul.products::before,
.cat-products-area ul.products::after,
body.tax-product_cat ul.products::before,
body.tax-product_cat ul.products::after,
body.tax-product_tag ul.products::before,
body.tax-product_tag ul.products::after,
body.post-type-archive-product ul.products::before,
body.post-type-archive-product ul.products::after {
    display: none !important;
    content: none !important;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    flex: 0 !important;
}

/* Garante que os itens não tenham float */
.cat-products-center ul.products li.product,
#catProductsArea ul.products li.product,
.cat-products-area ul.products li.product,
body.tax-product_cat ul.products li.product,
body.tax-product_tag ul.products li.product,
body.post-type-archive-product ul.products li.product {
    clear: none !important;
    float: none !important;
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    flex: none !important;
}

/* Sobrescreve classes de colunas do WooCommerce - evita stretch */
.cat-products-center ul.products.columns-1 li.product,
.cat-products-center ul.products.columns-2 li.product,
.cat-products-center ul.products.columns-3 li.product,
.cat-products-center ul.products.columns-4 li.product,
.cat-products-center ul.products.columns-5 li.product,
.cat-products-center ul.products.columns-6 li.product,
ul.products.columns-1 li.product,
ul.products.columns-2 li.product,
ul.products.columns-3 li.product,
ul.products.columns-4 li.product,
ul.products.columns-5 li.product,
ul.products.columns-6 li.product {
    width: auto !important;
    margin: 0 !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
    padding: 0 !important;
    float: none !important;
    clear: none !important;
    flex: 0 1 auto !important;
    max-width: none !important;
    min-width: 0 !important;
}

/* Reset de TUDO que WooCommerce coloca em ul.products (columns-N) */
#catProductsArea ul.products.columns-1,
#catProductsArea ul.products.columns-2,
#catProductsArea ul.products.columns-3,
#catProductsArea ul.products.columns-4,
#catProductsArea ul.products.columns-5,
#catProductsArea ul.products.columns-6,
.cat-products-area ul.products.columns-1,
.cat-products-area ul.products.columns-2,
.cat-products-area ul.products.columns-3,
.cat-products-area ul.products.columns-4,
.cat-products-area ul.products.columns-5,
.cat-products-area ul.products.columns-6,
body.post-type-archive-product ul.products.columns-1,
body.post-type-archive-product ul.products.columns-2,
body.post-type-archive-product ul.products.columns-3,
body.post-type-archive-product ul.products.columns-4,
body.post-type-archive-product ul.products.columns-5,
body.post-type-archive-product ul.products.columns-6,
body.tax-product_cat ul.products.columns-1,
body.tax-product_cat ul.products.columns-2,
body.tax-product_cat ul.products.columns-3,
body.tax-product_cat ul.products.columns-4,
body.tax-product_cat ul.products.columns-5,
body.tax-product_cat ul.products.columns-6,
body.tax-product_tag ul.products.columns-1,
body.tax-product_tag ul.products.columns-2,
body.tax-product_tag ul.products.columns-3,
body.tax-product_tag ul.products.columns-4,
body.tax-product_tag ul.products.columns-5,
body.tax-product_tag ul.products.columns-6 {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 20px !important;
    margin: 0 !important;
    padding: 5px 15px !important;
    border: none !important;
    list-style: none !important;
    float: none !important;
    width: 100% !important;
}


/* Modo lista */
#catProductsArea ul.products.list-view,
.cat-products-area ul.products.list-view {
    grid-template-columns: 1fr !important;
}

/* ============================================================
   7. CARD DO PRODUTO — PREMIUM (estilo carousel)
   ============================================================ */
#catProductsArea ul.products li.product,
.cat-products-area ul.products li.product,
body.post-type-archive-product ul.products li.product,
body.tax-product_cat ul.products li.product,
body.tax-product_tag ul.products li.product {
    /* Anula o width: 48% do WooCommerce para qualquer columns-N */
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    float: none !important;
    margin: 0 !important;
    /* Design premium estilo carousel */
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow: hidden !important;
    transition: transform 0.3s ease !important;
    position: relative !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    animation: cat-fadein .45s ease both;
}

/* Product Card - Estilo Ecommerce Moderno */
.woodev-product-card {
    background: transparent;
    overflow: visible !important; /* CORREÇÃO: Permite botão aparecer no hover */
    transition: transform 0.3s ease;
    height: 100%;
    padding-bottom: 20px; /* CORREÇÃO: Espaço para o botão no hover */
    position: relative; /* CORREÇÃO: Para posicionamento absoluto do botão */
}

.woodev-product-card:hover {
    transform: translateY(-4px);
}

/* Link que envolve apenas a imagem do produto */
.woodev-product-image-link {
    text-decoration: none;
    color: inherit;
    display: block;
}

/* Link do título do produto */
.woodev-product-title a {
    text-decoration: none;
    color: inherit;
    transition: color 0.2s ease;
}

.woodev-product-title a:hover {
    color: #ED3B4B;
}

.woodev-product-image {
    position: relative;
    aspect-ratio: 1;
    overflow: hidden;
    background: #f5f5f5;
    border-radius: 8px;
}

.woodev-product-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.woodev-product-card:hover .woodev-product-image img {
    transform: scale(1.05);
}

/* Badges */
.woodev-badge {
    position: absolute;
    top: 10px;
    left: 10px;
    padding: 4px 10px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    background: #ED3B4B;
    color: #fff;
    border-radius: 4px;
    z-index: 2;
}

.woodev-badge-sale {
    background: #ED3B4B;
}

.woodev-badge-out {
    background: #6b7280;
}

/* Quick Add Button - Moderno, Minimalista e Clean */
.woodev-quick-add {
    position: absolute !important;
    bottom: 12px !important;
    left: 50% !important;
    transform: translateX(-50%) translateY(60px) !important;
    background: #ffffff !important;
    border: 1px solid #e5e5e5 !important;
    border-radius: 50px !important;
    padding: 12px 24px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: #2a2420 !important;
    cursor: pointer;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06) !important;
    opacity: 0;
    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
    z-index: 3;
    text-decoration: none !important;
    letter-spacing: 0.02em;
}

.woodev-quick-add svg {
    stroke: #ca2b39 !important;
    flex-shrink: 0;
    width: 14px !important;
    height: 14px !important;
}

.woodev-product-card:hover .woodev-quick-add,
.woodev-product-card:focus-within .woodev-quick-add {
    transform: translateX(-50%) translateY(0) !important;
    opacity: 1 !important;
    z-index: 10;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1) !important;
}

.woodev-quick-add:hover {
    background: #ca2b39 !important;
    border-color: #ca2b39 !important;
    color: #ffffff !important;
    text-decoration: none !important;
    transform: translateX(-50%) translateY(0) scale(1.02) !important;
}

.woodev-quick-add:hover svg {
    stroke: #ffffff !important;
}

/* ============================================================
   CAROUSEL - Botão Quick Add Centralizado
   Design System: docs/category-page-styles.md
   ============================================================ */

/* Container do carousel */
.woodev-carousel,
.woodev-product-carousel {
    --stem: #ca2b39;
    --leaf: #a7212d;
    --text: #2a2420;
    --ease: cubic-bezier(.25, .46, .45, .94);
}

/* Track do carousel */
.woodev-carousel .woodev-carousel-track,
.woodev-product-carousel .woodev-carousel-track {
    display: flex !important;
    gap: 1.5rem !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    scroll-behavior: smooth !important;
    padding: 1rem 0 !important;
}

.woodev-carousel .woodev-carousel-track::-webkit-scrollbar,
.woodev-product-carousel .woodev-carousel-track::-webkit-scrollbar {
    display: none !important;
}

/* Item do carousel */
.woodev-carousel .woodev-carousel-item,
.woodev-product-carousel .woodev-carousel-item {
    flex: 0 0 auto !important;
    width: 280px !important;
    scroll-snap-align: start !important;
}

/* Card do produto no carousel */
.woodev-carousel .woodev-product-card,
.woodev-product-carousel .woodev-product-card {
    overflow: visible !important;
    position: relative !important;
    padding-bottom: 20px !important;
    background: transparent !important;
    border: none !important;
    border-radius: 12px !important;
    transition: all 0.3s var(--ease) !important;
}

.woodev-carousel .woodev-product-card:hover,
.woodev-product-carousel .woodev-product-card:hover {
    transform: translateY(-4px) !important;
}

/* Quick Add Button - conforme docs/category-page-styles.md */
.woodev-carousel .woodev-quick-add,
.woodev-product-carousel .woodev-quick-add {
    position: absolute !important;
    bottom: 12px !important;
    left: 50% !important;
    transform: translateX(-50%) translateY(60px) !important;
    background: #ffffff !important;
    border: 1px solid #e5e5e5 !important;
    border-radius: 50px !important;
    padding: 12px 24px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: #2a2420 !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06) !important;
    opacity: 0;
    transition: all 0.3s var(--ease) !important;
    z-index: 3;
    text-decoration: none !important;
    letter-spacing: 0.02em;
}

.woodev-carousel .woodev-quick-add svg,
.woodev-product-carousel .woodev-quick-add svg {
    stroke: var(--stem) !important;
    flex-shrink: 0;
    width: 14px !important;
    height: 14px !important;
}

/* Hover - conforme docs */
.woodev-carousel .woodev-product-card:hover .woodev-quick-add,
.woodev-product-carousel .woodev-product-card:hover .woodev-quick-add,
.woodev-carousel .woodev-product-card:focus-within .woodev-quick-add,
.woodev-product-carousel .woodev-product-card:focus-within .woodev-quick-add {
    transform: translateX(-50%) translateY(0) !important;
    opacity: 1 !important;
    z-index: 10;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1) !important;
}

.woodev-carousel .woodev-quick-add:hover,
.woodev-product-carousel .woodev-quick-add:hover {
    background: var(--stem) !important;
    border-color: var(--stem) !important;
    color: #ffffff !important;
    text-decoration: none !important;
    transform: translateX(-50%) translateY(0) scale(1.02) !important;
}

.woodev-carousel .woodev-quick-add:hover svg,
.woodev-product-carousel .woodev-quick-add:hover svg {
    stroke: #ffffff !important;
}

/* Navigation buttons do carousel */
.woodev-carousel .woodev-carousel-nav,
.woodev-product-carousel .woodev-carousel-nav {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 40px !important;
    height: 40px !important;
    background: #fff !important;
    border: 1.5px solid #e5e5e5 !important;
    border-radius: 50% !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.3s var(--ease) !important;
    z-index: 10 !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
}

.woodev-carousel .woodev-carousel-nav:hover,
.woodev-product-carousel .woodev-carousel-nav:hover {
    background: var(--stem) !important;
    border-color: var(--stem) !important;
    color: #fff !important;
}

.woodev-carousel .woodev-carousel-prev,
.woodev-product-carousel .woodev-carousel-prev {
    left: 0 !important;
}

.woodev-carousel .woodev-carousel-next,
.woodev-product-carousel .woodev-carousel-next {
    right: 0 !important;
}

/* Header do carousel */
.woodev-carousel .woodev-carousel-header,
.woodev-product-carousel .woodev-carousel-header {
    margin-bottom: 1.5rem !important;
    text-align: center !important;
}

.woodev-carousel .woodev-carousel-title,
.woodev-product-carousel .woodev-carousel-title {
    font-family: var(--ff-head) !important;
    font-size: clamp(1.8rem, 3vw, 2.5rem) !important;
    font-weight: 300 !important;
    color: var(--text) !important;
    margin: 0 !important;
}

.woodev-carousel .woodev-carousel-subtitle,
.woodev-product-carousel .woodev-carousel-subtitle {
    font-family: var(--ff-body) !important;
    font-size: 0.8rem !important;
    color: var(--muted) !important;
    letter-spacing: 0.1em !important;
    text-transform: uppercase !important;
}

/* Responsive */
@media (max-width: 768px) {
    .woodev-carousel .woodev-carousel-item,
    .woodev-product-carousel .woodev-carousel-item {
        width: 220px !important;
    }
    
    .woodev-carousel .woodev-carousel-nav,
    .woodev-product-carousel .woodev-carousel-nav {
        display: none !important;
    }
}

/* ============================================================
   BOTÃO ADICIONAR AO CARRINHO - Apenas centralizar
   ============================================================ */

/* Quick Add Button - Centralizado */
.woodev-quick-add {
    position: absolute !important;
    bottom: 12px !important;
    left: 50% !important;
    transform: translateX(-50%) translateY(60px) !important;
    opacity: 0;
    transition: all 0.3s ease !important;
    z-index: 3;
}

.woodev-product-card:hover .woodev-quick-add,
.woodev-product-card:focus-within .woodev-quick-add {
    transform: translateX(-50%) translateY(0) !important;
    opacity: 1 !important;
    z-index: 10;
}

.woodev-quick-add.loading {
    pointer-events: none;
    opacity: 0.7;
}

.woodev-quick-add.added {
    display: none !important;
}

.woodev-product-info {
    padding: 14px 4px 4px;
}

.woodev-product-title {
    font-size: 14px;
    font-weight: 600;
    color: #1f2937;
    margin: 0 0 8px;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-family: var(--font-body);
    min-height: 2.8em;
}

.woodev-product-price {
    font-size: 18px;
    font-weight: 800;
    color: #ED3B4B;
    font-family: var(--font-body);
    margin-bottom: 4px;
}

.woodev-product-price ins {
    text-decoration: none;
}

.woodev-product-price del {
    color: #9ca3af;
    font-size: 13px;
    font-weight: 500;
    margin-right: 8px;
    text-decoration: line-through;
}

.woodev-installments {
    font-size: 11px;
    color: #059669;
    font-weight: 600;
    margin-top: 4px;
}

#catProductsArea ul.products li.product:nth-child(1) {
    animation-delay: .04s;
}

#catProductsArea ul.products li.product:nth-child(2) {
    animation-delay: .09s;
}

#catProductsArea ul.products li.product:nth-child(3) {
    animation-delay: .14s;
}

#catProductsArea ul.products li.product:nth-child(4) {
    animation-delay: .19s;
}

#catProductsArea ul.products li.product:nth-child(5) {
    animation-delay: .24s;
}

#catProductsArea ul.products li.product:nth-child(6) {
    animation-delay: .29s;
}

#catProductsArea ul.products li.product:nth-child(7) {
    animation-delay: .34s;
}

#catProductsArea ul.products li.product:nth-child(8) {
    animation-delay: .39s;
}

#catProductsArea ul.products li.product:nth-child(9) {
    animation-delay: .44s;
}

@keyframes cat-fadein {
    from {
        opacity: 0;
        transform: translateY(16px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

#catProductsArea ul.products li.product:hover,
.cat-products-area ul.products li.product:hover {
    border-color: rgba(237, 59, 75, .3) !important;
    box-shadow: var(--cat-shadow-hover) !important;
    transform: translateY(-5px) !important;
}

/* Imagem do produto */
#catProductsArea ul.products li.product a.woocommerce-loop-product__link,
.cat-products-area ul.products li.product a.woocommerce-loop-product__link {
    display: block !important;
    overflow: hidden !important;
    text-decoration: none !important;
}

/* Imagem do produto - estilo carousel */
#catProductsArea ul.products li.product img,
.cat-products-area ul.products li.product img,
body.tax-product_cat ul.products li.product img,
body.tax-product_tag ul.products li.product img,
body.post-type-archive-product ul.products li.product img {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 !important;
    object-fit: cover !important;
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 2px !important;
    transition: transform 0.4s ease !important;
    float: none !important;
}

/* Link "Ver carrinho" pós-adição */
#catProductsArea ul.products li.product .added_to_cart,
.cat-products-area ul.products li.product .added_to_cart {
    display: block !important;
    text-align: center !important;
    font-size: .8rem !important;
    font-weight: 600 !important;
    color: var(--cat-primary) !important;
    padding: .35rem 1rem .6rem !important;
    text-decoration: none !important;
    background: rgba(237, 59, 75, .06) !important;
}

#catProductsArea ul.products li.product .added_to_cart:hover,
.cat-products-area ul.products li.product .added_to_cart:hover {
    background: rgba(237, 59, 75, .12) !important;
}

/* MODO LISTA */
#catProductsArea ul.products.list-view li.product {
    flex-direction: row !important;
    height: auto !important;
}

#catProductsArea ul.products.list-view li.product a.woocommerce-loop-product__link {
    flex: 0 0 180px !important;
    max-width: 180px !important;
}

#catProductsArea ul.products.list-view li.product img {
    height: 100% !important;
    min-height: 160px !important;
    border-radius: var(--cat-radius) 0 0 var(--cat-radius) !important;
}

#catProductsArea ul.products.list-view li.product .woocommerce-loop-product__title {
    font-size: 1.05rem !important;
}

#catProductsArea ul.products.list-view li.product .button {
    border-radius: 0 0 var(--cat-radius) 0 !important;
    width: auto !important;
    padding: .7rem 1.25rem !important;
}

/* ============================================================
   9. PAGINAÇÃO
   ============================================================ */
.cat-products-area .woocommerce-pagination,
#catProductsArea .woocommerce-pagination {
    margin-top: 2.5rem;
    text-align: center;
}

.cat-products-area .woocommerce-pagination .page-numbers,
#catProductsArea .woocommerce-pagination .page-numbers {
    display: inline-flex;
    gap: 6px;
    list-style: none;
    padding: 0;
    margin: 0;
}

.cat-products-area .woocommerce-pagination .page-numbers li,
#catProductsArea .woocommerce-pagination .page-numbers li {
    margin: 0 !important;
}

.cat-products-area .woocommerce-pagination .page-numbers a,
.cat-products-area .woocommerce-pagination .page-numbers span,
#catProductsArea .woocommerce-pagination .page-numbers a,
#catProductsArea .woocommerce-pagination .page-numbers span {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    font-size: .9rem;
    font-weight: 600;
    color: var(--cat-muted);
    background: var(--cat-surface);
    border: 1.5px solid var(--cat-border);
    transition: var(--cat-trans);
    text-decoration: none;
}

.cat-products-area .woocommerce-pagination .page-numbers a:hover,
#catProductsArea .woocommerce-pagination .page-numbers a:hover {
    border-color: var(--cat-primary);
    color: var(--cat-primary);
    background: rgba(237, 59, 75, .06);
}

.cat-products-area .woocommerce-pagination .page-numbers span.current,
#catProductsArea .woocommerce-pagination .page-numbers span.current {
    background: linear-gradient(135deg, var(--cat-primary), var(--cat-accent));
    color: #fff;
    border-color: var(--cat-primary);
}

.cat-products-area .woocommerce-pagination .page-numbers .prev,
.cat-products-area .woocommerce-pagination .page-numbers .next,
#catProductsArea .woocommerce-pagination .page-numbers .prev,
#catProductsArea .woocommerce-pagination .page-numbers .next {
    width: auto;
    padding: 0 14px;
}

/* ============================================================
   10. RESPONSIVIDADE
   ============================================================ */

/* Desktop grande: 4 colunas (1400px+) */
@media (min-width: 1400px) {

    #catProductsArea ul.products,
    #catProductsArea ul.products.columns-1,
    #catProductsArea ul.products.columns-2,
    #catProductsArea ul.products.columns-3,
    #catProductsArea ul.products.columns-4,
    #catProductsArea ul.products.columns-5,
    #catProductsArea ul.products.columns-6,
    .cat-products-area ul.products,
    .cat-products-area ul.products.columns-1,
    .cat-products-area ul.products.columns-2,
    .cat-products-area ul.products.columns-3,
    .cat-products-area ul.products.columns-4,
    .cat-products-area ul.products.columns-5,
    .cat-products-area ul.products.columns-6 {
        grid-template-columns: repeat(4, 1fr) !important;
    }
}

/* Desktop: 3 colunas (992px - 1399px) */
@media (min-width: 992px) and (max-width: 1399px) {

    #catProductsArea ul.products,
    #catProductsArea ul.products.columns-1,
    #catProductsArea ul.products.columns-2,
    #catProductsArea ul.products.columns-3,
    #catProductsArea ul.products.columns-4,
    #catProductsArea ul.products.columns-5,
    #catProductsArea ul.products.columns-6,
    .cat-products-area ul.products,
    .cat-products-area ul.products.columns-1,
    .cat-products-area ul.products.columns-2,
    .cat-products-area ul.products.columns-3,
    .cat-products-area ul.products.columns-4,
    .cat-products-area ul.products.columns-5,
    .cat-products-area ul.products.columns-6 {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

/* Tablet: 2 colunas + sidebar stacking (max-width: 991px) */
@media (max-width: 991px) {
    .cat-hero {
        height: 240px;
    }

    .cat-sidebar-col {
        order: 2;
        margin-top: 2rem;
    }

    /* 2 colunas no tablet */
    #catProductsArea ul.products,
    #catProductsArea ul.products.columns-1,
    #catProductsArea ul.products.columns-2,
    #catProductsArea ul.products.columns-3,
    #catProductsArea ul.products.columns-4,
    #catProductsArea ul.products.columns-5,
    #catProductsArea ul.products.columns-6,
    .cat-products-area ul.products,
    .cat-products-area ul.products.columns-1,
    .cat-products-area ul.products.columns-2,
    .cat-products-area ul.products.columns-3,
    .cat-products-area ul.products.columns-4,
    .cat-products-area ul.products.columns-5,
    .cat-products-area ul.products.columns-6 {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 1rem !important;
    }

    /* li size reset no tablet */
    #catProductsArea ul.products li.product,
    .cat-products-area ul.products li.product {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
    }
}

/* Mobile médio */
@media (max-width: 767px) {
    .cat-hero {
        height: 200px;
    }

    .cat-hero__title {
        font-size: 1.5rem;
    }

    .cat-hero__desc {
        display: none;
    }

    .cat-toolbar {
        position: relative;
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
        padding: 0.75rem 0;
        gap: 0.5rem;
        border-bottom: 1px solid #f3f4f6;
        margin-bottom: 1rem;
    }

    .cat-toolbar__left {
        flex: 1;
    }

    .cat-toolbar__right {
        flex: 1;
        justify-content: flex-end;
    }

    .cat-toolbar .woocommerce-result-count {
        display: block;
        font-size: 0.8rem;
        color: #9ca3af;
    }

    .cat-toolbar .woocommerce-ordering select {
        font-size: 0.8rem;
        padding: 8px 28px 8px 10px;
        min-width: auto;
    }
}

/* ============================================================
   MOBILE FIRST - 2 COLUNAS (max-width: 767px)
   ============================================================ */

/* Forçar grid em mobile/tablet — SOMENTE até 991px */
@media (max-width: 991px) {

    body.tax-product_cat .cat-products-center ul.products,
    body.tax-product_cat #catProductsArea ul.products,
    body.tax-product_cat .woocommerce ul.products,
    body.tax-product_tag .cat-products-center ul.products,
    body.tax-product_tag #catProductsArea ul.products,
    body.tax-product_tag .woocommerce ul.products,
    body.post-type-archive-product .cat-products-center ul.products,
    body.post-type-archive-product #catProductsArea ul.products,
    body.post-type-archive-product .woocommerce ul.products {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
        margin: 0 !important;
        padding: 0 10px !important;
        width: 100% !important;
        float: none !important;
    }

    /* Forçar largura dos produtos no mobile/tablet */
    body.tax-product_cat .cat-products-center ul.products li.product,
    body.tax-product_cat #catProductsArea ul.products li.product,
    body.tax-product_cat .woocommerce ul.products li.product,
    body.tax-product_tag .cat-products-center ul.products li.product,
    body.tax-product_tag #catProductsArea ul.products li.product,
    body.tax-product_tag .woocommerce ul.products li.product,
    body.post-type-archive-product .cat-products-center ul.products li.product,
    body.post-type-archive-product #catProductsArea ul.products li.product,
    body.post-type-archive-product .woocommerce ul.products li.product {
        width: 100% !important;
        max-width: 100% !important;
        flex: none !important;
        margin: 0 !important;
        padding: 0 !important;
        float: none !important;
        clear: none !important;
    }
}

/* Mobile - 2 colunas */
@media (max-width: 767px) {

    .cat-toolbar {
        flex-direction: row;
        gap: 0.5rem;
    }

    .cat-toolbar__left .woocommerce-result-count {
        font-size: 0.75rem;
    }

    .cat-toolbar .woocommerce-ordering select {
        font-size: 0.75rem;
        padding: 6px 24px 6px 8px;
    }

    /* Grid de 2 colunas no mobile */
    .cat-products-center ul.products,
    #catProductsArea ul.products,
    .woocommerce ul.products {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }

    .cat-products-center ul.products li.product,
    #catProductsArea ul.products li.product,
    .woocommerce ul.products li.product {
        width: 100% !important;
        max-width: calc(50% - 6px) !important;
        flex: 0 0 calc(50% - 6px) !important;
        margin: 0 !important;
    }

    .woocommerce-pagination .page-numbers .prev,
    .woocommerce-pagination .page-numbers .next {
        display: none !important;
    }
}



/* ============================================================
   12. SCROLL REVEAL (para páginas sem AJAX)
   ============================================================ */
#catProductsArea ul.products li.product.is-revealed,
.cat-products-area ul.products li.product.is-revealed {
    opacity: 1;
    transform: translateY(0);
}

/* ============================================================
   13. CORREÇÃO BOTÃO CORTADO NO HOVER/TOUCH (MOBILE)
   ============================================================ */

/* Garante que o container do produto não corte elementos filhos */
#catProductsArea ul.products li.product,
.cat-products-area ul.products li.product {
    overflow: visible !important;
    position: relative !important; /* CORREÇÃO: Contexto para posicionamento absoluto */
}

/* Ajuste específico para mobile - botão não encosta na borda do card inferior */
@media (max-width: 991px) {
    .woodev-product-card {
        padding-bottom: 30px !important; /* Mais espaço no mobile */
    }
    
    .woodev-quick-add {
        bottom: 5px;
        padding: 8px 16px;
    }
}

/* Garantir que o wrapper do botão tenha overflow visible */
.woodev-product-card .woodev-quick-add {
    overflow: visible !important;
}
