@font-face {
	font-family: Segoe UI;
	src: url(../fonts/SegoeUI-Regular/SegoeUI-Regular.woff2) format("woff2"), url(../fonts/SegoeUI-Regular/SegoeUI-Regular.woff) format("woff"), url(../fonts/SegoeUI-Regular/SegoeUI-Regular.ttf) format("opentype");
	font-weight: 400;
	font-style: normal;
	font-display: swap
}

@font-face {
	font-family: Segoe UI;
	src: url(../fonts/SegoeUI-Semibold/SegoeUI-Semibold.woff2) format("woff2"), url(../fonts/SegoeUI-Semibold/SegoeUI-Semibold.woff) format("woff"), url(../fonts/SegoeUI-Semibold/SegoeUI-Semibold.ttf) format("opentype");
	font-weight: 700;
	font-style: normal;
	font-display: swap
}

html {
	-webkit-font-smoothing: antialiased
}

body, html {
	height: 100%;
	font-family: Segoe UI, sans-serif;
	font-size: 16px;
	line-height: 1.3;
	color: #474747;
	font-weight: 400;
	font-style: normal
}

body:after {
	display: block;
	padding: 10px;
	position: fixed;
	bottom: 0;
	right: 0;
	background: #000;
	color: #fff;
	visibility: hidden;
	content: "320"
}

body.nav-showed {
	overflow: hidden
}

img {
	max-width: 100%;
	height: auto
}

button, input, textarea {
	-webkit-box-shadow: none;
	box-shadow: none
}

audio, canvas, iframe, img, svg, video {
	vertical-align: middle
}

textarea {
	resize: vertical
}

a:focus, button:focus, input:focus, textarea:focus {
	outline: none
}

dd, dl, dt, li, ol, p, ul {
	margin: 0;
	padding: 0
}

time {
	display: block
}

a {
	text-decoration: none;
	-webkit-transition: color .2s;
	transition: color .2s
}

a, a:hover {
	color: currentColor
}

a:hover {
	text-decoration: underline
}

.hr, hr {
	height: 1px;
	margin: 2em 0;
	border: 0;
	background: #f2f2f2
}

.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
	margin: 0 0 .5rem;
	line-height: 1.32
}

.h2, h2 {
	margin-bottom: 30px;
	font-size: 25px
}

.content-style img, .content-style picture {
	display: block;
	max-width: 100%;
	height: auto;
	margin: 1em auto
}

.content-style p img, .content-style p picture {
	float: right;
	margin: 0 0 .5em .5em
}

.content-style ol {
	margin: 1rem 0;
	counter-reset: olList1
}

.content-style ol li {
	list-style: none;
	padding-left: 17px;
	position: relative
}

.content-style ol li:before {
	position: absolute;
	top: 0;
	left: -5px;
	counter-increment: olList1;
	content: counter(olList1) "."
}

.content-style ol ol {
	margin: 0;
	counter-reset: olList2
}

.content-style ol ol li {
	padding-left: 27px
}

.content-style ol ol li:before {
	counter-increment: olList2;
	content: counter(olList1) "." counter(olList2) "."
}

.content-style ol ol ol {
	margin: 0;
	counter-reset: olList3
}

.content-style ol ol ol li {
	padding-left: 37px
}

.content-style ol ol ol li:before {
	counter-increment: olList3;
	content: counter(olList1) "." counter(olList2) "." counter(olList3) "."
}

.content-style table {
	display: inline-block;
	border-spacing: 0;
	border-collapse: collapse;
	overflow-x: auto;
	max-width: 100%;
	text-align: left;
	vertical-align: top;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0, rgba(0, 0, 0, .15)), to(rgba(0, 0, 0, .15))) 0 0, -webkit-gradient(linear, left top, left bottom, color-stop(0, rgba(0, 0, 0, .15)), to(rgba(0, 0, 0, .15))) 100% 0;
	background: linear-gradient(rgba(0, 0, 0, .15), rgba(0, 0, 0, .15)) 0 0, linear-gradient(rgba(0, 0, 0, .15), rgba(0, 0, 0, .15)) 100% 0;
	background-attachment: scroll, scroll;
	background-size: 1px 100%, 1px 100%;
	background-repeat: no-repeat, no-repeat
}

.content-style table caption {
	font-size: .9em;
	background: #fff
}

.content-style table td, .content-style table th {
	padding: 1em .75em;
	vertical-align: top;
	border: 1px solid #e5e5e5;
	border-top: 0;
	border-left: 0
}

.content-style table td:first-child, .content-style table th:first-child {
	padding-left: 0;
	background-image: -webkit-gradient(linear, left top, right top, color-stop(50%, #fff), to(hsla(0, 0%, 100%, 0)));
	background-image: linear-gradient(90deg, #fff 50%, hsla(0, 0%, 100%, 0));
	background-size: 2px 100%;
	background-repeat: no-repeat
}

.content-style table td:last-child, .content-style table th:last-child {
	padding-right: 0;
	border-right: 0;
	background-image: -webkit-gradient(linear, right top, left top, color-stop(50%, #fff), to(hsla(0, 0%, 100%, 0)));
	background-image: linear-gradient(270deg, #fff 50%, hsla(0, 0%, 100%, 0));
	background-position: 100% 0;
	background-size: 2px 100%;
	background-repeat: no-repeat
}

.content-style table td:only-child, .content-style table th:only-child {
	background-image: -webkit-gradient(linear, left top, right top, color-stop(50%, #fff), to(hsla(0, 0%, 100%, 0))), -webkit-gradient(linear, right top, left top, color-stop(50%, #fff), to(hsla(0, 0%, 100%, 0)));
	background-image: linear-gradient(90deg, #fff 50%, hsla(0, 0%, 100%, 0)), linear-gradient(270deg, #fff 50%, hsla(0, 0%, 100%, 0));
	background-position: 0 0, 100% 0;
	background-size: 2px 100%, 2px 100%;
	background-repeat: no-repeat, no-repeat
}

.content-style table th {
	font-weight: 500;
	line-height: 1.2
}

.btn:active {
	-webkit-transform: translateY(1px);
	transform: translateY(1px)
}

.browserupgrade {
	margin: .2em 0;
	background: #ccc;
	color: #000;
	padding: .2em 0
}

.browserupgrade a {
	text-decoration: underline;
	color: #6b75d7
}

.browserupgrade a:hover {
	text-decoration: none
}

.responsive-img {
	position: relative;
	background-position: 50%
}

.responsive-img:before {
	content: "";
	display: block;
	width: 100%;
	height: 0;
	padding-bottom: 100%
}

.responsive-img > img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%
}

.responsive-img--2x1:before {
	padding-bottom: 50%
}

.responsive-img--3x2:before {
	padding-bottom: 66.67%
}

.responsive-img--4x3:before {
	padding-bottom: 75%
}

.responsive-img--14x9:before {
	padding-bottom: 64.29%
}

.responsive-img--16x9:before {
	padding-bottom: 56.25%
}

img[data-object-fit=contain] {
	-o-object-fit: contain;
	object-fit: contain
}

img[data-object-fit=cover] {
	-o-object-fit: cover;
	object-fit: cover
}

img[data-object-fit=scale-down] {
	-o-object-fit: scale-down;
	object-fit: scale-down
}

img[data-object-fit=none] {
	-o-object-fit: none;
	object-fit: none
}

.fit-img {
	background-size: cover;
	background-position: 50%;
	background-repeat: no-repeat
}

.fit-img > img {
	opacity: 0
}

.fit-img--cover {
	background-size: cover
}

.fit-img--contain {
	background-size: contain
}

.visuallyhidden {
	position: absolute;
	overflow: hidden;
	clip: rect(0 0 0 0);
	height: 1px;
	width: 1px;
	margin: -1px;
	padding: 0;
	border: 0
}

.scale-img {
	overflow: hidden
}

.scale-img img {
	-webkit-transition: 3s ease;
	transition: 3s ease
}

.scale-img:hover img {
	-webkit-transform: scale(1.1);
	transform: scale(1.1)
}

img:not([src]) {
	visibility: hidden
}

img[data-src], img[data-srcset] {
	display: block;
	min-height: 1px
}

.lazyload-error {
	background: url(../img/theme/no-img.png) 50% no-repeat;
	background-size: cover
}

.anychart-tooltip {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	padding: 24px 15px;
	width: 130px;
	color: #474747;
	background-color: hsla(0, 0%, 100%, .8);
	-webkit-backdrop-filter: blur(3px);
	backdrop-filter: blur(3px);
	border-radius: 0
}

.anychart-tooltip .tooltip-img {
	margin-bottom: 10px;
	width: 38px
}

.anychart-tooltip .tooltip-name {
	font-size: 13px
}

.anychart-credits, .anychart-tooltip-separator {
	display: none
}

.btn {
	display: -webkit-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	padding: 15px 20px;
	border: 1px solid transparent;
	border-radius: 0;
	text-align: center;
	background: transparent;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	font-family: inherit;
	text-transform: uppercase;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: .07em;
	-webkit-box-shadow: none;
	box-shadow: none;
	-webkit-transition: background .1s, color .1s, border .1s;
	transition: background .1s, color .1s, border .1s;
	cursor: pointer
}

.btn, .btn:hover {
	text-decoration: none;
	color: currentColor
}

.btn svg {
	display: inline-block;
	vertical-align: middle;
	-webkit-transition: all .1s;
	transition: all .1s;
	fill: currentColor;
	stroke: currentColor
}

.btn--close {
	position: absolute;
	top: 10px;
	right: 10px;
	padding: 0;
	width: 18px;
	height: 18px
}

.btn--close:after, .btn--close:before {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	height: 1px;
	background-color: #474747;
	-webkit-transition: .3s ease;
	transition: .3s ease
}

.btn--close:before {
	-webkit-transform: translate(-50%, -50%) rotate(45deg);
	transform: translate(-50%, -50%) rotate(45deg)
}

.btn--close:after {
	-webkit-transform: translate(-50%, -50%) rotate(-45deg);
	transform: translate(-50%, -50%) rotate(-45deg)
}

.btn--close:hover:after, .btn--close:hover:before {
	background-color: #ff3946
}

.btn--search {
	padding: 0;
	font-size: 20px
}

.btn--search svg {
	fill: none
}

.btn--menu {
	position: relative;
	padding: 0;
	width: 30px;
	height: 25px
}

.btn--menu:after, .btn--menu:before {
	content: "";
	position: absolute;
	left: 0;
	width: 100%;
	height: 5px;
	background-color: #003160;
	-webkit-transition: .3s ease;
	transition: .3s ease
}

.btn--menu:before {
	top: 0;
	-webkit-box-shadow: 0 9px 0 0 #003160;
	box-shadow: 0 9px 0 0 #003160
}

.btn--menu:after {
	bottom: 0
}

.nav-showed .btn--menu:after, .nav-showed .btn--menu:before {
	top: 50%;
	left: 50%
}

.nav-showed .btn--menu:before {
	-webkit-box-shadow: 0 9px 0 0 transparent;
	box-shadow: 0 9px 0 0 transparent;
	-webkit-transform: translate(-50%, -50%) rotate(45deg);
	transform: translate(-50%, -50%) rotate(45deg)
}

.nav-showed .btn--menu:after {
	-webkit-transform: translate(-50%, -50%) rotate(-45deg);
	transform: translate(-50%, -50%) rotate(-45deg)
}

.btn--slider {
	font-size: 20px;
	color: currentColor
}

.btn--slider.swiper-button-disabled {
	color: #848484
}

.btn--small {
	min-width: 0;
	height: rem(36, 16);
	line-height: rem(33, 16)
}

.btn--hollow-white:hover, .btn--hollow:hover {
	background: #002447;
	color: #fff;
	border-color: transparent
}

.btn--hollow-white:active, .btn--hollow:active {
	background: #003160;
	color: #fff;
	border-color: transparent
}

.btn--hollow {
	border-color: #ddd
}

.btn--hollow svg {
	fill: #474747
}

.btn--hollow-white {
	color: #fff;
	border-color: #fff
}

.btn--blue {
	background: #003160;
	color: #fff
}

.btn--blue svg {
	fill: #fff
}

.btn--blue:hover {
	background: #002447;
	color: #fff
}

.btn--blue:active {
	background: #003160;
	color: #fff
}

.btn[disabled] {
	opacity: .5;
	cursor: not-allowed
}

.btn--hover-hollow:hover {
	background: none;
	border-color: #ddd;
	color: #474747
}

.btn--hover-hollow:hover svg {
	fill: #474747
}

.btn--hover-blue:hover {
	background: #003160;
	border-color: hsla(0, 0%, 100%, 0);
	color: #fff
}

.btn--hover-blue:active {
	background: #002447
}

.b-social__list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	list-style: none
}

.b-social__item {
	margin-right: 13px
}

.b-social__item:last-child {
	margin-right: 0
}

.b-social__link {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	width: 40px;
	height: 40px;
	color: #e5e5e5;
	border: 1px solid #e5e5e5;
	border-radius: 50%;
	-webkit-transition: .3s ease;
	transition: .3s ease
}

.b-social__link svg {
	margin: auto;
	fill: currentColor
}

.b-social__link:hover {
	color: #fff;
	background-color: #003160;
	border-color: #003160
}

.b-map {
	position: relative;
	height: 1px;
	height: 530px
}

.b-map__decor {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%
}

.b-map__map {
	height: 100%;
	overflow-x: auto
}

.b-map__map svg #ac_path_3 {
	fill: transparent
}

.b-map__map svg [id^=ac_path] {
	stroke: #fff
}

.b-map__info {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none
}

.map-info-showed .b-map__info {
	pointer-events: auto
}

.b-map-info {
	position: absolute;
	top: 120px;
	left: 50%;
	z-index: 1;
	padding: 20px;
	width: 290px;
	border-radius: 15px;
	background-color: #fff;
	-webkit-box-shadow: 0 11px 30px rgba(0, 0, 0, .11);
	box-shadow: 0 11px 30px rgba(0, 0, 0, .11);
	-webkit-transform: translateX(-50%) translateY(30px);
	transform: translateX(-50%) translateY(30px);
	opacity: 0;
	visibility: hidden;
	-webkit-transition: .5s ease;
	transition: .5s ease
}

.b-map-info__top {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	margin-bottom: 20px
}

.b-map-info__gerb {
	width: 100px
}

.b-map-info__gerb, .b-map-info__name {
	margin-bottom: 15px
}

.b-map-info__title {
	display: block;
	margin-bottom: 5px;
	font-size: 21px;
	font-weight: 700;
	color: #000
}

.b-map-info__subtitle {
	font-size: 14px
}

.b-map-info__number {
	float: left;
	margin-right: 10px;
	font-size: 25px;
	font-weight: 700;
	color: #003160
}

.b-map-info__text {
	font-size: 12px
}

.b-map-info__middle {
	margin-bottom: 20px
}

.b-map-info__props {
	list-style: none
}

.b-map-info__props-item {
	padding: 10px 0;
	border-bottom: 1px solid #848484
}

.b-map-info__props-item:last-child {
	border-bottom: 0
}

.b-map-info__props-number {
	display: block;
	font-size: 18px;
	font-weight: 700;
	color: #003160
}

.b-map-info__link {
	width: 100%;
	max-width: 360px
}

.map-info-showed .b-map-info.active {
	opacity: 1;
	visibility: visible;
	-webkit-transform: translateX(-50%) translateY(0);
	transform: translateX(-50%) translateY(0)
}

.b-statistic {
	list-style: none
}

.b-statistic__item {
	margin-bottom: 30px
}

.b-statistic__content, .b-statistic__item {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex
}

.b-statistic__content {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	padding: 40px 55px;
	width: 100%;
	text-align: center;
	background-color: #fff;
	-webkit-box-shadow: 0 11px 30px rgba(0, 0, 0, .11);
	box-shadow: 0 11px 30px rgba(0, 0, 0, .11);
	-webkit-transition: .5s ease;
	transition: .5s ease
}

.b-statistic__content:hover {
	-webkit-box-shadow: 0 13px 30px rgba(0, 0, 0, .31);
	box-shadow: 0 13px 30px rgba(0, 0, 0, .31)
}

.b-statistic__number {
	margin-bottom: 10px;
	font-size: 53px
}

.b-statistic__number--red {
	color: #ff3946
}

.b-statistic__number--dark-red {
	color: #006718
}

.b-statistic__number--blue {
	color: #003160
}

.b-statistic__number--cyan {
	color: #3d9ffe
}

.b-statistic__text {
	font-size: 18px
}

.b-popular-event__image {
	display: block;
	overflow: hidden
}

.b-popular-event__image:before {
	padding-bottom: 46.7123288%
}

.b-popular-event__description {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	padding: 25px 15px 35px;
	height: 100%;
	color: #fff;
	background-color: #003160
}

.b-popular-event__date {
	margin-bottom: 15px
}

.b-popular-event__title {
	margin-bottom: 20px;
	font-size: 21px
}

.b-popular-event__link {
	-ms-flex-item-align: center;
	align-self: center;
	width: 100%;
	max-width: 350px
}

.b-popular-new__image {
	display: block;
	overflow: hidden
}

.b-popular-new__image:before {
	padding-bottom: 75.862069%
}

.b-popular-new__description {
	padding: 25px 15px;
	background-color: #f2f2f2
}

.b-popular-new__date {
	margin-bottom: 15px;
	color: #848484
}

.b-popular-new__title {
	margin-bottom: 15px;
	font-size: 21px
}

.b-popular-new__text {
	font-size: 15px
}

.b-theme {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-flex: 1;
	-ms-flex-positive: 1;
	flex-grow: 1;
	margin-bottom: 40px;
	max-width: 100%
}

.b-theme__subtitle {
	margin-bottom: 10px;
	padding-top: 30px;
	font-size: 18px;
	color: #003160
}

.b-theme__content {
	position: relative;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	padding: 0 15px;
	background-color: #dfeafe
}

.b-theme__content, .b-theme__slider {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-flex: 1;
	-ms-flex-positive: 1;
	flex-grow: 1
}

.b-theme__slider {
	max-width: 100%
}

.b-theme__slider--news .swiper-wrapper {
	height: auto
}

.b-theme__slide {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column
}

.b-theme__item {
	height: 33.33333%
}

.b-theme__actions {
	padding-bottom: 15px
}

.b-theme__link {
	width: 100%;
	max-width: 360px
}

.b-theme--notice {
	margin-bottom: 0
}

.b-theme--notice .b-theme__content {
	margin: 0 -15px 40px
}

.b-theme-item {
	padding: 15px 0;
	border-bottom: 1px solid #707070
}

.b-theme-item:last-child {
	border: none
}

.b-theme-item__link {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	height: 100%
}

.b-theme-item__image {
	-ms-flex-negative: 0;
	flex-shrink: 0;
	margin-right: 15px;
	width: 120px
}

.b-theme-item__image:before {
	padding-bottom: 65%
}

.b-theme-item__date {
	margin-bottom: 5px;
	font-size: 13px;
	color: #003160
}

.b-theme-item__text, .b-theme-item__title {
	font-size: 14px
}

.b-new__image {
	display: block;
	margin-bottom: 25px;
	overflow: hidden
}

.b-new__image:before {
	padding-bottom: 75.1724138%
}

.b-new__date {
	margin-bottom: 10px;
	color: #848484
}

.b-new__title {
	font-size: 18px
}

.b-gallery__item {
	margin-bottom: 40px
}

.b-gallery__image {
	margin-bottom: 15px
}

.b-gallery__image:before {
	padding-bottom: 75.862069%
}

.b-gallery__text {
	font-size: 18px;
	font-weight: 700
}

.b-gallery__link {
	width: 100%;
	max-width: 360px
}

.b-partners .wrap {
	position: relative
}

.b-partners__slider {
	margin: 0 -15px 15px;
	padding-left: 15px;
	padding-right: 65px;
	overflow: visible
}

.b-partners__slide {
	-ms-flex-pack: center;
	-ms-flex-align: center;
	-ms-flex-item-align: stretch;
	align-self: stretch;
	height: auto;
	min-height: 160px;
	background-color: #fff
}

.b-partners__slide, .b-partners__slide a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	align-items: center
}

.b-partners__slide a {
	-ms-flex-pack: center;
	-ms-flex-align: center;
	width: 190px;
	height: 100px
}

.b-association .wrap {
	position: relative
}

.b-association__title {
	margin-bottom: 70px
}

.b-association__slider {
	overflow: visible
}

.b-association__slide {
	text-align: center
}

.b-association__gerb {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	margin: 0 auto 15px;
	width: 130px;
	height: 130px
}

.b-association__image-1, .b-association__image-2 {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	height: auto;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	-webkit-transition: .3s ease;
	transition: .3s ease
}

.b-association__image-2 {
	opacity: 0
}

.b-association__link:hover {
	text-decoration: none
}

.b-association__link:hover .b-association__image-1 {
	opacity: 0
}

.b-association__link:hover .b-association__image-2 {
	opacity: 1
}

.wrap-site {
	min-height: 100%;
	min-width: 320px;
	width: 100%;
	overflow: hidden;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-flow: column;
	flex-flow: column
}

.main, .wrap-site {
	position: relative
}

.main {
	-webkit-box-flex: 1;
	-ms-flex: 1 0 auto;
	flex: 1 0 auto
}

.wrap {
	width: 100%;
	max-width: 1200px;
	padding-left: 15px;
	padding-right: 15px;
	margin-left: auto;
	margin-right: auto
}

.header__wrapper {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 100;
	padding: 25px 0;
	width: 100%
}

.header__logo {
	display: inline-block;
	vertical-align: top;
	width: 124px
}

.header__language, .header__search {
	margin-right: 23px
}

.header__search {
	position: relative
}

.header__search-form {
	position: absolute;
	top: 100%;
	right: 0;
	border-radius: 2px;
	border: 2px solid #848484;
	-webkit-box-shadow: 0 11px 30px rgba(0, 0, 0, .11);
	box-shadow: 0 11px 30px rgba(0, 0, 0, .11);
	-webkit-transform: translateY(10px);
	transform: translateY(10px);
	opacity: 0;
	visibility: hidden;
	-webkit-transition: .5s ease;
	transition: .5s ease
}

.header__search-form.active {
	-webkit-transform: translateY(0);
	transform: translateY(0);
	opacity: 1;
	visibility: visible
}

.header__search-field {
	padding: 5px 10px;
	border: none;
	border-radius: 2px
}

.top-nav {
	font-size: 14px
}

.top-nav__item {
	position: relative;
	list-style: none;
	text-transform: uppercase
}

.top-nav__item:hover > .top-nav__item-icon {
	-webkit-transform: translateY(-50%) rotate(180deg);
	transform: translateY(-50%) rotate(180deg)
}

.top-nav__item:hover > .top-nav__link {
	text-decoration: underline
}

.top-nav__item:hover > .top-nav__sub-menu {
	opacity: 1;
	visibility: visible;
	-webkit-transform: translateY(0);
	transform: translateY(0)
}

.top-nav__link {
	padding: 15px;
	cursor: pointer
}

.top-nav__item-icon {
	position: absolute;
	top: 50%;
	right: 0;
	font-size: 10px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	-webkit-transition: .3s ease;
	transition: .3s ease
}

.top-nav__item-icon svg {
	fill: currentColor;
	stroke: currentColor
}

.top-nav__sub-menu {
	position: absolute;
	top: calc(100% + 15px);
	left: 15px;
	min-width: 250px;
	background-color: #fff;
	border: 1px solid #e5e5e5;
	list-style: none;
	-webkit-transition: .3s ease;
	transition: .3s ease;
	opacity: 0;
	visibility: hidden;
	-webkit-transform: translateY(-10px);
	transform: translateY(-10px)
}

.top-nav__sub-item {
	position: relative;
	text-transform: none
}

.top-nav__sub-item:last-child {
	margin-bottom: 0
}

.top-nav__sub-item > .top-nav__item-icon {
	right: 30px;
	-webkit-transform: translateY(-50%) rotate(-90deg);
	transform: translateY(-50%) rotate(-90deg)
}

.top-nav__sub-item > .top-nav__sub-menu {
	top: 15px;
	left: 95%;
	-webkit-transform: translateY(0) translateX(10px);
	transform: translateY(0) translateX(10px)
}

.top-nav__sub-item:hover > .top-nav__item-icon {
	-webkit-transform: translateY(-50%) translateX(5px) rotate(-90deg);
	transform: translateY(-50%) translateX(5px) rotate(-90deg)
}

.top-nav__sub-item:hover > .top-nav__sub-link {
	text-decoration: underline
}

.top-nav__sub-item:hover > .top-nav__sub-menu {
	opacity: 1;
	visibility: visible;
	-webkit-transform: translateX(0);
	transform: translateX(0)
}

.top-nav__sub-link {
	display: block;
	padding: 15px 35px;
	cursor: pointer
}

.b-language {
	position: relative
}

.b-language__button {
	padding: 0
}

.b-language__button svg {
	margin-left: 5px;
	font-size: 10px;
	-webkit-transition: .3s ease;
	transition: .3s ease
}

.b-language__list {
	display: none;
	position: absolute;
	top: 100%;
	right: 0;
	padding: 0 10px;
	min-width: 100%;
	background-color: #fff;
	border: 1px solid #e5e5e5;
	list-style: none
}

.b-language__link {
	display: inline-block;
	vertical-align: top;
	padding: 10px 0;
	text-transform: uppercase
}

.b-language.active .b-language__button svg {
	-webkit-transform: rotate(180deg);
	transform: rotate(180deg)
}

.mobile-nav {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 99;
	padding-top: 104px;
	width: 100vw;
	height: 100vh;
	background-color: #fff;
	-webkit-transition: .5s ease-out;
	transition: .5s ease-out;
	opacity: 0;
	-webkit-transform: translateX(100%);
	transform: translateX(100%)
}

.mobile-nav__list {
	padding: 0 25px;
	max-height: 100%;
	list-style: none;
	overflow-y: auto
}

.mobile-nav__item {
	color: #003160
}

.mobile-nav__link {
	position: relative;
	display: inline-block;
	vertical-align: top;
	padding: 15px 0;
	font-size: 18px;
	font-weight: 700;
	text-transform: uppercase
}

.mobile-nav__link.active .mobile-nav__item-icon {
	-webkit-transform: translateY(-50%) rotate(180deg);
	transform: translateY(-50%) rotate(180deg)
}

.mobile-nav__item-icon {
	position: absolute;
	top: 50%;
	right: -25px;
	font-size: 14px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	-webkit-transition: .3s ease;
	transition: .3s ease
}

.mobile-nav__item-icon svg {
	fill: currentColor;
	stroke: currentColor
}

.mobile-nav__sub-menu {
	display: none;
	padding-left: 50px;
	list-style: none
}

.mobile-nav__sub-item {
	color: #474747
}

.mobile-nav__sub-item > .mobile-nav__sub-menu .mobile-nav__sub-link {
	padding: 10px 0
}

.mobile-nav__sub-link {
	position: relative;
	display: inline-block;
	vertical-align: top;
	padding: 15px 0;
	color: #474747
}

.mobile-nav__sub-link.active .mobile-nav__item-icon {
	-webkit-transform: translateY(-50%) rotate(180deg);
	transform: translateY(-50%) rotate(180deg)
}

.nav-showed .mobile-nav {
	-webkit-transition: .5s ease-in;
	transition: .5s ease-in;
	opacity: 1;
	-webkit-transform: translateX(0);
	transform: translateX(0)
}

.footer {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-flow: column;
	flex-flow: column;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	padding: 40px 0 30px
}

.footer__logo {
	display: inline-block;
	vertical-align: top;
	margin-bottom: 40px;
	width: 200px
}

.footer__copyright {
	font-size: 12px
}

.foot-contacts {
	margin-bottom: 40px;
	list-style-type: none
}

.foot-contacts__item {
	margin-bottom: 35px;
	text-align: center
}

.foot-contacts__item:last-child {
	margin-bottom: 0
}

.foot-contacts__name {
	display: inline-block;
	vertical-align: top;
	margin-bottom: 20px;
	font-size: 16px;
	font-weight: 700
}

.foot-contacts__text {
	font-size: 14px;
	line-height: 1.9
}

.foot-contacts__text + .b-social {
	margin-top: 15px
}

[data-tooltip] {
	position: relative
}

[data-tooltip]:after, [data-tooltip]:before {
	z-index: 98;
	opacity: 0;
	visibility: hidden
}

[data-tooltip]:after {
	content: attr(data-tooltip);
	-webkit-box-sizing: content-box;
	box-sizing: content-box;
	height: 12px;
	padding: 6px;
	font-size: 12px;
	white-space: nowrap;
	line-height: 1;
	color: #fff;
	text-shadow: 1px 1px 0 #000;
	background-color: grey
}

[data-tooltip]:after, [data-tooltip]:before {
	position: absolute;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	display: block
}

[data-tooltip]:before {
	content: "";
	height: 0;
	width: 0;
	border-top: 6px solid grey;
	border-left: 3px solid transparent;
	border-right: 3px solid transparent;
	bottom: 100%
}

[data-tooltip]:after {
	bottom: 100%;
	margin-bottom: 6px
}

[data-tooltip]:hover:after, [data-tooltip]:hover:before {
	opacity: 1;
	visibility: visible;
	-webkit-transition: all .15s .2s;
	transition: all .15s .2s
}

.index__first, .index__gallery, .index__news, .index__notice {
	margin-bottom: 50px
}

.index__partners {
	padding: 50px 0;
	background-color: #f6f6f6
}

.index__partners-slider {
	margin-bottom: 25px
}

.index__partners-slider:last-child {
	margin-bottom: 0
}

.index__association {
	padding: 50px 0;
	color: #fff;
	background-color: #003160
}

.b-first__statistic {
	position: relative;
	margin-bottom: 20px
}

.b-first__statistic:after {
	content: "";
	position: absolute;
	top: -50px;
	left: 50%;
	z-index: -1;
	width: 100vw;
	height: 415px;
	background-image: url(../img/theme/points-bg.png);
	background-repeat: repeat-x;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%)
}

.b-news__new, .b-news__popular {
	margin-bottom: 40px
}

.b-news__link {
	width: 100%;
	max-width: 360px
}

@media (min-width: 576px) {
	body:after {
		content: "576px"
	}
}

@media (min-width: 768px) {
	body:after {
		content: "768px"
	}

	.content-style table {
		display: table;
		width: 100%;
		background: none
	}

	.btn--close {
		top: 15px;
		right: 15px
	}

	.btn--slider {
		padding: 0
	}

	.b-map {
		height: 78vh
	}

	.b-map-info {
		top: 160px;
		padding: 25px;
		width: 618px
	}

	.b-map-info__top {
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-direction: row;
		flex-direction: row;
		margin-bottom: 35px
	}

	.b-map-info__gerb, .b-map-info__name {
		margin-bottom: 0;
		margin-right: 15px
	}

	.b-map-info__title {
		margin-bottom: 10px;
		font-size: 25px
	}

	.b-map-info__place {
		margin-left: auto;
		width: 140px
	}

	.b-map-info__number {
		float: none;
		margin-right: 0
	}

	.b-map-info__middle {
		margin-bottom: 30px
	}

	.b-map-info__props {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex
	}

	.b-map-info__props-item {
		padding: 15px 20px;
		border-bottom: none;
		border-right: 1px solid #848484
	}

	.b-map-info__props-item:first-child {
		padding-left: 0
	}

	.b-map-info__props-item:last-child {
		padding-right: 0;
		border-right: none
	}

	.b-popular-event__image:before {
		padding-bottom: 48.461039%
	}

	.b-popular-event__description {
		padding: 25px 40px 35px
	}

	.b-popular-event__date {
		margin-bottom: 30px
	}

	.b-popular-event__title {
		margin-bottom: 40px;
		margin-bottom: 30px
	}

	.b-popular-new {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column
	}

	.b-popular-new__image:before {
		padding-bottom: 100%
	}

	.b-popular-new__description {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
		-webkit-box-flex: 1;
		-ms-flex-positive: 1;
		flex-grow: 1;
		padding: 25px 20px
	}

	.b-theme__title--news {
		width: calc(100% - 90px)
	}

	.b-theme__actions {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		margin: 0 auto;
		padding-bottom: 40px;
		width: 90px
	}

	.b-theme__actions--news {
		position: absolute;
		top: -50px;
		right: 0;
		padding-bottom: 0
	}

	.b-theme--notice .b-theme__content {
		margin: 0 0 40px
	}

	.b-theme--notice .b-theme__slider {
		margin-bottom: 10px
	}

	.b-new__image {
		margin-bottom: 15px
	}

	.b-new__image:before {
		padding-bottom: 75.8389262%
	}

	.b-gallery__item {
		margin-bottom: 35px
	}

	.b-gallery__image:before {
		padding-bottom: 75.8389262%
	}

	.b-partners__slider {
		margin: 0;
		padding: 0
	}

	.b-partners__slide a {
		width: 220px;
		height: 120px
	}

	.b-partners__actions {
		position: absolute;
		top: 10px;
		right: 75px;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		width: 90px
	}

	.b-association__title {
		margin-bottom: 50px
	}

	.b-association__actions {
		position: absolute;
		top: 10px;
		right: 75px;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		width: 90px
	}

	.wrap {
		padding-left: 75px;
		padding-right: 75px
	}

	.header__logo {
		width: 210px
	}

	.top-nav__list {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center
	}

	.mobile-nav {
		padding-top: 140px
	}

	.mobile-nav__list {
		padding: 0 75px
	}

	.mobile-nav__link {
		padding: 17px 0;
		font-size: 24px
	}

	.mobile-nav__sub-link {
		font-size: 18px
	}

	.footer__logo {
		margin-bottom: 55px
	}

	.foot-contacts {
		margin-bottom: 50px
	}

	.foot-contacts__item {
		margin-bottom: 0
	}

	.foot-contacts__text + .b-social {
		margin-top: 20px
	}

	.index__partners-slider {
		margin-bottom: 80px
	}

	.b-first__statistic:after {
		top: 0
	}

	.b-news__title--right {
		width: calc(100% - 90px);
		font-weight: 700
	}

	.b-news__popular {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-flex: 1;
		-ms-flex-positive: 1;
		flex-grow: 1
	}

	.b-news__link {
		margin-top: 20px
	}
}

@media (min-width: 992px) {
	body:after {
		content: "992px"
	}
}

@media (min-width: 1200px) {
	body:after {
		content: "1200px"
	}

	.btn--close {
		top: 25px;
		right: 25px
	}

	.b-social__list {
		-webkit-box-pack: start;
		-ms-flex-pack: start;
		justify-content: flex-start
	}

	.b-map {
		height: 822px
	}

	.b-map-info {
		left: auto;
		padding: 45px 40px 35px;
		width: auto;
		-webkit-transform: translateX(0) translateY(30px);
		transform: translateX(0) translateY(30px)
	}

	.b-map-info__top {
		margin-bottom: 55px
	}

	.b-map-info__gerb {
		margin-right: 25px
	}

	.b-map-info__number {
		font-size: 36px
	}

	.b-map-info__middle {
		margin-bottom: 50px
	}

	.b-map-info__props-item {
		padding: 20px
	}

	.b-map-info__props-number {
		margin-bottom: 5px;
		font-size: 24px
	}

	.map-info-showed .b-map-info.active {
		-webkit-transform: translateX(0) translateY(0);
		transform: translateX(0) translateY(0)
	}

	.b-statistic__item {
		margin-bottom: 0
	}

	.b-statistic__content {
		padding: 40px 45px
	}

	.b-popular-event__image {
		height: 100%
	}

	.b-popular-event__image:before {
		padding-bottom: 46.7123288%
	}

	.b-popular-event__description {
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
		padding: 50px 45px
	}

	.b-popular-new {
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-direction: row;
		flex-direction: row
	}

	.b-popular-new__image {
		width: 48%;
		height: 100%
	}

	.b-popular-new__description {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
		-webkit-box-flex: 0;
		-ms-flex-positive: 0;
		flex-grow: 0;
		padding: 15px 45px;
		width: 52%
	}

	.b-popular-new__date, .b-popular-new__title {
		margin-bottom: 30px
	}

	.b-theme__title--news {
		width: calc(100% - 60px)
	}

	.b-theme__subtitle {
		padding-top: 20px
	}

	.b-theme__actions {
		padding-bottom: 0;
		width: 60px
	}

	.b-theme--notice {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
		-webkit-box-flex: 1;
		-ms-flex-positive: 1;
		flex-grow: 1;
		margin: 0
	}

	.b-theme--notice .b-theme__content {
		margin-bottom: 93px
	}

	.b-theme--notice .b-theme__slider, .b-theme--notice .b-theme__subtitle {
		margin-bottom: 0
	}

	.b-theme--notice .b-theme__wrapper {
		position: relative
	}

	.b-theme--notice .b-theme__actions {
		position: absolute;
		top: 20px;
		right: 15px
	}

	.b-theme--notice .b-theme-item {
		padding: 25px 0
	}

	.b-gallery__image:before, .b-new__image:before {
		padding-bottom: 75.7142857%
	}

	.b-gallery__text {
		height: 46px;
		overflow: hidden
	}

	.b-partners__actions {
		right: 30px;
		width: 60px
	}

	.b-association__title {
		margin-bottom: 60px
	}

	.b-association__actions {
		right: 30px;
		width: 60px
	}

	.wrap {
		padding-left: 30px;
		padding-right: 30px
	}

	.header__search {
		margin-right: 0
	}

	.footer {
		padding-top: 50px
	}

	.footer__top {
		margin-bottom: 50px
	}

	.footer__copyright {
		font-size: 18px
	}

	.foot-contacts {
		margin-bottom: 0
	}

	.foot-contacts__item {
		text-align: left
	}

	.foot-contacts__name {
		font-size: 20px
	}

	.foot-contacts__text {
		font-size: 18px
	}

	.index__gallery-and-notice {
		margin-bottom: 50px
	}

	.index__gallery, .index__notice {
		margin-bottom: 0
	}

	.index__partners-slider {
		margin-bottom: 130px
	}

	.b-first__statistic {
		margin-bottom: 50px
	}

	.b-news__title--right {
		width: calc(100% - 60px)
	}

	.b-news__link {
		margin-top: 10px
	}
}