/**
 * Variant CSS: faq--categorized-tabs
 *
 * Static category tab row above a grouped <details> Q/A list. The active tab is
 * pre-set (no JS) so the section stays fully editable in Gutenberg; tabs read as
 * navigation chrome that organises a large FAQ thematically. Distinct from the
 * plain accordion, single column and 2-col grid. Text stays --ink (polarity-aware);
 * kicker, active tab, em and the +/- toggle take --accent. Part of the `faq` role.
 */

body.aibt-universal .universal-faq--categorized-tabs {
	background: var(--background);
	color: var(--ink);
	padding-block: calc(clamp(3rem, 7vw, 5rem) * var(--density, 1));
}

/* Intro. */
body.aibt-universal .universal-faq--categorized-tabs .universal-faq__intro {
	margin-bottom: clamp(1.4rem, 3vw, 2rem);
	text-align: center;
}

/* Restore WP constrained-layout centering for the centered intro elements. */
body.aibt-universal .universal-faq--categorized-tabs .universal-faq__intro .has-text-align-center {
	margin-inline: auto !important;
}

body.aibt-universal .universal-faq--categorized-tabs .universal-faq__kicker {
	font-family: var(--font-body) !important;
	font-size: var(--text-xs) !important;
	font-weight: 600 !important;
	letter-spacing: var(--tracking-widest) !important;
	text-transform: uppercase !important;
	color: var(--accent) !important;
	margin: 0 auto var(--space-sm) auto !important;
}

body.aibt-universal .universal-faq--categorized-tabs .universal-faq__headline {
	font-family: var(--font-display) !important;
	color: var(--ink) !important;
	margin: 0 auto !important;
}

body.aibt-universal .universal-faq--categorized-tabs .universal-faq__headline em {
	color: var(--accent) !important;
	font-style: italic;
}

/* Category tab row — pills, the active one filled with accent. */
body.aibt-universal .universal-faq--categorized-tabs .universal-faq__tabs {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: clamp(0.4rem, 1.4vw, 0.7rem);
	max-width: 720px;
	margin: 0 auto clamp(1.6rem, 3.5vw, 2.4rem) auto;
}

body.aibt-universal .universal-faq--categorized-tabs .universal-faq__tab {
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: 600;
	letter-spacing: 0.01em;
	line-height: 1;
	color: var(--ink);
	background: color-mix(in srgb, var(--ink) 5%, transparent);
	border: 1px solid color-mix(in srgb, var(--ink) 14%, transparent);
	border-radius: var(--decor-radius-pill, 999px);
	padding: 0.6em 1.15em;
	cursor: default;
	transition: border-color var(--duration-fast, 0.18s) var(--ease-default, ease),
		background-color var(--duration-fast, 0.18s) var(--ease-default, ease);
}

/* Active tab — accent fill, text on the accent surface. */
body.aibt-universal .universal-faq--categorized-tabs .universal-faq__tab.is-active {
	color: var(--cta-text-primary, var(--on-dark, #fff));
	background: var(--accent);
	border-color: var(--accent);
}

/* Group label between the tabs and the list. */
body.aibt-universal .universal-faq--categorized-tabs .universal-faq__group-label {
	font-family: var(--font-body) !important;
	font-size: var(--text-xs) !important;
	font-weight: 600 !important;
	letter-spacing: var(--tracking-wide) !important;
	text-transform: uppercase !important;
	color: color-mix(in srgb, var(--ink) 55%, transparent) !important;
	max-width: 760px;
	margin: 0 auto var(--space-md) auto !important;
	padding-bottom: var(--space-sm);
	border-bottom: 1px solid color-mix(in srgb, var(--ink) 12%, transparent);
}

/* List of grouped Q/A as native <details>. */
body.aibt-universal .universal-faq--categorized-tabs .universal-faq__list {
	display: flex;
	flex-direction: column;
	gap: 0;
	max-width: 760px;
	margin-inline: auto;
}

body.aibt-universal .universal-faq--categorized-tabs .universal-faq__item {
	border-bottom: 1px solid color-mix(in srgb, var(--ink) 12%, transparent);
	padding: var(--space-md) 0;
}

/* Summary (question) row. */
body.aibt-universal .universal-faq--categorized-tabs .universal-faq__q {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	list-style: none;
	cursor: pointer;
	font-family: var(--font-display) !important;
	font-size: clamp(1.05rem, 2vw, 1.25rem) !important;
	font-weight: 500 !important;
	line-height: 1.3 !important;
	color: var(--ink) !important;
}

body.aibt-universal .universal-faq--categorized-tabs .universal-faq__q::-webkit-details-marker {
	display: none;
}

/* Hover + keyboard focus on the interactive summary (a11y). */
body.aibt-universal .universal-faq--categorized-tabs .universal-faq__q:hover {
	color: var(--accent) !important;
}
body.aibt-universal .universal-faq--categorized-tabs .universal-faq__q:focus-visible {
	outline: 2px solid var(--accent);
	outline-offset: 3px;
	border-radius: var(--decor-radius, 4px);
}

/* +/- toggle. */
body.aibt-universal .universal-faq--categorized-tabs .universal-faq__q::after {
	content: "+";
	flex: 0 0 auto;
	font-family: var(--font-body);
	font-size: 1.5rem;
	font-weight: 400;
	line-height: 1;
	color: var(--accent);
	transition: transform var(--duration-fast, 0.18s) var(--ease-default, ease);
}

body.aibt-universal .universal-faq--categorized-tabs .universal-faq__item[open] .universal-faq__q::after {
	content: "\2212"; /* minus sign */
}

/* Answer. */
body.aibt-universal .universal-faq--categorized-tabs .universal-faq__a {
	font-family: var(--font-body) !important;
	font-size: var(--text-base) !important;
	line-height: var(--leading-relaxed) !important;
	color: var(--ink) !important;
	opacity: 0.78;
	margin-top: var(--space-sm);
	max-width: 64ch;
}

/* Mobile: cap letter-spacing on the uppercase labels and tighten rhythm. */
@media (max-width: 640px) {
	body.aibt-universal .universal-faq--categorized-tabs .universal-faq__kicker,
	body.aibt-universal .universal-faq--categorized-tabs .universal-faq__group-label {
		letter-spacing: 0 !important;
	}
}

@media (max-width: 781px) {
	body.aibt-universal .universal-faq--categorized-tabs .universal-faq__tab {
		font-size: var(--text-xs);
		padding: 0.55em 0.95em;
	}
	body.aibt-universal .universal-faq--categorized-tabs .universal-faq__item {
		padding: var(--space-sm) 0;
	}
	body.aibt-universal .universal-faq--categorized-tabs .universal-faq__q {
		font-size: var(--text-lg) !important;
	}
}

/* Respect users who prefer reduced motion. */
@media (prefers-reduced-motion: reduce) {
	body.aibt-universal .universal-faq--categorized-tabs .universal-faq__tab,
	body.aibt-universal .universal-faq--categorized-tabs .universal-faq__q,
	body.aibt-universal .universal-faq--categorized-tabs .universal-faq__q::after {
		transition: none;
	}
}
