/* =============================================================
   PIARNYA — Service Page
   Зависит от: variables.css, base.css
   ============================================================= */

/* ══ HERO ════════════════════════════════════════════════════ */
.svc-hero {
	background: var(--color-surface);
	border-bottom: 1px solid var(--color-border);
	padding: var(--sp-12) 0 var(--sp-16);
}

.svc-hero__inner {
	display: flex;
	flex-direction: column;
	gap: var(--sp-8);
}

/* Breadcrumb */
.svc-breadcrumb ol {
	display: flex;
	align-items: center;
	gap: var(--sp-2);
	flex-wrap: nowrap;
	overflow: hidden;
}

.svc-breadcrumb li {
	display: flex;
	align-items: center;
	gap: var(--sp-2);
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	white-space: nowrap;
}

.svc-breadcrumb li:last-child {
	overflow: hidden;
	text-overflow: ellipsis;
}

.svc-breadcrumb a {
	color: var(--color-text-muted);
	transition: color var(--dur-base) var(--ease);
}

.svc-breadcrumb a:hover {
	color: var(--color-primary);
}

.svc-breadcrumb [aria-current="page"] {
	color: var(--color-text);
	font-weight: 600;
}

/* Контент */
.svc-hero__content {
	max-width: 720px;
	display: flex;
	flex-direction: column;
	gap: var(--sp-5);
}

.svc-hero__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	border-radius: var(--radius-lg);
	background: var(--gradient-brand);
	color: #fff;
	flex-shrink: 0;
}

.svc-hero__title {
	font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl));
	color: var(--color-text);
	line-height: var(--leading-tight);
	margin: 0;
}

.svc-hero__tagline {
	font-size: var(--text-lg);
	color: var(--color-text-muted);
	line-height: var(--leading-normal);
	max-width: 60ch;
}

.svc-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sp-4);
	padding-top: var(--sp-3);
}

/* ══ СПИСОК ПОДУСЛУГ ═════════════════════════════════════════ */
.svc-list {
	background: var(--color-bg);
}

.svc-items {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--sp-5);
	list-style: none;
}

.svc-item {
	display: flex;
	flex-direction: column;
	gap: var(--sp-5);
	padding: var(--sp-8);
	border-radius: var(--radius-xl);
	border: 1.5px solid var(--color-border);
	background: var(--color-bg);
	transition:
		border-color var(--dur-base) var(--ease),
		box-shadow   var(--dur-base) var(--ease),
		transform    var(--dur-base) var(--ease);
}

.svc-item:hover {
	border-color: transparent;
	background:
		linear-gradient(var(--color-bg), var(--color-bg)) padding-box,
		var(--gradient-brand) border-box;
	border: 1.5px solid transparent;
	box-shadow: var(--shadow-lg);
	transform: translateY(-3px);
}

.svc-item__body {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: var(--sp-3);
}

.svc-item__title {
	font-size: var(--text-lg);
	font-weight: 700;
	color: var(--color-text);
	line-height: var(--leading-snug);
	transition: color var(--dur-base) var(--ease);
}

.svc-item:hover .svc-item__title {
	color: var(--color-primary);
}

.svc-item__desc {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	line-height: var(--leading-normal);
	max-width: none;
}

.svc-item__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sp-3);
	padding-top: var(--sp-4);
	border-top: 1px solid var(--color-border);
	margin-top: auto;
}

.svc-item__price {
	font-family: var(--font-display);
	font-size: var(--text-base);
	font-weight: 700;
	background: var(--gradient-brand);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	color: transparent;
}

.svc-item__cta {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-1);
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--color-text-subtle);
	min-height: 44px;
	padding-inline: var(--sp-1);
	transition: color var(--dur-base) var(--ease), gap var(--dur-base) var(--ease);
}

.svc-item__cta svg {
	transition: transform var(--dur-base) var(--ease);
}

.svc-item:hover .svc-item__cta {
	color: var(--color-primary);
	gap: var(--sp-2);
}

.svc-item:hover .svc-item__cta svg {
	transform: translateX(2px);
}

/* ══ ШАГИ ════════════════════════════════════════════════════ */
.svc-steps {
	background: var(--color-surface);
}

.svc-steps__list {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	position: relative;
	list-style: none;
}

/* Коннектор */
.svc-steps__list::before {
	content: '';
	position: absolute;
	top: 28px;
	left: calc(100% / 8);
	right: calc(100% / 8);
	height: 2px;
	background: var(--gradient-brand);
	opacity: .35;
	z-index: 0;
}

.svc-step {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: var(--sp-5);
	padding-inline: var(--sp-4);
	position: relative;
	z-index: 1;
}

.svc-step__node {
	width: 56px;
	height: 56px;
	border-radius: var(--radius-full);
	background: var(--gradient-brand);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	box-shadow: var(--shadow-md);
}

.svc-step__num {
	font-family: var(--font-display);
	font-size: var(--text-sm);
	font-weight: 700;
	color: #fff;
	letter-spacing: .04em;
}

.svc-step__body {
	display: flex;
	flex-direction: column;
	gap: var(--sp-2);
}

.svc-step__title {
	font-size: var(--text-base);
	font-weight: 700;
	color: var(--color-text);
}

.svc-step__desc {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	line-height: var(--leading-normal);
	max-width: none;
}

/* ══ АДАПТИВ ═════════════════════════════════════════════════ */
@media (max-width: 1024px) {
	.svc-items {
		grid-template-columns: repeat(2, 1fr);
	}

	.svc-steps__list {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--sp-10) var(--sp-4);
	}

	.svc-steps__list::before {
		display: none;
	}

	.svc-step:not(:nth-child(2n))::after {
		content: '';
		position: absolute;
		top: 28px;
		left: calc(50% + 28px);
		right: calc(-50% + 28px);
		height: 2px;
		background: var(--gradient-brand);
		opacity: .3;
	}
}

@media (max-width: 640px) {
	.svc-hero__actions {
		flex-direction: column;
	}

	.svc-hero__actions .btn {
		width: 100%;
		justify-content: center;
	}

	.svc-items {
		grid-template-columns: 1fr;
	}

	.svc-steps__list {
		grid-template-columns: 1fr;
		gap: 0;
	}

	.svc-step:not(:nth-child(2n))::after {
		display: none;
	}

	.svc-step {
		flex-direction: row;
		text-align: left;
		padding: var(--sp-5) 0;
		border-bottom: 1px solid var(--color-border);
	}

	.svc-step:last-child {
		border-bottom: none;
	}

	.svc-steps__list::before {
		display: block;
		top: 28px;
		left: 27px;
		right: auto;
		width: 2px;
		height: calc(100% - 56px);
	}
}
