/* ==========================================================================
   RN.MATES — 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: block;
}
.rn-cart__form { margin-bottom: clamp(1.5rem, 4vw, 2.5rem); }

.rn-cart__collaterals {
	display: grid;
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: start;
}
@media (min-width: 980px) {
	.rn-cart__collaterals {
		grid-template-columns: 1fr 360px;
	}
	/* Si hay cross-sells, ocupan la columna izquierda; los totales la derecha. */
	.rn-cart__crosssells { grid-column: 1; grid-row: 1; }
	.rn-cart__totals { grid-column: 2; grid-row: 1; }
	/* Si NO hay cross-sells, los totales igual quedan a la derecha. */
	.rn-cart__collaterals > .rn-cart__totals:only-child { grid-column: 2; }
}

/* --- Tabla de ítems --- */
.rn-cart__table {
	width: 100%;
	border-collapse: collapse;
	margin: 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);
}
.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; }

/* 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) ================== */
.rn-thankyou {
	max-width: var(--container-narrow);
	margin-inline: auto;
}
.rn-thankyou__head {
	text-align: center;
	margin-bottom: clamp(1.5rem, 4vw, 2.5rem);
}
.rn-thankyou__check {
	display: grid;
	place-items: center;
	width: 72px;
	height: 72px;
	margin: 0 auto var(--sp-4);
	border-radius: var(--r-pill);
	background: var(--c-verde-50);
	color: var(--c-verde-600);
}
.rn-thankyou__check svg { width: 36px; height: 36px; }
.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);
	color: var(--c-verde-900);
	margin: 0;
}
.rn-thankyou__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sp-3);
	justify-content: center;
	margin-top: var(--sp-4);
}

/* Resumen del pedido (overview). */
.rn-thankyou__overview {
	list-style: none;
	display: grid;
	gap: var(--sp-4);
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	margin: 0 0 clamp(1.5rem, 4vw, 2.5rem);
	padding: var(--sp-5);
	border: 1px solid var(--c-linea);
	border-radius: var(--r-lg);
	background: var(--c-crema);
}
.rn-thankyou__overview li {
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
	font-size: var(--fs-xs);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--c-tinta-3);
}
.rn-thankyou__overview li strong {
	font-size: var(--fs-body);
	font-weight: 500;
	letter-spacing: 0;
	text-transform: none;
	color: var(--c-verde-900);
}

/* Detalle del pedido (woocommerce_order_details: tabla + direcciones). */
.rn-thankyou .woocommerce-order-details,
.rn-thankyou .woocommerce-customer-details {
	margin-top: clamp(1.5rem, 4vw, 2.5rem);
}
.rn-thankyou .woocommerce-order-details__title,
.rn-thankyou .woocommerce-column__title {
	font-size: var(--fs-h3);
	margin-bottom: var(--sp-4);
}
.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;
}
.rn-thankyou .woocommerce-table--order-details th,
.rn-thankyou .woocommerce-table--order-details td,
.rn-thankyou table.shop_table th,
.rn-thankyou table.shop_table td {
	padding: var(--sp-3) var(--sp-4);
	text-align: left;
	border-bottom: 1px solid var(--c-linea);
	font-size: var(--fs-sm);
}
.rn-thankyou .woocommerce-table--order-details td.product-total,
.rn-thankyou .woocommerce-table--order-details th:last-child { 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 td { text-align: right; }

.rn-thankyou .woocommerce-customer-details .addresses {
	display: grid;
	gap: var(--sp-5);
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.rn-thankyou .woocommerce-customer-details address {
	font-style: normal;
	padding: var(--sp-4);
	border: 1px solid var(--c-linea);
	border-radius: var(--r-md);
	background: var(--c-crema);
	font-size: var(--fs-sm);
	color: var(--c-tinta-2);
	line-height: var(--lh-body);
}

.rn-thankyou__cta {
	text-align: center;
	margin-top: clamp(1.5rem, 4vw, 2.5rem);
}

/* ============================ 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-left: 3px solid var(--c-verde-600);
	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-left-color: var(--c-error);
	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-left-color: var(--c-info);
	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; }
}
