/* =========================================================
   Biopharvet — WooCommerce (archive de productos / shop)
   ========================================================= */

.bp-shop {
	background: var(--bp-white);
}

.bp-shop__container {
	padding-top: 56px;
	padding-bottom: 80px;
}

.bp-shop__layout {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 32px;
	align-items: flex-start;
}

/* ---------- Sidebar de categorías ---------- */

.bp-shop-aside {
	background: var(--bp-white);
	border: 1px solid var(--bp-border);
	border-radius: var(--bp-radius);
	padding: 22px 22px 12px;
	position: sticky;
	top: 24px;
}

.bp-shop-aside__title {
	font-size: 16px;
	font-weight: 700;
	color: var(--bp-navy);
	margin: 0 0 14px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--bp-border);
}

.bp-shop-aside__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.bp-shop-aside__item + .bp-shop-aside__item {
	border-top: 1px solid var(--bp-border);
}

.bp-shop-aside__item a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 12px 0;
	font-size: 14px;
	color: var(--bp-text-soft);
	transition: color var(--bp-trans);
}

.bp-shop-aside__item a:hover,
.bp-shop-aside__item.is-current a {
	color: var(--bp-green);
	font-weight: 600;
}

.bp-shop-aside__item svg {
	opacity: 0;
	color: var(--bp-green);
	transition: opacity var(--bp-trans), transform var(--bp-trans);
	transform: translateX(-4px);
	flex-shrink: 0;
}

.bp-shop-aside__item a:hover svg,
.bp-shop-aside__item.is-current a svg {
	opacity: 1;
	transform: translateX(0);
}

/* ---------- Main: grid de productos ---------- */

.bp-shop__main {
	min-width: 0; /* evita overflow del grid en mobile */
}

/* WooCommerce envuelve el loop en <ul class="products columns-N">.
   Prefijamos con .woocommerce/.woocommerce-page para vencer en especificidad
   los defaults de Woo (`.woocommerce ul.products li.product { width: 22.05% }`
   y `.woocommerce ul.products.columns-3 li.product { width: 30.75% }`). */
.woocommerce .bp-shop__main ul.products,
.woocommerce-page .bp-shop__main ul.products,
.bp-shop__main ul.products {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}

/* Woo añade ::before/::after a ul.products como clearfix del layout legacy basado
   en floats. En display:grid esos pseudo-elementos se convierten en grid items y
   ocupan celdas, empujando las cards una posición. Los anulamos. */
.bp-shop__main ul.products::before,
.bp-shop__main ul.products::after {
	display: none;
	content: none;
}

/* Anulamos float + width del default de Woo (incluido el de .columns-N). */
.woocommerce .bp-shop__main ul.products li.product,
.woocommerce-page .bp-shop__main ul.products li.product,
.woocommerce .bp-shop__main ul.products.columns-1 li.product,
.woocommerce .bp-shop__main ul.products.columns-2 li.product,
.woocommerce .bp-shop__main ul.products.columns-3 li.product,
.woocommerce .bp-shop__main ul.products.columns-4 li.product,
.woocommerce .bp-shop__main ul.products.columns-5 li.product,
.woocommerce-page .bp-shop__main ul.products.columns-1 li.product,
.woocommerce-page .bp-shop__main ul.products.columns-2 li.product,
.woocommerce-page .bp-shop__main ul.products.columns-3 li.product,
.woocommerce-page .bp-shop__main ul.products.columns-4 li.product,
.woocommerce-page .bp-shop__main ul.products.columns-5 li.product,
.bp-shop__main ul.products li.product {
	float: none !important;
	width: auto !important;
	max-width: none !important;
	margin: 0 !important;
	clear: none;
}

/* Card. */
.bp-shop__card {
	background: var(--bp-bg-soft);
	border: 1px solid var(--bp-border);
	border-radius: var(--bp-radius-lg);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform var(--bp-trans), box-shadow var(--bp-trans), border-color var(--bp-trans);
}

.bp-shop__card:hover {
	transform: translateY(-4px);
	box-shadow: 0 14px 28px rgba(15, 44, 115, 0.08);
	border-color: var(--bp-blue);
}

.bp-shop__media {
	background: var(--bp-white);
	aspect-ratio: 4 / 3;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
	position: relative;
}

.bp-shop__media img {
	max-width: 100%;
	max-height: 100%;
	width: auto;
	height: auto;
	object-fit: contain;
	margin: 0;
}

/* Badge "oferta" si Woo lo emite. */
.bp-shop__media .onsale {
	position: absolute;
	top: 12px;
	left: 12px;
	background: var(--bp-green);
	color: var(--bp-white);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	padding: 4px 10px;
	border-radius: 999px;
	min-width: 0;
	min-height: 0;
	line-height: 1.2;
}

.bp-shop__body {
	padding: 20px 20px 24px;
	text-align: center;
	display: flex;
	flex-direction: column;
	gap: 14px;
	flex: 1;
	border-top: 1px solid var(--bp-border);
}

.bp-shop__name {
	font-size: 16px;
	font-weight: 600;
	color: var(--bp-navy);
	margin: 0;
	line-height: 1.3;
}

.bp-shop__name a {
	color: inherit;
}

.bp-shop__name a:hover {
	color: var(--bp-blue);
}

.bp-shop__btn {
	align-self: center;
	margin-top: auto;
	padding: 10px 24px;
	font-size: 12px;
}

/* ---------- Aviso "no hay productos" ---------- */

.bp-shop__main .woocommerce-info,
.bp-shop__main .woocommerce-no-products-found {
	background: var(--bp-bg);
	border: 1px solid var(--bp-border);
	border-left: 4px solid var(--bp-blue);
	border-radius: var(--bp-radius);
	padding: 16px 18px;
	color: var(--bp-text-soft);
	font-size: 14px;
}

/* ---------- Paginación ---------- */

.bp-shop__main .woocommerce-pagination {
	margin-top: 40px;
	text-align: center;
}

.bp-shop__main .woocommerce-pagination ul.page-numbers {
	display: inline-flex;
	gap: 8px;
	list-style: none;
	margin: 0;
	padding: 0;
	border: 0;
}

.bp-shop__main .woocommerce-pagination ul.page-numbers li {
	border: 0;
	margin: 0;
	padding: 0;
}

.bp-shop__main .woocommerce-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 10px;
	border-radius: 999px;
	background: var(--bp-bg);
	color: var(--bp-text-soft);
	font-size: 13px;
	font-weight: 600;
	transition: background var(--bp-trans), color var(--bp-trans);
	border: 0;
}

.bp-shop__main .woocommerce-pagination .page-numbers:hover,
.bp-shop__main .woocommerce-pagination .page-numbers.current {
	background: var(--bp-blue);
	color: var(--bp-white);
}

/* ---------- Responsive ---------- */

@media (max-width: 1024px) {
	.woocommerce .bp-shop__main ul.products,
	.woocommerce-page .bp-shop__main ul.products,
	.bp-shop__main ul.products {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 860px) {
	.bp-shop__layout {
		grid-template-columns: 1fr;
		gap: 24px;
	}
	.bp-shop-aside {
		position: static;
	}
}

@media (max-width: 600px) {
	.bp-shop__container {
		padding-top: 32px;
		padding-bottom: 56px;
	}
	.woocommerce .bp-shop__main ul.products,
	.woocommerce-page .bp-shop__main ul.products,
	.bp-shop__main ul.products {
		grid-template-columns: 1fr;
	}
}


/* =========================================================
   Single product
   ========================================================= */

.bp-single {
	background: var(--bp-white);
}

/* ---------- Hero: galería + summary ---------- */

.bp-single__hero {
	background: var(--bp-white);
	padding: 48px 0 56px;
}

.bp-single__hero-inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 48px;
	align-items: flex-start;
}

/* Galería de Woo. */
.bp-single__gallery .woocommerce-product-gallery {
	width: 100% !important;
	margin: 0;
	float: none;
}

.bp-single__gallery .woocommerce-product-gallery__wrapper {
	margin: 0;
}

.bp-single__gallery .woocommerce-product-gallery__image {
	background: var(--bp-white);
	border: 1px solid var(--bp-border);
	border-radius: var(--bp-radius-lg);
	overflow: hidden;
	padding: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.bp-single__gallery .woocommerce-product-gallery__image img,
.bp-single__gallery .woocommerce-product-gallery__image a img {
	max-width: 100%;
	max-height: 480px;
	width: auto;
	height: auto;
	object-fit: contain;
	margin: 0;
}

/* Trigger de zoom (lupita) */
.bp-single__gallery .woocommerce-product-gallery__trigger {
	top: 16px;
	right: 16px;
	background: var(--bp-white);
	border: 1px solid var(--bp-border);
	border-radius: 50%;
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--bp-navy);
	text-decoration: none;
	font-size: 0;
}

.bp-single__gallery .woocommerce-product-gallery__trigger::before {
	content: '\1F50D';
	font-size: 16px;
}

/* Sale badge si lo hay. */
.bp-single__gallery .onsale {
	position: absolute;
	top: 16px;
	left: 16px;
	background: var(--bp-green);
	color: var(--bp-white);
	border-radius: 999px;
	padding: 4px 12px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	min-width: 0;
	min-height: 0;
	line-height: 1.2;
	margin: 0;
}

/* Thumbnails (cuando hay galería con más de una imagen). */
.bp-single__gallery .flex-control-thumbs {
	display: flex;
	gap: 10px;
	margin: 12px 0 0;
	padding: 0;
	list-style: none;
}

.bp-single__gallery .flex-control-thumbs li {
	width: 72px;
	margin: 0;
}

.bp-single__gallery .flex-control-thumbs img {
	border: 1px solid var(--bp-border);
	border-radius: var(--bp-radius);
	padding: 6px;
	background: var(--bp-white);
	cursor: pointer;
	opacity: 0.7;
	transition: opacity var(--bp-trans), border-color var(--bp-trans);
}

.bp-single__gallery .flex-control-thumbs img.flex-active,
.bp-single__gallery .flex-control-thumbs img:hover {
	opacity: 1;
	border-color: var(--bp-blue);
}

/* ---------- Summary ---------- */

.bp-single__summary {
	padding-top: 8px;
}

.bp-single__summary .product_title {
	font-size: clamp(26px, 2.4vw, 34px);
	color: var(--bp-navy);
	margin: 0 0 6px;
	line-height: 1.15;
	font-weight: 700;
}

.bp-single__pharma-form {
	margin: 0 0 16px;
	color: var(--bp-text-muted);
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 0.01em;
}

.bp-single__summary .woocommerce-product-details__short-description {
	color: var(--bp-text-soft);
	font-size: 15px;
	margin-bottom: 18px;
}

.bp-single__summary .woocommerce-product-details__short-description p:last-child {
	margin-bottom: 0;
}

.bp-single__meta {
	margin-top: 24px;
	padding-top: 18px;
	border-top: 1px solid var(--bp-border);
	font-size: 14px;
	color: var(--bp-text-soft);
}

.bp-single__meta-label {
	font-weight: 700;
	color: var(--bp-navy);
	margin-right: 4px;
}

.bp-single__meta-value a {
	color: var(--bp-text-soft);
}

.bp-single__meta-value a:hover {
	color: var(--bp-green);
}

/* ---------- Tabs ----------
   Selectores con alta especificidad para vencer los defaults de WooCommerce
   (`.woocommerce div.product .woocommerce-tabs ul.tabs ...`).
   --------------------------------------------------------- */

.bp-single__tabs {
	background: var(--bp-bg);
	padding: 40px 0 56px;
}

/* Wrapper de las tabs */
.woocommerce .bp-single__tabs .woocommerce-tabs,
.woocommerce-page .bp-single__tabs .woocommerce-tabs,
.bp-single__tabs .woocommerce-tabs {
	margin: 0;
	padding: 0;
}

/* UL — barra de pestañas */
.woocommerce .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs,
.woocommerce-page .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs,
.bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs {
	list-style: none;
	margin: 0 0 32px;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0;
	justify-content: center;
	background: transparent;
	border: 0;
	border-bottom: 2px solid var(--bp-green);
	overflow: visible;
	position: relative;
}

/* Quitar la línea inferior gris que Woo dibuja con ::before en la UL */
.woocommerce .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs::before,
.woocommerce-page .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs::before,
.bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs::before {
	display: none;
	content: none;
	border: 0;
	background: none;
}

/* LI — cada pestaña. Anular border/bg/border-radius/margins negativos/triángulos */
.woocommerce .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li,
.woocommerce-page .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li,
.bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li {
	display: block;
	background: transparent;
	border: 0;
	border-radius: 0;
	margin: 0;
	padding: 0;
	position: static;
	z-index: auto;
	box-shadow: none;
}

/* Eliminar los pseudo-elementos (las "orejitas" triangulares del default) */
.woocommerce .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li::before,
.woocommerce .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li::after,
.woocommerce-page .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li::before,
.woocommerce-page .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li::after,
.bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li::before,
.bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li::after {
	display: none;
	content: none;
	border: 0;
	background: none;
	box-shadow: none;
	width: 0;
	height: 0;
}

/* Enlace de cada pestaña */
.woocommerce .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li a,
.woocommerce-page .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li a,
.bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li a {
	display: inline-block;
	padding: 14px 28px;
	margin: 0;
	font-size: 14px;
	font-weight: 600;
	color: var(--bp-text-soft);
	background: transparent;
	text-transform: none;
	letter-spacing: 0.02em;
	text-shadow: none;
	border: 0;
	border-radius: 0;
	transition: color var(--bp-trans), background var(--bp-trans);
}

.woocommerce .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li a:hover,
.woocommerce-page .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li a:hover,
.bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li a:hover {
	color: var(--bp-green);
}

/* Pestaña activa */
.woocommerce .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li.active,
.woocommerce-page .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li.active,
.bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li.active {
	background: transparent;
	border: 0;
}

.woocommerce .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li.active a,
.woocommerce-page .bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li.active a,
.bp-single__tabs .woocommerce-tabs ul.tabs.wc-tabs li.active a {
	color: var(--bp-white);
	background: var(--bp-green);
}

/* Contenido de las pestañas */
.bp-single__tabs .woocommerce-Tabs-panel {
	color: var(--bp-text-soft);
	font-size: 14px;
	line-height: 1.7;
	max-width: 980px;
	margin: 0 auto;
	padding: 0;
}

.bp-single__tabs .woocommerce-Tabs-panel > h2:first-child {
	display: none; /* Woo añade un H2 con el título de la pestaña — el tab ya lo indica */
}

.bp-single__tabs .woocommerce-Tabs-panel h2,
.bp-single__tabs .woocommerce-Tabs-panel h3,
.bp-single__tabs .woocommerce-Tabs-panel h4 {
	color: var(--bp-navy);
	font-size: 15px;
	font-weight: 700;
	margin: 24px 0 10px;
}

/* ---------- Descargas ---------- */

.bp-single-downloads {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 12px;
}

.bp-single-downloads__item a {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 14px 18px;
	background: var(--bp-white);
	border: 1px solid var(--bp-border);
	border-radius: var(--bp-radius);
	color: var(--bp-text);
	font-size: 14px;
	font-weight: 500;
	transition: border-color var(--bp-trans), color var(--bp-trans), background var(--bp-trans);
}

.bp-single-downloads__item a:hover {
	border-color: var(--bp-green);
	color: var(--bp-green);
	background: #fff;
}

.bp-single-downloads__icon {
	color: var(--bp-green);
	display: inline-flex;
}

.bp-single-downloads__label {
	flex: 1;
}

.bp-single-downloads__ext {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.04em;
	color: var(--bp-text-muted);
	background: var(--bp-bg);
	padding: 4px 8px;
	border-radius: 4px;
}

/* ---------- Productos relacionados ---------- */

.bp-single__related {
	background: var(--bp-white);
	padding: 64px 0 80px;
}

.bp-single__related .related.products > h2,
.bp-single__related .upsells.products > h2 {
	text-align: center;
	font-size: clamp(22px, 2vw, 28px);
	color: var(--bp-navy);
	margin: 0 0 32px;
	font-weight: 700;
}

.bp-single__related ul.products {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
}

/* Mismo fix que en la shop: matar el clearfix pseudo-elemento de Woo
   que en display:grid roba una celda. */
.bp-single__related ul.products::before,
.bp-single__related ul.products::after {
	display: none;
	content: none;
}

.bp-single__related ul.products li.product {
	float: none;
	width: auto;
	margin: 0;
	clear: none;
}

/* ---------- Responsive ---------- */

@media (max-width: 960px) {
	.bp-single__hero-inner {
		grid-template-columns: 1fr;
		gap: 32px;
	}
	.bp-single__related ul.products {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 540px) {
	.bp-single__hero {
		padding: 32px 0 40px;
	}
	.bp-single__tabs {
		padding: 32px 0 40px;
	}
	.bp-single__related {
		padding: 48px 0 56px;
	}
	.bp-single__tabs ul.tabs.wc-tabs {
		flex-direction: column;
		align-items: stretch;
		gap: 6px;
	}
	.bp-single__tabs ul.tabs.wc-tabs li a {
		text-align: center;
		border-radius: var(--bp-radius);
	}
	.bp-single__related ul.products {
		grid-template-columns: 1fr;
	}
}
