/* ── Archive Guías (/mejores/) ──────────────────────────── */


/* ═══ HERO BASE ══════════════════════════════════════════ */

.rl-guia-archive-hero {
	position: relative; /* ancla el ring-clip y el SVG decorativo */
}

/* Cool blue-cyan glow — esquina superior derecha */
.rl-guia-archive-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 0;
	background:
 radial-gradient(ellipse 158% 131% at 100% 0%, rgba(14, 116, 144, 0.55) 0%, transparent 65%);
}

/* Dot grid — exacto a /ofertas/ */
.rl-guia-archive-hero::after {
	content: "";
	position: absolute;
	inset: 0;
	background-image: radial-gradient(circle, rgba(255, 255, 255, 0.05) 1px, transparent 1px);
	background-size: 28px 28px;
	pointer-events: none;
	z-index: 0;
}

/* Gap fix: marquee debe pegar directo con el hero sin espacio beige */
.rl-guia-archive-hero + .rl-prod-marquee,
.rl-guia-archive-hero + aside.rl-prod-marquee {
	margin-top: 0;
}

/* ─── Ring deco: corona de arcos — único de /mejores/ ──── */
.rl-guia-archive-hero__ring-clip {
	position: absolute;
	inset: 0;
	overflow: hidden;
	pointer-events: none;
	z-index: 1;
}

.rl-guia-archive-hero__ring-deco {
	position: absolute;
	top: -20px;
	left: 50%;
	transform: translateX(-50%);
	width: 700px;
	height: 700px;
	color: var(--cat-hub-ring, oklch(82% 0.08 175));
	pointer-events: none;
	user-select: none;
}

@keyframes rl-gah-bob-lg {

	0%,
100% {
		transform: translateY(0);
	}

	50% {
		transform: translateY(-16px);
	}
}

@keyframes rl-gah-bob-md {

	0%,
100% {
		transform: translateY(0);
	}

	50% {
		transform: translateY(-10px);
	}
}

@keyframes rl-gah-bob-sm {

	0%,
100% {
		transform: translateY(0);
	}

	50% {
		transform: translateY(-7px);
	}
}

@keyframes rl-gah-dot-glow {

	0%,
100% {
		opacity: 0.65;
	}

	50% {
		opacity: 1;
	}
}

.rl-gah-peak-center,
.rl-gah-peak-inner-l,
.rl-gah-peak-inner-r,
.rl-gah-peak-outer-l,
.rl-gah-peak-outer-r {
	transform-box: fill-box;
	transform-origin: 50% 100%;
}

.rl-gah-peak-center {
	animation: rl-gah-bob-lg 4s   ease-in-out infinite;
}

.rl-gah-peak-inner-l {
	animation: rl-gah-bob-md 4.5s ease-in-out infinite;
	animation-delay: -1.5s;
}

.rl-gah-peak-inner-r {
	animation: rl-gah-bob-md 4.5s ease-in-out infinite;
	animation-delay: -0.5s;
}

.rl-gah-peak-outer-l {
	animation: rl-gah-bob-sm 3.8s ease-in-out infinite;
	animation-delay: -2.2s;
}

.rl-gah-peak-outer-r {
	animation: rl-gah-bob-sm 3.8s ease-in-out infinite;
	animation-delay: -1s;
}

.rl-gah-crown-dot {
	animation: rl-gah-dot-glow 3s  ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) {

	.rl-gah-peak-center,
	.rl-gah-peak-inner-l,
	.rl-gah-peak-inner-r,
	.rl-gah-peak-outer-l,
	.rl-gah-peak-outer-r,
	.rl-gah-crown-dot {
		animation: none;
	}
}

@media (max-width: 767px) {

	.rl-guia-archive-hero__ring-deco {
		width: 380px;
		height: 380px;
		top: -10px;
		opacity: 0.5;
	}
}

/* Mobile: hero llena 100svh, configurador anclado a 7px del borde inferior */
@media (max-width: 639px) {

	.rl-guia-archive-hero {
		min-height: 100svh;
		display: flex;
		flex-direction: column;
		padding-block-start: 0 !important;
		padding-block-end: 7px !important;
	}

	.rl-guia-archive-hero__body {
		flex: 1;
		display: flex;
		flex-direction: column;
		padding-block-start: calc(64px + 0.5rem) !important;
		padding-block-end: 0;
	}
}

.rl-guia-archive-hero__body {
	position: relative;
	z-index: 2;
	text-align: center;
	padding-block-start: clamp(1.25rem, 4vw, 2.5rem);
	padding-block-end: clamp(1.25rem, 4vw, 2.5rem);
}

/* ─── Breadcrumb ──────────────────────────────────────── */
.rl-guia-archive-hero__breadcrumb {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.25rem;
	font-size: clamp(1rem, 2.5vw, 1.175rem);
	margin-bottom: 1.25rem;
	color: rgba(255, 255, 255, 0.35);
	animation: rl-hero-in 500ms cubic-bezier(0.16, 1, 0.3, 1) 0ms both;
}

.rl-guia-archive-hero__breadcrumb a {
	color: rgba(255, 255, 255, 0.35);
	text-decoration: none;
}

.rl-guia-archive-hero__breadcrumb a:hover {
	color: rgba(255, 255, 255, 0.65);
}

.rl-guia-archive-hero__breadcrumb [aria-hidden] {
	color: rgba(255, 255, 255, 0.2);
}

.rl-guia-archive-hero__breadcrumb [aria-current] {
	color: rgba(255, 255, 255, 0.55);
}

/* ─── Título estático (H1) ────────────────────────────── */
.rl-guia-archive-hero__title {
	font-size: clamp(1.875rem, 6.5vw, 4.5rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1.1;
	margin: 0 0 1rem;
	color: oklch(98% 0.004 22);
	animation: rl-hero-in 500ms cubic-bezier(0.16, 1, 0.3, 1) 80ms both;
}

.rl-guia-archive-hero__title-tail {
	display: block;
	font-size: clamp(1.25rem, 3vw, 2rem);
	font-weight: 500;
	letter-spacing: -0.01em;
	line-height: 1.3;
	color: rgba(255, 255, 255, 0.78);
	margin-top: 0.375rem;
}

.rl-guia-hero-accent {
	font-style: normal;
	color: oklch(79% 0.17 168);
}

/* En el lead, las negritas van en teal-cream (el color que distingue el H1 de sus palabras blancas) */
.rl-guia-archive-hero__copy .rl-guia-hero-accent {
	color: oklch(92% 0.05 165);
}

/* ─── Copy ────────────────────────────────────────────── */
.rl-guia-archive-hero__copy {
	margin: 0 auto 0;
	max-width: 480px;
	animation: rl-hero-in 500ms cubic-bezier(0.16, 1, 0.3, 1) 140ms both;
}

.rl-guia-archive-hero__copy p {
	font-size: 1rem;
	color: rgba(255, 255, 255, 0.6);
	line-height: 1.5;
	margin: 0;
}

.rl-guia-archive-hero__copy p + p {
	margin-top: 0.25rem;
}

@media (prefers-reduced-motion: reduce) {

	.rl-guia-archive-hero__breadcrumb,
	.rl-guia-archive-hero__title,
	.rl-guia-archive-hero__copy,
	.rl-guia-configurador {
		animation: none;
	}
}

/* ═══ CONFIGURADOR WIDGET ════════════════════════════════ */

.rl-guia-configurador {
	width: 100%;
	max-width: 580px;
	margin: 2rem auto 0;
	animation: rl-hero-in 500ms cubic-bezier(0.16, 1, 0.3, 1) 190ms both;
	background: rgba(255, 255, 255, 0.07);
	border: 1px solid rgba(255, 255, 255, 0.13);
	border-radius: 16px;
	padding: 1.25rem;
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	text-align: left;
}

.rl-guia-configurador__label {
	font-size: 0.8125rem;
	font-weight: 700;
	color: rgba(255, 255, 255, 0.6);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin: 0 0 0.875rem;
}

.rl-guia-configurador__selects {
	display: flex;
	gap: 0.625rem;
	flex-wrap: wrap;
}

.rl-guia-configurador__select {
	flex: 1;
	min-width: 180px;
	background: rgba(255, 255, 255, 0.1) !important;
	border: 1px solid rgba(255, 255, 255, 0.18) !important;
	border-radius: 10px !important;
	color: rgba(255, 255, 255, 0.9) !important;
	font-family: inherit;
	font-size: 0.9375rem;
	font-weight: 600;
	padding: 0.75rem 1rem !important;
	cursor: pointer;
}

.rl-guia-configurador__select option {
	background: #16263b;
	color: #fff;
}

.rl-guia-configurador__select:focus-visible {
	border-color: var(--cat-hub-ring, oklch(82% 0.08 175)) !important;
	outline: none;
}

.rl-guia-configurador__result {
	margin-top: 0.875rem;
	display: flex;
	align-items: center;
	gap: 0.875rem;
	flex-wrap: wrap;
	background: rgba(255, 255, 255, 0.07);
	border-radius: 10px;
	padding: 0.875rem 1rem;
	border: 1px solid rgba(255, 255, 255, 0.1);
	animation: rl-gc-fade-in 200ms ease both;
}

/* display:flex tiene más especificidad que el [hidden] del UA — forzar none */
.rl-guia-configurador__result[hidden],
.rl-guia-configurador__nomatch[hidden] {
	display: none !important;
}

@keyframes rl-gc-fade-in {

	from {
		opacity: 0;
		transform: translateY(4px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.rl-guia-configurador__result {
	transition: opacity 0.25s ease;
}

.rl-guia-configurador__result.rl-gc-fading {
	opacity: 0;
}

.rl-guia-configurador__result-chip {
	font-size: 0.6875rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: rgba(255, 255, 255, 0.6);
	white-space: nowrap;
}

.rl-guia-configurador__result-title {
	flex: 1;
	font-size: 0.9375rem;
	font-weight: 700;
	color: #fff;
	text-decoration: none;
	line-height: 1.3;
	min-width: 0;
}

.rl-guia-configurador__result-title:hover {
	color: rgba(255, 255, 255, 0.8);
}

.rl-guia-configurador__result-meta {
	font-size: 0.75rem;
	color: rgba(255, 255, 255, 0.45);
	white-space: nowrap;
}

.rl-guia-configurador__result-cta {
	white-space: nowrap;
	font-size: 0.875rem !important;
	padding: 0.625rem 1.25rem !important;
	background: var(--cat-hub-dark, oklch(38% 0.12 175)) !important;
	color: #fff !important;
	border-radius: 8px;
}

.rl-guia-configurador__result-cta:hover {
	background: var(--cat-hub-dark-hover, oklch(53% 0.12 175)) !important;
	color: #fff !important;
}

.rl-guia-configurador__nomatch {
	margin-top: 0.75rem;
	font-size: 0.875rem;
	color: rgba(255, 255, 255, 0.5);
	text-align: center;
}

.rl-guia-configurador__nomatch a {
	color: rgba(255, 255, 255, 0.75);
}

/* ═══ CATEGORY CARDS (hereda de .rl-prod-cats + style.css) ══════════════ */

/* bridge: JS añade is-active; style.css usa rl-prod-cat-card--active → mapear a teal */
.rl-prod-cats .rl-prod-cat-card.is-active {
	border-color: var(--cat-hub, #0f766e);
	box-shadow: 0 0 0 2px var(--cat-hub, #0f766e);
}

.rl-prod-cats .rl-prod-cat-all.is-active {
	box-shadow: 0 0 0 2px var(--cat-hub, #0f766e);
}

/* ═══ GRID + CARDS ════════════════════════════════════════ */

.rl-guia-archive-grid {
	padding-block: 2rem;
}

.rl-guia-archive-grid__items {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
}

/* Cards full-width: lista editorial, 1 columna siempre */
.rl-guia-card-v2 {
	display: grid;
	grid-template-columns: 220px 1fr;
	height: 210px;
	border: 1px solid var(--rl-border, #e2e5ed);
	border-top: 3px solid transparent;
	border-radius: 0.75rem;
	background: #fff;
	overflow: hidden;
	transition: box-shadow 0.15s, border-top-color 0.2s, transform 0.15s;
	box-shadow: 0 1px 2px rgba(22, 38, 59, 0.04), 0 4px 12px rgba(22, 38, 59, 0.04);
}

.rl-guia-card-v2:hover {
	box-shadow: 0 4px 16px rgba(22, 38, 59, 0.09);
	transform: translateY(-2px);
}

/* Guiño de color: top border + CTA al activar la categoría */
.rl-guia-card-v2.is-cat-active {
	border-top-color: var(--cat-card);
}

.rl-guia-card-v2.is-cat-active .rl-guia-card-v2__cta {
	background: var(--cat-card);
}

.rl-guia-card-v2.is-cat-active .rl-guia-card-v2__cat-badge {
	opacity: 1;
}

/* Image — ocupa altura completa de la card */
.rl-guia-card-v2__img {
	margin: 0;
	overflow: hidden;
	align-self: stretch;
}

.rl-guia-card-v2__img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.rl-guia-card-v2__img-placeholder {
	width: 100%;
	height: 100%;
	background:
 linear-gradient(135deg, color-mix(in srgb, var(--cat-card, var(--rl-coral)) 30%, #f9f7f2) 0%, color-mix(in srgb, var(--cat-card, var(--rl-coral)) 8%, #f9f7f2) 100%);
}

/* Body */
.rl-guia-card-v2__body {
	padding: 0.875rem 1rem 0.875rem 0.875rem;
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

.rl-guia-card-v2__meta {
	display: flex;
	align-items: center;
	gap: 0.375rem;
	margin-bottom: 0.25rem;
	flex-wrap: wrap;
}

.rl-guia-card-v2__tipo-badge {
	font-size: 0.625rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	background: rgba(22, 38, 59, 0.07);
	color: var(--rl-text, #3d4452);
	border-radius: 4px;
	padding: 0.125rem 0.4375rem;
	white-space: nowrap;
}

.rl-guia-card-v2__cat-badge {
	font-size: 0.625rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	opacity: 0.8;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.rl-guia-card-v2__excerpt {
	font-size: 0.8125rem;
	color: var(--rl-text, #3d4452);
	line-height: 1.4;
	margin: 0.25rem 0 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.rl-guia-card-v2__title {
	font-size: 0.9375rem;
	font-weight: 700;
	margin: 0 0 0.375rem;
	line-height: 1.3;
	flex: 1;
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}

.rl-guia-card-v2__title a {
	text-decoration: none;
	color: var(--rl-ink, #191c1d);
}

.rl-guia-card-v2__title a:hover {
	color: var(--cat-hub-dark, oklch(38% 0.12 175));
}

/* Footer: prod-count + CTA */
.rl-guia-card-v2__footer {
	margin-top: auto;
	padding-top: 0.5rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
}

.rl-guia-card-v2__prod-count {
	font-size: 0.6875rem;
	color: var(--rl-text, #3d4452);
	opacity: 0.7;
	white-space: nowrap;
}

/* CTA — cat-hub-accent igual que en /producto/ */
.rl-guia-card-v2__cta {
	display: inline-block;
	background: var(--cat-hub-accent, oklch(60% 0.18 178));
	color: #fff;
	font-size: 0.8125rem;
	font-weight: 700;
	padding: 0.4375rem 0.875rem;
	border-radius: 8px;
	text-decoration: none;
	transition: background 150ms;
	white-space: nowrap;
	border: none;
	cursor: pointer;
	font-family: inherit;
	line-height: inherit;
}

.rl-guia-card-v2__cta:hover {
	background: oklch(54% 0.18 178);
	color: #fff;
}

/* Load-more button (inyectado por JS) */
.rl-guia-load-more {
	padding-block: 2rem;
	display: flex;
	justify-content: center;
}

.rl-guia-load-more__btn {
	padding: 0.875rem 3.5rem;
	background: transparent;
	border: 2px solid var(--cat-hub-dark, oklch(38% 0.12 175));
	color: var(--cat-hub-dark, oklch(38% 0.12 175));
	border-radius: 10px;
	font-family: inherit;
	font-weight: 700;
	font-size: 1rem;
	cursor: pointer;
	transition: background 200ms, color 200ms;
}

.rl-guia-load-more__btn:hover:not(:disabled) {
	background: var(--cat-hub-dark, oklch(38% 0.12 175));
	color: #fff;
}

.rl-guia-load-more__btn:disabled {
	opacity: 0.6;
	cursor: wait;
}

/* ═══ MIA CARD EN GRID (mismas reglas que /producto/) ════ */

.rl-guia-card-mia {
	background: var(--cat-hub-soft, #e0f5f3);
	border-color: oklch(60% 0.18 178 / 0.25);
}

.rl-guia-card-mia:hover {
	box-shadow: 0 4px 24px oklch(60% 0.18 178 / 0.18);
	border-color: oklch(60% 0.18 178 / 0.55);
}

.rl-guia-card-mia .rl-guia-card-v2__img {
	background: oklch(60% 0.18 178 / 0.1);
	display: flex;
	align-items: center;
	justify-content: center;
}

.rl-guia-card-mia__avatar {
	font-size: 2.25rem;
	color: var(--cat-hub-accent, oklch(60% 0.18 178));
	line-height: 1;
}

.rl-guia-card-mia .rl-guia-card-v2__title {
	color: var(--rl-ink, #191c1d);
}

.rl-guia-card-mia .rl-guia-card-v2__excerpt {
	color: var(--rl-text, #3d4452);
}

.rl-guia-card-mia__trust {
	font-size: 0.8125rem;
	color: var(--cat-hub-accent, oklch(60% 0.18 178));
	margin: 0.125rem 0 0;
}

.rl-guia-card-mia .rl-guia-card-v2__cta {
	background: var(--cat-hub-accent, oklch(60% 0.18 178));
	-webkit-appearance: none;
	appearance: none;
	font-size: 0.8125rem;
	font-weight: 700;
	padding: 0.4375rem 0.875rem;
	border-radius: 8px;
	line-height: inherit;
	width: 100%;
	display: block;
	text-align: center;
}

.rl-guia-card-mia .rl-guia-card-v2__cta:hover {
	background: oklch(54% 0.18 178);
}

.rl-guia-card-mia .rl-guia-card-v2__footer {
	justify-content: flex-end;
}

/* ═══ PROMO CARD EDITORIAL ════════════════════════════════ */

.rl-guia-promo-card {
	display: grid;
	grid-template-columns: 220px 1fr;
	border-radius: 0.75rem;
	background: oklch(96.5% 0.02 160); /* igual que "Por qué confiar" en home */
	border: 1px solid rgba(0, 182, 122, 0.18);
	min-height: 220px;
	box-shadow: 0 1px 2px rgba(22, 38, 59, 0.04), 0 4px 12px rgba(22, 38, 59, 0.04);
}

.rl-guia-promo-card__img {
	margin: 0;
	padding: 1.25rem 0 1.25rem 1.25rem; /* aire: arriba, sin derecha, abajo, izquierda */
}

.rl-guia-promo-card__img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top;
	display: block;
	border-radius: 10px;
	opacity: 0.85;
}

.rl-guia-promo-wrap {
	padding-top: 1.5rem;
}

.rl-guia-promo-card__body {
	background: transparent;
	padding: 2rem 2.25rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 0.875rem;
}

.rl-guia-promo-card__eyebrow {
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: oklch(45% 0.12 160);
	margin: 0;
}

.rl-guia-promo-card__title {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 800;
	line-height: 1.15;
	letter-spacing: -0.02em;
	color: var(--rl-ink, #191c1d);
	margin: 0;
}

.rl-guia-promo-card__lead {
	font-size: 1.0625rem;
	line-height: 1.5;
	color: var(--rl-text, #3d4452);
	margin: 0;
}

@media (max-width: 639px) {

	.rl-guia-promo-card {
		grid-template-columns: 1fr;
	}

	.rl-guia-promo-card__img {
		padding: 1rem 1rem 0 1rem;
		height: 200px;
	}

	.rl-guia-promo-card__body {
		padding: 1.25rem;
	}
}

/* ═══ MOBILE ══════════════════════════════════════════════ */

@media (max-width: 639px) {

	/* copy mobile */
	.rl-guia-archive-hero__copy p {
		font-size: 1rem;
	}

	/* configurador: anclado al fondo en mobile */
	.rl-guia-configurador {
		padding: 0.75rem;
		margin-top: auto;
	}

	.rl-guia-configurador__label {
		margin-bottom: 0.5rem;
	}

	.rl-guia-configurador__selects {
		flex-direction: column;
		gap: 0.375rem;
	}

	.rl-guia-configurador__select {
		min-width: 0;
		width: 100%;
		font-size: 0.875rem;
		padding: 0.5rem 0.875rem !important;
	}

	/* resultado: compacto — título en 1 línea, botón ancho completo */
	.rl-guia-configurador__result {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.25rem;
		margin-top: 0.5rem;
		padding: 0.625rem 0.875rem;
	}

	.rl-guia-configurador__result-title {
		-webkit-line-clamp: 1;
		display: -webkit-box;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}

	.rl-guia-configurador__result-meta {
		display: none;
	} /* ocultar en mobile para ahorrar espacio */
	.rl-guia-configurador__result-cta {
		width: 100%;
		text-align: center;
		justify-content: center;
	}

	.rl-guia-card-v2 {
		grid-template-columns: 110px 1fr;
		height: 160px;
	}

	.rl-guia-card-v2__img img,
	.rl-guia-card-v2__img-placeholder {
		height: 100%;
	}
}

/* ============================================================
   Word-accent cat-hub + hero sub — familia rl-guia-archive-hero.
   Extraído de style.css (split fase 2.3). Byte-idéntico.
   Markup: patterns/archive/guia.php (único emisor).
   Carga condicional (AssetManager):
   is_post_type_archive( 'rl_guia' ).
   ============================================================ */

/* word-accent en hero /mejores/ — mismo patrón */
body.cat-hub .rl-guia-archive-hero h1 {
	color: oklch(98% 0.004 22) !important;
}

body.cat-hub .rl-guia-archive-hero h1 .rl-guia-hero-accent {
	color: oklch(79% 0.17 168);
}

.rl-guia-archive-hero__sub {
	font-size: 1.0625rem;
	color: rgba(255, 255, 255, 0.6);
	margin: 0 auto;
	max-width: 480px;
}
