/* ── Freq Accordion (fqa) ──────────────────────────────────────────────
   Prefijo: .fqa-   Clase raíz: .wp-block-aluna-freq-accordion
   CSS variables inyectadas desde render.php:
     --fqa-height:   altura del acordeón (px)  — default 620px
     --fqa-overlay:  opacidad del overlay (0–1) — default 0.78
──────────────────────────────────────────────────────────────────────── */

/*
 * Breakout del root-padding de TT5 (useRootPaddingAwareAlignments).
 * Misma técnica que mosaic-gallery: compensar el padding del body para
 * que el bloque ocupe el 100% del viewport cuando tiene align:full.
 */
.wp-block-aluna-freq-accordion.alignfull,
.wp-block-aluna-freq-accordion.alignwide {
	margin-top:    0 !important;
	margin-bottom: 0 !important;
	margin-left:  calc(-1 * var(--wp--style--root--padding-left,  clamp(30px, 5vw, 50px))) !important;
	margin-right: calc(-1 * var(--wp--style--root--padding-right, clamp(30px, 5vw, 50px))) !important;
	width: calc(
		100% +
		var(--wp--style--root--padding-left,  clamp(30px, 5vw, 50px)) +
		var(--wp--style--root--padding-right, clamp(30px, 5vw, 50px))
	) !important;
	max-width: none !important;
}

/* ── Wrapper ── */
.fqa {
	background: var(--wp--preset--color--base, #FBF5EC);
	padding-bottom: 0;
	position: relative;
}

/* ── Acordeón (desktop) ── */
.fqa-asym {
	display: flex;
	height: var(--fqa-height, 620px);
	gap: 3px;
}

/* ── Panel ── */
.fqa-panel {
	position: relative;
	overflow: hidden;
	cursor: pointer;
	flex: 1;
	transition: flex 0.55s cubic-bezier(0.4, 0, 0.2, 1);
	-webkit-tap-highlight-color: transparent;
}

.fqa-panel.open {
	flex: 2.9;
}

/* ── Imagen ── */
.fqa-panel__img {
	position: absolute;
	inset: 0;
	transition: transform 0.55s ease;
}

.fqa-panel:hover .fqa-panel__img,
.fqa-panel.open .fqa-panel__img {
	transform: scale(1.04);
}

.fqa-panel__img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	filter: brightness(0.82) saturate(0.92);
}

/* Placeholder cuando no hay imagen */
.fqa-panel__placeholder {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, #2C2420 0%, #6B5C4E 100%);
}

/* ── Overlay ── */
.fqa-panel__ov {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to top,
		rgba(28, 24, 20, 1)   0%,
		rgba(28, 24, 20, 0.3) 55%,
		rgba(28, 24, 20, 0)   100%
	);
	opacity: var(--fqa-overlay, 0.78);
	transition: opacity 0.4s;
}

.fqa-panel.open .fqa-panel__ov,
.fqa-panel:hover .fqa-panel__ov {
	opacity: min(1, calc(var(--fqa-overlay, 0.78) * 1.15));
}

/* ── Contenido ── */
.fqa-panel__cont {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 32px 28px;
	transform: translateY(58px);
	transition: transform 0.42s cubic-bezier(0.4, 0, 0.2, 1);
}

.fqa-panel.open .fqa-panel__cont,
.fqa-panel:hover .fqa-panel__cont {
	transform: translateY(0);
}

/* ── Número ── */
.fqa-panel__num {
	font-family: var(--aluna-font-display);
	font-size: var(--aluna-text-sm);
	font-weight: 400;
	letter-spacing: 4px;
	color: rgba(242, 230, 208, 0.52);
	margin-bottom: 8px;
}

/* ── Nombre (semántica: h3) ── */
.fqa-panel__name {
	font-family: var(--aluna-font-display);
	font-weight: 400;
	font-size: 52px;
	color: var(--aluna-white);
	line-height: 0.95;
	margin-bottom: 8px;
}

/* ── Frase (semántica: p) ── */
.fqa-panel__quote {
	font-family: var(--aluna-font-display);
	font-style: italic;
	font-size: var(--aluna-text-md);
	color: rgba(196, 169, 107, 0.95);
	margin-bottom: 14px;
}

/* ── Descripción (semántica: p, visible solo en panel abierto) ── */
.fqa-panel__desc {
	font-family: var(--aluna-font-body);
	font-size: var(--aluna-text-sm);
	font-weight: 300;
	color: rgba(242, 230, 208, 0.85);
	line-height: var(--aluna-lh-normal);
	margin-bottom: 20px;
	opacity: 0;
	transition: opacity 0.28s ease;
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
}

.fqa-panel.open .fqa-panel__desc,
.fqa-panel:hover .fqa-panel__desc {
	opacity: 1;
}

/* ── Link ── */
.fqa-panel__link {
	font-family: var(--aluna-font-body);
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--aluna-cream);
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	transition: gap 0.2s;
	white-space: nowrap;
}

.fqa-panel__link::after {
	content: '→';
}

.fqa-panel.open .fqa-panel__link,
.fqa-panel:hover .fqa-panel__link {
	gap: 13px;
}

/* ── Flechas (solo visibles en móvil) ── */
.fqa-arr {
	display: none;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 46px;
	height: 46px;
	align-items: center;
	justify-content: center;
	background: rgba(28, 24, 20, 0.42);
	border: 1px solid rgba(254, 252, 248, 0.28);
	color: #F2E6D0;
	font-size: 20px;
	cursor: pointer;
	z-index: 10;
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
	transition: background 0.25s, border-color 0.25s, opacity 0.3s;
}

.fqa-arr:hover {
	background: rgba(28, 24, 20, 0.72);
	border-color: rgba(254, 252, 248, 0.55);
}

.fqa-arr--prev { left: 10px; }
.fqa-arr--next { right: 10px; }

.fqa-arr.hide {
	opacity: 0;
	pointer-events: none;
}

/* ── Dots (solo visibles en móvil) ── */
.fqa-dots {
	display: none;
	justify-content: center;
	gap: 8px;
	padding: 14px 0 0;
}

.fqa-dot {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--wp--preset--color--accent-4, rgba(196, 169, 107, 0.5));
	cursor: pointer;
	transition: background 0.25s, transform 0.25s;
}

.fqa-dot.on {
	background: var(--wp--preset--color--accent-3, #8B7E70);
	transform: scale(1.45);
}

/* ── Accesibilidad: sin animaciones ── */
@media (prefers-reduced-motion: reduce) {
	.fqa-panel,
	.fqa-panel__img,
	.fqa-panel__ov,
	.fqa-panel__cont,
	.fqa-panel__desc,
	.fqa-panel__link {
		transition: none;
	}
}

/* ── Responsive — Tablet (2×2 grid) ── */
@media (max-width: 960px) {
	.fqa-asym {
		display: grid;
		grid-template-columns: 1fr 1fr;
		height: auto;
		gap: 3px;
	}

	.fqa-panel {
		height: clamp(200px, 36vw, 320px);
	}

	.fqa-panel.open {
		height: clamp(200px, 36vw, 320px);
		flex: unset;
	}

	.fqa-panel__cont {
		transform: translateY(0) !important;
		padding: 14px 16px;
	}

	.fqa-panel__desc {
		opacity: 1 !important;
		font-size: 14px;
		-webkit-line-clamp: 2;
		line-clamp: 2;
	}

	.fqa-panel:hover .fqa-panel__img {
		transform: none;
	}
}

/* ── Responsive — Móvil (scroll carousel) ── */
@media (max-width: 768px) {
	.fqa-asym {
		display: flex !important;
		overflow-x: auto;
		scroll-snap-type: x mandatory;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		-ms-overflow-style: none;
		padding: 0 0px 16px;
		scroll-padding-left: 20px;
		gap: 10px;
		height: auto;
	}

	.fqa-asym::-webkit-scrollbar {
		display: none;
	}

	/* Cada panel ocupa casi todo el ancho */
	.fqa-panel,
	.fqa-panel.open {
		flex: 0 0 88vw !important;
		min-width: 0;
		scroll-snap-align: start;
		height: 440px;
	}

	/* En móvil el contenido siempre visible */
	.fqa-panel__cont {
		transform: translateY(0) !important;
		padding: 28px 22px;
	}

	.fqa-panel__desc {
		opacity: 1 !important;
		font-size: 15px;
		-webkit-line-clamp: 3;
		line-clamp: 3;
	}

	.fqa-panel__name {
		font-size: clamp(30px, 8vw, 42px);
	}

	/* Mostrar flechas y dots */
	.fqa-arr {
		display: flex;
		top: 95%;
	}

	.fqa-dots {
		display: flex;
	}
}

@media (max-width: 480px) {
	.fqa-panel,
	.fqa-panel.open {
		flex: 0 0 92vw !important;
		height: 420px;
	}
}
