html {
  font-size: 62.5%;
}

html,
body {
  height: 100%;
}

@font-face {
  font-family: "Original Yu Gothic";
  src: local("Yu Gothic Medium"), local("YuGothic-Medium");
}
@font-face {
  font-family: "Original Yu Gothic";
  src: local("Yu Gothic Bold"), local("YuGothic-Bold");
  font-weight: bold;
}
* {
  font-family: YuGothic, "Original Yu Gothic", Meiryo, "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
}

* {
  font-size: 1.4rem;
  line-height: 1.66;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

html,
body {
  scroll-behavior: auto;
  background: #30a497;
  position: relative;
}

.pc {
  display: block;
}

.sp {
  display: none;
}

.m-headerLogo {
  position: relative;
  width: 100%;
  max-width: 1470px;
  margin: 0 auto;
}
.m-headerLogo > div {
  position: absolute;
  top: 20px;
  left: 20px;
  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;
  z-index: 10;
}
.m-headerLogo a {
  display: block;
}
.m-headerLogo a:first-child {
  width: 101.734px;
}
.m-headerLogo a:last-child {
  width: 115.273px;
  margin-left: 35.5px;
  position: relative;
}
.m-headerLogo a:last-child::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -17.75px;
  width: 1px;
  height: 24px;
  background: #231813;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
}
.m-headerLogo a img {
  width: 100%;
  height: auto;
  display: block;
}

.m-mainContainer {
  z-index: 100;
  position: relative;
  overflow-x: hidden;
}

.m-main-name {
  width: 460px;
  margin: 0 auto;
  padding-top: 55px;
  padding-bottom: 37px;
}
.m-main-name img {
  width: 100%;
}

.m-main-visual {
  margin: 0 auto;
  display: block;
}

.m-circleBG {
  position: absolute;
  width: 1518px;
  height: 1082px;
  background-image: url("../images/bg-circle.svg");
  background-repeat: no-repeat;
  background-size: 100%;
  top: -541px;
  margin: 0 auto;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: -1;
}

.m-description__title {
  font-size: 10rem;
  font-weight: bold;
  margin-bottom: 1rem;
  line-height: 14.5rem;
  font-family: zen-maru-gothic, sans-serif;
  font-style: normal;
  font-weight: 900;
  color: #ffffff;
  text-align: center;
  margin-top: 100px;
}
.m-description__text {
  font-size: 2.4rem;
  line-height: 5.4rem;
  font-family: zen-maru-gothic, sans-serif;
  font-style: normal;
  font-weight: 500;
  color: #ffffff;
  text-align: center;
  position: relative;
  width: 800px;
  margin: 65px auto 0;
}

.m-chara {
  position: absolute;
  -webkit-transition: opacity 0.3s linear, -webkit-transform 0.3s linear;
  transition: opacity 0.3s linear, -webkit-transform 0.3s linear;
  -o-transition: transform 0.3s linear, opacity 0.3s linear;
  transition: transform 0.3s linear, opacity 0.3s linear;
  transition: transform 0.3s linear, opacity 0.3s linear, -webkit-transform 0.3s linear;
  opacity: 0;
  will-change: transform, opacity;
}
.m-chara__img01 {
  top: -76px;
  right: -105px;
}
.m-chara__img02 {
  top: 195px;
  left: -96px;
}
.m-chara__img03 {
  top: 338px;
  right: -52px;
}
.m-chara__img04 {
  top: -47px;
  left: -100px;
}
.m-chara__img05 {
  top: 345px;
  right: -62px;
}
.m-chara__img06 {
  bottom: -73px;
  left: -102px;
}

.m-profile {
  background: #ffffff;
  max-width: 680px;
  margin: 120px auto 0;
  border-radius: 60px;
  padding: 72px 95px 31px;
  position: relative;
}
.m-profile__title {
  width: 360px;
  margin: 0 auto;
  padding-bottom: 22px;
  border-bottom: 6px solid #30a497;
  text-align: center;
}
.m-profile__title img {
  margin: 0 auto;
  width: 97.5%;
}
.m-profile__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 32px;
}
.m-profile__list dt,
.m-profile__list dd {
  width: 50%;
  border-bottom: 3px solid #30a497;
  padding-top: 32px;
  padding-bottom: 32px;
}
.m-profile__list dt:last-child {
  border-bottom: none;
}
.m-profile__list dt:nth-last-child(2),
.m-profile__list dd:nth-last-child(1) {
  border-bottom: none;
}

.m-footer {
  margin-top: 60px;
  padding: 60px 20px 95px;
}
.m-footer__logo {
  display: block;
  margin: 0 auto;
  width: 100px;
}
.m-footer__copyright {
  text-align: center;
  font-size: 1.2rem;
  line-height: 2rem;
  color: #ffffff;
  margin-top: 40px;
}

@media (max-width: 1024px) and (min-width: 751px) {
  .pc {
    display: block;
  }
  .sp {
    display: none;
  }
  .m-description__title {
    font-size: 10rem;
    font-size: 9.765625vw;
    line-height: 14.16015625vw;
    margin-bottom: 0.9765625vw;
    margin-top: 9.765625vw;
  }
  .m-description__text {
    font-size: 2.4rem;
    line-height: 5.4rem;
    font-size: 2.4rem;
    font-size: 2.34375vw;
    line-height: 5.2734375vw;
    margin-top: 6.34765625vw;
    width: 78.125vw;
  }
  .m-chara__img01 {
    top: -7.421875vw;
    right: -10.25390625vw;
    width: 23.046875vw;
  }
  .m-chara__img02 {
    top: 19.04296875vw;
    left: -9.375vw;
    width: 27.1484375vw;
  }
  .m-chara__img03 {
    top: 33.0078125vw;
    right: -5.078125vw;
    width: 31.4453125vw;
  }
  .m-chara__img04 {
    top: -4.58984375vw;
    left: -9.765625vw;
    width: 21.6796875vw;
  }
  .m-chara__img05 {
    top: 33.69140625vw;
    right: -6.0546875vw;
    width: 21.484375vw;
  }
  .m-chara__img06 {
    bottom: -7.12890625vw;
    left: -9.9609375vw;
    width: 19.3359375vw;
  }
  .m-profile {
    max-width: 66.40625vw;
    margin-top: 11.71875vw;
    border-radius: 5.859375vw;
    padding-top: 7.03125vw;
    padding-right: 9.27734375vw;
    padding-bottom: 3.02734375vw;
    padding-left: 9.27734375vw;
  }
  .m-profile__title {
    width: 35.15625vw;
    padding-bottom: 2.1484375vw;
    border-bottom: 6px solid #30a497;
  }
  .m-profile__list {
    margin-top: 3.125vw;
  }
  .m-profile__list dt,
.m-profile__list dd {
    width: 50%;
    border-bottom: 3px solid #30a497;
    padding-top: 32px;
    padding-bottom: 32px;
    padding-top: 3.125vw;
    padding-bottom: 3.125vw;
  }
  .m-profile__list dt:last-child {
    border-bottom: none;
  }
  .m-profile__list dt:nth-last-child(2),
.m-profile__list dd:nth-last-child(1) {
    border-bottom: none;
  }
  .m-profile__t-name {
    width: 7.51953125vw;
  }
  .m-profile__a-name {
    width: 9.47265625vw;
  }
  .m-profile__t-likefood {
    width: 16.015625vw;
  }
  .m-profile__a-likefood {
    width: 12.79296875vw;
  }
  .m-profile__t-dislikefood {
    width: 16.015625vw;
  }
  .m-profile__a-dislikefood {
    width: 4.6875vw;
  }
  .m-profile__t-birthday {
    width: 7.421875vw;
  }
  .m-profile__a-birthday {
    width: 5.17578125vw;
  }
  .m-profile__t-personality {
    width: 5.17578125vw;
  }
  .m-profile__a-personality {
    width: 21.09375vw;
  }
  .m-profile__t-hobby {
    width: 5.078125vw;
  }
  .m-profile__a-hobby {
    width: 9.86328125vw;
  }
  .m-footer {
    margin-top: 60px;
    padding: 60px 20px 95px;
  }
  .m-footer__logo {
    display: block;
    margin: 0 auto;
    width: 100px;
  }
  .m-footer__copyright {
    text-align: center;
    font-size: 1.2rem;
    line-height: 2rem;
    color: #ffffff;
    margin-top: 40px;
  }
}
@media (max-width: 750px) {
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
  .m-headerLogo > div {
    top: 2.6666666667vw;
    left: 2.6666666667vw;
  }
  .m-headerLogo a:first-child {
    width: 16.5333333333vw;
  }
  .m-headerLogo a:last-child {
    width: 18.6666666667vw;
    margin-left: 5.7333333333vw;
  }
  .m-headerLogo a:last-child::before {
    left: -2.8666666667vw;
    height: 4.2666666667vw;
  }
  .m-mainContainer {
    overflow-x: hidden;
    width: 100vw;
    padding-bottom: 53.3333333333vw;
  }
  .m-circleBG {
    position: absolute;
    width: 1518px;
    height: 1082px;
    width: 202.4vw;
    height: 144.2666666667vw;
    background-image: url("../images/bg-circle.svg");
    background-repeat: no-repeat;
    background-size: 100%;
    top: -541px;
    top: -72.1333333333vw;
    margin: 0 auto;
    left: 50%;
    -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
    z-index: -1;
  }
  .m-main-name {
    width: 45.3333333333vw;
    padding-bottom: 3.3333333333vw;
    padding-top: 12.6666666667vw;
  }
  .m-main-visual {
    width: 96vw;
    height: auto;
  }
  .m-description__title {
    white-space: nowrap;
    font-size: 8.4rem;
    font-size: 11.2vw;
    line-height: 16.1333333333vw;
    margin-bottom: 1.3333333333vw;
    margin-top: 16vw;
  }
  .m-description__text {
    font-size: 2.8rem;
    font-size: 3.7333333333vw;
    line-height: 7.2vw;
    margin-top: 8.6666666667vw;
    width: 100%;
  }
  .m-chara__img01 {
    top: 14.6666666667vw;
    right: -9.3333333333vw;
    width: 31.4666666667vw;
  }
  .m-chara__img02 {
    top: 48vw;
    left: -10.1333333333vw;
    width: 37.0666666667vw;
  }
  .m-chara__img03 {
    top: 76.6666666667vw;
    right: -6vw;
    width: 42.9333333333vw;
  }
  .m-chara__img04 {
    top: -12vw;
    left: -7.3333333333vw;
    width: 29.6vw;
  }
  .m-chara__img05 {
    top: 44.6666666667vw;
    right: -5.6vw;
    width: 29.3333333333vw;
  }
  .m-chara__img06 {
    bottom: -16.4vw;
    left: 0vw;
    width: 26.4vw;
  }
  .m-profile {
    max-width: 90.6666666667vw;
    margin-top: 14.2666666667vw;
    border-radius: 8vw;
    padding-top: 9.6vw;
    padding-right: 12.6666666667vw;
    padding-bottom: 4.1333333333vw;
    padding-left: 12.6666666667vw;
  }
  .m-profile__title {
    width: 48vw;
    padding-bottom: 2.9333333333vw;
    border-bottom: 0.8vw solid #30a497;
  }
  .m-profile__list {
    margin-top: 4.2666666667vw;
  }
  .m-profile__list dt,
.m-profile__list dd {
    border-bottom: 0.4vw solid #30a497;
    padding-top: 4.2666666667vw;
    padding-bottom: 4.2666666667vw;
  }
  .m-profile__t-name {
    width: 10.2666666667vw;
  }
  .m-profile__a-name {
    width: 12.9333333333vw;
  }
  .m-profile__t-likefood {
    width: 21.8666666667vw;
  }
  .m-profile__a-likefood {
    width: 17.4666666667vw;
  }
  .m-profile__t-dislikefood {
    width: 21.8666666667vw;
  }
  .m-profile__a-dislikefood {
    width: 6.4vw;
  }
  .m-profile__t-birthday {
    width: 10.1333333333vw;
  }
  .m-profile__a-birthday {
    width: 7.0666666667vw;
  }
  .m-profile__t-personality {
    width: 7.0666666667vw;
  }
  .m-profile__a-personality {
    width: 28.8vw;
  }
  .m-profile__t-hobby {
    width: 6.9333333333vw;
  }
  .m-profile__a-hobby {
    width: 13.4666666667vw;
  }
  .m-footer {
    margin-top: 8vw;
    padding-top: 8vw;
    padding-right: 2.6666666667vw;
    padding-bottom: 12.6666666667vw;
    padding-left: 2.6666666667vw;
  }
  .m-footer__logo {
    width: 28.4vw;
  }
  .m-footer__logo img {
    width: 100%;
  }
  .m-footer__copyright {
    margin-top: 7.2vw;
    font-size: 2.4rem;
    font-size: 3.2vw;
    line-height: 5.4666666667vw;
  }
}
