.mb-14 {
  margin-bottom: 14px;
}

.mb-30 {
  margin-bottom: 30px;
}

.mb-40 {
  margin-bottom: 40px;
}

.mb-60 {
  margin-bottom: 60px;
}

ul,
li {
  list-style: none;
}

.pnkz {
  margin: 15px 0 60px;
}

.pnkz ul {
  width: 100%;
  display: flex;
}

.pnkz li:nth-child(1):after {
  content: '>';
  margin: 0 8px;
}

.pnkz li:nth-child(2) {
  color: #5E68AF;
}

.m-h2 {
  color: #5E68AF;
  text-align: center;
  font-size: 40px;
  font-weight: normal;
  margin-bottom: 40px;
}

.m-h2::after {
  content: '';
  display: block;
  width: 270px;
  height: 2px;
  margin: 0 auto;
  background-color: #E75297;
}

/*FV下バナー*/
.point3box {
  background-color: transparent;
  margin: 70px 0;
  padding: 0;
}

.point3 {
  position: relative;
  top: 0;
}

/* ------------------ */
/* 202412 改修 */
.priceSection__wrap {
  justify-items: center;
  word-break: auto-phrase;
  font-size: 15px;
}

.priceSection__wrap section {
  max-width: 1200px;
  margin-bottom: 100px;
  font-weight: 400;
}

.priceService {
  place-items: center;
}

.serviceWrapper {
  max-width: 1200px;
  display: flex;
  flex-direction: column;
}

.serviceList__top,
.serviceList__bottom {
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
  padding: 0;
  margin-bottom: 60px;
  gap: 24px;
}

.serviceCard {
  text-align: center;
  line-height: 1.4;
}

.serviceCard img {
  width: 100%;
  height: auto;
  background: #eee;
  margin-bottom: 8px;
}

.serviceCard p {
  font-size: 18px;
}

.priceRerquest {
  text-align: center;
}

.priceRerquest h3 {
  font-size: 22px;
  margin-bottom: 60px;
}

.priceRerquest span {
  color: #e55195;
}

.requestAnswer {
  font-size: 24px;
}

.requestList {
  display: flex;
  max-width: 1200px;
  justify-content: center;
  flex-wrap: wrap;
  gap: 24px;
  margin-bottom: 1em;
}

.requestItem {
  width: 384px;
  border: 1px solid #b9b9b9;
}

.requestItem h4 {
  font-size: 18px;
  color: #fff;
  background: #e55195;
  padding: 10px 0;
  margin-bottom: 0;
}

.requestItem p {
  font-size: 18px;
  padding: 22px 0;
  font-weight:400;
}

.requestItem p span {
  font-size: 22px;
}

.requestNote__wrapper {
  text-align: left;
  margin-left: 1em;
}

.requestNote__wrapper small {
  font-size: 14px;
  margin-left: -1em;
}

.requestNote__wrapper small::before{
  content: '※';
}

.priceCource {
  /* text-align: center; */
  justify-items: center;
}

.priceCource h3 {
  align-content: center;
}

.priceCource h3,
 .priceCource p {
  text-align: center;
}

.dietDiscription {
  font-size: 18px;
}

.dietDiscription span,
.membershipDiscription span {
  background: #EFDADC;
}

.recommendList {
  font-size: 18px;
  justify-self: center;
  margin-bottom: 64px;
  word-break: break-all;
  margin-left: 1em;
}

.recommendList li::before {
  content: "・";
  margin-left: -1em;
}

.courceContent {
  max-width: 960px;
}

.courceDetail {
  display: flex;
  border: 1px solid #b9b9b9;
  text-align: center;
  max-width: 960px;
  width: 90vw;
}

/* 税込価格 の箇所 */
.courceDetail + small {
  font-size: 14px !important;
}

.membershipPlan .courceDetail:not(:nth-child(3)) {
  margin-bottom: 10px;
}

.membershipDiscription {
  font-size: 18px;
}

.detailTitle {
  font-size: 18px;
  font-weight: 500;
  color: #fff;
  background: #5e68af;
  width: 100%;
  height: 90px;
  max-width: 370px;
}

.detailPrice {
  font-size: 18px;
  align-content: center;
  padding: 0 24px;
  margin: auto;
  width: 100%;
  height: 90px;
  max-width: 590px;
}

.detailPrice span{
  color: #5e68af;
  font-size: 24px;
}

.courceContent small, .otherPlan small {
  display: block;
  text-align: right;
  font-size: 13px;
}

.detailPrice small {
  font-size: 14px;
  display: inline;
}

.courceBonus {
  color: #5e68af;
}

.bonusTitle {
  font-size: 18px;
  font-weight: 500;
  text-align: left !important;
}

.bonusList {
  display: flex;
  flex-wrap: wrap;
  max-width: 660px;
  gap: 6px;
  margin-bottom: 64px;
}

.bounsItem {
  padding: 4px 8px;
  border: 1px solid #bbc0e0;
}

@media screen and (max-width: 1200px) {
  .serviceList__top,
  .serviceList__bottom {
    margin-bottom: 24px;
    gap: 58px;
    padding: 0px 10vw;
    flex-wrap: wrap;
  }

  .requestList,
  .requestNote__wrapper {
    padding: 0 22vw;
  }
}

@media screen and (max-width: 768px) {
  .serviceList__top,
  .serviceList__bottom {
    padding: 0px 24px;
    margin-bottom: 24px;
  }

  .priceService {
    margin-bottom: 16px !important;
  }

  .priceRerquest ,.priceCource {
    padding: 0 86px; /* 変わらない場合、 .detailPrice の vw を調整 */
  }

  .courceDetail {
    display: block;
    width: 100%;
  }

  .requestList,
  .requestNote__wrapper {
    padding: 0;
  }

  .requestItem {
    width: 100%;
  }

  .detailTitle {
    max-width: 100%;
  }

  .detailPrice {
    width: 74vw;
  }
}

@media screen and (max-width: 599px) {
  .priceRerquest ,.priceCource {
    padding: 0 24px; /* 変わらない場合、 .detailPrice の vw を調整 */
  }
  .detailPrice {
    width: 88vw;
  }
}

/*-----------------------------------------------------------------------------------------*/
/*改修*/
/* .priceService .priceOther {
display: flex;
gap: 40px;
justify-content: center;
margin: 0 0 100px 0;
}
.priceService .priceOther li {
text-align: center;
background: linear-gradient(45deg, #df007e, #641783);
color: #fff;
height: 220px;
width: 220px;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
border-radius: 110px;
}
.priceService .priceOther li h3 {
position: relative;
padding: 0 0 10px 0;
margin: 0 0 10px 0;
}
.priceService .priceOther li h3::after {
content: '';
position: absolute;
bottom: 0;
left: 50%;
transform: translateX(-50%);
width: 50px;
height: 2px;
display: block;
background-color: #fff;
}
.priceInner p {
font-size: 24px;
}
.priceService .priceCommon {
display: flex;
gap: 40px;
margin: 0 0 100px 0;
justify-content: center;
align-items: center;
}
.priceService .priceCommon li {
max-width: 400px;
width: 100%;
text-align: center;
height: 150px;
display: flex;
justify-content: center;
align-items: center;
color: #fff;
position: relative;
filter: grayscale(100%);
}
.priceService .priceCommon li p {
font-size: 20px;
z-index: 1;
font-weight: 600;
}
.priceService .priceCommon li::after {
content: '';
display: block;
position: absolute;
background-color: rgba(0, 0, 0, 0.7);
top: 0;
left: 0;
width: 100%;
height: 100%;
}
.priceService .priceCommon li:nth-child(1) {
background-image: url(../img/facilitiesImg01.png);
background-position: center;
}
.priceService .priceCommon li:nth-child(2) {
background-image: url(../img/facilitiesImg05.png);
background-position: center;
}
.priceService .priceCommon li:nth-child(3) {
background-image: url(../img/facilitiesImg03.png);
background-position: center;
}
.priceCourse {
margin: 0 0 100px 0;
}
.priceCourse .wrapper1200 {
max-width: 1000px;
}
.priceCourse h3 {
text-align: center;
border-bottom: dashed 1px #bfbfbf;
font-size: 40px;
color: #f21b77;
}
.priceCourse h3 img {
max-width: 90%;
}
.priceCourse ul li {
background-color: #fafafa;
padding: 40px;
border: solid 1px #bfbfbf;
margin: 0 0 50px 0;
}
.priceCourse ul li:last-child {
margin: 0;
}
.priceCourse table {
max-width: 1000px;
margin: 20px auto 0;
width: 100%;
}
.priceCourse table td {
border: solid 1px #525ca4;
padding: 10px;
font-size: 45px;
font-weight: 600;
text-align: center;
background-color: #fff;
}
.priceCourse table tr:first-child td {
background-color: #525ca4;
color: #fff;
border-right: solid 1px #fff;
}
.priceCourse table tr:first-child td:last-child {
border-right: solid 1px #525ca4;
}
.priceCourse p {
font-size: 30px;
}

@media screen and (max-width:768px) {
.priceService .priceOther {
  flex-direction: column;
  align-items: center;
  gap: 20px;
  margin: 0 0 50px 0;
}
.priceService .priceOther li {
  height: auto;
  width: 100%;
  max-width: 400px;
  border-radius: unset;
  padding: 10px 0;
}
.priceService .priceCommon {
  flex-direction: column;
  align-items: center;
  gap: 20px;
  margin: 0 0 50px 0;
}
.priceCourse ul li {
  padding: 20px;
}
.priceCourse table td {
  font-size: 20px;
}
.priceCourse p {
  font-size: 20px;
}
} */

/*ここまで*/
/*-----------------------------------------------------------------------------------------*/
/*2か月集中ダイエットコース*/
/* .course_2month{
margin-bottom: 40px;
}
.course_3month{
margin-bottom: 60px;
}
.sub_title{
font-size: 28px;
font-family: serif;
color: #E75297;
text-align: center;
margin-bottom: 15px;
}
.sub_title::before{
  content: '';
  width: 1px;
  height: 45px;
  background-color: #E75297;
  display: inline-block;
  transform: translate(-20px, 15px) rotate(-40deg);
}
.sub_title::after{
  content: '';
  width: 1px;
  height: 45px;
  background-color: #E75297;
  display: inline-block;
  transform: translate(20px, 15px) rotate(40deg);
}
.main_title{
  margin-bottom: 40px;
}
.main_title img{
  width: 100%;
}
.course_detail{
  width: 100%;
  margin-bottom: 40px;
}
.course_detail > ul{
  width: 100%;
  display: flex;
}
.course_detail > ul > li{
  width: 50%;
}
.course_detail > ul > li:nth-child(1){
  padding-right: 40px;
}
.course_detail > ul li img{
  width: 100%;
}
.course_detail > ul p{
  margin: 15px 0 30px;
}
.benefits{
  width: 100%;
  display: flex;
  flex-wrap: wrap;
}
.benefits li{
  width: 50%;
  margin-bottom: 15px;
  height: 65px;
}
.benefits li:nth-child(odd){
  padding-right: 8px;
}
.benefits li:nth-child(even){
  padding-left: 8px;
}
.benefits li img{
  width: 100%;
}
.benefits p{
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: bold;
  font-size: 16px;
  color: #fff;
  background-color: #8d95d4;
  margin: 0 !important;
  height: 100%;
}
.recommend{
  background-color: #d9eddc;
  padding: 50px 70px;
  margin-bottom: 50px;
}
.recommend .h2Design{
  font-size: 30px;
}
.recommend ul{
  width: 100%;
  display: flex;
  justify-content: space-between;
}
.recommend li{
  width: 20%;
}
.recommend li img{
  width: 100%;
}
.priceTable img{
  width: 100%;
}
.priceTable p{
  text-align: left;
  font-size: 13px;
} */

/*otnerDetail*/
/* .title_hikaku{
  font-size: 45px;
  text-align: center;
  color: #E75297;
}
.freeExperience{
  font-size: 45px;
  color: #E75297;
  text-align: center;
  margin-bottom: 15px;
}
.freeExperience ~ p span{
  font-weight: bold;
  font-size: 30px;
  display: inline-block;
  margin-bottom: 15px;
  background: linear-gradient(transparent 70%,#EFD4CD 0%);
}
.otnerDetailBox{
  width: 100%;
  text-align: center;
  margin-bottom: 80px;
}
.otnerDetailBox img{
  margin: 0 auto;
}
.hikaku img {
display: block;
}
.hikakuText {
margin-bottom: 80px;
}
.otnerDetailTitle{
  margin-bottom: 60px;
}
.otnerDetailTitle img{
  width: 100%;
}

.benefits_3point{
  width: 100%;
  display: flex;
  justify-content: space-between;
}
.benefits_3point li{
  width: 25%;
}
.benefits_3point li img{
  width: 100%;
}
.serviceDetail{
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.serviceDetail li{
  width: 32.5%;
  margin-bottom: 15px;
  height: 70px;
}
.serviceDetail p{
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: bold;
  font-size: 18px;
  color: #fff;
  background-color: #8d95d4;
  margin: 0 !important;
  height: 100%;
}
.productDetail{
  width: 75%;
  margin: 0 auto 60px;
  display: flex;
  text-align: left;
}
.productDetail li:nth-child(1){
  width: 35%;
  padding-right: 40px;
  display: flex;
  align-items: center;
}
.productDetail li:nth-child(2){
  width: 65%;
}
.productDetail li img{
  width: 100%;
}
.productName{
  font-size: 26px;
  border-bottom: 2px dashed #aaa;
  margin-bottom: 20px;
  padding-bottom: 8px;
}
.productName span{
  font-size: 20px;
}
.productPrice{
  margin-bottom: 20px;
}
.productPrice span{
  font-size: 24px;
}
#payInfo_text{
  width: 80%;
  margin: 0 auto;
  text-align: left;
  margin-bottom: 30px;
}
.payInfo{
  width: 80%;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}
.payInfo li{
  width: 31%;
}
.payInfo li img{
  width: 100%;
}
.payInfo li:nth-child(3) p{
  margin-top: 8px;
  font-size: 12px;
  text-align: left;
} */


/* @media screen and (max-width:768px){
  .container{
      width: 100%;
      padding: 0 10px;
  } */

  /*2か月集中ダイエットコース*/
  /* .course_2month{
      margin-bottom: 40px;
  }
  .course_3month{
      margin-bottom: 60px;
  }
  .sub_title{
      font-size: 26px;
      line-height: 1.5;
      position: relative;
  }
  .course_3month .sub_title::before{
      content: '';
      width: 1px;
      height: 70px;
      background-color: #E75297;
      display: inline-block;
      transform: rotate(-30deg);
      position: absolute;
      bottom: 0;
      left: 25px;
  }
  .course_3month .sub_title::after{
      content: '';
      width: 1px;
      height: 70px;
      background-color: #E75297;
      display: inline-block;
      transform: rotate(30deg);
      position: absolute;
      bottom: 0;
      right: 25px;
  }

  .course_detail > ul{
      display: block;
  }
  .course_detail > ul > li{
      width: 100%;
  }
  .course_detail > ul > li:nth-child(1){
      padding-right: 0;
  }
  .benefits li{
      width: 50%;
      margin-bottom: 10px;
  }
  .benefits li:nth-child(odd){
      padding-right: 5px;
  }
  .benefits li:nth-child(even){
      padding-left: 5px;
  }


  .recommend{
      padding: 50px 30px;
  }
  .recommend .h2Design{
      font-size: 28px;
  }
  .recommend ul{
      flex-wrap: wrap;
  }
  .recommend li{
      width: 47%;
  }
  .recommend li:nth-child(1),
  .recommend li:nth-child(2){
      margin-bottom: 15px;
  }
  .title_hikaku{
      font-size: 34px;
      text-align: center;
      color: #E75297;
  } */
  /*otnerDetail*/
/* .freeExperience {
      font-size: 34px;
      margin-bottom: 0px;
  }
  .freeExperience ~ p{
      text-align: left;
  }
  .freeExperience ~ p span{
      font-size: 20px;
  }
  .otnerDetailBox{
      width: 100%;
      text-align: center;
      margin-bottom: 80px;
  }
  .otnerDetailTitle{
      margin-bottom: 50px;
  }
  .otnerDetailTitle img{
      width: 100%;
  }

  .benefits_3point{
      display: block;
  }
  .benefits_3point li{
      width: 100%;
  }
  .benefits_3point li:nth-child(1),
  .benefits_3point li:nth-child(2){
      margin-bottom: 20px;
  }
  .serviceDetail{
      justify-content: space-around;
  }
  .serviceDetail li{
      width: 48%;
      margin-bottom: 8px;
  }
  .serviceDetail p{
      font-size: 17px;
  }
  .productDetail{
      width: 100%;
      padding: 0 20px;
      display: block;
  }
  .productDetail li:nth-child(1){
      width: 100%;
      padding-right: 0;
  }
  .productDetail li:nth-child(2){
      width: 100%;
  }

  .productName{
      font-size: 26px;
      border-bottom: 2px dashed #aaa;
      margin: 15px 0 20px;
      padding-bottom: 8px;
      line-height: 1.3;
  }
  .productPrice{
      margin-bottom: 20px;
  }
  .productPrice span{
      font-size: 24px;
  }
  #payInfo_text{
      width: 100%;
      margin: 0 auto;
      padding: 0 20px;
      text-align: left;
      margin-bottom: 30px;
  }
  .payInfo{
      width: 100%;
      margin: 0 auto;
      padding: 0 20px;
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
  }
  .payInfo li{
      width: 100%;
      margin-bottom: 15px;
  } */
