html{ font-size: 18px; overflow-x: hidden; }
body{ margin:0; font-family: "Comfortaa", sans-serif; font-size: 1rem; overflow-x: hidden; }
img{ max-width: 100%; border:0; }
input:focus, textarea:focus, select:focus{ outline:none; }
input::-moz-focus-inner, select::-moz-focus-inner{ border:0; }
input{ padding:0; margin:0; border:0; }
a{ text-decoration: underline; color: inherit; }
a:hover{ text-decoration: none; color: inherit; }
ul{ padding-left: 1rem; }
ul li{ margin-bottom: .5rem; }
ul li:last-child{ margin-bottom: 0; }

ul.unstyled{ margin: 0; padding: 0; list-style: none; }

.content{ position: relative; }
.content .container{ padding-top: 1rem; padding-bottom: 1rem; }
.container{ position: relative; max-width: 100%; }

.title{ font-size: 1.5rem; margin-bottom: 30px; }
.main-text{ padding: 1rem 0; font-size: 1rem; line-height: 1.25; /* margin-left: auto;*/ margin-right: auto; width: 100%; }

.header{position: relative;}
.header a{ padding: 10px 0; display: block; background-color: #4c3e3d; text-align: center; }
.header__erid{position: absolute;top: 5px; right: 5px; font-size: 0.4rem; color: #ccc; opacity: 0.3;}

.top-picture{ overflow: hidden; min-height: 100vh; height: 100vh; background-position: center center; background-repeat: no-repeat; -webkit-background-size: cover; background-size: cover; background-attachment: fixed; }
.top-picture .top-picture_inner{ position: absolute; width: 100%; height: 100%; left: 0; top: 0; background-position: center center; background-repeat: no-repeat; -webkit-background-size: cover; background-size: cover; background-attachment: fixed; z-index: 10; }
.top-picture.big-picture{ height: 150vh; padding: 3rem 0; }
.top-picture .container{ position: relative; height: 100%; z-index: 20; padding-right: 15px; }
.picture-mobile{ display: none; }

h1{ position: relative; top: 67vh; background: rgba(255,255,255,.75); font-size: 2.8rem; margin: 0; line-height: 1.1; font-weight: normal; padding: .75rem 0 2rem; }
h1:before{ content:''; display: block; position: absolute; background: rgba(255,255,255,.75); width: 100%; left: -100%; top: 0; height: 100%; }
h1 span{ font-size: 10rem; line-height: 1; }
h2, h3{ font-size: 1.55rem; margin-bottom: 1rem; }

.sub-head{ position: absolute; bottom: 0; left: 0; width: 100%; padding: 1.7rem 0; background:rgba(0,0,0,.75); color: #fff; font-size: 2.8rem; line-height: 1; }
.sub-head:before,
.sub-head:after{ content:''; display: block; position: absolute; width: 100%; height: 100%; background:rgba(0,0,0,.75); top: 0; }
.sub-head:before{ left: 100%; }
.sub-head:after{ right: 100%; }

.hidden-info{ position: relative; max-width: 100%; display: inline-block;  font-size: 18px; margin-bottom: 36px; min-width: 96px; min-height: 104px; }
.hidden-info a{ text-decoration: none; }
.hidden-info .info-text{ padding: 30px 30px 30px 96px; opacity: 0; }
.hidden-info.active .info-text{ opacity: 1; }
.hidden-info .info-btn{ position: absolute; left: 0; top: 0; width: 96px; height: 104px; cursor: pointer; background-position: center; animation: attention 3s ease-in-out infinite; transform-origin: center; }
.hidden-info .info-btn:after{ content: ''; position: absolute; inset: 0; background: #ff9700; z-index: -1; animation: ripple 2.5s ease-out infinite; }
.hidden-info.active .info-btn{ animation: none; }
.hidden-info.active .info-btn:after{ display: none; }

.hidden-info.info { background-color: #ff9700; }
.hidden-info.info .info-btn{ background-image:url('../images/i.png?v=3'); }

.hidden-info.casca { background-color: #7cbdf4; }
.hidden-info.casca .info-btn{ background-image:url('../images/casca.png?v=2'); }
.hidden-info.casca .info-btn:after{ background: #7cbdf4; }


@keyframes attention {
	0%, 20%, 50%{ transform: rotate(0deg) scale(1); }
	25%{ transform: rotate(6deg)  scale(1.05); }
    30%{ transform: rotate(-6deg) scale(1.08); }
    35%{ transform: rotate(6deg)  scale(1.08); }
    40%{ transform: rotate(-6deg) scale(1.05); }
    45%{ transform: rotate(0deg) scale(1); }
}

@keyframes ripple {
	0%{ transform: scale(1); opacity: 0.6; }
	70%{ transform: scale(1.6); opacity: 0; }
	100%{ transform: scale(1.6); opacity: 0; }
}

.statistic{ position: relative; display: flex; gap: 30px; }
.statistic__data{ position: relative; max-width: 40%; }
.statistic__steps{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; display: flex; flex-direction: column; }
.statistic__steps .step{ flex-grow: 1; cursor: pointer; }
.statistic__info{ position: relative; flex-grow: 1; }
.statistic__info .item{ position: absolute; max-width: 100%; left: 0; right: 0; top: 40%; padding: 40px; color: #fff; background:rgba(0,0,0,.8); visibility: hidden; opacity: 0; transform: translateY(-50%); transition:0.5s; }
.statistic__info .item.active{ visibility: visible; opacity: 1; top: 50%; }

.scroll-top{ position: fixed; width: 60px; height: 60px; bottom: 50px; left: 50%; margin-left: -640px; padding-top: 17px; color: #fff; font-size: 1.5rem; text-align: center; line-height: 40px; background-color: #ff9700; transition:0.2s; cursor: pointer; visibility: hidden; opacity: 0; z-index: 30; }
.scroll-top.active{ visibility: visible; opacity: 0.6; }
.scroll-top.active:hover{ opacity: 0.85; }

.photo{ display: block; height: 0; padding-bottom: 70%; background-position: center center; background-repeat: no-repeat; background-size: cover; }
.photos { display: flex; align-items: stretch; }
.photos img { display: block; width: 100%; height: 100%; object-fit: cover; }
.cover { width: 340px; height: 400px; object-fit: cover; }

.audio-container { display: flex; align-items: center; gap: 12px; height: 40px; }
.audio-btn {height: 100%; background: none; border: none; padding: 0; cursor: pointer; } 
.audio-btn img { height: 100%; width: auto; }
.waveform-img { height: 100%; width: auto; }

.h-430 img { max-height: 430px; }
.h-750 img { max-height: 750px; }

.video{ position: relative; padding-bottom: 56.25%; }
.video iframe{ position: absolute; left: 0; top: 0; width: 100%; height: 100%; }

@keyframes shake-left {
    0%, 80%, 100% { transform: translateY(-50%) translateX(0); }
    85% { transform: translateY(-50%) translateX(-5px); }
    90% { transform: translateY(-50%) translateX(5px); }
    95% { transform: translateY(-50%) translateX(-3px); }
}

@keyframes shake-right {
    0%, 80%, 100% { transform: translateY(-50%) translateX(0); }
    85% { transform: translateY(-50%) translateX(5px); }
    90% { transform: translateY(-50%) translateX(-5px); }
    95% { transform: translateY(-50%) translateX(3px); }
}

.glide__arrow { background: transparent; border: none; padding: 0; cursor: pointer; position: absolute; top: 50%; transform: translateY(-50%); z-index: 10; transition: opacity 0.3s ease; width: 150px; height: 120px; }
.glide__arrow--left {  left: 10px; animation: shake-left 3s ease-in-out infinite;}
.glide__arrow--right { right: 10px; animation: shake-right 3s ease-in-out infinite;}


/*Слайдер дат v2*/
.date-slider_2.glide { max-width: 1100px; margin: 0 auto; }

.date-slider_2 .glide__slide { display: flex; justify-content: center; overflow: hidden;}
.date-slider_2 .glide__slide img { width: auto; max-width: 100%; height: 750px; object-fit: contain; margin: 0 auto; display: block; }

.date-slider_2 .glide__bullets { display: flex; justify-content: center; align-items: flex-end; margin-bottom: 30px; }
.date-slider_2 .bullet-item { display: flex; flex-direction: column; align-items: center; position: relative; flex: 1;  width: 150px; }
.date-slider_2 .bullet-item::after { content: ""; position: absolute; height: 2px; background: #000000; width: 100%; left: 50%; bottom: 15px; z-index: 1; }
.date-slider_2 .bullet-item .label{ color: #676767; transition: color .2s, font-weight .2s; font-size: 18px;}
.date-slider_2 .icon-wrapper { position: relative; z-index: 2; background: #fff; padding: 0; transition: transform .2s; }
.date-slider_2 .bullet-icon { width: 30px; height: 30px; display: block; transition: transform .2s; }
.date-slider_2 .glide__bullet { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0; cursor: pointer; z-index: 3; }

.date-slider_2 .bullet-item:last-child::after { display: none; }
.date-slider_2 .bullet-item--active .label { font-weight: bold; color: #000; }
.date-slider_2 .bullet-item--active .icon-wrapper { transform: scale(1.3); }
/**/

.footer{ position: relative; overflow-x: hidden; color: #fff; font-size: 15px; }
.footer .inner{ background-color: #4d3e3d; position: relative; padding: 15px 20px 20px; }
.footer .inner:before{ content:''; display: block; position: absolute; width: 100%; height: 18px; top: -18px; left: 0; background:url('../images/footer-before.png'); }
.footer .inner .f-table{ display: table; width: 100%; }
.footer .inner .f-cell{ display: table-cell; vertical-align: middle; width: 33.33%; }
.footer .inner .f-cell *{ vertical-align: middle; }

@media (min-width: 768px){
	.container{ padding-left: 30px; padding-right: 300px; }
	.container.bg-pattern:after{ content:''; display: block; position: absolute; height: 100%; width: 300px; top: 0; right: 0; background-repeat: repeat-y; background-position: top left; background-image: url('../images/bg_main.png'); background-size: 100% auto; }

	.footer{ margin-top: -9px; }
	.footer .container{ padding: 18px 0 0 0; }
	.footer .container:before,
	.footer .container:after{ content:''; display: block; position: absolute; height: 100%; width: 100%; background-color: #4d3e3d; border-top: 5px solid #fff; top: 0; }
	.footer .container:before{ right: 100%; }
	.footer .container:after{ left: 100%; }

	.mobile-only-arrows { display: none; }	
}

@media (min-width: 1200px){
	.container{ padding-left: 40px; padding-right: 350px; }
	.container.bg-pattern:after{ width: 350px; }

	h1{ max-width:80%; }
}

@media (min-width: 1450px){
	.container{ padding-left: 80px; padding-right: 380px; }
	.container.bg-pattern:after{ width: 380px; }
}

@media (min-width: 1600px){
	.container{ padding-left: 120px; padding-right: 550px; }
	.container.bg-pattern:after{ width: 550px; }

	.container{ padding-left: 100px; padding-right: 450px; }
	.container.bg-pattern:after{ width: 450px; }
}

@media (max-width: 1350px){
	.scroll-top{ margin-left: 0; left: 30px; bottom: 30px; }

	h1{ font-size: 1.8rem; }
}

@media (max-width: 1200px){
	html{ font-size: 20px; }
	.header__erid{font-size: 0.5rem;}

	.hidden-info{ min-width: 70px; min-height: 80px; }
	.hidden-info .info-btn{ width: 70px; height: 80px; background-size: cover; }
	.hidden-info .info-text{ padding: 15px 15px 15px 70px; font-size: 16px; }
}

@media (max-width: 992px){
	.sub-head{ font-size: 1.7rem; }

	.statistic{ gap: 15px; }
	.statistic__info .item{ padding: 25px; }

	.date-slider_2 .glide__slide img{ width: auto; height: 600px; }
    .date-slider_2 .glide__bullets { transform: scale(0.8); transform-origin: center; width: 125%; margin-left: -12.5%; }
	.date-slider_2 .bullet-item .label { font-size: 14px; }

	.glide__arrow { width: 80px; height: 80px; }
}

@media (max-width: 767px){
	html{ font-size: 18px; }

	.main-head{ font-size: 3rem; }
	.main-head span{ font-size: 7rem; }
	.h3, h3{ font-size: 1.5rem; }

	.main-text{ padding: .75rem 0; }
	.header__erid{ top: 1px; right: 2px; }

	.statistic{ gap: 10px; }
	.statistic__info .item{ padding: 15px; }

	.date-slider_2 .glide__slide img{ width: auto; height: 500px; max-width: 100%;}
	
	.footer{ background: #4d3e3d; }
	.h-750 img { max-height: 570px; }
	.h-430 img { max-height: 400px; }

	.mobile-only-arrows { display: flex; justify-content: space-between; }
}

@media (max-width: 576px){
	html{ font-size: 16px; }

	.main-head{ font-size: 2.5rem; }
	.main-head span{ font-size: 5rem; }

	.sub-head{ padding-left: 15px; padding-right: 15px; }

	/*.top-picture{ min-height: 65vh; height: 65vh; }*/
	.top-picture,
	.top-picture .top-picture_inner{ background-attachment: unset; }
	.top-picture.big-picture{ height: 104vh; }
	.picture-desktop{ display: none; }
	.picture-mobile{ display: block; }

	.statistic{ gap: 5px; }
	.statistic__info .item{ padding: 10px; font-size: .75rem; }

	
	.date-slider_2 .glide__slide img{ height: 400px; }
	.date-slider_2 .bullet-item .label { font-size: 12px; }
	.date-slider_2 .bullet-icon { width: 15px; height: 15px; }
	.date-slider_2 .bullet-item::after {bottom: 7.5px;}	
}

@media (max-width: 500px){
	.glide__arrow { width: 50px; height: 40px; }
	.date-slider_2 .glide__slide img{ height: 360px; }
	.date-slider_2 .bullet-item .label { font-size: 10px; }
}