/**
 * Church Ministries page — tab panel layouts (single + two-column),
 * meta rows, FAQ accordion. Matches static reference layout.
 */

.ministries-cta-row {
	text-align: center;
	margin: 2rem 0 0;
}

.ministries-tabs { margin-top: 3rem; }

/* === MINISTRY DETAIL (single panel layout) === */
.ministry-detail {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}

@media (min-width: 768px) {
	.ministry-detail {
		flex-direction: row;
		align-items: center;
		gap: 2.5rem;
	}
	.ministry-detail .ministry-image {
		flex: 0 0 40%;
		max-width: 40%;
		align-self: center;
	}
	.ministry-detail .ministry-image img {
		width: 100%;
		height: 300px;
		object-fit: cover;
	}
	.ministry-detail .ministry-content {
		flex: 1;
	}
}

.ministry-image {
	width: 100%;
	border-radius: var(--fbc-radius);
	overflow: hidden;
	box-shadow: var(--fbc-shadow-sm);
	display: flex;
	justify-content: center;
}

.ministry-image img {
	width: 100%;
	height: auto;
	max-height: 400px;
	object-fit: cover;
	object-position: center;
}

/* === HEADINGS === */
.ministry-content h2,
.column h3 {
	color: var(--fbc-primary);
	position: relative;
	padding-bottom: 0.75rem;
}

.ministry-content h2::after,
.column h3::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	height: 3px;
	background-color: var(--fbc-gold);
}

.ministry-content h2 {
	font-size: 2rem;
	margin-bottom: 1rem;
}

.ministry-content h2::after { width: 60px; }

.column h3 {
	font-size: 1.5rem;
	margin-bottom: 0.75rem;
}

.column h3::after { width: 40px; }

/* === DETAIL META ROW === */
.ministry-details {
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
	margin: 1.5rem 0;
	padding: 1rem;
	background: var(--fbc-bg);
	border-radius: var(--fbc-radius);
}

.detail-item {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.detail-item i {
	color: var(--fbc-gold);
	font-size: 1.2rem;
	width: 20px;
	text-align: center;
}

/* === DESCRIPTION === */
.ministry-description {
	line-height: 1.8;
	font-size: 1.05rem;
}

.ministry-description p {
	margin-bottom: 1rem;
}

.ministry-description p:last-child {
	margin-bottom: 0;
}

/* === TWO-COLUMN PANELS (Children's, Master Clubs) === */
.two-column-ministry {
	display: flex;
	flex-direction: column;
	gap: 2rem;
	margin-top: 1.5rem;
}

.column {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

@media (min-width: 768px) {
	.two-column-ministry {
		flex-direction: row;
		align-items: flex-start;
		gap: 2.5rem;
	}
}

/* === FAQ SECTION === */
.faq-section {
	margin: 2.5rem auto 0;
	max-width: var(--fbc-container);
}

.faq-card {
	background: var(--fbc-card-bg);
	border-radius: var(--fbc-radius);
	box-shadow: var(--fbc-shadow-md);
	padding: 1.5rem;
}

.faq-card h2 {
	margin-bottom: 1rem;
	font-size: 1.85rem;
	color: var(--fbc-primary);
}

.faq-list {
	display: grid;
	gap: 0.75rem;
}

.faq-list details {
	background: var(--fbc-bg);
	border: 1px solid #e9eef5;
	border-radius: 8px;
	padding: 0.75rem 1rem;
	transition: border-color var(--fbc-transition);
}

.faq-list details[open] {
	border-color: var(--fbc-gold);
}

.faq-list summary {
	cursor: pointer;
	font-weight: 700;
	font-family: var(--fbc-font-heading);
	color: var(--fbc-primary);
	list-style: none;
	outline: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
}

.faq-list summary::-webkit-details-marker { display: none; }

.faq-list summary::after {
	content: '\f078';
	font-family: 'Font Awesome 6 Free';
	font-weight: 900;
	color: var(--fbc-gold);
	font-size: 0.85rem;
	transition: transform var(--fbc-transition);
}

.faq-list details[open] summary::after {
	transform: rotate(180deg);
}

.faq-list p {
	margin: 0.5rem 0 0;
	color: var(--fbc-text);
	line-height: 1.7;
}
