/* ═══════════════════════════════════════════════════════════
   09-ANIMATIONS.CSS — Reveal, marquee, counters, pulse
   ═══════════════════════════════════════════════════════════ */

/* ── Reveal on Scroll ──────────────────────────────────── */

.evolve-reveal {
	opacity: 0;
	transform: translateY(40px);
	transition: opacity 600ms cubic-bezier(0.22, 1, 0.36, 1), transform 600ms cubic-bezier(0.22, 1, 0.36, 1);
}

.evolve-reveal[data-direction="left"] {
	transform: translateX(-40px);
}

.evolve-reveal[data-direction="right"] {
	transform: translateX(40px);
}

.evolve-reveal.is-visible {
	opacity: 1;
	transform: translate(0, 0);
}

/* ── Marquee ───────────────────────────────────────────── */

.evolve-marquee {
	position: relative;
	overflow: hidden;
	padding-block: 2rem;
}

.evolve-marquee::before,
.evolve-marquee::after {
	content: "";
	position: absolute;
	z-index: 2;
	inset-block: 0;
	width: 6rem;
	pointer-events: none;
}

.evolve-marquee::before {
	left: 0;
	background: linear-gradient(90deg, var(--evolve-background), transparent);
}

.evolve-marquee::after {
	right: 0;
	background: linear-gradient(270deg, var(--evolve-background), transparent);
}

.evolve-marquee-track {
	display: flex;
	align-items: center;
	width: max-content;
	white-space: nowrap;
	animation: evolve-marquee 30s linear infinite;
}

.evolve-marquee:hover .evolve-marquee-track {
	animation-play-state: paused;
}

.evolve-logo-word {
	flex: 0 0 auto;
	margin-inline: 2rem;
	color: color-mix(in srgb, var(--evolve-muted) 40%, transparent);
	font-family: "Space Grotesk", Inter, sans-serif;
	font-size: 1.125rem;
	font-weight: 700;
	transition: color 160ms ease;
}

.evolve-logo-word:hover {
	color: var(--evolve-muted);
}

.evolve-logo-image {
	flex: 0 0 auto;
	width: 9rem;
	height: 4.5rem;
	margin-inline: 1.5rem;
	object-fit: contain;
	opacity: 0.72;
	transition: opacity 160ms ease, transform 160ms ease;
}

.evolve-logo-image:hover {
	opacity: 1;
	transform: translateY(-1px);
}

@keyframes evolve-marquee {
	to { transform: translateX(-50%); }
}

/* ── Counters / Stats ──────────────────────────────────── */

.evolve-stat {
	text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.evolve-stat-number {
	margin-bottom: 0.5rem;
	background: var(--evolve-gradient);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	font-family: "Space Grotesk", Inter, sans-serif;
	font-size: clamp(2.25rem, 4vw, 3rem);
	font-weight: 700;
	line-height: 1;
}

.evolve-stat-desc {
	font-size: 0.75rem;
	color: var(--evolve-muted);
	margin-top: 0.75rem;
	line-height: 1.625;
	max-width: 220px;
	margin-inline: auto;
}

.evolve-stat > p {
	font-size: 0.875rem;
	color: var(--evolve-muted);
	margin: 0;
}

/* ── Live Badge ────────────────────────────────────────── */

.evolve-live-badge {
	display: inline-flex;
	align-items: center;
	padding: 0.25rem 0.75rem;
	border-radius: 999px;
	background: var(--evolve-gradient);
	color: #fff;
	font-size: 0.75rem;
	font-weight: 600;
	line-height: 1rem;
}

.evolve-event-meta {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 0.75rem;
}

.evolve-event-meta-time {
	font-size: 0.875rem;
	color: var(--evolve-muted);
}
