/*
 * SECCIONES — hero, media-text, logos, testimonios, FAQ y banda CTA.
 */

/* ---- Hero ----------------------------------------------------------- */
.hero {
	padding-block-start: var(--space-8);
}

.hero__grid {
	display: grid;
	gap: var(--space-7);
	align-items: center;
}

@media (min-width: 64em) {
	.hero__grid {
		grid-template-columns: 1.1fr 0.9fr;
	}
}

.hero__eyebrow {
	display: inline-block;
	font-size: var(--text-sm);
	font-weight: var(--weight-semibold);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--color-primary);
	margin-block-end: var(--space-4);
}

.hero__title {
	font-size: var(--text-display);
}

.hero__text {
	margin-block-start: var(--space-5);
	font-size: var(--text-lg);
	color: var(--color-ink-soft);
	max-width: 36rem;
}

.hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	margin-block-start: var(--space-6);
}

.hero__media img {
	border-radius: var(--radius-lg);
}

/* ---- Media + texto alterno ------------------------------------------ */
.media-text__row {
	display: grid;
	gap: var(--space-6);
	align-items: center;
	padding-block: var(--space-7);
}

.media-text__row + .media-text__row {
	border-block-start: 1px solid var(--color-line);
}

@media (min-width: 64em) {
	.media-text__row {
		grid-template-columns: 1fr 1fr;
		gap: var(--space-8);
	}

	/* Alternancia sin clases: las filas pares invierten columnas. */
	.media-text__row:nth-child(even) .media-text__media {
		order: 2;
	}
}

.media-text__media img,
.media-text__placeholder {
	width: 100%;
	border-radius: var(--radius-lg);
}

.media-text__placeholder {
	aspect-ratio: 4 / 3;
	background:
		linear-gradient(135deg, var(--color-surface), color-mix(in oklch, var(--color-primary) 12%, var(--color-surface)));
	border: 1px solid var(--color-line);
}

.media-text__text {
	margin-block-start: var(--space-4);
	color: var(--color-ink-soft);
}

.media-text__content .btn {
	margin-block-start: var(--space-5);
}

/* ---- Logos (marquee CSS) --------------------------------------------- */
.logos__title {
	text-align: center;
	font-size: var(--text-sm);
	font-weight: var(--weight-semibold);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--color-ink-soft);
	margin-block-end: var(--space-6);
}

.logos__marquee {
	overflow: hidden;
	mask-image: linear-gradient(to right, transparent, black 12%, black 88%, transparent);
}

.logos__track {
	display: flex;
	width: max-content;
	/* Velocidad constante: la duración crece con el número de logos. */
	animation: logos-scroll calc(var(--marquee-items, 5) * 6s) linear infinite;
}

.logos__marquee:hover .logos__track {
	animation-play-state: paused;
}

.logos__list {
	display: flex;
	align-items: center;
	gap: var(--space-8);
	padding-inline-end: var(--space-8);
}

.logos__name {
	font-size: var(--text-xl);
	font-weight: var(--weight-semibold);
	/* ink-soft pleno: 4.5:1 también en móvil, donde el texto baja de 24px. */
	color: var(--color-ink-soft);
	white-space: nowrap;
}

.logos__img {
	max-height: 44px;
	width: auto;
	opacity: 0.65;
}

/* ---- Testimonios ------------------------------------------------------ */
.testimonials__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(22rem, 100%), 1fr));
	gap: var(--space-5);
}

.testimonial {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
	padding: var(--space-6);
	background-color: var(--color-base);
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
}

.testimonial__mark {
	color: var(--color-accent);
}

.testimonial__quote p {
	font-size: var(--text-lg);
	line-height: var(--leading-snug);
}

.testimonial__author {
	margin-block-start: auto;
	display: flex;
	flex-direction: column;
}

.testimonial__name {
	font-weight: var(--weight-semibold);
}

.testimonial__role {
	font-size: var(--text-sm);
	color: var(--color-ink-soft);
}

/* ---- FAQ (details/summary nativo) ------------------------------------- */
.faq__item {
	border-block-end: 1px solid var(--color-line);
}

.faq__item:first-child {
	border-block-start: 1px solid var(--color-line);
}

.faq__question {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-4);
	padding-block: var(--space-5);
	font-weight: var(--weight-semibold);
	font-size: var(--text-lg);
	cursor: pointer;
	list-style: none;
}

.faq__question::-webkit-details-marker {
	display: none;
}

.faq__question .icon {
	flex-shrink: 0;
	color: var(--color-primary);
	transition: rotate var(--duration-base) var(--ease-out);
}

.faq__item[open] .faq__question .icon {
	rotate: 180deg;
	color: var(--color-accent);
}

.faq__answer {
	padding-block-end: var(--space-5);
	color: var(--color-ink-soft);
	max-width: 60ch;
}

/* ---- Banda CTA ---------------------------------------------------------- */
.cta-band {
	background-color: var(--color-primary-strong);
	color: var(--color-on-dark);
}

.cta-band__inner {
	text-align: center;
	max-width: 46rem;
}

.cta-band__title {
	color: var(--color-on-dark);
	font-size: var(--text-2xl);
}

.cta-band__text {
	margin-block-start: var(--space-4);
	color: var(--color-on-dark-soft);
	font-size: var(--text-lg);
}

.cta-band .btn {
	margin-block-start: var(--space-6);
}
