/* =============================================================================
   CÓDIGO N°4
   Carrusel de productos relacionados
   Archivo: 04-productos-relacionados-carrusel.css
   ============================================================================= */

/* ==========================================================================
   CONTENEDOR GENERAL
   ========================================================================== */

.related.products {
	--raco-related-arrow-size: 52px;
	--raco-related-arrow-gap: 24px;
	--raco-related-slide-gap: 28px;
	--raco-related-side-space: calc(var(--raco-related-arrow-size) + var(--raco-related-arrow-gap));

	position: relative !important;
	width: 100% !important;
	max-width: 1360px !important;
	margin: 64px auto 76px auto !important;
	padding: 0 16px !important;
	clear: both !important;
	box-sizing: border-box !important;
	overflow: visible !important;
}

.related.products,
.related.products * {
	box-sizing: border-box !important;
}

/* ==========================================================================
   TÍTULO
   ========================================================================== */

.related.products > h2 {
	width: 100% !important;
	margin: 0 0 28px 0 !important;
	padding: 0 calc(var(--raco-related-side-space) + 14px) !important;
	text-align: left !important;
	color: #063f88 !important;
	font-size: 30px !important;
	font-weight: 800 !important;
	line-height: 1.2 !important;
	letter-spacing: -0.3px !important;
}

/* ==========================================================================
   ESTRUCTURA DEL CARRUSEL
   ========================================================================== */

.related.products .raco-related-carousel-shell {
	position: relative !important;
	width: 100% !important;
	margin: 0 auto !important;
	padding: 0 var(--raco-related-side-space) !important;
	overflow: visible !important;
	box-sizing: border-box !important;
}

/* ==========================================================================
   FALLBACK ANTES DE SLICK
   ========================================================================== */

.related.products ul.products:not(.slick-initialized) {
	display: grid !important;
	grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
	gap: var(--raco-related-slide-gap) !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 var(--raco-related-side-space) !important;
	list-style: none !important;
	overflow: hidden !important;
	box-sizing: border-box !important;
}

.related.products ul.products:not(.slick-initialized) li.product {
	width: auto !important;
	max-width: none !important;
	margin: 0 !important;
	float: none !important;
	clear: none !important;
	background: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
}

/* ==========================================================================
   SLICK ACTIVO
   Slick debe calcular el ancho natural de cada producto.
   ========================================================================== */

.related.products ul.products.slick-initialized {
	display: block !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
	overflow: visible !important;
	visibility: visible !important;
	opacity: 1 !important;
	box-sizing: border-box !important;
}

.related.products .slick-list {
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	overflow: hidden !important;
	box-sizing: border-box !important;
}

.related.products .slick-track {
	display: flex !important;
	align-items: stretch !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

.related.products .slick-slide {
	float: none !important;
	height: auto !important;
	min-height: 1px !important;
	box-sizing: border-box !important;
}

.related.products ul.products li.product.slick-slide {
	height: auto !important;
	margin: 0 !important;
	padding: 0 calc(var(--raco-related-slide-gap) / 2) !important;
	float: none !important;
	clear: none !important;
	text-align: center !important;
	background: transparent !important;
	box-shadow: none !important;
	border: 0 !important;
	overflow: visible !important;
}

/* Limpieza WooCommerce */
.related.products ul.products::before,
.related.products ul.products::after {
	display: none !important;
	content: none !important;
}

/* ==========================================================================
   TARJETA
   ========================================================================== */

.related.products ul.products li.product .raco-related-card-inner {
	width: 100% !important;
	height: 100% !important;
	min-height: 100% !important;
	margin: 0 auto !important;

	display: flex !important;
	flex-direction: column !important;
	align-items: stretch !important;
	justify-content: flex-start !important;

	background: #ffffff !important;
	border: 2px solid rgba(1, 154, 163, 0.46) !important;
	border-radius: 16px !important;
	overflow: hidden !important;

	box-shadow: none !important;
	filter: none !important;

	transition:
		transform 0.2s ease,
		border-color 0.2s ease !important;
}

.related.products ul.products li.product .raco-related-card-inner:hover {
	transform: translateY(-3px) !important;
	border-color: rgba(1, 113, 122, 0.72) !important;
	box-shadow: none !important;
	filter: none !important;
}

/* ==========================================================================
   ENLACE PRINCIPAL
   ========================================================================== */

.related.products ul.products li.product .raco-related-card-inner > a,
.related.products ul.products li.product .raco-related-card-inner a.woocommerce-LoopProduct-link,
.related.products ul.products li.product .raco-related-card-inner a.woocommerce-loop-product__link,
.related.products ul.products li.product .raco-related-card-inner a.ast-loop-product__link {
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	text-align: center !important;
	text-decoration: none !important;
	overflow: visible !important;
	box-shadow: none !important;
	filter: none !important;
}

/* ==========================================================================
   IMAGEN
   ========================================================================== */

.related.products ul.products li.product .raco-related-card-inner img {
	display: block !important;
	width: 100% !important;
	max-width: 100% !important;
	height: auto !important;
	aspect-ratio: 1 / 1 !important;
	object-fit: cover !important;
	margin: 0 auto 18px auto !important;
	border-radius: 14px 14px 0 0 !important;
	border-bottom: 2px solid rgba(1, 154, 163, 0.26) !important;
	box-shadow: none !important;
	filter: none !important;
}

/* ==========================================================================
   TÍTULO DEL PRODUCTO
   ========================================================================== */

.related.products ul.products li.product .raco-related-card-inner .woocommerce-loop-product__title,
.related.products ul.products li.product .raco-related-card-inner h2.woocommerce-loop-product__title,
.related.products ul.products li.product .raco-related-card-inner h2,
.related.products ul.products li.product .raco-related-card-inner h3 {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;

	width: calc(100% - 34px) !important;
	max-width: calc(100% - 34px) !important;
	min-height: 48px !important;

	margin: 0 auto 10px auto !important;
	padding: 0 !important;

	text-align: center !important;
	color: #1f2933 !important;
	font-size: 17px !important;
	font-weight: 800 !important;
	line-height: 1.25 !important;

	white-space: normal !important;
	overflow: visible !important;
	text-overflow: clip !important;
	word-break: normal !important;
	overflow-wrap: anywhere !important;
}

/* ==========================================================================
   DURACIÓN
   ========================================================================== */

.related.products .product-duration {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;

	width: calc(100% - 34px) !important;
	max-width: calc(100% - 34px) !important;
	min-height: 34px !important;

	margin: 0 auto 16px auto !important;

	color: #0073aa !important;
	font-size: 13px !important;
	font-weight: 800 !important;
	line-height: 1.25 !important;
	text-align: center !important;
	white-space: normal !important;
}

/* ==========================================================================
   BOTÓN INCLUYE
   ========================================================================== */

.related.products .product-includes {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;

	width: calc(100% - 34px) !important;
	max-width: calc(100% - 34px) !important;
	min-height: 44px !important;

	margin: auto auto 24px auto !important;
	padding: 0 !important;
	text-align: center !important;
}

.related.products .product-includes button.includes-toggle {
	margin: 0 auto !important;
	min-height: 36px !important;
	padding: 8px 16px !important;
	font-size: 13px !important;
	line-height: 1.15 !important;

	background: #ffffff !important;
	border: 1px solid rgba(1, 154, 163, 0.48) !important;
	box-shadow: none !important;
	filter: none !important;
}

/* ==========================================================================
   FLECHAS PERSONALIZADAS TIPO PESTAÑA TRIANGULAR
   ========================================================================== */

.related.products .raco-related-arrow,
.related.products button.raco-related-arrow,
.related.products .raco-related-carousel-shell > button.raco-related-arrow {
	position: absolute !important;
	top: 50% !important;
	transform: translateY(-50%) !important;
	z-index: 80 !important;

	width: 46px !important;
	height: 58px !important;
	min-width: 46px !important;
	min-height: 58px !important;

	display: flex !important;
	align-items: center !important;
	justify-content: center !important;

	margin: 0 !important;
	padding: 0 0 5px 0 !important;

	background: #01717a !important;
	border: 1px solid rgba(255, 255, 255, 0.28) !important;

	color: #ffffff !important;
	font-family: Arial, Helvetica, sans-serif !important;
	font-size: 40px !important;
	font-weight: 700 !important;
	line-height: 1 !important;
	text-align: center !important;
	text-indent: 0 !important;

	cursor: pointer !important;
	box-shadow: 0 10px 26px rgba(0, 0, 0, 0.22) !important;
	opacity: 1 !important;
	visibility: visible !important;

	transition:
		background-color 0.18s ease,
		border-color 0.18s ease,
		box-shadow 0.18s ease,
		transform 0.18s ease !important;
}

.related.products .raco-related-arrow span {
	position: relative !important;
	z-index: 2 !important;
	display: block !important;
	line-height: 1 !important;
}

.related.products .raco-related-arrow::before {
	display: none !important;
	content: none !important;
}

.related.products .raco-related-arrow::after {
	content: "" !important;
	position: absolute !important;
	top: 50% !important;
	transform: translateY(-50%) !important;
	width: 0 !important;
	height: 0 !important;
	z-index: 1 !important;
}

/* Flecha izquierda */
.related.products .raco-related-arrow-prev,
.related.products button.raco-related-arrow-prev {
	left: 0 !important;
	border-radius: 0 14px 14px 0 !important;
	padding-right: 4px !important;
}

.related.products .raco-related-arrow-prev::after {
	right: -10px !important;
	border-top: 12px solid transparent !important;
	border-bottom: 12px solid transparent !important;
	border-left: 10px solid #01717a !important;
}

/* Flecha derecha */
.related.products .raco-related-arrow-next,
.related.products button.raco-related-arrow-next {
	right: 0 !important;
	border-radius: 14px 0 0 14px !important;
	padding-left: 4px !important;
}

.related.products .raco-related-arrow-next::after {
	left: -10px !important;
	border-top: 12px solid transparent !important;
	border-bottom: 12px solid transparent !important;
	border-right: 10px solid #01717a !important;
}

.related.products .raco-related-arrow:hover,
.related.products .raco-related-arrow:focus {
	background: #005f66 !important;
	border-color: rgba(255, 255, 255, 0.38) !important;
	color: #ffffff !important;
	outline: none !important;
	box-shadow: 0 12px 30px rgba(0, 0, 0, 0.26) !important;
}

.related.products .raco-related-arrow-prev:hover {
	transform: translateY(-50%) translateX(-2px) !important;
}

.related.products .raco-related-arrow-next:hover {
	transform: translateY(-50%) translateX(2px) !important;
}

.related.products .raco-related-arrow-prev:hover::after,
.related.products .raco-related-arrow-prev:focus::after {
	border-left-color: #005f66 !important;
}

.related.products .raco-related-arrow-next:hover::after,
.related.products .raco-related-arrow-next:focus::after {
	border-right-color: #005f66 !important;
}


/* Ocultar flechas cuando no hacen falta */
.related.products .raco-related-carousel-shell:not(.raco-related-show-arrows) > button.raco-related-arrow {
	display: none !important;
}

/* ==========================================================================
   NOTEBOOK
   ========================================================================== */

@media (max-width: 1280px) {
	.related.products {
		--raco-related-arrow-size: 48px;
		--raco-related-arrow-gap: 20px;
		--raco-related-slide-gap: 24px;

		max-width: 1180px !important;
	}

	.related.products > h2 {
		font-size: 28px !important;
	}

	.related.products ul.products:not(.slick-initialized) {
		grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
	}
}

/* ==========================================================================
   TABLET
   ========================================================================== */

@media (max-width: 900px) {
	.related.products {
		--raco-related-arrow-size: 44px;
		--raco-related-arrow-gap: 18px;
		--raco-related-slide-gap: 22px;

		max-width: 760px !important;
		margin-top: 48px !important;
		margin-bottom: 66px !important;
	}

	.related.products > h2 {
		padding-left: calc(var(--raco-related-side-space) + 8px) !important;
		padding-right: calc(var(--raco-related-side-space) + 8px) !important;
		text-align: center !important;
		font-size: 25px !important;
	}

	.related.products ul.products:not(.slick-initialized) {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}

	.related.products .raco-related-arrow,
	.related.products button.raco-related-arrow,
	.related.products .raco-related-carousel-shell > button.raco-related-arrow {
		width: 44px !important;
		height: 56px !important;
		min-width: 44px !important;
		min-height: 56px !important;
		font-size: 36px !important;
	}
}

/* ==========================================================================
   MÓVIL
   ========================================================================== */

@media (max-width: 680px) {
	.related.products {
		--raco-related-arrow-size: 42px;
		--raco-related-arrow-gap: 12px;
		--raco-related-slide-gap: 0px;
		--raco-related-side-space: calc(var(--raco-related-arrow-size) + var(--raco-related-arrow-gap));

		width: 100% !important;
		max-width: 100% !important;
		margin: 42px auto 96px auto !important;
		padding: 0 0 26px 0 !important;
		overflow: visible !important;
	}

	.related.products > h2 {
		width: 100% !important;
		margin: 0 0 24px 0 !important;
		padding: 0 54px !important;
		text-align: center !important;
		font-size: 23px !important;
		line-height: 1.18 !important;
	}

	.related.products .raco-related-carousel-shell {
		padding-left: var(--raco-related-side-space) !important;
		padding-right: var(--raco-related-side-space) !important;
	}

	.related.products ul.products.slick-initialized {
		overflow: visible !important;
	}

	.related.products .slick-list {
		overflow: hidden !important;
	}

	.related.products ul.products li.product.slick-slide {
		padding-left: 0 !important;
		padding-right: 0 !important;
	}

	.related.products ul.products li.product .raco-related-card-inner {
		border-radius: 16px !important;
		padding-bottom: 24px !important;
	}

	.related.products ul.products li.product .raco-related-card-inner img {
		margin-bottom: 18px !important;
		border-radius: 14px 14px 0 0 !important;
	}

	.related.products ul.products li.product .raco-related-card-inner .woocommerce-loop-product__title,
	.related.products ul.products li.product .raco-related-card-inner h2.woocommerce-loop-product__title,
	.related.products ul.products li.product .raco-related-card-inner h2,
	.related.products ul.products li.product .raco-related-card-inner h3 {
		width: calc(100% - 30px) !important;
		max-width: calc(100% - 30px) !important;
		min-height: 50px !important;
		margin-bottom: 10px !important;
		font-size: 16px !important;
		line-height: 1.25 !important;
	}

	.related.products .product-duration {
		width: calc(100% - 30px) !important;
		max-width: calc(100% - 30px) !important;
		min-height: 32px !important;
		margin-bottom: 16px !important;
		font-size: 13px !important;
	}

	.related.products .product-includes {
		width: calc(100% - 30px) !important;
		max-width: calc(100% - 30px) !important;
		min-height: 42px !important;
		margin-bottom: 0 !important;
	}

	.related.products .product-includes button.includes-toggle {
		min-height: 36px !important;
		padding: 8px 16px !important;
		font-size: 12px !important;
		box-shadow: none !important;
		filter: none !important;
	}

	.related.products .raco-related-arrow,
	.related.products button.raco-related-arrow,
	.related.products .raco-related-carousel-shell > button.raco-related-arrow {
		width: 40px !important;
		height: 54px !important;
		min-width: 40px !important;
		min-height: 54px !important;
		font-size: 34px !important;
		box-shadow: 0 8px 22px rgba(0, 0, 0, 0.20) !important;
	}

	.related.products .raco-related-arrow-prev,
	.related.products button.raco-related-arrow-prev {
		left: 0 !important;
	}

	.related.products .raco-related-arrow-next,
	.related.products button.raco-related-arrow-next {
		right: 0 !important;
	}

	.related.products .raco-related-arrow-prev::after {
		right: -9px !important;
		border-top-width: 11px !important;
		border-bottom-width: 11px !important;
		border-left-width: 9px !important;
	}

	.related.products .raco-related-arrow-next::after {
		left: -9px !important;
		border-top-width: 11px !important;
		border-bottom-width: 11px !important;
		border-right-width: 9px !important;
	}
}

/* ==========================================================================
   MÓVILES PEQUEÑOS
   ========================================================================== */

@media (max-width: 480px) {
	.related.products {
		--raco-related-arrow-size: 40px;
		--raco-related-arrow-gap: 10px;
		--raco-related-side-space: calc(var(--raco-related-arrow-size) + var(--raco-related-arrow-gap));
	}

	.related.products > h2 {
		font-size: 22px !important;
		padding-left: 48px !important;
		padding-right: 48px !important;
	}

	.related.products .raco-related-arrow,
	.related.products button.raco-related-arrow,
	.related.products .raco-related-carousel-shell > button.raco-related-arrow {
		width: 38px !important;
		height: 52px !important;
		min-width: 38px !important;
		min-height: 52px !important;
		font-size: 32px !important;
	}
}