/* ============================================================
   Drivers — две карточки с вертикальными заголовками + hotspots.
   Размеры синхронизированы с Figma:
     PC      6245:6428  (контейнер 1408)
     Tablet  6245:6492  (контейнер 992)
     Mobile  6245:6549  (контейнер 351)
   ============================================================ */

.drivers {
	background: #fff;
	color: #000;
	/* Нет горизонтальных паддингов — они в __inner */
	padding-block: 134px 48px;
}

.drivers__inner {
	width: min(100% - 32px, 1408px);
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: 0;
	position: relative;
}

/* ===== Заголовок секции ===== */
.drivers__heading {
	display: flex;
	align-items: flex-end;
	gap: 4px;
	padding-bottom: 12px;
	margin-bottom: 0;
	border-bottom: 1px solid rgba(217, 217, 217, 1);
}

.drivers__heading-label {
	font-weight: 500;
	font-size: 18px;
	line-height: 18px;
	letter-spacing: -0.05em;
	color: #000;
}

.drivers__heading-number {
	font-weight: 400;
	font-size: 10px;
	line-height: 18px;
	letter-spacing: -0.05em;
	color: #000;
}

/* ===== Viewport (клипует трек на мобильном слайдере) ===== */
.drivers__viewport {
	position: relative;
	width: 100%;
}

/* ===== Основная сетка / слайдер-трек ===== */
.drivers__grid {
	display: flex;
	gap: 12px;
	align-items: flex-start; /* кластеры прижаты сверху */
	flex-wrap: nowrap; /* PC: рядом */
	margin-top: 12px; /* отступ от divider у heading */
}

/* ===== Большая карточка ===== */
.drivers__card--main {
	flex: 1 1 0;
	min-width: 0;
	display: flex;
	gap: 12px;
	align-items: stretch;
	position: relative;
}

/* Изображение: квадрат, занимает остаток за вычетом side.
   На 1408px → 718px (Figma). */
.drivers__media {
	flex: 1 1 0;
	min-width: 0;
	position: relative;
	aspect-ratio: 1 / 1;
	background: #d9d9d9;
	overflow: hidden;
}

/* ===== Боковая колонка (vtitle + copy) ===== */
.drivers__side {
	flex: 0 0 280px;
	width: 280px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: flex-start;
	align-self: stretch; /* равна высоте media */
	min-height: 0;
}

/* ===== Вертикальный заголовок (main): 103×373, прижат к верху ===== */
.drivers__vtitle {
	display: flex;
	overflow: visible;
	flex: 0 0 auto;
	align-items: center;
	justify-content: center;
}

.drivers__vtitle span {
	display: block;
	writing-mode: vertical-lr;
	white-space: nowrap;
	font-weight: 400;
	letter-spacing: -0.05em;
	color: #000;
	line-height: 1.08;
}

.drivers__vtitle--main {
	width: 103px;
	height: 373px;
}

.drivers__vtitle--main span {
	font-size: 95.333px;
	line-height: 102.667px;
	padding-top: 33px;
}

/* ===== Copy: подпись + кнопка ===== */
.drivers__copy {
	display: flex;
	flex-direction: column;
	gap: 28px;
	padding-top: 0;
	width: 100%;
}

.drivers__caption {
	margin: 0;
	font-weight: 500;
	font-size: 21px;
	line-height: 24px;
	letter-spacing: -0.05em;
	color: #000;
}

/* ===== Малая карточка ===== */
.drivers__card--secondary {
	flex: 0 0 386px; /* 333 + 1 + 52 */
	display: flex;
	gap: 1px;
	align-items: flex-start;
}

.drivers__media--secondary {
	flex: 0 0 333px;
	width: 333px;
	position: relative;
	aspect-ratio: 1 / 1;
	background: #d9d9d9;
	overflow: hidden;
}

.drivers__vtitle--secondary {
	flex: 0 0 52px;
	width: 52px;
	height: 185px;
}

.drivers__vtitle--secondary span {
	font-size: 47.667px;
	line-height: 51.333px;
}

/* ===== Фон карточки ===== */
.drivers__bg {
	position: absolute;
	inset: 0;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
	background-color: #d9d9d9;
}

/* ===== Hotspot-маркеры ===== */
.drivers__hotspot {
	position: absolute;
	transform: translate(-50%, -50%);
	width: 22px;
	height: 22px;
	padding: 0;
	border: 1px solid rgba(217, 217, 217, 0.33);
	border-radius: 9px;
	background: #000;
	color: #fff;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	z-index: 5;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.drivers__hotspot:hover,
.drivers__hotspot:focus-visible {
	transform: translate(-50%, -50%) scale(1.1);
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.2);
}

.drivers__hotspot-mark {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 12px;
	height: 12px;
}

.drivers__hotspot-mark svg {
	width: 12px;
	height: 12px;
	display: block;
}

.drivers__hotspot-tip {
	display: none;
}

/* ===== Кнопки ===== */
.drivers__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 36px;
	padding: 9px 26px;
	border-radius: 22px;
	border: 1.33px solid transparent;
	font-weight: 500;
	font-size: 14px;
	line-height: 18px;
	letter-spacing: -0.05em;
	text-decoration: none;
	transition: opacity 0.15s ease, transform 0.15s ease;
	white-space: nowrap;
	flex-shrink: 0;
	cursor: pointer;
}

.drivers__btn--ghost {
	background: rgba(217, 217, 217, 0.33);
	padding: 9px 44px;
	border-color: rgba(150, 150, 150, 0.33);
	color: #000;
}

.drivers__btn:hover {
	opacity: 0.88;
	transform: translateY(-1px);
}

.drivers__btn--ghost:hover,
.drivers__btn--ghost:focus-visible {
	border-color: #000;
	color: #000;
	opacity: 1;
	transform: none;
}

.drivers__btn--ghost:active {
	border-color: #969696;
	color: #000;
	opacity: 1;
	transform: none;
}

.drivers__btn--ghost.is-disabled,
.drivers__btn--ghost[aria-disabled="true"] {
	border-color: rgba(217, 217, 217, 0.33);
	color: #d9d9d9;
	opacity: 1;
	transform: none;
	pointer-events: none;
}

/* ===== Footer ===== */
.drivers__footer {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 8px;
	margin-top: 0;
	position: absolute;
	right: 0;
	bottom: 1px;
}

.drivers__info {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: #000;
	text-decoration: none;
	font-size: 14px;
	font-weight: 500;
	line-height: 18px;
	letter-spacing: -0.05em;
}

.drivers__info-icon {
	width: 36px;
	height: 36px;
	border-radius: 9.536px;
	border: 1px solid rgba(217, 217, 217, 1);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	color: #000;
}

.drivers__info-icon svg {
	width: 32.571px;
	height: 32.571px;
}

.drivers__active-tip {
	position: absolute;
	left: 476px;
	bottom: 116px;
	display: block;
	width: 120px;
	padding: 9px;
	border-radius: 9px;
	background: #000;
	color: #fff;
	font-weight: 400;
	font-size: 10px;
	line-height: 12px;
	letter-spacing: -0.02em;
	white-space: normal;
	z-index: 6;
}

.drivers__active-tip:empty {
	display: none;
}

/* ============================================================
   Tablet (901–1280px): main image остаётся 718, side ужимается,
   secondary уходит строкой ниже (Figma 6245:6492, контейнер 992)
   ============================================================ */
@media (max-width: 1280px) and (min-width: 901px) {
	.drivers {
		padding-block: 60px 40px;
	}

	.drivers__grid {
		flex-wrap: wrap;
	}

	/* Main cluster — вся ширина */
	.drivers__card--main {
		flex: 1 1 100%;
	}

	/* Главная картинка фиксирована 718, как в Figma */
	.drivers__media {
		flex: 0 0 718px;
		width: 718px;
		max-width: 100%;
	}

	/* Side берёт остаток */
	.drivers__side {
		flex: 1 1 0;
		width: auto;
		min-width: 0;
	}

	.drivers__vtitle--main {
		width: 103px;
		height: 373px;
	}

	/* Secondary — строка ниже, размер из Figma 6245:6537 */
	.drivers__card--secondary {
		flex: 0 0 auto;
	}

	.drivers__media--secondary {
		flex: 0 0 388px;
		width: 388px;
	}

	.drivers__vtitle--secondary {
		flex: 0 0 60px;
		width: 60px;
		height: 216px;
	}

	.drivers__vtitle--secondary span {
		font-size: 55.54px;
		line-height: 59.812px;
	}

	.drivers__hotspot,
	.drivers__active-tip,
	.drivers__footer {
		display: none;
	}
}

/* ============================================================
   Slider-nav (стрелки под большой карточкой).
   По умолчанию скрыт; показывается на мобильном при >1 хотспоте.
   ============================================================ */
.drivers__slider-nav {
	display: none;
}

/* Overlay-подсказка — скрыта вне мобильного режима */
.drivers__slider-btn {
	width: 36px;
	height: 36px;
	padding: 0;
	border: 1.33px solid rgba(245, 245, 245, 0.33);
	border-radius: 16px;
	background: rgba(245, 245, 245, 0.33);
	color: #222;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: opacity 0.15s ease;
}

.drivers__slider-btn:hover {
	opacity: 0.6;
}

.drivers__slider-btn.is-disabled {
	opacity: 0.3;
	cursor: default;
	pointer-events: none;
}

.drivers__slider-btn svg {
	width: 15px;
	height: 13px;
	display: block;
}

/* ============================================================
   Mobile (≤900px) — Figma 6245:6549 (контейнер 351)
   Drivers__grid становится слайдер-треком: карточки-слайды на 100%
   ширины, translateX из JS переключает между main ↔ secondary.
   Viewport клипует переполнение.

   Содержимое main-карточки (слайд 1) через CSS Grid:
     row 1: media  | vtitle (Образец)
     row 2: active-tip  (текст активной подсказки под фото)
     row 3: copy        (caption + кнопка)
   Стрелки prev/next вынесены ПОД viewport (отдельным блоком).
   ============================================================ */
@media (max-width: 900px) {
	.drivers {
		padding-block: 48px 32px;
	}

	.drivers__inner {
		width: min(100% - 24px, 100%);
	}

	/* Viewport клипует горизонтальный оверфлоу трека */
	.drivers__viewport {
		overflow: hidden;
	}

	/* Трек из слайдов — JS двигает transform:translateX() */
	.drivers__grid {
		flex-direction: row;
		flex-wrap: nowrap;
		gap: 0;
		margin-top: 12px;
		align-items: stretch;
		transition: transform 650ms cubic-bezier(0.22, 1, 0.36, 1);
		will-change: transform;
		touch-action: pan-y;
	}

	.drivers__card {
		flex: 0 0 100%;
		min-width: 100%;
		max-width: 100%;
	}

	/* ===== Большая карточка (слайд 1) ===== */
	.drivers__card--main {
		width: 100%;
		display: grid;
		grid-template-columns: 1fr auto;
		grid-template-areas:
			'media vtitle'
			'tip   tip'
			'copy  copy';
		column-gap: 1px;
		row-gap: 12px;
		align-items: start;
	}

	.drivers__media {
		grid-area: media;
		width: 100%;
		flex: initial;
		aspect-ratio: 1 / 1;
	}

	/* __side пропускает детей (vtitle, copy) в грид-родителя */
	.drivers__side {
		display: contents;
	}

	/* Вертикальный заголовок «Образец» на мобильном — справа от фото */
	.drivers__vtitle--main {
		grid-area: vtitle;
		display: flex;
		width: 47px;
		height: 168px;
		align-self: start;
	}

	.drivers__vtitle--main span {
		font-size: 43.345px;
		line-height: 46.679px;
		padding-top: 23px;
	}

	.drivers__copy {
		grid-area: copy;
		padding-top: 0;
		gap: 16px;
	}

	.drivers__caption {
		font-size: 21px;
		line-height: 24px;
	}

	.drivers__btn--ghost {
		width: max-content;
	}

	/* ===== Вторичная карточка (слайд 2) ===== */
	.drivers__card--secondary {
		flex: 0 0 100%;
		width: 100%;
		gap: 1px;
		display: flex;
		align-items: flex-start;
	}

	.drivers__media--secondary {
		flex: 1 1 0;
		width: auto;
		min-width: 0;
		aspect-ratio: 1 / 1;
	}

	.drivers__vtitle--secondary {
		flex: 0 0 47px;
		width: 47px;
		height: 168px;
	}

	.drivers__vtitle--secondary span {
		font-size: 43.345px;
		line-height: 46.679px;
	}

	.drivers__footer {
		display: none;
	}

	/* ===== Слайдер-nav (снаружи viewport, между ним и footer) ===== */
	.drivers__slider-nav {
		display: flex;
		justify-content: space-between;
		align-items: center;
		width: 100%;
		margin-top: 16px;
	}

	/* На мобильном hotspot-tip внутри кнопки не показываем — текст идёт в __active-tip */
	.drivers__hotspot-tip {
		display: none;
	}

	/* Карточка-подсказка — блоком ПОД фотографией */
	.drivers__active-tip {
		grid-area: tip;
		position: static;
		left: auto;
		bottom: auto;
		display: block;
		max-width: 120px;
		padding: 9px;
		border-radius: 9px;
		background: #000;
		color: #fff;
		font-weight: 400;
		font-size: 10px;
		line-height: 12px;
		letter-spacing: -0.02em;
		white-space: normal;
		min-height: 0;
	}

	.drivers__active-tip:empty {
		display: none;
	}
}
