/* ATC Product Cards — v0.2.0 */

/* ─── Neutraliza qualquer elemento WC/tema que vazou para fora do nosso template ─── */

.woocommerce ul.products li.product .atc-product-card > a:not(.atc-cta-btn),
.woocommerce ul.products li.product > a:not(.atc-cta-btn):not([class]),
.woocommerce ul.products li.product .woocommerce-loop-product__title:not(.atc-card-title),
.woocommerce ul.products li.product .price:not(.atc-price-value .price),
.woocommerce ul.products li.product .star-rating:not(.atc-stars .star-rating),
.woocommerce ul.products li.product .button:not(.atc-cta-btn),
.woocommerce ul.products li.product .onsale {
	display: none !important;
}

/* ─── Grade ─────────────────────────────────────────────────────────────── */

.woocommerce ul.products,
ul.products.atc-product-grid {
	display: grid !important;
	grid-template-columns: repeat(var(--atc-cols-desktop, 3), minmax(0, 1fr)) !important;
	gap: var(--atc-gap, 20px) !important;
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

@media (max-width: 900px) {
	.woocommerce ul.products,
	ul.products.atc-product-grid {
		grid-template-columns: repeat(var(--atc-cols-tablet, 2), minmax(0, 1fr)) !important;
	}
}

@media (max-width: 540px) {
	.woocommerce ul.products,
	ul.products.atc-product-grid {
		grid-template-columns: 1fr !important;
	}
}

/* ─── Card ───────────────────────────────────────────────────────────────── */

.woocommerce ul.products li.product {
	background: #fff !important;
	border: 0.5px solid rgba(0, 0, 0, 0.09) !important;
	border-radius: var(--atc-card-radius, 12px) !important;
	overflow: hidden !important;
	display: flex !important;
	flex-direction: column !important;
	margin: 0 !important;
	padding: 0 !important;
	transition: box-shadow 0.2s ease;
}

.woocommerce ul.products li.product:hover {
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}

/* ─── Imagem ─────────────────────────────────────────────────────────────── */

.atc-card-image-wrap {
	position: relative;
	width: 100%;
	height: var(--atc-img-height, 220px);
	overflow: hidden;
	flex-shrink: 0;
}

.atc-card-image-wrap img,
.atc-card-image-wrap .atc-card-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* ─── Badges ─────────────────────────────────────────────────────────────── */

.atc-badge {
	position: absolute;
	font-size: 11px;
	font-weight: 500;
	line-height: 1;
	padding: 5px 11px;
	border-radius: 20px;
}

.atc-badge-category {
	top: 10px;
	left: 10px;
	background: var(--atc-badge-bg, #1a1a1a);
	color: var(--atc-badge-color, #fff);
}

.atc-badge-discount {
	top: 10px;
	right: 10px;
	background: var(--atc-cta-bg, #2d6a4f);
	color: var(--atc-cta-color, #fff);
}

/* ─── Corpo ──────────────────────────────────────────────────────────────── */

.atc-card-body {
	padding: 16px 18px 18px;
	display: flex;
	flex-direction: column;
	flex: 1;
	gap: 8px;
}

/* Estrelas */
.atc-stars .star-rating {
	font-size: 13px;
	color: #e0a500;
}

/* Título */
.atc-card-title {
	font-size: var(--atc-title-size, 18px) !important;
	font-weight: 600 !important;
	margin: 0 !important;
	line-height: 1.3 !important;
	color: #1a1a1a !important;
	padding: 0 !important;
}

/* Localização */
.atc-card-location {
	font-size: 12px;
	color: #777;
	margin: 0;
	line-height: 1.4;
}

/* ─── Preço ──────────────────────────────────────────────────────────────── */

.atc-price-row {
	display: flex;
	align-items: baseline;
	gap: 5px;
	flex-wrap: wrap;
	margin-top: 2px;
}

.atc-price-from {
	font-size: 13px;
	color: #777;
	flex-shrink: 0;
}

.atc-price-value {
	font-size: var(--atc-price-size, 22px);
	font-weight: 700;
	color: #1a1a1a;
	line-height: 1;
}

/* Remove qualquer span.from que vaze para dentro do .atc-price-value */
.atc-price-value .from,
.atc-price-value .woocommerce-Price-currencySymbol + .from {
	display: none !important;
}

.atc-price-unit {
	font-size: 13px;
	color: #777;
	flex-shrink: 0;
}

/* ─── Bloco do cupom ─────────────────────────────────────────────────────── */

.atc-coupon-block {
	background: var(--atc-coupon-bg, #f0f0eb);
	border-radius: 8px;
	padding: 9px 12px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 2px;
	position: relative;
	user-select: none;
	transition: background 0.15s ease;
}

.atc-coupon-block[data-atc-copyable="1"] {
	cursor: pointer;
}

.atc-coupon-block[data-atc-copyable="1"]:hover {
	filter: brightness(0.96);
}

.atc-coupon-label {
	font-size: 11px;
	color: #888;
}

.atc-coupon-code {
	font-size: 12px;
	font-weight: 600;
	font-family: var(--atc-coupon-font, monospace);
	letter-spacing: 0.5px;
	color: var(--atc-coupon-color, #2d6a4f);
}

.atc-coupon-feedback {
	font-size: 11px;
	color: #2d6a4f;
	position: absolute;
	right: 12px;
	opacity: 0;
	transition: opacity 0.2s;
	pointer-events: none;
}

.atc-coupon-feedback.visible {
	opacity: 1;
}

/* ─── Botão CTA ──────────────────────────────────────────────────────────── */

.atc-cta-btn {
	display: block !important;
	width: 100% !important;
	background: var(--atc-cta-bg, #2d6a4f) !important;
	color: var(--atc-cta-color, #fff) !important;
	border: none !important;
	border-radius: 8px !important;
	padding: 11px 16px !important;
	font-size: 14px !important;
	font-weight: 500 !important;
	text-align: center !important;
	text-decoration: none !important;
	cursor: pointer;
	margin-top: auto !important;
	transition: filter 0.15s ease;
	box-sizing: border-box !important;
	line-height: 1.4 !important;
}

.atc-cta-btn:hover {
	filter: brightness(0.88);
	color: var(--atc-cta-color, #fff) !important;
	text-decoration: none !important;
}

/* ─── Estado sem produtos ────────────────────────────────────────────────── */

.atc-no-products {
	font-size: 14px;
	color: #888;
	text-align: center;
	padding: 2rem 0;
}

/* ─── Estrelas Google ────────────────────────────────────────────────────── */

.atc-stars {
	display: flex;
	align-items: center;
	gap: 4px;
	line-height: 1;
}

.atc-star-rating {
	display: inline-flex;
	gap: 1px;
}

.atc-star {
	font-size: 16px;
	line-height: 1;
}

.atc-star-full {
	color: #e0a500;
}

.atc-star-half {
	color: #e0a500;
	opacity: 0.6;
}

.atc-star-empty {
	color: #ddd;
}

.atc-star-score {
	font-size: 13px;
	font-weight: 600;
	color: #555;
	margin-left: 2px;
}

/* ─── Estrelas Google ────────────────────────────────────────────────────── */

.atc-stars { display: flex; align-items: center; gap: 4px; line-height: 1; }

.atc-star-rating { display: inline-flex; gap: 1px; }

.atc-star { font-size: 16px; line-height: 1; }
.atc-star-full  { color: #e0a500; }
.atc-star-half  { color: #e0a500; opacity: 0.55; }
.atc-star-empty { color: #ddd; }

.atc-star-score { font-size: 13px; font-weight: 600; color: #666; margin-left: 2px; }

/* ─── Toolbar (filtros de cidade + ordenação) ────────────────────────────── */

.atc-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 20px;
}

.atc-toolbar-group {
	display: flex;
	align-items: center;
	gap: 6px;
	flex-wrap: wrap;
}

.atc-toolbar-group--right {
	margin-left: auto;
}

.atc-sort-label {
	font-size: 12px;
	color: #999;
	margin-right: 2px;
	white-space: nowrap;
}

.atc-filter-btn,
.atc-sort-btn {
	font-size: 12px;
	padding: 5px 14px;
	border-radius: 20px;
	border: 0.5px solid rgba(0, 0, 0, 0.18);
	background: #fff;
	color: #555;
	cursor: pointer;
	line-height: 1.4;
	transition: background 0.12s, color 0.12s, border-color 0.12s;
	white-space: nowrap;
}

.atc-filter-btn:hover,
.atc-sort-btn:hover {
	border-color: rgba(0, 0, 0, 0.35);
	color: #222;
}

.atc-filter-btn.active,
.atc-sort-btn.active {
	background: #1a1a1a;
	color: #fff;
	border-color: #1a1a1a;
}

@media (max-width: 600px) {
	.atc-toolbar {
		flex-direction: column;
		align-items: flex-start;
	}
	.atc-toolbar-group--right {
		margin-left: 0;
	}
}
