/* ==========================================================================
   Zarevo — Carrito y Checkout
   Estilos de la página de carrito (.rn-cart), checkout (.rn-checkout),
   carrito vacío (.rn-cart-empty) y gracias (.rn-thankyou).
   Reutiliza tokens y clases rn-* de theme.css. NO modifica theme.css.

   COORDINACIÓN (anti-conflicto):
   - El DRAWER mini-cart (.rn-minicart, .woocommerce-mini-cart*) y el selector
     de cantidad (.rn-qty*) ya los estila assets/css/woocommerce.css. Acá NO se
     duplican esos selectores.
   - Las tarjetas .rn-product (cross-sells) usan theme.css + woocommerce.css.
   ========================================================================== */

/* ============================ 1. PÁGINA DE CARRITO ===================== */
/* La tabla va arriba a ancho completo; debajo, .rn-cart__collaterals contiene
   (por hooks de WooCommerce) los cross-sells Y la card de totales. Hacemos que
   collaterals sea un grid de 2 columnas: cross-sells a la izquierda y totales a
   la derecha en desktop; apilados en mobile. Así no rompemos el orden de hooks. */
.rn-cart {
	display: grid;
	grid-template-columns: 1fr;
}
/* Titulos de columna FUERA de las cards: "Carrito" (izq) y "Resumen del pedido"
   (der) como una fila de headings arriba, a la misma altura; las cards debajo. */
.rn-cart .rn-cart__head {
	margin: 0;
	font-family: var(--font-display);
	color: var(--c-verde-900);
	line-height: 1.08;
	letter-spacing: -0.015em;
	text-wrap: balance;
}
.rn-cart .rn-cart__head--items { order: 1; font-size: var(--fs-h1); margin-bottom: var(--sp-4); }
.rn-cart .rn-cart__head--summary { order: 3; font-size: var(--fs-h2); margin-bottom: var(--sp-4); }
.rn-cart__form { order: 2; margin-bottom: clamp(2rem, 5vw, 2.75rem); }
.rn-cart__collaterals {
	order: 4;
	display: grid;
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: start;
}
@media (min-width: 980px) {
	/* Dos filas: headings arriba (Carrito | Resumen del pedido) y cards abajo
	   (items | totales). Asi "Resumen del pedido" queda arriba de su card, a la
	   misma altura que "Carrito". Las cards top-aligned (par cohesivo). */
	.rn-cart {
		grid-template-columns: minmax(0, 1fr) 360px;
		grid-template-rows: auto auto;
		column-gap: clamp(1.5rem, 4vw, 3rem);
		row-gap: clamp(1.1rem, 2.2vw, 1.6rem);
		align-items: start;
	}
	.rn-cart .rn-cart__head--items { grid-column: 1; grid-row: 1; margin-bottom: 0; }
	.rn-cart .rn-cart__head--summary { grid-column: 2; grid-row: 1; margin-bottom: 0; }
	/* Los ítems flotan sobre el lienzo (sin card ni sombra): editorial, aireado.
	   El marco se reserva solo para el "recibo" (resumen). */
	.rn-cart__form {
		grid-column: 1;
		grid-row: 2;
		margin-bottom: 0;
		background: transparent;
		border: 0;
		border-radius: 0;
		box-shadow: none;
		padding: 0;
	}
	.rn-cart__collaterals { grid-column: 2; grid-row: 2; display: block; }
	/* Cross-sells (si se configuran) se apilan bajo el resumen, a 1 por fila. */
	.rn-cart__crosssells { margin-top: clamp(1.5rem, 3vw, 2.25rem); }
}

/* --- Tabla de ítems --- */
.rn-cart__table {
	width: 100%;
	border-collapse: collapse;
	margin: 0;
}
/* La tabla no lleva marco propio: la card de items (.rn-cart__form en desktop)
   la enmarca. Quitamos el borde/box que agrega WooCommerce via .shop_table. */
.rn-cart .rn-cart__table { border: 0; border-radius: 0; }
.rn-cart__table thead th {
	text-align: left;
	font-family: var(--font-sans);
	font-size: var(--fs-xs);
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--c-tinta-3);
	padding: 0 0 var(--sp-3);
	border-bottom: 1px solid var(--c-linea);
}
.rn-cart__table thead th.product-price,
.rn-cart__table thead th.product-quantity,
.rn-cart__table thead th.product-subtotal {
	text-align: center;
}
.rn-cart__row td {
	padding: var(--sp-4) var(--sp-3);
	border-bottom: 1px solid var(--c-linea);
	vertical-align: middle;
}
.rn-cart__row td.product-remove { padding-left: 0; width: 36px; }
.rn-cart__row td.product-thumbnail { width: 84px; }
.rn-cart__row td.product-price,
.rn-cart__row td.product-quantity,
.rn-cart__row td.product-subtotal {
	text-align: center;
	white-space: nowrap;
}
.rn-cart__row td.product-subtotal { font-weight: 500; color: var(--c-tinta); padding-right: 0; }

.rn-cart__row .product-thumbnail img {
	width: 72px;
	height: 88px;
	object-fit: cover;
	border-radius: var(--r-md);
	border: 1px solid var(--c-linea);
	background: var(--c-crema-2);
}

.rn-cart__name {
	font-family: var(--font-display);
	font-size: 1.05rem;
	font-weight: 500;
	color: var(--c-verde-900);
	line-height: 1.25;
}
.rn-cart__name:hover { color: var(--c-acento); }
.rn-cart__row .variation,
.rn-cart__row .backorder_notification {
	margin: var(--sp-2) 0 0;
	font-size: var(--fs-xs);
	color: var(--c-tinta-3);
}
.rn-cart__row .variation p { margin: 0; max-width: none; }

/* Botón quitar (X). */
.rn-cart__remove {
	display: grid;
	place-items: center;
	width: 30px;
	height: 30px;
	border-radius: var(--r-pill);
	color: var(--c-tinta-3);
	background: var(--c-crema-2);
	transition: background var(--tr), color var(--tr);
}
.rn-cart__remove svg { width: 16px; height: 16px; }
.rn-cart__remove:hover { background: var(--c-acento-50); color: var(--c-acento-700); }

/* La cantidad usa .rn-qty (de woocommerce.css); acá solo la centramos. */
.rn-cart__row td.product-quantity .rn-qty { margin-inline: auto; }

/* --- Fila de acciones (cupón + actualizar) --- */
.rn-cart__actions {
	padding: var(--sp-5) 0 0 !important;
	border-bottom: none !important;
}
.rn-cart__actions::after { content: ""; display: table; clear: both; }
.rn-cart__coupon {
	display: inline-flex;
	gap: var(--sp-2);
	max-width: 360px;
	margin-right: var(--sp-3);
	vertical-align: middle;
}
.rn-cart__coupon-input { min-width: 0; }
.rn-cart__update { float: right; }

/* --- Card de totales --- */
.rn-cart__totals {
	position: sticky;
	top: calc(var(--header-h) + 1rem);
}
.rn-cart__totals-title {
	font-size: var(--fs-h3);
	margin-bottom: var(--sp-4);
}
/* Sin el margen superior que .rn-prose le da a los h2: asi el heading arranca en
   el tope de la card, a la misma altura que la primera fila del carrito (las dos
   columnas alineadas arriba). La especificidad (0,2,0) le gana a .rn-prose h2. */
.rn-cart__totals .rn-cart__totals-title { margin-top: 0; }
.rn-cart__totals-table {
	width: 100%;
	border-collapse: collapse;
	margin: 0 0 var(--sp-5);
}
.rn-cart__totals-table th,
.rn-cart__totals-table td {
	padding: var(--sp-3) 0;
	text-align: left;
	border-bottom: 1px solid var(--c-linea);
	font-size: var(--fs-sm);
	vertical-align: top;
}
.rn-cart__totals-table th {
	font-weight: 500;
	color: var(--c-tinta-2);
}
.rn-cart__totals-table td {
	text-align: right;
	color: var(--c-tinta);
}
.rn-cart__totals-table .order-total th,
.rn-cart__totals-table .order-total td {
	border-bottom: none;
	padding-top: var(--sp-4);
	font-family: var(--font-display);
	font-size: 1.2rem;
	font-weight: 600;
	color: var(--c-verde-900);
}
.rn-cart__totals-table .woocommerce-shipping-destination,
.rn-cart__totals-table .shipping-calculator-button {
	font-size: var(--fs-xs);
	color: var(--c-tinta-3);
}
.rn-cart__totals-table .shipping ul {
	list-style: none;
	margin: 0;
	padding: 0;
	text-align: right;
}
.rn-cart__totals-table .shipping ul li { margin-bottom: var(--sp-2); }
.rn-cart__totals-table .shipping ul label { cursor: pointer; }

/* El envío no se muestra en el carrito (se cotiza en el checkout). La plantilla
   cart-totals.php ya no imprime la fila; esto es red de seguridad por si algún
   refresh AJAX o plugin la reinyecta. Solo afecta al carrito: el checkout usa
   .rn-checkout__review, no .rn-cart__totals. */
.rn-cart__totals-table tr.shipping { display: none; }

/* CTA "Finalizar compra": WooCommerce engancha .checkout-button.button.alt. */
.rn-cart__proceed .checkout-button,
.rn-cart__proceed .button {
	display: flex;
	width: 100%;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	font-family: var(--font-sans);
	font-size: var(--fs-body);
	font-weight: 500;
	line-height: 1;
	padding: 1.05rem 2rem;
	border-radius: var(--r-pill);
	border: 1.5px solid transparent;
	background: var(--c-verde-600);
	color: var(--c-crema);
	transition: background var(--tr), transform var(--tr), box-shadow var(--tr);
}
.rn-cart__proceed .checkout-button:hover,
.rn-cart__proceed .button:hover {
	background: var(--c-verde-700);
	color: var(--c-crema);
	transform: translateY(-1px);
	box-shadow: var(--sh-md);
}

/* --- Cross-sells (reutiliza .rn-product / .rn-grid--4) --- */
.rn-cart__crosssells-title {
	font-size: var(--fs-h2);
	margin-bottom: clamp(1.25rem, 3vw, 2rem);
}
/* En desktop la grilla de cross-sells dentro de la columna izquierda usa
   tarjetas más angostas para convivir con la card de totales. */
@media (min-width: 980px) {
	.rn-cart__crosssells-grid {
		grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	}
}

/* ============================ 2. CARRITO VACÍO ======================== */
.rn-cart-empty {
	text-align: center;
	max-width: 46ch;
	margin-inline: auto;
	padding-block: clamp(2.5rem, 7vw, 5rem);
}
.rn-cart-empty__ico {
	display: grid;
	place-items: center;
	width: 76px;
	height: 76px;
	margin: 0 auto var(--sp-5);
	border-radius: var(--r-pill);
	background: var(--c-verde-50);
	color: var(--c-verde-600);
}
.rn-cart-empty__ico svg { width: 34px; height: 34px; }
.rn-cart-empty__title {
	font-family: var(--font-display);
	font-size: var(--fs-h2);
	color: var(--c-verde-900);
	margin: 0 0 var(--sp-3);
	background: none;
	padding: 0;
}
.rn-cart-empty__lead { margin: 0 auto var(--sp-5); }
.rn-cart-empty__action { margin: 0; }

/* ============================ 3. CHECKOUT ============================= */
.rn-checkout__cols {
	display: grid;
	gap: clamp(1.75rem, 4vw, 3rem);
	align-items: start;
}
@media (min-width: 980px) {
	.rn-checkout__cols {
		grid-template-columns: 1fr 400px;
	}
}

/* --- Columnas de datos (facturación + envío) --- */
.rn-checkout__details {
	display: grid;
	gap: clamp(1.5rem, 4vw, 2.5rem);
}
.rn-checkout__col { min-width: 0; }
.rn-checkout h3,
.rn-checkout .woocommerce-billing-fields > h3,
.rn-checkout .woocommerce-shipping-fields h3,
.rn-checkout .woocommerce-additional-fields h3 {
	font-size: var(--fs-h3);
	margin-bottom: var(--sp-4);
}

/* Campos: etiqueta arriba, helper/errores debajo (mobile-first, accesible). */
.rn-checkout .form-row {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	margin: 0 0 var(--sp-4);
	padding: 0;
}
.rn-checkout .form-row label {
	font-size: var(--fs-sm);
	font-weight: 500;
	color: var(--c-tinta-2);
	line-height: 1.3;
}
.rn-checkout .form-row .required {
	color: var(--c-acento-700);
	border: 0;
	text-decoration: none;
}
.rn-checkout .form-row .optional { color: var(--c-tinta-3); font-weight: 400; }

/* Inputs heredan el look de .rn-input vía estos selectores WC. */
.rn-checkout .input-text,
.rn-checkout textarea,
.rn-checkout select,
.rn-checkout .select2-container .select2-selection {
	width: 100%;
	padding: 0.7rem 0.9rem;
	background: var(--c-crema);
	color: var(--c-tinta);
	border: 1px solid var(--c-arena-2);
	border-radius: var(--r-md);
	font: inherit;
	line-height: 1.4;
	transition: border-color var(--tr), box-shadow var(--tr);
}
.rn-checkout textarea { min-height: 96px; resize: vertical; }
.rn-checkout .input-text:focus,
.rn-checkout textarea:focus,
.rn-checkout select:focus {
	outline: none;
	border-color: var(--c-verde-600);
	box-shadow: 0 0 0 3px var(--c-verde-100);
}
.rn-checkout .input-text::placeholder { color: var(--c-tinta-3); }

/* Select2 (país/provincia) alineado con la altura del resto. */
.rn-checkout .select2-container--default .select2-selection--single {
	min-height: 44px;
	height: auto;
	display: flex;
	align-items: center;
}
.rn-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
	line-height: 1.4;
	padding: 0;
	color: var(--c-tinta);
}
.rn-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
	height: 100%;
	right: 0.6rem;
}

/* Helper / descripción debajo del input. */
.rn-checkout .form-row .description {
	font-size: var(--fs-xs);
	color: var(--c-tinta-3);
	margin: 0;
}

/* Estados de validación de WooCommerce. */
.rn-checkout .woocommerce-invalid .input-text,
.rn-checkout .woocommerce-invalid select,
.rn-checkout .woocommerce-invalid .select2-container .select2-selection {
	border-color: var(--c-error);
}
.rn-checkout .woocommerce-invalid .input-text:focus {
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-error) 18%, transparent);
}
.rn-checkout .woocommerce-validated .input-text {
	border-color: var(--c-ok);
}

/* Checkbox "enviar a otra dirección" / crear cuenta. */
.rn-checkout .form-row.woocommerce-validated label.checkbox,
.rn-checkout .woocommerce-account-fields label.checkbox,
.rn-checkout label.woocommerce-form__label-for-checkbox {
	flex-direction: row;
	align-items: flex-start;
	gap: 0.6rem;
	cursor: pointer;
}
.rn-checkout input[type="checkbox"],
.rn-checkout input[type="radio"] {
	width: 18px;
	height: 18px;
	accent-color: var(--c-verde-600);
	margin-top: 2px;
	flex: none;
}
.rn-checkout #ship-to-different-address {
	margin-top: var(--sp-5);
}
.rn-checkout #ship-to-different-address label {
	flex-direction: row;
	align-items: center;
	gap: 0.6rem;
	font-family: var(--font-display);
	font-size: var(--fs-h3);
	color: var(--c-verde-900);
	cursor: pointer;
}

/* --- Aside: review-order sticky --- */
.rn-checkout__aside { min-width: 0; }
@media (min-width: 980px) {
	.rn-checkout__review {
		position: sticky;
		top: calc(var(--header-h) + 1rem);
	}
}
.rn-checkout__review-title {
	font-size: var(--fs-h3);
	margin-bottom: var(--sp-4);
}

/* Tabla de ítems del review. */
.rn-checkout__items {
	width: 100%;
	border-collapse: collapse;
	margin: 0 0 var(--sp-4);
}
.rn-checkout__items th {
	text-align: left;
	font-size: var(--fs-xs);
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--c-tinta-3);
	padding: 0 0 var(--sp-3);
	border-bottom: 1px solid var(--c-linea);
}
.rn-checkout__items th.product-total,
.rn-checkout__items td.product-total { text-align: right; }
.rn-checkout__items td {
	padding: var(--sp-3) 0;
	border-bottom: 1px solid var(--c-linea);
	font-size: var(--fs-sm);
	vertical-align: top;
}
.rn-checkout__items td.product-name { color: var(--c-tinta); }
.rn-checkout__item-qty { color: var(--c-tinta-3); font-weight: 500; }
.rn-checkout__items .variation {
	margin: var(--sp-2) 0 0;
	font-size: var(--fs-xs);
	color: var(--c-tinta-3);
}
.rn-checkout__items .variation p { margin: 0; max-width: none; }

/* Totales (tfoot del review). */
.rn-checkout__items tfoot th,
.rn-checkout__items tfoot td {
	padding: var(--sp-3) 0;
	border-bottom: 1px solid var(--c-linea);
	font-size: var(--fs-sm);
}
.rn-checkout__items tfoot th { text-align: left; font-weight: 500; color: var(--c-tinta-2); }
.rn-checkout__items tfoot td { text-align: right; color: var(--c-tinta); }
.rn-checkout__items tfoot .order-total th,
.rn-checkout__items tfoot .order-total td {
	border-bottom: none;
	padding-top: var(--sp-4);
	font-family: var(--font-display);
	font-size: 1.2rem;
	font-weight: 600;
	color: var(--c-verde-900);
}
.rn-checkout__items tfoot .shipping ul {
	list-style: none;
	margin: 0;
	padding: 0;
	text-align: right;
}
.rn-checkout__items tfoot .shipping ul li { margin-bottom: var(--sp-2); }
.rn-checkout__items tfoot .shipping label { cursor: pointer; }

/* --- Métodos de pago --- */
.rn-checkout__payment { margin-top: var(--sp-5); }
.rn-checkout__methods {
	list-style: none;
	margin: 0 0 var(--sp-5);
	padding: 0;
	border: 1px solid var(--c-linea);
	border-radius: var(--r-lg);
	overflow: hidden;
	background: var(--c-crema);
}
.rn-checkout__method {
	padding: var(--sp-4);
	border-bottom: 1px solid var(--c-linea);
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.6rem;
}
.rn-checkout__method:last-child { border-bottom: none; }
.rn-checkout__method-label {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	flex: 1 1 auto;
	font-weight: 500;
	color: var(--c-tinta);
	cursor: pointer;
}
.rn-checkout__method-radio { margin: 0; }
.rn-checkout__method-icon { margin-left: auto; display: inline-flex; align-items: center; gap: 0.4rem; }
.rn-checkout__method-icon img { max-height: 24px; width: auto; display: inline-block; }
.rn-checkout__method-box {
	flex-basis: 100%;
	margin-top: var(--sp-3);
	padding: var(--sp-3) var(--sp-4);
	background: var(--c-crema-2);
	border-radius: var(--r-md);
	font-size: var(--fs-sm);
	color: var(--c-tinta-2);
}
.rn-checkout__method-box p { margin: 0; max-width: none; }
.rn-checkout__method-box p + p { margin-top: var(--sp-3); }

.rn-checkout__no-payment {
	padding: var(--sp-4);
	font-size: var(--fs-sm);
	color: var(--c-tinta-2);
}

/* Botón "Realizar pedido": ya lleva clases rn-btn--primary/--block/--lg. */
.rn-checkout__place-order { margin: 0; }
.rn-checkout__place-order .rn-btn { margin-top: var(--sp-2); }

/* Términos y condiciones. */
.rn-checkout .woocommerce-terms-and-conditions-wrapper {
	margin-bottom: var(--sp-4);
	font-size: var(--fs-sm);
}
.rn-checkout .woocommerce-terms-and-conditions {
	margin-top: var(--sp-3);
	padding: var(--sp-4);
	border: 1px solid var(--c-linea);
	border-radius: var(--r-md);
	background: var(--c-crema-2);
	max-height: 180px;
	overflow-y: auto;
}

/* --- Cupón plegable arriba del checkout --- */
.rn-checkout__coupon-toggle {
	margin-bottom: var(--sp-4);
}
.rn-checkout__coupon-form {
	margin-bottom: var(--sp-5);
	padding: var(--sp-5);
	border: 1px dashed var(--c-arena-2);
	border-radius: var(--r-lg);
	background: var(--c-crema);
}
.rn-checkout__coupon-text { margin: 0 0 var(--sp-3); font-size: var(--fs-sm); color: var(--c-tinta-2); }
.rn-checkout__coupon-row {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: var(--sp-3);
}
.rn-checkout__coupon-row .form-row {
	margin: 0;
	flex: 1 1 200px;
}
.rn-checkout__coupon-submit { flex: none; }
.rn-checkout__coupon-link { font-weight: 500; }

/* ============================ 4. GRACIAS (thankyou) ================== */
/* Última pantalla de la compra: confirmación cálida + el "qué sigue" (pagar por
   transferencia) destacado, con el mismo recibo editorial del carrito. */
.rn-thankyou {
	max-width: var(--container-narrow);
	margin-inline: auto;
}

/* --- Encabezado: check + título --- */
.rn-thankyou__head {
	text-align: center;
	margin-bottom: clamp(1.75rem, 4vw, 2.75rem);
}
.rn-thankyou__check {
	display: grid;
	place-items: center;
	width: 76px;
	height: 76px;
	margin: 0 auto var(--sp-4);
	border-radius: var(--r-pill);
	background: var(--c-verde-50);
	color: var(--c-verde-600);
	box-shadow: 0 0 0 8px color-mix(in srgb, var(--c-verde-50) 55%, transparent);
}
.rn-thankyou__check svg { width: 38px; height: 38px; }
.rn-thankyou__head--failed .woocommerce-thankyou-order-failed {
	color: var(--c-error);
	font-size: 1.1rem;
}
.rn-thankyou__title {
	font-family: var(--font-display);
	font-size: var(--fs-h2);
	line-height: 1.12;
	color: var(--c-verde-900);
	margin: 0;
	text-wrap: balance;
}
.rn-thankyou__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sp-3);
	justify-content: center;
	margin-top: var(--sp-4);
}
/* Festejo discreto: el check aparece una sola vez (frecuencia: 1 por compra). */
@media (prefers-reduced-motion: no-preference) {
	.rn-thankyou__check { animation: rn-thanks-pop 520ms var(--ease-out-expo) both; }
	.rn-thankyou__check svg { animation: rn-thanks-pop 560ms var(--ease-out-expo) 140ms both; }
}
@keyframes rn-thanks-pop {
	from { opacity: 0; transform: scale(0.82); }
	to { opacity: 1; transform: scale(1); }
}

/* --- Resumen rápido (overview): tira centrada con los datos clave --- */
.rn-thankyou__overview {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--sp-4) clamp(1.75rem, 4vw, 3rem);
	margin: 0 0 clamp(1.5rem, 4vw, 2.5rem);
	padding: clamp(1.4rem, 3vw, 2rem);
	border: 1px solid var(--c-linea);
	border-radius: var(--r-lg);
	background: color-mix(in srgb, #fff 50%, var(--c-crema));
	text-align: center;
}
.rn-thankyou__overview li {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.3rem;
	min-width: 0; /* permite que el contenido se ajuste y no desborde */
	font-size: var(--fs-xs);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--c-tinta-3);
}
.rn-thankyou__overview li strong {
	min-width: 0;
	font-family: var(--font-sans);
	font-size: var(--fs-body);
	font-weight: 600;
	letter-spacing: 0;
	text-transform: none;
	color: var(--c-verde-900);
	overflow-wrap: anywhere; /* el email largo se parte; ya no pisa al Total */
}
.rn-thankyou__overview .total strong {
	font-variant-numeric: lining-nums tabular-nums;
	font-feature-settings: "lnum" 1, "tnum" 1;
}
/* .rn-prose le pone max-width:68ch a <ul> y <p>: eso dejaba el resumen y el botón
   más angostos y corridos a la izquierda que el título y la tabla. Los liberamos
   (especificidad 0,2,0 para ganarle a .rn-prose ul/p) para que queden centrados. */
.rn-thankyou .rn-thankyou__overview,
.rn-thankyou .rn-thankyou__cta {
	max-width: none;
}
/* El clearfix de WooCommerce (::before/::after) ya no hace falta y, como item de
   la tira flex, metía un hueco al inicio (la "celda fantasma"). Lo anulamos del
   todo, también en la grilla de direcciones. */
.rn-thankyou__overview::before,
.rn-thankyou__overview::after,
.rn-thankyou .woocommerce-customer-details .woocommerce-columns--addresses::before,
.rn-thankyou .woocommerce-customer-details .woocommerce-columns--addresses::after,
.rn-thankyou .woocommerce-customer-details .addresses::before,
.rn-thankyou .woocommerce-customer-details .addresses::after {
	content: none !important;
}

/* --- Pago por transferencia: el "qué sigue", bien visible (panel cálido) --- */
.rn-thankyou__pay {
	margin: 0 0 clamp(1.75rem, 4vw, 2.75rem);
	padding: clamp(1.5rem, 3.2vw, 2.1rem) clamp(1.4rem, 3vw, 2rem);
	border: 1px solid color-mix(in srgb, var(--c-acento-600) 22%, var(--c-linea));
	border-radius: var(--r-lg);
	background: var(--c-acento-50);
}
.rn-thankyou__pay-head {
	display: flex;
	align-items: center;
	gap: var(--sp-2);
	margin-bottom: var(--sp-3);
	font-family: var(--font-sans);
	font-size: var(--fs-xs);
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--c-acento-700);
}
.rn-thankyou__pay-head svg { width: 18px; height: 18px; flex: none; }
.rn-thankyou__pay p {
	margin: 0 0 var(--sp-2);
	color: var(--c-tinta);
	font-size: var(--fs-body);
	line-height: var(--lh-body);
}
.rn-thankyou__pay p:last-child { margin-bottom: 0; }
.rn-thankyou__pay strong { color: var(--c-verde-900); font-weight: 600; }

/* --- Detalle del pedido + direcciones --- */
.rn-thankyou .woocommerce-order-details,
.rn-thankyou .woocommerce-customer-details {
	margin-top: clamp(1.75rem, 4vw, 2.75rem);
}
.rn-thankyou .woocommerce-order-details__title,
.rn-thankyou .woocommerce-column__title {
	font-family: var(--font-display);
	font-size: var(--fs-h3);
	color: var(--c-verde-900);
	margin: 0 0 var(--sp-4);
}
/* Tabla del pedido: recibo editorial (sin grilla ni sombreados de WooCommerce
   core; solo hairlines y numerales lining/tabular como en el carrito). */
.rn-thankyou .woocommerce-table--order-details,
.rn-thankyou table.shop_table {
	width: 100%;
	border-collapse: collapse;
	border: 1px solid var(--c-linea);
	border-radius: var(--r-lg);
	overflow: hidden;
	background: transparent;
}
.rn-thankyou .woocommerce-table--order-details thead th,
.rn-thankyou .woocommerce-table--order-details tbody td,
.rn-thankyou .woocommerce-table--order-details tbody th,
.rn-thankyou .woocommerce-table--order-details tfoot td,
.rn-thankyou .woocommerce-table--order-details tfoot th {
	background: transparent !important; /* mata el zebra/sombreado de WC core */
	border: 0;
	border-bottom: 1px solid var(--c-linea);
	padding: var(--sp-3) var(--sp-4);
	text-align: left;
	font-size: var(--fs-sm);
}
.rn-thankyou .woocommerce-table--order-details thead th {
	font-family: var(--font-sans);
	font-size: var(--fs-xs);
	letter-spacing: 0.14em;
	text-transform: uppercase;
	font-weight: 600;
	color: var(--c-tinta-3);
}
.rn-thankyou .woocommerce-table--order-details td.product-total,
.rn-thankyou .woocommerce-table--order-details th.product-total,
.rn-thankyou .woocommerce-table--order-details thead th:last-child,
.rn-thankyou .woocommerce-table--order-details tfoot td { text-align: right; }
.rn-thankyou .woocommerce-table--order-details tfoot th { font-weight: 500; color: var(--c-tinta-2); }
.rn-thankyou .woocommerce-table--order-details tfoot tr:last-child th,
.rn-thankyou .woocommerce-table--order-details tfoot tr:last-child td { border-bottom: 0; }
/* Dinero igual que el recibo del carrito: Archivo + lining/tabular (mata las
   cifras oldstyle de Alegreya) y el simbolo $ atenuado en las lineas. */
.rn-thankyou .woocommerce-table--order-details .amount,
.rn-thankyou .woocommerce-table--order-details bdi {
	font-family: var(--font-sans);
	font-style: normal;
	font-variant-numeric: lining-nums tabular-nums;
	font-feature-settings: "lnum" 1, "tnum" 1;
}
.rn-thankyou .woocommerce-table--order-details .woocommerce-Price-currencySymbol { color: var(--c-tinta-3); }
/* Total como pieza. WooCommerce no le pone clase a las filas de totales, asi que
   aislamos el Total como "la ultima fila del tfoot con un importe" (la de Metodo
   de pago no tiene importe) via :has(). Etiqueta en versalita + cifra realzada,
   igual que el Total del carrito. */
.rn-thankyou .woocommerce-table--order-details tfoot tr:has(.woocommerce-Price-amount):not(:has(~ tr .woocommerce-Price-amount)) th {
	font-family: var(--font-sans);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-weight: 700;
	color: var(--c-verde-800);
}
.rn-thankyou .woocommerce-table--order-details tfoot tr:has(.woocommerce-Price-amount):not(:has(~ tr .woocommerce-Price-amount)) td {
	font-size: 1.3rem;
	font-weight: 700;
	letter-spacing: -0.01em;
	color: var(--c-verde-900);
}
/* El $ del Total (tabla y overview), alzado y en terracota (firma del recibo). */
.rn-thankyou .woocommerce-table--order-details tfoot tr:has(.woocommerce-Price-amount):not(:has(~ tr .woocommerce-Price-amount)) .woocommerce-Price-currencySymbol,
.rn-thankyou__overview .total .woocommerce-Price-currencySymbol {
	color: var(--c-acento-700);
	font-size: 0.62em;
	font-weight: 700;
	vertical-align: 0.36em;
	margin-right: 0.06em;
}
.rn-thankyou .woocommerce-table--order-details .product-name a { color: var(--c-verde-800); font-weight: 600; }
.rn-thankyou .woocommerce-table--order-details .product-name a:hover { color: var(--c-acento-700); }
.rn-thankyou .woocommerce-table--order-details .product-quantity { color: var(--c-tinta-3); }

.rn-thankyou .woocommerce-customer-details .woocommerce-columns--addresses,
.rn-thankyou .woocommerce-customer-details .addresses {
	display: grid;
	gap: var(--sp-4);
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	margin: 0;
}
.rn-thankyou .woocommerce-customer-details address {
	font-style: normal;
	padding: clamp(1.1rem, 2.5vw, 1.5rem);
	border: 1px solid var(--c-linea);
	border-radius: var(--r-md);
	background: color-mix(in srgb, #fff 50%, var(--c-crema));
	font-size: var(--fs-sm);
	color: var(--c-tinta-2);
	line-height: var(--lh-body);
}

/* --- CTA "Seguir comprando": el texto blanco le gana a .rn-prose a (terracota),
       que pisaba el color y dejaba el botón verde con texto ilegible. --- */
.rn-thankyou__cta {
	text-align: center;
	margin-top: clamp(1.75rem, 4vw, 2.75rem);
}
.rn-thankyou .rn-thankyou__cta .rn-btn--primary,
.rn-thankyou .rn-thankyou__cta .rn-btn--primary:hover,
.rn-thankyou .rn-thankyou__cta .rn-btn--primary:focus,
.rn-thankyou .rn-thankyou__actions .rn-btn--primary,
.rn-thankyou .rn-thankyou__actions .rn-btn--primary:hover {
	color: var(--c-crema);
}

/* Densidad mobile: afloja el padding de la tabla y baja el texto del metodo de
   envio para que no se apriete en pantallas chicas. */
@media (max-width: 520px) {
	.rn-thankyou .woocommerce-table--order-details thead th,
	.rn-thankyou .woocommerce-table--order-details tbody td,
	.rn-thankyou .woocommerce-table--order-details tbody th,
	.rn-thankyou .woocommerce-table--order-details tfoot td,
	.rn-thankyou .woocommerce-table--order-details tfoot th {
		padding: var(--sp-3) var(--sp-2);
	}
	.rn-thankyou .woocommerce-table--order-details tfoot tr:has(.woocommerce-Price-amount):not(:has(~ tr .woocommerce-Price-amount)) td { font-size: 1.2rem; }
	.rn-thankyou .woocommerce-table--order-details .shipped_via {
		display: block;
		margin-top: 0.15rem;
		font-size: var(--fs-xs);
		color: var(--c-tinta-3);
	}
}

/* ============================ 5. NOTICES (carrito/checkout) =========== */
/* Mensajes de WooCommerce con look de marca (cupón aplicado, errores, info). */
.rn-cart .woocommerce-message,
.rn-cart .woocommerce-info,
.rn-cart .woocommerce-error,
.rn-checkout .woocommerce-message,
.rn-checkout .woocommerce-info,
.rn-checkout .woocommerce-error,
.woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-notices-wrapper .woocommerce-info,
.woocommerce-notices-wrapper .woocommerce-error {
	list-style: none;
	margin: 0 0 var(--sp-4);
	padding: var(--sp-4) var(--sp-5);
	border-radius: var(--r-md);
	border: 1px solid color-mix(in srgb, var(--c-verde-600) 32%, var(--c-linea));
	background: var(--c-verde-50);
	color: var(--c-verde-900);
	font-size: var(--fs-sm);
}
.woocommerce-notices-wrapper .woocommerce-error,
.rn-checkout .woocommerce-error,
.rn-cart .woocommerce-error {
	border-color: color-mix(in srgb, var(--c-error) 32%, var(--c-linea));
	background: color-mix(in srgb, var(--c-error) 8%, var(--c-crema));
	color: var(--c-error);
}
.woocommerce-notices-wrapper .woocommerce-info,
.rn-checkout .woocommerce-info,
.rn-cart .woocommerce-info {
	border-color: color-mix(in srgb, var(--c-info) 32%, var(--c-linea));
	background: color-mix(in srgb, var(--c-info) 8%, var(--c-crema));
	color: var(--c-tinta);
}
.woocommerce-message .button,
.woocommerce-info .button,
.woocommerce-error .button {
	float: right;
	margin-left: var(--sp-4);
	font-size: var(--fs-xs);
	color: var(--c-verde-700);
	text-decoration: underline;
}

/* ============================ 6. RESPONSIVE =========================== */
@media (max-width: 720px) {
	/* Tabla del carrito a tarjetas (WooCommerce ya marca data-title). */
	.rn-cart__table thead { display: none; }
	.rn-cart__row {
		display: grid;
		grid-template-columns: 72px 1fr;
		gap: var(--sp-2) var(--sp-4);
		align-items: center;
		padding: var(--sp-4) 0;
		border-bottom: 1px solid var(--c-linea);
		position: relative;
	}
	.rn-cart__row td {
		border: none;
		padding: 0;
		text-align: left;
	}
	.rn-cart__row td.product-thumbnail {
		grid-row: 1 / span 4;
		grid-column: 1;
		width: auto;
	}
	.rn-cart__row td.product-name { grid-column: 2; }
	.rn-cart__row td.product-price,
	.rn-cart__row td.product-quantity,
	.rn-cart__row td.product-subtotal {
		grid-column: 2;
		text-align: left;
		display: flex;
		align-items: center;
		gap: var(--sp-2);
		white-space: normal;
	}
	.rn-cart__row td.product-price::before,
	.rn-cart__row td.product-subtotal::before {
		content: attr(data-title) ":";
		font-size: var(--fs-xs);
		color: var(--c-tinta-3);
	}
	.rn-cart__row td.product-quantity .rn-qty { margin-inline: 0; }
	.rn-cart__row td.product-remove {
		position: absolute;
		top: var(--sp-4);
		right: 0;
		width: auto;
	}
	.rn-cart__update { float: none; width: 100%; margin-top: var(--sp-3); }
	.rn-cart__coupon { display: flex; width: 100%; max-width: none; margin-right: 0; }
}

/* ============================ 7. ELEVACIÓN PREMIUM =================== */
/* Capa de refinamiento que carga al final (gana en la cascada): superficie del
   resumen elevada, números tabulares, total más jerárquico, notices on-brand
   sin franja lateral, miniaturas en el resumen y franja de confianza. */

/* --- Números tabulares: las cifras alinean en columna (detalle premium). --- */
.rn-cart__totals-table td,
.rn-cart__row td.product-price,
.rn-cart__row td.product-subtotal,
.rn-checkout__items td.product-total,
.rn-checkout__items tfoot td,
.rn-cart .amount,
.rn-checkout .amount {
	font-variant-numeric: tabular-nums;
	font-feature-settings: "tnum" 1;
}

/* --- Superficie del resumen del pedido (carrito + checkout): más aire y una
       sombra tenue tintada al verde de marca, no negro puro. --- */
.rn-cart__totals.rn-card,
.rn-checkout__review.rn-card {
	padding: clamp(1.5rem, 3vw, 2.15rem);
	background: color-mix(in srgb, #fff 50%, var(--c-crema));
	border: 1px solid var(--c-linea);
	border-radius: var(--r-lg);
	box-shadow: none;
}

/* --- Total con más jerarquía: tipografía display, más grande, con respiro. --- */
.rn-cart__totals-table .order-total th,
.rn-cart__totals-table .order-total td,
.rn-checkout__items tfoot .order-total th,
.rn-checkout__items tfoot .order-total td {
	padding-top: var(--sp-4);
	font-family: var(--font-display);
	font-size: 1.45rem;
	font-weight: 700;
	color: var(--c-verde-900);
	letter-spacing: -0.01em;
}

/* --- Franja de confianza (se inyecta por hook en inc/woocommerce.php). --- */
.rn-assurances {
	list-style: none;
	margin: var(--sp-4) 0 0;
	padding: var(--sp-4) 0 0;
	border-top: 1px solid var(--c-linea);
	display: grid;
	gap: var(--sp-3);
}
.rn-assurances li {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	font-size: var(--fs-sm);
	color: var(--c-tinta-2);
	line-height: 1.3;
}
.rn-assurances li svg {
	width: 19px;
	height: 19px;
	flex: none;
	color: var(--c-verde-600);
}

/* --- Ítems del resumen del checkout con miniatura: recibo premium. --- */
.rn-checkout__items td.product-name {
	display: flex;
	align-items: flex-start;
	gap: var(--sp-3);
}
.rn-checkout__item-media { flex: none; }
.rn-checkout__item-media img {
	display: block;
	width: 46px;
	height: 56px;
	object-fit: cover;
	border-radius: var(--r-sm);
	border: 1px solid var(--c-linea);
	background: var(--c-crema-2);
}
.rn-checkout__item-info {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
	min-width: 0;
}
.rn-checkout__item-name {
	font-family: var(--font-display);
	font-size: 1rem;
	font-weight: 500;
	color: var(--c-verde-900);
	line-height: 1.25;
}
.rn-checkout__items .rn-checkout__item-qty {
	display: inline-block;
	color: var(--c-tinta-3);
	font-weight: 500;
	font-size: var(--fs-xs);
}

/* --- Miniatura del carrito: plana, solo hairline (editorial flat). --- */
.rn-cart__row .product-thumbnail img {
	box-shadow: none;
}

/* --- Notices on-brand: borde completo + fondo tenue. Sin franja lateral
       (anti-patrón) y matando el border-top azul del core de WooCommerce. --- */
.woocommerce-cart .woocommerce-info,
.woocommerce-cart .woocommerce-message,
.woocommerce-cart .woocommerce-error,
.woocommerce-checkout .woocommerce-info,
.woocommerce-checkout .woocommerce-message,
.woocommerce-checkout .woocommerce-error,
.woocommerce-form-coupon-toggle .woocommerce-info {
	border: 1px solid var(--c-linea);
	border-radius: var(--r-md);
	background: var(--c-crema-2);
	color: var(--c-tinta);
	padding: var(--sp-4) var(--sp-5);
}
.woocommerce-cart .woocommerce-info::before,
.woocommerce-cart .woocommerce-message::before,
.woocommerce-cart .woocommerce-error::before,
.woocommerce-checkout .woocommerce-info::before,
.woocommerce-checkout .woocommerce-message::before,
.woocommerce-checkout .woocommerce-error::before,
.woocommerce-form-coupon-toggle .woocommerce-info::before {
	display: none;
}
.woocommerce-cart .woocommerce-message,
.woocommerce-checkout .woocommerce-message {
	border-color: color-mix(in srgb, var(--c-verde-600) 35%, var(--c-linea));
	background: var(--c-verde-50);
	color: var(--c-verde-900);
}
.woocommerce-cart .woocommerce-error,
.woocommerce-checkout .woocommerce-error {
	border-color: color-mix(in srgb, var(--c-error) 32%, var(--c-linea));
	background: color-mix(in srgb, var(--c-error) 7%, var(--c-crema));
	color: var(--c-error);
}

/* --- Cupón expandido: borde sólido fino, más prolijo que el dashed. --- */
.rn-checkout__coupon-form {
	border: 1px solid var(--c-linea);
	background: var(--c-crema-2);
}

/* --- Inputs: un toque más de respiro vertical (comodidad premium). --- */
.rn-checkout .input-text,
.rn-checkout textarea,
.rn-checkout select {
	padding: 0.85rem 1rem;
}

/* --- Botones del resumen: foco visible accesible. --- */
.rn-cart__proceed .button:focus-visible,
.rn-checkout__place-order .rn-btn:focus-visible {
	outline: 2px solid var(--c-verde-700);
	outline-offset: 3px;
}

/* ==========================================================================
   8. CAPA EDITORIAL MINIMALISTA (carrito + checkout)
   Última capa: gana en la cascada. Una sola superficie cálida, jerarquía
   tipográfica (Alegreya en nombres / Archivo tabular en cifras), hairlines
   finos, cero rejilla de planilla y cero sombras pesadas. Neutraliza el CSS
   core de WooCommerce (.shop_table) que pinta bordes verticales, banda de
   cabecera y filas rayadas en los totales.
   ========================================================================== */

/* --- 8.1 Matar la "planilla": tablas planas, solo hairlines horizontales ---
   El core de WooCommerce fuerza border-collapse:separate + bordes en cada
   celda (arriba/derecha) + fondo en las cabeceras. Se anula acotado a estas
   tablas (el !important pelea, legítimamente, contra el CSS del plugin). */
.rn-cart__table,
.rn-cart__totals-table,
.rn-checkout__items {
	border-collapse: collapse !important;
	border: 0 !important;
	background: transparent;
}
.rn-cart__table th, .rn-cart__table td,
.rn-cart__totals-table th, .rn-cart__totals-table td,
.rn-checkout__items th, .rn-checkout__items td {
	border-top: 0 !important;
	border-right: 0 !important;
	border-left: 0 !important;
	background: transparent !important;
}
/* Cabeceras de columna: sin banda de fondo, solo hairline inferior. */
.rn-cart__table thead th,
.rn-checkout__items thead th {
	border-bottom: 1px solid var(--c-linea) !important;
}

/* --- 8.2 Ítems del carrito: más aire y miniatura protagonista (editorial) ---
   Solo desktop (>=721px): en mobile la tabla se transforma en tarjetas
   apiladas (sección 6) con su propia grilla 72px + padding:0; no se pisa. */
@media (min-width: 721px) {
	.rn-cart__row td {
		padding-top: var(--sp-5);
		padding-bottom: var(--sp-5);
	}
	.rn-cart__row td.product-thumbnail { width: 96px; }
	.rn-cart__row .product-thumbnail img {
		width: 80px;
		height: 98px;
	}
}
.rn-cart__name { font-size: 1.1rem; }

/* --- 8.3 Métodos de pago: contenedor casi-blanco; adiós a la caja lila core ---
   El core pinta la descripción del gateway en gris-lila (#dfdcde) con un
   triangulito; choca con la paleta cálida. La pasamos a una nota verde de
   marca (alto contraste, on-brand) y matamos el triángulo. */
.rn-checkout__methods {
	background: color-mix(in srgb, #fff 50%, var(--c-crema));
	border-color: var(--c-linea);
}
.woocommerce-checkout #payment div.payment_box,
.rn-checkout__method-box {
	background: var(--c-verde-50) !important;
	color: var(--c-verde-900) !important;
	border: 1px solid color-mix(in srgb, var(--c-verde-600) 22%, var(--c-linea));
	border-radius: var(--r-md);
}
.woocommerce-checkout #payment div.payment_box::before,
.rn-checkout__method-box::before {
	display: none !important;
}
.rn-checkout__method-box p { color: var(--c-verde-900); }

/* --- 8.4 Cupón plegado del checkout: aviso liviano, no banner pesado --- */
.woocommerce-form-coupon-toggle .woocommerce-info {
	background: transparent;
	border: 1px dashed var(--c-linea);
	color: var(--c-tinta-2);
}

/* --- 8.5 Inputs del checkout: misma superficie casi-blanca que el recibo --- */
.rn-checkout .input-text,
.rn-checkout textarea,
.rn-checkout select {
	background: color-mix(in srgb, #fff 50%, var(--c-crema));
}

/* --- 8.6 Plugin Correo Argentino: su placeholder de cotización en el review ---
   El plugin inyecta .correo_argentino_review_order_section con una .shop_table
   que, sin código postal aún, queda vacía. El core de WooCommerce la pinta con
   borde/redondeado y deja una "caja vacía" fea bajo el Total. Se le quita el
   marco: sin cotización queda invisible; al cotizar, el plugin la llena y se ve
   integrada. (Si más adelante se afina la integración de Correo, se estiliza su
   contenido lleno acá.) */
.correo_argentino_review_order_section table,
.correo_argentino_review_order_section th,
.correo_argentino_review_order_section td {
	border: 0 !important;
	background: transparent !important;
}

/* --- 8.7 Acciones del carrito: botones de una sola línea (sin wrap del CTA) --- */
.rn-cart__coupon .rn-btn,
.rn-cart__update {
	white-space: nowrap;
	flex: none;
}
.rn-cart__coupon-input { flex: 1 1 auto; }

/* ==========================================================================
   9. CAPA PREMIUM EDITORIAL CÁLIDA — Zarevo
   Gana en cascada sobre los bloques 7 y 8. Carrito + Checkout. Light-only.
   El salto premium viene de oficio tipográfico (cifras lining+tabular,
   Total como pieza), del recibo como "hoja sellada" (doble regla superior) y
   de micro-gestos de marca (tacho que inclina la tapa, acento terracota como
   único hilo cálido), no de sombras ni gradientes.
   ========================================================================== */

/* --- 9.0 DINERO: una sola verdad. Toda cifra en Archivo (sans = lining
       nativo) + lining-nums tabular-nums forzados. Mata el oldstyle de
       Alegreya que dejaba el bloque 7 (solo forzaba tnum, nunca lnum). --- */
.rn-cart .amount,
.rn-checkout .amount,
.rn-cart__row td.product-price,
.rn-cart__row td.product-subtotal,
.rn-cart__totals-table td,
.rn-checkout__items td.product-total,
.rn-checkout__items tfoot td,
.rn-checkout__item-qty,
.rn-shipbar__msg .amount {
	font-family: var(--font-sans);
	font-variant-numeric: lining-nums tabular-nums;
	font-feature-settings: "lnum" 1, "tnum" 1;
	font-style: normal;
}

/* --- 9.1 RECIBO: card limpia. Superficie casi-blanca + hairline UNIFORME de
       1px. (Antes tenía una regla verde de 2px arriba que chocaba con las
       esquinas redondeadas y se veía como un corte/bug; eliminada.) --- */
.rn-cart__totals.rn-card,
.rn-checkout__review.rn-card {
	/* sticky (no relative): el card trae position:sticky + top de base para
	   seguir el scroll; con relative ese top lo empujaba 92px y lo desalineaba. */
	position: sticky;
	background: color-mix(in srgb, #fff 50%, var(--c-crema));
	border: 1px solid var(--c-linea);
	border-radius: var(--r-lg);
	box-shadow: none;
	padding: clamp(1.6rem, 3vw, 2.35rem);
}

/* --- 9.2 Encabezados de columna: versalita sans calma, tracking abierto. --- */
.rn-cart__table thead th,
.rn-checkout__items thead th {
	font-family: var(--font-sans);
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--c-tinta-3);
}

/* --- 9.3 Filas del carrito: aire, hairline de imprenta, hover cálido.
       Solo desktop (>=721px): en mobile manda la grilla de tarjetas (sec 6). --- */
@media (min-width: 721px) {
	.rn-cart__row td {
		border-bottom: 1px solid var(--c-linea);
	}
	.rn-cart__row { transition: background var(--tr) var(--ease-out-expo); }
	.rn-cart__row:hover {
		background: color-mix(in srgb, var(--c-verde-50) 55%, transparent);
	}
	.rn-cart__row .product-thumbnail img {
		border: 1px solid var(--c-arena-2);
		transition: transform var(--tr) var(--ease-out-expo);
	}
	.rn-cart__row:hover .product-thumbnail img { transform: scale(1.015); }
}
.rn-cart__name { color: var(--c-verde-900); transition: color var(--tr) var(--ease-out-expo); }
.rn-cart__name:hover { color: var(--c-cuero-700); }
/* Jerarquía por peso: precio unitario muted, subtotal en tinta plena. */
.rn-cart__row td.product-price { color: var(--c-tinta-2); }
.rn-cart__row td.product-subtotal { color: var(--c-tinta); font-weight: 600; }
/* $ atenuado en líneas de cuerpo (el número manda). No rompe tabular. */
.rn-cart .woocommerce-Price-currencySymbol,
.rn-checkout .woocommerce-Price-currencySymbol {
	color: var(--c-tinta-3);
	font-weight: inherit;
	margin-right: 0.1em;
}

/* --- 9.4 BOTÓN QUITAR = TACHO. Reposo casi invisible, hover terracota,
       la tapa se inclina apenas (micro-gesto de marca, solo transform). --- */
.rn-cart__remove {
	display: grid;
	place-items: center;
	width: 32px;
	height: 32px;
	border-radius: var(--r-pill);
	color: var(--c-tinta-3);
	background: transparent;
	border: 1px solid transparent;
	transition:
		color var(--tr) var(--ease-out-expo),
		background-color var(--tr) var(--ease-out-expo),
		border-color var(--tr) var(--ease-out-expo),
		transform var(--tr) var(--ease-out-expo);
}
.rn-cart__remove svg {
	width: 17px;
	height: 17px;
	display: block;
	transform-origin: 12px 7px; /* labio de la tapa */
	transition: transform var(--tr) var(--ease-out-expo);
}
.rn-cart__remove:hover,
.rn-cart__remove:focus-visible {
	color: var(--c-acento-700);
	background: var(--c-acento-50);
	border-color: color-mix(in srgb, var(--c-acento) 24%, transparent);
}
.rn-cart__remove:hover svg { transform: rotate(-8deg); }
.rn-cart__remove:active { transform: scale(0.94); }
.rn-cart__remove:focus-visible {
	outline: 2px solid var(--c-acento-600);
	outline-offset: 2px;
}

/* --- 9.5 Tabla de totales (carrito): etiquetas discretas vs Total héroe. --- */
.rn-cart__totals-table th { color: var(--c-tinta-2); font-weight: 500; }
.rn-cart__totals-table tr.cart-subtotal th,
.rn-cart__totals-table tr.cart-subtotal td {
	font-size: var(--fs-sm);
}
/* TOTAL carrito: etiqueta en versalita fina, cifra grande sans verde-900.
   Vence al bloque 7 (Alegreya 1.45rem) con misma/mayor especificidad. */
.rn-cart__totals-table .order-total th {
	font-family: var(--font-sans);
	font-size: var(--fs-sm);
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--c-verde-800);
	vertical-align: baseline;
}
.rn-cart__totals-table .order-total td,
.rn-cart__totals-table .order-total td .amount {
	font-family: var(--font-sans);
	font-variant-numeric: lining-nums tabular-nums;
	font-feature-settings: "lnum" 1, "tnum" 1;
	font-size: 1.75rem;
	font-weight: 700;
	line-height: 1.05;
	letter-spacing: -0.015em;
	color: var(--c-verde-900);
}
/* Subrayado terracota fino bajo el número del Total (único hilo cálido). */
.rn-cart__totals-table .order-total td .amount {
	display: inline-block;
	padding-bottom: 0.16em;
	box-shadow: inset 0 -2px 0 0 var(--c-acento);
}
/* $ del Total: alzado, más chico, terracota (detalle de papelería fina). */
.rn-cart__totals-table .order-total .woocommerce-Price-currencySymbol {
	font-size: 0.6em;
	font-weight: 600;
	color: var(--c-acento-700);
	vertical-align: 0.4em;
	margin-right: 0.1em;
}

/* --- 9.6 TOTAL del checkout (tfoot del review): misma pieza tipográfica. --- */
.rn-checkout__items tfoot .order-total th {
	font-family: var(--font-sans);
	font-size: var(--fs-sm);
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--c-verde-800);
	vertical-align: baseline;
}
.rn-checkout__items tfoot .order-total td,
.rn-checkout__items tfoot .order-total td .amount {
	font-family: var(--font-sans);
	font-variant-numeric: lining-nums tabular-nums;
	font-feature-settings: "lnum" 1, "tnum" 1;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.05;
	letter-spacing: -0.015em;
	color: var(--c-verde-900);
}
.rn-checkout__items tfoot .order-total td .amount {
	display: inline-block;
	padding-bottom: 0.16em;
	box-shadow: inset 0 -2px 0 0 var(--c-acento);
}
.rn-checkout__items tfoot .order-total .woocommerce-Price-currencySymbol {
	font-size: 0.6em;
	font-weight: 600;
	color: var(--c-acento-700);
	vertical-align: 0.4em;
	margin-right: 0.1em;
}

/* --- 9.7 Barra de envío gratis: fina, precisa (el fill usa scaleX inline). --- */
.rn-shipbar { margin-bottom: var(--sp-5); }
.rn-shipbar__msg {
	font-size: var(--fs-sm);
	color: var(--c-tinta-2);
	margin: 0 0 var(--sp-3);
}
.rn-shipbar__msg strong { color: var(--c-verde-700); font-weight: 600; }
.rn-shipbar__track {
	height: 5px;
	border-radius: var(--r-pill);
	background: var(--c-crema-2);
	overflow: hidden;
}
.rn-shipbar__fill {
	display: block;
	height: 100%;
	border-radius: var(--r-pill);
	background: var(--c-verde-600);
	transform-origin: left center;
	transition: transform 600ms var(--ease-out-expo);
}

/* --- 9.8 CTA: pill verde protagonista, micro-empuje (selectores REALES). --- */
.rn-cart__proceed .checkout-button,
.rn-cart__proceed .button,
.rn-checkout__place-order .rn-btn {
	box-shadow: 0 1px 0 0 color-mix(in srgb, var(--c-verde-900) 30%, transparent);
	transition:
		background var(--tr) var(--ease-out-expo),
		transform var(--tr) var(--ease-out-expo),
		box-shadow var(--tr) var(--ease-out-expo);
}
.rn-cart__proceed .checkout-button:hover,
.rn-cart__proceed .button:hover,
.rn-checkout__place-order .rn-btn:hover {
	background: var(--c-verde-700);
	transform: translateY(-1px);
	box-shadow: 0 8px 20px -10px color-mix(in srgb, var(--c-verde-900) 60%, transparent);
}
.rn-cart__proceed .checkout-button:active,
.rn-cart__proceed .button:active,
.rn-checkout__place-order .rn-btn:active { transform: translateY(0); }

/* --- 9.9 Review del checkout: miniatura con marco cálido, nombre serif. --- */
.rn-checkout__item-media img { border: 1px solid var(--c-arena-2); }
.rn-checkout__item-name { color: var(--c-verde-900); }
.rn-checkout__item-qty { color: var(--c-tinta-3); }

/* --- 9.10 Tira de confianza: iconos verde fino. --- */
.rn-assurances li svg { color: var(--c-verde-600); }

/* --- 9.11 Accesibilidad de movimiento: sin micro-gestos si se pide reduce. --- */
@media (prefers-reduced-motion: reduce) {
	.rn-cart__row,
	.rn-cart__row .product-thumbnail img,
	.rn-cart__name,
	.rn-cart__remove,
	.rn-cart__remove svg,
	.rn-shipbar__fill,
	.rn-cart__proceed .checkout-button,
	.rn-cart__proceed .button,
	.rn-checkout__place-order .rn-btn {
		transition: none !important;
		animation: none !important;
	}
	.rn-cart__remove:hover svg,
	.rn-cart__remove:active { transform: none; }
}

/* --- 9.12 Carrito con actualización automática ---
   El JS (initCartAjax) marca <body class="rn-cart-ajax"> cuando hay JS y
   re-postea el carrito al cambiar la cantidad. Entonces el botón "Actualizar
   carrito" sobra: se oculta. Sin JS, body no lleva la clase y el botón queda
   visible como respaldo funcional. Mientras recalcula, se atenúa el bloque. */
body.rn-cart-ajax .rn-cart__update { display: none; }
.rn-cart.is-updating { pointer-events: none; }
.rn-cart.is-updating .rn-cart__totals,
.rn-cart.is-updating .rn-cart__table tbody {
	opacity: 0.55;
	transition: opacity 0.12s var(--ease-out-expo);
}
@media (prefers-reduced-motion: reduce) {
	.rn-cart.is-updating .rn-cart__totals,
	.rn-cart.is-updating .rn-cart__table tbody { transition: none; }
}

/* --- 9.13 Bloque de pago: fuera el fondo gris-lila del core de WooCommerce ---
   El #payment del core trae background #ebe9eb (gris-violáceo) + un triangulito
   que no pega con la paleta cálida. Lo dejamos transparente (la card del recibo
   ya da el fondo). También damos tamaño al ícono de banco del método. */
.woocommerce-checkout #payment,
.woocommerce-checkout #payment .place-order {
	background: transparent !important;
}
.woocommerce-checkout #payment::before {
	display: none !important;
}
.woocommerce-checkout #payment .place-order {
	padding: 0 !important;
}
/* Ícono de banco (SVG) del método Transferencia bancaria, a la derecha del label. */
.rn-checkout__method-icon svg.rn-bank-icon {
	width: 22px;
	height: 22px;
	color: var(--c-verde-700);
}
