:root {
	--navy: #010c32;
	--navy-2: #03123c;
	--navy-3: #182a4c;
	--line: #454f70;
	--white: #fff;
	--gold-1: #bd8b57;
	--gold-2: #ffe7b2;
	--gold-3: #f9c066;
	--container: 1506px;
}

* {
	box-sizing: border-box
}

html {
	scroll-behavior: smooth
}

body {
	margin: 0;
	font-family: Lato, Arial, sans-serif;
	color: var(--white);
	background: var(--navy);
	font-size: 16px;
	line-height: 1.45
}

body.no-scroll {
	overflow: hidden
}

body.access-mode {
	font-size: 19px;
	filter: contrast(1.12)
}

body.access-mode .dark-section {
	background: #00091f
}

body.access-mode a,
body.access-mode button,
body.access-mode h1,
body.access-mode h2 {
	letter-spacing: .02em
}

a {
	color: inherit;
	text-decoration: none
}

button,
input,
select {
	font: inherit
}

button {
	cursor: pointer
}

.container {
	width: min(var(--container), calc(100% - 48px));
	margin-inline: auto
}

.topbar {
	height: 36px;
	background: #010c32;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 32px;
	color: #fff;
	font-size: 14px;
	position: relative;
	z-index: 40
}

.access-btn,
.icon-btn,
.lang-btn,
.main-nav button,
.menu-toggle {
	border: 0;
	background: transparent;
	color: inherit
}

.access-btn {
	display: flex;
	gap: 8px;
	align-items: center;
	font-weight: 800
}

.topbar-right {
	display: flex;
	align-items: center;
	gap: 18px
}

.topbar-right a {
	opacity: .96
}

.divider {
	width: 1px;
	height: 14px;
	background: rgba(255, 255, 255, .35)
}

.social {
	width: 18px;
	height: 18px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 700
}

.site-header {
	height: 80px;
	position: absolute;
	z-index: 35;
	left: 0;
	right: 0;
	top: 36px;
	display: flex;
	align-items: center;
	padding: 0 32px;
	background: rgba(22, 36, 86, .7);
	backdrop-filter: blur(16px);
	box-shadow: inset 0 -1px rgba(255, 255, 255, .14);
	overflow: visible
}

.site-header:before,
.site-header:after {
	content: "";
	position: absolute;
	border-radius: 999px;
	filter: blur(28px);
	pointer-events: none
}

.site-header:before {
	left: 0;
	top: 12px;
	width: 100px;
	height: 100px;
	background: rgba(255, 236, 183, .2)
}

.site-header:after {
	right: 220px;
	bottom: -35px;
	width: 100px;
	height: 100px;
	background: rgba(186, 227, 254, .22)
}

.brand {
	position: relative;
	z-index: 2;
	width: 425px;
	display: flex;
	gap: 8px;
	align-items: center;
	flex-shrink: 0
}

.brand-mark {
	width: 40px;
	height: 56px;
	display: block
}

.brand-mark svg {
	display: block;
	width: 100%;
	height: 100%
}

.brand-text {
	display: flex;
	flex-direction: column;
	gap: 0
}

.brand-text small {
	font-size: 14px;
	font-weight: 400;
	line-height: 16px
}

.brand-text strong {
	font-size: 16px;
	font-weight: 800;
	letter-spacing: .2px;
	line-height: 17px
}

.main-nav {
	position: relative;
	z-index: 2;
	display: flex;
	align-items: center;
	gap: 14px;
	margin-left: 28px;
	white-space: nowrap
}

.main-nav a,
.main-nav button {
	font-size: 15px;
	font-weight: 600;
	color: #fff;
	padding: 12px 0;
	line-height: 1
}

.nav-item {
	position: relative
}

.nav-trigger {
	display: flex;
	align-items: center;
	gap: 4px
}

.dropdown-menu {
	position: absolute;
	top: calc(100% + 18px);
	left: 0;
	min-width: 220px;
	padding: 10px;
	background: rgba(15, 30, 73, .96);
	border: 1px solid rgba(255, 255, 255, .14);
	border-radius: 14px;
	box-shadow: 0 22px 55px rgba(0, 0, 0, .35);
	opacity: 0;
	transform: translateY(-8px);
	pointer-events: none;
	transition: .2s ease
}

.dropdown-menu a {
	display: block;
	padding: 11px 14px;
	border-radius: 10px;
	font-size: 14px
}

.dropdown-menu a:hover {
	background: rgba(255, 255, 255, .1)
}

.nav-item.open .dropdown-menu,
.nav-item:hover .dropdown-menu {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto
}

.wide-nav .dropdown-menu {
	min-width: 270px
}

.gold-btn {
	border: 0;
	border-radius: 8px;
	color: #0b1630;
	font-weight: 700;
	background: linear-gradient(116deg, var(--gold-1) 0%, var(--gold-2) 52%, var(--gold-3) 100%);
	box-shadow: inset 0 0 2px rgba(255, 255, 255, 1), 0 0 4px rgba(255, 234, 179, .75);
	display: inline-flex;
	align-items: center;
	justify-content: center
}

.ticket-btn {
	position: relative;
	z-index: 2;
	margin-left: auto;
	width: 143px;
	height: 40px;
	flex-shrink: 0
}

.lang-wrap {
	position: relative;
	z-index: 2;
	margin-left: 12px
}

.lang-btn {
	font-weight: 600;
	padding: 10px 8px
}

.lang-menu {
	position: absolute;
	right: 0;
	top: 42px;
	min-width: 130px;
	background: #0f1e49;
	border: 1px solid rgba(255, 255, 255, .18);
	border-radius: 12px;
	padding: 8px;
	box-shadow: 0 18px 38px rgba(0, 0, 0, .3);
	display: none
}

.lang-menu.open {
	display: block
}

.lang-menu button {
	display: block;
	width: 100%;
	background: transparent;
	border: 0;
	color: #fff;
	text-align: left;
	padding: 8px 10px;
	border-radius: 8px
}

.lang-menu button:hover {
	background: rgba(255, 255, 255, .1)
}

.menu-toggle {
	display: none;
	position: relative;
	z-index: 2;
	margin-left: auto;
	font-size: 28px
}

.mobile-backdrop {
	display: none
}

.hero {
	position: relative;
	height: 572px;
	overflow: hidden;
	background: #092b55
}

.page-hero>img {
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	width: 100%;
	height: 480px;
	object-fit: cover
}

.hero:before {
	content: "";
	position: absolute;
	inset: 0 0 auto;
	height: 480px;
	background: rgba(0, 0, 0, .25);
	backdrop-filter: blur(2px);
	z-index: 1
}

.hero-gradient {
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	height: 480px;
	background: linear-gradient(90deg, rgba(0, 0, 0, .75), rgba(0, 0, 0, 0));
	z-index: 2
}

.hero-inner {
	position: relative;
	z-index: 3;
	height: 572px
}

.hero h1 {
	position: absolute;
	left: 65px;
	top: 224px;
	margin: 0;
	font-size: 72px;
	line-height: 1;
	font-weight: 600;
	letter-spacing: -.5px
}

.dark-section {
	position: relative;
	overflow: hidden;
	background: #010c32;
	padding: 25px 0 0;
	min-height: 1200px
}

.dark-section>.container {
	position: relative;
	z-index: 2
}

.decor {
	position: absolute;
	z-index: 1;
	border-radius: 999px;
	filter: blur(128px);
	opacity: .1
}

.decor-a {
	left: -96px;
	top: 40px;
	width: 374px;
	height: 374px;
	background: #ffecb7
}

.decor-b {
	left: 535px;
	top: -96px;
	width: 314px;
	height: 314px;
	background: #bae3fe
}

.decor-c {
	right: -175px;
	top: 325px;
	width: 553px;
	height: 553px;
	background: #ffecb7
}

.decor-d {
	right: 560px;
	top: 350px;
	width: 598px;
	height: 598px;
	background: #bae3fe
}

.search-card {
	min-height: 102px;
	width: 100%;
	border: 1px solid #454f70;
	border-radius: 13px;
	background: #182a4c;
	padding: 12px 24px;
	display: grid;
	grid-template-columns: repeat(4, 1fr) 237px;
	gap: 10px;
	align-items: center
}

.search-card label {
	position: relative;
	display: block
}

.search-card select {
	width: 100%;
	height: 47px;
	border: 1px solid #bac0c2;
	border-radius: 5px;
	background: #fff;
	color: #1f2a3f;
	appearance: none;
	padding: 0 44px 0 17px
}

.search-card label:after {
	content: "";
	position: absolute;
	right: 18px;
	top: 20px;
	border-left: 7px solid transparent;
	border-right: 7px solid transparent;
	border-top: 7px solid #1f2a3f
}

.search-card .gold-btn {
	height: 47px;
	font-size: 16px
}

.filter-status {
	min-height: 26px;
	margin: 10px 4px 0;
	color: #ffe7b2;
	font-weight: 600
}

.gallery-block {
	margin-top: 42px
}

.gallery-block.first-block {
	margin-top: 28px
}

.gallery-block h2 {
	margin: 0 0 17px;
	font-size: 23px;
	line-height: 29px;
	font-weight: 600
}

.gallery-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 11px 14px
}

.gallery-grid a {
	display: block;
	border-radius: 5px;
	overflow: hidden;
	background: #0c1737;
	aspect-ratio: 292/219;
	position: relative
}

.gallery-grid img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
	transition: transform .25s ease, filter .25s ease
}

.gallery-grid a:hover img {
	transform: scale(1.045);
	filter: brightness(1.08)
}

.gallery-card.hidden {
	display: none
}

.gallery-block.empty {
	display: none
}

.last-block {
	padding-bottom: 120px
}

.footer-strip {
	position: relative;
	z-index: 3;
	width: 100%;
	height: 145px;
	object-fit: cover;
	display: block;
	margin-top: 0
}

.detail-page {
	min-height: 1800px
}

.detail-page .search-card+.photo-detail {
	margin-top: 82px
}

.hero-photo {
	position: relative;
	margin: 0;
	width: 100%;
	aspect-ratio: 1506/1129;
	overflow: hidden;
	background: #000
}

.hero-photo>img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: opacity .22s ease
}

.hero-photo>img.is-changing {
	opacity: .25
}

.photo-title {
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	height: 66px;
	background: rgba(0, 0, 0, .33);
	border-radius: 0 0 27px 27px;
	padding: 18px 45px;
	font-size: 23px;
	line-height: 29px;
	font-weight: 600
}

.photo-bottom {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 66px;
	background: rgba(0, 0, 0, .51);
	border-radius: 27px 27px 0 0;
	display: flex;
	align-items: center;
	justify-content: center
}

.views {
	position: absolute;
	left: 50px;
	font-size: 23px;
	font-weight: 600;
	border: 0;
	background: transparent;
	color: #fff
}

.views.liked {
	color: #ffe7b2
}

.dots {
	display: flex;
	gap: 6px
}

.dots button {
	width: 8px;
	height: 8px;
	border: 0;
	padding: 0;
	border-radius: 50%;
	background: #b8ccff
}

.dots button.active {
	background: #70a5ff;
	transform: scale(1.25)
}

.slide {
	position: absolute;
	top: 47%;
	transform: translateY(-50%);
	width: 86px;
	height: 86px;
	border: 0;
	border-radius: 999px;
	background: rgba(0, 0, 0, .14);
	color: #fff;
	font-size: 90px;
	line-height: 70px
}

.slide:hover {
	background: rgba(0, 0, 0, .32)
}

.slide.prev {
	left: 70px
}

.slide.next {
	right: 37px
}

.thumb-row {
	margin: 26px auto 0;
	width: calc(100% - 132px);
	display: grid;
	grid-template-columns: 32px 1fr 32px;
	align-items: center;
	gap: 12px
}

.thumb-track {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 12px
}

.thumb-track button {
	border: 0;
	padding: 0;
	border-radius: 4px;
	overflow: hidden;
	height: 200px;
	background: #111b3f;
	outline: 3px solid transparent
}

.thumb-track button.active {
	outline-color: #ffe7b2
}

.thumb-track img {
	height: 100%;
	width: 100%;
	object-fit: cover;
	display: block
}

.thumb-arrow {
	border: 0;
	background: transparent;
	color: #fff;
	font-size: 58px
}

.thumb-arrow:hover {
	color: #ffe7b2
}

.detail-section {
	margin-top: 34px;
	color: #fff;
	border-top: 1px solid rgba(255, 255, 255, .85)
}

.detail-section h2 {
	margin: 0
}

.detail-section h2 button {
	width: 100%;
	height: 49px;
	border: 0;
	border-bottom: 1px solid rgba(255, 255, 255, .85);
	background: transparent;
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 21px;
	font-size: 23px;
	line-height: 29px;
	font-weight: 600;
	text-align: left
}

.detail-section h2 span {
	transition: .2s
}

.detail-section:not(.open) h2 span {
	transform: rotate(-90deg)
}

.accordion-content {
	overflow: hidden;
	transition: max-height .25s ease
}

.detail-section:not(.open) .accordion-content {
	max-height: 0 !important
}

.detail-section p {
	margin: 19px 21px 0;
	max-width: 1466px;
	color: #fff;
	font-size: 23px;
	line-height: 1.46
}

.detail-section ul {
	list-style: none;
	margin: 16px 21px 0;
	padding: 0;
	font-size: 23px;
	line-height: 1.5
}

.detail-section strong {
	font-weight: 600
}

.video-section {
	margin-top: 20px;
	padding-bottom: 120px
}

.video-card {
	position: relative;
	margin-top: 28px;
	width: 96%;
	aspect-ratio: 1445/857;
	overflow: hidden;
	background: #000
}

.video-card video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block
}

.play {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 183px;
	height: 183px;
	border: 0;
	border-radius: 50%;
	background: rgba(255, 255, 255, .45);
	box-shadow: 0 0 0 8px rgba(255, 255, 255, .15);
	transition: .2s
}

.play:after {
	content: "";
	position: absolute;
	left: 72px;
	top: 50px;
	border-left: 62px solid #fff;
	border-top: 41px solid transparent;
	border-bottom: 41px solid transparent
}

.video-card.playing .play {
	opacity: 0;
	pointer-events: none
}

.player-panel {
	position: absolute;
	left: 20px;
	right: 20px;
	bottom: 16px;
	display: grid;
	grid-template-columns: 46px 1fr 54px 46px 46px;
	gap: 12px;
	align-items: center;
	padding: 10px 12px;
	border-radius: 999px;
	background: rgba(0, 0, 0, .54);
	backdrop-filter: blur(8px);
	opacity: 0;
	transform: translateY(12px);
	transition: .2s
}

.video-card:hover .player-panel,
.video-card.playing .player-panel {
	opacity: 1;
	transform: translateY(0)
}

.player-panel button {
	border: 0;
	background: rgba(255, 255, 255, .15);
	color: #fff;
	border-radius: 999px;
	height: 36px
}

.progress {
	height: 8px;
	background: rgba(255, 255, 255, .25);
	border-radius: 999px;
	overflow: hidden;
	cursor: pointer
}

.progress span {
	display: block;
	width: 0;
	height: 100%;
	background: #ffe7b2
}

.player-panel time {
	font-size: 13px;
	color: #fff;
	text-align: center
}

.modal {
	position: fixed;
	inset: 0;
	z-index: 100;
	display: grid;
	place-items: center;
	background: rgba(1, 12, 50, .72);
	backdrop-filter: blur(8px);
	padding: 20px
}

.modal[hidden] {
	display: none
}

.modal-dialog {
	width: min(560px, 100%);
	background: #14264f;
	border: 1px solid rgba(255, 255, 255, .18);
	border-radius: 20px;
	padding: 28px;
	box-shadow: 0 30px 80px rgba(0, 0, 0, .45);
	position: relative
}

.modal-dialog h2 {
	margin: 0 0 18px;
	font-size: 28px
}

.modal-close {
	position: absolute;
	right: 16px;
	top: 12px;
	width: 38px;
	height: 38px;
	border: 0;
	border-radius: 50%;
	background: rgba(255, 255, 255, .1);
	color: #fff;
	font-size: 28px
}

.search-dialog form,
.ticket-form {
	display: grid;
	grid-template-columns: 1fr 140px;
	gap: 10px
}

.ticket-form {
	grid-template-columns: 1fr 1fr 160px 140px
}

.search-dialog input,
.ticket-form input {
	height: 46px;
	border: 1px solid #bac0c2;
	border-radius: 8px;
	padding: 0 14px
}

.search-results {
	margin-top: 16px
}

.search-results a {
	display: block;
	padding: 10px;
	border-radius: 10px;
	background: rgba(255, 255, 255, .08);
	margin-top: 8px
}

@media (max-width:1700px) {
	.main-nav {
		gap: 10px;
		margin-left: 22px
	}

	.main-nav a,
	.main-nav button {
		font-size: 13px
	}

	.brand {
		width: 360px
	}

	.ticket-btn {
		width: 135px
	}
}

@media (max-width:1280px) {
	.site-header {
		padding: 0 20px
	}

	.main-nav {
		position: fixed;
		right: 0;
		top: 0;
		bottom: 0;
		width: min(390px, 86vw);
		background: #0b1b45;
		display: flex;
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		margin: 0;
		padding: 96px 24px 24px;
		transform: translateX(104%);
		transition: .25s ease;
		z-index: 80;
		overflow: auto
	}

	.main-nav.open {
		transform: translateX(0)
	}

	.main-nav a,
	.main-nav button {
		font-size: 17px;
		padding: 15px 8px;
		text-align: left
	}

	.nav-item {
		border-bottom: 1px solid rgba(255, 255, 255, .08)
	}

	.dropdown-menu {
		position: static;
		opacity: 1;
		transform: none;
		pointer-events: auto;
		display: none;
		min-width: 0;
		box-shadow: none;
		background: rgba(255, 255, 255, .06);
		border-radius: 12px;
		margin-bottom: 10px
	}

	.nav-item.open .dropdown-menu {
		display: block
	}

	.menu-toggle {
		display: block
	}

	.mobile-backdrop.show {
		display: block;
		position: fixed;
		inset: 0;
		background: rgba(0, 0, 0, .45);
		z-index: 70
	}

	.ticket-btn,
	.lang-wrap {
		display: none
	}

	.brand {
		width: auto
	}

	.search-card {
		grid-template-columns: repeat(2, 1fr);
		padding: 18px
	}

	.search-card .gold-btn {
		grid-column: 1/-1
	}

	.gallery-grid {
		grid-template-columns: repeat(3, 1fr)
	}

	.hero h1 {
		left: 24px;
		font-size: 56px
	}


	.detail-page .search-card+.photo-detail {
		margin-top: 56px
	}

	.thumb-row {
		width: 100%
	}

	.thumb-track {
		grid-template-columns: repeat(3, 1fr)
	}

	.thumb-track button:nth-child(n+4) {
		display: none
	}

	.thumb-track button {
		height: 150px
	}

	.detail-section p,
	.detail-section ul {
		font-size: 18px
	}

	.video-card {
		width: 100%
	}

	.ticket-form {
		grid-template-columns: 1fr
	}
}

@media (max-width:760px) {
	.container {
		width: calc(100% - 28px)
	}

	.topbar {
		padding: 0 14px
	}

	.topbar-right a:not(.social),
	.divider,
	.icon-btn {
		display: none
	}

	.access-btn span {
		display: none
	}

	.site-header {
		top: 36px;
		height: 74px
	}

	.brand-text small {
		font-size: 11px
	}

	.brand-text strong {
		font-size: 12px
	}

	.brand-mark {
		width: 32px;
		height: 46px
	}

	.hero {
		height: 460px
	}

	.page-hero>img,
	.hero:before,
	.hero-gradient {
		height: 390px
	}

	.hero h1 {
		top: 190px;
		font-size: 38px
	}

	.dark-section {
		padding-top: 18px
	}

	.search-card {
		grid-template-columns: 1fr
	}

	.gallery-block {
		margin-top: 36px
	}

	.gallery-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 10px
	}

	.last-block {
		padding-bottom: 90px
	}

	.footer-strip {
		height: 85px
	}

	.detail-page .search-card+.photo-detail {
		margin-top: 34px
	}

	.photo-title {
		height: 50px;
		padding: 12px 18px;
		font-size: 18px
	}

	.photo-bottom {
		height: 50px
	}

	.views {
		left: 18px;
		font-size: 16px
	}

	.slide {
		display: none
	}

	.thumb-row {
		grid-template-columns: 1fr;
		gap: 10px;
		width: 100%
	}

	.thumb-arrow {
		display: none
	}

	.thumb-track {
		grid-template-columns: 1fr 1fr;
		gap: 10px
	}

	.thumb-track button {
		height: 110px
	}

	.thumb-track button:nth-child(n+3) {
		display: none
	}

	.detail-section h2 button {
		font-size: 19px;
		padding: 0 12px
	}

	.detail-section p,
	.detail-section ul {
		margin-left: 12px;
		margin-right: 12px;
		font-size: 16px
	}

	.play {
		width: 92px;
		height: 92px
	}

	.play:after {
		left: 37px;
		top: 27px;
		border-left-width: 30px;
		border-top-width: 20px;
		border-bottom-width: 20px
	}

	.player-panel {
		left: 10px;
		right: 10px;
		grid-template-columns: 38px 1fr 44px;
		gap: 8px;
		border-radius: 18px
	}

	.player-panel button:nth-last-child(-n+2) {
		display: none
	}

	.search-dialog form {
		grid-template-columns: 1fr
	}

	.modal-dialog {
		padding: 22px
	}
}

@media (max-width:480px) {
	.gallery-grid {
		grid-template-columns: 1fr
	}

	.search-card {
		padding: 12px
	}

	.hero h1 {
		font-size: 32px
	}

	.topbar-right {
		gap: 10px
	}

	.photo-bottom .dots {
		display: none
	}

	.thumb-track {
		grid-template-columns: 1fr
	}

	.thumb-track button:nth-child(n+2) {
		display: none
	}
}

.three-d-btn{
		position: absolute;
		top: 7px;
		right: 50px;

		display: flex;
		align-items: center;
		justify-content: center;
		gap: 8px;

		padding: 10px 14px;

		background: rgba(255,255,255,0.92);
		backdrop-filter: blur(8px);

		border-radius: 14px;

		box-shadow:
				0 8px 24px rgba(0,0,0,0.15),
				inset 0 1px 0 rgba(255,255,255,0.6);

		transition: .25s ease;
		z-index: 20;

		text-decoration: none;
}

.three-d-btn span{
		font-size: 14px;
		font-weight: 600;
		color: #222;
		white-space: nowrap;
}

.three-d-btn:hover{
		transform: translateY(-2px) scale(1.05);
		box-shadow:
				0 12px 30px rgba(0,0,0,0.2),
				inset 0 1px 0 rgba(255,255,255,0.7);
}

.three-d-btn img{
		width: 24px;
		height: 24px;
		object-fit: contain;
}
