/**
 * Стили архива услуг (archive-service, taxonomy-service_category)
 * Использует переменные из variables.css
 */

/* ============================================
   Hero
   ============================================ */

.sa-hero {
	padding: var(--spacing-3xl) 0 var(--spacing-xl);
}

.sa-hero__container {
	max-width: var(--container-max-width);
	margin: 0 auto;
	padding: 0 var(--spacing-4xl);
}

/* Заголовок + счётчик на одной строке */
.sa-hero__heading {
	display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
}

.sa-hero__count {
	font-family: var(--font-primary);
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	margin: 0;
	white-space: nowrap;
	flex-shrink: 0;
}

.sa-hero__title {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: var(--font-size-4xl);
	line-height: var(--line-height-tight);
	color: var(--color-primary);
	margin: 0;
	text-transform: uppercase;
}

.sa-hero__desc {
	font-family: var(--font-primary);
	font-weight: 500;
	font-size: var(--font-size-md);
	line-height: var(--line-height-relaxed);
	color: var(--color-text-muted);
	margin: 0;
	max-width: 600px;
}

/* ============================================
   Табы фильтрации
   ============================================ */

.sa-filters {
	padding: 0 0 var(--spacing-3xl);
}

.sa-filters__container {
	max-width: var(--container-max-width);
	margin: 0 auto;
	padding: 0 var(--spacing-4xl);
}

/* Глобальные переключатели: Услуги / Что лечим */
.sa-global-tabs {
	display: flex;
	gap: var(--spacing-3xl);
	margin-bottom: var(--spacing-lg);
	border-bottom: 2px solid var(--color-bg-light);
}

.sa-global-tabs__tab {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: var(--font-size-lg);
	color: var(--color-text-muted);
	text-decoration: none;
	padding-bottom: var(--spacing-sm);
	border-bottom: 3px solid transparent;
	margin-bottom: -2px;
	transition: all var(--transition-base);
	cursor: pointer;
}

.sa-global-tabs__tab:hover {
	color: var(--color-primary);
}

.sa-global-tabs__tab.is-active {
	color: var(--color-primary);
	border-bottom-color: var(--color-accent);
}

/* Подтабы */
.sa-tabs {
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-xs);
}

/* Скрытые подтабы (переключаются глобальными табами) */
.sa-tabs--hidden {
	display: none;
}

.sa-tabs__tab {
	display: inline-flex;
	align-items: center;
	padding: var(--spacing-xs) var(--spacing-lg);
	border: 2px solid var(--color-gray);
	border-radius: var(--radius-pill);
	background: var(--color-white);
	font-family: var(--font-primary);
	font-weight: 500;
	font-size: var(--font-size-sm);
	line-height: var(--line-height-relaxed);
	color: var(--color-primary);
	text-decoration: none;
	cursor: pointer;
	transition: all var(--transition-base);
	white-space: nowrap;
}

.sa-tabs__tab:hover {
	border-color: var(--color-primary);
}

.sa-tabs__tab.is-active {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
}

/* ============================================
   Сетка услуг
   ============================================ */

.sa-content {
	padding: 0 0 var(--spacing-4xl);
}

.sa-content__container {
	max-width: var(--container-max-width);
	margin: 0 auto;
	padding: 0 var(--spacing-4xl);
	display: flex;
	flex-direction: column;
	gap: var(--spacing-4xl);
}

/* Группа категории */
.sa-category-group {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xl);
}

.sa-category-group.is-hidden {
	display: none;
}

.sa-category-header {
	display: flex;
	align-items: baseline;
	gap: var(--spacing-md);
	border-bottom: 2px solid var(--color-bg-light);
	padding-bottom: var(--spacing-md);
}

.sa-category-title {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: var(--font-size-2xl);
	line-height: var(--line-height-tight);
	color: var(--color-primary);
	margin: 0;
}

.sa-category-title a {
	color: inherit;
	text-decoration: none;
	transition: color var(--transition-base);
}

.sa-category-title a:hover {
	color: var(--color-accent);
}

.sa-category-count {
	font-family: var(--font-primary);
	font-weight: 500;
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	white-space: nowrap;
}

/* Список услуг — каждая на своей строке */
.sa-services-grid {
	display: flex;
	flex-direction: column;
	gap: 0;
}

/* Ссылка-услуга */
.sa-service-link {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
	padding: var(--spacing-sm) 0;
	text-decoration: none;
	border-bottom: 1px solid var(--color-bg-light);
	transition: color var(--transition-base);
}

.sa-service-link:hover {
	color: var(--color-accent);
}

.sa-service-link__title {
	flex: 1;
	font-family: var(--font-primary);
	font-weight: 500;
	font-size: var(--font-size-base);
	line-height: var(--line-height-relaxed);
	color: var(--color-primary);
	transition: color var(--transition-base);
}

.sa-service-link:hover .sa-service-link__title {
	color: var(--color-accent);
}

.sa-service-link__arrow {
	flex-shrink: 0;
	color: var(--color-gray);
	transition: color var(--transition-base);
}

.sa-service-link:hover .sa-service-link__arrow {
	color: var(--color-accent);
}

/* Подуслуга — с точкой-маркером и отступом */
.sa-service-link--child {
	padding-left: var(--spacing-md);
}

.sa-service-link__dot {
	flex-shrink: 0;
	color: var(--color-text-muted);
	font-size: var(--font-size-sm);
}

.sa-service-link--child .sa-service-link__title {
	font-size: var(--font-size-sm);
}

/* Скрытые ссылки (>26) */
.sa-service-link--extra {
	display: none;
}

.sa-category-group.is-expanded .sa-service-link--extra {
	display: flex;
}

/* ============================================
   Кнопка «Показать все»
   ============================================ */

.sa-load-more {
	display: flex;
	justify-content: center;
	padding-top: var(--spacing-lg);
}

.sa-load-more__btn {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-xs);
	padding: var(--spacing-sm) var(--spacing-xl);
	border: 2px solid var(--color-gray);
	border-radius: var(--radius-pill);
	background: var(--color-white);
	font-family: var(--font-primary);
	font-weight: 500;
	font-size: var(--font-size-base);
	color: var(--color-primary);
	cursor: pointer;
	transition: all var(--transition-base);
}

.sa-load-more__btn:hover {
	border-color: var(--color-primary);
}

.sa-load-more__btn svg {
	transition: transform var(--transition-base);
}

/* Скрываем кнопку когда всё раскрыто */
.sa-category-group.is-expanded .sa-load-more {
	display: none;
}

/* Пустое состояние */
.sa-empty {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	color: var(--color-text-muted);
	text-align: center;
	padding: var(--spacing-4xl) 0;
	margin: 0;
}

/* ============================================
   Адаптивность
   ============================================ */

@media (max-width: 1200px) {
	.sa-hero__container,
	.sa-filters__container,
	.sa-content__container {
		padding: 0 var(--spacing-3xl);
	}
}

@media (max-width: 768px) {
	.sa-hero {
		padding: var(--spacing-xl) 0 var(--spacing-md);
	}

	.sa-hero__container,
	.sa-filters__container,
	.sa-content__container {
		padding: 0 var(--spacing-md);
	}

	.sa-hero__title {
		font-size: var(--font-size-2xl);
	}

	.sa-hero__desc {
		font-size: var(--font-size-base);
	}

	/* Табы — горизонтальный скролл */
	.sa-tabs {
		flex-wrap: nowrap;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		padding-bottom: var(--spacing-xs);
	}

	.sa-tabs::-webkit-scrollbar {
		display: none;
	}

	/* Список услуг на мобилке */
	.sa-service-link__title {
		font-size: var(--font-size-sm);
	}

	.sa-service-link--child .sa-service-link__title {
		font-size: var(--font-size-xs);
	}

	.sa-category-title {
		font-size: var(--font-size-xl);
	}

	.sa-content__container {
		gap: var(--spacing-3xl);
	}

	.sa-filters {
		padding-bottom: var(--spacing-xl);
	}
}

/* ============================================
   Переопределение CTA на страницах услуг
   ============================================ */

.services-archive-page .cta-section {
	padding: 0 var(--spacing-4xl) 0;
	background-color: #ffffff;
}
