/* ============================================ */
/* БЛОК: СЛАЙДЕР (slider)                      */
/* ============================================ */

/* ----- Основные стили ----- */

.slider {
	position: relative;
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 1.5rem;
}

/* Страховка от горизонтального скролла у контейнеров */
.header__container,
.slider__viewport,
.slider__track,
.mobile-menu,
.mobile-menu__content {
	max-width: 100vw;
}

.slider__viewport {
	position: relative;
	overflow: hidden;
	border-radius: 14px;
	box-shadow: var(--shadow);
	border: 1px solid rgba(255, 255, 255, 0.08);
	background: radial-gradient(120% 120% at 50% 0%, rgba(255, 255, 255, 0.06) 0%, rgba(255, 255, 255, 0.02) 100%);
	width: min(100%, 1080px);
	aspect-ratio: 1 / 1;
	margin: 0 auto;
	user-select: none;
}

.slider__track {
	display: flex;
	will-change: transform;
	transition: transform 0.6s ease;
}

.slider__slide {
	min-width: 100%;
	position: relative;
	height: 100%;
	background: #071e2d;
}

.slider__slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: saturate(1.05) contrast(1.05);
	pointer-events: none;
	user-select: none;
	-webkit-user-drag: none;
}

/* Стрелки */
.slider__arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 1px solid rgba(255, 255, 255, 0.35);
	background: rgba(10, 43, 64, 0.6);
	color: #fff;
	display: grid;
	place-items: center;
	cursor: pointer;
	transition: background 0.25s ease, transform 0.25s ease, opacity 0.25s ease;
	opacity: 0.9;
}

.slider__arrow:hover {
	background: rgba(255, 255, 255, 0.15);
	transform: translateY(-50%) scale(1.05);
}

.slider__arrow:active {
	transform: translateY(-50%) scale(0.98);
}

.slider__arrow--prev {
	left: 16px;
}

.slider__arrow--next {
	right: 16px;
}

/* Точки пагинации */
.slider__dots {
	display: flex;
	gap: 10px;
	justify-content: center;
	align-items: center;
	padding: 12px 0 0;
}

.slider__dot {
	width: 10px;
	height: 10px;
	background: rgba(255, 255, 255, 0.35);
	border-radius: 50%;
	border: 1px solid rgba(255, 255, 255, 0.5);
	transition: transform 0.25s ease, background 0.25s ease;
	cursor: pointer;
}

.slider__dot:hover {
	transform: scale(1.15);
}

.slider__dot--active {
	background: #fff;
	transform: scale(1.25);
}

/* ----- Адаптивные стили для слайдера ----- */

@media (max-width: 768px) {
	.slider__arrow {
		width: 38px;
		height: 38px;
	}
}

@media (min-width: 769px) {

	/* Уменьшаем слайдер на десктопе примерно в 2 раза (сохраняем пропорции).
	   Используем clamp для более плавного адаптивного поведения: минимальная
	   ширина 360px, идеальная ~45vw, максимум 540px. */
	.slider__viewport {
		width: clamp(360px, 45vw, 540px);
	}
}