/**
 * Macalé Catálogo de Produtos - CSS Principal
 * Design moderno, limpo e responsivo (mobile-first)
 * Cores: #1e3a8a (azul), #10b981 (verde)
 * Fonte: Montserrat
 *
 * @package Macale_Catalogo_Produtos
 */

/* ==========================================================================
   CSS Custom Properties (Variáveis)
   ========================================================================== */
:root {
    /* Cores principais - Macalé */
    --macale-primary: #1e3a8a;
    --macale-primary-dark: #172554;
    --macale-primary-light: #3b82f6;
    --macale-secondary: #10b981;
    --macale-secondary-dark: #059669;
    --macale-secondary-light: #34d399;
    
    /* Cores neutras */
    --macale-gray-50: #f9fafb;
    --macale-gray-100: #f3f4f6;
    --macale-gray-200: #e5e7eb;
    --macale-gray-300: #d1d5db;
    --macale-gray-400: #9ca3af;
    --macale-gray-500: #6b7280;
    --macale-gray-600: #4b5563;
    --macale-gray-700: #374151;
    --macale-gray-800: #1f2937;
    --macale-gray-900: #111827;
    
    /* Cores de estado */
    --macale-success: #10b981;
    --macale-warning: #f59e0b;
    --macale-error: #ef4444;
    
    /* Tipografia - Montserrat */
    --macale-font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --macale-font-size-xs: 0.75rem;
    --macale-font-size-sm: 0.875rem;
    --macale-font-size-base: 1rem;
    --macale-font-size-lg: 1.125rem;
    --macale-font-size-xl: 1.25rem;
    --macale-font-size-2xl: 1.5rem;
    --macale-font-size-3xl: 1.875rem;
    
    /* Espaçamento */
    --macale-spacing-xs: 0.25rem;
    --macale-spacing-sm: 0.5rem;
    --macale-spacing-md: 1rem;
    --macale-spacing-lg: 1.5rem;
    --macale-spacing-xl: 2rem;
    --macale-spacing-2xl: 3rem;
    
    /* Bordas */
    --macale-radius-sm: 0.25rem;
    --macale-radius-md: 0.5rem;
    --macale-radius-lg: 0.75rem;
    --macale-radius-xl: 1rem;
    --macale-radius-full: 9999px;
    
    /* Sombras */
    --macale-shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --macale-shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --macale-shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --macale-shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    
    /* Transições */
    --macale-transition-fast: 150ms ease;
    --macale-transition-base: 200ms ease;
    --macale-transition-slow: 300ms ease;
}

/* ==========================================================================
   Reset e Base - Alta Especificidade
   ========================================================================== */
.macale-catalogo-wrapper,
.macale-catalogo-wrapper *,
.macale-catalogo-wrapper *::before,
.macale-catalogo-wrapper *::after,
.macale-single-produto,
.macale-single-produto *,
.macale-single-produto *::before,
.macale-single-produto *::after {
    box-sizing: border-box !important;
}

.macale-catalogo-wrapper {
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-base) !important;
    line-height: 1.6 !important;
    color: var(--macale-gray-800) !important;
    max-width: 1400px !important;
    margin: 0 auto !important;
    padding: var(--macale-spacing-md) !important;
}

/* Reset de botões dentro do wrapper */
.macale-catalogo-wrapper button,
.macale-catalogo-wrapper button:hover,
.macale-catalogo-wrapper button:focus,
.macale-catalogo-wrapper button:active {
    background-color: transparent;
    border: none;
    outline: none;
    box-shadow: none;
    text-transform: none;
}

/* ==========================================================================
   Cabeçalho do Catálogo
   ========================================================================== */
.macale-catalogo-wrapper .macale-catalogo-header {
    text-align: center !important;
    margin-bottom: var(--macale-spacing-xl) !important;
    padding-bottom: var(--macale-spacing-lg) !important;
    border-bottom: 1px solid var(--macale-gray-200) !important;
}

.macale-catalogo-wrapper .macale-catalogo-titulo {
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-2xl) !important;
    font-weight: 700 !important;
    color: #1e3a8a !important;
    margin: 0 !important;
    letter-spacing: -0.025em !important;
}

@media (min-width: 768px) {
    .macale-catalogo-wrapper .macale-catalogo-titulo {
        font-size: var(--macale-font-size-3xl) !important;
    }
}

/* ==========================================================================
   Navegação de Filtros
   ========================================================================== */
.macale-catalogo-wrapper .macale-filtros-nav {
    display: flex !important;
    flex-direction: column !important;
    gap: var(--macale-spacing-md) !important;
    margin-bottom: var(--macale-spacing-lg) !important;
}

@media (min-width: 768px) {
    .macale-catalogo-wrapper .macale-filtros-nav {
        flex-direction: row !important;
        align-items: center !important;
        justify-content: space-between !important;
    }
}

/* Tabs de Filtro */
.macale-catalogo-wrapper .macale-filtros-tabs {
    display: flex !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    gap: var(--macale-spacing-xs) !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
}

.macale-catalogo-wrapper .macale-filtros-tabs::-webkit-scrollbar {
    display: none !important;
}

.macale-catalogo-wrapper .macale-tab-btn {
    display: inline-flex !important;
    align-items: center !important;
    padding: var(--macale-spacing-sm) var(--macale-spacing-md) !important;
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-sm) !important;
    font-weight: 600 !important;
    color: #4b5563 !important;
    background: transparent !important;
    border: 2px solid transparent !important;
    border-radius: var(--macale-radius-md) !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    transition: all var(--macale-transition-base) !important;
}

.macale-catalogo-wrapper .macale-tab-btn:hover {
    color: #1e3a8a !important;
    background: var(--macale-gray-50) !important;
}

.macale-catalogo-wrapper .macale-tab-btn:focus {
    outline: 2px solid #3b82f6 !important;
    outline-offset: 2px !important;
}

.macale-catalogo-wrapper .macale-tab-btn.active {
    color: #1e3a8a !important;
    background: var(--macale-gray-50) !important;
    border-color: #1e3a8a !important;
}

/* Campo de Busca */
.macale-catalogo-wrapper .macale-busca-wrapper {
    position: relative !important;
    width: 100% !important;
    max-width: 400px !important;
}

.macale-catalogo-wrapper .macale-busca-input {
    width: 100% !important;
    padding: var(--macale-spacing-sm) var(--macale-spacing-md) !important;
    padding-right: 48px !important;
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-base) !important;
    color: var(--macale-gray-800) !important;
    background: var(--macale-gray-50) !important;
    border: 2px solid var(--macale-gray-200) !important;
    border-radius: var(--macale-radius-lg) !important;
    transition: all var(--macale-transition-base) !important;
}

.macale-catalogo-wrapper .macale-busca-input:focus {
    outline: none !important;
    border-color: #1e3a8a !important;
    background: white !important;
    box-shadow: 0 0 0 3px rgb(30 58 138 / 0.1) !important;
}

.macale-catalogo-wrapper .macale-busca-input::placeholder {
    color: var(--macale-gray-400) !important;
}

.macale-catalogo-wrapper .macale-busca-btn {
    position: absolute !important;
    right: 4px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 40px !important;
    height: 40px !important;
    color: white !important;
    background: #1e3a8a !important;
    border: none !important;
    border-radius: var(--macale-radius-md) !important;
    cursor: pointer !important;
    transition: background var(--macale-transition-base) !important;
    padding: 0 !important;
}

.macale-catalogo-wrapper .macale-busca-btn:hover {
    background: #172554 !important;
    color: white !important;
}

.macale-catalogo-wrapper .macale-busca-btn svg {
    width: 20px !important;
    height: 20px !important;
    fill: currentColor !important;
}

/* ==========================================================================
   Painéis de Filtros
   ========================================================================== */
.macale-catalogo-wrapper .macale-filtros-paineis {
    margin-bottom: var(--macale-spacing-xl) !important;
}

.macale-catalogo-wrapper .macale-filtro-painel {
    display: none !important;
    animation: macaleFadeIn var(--macale-transition-slow) !important;
}

.macale-catalogo-wrapper .macale-filtro-painel.active,
.macale-catalogo-wrapper .macale-filtro-painel:not([hidden]) {
    display: block !important;
}

@keyframes macaleFadeIn {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Grid de Filtros - Ícones (Aplicação) */
.macale-catalogo-wrapper .macale-filtro-icones {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)) !important;
    gap: var(--macale-spacing-md) !important;
}

@media (min-width: 768px) {
    .macale-catalogo-wrapper .macale-filtro-icones {
        grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)) !important;
    }
}

.macale-catalogo-wrapper .macale-filtro-icone {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: var(--macale-spacing-sm) !important;
    padding: var(--macale-spacing-md) !important;
    background: white !important;
    border: 2px solid var(--macale-gray-200) !important;
    border-radius: var(--macale-radius-lg) !important;
    cursor: pointer !important;
    transition: all var(--macale-transition-base) !important;
}

.macale-catalogo-wrapper .macale-filtro-icone:hover {
    border-color: #3b82f6 !important;
    box-shadow: var(--macale-shadow-md) !important;
    transform: translateY(-2px) !important;
}

.macale-catalogo-wrapper .macale-filtro-icone.active {
    border-color: #1e3a8a !important;
    background: rgb(30 58 138 / 0.05) !important;
    box-shadow: var(--macale-shadow-md) !important;
}

.macale-catalogo-wrapper .macale-filtro-icone-img {
    width: 60px !important;
    height: 60px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: var(--macale-radius-full) !important;
    overflow: hidden !important;
    background: var(--macale-gray-100) !important;
}

.macale-catalogo-wrapper .macale-filtro-icone-img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

.macale-catalogo-wrapper .macale-filtro-icone-placeholder {
    width: 100% !important;
    height: 100% !important;
    background: linear-gradient(135deg, var(--macale-gray-200), var(--macale-gray-300)) !important;
}

.macale-catalogo-wrapper .macale-filtro-icone-nome {
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-sm) !important;
    font-weight: 500 !important;
    color: var(--macale-gray-700) !important;
    text-align: center !important;
}

.macale-catalogo-wrapper .macale-filtro-count {
    font-size: var(--macale-font-size-xs) !important;
    color: var(--macale-gray-400) !important;
}

/* Grid de Filtros - Cards (Fornecedor) */
.macale-catalogo-wrapper .macale-filtro-cards {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)) !important;
    gap: var(--macale-spacing-md) !important;
}

@media (min-width: 768px) {
    .macale-catalogo-wrapper .macale-filtro-cards {
        grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)) !important;
    }
}

.macale-catalogo-wrapper .macale-filtro-card {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: var(--macale-spacing-sm) !important;
    padding: var(--macale-spacing-lg) !important;
    background: white !important;
    border: 2px solid var(--macale-gray-200) !important;
    border-radius: var(--macale-radius-lg) !important;
    cursor: pointer !important;
    transition: all var(--macale-transition-base) !important;
}

.macale-catalogo-wrapper .macale-filtro-card:hover {
    border-color: #3b82f6 !important;
    box-shadow: var(--macale-shadow-md) !important;
}

.macale-catalogo-wrapper .macale-filtro-card.active {
    border-color: #1e3a8a !important;
    background: rgb(30 58 138 / 0.05) !important;
}

.macale-catalogo-wrapper .macale-filtro-card-img {
    width: 80px !important;
    height: 60px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
}

.macale-catalogo-wrapper .macale-filtro-card-img img {
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important;
}

.macale-catalogo-wrapper .macale-filtro-card-placeholder {
    width: 100% !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: var(--macale-gray-100) !important;
    border-radius: var(--macale-radius-md) !important;
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-xl) !important;
    font-weight: 700 !important;
    color: var(--macale-gray-400) !important;
}

.macale-catalogo-wrapper .macale-filtro-card-nome {
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-sm) !important;
    font-weight: 600 !important;
    color: var(--macale-gray-700) !important;
    text-align: center !important;
}

/* Lista de Filtros - Tipo */
.macale-catalogo-wrapper .macale-filtro-lista-desktop {
    display: none !important;
}

.macale-catalogo-wrapper .macale-filtro-dropdown-mobile {
    display: block !important;
}

@media (min-width: 768px) {
    .macale-catalogo-wrapper .macale-filtro-lista-desktop {
        display: block !important;
    }
    
    .macale-catalogo-wrapper .macale-filtro-dropdown-mobile {
        display: none !important;
    }
}

.macale-catalogo-wrapper .macale-filtro-lista {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: var(--macale-spacing-sm) !important;
}

.macale-catalogo-wrapper .macale-filtro-lista-item {
    padding: var(--macale-spacing-sm) var(--macale-spacing-md) !important;
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-sm) !important;
    color: var(--macale-gray-600) !important;
    background: white !important;
    border: 2px solid var(--macale-gray-200) !important;
    border-radius: var(--macale-radius-full) !important;
    cursor: pointer !important;
    transition: all var(--macale-transition-base) !important;
}

.macale-catalogo-wrapper .macale-filtro-lista-item:hover {
    border-color: #3b82f6 !important;
    color: #1e3a8a !important;
}

.macale-catalogo-wrapper .macale-filtro-lista-item.active {
    background: #1e3a8a !important;
    border-color: #1e3a8a !important;
    color: white !important;
}

.macale-catalogo-wrapper .macale-filtro-select {
    width: 100% !important;
    padding: var(--macale-spacing-sm) var(--macale-spacing-md) !important;
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-base) !important;
    color: var(--macale-gray-700) !important;
    background: white !important;
    border: 2px solid var(--macale-gray-200) !important;
    border-radius: var(--macale-radius-md) !important;
    cursor: pointer !important;
}

.macale-catalogo-wrapper .macale-filtro-select:focus {
    outline: none !important;
    border-color: #1e3a8a !important;
}

/* ==========================================================================
   Filtros Ativos
   ========================================================================== */
.macale-catalogo-wrapper .macale-filtros-ativos {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: var(--macale-spacing-sm) !important;
    margin-bottom: var(--macale-spacing-lg) !important;
    min-height: 32px !important;
}

.macale-catalogo-wrapper .macale-filtro-ativo {
    display: inline-flex !important;
    align-items: center !important;
    gap: var(--macale-spacing-xs) !important;
    padding: var(--macale-spacing-xs) var(--macale-spacing-sm) !important;
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-sm) !important;
    color: #1e3a8a !important;
    background: rgb(30 58 138 / 0.1) !important;
    border-radius: var(--macale-radius-full) !important;
}

.macale-catalogo-wrapper .macale-filtro-ativo-remover {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 18px !important;
    height: 18px !important;
    padding: 0 !important;
    color: #1e3a8a !important;
    background: transparent !important;
    border: none !important;
    border-radius: var(--macale-radius-full) !important;
    cursor: pointer !important;
    transition: background var(--macale-transition-fast) !important;
    font-size: 14px !important;
    line-height: 1 !important;
}

.macale-catalogo-wrapper .macale-filtro-ativo-remover:hover {
    background: rgb(30 58 138 / 0.2) !important;
    color: #1e3a8a !important;
}

/* ==========================================================================
   Grid de Produtos
   ========================================================================== */
.macale-catalogo-wrapper .macale-produtos-container {
    position: relative !important;
    min-height: 200px !important;
}

.macale-catalogo-wrapper .macale-produtos-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: var(--macale-spacing-lg) !important;
}

@media (min-width: 480px) {
    .macale-catalogo-wrapper .macale-produtos-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (min-width: 768px) {
    .macale-catalogo-wrapper .macale-produtos-grid {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

@media (min-width: 1024px) {
    .macale-catalogo-wrapper .macale-produtos-grid {
        grid-template-columns: repeat(4, 1fr) !important;
    }
}

/* Card de Produto */
.macale-catalogo-wrapper .macale-produto-card {
    display: flex !important;
    flex-direction: column !important;
    background: white !important;
    border: 1px solid var(--macale-gray-200) !important;
    border-radius: var(--macale-radius-lg) !important;
    overflow: hidden !important;
    transition: all var(--macale-transition-base) !important;
    cursor: pointer !important;
}

.macale-catalogo-wrapper .macale-produto-card:hover {
    border-color: var(--macale-gray-300) !important;
    box-shadow: var(--macale-shadow-lg) !important;
    transform: translateY(-4px) !important;
}

.macale-catalogo-wrapper .macale-produto-card:focus-within {
    outline: 2px solid #1e3a8a !important;
    outline-offset: 2px !important;
}

.macale-catalogo-wrapper .macale-produto-card-imagem {
    position: relative !important;
    aspect-ratio: 4/3 !important;
    background: var(--macale-gray-100) !important;
    overflow: hidden !important;
}

.macale-catalogo-wrapper .macale-produto-card-imagem img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform var(--macale-transition-slow) !important;
}

.macale-catalogo-wrapper .macale-produto-card:hover .macale-produto-card-imagem img {
    transform: scale(1.05) !important;
}

.macale-catalogo-wrapper .macale-produto-card-placeholder {
    width: 100% !important;
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: var(--macale-spacing-sm) !important;
    color: var(--macale-gray-400) !important;
}

.macale-catalogo-wrapper .macale-produto-card-placeholder svg {
    width: 48px !important;
    height: 48px !important;
}

.macale-catalogo-wrapper .macale-produto-card-conteudo {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 !important;
    padding: var(--macale-spacing-md) !important;
}

.macale-catalogo-wrapper .macale-produto-card-titulo {
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-base) !important;
    font-weight: 600 !important;
    color: var(--macale-gray-900) !important;
    margin: 0 0 var(--macale-spacing-sm) 0 !important;
    line-height: 1.4 !important;
}

.macale-catalogo-wrapper .macale-produto-card-titulo a {
    color: inherit !important;
    text-decoration: none !important;
}

.macale-catalogo-wrapper .macale-produto-card-titulo a:hover {
    color: #1e3a8a !important;
}

.macale-catalogo-wrapper .macale-produto-card-descricao {
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-sm) !important;
    color: var(--macale-gray-600) !important;
    margin: 0 0 var(--macale-spacing-md) 0 !important;
    flex: 1 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.macale-catalogo-wrapper .macale-produto-card-badges {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: var(--macale-spacing-xs) !important;
    margin-top: auto !important;
}

/* Badges */
.macale-catalogo-wrapper .macale-badge {
    display: inline-flex !important;
    align-items: center !important;
    padding: var(--macale-spacing-xs) var(--macale-spacing-sm) !important;
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-xs) !important;
    font-weight: 500 !important;
    border-radius: var(--macale-radius-sm) !important;
}

.macale-catalogo-wrapper .macale-badge-fornecedor {
    color: #1e3a8a !important;
    background: rgb(30 58 138 / 0.1) !important;
}

.macale-catalogo-wrapper .macale-badge-tipo {
    color: #10b981 !important;
    background: rgb(16 185 129 / 0.1) !important;
}

/* ==========================================================================
   Loading e Estados
   ========================================================================== */
.macale-catalogo-wrapper .macale-loading {
    display: none !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: rgb(255 255 255 / 0.9) !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: var(--macale-spacing-md) !important;
    z-index: 10 !important;
}

.macale-catalogo-wrapper .macale-loading.active {
    display: flex !important;
}

.macale-catalogo-wrapper .macale-loading-spinner {
    width: 40px !important;
    height: 40px !important;
    border: 3px solid var(--macale-gray-200) !important;
    border-top-color: #1e3a8a !important;
    border-radius: 50% !important;
    animation: macaleSpin 1s linear infinite !important;
}

@keyframes macaleSpin {
    to { transform: rotate(360deg); }
}

.macale-catalogo-wrapper .macale-no-results {
    display: none !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    padding: var(--macale-spacing-2xl) !important;
    text-align: center !important;
    color: var(--macale-gray-500) !important;
}

.macale-catalogo-wrapper .macale-no-results:not([hidden]) {
    display: flex !important;
}

.macale-catalogo-wrapper .macale-no-results svg {
    margin-bottom: var(--macale-spacing-md) !important;
    color: var(--macale-gray-300) !important;
}

.macale-catalogo-wrapper .macale-no-results p {
    font-family: var(--macale-font-family) !important;
    margin: 0 0 var(--macale-spacing-lg) 0 !important;
    font-size: var(--macale-font-size-lg) !important;
}

/* Mensagem de erro */
.macale-catalogo-wrapper .macale-error-message {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    padding: var(--macale-spacing-2xl) !important;
    text-align: center !important;
    color: #ef4444 !important;
    font-family: var(--macale-font-family) !important;
}

/* ==========================================================================
   Paginação
   ========================================================================== */
.macale-catalogo-wrapper .macale-paginacao {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: var(--macale-spacing-xs) !important;
    margin-top: var(--macale-spacing-xl) !important;
    padding-top: var(--macale-spacing-lg) !important;
    border-top: 1px solid var(--macale-gray-200) !important;
    flex-wrap: wrap !important;
}

.macale-catalogo-wrapper .macale-paginacao-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 40px !important;
    height: 40px !important;
    padding: var(--macale-spacing-sm) !important;
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-sm) !important;
    font-weight: 500 !important;
    color: var(--macale-gray-600) !important;
    background: white !important;
    border: 1px solid var(--macale-gray-200) !important;
    border-radius: var(--macale-radius-md) !important;
    cursor: pointer !important;
    transition: all var(--macale-transition-base) !important;
}

.macale-catalogo-wrapper .macale-paginacao-btn:hover:not(:disabled) {
    color: #1e3a8a !important;
    border-color: #1e3a8a !important;
}

.macale-catalogo-wrapper .macale-paginacao-btn.active {
    color: white !important;
    background: #1e3a8a !important;
    border-color: #1e3a8a !important;
}

.macale-catalogo-wrapper .macale-paginacao-btn:disabled {
    opacity: 0.5 !important;
    cursor: not-allowed !important;
}

.macale-catalogo-wrapper .macale-paginacao-info {
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-sm) !important;
    color: var(--macale-gray-500) !important;
    margin: 0 var(--macale-spacing-md) !important;
}

/* ==========================================================================
   Botões
   ========================================================================== */
.macale-catalogo-wrapper .macale-btn,
.macale-single-produto .macale-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: var(--macale-spacing-sm) !important;
    padding: var(--macale-spacing-sm) var(--macale-spacing-lg) !important;
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-base) !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border: 2px solid transparent !important;
    border-radius: var(--macale-radius-md) !important;
    cursor: pointer !important;
    transition: all var(--macale-transition-base) !important;
}

.macale-catalogo-wrapper .macale-btn svg,
.macale-single-produto .macale-btn svg {
    flex-shrink: 0 !important;
}

.macale-catalogo-wrapper .macale-btn-primary,
.macale-single-produto .macale-btn-primary {
    color: white !important;
    background: #10b981 !important;
    border-color: #10b981 !important;
}

.macale-catalogo-wrapper .macale-btn-primary:hover,
.macale-single-produto .macale-btn-primary:hover {
    background: #059669 !important;
    border-color: #059669 !important;
    color: white !important;
}

.macale-catalogo-wrapper .macale-btn-secondary,
.macale-single-produto .macale-btn-secondary {
    color: #1e3a8a !important;
    background: white !important;
    border-color: #1e3a8a !important;
}

.macale-catalogo-wrapper .macale-btn-secondary:hover,
.macale-single-produto .macale-btn-secondary:hover {
    color: white !important;
    background: #1e3a8a !important;
}

.macale-catalogo-wrapper .macale-btn-limpar-filtros {
    color: #1e3a8a !important;
    background: transparent !important;
    border: 2px solid #1e3a8a !important;
    padding: var(--macale-spacing-sm) var(--macale-spacing-md) !important;
}

.macale-catalogo-wrapper .macale-btn-limpar-filtros:hover {
    color: white !important;
    background: #1e3a8a !important;
}

.macale-catalogo-wrapper .macale-btn-download,
.macale-single-produto .macale-btn-download {
    color: var(--macale-gray-700) !important;
    background: var(--macale-gray-100) !important;
    border-color: var(--macale-gray-200) !important;
}

.macale-catalogo-wrapper .macale-btn-download:hover,
.macale-single-produto .macale-btn-download:hover {
    background: var(--macale-gray-200) !important;
    color: var(--macale-gray-700) !important;
}

/* ==========================================================================
   Modal
   ========================================================================== */
.macale-modal {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 999999 !important;
    display: none !important;
}

.macale-modal:not([hidden]) {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    animation: macaleFadeIn var(--macale-transition-base) !important;
}

.macale-modal .macale-modal-overlay {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: rgb(0 0 0 / 0.5) !important;
}

.macale-modal .macale-modal-content {
    position: relative !important;
    width: 90% !important;
    max-width: 900px !important;
    max-height: 90vh !important;
    background: white !important;
    border-radius: var(--macale-radius-xl) !important;
    box-shadow: var(--macale-shadow-xl) !important;
    overflow: hidden !important;
    animation: macaleSlideUp var(--macale-transition-slow) !important;
}

@keyframes macaleSlideUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.macale-modal .macale-modal-fechar {
    position: absolute !important;
    top: var(--macale-spacing-md) !important;
    right: var(--macale-spacing-md) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 40px !important;
    height: 40px !important;
    padding: 0 !important;
    color: #1e3a8a !important;
    background: white !important;
    border: 2px solid #1e3a8a !important;
    border-radius: var(--macale-radius-full) !important;
    cursor: pointer !important;
    z-index: 10 !important;
    transition: all var(--macale-transition-base) !important;
    box-shadow: var(--macale-shadow-md) !important;
    font-size: 20px !important;
    font-weight: bold !important;
    line-height: 1 !important;
}

.macale-modal .macale-modal-fechar:hover {
    color: white !important;
    background: #1e3a8a !important;
}

.macale-modal .macale-modal-body {
    max-height: 90vh !important;
    overflow-y: auto !important;
    padding: var(--macale-spacing-xl) !important;
}

/* Layout do conteúdo do modal - duas colunas no desktop */
.macale-modal .macale-single-content {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: var(--macale-spacing-xl) !important;
}

@media (min-width: 768px) {
    .macale-modal .macale-single-content {
        grid-template-columns: 1fr 1fr !important;
    }
}

.macale-modal .macale-single-imagem {
    position: relative !important;
}

.macale-modal .macale-single-imagem-wrapper {
    position: sticky !important;
    top: 0 !important;
    background: var(--macale-gray-100) !important;
    border-radius: var(--macale-radius-lg) !important;
    overflow: hidden !important;
}

.macale-modal .macale-single-imagem-wrapper img {
    width: 100% !important;
    height: auto !important;
    display: block !important;
}

.macale-modal .macale-single-info {
    display: flex !important;
    flex-direction: column !important;
}

.macale-modal .macale-single-header {
    margin-bottom: var(--macale-spacing-lg) !important;
}

.macale-modal .macale-single-titulo {
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-2xl) !important;
    font-weight: 700 !important;
    color: #1e3a8a !important;
    margin: 0 0 var(--macale-spacing-md) 0 !important;
    line-height: 1.3 !important;
}

.macale-modal .macale-single-badges {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: var(--macale-spacing-sm) !important;
}

.macale-modal .macale-single-cta {
    display: flex !important;
    flex-direction: column !important;
    gap: var(--macale-spacing-sm) !important;
    margin-bottom: var(--macale-spacing-xl) !important;
}

@media (min-width: 480px) {
    .macale-modal .macale-single-cta {
        flex-direction: row !important;
    }
}

.macale-modal .macale-single-secao {
    margin-bottom: var(--macale-spacing-lg) !important;
    padding-bottom: var(--macale-spacing-md) !important;
    border-bottom: 1px solid var(--macale-gray-200) !important;
}

.macale-modal .macale-single-secao:last-child {
    border-bottom: none !important;
}

.macale-modal .macale-secao-titulo {
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-lg) !important;
    font-weight: 600 !important;
    color: #1e3a8a !important;
    margin: 0 0 var(--macale-spacing-sm) 0 !important;
}

.macale-modal .macale-secao-conteudo {
    font-family: var(--macale-font-family) !important;
    color: var(--macale-gray-600) !important;
    line-height: 1.7 !important;
}

.macale-modal .macale-secao-conteudo p {
    margin: 0 0 var(--macale-spacing-sm) 0 !important;
}

.macale-modal .macale-secao-conteudo p:last-child {
    margin-bottom: 0 !important;
}

.macale-modal .macale-secao-indisponivel .macale-secao-conteudo {
    color: var(--macale-gray-400) !important;
    font-style: italic !important;
}

.macale-modal .macale-produto-img-placeholder {
    aspect-ratio: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: var(--macale-spacing-md) !important;
    color: var(--macale-gray-400) !important;
    background: var(--macale-gray-100) !important;
    border-radius: var(--macale-radius-lg) !important;
}

/* ==========================================================================
   Single Produto
   ========================================================================== */
.macale-single-produto {
    font-family: var(--macale-font-family) !important;
    color: var(--macale-gray-800) !important;
}

.macale-single-produto .macale-single-container {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: var(--macale-spacing-md) !important;
}

/* Breadcrumb */
.macale-single-produto .macale-breadcrumb {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: var(--macale-spacing-sm) !important;
    margin-bottom: var(--macale-spacing-xl) !important;
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-sm) !important;
    color: var(--macale-gray-500) !important;
}

.macale-single-produto .macale-breadcrumb a {
    color: var(--macale-gray-600) !important;
    text-decoration: none !important;
    transition: color var(--macale-transition-fast) !important;
}

.macale-single-produto .macale-breadcrumb a:hover {
    color: #1e3a8a !important;
}

.macale-single-produto .macale-breadcrumb-sep {
    color: var(--macale-gray-300) !important;
}

.macale-single-produto .macale-breadcrumb-current {
    color: var(--macale-gray-900) !important;
    font-weight: 500 !important;
}

/* Layout do Single */
.macale-single-produto .macale-single-content {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: var(--macale-spacing-xl) !important;
}

@media (min-width: 768px) {
    .macale-single-produto .macale-single-content {
        grid-template-columns: 1fr 1fr !important;
    }
}

/* Imagem */
.macale-single-produto .macale-single-imagem {
    position: relative !important;
}

.macale-single-produto .macale-single-imagem-wrapper {
    position: sticky !important;
    top: var(--macale-spacing-lg) !important;
    background: var(--macale-gray-100) !important;
    border-radius: var(--macale-radius-xl) !important;
    overflow: hidden !important;
}

.macale-single-produto .macale-single-imagem-wrapper img {
    width: 100% !important;
    height: auto !important;
    display: block !important;
}

.macale-single-produto .macale-produto-img-placeholder {
    aspect-ratio: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: var(--macale-spacing-md) !important;
    color: var(--macale-gray-400) !important;
}

/* Informações */
.macale-single-produto .macale-single-header {
    margin-bottom: var(--macale-spacing-lg) !important;
}

.macale-single-produto .macale-single-titulo {
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-2xl) !important;
    font-weight: 700 !important;
    color: #1e3a8a !important;
    margin: 0 0 var(--macale-spacing-md) 0 !important;
    line-height: 1.3 !important;
}

@media (min-width: 768px) {
    .macale-single-produto .macale-single-titulo {
        font-size: var(--macale-font-size-3xl) !important;
    }
}

.macale-single-produto .macale-single-badges {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: var(--macale-spacing-sm) !important;
}

.macale-single-produto .macale-single-badges .macale-badge {
    font-size: var(--macale-font-size-sm) !important;
    padding: var(--macale-spacing-sm) var(--macale-spacing-md) !important;
}

/* CTAs */
.macale-single-produto .macale-single-cta {
    display: flex !important;
    flex-direction: column !important;
    gap: var(--macale-spacing-sm) !important;
    margin-bottom: var(--macale-spacing-xl) !important;
}

@media (min-width: 480px) {
    .macale-single-produto .macale-single-cta {
        flex-direction: row !important;
    }
}

.macale-single-produto .macale-single-cta .macale-btn {
    flex: 1 !important;
    justify-content: center !important;
    padding: var(--macale-spacing-md) var(--macale-spacing-lg) !important;
}

/* Seções */
.macale-single-produto .macale-single-secao {
    margin-bottom: var(--macale-spacing-xl) !important;
    padding-bottom: var(--macale-spacing-lg) !important;
    border-bottom: 1px solid var(--macale-gray-200) !important;
}

.macale-single-produto .macale-single-secao:last-child {
    border-bottom: none !important;
}

.macale-single-produto .macale-secao-titulo {
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-lg) !important;
    font-weight: 600 !important;
    color: #1e3a8a !important;
    margin: 0 0 var(--macale-spacing-md) 0 !important;
}

.macale-single-produto .macale-secao-conteudo {
    font-family: var(--macale-font-family) !important;
    color: var(--macale-gray-600) !important;
    line-height: 1.7 !important;
}

.macale-single-produto .macale-secao-conteudo p {
    margin: 0 0 var(--macale-spacing-md) 0 !important;
}

.macale-single-produto .macale-secao-conteudo p:last-child {
    margin-bottom: 0 !important;
}

.macale-single-produto .macale-secao-indisponivel .macale-secao-conteudo {
    color: var(--macale-gray-400) !important;
    font-style: italic !important;
}

.macale-single-produto .macale-no-tips {
    color: var(--macale-gray-400) !important;
    font-style: italic !important;
}

/* Tags de Aplicação */
.macale-single-produto .macale-aplicacoes-tags {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: var(--macale-spacing-sm) !important;
    margin-bottom: var(--macale-spacing-md) !important;
}

.macale-single-produto .macale-tag {
    display: inline-flex !important;
    padding: var(--macale-spacing-xs) var(--macale-spacing-md) !important;
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-sm) !important;
    color: var(--macale-gray-700) !important;
    background: var(--macale-gray-100) !important;
    border-radius: var(--macale-radius-full) !important;
}

.macale-single-produto .macale-aplicacoes-texto {
    font-family: var(--macale-font-family) !important;
    color: var(--macale-gray-600) !important;
    margin: 0 !important;
}

/* Navegação entre produtos */
.macale-single-produto .macale-single-nav {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: var(--macale-spacing-md) !important;
    margin-top: var(--macale-spacing-2xl) !important;
    padding-top: var(--macale-spacing-xl) !important;
    border-top: 1px solid var(--macale-gray-200) !important;
}

@media (min-width: 768px) {
    .macale-single-produto .macale-single-nav {
        grid-template-columns: 1fr auto 1fr !important;
    }
}

.macale-single-produto .macale-nav-link {
    display: flex !important;
    flex-direction: column !important;
    padding: var(--macale-spacing-md) !important;
    text-decoration: none !important;
    background: var(--macale-gray-50) !important;
    border-radius: var(--macale-radius-lg) !important;
    transition: all var(--macale-transition-base) !important;
}

.macale-single-produto .macale-nav-link:hover {
    background: var(--macale-gray-100) !important;
}

.macale-single-produto .macale-nav-prev {
    text-align: left !important;
}

.macale-single-produto .macale-nav-next {
    text-align: right !important;
}

.macale-single-produto .macale-nav-todos {
    align-items: center !important;
    justify-content: center !important;
    color: #1e3a8a !important;
    font-family: var(--macale-font-family) !important;
    font-weight: 600 !important;
}

.macale-single-produto .macale-nav-label {
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-sm) !important;
    color: var(--macale-gray-500) !important;
}

.macale-single-produto .macale-nav-titulo {
    font-family: var(--macale-font-family) !important;
    font-size: var(--macale-font-size-base) !important;
    font-weight: 500 !important;
    color: var(--macale-gray-800) !important;
}

/* ==========================================================================
   Archive Wrapper
   ========================================================================== */
.macale-archive-wrapper {
    padding: var(--macale-spacing-lg) 0 !important;
}

.macale-archive-container {
    max-width: 1400px !important;
    margin: 0 auto !important;
    padding: 0 var(--macale-spacing-md) !important;
}

/* ==========================================================================
   Utilitários
   ========================================================================== */
.screen-reader-text {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/* ==========================================================================
   Print Styles
   ========================================================================== */
@media print {
    .macale-filtros-nav,
    .macale-filtros-paineis,
    .macale-filtros-ativos,
    .macale-paginacao,
    .macale-modal,
    .macale-single-cta,
    .macale-single-nav {
        display: none !important;
    }
    
    .macale-catalogo-wrapper,
    .macale-single-container {
        max-width: 100% !important;
        padding: 0 !important;
    }
}
