/*
 * La Galga Gris · page-cart.css
 * Override visual del carrito Woo + empty state.
 */

.lgg-cart { padding-block: clamp(2rem, 5vw, 4rem) clamp(3rem, 6vw, 5rem); }

.lgg-cart__head {
	max-width: var(--container-default);
	margin: 0 auto var(--sp-6);
	text-align: center;
	display: flex;
	flex-direction: column;
	gap: var(--sp-2);
	align-items: center;
}
.lgg-cart__title {
	margin: 0;
	font-family: var(--font-display);
	font-size: clamp(1.75rem, 3.5vw, 2.75rem);
	font-weight: var(--fw-medium);
	line-height: 1.05;
	letter-spacing: var(--ls-display);
	text-wrap: balance;
}
.lgg-cart__lead { margin: 0; max-width: 60ch; }

/* ── Layout 2 cols ──────────────────────────────────────────────── */
.lgg-cart__layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(2rem, 4vw, 3rem);
	max-width: var(--container-wide);
	margin: 0 auto;
}
@media (min-width: 960px) {
	.lgg-cart__layout { grid-template-columns: 1.6fr 1fr; gap: clamp(2.5rem, 5vw, 4rem); align-items: start; }
}

/* ── Líneas del carrito ─────────────────────────────────────────── */
.lgg-cart__table {
	width: 100%;
	border-collapse: collapse;
	background: var(--color-bg-card);
	border: 1px solid var(--color-border-subtle);
	border-radius: var(--radius-md);
	overflow: hidden;
}
.lgg-cart__table-head th {
	padding: var(--sp-3) var(--sp-4);
	font-size: var(--fz-micro);
	letter-spacing: var(--ls-eyebrow);
	text-transform: uppercase;
	color: var(--color-ink-muted);
	font-weight: var(--fw-semibold);
	background: var(--color-bg-subtle);
	text-align: left;
	border-bottom: 1px solid var(--color-border-subtle);
}
@media (max-width: 720px) {
	.lgg-cart__table-head { display: none; }
}

.lgg-cart__row td {
	padding: var(--sp-4);
	border-bottom: 1px solid var(--color-border-subtle);
	vertical-align: top;
}
.lgg-cart__row:last-child td { border-bottom: 0; }

@media (max-width: 720px) {
	.lgg-cart__row { display: grid; grid-template-columns: 1fr; padding: var(--sp-4); border-bottom: 1px solid var(--color-border-subtle); }
	.lgg-cart__row td { padding: var(--sp-2) 0; border: 0; display: flex; justify-content: space-between; gap: var(--sp-3); align-items: center; }
	.lgg-cart__row td[data-title]::before { content: attr(data-title); font-size: var(--fz-micro); letter-spacing: var(--ls-eyebrow); text-transform: uppercase; color: var(--color-ink-muted); font-weight: var(--fw-semibold); }
	.lgg-cart__row td.lgg-cart__cell-product::before { display: none; }
}

.lgg-cart__line {
	display: grid;
	grid-template-columns: 80px 1fr;
	gap: var(--sp-3);
}
.lgg-cart__thumb {
	display: block;
	width: 80px; height: 100px;
	border-radius: var(--radius-sm);
	overflow: hidden;
	background: var(--color-bg-subtle);
}
.lgg-cart__thumb img { width: 100%; height: 100%; object-fit: cover; }

.lgg-cart__meta { display: flex; flex-direction: column; gap: 4px; }
.lgg-cart__name {
	font-family: var(--font-display);
	font-size: 1.05rem;
	font-weight: var(--fw-medium);
	color: var(--color-ink-primary);
	text-decoration: none;
	line-height: 1.25;
}
.lgg-cart__name:hover { color: var(--color-accent); }

.lgg-cart__chip { width: fit-content; }
.lgg-cart__attrs {
	margin: var(--sp-1) 0 0;
	font-size: var(--fz-small);
	color: var(--color-ink-secondary);
}
.lgg-cart__attrs dt { display: inline; font-weight: var(--fw-semibold); }
.lgg-cart__attrs dt::after { content: ": "; }
.lgg-cart__attrs dd { display: inline; margin: 0 0 4px; }
.lgg-cart__attrs dd::after { content: "\A"; white-space: pre; }
.lgg-cart__attrs dt:last-of-type ~ dd:last-of-type::after { content: ""; }

.lgg-cart__remove {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	margin-top: var(--sp-1);
	font-size: var(--fz-micro);
	color: var(--color-ink-muted);
	text-decoration: none;
	width: fit-content;
}
.lgg-cart__remove:hover { color: var(--color-danger); }
.lgg-cart__remove-x {
	width: 32px; height: 32px;
	border-radius: 50%;
	background: transparent;
	color: var(--color-ink-muted);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
}
.lgg-cart__remove-x:hover { background: var(--color-bg-subtle); color: var(--color-danger); }

.lgg-cart__qty-input,
.quantity .qty {
	width: 64px !important;
	padding: 6px 8px;
	border: 1px solid var(--color-border-default);
	border-radius: var(--radius-sm);
	background: var(--color-bg-card);
	text-align: center;
	font-size: var(--fz-small);
	-moz-appearance: textfield;
}
.lgg-cart__qty-input::-webkit-outer-spin-button,
.lgg-cart__qty-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.lgg-cart__subtotal {
	font-family: var(--font-display);
	font-size: 1.05rem;
	font-weight: var(--fw-medium);
	color: var(--color-ink-primary);
	white-space: nowrap;
}

/* ── Actions row (coupon + update) ──────────────────────────────── */
.lgg-cart__actions { background: var(--color-bg-subtle); }
.lgg-cart__actions-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sp-3);
	align-items: center;
	padding-block: var(--sp-2);
}
.lgg-cart__coupon {
	flex: 1;
	min-width: 240px;
}
.lgg-cart__coupon-wrap {
	display: flex;
	gap: var(--sp-2);
	align-items: center;
}
.lgg-cart__coupon-input {
	flex: 1;
	max-width: 220px;
}

/* ── Summary sticky ─────────────────────────────────────────────── */
.lgg-cart__summary-sticky {
	position: sticky;
	top: calc(76px + var(--sp-4));
}
@media (min-width: 1024px) {
	.lgg-cart__summary-sticky { top: calc(84px + var(--sp-4)); }
}

.lgg-cart__summary-card {
	background: var(--color-bg-subtle);
	border: 1px solid var(--color-border-subtle);
	border-radius: var(--radius-md);
	padding: var(--sp-5);
	display: flex;
	flex-direction: column;
	gap: var(--sp-4);
}
.lgg-cart__summary-title {
	margin: 0;
	font-family: var(--font-display);
	font-size: 1.35rem;
	font-weight: var(--fw-medium);
}

.lgg-cart__totals { margin: 0; display: flex; flex-direction: column; gap: var(--sp-1); }
.lgg-cart__totals-row {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	padding-block: 6px;
	border-bottom: 1px dashed var(--color-border-subtle);
}
.lgg-cart__totals-row:last-child { border-bottom: 0; }
.lgg-cart__totals-row dt { font-size: var(--fz-small); color: var(--color-ink-secondary); font-weight: var(--fw-medium); }
.lgg-cart__totals-row dd { margin: 0; font-family: var(--font-body); font-weight: var(--fw-semibold); color: var(--color-ink-primary); }

.lgg-cart__totals-row--grand {
	margin-top: var(--sp-2);
	padding-top: var(--sp-3);
	border-top: 1px solid var(--color-border-default);
	border-bottom: 0;
}
.lgg-cart__totals-row--grand dt { font-family: var(--font-display); font-size: 1.1rem; font-weight: var(--fw-medium); color: var(--color-ink-primary); }
.lgg-cart__totals-row--grand dd { font-family: var(--font-display); font-size: 1.75rem; color: var(--color-accent); font-weight: var(--fw-medium); }

.lgg-cart__notice {
	margin: 0;
	padding: var(--sp-2) var(--sp-3);
	background: var(--color-accent-soft);
	color: var(--color-accent-hover);
	border-radius: var(--radius-sm);
	font-size: var(--fz-micro);
	line-height: 1.4;
}
.lgg-cart__cta .checkout-button, .lgg-cart__cta .button {
	display: block;
	width: 100%;
	padding: 1rem 1.5rem;
	background: var(--color-accent);
	color: var(--color-ink-inverse);
	border: 0;
	border-radius: var(--radius-md);
	font-family: var(--font-body);
	font-size: var(--fz-body);
	font-weight: var(--fw-semibold);
	letter-spacing: 0.01em;
	cursor: pointer;
	text-align: center;
	text-decoration: none;
	transition: background var(--dur-fast) var(--ease-standard);
}
.lgg-cart__cta .checkout-button:hover, .lgg-cart__cta .button:hover { background: var(--color-accent-hover); }

.lgg-cart__trust {
	list-style: none;
	margin: var(--sp-2) 0 0;
	padding: var(--sp-3) 0 0;
	border-top: 1px solid var(--color-border-subtle);
	display: flex;
	flex-direction: column;
	gap: var(--sp-2);
}
.lgg-cart__trust li {
	display: flex;
	align-items: center;
	gap: var(--sp-2);
	font-size: var(--fz-small);
	color: var(--color-ink-secondary);
}
.lgg-cart__trust svg { color: var(--color-ink-primary); flex: 0 0 auto; }

/* ── Empty state ────────────────────────────────────────────────── */
.lgg-cart-empty {
	padding-block: clamp(3rem, 8vw, 6rem);
}
.lgg-cart-empty__inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(2rem, 4vw, 3rem);
	align-items: center;
}
@media (min-width: 720px) {
	.lgg-cart-empty__inner { grid-template-columns: 1fr 1.2fr; }
}
.lgg-cart-empty__media { margin: 0; max-width: 420px; }
.lgg-cart-empty__media .lgg-ratio {
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--color-bg-subtle);
	box-shadow: var(--shadow-md);
}
.lgg-cart-empty__media .lgg-ratio img {
	position: absolute; inset: 0;
	width: 100%; height: 100%;
	object-fit: cover;
}
.lgg-cart-empty__copy { display: flex; flex-direction: column; gap: var(--sp-3); max-width: 50ch; }
.lgg-cart-empty__title {
	margin: 0;
	font-family: var(--font-display);
	font-size: clamp(2rem, 4vw, 3rem);
	font-weight: var(--fw-medium);
	line-height: 1.05;
	letter-spacing: var(--ls-display);
}
.lgg-cart-empty__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sp-3);
	margin-top: var(--sp-2);
}
.lgg-cart-empty__quick {
	list-style: none;
	margin: var(--sp-4) 0 0;
	padding: var(--sp-4) 0 0;
	border-top: 1px solid var(--color-border-subtle);
	display: flex;
	flex-wrap: wrap;
	gap: var(--sp-2);
}
.lgg-cart-empty__quick a {
	display: inline-flex;
	padding: 6px 14px;
	border: 1px solid var(--color-border-default);
	border-radius: var(--radius-pill);
	color: var(--color-ink-primary);
	text-decoration: none;
	font-size: var(--fz-small);
	font-weight: var(--fw-medium);
}
.lgg-cart-empty__quick a:hover {
	border-color: var(--color-accent);
	color: var(--color-accent);
}
