/*
 * ============================================================================
 * URBIFY · engagement.css
 * ============================================================================
 * Estilos de F5: favoritos, comparador, toast, botones flotantes, sparkline.
 *
 * Secciones:
 *   §1. Acciones en tarjeta (corazón + comparar)
 *   §2. Acciones en single (botones grandes pill)
 *   §3. Botones flotantes globales (footer fixed)
 *   §4. Toast notifications
 *   §5. Sparkline historial precio
 *   §6. Tabla comparador
 *   §7. Animación pulse
 *
 * @package Divi_Child_Urbify
 * @since   1.0.0
 */

/* ============================================================================
   §1. ACCIONES EN TARJETA (top-right de la imagen)
   ============================================================================ */

.urb-card__actions {
	position: absolute;
	top: var(--space-3);
	right: var(--space-3);
	z-index: 3;
	display: flex;
	flex-direction: row;
	gap: 6px;
}

.urb-card__action {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	padding: 0;
	background: rgba( 255, 255, 255, 0.95 );
	color: var(--urb-navy-900);
	border: 0;
	border-radius: var(--radius-full);
	cursor: pointer;
	box-shadow: var(--shadow-md);
	transition: background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);
	-webkit-backdrop-filter: blur(6px);
	backdrop-filter: blur(6px);
}

.urb-card__action:hover,
.urb-card__action:focus-visible {
	background: var(--urb-white);
	transform: translateY(-1px);
}

/* Estado activo: corazón relleno verde menta */
.urb-card__action--fav.is-active {
	background: var(--urb-mint-500);
	color: var(--urb-white);
}
.urb-card__action--fav.is-active svg {
	fill: var(--urb-white);
}

/* Estado activo: comparar en navy */
.urb-card__action--compare.is-active {
	background: var(--urb-navy-900);
	color: var(--urb-white);
}

/* ============================================================================
   §2. ACCIONES EN SINGLE (botones grandes con label)
   ============================================================================ */

.urb-single__actions {
	display: inline-flex;
	gap: var(--space-2);
	flex-wrap: wrap;
	margin-left: auto;
}

@media (max-width: 600px) {
	.urb-single__actions {
		margin-left: 0;
		width: 100%;
	}
}

.urb-action-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: 10px 16px;
	background: var(--urb-white);
	color: var(--urb-navy-900);
	border: 1.5px solid var(--urb-gray-200);
	border-radius: var(--radius-full);
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: var(--fw-medium);
	cursor: pointer;
	transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}

.urb-action-btn:hover,
.urb-action-btn:focus-visible {
	border-color: var(--urb-navy-900);
}

.urb-action-btn--fav.is-active {
	background: var(--urb-mint-500);
	color: var(--urb-white);
	border-color: var(--urb-mint-500);
}
.urb-action-btn--fav.is-active svg {
	fill: var(--urb-white);
}

.urb-action-btn--compare.is-active {
	background: var(--urb-navy-900);
	color: var(--urb-white);
	border-color: var(--urb-navy-900);
}

/* ============================================================================
   §3. BOTONES FLOTANTES GLOBALES (bottom-right fixed)
   ============================================================================ */

.urb-floating-actions {
	position: fixed;
	bottom: var(--space-6);
	right: var(--space-6);
	z-index: 999;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.urb-floating-actions[hidden] {
	display: none;
}

.urb-floating-actions__btn {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	background: var(--urb-navy-900);
	color: var(--urb-white);
	border-radius: var(--radius-full);
	box-shadow: var(--shadow-lg);
	text-decoration: none;
	transition: transform var(--transition-fast), background var(--transition-fast);
}

.urb-floating-actions__btn:hover,
.urb-floating-actions__btn:focus-visible {
	transform: translateY(-2px);
	background: var(--urb-navy-700);
}

.urb-floating-actions__btn--fav.has-items {
	background: var(--urb-mint-500);
}
.urb-floating-actions__btn--fav.has-items:hover {
	background: var(--urb-mint-400);
}

.urb-floating-actions__count {
	position: absolute;
	top: -4px;
	right: -4px;
	min-width: 20px;
	height: 20px;
	padding: 0 6px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--urb-gold);
	color: var(--urb-navy-900);
	font-family: var(--font-body);
	font-size: 11px;
	font-weight: var(--fw-bold);
	border-radius: var(--radius-full);
	box-shadow: var(--shadow-sm);
}

.urb-floating-actions__count.is-hidden {
	display: none;
}

@media (max-width: 600px) {
	.urb-floating-actions {
		bottom: var(--space-4);
		right: var(--space-4);
	}
	.urb-floating-actions__btn {
		width: 48px;
		height: 48px;
	}
}

/* ============================================================================
   §4. TOAST NOTIFICATIONS
   ============================================================================ */

.urb-toast-container {
	position: fixed;
	top: var(--space-6);
	right: 50%;
	transform: translateX( 50% );
	z-index: 10000;
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
	pointer-events: none;
	max-width: min( 92vw, 420px );
}

@media (min-width: 720px) {
	.urb-toast-container {
		right: var(--space-6);
		transform: none;
	}
}

.urb-toast {
	padding: 12px 18px;
	background: var(--urb-navy-900);
	color: var(--urb-white);
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: var(--fw-medium);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-lg);
	transform: translateY(-12px);
	opacity: 0;
	transition: opacity var(--transition-base), transform var(--transition-base);
	pointer-events: auto;
}

.urb-toast.is-visible {
	transform: translateY(0);
	opacity: 1;
}

.urb-toast--success { background: var(--urb-mint-500); }
.urb-toast--warning { background: var(--urb-warning); color: var(--urb-navy-900); }
.urb-toast--error   { background: var(--urb-danger); }
.urb-toast--info    { background: var(--urb-navy-900); }

@media (prefers-reduced-motion: reduce) {
	.urb-toast {
		transition: opacity var(--transition-fast);
		transform: none;
	}
}

/* ============================================================================
   §5. SPARKLINE HISTORIAL PRECIO
   ============================================================================ */

.urb-sparkline {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	margin-top: var(--space-3);
	padding: 6px 12px;
	background: var(--urb-gray-50);
	border-radius: var(--radius-md);
	font-size: var(--text-xs);
	font-weight: var(--fw-medium);
	color: var(--urb-gray-600);
}

.urb-sparkline--up   { color: var(--urb-danger); }
.urb-sparkline--down { color: var(--urb-mint-500); }

.urb-sparkline__icon {
	display: inline-flex;
}

.urb-sparkline__svg {
	width: 80px;
	height: 22px;
	flex-shrink: 0;
}

.urb-sparkline__summary {
	color: var(--urb-gray-600);
}

/* ============================================================================
   §6. TABLA COMPARADOR
   ============================================================================ */

.urb-compare {
	margin-top: var(--space-6);
}

.urb-compare__scroll {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.urb-compare__table {
	width: 100%;
	border-collapse: collapse;
	background: var(--urb-white);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
}

.urb-compare__table th,
.urb-compare__table td {
	padding: var(--space-4);
	text-align: left;
	vertical-align: middle;
	border-bottom: 1px solid var(--urb-gray-200);
	font-size: var(--text-sm);
	color: var(--urb-gray-900);
}

.urb-compare__table tr:last-child th,
.urb-compare__table tr:last-child td {
	border-bottom: 0;
}

.urb-compare__head {
	position: relative;
	min-width: 220px;
	padding: var(--space-5);
	background: var(--urb-cream);
	text-align: center;
}

.urb-compare__img {
	display: block;
	width: 100%;
	max-width: 200px;
	aspect-ratio: 4 / 3;
	margin: 0 auto var(--space-3);
	object-fit: cover;
	border-radius: var(--radius-md);
}

.urb-compare__title {
	display: block;
	margin-bottom: 4px;
	font-family: var(--font-display);
	font-size: var(--text-base);
	font-weight: var(--fw-semibold);
	color: var(--urb-navy-900);
	text-decoration: none;
	line-height: var(--leading-snug);
}
.urb-compare__title:hover { color: var(--urb-mint-500); }

.urb-compare__ref {
	display: block;
	font-family: var(--font-mono);
	font-size: var(--text-xs);
	color: var(--urb-gray-400);
}

.urb-compare__remove {
	position: absolute;
	top: var(--space-2);
	right: var(--space-2);
	width: 28px;
	height: 28px;
	background: var(--urb-white);
	color: var(--urb-gray-600);
	border: 1px solid var(--urb-gray-200);
	border-radius: var(--radius-full);
	font-size: 18px;
	line-height: 1;
	cursor: pointer;
	transition: background var(--transition-fast), color var(--transition-fast);
}
.urb-compare__remove:hover {
	background: var(--urb-danger);
	color: var(--urb-white);
	border-color: var(--urb-danger);
}

.urb-compare__rowhead {
	background: var(--urb-gray-50);
	font-weight: var(--fw-semibold);
	color: var(--urb-gray-600);
	font-size: var(--text-xs);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	min-width: 160px;
	white-space: nowrap;
}

.urb-compare__cell {
	font-weight: var(--fw-medium);
}

.urb-compare__best {
	background: var(--urb-mint-100);
	color: var(--urb-mint-500);
	font-weight: var(--fw-bold);
	position: relative;
}

.urb-compare__yes {
	color: var(--urb-mint-500);
	font-weight: var(--fw-bold);
	font-size: var(--text-base);
	text-align: center;
}
.urb-compare__no {
	color: var(--urb-gray-400);
	text-align: center;
}

/* ============================================================================
   §7. ANIMACIÓN PULSE (al añadir/quitar)
   ============================================================================ */

@keyframes urb-pulse {
	0%   { transform: scale( 1 ); }
	50%  { transform: scale( 1.25 ); }
	100% { transform: scale( 1 ); }
}

.urb-pulse {
	animation: urb-pulse 0.4s cubic-bezier( 0.34, 1.56, 0.64, 1 );
}

@media (prefers-reduced-motion: reduce) {
	.urb-pulse { animation: none; }
}

/* ============================================================================
   §8. CARD: DESHABILITAR placeholder antiguo del corazón (estaba display:none)
   ============================================================================ */

.urb-card__fav {
	display: none !important; /* Reemplazado por .urb-card__actions en F5 */
}

/* ============================================================================
   §9. ALERTAS POR EMAIL (F7-C) — botón trigger + modal
   ============================================================================ */

.urb-alerts-trigger-wrap {
	margin-top: var(--space-4);
	padding-top: var(--space-4);
	border-top: 1px solid var(--urb-gray-200);
}

.urb-alerts-trigger {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	width: 100%;
	padding: 10px 14px;
	background: var(--urb-mint-100);
	color: var(--urb-navy-900);
	border: 1.5px solid var(--urb-mint-500);
	border-radius: var(--radius-md);
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: var(--fw-semibold);
	cursor: pointer;
	transition: background var(--transition-fast), color var(--transition-fast);
	text-align: left;
}

.urb-alerts-trigger:hover,
.urb-alerts-trigger:focus-visible {
	background: var(--urb-mint-500);
	color: var(--urb-white);
}
.urb-alerts-trigger:hover svg,
.urb-alerts-trigger:focus-visible svg {
	color: var(--urb-white);
}

.urb-alerts-trigger svg {
	color: var(--urb-mint-500);
	flex-shrink: 0;
	transition: color var(--transition-fast);
}

/* ── Modal ── */

.urb-alerts-modal {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-4);
}

.urb-alerts-modal[hidden] { display: none; }

.urb-alerts-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba( 10, 31, 68, 0.65 );
	-webkit-backdrop-filter: blur( 4px );
	backdrop-filter: blur( 4px );
	animation: urb-fade-in 200ms ease-out;
}

@keyframes urb-fade-in {
	from { opacity: 0; }
	to   { opacity: 1; }
}

.urb-alerts-modal__dialog {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 480px;
	max-height: calc( 100vh - var(--space-8) );
	overflow-y: auto;
	padding: var(--space-8);
	background: var(--urb-white);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-xl);
	animation: urb-modal-slide 250ms cubic-bezier( 0.34, 1.56, 0.64, 1 );
}

@keyframes urb-modal-slide {
	from { opacity: 0; transform: translateY( 12px ) scale( 0.97 ); }
	to   { opacity: 1; transform: translateY( 0 )   scale( 1 ); }
}

.urb-alerts-modal__close {
	position: absolute;
	top: var(--space-3);
	right: var(--space-3);
	width: 36px;
	height: 36px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	background: transparent;
	color: var(--urb-gray-400);
	border: 0;
	border-radius: var(--radius-full);
	cursor: pointer;
	transition: background var(--transition-fast), color var(--transition-fast);
}
.urb-alerts-modal__close:hover,
.urb-alerts-modal__close:focus-visible {
	background: var(--urb-gray-50);
	color: var(--urb-navy-900);
}

.urb-alerts-modal__title {
	margin: 0 0 var(--space-3);
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	font-weight: var(--fw-semibold);
	color: var(--urb-navy-900);
	padding-right: var(--space-8);
}

.urb-alerts-modal__intro {
	margin: 0 0 var(--space-5);
	font-size: var(--text-sm);
	line-height: var(--leading-relaxed);
	color: var(--urb-gray-600);
}

.urb-alerts-modal__criteria {
	margin: 0 0 var(--space-5);
	padding: var(--space-4);
	background: var(--urb-cream);
	border-radius: var(--radius-md);
}

.urb-alerts-modal__criteria h3 {
	margin: 0 0 var(--space-2);
	font-family: var(--font-body);
	font-size: var(--text-xs);
	font-weight: var(--fw-semibold);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wider);
	color: var(--urb-gray-600);
}

.urb-alerts-modal__criteria ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.urb-alerts-modal__criteria li {
	font-size: var(--text-sm);
	color: var(--urb-gray-900);
	line-height: var(--leading-snug);
}

/* ── Form ── */

.urb-alerts-form {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

.urb-alerts-form__field {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

.urb-alerts-form__label {
	font-family: var(--font-body);
	font-size: var(--text-xs);
	font-weight: var(--fw-semibold);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wider);
	color: var(--urb-gray-600);
}

.urb-alerts-form__field input[type="email"] {
	width: 100%;
	padding: 12px 14px;
	font-family: var(--font-body);
	font-size: var(--text-base);
	color: var(--urb-gray-900);
	background: var(--urb-white);
	border: 1.5px solid var(--urb-gray-200);
	border-radius: var(--radius-md);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.urb-alerts-form__field input[type="email"]:focus {
	outline: 0;
	border-color: var(--urb-mint-500);
	box-shadow: 0 0 0 3px rgba( 46, 204, 113, 0.18 );
}

.urb-alerts-form__rgpd {
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
	font-size: var(--text-sm);
	color: var(--urb-gray-600);
	line-height: var(--leading-snug);
}

.urb-alerts-form__rgpd input {
	margin-top: 3px;
	flex-shrink: 0;
}

.urb-alerts-form__rgpd a {
	color: var(--urb-mint-500);
	text-decoration: underline;
	text-underline-offset: 2px;
}

.urb-alerts-form__feedback {
	margin: 0;
	min-height: 1.5em;
	font-size: var(--text-sm);
	font-weight: var(--fw-medium);
}

.urb-alerts-form__feedback--success {
	color: var(--urb-mint-500);
}

.urb-alerts-form__feedback--error {
	color: var(--urb-danger);
}

@media (prefers-reduced-motion: reduce) {
	.urb-alerts-modal__backdrop,
	.urb-alerts-modal__dialog {
		animation: none;
	}
}
