/*
 * Línea Complementos alimenticios — tema oscuro premium (acotado)
 * Activo con: body.page-complementos-alimenticios + data-theme="supplements-dark"
 * No afecta al resto del sitio.
 */

.page-complementos-alimenticios {
	/* Jerarquía de superficies */
	--supp-bg-page: #0b0c0e;
	--supp-bg-surface: #121418;
	--supp-bg-elevated: #181b21;
	--supp-bg-card: #1e2229;
	--supp-bg-card-inner: #232830;
	--supp-image-well: #f7f6f4;
	--supp-image-well-border: rgba(15, 15, 18, 0.12);

	--supp-text-primary: #f0f1f4;
	--supp-text-secondary: #9aa3b0;
	--supp-text-muted: #6d7684;

	--supp-border: rgba(255, 255, 255, 0.07);
	--supp-border-strong: rgba(255, 255, 255, 0.11);
	--supp-shadow-soft: 0 1px 0 rgba(255, 255, 255, 0.04) inset, 0 18px 48px rgba(0, 0, 0, 0.45);
	--supp-shadow-card: 0 12px 40px rgba(0, 0, 0, 0.35);
	--supp-shadow-image: 0 8px 32px rgba(0, 0, 0, 0.28);

	/* Un solo acento discreto (gris‑azulado, no multicolor) */
	--supp-accent: #8b98a8;
	--supp-accent-hover: #a8b2bf;
	--supp-accent-cta: #3d4a5c;

	/* Cards listado: override prodCardUI sin arcoíris */
	--prodCardUI-title: var(--supp-text-primary);
	--prodCardUI-price: #d4d9e0;
	--prodCardUI-price-promo: var(--supp-text-muted);
	--prodCardUI-button-background: var(--supp-accent-cta);
	--prodCardUI-button-color: #f8f9fb;
	--prodCardUI-pack-color: #7d8694;
}

/* Canvas completo */
body.page-complementos-alimenticios {
	min-height: 100vh;
	background-color: var(--supp-bg-page);
	color: var(--supp-text-primary);
}

/* Cabecera: cohesión sin perder legibilidad */
.page-complementos-alimenticios header.header {
	background-color: var(--supp-bg-surface);
	box-shadow: 0 2px 24px rgba(0, 0, 0, 0.55);
	border-bottom: 1px solid var(--supp-border);
}

.page-complementos-alimenticios header.header > nav.header-nav > li.header-nav-item > span.header-nav-text,
.page-complementos-alimenticios header.header > nav.header-subnav > li.header-nav-item > span.header-nav-text {
	color: var(--supp-text-secondary);
}

.page-complementos-alimenticios header.header > nav.header-nav > li.header-nav-item > a.header-nav-link,
.page-complementos-alimenticios header.header > nav.header-subnav > li.header-nav-item > a.header-nav-link {
	color: var(--supp-accent);
}

.page-complementos-alimenticios header.header > nav.header-nav > li.header-nav-item > a.header-nav-link:hover,
.page-complementos-alimenticios header.header > nav.header-subnav > li.header-nav-item > a.header-nav-link:hover {
	color: var(--supp-accent-hover);
}

.page-complementos-alimenticios header.header > nav.header-nav > li.header-nav-item > a.header-nav-link.header-nav-account > span {
	color: var(--supp-text-primary);
}

.page-complementos-alimenticios header.header > nav.header-nav > li.header-nav-item select.header-nav-select,
.page-complementos-alimenticios header.header > nav.header-subnav > li.header-nav-item select.header-nav-select {
	color: var(--supp-text-primary);
	border-color: var(--supp-border-strong);
	background-color: rgba(0, 0, 0, 0.28);
}

.page-complementos-alimenticios header.header > nav.header-nav > li.header-nav-item > button.header-nav-button,
.page-complementos-alimenticios header.header > nav.header-subnav > li.header-nav-item > button.header-nav-button {
	color: var(--supp-text-primary);
	border-color: var(--supp-border-strong);
}

.page-complementos-alimenticios header.header button.header-toggler {
	color: var(--supp-text-primary);
}

.page-complementos-alimenticios header.header > nav.menu {
	background-color: var(--supp-bg-elevated);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
	border-top: 1px solid var(--supp-border);
}

.page-complementos-alimenticios header.header > nav.menu > li.menu-item > a.menu-link {
	/* Estado base: sin degradado (solo en hover) */
	color: #ffffff;
	border: none;
	background: transparent;
}

.page-complementos-alimenticios header.header > nav.menu > li.menu-item > a.menu-link:hover {
	background:
		linear-gradient(#000000, #000000) padding-box,
		linear-gradient(to right, #0e92c6, #a45f93, #f77f00) border-box;
	color: #ffffff;
}

/* Activo: sin degradado (solo en hover) */
.page-complementos-alimenticios header.header > nav.menu > li.menu-item.active > a.menu-link {
	color: #ffffff;
	border: 3px solid rgba(255, 255, 255, 0.2);
	background: #151515;
	box-shadow: none;
}

.page-complementos-alimenticios footer.footer {
	background-color: var(--supp-bg-elevated);
	color: var(--supp-text-primary) !important;
}

.page-complementos-alimenticios .footer > .footer-links .footer-dropdown > .footer-dropdown-button {
	color: var(--supp-text-secondary);
	opacity: 1;
}

.page-complementos-alimenticios .footer > .footer-links .footer-link > a {
	color: var(--supp-text-secondary);
}

.page-complementos-alimenticios .footer > .footer-links .footer-link > a:hover {
	color: var(--supp-accent-hover);
}

.page-complementos-alimenticios .footer > .footer-container {
	background-color: var(--supp-bg-surface);
	border-top: 1px solid var(--supp-border);
}

.page-complementos-alimenticios .footer > .footer-container > .footer-text > p,
.page-complementos-alimenticios .footer > .footer-container > .footer-text {
	color: var(--supp-text-muted);
}

.page-complementos-alimenticios .page-container {
	background: var(--supp-bg-page);
	color: var(--supp-text-primary);
	padding-bottom: clamp(1.5rem, 4vw, 3rem);
}

/* Intro categoría */
.page-complementos-alimenticios .cat-complementos-root {
	width: 100%;
}

.page-complementos-alimenticios .cat-comp-section {
	padding: 1.75rem clamp(1rem, 4vw, 3rem) 2.25rem;
}

.page-complementos-alimenticios .cat-comp-section--dark {
	background: var(--supp-bg-page);
}

.page-complementos-alimenticios .cat-comp-section--gray {
	background: var(--supp-bg-surface);
}

/* Franja decorativa sobria (sin arcoíris) */
.page-complementos-alimenticios .cat-comp-section--accent-strip {
	height: 3px;
	padding: 0;
	background: linear-gradient(90deg, transparent, rgba(139, 152, 168, 0.45), transparent);
	opacity: 1;
}

.page-complementos-alimenticios .cat-comp-title,
.page-complementos-alimenticios .cat-comp-wrapper .wrapper-button {
	color: var(--supp-text-primary);
	letter-spacing: 0.04em;
}

.page-complementos-alimenticios .cat-comp-wrapper .page-text {
	color: var(--supp-text-secondary);
	line-height: 1.7;
}

.page-complementos-alimenticios .cat-comp-wrapper .wrapper {
	background: var(--supp-bg-elevated);
	border-radius: 12px;
	border: 1px solid var(--supp-border);
	box-shadow: var(--supp-shadow-soft);
}

.page-complementos-alimenticios .cat-comp-wrapper .wrapper-button {
	border-bottom-color: var(--supp-border-strong);
}

.page-complementos-alimenticios .cat-comp-legal {
	border-top: 1px solid var(--supp-border);
}

.page-complementos-alimenticios .cat-comp-benefits {
	padding-top: clamp(1.5rem, 3vw, 2rem);
	padding-bottom: clamp(1.75rem, 3.5vw, 2.5rem);
}

.page-complementos-alimenticios .cat-comp-benefits-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(0.85rem, 2.2vw, 1.25rem);
	max-width: 1100px;
	margin: 0 auto;
}

.page-complementos-alimenticios .cat-comp-benefit-card {
	background: var(--supp-bg-card);
	border: 1px solid var(--supp-border);
	border-radius: 12px;
	padding: clamp(1rem, 2.2vw, 1.25rem);
	box-shadow: var(--supp-shadow-card);
	min-height: 170px;
	display: flex;
	flex-direction: column;
	gap: 0.45rem;
}

.page-complementos-alimenticios .cat-comp-benefit-toggle {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	width: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	color: inherit;
	text-align: left;
	font: inherit;
	cursor: default;
}

.page-complementos-alimenticios .cat-comp-benefit-icon-wrap {
	width: 28px;
	height: 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid var(--supp-border);
	margin-bottom: 0.25rem;
}

.page-complementos-alimenticios .cat-comp-benefit-icon {
	width: 16px;
	height: 16px;
	max-width: 16px;
	max-height: 16px;
	display: block;
	opacity: 0.95;
}

.page-complementos-alimenticios .cat-comp-benefit-heading {
	color: var(--supp-text-primary);
	font-size: 1.02rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 1.2;
	margin: 0;
}

.page-complementos-alimenticios .cat-comp-benefit-detail {
	color: #c6ced8;
	font-size: 0.86rem;
	font-weight: 500;
	letter-spacing: 0.03em;
	margin: 0;
}

.page-complementos-alimenticios .cat-comp-benefit-description {
	color: var(--supp-text-secondary);
	font-size: 0.9rem;
	line-height: 1.45;
	margin: 0;
}

.page-complementos-alimenticios .cat-comp-benefit-body {
	display: flex;
	flex-direction: column;
	gap: 0.45rem;
}

.page-complementos-alimenticios .cat-comp-legal-text {
	font-size: 0.85rem;
	color: var(--supp-text-muted);
	margin: 0;
	max-width: 56rem;
	line-height: 1.55;
}

/* Tabla comparativa (INDESmed vs otras marcas) */
.page-complementos-alimenticios .cat-comp-compare {
	max-width: 1100px;
	margin: clamp(1.25rem, 3vw, 2rem) auto 0;
	padding-top: clamp(0.5rem, 1.5vw, 1rem);
	border-top: 1px solid var(--supp-border);
}

.page-complementos-alimenticios .cat-comp-compare-title {
	margin: 0 0 clamp(0.75rem, 2vw, 1.1rem);
	font-size: clamp(1rem, 2.2vw, 1.15rem);
	font-weight: 500;
	letter-spacing: 0.03em;
	color: var(--supp-text-primary);
}

.page-complementos-alimenticios .cat-comp-compare-scroll {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	overscroll-behavior-x: contain;
	margin: 0 calc(-1 * clamp(1rem, 4vw, 3rem));
	padding: 0 clamp(1rem, 4vw, 3rem);
	scrollbar-color: var(--supp-border-strong) transparent;
}

.page-complementos-alimenticios .cat-comp-compare-scroll:focus-visible {
	outline: 2px solid var(--supp-accent);
	outline-offset: 4px;
}

.page-complementos-alimenticios .cat-comp-compare-table {
	width: 100%;
	min-width: 560px;
	border-collapse: separate;
	border-spacing: 0;
	font-size: 0.88rem;
	line-height: 1.45;
	border: 1px solid var(--supp-border);
	border-radius: 12px;
	overflow: hidden;
	box-shadow: var(--supp-shadow-card);
	background: var(--supp-bg-card);
}

.page-complementos-alimenticios .cat-comp-compare-table thead th {
	padding: 0.75rem 0.85rem;
	text-align: left;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: var(--supp-text-primary);
	background: var(--supp-bg-card-inner);
	border-bottom: 1px solid var(--supp-border-strong);
	vertical-align: bottom;
}

.page-complementos-alimenticios .cat-comp-compare-table tbody th,
.page-complementos-alimenticios .cat-comp-compare-table tbody td {
	padding: 0.7rem 0.85rem;
	border-bottom: 1px solid var(--supp-border);
	vertical-align: top;
}

.page-complementos-alimenticios .cat-comp-compare-table tbody tr:last-child th,
.page-complementos-alimenticios .cat-comp-compare-table tbody tr:last-child td {
	border-bottom: none;
}

.page-complementos-alimenticios .cat-comp-compare-th-empty {
	width: 0;
	min-width: 7.25rem;
	max-width: 11rem;
}

.page-complementos-alimenticios .cat-comp-compare-row-label {
	min-width: 7.25rem;
	max-width: 11rem;
	font-weight: 600;
	color: var(--supp-text-primary);
	text-align: left;
	background: var(--supp-bg-card);
}

.page-complementos-alimenticios .cat-comp-compare-cell {
	color: var(--supp-text-secondary);
	background: var(--supp-bg-card);
}

.page-complementos-alimenticios .cat-comp-compare-cell--indes {
	color: #c8d0da;
}

.page-complementos-alimenticios .cat-comp-compare-th-brand {
	min-width: 11.5rem;
}

.page-complementos-alimenticios .cat-comp-compare-th-other {
	min-width: 11.5rem;
}

@media screen and (max-width: 640px) {
	.page-complementos-alimenticios .cat-comp-compare-table {
		min-width: 520px;
		font-size: 0.82rem;
	}

	.page-complementos-alimenticios .cat-comp-compare-th-empty,
	.page-complementos-alimenticios .cat-comp-compare-row-label {
		position: sticky;
		left: 0;
		z-index: 2;
		box-shadow: 4px 0 12px rgba(0, 0, 0, 0.25);
	}

	.page-complementos-alimenticios .cat-comp-compare-table thead .cat-comp-compare-th-empty {
		z-index: 3;
		background: var(--supp-bg-card-inner);
	}
}

/* ——— Listado: rejilla de productos ——— */
.page-complementos-alimenticios section.product-container {
	background: transparent;
	padding: clamp(1.5rem, 3vw, 2.5rem) 0 3rem;
	margin: 0 auto;
	max-width: min(1280px, 100%);
}

.page-complementos-alimenticios .product-container {
	gap: clamp(1.25rem, 2.5vw, 1.75rem);
}

.page-complementos-alimenticios .product-card {
	position: relative;
	background: var(--supp-bg-card);
	border: 1px solid var(--supp-border);
	border-radius: 14px;
	color: var(--supp-text-primary);
	box-shadow: var(--supp-shadow-card);
	overflow: hidden;
	transition:
		transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
		box-shadow 0.35s ease,
		border-color 0.25s ease;
}

.page-complementos-alimenticios .product-card::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	pointer-events: none;
	box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.03) inset;
}

.page-complementos-alimenticios .product-card:not([data-product-available="false" i]):hover {
	transform: translateY(-6px);
	box-shadow:
		0 20px 50px rgba(0, 0, 0, 0.55),
		0 0 0 1px var(--supp-border-strong);
	z-index: 2;
}

.page-complementos-alimenticios .product-card .product-title,
.page-complementos-alimenticios .product-card .product-title a {
	color: var(--supp-text-primary);
}

.page-complementos-alimenticios .product-card .product-price {
	color: var(--supp-text-primary);
	font-variant-numeric: tabular-nums;
	letter-spacing: 0.02em;
	font-weight: 600;
}

/* Zona imagen: “pozo” claro dentro de la card */
.page-complementos-alimenticios .product-card > .product-image {
	background: linear-gradient(180deg, var(--supp-image-well) 0%, #ebeae6 100%);
	border-bottom: 1px solid var(--supp-image-well-border);
}

.page-complementos-alimenticios .product-card > .product-image > img {
	padding: clamp(12px, 3vw, 22px);
	border-radius: 0;
	filter: drop-shadow(0 4px 14px rgba(0, 0, 0, 0.08));
}

.page-complementos-alimenticios .product-card > .product-details {
	background: var(--supp-bg-card-inner);
	border-top: 1px solid var(--supp-border);
	padding: clamp(1.1rem, 2.5vw, 1.35rem);
	gap: 12px;
}

.page-complementos-alimenticios .product-card > .product-details > .product-tags > .product-tag {
	background: rgba(255, 255, 255, 0.06);
	border-color: var(--supp-border);
	color: var(--supp-text-secondary);
}

.page-complementos-alimenticios .product-card > .product-details > .product-data > .product-buttons .product-button {
	background: var(--supp-accent-cta);
	color: #f0f3f7;
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 8px;
	font-weight: 600;
	letter-spacing: 0.04em;
	transition: background 0.25s ease, transform 0.2s ease;
}

.page-complementos-alimenticios .product-card > .product-details > .product-data > .product-buttons .product-button:hover {
	background: #4a586d;
}

/* Subnav móvil: sin máscara degradado triple */
.page-complementos-alimenticios .header-subnav .header-nav-link {
	position: relative;
	border-radius: 10px;
	transition: background 0.2s ease, box-shadow 0.2s ease;
}

.page-complementos-alimenticios .header-subnav .header-nav-link::before {
	display: none;
}

.page-complementos-alimenticios .header-subnav .header-nav-link:hover {
	box-shadow: 0 0 0 1px var(--supp-border);
	background: rgba(255, 255, 255, 0.04);
}

.page-complementos-alimenticios .menu-link {
	border-radius: 6px;
	padding: 0.15em 0.35em;
	transition: color 0.2s ease, background 0.2s ease;
}

.page-complementos-alimenticios .menu-link:hover {
	color: var(--supp-text-primary);
	border: 2px solid transparent;
	background: rgba(255, 255, 255, 0.06);
}

/* Migas */
.page-complementos-alimenticios .breadcrumb a,
.page-complementos-alimenticios .breadcrumb span,
.page-complementos-alimenticios .breadcrumb-link {
	color: var(--supp-text-muted);
}

.page-complementos-alimenticios .breadcrumb a:hover,
.page-complementos-alimenticios .breadcrumb-link:hover {
	color: var(--supp-accent-hover);
}

/* Secciones genéricas ficha */
.page-complementos-alimenticios .page-container .section {
	background-color: var(--supp-bg-surface);
	color: var(--supp-text-primary);
	padding-left: clamp(1rem, 5vw, 10%);
	padding-right: clamp(1rem, 5vw, 10%);
	padding-top: clamp(1.25rem, 3vw, 2rem);
	padding-bottom: clamp(1.25rem, 3vw, 2rem);
}

.page-complementos-alimenticios .page-container .page-text {
	color: var(--supp-text-secondary);
}

.page-complementos-alimenticios .page-container .page-title,
.page-complementos-alimenticios .page-container .page-subtitle {
	color: var(--supp-text-primary);
}

.page-complementos-alimenticios .page-container .page-title:not(h1) {
	background-color: var(--supp-bg-elevated);
	color: var(--supp-text-primary);
	border: 1px solid var(--supp-border);
	border-radius: 6px;
}

.page-complementos-alimenticios .page-container .separator {
	border-bottom-color: var(--supp-border);
}

.page-complementos-alimenticios .page-container .section.icon-section {
	background-color: var(--supp-bg-elevated);
	box-shadow: var(--supp-shadow-soft);
	border: 1px solid var(--supp-border);
	border-radius: 12px;
}

/* Bloque información / tablas: sin banda azul primaria */
.page-complementos-alimenticios .page-container .section.section-primary {
	background: var(--supp-bg-surface);
	padding-top: clamp(1.5rem, 4vw, 2.5rem);
	padding-bottom: clamp(2rem, 5vw, 3.5rem);
}

.page-complementos-alimenticios .page-container .section.section-primary.icon-section {
	color: var(--supp-text-primary) !important;
}

.page-complementos-alimenticios .page-container .section.section-primary .page-subtitle {
	background: var(--supp-bg-card);
	color: var(--supp-text-primary);
	border: 1px solid var(--supp-border);
}

.page-complementos-alimenticios .page-container .section.section-primary .page-text {
	color: var(--supp-text-secondary) !important;
}

.page-complementos-alimenticios .page-container .section.section-primary .section:not(.section-primary) .page-text {
	color: var(--supp-text-secondary) !important;
}

.page-complementos-alimenticios .page-container .section.section-primary .table-container > table {
	background-color: #fff;
	border-radius: 8px;
	overflow: hidden;
}

/* ——— Ficha producto (form.supplement-ficha) ——— */
.page-complementos-alimenticios form.product-container.supplement-ficha {
	align-items: stretch;
	gap: clamp(1.5rem, 3vw, 2.25rem);
	margin-bottom: 0;
	padding: 0 clamp(0.5rem, 3vw, 1rem);
	max-width: min(1200px, 100%);
	margin-left: auto;
	margin-right: auto;
}

.page-complementos-alimenticios form.supplement-ficha > .product-block.block-full {
	width: 100%;
	flex: 1 1 100%;
	text-align: center;
	margin-bottom: 0;
	padding: clamp(0.5rem, 2vw, 1rem) 0;
}

.page-complementos-alimenticios form.supplement-ficha .product-title {
	color: var(--supp-text-primary);
	font-weight: 500;
	letter-spacing: 0.03em;
}

.page-complementos-alimenticios form.supplement-ficha .product-subtitle {
	color: var(--supp-text-secondary);
	font-weight: 300;
}

.page-complementos-alimenticios form.supplement-ficha > .supplement-ficha-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.12fr) minmax(280px, 0.88fr);
	gap: clamp(1.25rem, 3vw, 2rem);
	width: 100%;
	flex: 1 1 100%;
	align-items: start;
	padding: clamp(1.25rem, 3vw, 1.75rem);
	background: var(--supp-bg-surface);
	border: 1px solid var(--supp-border);
	border-radius: 16px;
	box-shadow: var(--supp-shadow-soft);
}

/* Columna imagen */
.page-complementos-alimenticios form.supplement-ficha .supplement-ficha-grid > .product-block:first-child {
	width: 100% !important;
	flex: none !important;
	padding: 0;
	margin: 0;
}

.page-complementos-alimenticios form.supplement-ficha .supplement-ficha-grid .product-images {
	gap: clamp(0.75rem, 2vw, 1.25rem);
}

.page-complementos-alimenticios form.supplement-ficha .supplement-ficha-grid .product-images-preview {
	background: var(--supp-image-well);
	border-radius: 14px;
	padding: clamp(0.75rem, 2vw, 1.25rem);
	border: 1px solid var(--supp-image-well-border);
	box-shadow: var(--supp-shadow-image);
}

.page-complementos-alimenticios form.supplement-ficha .supplement-ficha-grid .product-images-preview .swiper-slide {
	border-radius: 10px;
	overflow: hidden;
	background: #fff;
}

.page-complementos-alimenticios form.supplement-ficha .supplement-ficha-grid .product-images-preview .swiper-slide > img,
.page-complementos-alimenticios form.supplement-ficha .supplement-ficha-grid .product-images-preview .swiper-slide > video {
	display: block;
	width: 100%;
	height: auto;
	max-height: min(520px, 70vh);
	object-fit: contain;
}

.page-complementos-alimenticios form.supplement-ficha .supplement-ficha-grid .product-images-thumbnails {
	background: rgba(0, 0, 0, 0.2);
	border-radius: 10px;
	padding: 6px 4px;
	border: 1px solid var(--supp-border);
}

.page-complementos-alimenticios form.supplement-ficha .supplement-ficha-grid .product-images-thumbnails .swiper-slide {
	border-radius: 8px;
	overflow: hidden;
	background: #fff;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
}

.page-complementos-alimenticios form.supplement-ficha .supplement-ficha-grid .product-images-thumbnails .swiper-slide > img {
	padding: 4px;
}

/* Columna datos: buy card */
.page-complementos-alimenticios form.supplement-ficha .supplement-ficha-grid > .product-block:last-child {
	width: 100% !important;
	flex: none !important;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: clamp(1rem, 2.5vw, 1.5rem);
}

.page-complementos-alimenticios form.supplement-ficha .product-data {
	background: var(--supp-bg-card);
	border: 1px solid var(--supp-border-strong);
	border-radius: 14px;
	padding: clamp(1.25rem, 3vw, 1.75rem);
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.25);
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
	align-items: stretch;
}

.page-complementos-alimenticios form.supplement-ficha .product-vars-name,
.page-complementos-alimenticios form.supplement-ficha .product-cars-name {
	color: var(--supp-text-secondary);
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 600;
}

.page-complementos-alimenticios form.supplement-ficha .product-module {
	margin-top: 0.25rem;
	padding: clamp(1rem, 2vw, 1.25rem) 0 0;
	border-top: 1px solid var(--supp-border);
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-end;
	gap: 1.25rem 2rem;
}

.page-complementos-alimenticios form.supplement-ficha .product-module > .product-module-block > .product-module-title {
	color: var(--supp-text-muted);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
}

.page-complementos-alimenticios form.supplement-ficha .product-price {
	font-size: clamp(1.65rem, 4vw, 2rem);
	color: var(--supp-text-primary);
	font-weight: 600;
	font-variant-numeric: tabular-nums;
}

.page-complementos-alimenticios form.supplement-ficha .product-price > .product-price-before {
	color: #9aa0a8;
}

.page-complementos-alimenticios form.supplement-ficha .product-quantity {
	min-width: 110px;
	border: 1px solid var(--supp-border-strong);
	background: var(--supp-bg-elevated);
	color: var(--supp-text-primary);
	border-radius: 8px;
	padding: 10px 12px;
}

.page-complementos-alimenticios form.supplement-ficha .button.button-buy {
	width: 100%;
	margin-top: 0.25rem;
	padding: 14px 18px;
	font-size: 1.05em;
	font-weight: 600;
	letter-spacing: 0.06em;
	border-radius: 10px;
	background: var(--supp-accent-cta);
	color: #f5f7fa;
	border: 1px solid rgba(255, 255, 255, 0.1);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
	transition: background 0.25s ease, transform 0.2s ease;
}

.page-complementos-alimenticios form.supplement-ficha .button.button-buy:hover:not([disabled]) {
	background: #4f5f75;
	transform: translateY(-1px);
}

.page-complementos-alimenticios form.supplement-ficha .button.button-buy[disabled] {
	opacity: 0.45;
}

.page-complementos-alimenticios form.supplement-ficha .product-specification {
	color: var(--supp-text-secondary);
	font-size: 0.92rem;
	padding-top: 0.25rem;
}

.page-complementos-alimenticios form.supplement-ficha .product-specification > .product-specification-list > li::before {
	color: var(--supp-accent);
}

.page-complementos-alimenticios form.supplement-ficha .product-specification > .product-specification-list > li p {
	color: var(--supp-text-secondary);
}

.page-complementos-alimenticios form.supplement-ficha .product-specification > .product-links > .button {
	background: transparent;
	color: var(--supp-accent);
	border: 1px solid var(--supp-border-strong);
	box-shadow: none;
	border-radius: 8px;
}

.page-complementos-alimenticios form.supplement-ficha .product-specification > .product-links > .button:hover {
	background: rgba(255, 255, 255, 0.06);
	color: var(--supp-accent-hover);
}

/* Variantes: chips legibles en oscuro */
.page-complementos-alimenticios form.supplement-ficha .product-vars > .product-vars-opts > .product-vars-opt:not([data-name="color"]),
.page-complementos-alimenticios form.supplement-ficha .product-cars > .product-cars-opts > .product-cars-opt:not([data-name="color"]) {
	border-color: var(--supp-border);
	background: var(--supp-bg-elevated);
	color: var(--supp-text-primary);
}

.page-complementos-alimenticios form.supplement-ficha .product-vars > .product-vars-opts > .product-vars-opt.active,
.page-complementos-alimenticios form.supplement-ficha .product-cars > .product-cars-opts > .product-cars-opt.active {
	border-color: var(--supp-accent);
	box-shadow: 0 0 0 1px rgba(139, 152, 168, 0.35);
}

/* Rating en ficha */
.page-complementos-alimenticios .rating > .rating-stars:after {
	color: #a89880;
}

.page-complementos-alimenticios .rating > .rating-count {
	color: var(--supp-text-secondary);
}

.page-complementos-alimenticios .rating > .rating-reviews {
	color: var(--supp-accent);
}

/* Reviews: alinear con superficies, menos “banner azul” */
.page-complementos-alimenticios .page-container .section .section-button {
	background: var(--supp-bg-card);
	color: var(--supp-text-primary);
	border: 1px solid var(--supp-border);
	border-radius: 10px;
	box-shadow: none;
	font-weight: 500;
	letter-spacing: 0.04em;
}

.page-complementos-alimenticios .page-container .section .section-button:hover {
	background: var(--supp-bg-card-inner);
	border-color: var(--supp-border-strong);
}

.page-complementos-alimenticios .reviews {
	margin: clamp(2rem, 5vw, 3rem) 0;
}

.page-complementos-alimenticios .reviews:before,
.page-complementos-alimenticios .reviews:after {
	width: 12%;
	background: linear-gradient(to right, var(--supp-bg-surface) 0%, transparent 100%);
}

.page-complementos-alimenticios .reviews:after {
	background: linear-gradient(to left, var(--supp-bg-surface) 0%, transparent 100%);
}

.page-complementos-alimenticios .reviews > .swiper-container > .swiper-button-next,
.page-complementos-alimenticios .reviews > .swiper-container > .swiper-button-prev {
	color: var(--supp-text-primary);
	background-color: var(--supp-bg-card);
	border: 1px solid var(--supp-border);
	box-shadow: var(--supp-shadow-card);
}

.page-complementos-alimenticios .reviews .review {
	color: var(--supp-text-primary);
	background: var(--supp-bg-card);
	border: 1px solid var(--supp-border);
	border-radius: 14px;
	box-shadow: var(--supp-shadow-soft);
	padding-top: 3.25rem;
	margin-top: 3.5rem;
}

.page-complementos-alimenticios .reviews .review > .review-avatar {
	border-color: var(--supp-bg-surface);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.35);
}

.page-complementos-alimenticios .reviews .review > .review-content > .review-name {
	color: var(--supp-text-primary);
}

.page-complementos-alimenticios .reviews .review > .review-content > .review-title {
	color: var(--supp-text-secondary);
	font-weight: 500;
}

.page-complementos-alimenticios .reviews .review > .review-content > .review-text {
	color: var(--supp-text-secondary);
}

.page-complementos-alimenticios .reviews .review .review-rating.rating > .rating-stars:after {
	color: #a89880;
}

/* Responsive ficha */
@media screen and (max-width: 1100px) {
	.page-complementos-alimenticios form.supplement-ficha > .supplement-ficha-grid {
		grid-template-columns: 1fr;
		padding: clamp(1rem, 3vw, 1.35rem);
	}

	.page-complementos-alimenticios form.supplement-ficha .supplement-ficha-grid > .product-block:last-child {
		order: 0;
	}
}

@media screen and (max-width: 600px) {
	.page-complementos-alimenticios .product-card:not([data-product-available="false" i]):hover {
		transform: translateY(-3px);
	}
}

@media screen and (max-width: 980px) {
	.page-complementos-alimenticios .cat-comp-benefits-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 640px) {
	.page-complementos-alimenticios .cat-comp-benefits-grid {
		grid-template-columns: 1fr;
	}

	.page-complementos-alimenticios .cat-comp-benefit-card {
		min-height: 0;
		padding: 0.85rem 0.9rem;
		gap: 0;
	}

	.page-complementos-alimenticios .cat-comp-benefit-toggle {
		cursor: pointer;
	}

	.page-complementos-alimenticios .cat-comp-benefit-heading {
		font-size: 0.98rem;
	}

	.page-complementos-alimenticios .cat-comp-benefit-body {
		max-height: 0;
		overflow: hidden;
		opacity: 0;
		transition: max-height 0.24s ease, opacity 0.2s ease;
	}

	.page-complementos-alimenticios .cat-comp-benefit-card.is-open .cat-comp-benefit-body {
		max-height: 180px;
		opacity: 1;
		margin-top: 0.5rem;
	}
}

/* Acordeones / información adicional (wrapper dentro de section-primary) */
.page-complementos-alimenticios .page-container .section.section-primary > .wrapper > .wrapper-button {
	color: var(--supp-text-primary) !important;
	border-bottom-color: var(--supp-border-strong);
}

.page-complementos-alimenticios .wrapper > .wrapper-button {
	color: var(--supp-accent);
	border-bottom-color: var(--supp-border-strong);
}

.page-complementos-alimenticios .wrapper > .wrapper-button:hover {
	color: var(--supp-accent-hover);
}

.page-complementos-alimenticios .wrapper > .wrapper-content > .wrapper-content-inner {
	color: var(--supp-text-secondary);
}

.page-complementos-alimenticios .wrapper > .wrapper-content > .wrapper-content-inner .page-text {
	color: var(--supp-text-secondary);
}

/* Overlay recálculo de precio en tema oscuro */
.page-complementos-alimenticios form.supplement-ficha .product-data[data-state="recalc"]:before,
.page-complementos-alimenticios form.supplement-ficha .product-data[data-state="loading"]:before {
	background-color: rgba(18, 20, 24, 0.65);
}

.page-complementos-alimenticios .section.section-primary .row > .col.col-image {
	background: var(--supp-image-well);
	border-radius: 12px;
	border: 1px solid var(--supp-image-well-border);
	box-shadow: var(--supp-shadow-image);
}

.page-complementos-alimenticios form.supplement-ficha .product-vars > .product-vars-opts > .product-vars-opt small,
.page-complementos-alimenticios form.supplement-ficha .product-cars > .product-cars-opts > .product-cars-opt small {
	color: var(--supp-text-muted);
}
