/* important */

body {
  font-family: 'DM Sans';
}

.d-none {
  display: none !important;
}

.w-100 {
  width: 100% !important;
}

.h-auto {
  height: auto !important;
}

.height-30px {
  height: 30px !important;
}

.mb-24px {
  margin-bottom: 24px !important;
}

.pointer-events-none {
  pointer-events: none !important;
}

.color-red {
  color: #e85226 !important;
}

.color-green {
  color: #49cbb0 !important;
}

.color-violet {
  color: #bb99f2 !important;
}

@media (max-width: 991px) {
  .d-none-for-xs {
    display: none !important;
  }

  .w-100-for-xs {
    width: 100% !important;
  }

  .height-30px-for-xs {
    height: 30px !important;
  }

  .mt-4px-for-xs {
    margin-top: 4px !important;
  }

  .mt-48px-for-xs {
    margin-top: 48px !important;
  }

  .mb-36px-for-xs {
    margin-bottom: 36px !important;
  }

  .height-18px-for-mobile {
    height: 18px !important;
  }
}

@media (min-width: 992px) {
  .d-none-for-desktop {
    display: none !important;
  }

  .height-30px-for-desktop {
    height: 30px !important;
  }

  .height-41px-for-desktop {
    height: 41px !important;
  }

  .mt-24px-for-desktop {
    margin-top: 24px !important;
  }

  .mt-90px-for-desktop {
    margin-top: 90px !important;
  }

  .mb-48px-for-desktop {
    margin-bottom: 48px !important;
  }

  .pr-48px-for-desktop {
    padding-right: 48px !important;
  }

  .w-50-for-desktop {
    width: 50% !important;
  }
}

/* front page cover */

.front-page-cover {
  height: calc(100vh - 92px - 0.362rem);
  background-size: cover;
  background-repeat: no-repeat;
  background-position-y: 70%;
}

.front-page-cover h2 {
  margin: 0;
  padding: 24px 36px;
  font-size: 35px;
  line-height: 41px;
  font-weight: 800;
  text-transform: uppercase;
  font-family: 'DM Sans';
  border-radius: 15px;
  border: 1px solid #000;
}

.front-page-cover h2 span {
  display: inline-block;
  margin-bottom: 12px;
  margin-bottom: 0;
  color: #9286dd;
  font-family: 'DM Sans';
  font-size: 35px;
  line-height: 41px;
  font-weight: 800;
}

.front-page-cover .front-title {
  position: absolute;
  z-index: 1;
  top: calc(30% - 90px);
  /*bottom: 48px;*/
  left: 48px;
  width: 30%;
  padding: 16px;
  padding-top: 24px;
  color: #bb99f2;
  background-color: rgba(255, 255, 255, 0.75);
  background-color: #f5fae8;
  border-radius: 0.156rem;
  border: 5px solid #49cbb0;
  outline: 1px solid #000;
  transform: rotate(-5deg);
}

.front-page-cover .front-title img {
  width: 90%;
  height: auto;
  margin-left: 5%;
  transform: rotate(5deg);
}

.front-page-cover .front-title-new {
  position: absolute;
  z-index: 1;
  top: calc(20% - 90px);
  /*bottom: 48px;*/
  left: 48px;
  width: 30vw;
  max-width: 500px;
}

.front-page-cover .front-title-new img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.center .people {
  width: 7rem;
  height: 3.5rem;
  right: -0.5rem;
}

.front-page-cover .cookies {
  align-items: center;
}

.front-page-cover .cookies img {
  width: 100%;
  height: auto;
}

.front-page-cover .cookies span.desc {
  display: none;
}

.front-page-cover .cookies .btn {
  -webkit-transition: all 0.2s ease-out;
  -moz-transition: all 0.2s ease-out;
  -o-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}

.front-page-cover .cookies .btn:hover {
  background-color: #e4f1c0;
}

.front-page-cover .front-link {
  position: absolute;
  top: 102%;
  left: 50%;
  transform: translateX(-50%);
  width: 65%;
}

/* front page trailer */


.front-page-trailer {
  margin-top: 1rem;
  margin-bottom: .5rem;
  padding-left: 0.13rem;
  padding-right: 0.13rem;
  position: relative;
}

.front-page-trailer .youtube {
  border: 1px solid #36363d;
  border-radius: 0.156rem;
  width: 100%;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
  aspect-ratio: 16 / 9;

}

/* front page song */

.front-page-song {
  display: flex;
  flex-direction: column;
  height: calc(100vh - 0.683rem);
  height: auto;
  margin-top: 66px;
  margin-bottom: 46px;
}

.front-page-song .description {
  flex: 1 1 45%;
  width: 45%;
  max-width: 45%;
  min-width: 45%;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: center;
  padding: 0 0.677rem;
  padding-right: 0;
}

.front-page-song h2 {
  width: 90%;
  margin: 16px 0;
  margin-top: 32px;
  padding: 0;
  color: #000;
  font-family: 'Roc Grotesk Condensed';
  font-size: 80px;
  font-weight: bold;
  line-height: 70px;
  text-transform: uppercase;
}

.front-page-song p {
  width: 80%;
  margin: 0;
  padding: 0;
  color: #000;
  font-family: 'DM Sans';
  font-size: 16px;
  line-height: 20px;
}

.front-page-song a {
  display: flex;
  align-self: flex-start;
  margin: 0;
  padding: 17px 48px 15px;
  color: #36363d;
  font-family: 'DM Sans';
  font-size: 25px;
  font-weight: 700;
  line-height: 25px;
  text-transform: uppercase;
  text-decoration: none;
  background-color: #bb99f2;
  border: 1px solid #000000;
  border-radius: 0.156rem;
  cursor: pointer;
  -webkit-transition: all 0.2s ease-out;
  -moz-transition: all 0.2s ease-out;
  -o-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}

.front-page-song a:hover {
  color: #fff;
  text-decoration: none;
  background-color: #49cbb0;
}

.front-page-song .photo {
  position: relative;
  flex: 1 1 55%;
  width: 55%;
  max-width: 55%;
  min-width: 55%;
  padding-right: 0.677rem;
  /*background-image: url('../img/characters.png');*/
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}

.front-page-song .photo > span {
  position: absolute;
  bottom: 32px;
  left: 0;
  width: calc(100% - 0.677rem);
  text-align: center;
  color: #fff;
  font-size: 30px;
  font-weight: 800;
  text-transform: uppercase;
  font-family: 'Roc Grotesk Condensed';
}

.front-page-song .photo img {
  width: 100%;
  height: auto;
  border-radius: 0.156rem;
}

.front-page-song .photo video {
  width: 100%;
  height: auto;
  border-radius: 0.156rem;
}

.front-page-song .song-content {
  display: flex;
  align-items: stretch;
  justify-content: center;
}
.front-page-song img.under-your-windows-title {
  width: 75%;
  height: auto;
  margin-top: 24px;
  margin-bottom: 24px;
}

/* front page contest */

.front-page-contest {
  display: flex;
  flex-direction: column;
  height: calc(100vh - 0.683rem);
  height: auto;
  margin-top: 66px;
  margin-bottom: 46px;
}

.front-page-contest .contest-content {
  padding: 0 0.677rem;
}

.front-page-contest .contest-content h4 {
  font-family: 'Roc Grotesk Condensed';
  font-size: 35px;
  line-height: 40px;
  margin-bottom: 32px;
  margin-top: 0;
  font-weight: 700;
  text-transform: uppercase;
}

.front-page-contest .contest-content .blocks {
  display: flex;
  gap: 48px;
}

.front-page-contest .contest-content .blocks > div {
  flex: 1 1 calc(100% / 2.5 - 32px);
  width: calc(100% / 2.5 - 32px);
  max-width: calc(100% / 2.5 - 32px);
  min-width: calc(100% / 2.5 - 32px);
  padding: 24px 32px;
  background-color: #fff;
  border-radius: 0.156rem;
}

.front-page-contest .contest-content .blocks > div.when {
  flex: 1 1 calc(100% / 5 - 32px);
  width: calc(100% / 5 - 32px);
  max-width: calc(100% / 5 - 32px);
  min-width: calc(100% / 5 - 32px);
}

.front-page-contest .contest-content .blocks p {
  margin-bottom: 8px;
  width: 90%;
}

.front-page-contest .contest-content .blocks p:last-child {
  margin-bottom: 0;
}

.front-page-contest .contest-content .blocks p span {
  display: inline-block;
  margin-bottom: 12px;
  font-weight: 700;
}

.front-page-contest img.under-your-windows-title {
  width: 75%;
  height: auto;
  margin-top: 24px;
  margin-bottom: 24px;
}

.front-page-contest .contest-title {
  width: 50%;
  margin-left: 25%;
  margin-bottom: 32px;
  height: auto;
}

/* front page banner */

.front-page-banner {
  padding: 24px 0.677rem;
  background-color: #fff;
}

.front-page-banner-container {
  position: relative;
}

.front-page-banner-buttons {
  position: absolute;
  bottom: 10%;
  left: 0;
  width: 100%;
  z-index: 1;
  display: flex;
  padding: 0 7%;
  gap: 16px;
  height: 20%;
}

.front-page-banner-button {
  width: 100%;
  height: 100%;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* front page banner crustum */

.front-page-banner-crustum {
  padding: 24px 0.677rem;
  background-color: #fff;
}

.front-page-banner-container {
  border-radius: 0.156rem;
  overflow: hidden;
  border: 1px solid #000;
  position: relative;
}

.front-page-banner-container img {
  width: 100%;
  height: auto;
  display: block;
}



/* front page superpower */

.front-page-superpower {
  height: auto;
  padding: 64px 0.677rem;
  padding-top: 0;
  background-color: #fff;
}

.front-page-superpower h2 {
  margin: 0;
  margin-bottom: 20px;
  padding: 0;
  color: #36363d;
  font-family: 'Roc Grotesk Condensed';
  font-size: 55px;
  font-weight: bold;
  line-height: 60px;
  text-transform: uppercase;
}

.front-page-superpower h3 {
  margin: 0;
  margin-bottom: 24px;
  padding: 0;
  color: #36363d;
  font-family: 'Roc Grotesk Condensed';
  font-size: 40px;
  font-weight: bold;
  line-height: 50px;
  text-transform: uppercase;
}

.front-page-superpower p {
  margin: 0 auto;
  padding: 0;
  color: #000;
  font-family: 'DM Sans';
  font-size: 16px;
  line-height: 24px;
}

.front-page-superpower .titles {
  text-align: center;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}

.front-page-superpower .titles p {
  width: 50%;
  margin-bottom: 24px;
}

.front-page-superpower .titles p:last-child {
  margin-bottom: 56px;
}

.front-page-superpower .titles .main-message {
  padding: 20px 32px;
  background-color: #f5fae8;
  border: 1px solid #000;
  border-radius: 0.156rem;
}

.front-page-superpower .titles .event-title {
  margin-top: 55px;
  margin-bottom: 25px;
  color: #49cbb0;
  font-family: 'Roc Grotesk Condensed';
  font-size: 45px;
  font-weight: bold;
  line-height: 45px;
  text-transform: uppercase;
}

.front-page-superpower .individual-block {
  display: flex;
  align-items: center;
  background-color: #f5fae8;
  border-radius: 0.156rem;
  border: 1px solid #000;
}

.front-page-superpower .blocks {
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.front-page-superpower .individual-block .description {
  flex: 1 1 50%;
  width: 50%;
  max-width: 50%;
  min-width: 50%;
  padding: 32px 64px;
}

.front-page-superpower .individual-block .description p {
  margin-bottom: 0;
}

.front-page-superpower .individual-block .description img {
  width: auto;
  height: 32px;
  margin-bottom: 16px;
}

.front-page-superpower .individual-block .photo {
  flex: 1 1 50%;
  width: 50%;
  max-width: 50%;
  min-width: 50%;
  height: 360px;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}

.front-page-superpower .individual-block.photo-left .photo {
  border-top-left-radius: 0.156rem;
  border-bottom-left-radius: 0.156rem;
}

.front-page-superpower .individual-block.photo-right .photo {
  border-top-right-radius: 0.156rem;
  border-bottom-right-radius: 0.156rem;
}

.front-page-superpower .individual-block .photo img {
  width: 100%;
  height: auto;
}

/* front page bar */

.front-page-bar {
  background-color: #fff;
  padding-top: 16px;
}

/* front page newsletter */

.front-page-newsletter {
  height: auto;
  display: flex;
  align-items: center;
  padding: 64px 0.677rem;
  background-color: #36363d;
}

.front-page-newsletter > div {
  flex: 1 1 50%;
  width: 50%;
  max-width: 50%;
  min-width: 50%;
}

.front-page-newsletter > div.full {
  flex: 1 1 100%;
  width: 100%;
  max-width: 100%;
  min-width: 100%;
  text-align: center;
}

.front-page-newsletter h2 {
  width: 90%;
  margin: 0;
  padding: 0;
  color: #f5fae8;
  font-family: 'Roc Grotesk Condensed';
  font-size: 50px;
  font-weight: bold;
  line-height: 60px;
  text-transform: uppercase;
}

.front-page-newsletter a {
  display: flex;
  align-self: flex-start;
  justify-content: center;
  width: 100%;
  margin: 0;
  margin-top: 16px;
  padding: 13px 48px 11px;
  color: #36363d;
  font-family: 'DM Sans';
  font-size: 25px;
  font-weight: 700;
  line-height: 25px;
  text-transform: uppercase;
  text-decoration: none;
  background-color: #bb99f2;
  border: 0;
  border-radius: 0.156rem;
  cursor: pointer;
  -webkit-transition: all 0.2s ease-out;
  -moz-transition: all 0.2s ease-out;
  -o-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}

.front-page-newsletter a:hover {
  color: #fff;
  text-decoration: none;
  background-color: #49cbb0;
}

.front-page-newsletter .newsletter-input-div {
  display: flex;
  flex-direction: column;
  padding-left: 96px;
}

.front-page-newsletter label {
  padding: 0;
  margin-bottom: 8px;
  color: #f5f5f5;
  font-family: 'DM Sans';
  font-size: 16px;
  line-height: 20px;
  font-weight: 300;
}

.front-page-newsletter input {
  padding: 12px 16px;
  color: #f5fae8;
  font-family: 'DM Sans';
  font-size: 16px;
  line-height: 20px;
  font-weight: 400;
  background-color: transparent;
  border: 1px solid #f5fae8;
  border-radius: 0.156rem;
}

/* front page contacts */

.front-page-contacts {
  position: relative;
  padding: 64px 0.677rem;
  background-color: #f5fae8;
}

.front-page-contacts p {
  font-family: 'DM Sans';
  font-size: 18px;
  line-height: 24px;
}

.front-page-contacts a {
  color: #36363d;
  text-decoration: none;
  font-weight: 700;
  border-bottom: 2px solid transparent;
  -webkit-transition: all 0.2s ease-out;
  -moz-transition: all 0.2s ease-out;
  -o-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}

.front-page-contacts a:hover {
  color: #36363d;
  text-decoration: none;
  font-weight: 700;
  border-bottom: 2px solid #36363d;
}

.front-page-contacts img {
  width: 100%;
  height: auto;
}

.front-page-contacts ul {
  list-style-type: none;
  padding-inline-start: 0;
  margin: 0;
  margin-top: 144px;
}

.front-page-contacts ul li {
  display: inline-block;
  margin-right: 16px;
}

.front-page-contacts ul li:last-child {
  margin-right: 0;
}

.front-page-contacts ul li a {
  border-bottom: 0;
}

.front-page-contacts ul li a:hover {
  border-bottom: 0;
}

.front-page-contacts ul li a img {
  height: 25px;
  width: auto;
  opacity: 1;
  -webkit-transition: all 0.2s ease-out;
  -moz-transition: all 0.2s ease-out;
  -o-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}

.front-page-contacts ul li a:hover img {
  opacity: 0.7;
}

.front-page-contacts > .contacts-content {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 32px;
  padding: 48px 64px 48px;
  background-color: #bb99f2;
  border: 1px solid #000;
  border-radius: 0.156rem;
}

.front-page-contacts .star-large {
  position: absolute;
  bottom: 0;
  left: 100px;
  width: 467px;
  height: 361px;
  background-image: url('../img/star_large.png');
  background-size: 467px;
  background-repeat: no-repeat;
  background-position: center center;
  pointer-events: none;
}

.front-page-contacts .star-small {
  position: absolute;
  top: 30px;
  right: 0;
  width: 254px;
  height: 410px;
  background-image: url('../img/star_small.png');
  background-size: 254px;
  background-repeat: no-repeat;
  background-position: center center;
  pointer-events: none;
}

.front-page-contacts .characters {
  position: absolute;
  bottom: 0;
  right: 10%;
  width: 633px;
  height: 353px;
  background-image: url('../img/people.png');
  background-size: 633px;
  background-repeat: no-repeat;
  background-position: center center;
  pointer-events: none;
}

.input-error {
  border: 1px solid #e74c3c !important;
}

@media (max-width: 991px) {
  .center .people-mobile {
    width: 80%;
    min-width: 0;
  }

  .front-page-cover {
    height: calc(100vh - 51px - 0.624rem);
  }

  .front-page-cover h2 {
    padding: 24px;
    font-size: 26px;
    line-height: 34px;
  }

  .front-page-cover h2 span {
    font-size: 30px;
    line-height: 35px;
  }

  .front-page-cover .front-title {
    top: 32px;
    bottom: auto;
    left: 16px;
    width: calc(100% - 32px);
    border-radius: 20px;
  }

  .front-page-cover .front-title-new {
    top: calc(20% - 90px);
    /*bottom: 48px;*/
    left: 50%;
    transform: translateX(-50%);
    width: 80%;
    max-width: 500px;
  }
  

  .front-page-cover .cookies img.desc {
    display: none;
  }

  .front-page-cover .cookies span.desc {
    display: inline-block;
    font-family: 'Oswald';
    font-size: 18px;
    line-height: 24px;
    padding-top: 8px;
    padding-bottom: 8px;
  }

  .front-page-cover .cookies .btn {
    padding: 20px;
  }

  .front-page-cover .cookies img {
    width: 80%;
    margin-left: 10%;
  }

  

  .front-page-trailer {
    padding-left: 0.261rem;
    padding-right: 0.261rem;
    }

  .front-page-song {
    flex-direction: column;
    margin-top: 10px;
    margin-bottom: 30px;
  }

  .front-page-song .description,
  .front-page-song .photo {
    flex: 1 1 100%;
    width: 100%;
    max-width: 100%;
    min-width: 100%;
    padding-left: 0.677rem;
  }

  .front-page-song .description {
    flex: 1 1 calc(100% - 0.677rem);
    width: calc(100% - 0.677rem);
    max-width: calc(100% - 0.677rem);
    min-width: calc(100% - 0.677rem);
    margin-right: 0.677rem;
    padding-top: 48px;
    padding-bottom: 48px;
  }

  .front-page-song img.under-your-windows-title {
    width: 75%;
    height: auto;
    margin-top: 24px;
    margin-bottom: 24px;
  }

  .front-page-song h2 {
    width: 100%;
    font-size: 55px;
    line-height: 55px;
  }

  .front-page-song .song-content {
    flex-direction: column;
  }

  .front-page-contest .contest-content {
    margin-top: 0;
  }

  .front-page-contest .contest-content .d-none-for-desktop {
    padding: 0;
    background-color: transparent;
    border-radius: unset;
    border: none;
  }

  .front-page-contest .contest-content .d-none-for-desktop img:last-child {
    margin-top: -8px;
  }

  .front-page-contest .contest-content .blocks {
    flex-direction: column;
    gap: 24px;
  }

  .front-page-contest .contest-content .blocks > div,
  .front-page-contest .contest-content .blocks > div.when {
    flex: 1 1 100%;
    width: 100%;
    min-width: 100%;
    max-width: 100%;
  }

  .front-page-contest .contest-title {
    width: 100%;
    margin-left: 0;
    margin-bottom: 24px;
    height: auto;
  }

  .front-page-superpower {
    padding: 48px 0.677rem;
    padding-top: 0;
  }

  .front-page-superpower .titles {
    width: 100%;
  }

  .front-page-superpower h2 {
    font-size: 45px;
    line-height: 45px;
  }

  .front-page-superpower .titles p {
    width: 100%;
    margin-bottom: 24px;
  }

  .front-page-superpower .titles p:last-child {
    margin-bottom: 40px;
  }

  .front-page-superpower .individual-block {
    flex-direction: column;
    flex-wrap: wrap;
  }

  .front-page-superpower .individual-block .description {
    flex: 1 1 100%;
    width: 100%;
    max-width: 100%;
    min-width: 100%;
    padding: 32px 16px 24px;
  }

  .front-page-superpower .individual-block .description img {
    height: 24px;
    max-width: 100%;
  }

  .front-page-superpower .individual-block .photo {
    flex: 1 1 250px;
    width: 100%;
    max-width: 100%;
    min-width: 250px;
    border-top-left-radius: 0.156rem;
    border-top-right-radius: 0.156rem;
    border-bottom-left-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
  }

  .front-page-superpower .individual-block.photo-right {
    flex-direction: column-reverse;
  }

  .front-page-newsletter {
    flex-direction: column;
    padding: 48px 0.677rem;
  }

  .front-page-newsletter > div {
    flex: 1 1 100%;
    width: 100%;
    max-width: 100%;
    min-width: 100%;
  }

  .front-page-newsletter h2 {
    width: 100%;
    font-size: 40px;
    line-height: 50px;
    text-align: center;
  }

  .front-page-newsletter .newsletter-input-div {
    margin-top: 32px;
    padding-left: 0;
  }

  .front-page-contacts {
    padding: 48px 0.677rem;
  }

  .front-page-contacts p {
    margin-top: 0;
    margin-bottom: 0;
  }

  .front-page-contacts ul {
    margin-top: 0;
    margin-bottom: 176px;
  }

  .front-page-contacts > .contacts-content {
    padding: 32px;
  }

  .front-page-contacts .characters {
    right: 0;
    width: 317px;
    height: 177px;
    background-size: 317px;
  }

  .front-page-contacts .star-large {
    width: 234px;
    height: 181px;
    background-size: 234px;
  }

  .front-page-contacts .star-small {
    width: 127px;
    height: 205px;
    background-size: 127px;
  }

  .front-page-song .photo > span {
    left: 0.677rem;
    width: calc(100% - 1.354rem);
    font-size: 25px;
  }
}

/* */
