@charset "utf-8";

.mahoubu_mh {
  background-image: url(../images/mahoubu_bg.jpg);
  background-size: cover;
  background-position: center;
  margin: 0 calc(50% - 50vw);
  padding-bottom: 570px;
  position: relative;
  width: 100vw;
}

.mahoubu_mh::after {
  background-image: url(../images/cloud_06.png);
  background-size: 100%;
  background-repeat: repeat-x;
  content: "";
  height: 242px;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 1824px;
}

.mahoubu_mh::before {
  background-image: url(../images/houki.gif);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
  height: 443px;
  position: absolute;
  bottom: -46px;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 878px;
  z-index: 1;
}

.mahoubu_mh img {
  height: auto;
  max-width: 100%;
}

.uranai_mh {
  padding-bottom: 100px;
  padding-top: 200px;
  position: relative;
}

.uranai_mh h2 {
  margin-bottom: 40px;
  margin-left: auto;
  margin-right: auto;
  max-width: 132px;
}

.uranai_banner_mh {
  margin-left: auto;
  margin-right: auto;
  max-width: 590px;
}

.pegasus_mh {
  margin-left: auto;
  margin-right: auto;
  max-width: 1170px;
  position: absolute;
  left: 50%;
  top: 0;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 100%;
  z-index: 1;
}

.pegasus_mh::after {
  background-image: url(../images/pegasus.gif);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
  height: 567px;
  position: absolute;
  right: -336px;
  top: -46px;
  width: 578px;
}

.book_mh {
  margin-bottom: 85px;
  margin-left: auto;
  margin-right: auto;
  max-width: 292px;
  position: relative;
}

.book_mh::before {
  background-image: url(../images/wing_02.png);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
  height: 378px;
  position: absolute;;
  right: -85px;
  top: 37px;
  width: 488px;
}

.book_mh::after {
  background-image: url(../images/cat_02.gif);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
  height: 244px;
  position: absolute;
  bottom: -180px;
  right: -195px;
  width: 160px;
}

.message_mh {
  margin-left: auto;
  margin-right: auto;
  max-width: 1170px;
  position: relative;
}

.message_mh::before {
  background-image: url(../images/castle_02.png);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
  height: 504px;
  position: absolute;
  right: -380px;
  top: 350px;
  width: 714px;
}

.message_mh::after {
  background-image: url(../images/witch_04.gif);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
  height: 646px;
  position: absolute;
  left: -420px;
  top: -155px;
  width: 700px;
}

.message_mh h2 {
  margin-bottom: 52px;
  margin-left: auto;
  margin-right: auto;
  max-width: 172px;
}

.message_mh p {
  margin-left: auto;
  margin-right: auto;
  max-width: 396px;
}

.wing03_mh {
  margin-left: auto;
  margin-right: auto;
  max-width: 590px;
  position: absolute;
  left: 50%;
  top: 20%;
  -webkit-transform: translate(-50%,-50%);
      -ms-transform: translate(-50%,-50%);
          transform: translate(-50%,-50%);
  width: 100%;
}

.wing03_mh::before {
  background-image: url(../images/wing_06.png);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
  height: 40px;
  position: absolute;
  left: 80px;
  top: 0;
  width: 50px;
}

.wing04_mh {
  margin-left: auto;
  margin-right: auto;
  max-width: 590px;
  position: absolute;
  left: 50%;
  top: 65%;
  -webkit-transform: translate(-50%,-50%);
      -ms-transform: translate(-50%,-50%);
          transform: translate(-50%,-50%);
  width: 100%;
}

.wing04_mh::before {
  background-image: url(../images/wing_07.png);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
  height: 48px;
  position: absolute;
  right: 0;
  top: 0;
  width: 46px;
}

.wing04_mh::after {
  background-image: url(../images/wing_08.png);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
  height: 66px;
  position: absolute;
  left: 0;
  top: 250px;
  width: 56px;
}

.cloud_mh {
  margin-left: auto;
  margin-right: auto;
  max-width: 590px;
  position: absolute;
  left: 50%;
  top: 0;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 100%;
}

.cloud_mh::before {
  background-image: url(../images/cloud_05.png);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
  height: 128px;
  position: absolute;
  right: -560px;
  top: 0;
  width: 178px;
}

@media not all and (min-width: 768px) {
  .mahoubu_mh {
    padding-bottom: 690px;
    padding-bottom: 184vw;
  }

  .mahoubu_mh::before {
    height: 76vw;
    bottom: -40px;
    width: 150.133333%;
  }

  .uranai_mh {
    padding-bottom: 60px;
    padding-top: 115px;
    padding-top: 30vw;
  }

  .uranai_mh h2 {
    margin-bottom: 30px;
    width: 20%;
  }

  .uranai_banner_mh {
    width: 84%;
  }

  .pegasus_mh::after {
    height: 84vw;
    right: -185px;
    right: -49.333333%;
    top: -51vw;
    width: 317px;
    width: 84.533333%;
  }

  .pegasus_mh::before {
    background-image: url(../images/cloud_05.png);
    background-size: 100%;
    background-repeat: no-repeat;
    content: "";
    height: 70px;
    position: absolute;
    bottom: -80px;
    right: -50px;
    width: 92px;
    z-index: 1;
  }

  .book_mh {
    margin-bottom: 25px;
    width: 53.333333%;
  }

  .book_mh::before {
    background-image: url(../images/wing_07.png);
    height: 30px;
    right: 0;
    top: -50px;
    width: 24px;
  }

  .book_mh::after {
    height: 40vw;
    bottom: -35vw;
    right: -55%;
    width: 47.5%;
  }

  .message_mh::before {
    height: 500px;
    height: 62vw;
    right: -46.666667%;
    bottom: -70vw;
    top: auto;
    width: 86%;
  }

  .message_mh::after {
    height: 94.668vw;
    bottom: -90vw;
    left: -38.666667%;
    top: auto;
    width: 102.666667%;
  }

  .message_mh h2 {
    margin-bottom: 36px;
    width: 24.266667%;
  }

  .message_mh p {
    width: 80%;
  }

  .wing03_mh {
    top: 0;
    z-index: 3;
  }

  .wing03_mh::before {
    left: 45px;
    width: 30px;
  }

  .wing04_mh::before {
    right: 10px;
    width: 30px;
  }

  .wing04_mh::after {
    left: 50px;
    top: 100px;
    width: 30px;
  }

  .cloud_mh::before {
    background-image: url(../images/wing_08.png);
    height: 33px;
    left: -50px;
    right: auto;
    top: 0;
    width: 29px;
  }
}