@charset "UTF-8";
.main {
  padding-bottom: 20.4rem;
}
.content_wrapper {
  width: 100rem;
}
.mv {
  height: 76rem;
}
.mv .inner {
  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;
  height: 100%;
}
.mv .content_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-top: 6rem;
}
.mv-logo {
  margin: 0 8.8rem 0 10.8rem;
  width: 33.1rem;
}
.mv-copy {
  margin-top: 2rem;
  max-width: 100%;
  width: 42.6rem;
}
.section + .section {
  margin-top: 13.8rem;
}
.section-title {
  font-weight: 600;
  font-size: 3rem;
  line-height: 1.66666667;
  letter-spacing: .06em;
  color: #5e4b79;
  margin-bottom: 2.2rem;
  position: relative;
}
.section-title::before {
  content: '';
  border-top: 2px solid #5c4b7a;
  display: inline-block;
  width: calc((100vw - 100%) / 2);
  position: absolute;
  top: 50%;
  left: -1rem;
  -webkit-transform: translate(-100%, -50%);
          transform: translate(-100%, -50%);
}
.section-description {
  font-size: 1.8rem;
  line-height: 1.77777778;
  color: #231815;
}
.section04 .section-description {
  margin-top: 2.6rem;
}
.link-style {
  font-size: 2.3rem;
  font-weight: 900;
  line-height: 1.39130435;
  letter-spacing: .08695652em;
  color: #d02019;
}
.section04 .link-style {
  display: inline-block;
}

@media screen and (min-width: 768px) {
  .section04 .section-description {
    font-size: 2.3rem;
    line-height: 1.39130435;
    letter-spacing: .0173913em;
    color: #000;
  }
}

@media screen and (max-width: 767px) {
  .main {
    padding-bottom: 12.4rem;
  }
  .mv {
    margin-bottom: 4.2rem;
    height: auto;
  }
  .mv .content_wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding-top: 3.6rem;
    padding-bottom: 3.6rem;
  }
  .mv-logo {
    margin: 0 auto;
    width: 17.9rem;
  }
  .mv-copy {
    margin-top: 3.3rem;
    width: 30rem;
  }
  .section + .section {
    margin-top: 8.9rem;
  }
  .section-title {
    font-size: 1.9rem;
    line-height: 1.73684211;
    letter-spacing: .05em;
    margin-bottom: .6rem;
  }
  .section-title::before {
    border-top-width: 1px;
    margin-top: 1.65rem;
    top: 0;
    left: -.5rem;
  }
  .section-description {
    font-size: 1.6rem;
    line-height: 1.5625;
  }
  .section04 .section-description {
    margin-top: 2rem;
  }
  .link-style {
    font-size: 2rem;
    letter-spacing: .09em;
  }
}
