@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@100..900&display=swap");
*,
*::before,
*::after {
  padding: 0;
  margin: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

p {
  line-height: 1.6;
}

img {
  width: 100%;
  display: block;
}

body {
  background: #212121;
}

.banner {
  font-size: 19.2px;
  margin: 0 auto;
  min-width: 280px;
  font-family: "Montserrat", sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #fff;
  position: relative;
  text-decoration: none;
}

.container {
  max-width: 95.8333333333em;
  width: 100%;
  margin: 0 auto;
  padding: 0 3.125em;
}

.header {
  padding: 2.34375em 0 5.2083333333em;
  position: relative;
}
.header__circle {
  position: absolute;
  width: 20.8333333333em;
  width: clamp(15.625em, 24vw, 20.8333333333em);
  height: 32%;
  background: url(../img/header-circle.png) no-repeat center 100%/contain;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-130%);
      -ms-transform: translateX(-130%);
          transform: translateX(-130%);
}
.header::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 43.5%;
  height: 102%;
  background: url(../img/bg.png) no-repeat right top/contain;
}
.header__logo {
  width: 9.8958333333em;
  margin: 0 auto 4.3em;
}
.header__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.header__txt {
  font-size: clamp(20px, 1.5vw, 1.4583333333em);
  width: 33%;
  text-align: left;
  -webkit-transform: translateY(-23%);
      -ms-transform: translateY(-23%);
          transform: translateY(-23%);
}
.header__title {
  font-size: 1.7em;
  margin: 0.8em 0 0.9em 0;
}
.header__title span {
  color: #ffbc00;
}
.header__img {
  width: 63.5%;
  height: 24.5833333333em;
  height: clamp(15.625em, 24.2vw, 24.5833333333em);
  position: relative;
}
.header__img--main {
  height: 100%;
  max-height: 18.0208333333em;
  position: absolute;
}
.header__img--people {
  width: 59%;
  top: 0;
  left: 0;
  background: url(../img/header-people.png) no-repeat left top/contain;
}
.header__img--stadium {
  width: 56%;
  bottom: 0;
  right: 0;
  background: url(../img/header-stadium.png) no-repeat right bottom/contain;
}

.body {
  background: #2c2c2c;
  padding: 4.1666666667em 0;
}
.body__container {
  max-width: 93.75em;
}
.body__title {
  font-size: clamp(1em, 1.6vw, 1.7em);
  margin: 0 auto 1em;
  text-align: center;
}
.body__txt {
  font-size: clamp(1em, 1.45vw, 1.44em);
  width: 50%;
  margin: 0 auto 2em;
  text-align: center;
}
.body__steps {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.body__step {
  width: 25%;
  padding: 0 2.6041666667em;
  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: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
}
.body__step-img {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  position: relative;
  margin-bottom: 3em;
  height: 3.3854166667em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
.body__step-img-1 {
  width: 4.3229166667em;
}
.body__step-img-2 {
  width: 3.6458333333em;
}
.body__step-img-3 {
  width: 3.0208333333em;
}
.body__step-img-4 {
  width: 5em;
}
.body__step-img::after {
  content: "";
  position: absolute;
  bottom: -2.5em;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  display: inline-block;
  width: 3.6458333333em;
  height: 0.5em;
  border-radius: 1em;
  background: #ffbc00;
  margin: 1em auto;
}
.body__step-title {
  font-size: clamp(1em, 1.2vw, 1.2em);
  margin-bottom: 1em;
}
.body__step-txt {
  font-size: clamp(0.9em, 1vw, 1em);
  width: 85%;
}

@media screen and (max-width: 1366px) {
  .header::before {
    top: 15px;
    width: 68.5%;
    height: 71%;
    background: url(../img/bg.png) no-repeat right top/contain;
  }
  .header__circle {
    -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
    width: clamp(10.625em, 31vw, 16em);
  }
  .header__container {
    max-width: 133.3984375em;
    padding: 0 4.125em;
  }
  .header__logo {
    width: 7.895833em;
    margin: 0 auto 3.3em;
  }
  .header__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .header__txt {
    font-size: 1.2em;
    font-size: clamp(0.6em, 2.2vw, 1.2em);
    width: 100%;
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    -webkit-transform: translateY(-29%);
        -ms-transform: translateY(-29%);
            transform: translateY(-29%);
  }
  .header__subtitle {
    width: 85%;
    margin-bottom: 1em;
  }
  .header__img {
    width: 100%;
    height: 36.2vw;
  }
  .header__img--main {
    width: 48vw;
    width: 57%;
    max-height: 100%;
  }
  .body {
    padding: 2.166667em 0;
  }
  .body__container {
    padding: 0 2.125em;
  }
  .body__title {
    font-size: clamp(1em, 2.5vw, 1.8em);
  }
  .body__txt {
    font-size: clamp(1em, 2.2vw, 1.8em);
    width: 80%;
    margin: 0 auto 2em;
    text-align: center;
  }
  .body__step {
    padding: 0 0.5em;
  }
  .body__step-img {
    margin-bottom: 2.5em;
  }
  .body__step-img::after {
    font-size: 0.75em;
  }
  .body__step-img-1 {
    width: 3.3229166667em;
  }
  .body__step-img-2 {
    width: 3.3em;
  }
  .body__step-img-3 {
    width: 2.645833em;
  }
  .body__step-img-4 {
    width: 3.645833em;
  }
  .body__step-title {
    font-size: clamp(0.6em, 1.8vw, 2.2em);
    margin-bottom: 1em;
  }
  .body__step-txt {
    font-size: clamp(0.6em, 1.5vw, 1.4em);
    width: 98%;
  }
}
@media screen and (max-width: 767px) {
  .header {
    padding: 1.5em 0 9em;
    overflow: hidden;
  }
  .header::before {
    top: 96px;
    width: 107.5%;
    height: 71%;
    background: url(../img/bg.png) no-repeat right top/contain;
  }
  .header__circle {
    -webkit-transform: translateX(-32%);
        -ms-transform: translateX(-32%);
            transform: translateX(-32%);
    width: clamp(13.625em, 32vw, 24em);
  }
  .header__container {
    max-width: 36em;
    padding: 0 1em;
  }
  .header__logo {
    width: 7.895833em;
    margin: 0 auto 2.3em;
  }
  .header__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .header__txt {
    font-size: clamp(1em, 4.8vw, 1.2em);
    width: 100%;
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
            transform: translateY(0);
  }
  .header__title {
    margin: 0.8em 0 0.4em 0;
  }
  .header__subtitle {
    width: 100%;
    margin-bottom: 1em;
  }
  .header__img {
    width: 100%;
    width: clamp(350px, 100%, 450px);
    height: clamp(280px, 77.2vw, 377px);
    margin-bottom: 1em;
  }
  .header__img--people {
    -webkit-transform: translateX(-15%);
        -ms-transform: translateX(-15%);
            transform: translateX(-15%);
  }
  .header__img--stadium {
    -webkit-transform: translateX(15%);
        -ms-transform: translateX(15%);
            transform: translateX(15%);
  }
  .header__img--main {
    width: 48vw;
    width: 89%;
    max-height: 100%;
  }
  .body {
    padding: 3em 0;
  }
  .body__container {
    max-width: 36em;
    padding: 0 1em;
  }
  .body__title {
    font-size: clamp(0.6em, 6vw, 1.4em);
    text-align: left;
  }
  .body__txt {
    font-size: clamp(1em, 3.2vw, 2.8em);
    width: 100%;
    margin: 0 0 3em;
    text-align: center;
    text-align: left;
  }
  .body__steps {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .body__step {
    width: 100%;
    padding: 0;
    text-align: left;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .body__step:not(:last-child) {
    margin-bottom: 2em;
  }
  .body__step-img {
    font-size: 0.6em;
    margin-bottom: 2.5em;
  }
  .body__step-img::after {
    font-size: 0.75em;
  }
  .body__step-img-1 {
    width: 3.3229166667em;
  }
  .body__step-img-2 {
    width: 3.3em;
  }
  .body__step-img-3 {
    width: 2.645833em;
  }
  .body__step-img-4 {
    width: 3.645833em;
  }
  .body__step-title {
    font-size: clamp(0.9em, 2.8vw, 1.4em);
    margin-bottom: 0.3em;
    width: 100%;
  }
  .body__step-txt {
    font-size: clamp(0.9em, 1.5vw, 1.1em);
    width: 98%;
  }
}
@media screen and (max-width: 389px) {
  .header::before {
    top: 65px;
  }
  .header__circle {
    width: clamp(9.625em, 36vw, 13em);
  }
  .header__img {
    width: clamp(248px, 100%, 450px);
    height: clamp(210px, 77.2vw, 377px);
  }
  .header__logo {
    width: 5.895833em;
    margin: 0 auto 1.5em;
  }
  .header {
    padding: 1.5em 0 6em;
  }
  .banner {
    font-size: 16px;
  }
}