/* ==========================================================================
   VORPC Suite · Frontend
   Paleta: #25b791 / #fd6571 / #00273f / #ededed
   Tipografía: Karla · Dancing Script
   Mobile-first.
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Karla:wght@400;500;600;700;800&family=Dancing+Script:wght@600;700&display=swap');

:root {
	--vf-primary:    #25b791;
	--vf-primary-d:  #1d9e7c;
	--vf-primary-l:  #e0f3ec;
	--vf-primary-glow: rgba(37,183,145,.2);

	--vf-accent:     #fd6571;
	--vf-accent-d:   #e34c59;
	--vf-accent-l:   #ffe4e7;

	--vf-dark:       #00273f;
	--vf-dark-soft:  #2a4861;

	--vf-base:       #ededed;
	--vf-bg-soft:    #f7f8fa;
	--vf-card:       #ffffff;
	--vf-line:       #ececec;

	--vf-text:       #15233a;
	--vf-text-soft:  #5c6877;
	--vf-text-mute:  #9aa4b3;

	--vf-r-sm:  10px;
	--vf-r:     14px;
	--vf-r-lg:  20px;
	--vf-r-pill: 999px;

	--vf-shadow-xs: 0 1px 2px rgba(0,39,63,.05);
	--vf-shadow-sm: 0 4px 14px rgba(0,39,63,.06);
	--vf-shadow:    0 10px 28px rgba(0,39,63,.1);

	--vf-ease:     cubic-bezier(.4,.0,.2,1);
	--vf-ease-out: cubic-bezier(.16,1,.3,1);

	--vf-font:        'Karla', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	--vf-font-decor:  'Dancing Script', cursive;
}

/* Container utility shared */
[class^="vorpc-"], [class*=" vorpc-"] { box-sizing: border-box; }

/* ==========================================================================
   Selector de variaciones (familia)
   ========================================================================== */
.vorpc-family-selector {
	font-family: var(--vf-font);
	margin: 20px 0;
	padding: 18px;
	background: var(--vf-card);
	border: 1px solid var(--vf-line);
	border-radius: var(--vf-r);
	box-shadow: var(--vf-shadow-sm);
	animation: vf-rise .4s var(--vf-ease-out) both;
}

@keyframes vf-rise {
	from { opacity: 0; transform: translateY(8px); }
	to   { opacity: 1; transform: translateY(0); }
}

.vorpc-family-selector__title {
	font-size: 13px;
	font-weight: 800;
	color: var(--vf-dark);
	text-transform: uppercase;
	letter-spacing: .12em;
	margin: 0 0 14px;
}

.vorpc-family-axis { margin-bottom: 16px; }
.vorpc-family-axis:last-child { margin-bottom: 0; }

.vorpc-family-axis__label {
	display: block;
	font-size: 11px;
	font-weight: 600;
	color: var(--vf-text-soft);
	margin-bottom: 8px;
	letter-spacing: .04em;
	text-transform: uppercase;
}

/* Ejes prioritarios (RAM · Almacenamiento · Procesador) — label más marcado */
.vorpc-family-axis.is-priority .vorpc-family-axis__label {
	font-size: 12px;
	font-weight: 800;
	color: var(--vf-dark);
	letter-spacing: .05em;
}
.vorpc-family-axis.is-priority {
	padding-bottom: 12px;
	border-bottom: 1px dashed var(--vf-line);
}
.vorpc-family-axis.is-priority + .vorpc-family-axis:not(.is-priority) {
	margin-top: 6px;
}
.vorpc-family-axis.is-condicion .vorpc-family-axis__label,
.vorpc-family-axis.is-extra-axis .vorpc-family-axis__label {
	color: var(--vf-text-soft);
}

.vorpc-family-axis__options {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.vorpc-axis-option {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	min-height: 40px;
	padding: 8px 16px;
	border-radius: 12px;             /* menos pill, más botón */
	background: var(--vf-bg-soft);
	color: var(--vf-dark);
	font-weight: 600;
	font-size: 14px;
	cursor: pointer;
	user-select: none;
	border: 2px solid transparent;
	text-decoration: none;
	transition: all .18s var(--vf-ease);
	line-height: 1.2;
}
.vorpc-axis-option:hover {
	background: #fff;
	border-color: var(--vf-primary);
	color: var(--vf-primary-d);
	transform: translateY(-1px);
}
.vorpc-axis-option.is-current {
	background: var(--vf-primary);
	color: #fff;
	border-color: var(--vf-primary);
	box-shadow: 0 4px 14px var(--vf-primary-glow);
}
.vorpc-axis-option.is-current:hover { color: #fff; }

/* Outlet — coral en lugar de verde, sin texto adicional */
.vorpc-axis-option.is-outlet {
	background: var(--vf-accent-l);
	color: var(--vf-accent-d);
	border-color: transparent;
}
.vorpc-axis-option.is-outlet:hover {
	background: #fff;
	border-color: var(--vf-accent);
	color: var(--vf-accent-d);
}
.vorpc-axis-option.is-outlet.is-current {
	background: var(--vf-accent);
	color: #fff;
	border-color: var(--vf-accent);
	box-shadow: 0 4px 14px rgba(253,101,113,.32);
}
.vorpc-axis-option.is-outlet.is-current:hover { color: #fff; background: var(--vf-accent-d); }

/* Disabled / agotado — sin texto, sólo opacidad + tachado */
.vorpc-axis-option.is-disabled {
	opacity: .35;
	cursor: not-allowed;
	pointer-events: none;
	background: var(--vf-bg-soft);
	color: var(--vf-text-mute);
}
.vorpc-axis-option.is-disabled.is-oos { text-decoration: line-through; }

/* No disponible para la combinación actual — opaco pero clicable */
.vorpc-axis-option.is-unavailable {
	opacity: .38;
	background: var(--vf-bg-soft);
	color: var(--vf-text-mute);
	box-shadow: none;
}
.vorpc-axis-option.is-unavailable:hover {
	opacity: .65;
	transform: none;
	border-color: var(--vf-line);
	color: var(--vf-text-mute);
	background: #fff;
}
.vorpc-axis-option.is-unavailable.is-outlet { background: var(--vf-accent-l); color: var(--vf-accent-d); }

/* Pill de diferencia de precio dentro del option */
.vorpc-axis-option__diff {
	font-size: 10px;
	font-weight: 800;
	padding: 2px 7px;
	border-radius: 999px;
	line-height: 1.4;
	letter-spacing: .02em;
	white-space: nowrap;
}
.vorpc-axis-option__diff--cheaper { background: rgba(37,183,145,.18);  color: #1d9e7c; }
.vorpc-axis-option__diff--pricier { background: rgba(253,101,113,.18); color: #d95c3a; }
.vorpc-axis-option.is-current .vorpc-axis-option__diff {
	background: rgba(255,255,255,.25);
	color: #fff;
}
.vorpc-axis-option__label { line-height: 1.2; }

/* Botón "Sin pack" — estilo ghost dentro del eje pa_extra */
.vorpc-axis-option--clear {
	background: transparent;
	color: var(--vf-text-mute);
	border: 2px dashed var(--vf-line);
}
.vorpc-axis-option--clear:hover {
	background: #fff;
	color: var(--vf-dark);
	border-color: var(--vf-dark);
	border-style: solid;
}
.vorpc-axis-option--clear.is-current {
	background: var(--vf-dark);
	color: #fff;
	border-color: var(--vf-dark);
	border-style: solid;
}
.vorpc-axis-option--clear .dashicons { color: inherit; }

/* Badge contextual (ya no se usa para outlet, mantenido por si lo invocas en otro lado) */
.vorpc-axis-badge {
	background: var(--vf-accent);
	color: #fff;
	padding: 2px 8px;
	font-size: 9px;
	font-weight: 700;
	border-radius: var(--vf-r-pill);
	text-transform: uppercase;
	letter-spacing: .08em;
	line-height: 1.4;
}

.vorpc-family-msg {
	margin-top: 12px;
	font-size: 13px;
	color: var(--vf-accent-d);
	font-weight: 700;
	display: none;
}
.vorpc-family-msg.is-shown { display: block; }

/* Desktop ajustes */
@media (min-width: 768px) {
	.vorpc-family-selector { padding: 22px 24px; }
	.vorpc-axis-option { padding: 9px 18px; font-size: 14px; }
}

/* ==========================================================================
   Related family
   ========================================================================== */
.vorpc-related-family {
	font-family: var(--vf-font);
	margin: 36px 0;
}
.vorpc-related-family__title {
	font-size: 20px;
	font-weight: 800;
	color: var(--vf-dark);
	margin: 0 0 6px;
	letter-spacing: -0.02em;
}
.vorpc-related-family__title em {
	font-style: normal;
	font-family: var(--vf-font-decor);
	font-weight: 600;
	color: var(--vf-primary);
	font-size: 1.1em;
}
.vorpc-related-family__sub {
	color: var(--vf-text-soft);
	font-size: 13px;
	margin: 0 0 16px;
}
.vorpc-related-family__grid {
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
}
@media (min-width: 768px) {
	.vorpc-related-family__grid { gap: 14px; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }
}

.vorpc-related-card {
	display: flex;
	flex-direction: column;
	gap: 6px;
	background: var(--vf-card);
	border: 1px solid var(--vf-line);
	border-radius: var(--vf-r);
	padding: 14px 16px;
	text-decoration: none;
	color: var(--vf-dark);
	transition: all .22s var(--vf-ease);
	box-shadow: var(--vf-shadow-xs);
	position: relative;
	overflow: hidden;
}
.vorpc-related-card:hover {
	border-color: var(--vf-primary);
	transform: translateY(-3px);
	box-shadow: var(--vf-shadow-sm);
}
.vorpc-related-card__specs {
	display: flex;
	flex-direction: column;
	gap: 2px;
	flex: 1;
	margin-bottom: 8px;
}
.vorpc-rf-spec {
	font-size: 13px;
	color: var(--vf-text-soft);
	line-height: 1.35;
}
/* RAM y almacenamiento — destacados (más grandes y bold, color dark) */
.vorpc-rf-spec--primary {
	font-size: 15px;
	font-weight: 800;
	color: var(--vf-dark);
	letter-spacing: -0.01em;
}
/* Pa_extra destacado — paleta dark + acento coral, no verde */
.vorpc-rf-spec--highlight {
	display: inline-flex;
	align-items: center;
	background: rgba(0,39,63,.05);
	color: var(--vf-dark);
	padding: 5px 10px 5px 12px;
	border-radius: 8px;
	font-size: 11.5px;
	font-weight: 700;
	line-height: 1.3;
	margin-top: 4px;
	border-left: 3px solid var(--vf-accent);
	width: fit-content;
	max-width: 100%;
}

/* Fila de precio · precio + diff inline, suffix en línea aparte */
.vorpc-related-card__pricerow {
	display: flex;
	align-items: baseline;
	gap: 8px;
	flex-wrap: nowrap;             /* fuerza una sola línea */
	margin-top: auto;
}
.vorpc-related-card__price {
	font-weight: 800;
	color: var(--vf-primary-d);
	font-size: 16px;
	display: inline-flex;
	align-items: baseline;
	gap: 4px;
	flex-shrink: 1;
	min-width: 0;
}
.vorpc-related-card__price .amount,
.vorpc-related-card__price ins .amount { color: var(--vf-primary-d); font-weight: 800; }
.vorpc-related-card__price del,
.vorpc-related-card__price del .amount { color: var(--vf-text-mute); font-weight: 500; font-size: 0.78em; }
.vorpc-related-card__price ins { text-decoration: none; }

/* Suffix WC ("impuestos incluidos") — línea separada, muy discreta */
.vorpc-related-card__suffix {
	display: block;
	font-size: 10.5px;
	color: var(--vf-text-mute);
	font-weight: 500;
	margin-top: 4px;
	letter-spacing: .02em;
}

/* Comparativa de precio con flecha */
.vorpc-rf-diff {
	display: inline-flex;
	align-items: center;
	gap: 3px;
	padding: 3px 9px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 800;
	letter-spacing: .02em;
	white-space: nowrap;
	line-height: 1.4;
	flex-shrink: 0;
}
.vorpc-rf-diff--cheaper { background: rgba(37,183,145,.15);  color: #1d9e7c; }
.vorpc-rf-diff--pricier { background: rgba(253,101,113,.15); color: #d95c3a; }
.vorpc-rf-diff--equal   { background: #f6f7fa; color: var(--vf-text-mute); }

/* Tarjeta outlet — borde coral sutil */
.vorpc-related-card.is-outlet {
	border-left: 3px solid var(--vf-accent);
}

.vorpc-related-card .vorpc-axis-badge {
	position: absolute;
	top: 10px; right: 10px;
}

/* ==========================================================================
   Badges
   ========================================================================== */
.vorpc-badge {
	display: inline-block;
	padding: 4px 12px;
	border-radius: var(--vf-r-pill);
	font-size: 11px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: #fff;
	font-family: var(--vf-font);
	box-shadow: 0 2px 6px rgba(0,39,63,.18);
	line-height: 1.5;
}
.vorpc-badge--new    { background: var(--vf-primary); }
.vorpc-badge--outlet { background: var(--vf-accent); }
.vorpc-badge--bf     { background: var(--vf-dark); }

.vorpc-badge-stack {
	position: absolute;
	top: 12px; left: 12px;
	display: flex;
	flex-direction: column;
	gap: 5px;
	z-index: 5;
}

/* ==========================================================================
   Pickup Madrid
   ========================================================================== */
.vorpc-pickup-madrid {
	font-family: var(--vf-font);
	background: linear-gradient(135deg, var(--vf-primary-l) 0%, #f6fdfa 100%);
	border: 1px solid rgba(37,183,145,.3);
	border-radius: var(--vf-r);
	padding: 14px 16px;
	margin: 16px 0;
	font-size: 14px;
	color: var(--vf-dark);
	line-height: 1.55;
	display: flex;
	gap: 10px;
	align-items: flex-start;
}
.vorpc-pickup-madrid::before {
	content: '🕒';
	font-size: 22px;
	flex-shrink: 0;
}
.vorpc-pickup-madrid strong { color: var(--vf-primary-d); font-weight: 800; }
.vorpc-link-more {
	display: inline-block;
	margin-top: 6px;
	color: var(--vf-primary-d);
	text-decoration: underline;
	font-weight: 700;
	font-size: 13px;
	cursor: pointer;
}

/* ==========================================================================
   Sticky cart V3 — barra 100% ancho, contenido al 60%, layout img | main | btn
   ========================================================================== */
.vorpc-sticky-cart {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	width: 100%;
	background: rgba(255,255,255,.96);
	backdrop-filter: blur(14px) saturate(120%);
	-webkit-backdrop-filter: blur(14px) saturate(120%);
	border-top: 1px solid var(--vf-line);
	box-shadow: 0 -12px 36px rgba(0,39,63,.10);
	padding: 0;
	margin: 0;
	z-index: 99999;
	font-family: var(--vf-font);
	transform: translateY(110%);
	opacity: 0;
	visibility: hidden;
	transition: transform .5s var(--vf-ease-out), opacity .3s var(--vf-ease), visibility 0s .5s;
}
.vorpc-sticky-cart.is-shown {
	transform: translateY(0);
	opacity: 1;
	visibility: visible;
	transition: transform .5s var(--vf-ease-out), opacity .3s var(--vf-ease), visibility 0s 0s;
}

/* Área útil — 60 % del ancho, centrada */
.vorpc-sticky-cart__inner {
	width: 60%;
	max-width: 1100px;
	min-height: 80px;
	margin: 0 auto;
	padding: 14px 0;
	display: flex;
	align-items: center;
	gap: 18px;
	box-sizing: border-box;
}

/* Imagen producto a la izquierda */
.vorpc-sticky-cart__img {
	flex-shrink: 0;
	display: block;
	width: 60px;
	height: 60px;
	border: 1px solid var(--vf-line);
	border-radius: 12px;
	padding: 4px;
	background: #fff;
	overflow: hidden;
	text-decoration: none;
	transition: transform .22s var(--vf-ease);
}
.vorpc-sticky-cart__img:hover { transform: scale(1.05); }
.vorpc-sticky-cart__img img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
}

/* Centro: 2 líneas (título + precio) */
.vorpc-sticky-cart__main {
	flex: 1 1 auto;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
	line-height: 1.25;
}
.vorpc-sticky-cart__title {
	font-weight: 700;
	color: var(--vf-dark);
	font-size: 16px;
	margin: 0;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.vorpc-sticky-cart__price {
	color: var(--vf-accent);
	font-weight: 800;
	font-size: 20px;
	margin: 0;
	display: flex;
	align-items: baseline;
	gap: 8px;
}
.vorpc-sticky-cart__price .amount,
.vorpc-sticky-cart__price ins .amount,
.vorpc-sticky-cart__price > .amount { color: var(--vf-accent); font-weight: 800; }
.vorpc-sticky-cart__price del,
.vorpc-sticky-cart__price del .amount {
	color: var(--vf-text-mute);
	text-decoration: line-through;
	font-size: 13px;
	font-weight: 500;
}
.vorpc-sticky-cart__price ins { text-decoration: none; }

/* Form — defensa contra themes que estiran form.cart al 100% */
.vorpc-sticky-cart__form {
	display: flex !important;
	align-items: center;
	gap: 8px;
	margin: 0 !important;
	padding: 0 !important;
	flex-shrink: 0;
	width: auto !important;
	border: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
}
.vorpc-sticky-cart__form * { box-sizing: border-box; }

/* Quantity selector */
.vorpc-sticky-cart__qty {
	display: flex;
	align-items: center;
	border: 1px solid var(--vf-line);
	border-radius: var(--vf-r-pill);
	overflow: hidden;
	background: #fff;
	height: 48px;
}
.vorpc-sticky-cart__qty button {
	background: transparent;
	border: 0;
	color: var(--vf-dark);
	font-size: 20px;
	width: 34px;
	height: 100%;
	cursor: pointer;
	transition: background .2s var(--vf-ease);
	font-weight: 800;
}
.vorpc-sticky-cart__qty button:hover { background: var(--vf-bg-soft); color: var(--vf-primary-d); }
.vorpc-sticky-cart__qty input.qty {
	width: 40px;
	height: 100%;
	border: 0;
	background: transparent;
	text-align: center;
	font-weight: 800;
	color: var(--vf-dark);
	font-size: 15px;
	font-family: var(--vf-font);
	padding: 0;
	-moz-appearance: textfield;
}
.vorpc-sticky-cart__qty input.qty::-webkit-outer-spin-button,
.vorpc-sticky-cart__qty input.qty::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

/* Botón — protegido contra reglas del theme (.button { width: 100% } etc.) */
.vorpc-sticky-cart__btn {
	background: var(--vf-primary) !important;
	border: 0 !important;
	color: #fff !important;
	border-radius: var(--vf-r-pill) !important;
	padding: 0 24px !important;
	height: 48px !important;
	min-height: 48px;
	width: auto !important;
	max-width: 100%;
	flex: 0 0 auto;
	font-weight: 800 !important;
	font-family: var(--vf-font) !important;
	font-size: 14px !important;
	letter-spacing: .06em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background .2s var(--vf-ease), transform .2s var(--vf-ease), box-shadow .2s var(--vf-ease);
	box-shadow: 0 6px 18px var(--vf-primary-glow);
	text-decoration: none !important;
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	gap: 8px;
	white-space: nowrap;
	line-height: 1 !important;
	margin: 0 !important;
}
/* Icono del botón — explícito y siempre visible */
.vorpc-sticky-cart__btn .vorpc-sticky-cart__icon,
.vorpc-sticky-cart__btn .dashicons {
	font-family: dashicons !important;
	font-size: 20px !important;
	width: 20px !important;
	height: 20px !important;
	line-height: 1 !important;
	margin: 0 !important;
	display: inline-block !important;
	flex-shrink: 0;
	color: #fff !important;
	vertical-align: middle;
	transform-origin: 50% 60%;
	animation: vorpc-cart-wiggle 4s ease-in-out infinite;
}

/* Wiggle sutil: queda quieto la mayor parte del ciclo y hace un movimiento
   corto cada 4 s — atrae la mirada sin agobiar al usuario. */
@keyframes vorpc-cart-wiggle {
	0%, 80%, 100% { transform: rotate(0); }
	83%           { transform: rotate(-14deg) translateY(-1px); }
	86%           { transform: rotate(12deg)  translateY(-1px); }
	89%           { transform: rotate(-8deg)  translateY(0); }
	92%           { transform: rotate(5deg)   translateY(0); }
	95%           { transform: rotate(-2deg); }
}
.vorpc-sticky-cart__btn:hover .vorpc-sticky-cart__icon,
.vorpc-sticky-cart__btn:focus .vorpc-sticky-cart__icon {
	animation: none;
	transform: scale(1.1);
	transition: transform .25s var(--vf-ease);
}

@media (prefers-reduced-motion: reduce) {
	.vorpc-sticky-cart__btn .vorpc-sticky-cart__icon,
	.vorpc-sticky-cart__btn .dashicons {
		animation: none !important;
	}
}
.vorpc-sticky-cart__btn:hover,
.vorpc-sticky-cart__btn:focus {
	background: var(--vf-primary-d);
	color: #fff;
	transform: translateY(-1px);
	box-shadow: 0 6px 18px var(--vf-primary-glow);
}
.vorpc-sticky-cart__btn:active { transform: translateY(0); }

/* Tablet — el 60 % es demasiado estrecho, ampliamos a 80 % */
@media (max-width: 1199px) {
	.vorpc-sticky-cart__inner { width: 80%; }
}

/* Mobile — ancho completo con padding interno */
@media (max-width: 768px) {
	.vorpc-sticky-cart__inner {
		width: 100%;
		max-width: none;
		padding: 12px 16px;
		gap: 14px;
		min-height: 0;
	}
	.vorpc-sticky-cart__img   { width: 52px; height: 52px; padding: 3px; }
	.vorpc-sticky-cart__title { font-size: 14px; }
	.vorpc-sticky-cart__price { font-size: 17px; }
}

@media (max-width: 540px) {
	.vorpc-sticky-cart__inner {
		padding: 10px 14px;
		gap: 12px;
	}
	.vorpc-sticky-cart__img   { width: 46px; height: 46px; }
	.vorpc-sticky-cart__title { font-size: 13px; }
	.vorpc-sticky-cart__price { font-size: 15px; }
	.vorpc-sticky-cart__btn {
		padding: 0 16px !important;
		font-size: 12px !important;
		height: 44px !important;
		min-height: 44px;
		gap: 6px;
	}
	.vorpc-sticky-cart__btn .vorpc-sticky-cart__icon,
	.vorpc-sticky-cart__btn .dashicons {
		font-size: 18px !important;
		width: 18px !important;
		height: 18px !important;
		display: inline-block !important;
	}
	.vorpc-sticky-cart__btn-text {
		display: inline-block;
		max-width: 80px;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
	}
	.vorpc-sticky-cart__qty { display: none; }
}

/* Ajuste body para que el contenido del producto no quede tapado */
body.vorpc-sticky-cart-shown { padding-bottom: 96px; }
@media (max-width: 540px) {
	body.vorpc-sticky-cart-shown { padding-bottom: 76px; }
}

/* (Offset del body para no tapar contenido — se activa con JS al mostrar la barra) */

/* ==========================================================================
   Product Video — slide en la galería
   ========================================================================== */
.woocommerce-product-gallery__image.vorpc-video-slide {
	background: #000;
}
.woocommerce-product-gallery__image.vorpc-video-slide > a {
	display: block;
	pointer-events: none;          /* sin lightbox sobre el vídeo */
	cursor: default;
}
/* Miniatura fallback (para themes que leen <img>) oculta visualmente */
.vorpc-video-thumb-fallback {
	position: absolute;
	width: 1px;
	height: 1px;
	opacity: 0;
	pointer-events: none;
	z-index: -1;
}
.vorpc-video-aspect {
	position: relative;
	width: 100%;
	height: 0;
	overflow: hidden;
	background: #000;
}
.vorpc-video-aspect > iframe,
.vorpc-video-aspect > video,
.vorpc-video-aspect > .vorpc-video {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	border: 0;
	pointer-events: none;
	object-fit: cover;
}
.vorpc-video-aspect > video {
	width: 100%;
	height: 100%;
}
/* Iframe ampliado para que las barras de control de YouTube/Vimeo queden
   FUERA del recuadro visible (over-scan). Funciona en cualquier aspecto. */
.vorpc-video-aspect > iframe {
	width: 170%;
	height: 170%;
}
.vorpc-video-slide[data-aspect="16-9"] .vorpc-video-aspect > iframe {
	width: 120%;
	height: 120%;
}
.vorpc-video-slide[data-aspect="9-16"] .vorpc-video-aspect > iframe {
	width: 100%;
	height: 200%;
}
/* Overlay transparente — captura clicks y tapa el botón ▶ inicial de YouTube
   mientras carga (microsegundos), evita controles si el user hace hover. */
.vorpc-video-overlay {
	position: absolute;
	inset: 0;
	z-index: 2;
	background: transparent;
	cursor: default;
	pointer-events: auto;
}

/* ==========================================================================
   SKU sutil — más pequeño y opaco en la ficha de producto
   ========================================================================== */
.vorpc-sku,
.product_meta .sku_wrapper,
.product_meta .sku {
	font-family: var(--vf-font);
	font-size: 11px !important;
	font-weight: 500;
	letter-spacing: .04em;
	color: var(--vf-text-mute) !important;
	opacity: .65;
	transition: opacity .2s ease;
}
.vorpc-sku:hover,
.product_meta .sku_wrapper:hover,
.product_meta .sku:hover {
	opacity: 1;
}
.vorpc-sku strong,
.product_meta .sku_wrapper strong {
	font-weight: 600;
	color: var(--vf-text-mute) !important;
	text-transform: uppercase;
	font-size: 10px;
	margin-right: 4px;
}
.product_meta .sku_wrapper .sku {
	font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
	font-size: 11px !important;
	color: var(--vf-text-mute) !important;
}

/* ==========================================================================
   Comparador familia
   ========================================================================== */
.vorpc-family-compare {
	margin: 24px 0;
	overflow-x: auto;
	font-family: var(--vf-font);
}
.vorpc-family-compare table {
	width: 100%;
	border-collapse: collapse;
	font-size: 13px;
	background: var(--vf-card);
	border-radius: var(--vf-r);
	overflow: hidden;
	box-shadow: var(--vf-shadow-xs);
}
.vorpc-family-compare th,
.vorpc-family-compare td {
	padding: 10px 14px;
	border-bottom: 1px solid var(--vf-line);
	text-align: left;
}
.vorpc-family-compare th {
	font-weight: 800;
	color: var(--vf-dark);
	background: var(--vf-bg-soft);
	text-transform: uppercase;
	letter-spacing: .05em;
	font-size: 11px;
}
.vorpc-family-compare tr.is-current td {
	background: var(--vf-primary-l);
	font-weight: 700;
}

/* ==========================================================================
   Progress bars (specs) — 100 % ancho, hijos al 100 %
   ========================================================================== */
.vorpc-progress-bars {
	font-family: var(--vf-font);
	margin: 20px 0;
	display: flex;
	flex-direction: column;
	gap: 14px;
	width: 100%;
}
.vorpc-progress-row {
	width: 100%;
}
.vorpc-progress-bar {
	width: 100%;
	background: var(--vf-base);
	border-radius: var(--vf-r-pill);
	overflow: hidden;
	height: 32px;
	position: relative;
	box-shadow: inset 0 1px 3px rgba(0,39,63,.06);
}
.vorpc-progress-bar .progress {
	background: linear-gradient(90deg, var(--vf-primary) 0%, var(--vf-primary-d) 100%);
	height: 100%;
	min-width: 60px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-weight: 800;
	font-size: 13px;
	border-radius: var(--vf-r-pill);
	transition: width 1.2s var(--vf-ease-out);
	box-shadow: 0 2px 8px var(--vf-primary-glow);
	white-space: nowrap;
	padding: 0 12px;
	box-sizing: border-box;
}
.vorpc-progress-note {
	margin: 6px 0 0 !important;
	font-size: 13px;
	color: var(--vf-text-soft);
}

/* ==========================================================================
   TOP VENTAS · countdown-style block
   ========================================================================== */
.bf-countdown-container {
	background: linear-gradient(135deg, rgba(37,183,145,.08) 0%, #fff 40%, rgba(253,101,113,.08) 100%);
	border: 1px solid rgba(37,183,145,.18);
	border-top: 5px solid var(--vf-primary);
	border-radius: 24px;
	padding: 26px 20px 20px;
	margin: 28px 0;
	text-align: center;
	box-shadow: 0 16px 38px rgba(37,183,145,.10), 0 10px 24px rgba(253,101,113,.08);
	position: relative;
	overflow: hidden;
	font-family: var(--vf-font);
	width: 100%;
	box-sizing: border-box;
}
.bf-countdown-container::before,
.bf-countdown-container::after {
	content: "";
	position: absolute;
	border-radius: 50%;
	z-index: 0;
	pointer-events: none;
}
.bf-countdown-container::before {
	width: 180px;
	height: 180px;
	top: -65px;
	right: -65px;
	background: radial-gradient(circle, rgba(253,101,113,.16) 0%, rgba(253,101,113,.02) 70%);
}
.bf-countdown-container::after {
	width: 180px;
	height: 180px;
	bottom: -70px;
	left: -70px;
	background: radial-gradient(circle, rgba(37,183,145,.16) 0%, rgba(37,183,145,.02) 70%);
}
.bf-countdown-badge,
.bf-countdown-title,
.bf-countdown-timer,
.bf-countdown-note {
	position: relative;
	z-index: 1;
}
.bf-countdown-badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: linear-gradient(135deg, var(--vf-accent) 0%, #ff7f89 100%);
	color: #fff;
	font-size: 12px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .08em;
	padding: 8px 14px;
	border-radius: 999px;
	margin-bottom: 14px;
	box-shadow: 0 10px 24px rgba(253,101,113,.22);
}
.bf-countdown-title {
	margin: 0 0 18px;
	font-weight: 900;
	text-transform: uppercase;
	font-size: 18px;
	letter-spacing: .04em;
	color: #1c5d53;
	line-height: 1.35;
}
.bf-countdown-timer {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 12px;
	margin-top: 6px;
}
.bf-countdown-item {
	background: #fff;
	border: 1px solid rgba(37,183,145,.12);
	border-radius: 18px;
	padding: 16px 10px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-height: 112px;
	box-shadow: 0 8px 22px rgba(37,183,145,.08);
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.bf-countdown-item:hover {
	transform: translateY(-4px);
	box-shadow: 0 14px 28px rgba(37,183,145,.12);
	border-color: rgba(253,101,113,.28);
}
.bf-countdown-item.days    { background: linear-gradient(180deg, rgba(253,101,113,.08) 0%, #fff 100%); }
.bf-countdown-item.hours   { background: linear-gradient(180deg, rgba(37,183,145,.10) 0%, #fff 100%); }
.bf-countdown-item.minutes { background: linear-gradient(180deg, rgba(253,101,113,.06) 0%, #fff 100%); }
.bf-countdown-item.seconds { background: linear-gradient(180deg, rgba(37,183,145,.12) 0%, #fff 100%); animation: bfHighlightPulse 1.8s infinite; }

.bf-countdown-number {
	width: 58px;
	height: 58px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 16px;
	font-size: 28px;
	font-weight: 800;
	line-height: 1;
	margin-bottom: 10px;
}
.bf-countdown-item.days    .bf-countdown-number { background: linear-gradient(135deg, var(--vf-accent) 0%, #ff8d96 100%); color: #fff; box-shadow: 0 10px 20px rgba(253,101,113,.20); }
.bf-countdown-item.hours   .bf-countdown-number { background: linear-gradient(135deg, var(--vf-primary) 0%, #42cfaa 100%); color: #fff; box-shadow: 0 10px 20px rgba(37,183,145,.20); }
.bf-countdown-item.minutes .bf-countdown-number { background: linear-gradient(135deg, var(--vf-accent) 0%, #ff8aa8 100%); color: #fff; box-shadow: 0 10px 20px rgba(253,101,113,.18); }
.bf-countdown-item.seconds .bf-countdown-number { background: linear-gradient(135deg, var(--vf-primary) 0%, #5ad8b7 100%); color: #fff; box-shadow: 0 10px 20px rgba(37,183,145,.22); }

.bf-countdown-label {
	font-weight: 800;
	color: #355d58;
	font-size: 14px;
	line-height: 1.3;
	text-align: center;
}
.bf-countdown-note {
	margin-top: 16px;
	padding: 14px 16px;
	border-radius: 16px;
	background: rgba(255,255,255,.88);
	border: 1px solid rgba(253,101,113,.14);
	font-size: 14px;
	color: #4f5c59;
	font-weight: 500;
	line-height: 1.6;
	box-shadow: 0 6px 18px rgba(253,101,113,.05);
	text-align: left;
}
.bf-countdown-note strong {
	color: var(--vf-accent);
	font-weight: 800;
}
@keyframes bfHighlightPulse {
	0%, 100% { transform: scale(1); }
	50%      { transform: scale(1.03); }
}
@media (max-width: 767px) {
	.bf-countdown-timer { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 480px) {
	.bf-countdown-container { padding: 22px 14px 16px; }
	.bf-countdown-title { font-size: 15px; }
	.bf-countdown-item { min-height: 100px; padding: 14px 8px; }
	.bf-countdown-number { width: 52px; height: 52px; font-size: 24px; }
	.bf-countdown-label { font-size: 13px; }
	.bf-countdown-note { font-size: 13px; }
}

/* ==========================================================================
   Popup "¿Qué es un reacondicionado?"
   ========================================================================== */
.vorpc-reacond-modal[hidden] { display: none; }
.vorpc-reacond-modal {
	position: fixed;
	inset: 0;
	z-index: 100000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
	font-family: var(--vf-font);
	animation: vf-modal-in .25s var(--vf-ease-out);
}
@keyframes vf-modal-in {
	from { opacity: 0; }
	to   { opacity: 1; }
}
.vorpc-reacond-modal__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0,39,63,.62);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	cursor: pointer;
}
.vorpc-reacond-modal__card {
	position: relative;
	background: #fff;
	border-radius: 18px;
	max-width: 720px;
	width: 100%;
	max-height: calc(100vh - 40px);
	display: flex;
	flex-direction: column;
	overflow: hidden;             /* el scroll vive en el __body */
	box-shadow: 0 30px 80px rgba(0,39,63,.4);
	animation: vf-modal-rise .35s var(--vf-ease-out);
}
@keyframes vf-modal-rise {
	from { transform: translateY(20px) scale(.97); opacity: 0; }
	to   { transform: translateY(0) scale(1);     opacity: 1; }
}
.vorpc-reacond-modal__video {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
	background: #000;
	flex-shrink: 0;
	overflow: hidden;
}
.vorpc-reacond-modal__video iframe {
	width: 100%;
	height: 100%;
	border: 0;
	display: block;
}
/* Escudo que tapa el logo de YouTube (esquina superior derecha) */
.vorpc-reacond-modal__video-shield {
	position: absolute;
	top: 0;
	right: 0;
	width: 110px;
	height: 44px;
	background: transparent;
	pointer-events: auto;
	cursor: default;
	z-index: 3;
}
.vorpc-reacond-modal__body {
	padding: 24px 30px 20px;
	color: var(--vf-text);
	line-height: 1.65;
	font-size: 14.5px;
	overflow-y: auto;
	flex: 1 1 auto;
	-webkit-overflow-scrolling: touch;
}
.vorpc-reacond-modal__body h2 {
	margin: 0 0 16px;
	font-size: 22px;
	font-weight: 800;
	color: var(--vf-dark);
	letter-spacing: -.01em;
	line-height: 1.2;
}
.vorpc-reacond-modal__body h3 {
	margin: 18px 0 6px;
	font-size: 15px;
	font-weight: 800;
	color: var(--vf-primary-d);
}
.vorpc-reacond-modal__body p {
	margin: 0 0 10px;
}
.vorpc-reacond-modal__body strong { color: var(--vf-dark); font-weight: 800; }
.vorpc-reacond-modal__body ol,
.vorpc-reacond-modal__body ul {
	margin: 10px 0 14px;
	padding-left: 22px;
}
.vorpc-reacond-modal__body ol li,
.vorpc-reacond-modal__body ul li {
	margin-bottom: 5px;
}

/* Footer con botón "Cerrar" — mismo estilo que [pickup_in_shop] */
.vorpc-reacond-modal__footer {
	flex-shrink: 0;
	text-align: right;
	padding: 12px 22px;
	background: var(--vf-bg-soft);
	border-top: 1px solid var(--vf-base);
}
.vorpc-reacond-modal__close-btn {
	background: #fff;
	border: 1px solid var(--vf-base);
	padding: 8px 22px;
	border-radius: 999px;
	cursor: pointer;
	font-family: var(--vf-font);
	color: var(--vf-dark);
	font-weight: 700;
	font-size: 13px;
	transition: all .2s var(--vf-ease);
}
.vorpc-reacond-modal__close-btn:hover {
	background: var(--vf-dark);
	color: #fff;
	border-color: var(--vf-dark);
}

/* Mobile */
@media (max-width: 768px) {
	.vorpc-reacond-modal { padding: 0; align-items: flex-end; }
	.vorpc-reacond-modal__card {
		max-height: 92vh;
		border-radius: 18px 18px 0 0;
		animation: vf-modal-sheet-up .35s var(--vf-ease-out);
	}
	.vorpc-reacond-modal__video { aspect-ratio: 16 / 10; }
	.vorpc-reacond-modal__body { padding: 20px 18px 16px; font-size: 14px; }
	.vorpc-reacond-modal__body h2 { font-size: 19px; margin-bottom: 12px; }
	.vorpc-reacond-modal__body h3 { font-size: 14px; margin: 14px 0 5px; }
	.vorpc-reacond-modal__body ol,
	.vorpc-reacond-modal__body ul { padding-left: 18px; }
	.vorpc-reacond-modal__footer { padding: 10px 18px; padding-bottom: max(10px, env(safe-area-inset-bottom)); }
	.vorpc-reacond-modal__close-btn { width: 100%; padding: 12px; font-size: 14px; }
}
@keyframes vf-modal-sheet-up {
	from { transform: translateY(100%); }
	to   { transform: translateY(0); }
}

/* ==========================================================================
   Ventajas por condición
   ========================================================================== */
.vorpc-ventajas {
	list-style: none !important;
	margin: 20px 0 !important;
	padding: 0 !important;
	font-family: var(--vf-font);
}
.vorpc-ventajas li {
	display: flex !important;
	align-items: flex-start !important;
	margin: 0 0 10px !important;
	padding: 0 !important;
	line-height: 1.45;
	font-size: 14px;
	color: var(--vf-dark);
}
.vorpc-ventajas .vorpc-ventaja-check {
	color: var(--vf-primary);
	margin-right: 10px;
	font-weight: 800;
	font-size: 18px;
	line-height: 1;
	flex-shrink: 0;
}

/* ==========================================================================
   Precio destacado · pegado entre euros y céntimos, badge -% bien grande
   ========================================================================== */
.vorpc-precio-destacado {
	font-family: var(--vf-font);
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 0;                  /* sin gap por defecto, espaciamos con margin */
	margin: 18px 0;
	line-height: 1;
}
.vorpc-precio-destacado .vp-eur {
	color: var(--vf-accent);
	font-size: 3em;
	font-weight: 800;
	line-height: 1;
	letter-spacing: -0.02em;
	margin: 0;
}
.vorpc-precio-destacado .vp-cent {
	color: var(--vf-accent);
	font-size: 1.5em;
	font-weight: 800;
	margin-right: 14px;       /* separación SÓLO tras los céntimos */
	margin-left: 1px;         /* PEGADO al entero, sin espacio */
}
.vorpc-precio-destacado .vp-old {
	color: var(--vf-text-mute);
	text-decoration: line-through;
	font-size: 1.3em;
	font-weight: 500;
	align-self: baseline;
	margin-right: 14px;
}
.vorpc-precio-destacado .vp-pct {
	background: var(--vf-accent);
	color: #fff;
	padding: 8px 18px;
	border-radius: var(--vf-r-pill);
	font-size: 1.35em;
	font-weight: 800;
	box-shadow: 0 6px 18px rgba(253,101,113,.3);
	line-height: 1;
	align-self: center;
	white-space: nowrap;
}
@media (max-width: 480px) {
	.vorpc-precio-destacado .vp-eur  { font-size: 2.4em; }
	.vorpc-precio-destacado .vp-cent { font-size: 1.3em; }
	.vorpc-precio-destacado .vp-pct  { font-size: 1.15em; padding: 6px 14px; }
	.vorpc-precio-destacado .vp-old  { font-size: 1.1em; }
}

/* ==========================================================================
   COOLMOD aviso
   ========================================================================== */
.vorpc-coolmod-notice {
	font-family: var(--vf-font);
	background: linear-gradient(135deg, var(--vf-primary-l) 0%, #f4fbf9 100%);
	border: 1px solid rgba(37,183,145,.3);
	border-left: 5px solid var(--vf-primary);
	border-radius: var(--vf-r);
	padding: 16px 18px;
	margin: 18px 0;
	display: flex;
	gap: 14px;
	align-items: center;
}
.vorpc-coolmod-notice__icon { font-size: 28px; }
.vorpc-coolmod-notice h4 {
	margin: 0 0 4px;
	color: var(--vf-primary-d);
	font-size: 15px;
	font-weight: 800;
}
.vorpc-coolmod-notice p {
	margin: 0;
	color: var(--vf-dark);
	font-size: 13px;
	line-height: 1.55;
}

/* ==========================================================================
   Cross-selling combo
   ========================================================================== */
.vorpc-combo {
	font-family: var(--vf-font);
	background: var(--vf-card);
	border: 1px solid var(--vf-line);
	border-radius: var(--vf-r-lg);
	margin: 28px 0;
	overflow: hidden;
	box-shadow: var(--vf-shadow-sm);
}
.vorpc-combo__head {
	background: linear-gradient(135deg, var(--vf-bg-soft) 0%, #fff 100%);
	padding: 16px 20px;
	border-bottom: 1px solid var(--vf-line);
}
.vorpc-combo__head h3 { margin: 0; color: var(--vf-dark); font-weight: 800; font-size: 17px; }
.vorpc-combo__head p { margin: 4px 0 0; color: var(--vf-text-soft); font-size: 13px; }
.vorpc-combo__body { padding: 8px 18px; }
.vorpc-combo__row {
	display: grid;
	grid-template-columns: 36px 64px 1fr;
	align-items: center;
	gap: 12px;
	padding: 14px 0;
	border-bottom: 1px solid var(--vf-line);
}
.vorpc-combo__row:last-child { border-bottom: 0; }
.vorpc-combo__plus {
	text-align: center;
	color: var(--vf-text-mute);
	font-weight: 800;
	font-size: 18px;
}
.vorpc-combo__footer {
	background: var(--vf-bg-soft);
	padding: 16px 20px;
	border-top: 1px solid var(--vf-line);
	text-align: center;
}
.vorpc-combo__total {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 12px;
	font-weight: 700;
	color: var(--vf-text-soft);
}
.vorpc-combo__total b {
	font-size: 22px;
	color: var(--vf-dark);
	font-weight: 800;
}
.vorpc-combo__btn {
	width: 100%;
	background: var(--vf-primary);
	color: #fff;
	border: 0;
	padding: 14px;
	font-size: 14px;
	font-weight: 800;
	border-radius: var(--vf-r-pill);
	cursor: pointer;
	font-family: var(--vf-font);
	text-transform: uppercase;
	letter-spacing: .06em;
	transition: all .22s var(--vf-ease);
	box-shadow: 0 4px 14px var(--vf-primary-glow);
}
.vorpc-combo__btn:hover {
	background: var(--vf-primary-d);
	transform: translateY(-2px);
}
.vorpc-combo__btn:disabled { opacity: .7; cursor: wait; transform: none; }

/* ==========================================================================
   Reduce motion accessibility
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: .01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: .01ms !important;
	}
}
