.button-disabled {
	opacity: 0.6;
	pointer-events: none;
	cursor: not-allowed;
}

/* xs */
:root {
	--black: #010101;
	--white: #FDFDFD;
	--yellow: #FDCC0D;
	--red: #E30613;

	--black-hover: #000000;
	--white-hover: #e0e0e0;
	--yellow-hover: #e5b800;
	--red-hover: #b3000f;

	--black-light: #1a1a1a;
	--white-pure: #ffffff;
	--yellow-light: #fed94d;
	--red-light: #ff333f;
}

* {
	outline: none !important;
}

body {
	background: var(--black);
	color: var(--white);
	margin: 0;
	font-family: 'Inter', sans-serif;
	line-height: 1.3;
	font-weight: 400;
	padding: 0 !important;
}
/*.modal {*/
/*	padding: 0 !important;*/
/*	background: rgb(0 0 0 / 50%);*/
/*}*/
#show {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: 100vh;
	height: 700px;
}
#show {
	background: url("/image/catalog/example/site/bg-show.jpg") center cover;
}
#show::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	z-index: 1;
}
#show::before {
	background: linear-gradient(180deg, transparent 40%, #000 75%, #000 100%);
}
#team .swiper-slide .box-team {
	transition: transform 0.35s ease;
	transform-origin: center center;
}

#team .swiper-slide-active .box-team {
	z-index: 2;
}
#team .smart-padding .swiper,
#tours .smart-padding .swiper {
	padding-left: 0 !important;
	padding-right: 0 !important;
}
.container {
	position: relative;
	z-index: 1;
}
h1 {
	font-family: 'Bona Nova SC', serif;
	font-weight: 700;
	font-size: 60px;
	text-transform: uppercase;
	line-height: 100%;
	color: var(--yellow) !important;
	margin-bottom: 0;
	font-style: normal;
}
h1 span {
	font-size: 36px;
	text-align: center;
	line-height: 100% !important;
}
h1 span.text-part-first {
	display: block;
}
h1 span.text-part-second {
	white-space: nowrap;
}
h1 span.text-part-third {
	display: block;
	font-size: 56px;
	line-height: 64px;
}
h2 {
	margin-bottom: 0.5rem;
	padding: 1rem 0;
}
h2,
.timer-number {
	font-weight: 500;
	font-size: 30px;
	line-height: 38px;
}
.text-extract {
	color: var(--yellow) !important;
}
.ff-bn-sc {
	font-family: 'Bona Nova SC', serif;
}
p {
	font-size: 16px;
	line-height: 120%;
	letter-spacing: 0;
}
.muffle-60 {
	opacity: 60% !important;
}
.muffle-80 {
	opacity: 80% !important;
}

html, body {
	min-width: 360px;
	overflow-x: hidden;
}
.categories__bottom {
	margin-top: 2rem;
}
#home.main,
#home.product {
	min-height: 720px !important;
}
#home.main {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	height: 100vh;
	height: 100svh;
	background: url(/image/catalog/example/site/home-tablet.webp) center 0px no-repeat;
	background-size: cover;
}
#home.main .container {
	padding-top: 1.5rem;
	padding-bottom: 1.5rem;
	margin-top: 126px;
	width: calc(100% - 24px);
}
#home.main .top-content {
	text-align: center;
}
#home.main h1 {
	margin-bottom: 1rem;
}
#home.main p {
	font-size: 15px;
}
#home.product {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	height: 100vh;
	height: 100svh;
	background: url(/image/catalog/example/site/show-tablet.webp) center -120px no-repeat;
	background-size: cover;
}
#home.product .container {
	padding-top: 1.5rem;
	padding-bottom: 3rem;
	margin-top: 126px;
	width: calc(100% - 24px);
}
#home.product .top-content {
	text-align: center;
}
#home.product h1 {
	margin-bottom: 1rem;
}
#home.product p {
	font-size: 15px;
}
.box-details {
	padding: 0.6rem 1rem;
	background: rgba(253, 253, 253, 0.09);
	border: 1px solid rgba(253, 253, 253, 0.12);
	backdrop-filter: blur(20px);
	border-radius: 20px;
	padding: 0.75rem;
}
.box-details.box-details__first {
	padding: 0.375rem 0.75rem;
}
.box-details .box-details__title {
	margin-bottom: 0.5rem;
}
.box-details .box-details__title,
.box-details .box-details__value {
	font-size: 10px;
	display: block;
}
.box-details__rating {
	border: 1px solid var(--yellow);
	border-radius: 50%;
}
.box-details__rating span {
	font-size: 15px;
	line-height: 143%;
	padding: 7px;
	display: inline-block;
}
.pe-0375 {
	padding-right: .375rem !important;
}
.ps-0375 {
	padding-left: .375rem !important;
}
.pe-075 {
	padding-right: .75rem !important;
}
.ps-075 {
	padding-left: .75rem !important;
}
.btn-long {
	width: 100%;
	max-width: 100% !important;
}

#menu {
	padding: 0.5rem;
}
#menu:not(.opened).active {
	backdrop-filter: blur(10px);
}
#menu:not(.opened) .container {
	background: rgba(1, 1, 1, 0.7);
	border: 1px solid rgba(1, 1, 1, 0.4);
	backdrop-filter: blur(10px);
	border-radius: 20px;
	padding: .25rem .5rem;
}
#menu.opened .nooffcanvas {
	opacity: 0 !important;
}
#menu .nav-link {
	color: var(--white) !important;
	font-size: 18px;
	transition: all 0.2s;
	font-weight: 400;
	text-decoration: none !important;
}
#menu .nav-link[href]:hover {
	color: var(--yellow) !important;
}
#menu .nav-link:not([href]) {
	pointer-events: none;
	user-select: none;
	color: rgb(253 253 253 / 60%) !important;
}

.btn {
	font-size: 14px;
	font-weight: 500;
	border-radius: 35px;
	padding: 0.75rem 1rem;
	border-width: 1px;
	white-space: nowrap;
}
.btn,
.btn * {
	transition: all 0.2s;
}
.btn-yellow {
	background-color: var(--yellow) !important;
	border-color: var(--yellow) !important;
	color: var(--black) !important;
}
.btn-yellow:hover {
	background-color: var(--yellow-hover) !important;
	border-color: var(--yellow-hover) !important;
	color: var(--black) !important;
}
.btn-yellow:hover svg,
.btn-yellow:hover svg path {
	fill: var(--black) !important;
}
.btn-yellow-transparent {
	background-color: transparent !important;
	border-color: var(--yellow) !important;
	color: var(--yellow) !important;
	/*backdrop-filter: blur(10px) !important;*/
}
.btn-yellow-transparent:hover {
	background-color: var(--yellow-hover) !important;
	border-color: var(--yellow-hover) !important;
	color: var(--black) !important;
}
.btn-yellow-transparent:hover svg,
.btn-yellow-transparent:hover svg path {
	fill: var(--black) !important;
}
.btn-disabled {
	/*background-color: transparent !important;*/
	pointer-events: none !important;
	opacity: .7 !important;
}
.btn-red {
	background-color: var(--red) !important;
	border-color: var(--red) !important;
	color: var(--white) !important;
}
.btn-red:hover {
	background-color: var(--red-hover) !important;
	border-color: var(--red-hover) !important;
	color: var(--white) !important;
}
.btn-red-transparent:hover svg,
.btn-red-transparent:hover svg path {
	fill: var(--white) !important;
}
.btn-red-transparent {
	background-color: transparent !important;
	border-color: var(--red) !important;
	color: var(--red) !important;
}
.btn-red-transparent:hover {
	background-color: var(--red-hover) !important;
	border-color: var(--red-hover) !important;
	color: var(--white) !important;
}
.btn-red-transparent:hover svg,
.btn-red-transparent:hover svg path {
	fill: var(--white) !important;
}
.btn .show {
	display: block;
	margin-top: -6px;
}
.btn .hide {
	font-weight: 300;
	font-size: 10px;
	line-height: 100%;
	display: block;
	margin-bottom: -2px;
	margin-top: -2px;
}
.btn-long {
	width: 100%;
}
.btn-min-width-180 {
	min-width: 180px;
}
.btn-icon {
	padding: 0.75rem;
}

.swiper {
	padding: 0.75rem 0.75rem 1rem 0.75rem;
}

.swiper-slide {
	height: auto !important;
	display: flex;
	margin-bottom: 10px;
}

.swiper-slide > .col {
	display: flex;
	flex-direction: column;
	height: 100%;
	width: 100%;
}

.swiper-scrollbar {
	width: auto !important;
	height: 1px !important;
	border: none;
	border-top: 1px solid rgba(255, 255, 255, 0.2);
	background: transparent !important;
	left: 0.75rem !important;
	right: 0.75rem !important;
	bottom: 0 !important;
}

.swiper-scrollbar-drag {
	height: 1px !important;
	border: none;
	border-top: 1px solid #fff;
	background: transparent !important;
	left: 0;
	top: -1px;
	min-width: 40px;
}

#timer {
	padding-top: 3rem;
	padding-bottom: 3rem;
	position: relative;
	background: url(/image/catalog/example/site/bg-timer.webp) center 25% no-repeat;
	background-size: cover;
	display: flex;
	align-items: center;
	min-height: calc(792px - 3rem);
}
#timer::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	background-color: #01010140;
	z-index: 1;
}
.box-timer__description {
	font-weight: 500;
	font-size: 20px;
	line-height: 120%;
	display: block;
	margin-bottom: 1rem;
}
.box-timer__image {
	display: block;
}
.box-timer__image,
.box-timer__image iframe {
	border-radius: 20px !important;
}
.timer-grid {
	text-align: center;
	display: flex;
	gap: 16px;
	background: rgba(14, 20, 19, 0.6);
	border: 1px solid rgba(1, 1, 1, 0.12);
	backdrop-filter: blur(20px);
	border-radius: 20px;
	margin-bottom: 1rem;
	width: 100%;
	justify-content: center;
}
.timer-block {
	padding: 9px 12px;
	min-width: 30px;
}
.timer-number {
	text-align: center;
	color: var(--white);
}
.timer-label {
	font-size: 15px;
	font-weight: 400;
	line-height: 120%;
	color: rgba(255, 255, 255, 0.9);
}
.timer-message {
	margin-top: 30px;
	font-size: 20px;
	color: #333;
	display: none;
	margin-bottom: 1rem;
}
.timer-message.active {
	display: block;
}

#tours.category::before,
#error.not_found::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	background: url(/image/catalog/example/site/bg-concerts.webp) center top / cover no-repeat;
	background-attachment: fixed;
	opacity: 0.3;
	padding: 3rem 0 calc(3rem + 16px) 0;
}
#error.not_found::before {
	background: url(/image/catalog/example/site/bg-faq.webp) center no-repeat;
	background-size: cover;
	background-attachment: fixed;
	opacity: 1;
}

#error {
	min-height: 512px;
}
/*#error::after {*/
/*	content: "";*/
/*	position: absolute;*/
/*	bottom: 0;*/
/*	left: 0;*/
/*	width: 100%;*/
/*	height: 150px;*/
/*	background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 1) 100%);*/
/*	z-index: 1;*/
/*}*/

#gallery::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	background: url(/image/catalog/example/site/bg-faq.webp) center no-repeat;
	background-attachment: fixed;
	background-size: cover;
	padding: 3rem 0 calc(3rem + 16px) 0;
}

#team, #stories, #video, #reviews, #timer, #faq {
	margin-top: 3rem;
}
#tours.product {
	margin-bottom: 3rem;
}

#tours, #contacts, #error {
	padding-top: 3rem;
}

/* Главный экран */
.hero {
	min-height: 100vh;
	background: var(--black);
	padding: 120px 0 60px;
}

.queen-logo {
	font-size: 5rem;
	font-weight: 900;
	line-height: 1;
	margin-bottom: 0.5rem;
}

.queen-logo span {
	color: var(--yellow);
}

.tribute-subtitle {
	font-size: 2rem;
	font-weight: 700;
	margin-bottom: 2rem;
	color: var(--white);
}

.program-title {
	font-size: 1.5rem;
	font-weight: 500;
	margin-bottom: 2rem;
	color: var(--white);
	max-width: 600px;
}

.city-date {
	font-size: 2rem;
	font-weight: 700;
	margin: 2rem 0 1rem;
}

.city-date span {
	color: var(--yellow);
}

.price-block {
	background: rgba(253, 253, 253, 0.05);
	border: 1px solid var(--yellow);
	padding: 2rem;
	margin: 2rem 0;
}

.price {
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--yellow);
}

.price small {
	font-size: 1rem;
	color: var(--white);
	font-weight: 400;
}

.price-note {
	font-size: 1rem;
	color: rgba(253, 253, 253, 0.7);
	margin-top: 0.5rem;
}

.genre-age {
	display: flex;
	gap: 2rem;
	font-size: 1.2rem;
	margin-top: 1rem;
}

.genre-age span:first-child {
	color: var(--yellow);
	font-weight: 600;
}

/* Иконки звезд для отзывов */
.stars {
	color: var(--yellow);
	margin-right: 0.5rem;
}

.navbar-brand {
	display: inline-block;
}

#gallery #video,
#gallery #stories {
	margin-top: 0;
}


.Modal .modal-content {
	max-width: 600px;
	width: calc(100% - 40px);
	margin: 1.75rem auto;
}

.modal .modal-content {
	overflow: hidden;
	display: flex;
	flex-direction: column;
	background: #010101;
	color: #FDFDFD;
	border: 1px solid #FDCC0C;
	border-radius: 20px;
}
.modal .modal-footer {
	border: 0;
}
.modal .modal-body {
	padding: 20px;
	overflow-y: auto;
	flex: 1 1 auto;
	font-size: 18px;
}

.modal .modal-header {
	border-bottom: 0;
}
.modal .modal-footer {
	padding: 15px 20px;
	display: flex;
	justify-content: flex-end;
	gap: 10px;
}

.modal .modal-header {
	justify-content: end;
}
.modal .modal-header button {
	background: transparent !important;
	border: none !important;
}

#pdModal .modal-content {
	height: 600px;
	max-height: calc(80vh - 40px);
}

#successModal .modal-content {
	max-height: calc(80vh - 40px);
}
#successModal .modal-dialog {
	width: 420px;
	max-width: 100%;
	margin: 0 auto;
}

#successModal .modal-body {
	text-align: center;
}

#successModal .modal-body p {
	font-size: 14px;
	opacity: 70%;
}


#gallery.category-info .media-item::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -70%);
	width: 48px;
	height: 48px;
	background: url(/image/catalog/example/site/icon-view.svg) no-repeat center;
	background-size: contain;
	pointer-events: none;
	transition: all 0.2s ease;
	opacity: 0;
}

#gallery.category-info .media-item:hover::after {
	opacity: 1;
}

:root {
	--menu-height: 73px;
}

#contacts {
	min-height: calc(100vh - var(--menu-height));
	min-height: calc(100svh - var(--menu-height));
	margin-bottom: 0 !important;
	padding-bottom: 64px !important;
}

#contacts #form-creator-51 input[type="checkbox"] {
	display: inline-block !important;
	vertical-align: middle;
	margin: 0;
	width: auto;
	margin-right: 3px;
	margin-top: -1px;
}

.modal {
	padding-right: 0 !important;
}
h2.d-inline {
	display: inline-block !important;
}
.cursor-pointer {
	cursor: pointer;
}

.notification {
	z-index: 1000;
	bottom: 0;
	left: 0;
	right: 0;
	position: fixed;
	background: linear-gradient(90deg, #FDCC0D 0%, #E30613 51.92%, #FDCC0D 100%);
	text-align: center;
	padding: 5px;
}
.notification p {
	margin-bottom: 0;
	padding: 0.25rem 0;
	font-size: 15px;
	font-weight: 600;
}

.notification + #cookie {
	bottom: 64px;
}

#cookie {
	z-index: 1084;
	bottom: 72px;
	right: 12px;
	position: fixed;
	text-align: center;
	background: #010101;
	border: 1px solid #FDCC0D;
	border-radius: 20px;
	width: 100%;
	max-width: calc(280px - 24px);
	padding: .75rem;
}
#cookie {
	display: none;
}
#cookie p {
	font-size: 10px;
}
#cookie p .link {
	color: var(--yellow) !important;
	border: none;
	background: none;
	padding: 0;
	cursor: pointer;
}
#cookie .btn {
	padding: 0.25rem .75rem;
}

#home.product h2 {
	padding: 0;
}

hr.special-hr {
	border-color: #FDCC0D;
	opacity: 1;
}

@media (max-width: 380px) {
	h1 span {
		font-size: 32px;
	}
	h1 span.text-part-third {
		font-size: 52px;
	}
}

/* Адаптивность */
@media (max-width: 768px) {
	.timer-block {
		padding: 9px 12px;
		min-width: 60px;
	}
	.queen-logo {
		font-size: 3.5rem;
	}

	.tribute-subtitle {
		font-size: 1.5rem;
	}

	.city-date {
		font-size: 1.5rem;
	}

	.price {
		font-size: 2rem;
	}

	.navbar-brand {
		font-size: 1.2rem;
	}
	.form-wrap {
		display: flex;
		flex-direction: column;
		align-items: center;
	}
	.form-wrap-heading {
		display: flex;
		align-items: center;
		justify-content: center;
		text-align: center;
	}
}

/* Стили для offcanvas */
.offcanvas {
	width: 70% !important;
	max-width: 340px;
	background: var(--black) !important;
}
.offcanvas-body {
	display: flex;
	flex-direction: column;
	padding: 0.5rem;
}

.offcanvas-body .row {
	flex: 1 1 auto;
}

.offcanvas-body .col:last-child {
	margin-top: auto;
}

.offcanvas-backdrop {
	transition: none !important;
}
.offcanvas.offcanvas-end {
	right: -1px !important;
}
.offcanvas .btn:first-child {
	font-size: 11px;
}
.offcanvas .btn-close {
	--bs-btn-close-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23FDCC0D'%3e%3cpath d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414z'/%3e%3c/svg%3e");
	--bs-btn-close-opacity: 1;
	--bs-btn-close-hover-opacity: 1;
}
.offcanvas .btn-close:focus {
	box-shadow: none;
}
.offcanvas-body .nav-link {
	font-weight: 500;
	font-size: 20px;
	line-height: 120%;
	margin-bottom: 0.5rem;
}
.offcanvas-body .nav-link:hover {
	text-decoration: underline !important;
	color: var(--yellow) !important;
}
/*.offcanvas .nav-link {*/
/*    font-size: 1.2rem;*/
/*    padding: 1rem 0 !important;*/
/*    border-bottom: 1px solid rgba(253, 253, 253, 0.1);*/
/*}*/

.navbar-brand-logo {
	width: 70px;
}
#show {
	justify-content: space-between !important;
}
.details {
	justify-content: center;
}

.navbar-toggler {
	--bs-navbar-toggler-icon-bg: url("data:image/svg+xml,%3csvg width='30' height='12' viewBox='0 0 30 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3e%3cline x1='1' y1='1' x2='29' y2='1' stroke='%23FDCC0D' stroke-width='2' stroke-linecap='round'/%3e%3cline x1='1' y1='6' x2='29' y2='6' stroke='%23FDCC0D' stroke-width='2' stroke-linecap='round'/%3e%3cline x1='1' y1='11' x2='29' y2='11' stroke='%23FDCC0D' stroke-width='2' stroke-linecap='round'/%3e%3c/svg%3e") !important;
	border: none !important;
}
.navbar-toggler:focus {
	box-shadow: none !important;
}

.modal-custom-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.5);
	display: none;
	justify-content: center;
	align-items: center;
	z-index: 9999;
	opacity: 0;
	transition: opacity 0.2s ease;
}

.modal-custom-overlay.show {
	display: flex;
	opacity: 1;
}

/* Контейнер модалки */
.modal-custom-container {
	max-width: 450px;
	width: 90%;
	margin: 0 auto;
}

/* Основное содержимое */
.modal-custom-content {
	background: white;
	border-radius: 24px;
	padding: 32px 24px;
	position: relative;
	box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
	border: 1px solid rgba(255, 255, 255, 0.1);
	animation: modalCustomAppear 0.2s ease-out;
}

/* Анимация появления */
@keyframes modalCustomAppear {
	from {
		transform: scale(0.95) translateY(-10px);
		opacity: 0;
	}
	to {
		transform: scale(1) translateY(0);
		opacity: 1;
	}
}

/* Кнопка закрытия */
.modal-custom-close {
	position: absolute;
	right: 20px;
	top: 20px;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	border: none;
	background: #f1f3f5;
	color: #495057;
	font-size: 20px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.2s ease;
	padding: 0;
	line-height: 1;
}

.modal-custom-close:hover {
	background: #e9ecef;
	transform: rotate(90deg);
}

.modal-custom-close:focus {
	outline: none;
	box-shadow: 0 0 0 3px rgba(13, 110, 253, 0.25);
}

/* Иконка успеха */
.modal-custom-icon {
	text-align: center;
	margin-bottom: 20px;
}

.modal-custom-icon svg {
	width: 64px;
	height: 64px;
	color: #28a745;
	filter: drop-shadow(0 4px 6px rgba(40, 167, 69, 0.2));
}

/* Заголовки и текст */
.modal-custom-title {
	font-size: 24px;
	font-weight: 700;
	color: #212529;
	margin: 0 0 8px 0;
	text-align: center;
	line-height: 1.3;
}

.modal-custom-text {
	font-size: 16px;
	color: #6c757d;
	margin: 0 0 24px 0;
	text-align: center;
	line-height: 1.5;
}

/* Раздел "Наши проекты" */
.modal-custom-projects-title {
	font-size: 18px;
	font-weight: 600;
	color: #212529;
	margin: 0 0 16px 0;
	padding-left: 8px;
	border-left: 4px solid #28a745;
}

/* Список проектов */
.modal-custom-projects-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-bottom: 28px;
}

.modal-custom-project-item {
	font-size: 16px;
	padding: 12px 20px;
	background: linear-gradient(135deg, #f8f9fa 0%, #ffffff 100%);
	border-radius: 40px;
	color: #212529;
	border: 1px solid #e9ecef;
	transition: all 0.2s ease;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.02);
	font-weight: 500;
	letter-spacing: 0.3px;
}

.modal-custom-project-item:hover {
	transform: translateX(5px);
	border-color: #28a745;
	box-shadow: 0 4px 8px rgba(40, 167, 69, 0.1);
	background: white;
}

/* Кнопка действия */
.modal-custom-button {
	display: block;
	width: 100%;
	padding: 14px 24px;
	background: white;
	color: #28a745;
	border: 2px solid #28a745;
	border-radius: 50px;
	font-size: 16px;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.2s ease;
	text-align: center;
	margin-top: 8px;
}

.modal-custom-button:hover {
	background: #28a745;
	color: white;
	transform: translateY(-2px);
	box-shadow: 0 6px 12px rgba(40, 167, 69, 0.2);
}

.modal-custom-button:focus {
	outline: none;
	box-shadow: 0 0 0 3px rgba(40, 167, 69, 0.4);
}

/* Демо-кнопка (не изолирована, только для демонстрации) */
.demo-button {
	position: fixed;
	bottom: 30px;
	left: 50%;
	transform: translateX(-50%);
	padding: 12px 30px;
	background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
	color: white;
	border: none;
	border-radius: 50px;
	font-size: 16px;
	font-weight: 600;
	cursor: pointer;
	box-shadow: 0 10px 20px rgba(102, 126, 234, 0.3);
	transition: all 0.2s ease;
	z-index: 1000;
}

.demo-button:hover {
	transform: translateX(-50%) translateY(-2px);
	box-shadow: 0 15px 30px rgba(102, 126, 234, 0.4);
}

/* Блокировка прокрутки страницы */
body.modal-custom-open {
	overflow: hidden;
}

#about {
	position: relative;
	display: flex;
	padding-top: 3rem;
}
#about::before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	background: #0000004D;
}
#about .container {
	position: relative;
	z-index: 1;
}
#about .container::before {
	content: '';
	position: absolute;
	top: -3rem;
	right: -36px;
	width: 232px;
	height: 434px;
	background: url(/image/catalog/example/site/bg-hero.webp) no-repeat;
	background-size: cover;
	pointer-events: none;
	z-index: -1;
}
#about h2 {
	font-style: normal;
	font-weight: 300;
	text-align: center;
	color: #FDFDFD;
}

.box-about {
	background: rgba(253, 253, 253, 0.09);
	border: 1px solid rgba(253, 253, 253, 0.12);
	backdrop-filter: blur(20px);
	border-radius: 20px;
	padding: 1rem;
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
}

.box-about__icon {
	display: block;
	margin-bottom: 1rem;
	flex-shrink: 0; /* Иконка не сжимается */
}

.box-about__icon img {
	height: 16px;
}

.box-about__title {
	display: block;
	margin-bottom: 0.75rem;
	font-weight: 500;
	font-size: 20px;
	line-height: 120%;
	color: #fff;
	flex-shrink: 0; /* Заголовок не сжимается */
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
}

.box-about__description {
	font-weight: 400;
	display: block;
	margin-bottom: 1rem;
	font-size: 15px;
	line-height: 140%; /* Немного увеличил для читаемости */
	color: rgba(255, 255, 255, 0.8);
	flex: 1; /* Занимает всё доступное пространство между заголовком и изображением */
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 4;
	overflow: hidden;
}

.box-about__image {
	width: 100%;
	min-height: 153px; /* Фиксированная высота как у img */
	flex-shrink: 0; /* Изображение не сжимается */
	border-radius: 20px;
	overflow: hidden;
	margin-top: auto; /* Прижимаем к низу */
}

.box-about__image img {
	width: 100%;
	border-radius: 20px;
	display: block;
}

#about .swiper-slide {
	width: 80%;
}

#contacts {
	margin-bottom: 3rem;
}
#contacts form {
	max-width: 450px;
}
#contacts a {
	color: var(--white) !important;
	text-decoration: none !important;
}
#contacts #form-creator-51 {
	background: rgba(253, 253, 253, 0.09);
	border: 1px solid rgba(253, 253, 253, 0.12);
	backdrop-filter: blur(20px);
	border-radius: 20px;
	padding: 2rem 1rem;
}
#contacts #form-creator-51 .form-wrap-button {
	text-align: left;
}
#contacts #form-creator-51 h2 {
	margin-bottom: 2rem;
	padding: 0;
}
#contacts #form-creator-51 label,
#contacts #form-creator-51 input,
#contacts #form-creator-51 button,
#contacts #form-creator-51 .contacts-terms {
	width: 400px;
	max-width: 100%;
}
#contacts #form-creator-51 input {
	display: flex;
	flex-direction: row;
	align-items: flex-start;
	padding: 15px 30px;
	gap: 10px;
	border: 0;
	border-bottom: 1px solid #FDFDFD;
	background: transparent;
	margin-bottom: 0.5rem;

}
#contacts .contacts-terms {
	font-size: 11px;
	cursor: pointer !important;
}
#contacts h3,
#contacts .h3 {
	display: block;
	font-size: 20px;
	line-height: 120%;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
	margin-bottom: 0;
	user-select: none;
}
#contacts .additional-info {
	margin-top: 3rem;
	margin-bottom: 3rem;
	text-align: center;
}
#contacts .additional-info .contacts-links a {
	font-weight: 400;
	font-size: 15px;
	line-height: 120%;
}
.contacts-links + .contacts-links {
	margin-top: 1.5rem;
}
#contacts .accordion-item {
	background-color: transparent !important;
	border-color: #FDFDFD40 !important;
	text-align: center;
}
#contacts .accordion-item .accordion-button {
	font-weight: 500;
	font-size: 20px;
	line-height: 120%;
	color: var(--white);
	background-color: transparent !important;
	box-shadow: none !important;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
	justify-content: center;
	margin-bottom: 0.5rem;
	user-select: none;
}
#contacts .accordion-item .accordion-button::after {
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23ffffff' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M2 5L8 11L14 5'/%3e%3c/svg%3e") !important;
}
#contacts .accordion-item .accordion-body {
	font-weight: 400;
	font-size: 18px;
	line-height: 120%;
	color: var(--white);
	/*padding: 0.75rem 0.75rem 1.25rem 0.75rem;*/
	padding: 0.75rem;
}
#contacts .accordion-item .accordion-body p {
	font-size: 15px;
}
/*#contacts .accordion-item .accordion-body p:last-child {*/
/*	margin-bottom: 0;*/
/*}*/
#contacts .accordion-button::after {
	margin-left: .5rem;
}
#faq .accordion-item {
	background-color: transparent !important;
	border-color: #FDFDFD40 !important;
}
#faq .accordion-flush>.accordion-item:first-child {
	border-top: 1px solid #FDFDFD40 !important;
}
#faq .accordion-flush>.accordion-item:last-child {
	border-bottom: 1px solid #FDFDFD40 !important;
}
#faq .accordion-item .accordion-button {
	font-weight: 500;
	font-size: 20px;
	line-height: 120%;
	color: var(--white);
	background-color: transparent !important;
	box-shadow: none !important;
	padding-left: 0.75rem;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
	/*padding: 0.75rem 1.25rem 0.75rem 0.75rem;*/
	padding: 0.75rem 0.75rem 0.75rem 0;
}
#faq .accordion-item .accordion-button::after {
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23ffffff' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M2 5L8 11L14 5'/%3e%3c/svg%3e") !important;
}
#faq .accordion-item .accordion-body {
	font-weight: 400;
	font-size: 18px;
	line-height: 120%;
	color: var(--white);
	padding: 0.75rem;
	padding-top: 0;
	padding-left: 0 !important;
}
#faq .accordion-item .accordion-body p {
	opacity: 80%;
	font-size: 15px;
}
#faq .accordion-item .accordion-body p:last-child {
	margin-bottom: 0;
}

.box-reviews {
	background: rgba(253, 253, 253, 0.09);
	border: 1px solid rgba(253, 253, 253, 0.12);
	backdrop-filter: blur(20px);
	border-radius: 20px;
	padding: 1rem;
	width: 100%;
	min-height: 190px;
}
.box-reviews__info {
	margin-bottom: 1rem;
}
.box-reviews__info > .row {
	white-space: nowrap;
	flex-wrap: nowrap;
	min-width: 0;
	width: 100%;
}
.box-reviews__info > .row > .col-3 {
	flex-shrink: 0;
	padding-right: 0;
}
.box-reviews__info > .row > .col-auto {
	flex-shrink: 1;
	overflow: hidden;
	padding-right: 0;
	/* align-items: center; */
	justify-content: center;
	vertical-align: middle;
}
.box-reviews__info-name {
	display: block;
	margin-bottom: 0.25rem;
	font-weight: 500;
	font-size: 16px;
	line-height: 120%;
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
	text-overflow: ellipsis;
}
.box-reviews__info-date {
	font-size: 15px;
	line-height: 120%;
}
.box-reviews__info-photo {
	display: block;
}
.box-reviews__info-photo img {
	width: 48px;
	height: 48px;
	border-radius: 50%;
}
/* Стили для кнопки "Читать полностью" */
.box-reviews__text-more {
	display: none;
	font-size: 14px;
	line-height: 120%;
	color: #6B9BFF;
	margin-top: 0.5rem;
	cursor: pointer;
	background: none;
	border: none;
	padding: 0;
	text-align: left;
	width: fit-content;
}

.mobile-more-btn {
	margin-top: 1rem;
	font-size: 15px;
	line-height: 18px;
	color: #FDFDFDAD;
	display: inline-block;
	background: none;
	border: none;
	padding: 0;
	cursor: pointer;
}

/* Для мобильных устройств */
@media (max-width: 1199px) {
	/* Скрываем обычную кнопку на мобильных */
	.box-reviews.more-available .box-reviews__text-more {
		display: none !important;
	}
}

/* Развернутое состояние текста */
.box-reviews__text.expanded {
	-webkit-line-clamp: unset !important;
	display: block !important;
}

/* Стили для контейнера текста */
.box-reviews__text {
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	overflow: hidden;
	font-size: 14px;
	line-height: 120%;
	position: relative;
	transition: all 0.2s ease;
}

/* Убираем старый span с Читать полностью из HTML */
.box-reviews__text .box-reviews__text-more {
	display: none;
}

#reviews .swiper-slide {
	width: 80%;
}

#stories .swiper {
	overflow: hidden;
	padding: 0 12px 24px;
}

#stories .swiper-wrapper {
	align-items: stretch;
}

#stories .swiper-slide {
	height: auto;
	box-sizing: border-box;
	margin-bottom: 0;
}

.box-stories {
	position: relative;
	width: 100%;
	height: 100%;
	display: block;
	cursor: pointer;
	background: rgba(253, 253, 253, 0.09);
	border: 1px solid rgba(253, 253, 253, 0.12);
	backdrop-filter: blur(20px);
	border-radius: 20px;
	transition: transform 0.2s ease-in-out;
}

.box-stories:not(.box-stories-accent) {
	transition: transform 0.35s ease;
	transform-origin: center center;
}

.box-stories-accent {
	position: relative;
	border: 2px solid #FDCC0D;
}

.box-stories-accent.playing::before {
	content: "";
	position: absolute;
	inset: -2px;
	background: linear-gradient(45deg, #f09433, #d62976, #962fbf, #4f5bd5);
	border-radius: 22px;
	z-index: -1;
	border: 0;
}

.box-stories__image {
	overflow: hidden;
	border-radius: 20px;
}

.box-stories__image.video_wrapper {
	position: relative;
	display: block;
	width: 100%;
	aspect-ratio: 9 / 16;
	overflow: hidden;
	border-radius: 20px;
	background: #000;
	cursor: pointer;
}

.box-stories__image.video_wrapper video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border-radius: 20px;
	background: #000;
	z-index: 1;
}

.box-stories__image.video_wrapper a.stories-play-link {
	position: absolute;
	inset: 0;
	text-decoration: none;
	z-index: 10;
	cursor: pointer;
}

.box-stories__image.video_wrapper a.stories-play-link::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -70%);
	width: 48px;
	height: 48px;
	background: url('/image/catalog/example/site/icon-play.svg') no-repeat center;
	background-size: contain;
	pointer-events: none;
	transition: all 0.2s ease;
	opacity: 0.9;
	z-index: 11;
}
.box-stories-accent.playing .box-stories__image.video_wrapper a.stories-play-link::before {
	content: none;
}

.box-stories__image.video_wrapper:hover a.stories-play-link::before {
	transform: translate(-50%, -70%) scale(1.1);
	opacity: 1;
}

.box-stories__image.video_wrapper.playing a.stories-play-link::before {
	opacity: 0;
	visibility: hidden;
}

.box-stories-bg img {
	display: block;
	height: 100%;
	max-height: 560px;
}

/* Индикатор видео */
.video-indicator {
	position: absolute;
	top: 10px;
	right: 50px;
	color: white;
	font-size: 12px;
	background: rgba(0, 0, 0, 0.5);
	padding: 4px 8px;
	z-index: 10;
	border-radius: 20px;
}

/* Стили для контейнера с видео */
.box-stories__image {
	position: relative;
	width: 100%;
	padding-bottom: 177.77%; /* Соотношение сторон 9:16 для stories */
	overflow: hidden;
	border-radius: 20px;
	cursor: pointer;
}

.box-stories__image img,
.box-stories__image video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	transition: transform 0.2s;
}

.box-stories__image video {
	background: #000;
}

/* Элементы управления видео (появляются при наведении) */
.box-stories__image video::-webkit-media-controls {
	opacity: 0;
	transition: opacity 0.2s;
}

.box-stories__image video:hover::-webkit-media-controls {
	opacity: 1;
}

/* Индикатор воспроизведения */
.video-playing-indicator {
	position: absolute;
	top: 10px;
	right: 10px;
	background: rgba(0, 0, 0, 0.6);
	color: white;
	padding: 4px 8px;
	border-radius: 4px;
	font-size: 12px;
	z-index: 3;
	display: flex;
	align-items: center;
	gap: 4px;
}

.video-playing-indicator::before {
	content: '';
	width: 8px;
	height: 8px;
	background: #ff0000;
	border-radius: 50%;
	animation: pulse 1.5s infinite;
}

@keyframes pulse {
	0% { opacity: 1; }
	50% { opacity: 0.5; }
	100% { opacity: 1; }
}

/* Анимация для градиентной обводки */
@keyframes gradientRotate {
	0% {
		filter: hue-rotate(0deg);
	}
	100% {
		filter: hue-rotate(360deg);
	}
}

.box-stories-accent::before {
	animation: gradientRotate 3s linear infinite;
}

#team {

}

.box-team {
	display: flex;
	flex-direction: column;
	width: 100%;
	height: 100%;
	background: rgba(253, 253, 253, 0.09);
	backdrop-filter: blur(20px);
	border-radius: 20px;
	border: 1px solid rgba(253, 253, 253, 0.12);
}

.box-team__image {
	width: 100%;
	min-height: 285px; /* Фиксированная высота для всех изображений */
	flex-shrink: 0; /* Запрещаем сжиматься */
	overflow: hidden;
	border-top-right-radius: 20px;
	border-top-left-radius: 20px;
}

.box-team__image img {
	width: 100%;
	display: block;
}

.box-team__info {
	padding: 1rem;
	border-top: 1px solid rgba(253, 253, 253, 0.12);
	justify-content: center;
}

.swiper-slide .box-team__info-title {
	display: block;
	margin-bottom: 0.5rem;
	font-weight: 500;
	color: var(--yellow);
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
	font-size: 24px;
	line-height: 29px;
}
.swiper-slide .box-team__info-description {
	display: block;
	line-height: 120%;
	color: var(--white);
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	overflow: hidden;
	font-size: 18px;
	line-height: 22px;
}

#gallery,
#tours,
#error {
	position: relative;
}
.tours-subtitle {
	margin-bottom: calc(2rem - 0.75rem);
}
.box-tours {
	background: rgba(253, 253, 253, 0.09);
	backdrop-filter: blur(20px);
	border-radius: 20px;
	border: 1px solid rgba(253, 253, 253, 0.12);
	padding: 1rem;
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
}
.box-tours__info-title {
	display: block;
	margin-bottom: 0.5rem;
	font-weight: 300;
	font-size: 10px;
	line-height: 10px;
}
.box-tours__info-value {
	display: block;
	margin-bottom: 1rem;
	font-weight: 400;
	font-size: 15px;
	line-height: 18px;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
	overflow: hidden;
}
.box-tours__info {
	display: flex;
	flex-direction: column;
	height: 100%;
	flex: 1;
}
.box-tours__info .btn {
	margin-top: auto !important;
}

.content-subscribe {
	margin-top: 2rem;
}
#video {

}
.box-video {
	position: relative;
	background: rgba(253, 253, 253, 0.09);
	border: 1px solid rgba(253, 253, 253, 0.12);
	backdrop-filter: blur(20px);
	border-radius: 20px;
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
}
.box-video__image {
	position: relative;
	display: block;
	border: 1px solid rgba(253, 253, 253, 0.12);
	border-radius: 20px;
	width: 100%;
	flex: 1;
}
.box-video__image::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	z-index: 1;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	background: linear-gradient(180deg, rgba(0, 0, 0, 0) 17.32%, rgba(0, 0, 0, 0.2) 80.96%);
}
.box-video__image.video_wrapper {
	position: relative;
}
.box-video__image.video_wrapper a.video-popup-link {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	text-decoration: none;
	z-index: 1;
}
.box-video__image.video_wrapper a.video-popup-link::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -70%);
	width: 48px;
	height: 48px;
	background: url('/image/catalog/example/site/icon-play.svg') no-repeat center;
	background-size: contain;
	pointer-events: none;
	transition: all 0.2s ease;
	opacity: 0.9;
}
.box-video__image.video_wrapper:hover a.video-popup-link::before {
	transform: translate(-50%, -70%) scale(1.1);
	opacity: 1;
}
.box-video__image img {
	width: 100%;
	height: 100%;
	border-radius: 20px;
}
.box-video__title {
	font-weight: 500;
	font-size: 20px;
	line-height: 120%;
	position: absolute;
	bottom: 0;
	margin: 0.75rem;
	left: 0;
	right: 0;
	z-index: 2;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
}

#video .swiper-slide {
	width: 80%;
}

/* Стили для контейнера в футере */
footer .footer-btn {
	/* базовые стили контейнера */
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	backdrop-filter: blur(10px);
	padding: 0.5rem 0.75rem;
	opacity: 0.5;
	visibility: hidden;
	z-index: 1024;
}
footer .footer-btn.active {
	opacity: 1;
	visibility: visible;
}

footer .footer-btn__button {
	margin-bottom: 0 !important;
}

.play-icon {
	width: 30px !important;
	height: auto !important;
	margin-left: 5px;
}

/* Стили для Magnific Popup */
.mfp-iframe-holder .mfp-content {
	max-width: 900px;
	max-height: 506px;
}

.mfp-iframe-scaler iframe {
	background: #000;
	box-shadow: 0 0 20px rgba(0,0,0,0.8);
	border-radius: 20px;
}

.mfp-fade.mfp-bg {
	opacity: 0;
	transition: all 0.2s ease-out;
}

.mfp-fade.mfp-bg.mfp-ready {
	opacity: 0.8;
}

.mfp-fade.mfp-bg.mfp-removing {
	opacity: 0;
}

.mfp-fade.mfp-wrap .mfp-content {
	opacity: 0;
	transition: all 0.2s ease-out;
}

.mfp-fade.mfp-wrap.mfp-ready .mfp-content {
	opacity: 1;
}

.mfp-fade.mfp-wrap.mfp-removing .mfp-content {
	opacity: 0;
}

#home {
	min-height: 73px;
}

#home.main::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	pointer-events: none; /* чтобы градиент не мешал кликам */
}
#home.main::before {
	background: linear-gradient(180deg, rgba(0, 0, 0, 0.4) 42.84%, rgba(0, 0, 0, 0.2) 50.05%, rgba(0, 0, 0, 0.4) 91.95%);
}

#home.product::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	pointer-events: none; /* чтобы градиент не мешал кликам */
}
#home.product::before {
	background: linear-gradient(180.02deg, rgba(0, 0, 0, 0) 26.9%, rgba(0, 0, 0, 0.45) 46.35%, rgba(0, 0, 0, 0.9) 78.68%);
}

.breadcrumbs {
	margin-bottom: 10px;
}
.breadcrumbs li {
	display: inline-block;
	font-weight: 400;
	font-size: 16px;
}

.breadcrumbs li {
	display: inline-block;
	font-weight: 500;
	margin: 0 2px;
}

.breadcrumbs li a {
	font-weight: 500;
}

.breadcrumbs li + li:before {
	margin: 0 3px 0 0px;
	content: "/";
	font-weight: 700;
}

#search {
	border-bottom: 1px solid #FDFDFD40;
}
#search .form-control {
	background: none;
	border: none;
	border-radius: 0;
	color: #FDFDFD !important;
	font-size: 18px;
}
#search .form-control:focus {
	box-shadow: none !important;
}
#search .form-control,
#search .form-control::placeholder,
#contacts #form-creator-51 input,
#contacts #form-creator-51 input::placeholder {
	color: rgb(253 253 253 / 80%) !important;
}
#search .form-control:focus,
#search .form-control:focus::placeholder,
#contacts #form-creator-51 input:focus,
#contacts #form-creator-51 input:focus::placeholder {
	color: rgb(253 253 253 / 100%) !important;
}
#search .input-group-btn,
#search .input-group-btn .btn {
	height: 47px;
	width: 47px;
}
#search .input-group-btn .btn {
	border-radius: 0 !important;
	border: none !important;
}
#search .input-group-btn .btn svg path {
	fill: rgb(253 253 253 / 80%) !important;
}
#search .input-group-btn .btn:hover svg path,
#search .input-group-btn .btn:focus svg path
#search .input-group-btn .btn:active svg path{
	fill: rgb(253 253 253 / 100%) !important;
}
.mb-6 {
	margin-bottom: 4.5rem !important;
}

.content-none {
	position: absolute;
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	clip-path: inset(100%);
	border: 0;
	white-space: nowrap;
}

.breadcrumbs-category {
	padding: 0;
}
.breadcrumbs-category li {
	list-style: none;
	display: inline-block;
	margin-bottom: .5rem;
	margin-right: .25rem;
}
.breadcrumbs-category li > a {
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	padding: 9px 12px;
	gap: 10px;
	background: rgba(253, 253, 253, 0.09);
	border: 1px solid rgba(253, 253, 253, 0.12);
	backdrop-filter: blur(20px);
	border-radius: 30px;
	text-decoration: none !important;
	font-size: 15px;
	line-height: 1.2;
	font-weight: 500;
	color: #FDFDFD;
	transition: 0.2s ease-in-out;
}
.breadcrumbs-category li.active > a,
.breadcrumbs-category li:hover > a {
	background: rgba(253, 253, 253, 0.23);
}

#tours.category .empty-result + div {
	display: none;
}

.empty-result {
	width: 100%;
}

#menu a[href*="#"]::before {
	content: "↓";
	/*content: "•";*/
	margin-right: 6px;
	opacity: 0.6;
}

#menu .navbar-brand[href*="#"]::before,
#menu .without_anchor[href*="#"]::before {
	content: none;
}

#home + #tours,
#home + #gallery,
#home + #error {
	padding-top: 0;
}

#tours.category .container,
#gallery.category .container,
#error .container {
	padding-top: 3rem;
	padding-bottom: 3rem;
}

#gallery .media-item {
	display: inline-block;
	position: relative;
	background: rgba(253, 253, 253, 0.09);
	border: 1px solid rgba(253, 253, 253, 0.12);
	backdrop-filter: blur(20px);
	border-radius: 20px;
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
}
#gallery .media-item img {
	display: inline-block;
	max-width: 100%;
	height: auto;
	border-radius: 20px;
}

#gallery .media-item::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	z-index: 3;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	background: linear-gradient(180deg, rgba(0, 0, 0, 0) 17.32%, rgba(0, 0, 0, 0.2) 80.96%);
}
#gallery .media-item .media-item__info {
	position: absolute;
	z-index: 4;
	display: block;
	left: 0;
	bottom: 0;
	width: 100%;
	margin: 0;
	color: #fff;
	text-align: left;
	padding: 0.75rem;
	font-weight: 500;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
	font-size: 16px;
	line-height: 20px;
}
.box-success {
	background: rgba(253, 253, 253, 0.09);
	border: 1px solid rgba(253, 253, 253, 0.12);
	backdrop-filter: blur(20px);
	border-radius: 20px;
	padding: 1rem;
}
.box-success .box-success__image {
	margin-bottom: 1rem;
}
.box-success .box-success__image img{
	max-width: 100%;
	border-radius: 20px;
}

.box-success .box-success__info {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.box-success .box-success__info h6 {
	margin-bottom: 0;
}

#pdModal .btn-min-width-180 {
	min-width: 130px;
}

@media (min-width: 576px) {
	/* sm */
	#cookie {
		bottom: 12px;
	}
	.offcanvas .btn:first-child {
		font-size: initial;
	}
	#pdModal .btn-min-width-180 {
		min-width: 180px;
	}
}

@media (min-width: 768px) {
	.btn-long {
		width: 328px;
	}
	.swiper-slide:not(.swiper-slide-active) .box-team {
		transform: scale(0.90);
		transform-origin: center center;
	}

	#team .swiper-slide .box-team {
		transform: scale(0.9);
		transform-origin: center center;
	}
	#team .swiper-slide-active .box-team {
		transform: scale(1);
	}
	.box-stories:not(.box-stories-accent) {
		transform: scale(0.95);
		transform-origin: center center;
	}
	#home.main {
		height: 670px;
		background: url(/image/catalog/example/site/home-tablet.webp) center no-repeat;
		background-size: cover;
	}
	#home.product {
		height: 670px;
		background: url(/image/catalog/example/site/show-tablet.webp) center no-repeat;
		background-size: cover;
	}

	#home {
		min-height: 113px;
	}
	/* md */
	.top-content {
		height: 100%;
		align-items: center;
		vertical-align: middle;
		align-content: center;
	}
	/*#home.main .btn-long {*/
	/*	width: auto;*/
	/*}*/
	/*#home.product .btn-long {*/
	/*	width: auto;*/
	/*}*/
	#menu {
		padding: 0;
	}
	#menu:not(.opened) .container {
		padding: 0.5rem 1rem;
	}
	#menu.fixed-top {
		padding-top: 1rem;
		padding-bottom: .5rem;
	}
	.navbar-brand-logo {
		width: 115px;
	}
	#about {
		position: relative;
		display: flex;
		background: none;
	}
	.text-part {
		position: relative;
	}
	.text-part__first {
		padding-left: 6rem;
	}
	.text-part__second {
		padding-left: 2rem;
	}
	.text-part__third {
		padding-left: 16rem;
	}
	#about h2 {
		text-align: left;
	}
	.box-details .box-details__title {
		margin-bottom: 0;
	}
	#tours.category .box-tours {
		width: 100% !important;
		flex: 0 0 100%;
		max-width: 100%;
		margin-bottom: 0;
		padding: 1rem 0;
		background: none;
		backdrop-filter: none;
		border-radius: 0;
		border: 0;
		border-top: 1px solid #FDFDFD40;
	}
	#tours.category .box-tours:last-child {
		border-bottom: 1px solid #FDFDFD40;
	}
	#tours.category .box-tours .box-tours__info-value {
		margin-bottom: 0;
		-webkit-line-clamp: 1;
	}
	#tours.category .box-tours .box-tours__info-date {
		width: 30%;
	}
	#tours.category .box-tours .box-tours__info-city {
		width: 32%;
	}
	#tours.category .box-tours .box-tours__info-place {
		width: 38%;
	}
	#tours.category .container,
	#gallery.category .container {
		padding-top: 5rem;
		padding-bottom: 5rem;
	}
	#box-success {
		padding: 1.5rem;
	}
	#successModal .modal-dialog {
		width: 744px;
		max-width: 100%;
	}
	#home.product h1 span {
		font-size: 34px;
		line-height: 41px;
		display: inline-block !important;
	}
	#home.product .h2 {
		font-size: 26px;
		line-height: 32px;
	}
	h1, h1 span {
		font-size: 35px;
		line-height: 42px;
	}
	#home.product .top-content {
		text-align: left;
	}
	.timer-grid {
		width: max-content;
		max-width: 100%;
	}
}

@media (min-width: 768px) and (max-width: 991px) {
	#tours.category .box-tours .box-tours__info-time,
	#tours.category .box-tours .box-tours__info-price {
		display: none !important;
	}
}

@media (min-width: 992px) {
	p {
		font-size: 17px;
	}
	.timer-block {
		padding: 9px 24px;
		min-width: 100px;
	}
	.timer-label {
		font-size: 17px;
	}
	h1, h1 span {
		font-size: 41px;
		line-height: 50px;
	}
	#home.product h1 span {
		font-size: 41px;
		line-height: 49px;
	}
	#home.product .h2 {
		font-size: 30px;
		line-height: 36px;
	}
	.box-timer__description {
		font-size: 24px;
	}

	#home {
		min-height: 113px;
	}
	/* lg */
	.nooffcanvas {
		width: 100%;
	}
	#menu .nav-link {
		padding: 12px 12px;
		font-size: 17px;
	}
	#home.main {
		height: 720px;
		background: url(/image/catalog/example/site/home-pc.webp) center no-repeat;
		background-size: cover;
	}
	#home.main p {
		font-size: 18px;
	}
	#home.main .details .row {
		justify-content: end !important;
	}
	#home.product {
		height: 720px;
		background: url(/image/catalog/example/site/show-pc.webp) center no-repeat;
		background-size: cover;
	}
	#home.product p {
		font-size: 18px;
	}
	#home.product .details .row {
		justify-content: end !important;
	}
	h1 span {
		font-size: 43px;
	}
	h1 span.text-part-third {
		font-size: 68px;
	}
	#tours .btn-long {
		width: 246px;
	}
	h2,
	.timer-number {
		font-size: 39px !important;
		line-height: 46px !important;
	}
	.timer-grid {
		gap: 23px;
	}
	#about::before {
		z-index: 0;
	}
	#about .container::before {
		height: 596px;
		width: 298px;
	}
	.swiper-slide .box-team__info-title {
		font-size: 18px;
		line-height: 22px;
	}
	.swiper-slide .box-team__info-description {
		font-size: 14px;
		line-height: 17px;
	}
	.swiper-slide.swiper-slide-active .box-team__info-title {
		font-size: 24px;
		line-height: 29px;
	}
	.swiper-slide.swiper-slide-active .box-team__info-description {
		font-size: 18px;
		line-height: 22px;
	}
	#tours.category .box-tours .box-tours__info-date {
		width: 21%;
	}
	#tours.category .box-tours .box-tours__info-time {
		width: 11%;
	}
	#tours.category .box-tours .box-tours__info-city {
		width: 21%;
	}
	#tours.category .box-tours .box-tours__info-price {
		width: 19%;
	}
	#tours.category .box-tours .box-tours__info-place {
		width: 28%;
	}
	#tours.category .box-tours .box-tours__info-time,
	#tours.category .box-tours .box-tours__info-price {
		display: block !important;
	}
	#tours.category .box-tours .box-tours__info-value {
		font-size: 18px;
		line-height: 22px;
	}
	#successModal .modal-dialog {
		width: 968px;
		max-width: 100%;
	}
	#cookie {
		right: 1.5rem;
		padding: 1rem;
		max-width: calc(360px - 24px);
	}
	#cookie p {
		font-size: 13px;
	}
	.notification p {
		padding: .5rem 0;
		font-size: 18px;
		font-weight: 600;
	}
}

@media (min-width: 1200px) {
	#timer + #faq {
		margin-top: 0 !important;
	}

	#home.product h1 span {
		font-size: 50px;
		line-height: 60px;
	}
	#home.product .h2 {
		font-size: 36px;
		line-height: 43px;
	}
	p {
		font-size: 18px;
	}
	#gallery .media-item .media-item__info {
		font-size: 18px;
		line-height: 22px;
	}
	.timer-label {
		font-size: 18px;
	}
	.breadcrumbs-category li > a {
		font-size: 18px;
		padding: 12px 24px;
	}
	#menu .nav-link {
		font-size: 18px;
	}
	#home.main {
		height: 865px;
		background: url(/image/catalog/example/site/home-tv.webp) center no-repeat;
		background-size: cover;
	}
	#home.product {
		height: 865px;
		background: url(/image/catalog/example/site/show-tv.webp) center 60% no-repeat;
		background-size: cover;
	}
	#faq {
		background: url(/image/catalog/example/site/bg-faq.webp) center no-repeat;
		background-size: cover;
		background-attachment: fixed;
		padding: 3rem 0 calc(3rem + 16px) 0;
	}
	#contacts {
		background: url(/image/catalog/example/site/bg-contacts.webp) center no-repeat;
		background-size: cover;
		background-attachment: fixed;
		position: relative;
	}
	#contacts::before {
		left: 0;
		top: 0;
		content: '';
		width: 100%;
		height: 100%;
		position: absolute;
		background: rgba(0, 0, 0, 0.9);
	}
	.mobile-more-btn {
		font-size: 18px;
		line-height: 22;
		color: #6B9BFF;
	}
	/* xl */
	h1 span {
		font-size: 50px;
	}
	h1 span.text-part-third {
		font-size: 80px;
	}
	h2,
	.timer-number {
		font-size: 48px !important;
		line-height: 54px !important;
	}
	.timer-grid {
		gap: 30px;
	}
	.box-reviews__info {
		margin-bottom: 0.5em;
	}
	.box-reviews__info-name {
		font-size: 24px;
	}
	.box-reviews__info-date,
	.box-reviews__text {
		font-size: 18px;
	}
	.box-reviews__info-photo img {
		width: 65px;
		height: 65px;
	}
	.box-reviews {
		background: none;
		border: none;
		backdrop-filter: none;
		border-radius: 0;
		padding: 0;
		margin-bottom: 2rem;
	}

	.box-reviews.more-available .box-reviews__text-more {
		display: block;
	}
	#home.main {
		height: 720px;
	}
	#home.product {
		height: 720px;
	}
	#about .container::before {
		height: 644px;
		width: 323px;
	}
	#menu .nav-link {
		padding: 1rem 1.5rem;
	}
	.box-reviews {
		min-height: auto;
	}
	.box-reviews__text-more {
		font-size: 18px;
		margin-top: 1rem;
	}
	#faq .accordion-item .accordion-button {
		font-size: 22px;
		/*padding: 1rem 1.5rem 1rem 1rem;*/
		padding: 1rem 1.5rem 1rem 0;
	}
	#faq .accordion-item .accordion-body p {
		font-size: 17px;
	}
	#faq .accordion-item .accordion-body {
		max-width: 60%;
		text-align: justify;
	}
	#team, #stories, #video, #reviews, #timer, #faq, #contacts.product {
		margin-top: 4rem;
	}
	#tours.product {
		margin-bottom: 4rem;
	}
	.box-about__title {
		font-size: 21px;
	}
	.box-about__description {
		font-size: 16px;
	}
	.box-video__title,
	.box-reviews__info-name {
		font-size: 22px;
	}
	.box-reviews__info-date,
	.box-reviews__text {
		font-size: 17px;
	}
	#contacts h3, #contacts .h3,
	#contacts .accordion-item .accordion-button {
		font-size: 22px;
	}
	#contacts .additional-info .contacts-links a,
	#contacts .accordion-item .accordion-body p {
		font-size: 17px;
	}
	.additional-info,
	#contacts .accordion-item {
		text-align: left !important;
	}
	#contacts .accordion-item .accordion-button {
		justify-content: start;
	}
	#contacts .accordion-item .accordion-body{
		padding: 0;
	}
	#contacts .accordion-item .accordion-button {
		padding-left: 0;
		padding-right: 0;
	}
	#contacts .h3 {
		font-size: 17px;
	}
	#contacts .accordion-collapse {
		display: block !important;
		transition: none !important;
	}
	#contacts .accordion-item .accordion-button::after {
		content: none;
	}
	#contacts #form-creator-51 {
		background: none;
		border: none;
		backdrop-filter: none;
		border-radius: 0;
		padding: 0;
		padding-right: 3rem;
	}
	#contacts .btn-long {
		width: auto;
	}
	.text-xl-left {
		text-align: left !important;
	}
	#contacts .additional-info {
		margin-top: 0;
	}
	#contacts .h3 {
		margin-top: 1rem;
	}
	#tours, #contacts {
		padding-top: 4rem;
	}

	#tours.home .swiper-wrapper {
		display: flex;
		flex-wrap: wrap;
		transform: none !important;
	}
	#tours.home .swiper-scrollbar,
	#reviews .swiper-scrollbar {
		display: none;
	}
	#tours.home .box-tours {
		width: 100% !important;
		flex: 0 0 100%;
		max-width: 100%;
		margin-bottom: 0;
		padding: 1rem 0;
		background: none;
		backdrop-filter: none;
		border-radius: 0;
		border: 0;
		border-top: 1px solid #FDFDFD40;
	}
	#tours.home .box-tours:last-child {
		border-bottom: 1px solid #FDFDFD40;
	}
	#tours.home .box-tours .box-tours__info-value {
		margin-bottom: 0;
		font-size: 18px;
		line-height: 22px;
		-webkit-line-clamp: 1;
	}
	#tours.home .box-tours .box-tours__info-date {
		width: 21%;
	}
	#tours.home .box-tours .box-tours__info-time {
		width: 11%;
	}
	#tours.home .box-tours .box-tours__info-city {
		width: 21%;
	}
	#tours.home .box-tours .box-tours__info-price {
		width: 19%;
	}
	#tours.home .box-tours .box-tours__info-place {
		width: 28%;
	}
	/*#tours.home .container {*/
	/*	padding-top: 5rem;*/
	/*	padding-bottom: 5rem;*/
	/*}*/
}

@media (min-width: 1400px) {
	#home.product h1 span {
		font-size: 60px;
		line-height: 72px;
	}
	#home.product .h2 {
		font-size: 48px;
		line-height: 54px;
	}
	#gallery .media-item .media-item__info {
		font-size: 20px;
		line-height: 24px;
	}
	/* xxl */
	#menu .nav-link {
		padding: 1rem 2rem;
	}
	#faq .accordion-item .accordion-button {
		font-size: 24px;
	}
	#faq .accordion-item .accordion-body p {
		font-size: 18px;
	}
	#team, #stories, #video, #reviews, #timer, #faq, #contacts.product {
		margin-top: 5rem;
	}
	#tours.product {
		margin-bottom: 5rem;
	}

	#tours, #contacts, #error {
		padding-top: 5rem;
	}
	.box-video__title,
	.box-reviews__info-name {
		font-size: 24px;
	}
	.box-reviews__info-date,
	.box-reviews__text {
		font-size: 18px;
	}
	#contacts h3, #contacts .h3,
	#contacts .accordion-item .accordion-button {
		font-size: 24px;
	}
	#contacts .additional-info .contacts-links a,
	#contacts .accordion-item .accordion-body p {
		font-size: 18px;
	}
	#contacts .h3 {
		font-size: 18px;
	}
	#contacts .contacts-terms br {
		display: none;
	}
	#contacts .h3 {
		margin-top: 1.5rem;
	}
	#tours.home .box-tours .box-tours__info-date {
		width: 19%;
	}
	#tours.home .box-tours .box-tours__info-time {
		width: 13%;
	}
	#tours.home .box-tours .box-tours__info-city {
		width: 23%;
	}
	#tours.home .box-tours .box-tours__info-price {
		width: 17%;
	}
	#tours.home .box-tours .box-tours__info-place {
		width: 28%;
	}
}

/* Ваши существующие градиенты для разных разрешений */
@media (max-width: 575px) {
	.offcanvas .btn-min-width-180 {
		min-width: auto;
	}
}

@media (min-width: 768px) {
	#home.main::before {
		background: linear-gradient(178.86deg, rgba(0, 0, 0, 0.2) 5.13%, rgba(0, 0, 0, 0.4) 58.68%);
	}
	#home.product::before {
		background: linear-gradient(180deg, rgba(0, 0, 0, 0) 44.73%, rgba(0, 0, 0, 0.93) 79.27%);
	}
}

@media (min-width: 992px) {
	#home.main::before {
		background: linear-gradient(103.5deg, rgba(0, 0, 0, 0) 41.05%, rgba(0, 0, 0, 0.7) 66.12%);
	}
	#home.product::before {
		background: linear-gradient(180deg, rgba(0, 0, 0, 0) 47.3%, #000000 71.92%);
	}
}

.notification-main.has-notification-unique {
	display: none;
}