@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&display=swap");
@media screen and (min-width: 835px) {
  .mbpc-0 {
    margin-bottom: 0px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-0 {
    margin-bottom: 0px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-1 {
    margin-bottom: 1px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-1 {
    margin-bottom: 1px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-2 {
    margin-bottom: 2px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-2 {
    margin-bottom: 2px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-3 {
    margin-bottom: 3px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-3 {
    margin-bottom: 3px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-4 {
    margin-bottom: 4px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-4 {
    margin-bottom: 4px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-5 {
    margin-bottom: 5px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-5 {
    margin-bottom: 5px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-6 {
    margin-bottom: 6px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-6 {
    margin-bottom: 6px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-7 {
    margin-bottom: 7px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-7 {
    margin-bottom: 7px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-8 {
    margin-bottom: 8px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-8 {
    margin-bottom: 8px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-9 {
    margin-bottom: 9px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-9 {
    margin-bottom: 9px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-10 {
    margin-bottom: 10px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-10 {
    margin-bottom: 10px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-11 {
    margin-bottom: 11px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-11 {
    margin-bottom: 11px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-12 {
    margin-bottom: 12px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-12 {
    margin-bottom: 12px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-13 {
    margin-bottom: 13px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-13 {
    margin-bottom: 13px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-14 {
    margin-bottom: 14px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-14 {
    margin-bottom: 14px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-15 {
    margin-bottom: 15px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-15 {
    margin-bottom: 15px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-16 {
    margin-bottom: 16px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-16 {
    margin-bottom: 16px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-17 {
    margin-bottom: 17px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-17 {
    margin-bottom: 17px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-18 {
    margin-bottom: 18px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-18 {
    margin-bottom: 18px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-19 {
    margin-bottom: 19px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-19 {
    margin-bottom: 19px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-20 {
    margin-bottom: 20px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-20 {
    margin-bottom: 20px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-21 {
    margin-bottom: 21px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-21 {
    margin-bottom: 21px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-22 {
    margin-bottom: 22px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-22 {
    margin-bottom: 22px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-23 {
    margin-bottom: 23px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-23 {
    margin-bottom: 23px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-24 {
    margin-bottom: 24px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-24 {
    margin-bottom: 24px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-25 {
    margin-bottom: 25px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-25 {
    margin-bottom: 25px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-26 {
    margin-bottom: 26px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-26 {
    margin-bottom: 26px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-27 {
    margin-bottom: 27px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-27 {
    margin-bottom: 27px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-28 {
    margin-bottom: 28px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-28 {
    margin-bottom: 28px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-29 {
    margin-bottom: 29px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-29 {
    margin-bottom: 29px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-30 {
    margin-bottom: 30px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-30 {
    margin-bottom: 30px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-31 {
    margin-bottom: 31px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-31 {
    margin-bottom: 31px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-32 {
    margin-bottom: 32px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-32 {
    margin-bottom: 32px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-33 {
    margin-bottom: 33px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-33 {
    margin-bottom: 33px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-34 {
    margin-bottom: 34px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-34 {
    margin-bottom: 34px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-35 {
    margin-bottom: 35px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-35 {
    margin-bottom: 35px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-36 {
    margin-bottom: 36px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-36 {
    margin-bottom: 36px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-37 {
    margin-bottom: 37px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-37 {
    margin-bottom: 37px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-38 {
    margin-bottom: 38px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-38 {
    margin-bottom: 38px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-39 {
    margin-bottom: 39px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-39 {
    margin-bottom: 39px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-40 {
    margin-bottom: 40px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-40 {
    margin-bottom: 40px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-41 {
    margin-bottom: 41px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-41 {
    margin-bottom: 41px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-42 {
    margin-bottom: 42px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-42 {
    margin-bottom: 42px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-43 {
    margin-bottom: 43px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-43 {
    margin-bottom: 43px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-44 {
    margin-bottom: 44px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-44 {
    margin-bottom: 44px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-45 {
    margin-bottom: 45px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-45 {
    margin-bottom: 45px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-46 {
    margin-bottom: 46px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-46 {
    margin-bottom: 46px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-47 {
    margin-bottom: 47px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-47 {
    margin-bottom: 47px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-48 {
    margin-bottom: 48px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-48 {
    margin-bottom: 48px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-49 {
    margin-bottom: 49px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-49 {
    margin-bottom: 49px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-50 {
    margin-bottom: 50px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-50 {
    margin-bottom: 50px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-51 {
    margin-bottom: 51px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-51 {
    margin-bottom: 51px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-52 {
    margin-bottom: 52px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-52 {
    margin-bottom: 52px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-53 {
    margin-bottom: 53px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-53 {
    margin-bottom: 53px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-54 {
    margin-bottom: 54px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-54 {
    margin-bottom: 54px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-55 {
    margin-bottom: 55px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-55 {
    margin-bottom: 55px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-56 {
    margin-bottom: 56px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-56 {
    margin-bottom: 56px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-57 {
    margin-bottom: 57px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-57 {
    margin-bottom: 57px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-58 {
    margin-bottom: 58px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-58 {
    margin-bottom: 58px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-59 {
    margin-bottom: 59px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-59 {
    margin-bottom: 59px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-60 {
    margin-bottom: 60px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-60 {
    margin-bottom: 60px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-61 {
    margin-bottom: 61px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-61 {
    margin-bottom: 61px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-62 {
    margin-bottom: 62px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-62 {
    margin-bottom: 62px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-63 {
    margin-bottom: 63px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-63 {
    margin-bottom: 63px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-64 {
    margin-bottom: 64px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-64 {
    margin-bottom: 64px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-65 {
    margin-bottom: 65px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-65 {
    margin-bottom: 65px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-66 {
    margin-bottom: 66px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-66 {
    margin-bottom: 66px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-67 {
    margin-bottom: 67px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-67 {
    margin-bottom: 67px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-68 {
    margin-bottom: 68px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-68 {
    margin-bottom: 68px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-69 {
    margin-bottom: 69px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-69 {
    margin-bottom: 69px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-70 {
    margin-bottom: 70px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-70 {
    margin-bottom: 70px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-71 {
    margin-bottom: 71px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-71 {
    margin-bottom: 71px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-72 {
    margin-bottom: 72px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-72 {
    margin-bottom: 72px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-73 {
    margin-bottom: 73px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-73 {
    margin-bottom: 73px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-74 {
    margin-bottom: 74px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-74 {
    margin-bottom: 74px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-75 {
    margin-bottom: 75px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-75 {
    margin-bottom: 75px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-76 {
    margin-bottom: 76px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-76 {
    margin-bottom: 76px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-77 {
    margin-bottom: 77px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-77 {
    margin-bottom: 77px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-78 {
    margin-bottom: 78px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-78 {
    margin-bottom: 78px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-79 {
    margin-bottom: 79px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-79 {
    margin-bottom: 79px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-80 {
    margin-bottom: 80px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-80 {
    margin-bottom: 80px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-81 {
    margin-bottom: 81px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-81 {
    margin-bottom: 81px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-82 {
    margin-bottom: 82px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-82 {
    margin-bottom: 82px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-83 {
    margin-bottom: 83px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-83 {
    margin-bottom: 83px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-84 {
    margin-bottom: 84px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-84 {
    margin-bottom: 84px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-85 {
    margin-bottom: 85px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-85 {
    margin-bottom: 85px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-86 {
    margin-bottom: 86px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-86 {
    margin-bottom: 86px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-87 {
    margin-bottom: 87px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-87 {
    margin-bottom: 87px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-88 {
    margin-bottom: 88px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-88 {
    margin-bottom: 88px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-89 {
    margin-bottom: 89px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-89 {
    margin-bottom: 89px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-90 {
    margin-bottom: 90px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-90 {
    margin-bottom: 90px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-91 {
    margin-bottom: 91px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-91 {
    margin-bottom: 91px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-92 {
    margin-bottom: 92px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-92 {
    margin-bottom: 92px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-93 {
    margin-bottom: 93px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-93 {
    margin-bottom: 93px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-94 {
    margin-bottom: 94px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-94 {
    margin-bottom: 94px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-95 {
    margin-bottom: 95px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-95 {
    margin-bottom: 95px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-96 {
    margin-bottom: 96px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-96 {
    margin-bottom: 96px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-97 {
    margin-bottom: 97px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-97 {
    margin-bottom: 97px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-98 {
    margin-bottom: 98px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-98 {
    margin-bottom: 98px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-99 {
    margin-bottom: 99px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-99 {
    margin-bottom: 99px !important;
  }
}
@media screen and (min-width: 835px) {
  .mbpc-100 {
    margin-bottom: 100px !important;
  }
}
@media screen and (max-width: 834px) {
  .mbsp-100 {
    margin-bottom: 100px !important;
  }
}
/* ====================================================
reset style
==================================================== */
html {
  overflow-y: scroll;
  overflow-x: hidden;
  font-size: 10px; /* Base font size, change to 14px or 16px if needed */
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, legend, input, textarea, p, blockquote, th, td {
  margin: 0;
  padding: 0;
}

* {
  box-sizing: border-box;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

fieldset, img {
  border: 0;
}

img {
  vertical-align: middle;
  max-width: 100%;
}

address, caption, cite, code, dfn, var {
  font-style: normal;
  font-weight: normal;
}

li {
  list-style: none;
}

caption, th {
  text-align: left;
}

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal;
}

q:before, q:after {
  content: "";
}

abbr, acronym {
  border: 0;
  font-variant: normal;
}

sup {
  vertical-align: text-top;
}

sub {
  vertical-align: text-bottom;
}

input, textarea, select, button {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/*to enable resizing for IE*/
input, textarea, select {
  *font-size: 100%;
}

/*because legend doesn't inherit in IE */
legend {
  color: #000;
}

del, ins {
  text-decoration: none;
}

main {
  display: block;
}

section {
  position: relative;
}

/* ====================================================
HTML
==================================================== */
html {
  font-size: 62.5%;
}

body {
  color: #3C3C3C;
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
  font-size: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1;
}
body:before {
  content: "";
  display: inline-block;
  width: 100vw;
  height: 100vh;
  background: url("../img/common/bg-body.jpg") no-repeat center top;
  background-size: cover;
  position: fixed;
}

a {
  display: inline-block;
  color: inherit;
  text-decoration: none;
  outline: none;
  border-bottom: dashed 1px;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* ====================================================
Layout
==================================================== */
.inner {
  padding: 0 45px;
}
@media screen and (max-width: 834px) {
  .inner {
    width: 100%;
    padding: 0 5%;
  }
}

/* ====================================================
Control
==================================================== */
.c-fc--ff {
  color: #fff;
}

.c-fw--lt {
  font-weight: 300 !important;
}
.c-fw--rg {
  font-weight: 400 !important;
}
.c-fw--md {
  font-weight: 500 !important;
}
.c-fw--sbd {
  font-weight: 600 !important;
}
.c-fw--bd {
  font-weight: 700 !important;
}
.c-fw--bk {
  font-weight: 900 !important;
}

.c-tx--v {
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}
@media screen and (min-width: 835px) {
  .c-tx--v-pc {
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
  }
}

.c-al--c {
  text-align: center !important;
}
.c-al--r {
  text-align: right !important;
}
.c-al--l {
  text-align: left !important;
}

.c-val--md {
  vertical-align: middle;
}
.c-val--top {
  vertical-align: top;
}

/* ====================================================
Component
==================================================== */
.c-txt__01 {
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 1.7222222222;
  font-weight: 700;
}
@media screen and (max-width: 640px) {
  .c-txt__01 {
    line-height: 1.8;
  }
}

.c-ttl__01 {
  font-size: 2.5rem;
  font-weight: 700;
}
.c-btn__01--ff, .c-btn__01 {
  position: relative;
  padding-bottom: 20px;
  width: 200px;
  font-size: 1.6rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  border-bottom: 2px solid #000;
  transition: 0.2s;
}
.c-btn__01--ff:before, .c-btn__01:before {
  content: "";
  display: inline-block;
  position: absolute;
  width: 18px;
  height: 18px;
  top: 1px;
  right: 0;
  font-size: 1.8rem;
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  content: "\f30b";
  transition: 0.2s;
}

@media (any-hover: hover) {
  .c-btn__01--ff:hover, .c-btn__01:hover {
    color: #9e0000;
    border-bottom: 2px solid #9e0000;
  }
  .c-btn__01--ff:hover:before, .c-btn__01:hover:before {
    right: -5px;
    color: #9e0000;
  }
}

.c-btn__01--ff {
  color: #fff;
  border-bottom: 2px solid #fff;
}

/* ====================================================
Utility
==================================================== */
@media screen and (max-width: 834px) {
  .pc {
    display: none;
  }
}

@media screen and (min-width: 835px) {
  .sp {
    display: none;
  }
}

@media screen and (max-width: 640px) {
  .pc-sm {
    display: none;
  }
}

@media screen and (min-width: 641px) {
  .sp-sm {
    display: none;
  }
}

.u-fn-hover {
  display: inline-block;
}
@media (any-hover: hover) {
  .u-fn-hover {
    transition: all 0.2s;
  }
  .u-fn-hover:hover {
    opacity: 0.7;
  }
}

.u-pull--left {
  margin-left: calc((100vw - 100%) / 2 * -1);
}
.u-pull--right {
  margin-right: calc((100vw - 100%) / 2 * -1);
}

.u-img-of {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  font-family: "object-fit: cover; object-position: center", sans-serif;
}

.c-scroll-box {
  padding-bottom: 20px;
  overflow-x: scroll;
  overflow-y: hidden;
}
.c-scroll-box-y {
  padding-bottom: 20px;
  overflow-x: hidden;
  overflow-y: scroll;
}
@media screen and (max-width: 834px) {
  .c-scroll-box-sp {
    padding-bottom: 20px;
    overflow-x: scroll;
    overflow-y: hidden;
  }
}

.js-u__scrollin {
  opacity: 0;
  transform: translate(0, 70px);
}

.js-u__scrollin.is-visible {
  opacity: 1;
  transform: translate(0, 0);
  transition: 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* ====================================================
Header
==================================================== */
.fixed-page {
  position: fixed;
  top: 16px;
  left: 23px;
  z-index: 10;
}
.fixed-page__logo {
  width: 200px;
  margin-bottom: 32px;
}
.fixed-page__slogan-txt-small {
  display: block;
  font-size: 1.2rem;
  margin-bottom: 10px;
}
.fixed-page__slogan-link {
  font-size: 3.3rem;
  font-weight: 700;
  display: inline-block;
  border-bottom: 1px solid #3C3C3C;
  padding-bottom: 3px;
}
@media (any-hover: hover) {
  .fixed-page__slogan-link {
    transition: all 0.2s;
  }
  .fixed-page__slogan-link:hover {
    opacity: 0.7;
  }
}

.main-header {
  background: #fff;
}
.main-header__inner {
  padding: 7px 10px;
}
.main-header__logo {
  width: 114px;
  border: none;
}

.main-footer {
  margin-top: 27px;
  padding: 17px 0 30px;
  background: #000;
}
.main-footer__logo {
  max-width: 124px;
  width: 100%;
  margin: 0 auto 12px;
}
@media (any-hover: hover) {
  .main-footer__logo {
    transition: all 0.2s;
  }
  .main-footer__logo:hover {
    opacity: 0.7;
  }
}
.main-footer__copyright {
  text-align: center;
  color: #fff;
  font-size: 0.9rem;
}

.main-footer a {
  border: none;
}

.scroll-page {
  max-width: 390px;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  background: #fff;
  margin: 0 auto;
  z-index: 2;
}

.mv-ttl {
  max-width: 350px;
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
}

.sec-example-top {
  padding: 10px 0;
}

.example-top__heading {
  text-align: center;
  position: relative;
  margin-bottom: 65px;
}
.example-top__heading:after {
  content: "";
  display: inline-block;
  position: absolute;
  width: 300px;
  height: 150px;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
}
.example-top__heading span {
  position: relative;
  z-index: 2;
}
.example-top__list {
  margin-bottom: 15px;
}
.example-top__list-item {
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 1.7222222222;
  font-weight: 700;
  text-align: center;
  height: 150px;
  margin-bottom: 30px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.example-top__list-item:last-of-type {
  margin-bottom: 0;
}
.example-top__list-item--01 {
  background: url("../img/index/img-01.png") no-repeat center/cover;
}
.example-top__list-item--02 {
  background: url("../img/index/img-02.png") no-repeat center/cover;
}
.example-top__list-item--03 {
  background: url("../img/index/img-03.png") no-repeat center/cover;
}

.sec-conditional-top {
  padding-bottom: 88px;
}

.conditional-top__ttl {
  font-size: 25px;
  font-size: 2.5rem;
  line-height: 1.32;
  font-weight: 700;
  text-align: center;
  padding: 15px 0;
  margin-bottom: 40px;
  position: relative;
}
.conditional-top__ttl:after {
  content: "";
  display: inline-block;
  position: absolute;
  width: 300px;
  height: 132px;
  background: url("../img/common/arrow-ttl.png") no-repeat center/100%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.conditional-top__list-item {
  margin-bottom: 86px;
  position: relative;
}
.conditional-top__list-item:after {
  content: "";
  display: inline-block;
  position: absolute;
  width: 149px;
  height: 150px;
  background: url("../img/common/icn_02.png") no-repeat center/100%;
  top: 66%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.conditional-top__list-item:last-of-type {
  margin-bottom: 0;
}
.conditional-top__list-ttl {
  text-align: center;
  margin-bottom: 10px;
  position: relative;
  z-index: 2;
}
.conditional-top__list-desc {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: center;
}

.sec-price-top .inner {
  padding: 0 10px;
}

.price-top__ttl {
  text-align: center;
  position: relative;
  margin-bottom: 42px;
}
.price-top__ttl:before {
  content: "";
  display: inline-block;
  position: absolute;
  width: 9px;
  height: 41px;
  background: url("../img/common/icn_bracket_01.png") no-repeat center/100%;
  top: calc(50% - 20.5px);
  left: 16px;
}
@media screen and (max-width: 640px) {
  .price-top__ttl:before {
    left: 5px;
  }
}
.price-top__ttl:after {
  content: "";
  display: inline-block;
  position: absolute;
  width: 9px;
  height: 41px;
  background: url("../img/common/icn_bracket_02.png") no-repeat center/100%;
  top: calc(50% - 20.5px);
  right: 16px;
}
@media screen and (max-width: 640px) {
  .price-top__ttl:after {
    right: 5px;
  }
}

.plan-block {
  background: #BBA15B;
  border-top: 10px solid #F5AE2C;
  border-bottom: 3px solid #F5AE2C;
  padding: 20px 30px 16px;
}
.plan-block__heading {
  position: relative;
  text-align: center;
  margin-bottom: 8px;
}
.plan-block__heading-tag {
  position: absolute;
  top: -17px;
  left: -28px;
}
.plan-block__heading-ttl {
  font-size: 3rem;
  font-weight: 700;
  color: #fff;
  position: relative;
}
.plan-block__ct {
  padding: 26px 0 24px;
  margin-bottom: 15px;
  border-bottom: 2px solid #fff;
  border-top: 2px solid #fff;
}
.plan-block__price {
  font-family: "fot-udkakugoc80-pro", sans-serif;
  font-size: 7rem;
  font-weight: 700;
  color: #fff;
  text-align: center;
  line-height: 1;
  margin-bottom: 20px;
}
.plan-block__price small {
  font-size: 2rem;
}
.plan-block__price span {
  font-size: 70%;
}
.plan-block__price span.plan-block__price-free {
  font-size: 4.5rem;
  font-weight: 700;
  text-align: center;
  display: block;
  margin-bottom: 13px;
}
.plan-block__note {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.2857142857;
  text-align: center;
  display: block;
  color: #fff;
}
.plan-block__bottom {
  text-align: center;
  font-size: 2.5rem;
  font-weight: 700;
  color: #fff;
}
.plan-block--styles02 {
  background: #FFC972;
  border-color: #fff;
}
.plan-block--styles02 > * {
  color: #454545;
}
.plan-block--styles02 .plan-block__heading-ttl {
  color: #454545;
}
.plan-block--styles02 .plan-block__ct {
  border-color: #454545;
  padding: 15px 0;
}
.plan-block--styles02 .plan-block__price {
  color: #454545;
  font-size: 4.7rem;
  margin-bottom: 13px;
  display: block;
}
.plan-block--styles02 .plan-block__price small {
  font-size: 1.3rem;
}
.plan-block--styles02 .plan-block__note {
  color: #454545;
}
.plan-block--styles02 .plan-block__bottom {
  font-size: 2rem;
}

.sec-greats-top {
  padding-top: 40px;
  padding-bottom: 38px;
}

.greats-top {
  padding: 0 24px;
}
.greats-top__ttl {
  text-align: center;
  margin-bottom: 22px;
}
.greats-top__list {
  padding: 0 5px;
  margin-bottom: 37px;
}
.greats-top__list-item {
  border: 1px solid #FFB500;
  background: #fff;
  padding: 20px 20px 22px;
  margin-bottom: 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
}
.greats-top__list-item:last-of-type {
  margin-bottom: 0;
}
.greats-top__list-item:before {
  content: "";
  display: inline-block;
  position: absolute;
  width: 40px;
  height: 40px;
  border-top: 1px solid #FFB500;
  border-right: 1px solid #FFB500;
  top: -5px;
  right: -5px;
}
.greats-top__list-item:after {
  content: "";
  display: inline-block;
  position: absolute;
  width: 40px;
  height: 40px;
  border-left: 1px solid #FFB500;
  border-bottom: 1px solid #FFB500;
  left: -5px;
  bottom: -5px;
}
.greats-top__list-left {
  position: relative;
  width: 115px;
}
.greats-top__list-left:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 7.5px 0 7.5px 15px;
  border-color: transparent transparent transparent #FFB500;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: -22px;
}
.greats-top__list-label {
  font-size: 1.6rem;
  display: block;
  margin-bottom: 12px;
}
.greats-top__list-value {
  font-size: 1.6rem;
  font-weight: 700;
  display: block;
  text-align: center;
}
.greats-top__list-price {
  font-family: "fot-udkakugoc80-pro", sans-serif;
  font-size: 3rem;
}
.greats-top__list-price small {
  font-size: 2rem;
}
.greats-top__list-price--yellow {
  color: #FFB500;
  font-weight: 700;
  margin-bottom: 7px;
}
.greats-top__list-right {
  padding-right: 11px;
  position: relative;
  top: 5px;
}
.greats-top__yearly-label {
  font-family: "Noto Sans JP", sans-serif;
  display: block;
  text-align: center;
  font-size: 1.4rem;
  margin-bottom: 15px;
}
.greats-top__yearly-price {
  font-family: "fot-udkakugoc80-pro", sans-serif;
  font-size: 2.5rem;
  font-weight: 700;
  text-align: center;
  position: relative;
  margin-bottom: 15px;
}
.greats-top__yearly-price:after {
  content: "";
  display: inline-block;
  position: absolute;
  width: 100%;
  height: 21px;
  background: #FFED65;
  bottom: 0;
  left: 0;
}
.greats-top__yearly-price span {
  position: relative;
  z-index: 2;
  white-space: nowrap;
}
.greats-top__yearly-price span > span {
  font-size: 3.6rem;
}
.greats-top__yearly-value {
  text-align: center;
  font-size: 2rem;
  font-weight: 700;
}

.sec-store-top {
  display: block;
  background: url("../img/common/bg-yellow.png") no-repeat center/cover;
  padding: 8px;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  width: 390px;
  margin: 0 auto;
  z-index: 10;
}
@media (any-hover: hover) {
  .sec-store-top {
    transition: all 0.2s;
  }
  .sec-store-top:hover {
    opacity: 0.7;
  }
}

.store-top {
  padding: 6px 0;
  max-width: 190px;
  width: 100%;
  margin: 0 auto;
  background: rgba(255, 255, 255, 0.75);
  display: block;
}
.store-top > * {
  display: block;
  text-align: center;
}
.store-top small {
  font-size: 1.2rem;
  margin-bottom: 4px;
}
.store-top span {
  font-size: 3.3rem;
  font-weight: 700;
}

.title_explain {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.8rem;
  font-weight: 400;
  color: #888888;
  line-height: 1.4;
  padding-top: 15px;
  padding-bottom: 30px;
}

.h3point {
  font-family: "fot-udkakugoc80-pro", sans-serif;
  font-size: 2.5rem;
  font-weight: 400;
  margin: 15px 0;
}

.tag {
  padding: 20px;
  background-color: rgb(185, 219, 255);
  border-radius: 10px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.7rem;
  font-weight: 400;
  margin-bottom: 50px;
  line-height: 1.3;
  text-align: center;
}

.shop_button a {
  background: #fff9ab;
  border-radius: 50px;
  position: relative;
  display: flex;
  justify-content: space-around;
  align-items: center;
  margin: 0 auto;
  max-width: 260px;
  padding: 10px 25px;
  color: #313131;
  transition: 0.3s ease-in-out;
  font-weight: 500;
}

.shop_button a:hover {
  background: #BBA15B;
  color: #FFF;
}

.shop_button a:after {
  content: "";
  width: 5px;
  height: 5px;
  border-top: 3px solid #BBA15B;
  border-right: 3px solid #BBA15B;
  transform: rotate(45deg) translateY(-50%);
  position: absolute;
  top: 50%;
  right: 20px;
  border-radius: 1px;
  transition: 0.3s ease-in-out;
}

.shop_button a:hover:after {
  border-color: #FFF;
}

.shop_button {
  font-family: "fot-udkakugoc80-pro", sans-serif;
  font-size: 2.5rem;
  font-weight: 400;
  margin-bottom: 10px;
}

/* ====================================================
Module
==================================================== */
/* ====================================================
Pages
==================================================== *//*# sourceMappingURL=styles.css.map */