/**
 * Archive Layout — Shop & category page structure styles.
 *
 * Covers the archive hero, two-column sidebar+content layout,
 * toolbar row, and bottom sections.
 *
 * @package SunmaintainV2
 */

/* ── Archive Hero ── */

.sm-archive-hero {
	padding: 1.5rem 0 1rem;
	margin-bottom: 0.5rem;
}

.sm-archive-hero__title {
	font-family: Georgia, 'Times New Roman', serif;
	font-size: clamp( 1.8rem, 3.5vw, 2.6rem );
	font-weight: 800;
	color: #1a1a1a;
	margin: 0 0 0.35rem;
}

.sm-archive-hero__description {
	font-family: 'Avenir Next', sans-serif;
	font-size: 0.95rem;
	color: #555;
	line-height: 1.6;
	max-width: 720px;
	margin: 0;
}

.sm-archive-hero__description p {
	margin: 0.25rem 0;
}

/* ── Two-column layout: sidebar + content ── */

.sm-archive-layout {
	display: flex;
	gap: 2rem;
	align-items: flex-start;
}

.sm-archive-layout__sidebar {
	width: 260px;
	flex-shrink: 0;
}

.sm-archive-layout__content {
	flex: 1;
	min-width: 0;
}

/* ── Toolbar: results count + sorting ── */

.sm-archive-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.5rem 0 1rem;
	gap: 1rem;
	flex-wrap: wrap;
}

.sm-archive-toolbar .woocommerce-result-count {
	font-family: 'Avenir Next', sans-serif;
	font-size: 0.85rem;
	color: #666;
	margin: 0;
}

.sm-archive-toolbar .woocommerce-ordering {
	margin: 0;
}

.sm-archive-toolbar .woocommerce-ordering select {
	font-family: 'Avenir Next', sans-serif;
	font-size: 0.85rem;
	padding: 0.4rem 2rem 0.4rem 0.6rem;
	border: 1px solid #d7cfc3;
	border-radius: 4px;
	background: #fff;
	color: #333;
	cursor: pointer;
}

.sm-archive-toolbar .woocommerce-ordering select:focus {
	border-color: #083d8f;
	outline: none;
	box-shadow: 0 0 0 2px rgba( 8, 61, 143, 0.15 );
}

/* ── Bottom sections ── */

.sm-archive-bottom {
	margin-top: 3rem;
}

/* Service value row */
.sm-archive-service-row {
	display: grid;
	grid-template-columns: repeat( 4, 1fr );
	gap: 1.5rem;
	padding: 2rem 0;
	border-top: 1px solid #e8e4de;
	border-bottom: 1px solid #e8e4de;
	margin-bottom: 2.5rem;
}

.sm-archive-service-item {
	text-align: center;
}

.sm-archive-service-item__icon {
	font-size: 1.8rem;
	margin-bottom: 0.5rem;
	display: block;
}

.sm-archive-service-item__title {
	font-family: 'Avenir Next', sans-serif;
	font-size: 0.9rem;
	font-weight: 800;
	color: #1a1a1a;
	margin: 0 0 0.25rem;
}

.sm-archive-service-item__text {
	font-family: 'Avenir Next', sans-serif;
	font-size: 0.8rem;
	color: #666;
	line-height: 1.5;
	margin: 0;
}

/* Education section */
.sm-archive-education {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2.5rem;
	padding: 2rem 0;
}

.sm-archive-education__heading {
	font-family: Georgia, 'Times New Roman', serif;
	font-size: 1.4rem;
	font-weight: 800;
	color: #1a1a1a;
	margin: 0 0 0.75rem;
}

.sm-archive-education__text {
	font-family: 'Avenir Next', sans-serif;
	font-size: 0.9rem;
	color: #444;
	line-height: 1.7;
}

.sm-archive-education__faq details {
	border-bottom: 1px solid #e8e4de;
	padding: 0.75rem 0;
}

.sm-archive-education__faq summary {
	font-family: 'Avenir Next', sans-serif;
	font-size: 0.88rem;
	font-weight: 700;
	color: #1a1a1a;
	cursor: pointer;
	list-style: none;
	padding-right: 1.5rem;
	position: relative;
}

.sm-archive-education__faq summary::-webkit-details-marker {
	display: none;
}

.sm-archive-education__faq summary::after {
	content: '+';
	position: absolute;
	right: 0;
	top: 0;
	font-weight: 400;
	color: #888;
}

.sm-archive-education__faq details[ open ] summary::after {
	content: '−';
}

.sm-archive-education__faq details p {
	font-family: 'Avenir Next', sans-serif;
	font-size: 0.85rem;
	color: #555;
	line-height: 1.6;
	margin: 0.5rem 0 0;
}

/* FAQ grid */
.sm-archive-faq-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	padding: 2rem 0;
	border-top: 1px solid #e8e4de;
}

.sm-archive-faq-grid details {
	padding: 1rem 1.5rem 1rem 0;
	border-bottom: 1px solid #e8e4de;
}

.sm-archive-faq-grid details:nth-child( odd ) {
	padding-right: 1.5rem;
	border-right: 1px solid #e8e4de;
}

.sm-archive-faq-grid details:nth-child( even ) {
	padding-left: 1.5rem;
}

.sm-archive-faq-grid summary {
	font-family: 'Avenir Next', sans-serif;
	font-size: 0.88rem;
	font-weight: 700;
	color: #1a1a1a;
	cursor: pointer;
	list-style: none;
	padding-right: 1.5rem;
	position: relative;
}

.sm-archive-faq-grid summary::-webkit-details-marker {
	display: none;
}

.sm-archive-faq-grid summary::after {
	content: '+';
	position: absolute;
	right: 0;
	top: 0;
	font-weight: 400;
	color: #888;
}

.sm-archive-faq-grid details[ open ] summary::after {
	content: '−';
}

.sm-archive-faq-grid details p {
	font-family: 'Avenir Next', sans-serif;
	font-size: 0.85rem;
	color: #555;
	line-height: 1.6;
	margin: 0.5rem 0 0;
}

.sm-archive-faq-grid__title {
	font-family: Georgia, 'Times New Roman', serif;
	font-size: 1.4rem;
	font-weight: 800;
	color: #1a1a1a;
	margin: 0 0 0.5rem;
	text-align: center;
	grid-column: 1 / -1;
}

/* ── Responsive ── */

@media ( max-width: 960px ) {
	.sm-archive-layout {
		flex-direction: column;
		gap: 0;
	}

	.sm-archive-layout__sidebar {
		width: 100%;
	}

	.sm-archive-service-row {
		grid-template-columns: repeat( 2, 1fr );
	}

	.sm-archive-education {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}

	.sm-archive-faq-grid {
		grid-template-columns: 1fr;
	}

	.sm-archive-faq-grid details:nth-child( odd ) {
		border-right: none;
		padding-right: 0;
	}

	.sm-archive-faq-grid details:nth-child( even ) {
		padding-left: 0;
	}
}

@media ( max-width: 600px ) {
	.sm-archive-hero {
		padding: 1rem 0 0.75rem;
	}

	.sm-archive-service-row {
		grid-template-columns: 1fr 1fr;
		gap: 1rem;
	}
}
