/*
Theme Name: Bode das Promoções
Theme URI: https://bodedaspromocoes.com.br
Author: Bode das Promoções
Author URI: https://bodedaspromocoes.com.br
Description: Tema WordPress próprio, construído do zero para e-commerce, com foco em performance, acessibilidade e compatibilidade total com WooCommerce e Elementor (incluindo Elementor Pro Theme Builder). Identidade visual baseada na paleta marrom e dourado da marca Bode das Promoções.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: bode-das-promocoes
Tags: e-commerce, custom-menu, custom-logo, featured-images, full-width-template, threaded-comments, translation-ready, block-styles, wide-blocks
*/

/* =========================================================================
   ÍNDICE
   1. Custom Properties (Design Tokens)
   2. Reset & Base
   3. Tipografia
   4. Layout & Container
   5. Acessibilidade & Foco
   6. Header (fallback nativo)
   7. Navegação (menu principal + mobile)
   8. Busca (overlay)
   9. Mini Carrinho
   10. Botões, Links & Formulários
   11. Cards (posts, produtos, genéricos)
   12. Conteúdo (single, page, blog, comentários)
   13. Sidebar & Widgets
   14. Footer (fallback nativo)
   15. Botão Voltar ao Topo
   16. Breadcrumbs
   17. WooCommerce
   18. Utilitários
   19. Responsividade
   ========================================================================= */

/* -------------------------------------------------------------------------
   1. CUSTOM PROPERTIES — paleta extraída da logo (marrom + dourado)
------------------------------------------------------------------------- */
:root {
	/* Marca */
	--bdp-primary: #5C3A21;
	--bdp-primary-dark: #3D2615;
	--bdp-primary-light: #7A5233;
	--bdp-secondary: #F5A623;
	--bdp-secondary-dark: #D98C0F;
	--bdp-secondary-light: #FBC463;
	--bdp-accent: #211A14;

	/* Neutros */
	--bdp-cream: #FFF8ED;
	--bdp-cream-dark: #F2E2C4;
	--bdp-white: #FFFFFF;
	--bdp-border: #E8DCC8;
	--bdp-text: #2B1B10;
	--bdp-text-muted: #6B5847;

	/* Semânticas */
	--bdp-success: #3F7A3F;
	--bdp-error: #B23B3B;
	--bdp-star: #F5A623;

	/* Tipografia (sobrescrito pelo Customizer) */
	--bdp-font-heading: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--bdp-font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

	/* Métricas */
	--bdp-radius-sm: 6px;
	--bdp-radius-md: 12px;
	--bdp-radius-lg: 20px;
	--bdp-shadow-sm: 0 1px 3px rgba(43, 27, 16, 0.08);
	--bdp-shadow-md: 0 6px 20px rgba(43, 27, 16, 0.08);
	--bdp-shadow-lg: 0 12px 32px rgba(43, 27, 16, 0.12);
	--bdp-container: 1280px;
	--bdp-header-height: 84px;
	--bdp-transition: 0.2s ease;
}

/* -------------------------------------------------------------------------
   2. RESET & BASE
------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
	margin: 0;
	background: var(--bdp-white);
	color: var(--bdp-text);
	font-family: var(--bdp-font-body);
	font-size: 16px;
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }
svg { display: inline-block; vertical-align: middle; }

a {
	color: var(--bdp-primary);
	text-decoration: none;
	transition: color var(--bdp-transition);
}
a:hover { color: var(--bdp-secondary-dark); }

ul, ol { margin: 0 0 1.5em; padding-left: 1.25em; }
p { margin: 0 0 1.5em; }
figure { margin: 0; }

table { width: 100%; border-collapse: collapse; }

hr {
	border: none;
	border-top: 1px solid var(--bdp-border);
	margin: 2em 0;
}

/* Elementor gerencia o próprio layout: nunca restringir largura de seções dele */
.elementor-section, .elementor-container, .elementor-widget-wrap {
	max-width: none;
}

/* -------------------------------------------------------------------------
   3. TIPOGRAFIA
------------------------------------------------------------------------- */
h1, h2, h3, h4, h5, h6 {
	font-family: var(--bdp-font-heading);
	font-weight: 700;
	line-height: 1.25;
	color: var(--bdp-primary-dark);
	margin: 0 0 0.6em;
}

h1 { font-size: clamp(2rem, 1.6rem + 1.6vw, 3rem); }
h2 { font-size: clamp(1.65rem, 1.4rem + 1vw, 2.25rem); }
h3 { font-size: clamp(1.35rem, 1.2rem + 0.6vw, 1.75rem); }
h4 { font-size: 1.25rem; }
h5 { font-size: 1.1rem; }
h6 { font-size: 1rem; text-transform: uppercase; letter-spacing: 0.06em; }

.entry-content, .page-content { font-size: 1.05rem; }

blockquote {
	margin: 1.5em 0;
	padding: 1em 1.5em;
	border-left: 4px solid var(--bdp-secondary);
	background: var(--bdp-cream);
	border-radius: 0 var(--bdp-radius-sm) var(--bdp-radius-sm) 0;
	font-style: italic;
	color: var(--bdp-text-muted);
}

/* -------------------------------------------------------------------------
   4. LAYOUT & CONTAINER
------------------------------------------------------------------------- */
.bdp-container {
	width: 100%;
	max-width: var(--bdp-container);
	margin-inline: auto;
	padding-inline: 24px;
}

.site-main { display: block; width: 100%; }

.bdp-content-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 48px;
	max-width: var(--bdp-container);
	margin-inline: auto;
	padding: 48px 24px;
}
.bdp-content-layout.has-sidebar { grid-template-columns: minmax(0, 2.4fr) minmax(0, 1fr); }

/* -------------------------------------------------------------------------
   5. ACESSIBILIDADE & FOCO
------------------------------------------------------------------------- */
.screen-reader-text {
	position: absolute !important;
	width: 1px; height: 1px;
	margin: -1px; padding: 0; overflow: hidden;
	clip: rect(0, 0, 0, 0);
	border: 0;
}

.skip-link {
	position: absolute;
	top: -100px;
	left: 12px;
	z-index: 100000;
	background: var(--bdp-primary);
	color: var(--bdp-white);
	padding: 12px 20px;
	border-radius: var(--bdp-radius-sm);
	transition: top var(--bdp-transition);
}
.skip-link:focus {
	top: 12px;
	color: var(--bdp-white);
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
.bdp-icon-btn:focus-visible {
	outline: 3px solid var(--bdp-secondary);
	outline-offset: 2px;
	border-radius: var(--bdp-radius-sm);
}

/* -------------------------------------------------------------------------
   6. HEADER (fallback — só é usado quando não há Header do Elementor Theme Builder)
------------------------------------------------------------------------- */
.site-header {
	background: var(--bdp-white);
	border-bottom: 1px solid var(--bdp-border);
	position: relative;
	z-index: 999;
}

.site-header.is-sticky {
	position: sticky;
	top: 0;
	box-shadow: var(--bdp-shadow-md);
	animation: bdp-slide-down 0.25s ease;
}

@keyframes bdp-slide-down {
	from { transform: translateY(-100%); }
	to { transform: translateY(0); }
}

.bdp-header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	min-height: var(--bdp-header-height);
	padding-block: 12px;
}

.site-branding { display: flex; align-items: center; }
.site-branding .custom-logo-link img { max-height: 56px; width: auto; }
.site-branding .site-title {
	font-family: var(--bdp-font-heading);
	font-size: 1.5rem;
	font-weight: 800;
	color: var(--bdp-primary);
	margin: 0;
}
.site-branding .site-description {
	font-size: 0.8rem;
	color: var(--bdp-text-muted);
	margin: 0;
}

.bdp-header-actions {
	display: flex;
	align-items: center;
	gap: 6px;
}

.bdp-icon-btn {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border: none;
	background: transparent;
	color: var(--bdp-primary-dark);
	border-radius: 50%;
	cursor: pointer;
	transition: background var(--bdp-transition), color var(--bdp-transition);
}
.bdp-icon-btn:hover { background: var(--bdp-cream); color: var(--bdp-secondary-dark); }
.bdp-icon-btn svg { width: 22px; height: 22px; }

.bdp-cart-count {
	position: absolute;
	top: 2px;
	right: 2px;
	min-width: 18px;
	height: 18px;
	padding: 0 4px;
	border-radius: 50%;
	background: var(--bdp-secondary);
	color: var(--bdp-primary-dark);
	font-size: 11px;
	font-weight: 700;
	line-height: 18px;
	text-align: center;
}

/* -------------------------------------------------------------------------
   7. NAVEGAÇÃO
------------------------------------------------------------------------- */
.bdp-main-nav { display: none; }

.bdp-main-nav ul {
	display: flex;
	align-items: center;
	gap: 4px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.bdp-main-nav a {
	display: block;
	padding: 10px 16px;
	border-radius: var(--bdp-radius-sm);
	color: var(--bdp-text);
	font-weight: 600;
	font-size: 0.95rem;
}
.bdp-main-nav a:hover,
.bdp-main-nav .current-menu-item > a {
	color: var(--bdp-primary-dark);
	background: var(--bdp-cream);
}

.bdp-main-nav li { position: relative; }

.bdp-main-nav ul ul {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 220px;
	background: var(--bdp-white);
	border: 1px solid var(--bdp-border);
	border-radius: var(--bdp-radius-md);
	box-shadow: var(--bdp-shadow-lg);
	padding: 8px;
	z-index: 50;
	flex-direction: column;
}
.bdp-main-nav li:hover > ul,
.bdp-main-nav li:focus-within > ul { display: flex; }
.bdp-main-nav ul ul a { border-radius: var(--bdp-radius-sm); }
.bdp-main-nav ul ul ul { top: 0; left: 100%; }

.bdp-menu-toggle {
	display: inline-flex;
}

.bdp-mobile-nav {
	position: fixed;
	inset: 0 0 0 auto;
	width: min(340px, 86vw);
	height: 100vh;
	background: var(--bdp-white);
	box-shadow: var(--bdp-shadow-lg);
	transform: translateX(100%);
	transition: transform 0.28s ease;
	z-index: 1001;
	overflow-y: auto;
	padding: 20px;
}
.bdp-mobile-nav.is-open { transform: translateX(0); }

.bdp-mobile-nav-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 16px;
}

.bdp-mobile-nav ul { list-style: none; margin: 0; padding: 0; }
.bdp-mobile-nav a {
	display: block;
	padding: 12px 8px;
	border-bottom: 1px solid var(--bdp-border);
	color: var(--bdp-text);
	font-weight: 600;
}
.bdp-mobile-nav ul ul { padding-left: 16px; }

.bdp-overlay {
	position: fixed;
	inset: 0;
	background: rgba(33, 26, 20, 0.5);
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--bdp-transition);
	z-index: 1000;
}
.bdp-overlay.is-visible { opacity: 1; visibility: visible; }

/* -------------------------------------------------------------------------
   8. BUSCA (overlay)
------------------------------------------------------------------------- */
.bdp-search-panel {
	position: fixed;
	inset: 0 0 auto 0;
	background: var(--bdp-white);
	border-bottom: 1px solid var(--bdp-border);
	box-shadow: var(--bdp-shadow-lg);
	transform: translateY(-100%);
	transition: transform 0.25s ease;
	z-index: 1002;
	padding: 32px 24px;
}
.bdp-search-panel.is-open { transform: translateY(0); }
.bdp-search-panel form {
	max-width: 760px;
	margin: 0 auto;
	display: flex;
	gap: 12px;
}
.bdp-search-panel input[type="search"] {
	flex: 1;
	font-size: 1.15rem;
	padding: 14px 18px;
}
.bdp-search-panel-close {
	position: absolute;
	top: 16px;
	right: 16px;
}

/* -------------------------------------------------------------------------
   9. MINI CARRINHO
------------------------------------------------------------------------- */
.bdp-mini-cart-panel {
	position: fixed;
	inset: 0 0 0 auto;
	width: min(400px, 90vw);
	height: 100vh;
	background: var(--bdp-white);
	box-shadow: var(--bdp-shadow-lg);
	transform: translateX(100%);
	transition: transform 0.28s ease;
	z-index: 1001;
	display: flex;
	flex-direction: column;
}
.bdp-mini-cart-panel.is-open { transform: translateX(0); }

.bdp-mini-cart-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 20px;
	border-bottom: 1px solid var(--bdp-border);
}
.bdp-mini-cart-body { flex: 1; overflow-y: auto; padding: 20px; }
.bdp-mini-cart-footer { padding: 20px; border-top: 1px solid var(--bdp-border); }

/* -------------------------------------------------------------------------
   10. BOTÕES, LINKS & FORMULÁRIOS
------------------------------------------------------------------------- */
.bdp-btn,
button:not(.bdp-icon-btn):not(.bdp-menu-toggle),
input[type="submit"],
input[type="button"],
.button,
.wp-block-button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	font-family: var(--bdp-font-heading);
	font-weight: 600;
	font-size: 0.95rem;
	padding: 13px 28px;
	border-radius: var(--bdp-radius-sm);
	border: 2px solid var(--bdp-primary);
	background: var(--bdp-primary);
	color: var(--bdp-white);
	cursor: pointer;
	transition: background var(--bdp-transition), border-color var(--bdp-transition), color var(--bdp-transition), transform var(--bdp-transition);
}
.bdp-btn:hover,
button:not(.bdp-icon-btn):not(.bdp-menu-toggle):hover,
input[type="submit"]:hover,
.button:hover,
.wp-block-button__link:hover {
	background: var(--bdp-primary-dark);
	border-color: var(--bdp-primary-dark);
	color: var(--bdp-white);
	transform: translateY(-1px);
}

.bdp-btn.is-secondary,
.button.alt,
.checkout-button,
.single_add_to_cart_button {
	background: var(--bdp-secondary);
	border-color: var(--bdp-secondary);
	color: var(--bdp-primary-dark);
}
.bdp-btn.is-secondary:hover,
.button.alt:hover,
.checkout-button:hover,
.single_add_to_cart_button:hover {
	background: var(--bdp-secondary-dark);
	border-color: var(--bdp-secondary-dark);
	color: var(--bdp-primary-dark);
}

.bdp-btn.is-outline {
	background: transparent;
	color: var(--bdp-primary);
}
.bdp-btn.is-outline:hover { background: var(--bdp-primary); color: var(--bdp-white); }

fieldset { border: 1px solid var(--bdp-border); border-radius: var(--bdp-radius-md); }

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
textarea,
select {
	width: 100%;
	padding: 12px 14px;
	background: var(--bdp-white);
	border: 1.5px solid var(--bdp-border);
	border-radius: var(--bdp-radius-sm);
	color: var(--bdp-text);
	font-family: var(--bdp-font-body);
	font-size: 0.95rem;
	transition: border-color var(--bdp-transition);
}
input:focus, textarea:focus, select:focus {
	border-color: var(--bdp-secondary);
	outline: none;
}
label { font-weight: 600; display: inline-block; margin-bottom: 6px; }

/* -------------------------------------------------------------------------
   11. CARDS
------------------------------------------------------------------------- */
.bdp-card {
	background: var(--bdp-white);
	border: 1px solid var(--bdp-border);
	border-radius: var(--bdp-radius-md);
	box-shadow: var(--bdp-shadow-sm);
	overflow: hidden;
	transition: box-shadow var(--bdp-transition), transform var(--bdp-transition);
}
.bdp-card:hover { box-shadow: var(--bdp-shadow-md); transform: translateY(-3px); }

.bdp-posts-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 32px;
}

.bdp-post-card .entry-thumbnail { aspect-ratio: 16 / 10; overflow: hidden; }
.bdp-post-card .entry-thumbnail img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.35s ease; }
.bdp-post-card:hover .entry-thumbnail img { transform: scale(1.05); }
.bdp-post-card .entry-body { padding: 20px; }
.bdp-post-card .entry-meta { font-size: 0.82rem; color: var(--bdp-text-muted); margin-bottom: 8px; }
.bdp-post-card .entry-title { font-size: 1.15rem; margin-bottom: 10px; }
.bdp-post-card .entry-title a { color: var(--bdp-primary-dark); }
.bdp-post-card .entry-excerpt { color: var(--bdp-text-muted); font-size: 0.92rem; }

/* -------------------------------------------------------------------------
   12. CONTEÚDO
------------------------------------------------------------------------- */
.entry-header { margin-bottom: 24px; }
.entry-title { color: var(--bdp-primary-dark); }
.entry-meta { color: var(--bdp-text-muted); font-size: 0.9rem; display: flex; flex-wrap: wrap; gap: 12px; }
.entry-meta a { color: inherit; }
.entry-thumbnail { margin-bottom: 32px; border-radius: var(--bdp-radius-md); overflow: hidden; }

.entry-tags { margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--bdp-border); }
.entry-tags a {
	display: inline-block;
	padding: 6px 14px;
	margin: 0 6px 6px 0;
	background: var(--bdp-cream);
	border-radius: 999px;
	font-size: 0.82rem;
	color: var(--bdp-primary-dark);
}

.post-navigation {
	display: flex;
	justify-content: space-between;
	gap: 24px;
	margin-top: 40px;
	padding-top: 24px;
	border-top: 1px solid var(--bdp-border);
}
.post-navigation a { font-weight: 600; }

.pagination, .bdp-pagination {
	display: flex;
	justify-content: center;
	gap: 8px;
	margin-top: 40px;
	list-style: none;
	padding: 0;
}
.pagination a, .pagination span,
.bdp-pagination a, .bdp-pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 12px;
	border-radius: var(--bdp-radius-sm);
	border: 1px solid var(--bdp-border);
	color: var(--bdp-text);
	font-weight: 600;
}
.pagination .current, .bdp-pagination .current {
	background: var(--bdp-primary);
	border-color: var(--bdp-primary);
	color: var(--bdp-white);
}

/* Comentários */
.comments-area { margin-top: 48px; }
.comment-list { list-style: none; margin: 0; padding: 0; }
.comment-list .children { list-style: none; padding-left: 32px; }
.comment-body {
	padding: 20px;
	margin-bottom: 16px;
	background: var(--bdp-cream);
	border-radius: var(--bdp-radius-md);
}
.comment-author .fn { font-weight: 700; color: var(--bdp-primary-dark); }
.comment-metadata { font-size: 0.82rem; color: var(--bdp-text-muted); }
.comment-reply-link { font-weight: 600; }

/* -------------------------------------------------------------------------
   13. SIDEBAR & WIDGETS
------------------------------------------------------------------------- */
.widget {
	margin-bottom: 32px;
	padding: 24px;
	background: var(--bdp-cream);
	border-radius: var(--bdp-radius-md);
}
.widget-title {
	font-size: 1.05rem;
	margin-bottom: 16px;
	padding-bottom: 12px;
	border-bottom: 2px solid var(--bdp-secondary);
}
.widget ul { list-style: none; margin: 0; padding: 0; }
.widget ul li { padding: 6px 0; border-bottom: 1px solid var(--bdp-border); }
.widget ul li:last-child { border-bottom: none; }
.widget select, .widget input { margin-top: 8px; }

/* -------------------------------------------------------------------------
   14. FOOTER (fallback)
------------------------------------------------------------------------- */
.site-footer {
	background: var(--bdp-primary-dark);
	color: var(--bdp-cream);
	margin-top: 64px;
}
.site-footer a { color: var(--bdp-secondary-light); }
.site-footer a:hover { color: var(--bdp-secondary); }

.bdp-footer-widgets {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 32px;
	padding: 56px 24px;
	max-width: var(--bdp-container);
	margin-inline: auto;
}
.bdp-footer-widgets .widget { background: transparent; padding: 0; }
.bdp-footer-widgets .widget-title { color: var(--bdp-white); border-bottom-color: var(--bdp-secondary); }
.bdp-footer-widgets .widget ul li { border-bottom-color: rgba(255,255,255,0.1); }

.bdp-footer-bottom {
	border-top: 1px solid rgba(255,255,255,0.12);
	padding: 20px 24px;
}
.bdp-footer-bottom-inner {
	max-width: var(--bdp-container);
	margin-inline: auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 12px;
	font-size: 0.85rem;
}
.bdp-social-links { display: flex; gap: 10px; list-style: none; margin: 0; padding: 0; }
.bdp-social-links a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border-radius: 50%;
	background: rgba(255,255,255,0.08);
}
.bdp-social-links a:hover { background: var(--bdp-secondary); color: var(--bdp-primary-dark); }
.bdp-social-links svg { width: 18px; height: 18px; }

/* -------------------------------------------------------------------------
   15. BOTÃO VOLTAR AO TOPO
------------------------------------------------------------------------- */
.bdp-back-to-top {
	position: fixed;
	right: 24px;
	bottom: 24px;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: var(--bdp-primary);
	color: var(--bdp-white);
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: var(--bdp-shadow-md);
	opacity: 0;
	visibility: hidden;
	transform: translateY(10px);
	transition: all var(--bdp-transition);
	z-index: 900;
	border: none;
	cursor: pointer;
}
.bdp-back-to-top.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }
.bdp-back-to-top:hover { background: var(--bdp-secondary); color: var(--bdp-primary-dark); }

/* -------------------------------------------------------------------------
   16. BREADCRUMBS
------------------------------------------------------------------------- */
.bdp-breadcrumbs {
	font-size: 0.85rem;
	color: var(--bdp-text-muted);
	padding: 16px 0;
}
.bdp-breadcrumbs a { color: var(--bdp-text-muted); }
.bdp-breadcrumbs a:hover { color: var(--bdp-primary); }
.bdp-breadcrumbs .sep { margin: 0 8px; opacity: 0.6; }

/* -------------------------------------------------------------------------
   17. WOOCOMMERCE
------------------------------------------------------------------------- */
.woocommerce ul.products {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 28px;
	margin: 0 0 40px;
	padding: 0;
	list-style: none;
}
.woocommerce ul.products li.product {
	background: var(--bdp-white);
	border: 1px solid var(--bdp-border);
	border-radius: var(--bdp-radius-md);
	padding: 18px;
	text-align: left;
	box-shadow: var(--bdp-shadow-sm);
	transition: box-shadow var(--bdp-transition), transform var(--bdp-transition);
	position: relative;
}
.woocommerce ul.products li.product:hover { box-shadow: var(--bdp-shadow-md); transform: translateY(-4px); }
.woocommerce ul.products li.product img {
	border-radius: var(--bdp-radius-sm);
	aspect-ratio: 1 / 1;
	object-fit: cover;
	margin-bottom: 14px;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--bdp-font-heading);
	font-size: 1rem;
	font-weight: 600;
	color: var(--bdp-text);
	margin-bottom: 6px;
}
.woocommerce ul.products li.product .price {
	font-family: var(--bdp-font-heading);
	color: var(--bdp-primary);
	font-weight: 700;
	font-size: 1.1rem;
}
.woocommerce ul.products li.product .price del { color: var(--bdp-text-muted); font-weight: 400; opacity: 0.7; }
.woocommerce ul.products li.product .price ins { text-decoration: none; }
.woocommerce ul.products li.product .button {
	margin-top: 14px;
	width: 100%;
	padding: 10px 16px;
	font-size: 0.85rem;
}
.woocommerce ul.products li.product .star-rating { color: var(--bdp-star); margin-bottom: 6px; }

.woocommerce span.onsale {
	position: absolute;
	top: 14px;
	left: 14px;
	background: var(--bdp-secondary);
	color: var(--bdp-primary-dark);
	font-weight: 700;
	font-size: 0.75rem;
	padding: 5px 12px;
	border-radius: 999px;
	min-height: auto;
	min-width: auto;
	line-height: 1;
}

.woocommerce nav.woocommerce-pagination ul { border: none; }
.woocommerce nav.woocommerce-pagination ul li { border: none; margin-right: 8px; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	border: 1px solid var(--bdp-border);
	border-radius: var(--bdp-radius-sm);
	padding: 8px 14px;
}

/* Página do produto */
.woocommerce div.product .product_title { color: var(--bdp-primary-dark); }
.woocommerce div.product p.price, .woocommerce div.product span.price {
	color: var(--bdp-primary);
	font-family: var(--bdp-font-heading);
	font-size: 1.6rem;
	font-weight: 700;
}
.woocommerce div.product .woocommerce-product-rating { margin-bottom: 20px; }
.woocommerce div.product .stock { font-weight: 600; color: var(--bdp-success); }
.woocommerce div.product .stock.out-of-stock { color: var(--bdp-error); }

.woocommerce div.product form.cart {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 16px;
	margin: 24px 0;
}
.woocommerce div.product form.cart .quantity input {
	width: 80px;
	text-align: center;
}
.woocommerce div.product .single_add_to_cart_button { padding: 16px 40px; font-size: 1rem; }

/* Galeria de produto */
.woocommerce div.product div.images .flex-control-thumbs {
	display: flex;
	gap: 10px;
	margin-top: 12px;
	list-style: none;
	padding: 0;
}
.woocommerce div.product div.images .flex-control-thumbs li { width: 72px; }
.woocommerce div.product div.images .flex-control-thumbs img {
	border-radius: var(--bdp-radius-sm);
	border: 2px solid transparent;
	cursor: pointer;
}
.woocommerce div.product div.images .flex-control-thumbs img.flex-active { border-color: var(--bdp-secondary); }
.woocommerce div.product div.images img { border-radius: var(--bdp-radius-md); }

/* Variações */
.woocommerce div.product .variations { margin-bottom: 20px; }
.woocommerce div.product .variations td.label { font-weight: 700; padding-right: 12px; }
.woocommerce div.product .variations select { max-width: 320px; }
.woocommerce div.product .woocommerce-variation-price .price { font-size: 1.3rem; }

/* Abas do produto */
.woocommerce div.product .woocommerce-tabs ul.tabs {
	border-bottom: 2px solid var(--bdp-border);
	list-style: none;
	padding: 0;
	display: flex;
	gap: 8px;
	margin-bottom: 24px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li { margin: 0; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	display: inline-block;
	padding: 12px 20px;
	font-weight: 600;
	color: var(--bdp-text-muted);
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--bdp-primary); border-bottom: 3px solid var(--bdp-secondary); }

/* Avaliações */
.woocommerce #reviews .comment-text { background: var(--bdp-cream); border-radius: var(--bdp-radius-md); }
.woocommerce #reviews .star-rating { color: var(--bdp-star); }
.woocommerce #review_form input, .woocommerce #review_form textarea { background: var(--bdp-white); }

/* Breadcrumbs nativo do Woo */
.woocommerce-breadcrumb {
	font-size: 0.85rem;
	color: var(--bdp-text-muted);
	margin-bottom: 24px;
}
.woocommerce-breadcrumb a { color: var(--bdp-text-muted); }

/* Mensagens */
.woocommerce-message, .woocommerce-info, .woocommerce-error, .woocommerce-noreviews,
.woocommerce-store-notice {
	background: var(--bdp-cream);
	border-top: 3px solid var(--bdp-secondary);
	border-radius: var(--bdp-radius-sm);
	padding: 16px 20px;
	list-style: none;
}
.woocommerce-error { border-top-color: var(--bdp-error); }
.woocommerce-message::before, .woocommerce-info::before, .woocommerce-error::before { display: none; }

/* Carrinho */
.woocommerce table.shop_table {
	border: 1px solid var(--bdp-border);
	border-radius: var(--bdp-radius-md);
	overflow: hidden;
	border-collapse: collapse;
}
.woocommerce table.shop_table th {
	background: var(--bdp-cream);
	font-family: var(--bdp-font-heading);
	text-align: left;
	padding: 14px;
}
.woocommerce table.shop_table td { padding: 14px; border-top: 1px solid var(--bdp-border); }
.woocommerce-cart-form .product-remove a { color: var(--bdp-error); }
.woocommerce .cart-collaterals .cart_totals { background: var(--bdp-cream); padding: 24px; border-radius: var(--bdp-radius-md); }
.woocommerce .cart-collaterals .cart_totals table { border: none; }
.woocommerce .cart-collaterals .cart_totals th, .woocommerce .cart-collaterals .cart_totals td { background: transparent; border-top: 1px solid var(--bdp-border); }

/* Checkout */
.woocommerce-checkout #payment { background: var(--bdp-cream); border-radius: var(--bdp-radius-md); padding: 20px; }
.woocommerce-checkout #payment ul.payment_methods { list-style: none; padding: 0; }
.woocommerce-checkout table.shop_table { background: var(--bdp-white); }
.woocommerce form .form-row { margin-bottom: 16px; }
.select2-container--default .select2-selection--single {
	height: 46px;
	border-color: var(--bdp-border);
	border-radius: var(--bdp-radius-sm);
	padding-top: 6px;
}

/* Minha Conta */
.woocommerce-account .woocommerce-MyAccount-navigation {
	background: var(--bdp-cream);
	border-radius: var(--bdp-radius-md);
	padding: 16px;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul { list-style: none; margin: 0; padding: 0; }
.woocommerce-account .woocommerce-MyAccount-navigation li { border-bottom: 1px solid var(--bdp-border); }
.woocommerce-account .woocommerce-MyAccount-navigation li:last-child { border-bottom: none; }
.woocommerce-account .woocommerce-MyAccount-navigation li a { display: block; padding: 10px 8px; font-weight: 600; }
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a { color: var(--bdp-primary); }
.woocommerce-account .woocommerce-MyAccount-content { background: var(--bdp-white); }

@media (min-width: 782px) {
	.woocommerce-account .woocommerce-MyAccount-navigation { float: left; width: 26%; margin-right: 4%; }
	.woocommerce-account .woocommerce-MyAccount-content { float: left; width: 70%; }
}

/* Lista de desejos (YITH / TI WooCommerce Wishlist) */
.yith-wcwl-add-to-wishlist { margin-top: 10px; }
.yith-wcwl-wishlistaddedbrowse a, .yith-wcwl-wishlistexistsbrowse a { color: var(--bdp-primary); font-weight: 600; }
.add_to_wishlist { color: var(--bdp-primary); font-weight: 600; }

/* Badges de destaque */
.bdp-badge {
	display: inline-block;
	padding: 4px 12px;
	border-radius: 999px;
	font-size: 0.75rem;
	font-weight: 700;
	background: var(--bdp-secondary);
	color: var(--bdp-primary-dark);
}

/* -------------------------------------------------------------------------
   18. UTILITÁRIOS
------------------------------------------------------------------------- */
.bdp-full-bleed { width: 100vw; margin-left: calc(50% - 50vw); }
.alignwide { max-width: calc(var(--bdp-container) + 120px); margin-inline: auto; }
.alignfull { max-width: none; }
.has-text-align-center { text-align: center; }
.bdp-hidden { display: none !important; }
.bdp-lock-scroll { overflow: hidden; }

/* -------------------------------------------------------------------------
   19. RESPONSIVIDADE
------------------------------------------------------------------------- */
@media (max-width: 1024px) {
	.bdp-content-layout.has-sidebar { grid-template-columns: minmax(0, 1fr); }
}

@media (min-width: 1025px) {
	.bdp-main-nav { display: block; }
	.bdp-menu-toggle { display: none; }
}

@media (max-width: 1024px) {
	.bdp-menu-toggle { display: inline-flex; }
}

@media (max-width: 600px) {
	:root { --bdp-header-height: 68px; }
	.site-branding .custom-logo-link img { max-height: 42px; }
	.bdp-footer-widgets { padding: 40px 20px; }
	.bdp-back-to-top { right: 16px; bottom: 16px; width: 42px; height: 42px; }
	.woocommerce ul.products { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 16px; }
}
