/* ==========================================================================
   CART PAGE — PadelProfi
   Paleta y tokens identicos al resto del sitio (checkout, product-detail).
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Variables CSS (espejo de checkout.css para uso autonomo en esta pagina)
   -------------------------------------------------------------------------- */
:root {
	--pp-orange:       #FE6100;
	--pp-orange-hover: #e55a00;
	--pp-orange-light: #fff4ee;
	--pp-orange-grad:  linear-gradient(135deg, #FF6000 0%, #FE6100 100%);
	--pp-price:        #BF0019;
	--pp-black:        #333333;
	--pp-gray-dark:    #555555;
	--pp-gray:         #888888;
	--pp-gray-light:   #f7f7f7;
	--pp-gray-border:  #e5e5e5;
	--pp-white:        #ffffff;
	--pp-green:        #2e7d32;
	--pp-radius:       12px;
	--pp-radius-sm:    8px;
	--pp-shadow:       0 2px 16px rgba(0,0,0,.07);
	--pp-shadow-md:    0 4px 24px rgba(254,97,0,.18);
	--pp-transition:   0.2s ease;
	--pp-font:         'Open Sans', sans-serif;
}

/* --------------------------------------------------------------------------
   2. Layout raiz: dos columnas
   -------------------------------------------------------------------------- */

/* Eliminar el espacio superior que añade el tema / Elementor al wrapper de pagina */
.pp-cart-page-wrap,
.page-template-template-cart .site-content,
.page-template-template-cart #content,
.page-template-template-cart .content-area,
.page-template-template-cart article.page,
.page-template-template-cart .entry-content,
.woocommerce-cart .woocommerce {
	padding-top: 0 !important;
	margin-top: 0 !important;
}

.pp-cart-page-wrap {
	padding: 0;
}

/*
 * Rompe el contenedor de Elementor/WC para usar el ancho
 * completo del viewport, con max-width propio.
 * Tecnica: width:100vw + margin-left negativo compensa el offset del padre.
 * Requiere que ningun ancestro tenga overflow:hidden.
 */
.pp-cart-page {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	box-sizing: border-box;
	padding: 28px max(20px, calc(50vw - 580px)) 60px;
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: 32px;
	align-items: start;
	font-family: var(--pp-font);
}

/* --------------------------------------------------------------------------
   3. Header del carrito
   -------------------------------------------------------------------------- */
.pp-cart-header {
	display: flex;
	align-items: baseline;
	gap: 10px;
	margin-bottom: 16px;
}

.pp-cart-title {
	font-size: 26px;
	font-weight: 800;
	color: var(--pp-black);
	margin: 0;
	line-height: 1.1;
}

.pp-cart-count,
#pp-cart-count {
	font-size: 14px;
	color: var(--pp-gray);
	font-weight: 500;
}

/* --------------------------------------------------------------------------
   4. Carrito vacio
   -------------------------------------------------------------------------- */
.pp-cart-empty {
	grid-column: 1 / -1;
	text-align: center;
	padding: 80px 20px;
}

.pp-cart-empty p { color: var(--pp-gray); margin: 0 0 24px; }

.pp-cart-empty .button,
.pp-cart-empty a.button {
	display: inline-block;
	padding: 13px 32px;
	background: var(--pp-orange-grad);
	color: var(--pp-white) !important;
	border-radius: var(--pp-radius-sm);
	font-weight: 700;
	text-decoration: none;
	font-size: 15px;
	box-shadow: var(--pp-shadow-md);
	transition: all var(--pp-transition);
}

.pp-cart-empty .button:hover,
.pp-cart-empty a.button:hover {
	background: linear-gradient(135deg, #e55a00 0%, #d95300 100%);
}

/* --------------------------------------------------------------------------
   5. Items del carrito
   -------------------------------------------------------------------------- */

/* min-width:0 es critico: sin el, las columnas del grid no limitan a sus hijos */
.pp-cart-main { min-width: 0; }

.pp-cart-item {
	background: var(--pp-white);
	border: 1px solid var(--pp-gray-border);
	border-radius: var(--pp-radius);
	margin-bottom: 12px;
	box-shadow: var(--pp-shadow);
	transition: box-shadow var(--pp-transition);
}

.pp-cart-item:hover {
	box-shadow: 0 4px 20px rgba(0,0,0,.10);
}

.pp-cart-item__main {
	display: flex;
	gap: 16px;
	padding: 18px;
	align-items: flex-start;
}

/* Imagen */
.pp-cart-item__imglink { flex-shrink: 0; display: block; }

.pp-cart-item__img {
	width: 100px;
	height: 100px;
	object-fit: contain;
	border: 1px solid var(--pp-gray-border);
	border-radius: var(--pp-radius-sm);
	background: var(--pp-gray-light);
	padding: 6px;
	display: block;
}

/* Info central */
.pp-cart-item__info {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.pp-cart-item__name {
	font-size: 14px;
	font-weight: 600;
	color: var(--pp-black);
	text-decoration: none;
	line-height: 1.4;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	transition: color var(--pp-transition);
}

.pp-cart-item__name:hover { color: var(--pp-orange); }

/* Meta: atributos de variacion o descripcion corta */
.pp-cart-item__meta {
	font-size: 12px;
	color: var(--pp-gray);
	line-height: 1.5;
	margin: 0;
}

.pp-cart-item__meta .pp-meta-label { color: var(--pp-gray); }
.pp-cart-item__meta .pp-meta-val   { color: var(--pp-gray-dark); font-weight: 600; }
.pp-cart-item__meta .pp-meta-desc  { color: var(--pp-gray); }

/* Precio */
.pp-cart-item__price-row { display: flex; align-items: center; gap: 8px; }

.pp-cart-item__price {
	font-size: 18px;
	font-weight: 700;
	color: var(--pp-price);
}

.pp-cart-item__price del {
	font-size: 13px;
	color: var(--pp-gray);
	font-weight: 400;
}

.pp-cart-item__price.pp-sale del { margin-right: 4px; }

/* Qty stepper — pill, igual que checkout */
.pp-cqty {
	display: inline-flex;
	align-items: center;
	border: 1.5px solid var(--pp-gray-border);
	border-radius: 50px;
	overflow: hidden;
	align-self: flex-start;
	margin-top: 4px;
	background: var(--pp-white);
}

.pp-cqty-btn {
	width: 32px;
	height: 32px;
	background: none;
	border: none;
	font-size: 18px;
	font-weight: 400;
	cursor: pointer;
	color: var(--pp-black);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background var(--pp-transition), color var(--pp-transition);
	line-height: 1;
}

.pp-cqty-btn:hover:not(:disabled) { background: var(--pp-orange-light); color: var(--pp-orange); }
.pp-cqty-btn:disabled { opacity: .35; cursor: default; }

.pp-cqty-val {
	min-width: 30px;
	text-align: center;
	font-size: 14px;
	font-weight: 700;
	color: var(--pp-black);
	border-left: 1.5px solid var(--pp-gray-border);
	border-right: 1.5px solid var(--pp-gray-border);
	height: 32px;
	line-height: 32px;
}

/* Columna derecha: precio total + eliminar */
.pp-cart-item__right {
	flex-shrink: 0;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 8px;
	padding-top: 2px;
}

.pp-cart-item__remove {
	background: none;
	border: none;
	cursor: pointer;
	color: var(--pp-gray-border);
	padding: 4px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	width: 26px;
	height: 26px;
	transition: color var(--pp-transition), background var(--pp-transition);
}

.pp-cart-item__remove:hover { color: var(--pp-price); background: #fff0f0; }

.pp-cart-item__line-price {
	font-size: 16px;
	font-weight: 700;
	color: var(--pp-black);
	white-space: nowrap;
}

/* --------------------------------------------------------------------------
   6. Cross-sells genericos — estilo MediaMarkt
   -------------------------------------------------------------------------- */
.pp-cart-cs {
	margin-top: 10px;
	padding: 20px 20px 16px;
	background: var(--pp-white);
	border: 1px solid var(--pp-gray-border);
	border-radius: var(--pp-radius);
	box-shadow: var(--pp-shadow);
}


.pp-cart-cs__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 16px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--pp-gray-border);
}

.pp-cart-cs__title {
	font-size: 14px;
	font-weight: 700;
	color: var(--pp-black);
	margin: 0;
	text-transform: uppercase;
	letter-spacing: .04em;
}

/* Flechas de navegacion */
.pp-cart-cs__arrows {
	display: flex;
	gap: 6px;
}

.pp-cs-arrow {
	width: 32px;
	height: 32px;
	border: 1.5px solid var(--pp-gray-border);
	border-radius: var(--pp-radius-sm);
	background: var(--pp-white);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--pp-gray-dark);
	transition: border-color var(--pp-transition), background var(--pp-transition), color var(--pp-transition);
	flex-shrink: 0;
}

.pp-cs-arrow:hover { border-color: var(--pp-black); background: var(--pp-black); color: var(--pp-white); }
.pp-cs-arrow:disabled { opacity: .3; cursor: default; }

/* Lista scrollable */
.pp-cart-cs__list {
	display: flex;
	gap: 12px;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	scroll-behavior: smooth;
	scrollbar-width: none;
	padding-bottom: 2px;
}

.pp-cart-cs__list::-webkit-scrollbar { display: none; }

/* Tarjeta */
.pp-cs-card {
	flex: 0 0 185px;
	background: var(--pp-white);
	border: 1px solid var(--pp-gray-border);
	border-radius: var(--pp-radius-sm);
	display: flex;
	flex-direction: column;
	overflow: hidden;
	transition: box-shadow var(--pp-transition), border-color var(--pp-transition);
	cursor: default;
}

.pp-cs-card:hover {
	border-color: #bbb;
	box-shadow: 0 4px 16px rgba(0,0,0,.10);
}

/* Zona imagen */
.pp-cs-card__img-wrap {
	position: relative;
	background: var(--pp-gray-light);
	padding: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 150px;
	flex-shrink: 0;
}

.pp-cs-card__img {
	width: 120px;
	height: 120px;
	object-fit: contain;
}

/* Badge de descuento */
.pp-cs-card__badge {
	position: absolute;
	top: 8px;
	left: 8px;
	background: var(--pp-price);
	color: var(--pp-white);
	font-size: 11px;
	font-weight: 800;
	padding: 3px 7px;
	border-radius: 3px;
	line-height: 1.3;
}

/* Cuerpo de la tarjeta */
.pp-cs-card__body {
	padding: 10px 12px;
	display: flex;
	flex-direction: column;
	gap: 5px;
	flex: 1;
}

/* Rating */
.pp-cs-card__rating {
	display: flex;
	align-items: center;
	gap: 5px;
}

/* Estrellas */
.pp-cs-stars {
	display: inline-block;
	position: relative;
	width: 70px;
	height: 12px;
	flex-shrink: 0;
}

.pp-cs-stars::before,
.pp-cs-stars::after {
	content: '&#9733;&#9733;&#9733;&#9733;&#9733;';
	content: '★★★★★';
	position: absolute;
	top: 0;
	left: 0;
	font-size: 12px;
	line-height: 1;
	letter-spacing: 1px;
}

.pp-cs-stars::before { color: var(--pp-gray-border); }

.pp-cs-stars::after {
	color: #FFA700;
	width: var(--r, 0%);
	overflow: hidden;
	white-space: nowrap;
}

.pp-cs-card__rcount {
	font-size: 11px;
	color: var(--pp-gray);
}

/* Nombre */
.pp-cs-card__name {
	font-size: 12px;
	font-weight: 600;
	color: var(--pp-black);
	line-height: 1.4;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Precios */
.pp-cs-card__pricing {
	display: flex;
	flex-direction: column;
	gap: 2px;
	margin-top: 2px;
}

.pp-cs-card__reg {
	font-size: 11px;
	color: var(--pp-gray);
	font-weight: 400;
	text-decoration: line-through;
}

.pp-cs-card__price {
	font-size: 17px;
	font-weight: 800;
	color: var(--pp-price);
	display: block;
}

.pp-cs-card__price--sale { color: var(--pp-price); }

/* Boton "In den Warenkorb" */
.pp-cs-card__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	width: 100%;
	padding: 10px 8px;
	background: var(--pp-black);
	color: var(--pp-white);
	border: none;
	font-size: 11px;
	font-weight: 700;
	cursor: pointer;
	font-family: var(--pp-font);
	transition: background var(--pp-transition);
	margin-top: auto;
	flex-shrink: 0;
}

.pp-cs-card__btn:hover    { background: var(--pp-orange); }
.pp-cs-card__btn.pp-added { background: var(--pp-green); }
.pp-cs-card__btn:disabled { opacity: .5; cursor: wait; }

/* --------------------------------------------------------------------------
   7. Sidebar / Resumen
   -------------------------------------------------------------------------- */
.pp-cart-sidebar {
	position: sticky;
	top: 100px;
}

.pp-cart-summary {
	background: var(--pp-white);
	border: 1px solid var(--pp-gray-border);
	border-radius: var(--pp-radius);
	padding: 22px;
	box-shadow: 0 4px 20px rgba(0,0,0,.07);
}

.pp-summary-title {
	font-size: 14px;
	font-weight: 700;
	color: var(--pp-black);
	margin: 0 0 18px;
	padding-bottom: 14px;
	border-bottom: 2px solid var(--pp-gray-border);
	text-transform: uppercase;
	letter-spacing: .04em;
}

/* Filas del resumen */
.pp-summary-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 7px 0;
	font-size: 14px;
	color: var(--pp-black);
	border-bottom: 1px solid var(--pp-gray-border);
}

.pp-summary-row:last-of-type { border-bottom: none; }

.pp-summary-total {
	font-size: 20px;
	font-weight: 800;
	color: var(--pp-black);
	padding: 14px 0 8px;
	border-top: 2px solid var(--pp-gray-border) !important;
	border-bottom: none !important;
	margin-top: 4px;
}

.pp-summary-total span:last-child { color: var(--pp-price); }

.pp-summary-tax {
	font-size: 11px;
	color: var(--pp-gray);
	margin: 0 0 4px;
	text-align: right;
}

/* Cupon aplicado */
.pp-summary-coupon {
	background: #eaf6ed;
	border-radius: var(--pp-radius-sm);
	padding: 5px 10px;
	font-size: 12px;
	font-weight: 600;
	color: var(--pp-green);
	gap: 6px;
	flex-wrap: wrap;
}

.pp-remove-coupon {
	background: none;
	border: none;
	color: var(--pp-gray);
	cursor: pointer;
	font-size: 15px;
	padding: 0 2px;
	line-height: 1;
	margin-left: auto;
	transition: color var(--pp-transition);
}

.pp-remove-coupon:hover { color: var(--pp-price); }

.pp-free-shipping { color: var(--pp-green); font-weight: 600; }

/* Boton Zur Kasse */
.pp-checkout-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	box-sizing: border-box;
	padding: 15px 20px;
	background: var(--pp-orange-grad);
	color: var(--pp-white) !important;
	border: none;
	border-radius: 10px;
	font-size: 16px;
	font-weight: 700;
	cursor: pointer;
	font-family: var(--pp-font);
	text-decoration: none !important;
	margin: 18px 0 10px;
	transition: all var(--pp-transition);
	letter-spacing: .01em;
	box-shadow: var(--pp-shadow-md);
}

.pp-checkout-btn:hover {
	background: linear-gradient(135deg, #e55a00 0%, #d95300 100%);
	box-shadow: 0 6px 28px rgba(254,97,0,.35);
	transform: translateY(-1px);
	color: var(--pp-white) !important;
}

/* Texto seguro */
.pp-summary-secure {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 5px;
	font-size: 11px;
	color: var(--pp-gray);
	margin: 0 0 18px;
}

/* Form cupon */
.pp-coupon-wrap {
	display: flex;
	gap: 8px;
	margin-top: 16px;
	border-top: 1px solid var(--pp-gray-border);
	padding-top: 16px;
}

#pp-coupon-input {
	flex: 1;
	padding: 9px 12px;
	border: 1.5px solid var(--pp-gray-border);
	border-radius: var(--pp-radius-sm);
	font-size: 13px;
	font-family: var(--pp-font);
	color: var(--pp-black);
	outline: none;
	transition: border-color var(--pp-transition), box-shadow var(--pp-transition);
	min-width: 0;
	background: var(--pp-white);
}

#pp-coupon-input:focus {
	border-color: var(--pp-orange);
	box-shadow: 0 0 0 3px rgba(254,97,0,.10);
}

#pp-coupon-apply {
	padding: 9px 14px;
	background: var(--pp-white);
	color: var(--pp-orange);
	border: 1.5px solid var(--pp-orange);
	border-radius: var(--pp-radius-sm);
	font-size: 13px;
	font-weight: 700;
	cursor: pointer;
	font-family: var(--pp-font);
	transition: all var(--pp-transition);
	white-space: nowrap;
	flex-shrink: 0;
}

#pp-coupon-apply:hover { background: var(--pp-orange); color: var(--pp-white); }
#pp-coupon-apply:disabled { opacity: .6; cursor: default; }

#pp-coupon-msg {
	font-size: 12px;
	margin: 6px 0 0;
	min-height: 16px;
}

.pp-coupon-msg--ok  { color: var(--pp-green); }
.pp-coupon-msg--err { color: var(--pp-price); }

/* --------------------------------------------------------------------------
   8. Loading state
   -------------------------------------------------------------------------- */
.pp-cart-loading { opacity: .5; pointer-events: none; }

/* --------------------------------------------------------------------------
   9. Footer móvil fijo (oculto por defecto — se muestra < 680px via media)
   -------------------------------------------------------------------------- */
.pp-mobile-footer { display: none; }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

/* Tablet ancha (< 1100px) */
@media (max-width: 1100px) {
	.pp-cart-page {
		grid-template-columns: minmax(0, 1fr) 280px;
		gap: 24px;
		padding: 24px max(16px, calc(50vw - 530px)) 50px;
	}
}

/* Tablet (900-1100px ya cubierta arriba); entre 768px y 900px
   el sidebar sigue visible en la columna derecha del grid */

/* Movil (< 768px): sidebar oculto, footer fijo, items compactos */
@media (max-width: 768px) {
	/* Ocultar sidebar — reemplazado por footer fijo */
	.pp-cart-sidebar { display: none !important; }

	/* Resetear el order:-1 del breakpoint de 900px */
	.pp-cart-page {
		grid-template-columns: 1fr;
		gap: 12px;
		padding: 14px 12px 0; /* espacio para el footer fijo */
	}

	/* Item: imagen mas pequena */
	.pp-cart-item__main {
		padding: 14px 12px;
		gap: 12px;
	}

	.pp-cart-item__img {
		width: 80px;
		height: 80px;
	}

	.pp-cart-item__name { font-size: 13px; }
	.pp-cart-item__price { font-size: 16px; }
	.pp-cart-item__line-price { font-size: 15px; }

	/* Cross-sells */
	.pp-cart-cs { padding: 14px 12px; }
	.pp-cs-card { flex: 0 0 160px; }
	.pp-cs-card__img-wrap { height: 130px; }
	.pp-cs-card__img { width: 100px; height: 100px; }

	/* Ocultar boton scroll-to-top del tema: solapa con el footer movil */
	.scroll-top-to,
	#scrollTopBtn { display: none !important; }

	/* X de eliminar: absolute en esquina superior derecha */
	.pp-cart-item__main { position: relative; }

	.pp-cart-item__remove {
		position: absolute;
		top: 8px;
		right: 8px;
		width: 16px;
		height: 16px;
		border-radius: 50%;
		background: none;
		color: var(--pp-gray);
		padding: 0;
	}

	/* Info: padding derecho para que el nombre no se solape con la X */
	.pp-cart-item__info { padding-right: 32px; }

	/* Columna derecha: solo muestra el precio total (la X ya es absolute) */
	.pp-cart-item__right {
		flex-direction: column;
		align-items: flex-end;
		gap: 4px;
		padding-top: 0;
	}

	/* ── Footer movil fijo ── */
	.pp-mobile-footer {
		display: flex;
		flex-direction: column;
		position: fixed;
		bottom: 0;
		left: 0;
		right: 0;
		z-index: 9999;
		background: var(--pp-white);
		border-top: 2px solid var(--pp-gray-border);
		box-shadow: 0 -4px 20px rgba(0,0,0,.12);
		font-family: var(--pp-font);
	}

	.pp-mobile-footer__toggle {
		display: flex;
		align-items: center;
		gap: 8px;
		background: var(--pp-gray-light);
		border: none;
		border-bottom: 1px solid var(--pp-gray-border);
		cursor: pointer;
		font-family: var(--pp-font);
		font-size: 13px;
		font-weight: 600;
		color: var(--pp-black);
		padding: 10px 16px;
		width: 100%;
		text-align: left;
	}

	.pp-mobile-footer__toggle-label { flex: 1; }

	.pp-mobile-footer__toggle-price {
		font-size: 15px;
		font-weight: 700;
		color: var(--pp-black);
	}

	.pp-footer-toggle-arrow {
		flex-shrink: 0;
		color: var(--pp-orange);
		transition: transform 0.3s ease;
	}

	.pp-footer-toggle-arrow.pp-toggle--open { transform: rotate(180deg); }

	.pp-mobile-drawer {
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.35s ease;
		background: var(--pp-white);
	}

	.pp-mobile-drawer.pp-mobile-drawer--open {
		max-height: 60vh;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		overscroll-behavior: contain;
		border-bottom: 1px solid var(--pp-gray-border);
	}

	.pp-mobile-drawer__inner { padding: 12px 16px; }

	.pp-mobile-drawer__inner .pp-summary-row {
		font-size: 13px;
		padding: 6px 0;
	}

	.pp-mobile-drawer__inner .pp-summary-total { font-size: 17px; }

	.pp-mobile-footer__bottom {
		padding: 12px 16px;
		padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px));
	}

	.pp-mobile-footer__btn {
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 8px;
		width: 100%;
		box-sizing: border-box;
		padding: 15px 20px;
		background: var(--pp-orange-grad);
		color: var(--pp-white) !important;
		border: none;
		border-radius: 50px;
		font-size: 16px;
		font-weight: 700;
		font-family: var(--pp-font);
		text-decoration: none !important;
		cursor: pointer;
		box-shadow: 0 2px 10px rgba(254,97,0,.30);
		letter-spacing: .02em;
		transition: background var(--pp-transition);
	}

	.pp-mobile-footer__btn:hover {
		background: linear-gradient(135deg, #e55a00 0%, #d95300 100%);
		color: var(--pp-white) !important;
	}
}

/* Movil (< 480px): layout grid para items */
@media (max-width: 480px) {
	.pp-cart-page { padding: 10px 10px 0; } /* mantener espacio para footer fijo */

	/* Item: grid 2 columnas — imagen | (info + controles) */
	.pp-cart-item { border-radius: var(--pp-radius-sm); margin-bottom: 10px; }

	.pp-cart-item__main {
		display: grid;
		grid-template-columns: 70px 1fr;
		grid-template-rows: auto auto;
		gap: 6px 10px;
		padding: 12px 10px;
		align-items: start;
	}

	/* Imagen ocupa las 2 filas de su columna */
	.pp-cart-item__imglink {
		grid-column: 1;
		grid-row: 1 / 3;
		align-self: start;
	}

	.pp-cart-item__img {
		width: 70px;
		height: 70px;
		padding: 4px;
	}

	/* Info: columna derecha fila 1 */
	.pp-cart-item__info {
		grid-column: 2;
		grid-row: 1;
		gap: 4px;
	}

	.pp-cart-item__name {
		font-size: 13px;
		-webkit-line-clamp: 2;
		line-height: 1.35;
	}

	.pp-cart-item__meta { font-size: 11px; }

	.pp-cart-item__price { font-size: 15px; }

	.pp-cqty { margin-top: 2px; }

	.pp-cqty-btn {
		width: 34px;
		height: 34px;
		font-size: 17px;
	}

	.pp-cqty-val {
		min-width: 28px;
		height: 34px;
		line-height: 34px;
		font-size: 13px;
	}

	/* Fila inferior derecha: solo precio (la X ya es absolute arriba) */
	.pp-cart-item__right {
		grid-column: 2;
		grid-row: 2;
		flex-direction: row;
		justify-content: flex-end;
		align-items: center;
		padding-top: 4px;
		border-top: 1px solid var(--pp-gray-border);
		margin-top: 4px;
	}

	.pp-cart-item__line-price {
		font-size: 14px;
		font-weight: 800;
	}

	/* Resumen: compacto */
	.pp-cart-summary { padding: 14px 12px; border-radius: var(--pp-radius-sm); }
	.pp-summary-title { font-size: 13px; margin-bottom: 12px; padding-bottom: 10px; }
	.pp-summary-row   { font-size: 13px; padding: 6px 0; }
	.pp-summary-total { font-size: 18px; }

	.pp-checkout-btn {
		font-size: 15px;
		padding: 14px 12px;
		margin: 12px 0 8px;
		min-height: 50px;
	}

	.pp-coupon-wrap {
		flex-direction: column;
		gap: 6px;
	}

	#pp-coupon-input  { width: 100%; }
	#pp-coupon-apply  { width: 100%; padding: 10px; }

	/* Cross-sells 480px */
	.pp-cart-cs { padding: 12px 10px; border-radius: var(--pp-radius-sm); }
	.pp-cart-cs__title { font-size: 12px; }
	.pp-cart-cs__arrows { display: none; }
	.pp-cs-card { flex: 0 0 150px; }
	.pp-cs-card__img-wrap { height: 120px; }
	.pp-cs-card__img { width: 90px; height: 90px; }
	.pp-cs-card__name { font-size: 11px; }
	.pp-cs-card__price { font-size: 14px; }
}

/* Muy pequeno (< 360px) */
@media (max-width: 360px) {
	.pp-cart-item__main { grid-template-columns: 60px 1fr; }
	.pp-cart-item__imglink { grid-row: 1 / 3; }
	.pp-cart-item__img { width: 60px; height: 60px; }
	.pp-cs-card { flex: 0 0 135px; }
}
