/**
 * Macalé Catálogo V6
 * Desktop: carousel side arrows (APPROVED)
 * Mobile: carousel 3col grid, bottom arrows, no dots
 */
:root {
    --macale-primary: #1e3a8a; --macale-primary-dark: #152e6e;
    --macale-green: #10b981; --macale-green-dark: #059669;
    --macale-bg: #ffffff; --macale-surface: #fff;
    --macale-border: #e2e2dd; --macale-border-lt: #ededea;
    --macale-text: #1a1a1a; --macale-text-mid: #4a4a45;
    --macale-text-sec: #7a7a72; --macale-text-hint: #a5a59e;
    --macale-radius: 14px; --macale-radius-sm: 10px;
    --macale-font: 'Montserrat', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}
.macale-catalogo-wrapper, .macale-catalogo-wrapper *, .macale-catalogo-wrapper *::before, .macale-catalogo-wrapper *::after { box-sizing: border-box !important; }
.macale-catalogo-wrapper { font-family: var(--macale-font) !important; color: var(--macale-text) !important; max-width: 1400px !important; margin: 0 auto !important; background: #ffffff !important; overflow: hidden !important; }

/* HEADER */
.macale-catalogo-header { text-align: center !important; padding: 32px 40px 16px !important; background: #ffffff !important; }
.macale-catalogo-titulo { font-size: 26px !important; font-weight: 700 !important; color: #1e3a8a !important; margin: 0 !important; }
.macale-instrucao { text-align: center !important; padding: 0 40px 20px !important; background: #ffffff !important; font-size: 14px !important; color: #7a7a72 !important; font-weight: 500 !important; border-bottom: 1px solid #e2e2dd !important; }

/* TABS */
.macale-tabs { display: flex !important; align-items: center !important; padding: 0 40px !important; background: #ffffff !important; border-bottom: 2px solid #e2e2dd !important; flex-wrap: wrap !important; }
.macale-tab { padding: 14px 24px !important; font-size: 14px !important; font-weight: 600 !important; color: #7a7a72 !important; background: transparent !important; border: none !important; border-bottom: 3px solid transparent !important; margin-bottom: -2px !important; cursor: pointer !important; outline: none !important; box-shadow: none !important; }
.macale-tab:hover { color: #1e3a8a !important; }
.macale-tab.active { color: #1e3a8a !important; border-bottom-color: #1e3a8a !important; }
.macale-busca-wrapper { margin-left: auto !important; position: relative !important; width: 280px !important; flex-shrink: 0 !important; }
.macale-busca-input { width: 100% !important; height: 44px !important; padding: 0 46px 0 14px !important; font-family: var(--macale-font) !important; font-size: 14px !important; color: #1a1a1a !important; background: #f7f7f4 !important; border: 1.5px solid #e2e2dd !important; border-radius: 12px !important; outline: none !important; }
.macale-busca-input:focus { border-color: #1e3a8a !important; background: #ffffff !important; }
.macale-busca-btn { position: absolute !important; right: 4px !important; top: 50% !important; transform: translateY(-50%) !important; width: 36px !important; height: 36px !important; display: flex !important; align-items: center !important; justify-content: center !important; background: #1e3a8a !important; border-radius: 10px !important; color: white !important; border: none !important; outline: none !important; box-shadow: none !important; cursor: pointer !important; }
.macale-busca-btn:hover { background: #152e6e !important; }
.macale-busca-btn svg { width: 22px !important; height: 22px !important; display: block !important; visibility: visible !important; opacity: 1 !important; overflow: visible !important; fill: white !important; color: white !important; pointer-events: none !important; }.macale-busca-btn svg path { fill: white !important; }

/* PANELS */
.macale-panel { display: none !important; background: #ffffff !important; border-bottom: 1px solid #ededea !important; }
.macale-panel.active { display: block !important; }
.macale-panel-inner { max-width: 1280px !important; margin: 0 auto !important; padding: 28px 40px 24px !important; }

/* CAROUSEL */
.macale-carousel-wrap { position: relative !important; overflow: visible !important; }
.macale-carousel { overflow: hidden !important; margin: 0 48px !important; }
.macale-carousel-track { display: flex !important; transition: transform 0.35s cubic-bezier(0.25, 0.1, 0.25, 1) !important; }
.macale-carousel-page { min-width: 100% !important; flex-shrink: 0 !important; }

/* ARROWS - desktop inline styles handle position, CSS handles hover */
.macale-arrow:hover { background: #1e3a8a !important; color: white !important; }

/* DOTS */
.macale-dots { display: flex !important; justify-content: center !important; align-items: center !important; gap: 5px !important; padding-top: 16px !important; }
.macale-dot { width: 6px !important; height: 6px !important; border-radius: 50% !important; background: #ddd !important; cursor: pointer !important; border: none !important; display: inline-block !important; }
.macale-dot.active { width: 16px !important; border-radius: 3px !important; background: #1e3a8a !important; }

/* DESKTOP GRIDS */
@media (min-width: 769px) {
    .macale-app-grid { display: grid !important; grid-template-columns: repeat(7, minmax(0, 1fr)) !important; grid-template-rows: auto !important; gap: 24px 0 !important; }
    .macale-forn-grid { display: grid !important; grid-template-columns: repeat(6, minmax(0, 1fr)) !important; gap: 24px 18px !important; }
    .macale-tipo-grid { display: grid !important; grid-template-columns: repeat(4, minmax(0, 1fr)) !important; gap: 16px !important; }
    .macale-app-ico, .macale-forn-logo { width: 86px !important; height: 86px !important; }
}

/* ITEMS */
.macale-app-item, .macale-forn-item { width: 100% !important; display: flex !important; flex-direction: column !important; align-items: center !important; text-align: center !important; padding: 4px 2px !important; gap: 8px !important; cursor: pointer !important; overflow: visible !important; }
.macale-app-ico, .macale-forn-logo { width: 86px !important; height: 86px !important; border-radius: 999px !important; overflow: hidden !important; display: flex !important; align-items: center !important; justify-content: center !important; margin: 0 auto !important; flex-shrink: 0 !important; background: #fff !important; border: 1px solid #ecebe6 !important; transition: border-color 0.2s, outline 0.2s !important; outline: 3px solid transparent !important; outline-offset: 2px !important; }
.macale-app-ico img, .macale-forn-logo img { width: 100% !important; height: 100% !important; object-fit: cover !important; display: block !important; border-radius: 999px !important; }
.macale-forn-logo img { object-fit: contain !important; width: 74% !important; height: 74% !important; }
.macale-app-item span[style*="font-size:14px"], .macale-forn-item span[style*="font-size:14px"] { display: -webkit-box !important; -webkit-line-clamp: 2 !important; -webkit-box-orient: vertical !important; overflow: hidden !important; text-align: center !important; font-size: 14px !important; line-height: 1.25 !important; font-weight: 600 !important; color: #4a4a45 !important; min-height: 34px !important; word-break: break-word !important; }
/* HOVER STATES */
.macale-app-item:hover .macale-app-ico, .macale-forn-item:hover .macale-forn-logo { outline-color: #1e3a8a !important; border-color: #1e3a8a !important; }
.macale-tipo-item { min-height: 54px !important; display: flex !important; flex-direction: column !important; align-items: center !important; justify-content: center !important; text-align: center !important; padding: 12px 10px !important; border-radius: 12px !important; background: #f7f7f4 !important; border: 1.5px solid #e2e2dd !important; cursor: pointer !important; transition: border-color 0.2s, background 0.2s !important; gap: 3px !important; }
.macale-tipo-item:hover { border-color: #1e3a8a !important; background: #eef1fa !important; }

/* ACTIVE STATES */
.macale-app-item.active .macale-app-ico, .macale-forn-item.active .macale-forn-logo { outline-color: #1e3a8a !important; border-color: #1e3a8a !important; }
.macale-tipo-item.active { box-shadow: 0 0 0 2px #1e3a8a inset !important; border-color: #1e3a8a !important; color: #1e3a8a !important; }

/* ═══════════════════════════════════════ */
/* MOBILE                                  */
/* ═══════════════════════════════════════ */
@media (max-width: 768px) {
    .macale-catalogo-header { padding: 16px 16px 10px !important; }
    .macale-catalogo-titulo { font-size: 20px !important; }
    .macale-instrucao { padding: 0 16px 16px !important; font-size: 13px !important; }

    /* Tabs: caber na mesma linha com fonte menor, centralizadas */
    .macale-tabs { padding: 0 4px !important; flex-wrap: wrap !important; overflow: visible !important; justify-content: center !important; }
    .macale-tab { padding: 12px 10px !important; font-size: 11px !important; white-space: nowrap !important; flex-shrink: 0 !important; }

    .macale-busca-wrapper { width: 100% !important; margin-left: 0 !important; margin-top: 0 !important; margin-bottom: 8px !important; order: 10 !important; padding: 8px 12px 0 !important; }

    /* Select mobile para Tipo de Produto */
    .macale-tipo-select-mobile { display: block !important; width: 100% !important; padding: 12px 16px !important; font-family: var(--macale-font) !important; font-size: 13px !important; font-weight: 600 !important; color: #1a1a1a !important; background: #f7f7f4 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%231e3a8a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 14px center !important; border: 1.5px solid #e2e2dd !important; border-radius: 12px !important; outline: none !important; appearance: none !important; -webkit-appearance: none !important; cursor: pointer !important; }
    .macale-panel-inner { padding: 14px 16px 18px !important; }

    /* Carousel: remove side margin, keep carousel working */
    .macale-carousel { margin: 0 !important; }

    /* Hide side arrows on mobile */
    .macale-carousel-wrap .macale-arrow { display: none !important; }

    /* Hide dots on mobile */
    .macale-dots { display: none !important; }

    /* Mobile grids - 3 cols, rows auto-fill, sem espaço vazio */
    .macale-app-grid { display: grid !important; grid-template-columns: repeat(3, minmax(0, 1fr)) !important; grid-template-rows: auto !important; gap: 18px 10px !important; justify-items: center !important; align-content: start !important; }
    .macale-forn-grid { display: grid !important; grid-template-columns: repeat(3, minmax(0, 1fr)) !important; gap: 18px 10px !important; justify-items: center !important; align-content: start !important; }

    /* Carousel track: não esticar páginas na altura da maior */
    .macale-carousel-track { align-items: flex-start !important; }
    .macale-carousel-page { align-self: flex-start !important; }

    /* Tipo de Produto: select no mobile (veja JS) - grid não é usado */

    /* Mobile icon size */
    .macale-app-ico, .macale-forn-logo { width: 74px !important; height: 74px !important; min-width: 74px !important; min-height: 74px !important; }
    .macale-app-item span[style*="font-size:14px"], .macale-forn-item span[style*="font-size:14px"] { font-size: 13px !important; min-height: 32px !important; }

    /* Products grid mobile - high specificity */
    .macale-catalogo-wrapper .macale-produtos-grid { display: grid !important; grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 12px !important; }
    .macale-catalogo-wrapper .macale-produtos-section { padding: 14px 16px 32px !important; }
    .macale-catalogo-wrapper .macale-produtos-header { padding: 0 !important; }
    .macale-catalogo-wrapper .macale-produto-card { max-width: 100% !important; }
    .macale-catalogo-wrapper .macale-produto-card-imagem { aspect-ratio: 4/3 !important; }
    .macale-catalogo-wrapper .macale-produto-card-imagem img { width: 100% !important; height: 100% !important; object-fit: cover !important; }
}

/* Mobile bottom arrows - created by JS */
.macale-mobile-arrows { display: none; }
@media (max-width: 768px) {
    .macale-mobile-arrows { display: flex !important; align-items: center !important; justify-content: center !important; gap: 20px !important; padding: 14px 0 4px !important; }
}

@media (max-width: 360px) {
    .macale-panel-inner { padding: 12px 12px 16px !important; }
    .macale-app-grid, .macale-forn-grid { gap: 14px 8px !important; }
    .macale-app-ico, .macale-forn-logo { width: 68px !important; height: 68px !important; }
}

/* ═══════════════════════════════════════ */
/* PRODUTOS, CARDS, LOADING, MODAL        */
/* ═══════════════════════════════════════ */
.macale-filtros-ativos { max-width: 1280px !important; margin: 0 auto !important; padding: 12px 40px 0 !important; display: flex !important; gap: 8px !important; flex-wrap: wrap !important; }
.macale-filtro-ativo { display: inline-flex !important; align-items: center !important; gap: 5px !important; padding: 5px 14px !important; font-size: 12px !important; font-weight: 600 !important; background: rgba(30,58,138,0.07) !important; color: #1e3a8a !important; border-radius: 50px !important; }
.macale-filtro-ativo-remover { cursor: pointer !important; font-size: 15px !important; font-weight: 700 !important; opacity: 0.6 !important; background: none !important; border: none !important; color: inherit !important; }
.macale-filtro-ativo-remover:hover { opacity: 1 !important; }

.macale-produtos-section { max-width: 1280px !important; margin: 0 auto !important; padding: 20px 40px 48px !important; background: transparent !important; }
@media (max-width: 640px) { .macale-produtos-section { padding: 14px 16px 32px !important; } }
.macale-catalogo-wrapper .macale-produtos-header { display: flex !important; justify-content: space-between !important; align-items: baseline !important; margin-bottom: 18px !important; background: transparent !important; }
.macale-catalogo-wrapper .macale-produtos-header h2 { font-size: 14px !important; font-weight: 700 !important; text-transform: uppercase !important; letter-spacing: 0.08em !important; color: #1e3a8a !important; margin: 0 !important; }
.macale-catalogo-wrapper .macale-produtos-count { font-size: 13px !important; color: #a5a59e !important; }
.macale-catalogo-wrapper .macale-produtos-container { position: relative !important; min-height: 200px !important; background: transparent !important; }
.macale-catalogo-wrapper .macale-produtos-grid { display: grid !important; grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 14px !important; }
@media (min-width: 640px) { .macale-catalogo-wrapper .macale-produtos-grid { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; gap: 16px !important; } }
@media (min-width: 900px) { .macale-catalogo-wrapper .macale-produtos-grid { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; gap: 18px !important; } }
@media (min-width: 1200px) { .macale-catalogo-wrapper .macale-produtos-grid { grid-template-columns: repeat(5, minmax(0, 1fr)) !important; gap: 20px !important; } }

.macale-produto-card { background: #ffffff !important; border-radius: 14px !important; overflow: hidden !important; border: 1px solid #ededea !important; cursor: pointer !important; transition: transform 0.2s, box-shadow 0.2s !important; }
.macale-produto-card:hover { transform: translateY(-4px) !important; box-shadow: 0 8px 24px rgba(0,0,0,0.06) !important; }
.macale-produto-card-imagem { aspect-ratio: 4/3 !important; background: linear-gradient(145deg, #f0f0ec, #e8e8e3) !important; overflow: hidden !important; }
.macale-produto-card-imagem img { width: 100% !important; height: 100% !important; object-fit: cover !important; }
.macale-produto-card-placeholder { width: 36px !important; height: 36px !important; border-radius: 50% !important; background: #ddd !important; opacity: 0.4 !important; }
.macale-produto-card-conteudo { padding: 14px !important; }
.macale-produto-card-titulo { font-size: 13px !important; font-weight: 600 !important; color: #1a1a1a !important; line-height: 1.35 !important; margin: 0 0 4px 0 !important; }
.macale-produto-card-titulo a { color: inherit !important; text-decoration: none !important; }
.macale-produto-card-titulo a:hover { color: #1e3a8a !important; }
.macale-produto-card-descricao { font-size: 11px !important; color: #7a7a72 !important; line-height: 1.4 !important; margin: 0 0 8px 0 !important; display: -webkit-box !important; -webkit-line-clamp: 2 !important; -webkit-box-orient: vertical !important; overflow: hidden !important; }
.macale-produto-card-badges { display: flex !important; gap: 5px !important; flex-wrap: wrap !important; }
.macale-badge { font-size: 10px !important; font-weight: 600 !important; padding: 3px 8px !important; border-radius: 5px !important; }
.macale-badge-fornecedor { background: rgba(30,58,138,0.07) !important; color: #1e3a8a !important; }
.macale-badge-tipo { background: rgba(16,185,129,0.07) !important; color: #059669 !important; }

.macale-loading { display: none !important; position: absolute !important; inset: 0 !important; background: rgba(255,255,255,0.9) !important; flex-direction: column !important; align-items: center !important; justify-content: center !important; gap: 12px !important; z-index: 10 !important; }
.macale-loading.active { display: flex !important; }
.macale-loading-spinner { width: 36px !important; height: 36px !important; border: 3px solid #e2e2dd !important; border-top-color: #1e3a8a !important; border-radius: 50% !important; animation: macaleSpin 1s linear infinite !important; }
@keyframes macaleSpin { to { transform: rotate(360deg); } }
.macale-no-results { display: none !important; flex-direction: column !important; align-items: center !important; padding: 48px 20px !important; text-align: center !important; color: #a5a59e !important; }
.macale-no-results:not([hidden]) { display: flex !important; }
.macale-btn-limpar-filtros { font-size: 13px !important; font-weight: 600 !important; padding: 8px 20px !important; border: 1.5px solid #1e3a8a !important; border-radius: 10px !important; background: transparent !important; color: #1e3a8a !important; cursor: pointer !important; }
.macale-btn-limpar-filtros:hover { background: #1e3a8a !important; color: white !important; }

.macale-paginacao { max-width: 1280px !important; margin: 0 auto !important; display: flex !important; justify-content: center !important; gap: 4px !important; padding: 0 40px 40px !important; flex-wrap: wrap !important; }
.macale-paginacao-btn { min-width: 40px !important; height: 40px !important; padding: 8px !important; font-size: 13px !important; color: #7a7a72 !important; background: #ffffff !important; border: 1px solid #e2e2dd !important; border-radius: 8px !important; cursor: pointer !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; }
.macale-paginacao-btn:hover:not(:disabled) { color: #1e3a8a !important; border-color: #1e3a8a !important; }
.macale-paginacao-btn.active { color: white !important; background: #1e3a8a !important; border-color: #1e3a8a !important; }
.macale-paginacao-btn:disabled { opacity: 0.4 !important; cursor: not-allowed !important; }

.macale-modal { position: fixed !important; inset: 0 !important; z-index: 999999 !important; display: none !important; }
.macale-modal:not([hidden]) { display: flex !important; align-items: center !important; justify-content: center !important; }
.macale-modal-overlay { position: absolute !important; inset: 0 !important; background: rgba(0,0,0,0.5) !important; }
.macale-modal-content { position: relative !important; width: 90% !important; max-width: 900px !important; max-height: 90vh !important; background: white !important; border-radius: 16px !important; box-shadow: 0 20px 25px -5px rgba(0,0,0,0.1) !important; overflow: hidden !important; }
.macale-modal-fechar { position: absolute !important; top: 12px !important; right: 12px !important; width: 40px !important; height: 40px !important; display: flex !important; align-items: center !important; justify-content: center !important; color: #1e3a8a !important; background: white !important; border: 2px solid #1e3a8a !important; border-radius: 50% !important; z-index: 10 !important; font-size: 20px !important; cursor: pointer !important; }
.macale-modal-fechar:hover { color: white !important; background: #1e3a8a !important; }
.macale-modal-body { max-height: 90vh !important; overflow-y: auto !important; padding: 32px !important; }
.macale-modal .macale-single-content { display: grid !important; grid-template-columns: 1fr !important; gap: 24px !important; }
@media (min-width: 768px) { .macale-modal .macale-single-content { grid-template-columns: 1fr 1fr !important; } }
.macale-modal .macale-single-titulo { font-size: 24px !important; font-weight: 700 !important; color: #1e3a8a !important; margin: 0 0 12px 0 !important; }
.macale-modal .macale-single-badges { display: flex !important; flex-wrap: wrap !important; gap: 8px !important; margin-bottom: 16px !important; }
.macale-modal .macale-single-imagem-wrapper { background: #f3f4f6 !important; border-radius: 12px !important; overflow: hidden !important; }
.macale-modal .macale-single-imagem-wrapper img { width: 100% !important; height: auto !important; display: block !important; }
.macale-modal .macale-secao-titulo { font-size: 16px !important; font-weight: 600 !important; color: #1e3a8a !important; margin: 0 0 8px 0 !important; }
.macale-modal .macale-secao-conteudo { color: #7a7a72 !important; line-height: 1.7 !important; }
.macale-modal .macale-single-secao { margin-bottom: 20px !important; padding-bottom: 16px !important; border-bottom: 1px solid #e2e2dd !important; }
.macale-modal .macale-single-secao:last-child { border-bottom: none !important; }
.macale-modal .macale-single-cta { display: flex !important; gap: 8px !important; margin-bottom: 24px !important; flex-wrap: wrap !important; }
.macale-btn-primary { padding: 10px 20px !important; font-size: 14px !important; font-weight: 600 !important; color: white !important; background: #10b981 !important; border: none !important; border-radius: 8px !important; text-decoration: none !important; display: inline-flex !important; }
.macale-btn-primary:hover { background: #059669 !important; }
.macale-btn-secondary { padding: 10px 20px !important; font-size: 14px !important; font-weight: 600 !important; color: #1e3a8a !important; background: white !important; border: 2px solid #1e3a8a !important; border-radius: 8px !important; text-decoration: none !important; display: inline-flex !important; }
.macale-btn-secondary:hover { color: white !important; background: #1e3a8a !important; }
.macale-btn-download { padding: 10px 20px !important; font-size: 14px !important; font-weight: 600 !important; color: #4a4a45 !important; background: #f3f4f6 !important; border: 1px solid #e2e2dd !important; border-radius: 8px !important; text-decoration: none !important; display: inline-flex !important; }
.macale-produto-img-placeholder { aspect-ratio: 1 !important; display: flex !important; align-items: center !important; justify-content: center !important; color: #ddd !important; background: #f3f4f6 !important; border-radius: 12px !important; }
.macale-secao-indisponivel .macale-secao-conteudo { color: #a5a59e !important; font-style: italic !important; }

@media print { .macale-tabs, .macale-panel, .macale-instrucao, .macale-filtros-ativos, .macale-paginacao, .macale-modal { display: none !important; } }


/* ═══════════════════════════════════════════════════════════════ */
/* SINGLE PRODUTO — Layout página individual                       */
/* Cole este bloco no FINAL do arquivo macale-catalogo.css         */
/* Adicionado em 26/03 — não altera nenhum estilo do catálogo     */
/* ═══════════════════════════════════════════════════════════════ */

/* === RESET SCOPED === */
.macale-single-produto,
.macale-single-produto *,
.macale-single-produto *::before,
.macale-single-produto *::after {
    box-sizing: border-box !important;
}

/* === CONTAINER EXTERNO === */
.macale-single-produto {
    font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    color: #1a1a1a !important;
    background: #ffffff !important;
}

.macale-single-container {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 24px !important;
}

/* === BREADCRUMB === */
.macale-breadcrumb {
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 4px !important;
    padding: 14px 0 !important;
    font-size: 12px !important;
    color: #7a7a72 !important;
    border-bottom: 1px solid #ededea !important;
    margin-bottom: 32px !important;
}

.macale-breadcrumb a {
    color: #1e3a8a !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    transition: opacity 0.15s !important;
}

.macale-breadcrumb a:hover {
    opacity: 0.75 !important;
}

.macale-breadcrumb-sep {
    color: #d0d0cc !important;
    font-size: 13px !important;
}

.macale-breadcrumb-current {
    color: #1a1a1a !important;
    font-weight: 600 !important;
}

/* === LAYOUT PRINCIPAL: IMAGEM + INFO === */
/* Desktop: imagem fixa à esquerda (480px), info com scroll à direita */
.macale-single-content {
    display: grid !important;
    grid-template-columns: 480px 1fr !important;
    gap: 48px !important;
    align-items: start !important;
    margin-bottom: 40px !important;
}

/* === COLUNA IMAGEM === */
/* sticky: imagem permanece visível enquanto o usuário rola o conteúdo */
.macale-single-imagem {
    position: sticky !important;
    top: 24px !important;
}

.macale-single-imagem-wrapper {
    background: #f3f4f6 !important;
    border-radius: 16px !important;
    overflow: hidden !important;
    aspect-ratio: 1 / 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 1px solid #ededea !important;
}

.macale-produto-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    border-radius: 16px !important;
}

.macale-produto-img-placeholder {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    width: 100% !important;
    height: 100% !important;
    color: #c7d2e8 !important;
}

.macale-produto-img-placeholder span {
    font-size: 12px !important;
    color: #a5a59e !important;
    font-weight: 500 !important;
}

/* === COLUNA INFO === */
.macale-single-info {
    padding-top: 4px !important;
}

/* === CABEÇALHO: TÍTULO + BADGES === */
.macale-single-header {
    margin-bottom: 20px !important;
}

.macale-single-titulo {
    font-size: 28px !important;
    font-weight: 700 !important;
    color: #1e3a8a !important;
    line-height: 1.25 !important;
    margin: 0 0 12px 0 !important;
}

.macale-single-badges {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
}

/* sobrescreve tamanho dos badges apenas no contexto do single */
.macale-single-badges .macale-badge {
    font-size: 11px !important;
    font-weight: 700 !important;
    padding: 4px 12px !important;
    border-radius: 20px !important;
}

/* === BOTÕES CTA === */
.macale-single-cta {
    display: flex !important;
    gap: 10px !important;
    flex-wrap: wrap !important;
    margin-bottom: 28px !important;
}

.macale-single-cta .macale-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    padding: 11px 20px !important;
    border-radius: 10px !important;
    text-decoration: none !important;
    cursor: pointer !important;
    letter-spacing: 0.02em !important;
    transition: background 0.18s, color 0.18s, border-color 0.18s !important;
}

.macale-single-cta .macale-btn svg {
    width: 16px !important;
    height: 16px !important;
    flex-shrink: 0 !important;
}

.macale-single-cta .macale-btn-primary {
    background: #10b981 !important;
    color: #ffffff !important;
    border: none !important;
}

.macale-single-cta .macale-btn-primary:hover {
    background: #059669 !important;
}

.macale-single-cta .macale-btn-secondary {
    background: #ffffff !important;
    color: #1e3a8a !important;
    border: 2px solid #1e3a8a !important;
}

.macale-single-cta .macale-btn-secondary:hover {
    background: #1e3a8a !important;
    color: #ffffff !important;
}

/* === SEÇÕES DE CONTEÚDO === */
.macale-single-secoes {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
}

.macale-single-secao {
    padding: 18px 0 !important;
    border-bottom: 1px solid #ededea !important;
}

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

.macale-secao-titulo {
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    color: #1e3a8a !important;
    margin: 0 0 10px 0 !important;
}

.macale-secao-conteudo {
    font-size: 14px !important;
    color: #4a4a45 !important;
    line-height: 1.7 !important;
}

.macale-secao-conteudo p {
    margin: 0 0 8px 0 !important;
}

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

/* === APLICAÇÕES: TAGS === */
.macale-aplicacoes-tags {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    margin-bottom: 8px !important;
}

.macale-tag {
    background: #f1f5f9 !important;
    color: #475569 !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    padding: 4px 12px !important;
    border-radius: 20px !important;
    border: 1px solid #e2e8f0 !important;
}

.macale-aplicacoes-texto {
    font-size: 13px !important;
    color: #4a4a45 !important;
    line-height: 1.65 !important;
    margin: 6px 0 0 0 !important;
}

/* === RECOMENDAÇÕES INDISPONÍVEIS === */
.macale-secao-indisponivel .macale-secao-conteudo {
    color: #a5a59e !important;
    font-style: italic !important;
    font-size: 13px !important;
}

/* === FICHA TÉCNICA — BOTÃO DOWNLOAD === */
.macale-secao-ficha .macale-btn-download {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    padding: 10px 18px !important;
    border-radius: 10px !important;
    background: #f3f4f6 !important;
    color: #4a4a45 !important;
    border: 1px solid #e2e2dd !important;
    text-decoration: none !important;
    transition: background 0.18s, border-color 0.18s !important;
}

.macale-secao-ficha .macale-btn-download:hover {
    background: #e8eaed !important;
    border-color: #c5c8cc !important;
}

.macale-secao-ficha .macale-btn-download svg {
    width: 16px !important;
    height: 16px !important;
    flex-shrink: 0 !important;
}

/* === NAVEGAÇÃO ENTRE PRODUTOS === */
.macale-single-nav {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 16px !important;
    padding: 20px 0 40px !important;
    border-top: 1px solid #ededea !important;
    margin-top: 8px !important;
}

.macale-nav-link {
    display: flex !important;
    flex-direction: column !important;
    gap: 3px !important;
    text-decoration: none !important;
    max-width: 280px !important;
}

.macale-nav-label {
    font-size: 11px !important;
    font-weight: 700 !important;
    color: #1e3a8a !important;
    letter-spacing: 0.02em !important;
}

.macale-nav-titulo {
    font-size: 12px !important;
    color: #7a7a72 !important;
    font-weight: 500 !important;
    line-height: 1.35 !important;
}

.macale-nav-todos {
    font-size: 12px !important;
    font-weight: 700 !important;
    color: #4a4a45 !important;
    text-decoration: none !important;
    border: 1px solid #e2e2dd !important;
    padding: 8px 16px !important;
    border-radius: 8px !important;
    white-space: nowrap !important;
    transition: border-color 0.18s, color 0.18s !important;
    flex-shrink: 0 !important;
}

.macale-nav-todos:hover {
    border-color: #1e3a8a !important;
    color: #1e3a8a !important;
}

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

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

/* ═══════════════════════════════════════════════════════════════ */
/* RESPONSIVIDADE — TABLET (max-width: 1024px)                    */
/* Duas colunas compactas, imagem menor, botões empilhados        */
/* ═══════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {

    .macale-single-container {
        padding: 0 20px !important;
    }

    .macale-single-content {
        grid-template-columns: 300px 1fr !important;
        gap: 32px !important;
        margin-bottom: 32px !important;
    }

    /* imagem não fica sticky no tablet */
    .macale-single-imagem {
        position: static !important;
    }

    .macale-single-titulo {
        font-size: 22px !important;
    }

    /* botões CTA ocupam linha inteira individualmente */
    .macale-single-cta {
        flex-direction: column !important;
        gap: 8px !important;
    }

    .macale-single-cta .macale-btn {
        width: 100% !important;
        justify-content: center !important;
        font-size: 12px !important;
        padding: 10px 14px !important;
    }

    .macale-nav-link {
        max-width: 200px !important;
    }
}

/* ═══════════════════════════════════════════════════════════════ */
/* RESPONSIVIDADE — MOBILE (max-width: 768px)                     */
/* Coluna única: imagem topo full-bleed, conteúdo abaixo          */
/* ═══════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {

    .macale-single-container {
        padding: 0 16px !important;
    }

    /* breadcrumb compacto, sem borda inferior */
    .macale-breadcrumb {
        font-size: 11px !important;
        padding: 12px 0 !important;
        margin-bottom: 0 !important;
        border-bottom: none !important;
    }

    /* layout: coluna única empilhada */
    .macale-single-content {
        grid-template-columns: 1fr !important;
        gap: 0 !important;
        margin-bottom: 24px !important;
    }

    /* imagem full-bleed: ultrapassa o padding lateral do container */
    .macale-single-imagem {
        position: static !important;
        margin: 0 -16px !important;
    }

    .macale-single-imagem-wrapper {
        border-radius: 0 !important;
        aspect-ratio: 4 / 3 !important;
        border-left: none !important;
        border-right: none !important;
        border-top: none !important;
    }

    /* info col: respiro acima do título */
    .macale-single-info {
        padding-top: 20px !important;
    }

    /* título mobile */
    .macale-single-titulo {
        font-size: 20px !important;
        margin-bottom: 10px !important;
    }

    /* CTA: dois botões lado a lado em grid 2 colunas */
    .macale-single-cta {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 8px !important;
        margin-bottom: 20px !important;
        flex-direction: unset !important;
    }

    .macale-single-cta .macale-btn {
        width: 100% !important;
        justify-content: center !important;
        font-size: 11px !important;
        padding: 10px 8px !important;
        text-align: center !important;
    }

    /* seções mais compactas */
    .macale-single-secao {
        padding: 14px 0 !important;
    }

    .macale-secao-conteudo {
        font-size: 13px !important;
    }

    /* tags menores */
    .macale-tag {
        font-size: 10px !important;
        padding: 3px 10px !important;
    }

    /* nav entre produtos: esconde subtítulo do produto, simplifica */
    .macale-single-nav {
        padding: 16px 0 32px !important;
        gap: 10px !important;
    }

    .macale-nav-titulo {
        display: none !important;
    }

    .macale-nav-link {
        max-width: 120px !important;
    }

    .macale-nav-todos {
        font-size: 11px !important;
        padding: 7px 12px !important;
    }
}

/* ═══════════════════════════════════════════════════════════════ */
/* RESPONSIVIDADE — MOBILE PEQUENO (max-width: 420px)             */
/* Botões CTA empilham em coluna única abaixo de 420px            */
/* ═══════════════════════════════════════════════════════════════ */
@media (max-width: 420px) {

    .macale-single-titulo {
        font-size: 18px !important;
    }

    /* abaixo de 420px os botões empilham em coluna */
    .macale-single-cta {
        grid-template-columns: 1fr !important;
    }

    .macale-single-cta .macale-btn {
        width: 100% !important;
    }

    .macale-nav-label {
        font-size: 10px !important;
    }
}

/* ═══════════════════════════════════════════════════════════════ */
/* FIM — SINGLE PRODUTO                                            */
/* ═══════════════════════════════════════════════════════════════ */

/* ── Tipo de Produto: grid flat desktop (sem carousel) ── */
.macale-tipo-grid-flat {
    display: grid !important;
    grid-template-columns: repeat(6, 1fr) !important;
    gap: 12px !important;
    padding: 8px 0 !important;
    width: 100% !important;
}
@media (max-width: 1100px) {
    .macale-tipo-grid-flat { grid-template-columns: repeat(4, 1fr) !important; }
}
@media (max-width: 768px) {
    .macale-tipo-grid-flat { grid-template-columns: repeat(2, 1fr) !important; }
}
.macale-tipo-grid-flat .macale-tipo-item {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
}
/* Esconder dots e arrows do painel tipo no desktop */
#macale-panel-tipo .macale-dots,
#macale-panel-tipo .macale-arrow { display: none !important; }

/* ═══════════════════════════════════════════════════════════════ */
/* FORNECEDORES — ÍCONES 2x MAIORES                               */
/* ═══════════════════════════════════════════════════════════════ */

/* Desktop: fornecedor icons 2x (86px → 172px) */
@media (min-width: 769px) {
    .macale-forn-item:not(.macale-subforn-item) .macale-forn-logo {
        width: 172px !important;
        height: 172px !important;
    }
    /* Ajustar grid para acomodar ícones maiores */
    .macale-forn-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
        gap: 28px 24px !important;
    }
}

/* Mobile: fornecedor icons 2x (74px → 148px) */
@media (max-width: 768px) {
    .macale-forn-item:not(.macale-subforn-item) .macale-forn-logo {
        width: 148px !important;
        height: 148px !important;
        min-width: 148px !important;
        min-height: 148px !important;
    }
    /* Grid 2 cols no mobile para caber ícones maiores */
    .macale-forn-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 20px 12px !important;
    }
}

@media (max-width: 360px) {
    .macale-forn-item:not(.macale-subforn-item) .macale-forn-logo {
        width: 130px !important;
        height: 130px !important;
        min-width: 130px !important;
        min-height: 130px !important;
    }
}

/* Indicador visual para fornecedor pai com filhos */
.macale-forn-has-children .macale-forn-logo {
    position: relative !important;
}
.macale-forn-has-children .macale-forn-logo::after {
    content: '▾' !important;
    position: absolute !important;
    bottom: 4px !important;
    right: 4px !important;
    width: 24px !important;
    height: 24px !important;
    background: #1e3a8a !important;
    color: #fff !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 14px !important;
    line-height: 1 !important;
    box-shadow: 0 2px 6px rgba(0,0,0,0.15) !important;
}

/* ═══════════════════════════════════════════════════════════════ */
/* SUB-FORNECEDORES — CARD HIERÁRQUICO                             */
/* ═══════════════════════════════════════════════════════════════ */
.macale-subforn-card {
    background: #f7f7f4 !important;
    border-top: 2px solid #1e3a8a !important;
    border-bottom: 1px solid #e2e2dd !important;
    overflow: hidden !important;
}
.macale-subforn-inner {
    max-width: 1280px !important;
    margin: 0 auto !important;
    padding: 20px 40px 24px !important;
}
.macale-subforn-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    margin-bottom: 16px !important;
}
.macale-subforn-title {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #1e3a8a !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
}
.macale-subforn-title::before {
    content: '↳ ' !important;
    opacity: 0.5 !important;
}
.macale-subforn-close {
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    background: #fff !important;
    border: 1.5px solid #e2e2dd !important;
    color: #7a7a72 !important;
    font-size: 18px !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: border-color 0.2s, color 0.2s !important;
}
.macale-subforn-close:hover {
    border-color: #1e3a8a !important;
    color: #1e3a8a !important;
}
.macale-subforn-grid {
    display: grid !important;
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
    gap: 20px 16px !important;
    justify-items: center !important;
}
.macale-subforn-item .macale-subforn-logo {
    width: 90px !important;
    height: 90px !important;
}
.macale-subforn-item.active .macale-forn-logo,
.macale-subforn-item.active .macale-subforn-logo {
    outline: 3px solid #1e3a8a !important;
    outline-offset: 2px !important;
    border-color: #1e3a8a !important;
}

@media (max-width: 768px) {
    .macale-subforn-inner {
        padding: 16px !important;
    }
    .macale-subforn-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 12px 8px !important;
    }
    .macale-subforn-item .macale-subforn-logo,
    .macale-subforn-item .macale-forn-logo {
        width: 56px !important;
        height: 56px !important;
        min-width: 56px !important;
        min-height: 56px !important;
    }
    .macale-subforn-item span[style*="font-size:14px"] {
        font-size: 11px !important;
        line-height: 1.2 !important;
    }
    .macale-subforn-item span[style*="font-size:12px"] {
        font-size: 10px !important;
    }
}

@media (max-width: 360px) {
    .macale-subforn-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}
