

/* Start:/local/templates/stork/styles.css?1781074931543583*/
:root {
	--color-bg: #071327;
	--color-text: #101828;
	--color-muted: #8c929f;
	--color-blue: #345ed6;
	--color-blue-dark: #223e9b;
	--color-surface: #ffffff;
	--color-line: #e7e9ef;
	--color-green: #54cf91;
	--container: 1900px;
	--radius: 26px;
	--font-base: "Raleway", Arial, "Helvetica Neue", sans-serif;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	min-width: 320px;
	margin: 0;
	background: #f4f6fb;
	color: var(--color-text);
	font-family: var(--font-base);
	font-size: 16px;
	line-height: 1.5;
}

a {
	color: inherit;
	text-decoration: none;
}

button,
input,
textarea,
select {
	font: inherit;
}

img,
canvas {
	display: block;
	max-width: 100%;
}

.site-shell {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}

.site-main {
	flex: 1;
}

.container {
	width: min(calc(100% - 64px), var(--container));
	margin: 0 auto;
}

.site-header {
	position: fixed;
	top: 18px;
	left: 0;
	right: 0;
	z-index: 30;
	padding: 0;
	pointer-events: none;
	transition: top 0.22s ease, padding 0.22s ease, background-color 0.22s ease, box-shadow 0.22s ease;
}

.site-header.is-scrolled {
	top: 0;
	padding: 14px 0;
	background: linear-gradient(90deg, rgba(232, 246, 255, 0.68), rgba(255, 255, 255, 0.76));
	box-shadow: 0 18px 60px rgba(5, 14, 32, 0.12);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
}

.site-header__inner {
	min-height: 58px;
	display: grid;
	grid-template-columns: minmax(150px, 0.42fr) auto minmax(310px, 0.42fr);
	align-items: center;
	gap: 22px;
	padding: 0;
	pointer-events: auto;
}

.site-logo {
	display: inline-flex;
	align-items: center;
	flex: 0 0 auto;
	justify-self: start;
	color: rgba(255, 255, 255, 0.92);
	font-weight: 600;
	letter-spacing: 0;
	transition: color 0.2s ease;
}

.site-header.is-scrolled .site-logo {
	color: #1d2634;
}

.site-logo__text {
	font-size: clamp(22px, 1.5vw, 28px);
	line-height: 1;
}

.site-nav {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	justify-self: center;
	gap: 4px;
	overflow: hidden;
	padding: 6px;
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 999px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.13), rgba(255, 255, 255, 0.04)),
		rgba(7, 19, 39, 0.42);
	box-shadow:
		0 18px 46px rgba(2, 8, 23, 0.28),
		inset 0 1px 0 rgba(255, 255, 255, 0.18);
	color: rgba(255, 255, 255, 0.74);
	font-size: clamp(13px, 0.82vw, 16px);
	font-weight: 600;
	white-space: nowrap;
	backdrop-filter: blur(18px) saturate(150%);
	-webkit-backdrop-filter: blur(18px) saturate(150%);
	transition: background 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.site-nav::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.03) 52%, rgba(124, 200, 255, 0.08));
	pointer-events: none;
}

.site-nav::after {
	content: "";
	position: absolute;
	inset: 1px;
	border-radius: inherit;
	border: 1px solid rgba(255, 255, 255, 0.08);
	pointer-events: none;
}

.site-nav a {
	position: relative;
	z-index: 1;
	display: inline-flex;
	align-items: center;
	min-height: 38px;
	padding: 0 clamp(12px, 0.95vw, 18px);
	border-radius: 999px;
	color: inherit;
	transition: color 0.18s ease, background-color 0.18s ease, box-shadow 0.18s ease;
}

.site-nav a:hover,
.site-nav a:focus-visible {
	color: #ffffff;
	background: rgba(124, 200, 255, 0.13);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.site-nav a:focus-visible {
	outline: 2px solid rgba(124, 200, 255, 0.78);
	outline-offset: 2px;
}

.site-header.is-scrolled .site-nav {
	border-color: rgba(203, 213, 225, 0.76);
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.76), rgba(255, 255, 255, 0.5)),
		rgba(255, 255, 255, 0.72);
	box-shadow:
		0 16px 40px rgba(15, 23, 42, 0.12),
		inset 0 1px 0 rgba(255, 255, 255, 0.84);
	color: #31405a;
}

.site-header.is-scrolled .site-nav a:hover,
.site-header.is-scrolled .site-nav a:focus-visible {
	color: #2449c7;
	background: rgba(52, 94, 214, 0.08);
}

.site-header--light .site-logo {
	color: #071327;
}

.site-header--light .site-nav {
	border-color: rgba(203, 213, 225, 0.74);
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.84), rgba(255, 255, 255, 0.56)),
		rgba(255, 255, 255, 0.72);
	box-shadow:
		0 16px 40px rgba(15, 23, 42, 0.12),
		inset 0 1px 0 rgba(255, 255, 255, 0.86);
	color: #31405a;
}

.site-header--light .site-nav::before {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0.12) 58%, rgba(52, 94, 214, 0.05));
}

.site-header--light .site-nav::after {
	border-color: rgba(52, 94, 214, 0.08);
}

.site-header--light .site-nav a:hover,
.site-header--light .site-nav a:focus-visible {
	color: #2449c7;
	background: rgba(52, 94, 214, 0.08);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.site-header__meta {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	justify-self: end;
	gap: clamp(12px, 0.95vw, 18px);
	white-space: nowrap;
}

.site-location {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: rgba(255, 255, 255, 0.82);
	font-size: clamp(14px, 0.86vw, 16px);
	font-weight: 500;
	transition: color 0.2s ease;
}

.site-header.is-scrolled .site-location {
	color: #46546a;
}

.site-header--light .site-location {
	color: #46546a;
}

.site-location__pin {
	position: relative;
	width: 26px;
	height: 26px;
	display: inline-block;
	border: 1px solid rgba(124, 200, 255, 0.28);
	border-radius: 50%;
	background: rgba(124, 200, 255, 0.14);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.site-location__pin::after {
	content: "";
	position: absolute;
	top: 8px;
	left: 8px;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #7cc8ff;
	box-shadow: 0 0 0 4px rgba(124, 200, 255, 0.14);
}

.site-phone {
	color: rgba(255, 255, 255, 0.9);
	font-size: clamp(14px, 0.86vw, 17px);
	font-weight: 600;
	transition: color 0.2s ease;
}

.site-header.is-scrolled .site-phone {
	color: #263244;
}

.site-header--light .site-phone {
	color: #263244;
}

.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 64px;
	padding: 18px 40px;
	border: 0;
	border-radius: 11px;
	background: var(--color-blue);
	color: #ffffff;
	font-weight: 600;
	line-height: 1.15;
	cursor: pointer;
	transition: background-color 0.18s ease, transform 0.18s ease, box-shadow 0.2s ease;
}

.button:hover {
	background: var(--color-blue-dark);
	transform: translateY(-1px);
}

.button--header {
	min-height: 46px;
	padding: 12px 22px;
	border-radius: 999px;
	background:
		linear-gradient(100deg, rgba(124, 200, 255, 0.96) 0%, rgba(52, 94, 214, 0.98) 100%);
	font-weight: 700;
	font-size: clamp(14px, 0.86vw, 16px);
	box-shadow:
		0 14px 34px rgba(52, 94, 214, 0.28),
		inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.button--header:hover {
	background: linear-gradient(100deg, #45b7ea 0%, #294fc4 100%);
}

.nav-toggle {
	width: 48px;
	height: 48px;
	display: none;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 7px;
	flex: 0 0 auto;
	border: 0;
	background: transparent;
	color: #1d2634;
	cursor: pointer;
}

.nav-toggle span {
	width: 27px;
	height: 2px;
	background: currentColor;
}

.hero-screen {
	position: relative;
	min-height: 100svh;
	overflow: hidden;
	padding: 140px 0 80px;
	border-radius: 0 0 22px 22px;
	background:
		radial-gradient(circle at 82% 18%, rgba(96, 139, 255, 0.72), transparent 34%),
		radial-gradient(circle at 92% 86%, rgba(46, 89, 196, 0.62), transparent 38%),
		radial-gradient(circle at 42% 38%, rgba(73, 104, 195, 0.2), transparent 36%),
		linear-gradient(112deg, #070f22 0%, #111c39 44%, #4164be 100%);
	color: #ffffff;
}

.hero-screen::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(90deg, rgba(4, 11, 26, 0.92), rgba(4, 11, 26, 0.54) 54%, rgba(255, 255, 255, 0.03)),
		linear-gradient(118deg, rgba(255, 255, 255, 0.055) 0 13%, transparent 13% 58%, rgba(255, 255, 255, 0.035) 58% 72%, transparent 72%),
		radial-gradient(circle at 74% 42%, rgba(159, 191, 255, 0.12), transparent 28%);
	pointer-events: none;
}

.hero-screen__stars {
	position: absolute;
	inset: 0;
	opacity: 0.42;
	background-image:
		radial-gradient(circle, rgba(255, 255, 255, 0.38) 0 1px, transparent 1.5px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px),
		linear-gradient(180deg, rgba(255, 255, 255, 0.026) 1px, transparent 1px);
	background-position: 24px 32px, center, center;
	background-size: 260px 220px, 96px 96px, 96px 96px;
	mask-image: linear-gradient(90deg, transparent 0%, #000 14%, #000 74%, transparent 100%);
}

.hero-screen__stars::before,
.hero-screen__stars::after {
	content: "";
	position: absolute;
	inset: 0;
	background-repeat: no-repeat;
	pointer-events: none;
}

.hero-screen__stars::before {
	opacity: 0.28;
	background:
		radial-gradient(ellipse at 76% 40%, rgba(255, 255, 255, 0.24), transparent 24%),
		linear-gradient(116deg, transparent 0 20%, rgba(255, 255, 255, 0.09) 20% 20.2%, transparent 20.2%),
		linear-gradient(116deg, transparent 0 60%, rgba(255, 255, 255, 0.065) 60% 60.16%, transparent 60.16%);
}

.hero-screen__stars::after {
	display: none;
}

@keyframes twinkle {
	0%,
	100% {
		opacity: 0.24;
	}

	50% {
		opacity: 0.62;
	}
}

.hero-screen__inner {
	position: relative;
	z-index: 1;
	min-height: calc(100svh - 188px);
	display: grid;
	grid-template-columns: minmax(560px, 0.95fr) minmax(420px, 0.62fr);
	align-items: center;
	gap: clamp(52px, 7vw, 140px);
	transform: translateY(-24px);
}

.hero-screen__content {
	align-self: center;
	max-width: 900px;
	padding-top: 0;
}

.hero-kicker {
	margin: 0 0 28px;
	color: rgba(255, 255, 255, 0.78);
	font-size: clamp(17px, 1.05vw, 22px);
	font-weight: 500;
	letter-spacing: 0;
}

.hero-screen h1 {
	max-width: 900px;
	margin: 0;
	font-size: clamp(54px, 4.55vw, 88px);
	font-weight: 700;
	line-height: 1.08;
	letter-spacing: 0;
}

.hero-subtitle {
	max-width: 790px;
	margin: 36px 0 0;
	color: rgba(255, 255, 255, 0.82);
	font-size: clamp(22px, 1.55vw, 31px);
	font-weight: 400;
	line-height: 1.34;
}

.hero-actions {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 24px;
	margin-top: 44px;
}

.hero-screen .hero-actions .button {
	min-width: 334px;
	background: var(--color-blue);
	box-shadow: none;
}

.hero-screen .hero-actions .button:hover {
	background: var(--color-blue-dark);
}

.hero-logo-visual {
	position: relative;
	width: min(100%, 520px);
	margin: 0;
	justify-self: end;
	pointer-events: none;
	opacity: 0.34;
}

.hero-logo-visual::after {
	display: none;
}

.hero-logo-visual img {
	position: relative;
	z-index: 1;
	width: 100%;
	height: auto;
	filter: brightness(0) invert(1) drop-shadow(16px 22px 0 rgba(0, 0, 0, 0.08));
	transform: translateX(20px) rotate(-8deg);
}

.hero-visual {
	position: relative;
	width: min(100%, 684px);
	height: clamp(430px, 28.5vw, 540px);
	justify-self: end;
	overflow: hidden;
	border: 1px solid rgba(148, 177, 255, 0.18);
	border-radius: 20px;
	background:
		radial-gradient(circle at 50% 50%, rgba(59, 91, 219, 0.14), transparent 30%),
		radial-gradient(circle at 24% 20%, rgba(96, 165, 250, 0.12), transparent 25%),
		rgba(255, 255, 255, 0.02);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}

.hero-visual::before,
.hero-visual::after {
	content: "";
	position: absolute;
	inset: 40px;
	border: 1px solid rgba(255, 255, 255, 0.06);
	border-radius: 50%;
	pointer-events: none;
}

.hero-visual::after {
	inset: 122px 116px;
	border-color: rgba(255, 255, 255, 0.08);
}

#hero-canvas {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
}

.hv-center {
	position: absolute;
	inset: 0;
	z-index: 2;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	pointer-events: none;
}

.hv-center-mark {
	position: relative;
	display: grid;
	place-items: center;
	width: 94px;
	height: 94px;
}

.hv-center-ring {
	position: relative;
	z-index: 2;
	width: 72px;
	height: 72px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1.5px solid rgba(96, 132, 255, 0.58);
	border-radius: 50%;
	background: rgba(59, 91, 219, 0.18);
	color: #cbd8ff;
	box-shadow: 0 0 42px rgba(59, 91, 219, 0.34);
}

.hv-center-label {
	margin-top: 8px;
	color: rgba(255, 255, 255, 0.46);
	font-size: 12px;
	font-weight: 700;
	line-height: 1;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.hv-pulse {
	position: absolute;
	inset: 10px;
	border: 1px solid rgba(96, 132, 255, 0.34);
	border-radius: 50%;
	animation: hv-pulse 2.5s ease-out infinite;
}

.hv-pulse-2 {
	animation-delay: 1.25s;
}

@keyframes hv-pulse {
	0% {
		opacity: 0.6;
		transform: scale(0.9);
	}

	100% {
		opacity: 0;
		transform: scale(1.65);
	}
}

.hv-node {
	position: absolute;
	z-index: 2;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	pointer-events: none;
}

.hv-node-icon {
	width: 44px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--hv-border);
	border-radius: 12px;
	background: var(--hv-bg);
	color: var(--hv-color);
	font-size: 14px;
	font-weight: 800;
	line-height: 1;
	box-shadow: 0 16px 34px rgba(0, 0, 0, 0.16);
}

.hv-node-text {
	color: rgba(255, 255, 255, 0.48);
	font-size: 11px;
	font-weight: 600;
	line-height: 1;
	letter-spacing: 0.03em;
	white-space: nowrap;
}

.hv-node--direct {
	top: 42px;
	left: 50%;
	transform: translateX(-50%);
	--hv-bg: rgba(255, 66, 66, 0.12);
	--hv-border: rgba(255, 66, 66, 0.25);
	--hv-color: #f87171;
}

.hv-node--maps {
	top: 116px;
	right: 44px;
	--hv-bg: rgba(251, 191, 36, 0.12);
	--hv-border: rgba(251, 191, 36, 0.25);
	--hv-color: #fbbf24;
}

.hv-node--reviews {
	right: 44px;
	bottom: 106px;
	--hv-bg: rgba(52, 211, 153, 0.12);
	--hv-border: rgba(52, 211, 153, 0.25);
	--hv-color: #34d399;
}

.hv-node--seo {
	bottom: 42px;
	left: 50%;
	transform: translateX(-50%);
	--hv-bg: rgba(139, 92, 246, 0.12);
	--hv-border: rgba(139, 92, 246, 0.25);
	--hv-color: #a78bfa;
}

.hv-node--doctors {
	left: 44px;
	bottom: 106px;
	--hv-bg: rgba(59, 130, 246, 0.12);
	--hv-border: rgba(59, 130, 246, 0.25);
	--hv-color: #60a5fa;
}

.hv-node--site {
	top: 116px;
	left: 44px;
	--hv-bg: rgba(244, 114, 182, 0.12);
	--hv-border: rgba(244, 114, 182, 0.25);
	--hv-color: #f472b6;
}

.hero-label,
.hero-title,
.hero-subtitle,
.hero-cta,
.hero-pills,
.hero-pill {
	opacity: 0;
	transform: translateY(12px);
	transition: opacity 500ms cubic-bezier(0.22, 1, 0.36, 1),
		transform 500ms cubic-bezier(0.22, 1, 0.36, 1);
}

.hero-label.visible {
	opacity: 1;
	transform: translateY(0);
	transition-delay: 0ms;
}

.hero-title.visible {
	opacity: 1;
	transform: translateY(0);
	transition-delay: 150ms;
}

.hero-subtitle.visible {
	opacity: 1;
	transform: translateY(0);
	transition-delay: 300ms;
}

.hero-cta.visible {
	opacity: 1;
	transform: translateY(0);
	transition-delay: 450ms;
}

.hero-pills.visible {
	opacity: 1;
	transform: translateY(0);
	transition-delay: 500ms;
}

.hero-pill:nth-child(1).visible {
	opacity: 1;
	transform: translateY(0);
	transition-delay: 550ms;
}

.hero-pill:nth-child(2).visible {
	opacity: 1;
	transform: translateY(0);
	transition-delay: 630ms;
}

.hero-pill:nth-child(3).visible {
	opacity: 1;
	transform: translateY(0);
	transition-delay: 710ms;
}

.hero-pill:nth-child(4).visible {
	opacity: 1;
	transform: translateY(0);
	transition-delay: 790ms;
}

.hero-pill:nth-child(5).visible {
	opacity: 1;
	transform: translateY(0);
	transition-delay: 870ms;
}

.hero-cta.visible:hover {
	transform: translateY(-2px);
	transition-delay: 0ms;
}

.hero-cta.visible:hover .button {
	box-shadow: 0 8px 24px rgba(59, 91, 219, 0.35);
}

.hero-dashboard {
	width: min(100%, 660px);
	justify-self: end;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	grid-template-areas:
		"leads leads cost"
		"romi path path";
	gap: 16px;
	align-items: stretch;
}

.hero-metric-card {
	position: relative;
	overflow: hidden;
	min-height: 186px;
	padding: 28px;
	border: 1px solid rgba(210, 224, 255, 0.82);
	border-radius: 34px;
	background: rgba(255, 255, 255, 0.96);
	color: #071027;
	box-shadow: 0 24px 70px rgba(4, 13, 32, 0.22);
}

.hero-metric-card--leads {
	grid-area: leads;
	min-height: 286px;
}

.hero-metric-card--cost {
	grid-area: cost;
	min-height: 286px;
	background:
		radial-gradient(circle at 88% 0%, rgba(40, 213, 232, 0.38), transparent 42%),
		linear-gradient(145deg, #060d22 0%, #08112b 100%);
	color: #ffffff;
	border-color: rgba(91, 221, 245, 0.24);
}

.hero-metric-card--romi {
	grid-area: romi;
	min-height: 186px;
}

.hero-metric-card--path {
	grid-area: path;
	min-height: 186px;
}

.hero-metric-card__top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 28px;
	color: #7a87a3;
	font-size: 15px;
	font-weight: 600;
	line-height: 1;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.hero-live {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 32px;
	padding: 8px 14px;
	border-radius: 999px;
	background: #e8f8f2;
	color: #10b981;
	font-size: 14px;
	font-weight: 700;
	line-height: 1;
	letter-spacing: 0.04em;
}

.hero-live::before {
	content: "";
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: currentColor;
	box-shadow: 0 0 0 6px rgba(16, 185, 129, 0.12);
}

.hero-metric-card__menu {
	width: 4px;
	height: 20px;
	border-radius: 999px;
	background: radial-gradient(circle, #9aa7bf 0 2px, transparent 2.5px) 0 0 / 4px 8px repeat-y;
}

.hero-metric-card__label {
	display: block;
	color: #687692;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

.hero-metric-card--cost .hero-metric-card__label {
	color: #65e8ff;
}

.hero-metric-card__value {
	margin-top: 14px;
	color: inherit;
	font-size: clamp(50px, 4.2vw, 76px);
	font-weight: 800;
	line-height: 0.95;
	letter-spacing: 0;
}

.hero-metric-card--romi .hero-metric-card__value {
	font-size: clamp(48px, 4vw, 68px);
}

.hero-metric-card--cost .hero-metric-card__value {
	color: #ffffff;
	font-size: clamp(42px, 3.1vw, 58px);
}

.hero-metric-card__trend {
	position: absolute;
	top: 132px;
	right: 30px;
	color: #10b981;
	font-size: 22px;
	font-weight: 800;
	line-height: 1;
}

.hero-metric-card__trend::before {
	content: "↗";
	margin-right: 7px;
}

.hero-metric-card__trend--down {
	position: static;
	margin-top: 26px;
	color: #22e0a6;
}

.hero-metric-card__trend--down::before {
	content: "↘";
}

.hero-metric-card p {
	margin: 22px 0 0;
	color: #687692;
	font-size: 17px;
	line-height: 1.35;
}

.hero-line-chart {
	position: absolute;
	left: 28px;
	right: 28px;
	bottom: 24px;
	height: 112px;
}

.hero-line-chart::before,
.hero-line-chart::after {
	content: "";
	position: absolute;
	inset: 0;
	clip-path: polygon(0 76%, 18% 67%, 31% 70%, 48% 48%, 61% 42%, 72% 49%, 100% 18%, 100% 100%, 0 100%);
}

.hero-line-chart::before {
	background: linear-gradient(180deg, rgba(40, 198, 226, 0.34), rgba(40, 198, 226, 0));
}

.hero-line-chart::after {
	background: linear-gradient(90deg, #25c9dd, #3176ff);
	box-shadow: 0 7px 18px rgba(49, 118, 255, 0.22);
	clip-path: polygon(0 76%, 18% 67%, 31% 70%, 48% 48%, 61% 42%, 72% 49%, 100% 18%, 100% 23%, 72% 54%, 61% 47%, 48% 53%, 31% 75%, 18% 72%, 0 81%);
}

.hero-bars {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	align-items: end;
	gap: 12px;
	height: 88px;
	margin-top: 22px;
}

.hero-bars span {
	height: var(--h);
	min-height: 26px;
	border-radius: 20px 20px 0 0;
	background: linear-gradient(180deg, #d4e9ff, #59a6ff);
}

.hero-bars span:nth-child(3) {
	background: linear-gradient(180deg, #5e9eff, #2868f0);
}

.hero-bars span:nth-child(4) {
	background: linear-gradient(180deg, #23d9df, #15b7d8);
}

.hero-path-stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 8px;
	margin-top: 16px;
	color: #687692;
	font-size: 10px;
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: 0.08em;
	text-align: center;
	text-transform: uppercase;
}

.hero-path-stats strong {
	display: block;
	margin-bottom: 5px;
	color: #071027;
	font-size: 17px;
	letter-spacing: 0;
}

.section {
	padding: 84px 0;
}

.section--surface {
	background: #ffffff;
}

.services-section {
	padding: 108px 0 118px;
	background:
		radial-gradient(circle at 78% 8%, rgba(59, 91, 219, 0.22), transparent 32%),
		radial-gradient(circle at 12% 76%, rgba(96, 165, 250, 0.1), transparent 30%),
		linear-gradient(135deg, #071327 0%, #0e1830 52%, #172655 100%);
	color: #ffffff;
}

.services-section__inner {
	display: grid;
	gap: 42px;
}

.services-section__intro {
	max-width: 1040px;
	display: grid;
	gap: 18px;
}

.services-section__kicker {
	margin: 0;
	color: #7cc8ff;
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.services-section__intro h2 {
	max-width: 980px;
	margin: 0;
	font-size: clamp(34px, 3.2vw, 62px);
	font-weight: 500;
	line-height: 1.06;
	letter-spacing: 0;
}

.services-section__intro p:last-child {
	max-width: 860px;
	margin: 0;
	color: rgba(255, 255, 255, 0.62);
	font-size: clamp(17px, 1.1vw, 22px);
	line-height: 1.42;
}

.services-grid {
	display: grid;
	grid-template-columns: repeat(12, minmax(0, 1fr));
	gap: 22px;
}

.service-card {
	position: relative;
	min-height: 410px;
	grid-column: span 6;
	overflow: hidden;
	border: 1px solid rgba(148, 177, 255, 0.18);
	border-radius: 32px;
	background:
		radial-gradient(circle at 88% 8%, rgba(96, 165, 250, 0.14), transparent 34%),
		linear-gradient(145deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0)),
		#0b1329;
	box-shadow: 0 18px 60px rgba(3, 8, 20, 0.22);
	transition: transform 420ms cubic-bezier(0.22, 1, 0.36, 1),
		border-color 420ms ease,
		box-shadow 420ms ease,
		background-color 420ms ease;
}

.service-card--site,
.service-card--maps {
	grid-column: span 7;
}

.service-card--seo,
.service-card--ads {
	grid-column: span 5;
}

.service-card--reviews,
.service-card--analytics {
	min-height: 380px;
}

.service-card--maps,
.service-card--analytics {
	background:
		radial-gradient(circle at 18% 100%, rgba(59, 91, 219, 0.32), transparent 44%),
		linear-gradient(145deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0)),
		#111c39;
}

.service-card:hover {
	transform: translateY(-8px);
	border-color: rgba(124, 200, 255, 0.42);
	box-shadow: 0 28px 84px rgba(3, 8, 20, 0.36);
}

.service-card__body {
	position: relative;
	z-index: 1;
	min-height: inherit;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	gap: 28px;
	padding: clamp(30px, 2.8vw, 54px);
}

.service-card h3 {
	max-width: 760px;
	margin: 0;
	color: #ffffff;
	font-size: clamp(28px, 2.45vw, 46px);
	font-weight: 500;
	line-height: 1.05;
	letter-spacing: 0;
}

.service-card__lead,
.service-card__result {
	max-width: 760px;
	margin: 18px 0 0;
	color: rgba(255, 255, 255, 0.58);
	font-size: clamp(16px, 1vw, 20px);
	font-weight: 600;
	line-height: 1.32;
}

.service-card__result {
	margin-top: auto;
	color: rgba(255, 255, 255, 0.7);
	font-weight: 400;
}

.service-card__link {
	width: fit-content;
	display: inline-flex;
	align-items: center;
	gap: 12px;
	margin-top: 4px;
	border-bottom: 2px solid currentColor;
	color: #7cc8ff;
	font-size: clamp(18px, 1.25vw, 24px);
	font-weight: 700;
	line-height: 1.1;
	transition: color 220ms ease, transform 220ms ease;
}

.service-card__link::after {
	content: "";
	width: 28px;
	height: 18px;
	background: currentColor;
	clip-path: polygon(0 43%, 72% 43%, 48% 0, 100% 50%, 48% 100%, 72% 57%, 0 57%);
	transform: translateX(0);
	transition: transform 220ms ease;
}

.service-card:hover .service-card__link {
	color: #a8dcff;
	transform: translateX(2px);
}

.service-card:hover .service-card__link::after {
	transform: translateX(6px);
}

.service-card__icon {
	position: absolute;
	right: clamp(28px, 2.6vw, 48px);
	bottom: clamp(28px, 2.4vw, 44px);
	width: 34px;
	height: 34px;
	border: 2px solid #7cc8ff;
	border-radius: 50%;
	opacity: 0.95;
	transform: rotate(-24deg);
}

.service-card__icon::before,
.service-card__icon::after {
	content: "";
	position: absolute;
	background: #7cc8ff;
}

.service-card__icon::before {
	left: 11px;
	top: 5px;
	width: 10px;
	height: 26px;
	border-radius: 8px;
}

.service-card__icon::after {
	left: 4px;
	bottom: -8px;
	width: 22px;
	height: 12px;
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
}

.service-visual {
	position: relative;
	min-height: 132px;
	margin: 8px 0;
}

.service-visual--site {
	width: min(100%, 520px);
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 12px;
	align-items: end;
}

.service-visual--site span {
	height: 104px;
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 18px;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.03)),
		linear-gradient(90deg, transparent 0 16px, rgba(255, 255, 255, 0.08) 16px 18px, transparent 18px);
	animation: service-float 4.5s ease-in-out infinite;
}

.service-visual--site span:nth-child(2) {
	height: 132px;
	animation-delay: 0.35s;
}

.service-visual--site span:nth-child(3) {
	height: 88px;
	animation-delay: 0.7s;
}

.service-visual--search {
	width: min(100%, 520px);
	min-height: 270px;
	padding: 20px;
	border-radius: 28px;
	background: rgba(255, 255, 255, 0.055);
}

.service-search-bar {
	position: relative;
	display: flex;
	align-items: center;
	gap: 14px;
	width: min(100%, 430px);
	min-height: 64px;
	padding: 15px 20px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.075);
}

.service-search-bar span {
	position: relative;
	width: 24px;
	height: 24px;
	flex: 0 0 auto;
	border: 3px solid rgba(255, 255, 255, 0.52);
	border-radius: 50%;
}

.service-search-bar span::after {
	content: "";
	position: absolute;
	width: 13px;
	height: 3px;
	background: rgba(255, 255, 255, 0.52);
	transform: translate(17px, 19px) rotate(45deg);
}

.service-search-bar em {
	display: inline-block;
	width: 0;
	max-width: 13ch;
	overflow: hidden;
	color: rgba(255, 255, 255, 0.64);
	font-style: normal;
	font-size: 17px;
	letter-spacing: 0.1em;
	white-space: nowrap;
	animation: service-type 2.2s steps(13, end) 0.45s forwards;
}

.service-search-bar i {
	width: 1px;
	height: 24px;
	background: rgba(124, 200, 255, 0.9);
	animation: service-blink 0.8s steps(1, end) infinite;
}

.service-serp {
	display: grid;
	gap: 10px;
	margin-top: 18px;
	opacity: 0;
	transform: translateY(16px);
	transition: opacity 420ms ease, transform 420ms cubic-bezier(0.22, 1, 0.36, 1);
}

.service-card--seo:hover .service-serp {
	opacity: 1;
	transform: translateY(0);
}

.service-serp__row {
	position: relative;
	min-height: 54px;
	display: grid;
	grid-template-columns: 1fr;
	gap: 7px;
	padding: 11px 14px;
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 10px;
	background: rgba(255, 255, 255, 0.035);
}

.service-serp__row--ad {
	grid-template-columns: 38px 1fr;
	border-color: rgba(124, 200, 255, 0.42);
	box-shadow: inset 0 0 0 1px rgba(52, 94, 214, 0.22);
}

.service-serp__row b {
	grid-row: span 2;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border-radius: 8px;
	background: rgba(124, 200, 255, 0.22);
	color: #7cc8ff;
	font-size: 13px;
	line-height: 1;
}

.service-serp__row span {
	display: block;
	height: 8px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.24);
}

.service-serp__row span:nth-child(2) {
	width: 68%;
}

.service-serp__row span:nth-child(3) {
	width: 86%;
	background: rgba(124, 200, 255, 0.42);
}

.service-serp__row:not(.service-serp__row--ad) span:nth-child(1) {
	width: 78%;
}

.service-serp__row:not(.service-serp__row--ad) span:nth-child(2) {
	width: 90%;
}

.service-serp__row:not(.service-serp__row--ad) span:nth-child(3) {
	width: 72%;
	background: rgba(255, 255, 255, 0.18);
}

.service-visual--ads {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
}

.service-visual--ads span {
	padding: 13px 18px;
	border-radius: 999px;
	background: rgba(59, 91, 219, 0.2);
	color: rgba(255, 255, 255, 0.82);
	font-size: 17px;
	font-weight: 700;
	animation: service-chip 4s ease-in-out infinite;
}

.service-visual--ads span:nth-child(2) {
	animation-delay: 0.35s;
}

.service-visual--ads span:nth-child(3) {
	animation-delay: 0.7s;
}

.service-visual--map {
	min-height: 150px;
	border-radius: 28px;
	background:
		linear-gradient(90deg, rgba(255, 255, 255, 0.06) 1px, transparent 1px),
		linear-gradient(180deg, rgba(255, 255, 255, 0.045) 1px, transparent 1px);
	background-size: 44px 44px;
}

.service-visual--map span {
	position: absolute;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: #7cc8ff;
	box-shadow: 0 0 0 10px rgba(124, 200, 255, 0.12);
	animation: service-ping 2.8s ease-in-out infinite;
}

.service-visual--map span:nth-child(1) {
	top: 28px;
	left: 18%;
}

.service-visual--map span:nth-child(2) {
	top: 72px;
	left: 52%;
	animation-delay: 0.5s;
}

.service-visual--map span:nth-child(3) {
	top: 42px;
	right: 16%;
	animation-delay: 1s;
}

.service-visual--reviews {
	display: flex;
	align-items: center;
	gap: 10px;
}

.service-visual--reviews span {
	width: 34px;
	height: 34px;
	background: #7cc8ff;
	clip-path: polygon(50% 0, 62% 34%, 98% 35%, 69% 56%, 79% 91%, 50% 70%, 21% 91%, 31% 56%, 2% 35%, 38% 34%);
	animation: service-star 3.6s ease-in-out infinite;
}

.service-visual--reviews span:nth-child(2) {
	animation-delay: 0.16s;
}

.service-visual--reviews span:nth-child(3) {
	animation-delay: 0.32s;
}

.service-visual--reviews span:nth-child(4) {
	animation-delay: 0.48s;
}

.service-visual--reviews span:nth-child(5) {
	animation-delay: 0.64s;
}

.service-visual--analytics {
	height: 150px;
	display: grid;
	grid-template-columns: repeat(4, 56px);
	align-items: end;
	gap: 14px;
}

.service-visual--analytics span {
	height: var(--h);
	min-height: 38px;
	border-radius: 16px 16px 4px 4px;
	background: linear-gradient(180deg, #7cc8ff, #345ed6);
	animation: service-bars 3.8s ease-in-out infinite;
}

.service-visual--analytics span:nth-child(2) {
	animation-delay: 0.24s;
}

.service-visual--analytics span:nth-child(3) {
	animation-delay: 0.48s;
}

.service-visual--analytics span:nth-child(4) {
	animation-delay: 0.72s;
}

@keyframes service-float {
	0%,
	100% { transform: translateY(0); }
	50% { transform: translateY(-10px); }
}

@keyframes service-type {
	from {
		width: 0;
	}

	to {
		width: 13ch;
	}
}

@keyframes service-blink {
	0%,
	100% {
		opacity: 1;
	}

	50% {
		opacity: 0;
	}
}

@keyframes service-chip {
	0%,
	100% { transform: translateY(0); background-color: rgba(59, 91, 219, 0.2); }
	50% { transform: translateY(-8px); background-color: rgba(59, 91, 219, 0.34); }
}

@keyframes service-ping {
	0%,
	100% { transform: scale(1); box-shadow: 0 0 0 8px rgba(124, 200, 255, 0.12); }
	50% { transform: scale(1.18); box-shadow: 0 0 0 18px rgba(124, 200, 255, 0); }
}

@keyframes service-star {
	0%,
	100% { transform: translateY(0) scale(1); opacity: 0.72; }
	50% { transform: translateY(-8px) scale(1.08); opacity: 1; }
}

@keyframes service-bars {
	0%,
	100% { transform: scaleY(0.88); transform-origin: bottom; }
	50% { transform: scaleY(1.08); transform-origin: bottom; }
}

.services-section {
	padding: 96px 0 108px;
	background:
		radial-gradient(circle at 82% 8%, rgba(92, 130, 221, 0.28), transparent 34%),
		radial-gradient(circle at 8% 92%, rgba(52, 94, 214, 0.18), transparent 30%),
		linear-gradient(135deg, #071327 0%, #0b1329 58%, #16285f 100%);
}

.services-section__inner {
	gap: 34px;
}

.services-section__kicker {
	color: #7cc8ff;
	font-size: 14px;
}

.services-section__intro h2 {
	max-width: 820px;
	font-size: clamp(32px, 3vw, 58px);
	font-weight: 500;
}

.services-section__intro p:last-child {
	max-width: 760px;
	font-size: clamp(16px, 1.05vw, 21px);
}

.services-grid {
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
}

.service-card,
.service-card--site,
.service-card--maps,
.service-card--seo,
.service-card--ads {
	grid-column: auto;
	min-height: 360px;
	border: 1px solid rgba(148, 177, 255, 0.2);
	border-radius: 24px;
	background:
		radial-gradient(circle at 88% 0%, rgba(96, 165, 250, 0.14), transparent 36%),
		linear-gradient(145deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.012)),
		#0b1329;
	box-shadow: 0 20px 58px rgba(3, 8, 20, 0.2);
}

.service-card--maps,
.service-card--analytics {
	background:
		radial-gradient(circle at 18% 100%, rgba(59, 91, 219, 0.26), transparent 44%),
		linear-gradient(145deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.012)),
		#111c39;
}

.service-card:hover {
	border-color: rgba(124, 200, 255, 0.45);
	box-shadow: 0 26px 74px rgba(3, 8, 20, 0.34);
}

.service-card__body {
	min-height: inherit;
	gap: 20px;
	padding: clamp(26px, 2.2vw, 38px);
}

.service-card h3 {
	font-size: clamp(26px, 2.05vw, 38px);
	line-height: 1.12;
}

.service-card__lead,
.service-card__result {
	margin-top: 14px;
	font-size: clamp(15px, 0.95vw, 18px);
	line-height: 1.38;
}

.service-card__link {
	color: #7cc8ff;
	font-size: clamp(17px, 1.1vw, 21px);
}

.service-card__link::after,
.service-card__icon {
	display: none;
}

.service-visual {
	min-height: 112px;
	margin: 0;
}

.service-visual--search {
	min-height: 232px;
	padding: 18px;
	border-radius: 22px;
	background: rgba(255, 255, 255, 0.055);
}

.service-search-bar {
	width: 100%;
	min-height: 56px;
	padding: 13px 18px;
}

.service-search-bar em {
	font-size: 15px;
}

.service-serp {
	gap: 8px;
	margin-top: 14px;
	pointer-events: none;
}

.service-serp__row {
	min-height: 44px;
	padding: 9px 12px;
}

.service-serp__row--ad {
	grid-template-columns: 34px 1fr;
}

.service-serp__row b {
	width: 30px;
	height: 30px;
	font-size: 12px;
}

.service-visual--ads span {
	background: rgba(52, 94, 214, 0.24);
	font-size: 15px;
}

.service-visual--map span,
.service-visual--reviews span {
	background: #7cc8ff;
}

.advantages-section {
	padding: 104px 0 118px;
	background:
		radial-gradient(circle at 8% 12%, rgba(52, 94, 214, 0.08), transparent 28%),
		#ffffff;
	color: #151922;
}

.advantages-section__inner {
	display: grid;
	gap: 46px;
	align-items: start;
}

.advantages-section__intro {
	max-width: 980px;
	display: grid;
	gap: 22px;
	align-items: start;
	text-align: left;
}

.advantages-section__intro h2 {
	max-width: 900px;
	margin: 0;
	font-size: clamp(42px, 4.15vw, 82px);
	font-weight: 400;
	line-height: 1.08;
	letter-spacing: 0;
}

.section-kicker {
	margin: 0 0 20px;
	color: var(--color-blue);
	font-size: 18px;
	font-weight: 600;
}

.advantages-section__intro p {
	max-width: 720px;
	margin: 0;
	color: #354052;
	font-size: clamp(20px, 1.45vw, 28px);
	line-height: 1.48;
}

.advantages-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	grid-template-rows: repeat(3, minmax(190px, auto));
	gap: 22px;
}

.advantage-card {
	position: relative;
	min-height: 190px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding: clamp(28px, 2.6vw, 44px);
	overflow: hidden;
	border: 1px solid rgba(218, 224, 235, 0.72);
	border-radius: 26px;
	background: #f7faff;
	box-shadow: 0 18px 48px rgba(15, 23, 42, 0.07);
}

.advantage-card::after {
	content: "";
	position: absolute;
	right: -44px;
	bottom: -44px;
	width: 150px;
	height: 150px;
	border-radius: 50%;
	background: rgba(52, 94, 214, 0.08);
	display: none;
}

.advantage-card--lead {
	background:
		linear-gradient(150deg, rgba(255, 255, 255, 0.1), transparent 36%),
		linear-gradient(135deg, #244ec6 0%, #5176e4 100%);
	color: #ffffff;
	box-shadow: 0 28px 72px rgba(52, 94, 214, 0.26);
}

.advantage-card--lead::after {
	width: 260px;
	height: 260px;
	background: rgba(255, 255, 255, 0.12);
	display: block;
}

.card-01 {
	grid-column: 1;
	grid-row: 1 / 4;
}

.card-02 {
	grid-column: 2;
	grid-row: 1;
}

.card-03 {
	grid-column: 2;
	grid-row: 2;
}

.card-04 {
	grid-column: 2;
	grid-row: 3;
}

.card-03::after {
	right: -40px;
	bottom: -40px;
	width: 140px;
	height: 140px;
	background: var(--color-blue);
	opacity: 0.09;
	display: block;
	pointer-events: none;
}

.advantage-card__number {
	position: relative;
	z-index: 1;
	color: rgba(52, 94, 214, 0.9);
	font-size: 18px;
	font-weight: 700;
}

.advantage-card--lead .advantage-card__number {
	color: rgba(255, 255, 255, 0.76);
}

.advantage-card h3 {
	position: relative;
	z-index: 1;
	margin: 0 0 18px;
	color: var(--color-blue);
	font-size: clamp(26px, 2vw, 38px);
	font-weight: 500;
	line-height: 1.16;
	letter-spacing: 0;
}

.advantage-card--lead h3 {
	color: #ffffff;
	font-size: clamp(34px, 3vw, 56px);
	font-weight: 400;
}

.advantage-card p {
	position: relative;
	z-index: 1;
	max-width: 980px;
	margin: 0;
	color: #20242c;
	font-size: clamp(17px, 1.18vw, 23px);
	line-height: 1.42;
}

.advantage-card--lead p {
	color: rgba(255, 255, 255, 0.82);
	font-size: clamp(20px, 1.45vw, 28px);
}

.advantage-card--report {
	border-color: rgba(52, 94, 214, 0.28);
	background: linear-gradient(180deg, rgba(52, 94, 214, 0.07), #ffffff 44%);
}

.advantage-card--report::after {
	display: none;
}

.reveal-enabled .section-header {
	opacity: 0;
	transform: translateY(-12px);
	transition: opacity 500ms cubic-bezier(0.22, 1, 0.36, 1),
		transform 500ms cubic-bezier(0.22, 1, 0.36, 1);
}

.reveal-enabled .section-header.revealed {
	opacity: 1;
	transform: translateY(0);
}

.reveal-enabled .card-01 {
	opacity: 0;
	transform: translateX(-20px);
	transition: opacity 600ms cubic-bezier(0.22, 1, 0.36, 1),
		transform 600ms cubic-bezier(0.22, 1, 0.36, 1);
	transition-delay: 100ms;
}

.reveal-enabled .card-01.revealed {
	opacity: 1;
	transform: translateX(0);
}

.reveal-enabled .card-02,
.reveal-enabled .card-03,
.reveal-enabled .card-04,
.reveal-enabled .service-card {
	opacity: 0;
	transform: translateY(16px);
	transition: opacity 500ms cubic-bezier(0.22, 1, 0.36, 1),
		transform 500ms cubic-bezier(0.22, 1, 0.36, 1),
		box-shadow 300ms ease;
}

.reveal-enabled .card-02 {
	transition-delay: 100ms;
}

.reveal-enabled .card-03 {
	transition-delay: 200ms;
}

.reveal-enabled .card-04 {
	transition-delay: 300ms;
}

.reveal-enabled .service-card:nth-child(1) {
	transition-delay: 80ms;
}

.reveal-enabled .service-card:nth-child(2) {
	transition-delay: 160ms;
}

.reveal-enabled .service-card:nth-child(3) {
	transition-delay: 240ms;
}

.reveal-enabled .service-card:nth-child(4) {
	transition-delay: 320ms;
}

.reveal-enabled .service-card:nth-child(5) {
	transition-delay: 400ms;
}

.reveal-enabled .service-card:nth-child(6) {
	transition-delay: 480ms;
}

.reveal-enabled .card-02.revealed,
.reveal-enabled .card-03.revealed,
.reveal-enabled .card-04.revealed,
.reveal-enabled .service-card.revealed {
	opacity: 1;
	transform: translateY(0);
}

.reveal-enabled .service-card.revealed:hover {
	transform: translateY(-8px);
}

.card-02,
.card-03,
.card-04 {
	cursor: default;
	transition: transform 300ms ease, box-shadow 300ms ease;
}

.card-02:hover,
.card-03:hover,
.card-04:hover,
.reveal-enabled .card-02.revealed:hover,
.reveal-enabled .card-03.revealed:hover,
.reveal-enabled .card-04.revealed:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1);
}

@media (prefers-reduced-motion: reduce) {
	.hero-label,
	.hero-title,
	.hero-subtitle,
	.hero-cta,
	.hero-pills,
	.hero-pill,
	.reveal-enabled .section-header,
	.reveal-enabled .card-01,
	.reveal-enabled .card-02,
	.reveal-enabled .card-03,
	.reveal-enabled .card-04,
	.reveal-enabled .service-card {
		opacity: 1;
		transform: none;
		transition: none;
	}

	.hero-screen__stars,
	.hero-screen__stars::before,
	.hero-screen__stars::after,
	.hv-pulse,
	.service-visual *,
	.service-visual *::after {
		animation: none;
	}
}

.section-head {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 28px;
	margin-bottom: 28px;
}

.section-title {
	margin: 0;
	font-size: clamp(34px, 4vw, 68px);
	font-weight: 400;
	line-height: 1.02;
	letter-spacing: 0;
}

.section-head p {
	max-width: 620px;
	margin: 0;
	color: #667085;
	font-size: 18px;
}

.cards-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.card {
	min-height: 180px;
	padding: 24px;
	border: 1px solid var(--color-line);
	border-radius: 14px;
	background: #ffffff;
}

.card h3 {
	margin: 0 0 12px;
	font-size: 22px;
	line-height: 1.2;
}

.card p {
	margin: 0;
	color: #667085;
}

.clients-strip-section {
	overflow: hidden;
	padding: 72px 0 92px;
	border-top: 1px solid #e5e7eb;
	border-radius: 0;
	background:
		radial-gradient(circle at 86% 8%, rgba(124, 200, 255, 0.14), transparent 30%),
		#f4f7fb;
	color: #071327;
}

.clients-strip-section__inner {
	display: grid;
	justify-items: center;
	text-align: center;
}

.clients-strip-section__kicker {
	justify-self: start;
	margin: 0 0 34px;
	color: var(--color-blue);
	font-size: 14px;
	font-weight: 700;
	line-height: 1;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.clients-strip-section h2 {
	max-width: 980px;
	margin: 0;
	color: #071327;
	font-size: clamp(42px, 4vw, 78px);
	font-weight: 500;
	line-height: 1.12;
	letter-spacing: 0;
}

.clients-strip-section__contact {
	margin: 24px 0 0;
	color: rgba(7, 19, 39, 0.76);
	font-size: clamp(18px, 1.3vw, 26px);
	font-weight: 600;
	line-height: 1.35;
}

.clients-strip-section__contact a {
	color: var(--color-blue);
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 5px;
	transition: color 180ms ease;
}

.clients-strip-section__contact a:hover {
	color: var(--color-blue-dark);
}

.clients-logo-row {
	width: 100%;
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: minmax(280px, 1fr);
	gap: 28px;
	margin-top: 62px;
	padding: 0 max(40px, calc((100vw - var(--container)) / 2));
	overflow-x: auto;
	scroll-snap-type: x proximity;
	scrollbar-width: thin;
}

.clients-logo-card {
	min-height: 150px;
	display: grid;
	align-content: center;
	gap: 8px;
	padding: 28px;
	border: 1px solid rgba(52, 94, 214, 0.12);
	border-radius: 18px;
	background: #ffffff;
	box-shadow: 0 18px 42px rgba(33, 55, 100, 0.06);
	scroll-snap-align: start;
}

.clients-logo-card span {
	display: block;
	color: #071327;
	font-size: clamp(28px, 2.1vw, 44px);
	font-weight: 700;
	line-height: 1;
	letter-spacing: 0;
}

.clients-logo-card small {
	display: block;
	color: rgba(7, 19, 39, 0.58);
	font-size: clamp(13px, 0.9vw, 17px);
	font-weight: 600;
	line-height: 1.25;
	letter-spacing: 0.02em;
	text-transform: uppercase;
}

.site-footer {
	padding: 0;
	background: #071327;
	color: rgba(255, 255, 255, 0.62);
}

.site-footer__top {
	display: grid;
	grid-template-columns: minmax(240px, 1.35fr) repeat(3, minmax(150px, 0.78fr)) minmax(220px, 0.95fr);
	gap: 0;
	padding: 58px 0 48px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.site-footer__brand {
	padding-right: 38px;
}

.site-footer__logo {
	display: inline-flex;
	margin-bottom: 10px;
	color: #ffffff;
	font-size: clamp(24px, 1.8vw, 32px);
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1;
}

.site-footer__tagline {
	max-width: 360px;
	margin: 0 0 24px;
	color: rgba(255, 255, 255, 0.46);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.site-footer__contacts {
	display: grid;
	gap: 9px;
	font-style: normal;
}

.site-footer__contact {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	width: fit-content;
	color: rgba(255, 255, 255, 0.64);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.25;
	transition: color 0.2s ease;
}

.site-footer__contact:hover,
.site-footer__contact:focus-visible {
	color: #ffffff;
}

.site-footer__contact-icon {
	width: 7px;
	height: 7px;
	flex: 0 0 auto;
	border-radius: 50%;
	background: #7cc8ff;
	box-shadow: 0 0 0 5px rgba(124, 200, 255, 0.12);
}

.site-footer__nav-col,
.site-footer__cta {
	padding: 0 24px;
	border-left: 1px solid rgba(255, 255, 255, 0.07);
}

.site-footer__nav-title {
	margin: 0 0 15px;
	color: rgba(255, 255, 255, 0.32);
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 0.1em;
	line-height: 1;
	text-transform: uppercase;
}

.site-footer__nav-list,
.site-footer__legal-list {
	display: grid;
	gap: 9px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.site-footer__nav-link {
	display: block;
	color: rgba(255, 255, 255, 0.58);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.25;
	transition: color 0.2s ease;
}

.site-footer__nav-link:hover,
.site-footer__nav-link:focus-visible {
	color: #ffffff;
}

.site-footer__cta-title {
	margin: 0 0 9px;
	color: #ffffff;
	font-size: 16px;
	font-weight: 800;
	line-height: 1.2;
}

.site-footer__cta-desc {
	margin: 0 0 18px;
	color: rgba(255, 255, 255, 0.48);
	font-size: 13px;
	font-weight: 600;
	line-height: 1.5;
}

.site-footer__cta-btn {
	display: inline-flex;
	align-items: center;
	min-height: 42px;
	padding: 11px 16px;
	border: 1px solid rgba(124, 200, 255, 0.3);
	border-radius: 999px;
	background: rgba(124, 200, 255, 0.1);
	color: #ffffff;
	font-size: 14px;
	font-weight: 800;
	line-height: 1;
	white-space: nowrap;
	transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.site-footer__cta-btn:hover,
.site-footer__cta-btn:focus-visible {
	border-color: rgba(124, 200, 255, 0.6);
	background: rgba(124, 200, 255, 0.16);
	transform: translateY(-1px);
}

.site-footer__bottom {
	background: #050d1c;
}

.site-footer__bottom-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 16px 0;
}

.site-footer__copy {
	margin: 0;
	color: rgba(255, 255, 255, 0.34);
	font-size: 12px;
	font-weight: 600;
	line-height: 1.4;
}

.site-footer__legal-list {
	display: flex;
	flex-wrap: wrap;
	gap: 18px;
}

.site-footer__legal-link {
	color: rgba(255, 255, 255, 0.36);
	font-size: 12px;
	font-weight: 600;
	line-height: 1.4;
	transition: color 0.2s ease;
}

.site-footer__legal-link:hover,
.site-footer__legal-link:focus-visible {
	color: rgba(255, 255, 255, 0.72);
}

.site-footer a:focus-visible {
	outline: 2px solid #7cc8ff;
	outline-offset: 4px;
}

@media (max-width: 1440px) {
	.site-header__inner {
		gap: 22px;
		grid-template-columns: minmax(120px, 0.35fr) auto minmax(250px, 0.35fr);
	}

	.site-nav {
		gap: 4px;
		padding-inline: 6px;
	}

	.site-location {
		display: none;
	}

	.hero-screen__inner {
		min-height: calc(100svh - 174px);
		grid-template-columns: minmax(500px, 0.92fr) minmax(460px, 0.64fr);
		gap: 42px;
	}

	.hero-dashboard {
		width: min(100%, 560px);
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 12px;
	}

	.hero-visual {
		width: min(100%, 560px);
		height: 440px;
	}

	.hero-logo-visual {
		width: min(100%, 440px);
	}

	.hero-metric-card {
		padding: 22px;
		border-radius: 28px;
	}

	.advantages-grid {
		grid-template-columns: 1fr 1fr;
	}

	.clients-logo-row {
		grid-auto-columns: minmax(300px, 1fr);
		gap: 20px;
	}

	.services-section {
		padding: 92px 0 104px;
	}

	.service-card__body {
		padding: 34px;
	}

	.service-card h3 {
		font-size: clamp(28px, 2.3vw, 42px);
	}
}

@media (max-width: 1180px) {
	.site-header__inner {
		grid-template-columns: auto 1fr auto;
	}

	.nav-toggle {
		display: inline-flex;
		grid-column: 3;
		color: rgba(255, 255, 255, 0.94);
		transition: color 0.2s ease;
	}

	.site-header.is-scrolled .nav-toggle {
		color: #1d2634;
	}

	.site-header--light .nav-toggle {
		color: #1d2634;
	}

	.site-nav {
		position: absolute;
		top: calc(100% + 12px);
		left: 0;
		right: 0;
		display: none;
		padding: 10px;
		border-radius: 22px;
		background:
			linear-gradient(135deg, rgba(15, 23, 42, 0.88), rgba(15, 23, 42, 0.68)),
			rgba(7, 19, 39, 0.78);
		box-shadow: 0 24px 60px rgba(5, 14, 32, 0.24);
	}

	.site-nav.is-open {
		display: grid;
		gap: 6px;
		justify-content: stretch;
	}

	.site-nav a {
		justify-content: center;
	}

	.site-header.is-scrolled .site-nav {
		background:
			linear-gradient(135deg, rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0.74)),
			rgba(255, 255, 255, 0.86);
	}

	.site-header--light .site-nav {
		border-color: rgba(203, 213, 225, 0.74);
		background:
			linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.76)),
			rgba(255, 255, 255, 0.88);
		color: #31405a;
		box-shadow: 0 24px 60px rgba(15, 23, 42, 0.14);
	}

	.site-header__meta {
		margin-left: auto;
	}

	.hero-screen__inner {
		grid-template-columns: 1fr;
		align-items: start;
		gap: 30px;
	}

	.hero-screen__content {
		padding-top: 30px;
	}

	.hero-dashboard {
		width: min(100%, 620px);
		justify-self: start;
	}

	.hero-visual {
		justify-self: start;
	}

	.hero-logo-visual {
		width: min(100%, 380px);
		justify-self: start;
	}

	.advantages-section__intro {
		grid-template-columns: 1fr;
		gap: 22px;
	}

	.advantages-grid {
		grid-template-columns: 1fr;
	}

	.clients-strip-section__kicker {
		justify-self: center;
	}

	.card-01,
	.card-02,
	.card-03,
	.card-04 {
		grid-column: auto;
		grid-row: auto;
	}

	.services-grid {
		grid-template-columns: 1fr;
	}

	.service-card,
	.service-card--site,
	.service-card--maps,
	.service-card--seo,
	.service-card--ads {
		grid-column: auto;
		min-height: 380px;
	}
}

@media (max-width: 820px) {
	.container {
		width: min(calc(100% - 28px), var(--container));
	}

	.site-header {
		top: 12px;
	}

	.site-header__inner {
		min-height: 52px;
	}

	.site-logo__text {
		font-size: 24px;
	}

	.button--header,
	.site-phone {
		display: none;
	}

	.hero-screen {
		padding-top: 112px;
		border-radius: 0 0 16px 16px;
	}

	.hero-screen__inner {
		min-height: calc(100svh - 132px);
	}

	.hero-screen h1 {
		font-size: clamp(44px, 13vw, 74px);
	}

	.hero-subtitle {
		margin-top: 28px;
		font-size: 21px;
	}

	.hero-actions {
		margin-top: 30px;
	}

	.hero-dashboard,
	.hero-visual,
	.hero-logo-visual {
		display: none;
	}

	.advantages-section {
		padding: 64px 0 76px;
	}

	.services-section {
		padding: 70px 0 82px;
	}

	.services-section__intro h2 {
		font-size: clamp(30px, 8vw, 46px);
	}

	.services-section__intro p:last-child {
		font-size: 18px;
	}

	.services-grid {
		gap: 16px;
	}

	.service-card {
		min-height: 0;
		border-radius: 24px;
	}

	.service-card__body {
		padding: 26px;
	}

	.service-card h3 {
		font-size: clamp(24px, 7vw, 34px);
	}

	.service-card__lead,
	.service-card__result {
		font-size: 16px;
	}

	.service-card__link {
		font-size: 18px;
	}

	.service-visual {
		min-height: 92px;
		transform: scale(0.84);
		transform-origin: left center;
	}

	.service-card__icon {
		display: none;
	}

	.advantages-section__inner {
		gap: 34px;
	}

	.advantages-section__intro h2 {
		font-size: clamp(36px, 10vw, 58px);
	}

	.advantages-section__intro p {
		font-size: 19px;
		line-height: 1.48;
	}

	.advantages-grid {
		gap: 18px;
	}

	.clients-strip-section {
		padding: 52px 0 64px;
		border-radius: 34px 34px 0 0;
	}

	.clients-strip-section__kicker {
		margin-bottom: 34px;
		font-size: 17px;
	}

	.clients-strip-section h2 {
		font-size: clamp(34px, 10vw, 54px);
	}

	.clients-strip-section__contact {
		margin-top: 18px;
		font-size: 18px;
	}

	.clients-logo-row {
		grid-auto-columns: minmax(250px, 78vw);
		gap: 14px;
		margin-top: 38px;
		padding-inline: 14px;
	}

	.clients-logo-card {
		min-height: 128px;
		padding: 24px;
		border-radius: 16px;
	}

	.advantage-card {
		min-height: 0;
		padding: 26px;
		border-radius: 18px;
	}

	.advantage-card h3 {
		font-size: 26px;
	}

	.advantage-card p {
		font-size: 17px;
	}

	.cards-grid {
		grid-template-columns: 1fr;
	}

	.site-footer__top {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 30px 0;
		padding: 42px 0 36px;
	}

	.site-footer__brand,
	.site-footer__cta {
		grid-column: 1 / -1;
	}

	.site-footer__brand {
		padding-right: 0;
		padding-bottom: 28px;
		border-bottom: 1px solid rgba(255, 255, 255, 0.07);
	}

	.site-footer__nav-col {
		padding-left: 0;
	}

	.site-footer__cta {
		padding-left: 0;
		padding-top: 26px;
		border-top: 1px solid rgba(255, 255, 255, 0.07);
		border-left: 0;
	}

	.section-head {
		display: grid;
	}
}

@media (max-width: 520px) {
	.hero-subtitle {
		font-size: 18px;
	}

	.hero-kicker {
		margin-bottom: 18px;
	}

	.hero-actions .button {
		width: 100%;
	}

	.site-footer__top {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 26px 18px;
	}

	.site-footer__nav-col {
		border-left: 0;
		padding-right: 0;
	}

	.site-footer__bottom-inner {
		display: grid;
		justify-items: start;
	}

	.site-footer__legal-list {
		gap: 12px 16px;
	}
}

.services-section {
	background:
		radial-gradient(circle at 82% 8%, rgba(92, 130, 221, 0.28), transparent 34%),
		radial-gradient(circle at 8% 92%, rgba(52, 94, 214, 0.18), transparent 30%),
		linear-gradient(135deg, #071327 0%, #0b1329 58%, #16285f 100%);
}

.services-grid {
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
}

.service-card,
.service-card--site,
.service-card--maps,
.service-card--seo,
.service-card--ads {
	grid-column: auto;
	min-height: 360px;
	border-color: rgba(148, 177, 255, 0.2);
	background:
		radial-gradient(circle at 88% 0%, rgba(96, 165, 250, 0.14), transparent 36%),
		linear-gradient(145deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.012)),
		#0b1329;
}

.service-card h3 {
	font-size: clamp(26px, 2.05vw, 38px);
}

.service-card__lead,
.service-card__result {
	font-size: clamp(15px, 0.95vw, 18px);
}

.service-card__link {
	color: #7cc8ff;
	font-size: clamp(17px, 1.1vw, 21px);
}

.service-card__link::after,
.service-card__icon {
	display: none;
}

.service-serp {
	opacity: 0;
	transform: translateY(16px);
}

.service-card--seo:hover .service-serp {
	opacity: 1;
	transform: translateY(0);
}

@media (max-width: 1180px) {
	.services-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 820px) {
	.service-card,
	.service-card--site,
	.service-card--maps,
	.service-card--seo,
	.service-card--ads {
		min-height: 0;
	}

	.service-card h3 {
		font-size: clamp(24px, 7vw, 34px);
	}
}

.service-visual--ads {
	min-height: 292px;
	display: block;
	position: relative;
	margin-top: 4px;
	overflow: visible;
	isolation: isolate;
}

.service-ad-card {
	position: absolute;
	width: min(74%, 450px);
	height: 224px;
	padding: 30px 34px;
	border: 1px solid rgba(158, 188, 255, 0.24);
	border-radius: 22px;
	background:
		linear-gradient(135deg, rgba(124, 200, 255, 0.16), transparent 34%),
		linear-gradient(145deg, rgba(255, 255, 255, 0.11), rgba(255, 255, 255, 0.025) 48%, rgba(45, 82, 178, 0.11)),
		rgba(13, 26, 58, 0.88);
	backdrop-filter: blur(18px);
	box-shadow:
		0 28px 72px rgba(3, 8, 20, 0.26),
		inset 0 1px 0 rgba(255, 255, 255, 0.08);
	transform-origin: center;
	transition: transform 420ms cubic-bezier(0.22, 1, 0.36, 1),
		border-color 360ms ease,
		box-shadow 360ms ease;
}

.service-ad-card::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	background: linear-gradient(120deg, transparent 0 38%, rgba(255, 255, 255, 0.08) 48%, transparent 58%);
	opacity: 0.55;
	pointer-events: none;
}

.service-ad-card--search {
	left: 2%;
	top: 44px;
	z-index: 2;
	transform: rotate(-4.5deg);
}

.service-ad-card--direct {
	left: 31%;
	top: 52px;
	z-index: 1;
	transform: rotate(5.5deg);
	opacity: 0.92;
}

.service-card--ads:hover .service-ad-card--search {
	transform: translate(-12px, -10px) rotate(-6deg);
	border-color: rgba(124, 200, 255, 0.42);
	box-shadow:
		0 34px 84px rgba(3, 8, 20, 0.3),
		0 0 0 1px rgba(124, 200, 255, 0.08),
		inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.service-card--ads:hover .service-ad-card--direct {
	transform: translate(16px, 10px) rotate(7deg);
	border-color: rgba(124, 200, 255, 0.34);
}

.service-ad-card__mark {
	position: absolute;
	left: 28px;
	top: 28px;
	width: 54px;
	height: 54px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 14px;
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.055)),
		rgba(7, 19, 43, 0.42);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
	font-size: 27px;
	font-weight: 800;
	line-height: 1;
}

.service-ad-card__mark--google {
	color: #7cc8ff;
}

.service-ad-card__mark--yandex {
	background: rgba(52, 94, 214, 0.28);
	color: #ffffff;
}

.service-ad-card__badge {
	position: absolute;
	top: 30px;
	right: 28px;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 42px;
	padding: 9px 20px;
	border-radius: 999px;
	background: linear-gradient(135deg, rgba(47, 102, 225, 0.96), rgba(20, 61, 150, 0.9));
	color: rgba(255, 255, 255, 0.82);
	box-shadow: 0 12px 30px rgba(34, 87, 215, 0.25);
	font-size: 19px;
	line-height: 1;
}

.service-ad-card__badge::before {
	content: "";
	width: 16px;
	height: 16px;
	border-radius: 50%;
	background:
		linear-gradient(135deg, transparent 0 42%, #ffffff 42% 56%, transparent 56%),
		#7cc8ff;
}

.service-ad-card strong {
	position: absolute;
	left: 34px;
	right: 34px;
	bottom: 34px;
	color: rgba(255, 255, 255, 0.74);
	font-size: clamp(26px, 2.15vw, 40px);
	font-weight: 500;
	line-height: 1.1;
}

@media (max-width: 820px) {
	.service-visual--ads {
		min-height: 190px;
		transform: none;
	}

	.service-ad-card {
		width: 72%;
		height: 142px;
		padding: 18px 20px;
	}

	.service-ad-card__badge {
		top: 18px;
		right: 16px;
		min-height: 32px;
		font-size: 13px;
		padding-inline: 12px;
	}

	.service-ad-card__mark {
		left: 18px;
		top: 18px;
		width: 38px;
		height: 38px;
		border-radius: 10px;
		font-size: 19px;
	}

	.service-ad-card strong {
		left: 20px;
		right: 20px;
		bottom: 18px;
		font-size: 20px;
	}
}

/* Final services composition */
.services-section {
	padding: 96px 0 112px;
	background:
		radial-gradient(circle at 80% 6%, rgba(124, 200, 255, 0.2), transparent 30%),
		radial-gradient(circle at 12% 88%, rgba(52, 94, 214, 0.2), transparent 34%),
		linear-gradient(135deg, #071327 0%, #0b1329 52%, #16285f 100%);
}

.services-section__intro h2 {
	max-width: 820px;
	font-size: clamp(32px, 2.8vw, 54px);
	line-height: 1.08;
}

.services-section__intro p:last-child {
	max-width: 780px;
	font-size: clamp(16px, 1vw, 20px);
}

.services-grid {
	grid-template-columns: repeat(12, minmax(0, 1fr));
	gap: 18px;
}

.service-card,
.service-card--site,
.service-card--maps,
.service-card--seo,
.service-card--ads,
.service-card--reviews,
.service-card--analytics {
	grid-column: span 6;
	min-height: 392px;
	border-radius: 26px;
	border-color: rgba(148, 177, 255, 0.2);
	background:
		radial-gradient(circle at 88% 0%, rgba(124, 200, 255, 0.14), transparent 34%),
		linear-gradient(145deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.015)),
		#0b1329;
}

.service-card--site,
.service-card--analytics {
	grid-column: span 7;
}

.service-card--seo,
.service-card--reviews {
	grid-column: span 5;
}

.service-card--maps,
.service-card--analytics {
	background:
		radial-gradient(circle at 16% 100%, rgba(52, 94, 214, 0.28), transparent 44%),
		linear-gradient(145deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.015)),
		#111c39;
}

.service-card h3 {
	font-size: clamp(24px, 1.9vw, 34px);
	line-height: 1.12;
}

.service-card__lead,
.service-card__result {
	font-size: clamp(14px, 0.9vw, 17px);
	line-height: 1.38;
}

.service-card__body {
	gap: 18px;
	padding: clamp(24px, 2.2vw, 38px);
}

.service-card__link {
	font-size: clamp(16px, 1vw, 20px);
}

.service-visual {
	width: min(100%, 560px);
	min-height: 190px;
	margin: 0;
}

.service-site-ui,
.service-map-ui,
.service-reviews-ui,
.service-analytics-ui {
	position: relative;
	overflow: hidden;
	border: 1px solid rgba(158, 188, 255, 0.2);
	border-radius: 24px;
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.105), rgba(255, 255, 255, 0.025)),
		rgba(13, 26, 58, 0.78);
	box-shadow:
		0 24px 62px rgba(3, 8, 20, 0.22),
		inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.service-visual--site {
	display: block;
}

.service-site-ui {
	width: min(100%, 500px);
	min-height: 230px;
	padding: 18px;
}

.service-site-ui__top {
	display: flex;
	gap: 8px;
	margin-bottom: 18px;
}

.service-site-ui__top span {
	width: 46px;
	height: 8px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.18);
}

.service-site-ui__doctor {
	display: grid;
	grid-template-columns: 46px 1fr;
	gap: 12px;
	align-items: center;
	padding: 14px;
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.07);
	transform: translateY(0);
	transition: transform 360ms cubic-bezier(0.22, 1, 0.36, 1);
}

.service-site-ui__doctor i {
	width: 46px;
	height: 46px;
	border-radius: 16px;
	background:
		radial-gradient(circle at 50% 34%, #ffffff 0 16%, transparent 17%),
		radial-gradient(circle at 50% 88%, rgba(255, 255, 255, 0.72) 0 33%, transparent 34%),
		linear-gradient(135deg, #7cc8ff, #345ed6);
}

.service-site-ui__doctor strong,
.service-site-ui__doctor span {
	display: block;
}

.service-site-ui__doctor strong {
	color: rgba(255, 255, 255, 0.9);
	font-size: 15px;
	font-weight: 700;
}

.service-site-ui__doctor span {
	margin-top: 4px;
	position: static;
	width: auto;
	height: auto;
	min-height: 0;
	border: 0;
	border-radius: 0;
	background: transparent;
	box-shadow: none;
	color: rgba(255, 255, 255, 0.55);
	font-size: 13px;
	animation: none;
	clip-path: none;
}

.service-site-ui__slots {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 8px;
	margin-top: 14px;
}

.service-site-ui__slots span,
.service-map-ui__tags span,
.service-analytics-ui__sources span {
	position: static;
	width: auto;
	height: auto;
	min-height: 0;
	display: block;
	padding: 9px 10px;
	border-radius: 999px;
	background: rgba(124, 200, 255, 0.11);
	box-shadow: none;
	color: rgba(255, 255, 255, 0.74);
	font-size: 12px;
	text-align: center;
	animation: none;
	clip-path: none;
}

.service-site-ui__slots span:nth-child(3) {
	background: linear-gradient(135deg, #7cc8ff, #345ed6);
	color: #ffffff;
}

.service-site-ui__button {
	width: fit-content;
	margin-top: 16px;
	padding: 11px 18px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.88);
	color: #071327;
	font-size: 13px;
	font-weight: 800;
}

.service-card--site:hover .service-site-ui__doctor {
	transform: translateY(-7px);
}

.service-search-bar em {
	max-width: 18ch;
	animation: service-type-medical 2.5s steps(18, end) 0.45s forwards;
}

.service-visual--search {
	min-height: 262px;
}

.service-visual--map {
	display: block;
	min-height: 224px;
	border-radius: 0;
	background: transparent;
}

.service-map-ui {
	width: min(100%, 520px);
	min-height: 224px;
	background:
		linear-gradient(90deg, rgba(255, 255, 255, 0.055) 1px, transparent 1px),
		linear-gradient(180deg, rgba(255, 255, 255, 0.045) 1px, transparent 1px),
		linear-gradient(145deg, rgba(255, 255, 255, 0.09), rgba(255, 255, 255, 0.025)),
		rgba(13, 26, 58, 0.72);
	background-size: 42px 42px, 42px 42px, auto, auto;
}

.service-map-ui__route {
	position: absolute;
	left: 12%;
	top: 48%;
	width: 72%;
	height: 2px;
	border-radius: 999px;
	background: linear-gradient(90deg, rgba(124, 200, 255, 0.1), rgba(124, 200, 255, 0.72), rgba(124, 200, 255, 0.16));
	box-shadow: none;
	transform: rotate(-14deg);
	animation: none;
	clip-path: none;
}

.service-map-ui__pin {
	position: absolute;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: #7cc8ff;
	box-shadow: 0 0 0 10px rgba(124, 200, 255, 0.12);
	animation: service-ping 2.8s ease-in-out infinite;
}

.service-map-ui__pin--main {
	left: 60%;
	top: 40%;
}

.service-map-ui__pin--alt {
	left: 24%;
	top: 63%;
	width: 12px;
	height: 12px;
	opacity: 0.72;
	animation-delay: 0.55s;
}

.service-map-ui__card {
	position: absolute;
	left: 24px;
	top: 24px;
	width: 190px;
	padding: 15px;
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.88);
	color: #071327;
	box-shadow: 0 18px 46px rgba(3, 8, 20, 0.18);
	transform: translateY(8px);
	transition: transform 360ms cubic-bezier(0.22, 1, 0.36, 1);
}

.service-map-ui__card strong,
.service-map-ui__card span,
.service-map-ui__card small {
	display: block;
}

.service-map-ui__card strong {
	font-size: 15px;
}

.service-map-ui__card span {
	margin-top: 7px;
	position: static;
	width: auto;
	height: auto;
	min-height: 0;
	border-radius: 0;
	background: transparent;
	box-shadow: none;
	color: #345ed6;
	font-size: 13px;
	font-weight: 800;
	animation: none;
	clip-path: none;
}

.service-map-ui__card small {
	margin-top: 7px;
	color: rgba(7, 19, 39, 0.58);
	font-size: 12px;
}

.service-map-ui__tags {
	position: absolute;
	right: 18px;
	bottom: 18px;
	display: flex;
	gap: 8px;
}

.service-card--maps:hover .service-map-ui__card {
	transform: translateY(0);
}

.service-visual--reviews {
	display: block;
	min-height: 220px;
}

.service-reviews-ui {
	width: min(100%, 430px);
	min-height: 220px;
	padding: 20px;
}

.service-reviews-ui__score {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 16px;
}

.service-reviews-ui__score strong {
	color: #ffffff;
	font-size: 44px;
	line-height: 0.95;
}

.service-reviews-ui__score span {
	position: static;
	width: auto;
	height: auto;
	background: transparent;
	box-shadow: none;
	color: #7cc8ff;
	font-size: 17px;
	letter-spacing: 0;
	animation: none;
	clip-path: none;
}

.service-reviews-ui__list {
	display: grid;
	gap: 10px;
	margin-top: 18px;
}

.service-reviews-ui__list p {
	margin: 0;
	padding: 12px 14px;
	border-radius: 16px;
	background: rgba(255, 255, 255, 0.075);
	color: rgba(255, 255, 255, 0.68);
	font-size: 13px;
	line-height: 1.3;
	transform: translateY(0);
	transition: transform 320ms cubic-bezier(0.22, 1, 0.36, 1);
}

.service-reviews-ui__badge {
	width: fit-content;
	margin-top: 14px;
	padding: 9px 13px;
	border-radius: 999px;
	background: rgba(124, 200, 255, 0.12);
	color: #a8dcff;
	font-size: 12px;
	font-weight: 800;
}

.service-card--reviews:hover .service-reviews-ui__list p:first-child {
	transform: translateY(-6px);
}

.service-card--reviews:hover .service-reviews-ui__list p:last-child {
	transform: translateY(-3px);
}

.service-visual--analytics {
	display: block;
	height: auto;
	min-height: 232px;
}

.service-analytics-ui {
	width: min(100%, 520px);
	min-height: 232px;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 12px;
	padding: 18px;
}

.service-analytics-ui__metric {
	padding: 16px;
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.075);
}

.service-analytics-ui__metric strong,
.service-analytics-ui__metric span {
	display: block;
}

.service-analytics-ui__metric strong {
	color: #ffffff;
	font-size: 28px;
	line-height: 1;
}

.service-analytics-ui__metric span {
	margin-top: 8px;
	position: static;
	width: auto;
	height: auto;
	min-height: 0;
	border-radius: 0;
	background: transparent;
	box-shadow: none;
	color: rgba(255, 255, 255, 0.55);
	font-size: 12px;
	animation: none;
	clip-path: none;
}

.service-analytics-ui__bars {
	grid-column: 1 / -1;
	height: 92px;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	align-items: end;
	gap: 10px;
	padding: 12px 10px 0;
}

.service-analytics-ui__bars span {
	height: var(--h);
	min-height: 26px;
	border-radius: 12px 12px 4px 4px;
	background: linear-gradient(180deg, #7cc8ff, #345ed6);
	animation: service-bars 3.8s ease-in-out infinite;
}

.service-analytics-ui__bars span:nth-child(2) {
	animation-delay: 0.24s;
}

.service-analytics-ui__bars span:nth-child(3) {
	animation-delay: 0.48s;
}

.service-analytics-ui__bars span:nth-child(4) {
	animation-delay: 0.72s;
}

.service-analytics-ui__sources {
	grid-column: 1 / -1;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 8px;
}

.service-card--analytics:hover .service-analytics-ui__metric:first-child {
	background: rgba(124, 200, 255, 0.12);
}

@keyframes service-type-medical {
	from {
		width: 0;
	}

	to {
		width: 18ch;
	}
}

@media (max-width: 1180px) {
	.service-card,
	.service-card--site,
	.service-card--maps,
	.service-card--seo,
	.service-card--ads,
	.service-card--reviews,
	.service-card--analytics {
		grid-column: 1 / -1;
	}
}

@media (max-width: 820px) {
	.services-section {
		padding: 72px 0 82px;
	}

	.service-card,
	.service-card--site,
	.service-card--maps,
	.service-card--seo,
	.service-card--ads,
	.service-card--reviews,
	.service-card--analytics {
		min-height: 0;
		border-radius: 22px;
	}

	.service-card__body {
		padding: 22px;
	}

	.service-visual {
		min-height: 0;
	}

	.service-site-ui,
	.service-map-ui,
	.service-reviews-ui,
	.service-analytics-ui {
		min-height: 190px;
	}

	.service-analytics-ui {
		grid-template-columns: 1fr;
	}

	.service-analytics-ui__metric,
	.service-analytics-ui__bars,
	.service-analytics-ui__sources {
		grid-column: auto;
	}
}

/* SEO services block */
.services-block {
	padding: 96px 0 112px;
	background:
		radial-gradient(circle at 84% 8%, rgba(124, 200, 255, 0.18), transparent 30%),
		radial-gradient(circle at 10% 90%, rgba(52, 94, 214, 0.18), transparent 34%),
		linear-gradient(135deg, #071327 0%, #0b1329 54%, #16285f 100%);
	color: #ffffff;
}

.services-block__inner {
	display: grid;
	gap: 34px;
}

.services-block__intro {
	max-width: 860px;
	display: grid;
	gap: 14px;
}

.services-block__kicker {
	margin: 0;
	color: #7cc8ff;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.services-block h2 {
	margin: 0;
	color: #ffffff;
	font-size: clamp(34px, 3vw, 56px);
	font-weight: 500;
	line-height: 1.06;
	letter-spacing: 0;
}

.services-block__intro p:last-child {
	max-width: 760px;
	margin: 0;
	color: rgba(255, 255, 255, 0.64);
	font-size: clamp(16px, 1vw, 20px);
	line-height: 1.42;
}

.services-groups {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
}

.service-group {
	--group-accent: #345ed6;
	--group-accent-rgb: 52, 94, 214;
	position: relative;
	display: grid;
	gap: 18px;
	min-width: 0;
	padding: clamp(22px, 2vw, 32px);
	border: 1px solid rgba(148, 177, 255, 0.18);
	border-radius: 28px;
	background:
		radial-gradient(circle at 92% 0%, rgba(var(--group-accent-rgb), 0.18), transparent 34%),
		linear-gradient(145deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.016)),
		rgba(11, 19, 41, 0.9);
	box-shadow: 0 22px 68px rgba(3, 8, 20, 0.22);
}

.service-group[data-group="acquisition"] {
	--group-accent: #345ed6;
	--group-accent-rgb: 52, 94, 214;
}

.service-group[data-group="reputation"] {
	--group-accent: #6d5dfc;
	--group-accent-rgb: 109, 93, 252;
}

.service-group[data-group="retention"] {
	--group-accent: #0f9f8e;
	--group-accent-rgb: 15, 159, 142;
}

.service-group[data-group="brand"] {
	--group-accent: #ef6b4f;
	--group-accent-rgb: 239, 107, 79;
}

.group-header {
	display: grid;
	gap: 10px;
}

.group-problem {
	width: fit-content;
	display: inline-flex;
	align-items: center;
	min-height: 28px;
	padding: 7px 12px;
	border-radius: 999px;
	background: rgba(var(--group-accent-rgb), 0.16);
	color: rgba(255, 255, 255, 0.76);
	font-size: 12px;
	font-weight: 700;
	line-height: 1;
}

.group-title {
	margin: 0;
	color: #ffffff;
	font-size: clamp(22px, 1.7vw, 30px);
	font-weight: 600;
	line-height: 1.14;
	letter-spacing: 0;
}

.service-cards {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.services-block .service-card {
	position: relative;
	min-height: 0;
	grid-column: auto;
	overflow: visible;
	border: 0;
	border-radius: 18px;
	background: transparent;
	box-shadow: none;
	list-style: none;
	transform: none;
	transition: none;
}

.services-block .service-card:hover {
	transform: none;
	border-color: transparent;
	box-shadow: none;
}

.card-link-wrap {
	min-height: 190px;
	height: 100%;
	display: grid;
	grid-template-rows: auto auto 1fr auto;
	gap: 10px;
	padding: 16px;
	border: 1px solid rgba(148, 177, 255, 0.16);
	border-radius: 18px;
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.095), rgba(255, 255, 255, 0.022)),
		rgba(13, 26, 58, 0.72);
	color: inherit;
	text-decoration: none;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
	transition: transform 220ms ease, border-color 220ms ease, background-color 220ms ease, box-shadow 220ms ease;
}

.services-block .service-card:hover .card-link-wrap,
.services-block .service-card:focus-within .card-link-wrap {
	transform: translateY(-2px);
	border-color: rgba(var(--group-accent-rgb), 0.52);
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.03)),
		rgba(15, 31, 69, 0.88);
	box-shadow:
		0 16px 38px rgba(3, 8, 20, 0.18),
		inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.card-link-wrap:focus-visible {
	outline: 2px solid var(--group-accent);
	outline-offset: 4px;
}

.card-icon {
	position: relative;
	width: 38px;
	height: 38px;
	display: block;
	border-radius: 14px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.36), transparent),
		linear-gradient(135deg, var(--group-accent), var(--group-accent)),
		var(--group-accent);
	box-shadow: 0 12px 26px rgba(var(--group-accent-rgb), 0.22);
}

.card-icon::before,
.card-icon::after {
	content: "";
	position: absolute;
	inset: 11px;
	border: 2px solid rgba(7, 19, 39, 0.7);
	border-radius: 50%;
}

.card-icon::after {
	inset: auto 8px 8px auto;
	width: 10px;
	height: 2px;
	border: 0;
	border-radius: 999px;
	background: rgba(7, 19, 39, 0.7);
	transform: rotate(45deg);
}

.card-icon--speakerphone::before {
	inset: 11px 9px 11px 14px;
	border-radius: 4px 12px 12px 4px;
}

.card-icon--speakerphone::after,
.card-icon--map-pin::after,
.card-icon--star::after,
.card-icon--gift::after,
.card-icon--palette::after {
	opacity: 0;
	width: 0;
	height: 0;
}

.card-icon--map-pin::before,
.card-icon--user-check::before {
	inset: 8px 11px 13px;
	border-radius: 50% 50% 50% 4px;
	transform: rotate(-45deg);
}

.card-icon--code::before {
	inset: 12px 9px;
	border: 0;
	border-left: 3px solid rgba(7, 19, 39, 0.7);
	border-bottom: 3px solid rgba(7, 19, 39, 0.7);
	border-radius: 0;
	transform: rotate(45deg);
}

.card-icon--code::after {
	right: 9px;
	bottom: 13px;
	width: 13px;
	height: 3px;
	transform: rotate(-45deg);
}

.card-icon--list-check::before,
.card-icon--database::before {
	inset: 9px 10px;
	border-radius: 6px;
}

.card-icon--list-check::after,
.card-icon--database::after {
	right: 10px;
	bottom: 12px;
}

.card-icon--star::before,
.card-icon--award::before {
	inset: 9px;
	border: 0;
	border-radius: 0;
	background: rgba(7, 19, 39, 0.72);
	clip-path: polygon(50% 0, 61% 34%, 97% 35%, 68% 56%, 78% 92%, 50% 70%, 22% 92%, 32% 56%, 3% 35%, 39% 34%);
}

.card-icon--repeat::before {
	inset: 10px;
	border-top-color: transparent;
	transform: rotate(35deg);
}

.card-icon--repeat::after {
	right: 9px;
	bottom: 12px;
	width: 8px;
	height: 8px;
	clip-path: polygon(0 0, 100% 50%, 0 100%);
	transform: none;
}

.card-icon--users::before,
.card-icon--social::before {
	inset: 9px 8px 13px;
	box-shadow: 10px 6px 0 -3px rgba(7, 19, 39, 0.7);
}

.card-icon--gift::before {
	inset: 11px 9px 8px;
	border-radius: 4px;
}

.card-icon--gift::after {
	display: block;
	left: 18px;
	top: 9px;
	width: 2px;
	height: 21px;
	background: rgba(7, 19, 39, 0.7);
	transform: none;
}

.card-icon--palette::before {
	inset: 8px;
	border-radius: 50% 50% 46% 54%;
}

.card-name {
	margin: 2px 0 0;
	color: #ffffff;
	font-size: clamp(16px, 1vw, 19px);
	font-weight: 700;
	line-height: 1.18;
	letter-spacing: 0;
}

.card-desc {
	display: block;
	color: rgba(255, 255, 255, 0.62);
	font-size: 13px;
	line-height: 1.36;
}

.card-cta {
	display: inline-flex;
	align-items: center;
	width: fit-content;
	color: var(--group-accent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.1;
}

@media (max-width: 1023px) {
	.services-groups {
		grid-template-columns: 1fr;
	}

	.service-cards {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	.services-block {
		padding: 72px 0 84px;
	}

	.services-block__inner {
		gap: 24px;
	}

	.service-group {
		gap: 16px;
		padding: 20px;
		border-radius: 22px;
	}

	.service-cards {
		grid-template-columns: 1fr;
	}

	.card-link-wrap {
		min-height: 0;
	}
}

/* Services light theme and custom SVG icon slots */
.services-block {
	background:
		radial-gradient(circle at 86% 6%, rgba(124, 200, 255, 0.18), transparent 30%),
		radial-gradient(circle at 10% 92%, rgba(52, 94, 214, 0.08), transparent 34%),
		#f4f7fb;
	color: #071327;
}

.services-block h2,
.group-title,
.card-name {
	color: #071327;
}

.services-block__intro p:last-child {
	color: rgba(7, 19, 39, 0.66);
}

.services-block__kicker {
	color: #345ed6;
}

.service-group {
	border-color: rgba(var(--group-accent-rgb), 0.16);
	background:
		radial-gradient(circle at 92% 0%, rgba(var(--group-accent-rgb), 0.14), transparent 34%),
		linear-gradient(145deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.68)),
		#ffffff;
	box-shadow: 0 22px 54px rgba(33, 55, 100, 0.09);
}

.group-problem {
	background: rgba(var(--group-accent-rgb), 0.14);
	color: rgba(7, 19, 39, 0.68);
}

.card-link-wrap {
	border-color: rgba(var(--group-accent-rgb), 0.14);
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(247, 250, 255, 0.86)),
		#ffffff;
	color: #071327;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.services-block .service-card:hover .card-link-wrap,
.services-block .service-card:focus-within .card-link-wrap {
	border-color: rgba(var(--group-accent-rgb), 0.48);
	background: #ffffff;
	box-shadow:
		0 16px 34px rgba(33, 55, 100, 0.12),
		inset 0 1px 0 rgba(255, 255, 255, 0.95);
}

.card-desc {
	color: rgba(7, 19, 39, 0.62);
}

.card-icon {
	position: relative;
	width: 42px;
	height: 42px;
	display: block;
	border: 1px solid rgba(var(--group-accent-rgb), 0.22);
	border-radius: 14px;
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.92), rgba(231, 242, 255, 0.72)),
		rgba(var(--group-accent-rgb), 0.12);
	box-shadow:
		0 12px 24px rgba(var(--group-accent-rgb), 0.1),
		inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

.card-icon::before,
.card-icon::after {
	content: "";
	position: absolute;
	inset: 12px;
	border: 2px solid rgba(7, 19, 39, 0.72);
	border-radius: 50%;
}

.card-icon::after {
	inset: auto 9px 10px auto;
	width: 10px;
	height: 2px;
	border: 0;
	border-radius: 999px;
	background: rgba(7, 19, 39, 0.72);
	transform: rotate(45deg);
}

.card-icon:not(:empty)::before,
.card-icon:not(:empty)::after {
	content: none;
}

.card-icon svg,
.card-icon img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: contain;
	padding: 9px;
}

.card-icon[class*="card-icon--"]::before {
	content: "";
	position: absolute;
	inset: 10px;
	border: 0;
	border-radius: 0;
	background: var(--group-accent);
	box-shadow: none;
	clip-path: none;
	transform: none;
	-webkit-mask: var(--card-icon-mask, url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.8-3.8'/%3E%3C/svg%3E")) center / contain no-repeat;
	mask: var(--card-icon-mask, url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.8-3.8'/%3E%3C/svg%3E")) center / contain no-repeat;
}

.card-icon[class*="card-icon--"]::after {
	content: none;
}

.card-icon--search {
	--card-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.8-3.8'/%3E%3C/svg%3E");
}

.card-icon--target {
	--card-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Ccircle cx='12' cy='12' r='5'/%3E%3Ccircle cx='12' cy='12' r='1.5'/%3E%3C/svg%3E");
}

.card-icon--shield-check {
	--card-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10Z'/%3E%3Cpath d='m9 12 2 2 4-5'/%3E%3C/svg%3E");
}

.card-icon--speakerphone {
	--card-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 13v-3a2 2 0 0 1 2-2h3l7-3v14l-7-3H6a2 2 0 0 1-2-2Z'/%3E%3Cpath d='M8 16l1 4'/%3E%3C/svg%3E");
}

.card-icon--map-pin {
	--card-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21s7-5.1 7-11a7 7 0 1 0-14 0c0 5.9 7 11 7 11Z'/%3E%3Ccircle cx='12' cy='10' r='2.3'/%3E%3C/svg%3E");
}

.card-icon--code {
	--card-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m8 9-4 3 4 3'/%3E%3Cpath d='m16 9 4 3-4 3'/%3E%3Cpath d='m14 5-4 14'/%3E%3C/svg%3E");
}

.card-icon--list-check {
	--card-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M10 6h10'/%3E%3Cpath d='M10 12h10'/%3E%3Cpath d='M10 18h10'/%3E%3Cpath d='m3 6 1.5 1.5L7 4'/%3E%3Cpath d='m3 12 1.5 1.5L7 10'/%3E%3Cpath d='m3 18 1.5 1.5L7 16'/%3E%3C/svg%3E");
}

.card-icon--star {
	--card-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='m12 2 3.1 6.3 6.9 1-5 4.9 1.2 6.8L12 17.8 5.8 21 7 14.2 2 9.3l6.9-1Z'/%3E%3C/svg%3E");
}

.card-icon--award {
	--card-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='8' r='5'/%3E%3Cpath d='M8.5 12.5 7 22l5-3 5 3-1.5-9.5'/%3E%3C/svg%3E");
}

.card-icon--repeat {
	--card-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m17 2 4 4-4 4'/%3E%3Cpath d='M3 11V9a4 4 0 0 1 4-4h14'/%3E%3Cpath d='m7 22-4-4 4-4'/%3E%3Cpath d='M21 13v2a4 4 0 0 1-4 4H3'/%3E%3C/svg%3E");
}

.card-icon--database {
	--card-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cellipse cx='12' cy='5' rx='7' ry='3'/%3E%3Cpath d='M5 5v10c0 1.7 3.1 3 7 3s7-1.3 7-3V5'/%3E%3Cpath d='M5 10c0 1.7 3.1 3 7 3s7-1.3 7-3'/%3E%3C/svg%3E");
}

.card-icon--users {
	--card-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 21v-2a4 4 0 0 0-4-4H7a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9.5' cy='7' r='4'/%3E%3Cpath d='M22 21v-2a4 4 0 0 0-3-3.8'/%3E%3Cpath d='M16 3.2a4 4 0 0 1 0 7.6'/%3E%3C/svg%3E");
}

.card-icon--gift {
	--card-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 12v10H4V12'/%3E%3Cpath d='M2 7h20v5H2Z'/%3E%3Cpath d='M12 22V7'/%3E%3Cpath d='M12 7H7.5A2.5 2.5 0 1 1 12 4.5V7Z'/%3E%3Cpath d='M12 7h4.5A2.5 2.5 0 1 0 12 4.5V7Z'/%3E%3C/svg%3E");
}

.card-icon--social {
	--card-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 11.5a8.5 8.5 0 0 1-12.7 7.4L3 20l1.1-5.1A8.5 8.5 0 1 1 21 11.5Z'/%3E%3Cpath d='M8 12h.01'/%3E%3Cpath d='M12 12h.01'/%3E%3Cpath d='M16 12h.01'/%3E%3C/svg%3E");
}

.card-icon--user-check {
	--card-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 21v-2a4 4 0 0 0-4-4H6a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='m16 11 2 2 4-5'/%3E%3C/svg%3E");
}

.card-icon--palette {
	--card-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22a10 10 0 1 1 10-10c0 1.7-1 3-2.5 3H17a2 2 0 0 0-2 2c0 .5.2 1 .5 1.4.7 1-.1 2.6-1.6 2.6H12Z'/%3E%3Ccircle cx='7.5' cy='10.5' r='1'/%3E%3Ccircle cx='12' cy='7.5' r='1'/%3E%3Ccircle cx='16.5' cy='10.5' r='1'/%3E%3C/svg%3E");
}

/* Services readability tuning */
.services-block {
	background:
		radial-gradient(circle at 84% 8%, rgba(124, 200, 255, 0.16), transparent 28%),
		radial-gradient(circle at 10% 92%, rgba(52, 94, 214, 0.08), transparent 32%),
		#f4f7fb;
}

.services-block__intro p:last-child {
	color: rgba(7, 19, 39, 0.74);
}

.service-group {
	border-color: rgba(var(--group-accent-rgb), 0.16);
	background:
		radial-gradient(circle at 92% 0%, rgba(var(--group-accent-rgb), 0.12), transparent 34%),
		#ffffff;
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.12);
}

.group-problem {
	background: rgba(var(--group-accent-rgb), 0.18);
	color: rgba(7, 19, 39, 0.76);
}

.card-link-wrap {
	min-height: 166px;
	align-content: start;
	border-color: rgba(var(--group-accent-rgb), 0.18);
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.94), rgba(244, 247, 251, 0.92)),
		#ffffff;
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.86),
		0 8px 20px rgba(33, 55, 100, 0.05);
	transition: transform 360ms cubic-bezier(0.22, 1, 0.36, 1),
		border-color 360ms ease,
		background 360ms ease,
		box-shadow 360ms ease;
}

.services-block .service-card:hover .card-link-wrap,
.services-block .service-card:focus-within .card-link-wrap {
	transform: translateY(-1px);
	border-color: rgba(var(--group-accent-rgb), 0.42);
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(239, 245, 255, 0.96)),
		#ffffff;
	box-shadow:
		0 10px 24px rgba(33, 55, 100, 0.1),
		inset 0 1px 0 rgba(255, 255, 255, 0.95);
}

.card-name {
	color: #071327;
	font-weight: 800;
}

.card-desc {
	color: rgba(7, 19, 39, 0.72);
	font-weight: 500;
}

.card-cta {
	color: var(--group-accent);
}

.card-icon {
	width: 42px;
	height: 42px;
	margin-bottom: 2px;
}

/* SEO hero block */
.hero {
	position: relative;
	min-height: 100vh;
	overflow: hidden;
	display: flex;
	align-items: center;
	padding: 150px 0 92px;
	background:
		radial-gradient(circle at 84% 22%, rgba(124, 200, 255, 0.34), transparent 34%),
		radial-gradient(circle at 52% 120%, rgba(52, 94, 214, 0.32), transparent 38%),
		linear-gradient(135deg, #071327 0%, #0b1329 56%, #1d356f 100%);
	color: #ffffff;
}

.hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(110deg, rgba(255, 255, 255, 0.055) 0 1px, transparent 1px 18%),
		radial-gradient(circle, rgba(255, 255, 255, 0.42) 0 1px, transparent 1.6px);
	background-size: 100% 100%, 360px 260px;
	opacity: 0.18;
	pointer-events: none;
}

.hero__stars {
	position: absolute;
	inset: 0;
	pointer-events: none;
}

.hero__inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	align-items: center;
	gap: 32px;
}

.hero__content {
	max-width: 1040px;
	display: grid;
	gap: 24px;
}

.hero__eyebrow {
	width: fit-content;
	margin: 0;
	padding: 9px 14px;
	border-radius: 999px;
	background: rgba(124, 200, 255, 0.13);
	color: rgba(255, 255, 255, 0.76);
	font-size: 14px;
	font-weight: 700;
	line-height: 1;
}

.hero__title {
	max-width: 940px;
	margin: 0;
	color: #ffffff;
	font-size: clamp(32px, 4.5vw, 56px);
	font-weight: 700;
	line-height: 1.15;
	letter-spacing: 0;
}

.hero__subtitle {
	max-width: 760px;
	margin: 0;
	color: rgba(255, 255, 255, 0.72);
	font-size: clamp(16px, 1.4vw, 20px);
	font-weight: 400;
	line-height: 1.55;
}

.hero__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 18px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: rgba(255, 255, 255, 0.78);
	font-size: 14px;
	font-weight: 600;
}

.hero__badges li {
	position: relative;
	padding-left: 22px;
}

.hero__badges li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.35em;
	width: 13px;
	height: 13px;
	border-radius: 50%;
	background:
		linear-gradient(135deg, transparent 0 42%, #071327 42% 56%, transparent 56%),
		#7cc8ff;
}

.hero__cta {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: center;
}

.btn {
	min-height: 52px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 8px;
	font-size: 16px;
	font-weight: 600;
	line-height: 1;
	white-space: nowrap;
	transition: transform 220ms ease, border-color 220ms ease, background-color 220ms ease, box-shadow 220ms ease;
}

.btn:hover,
.btn:focus-visible {
	transform: translateY(-1px);
}

.btn:focus-visible {
	outline: 2px solid #7cc8ff;
	outline-offset: 4px;
}

.btn--primary {
	padding: 14px 28px;
	background: linear-gradient(100deg, #55c0f2 0%, #345ed6 100%);
	color: #ffffff;
	box-shadow: 0 16px 34px rgba(52, 94, 214, 0.28);
}

.btn--ghost {
	padding: 14px 24px;
	border: 1.5px solid rgba(255, 255, 255, 0.48);
	background: rgba(255, 255, 255, 0.04);
	color: #ffffff;
}

.btn--ghost:hover,
.btn--ghost:focus-visible {
	border-color: rgba(124, 200, 255, 0.72);
	background: rgba(124, 200, 255, 0.08);
}

@media (max-width: 1023px) {
	.hero {
		min-height: auto;
		padding: 136px 0 72px;
	}

	.hero__inner {
		grid-template-columns: 1fr;
		gap: 34px;
	}

	.hero__content {
		max-width: 760px;
	}
}

@media (max-width: 767px) {
	.hero {
		padding: 124px 0 60px;
	}

	.hero__content {
		gap: 18px;
	}

	.hero__title {
		font-size: clamp(28px, 8.5vw, 42px);
		line-height: 1.14;
	}

	.hero__subtitle {
		font-size: 16px;
		line-height: 1.48;
	}

	.hero__badges {
		display: grid;
		gap: 8px;
		font-size: 13px;
	}

	.hero__cta {
		display: grid;
		grid-template-columns: 1fr;
	}

	.btn {
		width: 100%;
		white-space: normal;
		text-align: center;
	}

}

/* ============================================================
   Metrics Block
   ============================================================ */

.metrics-block {
	padding: 96px 0 112px;
	background: #ffffff;
}

.metrics-eyebrow {
	margin: 0 0 18px;
	color: #9ca3af;
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.metrics-head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 24px;
	margin-bottom: 34px;
}

.metrics-title {
	max-width: 760px;
	margin: 0;
	color: #0f172a;
	font-size: clamp(34px, 4.6vw, 72px);
	font-weight: 600;
	line-height: 0.98;
	letter-spacing: 0;
}

.metrics-controls {
	display: flex;
	gap: 10px;
	padding-top: 7px;
}

.metrics-arrow {
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(52, 94, 214, 0.18);
	border-radius: 50%;
	background: #ffffff;
	box-shadow: 0 14px 34px rgba(5, 14, 32, 0.07);
	color: var(--color-blue);
	font-size: 19px;
	line-height: 1;
	cursor: pointer;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.metrics-arrow:hover,
.metrics-arrow:focus-visible {
	border-color: transparent;
	background: linear-gradient(100deg, #55c0f2 0%, var(--color-blue) 100%);
	box-shadow: 0 18px 38px rgba(52, 94, 214, 0.24);
	color: #ffffff;
	transform: translateY(-1px);
}

.metrics-arrow:focus-visible,
.metrics-card:focus-visible,
.metrics-dot:focus-visible {
	outline: 2px solid #7cc8ff;
	outline-offset: 3px;
}

.metrics-cards {
	display: flex;
	gap: 10px;
	height: 360px;
	overflow: visible;
}

.metrics-card {
	--metric-accent: #7cc8ff;
	--metric-accent-rgb: 124, 200, 255;

	position: relative;
	flex: 0 0 78px;
	min-width: 0;
	padding: 0;
	overflow: hidden;
	border: 1px solid #e5e7eb;
	border-radius: 24px;
	background:
		linear-gradient(180deg, rgba(124, 200, 255, 0.1) 0%, rgba(255, 255, 255, 0) 42%),
		#ffffff;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
	color: inherit;
	text-align: left;
	cursor: pointer;
	transition:
		flex 0.62s cubic-bezier(0.16, 1, 0.3, 1),
		border-color 0.25s ease,
		box-shadow 0.25s ease,
		transform 0.25s ease,
		background 0.25s ease;
}

.metrics-card.is-active {
	flex: 1 1 0%;
	border-color: rgba(var(--metric-accent-rgb), 0.42);
	background:
		radial-gradient(circle at 88% 4%, rgba(var(--metric-accent-rgb), 0.24), transparent 30%),
		linear-gradient(135deg, #071327 0%, #0b1329 54%, #16285f 100%);
	box-shadow: 0 28px 70px rgba(7, 19, 39, 0.22);
}

.metrics-card:not(.is-active):hover {
	border-color: rgba(var(--metric-accent-rgb), 0.52);
	box-shadow: 0 18px 48px rgba(5, 14, 32, 0.08);
	transform: translateY(-2px);
}

.metrics-card__idle,
.metrics-card__body {
	position: absolute;
	inset: 0;
}

.metrics-card__idle {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-end;
	gap: 14px;
	padding: 22px 12px;
	transition: opacity 0.2s ease;
}

.metrics-card.is-active .metrics-card__idle {
	opacity: 0;
	pointer-events: none;
}

.metrics-card__idle-number {
	color: #0f172a;
	font-size: 32px;
	font-weight: 600;
	font-variant-numeric: tabular-nums;
	line-height: 1;
	writing-mode: vertical-rl;
	text-orientation: mixed;
}

.metrics-card__idle-label {
	color: #8c929f;
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	writing-mode: vertical-rl;
}

.metrics-card__body {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: clamp(24px, 3vw, 44px);
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s ease 0.18s;
}

.metrics-card.is-active .metrics-card__body {
	opacity: 1;
	pointer-events: auto;
}

.metrics-card__tag {
	margin: 0 0 16px;
	color: var(--metric-accent);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.metrics-card__number {
	margin: 0;
	color: #ffffff;
	font-size: clamp(72px, 9vw, 132px);
	font-weight: 600;
	font-variant-numeric: tabular-nums;
	line-height: 1;
	white-space: nowrap;
}

.metrics-card__affix {
	color: rgba(var(--metric-accent-rgb), 0.9);
	font-size: 0.35em;
	font-weight: 500;
	vertical-align: 0.14em;
}

.metrics-card__label {
	max-width: 430px;
	margin-top: 12px;
	color: #ffffff;
	font-size: clamp(17px, 1.5vw, 24px);
	font-weight: 500;
	line-height: 1.3;
}

.metrics-card__detail {
	max-width: 520px;
	margin-top: 16px;
	padding-left: 16px;
	border-left: 2px solid rgba(var(--metric-accent-rgb), 0.42);
	color: rgba(255, 255, 255, 0.68);
	font-size: clamp(13px, 1vw, 16px);
	font-weight: 500;
	line-height: 1.55;
}

.metrics-card__line {
	display: block;
	height: 1px;
	margin-top: 24px;
	background: linear-gradient(90deg, var(--metric-accent), rgba(255, 255, 255, 0.08));
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1) 0.3s;
}

.metrics-card.is-active .metrics-card__line {
	transform: scaleX(1);
}

.metrics-dots {
	display: flex;
	gap: 8px;
	margin-top: 18px;
}

.metrics-dot {
	width: 28px;
	height: 4px;
	padding: 0;
	border: 0;
	border-radius: 999px;
	background: #d7deeb;
	cursor: pointer;
	transition: width 0.25s ease, background 0.25s ease;
}

.metrics-dot.is-active {
	width: 42px;
	background: linear-gradient(90deg, #55c0f2, var(--color-blue));
}

/* --- Responsive --- */

@media (max-width: 768px) {
	.metrics-block {
		padding: 64px 0 80px;
	}

	.metrics-head {
		flex-wrap: wrap;
		margin-bottom: 28px;
	}

	.metrics-title {
		font-size: clamp(32px, 10vw, 52px);
	}

	.metrics-cards {
		height: auto;
		min-height: 520px;
		flex-direction: column;
		gap: 8px;
	}

	.metrics-card {
		flex: 0 0 74px;
		border-radius: 22px;
	}

	.metrics-card.is-active {
		flex: 1 1 340px;
	}

	.metrics-card__idle {
		flex-direction: row;
		justify-content: space-between;
		padding: 18px 22px;
	}

	.metrics-card__idle-number,
	.metrics-card__idle-label {
		writing-mode: horizontal-tb;
	}

	.metrics-card__idle-number {
		font-size: 30px;
	}

	.metrics-card__number {
		font-size: clamp(58px, 17vw, 92px);
	}
}

@media (max-width: 480px) {
	.metrics-block {
		padding: 56px 0 72px;
	}

	.metrics-cards {
		min-height: 500px;
	}

	.metrics-card__body {
		padding: 24px 22px;
	}

	.metrics-card__detail {
		padding-left: 12px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.metrics-card,
	.metrics-arrow,
	.metrics-dot,
	.metrics-card__idle,
	.metrics-card__body,
	.metrics-card__line {
		transition-duration: 0.01s;
	}

	.metrics-card {
		transform: none;
	}

	.metrics-card__line {
		transform: scaleX(1);
	}
}

/* ============================================================
   Cases Block
   ============================================================ */

.cases-block {
	padding: 96px 0 112px;
	background: #f4f7fb;
	color: #071327;
}

.cases-block__inner {
	display: grid;
	gap: 34px;
}

.cases-block__head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 24px;
}

.cases-block__intro {
	max-width: 820px;
	display: grid;
	gap: 12px;
}

.cases-block__kicker {
	margin: 0;
	color: var(--color-blue);
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.08em;
	line-height: 1;
	text-transform: uppercase;
}

.cases-block__title {
	margin: 0;
	color: #071327;
	font-size: clamp(34px, 3.5vw, 64px);
	font-weight: 600;
	line-height: 1.05;
	letter-spacing: 0;
}

.cases-block__all {
	display: inline-flex;
	align-items: center;
	min-height: 44px;
	padding: 11px 18px;
	border: 1px solid rgba(52, 94, 214, 0.2);
	border-radius: 999px;
	background: #ffffff;
	color: var(--color-blue);
	font-size: 15px;
	font-weight: 700;
	line-height: 1;
	white-space: nowrap;
	box-shadow: 0 12px 28px rgba(33, 55, 100, 0.06);
	transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}

.cases-block__all:hover,
.cases-block__all:focus-visible {
	border-color: rgba(52, 94, 214, 0.42);
	box-shadow: 0 16px 34px rgba(33, 55, 100, 0.11);
	transform: translateY(-1px);
}

.cases-block__all:focus-visible,
.case-card__title a:focus-visible,
.case-card__service:focus-visible,
.case-card__cta:focus-visible {
	outline: 2px solid #7cc8ff;
	outline-offset: 4px;
}

.cases-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.cases-grid__item {
	min-width: 0;
}

.case-card {
	height: 100%;
	display: flex;
	flex-direction: column;
	overflow: hidden;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 24px;
	background: #ffffff;
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.09);
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.case-card:hover,
.case-card:focus-within {
	border-color: rgba(52, 94, 214, 0.32);
	box-shadow: 0 24px 58px rgba(33, 55, 100, 0.14);
	transform: translateY(-2px);
}

.case-card__media {
	position: relative;
	display: block;
	aspect-ratio: 5 / 3;
	overflow: hidden;
	background: #e8f2ff;
}

.case-card__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.case-card:hover .case-card__image,
.case-card:focus-within .case-card__image {
	transform: scale(1.03);
}

.case-card__badge {
	position: absolute;
	left: 16px;
	top: 16px;
	display: inline-flex;
	align-items: center;
	min-height: 30px;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(7, 19, 39, 0.78);
	color: #ffffff;
	font-size: 12px;
	font-weight: 700;
	line-height: 1;
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}

.case-card__body {
	flex: 1;
	display: flex;
	flex-direction: column;
	padding: 22px;
}

.case-card__meta {
	margin: 0 0 10px;
	color: rgba(7, 19, 39, 0.52);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.08em;
	line-height: 1.35;
	text-transform: uppercase;
}

.case-card__title {
	margin: 0 0 18px;
	font-size: clamp(20px, 1.35vw, 26px);
	font-weight: 700;
	line-height: 1.18;
	letter-spacing: 0;
}

.case-card__title a {
	color: #071327;
	text-decoration: none;
}

.case-card__title a:hover {
	color: var(--color-blue);
}

.case-card__metrics {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
	margin: 0 0 18px;
	padding: 16px 0;
	border-top: 1px solid #e5e7eb;
	border-bottom: 1px solid #e5e7eb;
}

.case-card__metric {
	display: grid;
	gap: 4px;
	min-width: 0;
}

.case-card__metric-value {
	color: #071327;
	font-size: clamp(24px, 2vw, 34px);
	font-weight: 700;
	font-variant-numeric: tabular-nums;
	line-height: 1;
	white-space: nowrap;
}

.case-card__metric-label {
	color: rgba(7, 19, 39, 0.56);
	font-size: 12px;
	font-weight: 600;
	line-height: 1.22;
}

.case-card__services {
	display: flex;
	flex-wrap: wrap;
	gap: 7px;
	margin-bottom: 18px;
}

.case-card__service {
	display: inline-flex;
	align-items: center;
	min-height: 28px;
	padding: 7px 10px;
	border: 1px solid rgba(52, 94, 214, 0.18);
	border-radius: 999px;
	background: #f7faff;
	color: rgba(7, 19, 39, 0.72);
	font-size: 12px;
	font-weight: 700;
	line-height: 1;
	transition: border-color 0.2s ease, color 0.2s ease, background 0.2s ease;
}

.case-card__service:hover {
	border-color: rgba(52, 94, 214, 0.42);
	background: #ffffff;
	color: var(--color-blue);
}

.case-card__cta {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	width: fit-content;
	margin-top: auto;
	color: var(--color-blue);
	font-size: 15px;
	font-weight: 800;
	line-height: 1;
	text-decoration: none;
}

.case-card__cta span {
	display: inline-block;
	transition: transform 0.2s ease;
}

.case-card__cta:hover span {
	transform: translateX(4px);
}

@media (max-width: 1023px) {
	.cases-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.cases-block {
		padding: 72px 0 84px;
	}

	.cases-block__head {
		align-items: flex-start;
		flex-direction: column;
		gap: 18px;
	}

	.cases-grid {
		grid-template-columns: 1fr;
	}

	.case-card__body {
		padding: 20px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.case-card,
	.case-card__image,
	.case-card__cta span,
	.cases-block__all {
		transition: none;
	}

	.case-card:hover,
	.case-card:focus-within,
	.cases-block__all:hover,
	.cases-block__all:focus-visible {
		transform: none;
	}

	.case-card:hover .case-card__image,
	.case-card:focus-within .case-card__image,
	.case-card__cta:hover span {
		transform: none;
	}
}

/* ============================================================
   Audit CTA
   ============================================================ */

.audit-cta {
	padding: 96px 0 112px;
	background: #ffffff;
	color: #071327;
}

.audit-cta__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(380px, 0.76fr);
	gap: clamp(36px, 5vw, 76px);
	align-items: center;
	padding: clamp(32px, 4vw, 58px);
	overflow: hidden;
	border: 1px solid rgba(52, 94, 214, 0.16);
	border-radius: 28px;
	background:
		radial-gradient(circle at 10% 10%, rgba(124, 200, 255, 0.18), transparent 32%),
		linear-gradient(135deg, #071327 0%, #0b1329 56%, #16285f 100%);
	box-shadow: 0 28px 76px rgba(7, 19, 39, 0.18);
}

.audit-cta__content {
	display: grid;
	gap: 18px;
	color: #ffffff;
}

.audit-cta__eyebrow {
	width: fit-content;
	margin: 0;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(124, 200, 255, 0.14);
	color: #7cc8ff;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.08em;
	line-height: 1;
	text-transform: uppercase;
}

.audit-cta__title {
	max-width: 780px;
	margin: 0;
	color: #ffffff;
	font-size: clamp(36px, 4vw, 72px);
	font-weight: 600;
	line-height: 1.02;
	letter-spacing: 0;
}

.audit-cta__subtitle {
	max-width: 660px;
	margin: 0;
	color: rgba(255, 255, 255, 0.72);
	font-size: clamp(17px, 1.35vw, 22px);
	line-height: 1.5;
}

.audit-cta__checklist {
	display: grid;
	gap: 12px;
	margin: 8px 0 0;
	padding: 0;
	list-style: none;
}

.audit-cta__checklist li {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	color: rgba(255, 255, 255, 0.82);
	font-size: clamp(15px, 1vw, 18px);
	font-weight: 600;
	line-height: 1.35;
}

.audit-cta__checklist span {
	width: 24px;
	height: 24px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
	border-radius: 50%;
	background: rgba(124, 200, 255, 0.16);
	color: #7cc8ff;
	font-size: 14px;
}

.audit-cta__form-wrap {
	position: relative;
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 24px;
	background: rgba(255, 255, 255, 0.96);
	box-shadow:
		0 22px 58px rgba(3, 8, 20, 0.18),
		inset 0 1px 0 rgba(255, 255, 255, 0.98);
}

.audit-form {
	display: grid;
	gap: 15px;
	padding: clamp(22px, 2.6vw, 34px);
}

.audit-form__field {
	display: grid;
	gap: 7px;
}

.audit-form__label {
	color: rgba(7, 19, 39, 0.68);
	font-size: 13px;
	font-weight: 700;
	line-height: 1.2;
}

.audit-form__input {
	width: 100%;
	min-height: 54px;
	padding: 14px 16px;
	border: 1px solid rgba(52, 94, 214, 0.18);
	border-radius: 12px;
	background: #f7faff;
	color: #071327;
	font-size: 16px;
	font-weight: 600;
	line-height: 1.2;
	-webkit-appearance: none;
	transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.audit-form__input::placeholder {
	color: rgba(7, 19, 39, 0.34);
}

.audit-form__input:focus {
	outline: none;
	border-color: rgba(52, 94, 214, 0.48);
	background: #ffffff;
	box-shadow: 0 0 0 4px rgba(124, 200, 255, 0.18);
}

.audit-form__input:disabled {
	opacity: 0.62;
	cursor: not-allowed;
}

.audit-form__input.is-error {
	border-color: #d94646;
	background: #fff7f7;
}

.audit-form__error {
	min-height: 16px;
	margin: 0;
	color: #b42323;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.35;
}

.audit-form__submit {
	min-height: 56px;
	margin-top: 4px;
	padding: 15px 20px;
	border: 0;
	border-radius: 12px;
	background: linear-gradient(100deg, #55c0f2 0%, var(--color-blue) 100%);
	color: #ffffff;
	font-size: 16px;
	font-weight: 800;
	line-height: 1.1;
	cursor: pointer;
	box-shadow: 0 16px 34px rgba(52, 94, 214, 0.24);
	transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

.audit-form__submit:hover:not(:disabled),
.audit-form__submit:focus-visible {
	box-shadow: 0 20px 42px rgba(52, 94, 214, 0.3);
	transform: translateY(-1px);
}

.audit-form__submit:focus-visible,
.audit-success__reset:focus-visible,
.audit-form__privacy a:focus-visible {
	outline: 2px solid #7cc8ff;
	outline-offset: 4px;
}

.audit-form__submit:disabled {
	opacity: 0.62;
	cursor: not-allowed;
}

.audit-form__server-error {
	min-height: 18px;
	margin: 0;
	color: #b42323;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.45;
}

.audit-form__privacy {
	margin: 0;
	color: rgba(7, 19, 39, 0.48);
	font-size: 12px;
	font-weight: 600;
	line-height: 1.5;
}

.audit-form__privacy a {
	color: var(--color-blue);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}

.audit-success {
	display: grid;
	justify-items: center;
	gap: 14px;
	padding: clamp(34px, 4vw, 56px) clamp(22px, 2.6vw, 34px);
	text-align: center;
}

.audit-success[hidden] {
	display: none;
}

.audit-success__icon {
	width: 64px;
	height: 64px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: rgba(124, 200, 255, 0.16);
	color: var(--color-blue);
	font-size: 28px;
	font-weight: 800;
}

.audit-success__title {
	margin: 4px 0 0;
	color: #071327;
	font-size: clamp(26px, 2vw, 36px);
	font-weight: 700;
	line-height: 1.12;
}

.audit-success__subtitle {
	max-width: 360px;
	margin: 0;
	color: rgba(7, 19, 39, 0.66);
	font-size: 16px;
	font-weight: 600;
	line-height: 1.5;
}

.audit-success__reset {
	margin-top: 8px;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--color-blue);
	font-size: 14px;
	font-weight: 800;
	line-height: 1.2;
	text-decoration: underline;
	text-underline-offset: 4px;
	cursor: pointer;
}

@media (max-width: 900px) {
	.audit-cta__inner {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 640px) {
	.audit-cta {
		padding: 72px 0 84px;
	}

	.audit-cta__inner {
		padding: 24px;
		border-radius: 24px;
	}

	.audit-cta__title {
		font-size: clamp(32px, 9vw, 48px);
	}
}

@media (prefers-reduced-motion: reduce) {
	.audit-form__input,
	.audit-form__submit {
		transition: none;
	}

	.audit-form__submit:hover:not(:disabled),
	.audit-form__submit:focus-visible {
		transform: none;
	}
}

/* ============================================================
   Services Page
   ============================================================ */

.visually-hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0 0 0 0);
	white-space: nowrap;
	clip-path: inset(50%);
}

.services-page-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 78px;
	background:
		radial-gradient(circle at 86% 20%, rgba(124, 200, 255, 0.2), transparent 32%),
		radial-gradient(circle at 8% 100%, rgba(52, 94, 214, 0.14), transparent 34%),
		linear-gradient(180deg, #f7faff 0%, #ffffff 100%);
}

.services-page-breadcrumb {
	margin-bottom: 24px;
}

.services-page-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: #8c929f;
	font-size: 13px;
	font-weight: 600;
}

.services-page-breadcrumb__item + .services-page-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: #c7d2e7;
}

.services-page-breadcrumb__link {
	color: #8c929f;
	transition: color 0.2s ease;
}

.services-page-breadcrumb__link:hover,
.services-page-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.services-page-breadcrumb__item--current {
	color: #5e6877;
}

.services-page-hero__content {
	max-width: 920px;
	display: grid;
	gap: 18px;
}

.services-page-hero__eyebrow,
.services-page-section-head__eyebrow {
	width: fit-content;
	margin: 0;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(52, 94, 214, 0.1);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.services-page-hero__title {
	max-width: 920px;
	margin: 0;
	color: #071327;
	font-size: clamp(34px, 4.5vw, 72px);
	font-weight: 700;
	line-height: 1.02;
	letter-spacing: 0;
}

.services-page-hero__subtitle {
	max-width: 720px;
	margin: 0;
	color: rgba(7, 19, 39, 0.68);
	font-size: clamp(17px, 1.15vw, 22px);
	font-weight: 500;
	line-height: 1.55;
}

.services-page-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 10px;
}

.services-page-btn {
	min-height: 50px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 24px;
	border: 1px solid transparent;
	border-radius: 10px;
	font-size: 15px;
	font-weight: 800;
	line-height: 1.1;
	text-align: center;
	transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.services-page-btn:hover,
.services-page-btn:focus-visible {
	transform: translateY(-1px);
}

.services-page-btn:focus-visible {
	outline: 2px solid #7cc8ff;
	outline-offset: 4px;
}

.services-page-btn--primary {
	background: linear-gradient(100deg, #55c0f2 0%, var(--color-blue) 100%);
	color: #ffffff;
	box-shadow: 0 16px 34px rgba(52, 94, 214, 0.22);
}

.services-page-btn--secondary {
	border-color: rgba(52, 94, 214, 0.18);
	background: rgba(255, 255, 255, 0.72);
	color: #071327;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.services-page-btn--secondary:hover,
.services-page-btn--secondary:focus-visible {
	border-color: rgba(52, 94, 214, 0.4);
	color: var(--color-blue);
}

.services-page-btn--full {
	width: 100%;
}

.services-page-nav {
	position: sticky;
	top: 88px;
	z-index: 20;
	border-top: 1px solid rgba(52, 94, 214, 0.08);
	border-bottom: 1px solid rgba(52, 94, 214, 0.12);
	background: rgba(244, 247, 251, 0.78);
	backdrop-filter: blur(18px) saturate(140%);
	-webkit-backdrop-filter: blur(18px) saturate(140%);
}

.services-page-nav__inner {
	display: flex;
	gap: 4px;
	overflow-x: auto;
	padding-top: 8px;
	padding-bottom: 8px;
	scrollbar-width: none;
}

.services-page-nav__inner::-webkit-scrollbar {
	display: none;
}

.services-page-nav__link {
	display: inline-flex;
	align-items: center;
	min-height: 42px;
	padding: 10px 16px;
	border: 1px solid transparent;
	border-radius: 999px;
	color: #5e6877;
	font-size: 14px;
	font-weight: 800;
	white-space: nowrap;
	transition: color 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.services-page-nav__link:hover,
.services-page-nav__link:focus-visible,
.services-page-nav__link.is-active {
	border-color: rgba(52, 94, 214, 0.18);
	background: #ffffff;
	color: var(--color-blue);
}

.services-page-cards {
	padding: 72px 0 82px;
	background: #f4f7fb;
}

.services-page-cards__inner {
	display: grid;
	gap: 42px;
}

.services-page-group {
	--services-page-accent: var(--color-blue);
	--services-page-accent-rgb: 52, 94, 214;
	scroll-margin-top: 170px;
	display: grid;
	gap: 18px;
	padding: clamp(22px, 2vw, 34px);
	border: 1px solid rgba(var(--services-page-accent-rgb), 0.16);
	border-radius: 28px;
	background:
		radial-gradient(circle at 92% 0%, rgba(var(--services-page-accent-rgb), 0.12), transparent 34%),
		#ffffff;
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.services-page-group--violet {
	--services-page-accent: #6d5dfc;
	--services-page-accent-rgb: 109, 93, 252;
}

.services-page-group--teal {
	--services-page-accent: #0f9f8e;
	--services-page-accent-rgb: 15, 159, 142;
}

.services-page-group__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	padding-bottom: 14px;
	border-bottom: 1px solid rgba(var(--services-page-accent-rgb), 0.14);
}

.services-page-group__title {
	margin: 0;
	color: #071327;
	font-size: clamp(24px, 2vw, 34px);
	font-weight: 800;
	line-height: 1.12;
	letter-spacing: 0;
}

.services-page-group__count {
	min-height: 32px;
	display: inline-flex;
	align-items: center;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(var(--services-page-accent-rgb), 0.1);
	color: var(--services-page-accent);
	font-size: 12px;
	font-weight: 800;
	white-space: nowrap;
}

.services-page-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
}

.services-page-card {
	display: grid;
	grid-template-rows: auto auto 1fr auto auto;
	gap: 12px;
	min-height: 270px;
	padding: 22px;
	border: 1px solid rgba(var(--services-page-accent-rgb), 0.16);
	border-radius: 18px;
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(244, 247, 251, 0.9)),
		#ffffff;
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.92),
		0 8px 20px rgba(33, 55, 100, 0.05);
	transition: transform 0.32s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.25s ease, box-shadow 0.25s ease;
}

.services-page-card.is-observed {
	opacity: 0;
	transform: translateY(18px);
}

.services-page-card.is-visible {
	opacity: 1;
	transform: translateY(0);
	transition: opacity 0.42s ease, transform 0.42s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.25s ease, box-shadow 0.25s ease;
}

.services-page-card:hover,
.services-page-card:focus-within {
	transform: translateY(-2px);
	border-color: rgba(var(--services-page-accent-rgb), 0.42);
	box-shadow:
		0 14px 30px rgba(33, 55, 100, 0.1),
		inset 0 1px 0 rgba(255, 255, 255, 0.95);
}

.services-page-card__icon {
	position: relative;
	width: 44px;
	height: 44px;
	border: 1px solid rgba(var(--services-page-accent-rgb), 0.24);
	border-radius: 14px;
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.92), rgba(235, 244, 255, 0.74)),
		rgba(var(--services-page-accent-rgb), 0.12);
	box-shadow:
		0 12px 24px rgba(var(--services-page-accent-rgb), 0.1),
		inset 0 1px 0 rgba(255, 255, 255, 0.86);
}

.services-page-card__icon::before {
	content: "";
	position: absolute;
	inset: 10px;
	background: var(--services-page-accent);
	-webkit-mask: var(--services-icon-mask) center / contain no-repeat;
	mask: var(--services-icon-mask) center / contain no-repeat;
}

.services-page-icon--search {
	--services-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.8-3.8'/%3E%3C/svg%3E");
}

.services-page-icon--speakerphone {
	--services-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 13v-3a2 2 0 0 1 2-2h3l7-3v14l-7-3H6a2 2 0 0 1-2-2Z'/%3E%3Cpath d='M8 16l1 4'/%3E%3C/svg%3E");
}

.services-page-icon--map-pin {
	--services-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21s7-5.1 7-11a7 7 0 1 0-14 0c0 5.9 7 11 7 11Z'/%3E%3Ccircle cx='12' cy='10' r='2.3'/%3E%3C/svg%3E");
}

.services-page-icon--list-check {
	--services-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M10 6h10'/%3E%3Cpath d='M10 12h10'/%3E%3Cpath d='M10 18h10'/%3E%3Cpath d='m3 6 1.5 1.5L7 4'/%3E%3Cpath d='m3 12 1.5 1.5L7 10'/%3E%3Cpath d='m3 18 1.5 1.5L7 16'/%3E%3C/svg%3E");
}

.services-page-icon--star {
	--services-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='m12 2 3.1 6.3 6.9 1-5 4.9 1.2 6.8L12 17.8 5.8 21 7 14.2 2 9.3l6.9-1Z'/%3E%3C/svg%3E");
}

.services-page-icon--user-check {
	--services-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 21v-2a4 4 0 0 0-4-4H6a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='m16 11 2 2 4-5'/%3E%3C/svg%3E");
}

.services-page-icon--social {
	--services-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 11.5a8.5 8.5 0 0 1-12.7 7.4L3 20l1.1-5.1A8.5 8.5 0 1 1 21 11.5Z'/%3E%3Cpath d='M8 12h.01'/%3E%3Cpath d='M12 12h.01'/%3E%3Cpath d='M16 12h.01'/%3E%3C/svg%3E");
}

.services-page-icon--code {
	--services-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m8 9-4 3 4 3'/%3E%3Cpath d='m16 9 4 3-4 3'/%3E%3Cpath d='m14 5-4 14'/%3E%3C/svg%3E");
}

.services-page-icon--database {
	--services-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cellipse cx='12' cy='5' rx='7' ry='3'/%3E%3Cpath d='M5 5v10c0 1.7 3.1 3 7 3s7-1.3 7-3V5'/%3E%3Cpath d='M5 10c0 1.7 3.1 3 7 3s7-1.3 7-3'/%3E%3C/svg%3E");
}

.services-page-icon--palette {
	--services-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22a10 10 0 1 1 10-10c0 1.7-1 3-2.5 3H17a2 2 0 0 0-2 2c0 .5.2 1 .5 1.4.7 1-.1 2.6-1.6 2.6H12Z'/%3E%3Ccircle cx='7.5' cy='10.5' r='1'/%3E%3Ccircle cx='12' cy='7.5' r='1'/%3E%3Ccircle cx='16.5' cy='10.5' r='1'/%3E%3C/svg%3E");
}

.services-page-card__name {
	margin: 0;
	color: #071327;
	font-size: clamp(17px, 1vw, 20px);
	font-weight: 800;
	line-height: 1.16;
}

.services-page-card__pain {
	margin: 0;
	color: rgba(7, 19, 39, 0.68);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.45;
}

.services-page-card__result {
	margin: 0;
	padding: 10px 12px;
	border-left: 3px solid var(--services-page-accent);
	border-radius: 8px;
	background: rgba(var(--services-page-accent-rgb), 0.08);
	color: #071327;
	font-size: 13px;
	font-weight: 800;
	line-height: 1.35;
}

.services-page-card__link {
	width: fit-content;
	color: var(--services-page-accent);
	font-size: 14px;
	font-weight: 800;
	line-height: 1.1;
}

.services-page-section-head {
	max-width: 760px;
	display: grid;
	gap: 12px;
	margin-bottom: 32px;
}

.services-page-section-head--center {
	margin-right: auto;
	margin-left: auto;
	text-align: center;
	justify-items: center;
}

.services-page-section-head__title {
	margin: 0;
	color: #071327;
	font-size: clamp(30px, 3vw, 52px);
	font-weight: 800;
	line-height: 1.06;
	letter-spacing: 0;
}

.services-page-section-head__subtitle {
	max-width: 620px;
	margin: 0;
	color: rgba(7, 19, 39, 0.66);
	font-size: 17px;
	font-weight: 500;
	line-height: 1.5;
}

.services-page-packages {
	padding: 84px 0;
	background: #ffffff;
}

.services-page-packages__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
	align-items: stretch;
}

.services-page-package {
	position: relative;
	display: grid;
	grid-template-rows: auto auto 1fr auto;
	gap: 16px;
	padding: clamp(24px, 2vw, 32px);
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 24px;
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(244, 247, 251, 0.86)),
		#ffffff;
	box-shadow: 0 12px 34px rgba(33, 55, 100, 0.08);
}

.services-page-package--featured {
	border-color: rgba(52, 94, 214, 0.42);
	box-shadow: 0 24px 54px rgba(52, 94, 214, 0.16);
}

.services-page-package__badge {
	position: absolute;
	top: -13px;
	left: 28px;
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: var(--color-blue);
	color: #ffffff;
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
}

.services-page-package__label {
	margin: 0;
	color: #071327;
	font-size: clamp(22px, 1.7vw, 30px);
	font-weight: 800;
	line-height: 1.12;
}

.services-page-package__desc {
	margin: 0;
	color: rgba(7, 19, 39, 0.66);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.services-page-package__list {
	display: grid;
	gap: 0;
	margin: 4px 0 8px;
	padding: 0;
	list-style: none;
}

.services-page-package__list li {
	position: relative;
	padding: 11px 0 11px 26px;
	border-bottom: 1px solid rgba(52, 94, 214, 0.12);
	color: #071327;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.35;
}

.services-page-package__list li:last-child {
	border-bottom: 0;
}

.services-page-package__list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 14px;
	width: 15px;
	height: 15px;
	border-radius: 50%;
	background:
		linear-gradient(135deg, transparent 0 42%, #ffffff 42% 56%, transparent 56%),
		var(--color-blue);
}

.services-page-packages__note {
	margin: 24px 0 0;
	color: rgba(7, 19, 39, 0.62);
	font-size: 14px;
	font-weight: 600;
	text-align: center;
}

.services-page-packages__note a {
	color: var(--color-blue);
	font-weight: 800;
}

.services-page-metrics {
	padding: 58px 0;
	border-top: 1px solid rgba(52, 94, 214, 0.12);
	border-bottom: 1px solid rgba(52, 94, 214, 0.12);
	background:
		radial-gradient(circle at 15% 0%, rgba(124, 200, 255, 0.16), transparent 28%),
		#f4f7fb;
}

.services-page-metrics__inner {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.services-page-metric {
	display: grid;
	justify-items: center;
	gap: 8px;
	padding: 18px 24px;
	text-align: center;
	border-right: 1px solid rgba(52, 94, 214, 0.12);
}

.services-page-metric:last-child {
	border-right: 0;
}

.services-page-metric__value {
	color: var(--color-blue);
	font-size: clamp(34px, 4vw, 58px);
	font-weight: 800;
	line-height: 1;
}

.services-page-metric__label {
	max-width: 190px;
	color: rgba(7, 19, 39, 0.64);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.38;
}

.services-page-faq {
	padding: 84px 0;
	background: #ffffff;
}

.services-page-faq__inner {
	max-width: 940px;
}

.services-page-faq__list {
	overflow: hidden;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 24px;
	background: #ffffff;
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.services-page-faq__item + .services-page-faq__item {
	border-top: 1px solid rgba(52, 94, 214, 0.12);
}

.services-page-faq__question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 22px 26px;
	border: 0;
	background: #ffffff;
	color: #071327;
	font: inherit;
	font-size: 16px;
	font-weight: 800;
	line-height: 1.35;
	text-align: left;
	cursor: pointer;
	transition: color 0.2s ease, background 0.2s ease;
}

.services-page-faq__question:hover,
.services-page-faq__item.is-open .services-page-faq__question {
	background: #f7faff;
	color: var(--color-blue);
}

.services-page-faq__icon {
	position: relative;
	width: 22px;
	height: 22px;
	flex: 0 0 auto;
	border-radius: 50%;
	background: rgba(52, 94, 214, 0.1);
}

.services-page-faq__icon::before,
.services-page-faq__icon::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 10px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.services-page-faq__icon::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.services-page-faq__item.is-open .services-page-faq__icon::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(0deg);
}

.services-page-faq__answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.services-page-faq__item.is-open .services-page-faq__answer {
	max-height: 320px;
}

.services-page-faq__answer p {
	margin: 0;
	padding: 0 26px 24px;
	color: rgba(7, 19, 39, 0.66);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.65;
}

@media (max-width: 1280px) {
	.services-page-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 1023px) {
	.services-page-hero {
		padding: 136px 0 64px;
	}

	.services-page-nav {
		top: 78px;
	}

	.services-page-packages__grid {
		grid-template-columns: 1fr;
	}

	.services-page-package {
		max-width: 620px;
		width: 100%;
		margin: 0 auto;
	}

	.services-page-metrics__inner {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.services-page-metric:nth-child(2) {
		border-right: 0;
	}

	.services-page-metric:nth-child(1),
	.services-page-metric:nth-child(2) {
		border-bottom: 1px solid rgba(52, 94, 214, 0.12);
	}
}

@media (max-width: 767px) {
	.services-page-hero {
		padding: 122px 0 52px;
	}

	.services-page-hero__actions,
	.services-page-btn {
		width: 100%;
	}

	.services-page-nav {
		top: 70px;
	}

	.services-page-cards,
	.services-page-packages,
	.services-page-faq {
		padding: 58px 0;
	}

	.services-page-group {
		scroll-margin-top: 138px;
		padding: 20px;
		border-radius: 22px;
	}

	.services-page-group__head {
		display: grid;
	}

	.services-page-grid {
		grid-template-columns: 1fr;
	}

	.services-page-card {
		min-height: 0;
	}

	.services-page-metric {
		padding: 18px 12px;
	}

	.services-page-faq__question {
		padding: 18px 20px;
		font-size: 15px;
	}

	.services-page-faq__answer p {
		padding: 0 20px 20px;
	}
}

/* ============================================================
   Medicine Industry Page
   ============================================================ */

.medicine-page-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 76px;
	background:
		radial-gradient(circle at 86% 18%, color-mix(in srgb, var(--color-blue) 18%, transparent), transparent 32%),
		radial-gradient(circle at 8% 100%, color-mix(in srgb, var(--color-green) 14%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%) 0%, var(--color-surface) 100%);
}

.medicine-page-breadcrumb {
	margin-bottom: 24px;
}

.medicine-page-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 600;
}

.medicine-page-breadcrumb__item + .medicine-page-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--color-blue) 28%);
}

.medicine-page-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.medicine-page-breadcrumb__link:hover,
.medicine-page-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.medicine-page-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-text) 58%, var(--color-muted) 42%);
}

.medicine-page-hero__content {
	max-width: 960px;
	display: grid;
	gap: 18px;
}

.medicine-page-eyebrow {
	width: fit-content;
	margin: 0;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(52, 94, 214, 0.1);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.medicine-page-hero__title {
	max-width: 960px;
	margin: 0;
	color: var(--color-bg);
	font-size: 70px;
	font-weight: 700;
	line-height: 1.03;
	letter-spacing: 0;
}

.medicine-page-hero__subtitle {
	max-width: 760px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 22px;
	font-weight: 500;
	line-height: 1.58;
}

.medicine-page-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 10px;
}

.medicine-page-btn {
	min-height: 50px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 24px;
	border: 1px solid transparent;
	border-radius: 10px;
	font-size: 15px;
	font-weight: 800;
	line-height: 1.1;
	text-align: center;
	transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.medicine-page-btn:hover,
.medicine-page-btn:focus-visible {
	transform: translateY(-1px);
}

.medicine-page-btn:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

.medicine-page-btn--primary {
	background: linear-gradient(100deg, color-mix(in srgb, var(--color-blue) 74%, var(--color-green) 26%) 0%, var(--color-blue) 100%);
	color: var(--color-surface);
	box-shadow: 0 16px 34px rgba(52, 94, 214, 0.22);
}

.medicine-page-btn--secondary {
	border-color: rgba(52, 94, 214, 0.18);
	background: color-mix(in srgb, var(--color-surface) 78%, transparent);
	color: var(--color-bg);
	box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-surface) 92%, transparent);
}

.medicine-page-btn--secondary:hover,
.medicine-page-btn--secondary:focus-visible {
	border-color: rgba(52, 94, 214, 0.4);
	color: var(--color-blue);
}

.medicine-page-hero__trust {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 22px;
	margin: 6px 0 0;
	padding: 0;
	list-style: none;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.medicine-page-hero__trust li {
	position: relative;
	padding-left: 22px;
}

.medicine-page-hero__trust li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.35em;
	width: 13px;
	height: 13px;
	border-radius: 50%;
	background:
		linear-gradient(135deg, transparent 0 42%, var(--color-surface) 42% 56%, transparent 56%),
		color-mix(in srgb, var(--color-green) 74%, var(--color-blue) 26%);
}

.medicine-page-section-head {
	max-width: 780px;
	display: grid;
	gap: 12px;
	margin-bottom: 32px;
}

.medicine-page-section-head--center {
	margin-right: auto;
	margin-left: auto;
	text-align: center;
	justify-items: center;
}

.medicine-page-section-head__title,
.medicine-page-why__title,
.medicine-page-case__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 52px;
	font-weight: 800;
	line-height: 1.06;
	letter-spacing: 0;
}

.medicine-page-section-head__subtitle {
	max-width: 660px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 17px;
	font-weight: 500;
	line-height: 1.5;
}

.medicine-page-pains,
.medicine-page-tools,
.medicine-page-process {
	padding: 82px 0;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.medicine-page-pains__grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 14px;
}

.medicine-page-pain {
	display: grid;
	align-content: start;
	gap: 12px;
	padding: 22px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 20px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 98%, transparent), color-mix(in srgb, var(--color-surface) 86%, var(--color-blue) 14%)),
		var(--color-surface);
	box-shadow: 0 10px 24px rgba(33, 55, 100, 0.06);
}

.medicine-page-pain__icon,
.medicine-page-tool__icon {
	position: relative;
	width: 44px;
	height: 44px;
	border: 1px solid rgba(52, 94, 214, 0.18);
	border-radius: 14px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 92%, transparent), color-mix(in srgb, var(--color-surface) 74%, var(--color-blue) 26%)),
		rgba(52, 94, 214, 0.1);
	box-shadow:
		0 12px 24px rgba(52, 94, 214, 0.08),
		inset 0 1px 0 rgba(255, 255, 255, 0.86);
}

.medicine-page-pain__icon::before,
.medicine-page-tool__icon::before {
	content: "";
	position: absolute;
	inset: 10px;
	background: var(--color-blue);
}

.medicine-page-icon--site::before,
.medicine-page-icon--code::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='13' rx='2'/%3E%3Cpath d='M3 9h18'/%3E%3Cpath d='M9 21h6'/%3E%3Cpath d='M12 18v3'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='13' rx='2'/%3E%3Cpath d='M3 9h18'/%3E%3Cpath d='M9 21h6'/%3E%3Cpath d='M12 18v3'/%3E%3C/svg%3E") center / contain no-repeat;
}

.medicine-page-icon--budget::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 19 8 9l4 6 4-9 4 13'/%3E%3Ccircle cx='20' cy='5' r='2'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 19 8 9l4 6 4-9 4 13'/%3E%3Ccircle cx='20' cy='5' r='2'/%3E%3C/svg%3E") center / contain no-repeat;
}

.medicine-page-icon--visibility::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M2 12s4-7 10-7 10 7 10 7-4 7-10 7S2 12 2 12Z'/%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M2 12s4-7 10-7 10 7 10 7-4 7-10 7S2 12 2 12Z'/%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3C/svg%3E") center / contain no-repeat;
}

.medicine-page-icon--reviews::before,
.medicine-page-icon--star::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='m12 2 3.1 6.3 6.9 1-5 4.9 1.2 6.8L12 17.8 5.8 21 7 14.2 2 9.3l6.9-1Z'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='m12 2 3.1 6.3 6.9 1-5 4.9 1.2 6.8L12 17.8 5.8 21 7 14.2 2 9.3l6.9-1Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

.medicine-page-icon--chaos::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 7h16'/%3E%3Cpath d='M4 12h10'/%3E%3Cpath d='M4 17h13'/%3E%3Ccircle cx='19' cy='17' r='3'/%3E%3Cpath d='M19 15.6V17l1 1'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 7h16'/%3E%3Cpath d='M4 12h10'/%3E%3Cpath d='M4 17h13'/%3E%3Ccircle cx='19' cy='17' r='3'/%3E%3Cpath d='M19 15.6V17l1 1'/%3E%3C/svg%3E") center / contain no-repeat;
}

.medicine-page-icon--search::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.8-3.8'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.8-3.8'/%3E%3C/svg%3E") center / contain no-repeat;
}

.medicine-page-icon--speakerphone::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 13v-3a2 2 0 0 1 2-2h3l7-3v14l-7-3H6a2 2 0 0 1-2-2Z'/%3E%3Cpath d='M8 16l1 4'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 13v-3a2 2 0 0 1 2-2h3l7-3v14l-7-3H6a2 2 0 0 1-2-2Z'/%3E%3Cpath d='M8 16l1 4'/%3E%3C/svg%3E") center / contain no-repeat;
}

.medicine-page-icon--map-pin::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21s7-5.1 7-11a7 7 0 1 0-14 0c0 5.9 7 11 7 11Z'/%3E%3Ccircle cx='12' cy='10' r='2.3'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21s7-5.1 7-11a7 7 0 1 0-14 0c0 5.9 7 11 7 11Z'/%3E%3Ccircle cx='12' cy='10' r='2.3'/%3E%3C/svg%3E") center / contain no-repeat;
}

.medicine-page-icon--list-check::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M10 6h10'/%3E%3Cpath d='M10 12h10'/%3E%3Cpath d='M10 18h10'/%3E%3Cpath d='m3 6 1.5 1.5L7 4'/%3E%3Cpath d='m3 12 1.5 1.5L7 10'/%3E%3Cpath d='m3 18 1.5 1.5L7 16'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M10 6h10'/%3E%3Cpath d='M10 12h10'/%3E%3Cpath d='M10 18h10'/%3E%3Cpath d='m3 6 1.5 1.5L7 4'/%3E%3Cpath d='m3 12 1.5 1.5L7 10'/%3E%3Cpath d='m3 18 1.5 1.5L7 16'/%3E%3C/svg%3E") center / contain no-repeat;
}

.medicine-page-pain__title,
.medicine-page-tool__name {
	margin: 0;
	color: var(--color-bg);
	font-size: 17px;
	font-weight: 800;
	line-height: 1.18;
}

.medicine-page-pain__text,
.medicine-page-tool__desc {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.medicine-page-why,
.medicine-page-case,
.medicine-page-faq {
	padding: 84px 0;
	background: var(--color-surface);
}

.medicine-page-why__inner {
	display: grid;
	grid-template-columns: minmax(280px, 420px) minmax(0, 1fr);
	gap: clamp(42px, 6vw, 96px);
	align-items: start;
}

.medicine-page-why__lead {
	position: sticky;
	top: 130px;
	display: grid;
	gap: 16px;
}

.medicine-page-why__text {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.62;
}

.medicine-page-why__link,
.medicine-page-tool__link,
.medicine-page-faq__related-links a {
	width: fit-content;
	color: var(--color-blue);
	font-size: 14px;
	font-weight: 800;
	line-height: 1.1;
}

.medicine-page-why__features {
	display: grid;
	border-top: 1px solid rgba(52, 94, 214, 0.14);
}

.medicine-page-feature {
	display: grid;
	grid-template-columns: 54px minmax(0, 1fr);
	gap: 18px;
	padding: 26px 0;
	border-bottom: 1px solid rgba(52, 94, 214, 0.14);
}

.medicine-page-feature__num {
	color: rgba(52, 94, 214, 0.62);
	font-size: 13px;
	font-weight: 900;
	line-height: 1.3;
}

.medicine-page-feature__title {
	margin: 0 0 8px;
	color: var(--color-bg);
	font-size: 18px;
	font-weight: 800;
	line-height: 1.18;
}

.medicine-page-feature__text {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.58;
}

.medicine-page-tools__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.medicine-page-tool {
	display: grid;
	grid-template-rows: auto auto 1fr auto;
	gap: 12px;
	min-height: 250px;
	padding: 24px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 20px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 98%, transparent), color-mix(in srgb, var(--color-surface) 86%, var(--color-blue) 14%)),
		var(--color-surface);
	box-shadow: 0 10px 24px rgba(33, 55, 100, 0.06);
	transition: transform 0.32s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.25s ease, box-shadow 0.25s ease;
}

.medicine-page-tool.is-observed {
	opacity: 0;
	transform: translateY(18px);
}

.medicine-page-tool.is-visible {
	opacity: 1;
	transform: translateY(0);
	transition: opacity 0.42s ease, transform 0.42s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.25s ease, box-shadow 0.25s ease;
}

.medicine-page-tool:hover,
.medicine-page-tool:focus-within {
	transform: translateY(-2px);
	border-color: rgba(52, 94, 214, 0.38);
	box-shadow: 0 14px 30px rgba(33, 55, 100, 0.1);
}

.medicine-page-tools__footer {
	display: flex;
	justify-content: center;
	margin-top: 30px;
}

.medicine-page-case__card {
	max-width: 980px;
	padding: clamp(28px, 4vw, 54px);
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 28px;
	background:
		radial-gradient(circle at 92% 0%, rgba(124, 200, 255, 0.16), transparent 34%),
		color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.medicine-page-case__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
}

.medicine-page-case__tag {
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: rgba(52, 94, 214, 0.1);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.medicine-page-case__niche {
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.medicine-page-case__desc {
	max-width: 820px;
	margin: 16px 0 30px;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.62;
}

.medicine-page-case__metrics {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
	margin-bottom: 30px;
}

.medicine-page-case__metric {
	display: grid;
	gap: 6px;
	padding: 18px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 18px;
	background: var(--color-surface);
}

.medicine-page-case__metric-value {
	color: var(--color-blue);
	font-size: 44px;
	font-weight: 900;
	line-height: 1;
}

.medicine-page-case__metric-label {
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.32;
}

.medicine-page-process__steps {
	position: relative;
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
}

.medicine-page-process__steps::before {
	content: "";
	position: absolute;
	left: 8%;
	right: 8%;
	top: 24px;
	height: 1px;
	background: rgba(52, 94, 214, 0.16);
}

.medicine-page-process-step {
	position: relative;
	display: grid;
	gap: 14px;
	justify-items: center;
	text-align: center;
}

.medicine-page-process-step__head {
	position: relative;
	z-index: 1;
	display: grid;
	justify-items: center;
	gap: 8px;
	width: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--color-bg);
	font: inherit;
	cursor: pointer;
}

.medicine-page-process-step__circle {
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(52, 94, 214, 0.18);
	border-radius: 50%;
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 16px;
	font-weight: 900;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.medicine-page-process-step.is-active .medicine-page-process-step__circle {
	border-color: var(--color-blue);
	background: var(--color-blue);
	color: var(--color-surface);
}

.medicine-page-process-step__label {
	color: var(--color-bg);
	font-size: 16px;
	font-weight: 900;
	line-height: 1.15;
}

.medicine-page-process-step__time {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
}

.medicine-page-process-step__body {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	padding: 0 18px;
	border: 1px solid rgba(52, 94, 214, 0);
	border-radius: 18px;
	background: var(--color-surface);
	transition: max-height 0.28s ease, opacity 0.28s ease, padding 0.28s ease, border-color 0.28s ease;
}

.medicine-page-process-step.is-active .medicine-page-process-step__body {
	max-height: 240px;
	opacity: 1;
	padding: 18px;
	border-color: rgba(52, 94, 214, 0.14);
}

.medicine-page-process-step__body p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.58;
}

.medicine-page-faq__inner {
	max-width: 940px;
}

.medicine-page-faq__list {
	overflow: hidden;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 24px;
	background: var(--color-surface);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.medicine-page-faq__item + .medicine-page-faq__item {
	border-top: 1px solid rgba(52, 94, 214, 0.12);
}

.medicine-page-faq__question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 22px 26px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	font-size: 16px;
	font-weight: 800;
	line-height: 1.35;
	text-align: left;
	cursor: pointer;
	transition: color 0.2s ease, background 0.2s ease;
}

.medicine-page-faq__question:hover,
.medicine-page-faq__item.is-open .medicine-page-faq__question {
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
	color: var(--color-blue);
}

.medicine-page-faq__icon {
	position: relative;
	width: 22px;
	height: 22px;
	flex: 0 0 auto;
	border-radius: 50%;
	background: rgba(52, 94, 214, 0.1);
}

.medicine-page-faq__icon::before,
.medicine-page-faq__icon::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 10px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.medicine-page-faq__icon::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.medicine-page-faq__item.is-open .medicine-page-faq__icon::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(0deg);
}

.medicine-page-faq__answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.medicine-page-faq__item.is-open .medicine-page-faq__answer {
	max-height: 340px;
}

.medicine-page-faq__answer p {
	margin: 0;
	padding: 0 26px 24px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.65;
}

.medicine-page-faq__related {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 14px 22px;
	margin-top: 34px;
	padding-top: 24px;
	border-top: 1px solid rgba(52, 94, 214, 0.14);
}

.medicine-page-faq__related-label {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 54%, transparent);
	font-size: 13px;
	font-weight: 800;
}

.medicine-page-faq__related-links {
	display: flex;
	flex-wrap: wrap;
	gap: 12px 18px;
}

@media (max-width: 1180px) {
	.medicine-page-pains__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 1023px) {
	.medicine-page-hero {
		padding: 136px 0 64px;
	}

	.medicine-page-hero__title {
		font-size: 52px;
	}

	.medicine-page-hero__subtitle {
		font-size: 20px;
	}

	.medicine-page-section-head__title,
	.medicine-page-why__title,
	.medicine-page-case__title {
		font-size: 42px;
	}

	.medicine-page-case__metric-value {
		font-size: 36px;
	}

	.medicine-page-why__inner {
		grid-template-columns: 1fr;
	}

	.medicine-page-why__lead {
		position: static;
	}

	.medicine-page-tools__grid,
	.medicine-page-case__metrics {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.medicine-page-process__steps {
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.medicine-page-process__steps::before {
		display: none;
	}

	.medicine-page-process-step {
		justify-items: stretch;
		text-align: left;
	}

	.medicine-page-process-step__head {
		grid-template-columns: 48px minmax(0, 1fr) auto;
		align-items: center;
		justify-items: start;
		text-align: left;
	}
}

@media (max-width: 767px) {
	.medicine-page-hero {
		padding: 122px 0 52px;
	}

	.medicine-page-hero__title {
		font-size: 34px;
	}

	.medicine-page-hero__subtitle {
		font-size: 17px;
	}

	.medicine-page-section-head__title,
	.medicine-page-why__title,
	.medicine-page-case__title {
		font-size: 30px;
	}

	.medicine-page-section-head__subtitle {
		font-size: 16px;
	}

	.medicine-page-hero__actions,
	.medicine-page-btn {
		width: 100%;
	}

	.medicine-page-pains,
	.medicine-page-tools,
	.medicine-page-process,
	.medicine-page-why,
	.medicine-page-case,
	.medicine-page-faq {
		padding: 58px 0;
	}

	.medicine-page-pains__grid,
	.medicine-page-tools__grid,
	.medicine-page-case__metrics {
		grid-template-columns: 1fr;
	}

	.medicine-page-feature {
		grid-template-columns: 1fr;
		gap: 8px;
	}

	.medicine-page-case__card {
		border-radius: 22px;
	}

	.medicine-page-case__metric-value {
		font-size: 28px;
	}

	.medicine-page-process-step__head {
		grid-template-columns: 44px minmax(0, 1fr);
	}

	.medicine-page-process-step__time {
		grid-column: 2;
	}

	.medicine-page-faq__question {
		padding: 18px 20px;
		font-size: 15px;
	}

	.medicine-page-faq__answer p {
		padding: 0 20px 20px;
	}
}

/* ============================================================
   Cases Page
   ============================================================ */

.cases-page-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 62px;
	background:
		radial-gradient(circle at 86% 18%, color-mix(in srgb, var(--color-blue) 18%, transparent), transparent 32%),
		radial-gradient(circle at 10% 100%, color-mix(in srgb, var(--color-green) 12%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%) 0%, var(--color-surface) 100%);
}

.cases-page-hero__inner {
	display: grid;
	gap: 16px;
}

.cases-page-breadcrumb {
	margin-bottom: 8px;
}

.cases-page-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 600;
}

.cases-page-breadcrumb__item + .cases-page-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--color-blue) 28%);
}

.cases-page-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.cases-page-breadcrumb__link:hover,
.cases-page-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.cases-page-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-text) 58%, var(--color-muted) 42%);
}

.cases-page-hero__title {
	max-width: 920px;
	margin: 0;
	color: var(--color-bg);
	font-size: 64px;
	font-weight: 760;
	line-height: 1.05;
	letter-spacing: 0;
}

.cases-page-hero__subtitle {
	max-width: 650px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 20px;
	font-weight: 500;
	line-height: 1.58;
}

.cases-page-filter {
	position: sticky;
	top: 88px;
	z-index: 24;
	border-top: 1px solid color-mix(in srgb, var(--color-line) 78%, transparent);
	border-bottom: 1px solid color-mix(in srgb, var(--color-line) 78%, transparent);
	background: color-mix(in srgb, var(--color-surface) 84%, transparent);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
}

.cases-page-filter__inner {
	overflow: hidden;
}

.cases-page-filter__tabs {
	display: flex;
	gap: 8px;
	overflow-x: auto;
	padding: 10px 0;
	scrollbar-width: none;
}

.cases-page-filter__tabs::-webkit-scrollbar {
	display: none;
}

.cases-page-filter__btn {
	min-height: 42px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 18px;
	border: 1px solid transparent;
	border-radius: 999px;
	background: transparent;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 800;
	line-height: 1;
	white-space: nowrap;
	cursor: pointer;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.cases-page-filter__btn:hover,
.cases-page-filter__btn:focus-visible {
	color: var(--color-bg);
}

.cases-page-filter__btn:focus-visible,
.cases-page-card__inner:focus-visible,
.cases-page-related__links a:focus-visible,
.cases-page-empty a:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

.cases-page-filter__btn.is-active {
	border-color: color-mix(in srgb, var(--color-blue) 26%, transparent);
	background: linear-gradient(100deg, color-mix(in srgb, var(--color-blue) 14%, var(--color-surface) 86%), var(--color-surface));
	color: var(--color-blue);
	box-shadow: 0 10px 24px rgba(33, 55, 100, 0.08);
}

.cases-page-grid-section {
	padding: 48px 0 86px;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.cases-page-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.cases-page-card {
	min-width: 0;
	opacity: 0;
	transform: translateY(18px);
	transition: opacity 0.34s ease, transform 0.34s cubic-bezier(0.22, 1, 0.36, 1);
}

.cases-page-card.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.cases-page-card.is-hidden {
	display: none;
}

.cases-page-card__inner {
	height: 100%;
	display: flex;
	flex-direction: column;
	gap: 18px;
	padding: 26px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 22px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 98%, transparent), color-mix(in srgb, var(--color-surface) 88%, var(--color-blue) 12%)),
		var(--color-surface);
	color: var(--color-bg);
	box-shadow: 0 14px 34px rgba(33, 55, 100, 0.08);
	transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}

.cases-page-card__inner:hover,
.cases-page-card__inner:focus-visible {
	border-color: rgba(52, 94, 214, 0.38);
	box-shadow: 0 20px 46px rgba(33, 55, 100, 0.13);
	transform: translateY(-2px);
}

.cases-page-card__media {
	aspect-ratio: 16 / 9;
	overflow: hidden;
	border-radius: 16px;
	background: color-mix(in srgb, var(--color-surface) 86%, var(--color-blue) 14%);
}

.cases-page-card__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.36s ease;
}

.cases-page-card__inner:hover .cases-page-card__image,
.cases-page-card__inner:focus-visible .cases-page-card__image {
	transform: scale(1.03);
}

.cases-page-card__head {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px 10px;
}

.cases-page-card__niche {
	display: inline-flex;
	align-items: center;
	min-height: 28px;
	padding: 7px 11px;
	border-radius: 999px;
	background: rgba(52, 94, 214, 0.1);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.cases-page-card__city {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 13px;
	font-weight: 700;
	line-height: 1;
}

.cases-page-card__title {
	min-height: 86px;
	margin: 0;
	color: var(--color-bg);
	font-size: 22px;
	font-weight: 820;
	line-height: 1.18;
	letter-spacing: 0;
}

.cases-page-card__metrics {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
	margin-top: auto;
	padding: 16px 0;
	border-top: 1px solid rgba(52, 94, 214, 0.14);
	border-bottom: 1px solid rgba(52, 94, 214, 0.14);
}

.cases-page-card__metric {
	display: grid;
	gap: 5px;
	min-width: 0;
}

.cases-page-card__metric-value {
	color: var(--color-blue);
	font-size: 28px;
	font-weight: 900;
	font-variant-numeric: tabular-nums;
	line-height: 1;
	white-space: nowrap;
}

.cases-page-card__metric-label {
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 12px;
	font-weight: 700;
	line-height: 1.26;
}

.cases-page-card__footer {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 14px;
}

.cases-page-card__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 7px;
}

.cases-page-card__tag {
	display: inline-flex;
	align-items: center;
	min-height: 28px;
	padding: 7px 10px;
	border: 1px solid rgba(52, 94, 214, 0.16);
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-surface) 92%, var(--color-blue) 8%);
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 12px;
	font-weight: 760;
	line-height: 1;
}

.cases-page-card__more {
	flex: 0 0 auto;
	color: var(--color-blue);
	font-size: 14px;
	font-weight: 900;
	line-height: 1;
	white-space: nowrap;
}

.cases-page-empty {
	margin-top: 24px;
	padding: 36px 24px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 22px;
	background: var(--color-surface);
	text-align: center;
	box-shadow: 0 14px 34px rgba(33, 55, 100, 0.08);
}

.cases-page-empty[hidden] {
	display: none;
}

.cases-page-empty p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 600;
	line-height: 1.5;
}

.cases-page-empty a {
	color: var(--color-blue);
	font-weight: 900;
}

.cases-page-related {
	padding: 36px 0;
	border-top: 1px solid color-mix(in srgb, var(--color-line) 80%, transparent);
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.cases-page-related__inner {
	display: flex;
	align-items: flex-start;
	gap: 28px;
	flex-wrap: wrap;
}

.cases-page-related__group {
	display: flex;
	align-items: baseline;
	gap: 12px;
	flex-wrap: wrap;
}

.cases-page-related__label {
	flex: 0 0 auto;
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.2;
}

.cases-page-related__links {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.cases-page-related__links a {
	display: inline-flex;
	align-items: center;
	min-height: 30px;
	padding: 8px 11px;
	border: 1px solid rgba(52, 94, 214, 0.16);
	border-radius: 999px;
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 13px;
	font-weight: 760;
	line-height: 1;
	transition: border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.cases-page-related__links a:hover,
.cases-page-related__links a:focus-visible {
	border-color: rgba(52, 94, 214, 0.42);
	color: var(--color-blue);
	transform: translateY(-1px);
}

.cases-page-related__divider {
	width: 1px;
	min-height: 34px;
	background: color-mix(in srgb, var(--color-line) 76%, var(--color-blue) 24%);
}

@media (max-width: 1180px) {
	.cases-page-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 1023px) {
	.cases-page-hero {
		padding: 136px 0 58px;
	}

	.cases-page-hero__title {
		font-size: 48px;
	}

	.cases-page-hero__subtitle {
		font-size: 18px;
	}

	.cases-page-filter {
		top: 80px;
	}
}

@media (max-width: 767px) {
	.cases-page-hero {
		padding: 122px 0 44px;
	}

	.cases-page-hero__title {
		font-size: 32px;
	}

	.cases-page-hero__subtitle {
		font-size: 16px;
	}

	.cases-page-grid-section {
		padding: 38px 0 64px;
	}

	.cases-page-grid {
		grid-template-columns: 1fr;
	}

	.cases-page-card__inner {
		padding: 22px;
		border-radius: 20px;
	}

	.cases-page-card__title {
		min-height: 0;
		font-size: 20px;
	}

	.cases-page-card__metrics {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.cases-page-card__metric:last-child {
		grid-column: 1 / -1;
	}

	.cases-page-card__footer {
		align-items: flex-start;
		flex-direction: column;
	}

	.cases-page-related__inner {
		flex-direction: column;
		gap: 18px;
	}

	.cases-page-related__divider {
		display: none;
	}
}

@media (prefers-reduced-motion: reduce) {
	.cases-page-card,
	.cases-page-card__inner,
	.cases-page-card__image,
	.cases-page-filter__btn,
	.cases-page-related__links a {
		transition: none;
	}

	.cases-page-card__inner:hover,
	.cases-page-card__inner:focus-visible,
	.cases-page-card__inner:hover .cases-page-card__image,
	.cases-page-card__inner:focus-visible .cases-page-card__image,
	.cases-page-related__links a:hover,
	.cases-page-related__links a:focus-visible {
		transform: none;
	}
}

/* ============================================================
   Blog Page
   ============================================================ */

.blog-page-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 58px;
	background:
		radial-gradient(circle at 86% 18%, color-mix(in srgb, var(--color-blue) 18%, transparent), transparent 32%),
		radial-gradient(circle at 10% 100%, color-mix(in srgb, var(--color-green) 12%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%) 0%, var(--color-surface) 100%);
}

.blog-page-hero__inner {
	display: grid;
	gap: 16px;
}

.blog-page-breadcrumb {
	margin-bottom: 8px;
}

.blog-page-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 600;
}

.blog-page-breadcrumb__item + .blog-page-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--color-blue) 28%);
}

.blog-page-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.blog-page-breadcrumb__link:hover,
.blog-page-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.blog-page-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-text) 58%, var(--color-muted) 42%);
}

.blog-page-hero__title {
	max-width: 880px;
	margin: 0;
	color: var(--color-bg);
	font-size: 60px;
	font-weight: 760;
	line-height: 1.05;
	letter-spacing: 0;
}

.blog-page-hero__subtitle {
	max-width: 650px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 20px;
	font-weight: 500;
	line-height: 1.58;
}

.blog-page-filter {
	position: sticky;
	top: 88px;
	z-index: 24;
	border-top: 1px solid color-mix(in srgb, var(--color-line) 78%, transparent);
	border-bottom: 1px solid color-mix(in srgb, var(--color-line) 78%, transparent);
	background: color-mix(in srgb, var(--color-surface) 84%, transparent);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
}

.blog-page-filter__inner {
	overflow: hidden;
}

.blog-page-filter__tabs {
	display: flex;
	gap: 8px;
	overflow-x: auto;
	padding: 10px 0;
	scrollbar-width: none;
}

.blog-page-filter__tabs::-webkit-scrollbar {
	display: none;
}

.blog-page-filter__btn {
	min-height: 42px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 18px;
	border: 1px solid transparent;
	border-radius: 999px;
	background: transparent;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 800;
	line-height: 1;
	white-space: nowrap;
	cursor: pointer;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.blog-page-filter__btn:hover,
.blog-page-filter__btn:focus-visible {
	color: var(--color-bg);
}

.blog-page-filter__btn:focus-visible,
.blog-page-featured-card__title a:focus-visible,
.blog-page-featured-card__link:focus-visible,
.blog-page-post-card__inner:focus-visible,
.blog-page-empty a:focus-visible,
.blog-page-sidebar-cats a:focus-visible,
.blog-page-sidebar-popular a:focus-visible,
.blog-page-sidebar-cta__button:focus-visible,
.blog-page-pagination a:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

.blog-page-filter__btn.is-active {
	border-color: color-mix(in srgb, var(--color-blue) 26%, transparent);
	background: linear-gradient(100deg, color-mix(in srgb, var(--color-blue) 14%, var(--color-surface) 86%), var(--color-surface));
	color: var(--color-blue);
	box-shadow: 0 10px 24px rgba(33, 55, 100, 0.08);
}

.blog-page-featured {
	padding: 34px 0 0;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.blog-page-featured.is-hidden {
	display: none;
}

.blog-page-featured-card {
	position: relative;
	overflow: hidden;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(320px, 0.58fr);
	gap: 34px;
	align-items: center;
	padding: 36px 40px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-left: 4px solid var(--cat-color, var(--color-blue));
	border-radius: 0 24px 24px 0;
	background:
		radial-gradient(circle at 92% 8%, color-mix(in srgb, var(--cat-color, var(--color-blue)) 18%, transparent), transparent 30%),
		var(--color-surface);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.blog-page-featured-card__label {
	position: absolute;
	top: 22px;
	right: 24px;
	display: inline-flex;
	align-items: center;
	min-height: 28px;
	padding: 7px 11px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--cat-color, var(--color-blue)) 10%, var(--color-surface) 90%);
	color: var(--cat-color, var(--color-blue));
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.blog-page-featured-card__body {
	max-width: 780px;
	display: grid;
	gap: 14px;
}

.blog-page-featured-card__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px 14px;
}

.blog-page-featured-card__category {
	color: var(--cat-color, var(--color-blue));
	font-size: 13px;
	font-weight: 900;
	line-height: 1;
}

.blog-page-featured-card__date,
.blog-page-featured-card__read {
	color: color-mix(in srgb, var(--color-bg) 50%, transparent);
	font-size: 13px;
	font-weight: 700;
	line-height: 1;
}

.blog-page-featured-card__date::before,
.blog-page-featured-card__read::before {
	content: "";
	display: inline-block;
	width: 4px;
	height: 4px;
	margin: 0 8px 2px 0;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-line) 74%, var(--color-blue) 26%);
}

.blog-page-featured-card__title {
	max-width: 740px;
	margin: 0;
	font-size: 30px;
	font-weight: 820;
	line-height: 1.16;
	letter-spacing: 0;
}

.blog-page-featured-card__title a {
	color: var(--color-bg);
	transition: color 0.2s ease;
}

.blog-page-featured-card__title a:hover {
	color: var(--cat-color, var(--color-blue));
}

.blog-page-featured-card__excerpt {
	max-width: 700px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.62;
}

.blog-page-featured-card__link {
	width: fit-content;
	color: var(--cat-color, var(--color-blue));
	font-size: 15px;
	font-weight: 900;
	line-height: 1;
}

.blog-page-featured-card__media {
	display: block;
	overflow: hidden;
	border-radius: 22px;
	background: color-mix(in srgb, var(--cat-color, var(--color-blue)) 12%, var(--color-surface) 88%);
	box-shadow: 0 16px 34px rgba(33, 55, 100, 0.1);
}

.blog-page-featured-card__image {
	width: 100%;
	height: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	transition: transform 0.36s ease;
}

.blog-page-featured-card:hover .blog-page-featured-card__image,
.blog-page-featured-card:focus-within .blog-page-featured-card__image {
	transform: scale(1.03);
}

.blog-page-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: 34px;
	padding-top: 42px;
	padding-bottom: 84px;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.blog-page-layout__main,
.blog-page-layout__sidebar {
	min-width: 0;
}

.blog-page-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
}

.blog-page-post-card {
	min-width: 0;
	opacity: 0;
	transform: translateY(16px);
	transition: opacity 0.34s ease, transform 0.34s cubic-bezier(0.22, 1, 0.36, 1);
}

.blog-page-post-card.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.blog-page-post-card.is-hidden {
	display: none;
}

.blog-page-post-card__inner {
	height: 100%;
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding: 24px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-top: 4px solid var(--cat-color, var(--color-blue));
	border-radius: 0 0 22px 22px;
	background: var(--color-surface);
	color: var(--color-bg);
	box-shadow: 0 12px 30px rgba(33, 55, 100, 0.08);
	transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}

.blog-page-post-card__inner:hover,
.blog-page-post-card__inner:focus-visible {
	border-color: color-mix(in srgb, var(--cat-color, var(--color-blue)) 40%, transparent);
	box-shadow: 0 18px 42px rgba(33, 55, 100, 0.13);
	transform: translateY(-2px);
}

.blog-page-post-card__media {
	aspect-ratio: 16 / 9;
	overflow: hidden;
	margin: -12px -12px 4px;
	border-radius: 16px;
	background: color-mix(in srgb, var(--cat-color, var(--color-blue)) 12%, var(--color-surface) 88%);
}

.blog-page-post-card__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.36s ease;
}

.blog-page-post-card__inner:hover .blog-page-post-card__image,
.blog-page-post-card__inner:focus-visible .blog-page-post-card__image {
	transform: scale(1.03);
}

.blog-page-post-card__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px 10px;
}

.blog-page-post-card__category {
	color: var(--cat-color, var(--color-blue));
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
}

.blog-page-post-card__date {
	color: color-mix(in srgb, var(--color-bg) 48%, transparent);
	font-size: 12px;
	font-weight: 700;
	line-height: 1;
}

.blog-page-post-card__title {
	min-height: 84px;
	margin: 0;
	color: var(--color-bg);
	font-size: 20px;
	font-weight: 820;
	line-height: 1.22;
	letter-spacing: 0;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.blog-page-post-card__excerpt {
	margin: 0 0 6px;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.58;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.blog-page-post-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	margin-top: auto;
}

.blog-page-post-card__read {
	color: color-mix(in srgb, var(--color-bg) 48%, transparent);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
}

.blog-page-post-card__more {
	color: var(--cat-color, var(--color-blue));
	font-size: 14px;
	font-weight: 900;
	line-height: 1;
	white-space: nowrap;
}

.blog-page-empty {
	margin-top: 22px;
	padding: 34px 24px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 22px;
	background: var(--color-surface);
	box-shadow: 0 12px 30px rgba(33, 55, 100, 0.08);
	text-align: center;
}

.blog-page-empty[hidden] {
	display: none;
}

.blog-page-empty p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 600;
	line-height: 1.5;
}

.blog-page-empty a {
	color: var(--color-blue);
	font-weight: 900;
}

.blog-page-sidebar {
	display: grid;
	gap: 20px;
	position: sticky;
	top: 150px;
}

.blog-page-sidebar-widget,
.blog-page-sidebar-cta {
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 22px;
	background: var(--color-surface);
	box-shadow: 0 12px 30px rgba(33, 55, 100, 0.08);
}

.blog-page-sidebar-widget {
	padding: 22px;
}

.blog-page-sidebar-widget__title {
	margin: 0 0 14px;
	padding-bottom: 12px;
	border-bottom: 1px solid rgba(52, 94, 214, 0.14);
	color: var(--color-bg);
	font-size: 16px;
	font-weight: 900;
	line-height: 1.2;
}

.blog-page-sidebar-cats,
.blog-page-sidebar-popular {
	margin: 0;
	padding: 0;
}

.blog-page-sidebar-cats {
	display: grid;
	gap: 0;
	list-style: none;
}

.blog-page-sidebar-cats__item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 10px 0;
	border-bottom: 1px solid rgba(52, 94, 214, 0.1);
}

.blog-page-sidebar-cats__item:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.blog-page-sidebar-cats a,
.blog-page-sidebar-popular a {
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 13px;
	font-weight: 740;
	line-height: 1.4;
	transition: color 0.2s ease;
}

.blog-page-sidebar-cats a:hover,
.blog-page-sidebar-cats a:focus-visible,
.blog-page-sidebar-popular a:hover,
.blog-page-sidebar-popular a:focus-visible {
	color: var(--color-blue);
}

.blog-page-sidebar-cats__count {
	color: color-mix(in srgb, var(--color-bg) 42%, transparent);
	font-size: 12px;
	font-weight: 800;
}

.blog-page-sidebar-popular {
	display: grid;
	gap: 0;
	list-style: none;
	counter-reset: blog-popular;
}

.blog-page-sidebar-popular__item {
	display: grid;
	grid-template-columns: 26px minmax(0, 1fr);
	gap: 10px;
	padding: 12px 0;
	border-bottom: 1px solid rgba(52, 94, 214, 0.1);
	counter-increment: blog-popular;
}

.blog-page-sidebar-popular__item:first-child {
	padding-top: 0;
}

.blog-page-sidebar-popular__item:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.blog-page-sidebar-popular__item::before {
	content: counter(blog-popular);
	color: color-mix(in srgb, var(--color-blue) 46%, transparent);
	font-size: 20px;
	font-weight: 900;
	line-height: 1;
}

.blog-page-sidebar-cta {
	padding: 22px;
	background:
		radial-gradient(circle at 90% 0%, color-mix(in srgb, var(--color-blue) 18%, transparent), transparent 32%),
		var(--color-surface);
}

.blog-page-sidebar-cta__title {
	margin: 0 0 8px;
	color: var(--color-bg);
	font-size: 18px;
	font-weight: 900;
	line-height: 1.2;
}

.blog-page-sidebar-cta__text {
	margin: 0 0 18px;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.blog-page-sidebar-cta__button {
	min-height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 12px 18px;
	border-radius: 10px;
	background: linear-gradient(100deg, color-mix(in srgb, var(--color-blue) 74%, var(--color-green) 26%) 0%, var(--color-blue) 100%);
	color: var(--color-surface);
	font-size: 14px;
	font-weight: 900;
	line-height: 1;
	box-shadow: 0 14px 30px rgba(52, 94, 214, 0.2);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.blog-page-sidebar-cta__button:hover,
.blog-page-sidebar-cta__button:focus-visible {
	transform: translateY(-1px);
	box-shadow: 0 18px 36px rgba(52, 94, 214, 0.26);
}

.blog-page-pagination {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 12px;
	padding-top: 30px;
}

.blog-page-pagination__prev,
.blog-page-pagination__next,
.blog-page-pagination__page {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(52, 94, 214, 0.16);
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 64%, transparent);
	font-size: 14px;
	font-weight: 800;
	line-height: 1;
}

.blog-page-pagination__prev,
.blog-page-pagination__next {
	min-height: 40px;
	padding: 11px 16px;
	border-radius: 10px;
}

.blog-page-pagination__prev.is-disabled {
	opacity: 0.42;
}

.blog-page-pagination__pages {
	display: flex;
	align-items: center;
	gap: 6px;
}

.blog-page-pagination__page {
	width: 40px;
	height: 40px;
	border-radius: 10px;
}

.blog-page-pagination a {
	transition: border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.blog-page-pagination a:hover,
.blog-page-pagination a:focus-visible {
	border-color: rgba(52, 94, 214, 0.42);
	color: var(--color-blue);
	transform: translateY(-1px);
}

.blog-page-pagination__page.is-current {
	border-color: var(--color-blue);
	background: var(--color-blue);
	color: var(--color-surface);
}

@media (max-width: 1180px) {
	.blog-page-layout {
		grid-template-columns: minmax(0, 1fr) 300px;
		gap: 24px;
	}
}

@media (max-width: 1023px) {
	.blog-page-hero {
		padding: 136px 0 54px;
	}

	.blog-page-hero__title {
		font-size: 46px;
	}

	.blog-page-hero__subtitle {
		font-size: 18px;
	}

	.blog-page-featured-card {
		grid-template-columns: 1fr;
	}

	.blog-page-filter {
		top: 80px;
	}

	.blog-page-layout {
		grid-template-columns: 1fr;
	}

	.blog-page-layout__sidebar {
		order: -1;
	}

	.blog-page-sidebar {
		position: static;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		align-items: start;
	}

	.blog-page-sidebar-cta {
		grid-column: 1 / -1;
	}
}

@media (max-width: 767px) {
	.blog-page-hero {
		padding: 122px 0 42px;
	}

	.blog-page-hero__title {
		font-size: 32px;
	}

	.blog-page-hero__subtitle {
		font-size: 16px;
	}

	.blog-page-featured-card {
		padding: 24px 22px;
	}

	.blog-page-featured-card__label {
		position: static;
		width: fit-content;
		margin-bottom: 14px;
	}

	.blog-page-featured-card__title {
		font-size: 24px;
	}

	.blog-page-post-card__media {
		margin: -10px -10px 4px;
	}

	.blog-page-layout {
		padding-top: 34px;
		padding-bottom: 62px;
	}

	.blog-page-grid,
	.blog-page-sidebar {
		grid-template-columns: 1fr;
	}

	.blog-page-post-card__title {
		min-height: 0;
		font-size: 19px;
	}

	.blog-page-pagination {
		justify-content: center;
	}

	.blog-page-pagination__pages {
		display: none;
	}
}

@media (prefers-reduced-motion: reduce) {
	.blog-page-post-card,
	.blog-page-post-card__inner,
	.blog-page-post-card__image,
	.blog-page-featured-card__image,
	.blog-page-filter__btn,
	.blog-page-sidebar-cta__button,
	.blog-page-pagination a {
		transition: none;
	}

	.blog-page-post-card__inner:hover,
	.blog-page-post-card__inner:focus-visible,
	.blog-page-post-card__inner:hover .blog-page-post-card__image,
	.blog-page-post-card__inner:focus-visible .blog-page-post-card__image,
	.blog-page-featured-card:hover .blog-page-featured-card__image,
	.blog-page-featured-card:focus-within .blog-page-featured-card__image,
	.blog-page-sidebar-cta__button:hover,
	.blog-page-sidebar-cta__button:focus-visible,
	.blog-page-pagination a:hover,
	.blog-page-pagination a:focus-visible {
		transform: none;
	}
}

/* ============================================================
   Blog Category Page
   ============================================================ */

.cat-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 42px;
	background:
		radial-gradient(circle at 84% 20%, color-mix(in srgb, var(--cat-color, var(--color-blue)) 14%, transparent), transparent 32%),
		radial-gradient(circle at 8% 100%, color-mix(in srgb, var(--color-green) 10%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 94%, var(--cat-color, var(--color-blue)) 6%) 0%, var(--color-surface) 100%);
}

.cat-hero__container {
	display: grid;
	gap: 22px;
}

.cat-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 700;
}

.cat-breadcrumb__item + .cat-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--cat-color, var(--color-blue)) 28%);
}

.cat-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.cat-breadcrumb__link:hover,
.cat-breadcrumb__link:focus-visible {
	color: var(--cat-color, var(--color-blue));
}

.cat-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-bg) 58%, var(--color-muted) 42%);
}

.cat-hero__inner {
	display: flex;
	align-items: stretch;
	overflow: hidden;
	max-width: 980px;
	border: 1px solid color-mix(in srgb, var(--cat-color, var(--color-blue)) 18%, transparent);
	border-radius: 24px;
	background: var(--color-surface);
	box-shadow: 0 18px 44px color-mix(in srgb, var(--color-bg) 8%, transparent);
}

.cat-hero__accent {
	width: 7px;
	flex: 0 0 auto;
	background: var(--cat-color, var(--color-blue));
}

.cat-hero__content {
	display: grid;
	gap: 14px;
	padding: 30px 34px;
}

.cat-hero__title {
	max-width: 860px;
	margin: 0;
	color: var(--color-bg);
	font-size: 42px;
	font-weight: 840;
	line-height: 1.08;
	letter-spacing: 0;
}

.cat-hero__desc {
	max-width: 720px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 17px;
	font-weight: 500;
	line-height: 1.65;
}

.cat-hero__meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 10px 20px;
	padding-top: 2px;
}

.cat-hero__count {
	color: color-mix(in srgb, var(--color-bg) 48%, transparent);
	font-size: 13px;
	font-weight: 850;
	line-height: 1;
}

.cat-hero__all-link {
	color: var(--cat-color, var(--color-blue));
	font-size: 13px;
	font-weight: 900;
	line-height: 1;
}

.cat-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: 34px;
	align-items: start;
	padding-top: 42px;
	padding-bottom: 84px;
}

.cat-layout__main,
.cat-layout__sidebar {
	min-width: 0;
}

.cat-grid-section {
	display: grid;
	gap: 22px;
}

.cat-featured__inner {
	display: block;
	padding: 30px 34px;
	border: 1px solid color-mix(in srgb, var(--cat-color, var(--color-blue)) 16%, transparent);
	border-left: 5px solid var(--cat-color, var(--color-blue));
	border-radius: 0 24px 24px 0;
	background:
		radial-gradient(circle at 94% 0%, color-mix(in srgb, var(--cat-color, var(--color-blue)) 14%, transparent), transparent 30%),
		var(--color-surface);
	box-shadow: 0 16px 38px color-mix(in srgb, var(--color-bg) 8%, transparent);
	transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.cat-featured__inner:hover,
.cat-featured__inner:focus-visible {
	border-color: color-mix(in srgb, var(--cat-color, var(--color-blue)) 34%, transparent);
	box-shadow: 0 22px 48px color-mix(in srgb, var(--color-bg) 11%, transparent);
	transform: translateY(-2px);
}

.cat-featured__meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 10px 14px;
	margin-bottom: 14px;
}

.cat-featured__label {
	display: inline-flex;
	align-items: center;
	min-height: 28px;
	padding: 7px 11px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--cat-color, var(--color-blue)) 10%, var(--color-surface) 90%);
	color: var(--cat-color, var(--color-blue));
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.cat-featured__date,
.cat-featured__read {
	color: color-mix(in srgb, var(--color-bg) 50%, transparent);
	font-size: 13px;
	font-weight: 700;
	line-height: 1;
}

.cat-featured__date::before,
.cat-featured__read::before {
	content: "";
	display: inline-block;
	width: 4px;
	height: 4px;
	margin: 0 8px 2px 0;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-line) 74%, var(--cat-color, var(--color-blue)) 26%);
}

.cat-featured__title {
	max-width: 760px;
	margin: 0 0 12px;
	color: var(--color-bg);
	font-size: 30px;
	font-weight: 820;
	line-height: 1.16;
	letter-spacing: 0;
}

.cat-featured__excerpt {
	max-width: 720px;
	margin: 0 0 18px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.62;
}

.cat-featured__link {
	color: var(--cat-color, var(--color-blue));
	font-size: 15px;
	font-weight: 900;
	line-height: 1;
}

.cat-posts-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
}

.cat-empty {
	padding: 44px 24px;
	border: 1px solid color-mix(in srgb, var(--cat-color, var(--color-blue)) 14%, transparent);
	border-radius: 22px;
	background: var(--color-surface);
	text-align: center;
}

.cat-empty p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 64%, transparent);
	font-size: 15px;
	font-weight: 600;
	line-height: 1.5;
}

.cat-empty a {
	color: var(--cat-color, var(--color-blue));
	font-weight: 900;
}

.cat-related {
	padding: 34px 0 50px;
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	background: var(--color-surface);
}

.cat-related__container {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 14px 18px;
}

.cat-related__label {
	flex: 0 0 auto;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.2;
}

.cat-related__links {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 9px;
}

.cat-related__tag {
	display: inline-flex;
	align-items: center;
	min-height: 34px;
	padding: 9px 14px;
	border: 1px solid var(--tag-color, var(--color-blue));
	border-color: color-mix(in srgb, var(--tag-color, var(--color-blue)) 30%, transparent);
	border-radius: 999px;
	background: var(--color-surface);
	color: var(--tag-color, var(--color-blue));
	font-size: 13px;
	font-weight: 850;
	line-height: 1;
	transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.cat-related__tag:hover,
.cat-related__tag:focus-visible {
	border-color: var(--tag-color, var(--color-blue));
	background: color-mix(in srgb, var(--tag-color, var(--color-blue)) 8%, var(--color-surface) 92%);
	transform: translateY(-1px);
}

.cat-breadcrumb__link:focus-visible,
.cat-hero__all-link:focus-visible,
.cat-featured__inner:focus-visible,
.cat-empty a:focus-visible,
.cat-related__tag:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--cat-color, var(--color-blue)) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

@media (max-width: 1180px) {
	.cat-layout {
		grid-template-columns: minmax(0, 1fr) 300px;
		gap: 24px;
	}
}

@media (max-width: 1023px) {
	.cat-hero {
		padding: 136px 0 38px;
	}

	.cat-layout {
		grid-template-columns: 1fr;
	}

	.cat-layout__sidebar {
		order: -1;
	}
}

@media (max-width: 767px) {
	.cat-hero {
		padding: 122px 0 34px;
	}

	.cat-hero__content {
		padding: 24px;
	}

	.cat-hero__title {
		font-size: 31px;
	}

	.cat-hero__desc {
		font-size: 16px;
	}

	.cat-layout {
		padding-top: 34px;
		padding-bottom: 62px;
	}

	.cat-posts-grid {
		grid-template-columns: 1fr;
	}

	.cat-featured__inner {
		padding: 24px;
	}

	.cat-featured__title {
		font-size: 24px;
	}

	.cat-related__container {
		align-items: flex-start;
		flex-direction: column;
	}
}

@media (prefers-reduced-motion: reduce) {
	.cat-breadcrumb__link,
	.cat-featured__inner,
	.cat-related__tag {
		transition: none;
	}

	.cat-featured__inner:hover,
	.cat-featured__inner:focus-visible,
	.cat-related__tag:hover,
	.cat-related__tag:focus-visible {
		transform: none;
	}
}

/* ============================================================
   Contacts Page
   ============================================================ */

.contacts-page-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 58px;
	background:
		radial-gradient(circle at 86% 18%, color-mix(in srgb, var(--color-blue) 18%, transparent), transparent 32%),
		radial-gradient(circle at 10% 100%, color-mix(in srgb, var(--color-green) 12%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%) 0%, var(--color-surface) 100%);
}

.contacts-page-hero__inner {
	display: grid;
	gap: 16px;
}

.contacts-page-breadcrumb {
	margin-bottom: 8px;
}

.contacts-page-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 600;
}

.contacts-page-breadcrumb__item + .contacts-page-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--color-blue) 28%);
}

.contacts-page-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.contacts-page-breadcrumb__link:hover,
.contacts-page-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.contacts-page-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-text) 58%, var(--color-muted) 42%);
}

.contacts-page-hero__title {
	max-width: 760px;
	margin: 0;
	color: var(--color-bg);
	font-size: 60px;
	font-weight: 760;
	line-height: 1.05;
	letter-spacing: 0;
}

.contacts-page-hero__subtitle {
	max-width: 690px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 20px;
	font-weight: 500;
	line-height: 1.58;
}

.contacts-page-main {
	padding: 42px 0 38px;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.contacts-page-main__inner {
	display: grid;
	gap: 28px;
}

.contacts-page-layout {
	display: grid;
	grid-template-columns: minmax(0, 0.92fr) minmax(420px, 0.68fr);
	gap: 24px;
	align-items: stretch;
}

.contacts-page-panel {
	min-width: 0;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 24px;
	background:
		radial-gradient(circle at 92% 8%, color-mix(in srgb, var(--color-blue) 10%, transparent), transparent 30%),
		var(--color-surface);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.contacts-page-panel--data {
	padding: 28px;
}

.contacts-page-panel--form {
	padding: 30px;
}

.contacts-page-panel__head {
	display: grid;
	gap: 8px;
	margin-bottom: 22px;
}

.contacts-page-eyebrow {
	width: fit-content;
	margin: 0;
	padding: 7px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.contacts-page-panel__title,
.contacts-page-hours__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 28px;
	font-weight: 820;
	line-height: 1.16;
	letter-spacing: 0;
}

.contacts-page-info {
	display: grid;
	gap: 12px;
	margin: 0 0 22px;
	font-style: normal;
}

.contacts-page-contact {
	display: grid;
	grid-template-columns: 46px minmax(0, 1fr);
	gap: 14px;
	align-items: start;
	padding: 16px;
	border: 1px solid rgba(52, 94, 214, 0.12);
	border-radius: 18px;
	background: color-mix(in srgb, var(--color-surface) 96%, var(--color-blue) 4%);
}

.contacts-page-contact__icon,
.contacts-page-related-card__icon {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 46px;
	height: 46px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 18%, transparent);
	border-radius: 16px;
	background: color-mix(in srgb, var(--color-blue) 8%, var(--color-surface) 92%);
}

.contacts-page-contact__icon::before,
.contacts-page-related-card__icon::before {
	content: "";
	display: block;
	width: 22px;
	height: 22px;
	background: var(--color-blue);
	mask-repeat: no-repeat;
	mask-position: center;
	mask-size: contain;
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: center;
	-webkit-mask-size: contain;
}

.contacts-page-contact__icon--address::before {
	mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 22s7-6.1 7-13a7 7 0 1 0-14 0c0 6.9 7 13 7 13Zm0-9a4 4 0 1 1 0-8 4 4 0 0 1 0 8Z'/%3E%3C/svg%3E");
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 22s7-6.1 7-13a7 7 0 1 0-14 0c0 6.9 7 13 7 13Zm0-9a4 4 0 1 1 0-8 4 4 0 0 1 0 8Z'/%3E%3C/svg%3E");
}

.contacts-page-contact__icon--phone::before {
	mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.6 2h4l1.7 5.1-2.5 1.7c1.1 2.3 2.9 4.1 5.4 5.4l1.7-2.5 5.1 1.7v4C22 20 20 22 17.4 22 8.9 22 2 15.1 2 6.6 2 4 4 2 6.6 2Z'/%3E%3C/svg%3E");
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.6 2h4l1.7 5.1-2.5 1.7c1.1 2.3 2.9 4.1 5.4 5.4l1.7-2.5 5.1 1.7v4C22 20 20 22 17.4 22 8.9 22 2 15.1 2 6.6 2 4 4 2 6.6 2Z'/%3E%3C/svg%3E");
}

.contacts-page-contact__icon--email::before {
	mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 4h16a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2Zm8 9 8-5.2V7l-8 5.2L4 7v.8L12 13Z'/%3E%3C/svg%3E");
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 4h16a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2Zm8 9 8-5.2V7l-8 5.2L4 7v.8L12 13Z'/%3E%3C/svg%3E");
}

.contacts-page-contact__icon--messenger::before {
	mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 3C6.5 3 2 6.8 2 11.5c0 2.6 1.4 4.9 3.6 6.5L5 22l4.3-2.2c.9.2 1.8.3 2.7.3 5.5 0 10-3.8 10-8.6S17.5 3 12 3Zm-4 9.3a1.3 1.3 0 1 1 0-2.6 1.3 1.3 0 0 1 0 2.6Zm4 0a1.3 1.3 0 1 1 0-2.6 1.3 1.3 0 0 1 0 2.6Zm4 0a1.3 1.3 0 1 1 0-2.6 1.3 1.3 0 0 1 0 2.6Z'/%3E%3C/svg%3E");
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 3C6.5 3 2 6.8 2 11.5c0 2.6 1.4 4.9 3.6 6.5L5 22l4.3-2.2c.9.2 1.8.3 2.7.3 5.5 0 10-3.8 10-8.6S17.5 3 12 3Zm-4 9.3a1.3 1.3 0 1 1 0-2.6 1.3 1.3 0 0 1 0 2.6Zm4 0a1.3 1.3 0 1 1 0-2.6 1.3 1.3 0 0 1 0 2.6Zm4 0a1.3 1.3 0 1 1 0-2.6 1.3 1.3 0 0 1 0 2.6Z'/%3E%3C/svg%3E");
}

.contacts-page-contact__body {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.contacts-page-contact__label {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.contacts-page-contact__value {
	width: fit-content;
	color: var(--color-bg);
	font-size: 18px;
	font-weight: 820;
	line-height: 1.3;
	transition: color 0.2s ease;
}

a.contacts-page-contact__value:hover,
a.contacts-page-contact__value:focus-visible {
	color: var(--color-blue);
}

.contacts-page-contact__note {
	max-width: 560px;
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.contacts-page-messengers {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.contacts-page-messengers a {
	min-height: 34px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 8px 13px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 24%, transparent);
	border-radius: 999px;
	background: var(--color-surface);
	color: var(--color-blue);
	font-size: 13px;
	font-weight: 900;
	line-height: 1;
	transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.contacts-page-messengers a:hover,
.contacts-page-messengers a:focus-visible {
	background: var(--color-blue);
	color: var(--color-surface);
	transform: translateY(-1px);
}

.contacts-page-map {
	overflow: hidden;
	border: 1px solid rgba(52, 94, 214, 0.16);
	border-radius: 20px;
	background: color-mix(in srgb, var(--color-blue) 8%, var(--color-surface) 92%);
}

.contacts-page-map iframe {
	display: block;
	width: 100%;
	min-height: 320px;
	border: 0;
}

.contacts-page-form {
	display: grid;
	gap: 15px;
}

.contacts-page-field {
	display: grid;
	gap: 7px;
}

.contacts-page-field__label {
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1;
}

.contacts-page-field__control {
	width: 100%;
	min-height: 50px;
	padding: 13px 15px;
	border: 1px solid rgba(52, 94, 214, 0.16);
	border-radius: 14px;
	background: color-mix(in srgb, var(--color-surface) 98%, var(--color-blue) 2%);
	color: var(--color-bg);
	font-size: 15px;
	font-weight: 600;
	line-height: 1.3;
	outline: none;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.contacts-page-field__control::placeholder {
	color: color-mix(in srgb, var(--color-bg) 34%, transparent);
}

.contacts-page-field__control:focus {
	border-color: color-mix(in srgb, var(--color-blue) 52%, transparent);
	background: var(--color-surface);
	box-shadow: 0 0 0 4px color-mix(in srgb, var(--color-blue) 10%, transparent);
}

.contacts-page-field__control.is-error {
	border-color: #ef4444;
	box-shadow: 0 0 0 4px rgba(239, 68, 68, 0.1);
}

.contacts-page-field__select {
	appearance: none;
	padding-right: 42px;
	background-image: url("data:image/svg+xml,%3Csvg width='14' height='9' viewBox='0 0 14 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1.5 1.5 7 7l5.5-5.5' stroke='%238C929F' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 16px center;
	cursor: pointer;
}

.contacts-page-field__textarea {
	min-height: 118px;
	resize: vertical;
}

.contacts-page-field__error {
	min-height: 17px;
	margin: 0;
	color: #ef4444;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.35;
}

.contacts-page-field--policy {
	gap: 5px;
}

.contacts-page-policy {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 600;
	line-height: 1.5;
	cursor: pointer;
}

.contacts-page-policy__input {
	flex: 0 0 auto;
	width: 18px;
	height: 18px;
	margin: 1px 0 0;
	accent-color: var(--color-blue);
}

.contacts-page-policy a {
	color: var(--color-blue);
	font-weight: 900;
}

.contacts-page-policy a:hover,
.contacts-page-policy a:focus-visible {
	text-decoration: underline;
}

.contacts-page-submit {
	min-height: 54px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 15px 22px;
	border: 0;
	border-radius: 15px;
	background: linear-gradient(100deg, color-mix(in srgb, var(--color-blue) 74%, var(--color-green) 26%) 0%, var(--color-blue) 100%);
	color: var(--color-surface);
	font-size: 15px;
	font-weight: 900;
	line-height: 1;
	cursor: pointer;
	box-shadow: 0 14px 30px rgba(52, 94, 214, 0.2);
	transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

.contacts-page-submit:hover,
.contacts-page-submit:focus-visible {
	transform: translateY(-1px);
	box-shadow: 0 18px 36px rgba(52, 94, 214, 0.26);
}

.contacts-page-submit:disabled {
	cursor: wait;
	opacity: 0.76;
	transform: none;
}

.contacts-page-form__message {
	margin: 0;
	padding: 14px 16px;
	border-radius: 14px;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.5;
}

.contacts-page-form__message[hidden] {
	display: none;
}

.contacts-page-form__message--success {
	border: 1px solid rgba(84, 207, 145, 0.32);
	background: color-mix(in srgb, var(--color-green) 12%, var(--color-surface) 88%);
	color: color-mix(in srgb, var(--color-green) 54%, var(--color-bg) 46%);
}

.contacts-page-form__message--fail {
	border: 1px solid rgba(239, 68, 68, 0.24);
	background: #fff5f5;
	color: #991b1b;
}

.contacts-page-hours {
	display: grid;
	grid-template-columns: minmax(240px, 0.42fr) minmax(0, 1fr);
	gap: 24px;
	align-items: start;
	padding: 26px 28px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 24px;
	background: var(--color-surface);
	box-shadow: 0 14px 36px rgba(33, 55, 100, 0.08);
}

.contacts-page-hours__head {
	display: grid;
	gap: 10px;
}

.contacts-page-hours__list {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 12px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.contacts-page-hours__item {
	min-height: 96px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	gap: 16px;
	padding: 16px;
	border: 1px solid rgba(52, 94, 214, 0.12);
	border-radius: 18px;
	background: color-mix(in srgb, var(--color-surface) 96%, var(--color-blue) 4%);
	transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.contacts-page-hours__item.is-today {
	border-color: color-mix(in srgb, var(--color-blue) 38%, transparent);
	background:
		radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--color-blue) 16%, transparent), transparent 42%),
		color-mix(in srgb, var(--color-blue) 8%, var(--color-surface) 92%);
	box-shadow: 0 12px 28px rgba(52, 94, 214, 0.12);
}

.contacts-page-hours__days {
	color: color-mix(in srgb, var(--color-bg) 54%, transparent);
	font-size: 13px;
	font-weight: 900;
	line-height: 1.25;
}

.contacts-page-hours__time {
	color: var(--color-bg);
	font-size: 18px;
	font-weight: 820;
	line-height: 1.2;
}

.contacts-page-hours__item.is-today .contacts-page-hours__days {
	color: var(--color-blue);
}

.contacts-page-related {
	padding: 0 0 84px;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.contacts-page-related__inner {
	display: grid;
	gap: 14px;
}

.contacts-page-related__label {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 54%, transparent);
	font-size: 13px;
	font-weight: 900;
	line-height: 1;
}

.contacts-page-related__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.contacts-page-related-card {
	display: grid;
	grid-template-columns: 50px minmax(0, 1fr) 24px;
	gap: 14px;
	align-items: center;
	min-height: 118px;
	padding: 20px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 22px;
	background: var(--color-surface);
	color: var(--color-bg);
	box-shadow: 0 12px 30px rgba(33, 55, 100, 0.08);
	transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.contacts-page-related-card:hover,
.contacts-page-related-card:focus-visible {
	border-color: rgba(52, 94, 214, 0.36);
	box-shadow: 0 18px 42px rgba(33, 55, 100, 0.13);
	transform: translateY(-2px);
}

.contacts-page-related-card--audit .contacts-page-related-card__icon::before {
	mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m9.2 15.8-4-4L3 14l6.2 6.2L21.4 8 19.2 5.8 9.2 15.8Z'/%3E%3C/svg%3E");
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m9.2 15.8-4-4L3 14l6.2 6.2L21.4 8 19.2 5.8 9.2 15.8Z'/%3E%3C/svg%3E");
}

.contacts-page-related-card--cases .contacts-page-related-card__icon::before {
	mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 3h16a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2Zm1 5h14V6H5v2Zm2 5h10v-2H7v2Zm0 4h7v-2H7v2Z'/%3E%3C/svg%3E");
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 3h16a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2Zm1 5h14V6H5v2Zm2 5h10v-2H7v2Zm0 4h7v-2H7v2Z'/%3E%3C/svg%3E");
}

.contacts-page-related-card--services .contacts-page-related-card__icon::before {
	mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 2 3 6.8v10.4L12 22l9-4.8V6.8L12 2Zm0 4.2 4.8 2.6L12 11.4 7.2 8.8 12 6.2Zm-6 5.1 4.5 2.4v4.2L6 15.5v-4.2Zm7.5 6.6v-4.2l4.5-2.4v4.2l-4.5 2.4Z'/%3E%3C/svg%3E");
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 2 3 6.8v10.4L12 22l9-4.8V6.8L12 2Zm0 4.2 4.8 2.6L12 11.4 7.2 8.8 12 6.2Zm-6 5.1 4.5 2.4v4.2L6 15.5v-4.2Zm7.5 6.6v-4.2l4.5-2.4v4.2l-4.5 2.4Z'/%3E%3C/svg%3E");
}

.contacts-page-related-card__body {
	min-width: 0;
	display: grid;
	gap: 5px;
}

.contacts-page-related-card__title {
	color: var(--color-bg);
	font-size: 17px;
	font-weight: 900;
	line-height: 1.18;
}

.contacts-page-related-card__subtitle {
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 13px;
	font-weight: 600;
	line-height: 1.45;
}

.contacts-page-related-card__arrow {
	color: color-mix(in srgb, var(--color-blue) 64%, transparent);
	font-size: 22px;
	font-weight: 900;
	line-height: 1;
	transition: transform 0.2s ease, color 0.2s ease;
}

.contacts-page-related-card:hover .contacts-page-related-card__arrow,
.contacts-page-related-card:focus-visible .contacts-page-related-card__arrow {
	color: var(--color-blue);
	transform: translateX(3px);
}

.contacts-page-panel a:focus-visible,
.contacts-page-related-card:focus-visible,
.contacts-page-submit:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

@media (max-width: 1180px) {
	.contacts-page-layout {
		grid-template-columns: minmax(0, 1fr) minmax(380px, 0.7fr);
	}

	.contacts-page-hours {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 1023px) {
	.contacts-page-hero {
		padding: 136px 0 54px;
	}

	.contacts-page-hero__title {
		font-size: 46px;
	}

	.contacts-page-hero__subtitle {
		font-size: 18px;
	}

	.contacts-page-layout,
	.contacts-page-related__grid {
		grid-template-columns: 1fr;
	}

	.contacts-page-hours__list {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 767px) {
	.contacts-page-hero {
		padding: 122px 0 42px;
	}

	.contacts-page-hero__title {
		font-size: 32px;
	}

	.contacts-page-hero__subtitle {
		font-size: 16px;
	}

	.contacts-page-main {
		padding-top: 34px;
	}

	.contacts-page-panel--data,
	.contacts-page-panel--form,
	.contacts-page-hours {
		padding: 22px;
		border-radius: 20px;
	}

	.contacts-page-panel__title,
	.contacts-page-hours__title {
		font-size: 24px;
	}

	.contacts-page-contact {
		grid-template-columns: 42px minmax(0, 1fr);
		padding: 14px;
	}

	.contacts-page-contact__icon,
	.contacts-page-related-card__icon {
		width: 42px;
		height: 42px;
		border-radius: 14px;
	}

	.contacts-page-contact__value {
		font-size: 16px;
	}

	.contacts-page-map iframe {
		min-height: 260px;
	}

	.contacts-page-hours__time {
		font-size: 16px;
	}

	.contacts-page-related {
		padding-bottom: 62px;
	}

	.contacts-page-related-card {
		grid-template-columns: 46px minmax(0, 1fr) 20px;
		padding: 18px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.contacts-page-messengers a,
	.contacts-page-submit,
	.contacts-page-related-card,
	.contacts-page-related-card__arrow {
		transition: none;
	}

	.contacts-page-messengers a:hover,
	.contacts-page-messengers a:focus-visible,
	.contacts-page-submit:hover,
	.contacts-page-submit:focus-visible,
	.contacts-page-related-card:hover,
	.contacts-page-related-card:focus-visible,
	.contacts-page-related-card:hover .contacts-page-related-card__arrow,
	.contacts-page-related-card:focus-visible .contacts-page-related-card__arrow {
		transform: none;
	}
}

/* ============================================================
   SEO Service Page
   ============================================================ */

.seo-service-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 76px;
	background:
		radial-gradient(circle at 84% 18%, color-mix(in srgb, var(--color-blue) 18%, transparent), transparent 32%),
		radial-gradient(circle at 8% 100%, color-mix(in srgb, var(--color-green) 12%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%) 0%, var(--color-surface) 100%);
}

.seo-service-breadcrumb {
	margin-bottom: 24px;
}

.seo-service-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 600;
}

.seo-service-breadcrumb__item + .seo-service-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--color-blue) 28%);
}

.seo-service-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.seo-service-breadcrumb__link:hover,
.seo-service-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.seo-service-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-text) 58%, var(--color-muted) 42%);
}

.seo-service-hero__content {
	max-width: 980px;
	display: grid;
	gap: 18px;
}

.seo-service-eyebrow {
	width: fit-content;
	margin: 0;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(52, 94, 214, 0.1);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.seo-service-hero__title {
	max-width: 980px;
	margin: 0;
	color: var(--color-bg);
	font-size: 68px;
	font-weight: 760;
	line-height: 1.03;
	letter-spacing: 0;
}

.seo-service-hero__subtitle {
	max-width: 760px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 21px;
	font-weight: 500;
	line-height: 1.58;
}

.seo-service-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 10px;
}

.seo-service-btn {
	min-height: 50px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 24px;
	border: 1px solid transparent;
	border-radius: 10px;
	font-size: 15px;
	font-weight: 800;
	line-height: 1.1;
	text-align: center;
	transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.seo-service-btn:hover,
.seo-service-btn:focus-visible {
	transform: translateY(-1px);
}

.seo-service-btn:focus-visible,
.seo-service-breadcrumb__link:focus-visible,
.seo-service-scope-item__head:focus-visible,
.seo-service-process-step__head:focus-visible,
.seo-service-faq__question:focus-visible,
.seo-service-related-card:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

.seo-service-btn--primary {
	background: linear-gradient(100deg, color-mix(in srgb, var(--color-blue) 74%, var(--color-green) 26%) 0%, var(--color-blue) 100%);
	color: var(--color-surface);
	box-shadow: 0 16px 34px rgba(52, 94, 214, 0.22);
}

.seo-service-btn--secondary {
	border-color: rgba(52, 94, 214, 0.18);
	background: color-mix(in srgb, var(--color-surface) 78%, transparent);
	color: var(--color-bg);
	box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-surface) 92%, transparent);
}

.seo-service-btn--secondary:hover,
.seo-service-btn--secondary:focus-visible {
	border-color: rgba(52, 94, 214, 0.4);
	color: var(--color-blue);
}

.seo-service-btn--full {
	width: 100%;
}

.seo-service-hero__trust {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 22px;
	margin: 6px 0 0;
	padding: 0;
	list-style: none;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.seo-service-hero__trust li {
	position: relative;
	padding-left: 22px;
}

.seo-service-hero__trust li::before,
.seo-service-price-card__list li::before {
	content: "";
	position: absolute;
	width: 13px;
	height: 13px;
	border-radius: 50%;
	background:
		linear-gradient(135deg, transparent 0 42%, var(--color-surface) 42% 56%, transparent 56%),
		color-mix(in srgb, var(--color-green) 74%, var(--color-blue) 26%);
}

.seo-service-hero__trust li::before {
	left: 0;
	top: 0.35em;
}

.seo-service-section-head {
	max-width: 820px;
	display: grid;
	gap: 12px;
	margin-bottom: 32px;
}

.seo-service-section-head--center {
	margin-right: auto;
	margin-left: auto;
	text-align: center;
	justify-items: center;
}

.seo-service-section-head__title,
.seo-service-case__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 50px;
	font-weight: 800;
	line-height: 1.06;
	letter-spacing: 0;
}

.seo-service-section-head__subtitle {
	max-width: 680px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 17px;
	font-weight: 500;
	line-height: 1.5;
}

.seo-service-pain,
.seo-service-process,
.seo-service-price,
.seo-service-related {
	padding: 82px 0;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.seo-service-scope,
.seo-service-case,
.seo-service-faq {
	padding: 84px 0;
	background: var(--color-surface);
}

.seo-service-pain__list {
	overflow: hidden;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 26px;
	background: var(--color-surface);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.seo-service-pain-item {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 54px minmax(0, 1fr);
	align-items: stretch;
}

.seo-service-pain-item + .seo-service-pain-item {
	border-top: 1px solid rgba(52, 94, 214, 0.12);
}

.seo-service-pain-item__problem,
.seo-service-pain-item__solution {
	display: grid;
	align-content: start;
	gap: 10px;
	padding: 26px 30px;
}

.seo-service-pain-item__solution {
	border-left: 1px solid rgba(52, 94, 214, 0.12);
	background:
		radial-gradient(circle at 96% 0%, color-mix(in srgb, var(--color-blue) 10%, transparent), transparent 34%),
		color-mix(in srgb, var(--color-surface) 96%, var(--color-blue) 4%);
}

.seo-service-pain-item__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-blue);
	font-size: 24px;
	font-weight: 800;
}

.seo-service-pain-item__label {
	width: fit-content;
	padding: 7px 10px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.seo-service-pain-item__label--problem {
	background: rgba(239, 68, 68, 0.1);
	color: #ef4444;
}

.seo-service-pain-item__label--solution {
	background: rgba(52, 94, 214, 0.1);
	color: var(--color-blue);
}

.seo-service-pain-item p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 15px;
	font-weight: 600;
	line-height: 1.58;
}

.seo-service-scope__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	overflow: hidden;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 26px;
	background: var(--color-surface);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.seo-service-scope-item {
	border-bottom: 1px solid rgba(52, 94, 214, 0.12);
	border-right: 1px solid rgba(52, 94, 214, 0.12);
}

.seo-service-scope-item:nth-child(2n) {
	border-right: 0;
}

.seo-service-scope-item:nth-last-child(-n+2) {
	border-bottom: 0;
}

.seo-service-scope-item__head {
	width: 100%;
	display: grid;
	grid-template-columns: 38px minmax(0, 1fr) 28px;
	gap: 14px;
	align-items: center;
	padding: 22px 24px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	text-align: left;
	cursor: pointer;
	transition: background 0.2s ease, color 0.2s ease;
}

.seo-service-scope-item__head:hover,
.seo-service-scope-item.is-open .seo-service-scope-item__head {
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
	color: var(--color-blue);
}

.seo-service-scope-item__num {
	color: color-mix(in srgb, var(--color-blue) 58%, transparent);
	font-size: 13px;
	font-weight: 900;
	line-height: 1;
}

.seo-service-scope-item__name {
	font-size: 16px;
	font-weight: 900;
	line-height: 1.28;
}

.seo-service-scope-item__toggle {
	position: relative;
	width: 26px;
	height: 26px;
	border-radius: 50%;
	background: rgba(52, 94, 214, 0.1);
}

.seo-service-scope-item__toggle::before,
.seo-service-scope-item__toggle::after,
.seo-service-faq__icon::before,
.seo-service-faq__icon::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 11px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.seo-service-scope-item__toggle::after,
.seo-service-faq__icon::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.seo-service-scope-item.is-open .seo-service-scope-item__toggle::after,
.seo-service-faq__item.is-open .seo-service-faq__icon::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(0deg);
}

.seo-service-scope-item__body {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.seo-service-scope-item.is-open .seo-service-scope-item__body {
	max-height: 260px;
}

.seo-service-scope-item__body p {
	margin: 0;
	padding: 0 24px 24px 76px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.62;
}

.seo-service-process__steps {
	position: relative;
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 12px;
}

.seo-service-process__steps::before {
	content: "";
	position: absolute;
	left: 8%;
	right: 8%;
	top: 24px;
	height: 1px;
	background: rgba(52, 94, 214, 0.16);
}

.seo-service-process-step {
	position: relative;
	display: grid;
	gap: 14px;
	justify-items: center;
	text-align: center;
}

.seo-service-process-step__head {
	position: relative;
	z-index: 1;
	display: grid;
	justify-items: center;
	gap: 8px;
	width: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--color-bg);
	font: inherit;
	cursor: pointer;
}

.seo-service-process-step__circle {
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(52, 94, 214, 0.18);
	border-radius: 50%;
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 16px;
	font-weight: 900;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.seo-service-process-step.is-active .seo-service-process-step__circle {
	border-color: var(--color-blue);
	background: var(--color-blue);
	color: var(--color-surface);
}

.seo-service-process-step__label {
	color: var(--color-bg);
	font-size: 16px;
	font-weight: 900;
	line-height: 1.15;
}

.seo-service-process-step__time {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
}

.seo-service-process-step__body {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	padding: 0 16px;
	border: 1px solid rgba(52, 94, 214, 0);
	border-radius: 18px;
	background: var(--color-surface);
	text-align: left;
	transition: max-height 0.28s ease, opacity 0.28s ease, padding 0.28s ease, border-color 0.28s ease;
}

.seo-service-process-step.is-active .seo-service-process-step__body {
	max-height: 280px;
	opacity: 1;
	padding: 18px;
	border-color: rgba(52, 94, 214, 0.14);
}

.seo-service-process-step__body p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.58;
}

.seo-service-process-step__body p + p {
	margin-top: 8px;
}

.seo-service-process-step__result {
	color: var(--color-bg);
	font-weight: 800;
}

.seo-service-case__card {
	max-width: 1040px;
	padding: 48px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-left: 4px solid var(--color-blue);
	border-radius: 0 28px 28px 0;
	background:
		radial-gradient(circle at 92% 0%, rgba(124, 200, 255, 0.16), transparent 34%),
		color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.seo-service-case__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
}

.seo-service-case__tag {
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: rgba(52, 94, 214, 0.1);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.seo-service-case__niche {
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.seo-service-case__desc {
	max-width: 840px;
	margin: 16px 0 30px;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.62;
}

.seo-service-case__metrics {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
	margin-bottom: 30px;
}

.seo-service-case__metric {
	display: grid;
	gap: 6px;
	padding: 18px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 18px;
	background: var(--color-surface);
}

.seo-service-case__metric-value {
	color: var(--color-blue);
	font-size: 44px;
	font-weight: 900;
	line-height: 1;
}

.seo-service-case__metric-label {
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.32;
}

.seo-service-price__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
	align-items: stretch;
}

.seo-service-price-card {
	position: relative;
	display: grid;
	grid-template-rows: auto auto auto 1fr auto;
	gap: 16px;
	padding: 30px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 24px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 96%, transparent), color-mix(in srgb, var(--color-surface) 86%, var(--color-blue) 14%)),
		var(--color-surface);
	box-shadow: 0 12px 34px rgba(33, 55, 100, 0.08);
}

.seo-service-price-card--featured {
	border-color: rgba(52, 94, 214, 0.42);
	box-shadow: 0 24px 54px rgba(52, 94, 214, 0.16);
}

.seo-service-price-card__badge {
	position: absolute;
	top: -13px;
	left: 28px;
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: var(--color-blue);
	color: var(--color-surface);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
}

.seo-service-price-card__name {
	margin: 0;
	color: var(--color-bg);
	font-size: 28px;
	font-weight: 900;
	line-height: 1.12;
}

.seo-service-price-card__desc {
	min-height: 44px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.seo-service-price-card__price {
	margin: 0;
	color: var(--color-bg);
	font-size: 26px;
	font-weight: 900;
	line-height: 1.15;
}

.seo-service-price-card__price span {
	color: color-mix(in srgb, var(--color-bg) 48%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.seo-service-price-card__list {
	display: grid;
	gap: 0;
	margin: 0 0 8px;
	padding: 0;
	list-style: none;
}

.seo-service-price-card__list li {
	position: relative;
	padding: 11px 0 11px 26px;
	border-bottom: 1px solid rgba(52, 94, 214, 0.12);
	color: var(--color-bg);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.35;
}

.seo-service-price-card__list li:last-child {
	border-bottom: 0;
}

.seo-service-price-card__list li::before {
	left: 0;
	top: 14px;
}

.seo-service-price__note {
	max-width: 760px;
	margin: 24px auto 0;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.55;
	text-align: center;
}

.seo-service-price__note a {
	color: var(--color-blue);
	font-weight: 900;
}

.seo-service-faq__inner {
	max-width: 940px;
}

.seo-service-faq__list {
	overflow: hidden;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 24px;
	background: var(--color-surface);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.seo-service-faq__item + .seo-service-faq__item {
	border-top: 1px solid rgba(52, 94, 214, 0.12);
}

.seo-service-faq__question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 22px 26px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	font-size: 16px;
	font-weight: 800;
	line-height: 1.35;
	text-align: left;
	cursor: pointer;
	transition: color 0.2s ease, background 0.2s ease;
}

.seo-service-faq__question:hover,
.seo-service-faq__item.is-open .seo-service-faq__question {
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
	color: var(--color-blue);
}

.seo-service-faq__icon {
	position: relative;
	width: 22px;
	height: 22px;
	flex: 0 0 auto;
	border-radius: 50%;
	background: rgba(52, 94, 214, 0.1);
}

.seo-service-faq__answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.seo-service-faq__item.is-open .seo-service-faq__answer {
	max-height: 360px;
}

.seo-service-faq__answer p {
	margin: 0;
	padding: 0 26px 24px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.65;
}

.seo-service-related__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
}

.seo-service-related-card {
	position: relative;
	display: grid;
	gap: 8px;
	min-height: 150px;
	padding: 22px 48px 22px 22px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 20px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px rgba(33, 55, 100, 0.06);
	transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.seo-service-related-card:hover,
.seo-service-related-card:focus-visible {
	border-color: rgba(52, 94, 214, 0.38);
	box-shadow: 0 14px 30px rgba(33, 55, 100, 0.1);
	transform: translateY(-2px);
}

.seo-service-related-card__name {
	color: var(--color-bg);
	font-size: 17px;
	font-weight: 900;
	line-height: 1.18;
}

.seo-service-related-card__desc {
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 600;
	line-height: 1.45;
}

.seo-service-related-card__arrow {
	position: absolute;
	top: 20px;
	right: 20px;
	color: color-mix(in srgb, var(--color-blue) 64%, transparent);
	font-size: 22px;
	font-weight: 900;
	line-height: 1;
	transition: transform 0.2s ease, color 0.2s ease;
}

.seo-service-related-card:hover .seo-service-related-card__arrow,
.seo-service-related-card:focus-visible .seo-service-related-card__arrow {
	color: var(--color-blue);
	transform: translateX(3px);
}

@media (max-width: 1180px) {
	.seo-service-price__grid,
	.seo-service-related__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.seo-service-process__steps {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.seo-service-process__steps::before {
		display: none;
	}
}

@media (max-width: 1023px) {
	.seo-service-hero {
		padding: 136px 0 64px;
	}

	.seo-service-hero__title {
		font-size: 52px;
	}

	.seo-service-hero__subtitle {
		font-size: 19px;
	}

	.seo-service-section-head__title,
	.seo-service-case__title {
		font-size: 40px;
	}

	.seo-service-pain-item {
		grid-template-columns: 1fr;
	}

	.seo-service-pain-item__arrow {
		padding: 8px 0;
		transform: rotate(90deg);
	}

	.seo-service-pain-item__solution {
		border-left: 0;
		border-top: 1px solid rgba(52, 94, 214, 0.12);
	}

	.seo-service-scope__grid,
	.seo-service-process__steps {
		grid-template-columns: 1fr;
	}

	.seo-service-scope-item,
	.seo-service-scope-item:nth-child(2n),
	.seo-service-scope-item:nth-last-child(-n+2) {
		border-right: 0;
		border-bottom: 1px solid rgba(52, 94, 214, 0.12);
	}

	.seo-service-scope-item:last-child {
		border-bottom: 0;
	}

	.seo-service-process-step {
		justify-items: stretch;
		text-align: left;
	}

	.seo-service-process-step__head {
		grid-template-columns: 48px minmax(0, 1fr) auto;
		align-items: center;
		justify-items: start;
		text-align: left;
	}

	.seo-service-case__metrics {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	.seo-service-hero {
		padding: 122px 0 52px;
	}

	.seo-service-hero__title {
		font-size: 34px;
	}

	.seo-service-hero__subtitle,
	.seo-service-section-head__subtitle {
		font-size: 16px;
	}

	.seo-service-section-head__title,
	.seo-service-case__title {
		font-size: 30px;
	}

	.seo-service-hero__actions,
	.seo-service-btn {
		width: 100%;
	}

	.seo-service-pain,
	.seo-service-scope,
	.seo-service-process,
	.seo-service-case,
	.seo-service-price,
	.seo-service-faq,
	.seo-service-related {
		padding: 58px 0;
	}

	.seo-service-pain-item__problem,
	.seo-service-pain-item__solution {
		padding: 22px;
	}

	.seo-service-scope-item__head {
		grid-template-columns: 34px minmax(0, 1fr) 26px;
		padding: 20px;
	}

	.seo-service-scope-item__body p {
		padding: 0 20px 20px;
	}

	.seo-service-process-step__head {
		grid-template-columns: 44px minmax(0, 1fr);
	}

	.seo-service-process-step__time {
		grid-column: 2;
	}

	.seo-service-case__card {
		padding: 28px 22px;
		border-radius: 0 22px 22px 0;
	}

	.seo-service-case__metrics,
	.seo-service-price__grid,
	.seo-service-related__grid {
		grid-template-columns: 1fr;
	}

	.seo-service-case__metric-value {
		font-size: 30px;
	}

	.seo-service-price-card {
		padding: 26px 22px;
	}

	.seo-service-price-card__desc {
		min-height: 0;
	}

	.seo-service-faq__question {
		padding: 18px 20px;
		font-size: 15px;
	}

	.seo-service-faq__answer p {
		padding: 0 20px 20px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.seo-service-btn,
	.seo-service-breadcrumb__link,
	.seo-service-scope-item__head,
	.seo-service-scope-item__body,
	.seo-service-process-step__body,
	.seo-service-faq__question,
	.seo-service-faq__answer,
	.seo-service-related-card,
	.seo-service-related-card__arrow {
		transition: none;
	}

	.seo-service-btn:hover,
	.seo-service-btn:focus-visible,
	.seo-service-related-card:hover,
	.seo-service-related-card:focus-visible,
	.seo-service-related-card:hover .seo-service-related-card__arrow,
	.seo-service-related-card:focus-visible .seo-service-related-card__arrow {
		transform: none;
	}
}

/* ============================================================
   Context Ads Service Page
   ============================================================ */

.ads-service-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 76px;
	background:
		radial-gradient(circle at 84% 18%, color-mix(in srgb, var(--color-blue) 18%, transparent), transparent 32%),
		radial-gradient(circle at 8% 100%, color-mix(in srgb, var(--color-green) 12%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%) 0%, var(--color-surface) 100%);
}

.ads-service-breadcrumb {
	margin-bottom: 24px;
}

.ads-service-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 600;
}

.ads-service-breadcrumb__item + .ads-service-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--color-blue) 28%);
}

.ads-service-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.ads-service-breadcrumb__link:hover,
.ads-service-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.ads-service-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-text) 58%, var(--color-muted) 42%);
}

.ads-service-hero__content {
	max-width: 980px;
	display: grid;
	gap: 18px;
}

.ads-service-eyebrow {
	width: fit-content;
	margin: 0;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(52, 94, 214, 0.1);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.ads-service-hero__title {
	max-width: 980px;
	margin: 0;
	color: var(--color-bg);
	font-size: 66px;
	font-weight: 760;
	line-height: 1.03;
	letter-spacing: 0;
}

.ads-service-hero__subtitle {
	max-width: 760px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 21px;
	font-weight: 500;
	line-height: 1.58;
}

.ads-service-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 10px;
}

.ads-service-btn {
	min-height: 50px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 24px;
	border: 1px solid transparent;
	border-radius: 10px;
	font-size: 15px;
	font-weight: 800;
	line-height: 1.1;
	text-align: center;
	transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.ads-service-btn:hover,
.ads-service-btn:focus-visible {
	transform: translateY(-1px);
}

.ads-service-btn:focus-visible,
.ads-service-breadcrumb__link:focus-visible,
.ads-service-scope-item__head:focus-visible,
.ads-service-process-step__head:focus-visible,
.ads-service-faq__question:focus-visible,
.ads-service-related-card:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

.ads-service-btn--primary {
	background: linear-gradient(100deg, color-mix(in srgb, var(--color-blue) 74%, var(--color-green) 26%) 0%, var(--color-blue) 100%);
	color: var(--color-surface);
	box-shadow: 0 16px 34px rgba(52, 94, 214, 0.22);
}

.ads-service-btn--secondary {
	border-color: rgba(52, 94, 214, 0.18);
	background: color-mix(in srgb, var(--color-surface) 78%, transparent);
	color: var(--color-bg);
	box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-surface) 92%, transparent);
}

.ads-service-btn--secondary:hover,
.ads-service-btn--secondary:focus-visible {
	border-color: rgba(52, 94, 214, 0.4);
	color: var(--color-blue);
}

.ads-service-btn--full {
	width: 100%;
}

.ads-service-hero__trust {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 22px;
	margin: 6px 0 0;
	padding: 0;
	list-style: none;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.ads-service-hero__trust li,
.ads-service-price-card__list li {
	position: relative;
}

.ads-service-hero__trust li {
	padding-left: 22px;
}

.ads-service-hero__trust li::before,
.ads-service-price-card__list li::before {
	content: "";
	position: absolute;
	width: 13px;
	height: 13px;
	border-radius: 50%;
	background:
		linear-gradient(135deg, transparent 0 42%, var(--color-surface) 42% 56%, transparent 56%),
		color-mix(in srgb, var(--color-green) 74%, var(--color-blue) 26%);
}

.ads-service-hero__trust li::before {
	left: 0;
	top: 0.35em;
}

.ads-service-section-head {
	max-width: 820px;
	display: grid;
	gap: 12px;
	margin-bottom: 32px;
}

.ads-service-section-head--center {
	margin-right: auto;
	margin-left: auto;
	text-align: center;
	justify-items: center;
}

.ads-service-section-head__title,
.ads-service-case__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 50px;
	font-weight: 800;
	line-height: 1.06;
	letter-spacing: 0;
}

.ads-service-section-head__subtitle {
	max-width: 680px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 17px;
	font-weight: 500;
	line-height: 1.5;
}

.ads-service-pain,
.ads-service-process,
.ads-service-price,
.ads-service-related {
	padding: 82px 0;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.ads-service-scope,
.ads-service-case,
.ads-service-faq {
	padding: 84px 0;
	background: var(--color-surface);
}

.ads-service-pain__list,
.ads-service-scope__grid,
.ads-service-faq__list {
	overflow: hidden;
	border: 1px solid rgba(52, 94, 214, 0.14);
	background: var(--color-surface);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.ads-service-pain__list,
.ads-service-scope__grid {
	border-radius: 26px;
}

.ads-service-pain-item {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 54px minmax(0, 1fr);
	align-items: stretch;
}

.ads-service-pain-item + .ads-service-pain-item {
	border-top: 1px solid rgba(52, 94, 214, 0.12);
}

.ads-service-pain-item__problem,
.ads-service-pain-item__solution {
	display: grid;
	align-content: start;
	gap: 10px;
	padding: 26px 30px;
}

.ads-service-pain-item__solution {
	border-left: 1px solid rgba(52, 94, 214, 0.12);
	background:
		radial-gradient(circle at 96% 0%, color-mix(in srgb, var(--color-blue) 10%, transparent), transparent 34%),
		color-mix(in srgb, var(--color-surface) 96%, var(--color-blue) 4%);
}

.ads-service-pain-item__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-blue);
	font-size: 24px;
	font-weight: 800;
}

.ads-service-pain-item__label {
	width: fit-content;
	padding: 7px 10px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.ads-service-pain-item__label--problem {
	background: rgba(239, 68, 68, 0.1);
	color: #ef4444;
}

.ads-service-pain-item__label--solution {
	background: rgba(52, 94, 214, 0.1);
	color: var(--color-blue);
}

.ads-service-pain-item p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 15px;
	font-weight: 600;
	line-height: 1.58;
}

.ads-service-scope__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ads-service-scope-item {
	border-bottom: 1px solid rgba(52, 94, 214, 0.12);
	border-right: 1px solid rgba(52, 94, 214, 0.12);
}

.ads-service-scope-item:nth-child(2n) {
	border-right: 0;
}

.ads-service-scope-item:nth-last-child(-n+2) {
	border-bottom: 0;
}

.ads-service-scope-item__head {
	width: 100%;
	display: grid;
	grid-template-columns: 38px minmax(0, 1fr) 28px;
	gap: 14px;
	align-items: center;
	padding: 22px 24px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	text-align: left;
	cursor: pointer;
	transition: background 0.2s ease, color 0.2s ease;
}

.ads-service-scope-item__head:hover,
.ads-service-scope-item.is-open .ads-service-scope-item__head {
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
	color: var(--color-blue);
}

.ads-service-scope-item__num {
	color: color-mix(in srgb, var(--color-blue) 58%, transparent);
	font-size: 13px;
	font-weight: 900;
	line-height: 1;
}

.ads-service-scope-item__name {
	font-size: 16px;
	font-weight: 900;
	line-height: 1.28;
}

.ads-service-scope-item__toggle,
.ads-service-faq__icon {
	position: relative;
	border-radius: 50%;
	background: rgba(52, 94, 214, 0.1);
}

.ads-service-scope-item__toggle {
	width: 26px;
	height: 26px;
}

.ads-service-faq__icon {
	width: 22px;
	height: 22px;
	flex: 0 0 auto;
}

.ads-service-scope-item__toggle::before,
.ads-service-scope-item__toggle::after,
.ads-service-faq__icon::before,
.ads-service-faq__icon::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 11px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.ads-service-scope-item__toggle::after,
.ads-service-faq__icon::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.ads-service-scope-item.is-open .ads-service-scope-item__toggle::after,
.ads-service-faq__item.is-open .ads-service-faq__icon::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(0deg);
}

.ads-service-scope-item__body,
.ads-service-faq__answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.ads-service-scope-item.is-open .ads-service-scope-item__body {
	max-height: 260px;
}

.ads-service-scope-item__body p {
	margin: 0;
	padding: 0 24px 24px 76px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.62;
}

.ads-service-process__steps {
	position: relative;
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 12px;
}

.ads-service-process__steps::before {
	content: "";
	position: absolute;
	left: 8%;
	right: 8%;
	top: 24px;
	height: 1px;
	background: rgba(52, 94, 214, 0.16);
}

.ads-service-process-step {
	position: relative;
	display: grid;
	gap: 14px;
	justify-items: center;
	text-align: center;
}

.ads-service-process-step__head {
	position: relative;
	z-index: 1;
	display: grid;
	justify-items: center;
	gap: 8px;
	width: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--color-bg);
	font: inherit;
	cursor: pointer;
}

.ads-service-process-step__circle {
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(52, 94, 214, 0.18);
	border-radius: 50%;
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 16px;
	font-weight: 900;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.ads-service-process-step.is-active .ads-service-process-step__circle {
	border-color: var(--color-blue);
	background: var(--color-blue);
	color: var(--color-surface);
}

.ads-service-process-step__label {
	color: var(--color-bg);
	font-size: 16px;
	font-weight: 900;
	line-height: 1.15;
}

.ads-service-process-step__time {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
}

.ads-service-process-step__body {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	padding: 0 16px;
	border: 1px solid rgba(52, 94, 214, 0);
	border-radius: 18px;
	background: var(--color-surface);
	text-align: left;
	transition: max-height 0.28s ease, opacity 0.28s ease, padding 0.28s ease, border-color 0.28s ease;
}

.ads-service-process-step.is-active .ads-service-process-step__body {
	max-height: 280px;
	opacity: 1;
	padding: 18px;
	border-color: rgba(52, 94, 214, 0.14);
}

.ads-service-process-step__body p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.58;
}

.ads-service-process-step__body p + p {
	margin-top: 8px;
}

.ads-service-process-step__result {
	color: var(--color-bg);
	font-weight: 800;
}

.ads-service-case__card {
	max-width: 1040px;
	padding: 48px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-left: 4px solid var(--color-blue);
	border-radius: 0 28px 28px 0;
	background:
		radial-gradient(circle at 92% 0%, rgba(124, 200, 255, 0.16), transparent 34%),
		color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.ads-service-case__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
}

.ads-service-case__tag {
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: rgba(52, 94, 214, 0.1);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.ads-service-case__niche {
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.ads-service-case__desc {
	max-width: 840px;
	margin: 16px 0 30px;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.62;
}

.ads-service-case__metrics,
.ads-service-price__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.ads-service-case__metrics {
	margin-bottom: 30px;
}

.ads-service-case__metric {
	display: grid;
	gap: 6px;
	padding: 18px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 18px;
	background: var(--color-surface);
}

.ads-service-case__metric-value {
	color: var(--color-blue);
	font-size: 44px;
	font-weight: 900;
	line-height: 1;
}

.ads-service-case__metric-label {
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.32;
}

.ads-service-price-card {
	position: relative;
	display: grid;
	grid-template-rows: auto auto auto 1fr auto;
	gap: 16px;
	padding: 30px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 24px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 96%, transparent), color-mix(in srgb, var(--color-surface) 86%, var(--color-blue) 14%)),
		var(--color-surface);
	box-shadow: 0 12px 34px rgba(33, 55, 100, 0.08);
}

.ads-service-price-card--featured {
	border-color: rgba(52, 94, 214, 0.42);
	box-shadow: 0 24px 54px rgba(52, 94, 214, 0.16);
}

.ads-service-price-card__badge {
	position: absolute;
	top: -13px;
	left: 28px;
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: var(--color-blue);
	color: var(--color-surface);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
}

.ads-service-price-card__name {
	margin: 0;
	color: var(--color-bg);
	font-size: 28px;
	font-weight: 900;
	line-height: 1.12;
}

.ads-service-price-card__desc {
	min-height: 44px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.ads-service-price-card__price {
	margin: 0;
	color: var(--color-bg);
	font-size: 26px;
	font-weight: 900;
	line-height: 1.15;
}

.ads-service-price-card__price span {
	color: color-mix(in srgb, var(--color-bg) 48%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.ads-service-price-card__list {
	display: grid;
	gap: 0;
	margin: 0 0 8px;
	padding: 0;
	list-style: none;
}

.ads-service-price-card__list li {
	padding: 11px 0 11px 26px;
	border-bottom: 1px solid rgba(52, 94, 214, 0.12);
	color: var(--color-bg);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.35;
}

.ads-service-price-card__list li:last-child {
	border-bottom: 0;
}

.ads-service-price-card__list li::before {
	left: 0;
	top: 14px;
}

.ads-service-price__note {
	max-width: 760px;
	margin: 24px auto 0;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.55;
	text-align: center;
}

.ads-service-price__note a {
	color: var(--color-blue);
	font-weight: 900;
}

.ads-service-faq__inner {
	max-width: 940px;
}

.ads-service-faq__list {
	border-radius: 24px;
}

.ads-service-faq__item + .ads-service-faq__item {
	border-top: 1px solid rgba(52, 94, 214, 0.12);
}

.ads-service-faq__question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 22px 26px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	font-size: 16px;
	font-weight: 800;
	line-height: 1.35;
	text-align: left;
	cursor: pointer;
	transition: color 0.2s ease, background 0.2s ease;
}

.ads-service-faq__question:hover,
.ads-service-faq__item.is-open .ads-service-faq__question {
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
	color: var(--color-blue);
}

.ads-service-faq__item.is-open .ads-service-faq__answer {
	max-height: 360px;
}

.ads-service-faq__answer p {
	margin: 0;
	padding: 0 26px 24px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.65;
}

.ads-service-related__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
}

.ads-service-related-card {
	position: relative;
	display: grid;
	gap: 8px;
	min-height: 150px;
	padding: 22px 48px 22px 22px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 20px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px rgba(33, 55, 100, 0.06);
	transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.ads-service-related-card:hover,
.ads-service-related-card:focus-visible {
	border-color: rgba(52, 94, 214, 0.38);
	box-shadow: 0 14px 30px rgba(33, 55, 100, 0.1);
	transform: translateY(-2px);
}

.ads-service-related-card__name {
	color: var(--color-bg);
	font-size: 17px;
	font-weight: 900;
	line-height: 1.18;
}

.ads-service-related-card__desc {
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 600;
	line-height: 1.45;
}

.ads-service-related-card__arrow {
	position: absolute;
	top: 20px;
	right: 20px;
	color: color-mix(in srgb, var(--color-blue) 64%, transparent);
	font-size: 22px;
	font-weight: 900;
	line-height: 1;
	transition: transform 0.2s ease, color 0.2s ease;
}

.ads-service-related-card:hover .ads-service-related-card__arrow,
.ads-service-related-card:focus-visible .ads-service-related-card__arrow {
	color: var(--color-blue);
	transform: translateX(3px);
}

@media (max-width: 1180px) {
	.ads-service-price__grid,
	.ads-service-related__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.ads-service-process__steps {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.ads-service-process__steps::before {
		display: none;
	}
}

@media (max-width: 1023px) {
	.ads-service-hero {
		padding: 136px 0 64px;
	}

	.ads-service-hero__title {
		font-size: 52px;
	}

	.ads-service-hero__subtitle {
		font-size: 19px;
	}

	.ads-service-section-head__title,
	.ads-service-case__title {
		font-size: 40px;
	}

	.ads-service-pain-item,
	.ads-service-scope__grid,
	.ads-service-process__steps {
		grid-template-columns: 1fr;
	}

	.ads-service-pain-item__arrow {
		padding: 8px 0;
		transform: rotate(90deg);
	}

	.ads-service-pain-item__solution {
		border-left: 0;
		border-top: 1px solid rgba(52, 94, 214, 0.12);
	}

	.ads-service-scope-item,
	.ads-service-scope-item:nth-child(2n),
	.ads-service-scope-item:nth-last-child(-n+2) {
		border-right: 0;
		border-bottom: 1px solid rgba(52, 94, 214, 0.12);
	}

	.ads-service-scope-item:last-child {
		border-bottom: 0;
	}

	.ads-service-process-step {
		justify-items: stretch;
		text-align: left;
	}

	.ads-service-process-step__head {
		grid-template-columns: 48px minmax(0, 1fr) auto;
		align-items: center;
		justify-items: start;
		text-align: left;
	}

	.ads-service-case__metrics {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	.ads-service-hero {
		padding: 122px 0 52px;
	}

	.ads-service-hero__title {
		font-size: 34px;
	}

	.ads-service-hero__subtitle,
	.ads-service-section-head__subtitle {
		font-size: 16px;
	}

	.ads-service-section-head__title,
	.ads-service-case__title {
		font-size: 30px;
	}

	.ads-service-hero__actions,
	.ads-service-btn {
		width: 100%;
	}

	.ads-service-pain,
	.ads-service-scope,
	.ads-service-process,
	.ads-service-case,
	.ads-service-price,
	.ads-service-faq,
	.ads-service-related {
		padding: 58px 0;
	}

	.ads-service-pain-item__problem,
	.ads-service-pain-item__solution {
		padding: 22px;
	}

	.ads-service-scope-item__head {
		grid-template-columns: 34px minmax(0, 1fr) 26px;
		padding: 20px;
	}

	.ads-service-scope-item__body p {
		padding: 0 20px 20px;
	}

	.ads-service-process-step__head {
		grid-template-columns: 44px minmax(0, 1fr);
	}

	.ads-service-process-step__time {
		grid-column: 2;
	}

	.ads-service-case__card {
		padding: 28px 22px;
		border-radius: 0 22px 22px 0;
	}

	.ads-service-case__metrics,
	.ads-service-price__grid,
	.ads-service-related__grid {
		grid-template-columns: 1fr;
	}

	.ads-service-case__metric-value {
		font-size: 30px;
	}

	.ads-service-price-card {
		padding: 26px 22px;
	}

	.ads-service-price-card__desc {
		min-height: 0;
	}

	.ads-service-faq__question {
		padding: 18px 20px;
		font-size: 15px;
	}

	.ads-service-faq__answer p {
		padding: 0 20px 20px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.ads-service-btn,
	.ads-service-breadcrumb__link,
	.ads-service-scope-item__head,
	.ads-service-scope-item__body,
	.ads-service-process-step__body,
	.ads-service-faq__question,
	.ads-service-faq__answer,
	.ads-service-related-card,
	.ads-service-related-card__arrow {
		transition: none;
	}

	.ads-service-btn:hover,
	.ads-service-btn:focus-visible,
	.ads-service-related-card:hover,
	.ads-service-related-card:focus-visible,
	.ads-service-related-card:hover .ads-service-related-card__arrow,
	.ads-service-related-card:focus-visible .ads-service-related-card__arrow {
		transform: none;
	}
}

/* ============================================================
   Maps Promotion Service Page
   ============================================================ */

.maps-service-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 76px;
	background:
		radial-gradient(circle at 84% 18%, color-mix(in srgb, var(--color-green) 20%, transparent), transparent 32%),
		radial-gradient(circle at 8% 100%, color-mix(in srgb, var(--color-blue) 12%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 93%, var(--color-green) 7%) 0%, var(--color-surface) 100%);
}

.maps-service-breadcrumb {
	margin-bottom: 24px;
}

.maps-service-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 600;
}

.maps-service-breadcrumb__item + .maps-service-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 70%, var(--color-green) 30%);
}

.maps-service-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.maps-service-breadcrumb__link:hover,
.maps-service-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.maps-service-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-text) 58%, var(--color-muted) 42%);
}

.maps-service-hero__content {
	max-width: 980px;
	display: grid;
	gap: 18px;
}

.maps-service-eyebrow {
	width: fit-content;
	margin: 0;
	padding: 8px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-green) 16%, transparent);
	color: color-mix(in srgb, var(--color-blue) 78%, var(--color-green) 22%);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.maps-service-hero__title {
	max-width: 1020px;
	margin: 0;
	color: var(--color-bg);
	font-size: 66px;
	font-weight: 760;
	line-height: 1.03;
	letter-spacing: 0;
}

.maps-service-hero__subtitle {
	max-width: 760px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 21px;
	font-weight: 500;
	line-height: 1.58;
}

.maps-service-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 10px;
}

.maps-service-btn {
	min-height: 50px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 24px;
	border: 1px solid transparent;
	border-radius: 10px;
	font-size: 15px;
	font-weight: 800;
	line-height: 1.1;
	text-align: center;
	transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.maps-service-btn:hover,
.maps-service-btn:focus-visible {
	transform: translateY(-1px);
}

.maps-service-btn:focus-visible,
.maps-service-breadcrumb__link:focus-visible,
.maps-service-scope-item__head:focus-visible,
.maps-service-process-step__head:focus-visible,
.maps-service-faq__question:focus-visible,
.maps-service-related-card:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-green) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

.maps-service-btn--primary {
	background: linear-gradient(100deg, color-mix(in srgb, var(--color-blue) 72%, var(--color-green) 28%) 0%, var(--color-blue) 100%);
	color: var(--color-surface);
	box-shadow: 0 16px 34px rgba(52, 94, 214, 0.22);
}

.maps-service-btn--secondary {
	border-color: color-mix(in srgb, var(--color-blue) 18%, transparent);
	background: color-mix(in srgb, var(--color-surface) 78%, transparent);
	color: var(--color-bg);
	box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-surface) 92%, transparent);
}

.maps-service-btn--secondary:hover,
.maps-service-btn--secondary:focus-visible {
	border-color: color-mix(in srgb, var(--color-blue) 40%, transparent);
	color: var(--color-blue);
}

.maps-service-btn--full {
	width: 100%;
}

.maps-service-hero__trust {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 22px;
	margin: 6px 0 0;
	padding: 0;
	list-style: none;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.maps-service-hero__trust li,
.maps-service-price-card__list li {
	position: relative;
}

.maps-service-hero__trust li {
	padding-left: 22px;
}

.maps-service-hero__trust li::before,
.maps-service-price-card__list li::before {
	content: "";
	position: absolute;
	width: 13px;
	height: 13px;
	border-radius: 50%;
	background:
		linear-gradient(135deg, transparent 0 42%, var(--color-surface) 42% 56%, transparent 56%),
		color-mix(in srgb, var(--color-green) 76%, var(--color-blue) 24%);
}

.maps-service-hero__trust li::before {
	left: 0;
	top: 0.35em;
}

.maps-service-section-head {
	max-width: 820px;
	display: grid;
	gap: 12px;
	margin-bottom: 32px;
}

.maps-service-section-head--center {
	margin-right: auto;
	margin-left: auto;
	text-align: center;
	justify-items: center;
}

.maps-service-section-head__title,
.maps-service-case__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 50px;
	font-weight: 800;
	line-height: 1.06;
	letter-spacing: 0;
}

.maps-service-section-head__subtitle {
	max-width: 680px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 17px;
	font-weight: 500;
	line-height: 1.5;
}

.maps-service-pain,
.maps-service-process,
.maps-service-price,
.maps-service-related {
	padding: 82px 0;
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-green) 6%);
}

.maps-service-scope,
.maps-service-case,
.maps-service-faq {
	padding: 84px 0;
	background: var(--color-surface);
}

.maps-service-pain__list,
.maps-service-scope__grid,
.maps-service-faq__list {
	overflow: hidden;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	background: var(--color-surface);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.maps-service-pain__list,
.maps-service-scope__grid {
	border-radius: 26px;
}

.maps-service-pain-item {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 54px minmax(0, 1fr);
	align-items: stretch;
}

.maps-service-pain-item + .maps-service-pain-item {
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.maps-service-pain-item__problem,
.maps-service-pain-item__solution {
	display: grid;
	align-content: start;
	gap: 10px;
	padding: 26px 30px;
}

.maps-service-pain-item__solution {
	border-left: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	background:
		radial-gradient(circle at 96% 0%, color-mix(in srgb, var(--color-green) 12%, transparent), transparent 34%),
		color-mix(in srgb, var(--color-surface) 95%, var(--color-green) 5%);
}

.maps-service-pain-item__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-blue);
	font-size: 24px;
	font-weight: 800;
}

.maps-service-pain-item__label {
	width: fit-content;
	padding: 7px 10px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.maps-service-pain-item__label--problem {
	background: color-mix(in srgb, var(--color-muted) 12%, transparent);
	color: color-mix(in srgb, var(--color-bg) 62%, var(--color-muted) 38%);
}

.maps-service-pain-item__label--solution {
	background: color-mix(in srgb, var(--color-green) 16%, transparent);
	color: color-mix(in srgb, var(--color-blue) 76%, var(--color-green) 24%);
}

.maps-service-pain-item p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 15px;
	font-weight: 600;
	line-height: 1.58;
}

.maps-service-scope__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.maps-service-scope-item {
	border-bottom: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	border-right: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.maps-service-scope-item:nth-child(2n) {
	border-right: 0;
}

.maps-service-scope-item:nth-last-child(-n+2) {
	border-bottom: 0;
}

.maps-service-scope-item__head {
	width: 100%;
	display: grid;
	grid-template-columns: 38px minmax(0, 1fr) 28px;
	gap: 14px;
	align-items: center;
	padding: 22px 24px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	text-align: left;
	cursor: pointer;
	transition: background 0.2s ease, color 0.2s ease;
}

.maps-service-scope-item__head:hover,
.maps-service-scope-item.is-open .maps-service-scope-item__head {
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-green) 7%);
	color: var(--color-blue);
}

.maps-service-scope-item__num {
	color: color-mix(in srgb, var(--color-blue) 58%, transparent);
	font-size: 13px;
	font-weight: 900;
	line-height: 1;
}

.maps-service-scope-item__name {
	font-size: 16px;
	font-weight: 900;
	line-height: 1.28;
}

.maps-service-scope-item__toggle,
.maps-service-faq__icon {
	position: relative;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-green) 14%, transparent);
}

.maps-service-scope-item__toggle {
	width: 26px;
	height: 26px;
}

.maps-service-faq__icon {
	width: 22px;
	height: 22px;
	flex: 0 0 auto;
}

.maps-service-scope-item__toggle::before,
.maps-service-scope-item__toggle::after,
.maps-service-faq__icon::before,
.maps-service-faq__icon::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 11px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.maps-service-scope-item__toggle::after,
.maps-service-faq__icon::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.maps-service-scope-item.is-open .maps-service-scope-item__toggle::after,
.maps-service-faq__item.is-open .maps-service-faq__icon::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(0deg);
}

.maps-service-scope-item__body,
.maps-service-faq__answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.maps-service-scope-item.is-open .maps-service-scope-item__body {
	max-height: 260px;
}

.maps-service-scope-item__body p {
	margin: 0;
	padding: 0 24px 24px 76px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.62;
}

.maps-service-process__steps {
	position: relative;
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 12px;
}

.maps-service-process__steps::before {
	content: "";
	position: absolute;
	left: 8%;
	right: 8%;
	top: 24px;
	height: 1px;
	background: color-mix(in srgb, var(--color-blue) 16%, transparent);
}

.maps-service-process-step {
	position: relative;
	display: grid;
	gap: 14px;
	justify-items: center;
	text-align: center;
}

.maps-service-process-step__head {
	position: relative;
	z-index: 1;
	display: grid;
	justify-items: center;
	gap: 8px;
	width: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--color-bg);
	font: inherit;
	cursor: pointer;
}

.maps-service-process-step__circle {
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid color-mix(in srgb, var(--color-blue) 18%, transparent);
	border-radius: 50%;
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 16px;
	font-weight: 900;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.maps-service-process-step.is-active .maps-service-process-step__circle {
	border-color: var(--color-blue);
	background: var(--color-blue);
	color: var(--color-surface);
}

.maps-service-process-step__label {
	color: var(--color-bg);
	font-size: 16px;
	font-weight: 900;
	line-height: 1.15;
}

.maps-service-process-step__time {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
}

.maps-service-process-step__body {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	padding: 0 16px;
	border: 1px solid transparent;
	border-radius: 18px;
	background: var(--color-surface);
	text-align: left;
	transition: max-height 0.28s ease, opacity 0.28s ease, padding 0.28s ease, border-color 0.28s ease;
}

.maps-service-process-step.is-active .maps-service-process-step__body {
	max-height: 280px;
	opacity: 1;
	padding: 18px;
	border-color: color-mix(in srgb, var(--color-blue) 14%, transparent);
}

.maps-service-process-step__body p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.58;
}

.maps-service-process-step__body p + p {
	margin-top: 8px;
}

.maps-service-process-step__result {
	color: var(--color-bg);
	font-weight: 800;
}

.maps-service-case__card {
	max-width: 1040px;
	padding: 48px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-left: 4px solid var(--color-green);
	border-radius: 0 28px 28px 0;
	background:
		radial-gradient(circle at 92% 0%, color-mix(in srgb, var(--color-green) 18%, transparent), transparent 34%),
		color-mix(in srgb, var(--color-surface) 93%, var(--color-green) 7%);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.maps-service-case__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
}

.maps-service-case__tag {
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-green) 16%, transparent);
	color: color-mix(in srgb, var(--color-blue) 76%, var(--color-green) 24%);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.maps-service-case__niche {
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.maps-service-case__desc {
	max-width: 840px;
	margin: 16px 0 30px;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.62;
}

.maps-service-case__metrics,
.maps-service-price__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.maps-service-case__metrics {
	margin-bottom: 30px;
}

.maps-service-case__metric {
	display: grid;
	gap: 6px;
	padding: 18px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 18px;
	background: var(--color-surface);
}

.maps-service-case__metric-value {
	color: var(--color-blue);
	font-size: 40px;
	font-weight: 900;
	line-height: 1;
}

.maps-service-case__metric-label {
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.32;
}

.maps-service-price-card {
	position: relative;
	display: grid;
	grid-template-rows: auto auto auto 1fr auto;
	gap: 16px;
	padding: 30px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 24px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 96%, transparent), color-mix(in srgb, var(--color-surface) 88%, var(--color-green) 12%)),
		var(--color-surface);
	box-shadow: 0 12px 34px rgba(33, 55, 100, 0.08);
}

.maps-service-price-card--featured {
	border-color: color-mix(in srgb, var(--color-blue) 42%, transparent);
	box-shadow: 0 24px 54px rgba(52, 94, 214, 0.16);
}

.maps-service-price-card__badge {
	position: absolute;
	top: -13px;
	left: 28px;
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: var(--color-blue);
	color: var(--color-surface);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
}

.maps-service-price-card__name {
	margin: 0;
	color: var(--color-bg);
	font-size: 28px;
	font-weight: 900;
	line-height: 1.12;
}

.maps-service-price-card__desc {
	min-height: 44px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.maps-service-price-card__price {
	margin: 0;
	color: var(--color-bg);
	font-size: 26px;
	font-weight: 900;
	line-height: 1.15;
}

.maps-service-price-card__price span {
	color: color-mix(in srgb, var(--color-bg) 48%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.maps-service-price-card__list {
	display: grid;
	gap: 0;
	margin: 0 0 8px;
	padding: 0;
	list-style: none;
}

.maps-service-price-card__list li {
	padding: 11px 0 11px 26px;
	border-bottom: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	color: var(--color-bg);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.35;
}

.maps-service-price-card__list li:last-child {
	border-bottom: 0;
}

.maps-service-price-card__list li::before {
	left: 0;
	top: 14px;
}

.maps-service-price__note {
	max-width: 760px;
	margin: 24px auto 0;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.55;
	text-align: center;
}

.maps-service-price__note a {
	color: var(--color-blue);
	font-weight: 900;
}

.maps-service-faq__inner {
	max-width: 940px;
}

.maps-service-faq__list {
	border-radius: 24px;
}

.maps-service-faq__item + .maps-service-faq__item {
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.maps-service-faq__question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 22px 26px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	font-size: 16px;
	font-weight: 800;
	line-height: 1.35;
	text-align: left;
	cursor: pointer;
	transition: color 0.2s ease, background 0.2s ease;
}

.maps-service-faq__question:hover,
.maps-service-faq__item.is-open .maps-service-faq__question {
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-green) 7%);
	color: var(--color-blue);
}

.maps-service-faq__item.is-open .maps-service-faq__answer {
	max-height: 360px;
}

.maps-service-faq__answer p {
	margin: 0;
	padding: 0 26px 24px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.65;
}

.maps-service-related__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
}

.maps-service-related-card {
	position: relative;
	display: grid;
	gap: 8px;
	min-height: 150px;
	padding: 22px 48px 22px 22px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 20px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px rgba(33, 55, 100, 0.06);
	transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.maps-service-related-card:hover,
.maps-service-related-card:focus-visible {
	border-color: color-mix(in srgb, var(--color-blue) 38%, transparent);
	box-shadow: 0 14px 30px rgba(33, 55, 100, 0.1);
	transform: translateY(-2px);
}

.maps-service-related-card__name {
	color: var(--color-bg);
	font-size: 17px;
	font-weight: 900;
	line-height: 1.18;
}

.maps-service-related-card__desc {
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 600;
	line-height: 1.45;
}

.maps-service-related-card__arrow {
	position: absolute;
	top: 20px;
	right: 20px;
	color: color-mix(in srgb, var(--color-blue) 64%, transparent);
	font-size: 22px;
	font-weight: 900;
	line-height: 1;
	transition: transform 0.2s ease, color 0.2s ease;
}

.maps-service-related-card:hover .maps-service-related-card__arrow,
.maps-service-related-card:focus-visible .maps-service-related-card__arrow {
	color: var(--color-blue);
	transform: translateX(3px);
}

@media (max-width: 1180px) {
	.maps-service-price__grid,
	.maps-service-related__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.maps-service-process__steps {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.maps-service-process__steps::before {
		display: none;
	}
}

@media (max-width: 1023px) {
	.maps-service-hero {
		padding: 136px 0 64px;
	}

	.maps-service-hero__title {
		font-size: 52px;
	}

	.maps-service-hero__subtitle {
		font-size: 19px;
	}

	.maps-service-section-head__title,
	.maps-service-case__title {
		font-size: 40px;
	}

	.maps-service-pain-item,
	.maps-service-scope__grid,
	.maps-service-process__steps {
		grid-template-columns: 1fr;
	}

	.maps-service-pain-item__arrow {
		padding: 8px 0;
		transform: rotate(90deg);
	}

	.maps-service-pain-item__solution {
		border-left: 0;
		border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	}

	.maps-service-scope-item,
	.maps-service-scope-item:nth-child(2n),
	.maps-service-scope-item:nth-last-child(-n+2) {
		border-right: 0;
		border-bottom: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	}

	.maps-service-scope-item:last-child {
		border-bottom: 0;
	}

	.maps-service-process-step {
		justify-items: stretch;
		text-align: left;
	}

	.maps-service-process-step__head {
		grid-template-columns: 48px minmax(0, 1fr) auto;
		align-items: center;
		justify-items: start;
		text-align: left;
	}

	.maps-service-case__metrics {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	.maps-service-hero {
		padding: 122px 0 52px;
	}

	.maps-service-hero__title {
		font-size: 34px;
	}

	.maps-service-hero__subtitle,
	.maps-service-section-head__subtitle {
		font-size: 16px;
	}

	.maps-service-section-head__title,
	.maps-service-case__title {
		font-size: 30px;
	}

	.maps-service-hero__actions,
	.maps-service-btn {
		width: 100%;
	}

	.maps-service-pain,
	.maps-service-scope,
	.maps-service-process,
	.maps-service-case,
	.maps-service-price,
	.maps-service-faq,
	.maps-service-related {
		padding: 58px 0;
	}

	.maps-service-pain-item__problem,
	.maps-service-pain-item__solution {
		padding: 22px;
	}

	.maps-service-scope-item__head {
		grid-template-columns: 34px minmax(0, 1fr) 26px;
		padding: 20px;
	}

	.maps-service-scope-item__body p {
		padding: 0 20px 20px;
	}

	.maps-service-process-step__head {
		grid-template-columns: 44px minmax(0, 1fr);
	}

	.maps-service-process-step__time {
		grid-column: 2;
	}

	.maps-service-case__card {
		padding: 28px 22px;
		border-radius: 0 22px 22px 0;
	}

	.maps-service-case__metrics,
	.maps-service-price__grid,
	.maps-service-related__grid {
		grid-template-columns: 1fr;
	}

	.maps-service-case__metric-value {
		font-size: 30px;
	}

	.maps-service-price-card {
		padding: 26px 22px;
	}

	.maps-service-price-card__desc {
		min-height: 0;
	}

	.maps-service-faq__question {
		padding: 18px 20px;
		font-size: 15px;
	}

	.maps-service-faq__answer p {
		padding: 0 20px 20px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.maps-service-btn,
	.maps-service-breadcrumb__link,
	.maps-service-scope-item__head,
	.maps-service-scope-item__body,
	.maps-service-process-step__body,
	.maps-service-faq__question,
	.maps-service-faq__answer,
	.maps-service-related-card,
	.maps-service-related-card__arrow {
		transition: none;
	}

	.maps-service-btn:hover,
	.maps-service-btn:focus-visible,
	.maps-service-related-card:hover,
	.maps-service-related-card:focus-visible,
	.maps-service-related-card:hover .maps-service-related-card__arrow,
	.maps-service-related-card:focus-visible .maps-service-related-card__arrow {
		transform: none;
	}
}

/* ============================================================
   Medical Aggregators Service Page
   ============================================================ */

.agg-service-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 76px;
	background:
		radial-gradient(circle at 84% 18%, color-mix(in srgb, var(--color-blue) 18%, transparent), transparent 32%),
		radial-gradient(circle at 8% 100%, color-mix(in srgb, var(--color-green) 10%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%) 0%, var(--color-surface) 100%);
}

.agg-service-breadcrumb {
	margin-bottom: 24px;
}

.agg-service-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 600;
}

.agg-service-breadcrumb__item + .agg-service-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 70%, var(--color-blue) 30%);
}

.agg-service-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.agg-service-breadcrumb__link:hover,
.agg-service-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.agg-service-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-text) 58%, var(--color-muted) 42%);
}

.agg-service-hero__content {
	max-width: 1040px;
	display: grid;
	gap: 18px;
}

.agg-service-eyebrow {
	width: fit-content;
	margin: 0;
	padding: 8px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 11%, transparent);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.agg-service-hero__title {
	max-width: 1040px;
	margin: 0;
	color: var(--color-bg);
	font-size: 66px;
	font-weight: 760;
	line-height: 1.03;
	letter-spacing: 0;
}

.agg-service-hero__subtitle {
	max-width: 770px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 21px;
	font-weight: 500;
	line-height: 1.58;
}

.agg-service-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 10px;
}

.agg-service-btn {
	min-height: 50px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 24px;
	border: 1px solid transparent;
	border-radius: 10px;
	font-size: 15px;
	font-weight: 800;
	line-height: 1.1;
	text-align: center;
	transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.agg-service-btn:hover,
.agg-service-btn:focus-visible {
	transform: translateY(-1px);
}

.agg-service-btn:focus-visible,
.agg-service-breadcrumb__link:focus-visible,
.agg-service-scope-item__head:focus-visible,
.agg-service-process-step__head:focus-visible,
.agg-service-faq__question:focus-visible,
.agg-service-related-card:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

.agg-service-btn--primary {
	background: linear-gradient(100deg, color-mix(in srgb, var(--color-blue) 76%, var(--color-green) 24%) 0%, var(--color-blue) 100%);
	color: var(--color-surface);
	box-shadow: 0 16px 34px rgba(52, 94, 214, 0.22);
}

.agg-service-btn--secondary {
	border-color: color-mix(in srgb, var(--color-blue) 18%, transparent);
	background: color-mix(in srgb, var(--color-surface) 78%, transparent);
	color: var(--color-bg);
	box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-surface) 92%, transparent);
}

.agg-service-btn--secondary:hover,
.agg-service-btn--secondary:focus-visible {
	border-color: color-mix(in srgb, var(--color-blue) 40%, transparent);
	color: var(--color-blue);
}

.agg-service-btn--full {
	width: 100%;
}

.agg-service-hero__trust {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 22px;
	margin: 6px 0 0;
	padding: 0;
	list-style: none;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.agg-service-hero__trust li,
.agg-service-price-card__list li {
	position: relative;
}

.agg-service-hero__trust li {
	padding-left: 22px;
}

.agg-service-hero__trust li::before,
.agg-service-price-card__list li::before {
	content: "";
	position: absolute;
	width: 13px;
	height: 13px;
	border-radius: 50%;
	background:
		linear-gradient(135deg, transparent 0 42%, var(--color-surface) 42% 56%, transparent 56%),
		color-mix(in srgb, var(--color-blue) 72%, var(--color-green) 28%);
}

.agg-service-hero__trust li::before {
	left: 0;
	top: 0.35em;
}

.agg-service-section-head {
	max-width: 820px;
	display: grid;
	gap: 12px;
	margin-bottom: 32px;
}

.agg-service-section-head--center {
	margin-right: auto;
	margin-left: auto;
	text-align: center;
	justify-items: center;
}

.agg-service-section-head__title,
.agg-service-case__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 50px;
	font-weight: 800;
	line-height: 1.06;
	letter-spacing: 0;
}

.agg-service-section-head__subtitle {
	max-width: 680px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 17px;
	font-weight: 500;
	line-height: 1.5;
}

.agg-service-pain,
.agg-service-platforms,
.agg-service-process,
.agg-service-price,
.agg-service-related {
	padding: 82px 0;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.agg-service-scope,
.agg-service-case,
.agg-service-faq {
	padding: 84px 0;
	background: var(--color-surface);
}

.agg-service-pain__list,
.agg-service-scope__grid,
.agg-service-faq__list {
	overflow: hidden;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	background: var(--color-surface);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.agg-service-pain__list,
.agg-service-scope__grid {
	border-radius: 26px;
}

.agg-service-pain-item {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 54px minmax(0, 1fr);
	align-items: stretch;
}

.agg-service-pain-item + .agg-service-pain-item {
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.agg-service-pain-item__problem,
.agg-service-pain-item__solution {
	display: grid;
	align-content: start;
	gap: 10px;
	padding: 26px 30px;
}

.agg-service-pain-item__solution {
	border-left: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	background:
		radial-gradient(circle at 96% 0%, color-mix(in srgb, var(--color-blue) 10%, transparent), transparent 34%),
		color-mix(in srgb, var(--color-surface) 95%, var(--color-blue) 5%);
}

.agg-service-pain-item__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-blue);
	font-size: 24px;
	font-weight: 800;
}

.agg-service-pain-item__label {
	width: fit-content;
	padding: 7px 10px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.agg-service-pain-item__label--problem {
	background: color-mix(in srgb, var(--color-muted) 12%, transparent);
	color: color-mix(in srgb, var(--color-bg) 62%, var(--color-muted) 38%);
}

.agg-service-pain-item__label--solution {
	background: color-mix(in srgb, var(--color-blue) 12%, transparent);
	color: var(--color-blue);
}

.agg-service-pain-item p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 15px;
	font-weight: 600;
	line-height: 1.58;
}

.agg-service-platforms__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
}

.agg-service-platform-card {
	min-height: 280px;
	display: flex;
	flex-direction: column;
	gap: 16px;
	padding: 24px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 98%, transparent), color-mix(in srgb, var(--color-surface) 90%, var(--color-blue) 10%)),
		var(--color-surface);
	box-shadow: 0 12px 34px rgba(33, 55, 100, 0.08);
}

.agg-service-platform-card__head {
	display: grid;
	gap: 10px;
}

.agg-service-platform-card__name {
	margin: 0;
	color: var(--color-bg);
	font-size: 22px;
	font-weight: 900;
	line-height: 1.12;
}

.agg-service-platform-card__priority {
	width: fit-content;
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 10px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 10%, transparent);
	color: var(--color-blue);
	font-size: 11px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.agg-service-platform-card__desc {
	flex: 1;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.58;
}

.agg-service-platform-card__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.agg-service-platform-card__tags li {
	padding: 6px 9px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	border-radius: 8px;
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 11px;
	font-weight: 800;
	line-height: 1.1;
}

.agg-service-scope__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.agg-service-scope-item {
	border-bottom: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	border-right: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.agg-service-scope-item:nth-child(2n) {
	border-right: 0;
}

.agg-service-scope-item:nth-last-child(-n+2) {
	border-bottom: 0;
}

.agg-service-scope-item__head {
	width: 100%;
	display: grid;
	grid-template-columns: 38px minmax(0, 1fr) 28px;
	gap: 14px;
	align-items: center;
	padding: 22px 24px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	text-align: left;
	cursor: pointer;
	transition: background 0.2s ease, color 0.2s ease;
}

.agg-service-scope-item__head:hover,
.agg-service-scope-item.is-open .agg-service-scope-item__head {
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
	color: var(--color-blue);
}

.agg-service-scope-item__num {
	color: color-mix(in srgb, var(--color-blue) 58%, transparent);
	font-size: 13px;
	font-weight: 900;
	line-height: 1;
}

.agg-service-scope-item__name {
	font-size: 16px;
	font-weight: 900;
	line-height: 1.28;
}

.agg-service-scope-item__toggle,
.agg-service-faq__icon {
	position: relative;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-blue) 10%, transparent);
}

.agg-service-scope-item__toggle {
	width: 26px;
	height: 26px;
}

.agg-service-faq__icon {
	width: 22px;
	height: 22px;
	flex: 0 0 auto;
}

.agg-service-scope-item__toggle::before,
.agg-service-scope-item__toggle::after,
.agg-service-faq__icon::before,
.agg-service-faq__icon::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 11px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.agg-service-scope-item__toggle::after,
.agg-service-faq__icon::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.agg-service-scope-item.is-open .agg-service-scope-item__toggle::after,
.agg-service-faq__item.is-open .agg-service-faq__icon::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(0deg);
}

.agg-service-scope-item__body,
.agg-service-faq__answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.agg-service-scope-item.is-open .agg-service-scope-item__body {
	max-height: 260px;
}

.agg-service-scope-item__body p {
	margin: 0;
	padding: 0 24px 24px 76px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.62;
}

.agg-service-process__steps {
	position: relative;
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 12px;
}

.agg-service-process__steps::before {
	content: "";
	position: absolute;
	left: 8%;
	right: 8%;
	top: 24px;
	height: 1px;
	background: color-mix(in srgb, var(--color-blue) 16%, transparent);
}

.agg-service-process-step {
	position: relative;
	display: grid;
	gap: 14px;
	justify-items: center;
	text-align: center;
}

.agg-service-process-step__head {
	position: relative;
	z-index: 1;
	display: grid;
	justify-items: center;
	gap: 8px;
	width: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--color-bg);
	font: inherit;
	cursor: pointer;
}

.agg-service-process-step__circle {
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid color-mix(in srgb, var(--color-blue) 18%, transparent);
	border-radius: 50%;
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 16px;
	font-weight: 900;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.agg-service-process-step.is-active .agg-service-process-step__circle {
	border-color: var(--color-blue);
	background: var(--color-blue);
	color: var(--color-surface);
}

.agg-service-process-step__label {
	color: var(--color-bg);
	font-size: 16px;
	font-weight: 900;
	line-height: 1.15;
}

.agg-service-process-step__time {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
}

.agg-service-process-step__body {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	padding: 0 16px;
	border: 1px solid transparent;
	border-radius: 18px;
	background: var(--color-surface);
	text-align: left;
	transition: max-height 0.28s ease, opacity 0.28s ease, padding 0.28s ease, border-color 0.28s ease;
}

.agg-service-process-step.is-active .agg-service-process-step__body {
	max-height: 280px;
	opacity: 1;
	padding: 18px;
	border-color: color-mix(in srgb, var(--color-blue) 14%, transparent);
}

.agg-service-process-step__body p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.58;
}

.agg-service-process-step__body p + p {
	margin-top: 8px;
}

.agg-service-process-step__result {
	color: var(--color-bg);
	font-weight: 800;
}

.agg-service-case__card {
	max-width: 1040px;
	padding: 48px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-left: 4px solid var(--color-blue);
	border-radius: 0 28px 28px 0;
	background:
		radial-gradient(circle at 92% 0%, color-mix(in srgb, var(--color-blue) 16%, transparent), transparent 34%),
		color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.agg-service-case__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
}

.agg-service-case__tag {
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 10%, transparent);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.agg-service-case__niche {
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.agg-service-case__desc {
	max-width: 840px;
	margin: 16px 0 30px;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.62;
}

.agg-service-case__metrics,
.agg-service-price__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.agg-service-case__metrics {
	margin-bottom: 30px;
}

.agg-service-case__metric {
	display: grid;
	gap: 6px;
	padding: 18px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 18px;
	background: var(--color-surface);
}

.agg-service-case__metric-value {
	color: var(--color-blue);
	font-size: 40px;
	font-weight: 900;
	line-height: 1;
}

.agg-service-case__metric-label {
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.32;
}

.agg-service-price-card {
	position: relative;
	display: grid;
	grid-template-rows: auto auto auto 1fr auto;
	gap: 16px;
	padding: 30px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 24px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 96%, transparent), color-mix(in srgb, var(--color-surface) 86%, var(--color-blue) 14%)),
		var(--color-surface);
	box-shadow: 0 12px 34px rgba(33, 55, 100, 0.08);
}

.agg-service-price-card--featured {
	border-color: color-mix(in srgb, var(--color-blue) 42%, transparent);
	box-shadow: 0 24px 54px rgba(52, 94, 214, 0.16);
}

.agg-service-price-card__badge {
	position: absolute;
	top: -13px;
	left: 28px;
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: var(--color-blue);
	color: var(--color-surface);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
}

.agg-service-price-card__name {
	margin: 0;
	color: var(--color-bg);
	font-size: 28px;
	font-weight: 900;
	line-height: 1.12;
}

.agg-service-price-card__desc {
	min-height: 44px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.agg-service-price-card__price {
	margin: 0;
	color: var(--color-bg);
	font-size: 26px;
	font-weight: 900;
	line-height: 1.15;
}

.agg-service-price-card__price span {
	color: color-mix(in srgb, var(--color-bg) 48%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.agg-service-price-card__list {
	display: grid;
	gap: 0;
	margin: 0 0 8px;
	padding: 0;
	list-style: none;
}

.agg-service-price-card__list li {
	padding: 11px 0 11px 26px;
	border-bottom: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	color: var(--color-bg);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.35;
}

.agg-service-price-card__list li:last-child {
	border-bottom: 0;
}

.agg-service-price-card__list li::before {
	left: 0;
	top: 14px;
}

.agg-service-price__note {
	max-width: 760px;
	margin: 24px auto 0;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.55;
	text-align: center;
}

.agg-service-price__note a {
	color: var(--color-blue);
	font-weight: 900;
}

.agg-service-faq__inner {
	max-width: 940px;
}

.agg-service-faq__list {
	border-radius: 24px;
}

.agg-service-faq__item + .agg-service-faq__item {
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.agg-service-faq__question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 22px 26px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	font-size: 16px;
	font-weight: 800;
	line-height: 1.35;
	text-align: left;
	cursor: pointer;
	transition: color 0.2s ease, background 0.2s ease;
}

.agg-service-faq__question:hover,
.agg-service-faq__item.is-open .agg-service-faq__question {
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
	color: var(--color-blue);
}

.agg-service-faq__item.is-open .agg-service-faq__answer {
	max-height: 360px;
}

.agg-service-faq__answer p {
	margin: 0;
	padding: 0 26px 24px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.65;
}

.agg-service-related__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
}

.agg-service-related-card {
	position: relative;
	display: grid;
	gap: 8px;
	min-height: 150px;
	padding: 22px 48px 22px 22px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 20px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px rgba(33, 55, 100, 0.06);
	transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.agg-service-related-card:hover,
.agg-service-related-card:focus-visible {
	border-color: color-mix(in srgb, var(--color-blue) 38%, transparent);
	box-shadow: 0 14px 30px rgba(33, 55, 100, 0.1);
	transform: translateY(-2px);
}

.agg-service-related-card__name {
	color: var(--color-bg);
	font-size: 17px;
	font-weight: 900;
	line-height: 1.18;
}

.agg-service-related-card__desc {
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 600;
	line-height: 1.45;
}

.agg-service-related-card__arrow {
	position: absolute;
	top: 20px;
	right: 20px;
	color: color-mix(in srgb, var(--color-blue) 64%, transparent);
	font-size: 22px;
	font-weight: 900;
	line-height: 1;
	transition: transform 0.2s ease, color 0.2s ease;
}

.agg-service-related-card:hover .agg-service-related-card__arrow,
.agg-service-related-card:focus-visible .agg-service-related-card__arrow {
	color: var(--color-blue);
	transform: translateX(3px);
}

@media (max-width: 1180px) {
	.agg-service-platforms__grid,
	.agg-service-price__grid,
	.agg-service-related__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.agg-service-process__steps {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.agg-service-process__steps::before {
		display: none;
	}
}

@media (max-width: 1023px) {
	.agg-service-hero {
		padding: 136px 0 64px;
	}

	.agg-service-hero__title {
		font-size: 52px;
	}

	.agg-service-hero__subtitle {
		font-size: 19px;
	}

	.agg-service-section-head__title,
	.agg-service-case__title {
		font-size: 40px;
	}

	.agg-service-pain-item,
	.agg-service-scope__grid,
	.agg-service-process__steps {
		grid-template-columns: 1fr;
	}

	.agg-service-pain-item__arrow {
		padding: 8px 0;
		transform: rotate(90deg);
	}

	.agg-service-pain-item__solution {
		border-left: 0;
		border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	}

	.agg-service-scope-item,
	.agg-service-scope-item:nth-child(2n),
	.agg-service-scope-item:nth-last-child(-n+2) {
		border-right: 0;
		border-bottom: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	}

	.agg-service-scope-item:last-child {
		border-bottom: 0;
	}

	.agg-service-process-step {
		justify-items: stretch;
		text-align: left;
	}

	.agg-service-process-step__head {
		grid-template-columns: 48px minmax(0, 1fr) auto;
		align-items: center;
		justify-items: start;
		text-align: left;
	}

	.agg-service-case__metrics {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	.agg-service-hero {
		padding: 122px 0 52px;
	}

	.agg-service-hero__title {
		font-size: 34px;
	}

	.agg-service-hero__subtitle,
	.agg-service-section-head__subtitle {
		font-size: 16px;
	}

	.agg-service-section-head__title,
	.agg-service-case__title {
		font-size: 30px;
	}

	.agg-service-hero__actions,
	.agg-service-btn {
		width: 100%;
	}

	.agg-service-pain,
	.agg-service-platforms,
	.agg-service-scope,
	.agg-service-process,
	.agg-service-case,
	.agg-service-price,
	.agg-service-faq,
	.agg-service-related {
		padding: 58px 0;
	}

	.agg-service-pain-item__problem,
	.agg-service-pain-item__solution {
		padding: 22px;
	}

	.agg-service-platforms__grid,
	.agg-service-case__metrics,
	.agg-service-price__grid,
	.agg-service-related__grid {
		grid-template-columns: 1fr;
	}

	.agg-service-platform-card {
		min-height: 0;
		padding: 22px;
	}

	.agg-service-scope-item__head {
		grid-template-columns: 34px minmax(0, 1fr) 26px;
		padding: 20px;
	}

	.agg-service-scope-item__body p {
		padding: 0 20px 20px;
	}

	.agg-service-process-step__head {
		grid-template-columns: 44px minmax(0, 1fr);
	}

	.agg-service-process-step__time {
		grid-column: 2;
	}

	.agg-service-case__card {
		padding: 28px 22px;
		border-radius: 0 22px 22px 0;
	}

	.agg-service-case__metric-value {
		font-size: 30px;
	}

	.agg-service-price-card {
		padding: 26px 22px;
	}

	.agg-service-price-card__desc {
		min-height: 0;
	}

	.agg-service-faq__question {
		padding: 18px 20px;
		font-size: 15px;
	}

	.agg-service-faq__answer p {
		padding: 0 20px 20px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.agg-service-btn,
	.agg-service-breadcrumb__link,
	.agg-service-scope-item__head,
	.agg-service-scope-item__body,
	.agg-service-process-step__body,
	.agg-service-faq__question,
	.agg-service-faq__answer,
	.agg-service-related-card,
	.agg-service-related-card__arrow {
		transition: none;
	}

	.agg-service-btn:hover,
	.agg-service-btn:focus-visible,
	.agg-service-related-card:hover,
	.agg-service-related-card:focus-visible,
	.agg-service-related-card:hover .agg-service-related-card__arrow,
	.agg-service-related-card:focus-visible .agg-service-related-card__arrow {
		transform: none;
	}
}

/* ============================================================
   Reputation Management Service Page
   ============================================================ */

.rep-service-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 76px;
	background:
		radial-gradient(circle at 84% 18%, color-mix(in srgb, var(--color-blue) 16%, transparent), transparent 32%),
		radial-gradient(circle at 8% 100%, color-mix(in srgb, var(--color-green) 14%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 94%, var(--color-green) 6%) 0%, var(--color-surface) 100%);
}

.rep-service-breadcrumb {
	margin-bottom: 24px;
}

.rep-service-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 600;
}

.rep-service-breadcrumb__item + .rep-service-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 70%, var(--color-green) 30%);
}

.rep-service-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.rep-service-breadcrumb__link:hover,
.rep-service-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.rep-service-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-text) 58%, var(--color-muted) 42%);
}

.rep-service-hero__content {
	max-width: 1040px;
	display: grid;
	gap: 18px;
}

.rep-service-eyebrow {
	width: fit-content;
	margin: 0;
	padding: 8px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-green) 14%, transparent);
	color: color-mix(in srgb, var(--color-blue) 72%, var(--color-green) 28%);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.rep-service-hero__title {
	max-width: 1040px;
	margin: 0;
	color: var(--color-bg);
	font-size: 66px;
	font-weight: 760;
	line-height: 1.03;
	letter-spacing: 0;
}

.rep-service-hero__subtitle {
	max-width: 780px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 21px;
	font-weight: 500;
	line-height: 1.58;
}

.rep-service-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 10px;
}

.rep-service-btn {
	min-height: 50px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 24px;
	border: 1px solid transparent;
	border-radius: 10px;
	font-size: 15px;
	font-weight: 800;
	line-height: 1.1;
	text-align: center;
	transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.rep-service-btn:hover,
.rep-service-btn:focus-visible {
	transform: translateY(-1px);
}

.rep-service-btn:focus-visible,
.rep-service-breadcrumb__link:focus-visible,
.rep-service-scope-item__head:focus-visible,
.rep-service-process-step__head:focus-visible,
.rep-service-faq__question:focus-visible,
.rep-service-related-card:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-green) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

.rep-service-btn--primary {
	background: linear-gradient(100deg, color-mix(in srgb, var(--color-blue) 72%, var(--color-green) 28%) 0%, var(--color-blue) 100%);
	color: var(--color-surface);
	box-shadow: 0 16px 34px rgba(52, 94, 214, 0.22);
}

.rep-service-btn--secondary {
	border-color: color-mix(in srgb, var(--color-blue) 18%, transparent);
	background: color-mix(in srgb, var(--color-surface) 78%, transparent);
	color: var(--color-bg);
	box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-surface) 92%, transparent);
}

.rep-service-btn--secondary:hover,
.rep-service-btn--secondary:focus-visible {
	border-color: color-mix(in srgb, var(--color-blue) 40%, transparent);
	color: var(--color-blue);
}

.rep-service-btn--full {
	width: 100%;
}

.rep-service-hero__trust {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 22px;
	margin: 6px 0 0;
	padding: 0;
	list-style: none;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.rep-service-hero__trust li,
.rep-service-price-card__list li {
	position: relative;
}

.rep-service-hero__trust li {
	padding-left: 22px;
}

.rep-service-hero__trust li::before,
.rep-service-price-card__list li::before {
	content: "";
	position: absolute;
	width: 13px;
	height: 13px;
	border-radius: 50%;
	background:
		linear-gradient(135deg, transparent 0 42%, var(--color-surface) 42% 56%, transparent 56%),
		color-mix(in srgb, var(--color-green) 74%, var(--color-blue) 26%);
}

.rep-service-hero__trust li::before {
	left: 0;
	top: 0.35em;
}

.rep-service-section-head {
	max-width: 820px;
	display: grid;
	gap: 12px;
	margin-bottom: 32px;
}

.rep-service-section-head--center {
	margin-right: auto;
	margin-left: auto;
	text-align: center;
	justify-items: center;
}

.rep-service-section-head__title,
.rep-service-case__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 50px;
	font-weight: 800;
	line-height: 1.06;
	letter-spacing: 0;
}

.rep-service-section-head__subtitle {
	max-width: 680px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 17px;
	font-weight: 500;
	line-height: 1.5;
}

.rep-service-pain,
.rep-service-process,
.rep-service-price,
.rep-service-related {
	padding: 82px 0;
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-green) 6%);
}

.rep-service-impact,
.rep-service-scope,
.rep-service-case,
.rep-service-faq {
	padding: 84px 0;
	background: var(--color-surface);
}

.rep-service-pain__list,
.rep-service-scope__grid,
.rep-service-faq__list {
	overflow: hidden;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	background: var(--color-surface);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.rep-service-pain__list,
.rep-service-scope__grid {
	border-radius: 26px;
}

.rep-service-pain-item {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 54px minmax(0, 1fr);
	align-items: stretch;
}

.rep-service-pain-item + .rep-service-pain-item {
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.rep-service-pain-item__problem,
.rep-service-pain-item__solution {
	display: grid;
	align-content: start;
	gap: 10px;
	padding: 26px 30px;
}

.rep-service-pain-item__solution {
	border-left: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	background:
		radial-gradient(circle at 96% 0%, color-mix(in srgb, var(--color-green) 12%, transparent), transparent 34%),
		color-mix(in srgb, var(--color-surface) 95%, var(--color-green) 5%);
}

.rep-service-pain-item__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-blue);
	font-size: 24px;
	font-weight: 800;
}

.rep-service-pain-item__label {
	width: fit-content;
	padding: 7px 10px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.rep-service-pain-item__label--problem {
	background: color-mix(in srgb, var(--color-muted) 12%, transparent);
	color: color-mix(in srgb, var(--color-bg) 62%, var(--color-muted) 38%);
}

.rep-service-pain-item__label--solution {
	background: color-mix(in srgb, var(--color-green) 16%, transparent);
	color: color-mix(in srgb, var(--color-blue) 76%, var(--color-green) 24%);
}

.rep-service-pain-item p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 15px;
	font-weight: 600;
	line-height: 1.58;
}

.rep-service-impact__list {
	overflow: hidden;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 26px;
	background: var(--color-surface);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.rep-service-impact-item {
	display: grid;
	grid-template-columns: 180px 220px minmax(0, 1fr);
	align-items: center;
	gap: 24px;
	padding: 26px 30px;
	border-left: 4px solid var(--color-blue);
}

.rep-service-impact-item + .rep-service-impact-item {
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.rep-service-impact-item--high {
	border-left-color: var(--color-green);
}

.rep-service-impact-item--mid {
	border-left-color: color-mix(in srgb, var(--color-green) 48%, var(--color-blue) 52%);
}

.rep-service-impact-item--low {
	border-left-color: color-mix(in srgb, var(--color-bg) 72%, var(--color-muted) 28%);
}

.rep-service-impact-item__rating {
	display: grid;
	gap: 6px;
}

.rep-service-impact-item__stars {
	color: var(--color-blue);
	font-size: 20px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
}

.rep-service-impact-item--high .rep-service-impact-item__stars {
	color: var(--color-green);
}

.rep-service-impact-item--low .rep-service-impact-item__stars {
	color: color-mix(in srgb, var(--color-bg) 52%, var(--color-muted) 48%);
}

.rep-service-impact-item__range {
	color: var(--color-bg);
	font-size: 15px;
	font-weight: 900;
	line-height: 1;
}

.rep-service-impact-item__bar-wrap {
	height: 10px;
	overflow: hidden;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-line) 68%, var(--color-surface) 32%);
}

.rep-service-impact-item__bar {
	display: block;
	height: 100%;
	border-radius: inherit;
	background: var(--color-blue);
}

.rep-service-impact-item--high .rep-service-impact-item__bar {
	background: var(--color-green);
}

.rep-service-impact-item--mid .rep-service-impact-item__bar {
	background: linear-gradient(90deg, var(--color-blue), color-mix(in srgb, var(--color-green) 58%, var(--color-blue) 42%));
}

.rep-service-impact-item--low .rep-service-impact-item__bar {
	background: color-mix(in srgb, var(--color-bg) 72%, var(--color-muted) 28%);
}

.rep-service-impact-item__body {
	display: grid;
	gap: 10px;
}

.rep-service-impact-item__body p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.62;
}

.rep-service-impact-item__label {
	width: fit-content;
	padding: 7px 10px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 10%, transparent);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
}

.rep-service-scope__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.rep-service-scope-item {
	border-bottom: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	border-right: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.rep-service-scope-item:nth-child(2n) {
	border-right: 0;
}

.rep-service-scope-item:nth-last-child(-n+2) {
	border-bottom: 0;
}

.rep-service-scope-item__head {
	width: 100%;
	display: grid;
	grid-template-columns: 38px minmax(0, 1fr) 28px;
	gap: 14px;
	align-items: center;
	padding: 22px 24px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	text-align: left;
	cursor: pointer;
	transition: background 0.2s ease, color 0.2s ease;
}

.rep-service-scope-item__head:hover,
.rep-service-scope-item.is-open .rep-service-scope-item__head {
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-green) 7%);
	color: var(--color-blue);
}

.rep-service-scope-item__num {
	color: color-mix(in srgb, var(--color-blue) 58%, transparent);
	font-size: 13px;
	font-weight: 900;
	line-height: 1;
}

.rep-service-scope-item__name {
	font-size: 16px;
	font-weight: 900;
	line-height: 1.28;
}

.rep-service-scope-item__toggle,
.rep-service-faq__icon {
	position: relative;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-green) 14%, transparent);
}

.rep-service-scope-item__toggle {
	width: 26px;
	height: 26px;
}

.rep-service-faq__icon {
	width: 22px;
	height: 22px;
	flex: 0 0 auto;
}

.rep-service-scope-item__toggle::before,
.rep-service-scope-item__toggle::after,
.rep-service-faq__icon::before,
.rep-service-faq__icon::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 11px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.rep-service-scope-item__toggle::after,
.rep-service-faq__icon::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.rep-service-scope-item.is-open .rep-service-scope-item__toggle::after,
.rep-service-faq__item.is-open .rep-service-faq__icon::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(0deg);
}

.rep-service-scope-item__body,
.rep-service-faq__answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.rep-service-scope-item.is-open .rep-service-scope-item__body {
	max-height: 260px;
}

.rep-service-scope-item__body p {
	margin: 0;
	padding: 0 24px 24px 76px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.62;
}

.rep-service-process__steps {
	position: relative;
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 12px;
}

.rep-service-process__steps::before {
	content: "";
	position: absolute;
	left: 8%;
	right: 8%;
	top: 24px;
	height: 1px;
	background: color-mix(in srgb, var(--color-blue) 16%, transparent);
}

.rep-service-process-step {
	position: relative;
	display: grid;
	gap: 14px;
	justify-items: center;
	text-align: center;
}

.rep-service-process-step__head {
	position: relative;
	z-index: 1;
	display: grid;
	justify-items: center;
	gap: 8px;
	width: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--color-bg);
	font: inherit;
	cursor: pointer;
}

.rep-service-process-step__circle {
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid color-mix(in srgb, var(--color-blue) 18%, transparent);
	border-radius: 50%;
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 16px;
	font-weight: 900;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.rep-service-process-step.is-active .rep-service-process-step__circle {
	border-color: var(--color-blue);
	background: var(--color-blue);
	color: var(--color-surface);
}

.rep-service-process-step__label {
	color: var(--color-bg);
	font-size: 16px;
	font-weight: 900;
	line-height: 1.15;
}

.rep-service-process-step__time {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
}

.rep-service-process-step__body {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	padding: 0 16px;
	border: 1px solid transparent;
	border-radius: 18px;
	background: var(--color-surface);
	text-align: left;
	transition: max-height 0.28s ease, opacity 0.28s ease, padding 0.28s ease, border-color 0.28s ease;
}

.rep-service-process-step.is-active .rep-service-process-step__body {
	max-height: 280px;
	opacity: 1;
	padding: 18px;
	border-color: color-mix(in srgb, var(--color-blue) 14%, transparent);
}

.rep-service-process-step__body p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.58;
}

.rep-service-process-step__body p + p {
	margin-top: 8px;
}

.rep-service-process-step__result {
	color: var(--color-bg);
	font-weight: 800;
}

.rep-service-case__card {
	max-width: 1040px;
	padding: 48px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-left: 4px solid var(--color-green);
	border-radius: 0 28px 28px 0;
	background:
		radial-gradient(circle at 92% 0%, color-mix(in srgb, var(--color-green) 18%, transparent), transparent 34%),
		color-mix(in srgb, var(--color-surface) 93%, var(--color-green) 7%);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.rep-service-case__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
}

.rep-service-case__tag {
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-green) 16%, transparent);
	color: color-mix(in srgb, var(--color-blue) 76%, var(--color-green) 24%);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.rep-service-case__niche {
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.rep-service-case__desc {
	max-width: 840px;
	margin: 16px 0 30px;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.62;
}

.rep-service-case__metrics,
.rep-service-price__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.rep-service-case__metrics {
	margin-bottom: 30px;
}

.rep-service-case__metric {
	display: grid;
	gap: 6px;
	padding: 18px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 18px;
	background: var(--color-surface);
}

.rep-service-case__metric-value {
	color: var(--color-blue);
	font-size: 40px;
	font-weight: 900;
	line-height: 1;
}

.rep-service-case__metric-label {
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.32;
}

.rep-service-price-card {
	position: relative;
	display: grid;
	grid-template-rows: auto auto auto 1fr auto;
	gap: 16px;
	padding: 30px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 24px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 96%, transparent), color-mix(in srgb, var(--color-surface) 88%, var(--color-green) 12%)),
		var(--color-surface);
	box-shadow: 0 12px 34px rgba(33, 55, 100, 0.08);
}

.rep-service-price-card--featured {
	border-color: color-mix(in srgb, var(--color-blue) 42%, transparent);
	box-shadow: 0 24px 54px rgba(52, 94, 214, 0.16);
}

.rep-service-price-card__badge {
	position: absolute;
	top: -13px;
	left: 28px;
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: var(--color-blue);
	color: var(--color-surface);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
}

.rep-service-price-card__name {
	margin: 0;
	color: var(--color-bg);
	font-size: 28px;
	font-weight: 900;
	line-height: 1.12;
}

.rep-service-price-card__desc {
	min-height: 44px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.rep-service-price-card__price {
	margin: 0;
	color: var(--color-bg);
	font-size: 26px;
	font-weight: 900;
	line-height: 1.15;
}

.rep-service-price-card__price span {
	color: color-mix(in srgb, var(--color-bg) 48%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.rep-service-price-card__list {
	display: grid;
	gap: 0;
	margin: 0 0 8px;
	padding: 0;
	list-style: none;
}

.rep-service-price-card__list li {
	padding: 11px 0 11px 26px;
	border-bottom: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	color: var(--color-bg);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.35;
}

.rep-service-price-card__list li:last-child {
	border-bottom: 0;
}

.rep-service-price-card__list li::before {
	left: 0;
	top: 14px;
}

.rep-service-price__note {
	max-width: 760px;
	margin: 24px auto 0;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.55;
	text-align: center;
}

.rep-service-price__note a {
	color: var(--color-blue);
	font-weight: 900;
}

.rep-service-faq__inner {
	max-width: 940px;
}

.rep-service-faq__list {
	border-radius: 24px;
}

.rep-service-faq__item + .rep-service-faq__item {
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.rep-service-faq__question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 22px 26px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	font-size: 16px;
	font-weight: 800;
	line-height: 1.35;
	text-align: left;
	cursor: pointer;
	transition: color 0.2s ease, background 0.2s ease;
}

.rep-service-faq__question:hover,
.rep-service-faq__item.is-open .rep-service-faq__question {
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-green) 7%);
	color: var(--color-blue);
}

.rep-service-faq__item.is-open .rep-service-faq__answer {
	max-height: 360px;
}

.rep-service-faq__answer p {
	margin: 0;
	padding: 0 26px 24px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.65;
}

.rep-service-related__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
}

.rep-service-related-card {
	position: relative;
	display: grid;
	gap: 8px;
	min-height: 150px;
	padding: 22px 48px 22px 22px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 20px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px rgba(33, 55, 100, 0.06);
	transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.rep-service-related-card:hover,
.rep-service-related-card:focus-visible {
	border-color: color-mix(in srgb, var(--color-blue) 38%, transparent);
	box-shadow: 0 14px 30px rgba(33, 55, 100, 0.1);
	transform: translateY(-2px);
}

.rep-service-related-card__name {
	color: var(--color-bg);
	font-size: 17px;
	font-weight: 900;
	line-height: 1.18;
}

.rep-service-related-card__desc {
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 600;
	line-height: 1.45;
}

.rep-service-related-card__arrow {
	position: absolute;
	top: 20px;
	right: 20px;
	color: color-mix(in srgb, var(--color-blue) 64%, transparent);
	font-size: 22px;
	font-weight: 900;
	line-height: 1;
	transition: transform 0.2s ease, color 0.2s ease;
}

.rep-service-related-card:hover .rep-service-related-card__arrow,
.rep-service-related-card:focus-visible .rep-service-related-card__arrow {
	color: var(--color-blue);
	transform: translateX(3px);
}

@media (max-width: 1180px) {
	.rep-service-price__grid,
	.rep-service-related__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.rep-service-process__steps {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.rep-service-process__steps::before {
		display: none;
	}
}

@media (max-width: 1023px) {
	.rep-service-hero {
		padding: 136px 0 64px;
	}

	.rep-service-hero__title {
		font-size: 52px;
	}

	.rep-service-hero__subtitle {
		font-size: 19px;
	}

	.rep-service-section-head__title,
	.rep-service-case__title {
		font-size: 40px;
	}

	.rep-service-pain-item,
	.rep-service-impact-item,
	.rep-service-scope__grid,
	.rep-service-process__steps {
		grid-template-columns: 1fr;
	}

	.rep-service-impact-item__bar-wrap {
		max-width: 260px;
	}

	.rep-service-pain-item__arrow {
		padding: 8px 0;
		transform: rotate(90deg);
	}

	.rep-service-pain-item__solution {
		border-left: 0;
		border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	}

	.rep-service-scope-item,
	.rep-service-scope-item:nth-child(2n),
	.rep-service-scope-item:nth-last-child(-n+2) {
		border-right: 0;
		border-bottom: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	}

	.rep-service-scope-item:last-child {
		border-bottom: 0;
	}

	.rep-service-process-step {
		justify-items: stretch;
		text-align: left;
	}

	.rep-service-process-step__head {
		grid-template-columns: 48px minmax(0, 1fr) auto;
		align-items: center;
		justify-items: start;
		text-align: left;
	}

	.rep-service-case__metrics {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	.rep-service-hero {
		padding: 122px 0 52px;
	}

	.rep-service-hero__title {
		font-size: 34px;
	}

	.rep-service-hero__subtitle,
	.rep-service-section-head__subtitle {
		font-size: 16px;
	}

	.rep-service-section-head__title,
	.rep-service-case__title {
		font-size: 30px;
	}

	.rep-service-hero__actions,
	.rep-service-btn {
		width: 100%;
	}

	.rep-service-pain,
	.rep-service-impact,
	.rep-service-scope,
	.rep-service-process,
	.rep-service-case,
	.rep-service-price,
	.rep-service-faq,
	.rep-service-related {
		padding: 58px 0;
	}

	.rep-service-pain-item__problem,
	.rep-service-pain-item__solution,
	.rep-service-impact-item {
		padding: 22px;
	}

	.rep-service-scope-item__head {
		grid-template-columns: 34px minmax(0, 1fr) 26px;
		padding: 20px;
	}

	.rep-service-scope-item__body p {
		padding: 0 20px 20px;
	}

	.rep-service-process-step__head {
		grid-template-columns: 44px minmax(0, 1fr);
	}

	.rep-service-process-step__time {
		grid-column: 2;
	}

	.rep-service-case__card {
		padding: 28px 22px;
		border-radius: 0 22px 22px 0;
	}

	.rep-service-case__metrics,
	.rep-service-price__grid,
	.rep-service-related__grid {
		grid-template-columns: 1fr;
	}

	.rep-service-case__metric-value {
		font-size: 30px;
	}

	.rep-service-price-card {
		padding: 26px 22px;
	}

	.rep-service-price-card__desc {
		min-height: 0;
	}

	.rep-service-faq__question {
		padding: 18px 20px;
		font-size: 15px;
	}

	.rep-service-faq__answer p {
		padding: 0 20px 20px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.rep-service-btn,
	.rep-service-breadcrumb__link,
	.rep-service-scope-item__head,
	.rep-service-scope-item__body,
	.rep-service-process-step__body,
	.rep-service-faq__question,
	.rep-service-faq__answer,
	.rep-service-related-card,
	.rep-service-related-card__arrow {
		transition: none;
	}

	.rep-service-btn:hover,
	.rep-service-btn:focus-visible,
	.rep-service-related-card:hover,
	.rep-service-related-card:focus-visible,
	.rep-service-related-card:hover .rep-service-related-card__arrow,
	.rep-service-related-card:focus-visible .rep-service-related-card__arrow {
		transform: none;
	}
}

/* ============================================================
   Cosmetology Industry Page
   ============================================================ */

.cosm-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 86px;
	background:
		radial-gradient(circle at 84% 18%, color-mix(in srgb, var(--color-green) 12%, transparent), transparent 30%),
		radial-gradient(circle at 12% 94%, color-mix(in srgb, var(--color-green) 15%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%) 0%, var(--color-surface) 100%);
}

.cosm-hero__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 372px;
	gap: 54px;
	align-items: center;
}

.cosm-hero__content {
	display: grid;
	gap: 18px;
	max-width: 940px;
}

.cosm-breadcrumb {
	margin-bottom: 4px;
}

.cosm-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 700;
}

.cosm-breadcrumb__item + .cosm-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--color-blue) 28%);
}

.cosm-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.cosm-breadcrumb__link:hover,
.cosm-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.cosm-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-bg) 58%, var(--color-muted) 42%);
}

.cosm-eyebrow {
	width: fit-content;
	margin: 0;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(52, 94, 214, 0.1);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.cosm-hero__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 66px;
	font-weight: 800;
	line-height: 1.04;
	letter-spacing: 0;
}

.cosm-hero__subtitle {
	max-width: 780px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 21px;
	font-weight: 500;
	line-height: 1.58;
}

.cosm-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 10px;
}

.cosm-btn {
	min-height: 50px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 24px;
	border: 1px solid transparent;
	border-radius: 10px;
	font-size: 15px;
	font-weight: 850;
	line-height: 1.1;
	text-align: center;
	transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.cosm-btn:hover,
.cosm-btn:focus-visible {
	transform: translateY(-1px);
}

.cosm-btn:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

.cosm-btn--primary {
	background: linear-gradient(100deg, color-mix(in srgb, var(--color-blue) 74%, var(--color-green) 26%) 0%, var(--color-blue) 100%);
	color: var(--color-surface);
	box-shadow: 0 16px 34px rgba(52, 94, 214, 0.22);
}

.cosm-btn--secondary {
	border-color: rgba(52, 94, 214, 0.18);
	background: color-mix(in srgb, var(--color-surface) 78%, transparent);
	color: var(--color-bg);
	box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-surface) 92%, transparent);
}

.cosm-btn--secondary:hover,
.cosm-btn--secondary:focus-visible {
	border-color: rgba(52, 94, 214, 0.4);
	color: var(--color-blue);
}

.cosm-hero__trust {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 22px;
	margin: 6px 0 0;
	padding: 0;
	list-style: none;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.cosm-hero__trust li {
	position: relative;
	padding-left: 22px;
}

.cosm-hero__trust li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.35em;
	width: 13px;
	height: 13px;
	border-radius: 50%;
	background:
		linear-gradient(135deg, transparent 0 42%, var(--color-surface) 42% 56%, transparent 56%),
		color-mix(in srgb, var(--color-green) 74%, var(--color-blue) 26%);
}

.cosm-hero__visual {
	position: relative;
	min-height: 460px;
}

.cosm-hero-phone {
	position: relative;
	min-height: 460px;
	padding: 24px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 34px;
	background:
		linear-gradient(160deg, rgba(255, 255, 255, 0.88), rgba(255, 255, 255, 0.54)),
		color-mix(in srgb, var(--color-surface) 88%, var(--color-blue) 12%);
	box-shadow:
		0 30px 70px rgba(33, 55, 100, 0.13),
		inset 0 1px 0 rgba(255, 255, 255, 0.86);
}

.cosm-hero-phone::before {
	content: "";
	position: absolute;
	inset: 18px;
	border-radius: 28px;
	background:
		radial-gradient(circle at 70% 8%, color-mix(in srgb, var(--color-green) 14%, transparent), transparent 38%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-bg) 92%, var(--color-blue) 8%), var(--color-bg));
}

.cosm-hero-phone__bar {
	position: absolute;
	z-index: 1;
	left: 50%;
	top: 36px;
	width: 78px;
	height: 6px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.28);
	transform: translateX(-50%);
}

.cosm-hero-phone__card {
	position: absolute;
	z-index: 2;
	left: 46px;
	right: 46px;
	display: grid;
	gap: 8px;
	padding: 20px;
	border: 1px solid rgba(255, 255, 255, 0.28);
	border-radius: 22px;
	background: rgba(255, 255, 255, 0.12);
	backdrop-filter: blur(18px);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

.cosm-hero-phone__card--1 {
	top: 84px;
}

.cosm-hero-phone__card--2 {
	top: 202px;
	left: 76px;
}

.cosm-hero-phone__card--3 {
	top: 322px;
	right: 76px;
}

.cosm-hero-phone__card span {
	color: var(--color-surface);
	font-size: 22px;
	font-weight: 900;
	line-height: 1.1;
}

.cosm-hero-phone__card small {
	color: rgba(255, 255, 255, 0.68);
	font-size: 13px;
	font-weight: 700;
	line-height: 1.35;
}

.cosm-section-head {
	max-width: 820px;
	display: grid;
	gap: 12px;
	margin-bottom: 32px;
}

.cosm-section-head--center {
	margin-right: auto;
	margin-left: auto;
	text-align: center;
	justify-items: center;
}

.cosm-section-head__title,
.cosm-case__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 52px;
	font-weight: 850;
	line-height: 1.06;
	letter-spacing: 0;
}

.cosm-section-head__subtitle {
	max-width: 690px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 17px;
	font-weight: 500;
	line-height: 1.5;
}

.cosm-pains,
.cosm-tools,
.cosm-process,
.cosm-related {
	padding: 82px 0;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.cosm-types,
.cosm-case,
.cosm-faq {
	padding: 84px 0;
	background: var(--color-surface);
}

.cosm-pains__grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 14px;
}

.cosm-pain-card,
.cosm-tool-card {
	display: grid;
	align-content: start;
	gap: 12px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 20px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 98%, transparent), color-mix(in srgb, var(--color-surface) 86%, var(--color-blue) 14%)),
		var(--color-surface);
	box-shadow: 0 10px 24px rgba(33, 55, 100, 0.06);
}

.cosm-pain-card {
	padding: 22px;
}

.cosm-icon {
	position: relative;
	width: 44px;
	height: 44px;
	border: 1px solid rgba(52, 94, 214, 0.18);
	border-radius: 14px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 92%, transparent), color-mix(in srgb, var(--color-surface) 74%, var(--color-blue) 26%)),
		rgba(52, 94, 214, 0.1);
	box-shadow:
		0 12px 24px rgba(52, 94, 214, 0.08),
		inset 0 1px 0 rgba(255, 255, 255, 0.86);
}

.cosm-icon::before {
	content: "";
	position: absolute;
	inset: 10px;
	background: var(--color-blue);
}

.cosm-icon--price::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 7h8a4 4 0 0 1 0 8H6'/%3E%3Cpath d='M6 3v18'/%3E%3Cpath d='M6 15h12'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 7h8a4 4 0 0 1 0 8H6'/%3E%3Cpath d='M6 3v18'/%3E%3Cpath d='M6 15h12'/%3E%3C/svg%3E") center / contain no-repeat;
}

.cosm-icon--season::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 17c4-7 12-7 16 0'/%3E%3Cpath d='M4 20h16'/%3E%3Ccircle cx='12' cy='9' r='3'/%3E%3Cpath d='M12 2v2'/%3E%3Cpath d='m5 5 1.4 1.4'/%3E%3Cpath d='m19 5-1.4 1.4'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 17c4-7 12-7 16 0'/%3E%3Cpath d='M4 20h16'/%3E%3Ccircle cx='12' cy='9' r='3'/%3E%3Cpath d='M12 2v2'/%3E%3Cpath d='m5 5 1.4 1.4'/%3E%3Cpath d='m19 5-1.4 1.4'/%3E%3C/svg%3E") center / contain no-repeat;
}

.cosm-icon--moderation::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3 4 6v6c0 5 3.4 8 8 9 4.6-1 8-4 8-9V6Z'/%3E%3Cpath d='m9 12 2 2 4-5'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3 4 6v6c0 5 3.4 8 8 9 4.6-1 8-4 8-9V6Z'/%3E%3Cpath d='m9 12 2 2 4-5'/%3E%3C/svg%3E") center / contain no-repeat;
}

.cosm-icon--social::before,
.cosm-icon--smm::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='4' width='16' height='16' rx='4'/%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3Ccircle cx='17' cy='7' r='1'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='4' width='16' height='16' rx='4'/%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3Ccircle cx='17' cy='7' r='1'/%3E%3C/svg%3E") center / contain no-repeat;
}

.cosm-icon--launch::before,
.cosm-icon--ads::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 13v-3a2 2 0 0 1 2-2h3l7-3v14l-7-3H6a2 2 0 0 1-2-2Z'/%3E%3Cpath d='M8 16l1 4'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 13v-3a2 2 0 0 1 2-2h3l7-3v14l-7-3H6a2 2 0 0 1-2-2Z'/%3E%3Cpath d='M8 16l1 4'/%3E%3C/svg%3E") center / contain no-repeat;
}

.cosm-icon--search::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.8-3.8'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.8-3.8'/%3E%3C/svg%3E") center / contain no-repeat;
}

.cosm-icon--map::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21s7-5.1 7-11a7 7 0 1 0-14 0c0 5.9 7 11 7 11Z'/%3E%3Ccircle cx='12' cy='10' r='2.3'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21s7-5.1 7-11a7 7 0 1 0-14 0c0 5.9 7 11 7 11Z'/%3E%3Ccircle cx='12' cy='10' r='2.3'/%3E%3C/svg%3E") center / contain no-repeat;
}

.cosm-icon--star::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='m12 2 3.1 6.3 6.9 1-5 4.9 1.2 6.8L12 17.8 5.8 21 7 14.2 2 9.3l6.9-1Z'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='m12 2 3.1 6.3 6.9 1-5 4.9 1.2 6.8L12 17.8 5.8 21 7 14.2 2 9.3l6.9-1Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

.cosm-icon--crm::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cellipse cx='12' cy='6' rx='7' ry='3'/%3E%3Cpath d='M5 6v6c0 1.7 3.1 3 7 3s7-1.3 7-3V6'/%3E%3Cpath d='M5 12v6c0 1.7 3.1 3 7 3s7-1.3 7-3v-6'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cellipse cx='12' cy='6' rx='7' ry='3'/%3E%3Cpath d='M5 6v6c0 1.7 3.1 3 7 3s7-1.3 7-3V6'/%3E%3Cpath d='M5 12v6c0 1.7 3.1 3 7 3s7-1.3 7-3v-6'/%3E%3C/svg%3E") center / contain no-repeat;
}

.cosm-pain-card__title,
.cosm-tool-card__name {
	margin: 0;
	color: var(--color-bg);
	font-size: 17px;
	font-weight: 850;
	line-height: 1.18;
}

.cosm-pain-card__text,
.cosm-tool-card__desc {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.cosm-types__layout {
	display: grid;
	grid-template-columns: 310px minmax(0, 1fr);
	gap: 24px;
	align-items: start;
}

.cosm-types__tabs {
	display: grid;
	gap: 10px;
}

.cosm-types__tab {
	display: grid;
	gap: 6px;
	width: 100%;
	padding: 18px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 18px;
	background: color-mix(in srgb, var(--color-surface) 88%, var(--color-blue) 12%);
	color: var(--color-bg);
	font: inherit;
	text-align: left;
	cursor: pointer;
	transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.cosm-types__tab:hover,
.cosm-types__tab:focus-visible,
.cosm-types__tab.is-active {
	border-color: rgba(52, 94, 214, 0.36);
	background: var(--color-surface);
	box-shadow: 0 14px 30px rgba(33, 55, 100, 0.1);
	transform: translateY(-1px);
}

.cosm-types__tab:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 36%, var(--color-surface) 64%);
	outline-offset: 3px;
}

.cosm-types__tab span {
	font-size: 18px;
	font-weight: 900;
	line-height: 1.1;
}

.cosm-types__tab small {
	color: color-mix(in srgb, var(--color-bg) 55%, transparent);
	font-size: 13px;
	font-weight: 700;
	line-height: 1.3;
}

.cosm-types__panel {
	padding: 32px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 28px;
	background:
		radial-gradient(circle at 94% 0%, color-mix(in srgb, var(--color-green) 10%, transparent), transparent 34%),
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 98%, transparent), color-mix(in srgb, var(--color-surface) 89%, var(--color-blue) 11%));
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.09);
}

.cosm-types__panel-head {
	display: grid;
	gap: 12px;
	max-width: 780px;
}

.cosm-types__panel-head h3 {
	margin: 0;
	color: var(--color-bg);
	font-size: 34px;
	font-weight: 850;
	line-height: 1.1;
}

.cosm-types__panel-head p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.58;
}

.cosm-types__query-list {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 24px 0;
}

.cosm-types__query-list span {
	display: inline-flex;
	align-items: center;
	min-height: 34px;
	padding: 8px 12px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 999px;
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.1;
}

.cosm-types__details {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
}

.cosm-types__detail {
	padding: 18px;
	border: 1px solid rgba(52, 94, 214, 0.12);
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.76);
}

.cosm-types__detail span {
	display: block;
	margin-bottom: 8px;
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.cosm-types__detail p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.55;
}

.cosm-tools__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.cosm-tool-card {
	grid-template-rows: auto auto 1fr auto;
	min-height: 250px;
	padding: 24px;
	transition: transform 0.32s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.25s ease, box-shadow 0.25s ease;
}

.cosm-tool-card.is-observed {
	opacity: 0;
	transform: translateY(18px);
}

.cosm-tool-card.is-visible {
	opacity: 1;
	transform: translateY(0);
	transition: opacity 0.42s ease, transform 0.42s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.25s ease, box-shadow 0.25s ease;
}

.cosm-tool-card:hover,
.cosm-tool-card:focus-within {
	transform: translateY(-2px);
	border-color: rgba(52, 94, 214, 0.38);
	box-shadow: 0 14px 30px rgba(33, 55, 100, 0.1);
}

.cosm-tool-card__link {
	width: fit-content;
	color: var(--color-blue);
	font-size: 14px;
	font-weight: 850;
	line-height: 1.1;
}

.cosm-tools__footer {
	display: flex;
	justify-content: center;
	margin-top: 30px;
}

.cosm-case__card {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 340px;
	gap: 32px;
	align-items: stretch;
	padding: 44px;
	border-radius: 30px;
	background:
		radial-gradient(circle at 92% 0%, rgba(124, 200, 255, 0.18), transparent 32%),
		radial-gradient(circle at 8% 100%, rgba(92, 214, 170, 0.12), transparent 34%),
		linear-gradient(135deg, var(--color-bg) 0%, color-mix(in srgb, var(--color-bg) 74%, var(--color-blue) 26%) 100%);
	box-shadow: 0 22px 56px rgba(7, 19, 39, 0.18);
}

.cosm-case__content {
	display: grid;
	align-content: start;
	gap: 18px;
}

.cosm-case__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
}

.cosm-case__tag {
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: rgba(124, 200, 255, 0.16);
	color: color-mix(in srgb, var(--color-blue) 45%, var(--color-surface) 55%);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.cosm-case__niche {
	color: rgba(255, 255, 255, 0.66);
	font-size: 14px;
	font-weight: 750;
}

.cosm-case__title {
	max-width: 760px;
	color: var(--color-surface);
}

.cosm-case__desc {
	max-width: 760px;
	margin: 0;
	color: rgba(255, 255, 255, 0.72);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.62;
}

.cosm-case .cosm-btn--secondary {
	width: fit-content;
	margin-top: 8px;
	border-color: rgba(255, 255, 255, 0.24);
	background: rgba(255, 255, 255, 0.1);
	color: var(--color-surface);
}

.cosm-case__metrics {
	display: grid;
	gap: 14px;
}

.cosm-case__metric {
	display: grid;
	align-content: center;
	gap: 8px;
	min-height: 128px;
	padding: 22px;
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 22px;
	background: rgba(255, 255, 255, 0.09);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

.cosm-case__metric-value {
	color: color-mix(in srgb, var(--color-blue) 45%, var(--color-surface) 55%);
	font-size: 42px;
	font-weight: 950;
	line-height: 1;
}

.cosm-case__metric-label {
	color: rgba(255, 255, 255, 0.68);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.32;
}

.cosm-process__steps {
	position: relative;
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
}

.cosm-process__steps::before {
	content: "";
	position: absolute;
	left: 8%;
	right: 8%;
	top: 24px;
	height: 1px;
	background: rgba(52, 94, 214, 0.16);
}

.cosm-process-step {
	position: relative;
	display: grid;
	gap: 14px;
	justify-items: center;
	text-align: center;
}

.cosm-process-step__head {
	position: relative;
	z-index: 1;
	display: grid;
	justify-items: center;
	gap: 8px;
	width: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--color-bg);
	font: inherit;
	cursor: pointer;
}

.cosm-process-step__circle {
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(52, 94, 214, 0.18);
	border-radius: 50%;
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 16px;
	font-weight: 900;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.cosm-process-step.is-active .cosm-process-step__circle {
	border-color: var(--color-blue);
	background: var(--color-blue);
	color: var(--color-surface);
}

.cosm-process-step__label {
	color: var(--color-bg);
	font-size: 16px;
	font-weight: 900;
	line-height: 1.15;
}

.cosm-process-step__time {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 12px;
	font-weight: 850;
	line-height: 1;
}

.cosm-process-step__body {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	padding: 0 18px;
	border: 1px solid rgba(52, 94, 214, 0);
	border-radius: 18px;
	background: var(--color-surface);
	transition: max-height 0.28s ease, opacity 0.28s ease, padding 0.28s ease, border-color 0.28s ease;
}

.cosm-process-step.is-active .cosm-process-step__body {
	max-height: 250px;
	opacity: 1;
	padding: 18px;
	border-color: rgba(52, 94, 214, 0.14);
}

.cosm-process-step__body p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.58;
}

.cosm-faq__inner {
	max-width: 940px;
}

.cosm-faq__list {
	overflow: hidden;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 24px;
	background: var(--color-surface);
	box-shadow: 0 18px 46px rgba(33, 55, 100, 0.1);
}

.cosm-faq__item + .cosm-faq__item {
	border-top: 1px solid rgba(52, 94, 214, 0.12);
}

.cosm-faq__question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 22px 26px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	font-size: 16px;
	font-weight: 850;
	line-height: 1.35;
	text-align: left;
	cursor: pointer;
	transition: color 0.2s ease, background 0.2s ease;
}

.cosm-faq__question:hover,
.cosm-faq__item.is-open .cosm-faq__question {
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
	color: var(--color-blue);
}

.cosm-faq__icon {
	position: relative;
	width: 22px;
	height: 22px;
	flex: 0 0 auto;
	border-radius: 50%;
	background: rgba(52, 94, 214, 0.1);
}

.cosm-faq__icon::before,
.cosm-faq__icon::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 10px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.cosm-faq__icon::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.cosm-faq__item.is-open .cosm-faq__icon::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(0deg);
}

.cosm-faq__answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.cosm-faq__item.is-open .cosm-faq__answer {
	max-height: 360px;
}

.cosm-faq__answer p {
	margin: 0;
	padding: 0 26px 24px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.65;
}

.cosm-related__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.cosm-related-card {
	position: relative;
	min-height: 210px;
	display: grid;
	grid-template-rows: auto 1fr auto;
	gap: 12px;
	padding: 24px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 20px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px rgba(33, 55, 100, 0.06);
	transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.cosm-related-card:hover,
.cosm-related-card:focus-visible {
	transform: translateY(-2px);
	border-color: rgba(52, 94, 214, 0.36);
	box-shadow: 0 14px 30px rgba(33, 55, 100, 0.1);
}

.cosm-related-card__name {
	color: var(--color-bg);
	font-size: 19px;
	font-weight: 900;
	line-height: 1.15;
}

.cosm-related-card__desc {
	color: color-mix(in srgb, var(--color-bg) 64%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.cosm-related-card__arrow {
	color: var(--color-blue);
	font-size: 22px;
	font-weight: 900;
	line-height: 1;
	transition: transform 0.2s ease;
}

.cosm-related-card:hover .cosm-related-card__arrow,
.cosm-related-card:focus-visible .cosm-related-card__arrow {
	transform: translateX(4px);
}

.cosm-related__services {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 24px;
}

.cosm-related__services a {
	display: inline-flex;
	align-items: center;
	min-height: 38px;
	padding: 10px 14px;
	border: 1px solid rgba(52, 94, 214, 0.14);
	border-radius: 999px;
	background: var(--color-surface);
	color: var(--color-blue);
	font-size: 14px;
	font-weight: 850;
	line-height: 1.1;
}

@media (max-width: 1180px) {
	.cosm-hero__inner {
		grid-template-columns: minmax(0, 1fr) 320px;
		gap: 34px;
	}

	.cosm-pains__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 1023px) {
	.cosm-hero {
		padding: 136px 0 64px;
	}

	.cosm-hero__inner,
	.cosm-types__layout,
	.cosm-case__card {
		grid-template-columns: 1fr;
	}

	.cosm-hero__visual {
		min-height: 340px;
	}

	.cosm-hero-phone {
		min-height: 340px;
	}

	.cosm-hero-phone__card--1 {
		top: 72px;
	}

	.cosm-hero-phone__card--2 {
		top: 156px;
	}

	.cosm-hero-phone__card--3 {
		top: 240px;
	}

	.cosm-hero__title {
		font-size: 50px;
	}

	.cosm-hero__subtitle {
		font-size: 19px;
	}

	.cosm-section-head__title,
	.cosm-case__title {
		font-size: 42px;
	}

	.cosm-types__tabs {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.cosm-types__details,
	.cosm-tools__grid,
	.cosm-related__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.cosm-process__steps {
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.cosm-process__steps::before {
		display: none;
	}

	.cosm-process-step {
		justify-items: stretch;
		text-align: left;
	}

	.cosm-process-step__head {
		grid-template-columns: 48px minmax(0, 1fr) auto;
		align-items: center;
		justify-items: start;
		text-align: left;
	}
}

@media (max-width: 767px) {
	.cosm-hero {
		padding: 122px 0 52px;
	}

	.cosm-hero__title {
		font-size: 34px;
	}

	.cosm-hero__subtitle {
		font-size: 17px;
	}

	.cosm-section-head__title,
	.cosm-case__title {
		font-size: 30px;
	}

	.cosm-section-head__subtitle {
		font-size: 16px;
	}

	.cosm-hero__actions,
	.cosm-btn {
		width: 100%;
	}

	.cosm-hero__visual {
		min-height: 300px;
	}

	.cosm-hero-phone {
		min-height: 300px;
		border-radius: 26px;
	}

	.cosm-hero-phone__card {
		left: 34px;
		right: 34px;
		padding: 16px;
	}

	.cosm-hero-phone__card--2 {
		left: 48px;
	}

	.cosm-hero-phone__card--3 {
		right: 48px;
	}

	.cosm-pains,
	.cosm-tools,
	.cosm-process,
	.cosm-related,
	.cosm-types,
	.cosm-case,
	.cosm-faq {
		padding: 58px 0;
	}

	.cosm-pains__grid,
	.cosm-types__tabs,
	.cosm-types__details,
	.cosm-tools__grid,
	.cosm-related__grid {
		grid-template-columns: 1fr;
	}

	.cosm-types__panel,
	.cosm-case__card {
		padding: 24px;
		border-radius: 22px;
	}

	.cosm-types__panel-head h3 {
		font-size: 26px;
	}

	.cosm-case__metric-value {
		font-size: 32px;
	}

	.cosm-process-step__head {
		grid-template-columns: 44px minmax(0, 1fr);
	}

	.cosm-process-step__time {
		grid-column: 2;
	}

	.cosm-faq__question {
		padding: 18px 20px;
		font-size: 15px;
	}

	.cosm-faq__answer p {
		padding: 0 20px 20px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.cosm-btn,
	.cosm-breadcrumb__link,
	.cosm-types__tab,
	.cosm-tool-card,
	.cosm-process-step__body,
	.cosm-faq__question,
	.cosm-faq__answer,
	.cosm-related-card,
	.cosm-related-card__arrow {
		transition: none;
	}

	.cosm-btn:hover,
	.cosm-btn:focus-visible,
	.cosm-types__tab:hover,
	.cosm-types__tab:focus-visible,
	.cosm-tool-card:hover,
	.cosm-related-card:hover,
	.cosm-related-card:focus-visible,
	.cosm-related-card:hover .cosm-related-card__arrow,
	.cosm-related-card:focus-visible .cosm-related-card__arrow {
		transform: none;
	}
}

/* ============================================================
   About Page
   ============================================================ */

.about-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 76px;
	background:
		radial-gradient(circle at 82% 18%, color-mix(in srgb, var(--color-blue) 16%, transparent), transparent 32%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%) 0%, var(--color-surface) 100%);
}

.about-hero__inner {
	max-width: 980px;
	display: grid;
	gap: 18px;
}

.about-breadcrumb {
	margin-bottom: 4px;
}

.about-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 700;
}

.about-breadcrumb__item + .about-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--color-blue) 28%);
}

.about-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.about-breadcrumb__link:hover,
.about-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.about-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-bg) 58%, var(--color-muted) 42%);
}

.about-eyebrow {
	width: fit-content;
	margin: 0;
	padding: 8px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.about-hero__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 66px;
	font-weight: 850;
	line-height: 1.04;
	letter-spacing: 0;
}

.about-hero__subtitle {
	max-width: 760px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 21px;
	font-weight: 500;
	line-height: 1.58;
}

.about-story,
.about-team,
.about-related {
	padding: 84px 0;
	background: var(--color-surface);
}

.about-why,
.about-values {
	padding: 84px 0;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.about-section-head {
	max-width: 760px;
	display: grid;
	gap: 12px;
	margin-bottom: 36px;
}

.about-section-title {
	margin: 0;
	color: var(--color-bg);
	font-size: 52px;
	font-weight: 850;
	line-height: 1.06;
	letter-spacing: 0;
}

.about-section-subtitle {
	max-width: 660px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 17px;
	font-weight: 500;
	line-height: 1.5;
}

.about-story__layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 340px;
	gap: 72px;
	align-items: start;
}

.about-story__text {
	display: grid;
	gap: 14px;
	max-width: 780px;
}

.about-story__text p:not(.about-eyebrow) {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.72;
}

.about-story__facts {
	overflow: hidden;
	display: grid;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 24px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 98%, transparent), color-mix(in srgb, var(--color-surface) 88%, var(--color-blue) 12%)),
		var(--color-surface);
	box-shadow: 0 18px 46px color-mix(in srgb, var(--color-bg) 8%, transparent);
}

.about-story-fact {
	display: grid;
	gap: 8px;
	padding: 24px;
	border-bottom: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.about-story-fact:last-child {
	border-bottom: 0;
}

.about-story-fact__value {
	color: var(--color-bg);
	font-size: 28px;
	font-weight: 900;
	line-height: 1.08;
}

.about-story-fact__label {
	color: color-mix(in srgb, var(--color-bg) 54%, transparent);
	font-size: 12px;
	font-weight: 850;
	line-height: 1.28;
	letter-spacing: 0;
	text-transform: uppercase;
}

.about-why__layout {
	display: grid;
	grid-template-columns: minmax(280px, 390px) minmax(0, 1fr);
	gap: 72px;
	align-items: start;
}

.about-why__lead {
	position: sticky;
	top: 130px;
	display: grid;
	gap: 16px;
}

.about-why__text {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.62;
}

.about-why__features {
	display: grid;
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
}

.about-why-feature {
	display: grid;
	grid-template-columns: 54px minmax(0, 1fr);
	gap: 18px;
	padding: 26px 0;
	border-bottom: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
}

.about-why-feature__num {
	color: color-mix(in srgb, var(--color-blue) 62%, transparent);
	font-size: 13px;
	font-weight: 900;
	line-height: 1.3;
}

.about-why-feature__title {
	margin: 0 0 8px;
	color: var(--color-bg);
	font-size: 18px;
	font-weight: 850;
	line-height: 1.18;
}

.about-why-feature__text {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.58;
}

.about-team__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
}

.about-team-card {
	overflow: hidden;
	display: grid;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 98%, transparent), color-mix(in srgb, var(--color-surface) 89%, var(--color-blue) 11%)),
		var(--color-surface);
	box-shadow: 0 10px 24px color-mix(in srgb, var(--color-bg) 6%, transparent);
}

.about-team-card__avatar {
	min-height: 178px;
	display: flex;
	align-items: center;
	justify-content: center;
	background:
		radial-gradient(circle at 72% 18%, color-mix(in srgb, var(--color-green) 12%, transparent), transparent 34%),
		linear-gradient(135deg, var(--color-bg), color-mix(in srgb, var(--color-bg) 76%, var(--color-blue) 24%));
	color: var(--color-surface);
	font-size: 42px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
}

.about-team-card__info {
	display: grid;
	gap: 8px;
	padding: 22px;
}

.about-team-card__name {
	margin: 0;
	color: var(--color-bg);
	font-size: 17px;
	font-weight: 900;
	line-height: 1.18;
}

.about-team-card__role {
	margin: 0;
	color: var(--color-blue);
	font-size: 13px;
	font-weight: 850;
	line-height: 1.25;
}

.about-team-card__spec {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 500;
	line-height: 1.5;
}

.about-values__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 16px;
}

.about-value-card {
	display: grid;
	align-content: start;
	gap: 12px;
	padding: 28px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px color-mix(in srgb, var(--color-bg) 6%, transparent);
}

.about-value-card__icon {
	position: relative;
	width: 48px;
	height: 48px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 18%, transparent);
	border-radius: 16px;
	background: color-mix(in srgb, var(--color-blue) 8%, var(--color-surface) 92%);
}

.about-value-card__icon::before {
	content: "";
	position: absolute;
	inset: 11px;
	background: var(--color-blue);
	mask-position: center;
	mask-repeat: no-repeat;
	mask-size: contain;
	-webkit-mask-position: center;
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-size: contain;
}

.about-value-card__icon--focus::before {
	mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 2a10 10 0 1 0 0 20 10 10 0 0 0 0-20Zm0 4a6 6 0 1 1 0 12 6 6 0 0 1 0-12Zm0 3a3 3 0 1 0 0 6 3 3 0 0 0 0-6Z'/%3E%3C/svg%3E");
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 2a10 10 0 1 0 0 20 10 10 0 0 0 0-20Zm0 4a6 6 0 1 1 0 12 6 6 0 0 1 0-12Zm0 3a3 3 0 1 0 0 6 3 3 0 0 0 0-6Z'/%3E%3C/svg%3E");
}

.about-value-card__icon--numbers::before {
	mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 19 8.5 9l4 6 3.5-9 4 13h-2.2l-2-6.5-3 7.5-4-6-2.6 5H4Z'/%3E%3C/svg%3E");
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 19 8.5 9l4 6 3.5-9 4 13h-2.2l-2-6.5-3 7.5-4-6-2.6 5H4Z'/%3E%3C/svg%3E");
}

.about-value-card__icon--honest::before {
	mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 3 4 6v6c0 5.3 3.4 8.2 8 9 4.6-.8 8-3.7 8-9V6l-8-3Zm4.7 6.7-5.5 5.5-2.9-2.9 1.4-1.4 1.5 1.5 4.1-4.1 1.4 1.4Z'/%3E%3C/svg%3E");
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 3 4 6v6c0 5.3 3.4 8.2 8 9 4.6-.8 8-3.7 8-9V6l-8-3Zm4.7 6.7-5.5 5.5-2.9-2.9 1.4-1.4 1.5 1.5 4.1-4.1 1.4 1.4Z'/%3E%3C/svg%3E");
}

.about-value-card__icon--plain::before {
	mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 4h16v12H7.8L4 20V4Zm3 4v2h10V8H7Zm0 4v2h7v-2H7Z'/%3E%3C/svg%3E");
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 4h16v12H7.8L4 20V4Zm3 4v2h10V8H7Zm0 4v2h7v-2H7Z'/%3E%3C/svg%3E");
}

.about-value-card__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 18px;
	font-weight: 850;
	line-height: 1.26;
}

.about-value-card__text {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.6;
}

.about-related {
	padding-top: 64px;
}

.about-related__label {
	margin: 0 0 16px;
	color: color-mix(in srgb, var(--color-bg) 54%, transparent);
	font-size: 13px;
	font-weight: 850;
	text-transform: uppercase;
	letter-spacing: 0;
}

.about-related__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.about-related-card {
	display: grid;
	grid-template-columns: 50px minmax(0, 1fr) 24px;
	gap: 14px;
	align-items: center;
	min-height: 118px;
	padding: 20px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background: var(--color-surface);
	color: var(--color-bg);
	box-shadow: 0 12px 30px color-mix(in srgb, var(--color-bg) 8%, transparent);
	transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.about-related-card:hover,
.about-related-card:focus-visible {
	border-color: color-mix(in srgb, var(--color-blue) 36%, transparent);
	box-shadow: 0 18px 42px color-mix(in srgb, var(--color-bg) 12%, transparent);
	transform: translateY(-2px);
}

.about-related-card:focus-visible,
.about-breadcrumb__link:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

.about-related-card__icon {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 46px;
	height: 46px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 18%, transparent);
	border-radius: 16px;
	background: color-mix(in srgb, var(--color-blue) 8%, var(--color-surface) 92%);
}

.about-related-card__icon::before {
	content: "";
	display: block;
	width: 22px;
	height: 22px;
	background: var(--color-blue);
	mask-repeat: no-repeat;
	mask-position: center;
	mask-size: contain;
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: center;
	-webkit-mask-size: contain;
}

.about-related-card--services .about-related-card__icon::before {
	mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 2 3 6.8v10.4L12 22l9-4.8V6.8L12 2Zm0 4.2 4.8 2.6L12 11.4 7.2 8.8 12 6.2Zm-6 5.1 4.5 2.4v4.2L6 15.5v-4.2Zm7.5 6.6v-4.2l4.5-2.4v4.2l-4.5 2.4Z'/%3E%3C/svg%3E");
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 2 3 6.8v10.4L12 22l9-4.8V6.8L12 2Zm0 4.2 4.8 2.6L12 11.4 7.2 8.8 12 6.2Zm-6 5.1 4.5 2.4v4.2L6 15.5v-4.2Zm7.5 6.6v-4.2l4.5-2.4v4.2l-4.5 2.4Z'/%3E%3C/svg%3E");
}

.about-related-card--cases .about-related-card__icon::before {
	mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 3h16a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2Zm1 5h14V6H5v2Zm2 5h10v-2H7v2Zm0 4h7v-2H7v2Z'/%3E%3C/svg%3E");
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 3h16a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2Zm1 5h14V6H5v2Zm2 5h10v-2H7v2Zm0 4h7v-2H7v2Z'/%3E%3C/svg%3E");
}

.about-related-card--contacts .about-related-card__icon::before {
	mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 4h3l1.5 3.5-2 1.2c1 2 2.3 3.3 4.3 4.3l1.2-2 3.5 1.5.5 3.5c-6.6 1.1-13.1-5.4-12-12Zm14 1h-6v2h6v6h2V5h-2Z'/%3E%3C/svg%3E");
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 4h3l1.5 3.5-2 1.2c1 2 2.3 3.3 4.3 4.3l1.2-2 3.5 1.5.5 3.5c-6.6 1.1-13.1-5.4-12-12Zm14 1h-6v2h6v6h2V5h-2Z'/%3E%3C/svg%3E");
}

.about-related-card__body {
	min-width: 0;
	display: grid;
	gap: 5px;
}

.about-related-card__title {
	color: var(--color-bg);
	font-size: 17px;
	font-weight: 900;
	line-height: 1.18;
}

.about-related-card__subtitle {
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 13px;
	font-weight: 600;
	line-height: 1.45;
}

.about-related-card__arrow {
	color: color-mix(in srgb, var(--color-blue) 64%, transparent);
	font-size: 22px;
	font-weight: 900;
	line-height: 1;
	transition: transform 0.2s ease, color 0.2s ease;
}

.about-related-card:hover .about-related-card__arrow,
.about-related-card:focus-visible .about-related-card__arrow {
	color: var(--color-blue);
	transform: translateX(3px);
}

@media (max-width: 1023px) {
	.about-hero {
		padding: 136px 0 64px;
	}

	.about-hero__title {
		font-size: 52px;
	}

	.about-hero__subtitle {
		font-size: 19px;
	}

	.about-section-title {
		font-size: 42px;
	}

	.about-story__layout,
	.about-why__layout {
		grid-template-columns: 1fr;
		gap: 36px;
	}

	.about-why__lead {
		position: static;
	}

	.about-story__facts,
	.about-team__grid,
	.about-values__grid,
	.about-related__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	.about-hero {
		padding: 122px 0 52px;
	}

	.about-hero__title {
		font-size: 34px;
	}

	.about-hero__subtitle {
		font-size: 17px;
	}

	.about-section-title {
		font-size: 30px;
	}

	.about-section-subtitle {
		font-size: 16px;
	}

	.about-story,
	.about-team,
	.about-related,
	.about-why,
	.about-values {
		padding: 58px 0;
	}

	.about-story__facts,
	.about-team__grid,
	.about-values__grid,
	.about-related__grid {
		grid-template-columns: 1fr;
	}

	.about-story-fact {
		padding: 20px;
	}

	.about-story-fact__value {
		font-size: 24px;
	}

	.about-why-feature {
		grid-template-columns: 1fr;
		gap: 8px;
	}

	.about-team-card__avatar {
		min-height: 150px;
	}

	.about-value-card {
		padding: 22px;
	}

	.about-related-card {
		grid-template-columns: 46px minmax(0, 1fr) 20px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.about-breadcrumb__link,
	.about-related-card,
	.about-related-card__arrow {
		transition: none;
	}

	.about-related-card:hover,
	.about-related-card:focus-visible,
	.about-related-card:hover .about-related-card__arrow,
	.about-related-card:focus-visible .about-related-card__arrow {
		transform: none;
	}
}

/* ============================================================
   Web Development Service Page
   ============================================================ */

.web-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 84px;
	background:
		radial-gradient(circle at 84% 18%, color-mix(in srgb, var(--color-blue) 18%, transparent), transparent 32%),
		radial-gradient(circle at 10% 100%, color-mix(in srgb, var(--color-green) 12%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%) 0%, var(--color-surface) 100%);
}

.web-hero__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 420px;
	gap: 56px;
	align-items: center;
}

.web-hero__content {
	display: grid;
	gap: 18px;
	max-width: 940px;
}

.web-breadcrumb {
	margin-bottom: 4px;
}

.web-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 700;
}

.web-breadcrumb__item + .web-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--color-blue) 28%);
}

.web-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.web-breadcrumb__link:hover,
.web-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.web-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-bg) 58%, var(--color-muted) 42%);
}

.web-eyebrow {
	width: fit-content;
	margin: 0;
	padding: 8px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.web-hero__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 62px;
	font-weight: 850;
	line-height: 1.04;
	letter-spacing: 0;
}

.web-hero__subtitle {
	max-width: 780px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 21px;
	font-weight: 500;
	line-height: 1.58;
}

.web-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 10px;
}

.web-btn {
	min-height: 50px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 24px;
	border: 1px solid transparent;
	border-radius: 10px;
	font-size: 15px;
	font-weight: 850;
	line-height: 1.1;
	text-align: center;
	transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.web-btn:hover,
.web-btn:focus-visible {
	transform: translateY(-1px);
}

.web-btn:focus-visible,
.web-breadcrumb__link:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

.web-btn--primary {
	background: linear-gradient(100deg, color-mix(in srgb, var(--color-blue) 74%, var(--color-green) 26%) 0%, var(--color-blue) 100%);
	color: var(--color-surface);
	box-shadow: 0 16px 34px color-mix(in srgb, var(--color-blue) 22%, transparent);
}

.web-btn--secondary {
	border-color: color-mix(in srgb, var(--color-blue) 18%, transparent);
	background: color-mix(in srgb, var(--color-surface) 78%, transparent);
	color: var(--color-bg);
	box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-surface) 92%, transparent);
}

.web-btn--secondary:hover,
.web-btn--secondary:focus-visible {
	border-color: color-mix(in srgb, var(--color-blue) 40%, transparent);
	color: var(--color-blue);
}

.web-hero__trust {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 22px;
	margin: 6px 0 0;
	padding: 0;
	list-style: none;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.web-hero__trust li {
	position: relative;
	padding-left: 22px;
}

.web-hero__trust li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.35em;
	width: 13px;
	height: 13px;
	border-radius: 50%;
	background:
		linear-gradient(135deg, transparent 0 42%, var(--color-surface) 42% 56%, transparent 56%),
		color-mix(in srgb, var(--color-green) 74%, var(--color-blue) 26%);
}

.web-site-preview {
	position: relative;
	min-height: 430px;
	padding: 26px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 30px;
	background:
		linear-gradient(160deg, color-mix(in srgb, var(--color-surface) 88%, transparent), color-mix(in srgb, var(--color-surface) 54%, var(--color-blue) 46%)),
		var(--color-surface);
	box-shadow:
		0 30px 70px color-mix(in srgb, var(--color-bg) 14%, transparent),
		inset 0 1px 0 color-mix(in srgb, var(--color-surface) 86%, transparent);
}

.web-site-preview::before {
	content: "";
	position: absolute;
	inset: 58px 26px 26px;
	border-radius: 22px;
	background: var(--color-surface);
	box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.web-site-preview__top {
	position: absolute;
	z-index: 1;
	left: 26px;
	right: 26px;
	top: 26px;
	height: 28px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-bg) 88%, var(--color-blue) 12%);
}

.web-site-preview__hero,
.web-site-preview__grid,
.web-site-preview__form {
	position: relative;
	z-index: 1;
}

.web-site-preview__hero {
	height: 108px;
	margin: 60px 16px 18px;
	border-radius: 18px;
	background:
		linear-gradient(90deg, color-mix(in srgb, var(--color-bg) 88%, var(--color-blue) 12%), color-mix(in srgb, var(--color-blue) 58%, var(--color-bg) 42%));
}

.web-site-preview__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
	margin: 0 16px 18px;
}

.web-site-preview__grid span {
	height: 78px;
	border-radius: 16px;
	background: color-mix(in srgb, var(--color-blue) 8%, var(--color-surface) 92%);
	box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.web-site-preview__form {
	display: grid;
	gap: 10px;
	margin: 0 16px;
	padding: 16px;
	border-radius: 18px;
	background: color-mix(in srgb, var(--color-bg) 92%, var(--color-blue) 8%);
}

.web-site-preview__form span {
	height: 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-surface) 26%, transparent);
}

.web-site-preview__form strong {
	min-height: 38px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 10px;
	background: var(--color-blue);
	color: var(--color-surface);
	font-size: 13px;
	font-weight: 900;
	line-height: 1;
}

.web-section-head {
	max-width: 820px;
	display: grid;
	gap: 12px;
	margin-bottom: 32px;
}

.web-section-head--center {
	margin-right: auto;
	margin-left: auto;
	text-align: center;
	justify-items: center;
}

.web-section-head__title,
.web-case__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 52px;
	font-weight: 850;
	line-height: 1.06;
	letter-spacing: 0;
}

.web-section-head__subtitle {
	max-width: 680px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 17px;
	font-weight: 500;
	line-height: 1.5;
}

.web-pain,
.web-process,
.web-price,
.web-related {
	padding: 82px 0;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.web-scope,
.web-case,
.web-faq {
	padding: 84px 0;
	background: var(--color-surface);
}

.web-pain__list {
	display: grid;
	gap: 14px;
}

.web-pain-item {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 44px minmax(0, 1fr);
	gap: 18px;
	align-items: stretch;
	padding: 18px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px color-mix(in srgb, var(--color-bg) 6%, transparent);
}

.web-pain-item__problem,
.web-pain-item__solution {
	display: grid;
	align-content: start;
	gap: 10px;
	padding: 18px;
	border-radius: 18px;
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
}

.web-pain-item__solution {
	background: color-mix(in srgb, var(--color-surface) 90%, var(--color-green) 10%);
}

.web-pain-item__label {
	width: fit-content;
	padding: 6px 10px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.web-pain-item__label--problem {
	background: color-mix(in srgb, var(--color-bg) 9%, var(--color-surface) 91%);
	color: color-mix(in srgb, var(--color-bg) 70%, transparent);
}

.web-pain-item__label--solution {
	background: color-mix(in srgb, var(--color-green) 14%, var(--color-surface) 86%);
	color: color-mix(in srgb, var(--color-green) 42%, var(--color-bg) 58%);
}

.web-pain-item p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.58;
}

.web-pain-item__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-blue);
	font-size: 24px;
	font-weight: 900;
	line-height: 1;
}

.web-scope__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}

.web-scope-item {
	overflow: hidden;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 20px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 98%, transparent), color-mix(in srgb, var(--color-surface) 89%, var(--color-blue) 11%)),
		var(--color-surface);
}

.web-scope-item__head {
	width: 100%;
	display: grid;
	grid-template-columns: 42px minmax(0, 1fr) 26px;
	gap: 12px;
	align-items: center;
	padding: 20px;
	border: 0;
	background: transparent;
	color: var(--color-bg);
	font: inherit;
	text-align: left;
	cursor: pointer;
}

.web-scope-item__num {
	color: color-mix(in srgb, var(--color-blue) 64%, transparent);
	font-size: 13px;
	font-weight: 900;
}

.web-scope-item__name {
	color: var(--color-bg);
	font-size: 17px;
	font-weight: 850;
	line-height: 1.18;
}

.web-scope-item__toggle {
	position: relative;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
}

.web-scope-item__toggle::before,
.web-scope-item__toggle::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 10px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.web-scope-item__toggle::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.web-scope-item.is-open .web-scope-item__toggle::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(0deg);
}

.web-scope-item__body {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.web-scope-item.is-open .web-scope-item__body {
	max-height: 220px;
}

.web-scope-item__body p {
	margin: 0;
	padding: 0 20px 20px 74px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.58;
}

.web-process__steps {
	position: relative;
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 12px;
}

.web-process__steps::before {
	content: "";
	position: absolute;
	left: 7%;
	right: 7%;
	top: 24px;
	height: 1px;
	background: color-mix(in srgb, var(--color-blue) 16%, transparent);
}

.web-step {
	position: relative;
	display: grid;
	gap: 14px;
	justify-items: center;
	text-align: center;
}

.web-step__head {
	position: relative;
	z-index: 1;
	display: grid;
	justify-items: center;
	gap: 8px;
	width: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--color-bg);
	font: inherit;
	cursor: pointer;
}

.web-step__circle {
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid color-mix(in srgb, var(--color-blue) 18%, transparent);
	border-radius: 50%;
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 16px;
	font-weight: 900;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.web-step.is-active .web-step__circle {
	border-color: var(--color-blue);
	background: var(--color-blue);
	color: var(--color-surface);
}

.web-step__label {
	color: var(--color-bg);
	font-size: 15px;
	font-weight: 900;
	line-height: 1.15;
}

.web-step__time {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 12px;
	font-weight: 850;
	line-height: 1;
}

.web-step__body {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	padding: 0 14px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 0%, transparent);
	border-radius: 18px;
	background: var(--color-surface);
	transition: max-height 0.28s ease, opacity 0.28s ease, padding 0.28s ease, border-color 0.28s ease;
}

.web-step.is-active .web-step__body {
	max-height: 280px;
	opacity: 1;
	padding: 16px;
	border-color: color-mix(in srgb, var(--color-blue) 14%, transparent);
}

.web-step__body p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 13px;
	font-weight: 500;
	line-height: 1.55;
}

.web-step__body p + p {
	margin-top: 8px;
}

.web-step__result {
	color: var(--color-bg);
	font-weight: 800;
}

.web-case__card {
	max-width: 980px;
	padding: 44px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 28px;
	background:
		radial-gradient(circle at 92% 0%, color-mix(in srgb, var(--color-blue) 14%, transparent), transparent 34%),
		color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
	box-shadow: 0 18px 46px color-mix(in srgb, var(--color-bg) 10%, transparent);
}

.web-case__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
}

.web-case__tag {
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.web-case__niche {
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 14px;
	font-weight: 750;
}

.web-case__desc {
	max-width: 820px;
	margin: 16px 0 30px;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.62;
}

.web-case__metrics {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
	margin-bottom: 30px;
}

.web-case__metric {
	display: grid;
	gap: 6px;
	padding: 18px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 18px;
	background: var(--color-surface);
}

.web-case__metric-value {
	color: var(--color-blue);
	font-size: 42px;
	font-weight: 950;
	line-height: 1;
}

.web-case__metric-label {
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.32;
}

.web-price__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.web-price-card {
	position: relative;
	display: grid;
	grid-template-rows: auto auto auto 1fr auto;
	gap: 14px;
	padding: 28px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px color-mix(in srgb, var(--color-bg) 6%, transparent);
}

.web-price-card--featured {
	border-color: color-mix(in srgb, var(--color-blue) 40%, transparent);
	box-shadow: 0 18px 42px color-mix(in srgb, var(--color-blue) 16%, transparent);
}

.web-price-card__badge {
	width: fit-content;
	min-height: 26px;
	display: inline-flex;
	align-items: center;
	padding: 6px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 12%, var(--color-surface) 88%);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
}

.web-price-card__name {
	margin: 0;
	color: var(--color-bg);
	font-size: 24px;
	font-weight: 900;
	line-height: 1.15;
}

.web-price-card__desc {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.45;
}

.web-price-card__price {
	margin: 0;
	color: var(--color-blue);
	font-size: 30px;
	font-weight: 950;
	line-height: 1;
}

.web-price-card__list {
	display: grid;
	gap: 10px;
	margin: 4px 0 0;
	padding: 0;
	list-style: none;
}

.web-price-card__list li {
	position: relative;
	padding-left: 20px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.45;
}

.web-price-card__list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.45em;
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-green) 70%, var(--color-blue) 30%);
}

.web-price-card .web-btn {
	width: 100%;
	margin-top: 6px;
}

.web-price__note {
	margin: 28px 0 0;
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.5;
	text-align: center;
}

.web-price__note a {
	color: var(--color-blue);
	font-weight: 850;
}

.web-faq__inner {
	max-width: 940px;
}

.web-faq__list {
	overflow: hidden;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 24px;
	background: var(--color-surface);
	box-shadow: 0 18px 46px color-mix(in srgb, var(--color-bg) 10%, transparent);
}

.web-faq__item + .web-faq__item {
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.web-faq__question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 22px 26px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	font-size: 16px;
	font-weight: 850;
	line-height: 1.35;
	text-align: left;
	cursor: pointer;
	transition: color 0.2s ease, background 0.2s ease;
}

.web-faq__question:hover,
.web-faq__item.is-open .web-faq__question {
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
	color: var(--color-blue);
}

.web-faq__icon {
	position: relative;
	width: 22px;
	height: 22px;
	flex: 0 0 auto;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
}

.web-faq__icon::before,
.web-faq__icon::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 10px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.web-faq__icon::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.web-faq__item.is-open .web-faq__icon::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(0deg);
}

.web-faq__answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.web-faq__item.is-open .web-faq__answer {
	max-height: 340px;
}

.web-faq__answer p {
	margin: 0;
	padding: 0 26px 24px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.65;
}

.web-related__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
}

.web-related-card {
	position: relative;
	min-height: 210px;
	display: grid;
	grid-template-rows: auto 1fr auto;
	gap: 12px;
	padding: 24px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 20px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px color-mix(in srgb, var(--color-bg) 6%, transparent);
	transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.web-related-card:hover,
.web-related-card:focus-visible {
	transform: translateY(-2px);
	border-color: color-mix(in srgb, var(--color-blue) 36%, transparent);
	box-shadow: 0 14px 30px color-mix(in srgb, var(--color-bg) 10%, transparent);
}

.web-related-card__name {
	color: var(--color-bg);
	font-size: 19px;
	font-weight: 900;
	line-height: 1.15;
}

.web-related-card__desc {
	color: color-mix(in srgb, var(--color-bg) 64%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.web-related-card__arrow {
	color: var(--color-blue);
	font-size: 22px;
	font-weight: 900;
	line-height: 1;
	transition: transform 0.2s ease;
}

.web-related-card:hover .web-related-card__arrow,
.web-related-card:focus-visible .web-related-card__arrow {
	transform: translateX(4px);
}

.web-scope-item__head:focus-visible,
.web-step__head:focus-visible,
.web-faq__question:focus-visible,
.web-related-card:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

@media (max-width: 1180px) {
	.web-hero__inner {
		grid-template-columns: minmax(0, 1fr) 360px;
		gap: 34px;
	}

	.web-related__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 1023px) {
	.web-hero {
		padding: 136px 0 64px;
	}

	.web-hero__inner {
		grid-template-columns: 1fr;
	}

	.web-hero__title {
		font-size: 50px;
	}

	.web-hero__subtitle {
		font-size: 19px;
	}

	.web-section-head__title,
	.web-case__title {
		font-size: 42px;
	}

	.web-site-preview {
		min-height: 360px;
	}

	.web-site-preview__hero {
		height: 82px;
	}

	.web-pain-item,
	.web-scope__grid,
	.web-price__grid,
	.web-case__metrics {
		grid-template-columns: 1fr;
	}

	.web-pain-item__arrow {
		min-height: 24px;
		transform: rotate(90deg);
	}

	.web-process__steps {
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.web-process__steps::before {
		display: none;
	}

	.web-step {
		justify-items: stretch;
		text-align: left;
	}

	.web-step__head {
		grid-template-columns: 48px minmax(0, 1fr) auto;
		align-items: center;
		justify-items: start;
		text-align: left;
	}
}

@media (max-width: 767px) {
	.web-hero {
		padding: 122px 0 52px;
	}

	.web-hero__title {
		font-size: 34px;
	}

	.web-hero__subtitle {
		font-size: 17px;
	}

	.web-section-head__title,
	.web-case__title {
		font-size: 30px;
	}

	.web-section-head__subtitle {
		font-size: 16px;
	}

	.web-hero__actions,
	.web-btn {
		width: 100%;
	}

	.web-site-preview {
		min-height: 310px;
		padding: 18px;
		border-radius: 24px;
	}

	.web-site-preview::before {
		inset: 46px 18px 18px;
	}

	.web-site-preview__top {
		left: 18px;
		right: 18px;
		top: 18px;
	}

	.web-site-preview__hero {
		height: 64px;
		margin: 52px 10px 12px;
	}

	.web-site-preview__grid {
		gap: 8px;
		margin: 0 10px 12px;
	}

	.web-site-preview__grid span {
		height: 54px;
	}

	.web-site-preview__form {
		margin: 0 10px;
	}

	.web-pain,
	.web-process,
	.web-price,
	.web-related,
	.web-scope,
	.web-case,
	.web-faq {
		padding: 58px 0;
	}

	.web-scope-item__head {
		grid-template-columns: 36px minmax(0, 1fr) 24px;
		padding: 18px;
	}

	.web-scope-item__body p {
		padding: 0 18px 18px;
	}

	.web-case__card,
	.web-price-card {
		padding: 24px;
		border-radius: 22px;
	}

	.web-case__metric-value {
		font-size: 32px;
	}

	.web-step__head {
		grid-template-columns: 44px minmax(0, 1fr);
	}

	.web-step__time {
		grid-column: 2;
	}

	.web-faq__question {
		padding: 18px 20px;
		font-size: 15px;
	}

	.web-faq__answer p {
		padding: 0 20px 20px;
	}

	.web-related__grid {
		grid-template-columns: 1fr;
	}
}

@media (prefers-reduced-motion: reduce) {
	.web-btn,
	.web-breadcrumb__link,
	.web-scope-item__toggle::before,
	.web-scope-item__toggle::after,
	.web-scope-item__body,
	.web-step__circle,
	.web-step__body,
	.web-faq__question,
	.web-faq__answer,
	.web-faq__icon::before,
	.web-faq__icon::after,
	.web-related-card,
	.web-related-card__arrow {
		transition: none;
	}

	.web-btn:hover,
	.web-btn:focus-visible,
	.web-related-card:hover,
	.web-related-card:focus-visible,
	.web-related-card:hover .web-related-card__arrow,
	.web-related-card:focus-visible .web-related-card__arrow {
		transform: none;
	}
}

/* ============================================================
   SMM Service Page
   ============================================================ */

.smm-service-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 84px;
	background:
		radial-gradient(circle at 84% 18%, color-mix(in srgb, var(--color-blue) 18%, transparent), transparent 32%),
		radial-gradient(circle at 10% 100%, color-mix(in srgb, var(--color-green) 12%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%) 0%, var(--color-surface) 100%);
}

.smm-service-hero__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 390px;
	gap: 56px;
	align-items: center;
}

.smm-service-hero__content {
	display: grid;
	gap: 18px;
	max-width: 940px;
}

.smm-service-breadcrumb {
	margin-bottom: 4px;
}

.smm-service-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 700;
}

.smm-service-breadcrumb__item + .smm-service-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--color-blue) 28%);
}

.smm-service-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.smm-service-breadcrumb__link:hover,
.smm-service-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.smm-service-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-bg) 58%, var(--color-muted) 42%);
}

.smm-service-eyebrow {
	width: fit-content;
	margin: 0;
	padding: 8px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.smm-service-hero__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 62px;
	font-weight: 850;
	line-height: 1.04;
	letter-spacing: 0;
}

.smm-service-hero__subtitle {
	max-width: 780px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 21px;
	font-weight: 500;
	line-height: 1.58;
}

.smm-service-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 10px;
}

.smm-service-btn {
	min-height: 50px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 24px;
	border: 1px solid transparent;
	border-radius: 10px;
	font-size: 15px;
	font-weight: 850;
	line-height: 1.1;
	text-align: center;
	transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.smm-service-btn:hover,
.smm-service-btn:focus-visible {
	transform: translateY(-1px);
}

.smm-service-btn:focus-visible,
.smm-service-breadcrumb__link:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

.smm-service-btn--primary {
	background: linear-gradient(100deg, color-mix(in srgb, var(--color-blue) 74%, var(--color-green) 26%) 0%, var(--color-blue) 100%);
	color: var(--color-surface);
	box-shadow: 0 16px 34px color-mix(in srgb, var(--color-blue) 22%, transparent);
}

.smm-service-btn--secondary {
	border-color: color-mix(in srgb, var(--color-blue) 18%, transparent);
	background: color-mix(in srgb, var(--color-surface) 78%, transparent);
	color: var(--color-bg);
	box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-surface) 92%, transparent);
}

.smm-service-btn--secondary:hover,
.smm-service-btn--secondary:focus-visible {
	border-color: color-mix(in srgb, var(--color-blue) 40%, transparent);
	color: var(--color-blue);
}

.smm-service-hero__trust {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 22px;
	margin: 6px 0 0;
	padding: 0;
	list-style: none;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.smm-service-hero__trust li {
	position: relative;
	padding-left: 22px;
}

.smm-service-hero__trust li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.35em;
	width: 13px;
	height: 13px;
	border-radius: 50%;
	background:
		linear-gradient(135deg, transparent 0 42%, var(--color-surface) 42% 56%, transparent 56%),
		color-mix(in srgb, var(--color-green) 74%, var(--color-blue) 26%);
}

.smm-service-feed {
	position: relative;
	min-height: 430px;
	padding: 26px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 34px;
	background:
		linear-gradient(160deg, color-mix(in srgb, var(--color-surface) 88%, transparent), color-mix(in srgb, var(--color-surface) 56%, var(--color-blue) 44%)),
		var(--color-surface);
	box-shadow:
		0 30px 70px color-mix(in srgb, var(--color-bg) 14%, transparent),
		inset 0 1px 0 color-mix(in srgb, var(--color-surface) 86%, transparent);
}

.smm-service-feed::before {
	content: "";
	position: absolute;
	inset: 18px;
	border-radius: 28px;
	background:
		radial-gradient(circle at 78% 10%, color-mix(in srgb, var(--color-green) 14%, transparent), transparent 36%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-bg) 92%, var(--color-blue) 8%), var(--color-bg));
}

.smm-service-feed__top,
.smm-service-feed__post,
.smm-service-feed__stats,
.smm-service-feed__button {
	position: relative;
	z-index: 1;
}

.smm-service-feed__top {
	height: 18px;
	margin: 16px 10px 24px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-surface) 24%, transparent);
}

.smm-service-feed__post {
	height: 82px;
	margin: 0 10px 16px;
	border: 1px solid color-mix(in srgb, var(--color-surface) 18%, transparent);
	border-radius: 20px;
	background: color-mix(in srgb, var(--color-surface) 10%, transparent);
	box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-surface) 14%, transparent);
}

.smm-service-feed__post--large {
	height: 142px;
	background:
		linear-gradient(135deg, color-mix(in srgb, var(--color-blue) 34%, transparent), color-mix(in srgb, var(--color-green) 18%, transparent)),
		color-mix(in srgb, var(--color-surface) 8%, transparent);
}

.smm-service-feed__stats {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
	margin: 0 10px 16px;
}

.smm-service-feed__stats span {
	min-height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid color-mix(in srgb, var(--color-surface) 18%, transparent);
	border-radius: 16px;
	background: color-mix(in srgb, var(--color-surface) 9%, transparent);
	color: var(--color-surface);
	font-size: 13px;
	font-weight: 900;
}

.smm-service-feed__button {
	min-height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 10px;
	border-radius: 14px;
	background: var(--color-blue);
	color: var(--color-surface);
	font-size: 14px;
	font-weight: 900;
}

.smm-service-section-head {
	max-width: 820px;
	display: grid;
	gap: 12px;
	margin-bottom: 32px;
}

.smm-service-section-head--center {
	margin-right: auto;
	margin-left: auto;
	text-align: center;
	justify-items: center;
}

.smm-service-section-head__title,
.smm-service-case__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 52px;
	font-weight: 850;
	line-height: 1.06;
	letter-spacing: 0;
}

.smm-service-section-head__subtitle {
	max-width: 680px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 17px;
	font-weight: 500;
	line-height: 1.5;
}

.smm-service-pain,
.smm-service-process,
.smm-service-price,
.smm-service-related {
	padding: 82px 0;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.smm-service-scope,
.smm-service-case,
.smm-service-faq {
	padding: 84px 0;
	background: var(--color-surface);
}

.smm-service-pain__list {
	display: grid;
	gap: 14px;
}

.smm-service-pain-item {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 44px minmax(0, 1fr);
	gap: 18px;
	align-items: stretch;
	padding: 18px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px color-mix(in srgb, var(--color-bg) 6%, transparent);
}

.smm-service-pain-item__problem,
.smm-service-pain-item__solution {
	display: grid;
	align-content: start;
	gap: 10px;
	padding: 18px;
	border-radius: 18px;
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
}

.smm-service-pain-item__solution {
	background: color-mix(in srgb, var(--color-surface) 90%, var(--color-green) 10%);
}

.smm-service-pain-item__label {
	width: fit-content;
	padding: 6px 10px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.smm-service-pain-item__label--problem {
	background: color-mix(in srgb, var(--color-bg) 9%, var(--color-surface) 91%);
	color: color-mix(in srgb, var(--color-bg) 70%, transparent);
}

.smm-service-pain-item__label--solution {
	background: color-mix(in srgb, var(--color-green) 14%, var(--color-surface) 86%);
	color: color-mix(in srgb, var(--color-green) 42%, var(--color-bg) 58%);
}

.smm-service-pain-item p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.58;
}

.smm-service-pain-item__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-blue);
	font-size: 24px;
	font-weight: 900;
	line-height: 1;
}

.smm-service-scope__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}

.smm-service-scope-item {
	overflow: hidden;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 20px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 98%, transparent), color-mix(in srgb, var(--color-surface) 89%, var(--color-blue) 11%)),
		var(--color-surface);
}

.smm-service-scope-item__head {
	width: 100%;
	display: grid;
	grid-template-columns: 42px minmax(0, 1fr) 26px;
	gap: 12px;
	align-items: center;
	padding: 20px;
	border: 0;
	background: transparent;
	color: var(--color-bg);
	font: inherit;
	text-align: left;
	cursor: pointer;
}

.smm-service-scope-item__num {
	color: color-mix(in srgb, var(--color-blue) 64%, transparent);
	font-size: 13px;
	font-weight: 900;
}

.smm-service-scope-item__name {
	color: var(--color-bg);
	font-size: 17px;
	font-weight: 850;
	line-height: 1.18;
}

.smm-service-scope-item__toggle {
	position: relative;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
}

.smm-service-scope-item__toggle::before,
.smm-service-scope-item__toggle::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 10px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.smm-service-scope-item__toggle::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.smm-service-scope-item.is-open .smm-service-scope-item__toggle::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(0deg);
}

.smm-service-scope-item__body {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.smm-service-scope-item.is-open .smm-service-scope-item__body {
	max-height: 220px;
}

.smm-service-scope-item__body p {
	margin: 0;
	padding: 0 20px 20px 74px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.58;
}

.smm-service-process__steps {
	position: relative;
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 12px;
}

.smm-service-process__steps::before {
	content: "";
	position: absolute;
	left: 7%;
	right: 7%;
	top: 24px;
	height: 1px;
	background: color-mix(in srgb, var(--color-blue) 16%, transparent);
}

.smm-service-step {
	position: relative;
	display: grid;
	gap: 14px;
	justify-items: center;
	text-align: center;
}

.smm-service-step__head {
	position: relative;
	z-index: 1;
	display: grid;
	justify-items: center;
	gap: 8px;
	width: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--color-bg);
	font: inherit;
	cursor: pointer;
}

.smm-service-step__circle {
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid color-mix(in srgb, var(--color-blue) 18%, transparent);
	border-radius: 50%;
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 16px;
	font-weight: 900;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.smm-service-step.is-active .smm-service-step__circle {
	border-color: var(--color-blue);
	background: var(--color-blue);
	color: var(--color-surface);
}

.smm-service-step__label {
	color: var(--color-bg);
	font-size: 15px;
	font-weight: 900;
	line-height: 1.15;
}

.smm-service-step__time {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 12px;
	font-weight: 850;
	line-height: 1;
}

.smm-service-step__body {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	padding: 0 14px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 0%, transparent);
	border-radius: 18px;
	background: var(--color-surface);
	transition: max-height 0.28s ease, opacity 0.28s ease, padding 0.28s ease, border-color 0.28s ease;
}

.smm-service-step.is-active .smm-service-step__body {
	max-height: 280px;
	opacity: 1;
	padding: 16px;
	border-color: color-mix(in srgb, var(--color-blue) 14%, transparent);
}

.smm-service-step__body p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 13px;
	font-weight: 500;
	line-height: 1.55;
}

.smm-service-step__body p + p {
	margin-top: 8px;
}

.smm-service-step__result {
	color: var(--color-bg);
	font-weight: 800;
}

.smm-service-case__card {
	max-width: 980px;
	padding: 44px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 28px;
	background:
		radial-gradient(circle at 92% 0%, color-mix(in srgb, var(--color-blue) 14%, transparent), transparent 34%),
		color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
	box-shadow: 0 18px 46px color-mix(in srgb, var(--color-bg) 10%, transparent);
}

.smm-service-case__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
}

.smm-service-case__tag {
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.smm-service-case__niche {
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 14px;
	font-weight: 750;
}

.smm-service-case__desc {
	max-width: 820px;
	margin: 16px 0 30px;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.62;
}

.smm-service-case__metrics {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
	margin-bottom: 30px;
}

.smm-service-case__metric {
	display: grid;
	gap: 6px;
	padding: 18px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 18px;
	background: var(--color-surface);
}

.smm-service-case__metric-value {
	color: var(--color-blue);
	font-size: 42px;
	font-weight: 950;
	line-height: 1;
}

.smm-service-case__metric-label {
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.32;
}

.smm-service-price__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.smm-service-price-card {
	position: relative;
	display: grid;
	grid-template-rows: auto auto auto 1fr auto;
	gap: 14px;
	padding: 28px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px color-mix(in srgb, var(--color-bg) 6%, transparent);
}

.smm-service-price-card--featured {
	border-color: color-mix(in srgb, var(--color-blue) 40%, transparent);
	box-shadow: 0 18px 42px color-mix(in srgb, var(--color-blue) 16%, transparent);
}

.smm-service-price-card__badge {
	width: fit-content;
	min-height: 26px;
	display: inline-flex;
	align-items: center;
	padding: 6px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 12%, var(--color-surface) 88%);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
}

.smm-service-price-card__name {
	margin: 0;
	color: var(--color-bg);
	font-size: 24px;
	font-weight: 900;
	line-height: 1.15;
}

.smm-service-price-card__desc {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.45;
}

.smm-service-price-card__price {
	margin: 0;
	color: var(--color-blue);
	font-size: 30px;
	font-weight: 950;
	line-height: 1;
}

.smm-service-price-card__price span {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 13px;
	font-weight: 850;
}

.smm-service-price-card__list {
	display: grid;
	gap: 10px;
	margin: 4px 0 0;
	padding: 0;
	list-style: none;
}

.smm-service-price-card__list li {
	position: relative;
	padding-left: 20px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.45;
}

.smm-service-price-card__list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.45em;
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-green) 70%, var(--color-blue) 30%);
}

.smm-service-price-card .smm-service-btn {
	width: 100%;
	margin-top: 6px;
}

.smm-service-price__note {
	margin: 28px 0 0;
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.5;
	text-align: center;
}

.smm-service-price__note a {
	color: var(--color-blue);
	font-weight: 850;
}

.smm-service-faq__inner {
	max-width: 940px;
}

.smm-service-faq__list {
	overflow: hidden;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 24px;
	background: var(--color-surface);
	box-shadow: 0 18px 46px color-mix(in srgb, var(--color-bg) 10%, transparent);
}

.smm-service-faq__item + .smm-service-faq__item {
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.smm-service-faq__question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 22px 26px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	font-size: 16px;
	font-weight: 850;
	line-height: 1.35;
	text-align: left;
	cursor: pointer;
	transition: color 0.2s ease, background 0.2s ease;
}

.smm-service-faq__question:hover,
.smm-service-faq__item.is-open .smm-service-faq__question {
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
	color: var(--color-blue);
}

.smm-service-faq__icon {
	position: relative;
	width: 22px;
	height: 22px;
	flex: 0 0 auto;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
}

.smm-service-faq__icon::before,
.smm-service-faq__icon::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 10px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.smm-service-faq__icon::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.smm-service-faq__item.is-open .smm-service-faq__icon::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(0deg);
}

.smm-service-faq__answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.smm-service-faq__item.is-open .smm-service-faq__answer {
	max-height: 340px;
}

.smm-service-faq__answer p {
	margin: 0;
	padding: 0 26px 24px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.65;
}

.smm-service-related__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
}

.smm-service-related-card {
	position: relative;
	min-height: 210px;
	display: grid;
	grid-template-rows: auto 1fr auto;
	gap: 12px;
	padding: 24px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 20px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px color-mix(in srgb, var(--color-bg) 6%, transparent);
	transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.smm-service-related-card:hover,
.smm-service-related-card:focus-visible {
	transform: translateY(-2px);
	border-color: color-mix(in srgb, var(--color-blue) 36%, transparent);
	box-shadow: 0 14px 30px color-mix(in srgb, var(--color-bg) 10%, transparent);
}

.smm-service-related-card__name {
	color: var(--color-bg);
	font-size: 19px;
	font-weight: 900;
	line-height: 1.15;
}

.smm-service-related-card__desc {
	color: color-mix(in srgb, var(--color-bg) 64%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.smm-service-related-card__arrow {
	color: var(--color-blue);
	font-size: 22px;
	font-weight: 900;
	line-height: 1;
	transition: transform 0.2s ease;
}

.smm-service-related-card:hover .smm-service-related-card__arrow,
.smm-service-related-card:focus-visible .smm-service-related-card__arrow {
	transform: translateX(4px);
}

.smm-service-scope-item__head:focus-visible,
.smm-service-step__head:focus-visible,
.smm-service-faq__question:focus-visible,
.smm-service-related-card:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

@media (max-width: 1180px) {
	.smm-service-hero__inner {
		grid-template-columns: minmax(0, 1fr) 340px;
		gap: 34px;
	}

	.smm-service-related__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 1023px) {
	.smm-service-hero {
		padding: 136px 0 64px;
	}

	.smm-service-hero__inner {
		grid-template-columns: 1fr;
	}

	.smm-service-hero__title {
		font-size: 50px;
	}

	.smm-service-hero__subtitle {
		font-size: 19px;
	}

	.smm-service-section-head__title,
	.smm-service-case__title {
		font-size: 42px;
	}

	.smm-service-feed {
		min-height: 360px;
	}

	.smm-service-feed__post--large {
		height: 106px;
	}

	.smm-service-pain-item,
	.smm-service-scope__grid,
	.smm-service-price__grid,
	.smm-service-case__metrics {
		grid-template-columns: 1fr;
	}

	.smm-service-pain-item__arrow {
		min-height: 24px;
		transform: rotate(90deg);
	}

	.smm-service-process__steps {
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.smm-service-process__steps::before {
		display: none;
	}

	.smm-service-step {
		justify-items: stretch;
		text-align: left;
	}

	.smm-service-step__head {
		grid-template-columns: 48px minmax(0, 1fr) auto;
		align-items: center;
		justify-items: start;
		text-align: left;
	}
}

@media (max-width: 767px) {
	.smm-service-hero {
		padding: 122px 0 52px;
	}

	.smm-service-hero__title {
		font-size: 34px;
	}

	.smm-service-hero__subtitle {
		font-size: 17px;
	}

	.smm-service-section-head__title,
	.smm-service-case__title {
		font-size: 30px;
	}

	.smm-service-section-head__subtitle {
		font-size: 16px;
	}

	.smm-service-hero__actions,
	.smm-service-btn {
		width: 100%;
	}

	.smm-service-feed {
		min-height: 310px;
		padding: 18px;
		border-radius: 24px;
	}

	.smm-service-feed__top {
		margin: 12px 8px 16px;
	}

	.smm-service-feed__post {
		height: 62px;
		margin: 0 8px 12px;
	}

	.smm-service-feed__post--large {
		height: 88px;
	}

	.smm-service-feed__stats {
		gap: 8px;
		margin: 0 8px 12px;
	}

	.smm-service-feed__stats span {
		min-height: 40px;
	}

	.smm-service-feed__button {
		margin: 0 8px;
	}

	.smm-service-pain,
	.smm-service-process,
	.smm-service-price,
	.smm-service-related,
	.smm-service-scope,
	.smm-service-case,
	.smm-service-faq {
		padding: 58px 0;
	}

	.smm-service-scope-item__head {
		grid-template-columns: 36px minmax(0, 1fr) 24px;
		padding: 18px;
	}

	.smm-service-scope-item__body p {
		padding: 0 18px 18px;
	}

	.smm-service-case__card,
	.smm-service-price-card {
		padding: 24px;
		border-radius: 22px;
	}

	.smm-service-case__metric-value {
		font-size: 32px;
	}

	.smm-service-step__head {
		grid-template-columns: 44px minmax(0, 1fr);
	}

	.smm-service-step__time {
		grid-column: 2;
	}

	.smm-service-faq__question {
		padding: 18px 20px;
		font-size: 15px;
	}

	.smm-service-faq__answer p {
		padding: 0 20px 20px;
	}

	.smm-service-related__grid {
		grid-template-columns: 1fr;
	}
}

@media (prefers-reduced-motion: reduce) {
	.smm-service-btn,
	.smm-service-breadcrumb__link,
	.smm-service-scope-item__toggle::before,
	.smm-service-scope-item__toggle::after,
	.smm-service-scope-item__body,
	.smm-service-step__circle,
	.smm-service-step__body,
	.smm-service-faq__question,
	.smm-service-faq__answer,
	.smm-service-faq__icon::before,
	.smm-service-faq__icon::after,
	.smm-service-related-card,
	.smm-service-related-card__arrow {
		transition: none;
	}

	.smm-service-btn:hover,
	.smm-service-btn:focus-visible,
	.smm-service-related-card:hover,
	.smm-service-related-card:focus-visible,
	.smm-service-related-card:hover .smm-service-related-card__arrow,
	.smm-service-related-card:focus-visible .smm-service-related-card__arrow {
		transform: none;
	}
}

/* ============================================================
   Doctor Promotion Service Page
   ============================================================ */

.doc-service-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 84px;
	background:
		radial-gradient(circle at 82% 18%, color-mix(in srgb, var(--color-blue) 17%, transparent), transparent 32%),
		radial-gradient(circle at 10% 100%, color-mix(in srgb, var(--color-green) 13%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%) 0%, var(--color-surface) 100%);
}

.doc-service-hero__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 400px;
	gap: 56px;
	align-items: center;
}

.doc-service-hero__content {
	display: grid;
	gap: 18px;
	max-width: 940px;
}

.doc-service-breadcrumb {
	margin-bottom: 4px;
}

.doc-service-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 700;
}

.doc-service-breadcrumb__item + .doc-service-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--color-blue) 28%);
}

.doc-service-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.doc-service-breadcrumb__link:hover,
.doc-service-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.doc-service-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-bg) 58%, var(--color-muted) 42%);
}

.doc-service-eyebrow {
	width: fit-content;
	margin: 0;
	padding: 8px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.doc-service-hero__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 62px;
	font-weight: 850;
	line-height: 1.04;
	letter-spacing: 0;
}

.doc-service-hero__subtitle {
	max-width: 780px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 21px;
	font-weight: 500;
	line-height: 1.58;
}

.doc-service-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 10px;
}

.doc-service-btn {
	min-height: 50px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 24px;
	border: 1px solid transparent;
	border-radius: 10px;
	font-size: 15px;
	font-weight: 850;
	line-height: 1.1;
	text-align: center;
	transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.doc-service-btn:hover,
.doc-service-btn:focus-visible {
	transform: translateY(-1px);
}

.doc-service-btn:focus-visible,
.doc-service-breadcrumb__link:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

.doc-service-btn--primary {
	background: linear-gradient(100deg, color-mix(in srgb, var(--color-blue) 74%, var(--color-green) 26%) 0%, var(--color-blue) 100%);
	color: var(--color-surface);
	box-shadow: 0 16px 34px color-mix(in srgb, var(--color-blue) 22%, transparent);
}

.doc-service-btn--secondary {
	border-color: color-mix(in srgb, var(--color-blue) 18%, transparent);
	background: color-mix(in srgb, var(--color-surface) 78%, transparent);
	color: var(--color-bg);
	box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-surface) 92%, transparent);
}

.doc-service-btn--secondary:hover,
.doc-service-btn--secondary:focus-visible {
	border-color: color-mix(in srgb, var(--color-blue) 40%, transparent);
	color: var(--color-blue);
}

.doc-service-hero__trust {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 22px;
	margin: 6px 0 0;
	padding: 0;
	list-style: none;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.doc-service-hero__trust li {
	position: relative;
	padding-left: 22px;
}

.doc-service-hero__trust li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.35em;
	width: 13px;
	height: 13px;
	border-radius: 50%;
	background:
		linear-gradient(135deg, transparent 0 42%, var(--color-surface) 42% 56%, transparent 56%),
		color-mix(in srgb, var(--color-green) 74%, var(--color-blue) 26%);
}

.doc-service-profile {
	position: relative;
	min-height: 430px;
	display: grid;
	align-content: start;
	gap: 16px;
	padding: 28px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 34px;
	background:
		linear-gradient(160deg, color-mix(in srgb, var(--color-surface) 92%, transparent), color-mix(in srgb, var(--color-surface) 58%, var(--color-blue) 42%)),
		var(--color-surface);
	box-shadow:
		0 30px 70px color-mix(in srgb, var(--color-bg) 14%, transparent),
		inset 0 1px 0 color-mix(in srgb, var(--color-surface) 88%, transparent);
}

.doc-service-profile::before {
	content: "";
	position: absolute;
	inset: 18px;
	border-radius: 28px;
	background:
		radial-gradient(circle at 78% 10%, color-mix(in srgb, var(--color-green) 15%, transparent), transparent 36%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-bg) 92%, var(--color-blue) 8%), var(--color-bg));
}

.doc-service-profile > * {
	position: relative;
	z-index: 1;
}

.doc-service-profile__photo {
	width: 92px;
	height: 92px;
	margin: 14px auto 2px;
	border: 2px solid color-mix(in srgb, var(--color-surface) 72%, transparent);
	border-radius: 50%;
	background:
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 82%, var(--color-blue) 18%) 0 48%, color-mix(in srgb, var(--color-blue) 42%, var(--color-bg) 58%) 48% 100%),
		var(--color-surface);
	box-shadow: 0 18px 34px color-mix(in srgb, var(--color-bg) 22%, transparent);
}

.doc-service-profile__name,
.doc-service-profile__spec {
	height: 16px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-surface) 24%, transparent);
}

.doc-service-profile__name {
	width: 64%;
	margin: 0 auto;
}

.doc-service-profile__spec {
	width: 44%;
	margin: 0 auto 8px;
	background: color-mix(in srgb, var(--color-surface) 14%, transparent);
}

.doc-service-profile__rating {
	display: grid;
	grid-template-columns: 86px minmax(0, 1fr);
	gap: 14px;
	align-items: center;
	padding: 16px;
	border: 1px solid color-mix(in srgb, var(--color-surface) 18%, transparent);
	border-radius: 18px;
	background: color-mix(in srgb, var(--color-surface) 10%, transparent);
}

.doc-service-profile__rating span {
	color: var(--color-surface);
	font-size: 36px;
	font-weight: 950;
	line-height: 1;
}

.doc-service-profile__rating strong {
	color: color-mix(in srgb, var(--color-surface) 76%, transparent);
	font-size: 14px;
	font-weight: 850;
	line-height: 1.2;
}

.doc-service-profile__channels {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
}

.doc-service-profile__channels span {
	min-height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid color-mix(in srgb, var(--color-surface) 18%, transparent);
	border-radius: 16px;
	background: color-mix(in srgb, var(--color-surface) 9%, transparent);
	color: var(--color-surface);
	font-size: 12px;
	font-weight: 900;
	line-height: 1.15;
	text-align: center;
}

.doc-service-profile__cta {
	min-height: 46px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 14px;
	background: var(--color-blue);
	color: var(--color-surface);
	font-size: 14px;
	font-weight: 900;
}

.doc-service-section-head {
	max-width: 820px;
	display: grid;
	gap: 12px;
	margin-bottom: 32px;
}

.doc-service-section-head--center {
	margin-right: auto;
	margin-left: auto;
	text-align: center;
	justify-items: center;
}

.doc-service-section-head__title,
.doc-service-case__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 52px;
	font-weight: 850;
	line-height: 1.06;
	letter-spacing: 0;
}

.doc-service-section-head__subtitle {
	max-width: 680px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 17px;
	font-weight: 500;
	line-height: 1.5;
}

.doc-service-pain,
.doc-service-process,
.doc-service-price,
.doc-service-related {
	padding: 82px 0;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.doc-service-channels,
.doc-service-scope,
.doc-service-case,
.doc-service-faq {
	padding: 84px 0;
	background: var(--color-surface);
}

.doc-service-pain__list {
	display: grid;
	gap: 14px;
}

.doc-service-pain-item {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 44px minmax(0, 1fr);
	gap: 18px;
	align-items: stretch;
	padding: 18px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px color-mix(in srgb, var(--color-bg) 6%, transparent);
}

.doc-service-pain-item__problem,
.doc-service-pain-item__solution {
	display: grid;
	align-content: start;
	gap: 10px;
	padding: 18px;
	border-radius: 18px;
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
}

.doc-service-pain-item__solution {
	background: color-mix(in srgb, var(--color-surface) 90%, var(--color-green) 10%);
}

.doc-service-pain-item__label {
	width: fit-content;
	padding: 6px 10px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.doc-service-pain-item__label--problem {
	background: color-mix(in srgb, var(--color-bg) 9%, var(--color-surface) 91%);
	color: color-mix(in srgb, var(--color-bg) 70%, transparent);
}

.doc-service-pain-item__label--solution {
	background: color-mix(in srgb, var(--color-green) 14%, var(--color-surface) 86%);
	color: color-mix(in srgb, var(--color-green) 42%, var(--color-bg) 58%);
}

.doc-service-pain-item p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.58;
}

.doc-service-pain-item__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-blue);
	font-size: 24px;
	font-weight: 900;
	line-height: 1;
}

.doc-service-channels__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
}

.doc-service-channel-card {
	position: relative;
	min-height: 320px;
	display: grid;
	grid-template-rows: auto auto auto 1fr auto;
	gap: 12px;
	padding: 24px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-top: 3px solid color-mix(in srgb, var(--color-blue) 70%, var(--color-green) 30%);
	border-radius: 20px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 98%, transparent), color-mix(in srgb, var(--color-surface) 90%, var(--color-blue) 10%)),
		var(--color-surface);
	box-shadow: 0 10px 24px color-mix(in srgb, var(--color-bg) 6%, transparent);
}

.doc-service-channel-card__priority {
	width: fit-content;
	padding: 6px 10px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
	color: var(--color-blue);
	font-size: 11px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
}

.doc-service-channel-card__name {
	margin: 0;
	color: var(--color-bg);
	font-size: 20px;
	font-weight: 900;
	line-height: 1.15;
}

.doc-service-channel-card__platforms {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 13px;
	font-weight: 850;
	line-height: 1.35;
}

.doc-service-channel-card__desc {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.56;
}

.doc-service-channel-card__result {
	margin: 0;
	padding-top: 14px;
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	color: var(--color-bg);
	font-size: 13px;
	font-weight: 850;
	line-height: 1.35;
}

.doc-service-scope__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}

.doc-service-scope-item {
	overflow: hidden;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 20px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 98%, transparent), color-mix(in srgb, var(--color-surface) 89%, var(--color-blue) 11%)),
		var(--color-surface);
}

.doc-service-scope-item__head {
	width: 100%;
	display: grid;
	grid-template-columns: 42px minmax(0, 1fr) 26px;
	gap: 12px;
	align-items: center;
	padding: 20px;
	border: 0;
	background: transparent;
	color: var(--color-bg);
	font: inherit;
	text-align: left;
	cursor: pointer;
}

.doc-service-scope-item__num {
	color: color-mix(in srgb, var(--color-blue) 64%, transparent);
	font-size: 13px;
	font-weight: 900;
}

.doc-service-scope-item__name {
	color: var(--color-bg);
	font-size: 17px;
	font-weight: 850;
	line-height: 1.18;
}

.doc-service-scope-item__toggle {
	position: relative;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
}

.doc-service-scope-item__toggle::before,
.doc-service-scope-item__toggle::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 10px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.doc-service-scope-item__toggle::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.doc-service-scope-item.is-open .doc-service-scope-item__toggle::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(0deg);
}

.doc-service-scope-item__body {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.doc-service-scope-item.is-open .doc-service-scope-item__body {
	max-height: 240px;
}

.doc-service-scope-item__body p {
	margin: 0;
	padding: 0 20px 20px 74px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.58;
}

.doc-service-process__steps {
	position: relative;
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 12px;
}

.doc-service-process__steps::before {
	content: "";
	position: absolute;
	left: 7%;
	right: 7%;
	top: 24px;
	height: 1px;
	background: color-mix(in srgb, var(--color-blue) 16%, transparent);
}

.doc-service-step {
	position: relative;
	display: grid;
	gap: 14px;
	justify-items: center;
	text-align: center;
}

.doc-service-step__head {
	position: relative;
	z-index: 1;
	display: grid;
	justify-items: center;
	gap: 8px;
	width: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--color-bg);
	font: inherit;
	cursor: pointer;
}

.doc-service-step__circle {
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid color-mix(in srgb, var(--color-blue) 18%, transparent);
	border-radius: 50%;
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 16px;
	font-weight: 900;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.doc-service-step.is-active .doc-service-step__circle {
	border-color: var(--color-blue);
	background: var(--color-blue);
	color: var(--color-surface);
}

.doc-service-step__label {
	color: var(--color-bg);
	font-size: 15px;
	font-weight: 900;
	line-height: 1.15;
}

.doc-service-step__time {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 12px;
	font-weight: 850;
	line-height: 1;
}

.doc-service-step__body {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	padding: 0 14px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 0%, transparent);
	border-radius: 18px;
	background: var(--color-surface);
	transition: max-height 0.28s ease, opacity 0.28s ease, padding 0.28s ease, border-color 0.28s ease;
}

.doc-service-step.is-active .doc-service-step__body {
	max-height: 280px;
	opacity: 1;
	padding: 16px;
	border-color: color-mix(in srgb, var(--color-blue) 14%, transparent);
}

.doc-service-step__body p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 13px;
	font-weight: 500;
	line-height: 1.55;
}

.doc-service-step__body p + p {
	margin-top: 8px;
}

.doc-service-step__result {
	color: var(--color-bg);
	font-weight: 800;
}

.doc-service-case__card {
	max-width: 980px;
	padding: 44px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 28px;
	background:
		radial-gradient(circle at 92% 0%, color-mix(in srgb, var(--color-green) 14%, transparent), transparent 34%),
		color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
	box-shadow: 0 18px 46px color-mix(in srgb, var(--color-bg) 10%, transparent);
}

.doc-service-case__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
}

.doc-service-case__tag {
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.doc-service-case__niche {
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 14px;
	font-weight: 750;
}

.doc-service-case__desc {
	max-width: 820px;
	margin: 16px 0 30px;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.62;
}

.doc-service-case__metrics {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
	margin-bottom: 30px;
}

.doc-service-case__metric {
	display: grid;
	gap: 6px;
	padding: 18px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 18px;
	background: var(--color-surface);
}

.doc-service-case__metric-value {
	color: var(--color-blue);
	font-size: 42px;
	font-weight: 950;
	line-height: 1;
}

.doc-service-case__metric-label {
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.32;
}

.doc-service-price__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.doc-service-price-card {
	position: relative;
	display: grid;
	grid-template-rows: auto auto auto 1fr auto;
	gap: 14px;
	padding: 28px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px color-mix(in srgb, var(--color-bg) 6%, transparent);
}

.doc-service-price-card--featured {
	border-color: color-mix(in srgb, var(--color-blue) 40%, transparent);
	box-shadow: 0 18px 42px color-mix(in srgb, var(--color-blue) 16%, transparent);
}

.doc-service-price-card__badge {
	width: fit-content;
	min-height: 26px;
	display: inline-flex;
	align-items: center;
	padding: 6px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 12%, var(--color-surface) 88%);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
}

.doc-service-price-card__name {
	margin: 0;
	color: var(--color-bg);
	font-size: 24px;
	font-weight: 900;
	line-height: 1.15;
}

.doc-service-price-card__desc {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.45;
}

.doc-service-price-card__price {
	margin: 0;
	color: var(--color-blue);
	font-size: 30px;
	font-weight: 950;
	line-height: 1;
}

.doc-service-price-card__price span {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 13px;
	font-weight: 850;
}

.doc-service-price-card__list {
	display: grid;
	gap: 10px;
	margin: 4px 0 0;
	padding: 0;
	list-style: none;
}

.doc-service-price-card__list li {
	position: relative;
	padding-left: 20px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.45;
}

.doc-service-price-card__list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.45em;
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-green) 70%, var(--color-blue) 30%);
}

.doc-service-price-card .doc-service-btn {
	width: 100%;
	margin-top: 6px;
}

.doc-service-price__note {
	margin: 28px 0 0;
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.5;
	text-align: center;
}

.doc-service-price__note a {
	color: var(--color-blue);
	font-weight: 850;
}

.doc-service-faq__inner {
	max-width: 940px;
}

.doc-service-faq__list {
	overflow: hidden;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 24px;
	background: var(--color-surface);
	box-shadow: 0 18px 46px color-mix(in srgb, var(--color-bg) 10%, transparent);
}

.doc-service-faq__item + .doc-service-faq__item {
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.doc-service-faq__question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 22px 26px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	font-size: 16px;
	font-weight: 850;
	line-height: 1.35;
	text-align: left;
	cursor: pointer;
	transition: color 0.2s ease, background 0.2s ease;
}

.doc-service-faq__question:hover,
.doc-service-faq__item.is-open .doc-service-faq__question {
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
	color: var(--color-blue);
}

.doc-service-faq__icon {
	position: relative;
	width: 22px;
	height: 22px;
	flex: 0 0 auto;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
}

.doc-service-faq__icon::before,
.doc-service-faq__icon::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 10px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.doc-service-faq__icon::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.doc-service-faq__item.is-open .doc-service-faq__icon::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(0deg);
}

.doc-service-faq__answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.doc-service-faq__item.is-open .doc-service-faq__answer {
	max-height: 340px;
}

.doc-service-faq__answer p {
	margin: 0;
	padding: 0 26px 24px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.65;
}

.doc-service-related__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
}

.doc-service-related-card {
	position: relative;
	min-height: 210px;
	display: grid;
	grid-template-rows: auto 1fr auto;
	gap: 12px;
	padding: 24px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 20px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px color-mix(in srgb, var(--color-bg) 6%, transparent);
	transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.doc-service-related-card:hover,
.doc-service-related-card:focus-visible {
	transform: translateY(-2px);
	border-color: color-mix(in srgb, var(--color-blue) 36%, transparent);
	box-shadow: 0 14px 30px color-mix(in srgb, var(--color-bg) 10%, transparent);
}

.doc-service-related-card__name {
	color: var(--color-bg);
	font-size: 19px;
	font-weight: 900;
	line-height: 1.15;
}

.doc-service-related-card__desc {
	color: color-mix(in srgb, var(--color-bg) 64%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.doc-service-related-card__arrow {
	color: var(--color-blue);
	font-size: 22px;
	font-weight: 900;
	line-height: 1;
	transition: transform 0.2s ease;
}

.doc-service-related-card:hover .doc-service-related-card__arrow,
.doc-service-related-card:focus-visible .doc-service-related-card__arrow {
	transform: translateX(4px);
}

.doc-service-scope-item__head:focus-visible,
.doc-service-step__head:focus-visible,
.doc-service-faq__question:focus-visible,
.doc-service-related-card:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

@media (max-width: 1180px) {
	.doc-service-hero__inner {
		grid-template-columns: minmax(0, 1fr) 350px;
		gap: 34px;
	}

	.doc-service-channels__grid,
	.doc-service-related__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 1023px) {
	.doc-service-hero {
		padding: 136px 0 64px;
	}

	.doc-service-hero__inner {
		grid-template-columns: 1fr;
	}

	.doc-service-hero__title {
		font-size: 50px;
	}

	.doc-service-hero__subtitle {
		font-size: 19px;
	}

	.doc-service-section-head__title,
	.doc-service-case__title {
		font-size: 42px;
	}

	.doc-service-profile {
		min-height: 360px;
	}

	.doc-service-pain-item,
	.doc-service-scope__grid,
	.doc-service-price__grid,
	.doc-service-case__metrics {
		grid-template-columns: 1fr;
	}

	.doc-service-pain-item__arrow {
		min-height: 24px;
		transform: rotate(90deg);
	}

	.doc-service-process__steps {
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.doc-service-process__steps::before {
		display: none;
	}

	.doc-service-step {
		justify-items: stretch;
		text-align: left;
	}

	.doc-service-step__head {
		grid-template-columns: 48px minmax(0, 1fr) auto;
		align-items: center;
		justify-items: start;
		text-align: left;
	}
}

@media (max-width: 767px) {
	.doc-service-hero {
		padding: 122px 0 52px;
	}

	.doc-service-hero__title {
		font-size: 34px;
	}

	.doc-service-hero__subtitle {
		font-size: 17px;
	}

	.doc-service-section-head__title,
	.doc-service-case__title {
		font-size: 30px;
	}

	.doc-service-section-head__subtitle {
		font-size: 16px;
	}

	.doc-service-hero__actions,
	.doc-service-btn {
		width: 100%;
	}

	.doc-service-profile {
		min-height: 314px;
		padding: 18px;
		border-radius: 24px;
	}

	.doc-service-profile__photo {
		width: 74px;
		height: 74px;
		margin-top: 10px;
	}

	.doc-service-profile__rating {
		grid-template-columns: 74px minmax(0, 1fr);
		padding: 14px;
	}

	.doc-service-profile__rating span {
		font-size: 30px;
	}

	.doc-service-profile__channels {
		gap: 8px;
	}

	.doc-service-profile__channels span {
		min-height: 40px;
		font-size: 11px;
	}

	.doc-service-pain,
	.doc-service-process,
	.doc-service-price,
	.doc-service-related,
	.doc-service-channels,
	.doc-service-scope,
	.doc-service-case,
	.doc-service-faq {
		padding: 58px 0;
	}

	.doc-service-channels__grid,
	.doc-service-related__grid {
		grid-template-columns: 1fr;
	}

	.doc-service-channel-card {
		min-height: 0;
	}

	.doc-service-scope-item__head {
		grid-template-columns: 36px minmax(0, 1fr) 24px;
		padding: 18px;
	}

	.doc-service-scope-item__body p {
		padding: 0 18px 18px;
	}

	.doc-service-case__card,
	.doc-service-price-card {
		padding: 24px;
		border-radius: 22px;
	}

	.doc-service-case__metric-value {
		font-size: 32px;
	}

	.doc-service-step__head {
		grid-template-columns: 44px minmax(0, 1fr);
	}

	.doc-service-step__time {
		grid-column: 2;
	}

	.doc-service-faq__question {
		padding: 18px 20px;
		font-size: 15px;
	}

	.doc-service-faq__answer p {
		padding: 0 20px 20px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.doc-service-btn,
	.doc-service-breadcrumb__link,
	.doc-service-scope-item__toggle::before,
	.doc-service-scope-item__toggle::after,
	.doc-service-scope-item__body,
	.doc-service-step__circle,
	.doc-service-step__body,
	.doc-service-faq__question,
	.doc-service-faq__answer,
	.doc-service-faq__icon::before,
	.doc-service-faq__icon::after,
	.doc-service-related-card,
	.doc-service-related-card__arrow {
		transition: none;
	}

	.doc-service-btn:hover,
	.doc-service-btn:focus-visible,
	.doc-service-related-card:hover,
	.doc-service-related-card:focus-visible,
	.doc-service-related-card:hover .doc-service-related-card__arrow,
	.doc-service-related-card:focus-visible .doc-service-related-card__arrow {
		transform: none;
	}
}

/* ============================================================
   Branding Service Page
   ============================================================ */

.brand-service-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 84px;
	background:
		radial-gradient(circle at 82% 18%, color-mix(in srgb, var(--color-blue) 17%, transparent), transparent 32%),
		radial-gradient(circle at 10% 100%, color-mix(in srgb, var(--color-green) 13%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%) 0%, var(--color-surface) 100%);
}

.brand-service-hero__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 400px;
	gap: 56px;
	align-items: center;
}

.brand-service-hero__content {
	display: grid;
	gap: 18px;
	max-width: 940px;
}

.brand-service-breadcrumb {
	margin-bottom: 4px;
}

.brand-service-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 700;
}

.brand-service-breadcrumb__item + .brand-service-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--color-blue) 28%);
}

.brand-service-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.brand-service-breadcrumb__link:hover,
.brand-service-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.brand-service-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-bg) 58%, var(--color-muted) 42%);
}

.brand-service-eyebrow {
	width: fit-content;
	margin: 0;
	padding: 8px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.brand-service-hero__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 62px;
	font-weight: 850;
	line-height: 1.04;
	letter-spacing: 0;
}

.brand-service-hero__subtitle {
	max-width: 780px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 21px;
	font-weight: 500;
	line-height: 1.58;
}

.brand-service-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 10px;
}

.brand-service-btn {
	min-height: 50px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 24px;
	border: 1px solid transparent;
	border-radius: 10px;
	font-size: 15px;
	font-weight: 850;
	line-height: 1.1;
	text-align: center;
	transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.brand-service-btn:hover,
.brand-service-btn:focus-visible {
	transform: translateY(-1px);
}

.brand-service-btn:focus-visible,
.brand-service-breadcrumb__link:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

.brand-service-btn--primary {
	background: linear-gradient(100deg, color-mix(in srgb, var(--color-blue) 74%, var(--color-green) 26%) 0%, var(--color-blue) 100%);
	color: var(--color-surface);
	box-shadow: 0 16px 34px color-mix(in srgb, var(--color-blue) 22%, transparent);
}

.brand-service-btn--secondary {
	border-color: color-mix(in srgb, var(--color-blue) 18%, transparent);
	background: color-mix(in srgb, var(--color-surface) 78%, transparent);
	color: var(--color-bg);
	box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-surface) 92%, transparent);
}

.brand-service-btn--secondary:hover,
.brand-service-btn--secondary:focus-visible {
	border-color: color-mix(in srgb, var(--color-blue) 40%, transparent);
	color: var(--color-blue);
}

.brand-service-hero__trust {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 22px;
	margin: 6px 0 0;
	padding: 0;
	list-style: none;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.brand-service-hero__trust li {
	position: relative;
	padding-left: 22px;
}

.brand-service-hero__trust li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.35em;
	width: 13px;
	height: 13px;
	border-radius: 50%;
	background:
		linear-gradient(135deg, transparent 0 42%, var(--color-surface) 42% 56%, transparent 56%),
		color-mix(in srgb, var(--color-green) 74%, var(--color-blue) 26%);
}

.brand-service-kit {
	position: relative;
	min-height: 430px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: auto auto 1fr auto;
	gap: 14px;
	padding: 28px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 34px;
	background:
		linear-gradient(160deg, color-mix(in srgb, var(--color-surface) 92%, transparent), color-mix(in srgb, var(--color-surface) 58%, var(--color-blue) 42%)),
		var(--color-surface);
	box-shadow:
		0 30px 70px color-mix(in srgb, var(--color-bg) 14%, transparent),
		inset 0 1px 0 color-mix(in srgb, var(--color-surface) 88%, transparent);
}

.brand-service-kit::before {
	content: "";
	position: absolute;
	inset: 18px;
	border-radius: 28px;
	background:
		radial-gradient(circle at 78% 10%, color-mix(in srgb, var(--color-green) 15%, transparent), transparent 36%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-bg) 92%, var(--color-blue) 8%), var(--color-bg));
}

.brand-service-kit > * {
	position: relative;
	z-index: 1;
}

.brand-service-kit__logo {
	width: 104px;
	height: 104px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 2px solid color-mix(in srgb, var(--color-surface) 72%, transparent);
	border-radius: 30px;
	background:
		linear-gradient(135deg, color-mix(in srgb, var(--color-blue) 62%, var(--color-green) 38%), var(--color-blue)),
		var(--color-blue);
	color: var(--color-surface);
	font-size: 30px;
	font-weight: 950;
	line-height: 1;
}

.brand-service-kit__swatches {
	display: grid;
	align-content: start;
	gap: 10px;
}

.brand-service-kit__swatches span {
	min-height: 28px;
	border: 1px solid color-mix(in srgb, var(--color-surface) 18%, transparent);
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-surface) 18%, transparent);
}

.brand-service-kit__swatches span:nth-child(2) {
	background: color-mix(in srgb, var(--color-blue) 48%, var(--color-surface) 52%);
}

.brand-service-kit__swatches span:nth-child(3) {
	background: color-mix(in srgb, var(--color-green) 48%, var(--color-surface) 52%);
}

.brand-service-kit__card {
	min-height: 134px;
	border: 1px solid color-mix(in srgb, var(--color-surface) 18%, transparent);
	border-radius: 22px;
	background:
		linear-gradient(135deg, color-mix(in srgb, var(--color-surface) 20%, transparent) 0 42%, transparent 42%),
		color-mix(in srgb, var(--color-surface) 9%, transparent);
}

.brand-service-kit__card--paper {
	grid-column: 1 / 2;
}

.brand-service-kit__card--nav {
	grid-column: 2 / 3;
	background:
		linear-gradient(90deg, color-mix(in srgb, var(--color-surface) 24%, transparent) 0 28%, transparent 28%),
		color-mix(in srgb, var(--color-surface) 9%, transparent);
}

.brand-service-kit__label {
	grid-column: 1 / -1;
	min-height: 46px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 14px;
	background: var(--color-blue);
	color: var(--color-surface);
	font-size: 13px;
	font-weight: 900;
	line-height: 1.2;
	text-align: center;
}

.brand-service-section-head {
	max-width: 820px;
	display: grid;
	gap: 12px;
	margin-bottom: 32px;
}

.brand-service-section-head--center {
	margin-right: auto;
	margin-left: auto;
	text-align: center;
	justify-items: center;
}

.brand-service-section-head__title,
.brand-service-case__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 52px;
	font-weight: 850;
	line-height: 1.06;
	letter-spacing: 0;
}

.brand-service-section-head__subtitle {
	max-width: 680px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 17px;
	font-weight: 500;
	line-height: 1.5;
}

.brand-service-pain,
.brand-service-deliverables,
.brand-service-price,
.brand-service-related {
	padding: 82px 0;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.brand-service-scope,
.brand-service-process,
.brand-service-case,
.brand-service-faq {
	padding: 84px 0;
	background: var(--color-surface);
}

.brand-service-pain__list {
	display: grid;
	gap: 14px;
}

.brand-service-pain-item {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 44px minmax(0, 1fr);
	gap: 18px;
	align-items: stretch;
	padding: 18px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px color-mix(in srgb, var(--color-bg) 6%, transparent);
}

.brand-service-pain-item__problem,
.brand-service-pain-item__solution {
	display: grid;
	align-content: start;
	gap: 10px;
	padding: 18px;
	border-radius: 18px;
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
}

.brand-service-pain-item__solution {
	background: color-mix(in srgb, var(--color-surface) 90%, var(--color-green) 10%);
}

.brand-service-pain-item__label {
	width: fit-content;
	padding: 6px 10px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.brand-service-pain-item__label--problem {
	background: color-mix(in srgb, var(--color-bg) 9%, var(--color-surface) 91%);
	color: color-mix(in srgb, var(--color-bg) 70%, transparent);
}

.brand-service-pain-item__label--solution {
	background: color-mix(in srgb, var(--color-green) 14%, var(--color-surface) 86%);
	color: color-mix(in srgb, var(--color-green) 42%, var(--color-bg) 58%);
}

.brand-service-pain-item p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.58;
}

.brand-service-pain-item__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-blue);
	font-size: 24px;
	font-weight: 900;
	line-height: 1;
}

.brand-service-scope__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}

.brand-service-scope-item {
	overflow: hidden;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 20px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 98%, transparent), color-mix(in srgb, var(--color-surface) 89%, var(--color-blue) 11%)),
		var(--color-surface);
}

.brand-service-scope-item__head {
	width: 100%;
	display: grid;
	grid-template-columns: 42px minmax(0, 1fr) 26px;
	gap: 12px;
	align-items: center;
	padding: 20px;
	border: 0;
	background: transparent;
	color: var(--color-bg);
	font: inherit;
	text-align: left;
	cursor: pointer;
}

.brand-service-scope-item__num {
	color: color-mix(in srgb, var(--color-blue) 64%, transparent);
	font-size: 13px;
	font-weight: 900;
}

.brand-service-scope-item__name {
	color: var(--color-bg);
	font-size: 17px;
	font-weight: 850;
	line-height: 1.18;
}

.brand-service-scope-item__toggle {
	position: relative;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
}

.brand-service-scope-item__toggle::before,
.brand-service-scope-item__toggle::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 10px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.brand-service-scope-item__toggle::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.brand-service-scope-item.is-open .brand-service-scope-item__toggle::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(0deg);
}

.brand-service-scope-item__body {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.brand-service-scope-item.is-open .brand-service-scope-item__body {
	max-height: 240px;
}

.brand-service-scope-item__body p {
	margin: 0;
	padding: 0 20px 20px 74px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.58;
}

.brand-service-deliverables__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.brand-service-deliverables-group {
	display: grid;
	gap: 14px;
	padding: 26px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background: var(--color-surface);
	box-shadow: 0 12px 28px color-mix(in srgb, var(--color-bg) 7%, transparent);
}

.brand-service-deliverables-group__icon {
	width: 46px;
	height: 46px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 15px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 92%, transparent), color-mix(in srgb, var(--color-surface) 74%, var(--color-blue) 26%)),
		color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
	color: var(--color-blue);
	font-size: 15px;
	font-weight: 950;
	box-shadow:
		0 12px 24px color-mix(in srgb, var(--color-blue) 8%, transparent),
		inset 0 1px 0 color-mix(in srgb, var(--color-surface) 86%, transparent);
}

.brand-service-deliverables-group__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 22px;
	font-weight: 900;
	line-height: 1.15;
}

.brand-service-deliverables-list {
	display: grid;
	margin: 0;
	padding: 0;
	list-style: none;
}

.brand-service-deliverables-list li {
	position: relative;
	padding: 10px 0 10px 20px;
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 11%, transparent);
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.42;
}

.brand-service-deliverables-list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 1.1em;
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-green) 70%, var(--color-blue) 30%);
}

.brand-service-process__steps {
	position: relative;
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 12px;
}

.brand-service-process__steps::before {
	content: "";
	position: absolute;
	left: 7%;
	right: 7%;
	top: 24px;
	height: 1px;
	background: color-mix(in srgb, var(--color-blue) 16%, transparent);
}

.brand-service-step {
	position: relative;
	display: grid;
	gap: 14px;
	justify-items: center;
	text-align: center;
}

.brand-service-step__head {
	position: relative;
	z-index: 1;
	display: grid;
	justify-items: center;
	gap: 8px;
	width: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--color-bg);
	font: inherit;
	cursor: pointer;
}

.brand-service-step__circle {
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid color-mix(in srgb, var(--color-blue) 18%, transparent);
	border-radius: 50%;
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 16px;
	font-weight: 900;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.brand-service-step.is-active .brand-service-step__circle {
	border-color: var(--color-blue);
	background: var(--color-blue);
	color: var(--color-surface);
}

.brand-service-step__label {
	color: var(--color-bg);
	font-size: 15px;
	font-weight: 900;
	line-height: 1.15;
}

.brand-service-step__time {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 12px;
	font-weight: 850;
	line-height: 1;
}

.brand-service-step__body {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	padding: 0 14px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 0%, transparent);
	border-radius: 18px;
	background: var(--color-surface);
	transition: max-height 0.28s ease, opacity 0.28s ease, padding 0.28s ease, border-color 0.28s ease;
}

.brand-service-step.is-active .brand-service-step__body {
	max-height: 280px;
	opacity: 1;
	padding: 16px;
	border-color: color-mix(in srgb, var(--color-blue) 14%, transparent);
}

.brand-service-step__body p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 13px;
	font-weight: 500;
	line-height: 1.55;
}

.brand-service-step__body p + p {
	margin-top: 8px;
}

.brand-service-step__result {
	color: var(--color-bg);
	font-weight: 800;
}

.brand-service-case__card {
	max-width: 980px;
	padding: 44px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 28px;
	background:
		radial-gradient(circle at 92% 0%, color-mix(in srgb, var(--color-green) 14%, transparent), transparent 34%),
		color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
	box-shadow: 0 18px 46px color-mix(in srgb, var(--color-bg) 10%, transparent);
}

.brand-service-case__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
}

.brand-service-case__tag {
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.brand-service-case__niche {
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 14px;
	font-weight: 750;
}

.brand-service-case__desc {
	max-width: 820px;
	margin: 16px 0 30px;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.62;
}

.brand-service-case__metrics {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
	margin-bottom: 30px;
}

.brand-service-case__metric {
	display: grid;
	gap: 6px;
	padding: 18px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 18px;
	background: var(--color-surface);
}

.brand-service-case__metric-value {
	color: var(--color-blue);
	font-size: 42px;
	font-weight: 950;
	line-height: 1;
}

.brand-service-case__metric-label {
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.32;
}

.brand-service-price__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.brand-service-price-card {
	position: relative;
	display: grid;
	grid-template-rows: auto auto auto 1fr auto;
	gap: 14px;
	padding: 28px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px color-mix(in srgb, var(--color-bg) 6%, transparent);
}

.brand-service-price-card--featured {
	border-color: color-mix(in srgb, var(--color-blue) 40%, transparent);
	box-shadow: 0 18px 42px color-mix(in srgb, var(--color-blue) 16%, transparent);
}

.brand-service-price-card__badge {
	width: fit-content;
	min-height: 26px;
	display: inline-flex;
	align-items: center;
	padding: 6px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 12%, var(--color-surface) 88%);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
}

.brand-service-price-card__name {
	margin: 0;
	color: var(--color-bg);
	font-size: 24px;
	font-weight: 900;
	line-height: 1.15;
}

.brand-service-price-card__desc {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.45;
}

.brand-service-price-card__price {
	margin: 0;
	color: var(--color-blue);
	font-size: 30px;
	font-weight: 950;
	line-height: 1;
}

.brand-service-price-card__price span {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 13px;
	font-weight: 850;
}

.brand-service-price-card__list {
	display: grid;
	gap: 10px;
	margin: 4px 0 0;
	padding: 0;
	list-style: none;
}

.brand-service-price-card__list li {
	position: relative;
	padding-left: 20px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.45;
}

.brand-service-price-card__list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.45em;
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-green) 70%, var(--color-blue) 30%);
}

.brand-service-price-card .brand-service-btn {
	width: 100%;
	margin-top: 6px;
}

.brand-service-price__note {
	margin: 28px 0 0;
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.5;
	text-align: center;
}

.brand-service-price__note a {
	color: var(--color-blue);
	font-weight: 850;
}

.brand-service-faq__inner {
	max-width: 940px;
}

.brand-service-faq__list {
	overflow: hidden;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 24px;
	background: var(--color-surface);
	box-shadow: 0 18px 46px color-mix(in srgb, var(--color-bg) 10%, transparent);
}

.brand-service-faq__item + .brand-service-faq__item {
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.brand-service-faq__question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 22px 26px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	font-size: 16px;
	font-weight: 850;
	line-height: 1.35;
	text-align: left;
	cursor: pointer;
	transition: color 0.2s ease, background 0.2s ease;
}

.brand-service-faq__question:hover,
.brand-service-faq__item.is-open .brand-service-faq__question {
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
	color: var(--color-blue);
}

.brand-service-faq__icon {
	position: relative;
	width: 22px;
	height: 22px;
	flex: 0 0 auto;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
}

.brand-service-faq__icon::before,
.brand-service-faq__icon::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 10px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.brand-service-faq__icon::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.brand-service-faq__item.is-open .brand-service-faq__icon::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(0deg);
}

.brand-service-faq__answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.brand-service-faq__item.is-open .brand-service-faq__answer {
	max-height: 340px;
}

.brand-service-faq__answer p {
	margin: 0;
	padding: 0 26px 24px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.65;
}

.brand-service-related__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
}

.brand-service-related-card {
	position: relative;
	min-height: 210px;
	display: grid;
	grid-template-rows: auto 1fr auto;
	gap: 12px;
	padding: 24px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 20px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px color-mix(in srgb, var(--color-bg) 6%, transparent);
	transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.brand-service-related-card:hover,
.brand-service-related-card:focus-visible {
	transform: translateY(-2px);
	border-color: color-mix(in srgb, var(--color-blue) 36%, transparent);
	box-shadow: 0 14px 30px color-mix(in srgb, var(--color-bg) 10%, transparent);
}

.brand-service-related-card__name {
	color: var(--color-bg);
	font-size: 19px;
	font-weight: 900;
	line-height: 1.15;
}

.brand-service-related-card__desc {
	color: color-mix(in srgb, var(--color-bg) 64%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.brand-service-related-card__arrow {
	color: var(--color-blue);
	font-size: 22px;
	font-weight: 900;
	line-height: 1;
	transition: transform 0.2s ease;
}

.brand-service-related-card:hover .brand-service-related-card__arrow,
.brand-service-related-card:focus-visible .brand-service-related-card__arrow {
	transform: translateX(4px);
}

.brand-service-scope-item__head:focus-visible,
.brand-service-step__head:focus-visible,
.brand-service-faq__question:focus-visible,
.brand-service-related-card:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

@media (max-width: 1180px) {
	.brand-service-hero__inner {
		grid-template-columns: minmax(0, 1fr) 350px;
		gap: 34px;
	}

	.brand-service-deliverables__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.brand-service-related__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 1023px) {
	.brand-service-hero {
		padding: 136px 0 64px;
	}

	.brand-service-hero__inner {
		grid-template-columns: 1fr;
	}

	.brand-service-hero__title {
		font-size: 50px;
	}

	.brand-service-hero__subtitle {
		font-size: 19px;
	}

	.brand-service-section-head__title,
	.brand-service-case__title {
		font-size: 42px;
	}

	.brand-service-kit {
		min-height: 360px;
	}

	.brand-service-pain-item,
	.brand-service-scope__grid,
	.brand-service-price__grid,
	.brand-service-case__metrics {
		grid-template-columns: 1fr;
	}

	.brand-service-pain-item__arrow {
		min-height: 24px;
		transform: rotate(90deg);
	}

	.brand-service-process__steps {
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.brand-service-process__steps::before {
		display: none;
	}

	.brand-service-step {
		justify-items: stretch;
		text-align: left;
	}

	.brand-service-step__head {
		grid-template-columns: 48px minmax(0, 1fr) auto;
		align-items: center;
		justify-items: start;
		text-align: left;
	}
}

@media (max-width: 767px) {
	.brand-service-hero {
		padding: 122px 0 52px;
	}

	.brand-service-hero__title {
		font-size: 34px;
	}

	.brand-service-hero__subtitle {
		font-size: 17px;
	}

	.brand-service-section-head__title,
	.brand-service-case__title {
		font-size: 30px;
	}

	.brand-service-section-head__subtitle {
		font-size: 16px;
	}

	.brand-service-hero__actions,
	.brand-service-btn {
		width: 100%;
	}

	.brand-service-kit {
		min-height: 314px;
		padding: 18px;
		border-radius: 24px;
	}

	.brand-service-kit__logo {
		width: 78px;
		height: 78px;
		border-radius: 22px;
		font-size: 24px;
	}

	.brand-service-kit__card {
		min-height: 96px;
		border-radius: 18px;
	}

	.brand-service-pain,
	.brand-service-deliverables,
	.brand-service-price,
	.brand-service-related,
	.brand-service-scope,
	.brand-service-process,
	.brand-service-case,
	.brand-service-faq {
		padding: 58px 0;
	}

	.brand-service-deliverables__grid,
	.brand-service-related__grid {
		grid-template-columns: 1fr;
	}

	.brand-service-scope-item__head {
		grid-template-columns: 36px minmax(0, 1fr) 24px;
		padding: 18px;
	}

	.brand-service-scope-item__body p {
		padding: 0 18px 18px;
	}

	.brand-service-case__card,
	.brand-service-price-card,
	.brand-service-deliverables-group {
		padding: 24px;
		border-radius: 22px;
	}

	.brand-service-case__metric-value {
		font-size: 32px;
	}

	.brand-service-step__head {
		grid-template-columns: 44px minmax(0, 1fr);
	}

	.brand-service-step__time {
		grid-column: 2;
	}

	.brand-service-faq__question {
		padding: 18px 20px;
		font-size: 15px;
	}

	.brand-service-faq__answer p {
		padding: 0 20px 20px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.brand-service-btn,
	.brand-service-breadcrumb__link,
	.brand-service-scope-item__toggle::before,
	.brand-service-scope-item__toggle::after,
	.brand-service-scope-item__body,
	.brand-service-step__circle,
	.brand-service-step__body,
	.brand-service-faq__question,
	.brand-service-faq__answer,
	.brand-service-faq__icon::before,
	.brand-service-faq__icon::after,
	.brand-service-related-card,
	.brand-service-related-card__arrow {
		transition: none;
	}

	.brand-service-btn:hover,
	.brand-service-btn:focus-visible,
	.brand-service-related-card:hover,
	.brand-service-related-card:focus-visible,
	.brand-service-related-card:hover .brand-service-related-card__arrow,
	.brand-service-related-card:focus-visible .brand-service-related-card__arrow {
		transform: none;
	}
}

/* ============================================================
   Doctors Industry Page
   ============================================================ */

.doctors-page-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 86px;
	background:
		radial-gradient(circle at 84% 18%, color-mix(in srgb, var(--color-green) 12%, transparent), transparent 30%),
		radial-gradient(circle at 12% 94%, color-mix(in srgb, var(--color-green) 15%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%) 0%, var(--color-surface) 100%);
}

.doctors-page-hero__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 380px;
	gap: 56px;
	align-items: center;
}

.doctors-page-hero__content {
	display: grid;
	gap: 18px;
	max-width: 950px;
}

.doctors-page-breadcrumb {
	margin-bottom: 4px;
}

.doctors-page-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 700;
}

.doctors-page-breadcrumb__item + .doctors-page-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--color-blue) 28%);
}

.doctors-page-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.doctors-page-breadcrumb__link:hover,
.doctors-page-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.doctors-page-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-bg) 58%, var(--color-muted) 42%);
}

.doctors-page-eyebrow {
	width: fit-content;
	margin: 0;
	padding: 8px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 14%, var(--color-surface) 86%);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.doctors-page-hero__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 64px;
	font-weight: 850;
	line-height: 1.04;
	letter-spacing: 0;
}

.doctors-page-hero__subtitle {
	max-width: 790px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 21px;
	font-weight: 500;
	line-height: 1.58;
}

.doctors-page-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 10px;
}

.doctors-page-btn {
	min-height: 50px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 24px;
	border: 1px solid transparent;
	border-radius: 10px;
	font-size: 15px;
	font-weight: 850;
	line-height: 1.1;
	text-align: center;
	transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.doctors-page-btn:hover,
.doctors-page-btn:focus-visible {
	transform: translateY(-1px);
}

.doctors-page-btn:focus-visible,
.doctors-page-breadcrumb__link:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

.doctors-page-btn--primary {
	background: linear-gradient(100deg, color-mix(in srgb, var(--color-blue) 78%, var(--color-green) 22%) 0%, var(--color-blue) 100%);
	color: var(--color-surface);
	box-shadow: 0 16px 34px color-mix(in srgb, var(--color-blue) 24%, transparent);
}

.doctors-page-btn--secondary {
	border-color: color-mix(in srgb, var(--color-blue) 18%, transparent);
	background: var(--color-surface);
	color: var(--color-bg);
	box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-surface) 92%, transparent);
}

.doctors-page-btn--secondary:hover,
.doctors-page-btn--secondary:focus-visible {
	border-color: color-mix(in srgb, var(--color-blue) 44%, transparent);
	color: var(--color-blue);
}

.doctors-page-hero__trust {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 22px;
	margin: 6px 0 0;
	padding: 0;
	list-style: none;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.doctors-page-hero__trust li {
	position: relative;
	padding-left: 22px;
}

.doctors-page-hero__trust li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.35em;
	width: 13px;
	height: 13px;
	border-radius: 50%;
	background:
		linear-gradient(135deg, transparent 0 42%, var(--color-surface) 42% 56%, transparent 56%),
		color-mix(in srgb, var(--color-green) 70%, var(--color-blue) 30%);
}

.doctors-page-hero__visual {
	position: relative;
	min-height: 456px;
}

.doctors-page-profile {
	position: relative;
	display: grid;
	grid-template-columns: 78px minmax(0, 1fr);
	gap: 18px;
	min-height: 456px;
	padding: 28px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 34px;
	background:
		linear-gradient(160deg, color-mix(in srgb, var(--color-surface) 96%, transparent), color-mix(in srgb, var(--color-surface) 78%, var(--color-blue) 22%)),
		var(--color-surface);
	backdrop-filter: blur(18px);
	box-shadow:
		0 30px 70px color-mix(in srgb, var(--color-bg) 13%, transparent),
		inset 0 1px 0 color-mix(in srgb, var(--color-surface) 86%, transparent);
}

.doctors-page-profile::before {
	content: "";
	position: absolute;
	inset: 18px;
	border-radius: 28px;
	background:
		linear-gradient(180deg, color-mix(in srgb, var(--color-bg) 84%, var(--color-blue) 16%), var(--color-bg));
}

.doctors-page-profile > * {
	position: relative;
	z-index: 1;
}

.doctors-page-profile__photo {
	width: 78px;
	height: 78px;
	border-radius: 24px;
	background:
		radial-gradient(circle at 50% 32%, var(--color-surface) 0 16%, transparent 17%),
		radial-gradient(circle at 50% 86%, color-mix(in srgb, var(--color-surface) 88%, var(--color-blue) 12%) 0 34%, transparent 35%),
		linear-gradient(135deg, color-mix(in srgb, var(--color-blue) 64%, var(--color-green) 36%), var(--color-blue-dark));
	box-shadow: 0 16px 30px color-mix(in srgb, var(--color-blue) 26%, transparent);
}

.doctors-page-profile__main {
	display: grid;
	align-content: center;
	gap: 6px;
	min-width: 0;
}

.doctors-page-profile__label {
	color: color-mix(in srgb, var(--color-blue) 46%, var(--color-surface) 54%);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
}

.doctors-page-profile__main strong {
	color: var(--color-surface);
	font-size: 24px;
	font-weight: 900;
	line-height: 1.1;
}

.doctors-page-profile__main small {
	color: color-mix(in srgb, var(--color-surface) 58%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.doctors-page-profile__rating,
.doctors-page-profile__stats,
.doctors-page-profile__cta {
	grid-column: 1 / -1;
}

.doctors-page-profile__rating {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 18px;
	margin-top: 8px;
	padding: 20px;
	border: 1px solid color-mix(in srgb, var(--color-surface) 14%, transparent);
	border-radius: 22px;
	background: color-mix(in srgb, var(--color-surface) 9%, transparent);
}

.doctors-page-profile__rating span {
	color: color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	font-size: 48px;
	font-weight: 950;
	line-height: 1;
}

.doctors-page-profile__rating small {
	color: color-mix(in srgb, var(--color-surface) 62%, transparent);
	font-size: 14px;
	font-weight: 800;
}

.doctors-page-profile__stats {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
	margin-top: 4px;
}

.doctors-page-profile__stats div {
	display: grid;
	gap: 8px;
	min-height: 104px;
	padding: 16px;
	border: 1px solid color-mix(in srgb, var(--color-surface) 12%, transparent);
	border-radius: 18px;
	background: color-mix(in srgb, var(--color-surface) 7%, transparent);
}

.doctors-page-profile__stats span {
	color: var(--color-surface);
	font-size: 22px;
	font-weight: 950;
	line-height: 1;
}

.doctors-page-profile__stats small {
	color: color-mix(in srgb, var(--color-surface) 58%, transparent);
	font-size: 12px;
	font-weight: 750;
	line-height: 1.35;
}

.doctors-page-profile__cta {
	align-self: end;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 50px;
	margin-top: 4px;
	border-radius: 999px;
	background: var(--color-surface);
	color: var(--color-blue);
	font-size: 14px;
	font-weight: 900;
}

.doctors-page-section-head {
	max-width: 830px;
	display: grid;
	gap: 12px;
	margin-bottom: 32px;
}

.doctors-page-section-head--center {
	margin-right: auto;
	margin-left: auto;
	text-align: center;
	justify-items: center;
}

.doctors-page-section-head__title,
.doctors-page-case__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 52px;
	font-weight: 850;
	line-height: 1.06;
	letter-spacing: 0;
}

.doctors-page-section-head__subtitle {
	max-width: 700px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 17px;
	font-weight: 500;
	line-height: 1.5;
}

.doctors-page-pains,
.doctors-page-tools,
.doctors-page-process,
.doctors-page-related {
	padding: 82px 0;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.doctors-page-types,
.doctors-page-case,
.doctors-page-faq {
	padding: 84px 0;
	background: var(--color-surface);
}

.doctors-page-pains__grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 14px;
}

.doctors-page-pain-card,
.doctors-page-tool-card {
	display: grid;
	align-content: start;
	gap: 12px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 20px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 98%, transparent), color-mix(in srgb, var(--color-surface) 87%, var(--color-blue) 13%)),
		var(--color-surface);
	box-shadow: 0 10px 24px color-mix(in srgb, var(--color-bg) 7%, transparent);
}

.doctors-page-pain-card {
	padding: 22px;
}

.doctors-page-icon {
	position: relative;
	width: 44px;
	height: 44px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 18%, transparent);
	border-radius: 14px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 94%, transparent), color-mix(in srgb, var(--color-surface) 76%, var(--color-blue) 24%)),
		color-mix(in srgb, var(--color-blue) 10%, transparent);
	box-shadow:
		0 12px 24px color-mix(in srgb, var(--color-blue) 9%, transparent),
		inset 0 1px 0 color-mix(in srgb, var(--color-surface) 86%, transparent);
}

.doctors-page-icon::before {
	content: "";
	position: absolute;
	inset: 10px;
	background: var(--color-blue);
}

.doctors-page-icon--patient::before,
.doctors-page-icon--profile::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21a8 8 0 0 0-16 0'/%3E%3Ccircle cx='12' cy='8' r='4'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21a8 8 0 0 0-16 0'/%3E%3Ccircle cx='12' cy='8' r='4'/%3E%3C/svg%3E") center / contain no-repeat;
}

.doctors-page-icon--trust::before,
.doctors-page-icon--star::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='m12 2 3.1 6.3 6.9 1-5 4.9 1.2 6.8L12 17.8 5.8 21 7 14.2 2 9.3l6.9-1Z'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='m12 2 3.1 6.3 6.9 1-5 4.9 1.2 6.8L12 17.8 5.8 21 7 14.2 2 9.3l6.9-1Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

.doctors-page-icon--content::before,
.doctors-page-icon--smm::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15a4 4 0 0 1-4 4H8l-5 3V7a4 4 0 0 1 4-4h10a4 4 0 0 1 4 4Z'/%3E%3Cpath d='M8 9h8M8 13h5'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15a4 4 0 0 1-4 4H8l-5 3V7a4 4 0 0 1 4-4h10a4 4 0 0 1 4 4Z'/%3E%3Cpath d='M8 9h8M8 13h5'/%3E%3C/svg%3E") center / contain no-repeat;
}

.doctors-page-icon--transition::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 7h11a5 5 0 0 1 0 10H5'/%3E%3Cpath d='m8 13-4 4 4 4'/%3E%3Cpath d='m16 3 4 4-4 4'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 7h11a5 5 0 0 1 0 10H5'/%3E%3Cpath d='m8 13-4 4 4 4'/%3E%3Cpath d='m16 3 4 4-4 4'/%3E%3C/svg%3E") center / contain no-repeat;
}

.doctors-page-icon--aggregator::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='3' width='16' height='18' rx='3'/%3E%3Cpath d='M8 8h8M8 12h8M8 16h5'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='3' width='16' height='18' rx='3'/%3E%3Cpath d='M8 8h8M8 12h8M8 16h5'/%3E%3C/svg%3E") center / contain no-repeat;
}

.doctors-page-icon--map::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21s7-5.1 7-11a7 7 0 1 0-14 0c0 5.9 7 11 7 11Z'/%3E%3Ccircle cx='12' cy='10' r='2.3'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21s7-5.1 7-11a7 7 0 1 0-14 0c0 5.9 7 11 7 11Z'/%3E%3Ccircle cx='12' cy='10' r='2.3'/%3E%3C/svg%3E") center / contain no-repeat;
}

.doctors-page-icon--search::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.8-3.8'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.8-3.8'/%3E%3C/svg%3E") center / contain no-repeat;
}

.doctors-page-icon--site::before {
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='14' rx='3'/%3E%3Cpath d='M8 21h8M12 18v3M7 9h10M7 13h6'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='14' rx='3'/%3E%3Cpath d='M8 21h8M12 18v3M7 9h10M7 13h6'/%3E%3C/svg%3E") center / contain no-repeat;
}

.doctors-page-pain-card__title,
.doctors-page-tool-card__name {
	margin: 0;
	color: var(--color-bg);
	font-size: 17px;
	font-weight: 850;
	line-height: 1.18;
}

.doctors-page-pain-card__text,
.doctors-page-tool-card__desc {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.doctors-page-types__layout {
	display: grid;
	grid-template-columns: 310px minmax(0, 1fr);
	gap: 24px;
	align-items: start;
}

.doctors-page-types__tabs {
	display: grid;
	gap: 10px;
}

.doctors-page-types__tab {
	display: grid;
	gap: 6px;
	width: 100%;
	padding: 18px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 18px;
	background: color-mix(in srgb, var(--color-surface) 88%, var(--color-blue) 12%);
	color: var(--color-bg);
	font: inherit;
	text-align: left;
	cursor: pointer;
	transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.doctors-page-types__tab:hover,
.doctors-page-types__tab:focus-visible,
.doctors-page-types__tab.is-active {
	border-color: color-mix(in srgb, var(--color-blue) 36%, transparent);
	background: var(--color-surface);
	box-shadow: 0 14px 30px color-mix(in srgb, var(--color-bg) 10%, transparent);
	transform: translateY(-1px);
}

.doctors-page-types__tab:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 36%, var(--color-surface) 64%);
	outline-offset: 3px;
}

.doctors-page-types__tab span {
	font-size: 18px;
	font-weight: 900;
	line-height: 1.1;
}

.doctors-page-types__tab small {
	color: color-mix(in srgb, var(--color-bg) 55%, transparent);
	font-size: 13px;
	font-weight: 700;
	line-height: 1.3;
}

.doctors-page-types__panel {
	padding: 32px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 28px;
	background:
		radial-gradient(circle at 94% 0%, color-mix(in srgb, var(--color-green) 10%, transparent), transparent 34%),
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 98%, transparent), color-mix(in srgb, var(--color-surface) 89%, var(--color-blue) 11%));
	box-shadow: 0 18px 46px color-mix(in srgb, var(--color-bg) 9%, transparent);
}

.doctors-page-types__panel-head {
	display: grid;
	gap: 12px;
	max-width: 780px;
}

.doctors-page-types__panel-head h3 {
	margin: 0;
	color: var(--color-bg);
	font-size: 34px;
	font-weight: 850;
	line-height: 1.1;
}

.doctors-page-types__panel-head p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.58;
}

.doctors-page-types__query-list {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 24px 0;
}

.doctors-page-types__query-list span {
	display: inline-flex;
	align-items: center;
	min-height: 34px;
	padding: 8px 12px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 999px;
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.1;
}

.doctors-page-types__details {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
}

.doctors-page-types__detail {
	padding: 18px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	border-radius: 18px;
	background: color-mix(in srgb, var(--color-surface) 78%, transparent);
}

.doctors-page-types__detail span {
	display: block;
	margin-bottom: 8px;
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.doctors-page-types__detail p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.55;
}

.doctors-page-tools__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.doctors-page-tool-card {
	grid-template-rows: auto auto 1fr auto;
	min-height: 250px;
	padding: 24px;
	transition: transform 0.32s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.25s ease, box-shadow 0.25s ease;
}

.doctors-page-tool-card.is-observed {
	opacity: 0;
	transform: translateY(18px);
}

.doctors-page-tool-card.is-visible {
	opacity: 1;
	transform: translateY(0);
	transition: opacity 0.42s ease, transform 0.42s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.25s ease, box-shadow 0.25s ease;
}

.doctors-page-tool-card:hover,
.doctors-page-tool-card:focus-within {
	transform: translateY(-2px);
	border-color: color-mix(in srgb, var(--color-blue) 38%, transparent);
	box-shadow: 0 14px 30px color-mix(in srgb, var(--color-bg) 10%, transparent);
}

.doctors-page-tool-card__link {
	width: fit-content;
	color: var(--color-blue);
	font-size: 14px;
	font-weight: 850;
	line-height: 1.1;
}

.doctors-page-tools__footer {
	display: flex;
	justify-content: center;
	margin-top: 30px;
}

.doctors-page-tools .doctors-page-btn--secondary {
	background: var(--color-surface);
	color: var(--color-blue);
}

.doctors-page-case__card {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 390px;
	gap: 32px;
	align-items: stretch;
	padding: 44px;
	border-radius: 30px;
	background:
		radial-gradient(circle at 92% 0%, color-mix(in srgb, var(--color-blue) 24%, transparent), transparent 32%),
		radial-gradient(circle at 8% 100%, color-mix(in srgb, var(--color-green) 15%, transparent), transparent 34%),
		linear-gradient(135deg, var(--color-bg) 0%, color-mix(in srgb, var(--color-bg) 74%, var(--color-blue) 26%) 100%);
	box-shadow: 0 22px 56px color-mix(in srgb, var(--color-bg) 20%, transparent);
}

.doctors-page-case__content {
	display: grid;
	align-content: start;
	gap: 18px;
}

.doctors-page-case__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
}

.doctors-page-case__tag {
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 6px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 16%, transparent);
	color: color-mix(in srgb, var(--color-blue) 45%, var(--color-surface) 55%);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	text-transform: uppercase;
}

.doctors-page-case__niche {
	color: color-mix(in srgb, var(--color-surface) 66%, transparent);
	font-size: 14px;
	font-weight: 750;
}

.doctors-page-case__title {
	max-width: 760px;
	color: var(--color-surface);
}

.doctors-page-case__desc {
	max-width: 760px;
	margin: 0;
	color: color-mix(in srgb, var(--color-surface) 72%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.62;
}

.doctors-page-case .doctors-page-btn--secondary {
	width: fit-content;
	margin-top: 8px;
	border-color: color-mix(in srgb, var(--color-surface) 24%, transparent);
	background: color-mix(in srgb, var(--color-surface) 10%, transparent);
	color: var(--color-surface);
}

.doctors-page-case__metrics {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}

.doctors-page-case__metric {
	display: grid;
	align-content: center;
	gap: 8px;
	min-height: 132px;
	padding: 22px;
	border: 1px solid color-mix(in srgb, var(--color-surface) 14%, transparent);
	border-radius: 22px;
	background: color-mix(in srgb, var(--color-surface) 9%, transparent);
	box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-surface) 16%, transparent);
}

.doctors-page-case__metric-value {
	color: color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	font-size: 38px;
	font-weight: 950;
	line-height: 1;
}

.doctors-page-case__metric-label {
	color: color-mix(in srgb, var(--color-surface) 68%, transparent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.32;
}

.doctors-page-process__steps {
	position: relative;
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
}

.doctors-page-process__steps::before {
	content: "";
	position: absolute;
	left: 8%;
	right: 8%;
	top: 24px;
	height: 1px;
	background: color-mix(in srgb, var(--color-blue) 16%, transparent);
}

.doctors-page-process-step {
	position: relative;
	display: grid;
	gap: 14px;
	justify-items: center;
	text-align: center;
}

.doctors-page-process-step__head {
	position: relative;
	z-index: 1;
	display: grid;
	justify-items: center;
	gap: 8px;
	width: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--color-bg);
	font: inherit;
	cursor: pointer;
}

.doctors-page-process-step__circle {
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid color-mix(in srgb, var(--color-blue) 18%, transparent);
	border-radius: 50%;
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 16px;
	font-weight: 900;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.doctors-page-process-step.is-active .doctors-page-process-step__circle {
	border-color: var(--color-blue);
	background: var(--color-blue);
	color: var(--color-surface);
}

.doctors-page-process-step__label {
	color: var(--color-bg);
	font-size: 16px;
	font-weight: 900;
	line-height: 1.15;
}

.doctors-page-process-step__time {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 12px;
	font-weight: 850;
	line-height: 1;
}

.doctors-page-process-step__body {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	padding: 0 18px;
	border: 1px solid transparent;
	border-radius: 18px;
	background: var(--color-surface);
	transition: max-height 0.28s ease, opacity 0.28s ease, padding 0.28s ease, border-color 0.28s ease;
}

.doctors-page-process-step.is-active .doctors-page-process-step__body {
	max-height: 330px;
	opacity: 1;
	padding: 18px;
	border-color: color-mix(in srgb, var(--color-blue) 14%, transparent);
}

.doctors-page-process-step__body p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.58;
}

.doctors-page-process-step__body p + p {
	margin-top: 10px;
}

.doctors-page-process-step__result {
	color: var(--color-blue);
	font-weight: 850;
}

.doctors-page-faq__inner {
	max-width: 940px;
}

.doctors-page-faq__list {
	overflow: hidden;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 24px;
	background: var(--color-surface);
	box-shadow: 0 18px 46px color-mix(in srgb, var(--color-bg) 10%, transparent);
}

.doctors-page-faq__item + .doctors-page-faq__item {
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.doctors-page-faq__question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 22px 26px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	font-size: 16px;
	font-weight: 850;
	line-height: 1.35;
	text-align: left;
	cursor: pointer;
	transition: color 0.2s ease, background 0.2s ease;
}

.doctors-page-faq__question:hover,
.doctors-page-faq__item.is-open .doctors-page-faq__question {
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
	color: var(--color-blue);
}

.doctors-page-faq__icon {
	position: relative;
	width: 22px;
	height: 22px;
	flex: 0 0 auto;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-blue) 10%, transparent);
}

.doctors-page-faq__icon::before,
.doctors-page-faq__icon::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 10px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.doctors-page-faq__icon::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.doctors-page-faq__item.is-open .doctors-page-faq__icon::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(0deg);
}

.doctors-page-faq__answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.doctors-page-faq__item.is-open .doctors-page-faq__answer {
	max-height: 390px;
}

.doctors-page-faq__answer p {
	margin: 0;
	padding: 0 26px 24px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 500;
	line-height: 1.65;
}

.doctors-page-related__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.doctors-page-related-card {
	position: relative;
	min-height: 210px;
	display: grid;
	grid-template-rows: auto 1fr auto;
	gap: 12px;
	padding: 24px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 20px;
	background: var(--color-surface);
	box-shadow: 0 10px 24px color-mix(in srgb, var(--color-bg) 7%, transparent);
	transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.doctors-page-related-card:hover,
.doctors-page-related-card:focus-visible {
	transform: translateY(-2px);
	border-color: color-mix(in srgb, var(--color-blue) 36%, transparent);
	box-shadow: 0 14px 30px color-mix(in srgb, var(--color-bg) 10%, transparent);
}

.doctors-page-related-card__name {
	color: var(--color-bg);
	font-size: 19px;
	font-weight: 900;
	line-height: 1.15;
}

.doctors-page-related-card__desc {
	color: color-mix(in srgb, var(--color-bg) 64%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.doctors-page-related-card__arrow {
	color: var(--color-blue);
	font-size: 22px;
	font-weight: 900;
	line-height: 1;
	transition: transform 0.2s ease;
}

.doctors-page-related-card:hover .doctors-page-related-card__arrow,
.doctors-page-related-card:focus-visible .doctors-page-related-card__arrow {
	transform: translateX(4px);
}

.doctors-page-related__services {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 24px;
}

.doctors-page-related__services a {
	display: inline-flex;
	align-items: center;
	min-height: 38px;
	padding: 10px 14px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 999px;
	background: var(--color-surface);
	color: var(--color-blue);
	font-size: 14px;
	font-weight: 850;
	line-height: 1.1;
}

@media (max-width: 1180px) {
	.doctors-page-hero__inner {
		grid-template-columns: minmax(0, 1fr) 330px;
		gap: 34px;
	}

	.doctors-page-pains__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 1023px) {
	.doctors-page-hero {
		padding: 136px 0 64px;
	}

	.doctors-page-hero__inner,
	.doctors-page-types__layout,
	.doctors-page-case__card {
		grid-template-columns: 1fr;
	}

	.doctors-page-hero__visual,
	.doctors-page-profile {
		min-height: 360px;
	}

	.doctors-page-hero__title {
		font-size: 50px;
	}

	.doctors-page-hero__subtitle {
		font-size: 19px;
	}

	.doctors-page-section-head__title,
	.doctors-page-case__title {
		font-size: 42px;
	}

	.doctors-page-types__tabs {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.doctors-page-types__details,
	.doctors-page-tools__grid,
	.doctors-page-related__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.doctors-page-process__steps {
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.doctors-page-process__steps::before {
		display: none;
	}

	.doctors-page-process-step {
		justify-items: stretch;
		text-align: left;
	}

	.doctors-page-process-step__head {
		grid-template-columns: 48px minmax(0, 1fr) auto;
		align-items: center;
		justify-items: start;
		text-align: left;
	}
}

@media (max-width: 767px) {
	.doctors-page-hero {
		padding: 122px 0 52px;
	}

	.doctors-page-hero__title {
		font-size: 34px;
	}

	.doctors-page-hero__subtitle {
		font-size: 17px;
	}

	.doctors-page-section-head__title,
	.doctors-page-case__title {
		font-size: 30px;
	}

	.doctors-page-section-head__subtitle {
		font-size: 16px;
	}

	.doctors-page-hero__actions,
	.doctors-page-btn {
		width: 100%;
	}

	.doctors-page-hero__visual,
	.doctors-page-profile {
		min-height: 330px;
	}

	.doctors-page-profile {
		grid-template-columns: 58px minmax(0, 1fr);
		padding: 22px;
		border-radius: 26px;
	}

	.doctors-page-profile::before {
		inset: 14px;
		border-radius: 22px;
	}

	.doctors-page-profile__photo {
		width: 58px;
		height: 58px;
		border-radius: 18px;
	}

	.doctors-page-profile__main strong {
		font-size: 18px;
	}

	.doctors-page-profile__rating {
		padding: 16px;
	}

	.doctors-page-profile__rating span {
		font-size: 36px;
	}

	.doctors-page-profile__stats {
		grid-template-columns: 1fr;
	}

	.doctors-page-profile__stats div {
		min-height: 82px;
	}

	.doctors-page-pains,
	.doctors-page-tools,
	.doctors-page-process,
	.doctors-page-related,
	.doctors-page-types,
	.doctors-page-case,
	.doctors-page-faq {
		padding: 58px 0;
	}

	.doctors-page-pains__grid,
	.doctors-page-types__tabs,
	.doctors-page-types__details,
	.doctors-page-tools__grid,
	.doctors-page-case__metrics,
	.doctors-page-related__grid {
		grid-template-columns: 1fr;
	}

	.doctors-page-types__panel,
	.doctors-page-case__card {
		padding: 24px;
		border-radius: 22px;
	}

	.doctors-page-types__panel-head h3 {
		font-size: 26px;
	}

	.doctors-page-case__metric-value {
		font-size: 32px;
	}

	.doctors-page-process-step__head {
		grid-template-columns: 44px minmax(0, 1fr);
	}

	.doctors-page-process-step__time {
		grid-column: 2;
	}

	.doctors-page-faq__question {
		padding: 18px 20px;
		font-size: 15px;
	}

	.doctors-page-faq__answer p {
		padding: 0 20px 20px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.doctors-page-btn,
	.doctors-page-breadcrumb__link,
	.doctors-page-types__tab,
	.doctors-page-tool-card,
	.doctors-page-process-step__circle,
	.doctors-page-process-step__body,
	.doctors-page-faq__question,
	.doctors-page-faq__answer,
	.doctors-page-faq__icon::before,
	.doctors-page-faq__icon::after,
	.doctors-page-related-card,
	.doctors-page-related-card__arrow {
		transition: none;
	}

	.doctors-page-btn:hover,
	.doctors-page-btn:focus-visible,
	.doctors-page-types__tab:hover,
	.doctors-page-types__tab:focus-visible,
	.doctors-page-tool-card:hover,
	.doctors-page-related-card:hover,
	.doctors-page-related-card:focus-visible,
	.doctors-page-related-card:hover .doctors-page-related-card__arrow,
	.doctors-page-related-card:focus-visible .doctors-page-related-card__arrow {
		transform: none;
	}
}

/* ============================================================
   Case Detail Page
   ============================================================ */

.case-detail-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 64px;
	background:
		radial-gradient(circle at 86% 18%, color-mix(in srgb, var(--color-blue) 16%, transparent), transparent 32%),
		radial-gradient(circle at 12% 96%, color-mix(in srgb, var(--color-green) 13%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%) 0%, var(--color-surface) 100%);
}

.case-detail-hero__inner {
	display: grid;
	gap: 20px;
}

.case-detail-breadcrumb {
	margin-bottom: 8px;
}

.case-detail-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 700;
}

.case-detail-breadcrumb__item + .case-detail-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--color-blue) 28%);
}

.case-detail-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.case-detail-breadcrumb__link:hover,
.case-detail-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.case-detail-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-bg) 58%, var(--color-muted) 42%);
}

.case-detail-hero__meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 10px;
}

.case-detail-hero__niche,
.case-detail-hero__service-tag {
	display: inline-flex;
	align-items: center;
	min-height: 30px;
	padding: 8px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.case-detail-hero__city,
.case-detail-hero__duration,
.case-detail-hero__year {
	color: color-mix(in srgb, var(--color-bg) 54%, transparent);
	font-size: 13px;
	font-weight: 760;
	line-height: 1;
}

.case-detail-hero__city::before,
.case-detail-hero__duration::before,
.case-detail-hero__year::before {
	content: "·";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--color-blue) 28%);
}

.case-detail-hero__title {
	max-width: 980px;
	margin: 0;
	color: var(--color-bg);
	font-size: 62px;
	font-weight: 840;
	line-height: 1.06;
	letter-spacing: 0;
}

.case-detail-hero__metrics {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
	max-width: 1000px;
	margin-top: 12px;
}

.case-detail-hero__metric {
	display: grid;
	gap: 8px;
	min-height: 150px;
	padding: 24px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--color-surface) 98%, transparent), color-mix(in srgb, var(--color-surface) 88%, var(--color-blue) 12%)),
		var(--color-surface);
	box-shadow: 0 14px 34px color-mix(in srgb, var(--color-bg) 8%, transparent);
}

.case-detail-hero__metric-value {
	color: var(--color-blue);
	font-size: 48px;
	font-weight: 950;
	font-variant-numeric: tabular-nums;
	line-height: 1;
}

.case-detail-hero__metric-label {
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 800;
	line-height: 1.3;
}

.case-detail-hero__services {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
}

.case-detail-hero__service-label {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 13px;
	font-weight: 800;
}

.case-detail-hero__service-tag {
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	background: var(--color-surface);
	text-transform: none;
	transition: border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.case-detail-hero__service-tag:hover,
.case-detail-hero__service-tag:focus-visible {
	border-color: color-mix(in srgb, var(--color-blue) 40%, transparent);
	transform: translateY(-1px);
}

.case-detail-section-title {
	margin: 0;
	color: var(--color-bg);
	font-size: 42px;
	font-weight: 840;
	line-height: 1.08;
	letter-spacing: 0;
}

.case-detail-context,
.case-detail-results,
.case-detail-more {
	padding: 82px 0;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.case-detail-work,
.case-detail-timeline {
	padding: 84px 0;
	background: var(--color-surface);
}

.case-detail-context__layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 0.88fr);
	gap: 44px;
	align-items: start;
}

.case-detail-context__situation,
.case-detail-context__goal {
	display: grid;
	gap: 20px;
	padding: 30px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 24px;
	background: var(--color-surface);
	box-shadow: 0 14px 34px color-mix(in srgb, var(--color-bg) 7%, transparent);
}

.case-detail-context__situation p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.7;
}

.case-detail-context__facts,
.case-detail-context__goals {
	display: grid;
	gap: 0;
	margin: 0;
	padding: 0;
	list-style: none;
}

.case-detail-context__facts li {
	display: flex;
	justify-content: space-between;
	gap: 18px;
	padding: 13px 0;
	border-bottom: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.case-detail-context__facts li:last-child {
	border-bottom: 0;
}

.case-detail-context__fact-label {
	color: color-mix(in srgb, var(--color-bg) 58%, transparent);
	font-size: 14px;
	font-weight: 700;
}

.case-detail-context__fact-value {
	color: var(--color-bg);
	font-size: 14px;
	font-weight: 850;
	text-align: right;
}

.case-detail-context__goals {
	gap: 12px;
}

.case-detail-context__goals li {
	position: relative;
	padding-left: 26px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 15px;
	font-weight: 600;
	line-height: 1.55;
}

.case-detail-context__goals li::before {
	content: "→";
	position: absolute;
	left: 0;
	top: 0;
	color: var(--color-blue);
	font-weight: 900;
}

.case-detail-context__constraint {
	padding: 18px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 18px;
	background: color-mix(in srgb, var(--color-surface) 92%, var(--color-blue) 8%);
}

.case-detail-context__constraint-label {
	display: block;
	margin-bottom: 8px;
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.case-detail-context__constraint p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.6;
}

.case-detail-work__inner,
.case-detail-results__inner,
.case-detail-timeline__inner,
.case-detail-more__inner {
	display: grid;
	gap: 32px;
}

.case-detail-work__groups {
	display: grid;
	gap: 30px;
}

.case-detail-work-group {
	display: grid;
	gap: 14px;
}

.case-detail-work-group__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 20px;
	font-weight: 900;
	line-height: 1.2;
}

.case-detail-work-list {
	overflow: hidden;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background: var(--color-surface);
	box-shadow: 0 14px 34px color-mix(in srgb, var(--color-bg) 7%, transparent);
}

.case-detail-work-item + .case-detail-work-item {
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
}

.case-detail-work-item__head {
	width: 100%;
	display: grid;
	grid-template-columns: 40px minmax(0, 1fr) 26px;
	align-items: center;
	gap: 16px;
	padding: 20px 24px;
	border: 0;
	background: var(--color-surface);
	color: var(--color-bg);
	font: inherit;
	text-align: left;
	cursor: pointer;
	transition: background 0.2s ease, color 0.2s ease;
}

.case-detail-work-item__head:hover,
.case-detail-work-item.is-open .case-detail-work-item__head {
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%);
}

.case-detail-work-item__num {
	color: color-mix(in srgb, var(--color-bg) 42%, transparent);
	font-size: 13px;
	font-weight: 900;
	line-height: 1;
}

.case-detail-work-item__name {
	color: var(--color-bg);
	font-size: 16px;
	font-weight: 850;
	line-height: 1.25;
}

.case-detail-work-item.is-open .case-detail-work-item__name {
	color: var(--color-blue);
}

.case-detail-work-item__toggle {
	position: relative;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--color-blue) 10%, transparent);
	transition: transform 0.2s ease;
}

.case-detail-work-item__toggle::before,
.case-detail-work-item__toggle::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 10px;
	height: 2px;
	border-radius: 999px;
	background: var(--color-blue);
	transform: translate(-50%, -50%);
}

.case-detail-work-item__toggle::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.case-detail-work-item.is-open .case-detail-work-item__toggle {
	transform: rotate(45deg);
}

.case-detail-work-item__body {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.28s ease;
}

.case-detail-work-item.is-open .case-detail-work-item__body {
	max-height: 260px;
}

.case-detail-work-item__body p {
	margin: 0;
	padding: 0 24px 22px 80px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.65;
}

.case-detail-results__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
}

.case-detail-result-card {
	display: grid;
	justify-items: center;
	align-content: start;
	gap: 8px;
	min-height: 250px;
	padding: 24px 20px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background: var(--color-surface);
	text-align: center;
	box-shadow: 0 14px 34px color-mix(in srgb, var(--color-bg) 7%, transparent);
}

.case-detail-result-card__before {
	color: color-mix(in srgb, var(--color-bg) 42%, transparent);
	font-size: 13px;
	font-weight: 760;
	text-decoration: line-through;
}

.case-detail-result-card__arrow {
	color: var(--color-blue);
	font-size: 14px;
	font-weight: 900;
	line-height: 1;
}

.case-detail-result-card__after {
	color: var(--color-blue);
	font-size: 38px;
	font-weight: 950;
	font-variant-numeric: tabular-nums;
	line-height: 1;
}

.case-detail-result-card__label {
	margin: 4px 0 0;
	color: var(--color-bg);
	font-size: 14px;
	font-weight: 850;
	line-height: 1.3;
}

.case-detail-result-card__note {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 56%, transparent);
	font-size: 13px;
	font-weight: 500;
	line-height: 1.5;
}

.case-detail-results__summary {
	max-width: 820px;
	padding: 24px 28px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-left: 4px solid var(--color-blue);
	border-radius: 0 20px 20px 0;
	background: var(--color-surface);
	box-shadow: 0 14px 34px color-mix(in srgb, var(--color-bg) 7%, transparent);
}

.case-detail-results__summary p {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 16px;
	font-weight: 500;
	font-style: italic;
	line-height: 1.68;
}

.case-detail-timeline__inner {
	max-width: 900px;
}

.case-detail-timeline__list {
	position: relative;
	display: grid;
	gap: 0;
	padding-left: 34px;
}

.case-detail-timeline__list::before {
	content: "";
	position: absolute;
	left: 7px;
	top: 8px;
	bottom: 10px;
	width: 2px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 16%, transparent);
}

.case-detail-timeline-item {
	position: relative;
	padding-bottom: 34px;
}

.case-detail-timeline-item:last-child {
	padding-bottom: 0;
}

.case-detail-timeline-item__marker {
	position: absolute;
	left: -34px;
	top: 7px;
	z-index: 1;
	width: 16px;
	height: 16px;
	border: 3px solid var(--color-blue);
	border-radius: 50%;
	background: var(--color-surface);
}

.case-detail-timeline-item--final .case-detail-timeline-item__marker {
	background: var(--color-blue);
}

.case-detail-timeline-item__content {
	display: grid;
	gap: 8px;
	padding: 22px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 12%, transparent);
	border-radius: 20px;
	background: color-mix(in srgb, var(--color-surface) 96%, var(--color-blue) 4%);
}

.case-detail-timeline-item__period {
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.case-detail-timeline-item__heading {
	margin: 0;
	color: var(--color-bg);
	font-size: 18px;
	font-weight: 900;
	line-height: 1.2;
}

.case-detail-timeline-item__desc {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.65;
}

.case-detail-timeline-item__result {
	width: fit-content;
	margin-top: 4px;
	padding: 9px 12px;
	border-left: 3px solid var(--color-blue);
	border-radius: 0 12px 12px 0;
	background: color-mix(in srgb, var(--color-blue) 8%, var(--color-surface) 92%);
	color: var(--color-blue);
	font-size: 13px;
	font-weight: 850;
	line-height: 1.35;
}

.case-detail-more__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
}

.case-detail-more__all {
	flex: 0 0 auto;
	color: var(--color-blue);
	font-size: 14px;
	font-weight: 900;
	line-height: 1;
}

.case-detail-more__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.case-detail-not-found {
	padding: 150px 0 90px;
	background: var(--color-surface);
}

.case-detail-not-found h1 {
	margin: 0 0 12px;
	color: var(--color-bg);
	font-size: 44px;
	font-weight: 850;
	line-height: 1.1;
}

.case-detail-not-found p {
	margin: 0 0 22px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 18px;
	font-weight: 500;
	line-height: 1.5;
}

.case-detail-not-found a {
	color: var(--color-blue);
	font-weight: 900;
}

.case-detail-breadcrumb__link:focus-visible,
.case-detail-hero__service-tag:focus-visible,
.case-detail-work-item__head:focus-visible,
.case-detail-more__all:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

@media (max-width: 1180px) {
	.case-detail-results__grid,
	.case-detail-more__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 1023px) {
	.case-detail-hero {
		padding: 136px 0 58px;
	}

	.case-detail-hero__title {
		font-size: 48px;
	}

	.case-detail-context__layout {
		grid-template-columns: 1fr;
	}

	.case-detail-section-title {
		font-size: 36px;
	}
}

@media (max-width: 767px) {
	.case-detail-hero {
		padding: 122px 0 46px;
	}

	.case-detail-hero__title {
		font-size: 32px;
	}

	.case-detail-hero__metrics,
	.case-detail-results__grid,
	.case-detail-more__grid {
		grid-template-columns: 1fr;
	}

	.case-detail-hero__metric {
		min-height: 124px;
		padding: 22px;
	}

	.case-detail-hero__metric-value {
		font-size: 38px;
	}

	.case-detail-context,
	.case-detail-results,
	.case-detail-more,
	.case-detail-work,
	.case-detail-timeline {
		padding: 58px 0;
	}

	.case-detail-context__situation,
	.case-detail-context__goal {
		padding: 24px;
		border-radius: 22px;
	}

	.case-detail-context__facts li {
		display: grid;
		gap: 5px;
	}

	.case-detail-context__fact-value {
		text-align: left;
	}

	.case-detail-section-title {
		font-size: 30px;
	}

	.case-detail-work-item__head {
		grid-template-columns: 34px minmax(0, 1fr) 24px;
		gap: 12px;
		padding: 18px 20px;
	}

	.case-detail-work-item__body p {
		padding: 0 20px 20px 66px;
	}

	.case-detail-result-card__after {
		font-size: 32px;
	}

	.case-detail-results__summary {
		padding: 22px;
	}

	.case-detail-more__header {
		align-items: flex-start;
		flex-direction: column;
	}
}

@media (prefers-reduced-motion: reduce) {
	.case-detail-breadcrumb__link,
	.case-detail-hero__service-tag,
	.case-detail-work-item__head,
	.case-detail-work-item__toggle,
	.case-detail-work-item__body {
		transition: none;
	}

	.case-detail-hero__service-tag:hover,
	.case-detail-hero__service-tag:focus-visible,
	.case-detail-work-item.is-open .case-detail-work-item__toggle {
		transform: none;
	}
}

/* ============================================================
   Article Detail Page
   ============================================================ */

.article-detail-hero {
	position: relative;
	overflow: hidden;
	padding: 154px 0 46px;
	background:
		radial-gradient(circle at 86% 18%, color-mix(in srgb, var(--color-blue) 16%, transparent), transparent 32%),
		radial-gradient(circle at 10% 100%, color-mix(in srgb, var(--color-green) 12%, transparent), transparent 34%),
		linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 94%, var(--color-blue) 6%) 0%, var(--color-surface) 100%);
}

.article-detail-hero__inner {
	display: grid;
	gap: 18px;
}

.article-detail-breadcrumb {
	margin-bottom: 8px;
}

.article-detail-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 13px;
	font-weight: 700;
}

.article-detail-breadcrumb__item + .article-detail-breadcrumb__item::before {
	content: "/";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--color-blue) 28%);
}

.article-detail-breadcrumb__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}

.article-detail-breadcrumb__link:hover,
.article-detail-breadcrumb__link:focus-visible {
	color: var(--color-blue);
}

.article-detail-breadcrumb__item--current {
	color: color-mix(in srgb, var(--color-bg) 58%, var(--color-muted) 42%);
}

.article-detail-hero__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px 14px;
}

.article-detail-hero__category {
	display: inline-flex;
	align-items: center;
	min-height: 30px;
	padding: 8px 12px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-blue) 10%, var(--color-surface) 90%);
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
	transition: background 0.2s ease;
}

.article-detail-hero__category:hover,
.article-detail-hero__category:focus-visible {
	background: color-mix(in srgb, var(--color-blue) 16%, var(--color-surface) 84%);
}

.article-detail-hero__date,
.article-detail-hero__read {
	color: color-mix(in srgb, var(--color-bg) 54%, transparent);
	font-size: 13px;
	font-weight: 760;
	line-height: 1;
}

.article-detail-hero__date::before,
.article-detail-hero__read::before {
	content: "·";
	margin-right: 8px;
	color: color-mix(in srgb, var(--color-line) 72%, var(--color-blue) 28%);
}

.article-detail-hero__title {
	max-width: 940px;
	margin: 0;
	color: var(--color-bg);
	font-size: 58px;
	font-weight: 840;
	line-height: 1.08;
	letter-spacing: 0;
}

.article-detail-hero__lead {
	max-width: 780px;
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 20px;
	font-weight: 500;
	line-height: 1.65;
}

.article-detail-hero__author {
	display: flex;
	align-items: center;
	gap: 12px;
	max-width: 780px;
	margin-top: 8px;
	padding-top: 20px;
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
}

.article-detail-author-avatar {
	width: 42px;
	height: 42px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
	border-radius: 50%;
	background: linear-gradient(135deg, color-mix(in srgb, var(--color-blue) 78%, var(--color-green) 22%), var(--color-blue));
	color: var(--color-surface);
	font-size: 13px;
	font-weight: 950;
	line-height: 1;
}

.article-detail-author-avatar--large {
	width: 58px;
	height: 58px;
	font-size: 16px;
}

.article-detail-hero__author-info {
	display: grid;
	gap: 3px;
}

.article-detail-hero__author-name {
	color: var(--color-bg);
	font-size: 14px;
	font-weight: 850;
	line-height: 1.2;
}

.article-detail-hero__author-role {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 12px;
	font-weight: 700;
	line-height: 1.25;
}

.article-detail-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: 34px;
	align-items: start;
	padding-top: 48px;
	padding-bottom: 84px;
}

.article-detail-layout__main,
.article-detail-layout__sidebar {
	min-width: 0;
}

.article-detail-progress {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 80;
	height: 3px;
	background: color-mix(in srgb, var(--color-line) 68%, transparent);
}

.article-detail-progress__bar {
	width: 0;
	height: 100%;
	background: var(--color-blue);
	transition: width 0.1s linear;
}

.article-detail-content {
	display: grid;
	gap: 30px;
}

.article-detail-toc {
	padding: 22px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background: var(--color-surface);
	box-shadow: 0 12px 30px color-mix(in srgb, var(--color-bg) 8%, transparent);
}

.article-detail-toc[hidden] {
	display: none;
}

.article-detail-toc__title {
	margin: 0 0 12px;
	color: color-mix(in srgb, var(--color-bg) 48%, transparent);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.article-detail-toc__list {
	display: grid;
	gap: 7px;
	margin: 0;
	padding: 0;
	list-style: none;
	counter-reset: article-toc;
}

.article-detail-toc__list li {
	counter-increment: article-toc;
}

.article-detail-toc__list a {
	display: flex;
	align-items: baseline;
	gap: 8px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.35;
	transition: color 0.2s ease;
}

.article-detail-toc__list a::before {
	content: counter(article-toc) ".";
	color: color-mix(in srgb, var(--color-bg) 42%, transparent);
	font-size: 12px;
	font-weight: 900;
}

.article-detail-toc__list a:hover,
.article-detail-toc__list a:focus-visible,
.article-detail-toc__list a.is-active {
	color: var(--color-blue);
}

.article-detail-body {
	padding: 34px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 24px;
	background: var(--color-surface);
	box-shadow: 0 14px 34px color-mix(in srgb, var(--color-bg) 7%, transparent);
	color: color-mix(in srgb, var(--color-bg) 68%, transparent);
	font-size: 17px;
	font-weight: 500;
	line-height: 1.78;
}

.article-detail-body h2 {
	margin: 2em 0 0.6em;
	color: var(--color-bg);
	font-size: 30px;
	font-weight: 850;
	line-height: 1.18;
	letter-spacing: 0;
	scroll-margin-top: 108px;
}

.article-detail-body h2:first-child {
	margin-top: 0;
}

.article-detail-body h3 {
	margin: 1.6em 0 0.55em;
	color: var(--color-bg);
	font-size: 22px;
	font-weight: 850;
	line-height: 1.25;
}

.article-detail-body p {
	margin: 0 0 1.15em;
}

.article-detail-body p:last-child {
	margin-bottom: 0;
}

.article-detail-body ul,
.article-detail-body ol {
	margin: 0 0 1.25em;
	padding-left: 22px;
}

.article-detail-body li {
	margin-bottom: 0.42em;
	line-height: 1.68;
}

.article-detail-body strong {
	color: var(--color-bg);
}

.article-detail-body a {
	color: var(--color-blue);
	text-decoration: underline;
	text-decoration-color: color-mix(in srgb, var(--color-blue) 38%, transparent);
	transition: text-decoration-color 0.2s ease;
}

.article-detail-body a:hover,
.article-detail-body a:focus-visible {
	text-decoration-color: var(--color-blue);
}

.article-detail-body blockquote {
	margin: 1.5em 0;
	padding: 18px 22px 18px 24px;
	border-left: 4px solid var(--color-blue);
	border-radius: 0 18px 18px 0;
	background: color-mix(in srgb, var(--color-blue) 6%, var(--color-surface) 94%);
	color: var(--color-bg);
	font-size: 17px;
	font-style: italic;
	font-weight: 650;
	line-height: 1.62;
}

.article-detail-body img {
	display: block;
	max-width: 100%;
	height: auto;
	margin: 1.5em 0;
	border-radius: 18px;
}

.article-detail-table-wrap {
	overflow-x: auto;
	margin: 1.5em 0;
}

.article-detail-body table {
	width: 100%;
	min-width: 520px;
	border-collapse: collapse;
	font-size: 14px;
	line-height: 1.45;
}

.article-detail-body th,
.article-detail-body td {
	padding: 12px 14px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	text-align: left;
	vertical-align: top;
}

.article-detail-body th {
	background: color-mix(in srgb, var(--color-surface) 90%, var(--color-blue) 10%);
	color: var(--color-bg);
	font-weight: 900;
}

.article-detail-body code {
	padding: 2px 6px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 6px;
	background: color-mix(in srgb, var(--color-surface) 90%, var(--color-blue) 10%);
	color: var(--color-bg);
	font-family: monospace;
	font-size: 14px;
}

.article-detail-cta-inline {
	margin: 2em 0;
	padding: 22px 24px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 22%, transparent);
	border-radius: 20px;
	background:
		radial-gradient(circle at 92% 8%, color-mix(in srgb, var(--color-blue) 15%, transparent), transparent 34%),
		color-mix(in srgb, var(--color-blue) 7%, var(--color-surface) 93%);
}

.article-detail-cta-inline__content {
	display: flex;
	align-items: center;
	gap: 18px;
	flex-wrap: wrap;
}

.article-detail-cta-inline__text {
	flex: 1 1 280px;
	margin: 0;
	color: var(--color-bg);
	font-size: 16px;
	font-weight: 850;
	line-height: 1.45;
}

.article-detail-cta-inline__btn {
	min-height: 42px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 11px 16px;
	border: 1px solid var(--color-blue);
	border-radius: 10px;
	color: var(--color-blue);
	font-size: 14px;
	font-weight: 900;
	line-height: 1;
	white-space: nowrap;
	transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.article-detail-cta-inline__btn:hover,
.article-detail-cta-inline__btn:focus-visible {
	background: var(--color-blue);
	color: var(--color-surface);
	transform: translateY(-1px);
}

.article-detail-tags,
.article-detail-share {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 9px;
}

.article-detail-tags {
	padding-top: 22px;
	border-top: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
}

.article-detail-tags__label,
.article-detail-share__label {
	color: color-mix(in srgb, var(--color-bg) 52%, transparent);
	font-size: 13px;
	font-weight: 800;
}

.article-detail-tags__tag,
.article-detail-share__btn {
	display: inline-flex;
	align-items: center;
	min-height: 34px;
	padding: 9px 12px;
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 999px;
	background: var(--color-surface);
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 13px;
	font-weight: 800;
	line-height: 1;
	transition: border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.article-detail-tags__tag:hover,
.article-detail-tags__tag:focus-visible,
.article-detail-share__btn:hover,
.article-detail-share__btn:focus-visible {
	border-color: color-mix(in srgb, var(--color-blue) 40%, transparent);
	color: var(--color-blue);
	transform: translateY(-1px);
}

.article-detail-sidebar {
	display: grid;
	gap: 20px;
	position: sticky;
	top: 150px;
}

.article-detail-sidebar-widget,
.article-detail-sidebar-cta {
	border: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	border-radius: 22px;
	background: var(--color-surface);
	box-shadow: 0 12px 30px color-mix(in srgb, var(--color-bg) 8%, transparent);
}

.article-detail-sidebar-widget {
	padding: 22px;
}

.article-detail-sidebar-widget__title {
	margin: 0 0 14px;
	padding-bottom: 12px;
	border-bottom: 1px solid color-mix(in srgb, var(--color-blue) 14%, transparent);
	color: var(--color-bg);
	font-size: 16px;
	font-weight: 900;
	line-height: 1.2;
}

.article-detail-sidebar-author {
	display: grid;
	gap: 12px;
}

.article-detail-sidebar-author__name {
	margin: 0 0 3px;
	color: var(--color-bg);
	font-size: 15px;
	font-weight: 900;
	line-height: 1.2;
}

.article-detail-sidebar-author__role {
	margin: 0 0 9px;
	color: var(--color-blue);
	font-size: 12px;
	font-weight: 850;
	line-height: 1.3;
}

.article-detail-sidebar-author__bio {
	margin: 0;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 13px;
	font-weight: 500;
	line-height: 1.6;
}

.article-detail-sidebar-cats {
	display: grid;
	gap: 0;
	margin: 0;
	padding: 0;
	list-style: none;
}

.article-detail-sidebar-cats__item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 10px 0;
	border-bottom: 1px solid color-mix(in srgb, var(--color-blue) 10%, transparent);
}

.article-detail-sidebar-cats__item:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.article-detail-sidebar-cats a {
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 13px;
	font-weight: 760;
	line-height: 1.4;
	transition: color 0.2s ease;
}

.article-detail-sidebar-cats a:hover,
.article-detail-sidebar-cats a:focus-visible {
	color: var(--color-blue);
}

.article-detail-sidebar-cats__count {
	color: color-mix(in srgb, var(--color-bg) 42%, transparent);
	font-size: 12px;
	font-weight: 800;
}

.article-detail-sidebar-cta {
	padding: 22px;
	background:
		radial-gradient(circle at 90% 0%, color-mix(in srgb, var(--color-blue) 18%, transparent), transparent 32%),
		var(--color-surface);
}

.article-detail-sidebar-cta__title {
	margin: 0 0 8px;
	color: var(--color-bg);
	font-size: 18px;
	font-weight: 900;
	line-height: 1.2;
}

.article-detail-sidebar-cta__text {
	margin: 0 0 18px;
	color: color-mix(in srgb, var(--color-bg) 62%, transparent);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}

.article-detail-sidebar-cta__button {
	min-height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 12px 18px;
	border-radius: 10px;
	background: linear-gradient(100deg, color-mix(in srgb, var(--color-blue) 74%, var(--color-green) 26%) 0%, var(--color-blue) 100%);
	color: var(--color-surface);
	font-size: 14px;
	font-weight: 900;
	line-height: 1;
	box-shadow: 0 14px 30px color-mix(in srgb, var(--color-blue) 20%, transparent);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.article-detail-sidebar-cta__button:hover,
.article-detail-sidebar-cta__button:focus-visible {
	transform: translateY(-1px);
	box-shadow: 0 18px 36px color-mix(in srgb, var(--color-blue) 26%, transparent);
}

.article-detail-more {
	padding: 64px 0 78px;
	background: color-mix(in srgb, var(--color-surface) 93%, var(--color-blue) 7%);
}

.article-detail-more__inner {
	display: grid;
	gap: 28px;
}

.article-detail-more__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
}

.article-detail-more__title {
	margin: 0;
	color: var(--color-bg);
	font-size: 42px;
	font-weight: 840;
	line-height: 1.08;
	letter-spacing: 0;
}

.article-detail-more__all {
	flex: 0 0 auto;
	color: var(--color-blue);
	font-size: 14px;
	font-weight: 900;
	line-height: 1;
}

.article-detail-more__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.article-detail-not-found {
	padding: 150px 0 90px;
	background: var(--color-surface);
}

.article-detail-not-found h1 {
	margin: 0 0 12px;
	color: var(--color-bg);
	font-size: 44px;
	font-weight: 850;
	line-height: 1.1;
}

.article-detail-not-found p {
	margin: 0 0 22px;
	color: color-mix(in srgb, var(--color-bg) 66%, transparent);
	font-size: 18px;
	font-weight: 500;
	line-height: 1.5;
}

.article-detail-not-found a {
	color: var(--color-blue);
	font-weight: 900;
}

.article-detail-breadcrumb__link:focus-visible,
.article-detail-hero__category:focus-visible,
.article-detail-toc__list a:focus-visible,
.article-detail-cta-inline__btn:focus-visible,
.article-detail-tags__tag:focus-visible,
.article-detail-share__btn:focus-visible,
.article-detail-sidebar-cats a:focus-visible,
.article-detail-sidebar-cta__button:focus-visible,
.article-detail-more__all:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--color-blue) 42%, var(--color-surface) 58%);
	outline-offset: 4px;
}

@media (max-width: 1180px) {
	.article-detail-layout {
		grid-template-columns: minmax(0, 1fr) 300px;
		gap: 24px;
	}

	.article-detail-more__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 1023px) {
	.article-detail-hero {
		padding: 136px 0 42px;
	}

	.article-detail-hero__title {
		font-size: 46px;
	}

	.article-detail-hero__lead {
		font-size: 18px;
	}

	.article-detail-layout {
		grid-template-columns: 1fr;
	}

	.article-detail-layout__sidebar {
		order: -1;
	}

	.article-detail-sidebar {
		position: static;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		align-items: start;
	}

	.article-detail-sidebar-cta {
		grid-column: 1 / -1;
	}
}

@media (max-width: 767px) {
	.article-detail-hero {
		padding: 122px 0 38px;
	}

	.article-detail-hero__title {
		font-size: 32px;
	}

	.article-detail-hero__lead {
		font-size: 16px;
	}

	.article-detail-layout {
		padding-top: 34px;
		padding-bottom: 62px;
	}

	.article-detail-sidebar,
	.article-detail-more__grid {
		grid-template-columns: 1fr;
	}

	.article-detail-body {
		padding: 24px;
		border-radius: 22px;
		font-size: 16px;
	}

	.article-detail-body h2 {
		font-size: 25px;
	}

	.article-detail-body h3 {
		font-size: 20px;
	}

	.article-detail-cta-inline__content,
	.article-detail-cta-inline__btn {
		width: 100%;
	}

	.article-detail-more {
		padding: 58px 0 64px;
	}

	.article-detail-more__header {
		align-items: flex-start;
		flex-direction: column;
	}

	.article-detail-more__title {
		font-size: 30px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.article-detail-breadcrumb__link,
	.article-detail-hero__category,
	.article-detail-progress__bar,
	.article-detail-toc__list a,
	.article-detail-body a,
	.article-detail-cta-inline__btn,
	.article-detail-tags__tag,
	.article-detail-share__btn,
	.article-detail-sidebar-cats a,
	.article-detail-sidebar-cta__button {
		transition: none;
	}

	.article-detail-cta-inline__btn:hover,
	.article-detail-cta-inline__btn:focus-visible,
	.article-detail-tags__tag:hover,
	.article-detail-tags__tag:focus-visible,
	.article-detail-share__btn:hover,
	.article-detail-share__btn:focus-visible,
	.article-detail-sidebar-cta__button:hover,
	.article-detail-sidebar-cta__button:focus-visible {
		transform: none;
	}
}

/* End */
/* /local/templates/stork/styles.css?1781074931543583 */
