/**
 * Блок «Направления» — макет AMSI 2.0 / Figma.
 * Карточка: 389.33×399.43; иконка 64×64; градиентная линия сверху при hover.
 */

.wp-block-acf-directions {
	margin: 0;
	max-width: none !important;
	width: 100%;
	min-width: 0;
}

.amsi-directions {
	--dir-navy: #0b132b;
	--dir-blue: #0000ff;
	--dir-cyan: #48cae4;
	--dir-text-muted: rgba(11, 19, 43, 0.65);
	/* Текст в карточке: #0B132B 60 % */
	--dir-card-text-color: rgba(11, 19, 43, 0.6);
	--dir-icon-rest-bg: #f5f7fa;

	--dir-max: 1232px;
	--dir-gap: 24px;

	--dir-card-pad-x: 40px;
	--dir-card-pad-y: 40px;
	--dir-card-radius: 24px;
	/* Stroke inside в Figma: 0.75 px, #0B132B 4 % */
	--dir-card-border: rgba(11, 19, 43, 0.04);
	--dir-card-border-w: 0.75px;
	--dir-card-shadow: 0 4px 24px rgba(11, 19, 43, 0.06);

	--dir-stripe-h: 3px;
	/* Градиент полоски hover (Figma → правый край в cyan) */
	--dir-stripe-gradient: linear-gradient(
		90deg,
		var(--dir-stripe-grad-start, #0000ff) 0%,
		var(--dir-stripe-grad-end, #48cae4) 100%
	);

	--dir-icon-box: 64px;
	--dir-icon-radius: 12px;
	--dir-icon-svg: 40px;
	--dir-icon-mb: 31px;

	/* Десктоп: Montserrat Bold 24 / Regular 16 / SemiBold 14 + 0.7px tracking */
	--dir-title-fs: 24px;
	--dir-title-lh: 28px;
	--dir-title-mb: 16px;

	--dir-text-fs: 16px;
	--dir-text-lh: 24px;
	--dir-text-mb: 20px;

	--dir-cta-fs: 14px;
	--dir-cta-lh: 20px;
	--dir-cta-track: 0.7px;

	--dir-pad-x: clamp(16px, 4vw, 24px);

	position: relative;
	overflow-x: visible;
	overflow-y: visible;
	width: 100%;
	min-width: 0;
	background: #fff;
	color: var(--dir-navy);
	font-family: var(--amsi-font, "Montserrat", system-ui, sans-serif);
	padding-top: clamp(56px, 7vw, 96px);
	padding-bottom: clamp(56px, 7vw, 96px);
}

.amsi-directions::before {
	content: "";
	position: absolute;
	right: 0;
	top: 10%;
	width: min(320px, 85vw);
	height: min(320px, 85vw);
	max-width: 100%;
	border-radius: 50%;
	background: rgba(72, 202, 228, 0.06);
	filter: blur(90px);
	pointer-events: none;
	z-index: 0;
}

.amsi-directions__inner {
	position: relative;
	z-index: 1;
	box-sizing: border-box;
	width: 100%;
	max-width: var(--dir-max);
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--dir-pad-x);
	padding-right: var(--dir-pad-x);
	min-width: 0;
}

.amsi-directions__header {
	text-align: center;
	margin-bottom: clamp(32px, 5vw, 48px);
	max-width: 100%;
	min-width: 0;
}

.amsi-directions__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: max-content;
	max-width: 100%;
	margin: 0 0 16px;
	padding: 8px 22px;
	border-radius: 9999px;
	background: var(--dir-blue);
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	line-height: 16px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	box-sizing: border-box;
	white-space: normal;
	text-align: center;
}

.amsi-directions__badge-dot {
	flex-shrink: 0;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--dir-cyan);
}

.amsi-directions__badge-text {
	min-width: 0;
	max-width: 100%;
	white-space: normal;
	text-wrap: balance;
}

.amsi-directions__title {
	margin: 0 0 12px;
	font-size: clamp(28px, 4.5vw, 56px);
	font-weight: 700;
	line-height: 1.12;
	letter-spacing: -0.02em;
	color: var(--dir-navy);
	word-wrap: break-word;
	overflow-wrap: anywhere;
}

.amsi-directions__intro {
	margin: 0 auto;
	max-width: min(640px, 100%);
	font-size: 20px;
	line-height: 26px;
	color: var(--dir-text-muted);
}

.amsi-directions__intro p {
	margin: 0;
}

/* Сетка: 3 колонки на десктопе (макет 6 карточек = 2 ряда) */
.amsi-directions__grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--dir-gap);
	width: 100%;
	min-width: 0;
	align-items: stretch;
}

.amsi-directions__item {
	min-width: 0;
	display: flex;
}

.amsi-directions__card {
	position: relative;
	overflow: hidden;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	width: 100%;
	height: 100%;
	min-height: 100%;
	padding: var(--dir-card-pad-y) var(--dir-card-pad-x);
	border-radius: var(--dir-card-radius);
	border: var(--dir-card-border-w) solid var(--dir-card-border);
	background: #fff;
	box-shadow: var(--dir-card-shadow);
	text-decoration: none !important;
	color: inherit !important;
	transition:
		transform 0.28s cubic-bezier(0.4, 0, 0.2, 1),
		box-shadow 0.28s ease,
		border-color 0.28s ease;
}

/* Градиентная линия сверху — только при hover / focus-visible */
.amsi-directions__card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: var(--dir-stripe-h);
	background: var(--dir-stripe-gradient);
	border-radius: var(--dir-card-radius) var(--dir-card-radius) 0 0;
	opacity: 0;
	transition: opacity 0.28s ease;
	pointer-events: none;
}

a.amsi-directions__card {
	cursor: pointer;
}

.amsi-directions__card:hover,
.amsi-directions__card:focus-visible {
	transform: translateY(-4px);
	border-color: rgba(0, 0, 255, 0.28);
	box-shadow:
		0 16px 48px rgba(0, 0, 255, 0.1),
		0 4px 16px rgba(11, 19, 43, 0.06);
}

.amsi-directions__card:hover::before,
.amsi-directions__card:focus-visible::before {
	opacity: 1;
}

a.amsi-directions__card:focus-visible {
	outline: 2px solid var(--dir-blue);
	outline-offset: 2px;
}

.amsi-directions__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: var(--dir-icon-box);
	height: var(--dir-icon-box);
	margin-bottom: var(--dir-icon-mb);
	border-radius: var(--dir-icon-radius);
	color: var(--dir-blue);
	background: var(--dir-icon-rest-bg);
	border: 1px solid rgba(11, 19, 43, 0.06);
	transition:
		background 0.28s ease,
		border-color 0.28s ease,
		color 0.28s ease;
}

.amsi-directions__card:hover .amsi-directions__icon,
.amsi-directions__card:focus-visible .amsi-directions__icon {
	background: var(--dir-blue);
	color: #fff;
	border-color: transparent;
}

.amsi-directions__icon .amsi-directions__svg {
	display: block;
	width: var(--dir-icon-svg);
	height: var(--dir-icon-svg);
	flex-shrink: 0;
}

.amsi-directions__card-main {
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
	align-items: flex-start;
	width: 100%;
	min-height: 0;
	text-align: left;
}

.amsi-directions__card-title {
	margin: 0 0 var(--dir-title-mb);
	font-size: var(--dir-title-fs);
	font-weight: 700;
	line-height: var(--dir-title-lh);
	letter-spacing: -0.01em;
	color: var(--dir-navy);
}

.amsi-directions__card-text {
	margin: 0 0 var(--dir-text-mb);
	font-size: var(--dir-text-fs);
	font-weight: 400;
	/* line-height: var(--dir-text-lh); */
	color: var(--dir-card-text-color);
	flex: 1 1 auto;
}

.amsi-directions__card-text p {
	margin: 0 0 0.5rem;
}

.amsi-directions__card-text p:last-child {
	margin-bottom: 0;
}

.amsi-directions__card-more {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: auto;
	font-size: var(--dir-cta-fs);
	font-weight: 600;
	line-height: var(--dir-cta-lh);
	letter-spacing: var(--dir-cta-track);
	text-transform: uppercase;
	color: var(--dir-blue);
	transition: gap 0.22s ease;
}

.amsi-directions__card:hover .amsi-directions__card-more,
.amsi-directions__card:focus-visible .amsi-directions__card-more {
	gap: 10px;
}

.amsi-directions__card-arrow {
	display: block;
	flex-shrink: 0;
	width: 20px;
	height: 20px;
	vertical-align: middle;
	transition: transform 0.22s ease;
}

.amsi-directions__card:hover .amsi-directions__card-arrow,
.amsi-directions__card:focus-visible .amsi-directions__card-arrow {
	transform: translateX(3px);
}

.amsi-directions__empty {
	margin: 0;
	padding: 2rem;
	text-align: center;
	color: var(--dir-card-text-color);
	font-size: 15px;
	line-height: 24px;
	border-radius: var(--dir-card-radius);
	border: 0.75px dashed rgba(11, 19, 43, 0.15);
}

/* Кнопка «Все услуги» под сеткой */
.amsi-directions__footer {
	margin-top: clamp(40px, 5vw, 56px);
	text-align: center;
}

.amsi-directions__footer-cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	box-sizing: border-box;
	min-height: 56px;
	height: auto;
	padding: 18px 36px;
	border-radius: 14px;
	background: var(--dir-blue);
	color: #fff;
	font-size: 16px;
	font-weight: 700;
	line-height: 1.25;
	font-family: inherit;
	text-decoration: none !important;
	box-shadow: 0 10px 24px rgba(0, 0, 255, 0.22);
	transition:
		background 0.25s ease,
		box-shadow 0.25s ease,
		transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

.amsi-directions__footer-cta:hover {
	background: #1a1aff;
	box-shadow: 0 14px 32px rgba(0, 0, 255, 0.32);
	transform: translateY(-2px);
	color: #fff;
}

.amsi-directions__footer-cta:focus-visible {
	background: #1a1aff;
	box-shadow: 0 14px 32px rgba(0, 0, 255, 0.32);
	transform: translateY(-2px);
	color: #fff;
	outline: 2px solid var(--dir-navy);
	outline-offset: 3px;
}

.amsi-directions__footer-cta-text {
	display: inline-block;
}

.amsi-directions__footer-cta-arrow {
	display: block;
	flex-shrink: 0;
	width: 22px;
	height: 22px;
	transition: transform 0.22s ease;
}

.amsi-directions__footer-cta:hover .amsi-directions__footer-cta-arrow,
.amsi-directions__footer-cta:focus-visible .amsi-directions__footer-cta-arrow {
	transform: translateX(3px);
}

/* Десктоп (3 колонки): высота карточки по макету ~399px */
@media (min-width: 1024px) {
	.amsi-directions__card {
		min-height: 399px;
	}
}

/* Планшет: 2 колонки */
@media (max-width: 1023px) {
	.amsi-directions__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

/* Мобилка: одна колонка */
@media (max-width: 639px) {
	.amsi-directions__grid {
		grid-template-columns: 1fr;
	}

	.amsi-directions {
		--dir-card-pad-x: 20px;
		--dir-card-pad-y: 20px;
		--dir-title-fs: 18px;
		--dir-title-lh: 24px;
		--dir-text-fs: 15px;
		--dir-text-lh: 22px;
		--dir-cta-fs: 13px;
		--dir-cta-lh: 18px;
	}
}

@media (max-width: 479px) {
	.amsi-directions__badge {
		font-size: 10px;
		line-height: 14px;
		letter-spacing: 0.14em;
		padding: 8px 16px;
		white-space: normal;
		text-align: center;
	}
}
