/* ============================================================================
   FAQ PAGE STYLES
   Mobile-first responsive design with BEM naming
   ========================================================================= */

/* ============================================================================
   FAQ Page - Hero Section with Background Image
   Implementation Date: 2025-11-03
   Dependencies: ComponentHeadline component
   ============================================================================ */

/* Hero section container with responsive spacing */
.faq-page__hero {
	padding: var(--spacing-8) 0; /* 2rem = 32px mobile (320-639px) */
}

/* Responsive: Tablet (≥640px) */
@media (min-width: 640px) {
	.faq-page__hero {
		padding: var(--spacing-12) 0; /* 3rem = 48px tablet (640-1023px) */
	}
}

/* Responsive: Desktop (≥1024px) */
@media (min-width: 1024px) {
	.faq-page__hero {
		padding: var(--spacing-16) 0; /* 4rem = 64px desktop (1024px+) */
	}
}

/* Background image modifier - Mobile first (320-639px) */
.faq-page__hero--with-image {
	background-image: url('/images/faq/faq-hero.webp');
	background-size: cover; /* Scale image proportionally to cover entire section */
	background-position: center; /* Center focal point */
	background-repeat: no-repeat;
	min-height: 250px; /* Mobile: 250px min-height */
	position: relative; /* Position context for overlay */
	/* Padding removed - handled by overlay element */
}

/* Semi-transparent overlay for text contrast */
.faq-page__hero-overlay {
	background-color: rgba(102, 22, 82, 0.5); /* 50% wine red (--color-primary-500) */
	padding: var(--spacing-8) 0; /* 2rem = 32px mobile vertical padding */
	min-height: inherit; /* Inherit min-height from parent (250px mobile) */
	display: flex;
	align-items: center; /* Vertically center ComponentHeadline */
}

/* Override ComponentHeadline text colors to white for readability */
.faq-page__hero--with-image .component-headline__tagline,
.faq-page__hero--with-image .component-headline__heading {
	color: var(--color-neutral-white); /* White text on dark overlay */
}

/* Override ComponentHeadline SVG divider color to white */
.faq-page__hero--with-image .component-headline__divider-svg {
	fill: var(--color-neutral-white); /* White SVG on dark overlay */
}

/* Responsive: Tablet (640-1023px) */
@media (min-width: 640px) {
	.faq-page__hero--with-image {
		min-height: 350px; /* Tablet: 350px min-height */
	}

	.faq-page__hero-overlay {
		padding: var(--spacing-12) 0; /* 3rem = 48px tablet vertical padding */
	}
}

/* Responsive: Desktop (1024px+) */
@media (min-width: 1024px) {
	.faq-page__hero--with-image {
		min-height: 400px; /* Desktop: 400px min-height */
	}

	.faq-page__hero-overlay {
		padding: var(--spacing-16) 0; /* 4rem = 64px desktop vertical padding */
	}
}

/* ============================================================================
   FAQ Page - Table of Contents Section
   ============================================================================ */

.faq-page__toc {
	background-color: var(--color-neutral-white);
	padding: var(--spacing-12) 0;
	border-bottom: 1px solid var(--color-neutral-200);
}

.faq-page__toc-heading {
	font-family: var(--font-heading);
	font-size: var(--font-size-2xl);
	font-weight: var(--font-weight-semibold);
	color: var(--color-primary-900);
	margin-bottom: var(--spacing-6);
	text-align: center;
}

.faq-page__toc-nav {
	max-width: var(--max-width-4xl);
	margin: 0 auto;
}

.faq-page__toc-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--spacing-4);
}

@media (min-width: 640px) {
	.faq-page__toc-list {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.faq-page__toc-list {
		grid-template-columns: repeat(3, 1fr);
	}
}

.faq-page__toc-item {
	margin: 0;
}

.faq-page__toc-link {
	display: block;
	padding: var(--spacing-4) var(--spacing-6);
	background-color: var(--color-neutral-50);
	border: 1px solid var(--color-neutral-200);
	border-radius: var(--border-radius-md);
	color: var(--color-primary-900);
	text-decoration: none;
	font-family: var(--font-body);
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-medium);
	transition: all var(--transition-normal);
	text-align: center;
}

.faq-page__toc-link:hover {
	background-color: var(--color-primary-50);
	border-color: var(--color-primary-500);
	color: var(--color-primary-700);
	transform: translateY(-2px);
	box-shadow: var(--shadow-sm);
}

/* ============================================================================
   FAQ Page - Content Section
   ============================================================================ */

.faq-page__content {
	background-color: var(--color-neutral-50);
	padding: var(--spacing-16) 0;
}

.faq-page__category-header {
	font-family: var(--font-heading);
	font-size: var(--font-size-3xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary-900);
	margin-top: var(--spacing-16);
	margin-bottom: var(--spacing-8);
	padding-bottom: var(--spacing-4);
	border-bottom: 2px solid var(--color-primary-500);
}

.faq-page__category-header:first-child {
	margin-top: 0;
}

/* Link styling within FAQ answers */
.faq-page__link {
	color: var(--color-primary-700);
	text-decoration: underline;
	transition: color var(--transition-normal);
}

.faq-page__link:hover {
	color: var(--color-primary-500);
}

/* Responsive adjustments */
@media (max-width: 767px) {
	.faq-page__toc {
		padding: var(--spacing-8) 0;
	}

	.faq-page__toc-heading {
		font-size: var(--font-size-xl);
		margin-bottom: var(--spacing-4);
	}

	.faq-page__content {
		padding: var(--spacing-12) 0;
	}

	.faq-page__category-header {
		font-size: var(--font-size-2xl);
		margin-top: var(--spacing-12);
		margin-bottom: var(--spacing-6);
	}
}
