@import url("https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@400;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=M+PLUS+1p&display=swap");
.keySection {
  margin: 0 auto;
  opacity: 0;
  position: relative;
  -webkit-transition: opacity 1s ease-in-out;
  transition: opacity 1s ease-in-out;
}

@media screen and (max-width: 768px) {
  .keySection {
    margin: calc(90 / 390 * 100vw) calc(40 / 390 * 100vw) 0;
  }
}

.keySection__head {
  margin: 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

@media print, screen and (min-width: 768px) {
  .keySection__head {
    padding-top: calc(200 / 1440 * 100vw);
  }
}

@media print, screen and (min-width: 768px) {
  .keySection__head .photo {
    width: 259px;
  }
}

@media screen and (max-width: 768px) {
  .keySection__head .photo {
    width: calc(230 / 390 * 100vw);
  }
}

.keySection__cont {
  margin: 0 auto;
}

@media print, screen and (min-width: 768px) {
  .keySection__cont {
    margin-top: calc(120 / 1440 * 100vw);
    width: 461px;
  }
}

@media screen and (max-width: 768px) {
  .keySection__cont {
    margin-top: calc(80 / 390 * 100vw);
    width: calc(195 / 390 * 100vw);
  }
}

@media print, screen and (min-width: 768px) {
  .keySection__copy {
    left: calc(113 / 1440 * 100vw);
    position: absolute;
    top: calc(70 / 1440 * 100vw);
    width: calc(116 / 1440 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .keySection__copy {
    width: calc(71 / 390 * 100vw);
  }
}

.keySection.is-load {
  opacity: 1;
}

.miraresiBg {
  overflow: hidden;
  position: relative;
}

@media screen and (max-width: 768px) {
  .miraresiBg {
    padding-right: calc(30 / 390 * 100vw);
  }
}

.miraresiBg__front {
  background: -webkit-gradient(linear, left top, right bottom, from(#31565e), to(#04191e));
  background: linear-gradient(to bottom right, #31565e 0%, #04191e 100%);
  left: 0;
  position: absolute;
  top: 0;
}

@media print, screen and (min-width: 768px) {
  .miraresiBg__front {
    height: calc(100% - 64px);
    width: calc(100% - 64px);
  }
}

@media screen and (max-width: 768px) {
  .miraresiBg__front {
    height: calc(100% - calc(32 / 390 * 100vw));
    width: calc(100% - calc(32 / 390 * 100vw));
  }
}

.miraresiBg__back {
  position: absolute;
  right: 0;
}

@media print, screen and (min-width: 768px) {
  .miraresiBg__back {
    aspect-ratio: 2720 / 872;
    background: url("../imgs/pc/bg-miraresi@2x.jpg") center top repeat-y;
    background-size: 100% auto;
    height: calc(100% - 30px);
    top: 30px;
    width: calc(100% - 80px);
  }
}

@media screen and (max-width: 768px) {
  .miraresiBg__back {
    aspect-ratio: 700 / 3076;
    background: url("../imgs/sp/bg-miraresi@2x.jpg") center top repeat-y;
    background-size: 100% auto;
    height: calc(100% - calc(25 / 390 * 100vw));
    top: calc(25 / 390 * 100vw);
    width: calc(100% - calc(40 / 390 * 100vw));
  }
}

.miraresiSect {
  color: #ffffff;
  margin: 0 auto;
}

@media print, screen and (min-width: 768px) {
  .miraresiSect {
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  .miraresiSect {
    width: calc(310 / 390 * 100vw);
  }
}

.miraresiSect__head {
  font-family: "Zen Kaku Gothic New", sans-serif;
  text-align: center;
  line-height: 2.42857;
}

.miraresiSect__head:before {
  content: '';
  margin-top: calc((1 - 2.42857) * .5em);
}

.miraresiSect__head:after {
  margin-bottom: calc((1 - 2.42857) * .5em);
}

.miraresiSect__head:before, .miraresiSect__head:after {
  content: '';
  display: block;
  height: 0;
  width: 0;
}

@media print, screen and (min-width: 768px) {
  .miraresiSect__head {
    font-size: 14px;
  }
}

@media screen and (max-width: 768px) {
  .miraresiSect__head {
    font-size: calc(13 / 390 * 100vw);
  }
}

@media print, screen and (min-width: 768px) {
  .miraresiSect__head + .miraresiSect__cont {
    margin-top: 160px;
  }
}

@media screen and (max-width: 768px) {
  .miraresiSect__head + .miraresiSect__cont {
    margin-top: calc(120 / 390 * 100vw);
  }
}

.miraresiSect__cont {
  margin: 0 auto;
}

.miraresiSect__cont .photo {
  margin: 0 auto;
}

@media print, screen and (min-width: 768px) {
  .miraresiSect__cont .photo {
    width: 260px;
  }
}

@media screen and (max-width: 768px) {
  .miraresiSect__cont .photo {
    width: calc(260 / 390 * 100vw);
  }
}

.miraresiSect__txt {
  letter-spacing: .08em;
  line-height: 2;
}

.miraresiSect__txt:before {
  content: '';
  margin-top: calc((1 - 2) * .5em);
}

.miraresiSect__txt:after {
  margin-bottom: calc((1 - 2) * .5em);
}

.miraresiSect__txt:before, .miraresiSect__txt:after {
  content: '';
  display: block;
  height: 0;
  width: 0;
}

@media print, screen and (min-width: 768px) {
  .miraresiSect__txt {
    font-size: 12px;
    margin-top: 20px;
    text-align: center;
  }
}

@media screen and (max-width: 768px) {
  .miraresiSect__txt {
    font-size: calc(12 / 390 * 100vw);
    margin: calc(30 / 390 * 100vw) auto 0;
    width: calc(278 / 390 * 100vw);
  }
}

@media print, screen and (min-width: 768px) {
  .miraresi-miraresi {
    margin: 167px auto 224px;
  }
}

@media screen and (max-width: 768px) {
  .miraresi-miraresi {
    margin: calc(90 / 390 * 100vw) auto calc(152 / 390 * 100vw);
  }
}
