/**
 * Carrito lateral (side-cart) — estilos autosuficientes.
 *
 * Todo va bajo el espacio de nombres `.wck-sc` para no chocar con el tema.
 * Las variables propias `--wck-sc-*` toman como valor por defecto los tokens
 * del tema (`--accent`, `--ink`, `--line`, etc.) cuando existen, y caen a un
 * valor neutro si el tema no los expone. Así el panel se ve bien aunque los
 * estilos nativos de WooCommerce estén desencolados.
 */

/* ----------------------------------------------------------------------
 * Variables del módulo (con fallback a los tokens del tema)
 * ------------------------------------------------------------------- */
.wck-sc {
	--wck-sc-z: 99990; /* sobre header/mega/whatsapp del tema, bajo la admin bar (99999) */
	--wck-sc-width: min(420px, 100%);

	--wck-sc-bg: var(--white, #ffffff);
	--wck-sc-ink: var(--ink, #181715);
	--wck-sc-ink-2: var(--ink-2, #4a4843);
	--wck-sc-muted: var(--muted, #8a8780);
	--wck-sc-line: var(--line, #e8e6e1);
	--wck-sc-tint: var(--tint, #f7f6f2);

	--wck-sc-accent: var(--accent, #6366f1);
	--wck-sc-accent-deep: var(--accent-deep, #4f46e5);
	--wck-sc-on-accent: #ffffff;
	--wck-sc-success: var(--success, #16a34a);
	--wck-sc-error: var(--error, #dc2626);

	--wck-sc-overlay: rgba(24, 23, 21, 0.5);
	--wck-sc-shadow: var(--sh-4, 0 24px 60px rgba(0, 0, 0, 0.18));

	--wck-sc-r: var(--r-md, 12px);
	--wck-sc-r-sm: var(--r-sm, 8px);
	--wck-sc-r-pill: var(--r-pill, 999px);

	--wck-sc-pad: 20px;
	--wck-sc-gap: 14px;

	--wck-sc-font: var(--font, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif);
	--wck-sc-duration: 0.34s; /* debe coincidir con CLOSE_MS del JS */
	--wck-sc-ease: var(--ease, cubic-bezier(0.22, 1, 0.36, 1));

	font-family: var(--wck-sc-font);
	color: var(--wck-sc-ink);
	line-height: 1.45;
}

/* Reset acotado al panel para no heredar rarezas del tema. */
.wck-sc *,
.wck-sc *::before,
.wck-sc *::after {
	box-sizing: border-box;
}

/* Estado cerrado real: fuera del flujo y del árbol de accesibilidad. */
.wck-sc[hidden] {
	display: none !important;
}

/* ----------------------------------------------------------------------
 * Contenedor, overlay y panel
 * ------------------------------------------------------------------- */
.wck-sc {
	position: fixed;
	inset: 0;
	z-index: var(--wck-sc-z);
}

.wck-sc__overlay {
	position: absolute;
	inset: 0;
	z-index: 1;
	background: var(--wck-sc-overlay);
	opacity: 0;
	transition: opacity var(--wck-sc-duration) var(--wck-sc-ease);
	-webkit-tap-highlight-color: transparent;
}

.wck-sc.is-open .wck-sc__overlay {
	opacity: 1;
}

.wck-sc__panel {
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	z-index: 2;
	display: flex;
	flex-direction: column;
	width: var(--wck-sc-width);
	max-width: 100%;
	height: 100%;
	background: var(--wck-sc-bg);
	box-shadow: var(--wck-sc-shadow);
	transform: translateX(100%);
	transition: transform var(--wck-sc-duration) var(--wck-sc-ease);
	will-change: transform;
	outline: none;
}

.wck-sc.is-open .wck-sc__panel {
	transform: translateX(0);
}

/* Panel anclado a la izquierda. */
.wck-sc[data-position="left"] .wck-sc__panel {
	right: auto;
	left: 0;
	transform: translateX(-100%);
}

.wck-sc[data-position="left"].is-open .wck-sc__panel {
	transform: translateX(0);
}

/* ----------------------------------------------------------------------
 * Cabecera
 * ------------------------------------------------------------------- */
.wck-sc__header {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: var(--wck-sc-pad);
	border-bottom: 1px solid var(--wck-sc-line);
}

.wck-sc__title {
	display: flex;
	align-items: center;
	gap: 8px;
	margin: 0;
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--wck-sc-ink);
}

/* Píldora con el número de productos. */
.wck-sc__count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 22px;
	height: 22px;
	padding: 0 7px;
	border-radius: var(--wck-sc-r-pill);
	background: var(--wck-sc-accent);
	color: var(--wck-sc-on-accent);
	font-size: 0.75rem;
	font-weight: 700;
	line-height: 1;
}

.wck-sc__count.is-empty {
	display: none;
}

.wck-sc__close {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	margin: -8px -8px -8px 0;
	padding: 0;
	border: 0;
	border-radius: var(--wck-sc-r-pill);
	background: transparent;
	color: var(--wck-sc-ink-2);
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease;
}

.wck-sc__close:hover,
.wck-sc__close:focus-visible {
	background: var(--wck-sc-tint);
	color: var(--wck-sc-ink);
}

.wck-sc__close:focus-visible {
	outline: 2px solid var(--wck-sc-accent);
	outline-offset: 2px;
}

/* ----------------------------------------------------------------------
 * Aviso (aria-live)
 * ------------------------------------------------------------------- */
.wck-sc__notice {
	flex: 0 0 auto;
	margin: 0;
	padding: 10px var(--wck-sc-pad);
	background: var(--wck-sc-tint);
	color: var(--wck-sc-ink-2);
	font-size: 0.875rem;
	border-bottom: 1px solid var(--wck-sc-line);
}

.wck-sc__notice:empty {
	display: none;
}

.wck-sc__notice.is-error {
	background: color-mix(in srgb, var(--wck-sc-error) 12%, transparent);
	color: var(--wck-sc-error);
}

/* ----------------------------------------------------------------------
 * Contenido (este bloque es el fragment `div.wck-sc__contents`)
 * ------------------------------------------------------------------- */
.wck-sc__contents {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	min-height: 0; /* permite que la lista interna haga scroll */
}

/* ----------------------------------------------------------------------
 * Barra de progreso de envío gratis
 * ------------------------------------------------------------------- */
.wck-sc__progress {
	flex: 0 0 auto;
	padding: 14px var(--wck-sc-pad);
	border-bottom: 1px solid var(--wck-sc-line);
}

.wck-sc__progress-text {
	margin: 0 0 8px;
	font-size: 0.85rem;
	color: var(--wck-sc-ink-2);
}

.wck-sc__progress-track {
	height: 8px;
	border-radius: var(--wck-sc-r-pill);
	background: var(--wck-sc-line);
	overflow: hidden;
}

.wck-sc__progress-bar {
	display: block;
	height: 100%;
	width: 0;
	border-radius: inherit;
	background: var(--wck-sc-accent);
	transition: width 0.4s var(--wck-sc-ease);
}

.wck-sc__progress.is-reached .wck-sc__progress-bar {
	background: var(--wck-sc-success);
}

/* ----------------------------------------------------------------------
 * Lista de líneas
 * ------------------------------------------------------------------- */
.wck-sc__items {
	flex: 1 1 auto;
	min-height: 0;
	margin: 0;
	padding: 0 var(--wck-sc-pad);
	list-style: none;
	overflow-y: auto;
	overflow-x: hidden;
	-webkit-overflow-scrolling: touch;
	overscroll-behavior: contain;
}

.wck-sc__item {
	display: flex;
	gap: 12px;
	padding: 16px 0;
	border-bottom: 1px solid var(--wck-sc-line);
}

.wck-sc__item:last-child {
	border-bottom: 0;
}

.wck-sc__thumb {
	flex: 0 0 auto;
	display: block;
	width: 64px;
	height: 64px;
	border-radius: var(--wck-sc-r-sm);
	overflow: hidden;
	background: var(--wck-sc-tint);
}

.wck-sc__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	margin: 0;
}

.wck-sc__item-body {
	flex: 1 1 auto;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.wck-sc__name {
	font-size: 0.95rem;
	font-weight: 600;
	line-height: 1.3;
	color: var(--wck-sc-ink);
	text-decoration: none;
}

a.wck-sc__name:hover,
a.wck-sc__name:focus-visible {
	color: var(--wck-sc-accent);
}

/* Metadatos de la línea (variaciones, add-ons): salida de WooCommerce. */
.wck-sc__item-body .variation,
.wck-sc__item-body dl {
	margin: 0;
	font-size: 0.78rem;
	color: var(--wck-sc-muted);
}

.wck-sc__item-body .variation dt,
.wck-sc__item-body .variation dd {
	display: inline;
	margin: 0;
	font-weight: 400;
}

.wck-sc__item-body .variation dd {
	margin-right: 6px;
}

.wck-sc__price {
	font-size: 0.82rem;
	color: var(--wck-sc-muted);
}

.wck-sc__row {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-top: 6px;
}

/* Selector de cantidad. */
.wck-sc__qty {
	display: inline-flex;
	align-items: center;
	border: 1px solid var(--wck-sc-line);
	border-radius: var(--wck-sc-r-pill);
	overflow: hidden;
}

.wck-sc__qty-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--wck-sc-ink);
	cursor: pointer;
	transition: background-color 0.15s ease;
}

.wck-sc__qty-btn:hover,
.wck-sc__qty-btn:focus-visible {
	background: var(--wck-sc-tint);
}

.wck-sc__qty-btn:focus-visible {
	outline: 2px solid var(--wck-sc-accent);
	outline-offset: -2px;
}

.wck-sc__qty-input {
	width: 38px;
	height: 30px;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--wck-sc-ink);
	font: inherit;
	font-size: 0.9rem;
	text-align: center;
	-moz-appearance: textfield;
	appearance: textfield;
}

.wck-sc__qty-input::-webkit-outer-spin-button,
.wck-sc__qty-input::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

.wck-sc__qty-input:focus-visible {
	outline: none;
}

/* Cantidad fija (producto de venta individual). */
.wck-sc__qty-static {
	font-size: 0.9rem;
	color: var(--wck-sc-muted);
}

.wck-sc__line-subtotal {
	margin-left: auto;
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--wck-sc-ink);
	white-space: nowrap;
}

.wck-sc__remove {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	padding: 0;
	border: 0;
	border-radius: var(--wck-sc-r-pill);
	background: transparent;
	color: var(--wck-sc-muted);
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease;
}

.wck-sc__remove:hover,
.wck-sc__remove:focus-visible {
	background: color-mix(in srgb, var(--wck-sc-error) 10%, transparent);
	color: var(--wck-sc-error);
}

.wck-sc__remove:focus-visible {
	outline: 2px solid var(--wck-sc-error);
	outline-offset: 2px;
}

/* ----------------------------------------------------------------------
 * Pie: totales + acciones
 * ------------------------------------------------------------------- */
.wck-sc__footer {
	flex: 0 0 auto;
	display: flex;
	flex-direction: column;
	gap: 14px;
	padding: var(--wck-sc-pad);
	border-top: 1px solid var(--wck-sc-line);
	background: var(--wck-sc-bg);
}

.wck-sc__totals {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 12px;
}

.wck-sc__totals-label {
	font-size: 0.95rem;
	color: var(--wck-sc-ink-2);
}

.wck-sc__totals-value {
	font-size: 1.15rem;
	font-weight: 700;
	color: var(--wck-sc-ink);
}

.wck-sc__actions {
	display: flex;
	gap: 10px;
}

.wck-sc__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 12px 16px;
	border: 1px solid transparent;
	border-radius: var(--wck-sc-r-sm);
	font-size: 0.95rem;
	font-weight: 600;
	line-height: 1.2;
	text-align: center;
	text-decoration: none;
	cursor: pointer;
	transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease, transform 0.05s ease;
}

.wck-sc__btn:active {
	transform: translateY(1px);
}

.wck-sc__actions .wck-sc__btn {
	flex: 1 1 0;
}

.wck-sc__btn--primary {
	background: var(--wck-sc-accent);
	border-color: var(--wck-sc-accent);
	color: var(--wck-sc-on-accent);
}

.wck-sc__btn--primary:hover,
.wck-sc__btn--primary:focus-visible {
	background: var(--wck-sc-accent-deep);
	border-color: var(--wck-sc-accent-deep);
	color: var(--wck-sc-on-accent);
}

.wck-sc__btn--secondary {
	background: transparent;
	border-color: var(--wck-sc-line);
	color: var(--wck-sc-ink);
}

.wck-sc__btn--secondary:hover,
.wck-sc__btn--secondary:focus-visible {
	background: var(--wck-sc-tint);
	border-color: var(--wck-sc-ink-2);
	color: var(--wck-sc-ink);
}

.wck-sc__btn:focus-visible {
	outline: 2px solid var(--wck-sc-accent);
	outline-offset: 2px;
}

/* ----------------------------------------------------------------------
 * Estado vacío
 * ------------------------------------------------------------------- */
.wck-sc__empty {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 16px;
	padding: 48px var(--wck-sc-pad);
	text-align: center;
}

.wck-sc__empty-icon {
	color: var(--wck-sc-line);
}

.wck-sc__empty-text {
	margin: 0;
	font-size: 1rem;
	color: var(--wck-sc-ink-2);
}

.wck-sc__empty .wck-sc__btn {
	flex: 0 0 auto;
}

/* ----------------------------------------------------------------------
 * Spinner de ocupado (durante AJAX): cubre el panel y bloquea interacción
 * ------------------------------------------------------------------- */
.wck-sc__spinner {
	position: absolute;
	inset: 0;
	z-index: 3;
	display: none;
	align-items: center;
	justify-content: center;
	background: color-mix(in srgb, var(--wck-sc-bg) 60%, transparent);
}

.wck-sc.is-busy .wck-sc__spinner {
	display: flex;
}

.wck-sc__spinner::after {
	content: "";
	width: 34px;
	height: 34px;
	border-radius: 50%;
	border: 3px solid var(--wck-sc-line);
	border-top-color: var(--wck-sc-accent);
	animation: wck-sc-spin 0.7s linear infinite;
}

@keyframes wck-sc-spin {
	to {
		transform: rotate(360deg);
	}
}

/* ----------------------------------------------------------------------
 * Botón disparador del shortcode [wck_cart_toggle]
 * ------------------------------------------------------------------- */
.wck-sc-toggle-btn {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	padding: 0;
	border: 1px solid var(--line, #e8e6e1);
	border-radius: var(--r-pill, 999px);
	background: var(--white, #ffffff);
	color: var(--ink, #181715);
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease;
}

.wck-sc-toggle-btn:hover,
.wck-sc-toggle-btn:focus-visible {
	background: var(--tint, #f7f6f2);
}

.wck-sc-toggle-btn:focus-visible {
	outline: 2px solid var(--accent, #6366f1);
	outline-offset: 2px;
}

/* El contador del botón flota en la esquina superior. */
.wck-sc-toggle-btn .wck-sc__count {
	position: absolute;
	top: -4px;
	inset-inline-end: -4px;
	min-width: 18px;
	height: 18px;
	padding: 0 5px;
	font-size: 0.68rem;
}

/* ----------------------------------------------------------------------
 * Bloqueo de scroll del documento mientras el panel está abierto
 * (la clase la pone/quita el JS en <html>)
 * ------------------------------------------------------------------- */
html.wck-sc-locked,
html.wck-sc-locked body {
	overflow: hidden;
}

/* ----------------------------------------------------------------------
 * Movimiento reducido: respeta la preferencia del sistema
 * ------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
	.wck-sc__overlay,
	.wck-sc__panel,
	.wck-sc__progress-bar,
	.wck-sc__btn,
	.wck-sc__close,
	.wck-sc__qty-btn,
	.wck-sc__remove {
		transition: none !important;
	}

	.wck-sc__spinner::after {
		animation-duration: 1.4s;
	}
}
