/* ==========================================================================
   RN.MATES — Estilos de la HOME (front-page)
   Porta a clases reales rn- lo que en index.html vivia como pv-* (preview):
   grilla de beneficios, encabezados de seccion, grilla de categorias y el
   split de la seccion "Sobre la marca". Reutiliza tokens de theme.css.
   NO edita theme.css. Todas las clases nuevas van prefijadas con rn-.
   ========================================================================== */

/* ----------------------------------------------------------------------
   Encabezado de seccion (antes .pv-head)
   ---------------------------------------------------------------------- */
.rn-sec-head {
	max-width: 54ch;
	margin-bottom: clamp(1.5rem, 4vw, 2.5rem);
}
.rn-sec-head h2 {
	margin-top: 0.4rem;
}
.rn-sec-head p {
	color: var(--c-tinta-2);
	margin-top: 0.5rem;
}

/* ----------------------------------------------------------------------
   Hero: relacion de aspecto del nucleo del double-bezel
   (en index.html iba como style inline; aca queda como clase)
   ---------------------------------------------------------------------- */
.rn-hero__bezel-core {
	aspect-ratio: 5 / 4;
	background: var(--c-verde-800);
}
.rn-hero__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* ----------------------------------------------------------------------
   Beneficios (antes .pv-benefits / .pv-benefit)
   ---------------------------------------------------------------------- */
.rn-benefits-section {
	padding-block: clamp(1.75rem, 4vw, 2.75rem);
}
.rn-benefits {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1rem;
}
.rn-benefit {
	display: flex;
	gap: 0.8rem;
	align-items: flex-start;
}
.rn-benefit__ico {
	flex: none;
	margin-top: 2px;
	color: var(--c-verde-600);
	display: inline-flex;
}
.rn-benefit__ico svg {
	width: 26px;
	height: 26px;
}
.rn-benefit__title {
	font-weight: 500;
	display: block;
	color: var(--c-verde-900);
}
.rn-benefit__text {
	color: var(--c-tinta-2);
	font-size: 0.9rem;
}

/* ----------------------------------------------------------------------
   Categorias (antes .pv-cats)
   Tiles .rn-cat ya estilados en theme.css; aca solo la grilla.
   ---------------------------------------------------------------------- */
.rn-cats {
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
/* Placeholder cuando una categoria no tiene imagen. */
.rn-cat__placeholder {
	position: absolute;
	inset: 0;
	background:
		radial-gradient(120% 80% at 50% 0%, var(--c-verde-700) 0%, var(--c-verde-900) 100%);
}

/* ----------------------------------------------------------------------
   Destacados
   ---------------------------------------------------------------------- */
.rn-featured__empty {
	margin-top: 0.5rem;
}

/* ----------------------------------------------------------------------
   Sobre la marca / Story (antes .pv-story)
   ---------------------------------------------------------------------- */
.rn-story {
	display: grid;
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: center;
}
@media (min-width: 820px) {
	.rn-story {
		grid-template-columns: 1fr 1fr;
	}
}
.rn-story__bezel-core {
	aspect-ratio: 4 / 3;
}
.rn-story__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.rn-story__title {
	margin: 0.4rem 0 0.75rem;
}
.rn-story__cta {
	margin-top: 1.25rem;
}

/* ----------------------------------------------------------------------
   Newsletter (franja verde)
   ---------------------------------------------------------------------- */
.rn-newsletter__head {
	margin-inline: auto;
	text-align: center;
}
.rn-newsletter__title {
	color: var(--c-crema);
}
.rn-newsletter__text {
	color: var(--c-verde-100);
	margin-inline: auto;
}
.rn-newsletter__form {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	justify-content: center;
	max-width: 520px;
	margin-inline: auto;
}
.rn-newsletter__input {
	flex: 1;
	min-width: 220px;
}
.rn-newsletter__btn {
	flex: none;
}
/* Honeypot anti-spam: fuera de pantalla, accesible solo a bots. */
.rn-newsletter__hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

/* ======================================================================
   REVIEW IMPECCABLE — refinamientos + secciones nuevas de la home
   Rompe la monotonía del medio (ritmo de superficies verde/cálido/claro),
   suma prueba social, combos, guía, reaseguro e Instagram. Reusa tokens.
   ====================================================================== */

/* --- Hero: profundidad del verde + chips de confianza bajo los CTAs --- */
.rn-hero.rn-hero--green {
	background: radial-gradient(125% 125% at 12% 16%, var(--c-verde-800) 0%, var(--c-verde-900) 60%);
}
.rn-hero__figure { position: relative; }

/* --- Cabecera de sección con acción a la derecha (no es eyebrow decorativo) --- */
.rn-sec-head--row {
	max-width: none;
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 0.5rem 1.5rem;
	flex-wrap: wrap;
}
.rn-sec-head__action {
	flex: none;
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-family: var(--font-sans);
	font-size: var(--fs-sm);
	font-weight: 500;
	color: var(--c-verde-700);
}
.rn-sec-head__action svg { width: 18px; height: 18px; transition: transform var(--tr); }
@media (hover: hover) and (pointer: fine) {
	.rn-sec-head__action:hover { color: var(--c-acento); }
	.rn-sec-head__action:hover svg { transform: translateX(3px); }
}

/* --- Beneficios: bandeja cálida que cierra el hero y abre la tienda --- */
.rn-benefits-section {
	background: color-mix(in srgb, var(--c-arena) 36%, var(--c-crema));
	border-bottom: 1px solid var(--c-linea);
}

/* --- Ritmo vertical: la historia marca "cambio de tema" con más aire arriba --- */
.rn-story-section { padding-block-start: clamp(4rem, 8vw, 8rem); }

/* --- Títulos editoriales un escalón por encima de los rótulos de grilla --- */
.rn-story__title,
.rn-newsletter__title {
	font-size: clamp(1.75rem, 1.3rem + 1.8vw, 2.6rem);
}

/* --- Categorías: mosaico editorial (1 tile grande) para diferenciarlas
       del grid uniforme de productos. En mobile cae al grid base. --- */
@media (min-width: 760px) {
	.rn-cats--editorial {
		grid-template-columns: repeat(3, 1fr);
		grid-auto-rows: clamp(170px, 18vw, 230px);
		grid-auto-flow: dense; /* rellena huecos: robusto para 3, 5 o 6 categorías */
	}
	.rn-cats--editorial > .rn-cat { aspect-ratio: auto; }
	.rn-cats--editorial > .rn-cat:first-child { grid-column: span 2; grid-row: span 2; }
}

/* --- Story: en mobile, primero el texto y la foto de apoyo abajo --- */
@media (max-width: 819px) {
	.rn-story__text { order: -1; }
	.rn-story__bezel-core { aspect-ratio: 16 / 10; }
}

/* --- Guía "¿Cuál es tu mate?" --- */
.rn-guide {
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(auto-fit, minmax(220px, 360px));
	justify-content: center;
}
.rn-guide__card {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.5rem;
	padding: clamp(1.25rem, 3vw, 1.75rem);
	background: var(--c-crema-2);
	border: 1px solid var(--c-linea);
	border-radius: var(--r-lg);
	color: var(--c-tinta);
	transition: border-color var(--tr), transform var(--tr), box-shadow var(--tr);
}
@media (hover: hover) and (pointer: fine) {
	.rn-guide__card:hover { border-color: var(--c-verde-300); transform: translateY(-3px); box-shadow: var(--sh-float); }
}
.rn-guide__ico {
	display: inline-grid;
	place-items: center;
	width: 46px;
	height: 46px;
	border-radius: var(--r-md);
	background: var(--c-verde-50);
	color: var(--c-verde-700);
}
.rn-guide__ico svg { width: 24px; height: 24px; }
.rn-guide__title { margin: 0.25rem 0 0; }
.rn-guide__text { color: var(--c-tinta-2); font-size: 0.95rem; margin: 0; }
.rn-guide__link {
	margin-top: auto;
	padding-top: 0.5rem;
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-size: var(--fs-sm);
	font-weight: 500;
	color: var(--c-acento-700);
}
.rn-guide__link svg { width: 16px; height: 16px; }

/* --- Combos / kit matero (sobre verde) --- */
.rn-combos__head { max-width: 60ch; }
.rn-combos__lead { color: var(--c-verde-100); margin-top: 0.5rem; }
.rn-combos {
	display: grid;
	gap: clamp(1rem, 2.5vw, 1.75rem);
	grid-template-columns: repeat(auto-fit, minmax(280px, 420px));
	justify-content: center; /* con 1-2 combos no se estiran a ancho completo */
}
.rn-combo {
	display: flex;
	flex-direction: column;
	background: var(--c-crema);
	border-radius: var(--r-lg);
	overflow: hidden;
	box-shadow: var(--sh-float);
}
.rn-combo__media { position: relative; aspect-ratio: 16 / 11; background: var(--c-arena); }
.rn-combo__img { width: 100%; height: 100%; object-fit: cover; }
.rn-combo__flag { position: absolute; top: 0.7rem; left: 0.7rem; }
.rn-combo__body {
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
	padding: clamp(1.1rem, 2.5vw, 1.5rem);
	flex: 1;
}
.rn-combo__title { margin: 0; color: var(--c-verde-900); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.rn-combo__items {
	display: flex;
	flex-direction: column;
	gap: 0.3rem;
	margin: 0;
	padding: 0;
	list-style: none;
	font-size: 0.95rem;
	color: var(--c-tinta-2);
}
.rn-combo__items li { display: flex; align-items: center; gap: 0.5rem; }
.rn-combo__check { display: inline-flex; color: var(--c-verde-600); flex: none; }
.rn-combo__check svg { width: 18px; height: 18px; }
.rn-combo__foot {
	margin-top: auto;
	padding-top: 0.4rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	flex-wrap: wrap;
}
.rn-combo__price { display: flex; align-items: baseline; gap: 0.5rem; }
.rn-combo__price-now { font-family: var(--font-display); font-size: 1.35rem; font-weight: 700; color: var(--c-verde-900); }
.rn-combo__price-was { color: var(--c-tinta-3); font-size: 0.95rem; }

/* --- Testimonios / prueba social --- */
.rn-testimonials {
	display: grid;
	gap: clamp(1rem, 2.5vw, 1.75rem);
	grid-template-columns: repeat(auto-fit, minmax(260px, 400px));
	justify-content: center;
}
.rn-testimonial {
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
	margin: 0;
	padding: clamp(1.25rem, 3vw, 1.75rem);
	background: var(--c-crema);
	border: 1px solid var(--c-linea);
	border-radius: var(--r-lg);
}
.rn-testimonial__stars { display: inline-flex; gap: 2px; color: var(--c-acento); }
.rn-testimonial__stars svg { width: 18px; height: 18px; }
.rn-testimonial__quote {
	margin: 0;
	font-family: var(--font-display);
	font-size: 1.15rem;
	line-height: 1.45;
	color: var(--c-verde-900);
	display: -webkit-box;
	-webkit-line-clamp: 6;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.rn-testimonial__quote::before { content: "\201C"; }
.rn-testimonial__quote::after { content: "\201D"; }
.rn-testimonial__author { display: flex; align-items: center; gap: 0.7rem; margin-top: auto; }
.rn-testimonial__avatar { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; flex: none; }
.rn-testimonial__avatar--initial {
	display: grid;
	place-items: center;
	background: var(--c-verde-100);
	color: var(--c-verde-800);
	font-family: var(--font-display);
	font-weight: 700;
}
.rn-testimonial__meta { display: flex; flex-direction: column; line-height: 1.25; }
.rn-testimonial__meta b { color: var(--c-verde-900); }
.rn-testimonial__city { font-size: var(--fs-sm); color: var(--c-tinta-3); }

/* --- Tira de reaseguro (último empujón antes del newsletter) --- */
.rn-reassurance {
	background: color-mix(in srgb, var(--c-arena) 45%, var(--c-crema));
	border-block: 1px solid var(--c-linea);
	padding-block: clamp(1rem, 2.5vw, 1.4rem);
}
.rn-reassurance__inner {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem clamp(1.5rem, 5vw, 3.5rem);
	align-items: center;
	justify-content: center;
}
.rn-reassurance__item {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	font-size: var(--fs-sm);
	font-weight: 500;
	color: var(--c-cuero-700);
}
.rn-reassurance__ico { display: inline-flex; color: var(--c-verde-600); flex: none; }
.rn-reassurance__ico svg { width: 22px; height: 22px; }

/* --- Instagram / UGC --- */
.rn-instagram__head {
	max-width: none;
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 0.5rem 1.5rem;
	flex-wrap: wrap;
}
.rn-instagram__ico { display: inline-flex; }
.rn-instagram__ico svg { width: 18px; height: 18px; }
.rn-instagram__grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 0.6rem;
	margin: 0;
	padding: 0;
	list-style: none;
}
@media (max-width: 720px) { .rn-instagram__grid { grid-template-columns: repeat(3, 1fr); } }
.rn-instagram__cell { position: relative; aspect-ratio: 1; border-radius: var(--r-md); overflow: hidden; }
.rn-instagram__cell a { display: block; width: 100%; height: 100%; }
.rn-instagram__cell img { width: 100%; height: 100%; object-fit: cover; transition: transform 600ms var(--ease-out-expo); }
.rn-instagram__overlay {
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	color: #fff;
	background: color-mix(in srgb, var(--c-verde-900) 45%, transparent);
	opacity: 0;
	transition: opacity var(--tr);
}
.rn-instagram__overlay svg { width: 28px; height: 28px; }
@media (hover: hover) and (pointer: fine) {
	.rn-instagram__cell:hover img { transform: scale(1.06); }
	.rn-instagram__cell:hover .rn-instagram__overlay { opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
	.rn-guide__card,
	.rn-instagram__cell img,
	.rn-sec-head__action svg { transition: none; }
	.rn-instagram__cell:hover img { transform: none; }
}

/* Instagram sin fotos cargadas: llamado a seguir el perfil (sin grilla de relleno) */
.rn-instagram-section--cta { padding-block: clamp(2.5rem, 5vw, 4rem); }
.rn-instagram__cta {
	max-width: 46ch;
	margin-inline: auto;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.85rem;
}
.rn-instagram__cta-text { color: var(--c-tinta-2); margin: 0; }
