/* ==========================================================================
   Video Background Slider — фронтенд
   ========================================================================== */

.vslider {
	--vs-accent: #aa9874;
	--vs-height: 88vh;
	--vs-overlay: 0.45;

	position: relative;
	width: 100%;
	height: var(--vs-height);
	min-height: 420px;
	overflow: hidden;
	color: #fff;
	font-family: inherit;
}

/* --- Видео-фон: фиксированный слой, не двигается при перелистывании --- */
.vslider__bg {
	position: absolute;
	inset: 0;
	z-index: 1;
}

.vslider__video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.vslider__overlay {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,.55) 100%),
		rgba(0, 0, 0, var(--vs-overlay));
}

/* --- Слайдер поверх видео --- */
.vslider__swiper {
	position: relative;
	z-index: 2;
	width: 100%;
	height: 100%;
}

/* Прозрачный слайд: виден только контент */
.vslider__slide {
	display: flex;
	align-items: center;
	background: transparent;
}

.vslider__content {
	width: 100%;
	max-width: 1180px;
	margin: 0 auto;
	padding: 0 clamp(20px, 6vw, 90px);
	box-sizing: border-box;
}

.vslider__badge {
	display: inline-block;
	font-size: 13px;
	letter-spacing: .18em;
	text-transform: uppercase;
	font-weight: 700;
	color: var(--vs-accent);
	padding: 6px 14px;
	border: 1px solid currentColor;
	border-radius: 2px;
	margin-bottom: 22px;
}

/* Цвет задан с !important и -webkit-text-fill-color, чтобы тема сайта
   не перебивала его своими правилами для h2/p (частая причина «невидимого» текста). */
.vslider .vslider__title {
	color: #fff !important;
	-webkit-text-fill-color: #fff;
	font-size: clamp(30px, 5.2vw, 64px);
	line-height: 1.05;
	font-weight: 800;
	margin: 0 0 18px;
	max-width: 16ch;
	text-shadow: 0 2px 24px rgba(0, 0, 0, .55);
}

.vslider .vslider__text {
	color: #fff !important;
	-webkit-text-fill-color: #fff;
	font-size: clamp(15px, 1.4vw, 19px);
	line-height: 1.6;
	max-width: 46ch;
	margin: 0 0 32px;
	opacity: .95;
	text-shadow: 0 1px 14px rgba(0, 0, 0, .5);
}

.vslider__meta {
	display: flex;
	align-items: center;
	gap: 28px;
	flex-wrap: wrap;
}

.vslider__price {
	font-size: clamp(26px, 3vw, 38px);
	font-weight: 800;
	color: var(--vs-accent);
	text-shadow: 0 2px 18px rgba(0, 0, 0, .4);
}

.vslider__btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 15px 36px;
	background: var(--vs-accent);
	color: #fff !important;
	-webkit-text-fill-color: #fff;
	font-weight: 700;
	font-size: 16px;
	text-decoration: none;
	border-radius: 3px;
	transition: transform .25s ease, filter .25s ease, box-shadow .25s ease;
	box-shadow: 0 10px 30px -8px rgba(0, 0, 0, .5);
}

.vslider__btn:hover {
	transform: translateY(-2px);
	filter: brightness(1.08);
	box-shadow: 0 16px 38px -8px rgba(0, 0, 0, .55);
}

/* --- Навигация --- */
.vslider .swiper-button-prev,
.vslider .swiper-button-next {
	width: 52px;
	height: 52px;
	border-radius: 50%;
	background: rgba(255, 255, 255, .12);
	backdrop-filter: blur(6px);
	border: 1px solid rgba(255, 255, 255, .25);
	color: #fff;
	transition: background .25s ease;
}

.vslider .swiper-button-prev:hover,
.vslider .swiper-button-next:hover {
	background: var(--vs-accent);
	border-color: var(--vs-accent);
}

.vslider .swiper-button-prev::after,
.vslider .swiper-button-next::after {
	font-size: 18px;
	font-weight: 700;
}

.vslider .swiper-pagination-bullet {
	width: 10px;
	height: 10px;
	background: #fff;
	opacity: .45;
	transition: opacity .25s ease, width .25s ease;
}

.vslider .swiper-pagination-bullet-active {
	opacity: 1;
	width: 26px;
	border-radius: 6px;
	background: var(--vs-accent);
}

/* --- Анимация контента при смене слайда --- */
.vslider__slide .vslider__content > * {
	opacity: 0;
	transform: translateY(26px);
}

.vslider__slide.swiper-slide-active .vslider__content > * {
	animation: vsliderIn .7s cubic-bezier(.2, .7, .2, 1) forwards;
}

.vslider__slide.swiper-slide-active .vslider__badge { animation-delay: .05s; }
.vslider__slide.swiper-slide-active .vslider__title { animation-delay: .15s; }
.vslider__slide.swiper-slide-active .vslider__text  { animation-delay: .25s; }
.vslider__slide.swiper-slide-active .vslider__meta  { animation-delay: .35s; }

@keyframes vsliderIn {
	to { opacity: 1; transform: translateY(0); }
}

/* --- Планшеты и мобильные: стрелки уходят вниз, чтобы не перекрывать текст --- */
@media (max-width: 768px) {
	.vslider .swiper-button-prev,
	.vslider .swiper-button-next {
		top: auto;
		bottom: 18px;
		margin-top: 0;
		width: 42px;
		height: 42px;
	}

	.vslider .swiper-button-next { right: 16px; left: auto; }
	.vslider .swiper-button-prev { right: 68px; left: auto; }

	.vslider .swiper-button-prev::after,
	.vslider .swiper-button-next::after {
		font-size: 15px;
	}

	/* Точки — слева внизу, чтобы не пересекались со стрелками */
	.vslider .swiper-pagination {
		bottom: 30px;
		left: clamp(20px, 6vw, 90px);
		width: auto;
		text-align: left;
	}

	/* Контент приподнят, чтобы кнопка не уходила под стрелки */
	.vslider__content {
		padding-bottom: 84px;
	}

	/* Кнопка компактнее */
	.vslider__btn {
		padding: 12px 26px;
		font-size: 15px;
	}

	.vslider__meta {
		gap: 18px;
	}
}

@media (max-width: 640px) {
	.vslider { --vs-height: 80vh; }
}

@media (prefers-reduced-motion: reduce) {
	.vslider__slide .vslider__content > * { opacity: 1; transform: none; animation: none; }
}
