/**
 * PX Accordion (FAQ) - Static CSS
 *
 * Vertical list of collapsible question/answer items.
 * Closed: dark text + down-arrow icon.
 * Open: blue text + up-arrow icon + answer panel.
 */

/* ==========================================================================
   Section
   ========================================================================== */

.px-accordion {
	padding: var(--space-d3) 0;
}

/* ==========================================================================
   Container (centered, max-width)
   ========================================================================== */

.px-accordion__container {
	display: flex;
	flex-direction: column;
	gap: var(--space-d1);

	max-width: var(--row-width);
	width: 100%;

	margin-left: auto;
	margin-right: auto;
}

/* ==========================================================================
   Item
   ========================================================================== */

.px-accordion__item {
	display: flex;
	flex-direction: column;
}

/* ==========================================================================
   Question heading + button
   ========================================================================== */

.px-accordion__heading {
	margin: 0;
}

.px-accordion__question {
	display: flex;
	align-items: flex-start;
	gap: var(--space-d05);

	text-align: left;
	color: var(--text-base);

	padding: var(--space-d025) 0;
	margin: 0;

	width: 100%;

	border: none;

	background: none;

	cursor: pointer;

	transition: color var(--duration-normal) var(--ease-smooth);
}

.px-accordion__question:hover {
	color: var(--action);
}

/* Open state: blue text */
.is-open .px-accordion__question {
	color: var(--action);
}

/* Focus ring */
.px-accordion__question:focus-visible {
	outline: solid 3px var(--btn-focus-ring);
	outline-offset: 2px;
}

/* ==========================================================================
   Question text
   ========================================================================== */

.px-accordion__question-text {
	font-family: var(--font-display);
	font-size: var(--text-d1);
	font-weight: var(--weight-medium);
	line-height: var(--lh-normal);
	letter-spacing: var(--ls-tight);
	text-decoration: underline;
	text-underline-offset: 0.15em;
}

.px-accordion__question:hover .px-accordion__question-text {
	text-decoration: none;
}

/* Open state: blue text */
.is-open .px-accordion__question-text {
	text-decoration: none;
}

/* ==========================================================================
   Icon (arrow-down, rotates 180° on open)
   ========================================================================== */

.px-accordion__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;

	width: var(--space-d1);
	height: var(--space-d1);

	margin-top: var(--space-d025);

	transition: transform var(--duration-normal) var(--ease-smooth);
}

.px-accordion__icon svg {
	width: 100%;
	height: 100%;
	fill: currentColor;
}

/* Open: rotate the arrow 180° */
.is-open .px-accordion__icon {
	transform: rotate(180deg);
}

/* ==========================================================================
   Answer panel (animated height via CSS grid 0fr → 1fr)
   ========================================================================== */

.px-accordion__answer-wrap {
	display: grid;
	grid-template-rows: 0fr;
	transition: grid-template-rows var(--duration-normal) var(--ease-smooth);
}

.is-open .px-accordion__answer-wrap {
	grid-template-rows: 1fr;
}

.px-accordion__answer {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: var(--space-d075);

	padding-left: calc(var(--space-d1) + var(--space-d05));

	overflow: hidden;
	visibility: hidden;

	transition: padding var(--duration-normal) var(--ease-smooth),
	            visibility 0s linear var(--duration-normal);
}

.is-open .px-accordion__answer {
	visibility: visible;

	padding-top: var(--space-d05);
	padding-bottom: var(--space-d025);
	
	transition: padding var(--duration-normal) var(--ease-smooth),
	            visibility 0s linear 0s;
}

/* ==========================================================================
   Answer body text
   ========================================================================== */

.px-accordion__answer-text p {
	margin: 0 0 var(--space-d05) 0;
}

.px-accordion__answer-text p:last-child {
	margin-bottom: 0;
}

/* ==========================================================================
   Answer CTA button
   ========================================================================== */

.px-accordion__answer-btn {
	margin-top: var(--space-d025);
}