/* ============================================================
   Ludik — Valores ("Conoce nuestros valores")
   Símbolos de mando (○ □ △ ✕) conectados por línea punteada.
   ============================================================ */

.valores {
	padding-block: var(--sp-4xl);
	background: var(--color-bg);
}

.valores__head {
	text-align: center;
	margin-bottom: var(--sp-3xl);
}
.valores__eyebrow {
	display: inline-flex;
	align-items: center;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--sp-sm);
	font-size: var(--fs-small);
	font-weight: var(--fw-semibold);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--color-text-muted);
	margin-bottom: var(--sp-md);
}
.valores__badge {
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	font-size: var(--fs-caption);
	letter-spacing: 0.08em;
	padding: 0.35em 0.8em;
	border-radius: var(--radius-pill);
	color: var(--c-neutral-900);
	background: var(--color-accent-green);
}
.valores__title {
	font-size: clamp(1.9rem, 4.5vw, 3.25rem);
	letter-spacing: -0.02em;
}
.valores__accent {
	background: var(--gradient-energy);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

/* ---------- Bento de valores ---------- */
.valores__grid {
	list-style: none;
	margin-block: 0; /* no usar margin:0 → pisaría el centrado de .container */
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--sp-lg);
}

.valor {
	position: relative;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	gap: var(--sp-md);
	padding: var(--sp-2xl) var(--sp-xl);
	min-height: 220px;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: 0 1px 2px rgba(57, 61, 100, 0.04);
	transition: transform 0.4s var(--ease-out), box-shadow 0.4s var(--ease-out), border-color 0.4s var(--ease-out);
}
.valor:hover {
	transform: translateY(-6px);
	border-color: transparent;
	box-shadow:
		0 20px 44px rgba(57, 61, 100, 0.13),
		0 10px 26px color-mix(in srgb, var(--v-accent, var(--color-primary)) 22%, transparent);
}

/* Badge de ícono con gradiente del color del valor (símbolo en blanco). */
.valor__symbol {
	position: relative;
	z-index: 1;
	display: grid;
	place-items: center;
	width: 64px;
	height: 64px;
	border-radius: var(--radius-md);
	color: #fff;
	background: linear-gradient(140deg, var(--v-accent, var(--color-primary)) 0%, color-mix(in srgb, var(--v-accent, var(--color-primary)) 75%, #1f2138) 100%);
	box-shadow: 0 8px 20px color-mix(in srgb, var(--v-accent, var(--color-primary)) 32%, transparent);
	transition: transform 0.4s var(--ease-spring), box-shadow 0.4s var(--ease-out);
}
.valor__symbol svg { width: 38px; height: 38px; }
.valor:hover .valor__symbol {
	transform: scale(1.08) rotate(-5deg);
	box-shadow: 0 12px 28px color-mix(in srgb, var(--v-accent, var(--color-primary)) 45%, transparent);
}

.valor__body { position: relative; z-index: 1; }
.valor__title {
	font-size: var(--fs-h3);
	color: var(--color-text);
	margin-bottom: var(--sp-xs);
}
.valor__desc {
	font-size: var(--fs-body);
	line-height: var(--lh-normal);
	color: var(--color-text-muted);
}

/* Versión sobria: ocultamos la etiqueta "PRESS". */
.valor__btn { display: none; }

/* Marca de agua: el símbolo gigante sutil al fondo. */
.valor__watermark {
	position: absolute;
	right: -14px;
	bottom: -26px;
	z-index: 0;
	width: 160px;
	height: 160px;
	color: var(--v-accent, var(--color-primary));
	opacity: 0.07;
	transform: rotate(-8deg);
	transition: transform 0.5s var(--ease-spring), opacity 0.4s var(--ease-out);
	pointer-events: none;
}
.valor__watermark svg { width: 100%; height: 100%; }
.valor:hover .valor__watermark { opacity: 0.13; transform: rotate(4deg) scale(1.08); }

/* Fallback si no hay color-mix (navegadores viejos). */
@supports not (background: color-mix(in srgb, red 10%, transparent)) {
	.valor:hover { box-shadow: var(--shadow-lg); }
	.valor__symbol { background: var(--v-accent, var(--color-primary)); }
}

/* ---------- Responsive (bento 2x2) ---------- */
@media (min-width: 640px) {
	.valores__grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-lg); }
}
@media (min-width: 1024px) {
	.valores__grid { gap: var(--sp-xl); }
}

@media (prefers-reduced-motion: reduce) {
	.valor:hover { transform: none; }
	.valor:hover .valor__symbol,
	.valor:hover .valor__watermark { transform: rotate(-8deg); }
}
