/**
 * Стили архива услуг (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;
}

/* Сетка услуг — 2 колонки */
.sa-services-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--spacing-md);
	align-items: start;
}

/* Ячейка услуги: родитель + опциональный раскрывающийся список подуслуг */
.sa-service-item {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xs);
	min-width: 0;
}

/* Ссылка-услуга — карточка */
.sa-service-link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--spacing-sm);
	padding: var(--spacing-md) var(--spacing-lg);
	background-color: var(--color-bg-lighter);
	border-radius: var(--radius-md);
	text-decoration: none;
	transition: all var(--transition-base);
	min-height: 60px;
}

.sa-service-link:hover {
	background-color: var(--color-bg-light);
}

.sa-service-link__title {
	flex: 1;
	font-family: var(--font-primary);
	font-weight: 500;
	font-size: var(--font-size-base);
	line-height: 1.3;
	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-primary);
	transition: transform var(--transition-base);
}

.sa-service-link:hover .sa-service-link__arrow {
	transform: translateX(4px);
}

/* Подуслуга — с точкой-маркером */
.sa-service-link--child {
	background-color: transparent;
	border: 1px solid var(--color-bg-light);
}

.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-item--extra {
	display: none;
}

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

/* Родитель-toggle: стрелка поворачивается вниз при раскрытии */
.sa-service-link--toggle .sa-service-link__arrow {
	transition: transform var(--transition-base);
}

.sa-service-link--toggle[aria-expanded="true"] .sa-service-link__arrow {
	transform: rotate(90deg);
}

/* При раскрытии гасим hover-смещение, чтобы не конфликтовать с ротацией */
.sa-service-link--toggle[aria-expanded="true"]:hover .sa-service-link__arrow {
	transform: rotate(90deg);
}

/* Контейнер подуслуг */
.sa-service-children {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xs);
	padding: var(--spacing-xs) 0 var(--spacing-xs) var(--spacing-md);
}

.sa-service-children[hidden] {
	display: none;
}

.sa-service-children .sa-service-link--child {
	min-height: 48px;
	padding: var(--spacing-sm) var(--spacing-md);
}

/* Обёртка списка услуг */
.sa-content__services {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-4xl);
}

/* ============================================
   Двухколоночный layout с фото категории
   ============================================ */

.sa-content__container--with-photo {
	flex-direction: row;
	gap: var(--spacing-3xl);
	align-items: flex-start;
}

.sa-content__container--with-photo .sa-content__services {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-4xl);
}

.sa-content__photo {
	width: 420px;
	flex-shrink: 0;
	position: sticky;
	top: var(--spacing-xl);
	border-radius: var(--radius-lg, 12px);
	overflow: hidden;
}

.sa-content__photo img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
}

/* ============================================
   Двухколоночный layout внутри группы (архив)
   ============================================ */

.sa-category-group--with-photo {
	flex-direction: row;
	gap: var(--spacing-3xl);
	align-items: flex-start;
}

.sa-category-group--with-photo .sa-category-group__services {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xl);
}

.sa-category-group__photo {
	width: 420px;
	flex-shrink: 0;
	position: sticky;
	top: var(--spacing-xl);
	border-radius: var(--radius-lg, 12px);
	overflow: hidden;
}

.sa-category-group__photo img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
}

/* «Как лечим» (service_category): фото справа скрываем, услуги в 3 колонки */
#content-services .sa-category-group--with-photo {
	flex-direction: column;
	align-items: stretch;
}

#content-services .sa-category-group__photo {
	display: none;
}

#content-services .sa-services-grid {
	grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 1024px) {
	#content-services .sa-services-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 768px) {
	#content-services .sa-services-grid {
		grid-template-columns: 1fr;
	}
}

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

.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-content--methods {
	padding-top: 0;
}

.sa-category-header--main {
	border-bottom: 2px solid var(--color-bg-light);
}

.sa-content--methods .sa-category-header {
	border-bottom: none;
}

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

/* Пустое состояние */
.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: 1024px) {
	.sa-content__container--with-photo {
		flex-direction: column;
	}

	.sa-content__photo {
		width: 100%;
		max-width: 400px;
		position: static;
	}

	.sa-category-group--with-photo {
		flex-direction: column;
	}

	.sa-category-group__photo {
		width: 100%;
		max-width: 400px;
		position: static;
	}
}

@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-content__photo,
	.sa-category-group__photo {
		display: none;
	}

	.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;
	}

	/* Сетка услуг — 1 колонка на мобилке */
	.sa-services-grid {
		grid-template-columns: 1fr;
	}

	.sa-service-link {
		padding: var(--spacing-14) var(--spacing-md);
		min-height: auto;
	}

	.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;
}
