/* メニュー１ */

.explain1 {
  background-color: #FFF;
  border-radius: 20px;
  padding: 3rem;
  width: 60%;
  margin: 5rem auto 10rem;
}

.explain1-ttl {
  text-align: center;
  font-size: 2rem;
  border-bottom: 1px solid #64C0AB;
  padding-bottom: 1rem;
}

.explain1-list {
  width: 65%;
  margin: 3.5rem auto 0;
}



.price1 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  background-color: #FFF;
  border-radius: 20px;
  margin-top: 5rem;
  padding: 4rem 2vw 8rem;
}


.price1-txt {
  padding-left: 1.5rem;
}


/*--------------------------------
sp css
--------------------------------*/

@media screen and (max-width: 1000px) {

  .explain1-list {
    width: 80%;
  }

  .price1-txt {
    font-size: 1.6rem;
  }

  .price1 {
    flex-direction: column;
  }
}


@media screen and (max-width: 767px) {

  .price1 {
    font-size: 1.4rem;
  }

  .price1-txt {
    font-size: 1.3rem;
  }

  .explain1-ttl {
    padding-bottom: 0.5rem;
  }

  .explain1-list {
    margin: 1.5rem auto 0;
  }
}

/* メニュー１ここまで */




/* メニュー2 */

.explain2 {
  border-radius: 20px;
  display: flex;
  justify-content: space-between;
  margin-top: 5rem;
}

.explain2-ttl {
  text-align: center;
  font-size: 2rem;
  border-bottom: 1px solid #74B5E4;
  padding-bottom: 1rem;
}


.explain2-list {
  background-color: #FFF;
  border-radius: 20px;
  width: 47%;
  padding: 4.6rem 3vw;
  font-size: 1.6rem;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.explain2-list::after {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 20px 0 20px 18px;
  border-color: transparent transparent transparent #3E3A39;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: -9%;
  margin-top: -6px;
}




.explain2-txt1 {
  background-color: #FFF;
  border-radius: 20px;
  width: 47%;
  padding: 3rem;
  font-size: 1.6rem;
  display: flex;
  align-items: center;
}


.price2 {
  background-color: #FFF;
  border-radius: 20px;
  margin-top: 5rem;
  padding: 8rem 2vw 4rem;
}

.price-br {
  display: none;
}

.price2-content {
  display: flex;
  justify-content: space-between;
  padding: 3rem 0 5rem;
}


.price2-adult, .price2-child {
  text-align: center;
  color: #FFF;
  background-color: #74B5E4;
  font-size: 2.4rem;
  padding: .6em 0;
  width: 100%;
  border-radius: 999px;
}


.price2-sub {
  color: #74B5E4;
  padding: 2.5rem 0 0 1.5rem;
  font-size: 2rem;
}



.price2-item span, .explain2-item span {
  color: #74B5E4;
}


/*--------------------------------
sp css
--------------------------------*/


@media screen and (max-width: 900px) {

  .price-br {
    display: block;
  }
}




.price2-adult, .price2-child {
  font-size: 2rem;
}



@media screen and (max-width: 767px) {

  .explain2 {
    margin-top: 2rem;
    flex-direction: column;
  }

  .explain2-list, .explain2-txt1 {
    width: 100%;
    padding: 2rem;
    font-size: 1.4rem;
  }

  .explain2-txt1 {
    margin-top: 3.5rem;
  }

  .price2 {
    padding: 3rem 2rem;
    margin-top: 3rem;
  }

  .price2-adult, .price2-child {
    font-size: 1.4rem;
    padding: 0.3em 0;
  }

  .price2-child {
    margin-top: 4rem;
  }

  .price2-sub {
    font-size: 1.4rem;
    text-align: center;
  }

  .price2-content {
    padding: 3.5rem 0 0 0;
  }

  .explain2-list::after {
    top: auto;
    left: 50%;
    bottom: -30px;
    transform: translateX(-50%) rotate(90deg);
    border-width: 13px 0 13px 10px;
  }
}



/* メニュー2ここまで */






/* メニュー3 */

.explain3 {
  background-color: #FFF;
  border-radius: 20px;
  padding: 3rem 2vw 4rem;
  width: 60%;
  margin: 5rem auto 9rem;
}

.explain3-ttl {
  text-align: center;
  font-size: 2rem;
  padding-bottom: 1rem;
}

.explain3-list {
  width: 80%;
  margin: 1.5rem auto 0;
}

.explain3-item span {
  color: #45BDCF;
}



.price3 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  background-color: #FFF;
  border-radius: 20px;
  margin-top: 5rem;
  padding: 6rem 2vw;
}


.price3-ttl {
  font-size: 2rem;
  border-bottom: 1px solid #45BDCF;
  padding: 0 0 1rem 1.5rem;
}


.price3-item span {
  color: #45BDCF;
}


.price3-wrapCenter {
  margin: auto;
  position: relative;
  width: 70% !important;
}

.price3-wrapCenter::before {
  position: absolute;
  content: '';
  display: inline-block;
  background-size: cover;
  background-repeat: no-repeat;
  top: 7px;
  right: -131px;
  width: 132px;
  height: 129px;
  background-image: url(../img/supplement1.png);
}

.price3-ttlCenter {
  text-align: center;
}

.explain3-br {
  display: none;
}

/*--------------------------------
sp css
--------------------------------*/

@media screen and (max-width: 1400px) {

  .explain3, .explain1 {
    width: 85%;
  }
}


@media screen and (max-width: 1300px) {

  .price3-wrapCenter {
    width: 70% !important;
  }

  .price3-ttl {
    text-align: center;
  }

  .price3-wrapCenter::before {
    right: -6px;
}
}

@media screen and (max-width: 1000px) {

  .explain3-list, .explain1-list {
    width: 80%;
  }


  .price3-ttl {
    text-align: center;
  }

  .price3-wrapCenter::before {
    top: -19px;
    right: -40px;
    width: 95px;
    height: 93px;
  }

  .price3-wrap {
    margin-top: 3rem;
  }

  .price3-wrap:first-of-type {
    margin-top: 0;
  }


}


@media screen and (max-width: 820px) {

  .price3-wrapCenter::before {
    right: -40px;
  }


}

@media screen and (max-width: 767px) {

  .price3-item {
    padding-left: 1em;
    text-indent: -1em;
  }

  .explain3 {
    width: 100%;
    padding: 2rem 1rem;
    margin: 2rem auto;
  }

  .explain3-ttl {
    font-size: 1.6rem;
    padding-bottom: 0;
  }

  .explain3-list {
    width: 100%;
    padding-bottom: 0;
  }

  .price3 {
    margin-top: 3rem;
    padding: 2rem;
  }

  .price3-ttl {
    font-size: 1.6rem;
    padding: 0 0 0.5rem 1.5rem;
  }

  .price3-wrap {
    margin-top: 2rem;
  }
}

@media screen and (max-width: 500px) {

  .explain3-br {
    display: block;
  }

  .price3-wrapCenter::before {
    top: -16px;
    right: -59px;
    width: 66px;
    height: 65px;
  }
}


@media screen and (max-width: 400px) {
  .price3-wrapCenter::before {
    top: 14px;
    right: -34px;
  }
}

/* メニュー3ここまで */



/* メニュー4*/

.explain4 {
  border-radius: 20px;
  display: flex;
  justify-content: space-between;
  margin-top: 5rem;
}


.explain4-list {
  background-color: #FFF;
  border-radius: 20px;
  width: 47%;
  padding: 4.5rem 2vw;
  font-size: 1.6rem;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.explain4-list::after {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 20px 0 20px 18px;
  border-color: transparent transparent transparent #3E3A39;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: -9%;
  margin-top: -6px;
}

.explain4-list:last-of-type:after {
  display: none;
}


.explain4-item {
  padding-left: 1em;
  text-indent: -1.3em;
}


.explain4-item span {
  color: #64C0AB;
}

.price4 {
  background-color: #FFF;
  border-radius: 20px;
  margin-top: 5rem;
  padding: 3rem 2vw;
}



.price4-top {
  text-align: center;
  font-size: 2rem;
  width: 100%;
  border-radius: 999px;
}


.price4-content {
  display: flex;
  justify-content: space-between;
}

.price4-ttl {
  font-size: 2rem;
  padding: 0 0 1rem 1.5rem;
  border-bottom: 1px solid #64C0AB;
}

.price4-ttlCenter {
  text-align: center;
}

.price4-item, .explain3-item {
  padding-left: 2rem;
  text-indent: -1.5em;
  margin-top: 0.5em;
}


.price4-item span {
  color: #64C0AB;
}

/*--------------------------------
sp css
--------------------------------*/



@media screen and (max-width: 767px) {

  .explain4 {
    margin-top: 2rem;
    flex-direction: column;
  }

  .explain4-list {
    width: 100%;
    font-size: 1.4rem;
  }

  .explain4-list {
    padding: 2rem;
  }

  .explain4-list:last-of-type {
    margin-top: 3.5rem;
  }

  .explain4-list::after {
    top: auto;
    left: 50%;
    bottom: -30px;
    transform: translateX(-50%) rotate(90deg);
    border-width: 13px 0 13px 10px;
  }

  .price4-top {
    font-size: 1.6rem;
  }

  .price4 {
    padding: 2rem 4vw;
  }

  .price4-ttl {
    font-size: 1.6rem;
    margin-top: 1.5rem;
    padding-bottom: 0.5rem;
  }

  .price4 {
    margin-top: 3rem;
  }

  .price4-item, .explain3-item {
    font-size: 1.3rem;
  }
}



/* メニュー4ここまで */




/* メニュー5*/

.explain5 {
  background-color: #FFF;
  border-radius: 20px;
  padding: 6rem 5rem;
  margin-top: 5rem;
}

.explain5-top {
  text-align: center;
  color: #FFF;
  background-color: #74B5E4;
  font-size: 2rem;
  padding: 0.6em 3rem;
  width: 90%;
  border-radius: 999px;
  margin: auto;
}


.explain5-list {
  display: flex;
  justify-content: space-between;
  padding-top: 19rem;
}

.explain5-item {
  width: 48%;
  position: relative;
}

.explain5-item::before {
  position: absolute;
  content: '';
  display: inline-block;
  background-size: cover;
  background-repeat: no-repeat;
}

.explain5-item1::before {
  top: -150px;
  left: 50%;
  width: 121px;
  height: 134px;
  transform: translateX(-50%);
  background-image: url(../img/supplement2.png);
}

.explain5-item2::before {
  top: -150px;
  left: 50%;
  width: 121px;
  height: 134px;
  transform: translateX(-50%);
  background-image: url(../img/supplement3.png);
}


.explain5-ttl {
  text-align: center;
  border-bottom: 1px solid #74B5E4;
  font-size: 2rem;
  padding-bottom: 1rem;
}

.explain5-txt {
  padding: 1.5rem 2rem 0;
  font-size: 1.6rem;
}


.price5 {
  background-color: #FFF;
  border-radius: 20px;
  margin-top: 5rem;
  padding: 3rem;
  position: relative;
}


.price5::before {
  position: absolute;
  content: '';
  display: inline-block;
  background-size: cover;
  background-repeat: no-repeat;
  top: -33px;
  right: -4px;
  width: 132px;
  height: 145px;
  background-image: url(../img/supplement4.png);
}

.price5-listCenter {
  margin-top: 1.8rem;
}



.price5-content {
  display: flex;
  justify-content: space-between;
}


.price5-top {
  text-align: center;
  font-size: 2.4rem;
  padding: .3em 3rem;
  width: 100%;
  border-radius: 999px;
}



.price5-ttl {
  font-size: 2rem;
  padding: 0 0 1rem 1.5rem;
  border-bottom: 1px solid #74B5E4;
}

.price5-ttlCenter {
  text-align: center;
}


.explain5-br {
  display: none;
}


.price5-item span, .explain5-item span, .price8-item span {
  color: #74B5E4;
}



/*--------------------------------
sp css
--------------------------------*/


@media screen and (max-width: 1300px) {

  .explain5-br {
    display: block;
  }
}



@media screen and (max-width: 1100px) {

  .explain5-list {
    flex-direction: column;
  }

  .explain5-item {
    width: 100%;
  }

  .explain5-item:last-of-type {
    margin-top: 20rem;
  }

}


@media screen and (max-width: 1000px) {

  .price5::before {
    top: 205px;
    right: 15px;
    width: 100px;
    height: 110px;
  }

  .price5-content {
    flex-direction: column;
  }

  .price5-listCenter {
    margin-top: 0;
  }

  .price5-ttlCenter {
    margin-top: 2rem;
  }
}



@media screen and (max-width: 767px) {
  .explain5 {
    margin-top: 2rem;
    padding: 2rem;
  }

  .explain5-top {
    font-size: 1.4rem;
    padding: 0.6em 2vw;
    width: 100%;
  }

  .explain5-ttl {
    font-size: 1.6rem;
    padding-bottom: .5rem;
  }

  .explain5-list {
    padding-top: 13rem;
  }

  .explain5-item1::before, .explain5-item2::before {
    top: -97px;
    left: 50%;
    width: 79px;
    height: 87px;
  }

  .price5::before {
    top: 91px;
    right: 15px;
    width: 81px;
    height: 89px;
  }

  .explain5-item:last-of-type {
    margin-top: 13rem;
  }

  .explain5-txt {
    padding: 1rem 0 0;
    font-size: 1.4rem;
  }

  .price5 {
    padding: 2rem;
    margin-top: 3rem;
  }

  .price5-ttl {
    font-size: 1.6rem;
    padding: 0 0 0.5rem 1.5rem;
  }

  .price5-ttlCenter {
    margin-top: 0;
  }
}


@media screen and (max-width: 500px) {

  .price5::before {
    top: 103px;
    right: -20px;
    width: 69px;
    height: 75px;
  }

}



@media screen and (max-width: 460px) {

  .explain5-top {
    border-radius: 20px;
  }

  .explain5-br {
    display: none;
  }
}


/* メニュー5ここまで */





/* メニュー6 */

.explain6-item {
  background-color: #FFF;
  border-radius: 20px;
  padding: 3rem;
  text-align: center;
  margin-top: 2.5rem;
}


.explain6-item:first-of-type {
  margin-top: 0;
}


.explain6-ttl {
  color: #45BDCF;
  font-size: 2rem;
}

.explain6-txt {
  font-size: 1.4rem;
  margin-top: .5rem;
}

/*--------------------------------
sp css
--------------------------------*/

@media screen and (max-width: 767px) {

  .explain6-item {
    padding: 2rem;
  }

  .explain6-ttl {
    font-size: 1.5rem;
  }

  .explain6-txt {
    font-size: 1.4rem;
    margin-top: 1rem;
  }
}



/* メニュー6ここまで */




/* メニュー7 */

.price7-list1 {
  display: flex;
  background-color: #FFF;
  border-radius: 20px;
}

.price7-item {
  margin-right: 5rem;
  text-align: center;
  margin: auto;
}

.price7-arrow {
  text-align: center;
  margin: 3rem 0;
  color: #FFF;
}


.price7-plus {
  text-align: center;
  position: relative;
}

.price7-plus::after {
  position: absolute;
  content: "＋";
}

.price7-plus1::after {
  right: -69px;
}

.price7-plus2::after {
  right: -73px;
}

.price7-plus3::after {
  right: -64px;
}

.price7-equal {
  position: relative;
}

.price7-equal::after {
  position: absolute;
  content: "＝";
  right: -66px;
}

.price7-type {
  display: block;
}

.price7-total:last-of-type:after {
  display: none;
}



.price7-wrap {
  background-color: #FFF;
  border-radius: 20px;
  padding: 5rem 3rem;
}

.price7-txt {
  text-align: center;
  margin-top: 3rem;
  font-size: 1.8rem;
}


.price7-ttl {
  padding-bottom: 2rem;
  border-bottom: 1px solid #64C0AB;
}

.price7-list3 {
  width: 90%;
  margin: 4rem auto 0;
  text-align: center;
}



.price7-list2 {
  position: relative;
}

.price7-list2::after {
  position: absolute;
  content: '';
  display: inline-block;
  background-size: cover;
  background-repeat: no-repeat;
  top: -101px;
  right: 20px;
  width: 124px;
  height: 134px;
  background-image: url(../img/supplement5.png);
}

.price7-item2 {
  margin-top: .5rem;
  padding-left: 1em;
  text-indent: -1.5em;
}

.price7-item2 span {
  color: #64C0AB;
}

.price7-ttlCenter {
  text-align: center;
  margin-top: 3rem;
}


.price7-br {
  display: none;
}

.price7-arrowRight {
  padding: 0 1em;
  color: #3E3A39 !important;
}

.price7 {
  margin-top: 5rem;
}


/*--------------------------------
sp css
--------------------------------*/

@media screen and (max-width: 1400px) {

  .price7-plus1::after {
    right: -4.5vw;
  }

  .price7-plus2::after {
    right: -5.5vw;
  }

  .price7-plus3::after {
    right: -4.5vw;
  }

  .price7-equal::after {
    right: -4.5vw;
  }
}



@media screen and (max-width: 1000px) {

  .price7-list2::after {
    top: -72px;
    right: 2px;
    width: 79px;
    height: 88px;
  }

}


@media screen and (max-width: 900px) {

  .price7-br {
    display: block;
  }

  .price7-arrowRight {
    padding-left: 0;
  }

  .price7-type, .price7-none {
    font-size: 1.4rem;
  }

  .price7-plus2::after {
    right: -4.5vw;
  }

  .price7-plus3::after {
    right: -3.5vw;
  }

  .price7-equal::after {
    right: -3.5vw;
  }

}



@media screen and (max-width: 767px) {

  .price7-txt {
    font-size: 1.4rem;
  }

  .price7-list1 {
    flex-direction: column;
  }

  .price7-plus1::after {
    right: 18px;
    bottom: -27px;
  }

  .price7-wrap {
    padding: 2rem;
  }

  .price7-item {
    margin: 2.5rem auto 0;
    font-size: 1.4rem;
  }

  .price7-item:first-of-type {
    margin-top: 0;
  }

  .price7-plus2::after {
    right: 17px;
    bottom: -27px;
  }

  .price7-plus3::after {
    right: 17px;
    bottom: -27px;
  }

  .price7-equal::after {
    right: 17px;
    bottom: -27px;
    transform: rotate(90deg);
  }

  .price7-none {
    display: none;
  }

  .price7 {
    margin-top: 2rem;
  }

  .price7-ttl {
    padding-bottom: .5rem;
  }

  .price7-item2 {
    margin-top: 1.5rem;
    padding-left: 1.2em;
    text-indent: -1.5em;
  }

  .price7-list3 {
    width: 100%;
    font-size: 1.4rem;
    margin: 1.5rem auto;
  }


}

@media screen and (max-width: 500px) {
  .price7-list2::after {
    top: -46px;
    right: 30px;
    width: 65px;
    height: 71px;
  }
}


/* メニュー7ここまで */





/* メニュー8 */

.price8-item {
  text-align: center;
  background-color: #FFF;
  border-radius: 20px;
  padding: 3rem;
  margin-top: 5rem;
}


.price4-txt {
  text-align: center;
}

/*--------------------------------
sp css
--------------------------------*/

@media screen and (max-width: 767px) {

  .price8-item {
    font-size: 1.4rem;
    margin-top: 2rem;
    padding: 1.5rem;

  }
}


/* メニュー8ここまで



/*--------------------------------
price
--------------------------------*/

.price {
  background-color: #F9F8F4;
  padding-top: 18rem;
}

.price-img {
  width: 40%;
  margin: 8rem auto 0;
  min-width: 300px;
}

.price-img img {
  width: 100%;
}


.price-wrap {
  padding-bottom: 18rem;
}

/* 色指定 */

.price-bg1 {
  background-color: #64C0AB;
}

.price-color1 {
  background-color: #FFF;
  color: #64C0AB;
}


.price-bg2 {
  background-color: #74B5E4;
}

.price-color2 {
  background-color: #FFF;
  color: #74B5E4;
}


.price-bg3 {
  background-color: #45BDCF;
}

.price-color3 {
  background-color: #FFF;
  color: #45BDCF;
}

/* 色指定ここまで */



/* 共通 */
.price-ttl {
  transition: .3s;
}

.price-ttl:hover {
  opacity: .7;
}

.price-ttl span {
  position: relative;
  color: #FFF;
  display: block;
  font-size: 2.2rem;
}

.price-ttl h2 {
  display: inline-block;
  font-size: 4rem;
  padding: 0.1em 1em;
  margin-top: 3rem !important;
  width: 90%;
  margin: auto;
}

.price-ttl span:before,
.price-ttl span:after {
  position: relative;
  display: inline-block;
  content: "";
  background: #FFF;
  width: 2px;
  height: 2em;
  margin: 0 1em;
  margin-top: -.2em;
  vertical-align: middle;
}

.price-ttl span:before {
  transform: rotate(-20deg);
}

.price-ttl span:after {
  transform: rotate(20deg);
}


.price-txt {
  color: #FFF;
}


.price1-wrap, .price2-wrap, .price3-wrap, .price4-wrap, .price5-wrap {
  width: 48%;
}


.price1-ttl, .price2-ttl {
  font-size: 2rem;
  color: #64C0AB;
  border-bottom: 1px solid #64C0AB;
  padding: 0 0 1rem 1.5rem;
}


.price2-ttl {
  color: #74B5E4;
  border-bottom: 1px solid #74B5E4;
}



.price1-list, .price2-list, .price3-list, .price4-list, .price5-list {
  padding: 1.5rem 0 1.5rem 1.5rem;
  font-size: 2rem;
}

.price-listCenter {
  text-align: center;
}


.price1-item span, .explain1-item span {
  color: #64C0AB;
}


/* 共通ここまで */



/* アコーディオンメニュー */


/* アコーディオンメニュー全体のサイズ・位置 */
.price-menu {
  width: 85%;
  max-width: 1200px;
  margin: 11rem auto 0;
  border-radius: 20px;
}

/* クリック領域 */
.price-ttl {
  position: relative;
  color: #fff;
  text-align: center;
  padding: 9rem 3rem 7rem;
  cursor: pointer;
}

/* クリックしたら表示される領域 */
.price-content {
  display: none;
  border-radius: 30px;
  padding: 0 7vw 14rem;
}

/* 擬似要素で下三角形を作成 */
.price-ttl:after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 86%;
  left: 50%;
  width: 20px;
  height: 20px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: translateX(-50%) translateY(-50%) rotate(45deg);
  transition: .3s;
}

/* オープン時にopenクラスを付与 */
.price-ttl.open:after {
  transform: translateX(-50%) translateY(-50%) rotate(225deg);
}


/* アコーディオンメニューここまで */



/*--------------------------------
sp css
--------------------------------*/

@media screen and (max-width: 1400px) {

  .price1-wrap, .price2-wrap, .price3-wrap, .price4-wrap, .price5-wrap {
    width: 48%;
  }
}


@media screen and (max-width: 1300px) {

  .price1-ttl, .price2-ttl {
    text-align: center;
  }

  .price1-wrap, .price2-wrap, .price3-wrap, .price4-wrap {
    width: 100% !important;
  }

  .price1-wrap:last-of-type {
    margin-top: 3rem;
  }

  .price-listCenter {
    text-align: left;
    padding: 1.5rem 0 1.5rem 1.5rem;
  }

  .price2-content {
    flex-direction: column;
  }

  .price2-wrap:last-of-type {
    margin-top: 3rem;
  }

  .price2-child {
    margin-top: 5rem;
  }


  .price4-content {
    flex-direction: column;
    padding: 0;
  }

  .price4-ttl {
    text-align: center;
  }

  .price4-ttl {
    margin-top: 3rem;
  }

  .price4-ttl4 {
    margin-top: 0;
  }
}

.top-br {
  display: none;
}


@media screen and (max-width: 950px) {

  .price3-wrap, .price5-wrap {
    width: 100% !important;
  }

  .price-ttl h2 {
    font-size: 3.2rem;
  }

  .price-ttl span {
    font-size: 2.1rem;
  }
}

@media screen and (max-width: 767px) {

  .price-txt {
    font-size: 1.3rem;
  }

  .price1-ttl, .price2-ttl {
    font-size: 1.6rem;
    padding: 0 0 0.5rem 1.5rem;
  }

  .price {
    padding-top: 10rem;
  }

  .price-ttl:hover {
    opacity: 1;
  }

  .explain1-item {
    font-size: 1.3rem;
  }

  .price-content {
    padding: 0 4vw 4rem;
  }

  .price1-list, .price2-list, .price3-list, .price4-list, .price5-list {
    padding: 1.5rem 0 1.5rem 0rem;
    font-size: 1.4rem;
  }

  .price-img {
    min-width: 270px;
    margin-top: 3rem;
  }

  .price-ttl h2 {
    display: block;
    font-size: 2rem;
    margin-top: 1rem;
    padding: 0.3rem 2vw;
  }

  .price2-wrap:last-of-type {
    margin-top: 1rem;
  }

  .price-ttl span {
    font-size: 1.6rem;
  }

  .price-ttl {
    padding: 3rem 2vw 4rem;
  }

  .price-ttl:after {
    top: auto;
    bottom: 12px;
    left: 50%;
    width: 10px;
    height: 10px;
  }

  .price-menu {
    margin: 5rem auto 0;
  }

  .price-wrap {
    padding-bottom: 10rem;
  }

  .explain1 {
    margin: 1rem auto;
    width: 100%;
    padding: 1.5rem 2rem;
  }

  .explain1-ttl {
    font-size: 1.6rem;
  }

  .explain1-list {
    width: 100%;
  }

  .price1 {
    margin-top: 2rem;
    padding: 2rem;
  }

}

@media screen and (max-width: 570px) {

  .top-br {
    display: block;
  }

  .price-ttl span:before, .price-ttl span:after {
    width: 1.5px;
    height: 25px;
    margin: 0;
    position: absolute;
    bottom: 0;
  }

  .price-ttl span:before {
    left: 40px;
  }

  .price-ttl span:after {
    right: 40px;
  }
}

@media screen and (max-width: 430px) {

  .price-ttl span:before {
    left: 20px;
  }

  .price-ttl span:after {
    right: 20px;
  }

  .price-ttl h2 {
    font-size: 1.7rem;
  }

  .price-ttl span {
    font-size: 1.4rem;
  }


  .price4-ttlCenter {
    margin-top: 0;
  }
}