/* ==========================================================================
   wb-faqs — FAQ Accordion Widget
   BEM: wb-faqs (block)
   ========================================================================== */

/* Block */
.wb-faqs {
	/* Background controlled by Elementor */
	position: relative;
	width: 100%;
}

.wb-faqs__container {
	max-width: var(--container-container-large, 75rem);
	margin-left: auto;
	margin-right: auto;
	padding: 0 var(--page-padding-padding-global, 1.25rem);
	width: 100%;
	box-sizing: border-box;
}

/* Header */
.wb-faqs__header {
	text-align: center;
	margin-bottom: var(--padding-section-medium, 5rem);
	max-width: 50rem;
	margin-left: auto;
	margin-right: auto;
}

/* Title spacing - applied via wb-global-styles.css (--spacing-12x) */

.wb-faqs__description {
	max-width: 40rem;
	margin-left: auto;
	margin-right: auto;
}

/* List */
.wb-faqs__list {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wb-spacing-sm, 1rem); /* Mantener gap: CSS Grid estándar */
	max-width: 50rem;
	margin-left: auto;
	margin-right: auto;
}

/* Accordion Item */
.wb-faqs__accordion {
	cursor: pointer;
	transition: all var(--wb-header-animation-transition, 0.3s) ease;
	border: var(--_ui-styles---stroke--divider-width, 1px) solid transparent;
	border-radius: var(--radius-small);
}

/* Question Button */
.wb-faqs__question {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	padding: var(--wb-spacing-sm, 1rem);
	background: transparent;
	border: none;
	cursor: pointer;
	font-family: inherit;
	font-size: inherit;
	color: inherit;
}

/* Override Elementor Kit button styles for FAQ buttons */
.wb-faqs__question:hover,
.wb-faqs__question:focus,
.wb-faqs__question:focus-visible {
	background-color: transparent !important;
	color: inherit !important;
	outline: none;
}

.wb-faqs__question:focus-visible {
	outline: 2px solid var(--e-global-color-accent, currentColor);
	outline-offset: 2px;
}

.wb-faqs__q {
	flex: 1;
}

/* Icon (+/x toggle) */
.wb-faqs__icon {
	transition: transform var(--wb-header-animation-transition, 0.3s) ease;
	display: flex;
	align-items: center;
	justify-content: center;
	width: var(--wb-spacing-md, 1.5rem);
	height: var(--wb-spacing-md, 1.5rem);
	flex-shrink: 0;
	margin-left: var(--wb-spacing-sm, 1rem);
}

.wb-faqs__icon svg {
	width: 100%;
	height: 100%;
	transition: color var(--wb-header-animation-transition, 0.3s) ease;
}

.wb-faqs__accordion--open .wb-faqs__icon {
	transform: rotate(45deg);
}

/* Answer (collapsed by default) */
.wb-faqs__answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height var(--wb-header-animation-transition, 0.3s) ease, padding var(--wb-header-animation-transition, 0.3s) ease;
	padding: 0 var(--wb-spacing-sm, 1rem);
}

.wb-faqs__accordion--open .wb-faqs__answer {
	padding: 0 var(--wb-spacing-sm, 1rem) var(--wb-spacing-sm, 1rem);
}

/* Footer */
.wb-faqs__footer {
	text-align: center;
	margin-top: var(--padding-section-medium, 5rem);
	max-width: 50rem;
	margin-left: auto;
	margin-right: auto;
}

.wb-faqs__bottom-title {
	margin-bottom: 0.5rem;
}

.wb-faqs__bottom-description {
	margin-bottom: 2rem;
}

.wb-faqs__buttons.button-group {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}

.wb-faqs__buttons.button-group > *:not(:last-child) {
	margin-right: var(--wb-spacing-sm, 1rem);
}

/* ---------- Responsive ---------- */

@media (max-width: 991px) {
	.wb-faqs__container {
		padding: var(--padding-section-small, 3rem) var(--page-padding-padding-global, 1.25rem);
	}

	.wb-faqs__header {
		margin-bottom: var(--padding-section-small, 3rem);
	}

	.wb-faqs__footer {
		margin-top: var(--padding-section-small, 3rem);
	}
}

@media (max-width: 767px) {
	.wb-faqs__container {
		padding: var(--padding-section-small, 2rem) var(--page-padding-padding-global, 1rem);
	}

	.wb-faqs__header {
		margin-bottom: 2.5rem;
	}

	.wb-faqs__question {
		padding: 0.875rem;
	}

	.wb-faqs__accordion--open .wb-faqs__answer {
		padding: 0 0.875rem 0.875rem;
	}

	.wb-faqs__answer {
		padding: 0 0.875rem;
	}

	.wb-faqs__footer {
		margin-top: 2.5rem;
	}
}

/* ---------- Elementor Editor Fixes ---------- */

.elementor-editor-active .wb-faqs {
	overflow: visible;
	display: block;
	width: 100%;
}

.elementor-editor-active .wb-faqs__container {
	position: relative;
	z-index: 1;
	display: block;
	width: 100%;
	max-width: var(--container-container-large, 75rem);
	margin-left: auto;
	margin-right: auto;
}

.elementor-editor-active .wb-faqs__list {
	display: grid;
	grid-template-columns: 1fr;
	width: 100%;
}

.elementor-editor-active .wb-faqs__accordion {
	position: relative;
	z-index: 1;
	display: block;
	width: 100%;
}
